| 1 | SPNPRT07 ;HIRMFO/WAA- PRINT Possible Reg. Based on D/C ;10/25/96  11:30 | 
|---|
| 2 | ;;2.0;Spinal Cord Dysfunction;**11,13**;01/02/1997 | 
|---|
| 3 | ;; | 
|---|
| 4 | EN1 ; Main Entry Point | 
|---|
| 5 | N SPNLEXIT,SPNIO,SPNPAGE,SPNDATE,SPNEDAT S SPNPAGE=1 | 
|---|
| 6 | S SPNLEXIT=0 | 
|---|
| 7 | S SPNA="   Enter START Date: " | 
|---|
| 8 | S SPNQ=" Enter the earliest date of Discharge for the print to START with." | 
|---|
| 9 | D QUEST^SPNPRT04("DA^:NOW:EP",SPNA,SPNQ) Q:SPNLEXIT | 
|---|
| 10 | S SPNDATE=Y | 
|---|
| 11 | S ZTSAVE("SPN*")="" | 
|---|
| 12 | S SPNA="   Enter END Date: " | 
|---|
| 13 | S SPNQ=" Enter the latest date of Discharge for the print to END with." | 
|---|
| 14 | D QUEST^SPNPRT04("DA^"_SPNDATE_":NOW:EP",SPNA,SPNQ) Q:SPNLEXIT | 
|---|
| 15 | S SPNEDAT=Y | 
|---|
| 16 | D DEVICE^SPNPRTMT("PRINT^SPNPRT07","SCD/SCI Discharges Patients",.ZTSAVE) Q:SPNLEXIT | 
|---|
| 17 | I SPNIO="Q" D EXIT Q  ; Print was Queued | 
|---|
| 18 | I IO'="" D PRINT D EXIT Q  ; Print was not Queued | 
|---|
| 19 | Q | 
|---|
| 20 | EXIT ; Exit routine | 
|---|
| 21 | K ^TMP($J,"SPN"),^TMP($J,"SPNPRT","AUTO"),^TMP($J,"SPNPRT","POST") | 
|---|
| 22 | K SPNDATE | 
|---|
| 23 | Q | 
|---|
| 24 | PRINT ; Print main Body | 
|---|
| 25 | U IO | 
|---|
| 26 | K ^TMP($J,"SPN") | 
|---|
| 27 | S SPNLEXIT=$G(SPNLEXIT,0) ; Ensure that the exit is set | 
|---|
| 28 | N SPNDFN,SPNX,SPNFAC | 
|---|
| 29 | S (SPNDFN,SPNLPRT,SPNFAC)=0 | 
|---|
| 30 | S SPNQDAT=SPNDATE-.000001 | 
|---|
| 31 | Q:SPNLEXIT | 
|---|
| 32 | F  S SPNQDAT=$O(^DGPM("AMV3",SPNQDAT)) Q:(SPNQDAT<1)  Q:(SPNQDAT>SPNEDAT)  D  Q:SPNLEXIT | 
|---|
| 33 | . S SPNDFN=0 | 
|---|
| 34 | . F  S SPNDFN=$O(^DGPM("AMV3",SPNQDAT,SPNDFN)) Q:SPNDFN<1  D  Q:SPNLEXIT | 
|---|
| 35 | .. S SPNIEN=0 F  S SPNIEN=$O(^DGPM("AMV3",SPNQDAT,SPNDFN,SPNIEN)) Q:SPNIEN<1  D  Q:SPNLEXIT | 
|---|
| 36 | ... N DFN,SPNLINE,SPNLOS | 
|---|
| 37 | ... I '$D(^SPNL(154,SPNDFN,0)),'(+$$GET1^DIQ(2,SPNDFN,57.4,"I")) Q | 
|---|
| 38 | ... S DFN=SPNDFN,VAIP("E")=SPNIEN D IN5^VADPT | 
|---|
| 39 | ... S SPNLOS=$$FMDIFF^XLFDT(SPNQDAT,$P(VAIP(15,1),U)) ; LENGTH OF STAY | 
|---|
| 40 | ... ; SPNLINE=Movement date(E)^pointer to PTF(I)^Length of Stay | 
|---|
| 41 | ... ;         ^Ward location(E)^D/C date | 
|---|
| 42 | ... S SPNLINE=$P(VAIP(15,1),U)_U_VAIP(12)_U_SPNLOS_U_$P(VAIP(5),U,2)_U_SPNQDAT | 
|---|
| 43 | ... S ^TMP($J,"SPN",$$GET1^DIQ(2,SPNDFN,.01,"E"),SPNDFN,SPNIEN)=SPNLINE | 
|---|
| 44 | ... D KVAR^VADPT | 
|---|
| 45 | ... Q | 
|---|
| 46 | .. Q | 
|---|
| 47 | . Q | 
|---|
| 48 | I $D(^TMP($J,"SPN")) D  Q:SPNLEXIT  ; Indicates the report had data | 
|---|
| 49 | . N SPNSTATE,SPNDFN,SPNNAME,SPNCOU | 
|---|
| 50 | . S SPNCOU=0 | 
|---|
| 51 | . S SPNNAME="" F  S SPNNAME=$O(^TMP($J,"SPN",SPNNAME)) Q:SPNNAME=""  D  Q:SPNLEXIT | 
|---|
| 52 | .. S SPNDFN=0 F  S SPNDFN=$O(^TMP($J,"SPN",SPNNAME,SPNDFN)) Q:SPNDFN<1  D NEWPAT(SPNDFN) Q:SPNLEXIT  D  Q:SPNLEXIT  W ! | 
|---|
| 53 | ... S SPNIEN=0 F  S SPNIEN=$O(^TMP($J,"SPN",SPNNAME,SPNDFN,SPNIEN)) Q:SPNIEN<1  D  Q:SPNLEXIT | 
|---|
| 54 | .... S SPNLINE=^TMP($J,"SPN",SPNNAME,SPNDFN,SPNIEN) | 
|---|
| 55 | ... D HEAD Q:SPNLEXIT | 
|---|
| 56 | ... D PATIENT(SPNDFN,SPNLINE) Q:SPNLEXIT | 
|---|
| 57 | ... Q | 
|---|
| 58 | .. Q | 
|---|
| 59 | .I SPNCOU D | 
|---|
| 60 | .. W !,?15,SPNCOU," Patients have been processed." | 
|---|
| 61 | .. I SPNFAC D RECFAC | 
|---|
| 62 | .. Q | 
|---|
| 63 | . Q | 
|---|
| 64 | E  W !,"     ******* No Data for this report. *******" | 
|---|
| 65 | I $E(IOST,1)="C" N DIR S DIR(0)="E" D ^DIR  K Y | 
|---|
| 66 | D CLOSE^SPNPRTMT | 
|---|
| 67 | K ^TMP($J,"SPN") | 
|---|
| 68 | Q | 
|---|
| 69 | RECFAC ; Print out a frequency table for receiving facilities | 
|---|
| 70 | S SPNPAGE=1 | 
|---|
| 71 | N SPNFACN | 
|---|
| 72 | S SPNFACN=0 | 
|---|
| 73 | F  S SPNFACN=$O(SPNFAC(SPNFACN)) Q:SPNFACN<1  D  Q:SPNLEXIT | 
|---|
| 74 | . N SPNIEN | 
|---|
| 75 | . S SPNIEN=0 | 
|---|
| 76 | . F  S SPNIEN=$O(^DIC(4,"D",SPNFACN,SPNIEN)) Q:SPNIEN<1  D  Q:SPNLEXIT | 
|---|
| 77 | .. Q:$G(^DIC(4,SPNIEN,0))="" | 
|---|
| 78 | .. D HEAD2 Q:SPNLEXIT | 
|---|
| 79 | .. W !,?8,"| ",$E($$GET1^DIQ(4,SPNIEN,.01,"E"),1,40),?46,"| ",SPNFACN,?59,"| ",SPNFAC(SPNFACN),?72,"|" | 
|---|
| 80 | .. W !,?8,$$REPEAT^XLFSTR("-",65) ; Last Line in table | 
|---|
| 81 | .. Q | 
|---|
| 82 | . Q | 
|---|
| 83 | Q | 
|---|
| 84 | NEWPAT(SPNDFN) ; New patient to print | 
|---|
| 85 | D HEAD Q:SPNLEXIT | 
|---|
| 86 | N DFN | 
|---|
| 87 | S DFN=SPNDFN D DEM^VADPT | 
|---|
| 88 | W !!,"  Patient: ",$E(VADM(1),1,25),?38,"SSN: ",$P(VADM(2),U),?56,"SCI: ",$E($$GET1^DIQ(2,SPNDFN,57.4,"E"),1,23) | 
|---|
| 89 | D KVAR^VADPT | 
|---|
| 90 | S SPNCOU=SPNCOU+1 | 
|---|
| 91 | I '$D(^SPNL(154,SPNDFN,0)) Q | 
|---|
| 92 | I $O(^SPNL(154,SPNDFN,"E",0))<1 Q | 
|---|
| 93 | N SPNETI,SPNDFLG | 
|---|
| 94 | S (SPNETI,SPNDFLG)=0 W !,"  Etiology: " | 
|---|
| 95 | F  S SPNETI=$O(^SPNL(154,SPNDFN,"E",SPNETI)) Q:SPNETI<1  D  Q:SPNLEXIT | 
|---|
| 96 | .N SPNETO | 
|---|
| 97 | .S SPNETO=$P($G(^SPNL(154,SPNDFN,"E",SPNETI,0)),U) Q:SPNETO="" | 
|---|
| 98 | .I $X>13 D HEAD Q:SPNLEXIT  W ! | 
|---|
| 99 | .W ?12,$E($$GET^DDSVAL(154.03,SPNETO,.01,"","E"),1,30) | 
|---|
| 100 | .I 'SPNDFLG W ?45,"Registration Date: ",$$FMTE^XLFDT($P($G(^SPNL(154,SPNDFN,0)),U,2),"2D") S SPNDFLG=1 | 
|---|
| 101 | .Q | 
|---|
| 102 | Q | 
|---|
| 103 | PATIENT(SPNDFN,SPNLINE) ; Print Patient data | 
|---|
| 104 | ; SPNLINE=Movement date(I)^pointer to PTF(I)^Length of Stay | 
|---|
| 105 | ;         ^Ward location(E)^D/C Date | 
|---|
| 106 | ; SPNLINE=$P(VAIP(15,1),U,2)_U_VAIP(12)_U_SPNLOS_U_$P(VAIP(5),U,2)_U_SPNQDAT | 
|---|
| 107 | Q:SPNLEXIT | 
|---|
| 108 | W !,$$FMTE^XLFDT($P(SPNLINE,U,5),"2D"),?11,$P(SPNLINE,U,3) | 
|---|
| 109 | W ?16,$E($P(SPNLINE,U,4),1,28) | 
|---|
| 110 | Q:$P(SPNLINE,U,2)="" | 
|---|
| 111 | N SPNODE,SPNNODE | 
|---|
| 112 | S SPNNODE=$G(^DGPT($P(SPNLINE,U,2),70)) Q:SPNNODE="" | 
|---|
| 113 | I $P(SPNNODE,U,12)?1N.N S SPNFAC=SPNFAC+1,SPNFAC($P(SPNNODE,U,12))=$G(SPNFAC($P(SPNNODE,U,12)))+1 ; Collect Receiving Facility | 
|---|
| 114 | N SPNY | 
|---|
| 115 | F SPNODE=10,16:1:24 D  Q:SPNLEXIT | 
|---|
| 116 | .S SPNY=$P(SPNNODE,U,SPNODE) | 
|---|
| 117 | .I SPNY'>0 Q | 
|---|
| 118 | .I $G(^ICD9(SPNY,0))="" Q | 
|---|
| 119 | .I $X>50 D HEAD Q:SPNLEXIT  W ! | 
|---|
| 120 | .W ?50,$E($$GET1^DIQ(80,SPNY,3,"E"),1,29) | 
|---|
| 121 | .Q | 
|---|
| 122 | I '$D(^SPNL(154,SPNDFN,0)) W !?2,"*** NOT IN THE REGISTRY ! ***" | 
|---|
| 123 | Q | 
|---|
| 124 | HEAD ; Header Print | 
|---|
| 125 | I SPNPAGE'=1 Q:$Y<(IOSL-4) | 
|---|
| 126 | I $E(IOST,1)="C" D  Q:SPNLEXIT | 
|---|
| 127 | .I SPNPAGE=1 W @IOF Q | 
|---|
| 128 | .I SPNPAGE'=1 D  Q:SPNLEXIT | 
|---|
| 129 | ..N DIR S DIR(0)="E" D ^DIR I 'Y S SPNLEXIT=1 | 
|---|
| 130 | ..K Y | 
|---|
| 131 | ..Q | 
|---|
| 132 | .Q | 
|---|
| 133 | Q:SPNLEXIT | 
|---|
| 134 | I SPNPAGE'=1 W @IOF | 
|---|
| 135 | W !,$$FMTE^XLFDT($$NOW^XLFDT,1),?70,"Page: ",SPNPAGE | 
|---|
| 136 | W !!,?27,"SCD/SCI Discharge Patients" | 
|---|
| 137 | W !,?27,"From: ",$$FMTE^XLFDT(SPNDATE,"2D")," to: ",$$FMTE^XLFDT(SPNEDAT,"2D") | 
|---|
| 138 | W !!,"Date D/C",?11,"LOS",?16,"D/C Location",?50,"Diagnosis Codes" | 
|---|
| 139 | W !,$$REPEAT^XLFSTR("-",79) | 
|---|
| 140 | S SPNPAGE=SPNPAGE+1 | 
|---|
| 141 | I $D(ZTQUEUED) S:$$STPCK^SPNPRTMT SPNLEXIT=1 | 
|---|
| 142 | Q | 
|---|
| 143 | HEAD2 ; Header Print | 
|---|
| 144 | I SPNPAGE'=1 Q:$Y<(IOSL-4) | 
|---|
| 145 | I $E(IOST,1)="C" D  Q:SPNLEXIT | 
|---|
| 146 | .I SPNPAGE=1 W @IOF Q | 
|---|
| 147 | .I SPNPAGE'=1 D  Q:SPNLEXIT | 
|---|
| 148 | ..N DIR S DIR(0)="E" D ^DIR I 'Y S SPNLEXIT=1 | 
|---|
| 149 | ..K Y | 
|---|
| 150 | ..Q | 
|---|
| 151 | .Q | 
|---|
| 152 | Q:SPNLEXIT | 
|---|
| 153 | W @IOF | 
|---|
| 154 | W !,$$FMTE^XLFDT($$NOW^XLFDT,1),?70,"Page: ",SPNPAGE | 
|---|
| 155 | W !!,?27,"SCD/SCI Discharges Patients" | 
|---|
| 156 | W !,?20,"Frequency Table of Discharge Destination" | 
|---|
| 157 | W !!,?9,"Facility",?47,"Station #",?60,"Total" | 
|---|
| 158 | W !,?8,$$REPEAT^XLFSTR("-",65) ; first Line in table | 
|---|
| 159 | S SPNPAGE=SPNPAGE+1 | 
|---|
| 160 | I $D(ZTQUEUED) S:$$STPCK^SPNPRTMT SPNLEXIT=1 | 
|---|
| 161 | Q | 
|---|