| 1 | ORWRP16 ; ALB/MJK Report Calls - 16bit ;5/22/97  19:13
 | 
|---|
| 2 |  ;;3.0;ORDER ENTRY/RESULTS REPORTING;;Dec 17, 1997
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | LIST(ROOT) ; -- return lists for list boxes
 | 
|---|
| 5 |  ;  RPC: ORWRP REPORT LIST
 | 
|---|
| 6 |  ;  See RPC definition for details on input and output parameters
 | 
|---|
| 7 |  ;
 | 
|---|
| 8 |  N EOF
 | 
|---|
| 9 |  S EOF="$$END",ROOT=$NA(^TMP($J,"ORPTLIST"))
 | 
|---|
| 10 |  K @ROOT
 | 
|---|
| 11 |  ;
 | 
|---|
| 12 |  ; -- get list of reports
 | 
|---|
| 13 |  D GETRPTS(.ROOT,.EOF)
 | 
|---|
| 14 |  ; -- get list of health summary types
 | 
|---|
| 15 |  D GETHS(.ROOT,.EOF)
 | 
|---|
| 16 |  ; -- get list of date ranges
 | 
|---|
| 17 |  D GETDT(.ROOT,.EOF)
 | 
|---|
| 18 |  ;
 | 
|---|
| 19 |  Q
 | 
|---|
| 20 |  ;
 | 
|---|
| 21 | GETRPTS(ROOT,EOF) ;  -- get list of reports
 | 
|---|
| 22 |  N I,X
 | 
|---|
| 23 |  D SETITEM(.ROOT,"[REPORT LIST]")
 | 
|---|
| 24 |  F I=2:1 S X=$P($T(RPTLIST+I),";",3) D SETITEM(.ROOT,X) Q:X=EOF
 | 
|---|
| 25 |  Q
 | 
|---|
| 26 |  ;
 | 
|---|
| 27 | RPTLIST ; -- list of reports
 | 
|---|
| 28 |  ;<ID> ^ <report name> ^ <ask date range> ^ <ask health summary type> ^ <right margin>
 | 
|---|
| 29 |  ;;1^Health Summary^N^Y^80
 | 
|---|
| 30 |  ;;2^Blood Bank Report^N^N^80
 | 
|---|
| 31 |  ;;3^Anatomic Path Report^N^N^80
 | 
|---|
| 32 |  ;;4^Dietetics Profile^N^N^80
 | 
|---|
| 33 |  ;;5^Vitals Cumulative^Y^N^132
 | 
|---|
| 34 |  ;;6^Vitals SF511^Y^N^132
 | 
|---|
| 35 |  ;;$$END
 | 
|---|
| 36 |  ;
 | 
|---|
| 37 | GETHS(ROOT,EOF) ; --get list of health summary types
 | 
|---|
| 38 |  N I,HSPARM
 | 
|---|
| 39 |  D GETLST^XPAR(.HSPARM,"SYS","ORWRP HEALTH SUMMARY TYPE LIST","N")
 | 
|---|
| 40 |  ;
 | 
|---|
| 41 |  D SETITEM(.ROOT,"[HEALTH SUMMARY TYPES]")
 | 
|---|
| 42 |  S I=0  F  S I=$O(HSPARM(I)) Q:'I  D SETITEM(.ROOT,HSPARM(I))
 | 
|---|
| 43 |  D SETITEM(.ROOT,EOF)
 | 
|---|
| 44 |  Q
 | 
|---|
| 45 |  ;
 | 
|---|
| 46 | GETDT(ROOT,EOF) ; -- get date range choices
 | 
|---|
| 47 |  N I,X
 | 
|---|
| 48 |  D SETITEM(.ROOT,"[DATE RANGES]")
 | 
|---|
| 49 |  F I=2:1 S X=$P($T(DTLIST+I),";",3) D SETITEM(.ROOT,X) Q:X=EOF
 | 
|---|
| 50 |  Q
 | 
|---|
| 51 |  ;
 | 
|---|
| 52 | DTLIST ; -- list of date ranges
 | 
|---|
| 53 |  ;<number of days>^ <display text>
 | 
|---|
| 54 |  ;;0^Today
 | 
|---|
| 55 |  ;;7^One Week Back
 | 
|---|
| 56 |  ;;14^Two Weeks Back
 | 
|---|
| 57 |  ;;30^One Month Back
 | 
|---|
| 58 |  ;;180^Six Months Back
 | 
|---|
| 59 |  ;;365^One Year Back
 | 
|---|
| 60 |  ;;$$END
 | 
|---|
| 61 |  ;
 | 
|---|
| 62 | SETITEM(ROOT,X) ; -- set item in list
 | 
|---|
| 63 |  S @ROOT@($O(@ROOT@(9999),-1)+1)=X
 | 
|---|
| 64 |  Q
 | 
|---|
| 65 |  ;
 | 
|---|
| 66 | RPT(ROOT,DFN,RPTID,HSTYPE,DTRANGE,SECTION) ; -- return report text
 | 
|---|
| 67 |  ;  RPC: ORWRP REPORT TEXT
 | 
|---|
| 68 |  ;  See RPC definition for details on input and output parameters
 | 
|---|
| 69 |  ;
 | 
|---|
| 70 |  IF $G(SECTION),$D(^TMP("ORDATA",$J,SECTION)) D  G RPTQ
 | 
|---|
| 71 |  . S ROOT=$NA(^TMP("ORDATA",$J,SECTION))
 | 
|---|
| 72 |  ;
 | 
|---|
| 73 |  ; -- init output global for close logic of WORKSTATION device
 | 
|---|
| 74 |  K ^TMP("ORDATA",$J)
 | 
|---|
| 75 |  S ROOT=$NA(^TMP("ORDATA",$J,1))
 | 
|---|
| 76 |  ;
 | 
|---|
| 77 |  ; -- get report text
 | 
|---|
| 78 |  IF RPTID=1 D HS(DFN,HSTYPE) G RPTQ
 | 
|---|
| 79 |  IF RPTID=2 D BL(DFN) G RPTQ
 | 
|---|
| 80 |  IF RPTID=3 D PATH(DFN) G RPTQ
 | 
|---|
| 81 |  IF RPTID=4 D DIET(.ROOT,DFN) G RPTQ
 | 
|---|
| 82 |  IF RPTID=5 D VITALS(DFN,DTRANGE,"VITCUM") G RPTQ
 | 
|---|
| 83 |  IF RPTID=6 D VITALS(DFN,DTRANGE,"VIT511") G RPTQ
 | 
|---|
| 84 |  ;
 | 
|---|
| 85 |  ; -- basic report if id not found above
 | 
|---|
| 86 |  D NOTYET(.ROOT)
 | 
|---|
| 87 | RPTQ Q
 | 
|---|
| 88 |  ;
 | 
|---|
| 89 | HS(ORDFN,ORHS) ; - get health summary report
 | 
|---|
| 90 |  N ZTQUEUED,ORRM,ORHFS,ORSUB,ORIO
 | 
|---|
| 91 |  S ORRM=80,ORHFS=$$HFS(),ORSUB="ORDATA"
 | 
|---|
| 92 |  D OPEN(.ORRM,.ORHFS,"W",.ORIO)
 | 
|---|
| 93 |  ;
 | 
|---|
| 94 |  D HSB(.ORDFN,.ORHS)
 | 
|---|
| 95 |  ;
 | 
|---|
| 96 |  D CLOSE(.ORRM,.ORHFS,.ORSUB,.ORIO)
 | 
|---|
| 97 |  Q
 | 
|---|
| 98 |  ;
 | 
|---|
| 99 | HSB(ORDFN,ORHS) ; - build health summary report
 | 
|---|
| 100 |  N ORVP,GMTYP,Y
 | 
|---|
| 101 |  S ORVP=ORDFN_";DPT("
 | 
|---|
| 102 |  S Y=$P($G(^GMT(142,+ORHS,0)),U)
 | 
|---|
| 103 |  S GMTYP(0)=1,GMTYP(1)=+ORHS_U_Y_U_Y_U_Y
 | 
|---|
| 104 |  D PQ^ORPRS13
 | 
|---|
| 105 |  Q
 | 
|---|
| 106 |  ;
 | 
|---|
| 107 | BL(ORDFN) ; -- get blood bank report
 | 
|---|
| 108 |  N ZTQUEUED,ORRM,ORHFS,ORSUB,ORIO
 | 
|---|
| 109 |  S ORRM=80,ORHFS=$$HFS(),ORSUB="ORDATA"
 | 
|---|
| 110 |  D OPEN(.ORRM,.ORHFS,"W",.ORIO)
 | 
|---|
| 111 |  ;
 | 
|---|
| 112 |  D BLB(.ORDFN)
 | 
|---|
| 113 |  ;
 | 
|---|
| 114 |  D CLOSE(.ORRM,.ORHFS,.ORSUB,.ORIO)
 | 
|---|
| 115 |  Q
 | 
|---|
| 116 |  ; 
 | 
|---|
| 117 | BLB(ORDFN) ; -- build blood bank report
 | 
|---|
| 118 |  N DFN
 | 
|---|
| 119 |  ;
 | 
|---|
| 120 |  D SET^LRBLPD1
 | 
|---|
| 121 |  IF $G(OREND)'=1 D
 | 
|---|
| 122 |  . S DFN=ORDFN
 | 
|---|
| 123 |  . D OERR^LRBLPD1
 | 
|---|
| 124 |  . D CLEAN^LRBLPD1
 | 
|---|
| 125 |  Q
 | 
|---|
| 126 |  ; 
 | 
|---|
| 127 | PATH(ORDFN) ; -- get anatomic path report
 | 
|---|
| 128 |  N ZTQUEUED,ORRM,ORHFS,ORSUB,ORIO
 | 
|---|
| 129 |  S ORRM=80,ORHFS=$$HFS(),ORSUB="ORDATA"
 | 
|---|
| 130 |  D OPEN(.ORRM,.ORHFS,"W",.ORIO)
 | 
|---|
| 131 |  ;
 | 
|---|
| 132 |  D PATHB(.ORDFN)
 | 
|---|
| 133 |  ;
 | 
|---|
| 134 |  D CLOSE(.ORRM,.ORHFS,.ORSUB,.ORIO)
 | 
|---|
| 135 |  Q
 | 
|---|
| 136 |  ;
 | 
|---|
| 137 | PATHB(ORDFN) ; -- build anatomic path report
 | 
|---|
| 138 |  N DFN
 | 
|---|
| 139 |  ;
 | 
|---|
| 140 |  D SET^LRAPS3
 | 
|---|
| 141 |  IF $G(OREND)'=1 D
 | 
|---|
| 142 |  . S DFN=ORDFN
 | 
|---|
| 143 |  . D OERR^LRAPS3
 | 
|---|
| 144 |  . D CLEAN^LRAPS3
 | 
|---|
| 145 |  Q
 | 
|---|
| 146 |  ;
 | 
|---|
| 147 | DIET(ROOT,DFN) ; -- get dietetics profile
 | 
|---|
| 148 |  D NOTYET(.ROOT)
 | 
|---|
| 149 |  Q
 | 
|---|
| 150 |  ;
 | 
|---|
| 151 | DIETB(DFN) ; -- get dietetics profile
 | 
|---|
| 152 |  W !!,"Dietetics Profile not yet available."
 | 
|---|
| 153 |  Q
 | 
|---|
| 154 |  ;
 | 
|---|
| 155 | VITALS(DFN,DTRANGE,ORTAG) ; -- get vitals report
 | 
|---|
| 156 |  N ZTQUEUED,ORRM,ORHFS,ORSUB,ORIO
 | 
|---|
| 157 |  S ORRM=132,ORHFS=$$HFS(),ORSUB="ORDATA"
 | 
|---|
| 158 |  D OPEN(.ORRM,.ORHFS,"W",.ORIO)
 | 
|---|
| 159 |  ;
 | 
|---|
| 160 |  D VITALSB(.DFN,.DTRANGE,.ORTAG)
 | 
|---|
| 161 |  ;
 | 
|---|
| 162 |  D CLOSE(.ORRM,.ORHFS,.ORSUB,.ORIO)
 | 
|---|
| 163 |  Q
 | 
|---|
| 164 |  ;
 | 
|---|
| 165 | VITALSB(DFN,DTRANGE,ORTAG) ; -- build vitals report
 | 
|---|
| 166 |  N ORVP,XQORNOD,ORSSTRT,ORSSTOP
 | 
|---|
| 167 |  ;
 | 
|---|
| 168 |  S ORVP=DFN_";DPT(",XQORNOD=1
 | 
|---|
| 169 |  S X1=DT
 | 
|---|
| 170 |  ; -- if TODAY then do not substract 1
 | 
|---|
| 171 |  S X2=-$S(DTRANGE:DTRANGE-1,1:0)
 | 
|---|
| 172 |  D C^%DTC
 | 
|---|
| 173 |  S ORSSTRT(XQORNOD)=X-.7641,ORSSTOP(XQORNOD)=DT+.2359
 | 
|---|
| 174 |  D @ORTAG^ORPRS14
 | 
|---|
| 175 |  Q
 | 
|---|
| 176 |  ;
 | 
|---|
| 177 | NOTYET(ROOT) ; -- standard not available display text
 | 
|---|
| 178 |  D SETITEM(.ROOT,"Report not available at this time.")
 | 
|---|
| 179 |  S @ROOT@(.1)="1^1"
 | 
|---|
| 180 |  Q
 | 
|---|
| 181 |  ;
 | 
|---|
| 182 | HFS() ; -- get hfs file name
 | 
|---|
| 183 |  ; -- need to define better unique algorithm
 | 
|---|
| 184 |  Q "ORU_"_$J_".DAT"
 | 
|---|
| 185 |  ;
 | 
|---|
| 186 | OPEN(ORRM,ORHFS,ORMODE,ORIO) ; -- open WORKSTATION device
 | 
|---|
| 187 |  ;   ORRM: right margin
 | 
|---|
| 188 |  ;  ORHFS: host file name
 | 
|---|
| 189 |  ; ORMODE: open file in 'R'ead or 'W'rite mode
 | 
|---|
| 190 |  S ZTQUEUED="" K IOPAR
 | 
|---|
| 191 |  S IOP="WORKSTATION;"_$G(ORRM,80)
 | 
|---|
| 192 |  S %ZIS("HFSMODE")=ORMODE,%ZIS("HFSNAME")=ORHFS
 | 
|---|
| 193 |  D ^%ZIS K IOP,%ZIS
 | 
|---|
| 194 |  U IO S ORIO=IO
 | 
|---|
| 195 |  Q
 | 
|---|
| 196 |  ;
 | 
|---|
| 197 | CLOSE(ORRM,ORHFS,ORSUB,ORIO) ; -- close WORKSTATION device
 | 
|---|
| 198 |  ; ORSUB: unique subscript name for output 
 | 
|---|
| 199 |  IF IO=ORIO D ^%ZISC
 | 
|---|
| 200 |  U IO
 | 
|---|
| 201 |  D USEHFS
 | 
|---|
| 202 |  U IO
 | 
|---|
| 203 |  Q
 | 
|---|
| 204 | USEHFS ; -- use host file to build global array
 | 
|---|
| 205 |  N IO,OROK
 | 
|---|
| 206 |  ; D OPEN^%ZISH(ORSUB,"",ORHFS,"R") I POP Q
 | 
|---|
| 207 |  K ^TMP($J,"ORTMPLST")
 | 
|---|
| 208 |  S OROK=$$FTG^%ZISH(,ORHFS,$NA(^TMP($J,"ORTMPLST",1)),3)
 | 
|---|
| 209 |  D BUILD
 | 
|---|
| 210 |  K ^TMP($J,"ORTMPLST")
 | 
|---|
| 211 |  ; D CLOSE^%ZISH(ORSUB)
 | 
|---|
| 212 |  N ORARR S ORARR(ORHFS)=""
 | 
|---|
| 213 |  S OROK=$$DEL^%ZISH("",$NA(ORARR))
 | 
|---|
| 214 |  Q
 | 
|---|
| 215 |  ;
 | 
|---|
| 216 | BUILD ; -- build tmp global for report
 | 
|---|
| 217 |  N INC,CNT,MAX,SECTION,ROOT,STRIP,LN
 | 
|---|
| 218 |  S SECTION=0,MAX=20000,STRIP=$C(7,12)
 | 
|---|
| 219 |  D INIT
 | 
|---|
| 220 |  ; -- strip out ff's and quit on error
 | 
|---|
| 221 |  S LN=0 F  S LN=$O(^TMP($J,"ORTMPLST",LN)) Q:'LN  S X=^(LN) D
 | 
|---|
| 222 |  . ;F  U IO R X:5 D  Q:$$STATUS^%ZISH
 | 
|---|
| 223 |  . I (CNT+250)>MAX D INIT
 | 
|---|
| 224 |  . S X=$TR(X,STRIP,"")
 | 
|---|
| 225 |  . S INC=INC+1,@ROOT@(INC)=X
 | 
|---|
| 226 |  . S CNT=CNT+$L(X)
 | 
|---|
| 227 |  D FINAL
 | 
|---|
| 228 |  Q
 | 
|---|
| 229 |  ;
 | 
|---|
| 230 | INIT ; -- initialize counts and global section
 | 
|---|
| 231 |  S (INC,CNT)=0,SECTION=SECTION+1
 | 
|---|
| 232 |  S ROOT=$NA(^TMP(ORSUB,$J,SECTION))
 | 
|---|
| 233 |  K @ROOT
 | 
|---|
| 234 |  Q
 | 
|---|
| 235 |  ;
 | 
|---|
| 236 | FINAL ; -- set 'x of y' for each section
 | 
|---|
| 237 |  N I
 | 
|---|
| 238 |  F I=1:1:SECTION S ^TMP(ORSUB,$J,I,.1)=I_U_SECTION
 | 
|---|
| 239 |  Q
 | 
|---|
| 240 |  ;
 | 
|---|