| 1 | ORWGAPI2 ; SLC/STAFF - Graph API Items ;12/21/05  08:16
 | 
|---|
| 2 |  ;;3.0;ORDER ENTRY/RESULTS REPORTING;**215**;Dec 17, 1997
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | ADMITS(ITEMS,DFN,FMT,OLDEST,NEWEST,CNT,TMP) ; from ORWGAPIR
 | 
|---|
| 5 |  N DATE,DATE2,DISCH,LINE,LST,NUM,OK,RESULT K LST
 | 
|---|
| 6 |  K ^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 7 |  D ADMITLST^ORWPT(.LST,DFN)
 | 
|---|
| 8 |  S OK=0
 | 
|---|
| 9 |  S NUM=0
 | 
|---|
| 10 |  F  S NUM=$O(LST(NUM)) Q:NUM<1  D  Q:OK
 | 
|---|
| 11 |  . S LINE=LST(NUM)
 | 
|---|
| 12 |  . S DATE=$P(LINE,U)
 | 
|---|
| 13 |  . S DISCH=$P(LINE,U,5)
 | 
|---|
| 14 |  . S DATE2=$$DISCH^ORWGAPIA(DISCH)
 | 
|---|
| 15 |  . I DATE2="" S DATE2=DATE2\1
 | 
|---|
| 16 |  . I FMT=6 D  Q
 | 
|---|
| 17 |  .. I DATE>NEWEST Q
 | 
|---|
| 18 |  .. I DATE2>0,DATE2<OLDEST Q
 | 
|---|
| 19 |  .. I $D(^TMP("ORWGRPC TEMP",$J,"ADMIT")) Q
 | 
|---|
| 20 |  .. S ^TMP("ORWGRPC TEMP",$J,"ADMIT")=""
 | 
|---|
| 21 |  .. S CNT=CNT+1
 | 
|---|
| 22 |  .. S OK=1
 | 
|---|
| 23 |  .. S RESULT="405^ADMIT"
 | 
|---|
| 24 |  . I FMT=3 D  Q
 | 
|---|
| 25 |  .. I $D(^TMP("ORWGRPC TEMP",$J,"ADMIT")) Q
 | 
|---|
| 26 |  .. S ^TMP("ORWGRPC TEMP",$J,"ADMIT")=""
 | 
|---|
| 27 |  .. S CNT=CNT+1
 | 
|---|
| 28 |  .. S OK=1
 | 
|---|
| 29 |  .. S RESULT="405^ADMIT^^ADMIT^^"_DATE
 | 
|---|
| 30 |  . I FMT=0 D  Q
 | 
|---|
| 31 |  .. S ^TMP("ORWGRPC TEMP",$J,"ADMIT")=""
 | 
|---|
| 32 |  .. S CNT=CNT+1
 | 
|---|
| 33 |  .. S OK=1
 | 
|---|
| 34 |  .. S RESULT="405^ADMIT^ADMIT"
 | 
|---|
| 35 |  I OK D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 36 |  K ^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 37 |  Q
 | 
|---|
| 38 |  ;
 | 
|---|
| 39 | ADVERSE(ITEMS,DFN,FMT,OLDEST,NEWEST,CNT,TMP) ; from ORWGAPIR
 | 
|---|
| 40 |  N DATE,IEN,ITEM,RESULT
 | 
|---|
| 41 |  K ^TMP("ORWGRPC SORT",$J),^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 42 |  S IEN=0
 | 
|---|
| 43 |  F  S IEN=$O(^GMR(120.8,"B",DFN,IEN)) Q:IEN<1  D
 | 
|---|
| 44 |  . I '$D(^GMR(120.8,IEN,0)) Q
 | 
|---|
| 45 |  . I $G(^GMR(120.8,IEN,"ER")) Q
 | 
|---|
| 46 |  . I '$P(^GMR(120.8,IEN,0),U,12) Q
 | 
|---|
| 47 |  . S DATE=+$P($G(^GMR(120.8,IEN,0)),U,4) I 'DATE Q
 | 
|---|
| 48 |  . S ITEM=$P(^GMR(120.8,IEN,0),U,2) I '$L(ITEM) Q
 | 
|---|
| 49 |  . S ^TMP("ORWGRPC SORT",$J,DATE,ITEM)="" ;ADVERSE
 | 
|---|
| 50 |  I FMT=6 D
 | 
|---|
| 51 |  . S DATE=OLDEST
 | 
|---|
| 52 |  . F  S DATE=$O(^TMP("ORWGRPC SORT",$J,DATE)) Q:DATE<1  Q:DATE>NEWEST  D
 | 
|---|
| 53 |  .. S ITEM=""
 | 
|---|
| 54 |  .. F  S ITEM=$O(^TMP("ORWGRPC SORT",$J,DATE,ITEM)) Q:ITEM=""  D
 | 
|---|
| 55 |  ... I $D(^TMP("ORWGRPC TEMP",$J,ITEM)) Q
 | 
|---|
| 56 |  ... S ^TMP("ORWGRPC TEMP",$J,ITEM)=""
 | 
|---|
| 57 |  ... S CNT=CNT+1
 | 
|---|
| 58 |  ... S RESULT="120.8^"_ITEM
 | 
|---|
| 59 |  ... D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 60 |  I FMT'=6 D
 | 
|---|
| 61 |  . S DATE=0
 | 
|---|
| 62 |  . F  S DATE=$O(^TMP("ORWGRPC SORT",$J,DATE)) Q:DATE<1  D
 | 
|---|
| 63 |  .. S ITEM=""
 | 
|---|
| 64 |  .. F  S ITEM=$O(^TMP("ORWGRPC SORT",$J,DATE,ITEM)) Q:ITEM=""  D
 | 
|---|
| 65 |  ... I $D(^TMP("ORWGRPC TEMP",$J,ITEM)) Q
 | 
|---|
| 66 |  ... S ^TMP("ORWGRPC TEMP",$J,ITEM)=""
 | 
|---|
| 67 |  ... S CNT=CNT+1
 | 
|---|
| 68 |  ... I FMT=3 S RESULT="120.8^"_ITEM_"^^"_ITEM_"^^"_DATE
 | 
|---|
| 69 |  ... I FMT=0 S RESULT="120.8^"_ITEM_U_ITEM
 | 
|---|
| 70 |  ... D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 71 |  K ^TMP("ORWGRPC SORT",$J),^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 72 |  Q
 | 
|---|
| 73 |  ;
 | 
|---|
| 74 | PL(ITEMS,DFN,FMT,OLDEST,NEWEST,CNT,TMP) ; from ORWGAPIR
 | 
|---|
| 75 |  N DATE,ICD9,OK,PRIORITY,RESULT,STATUS
 | 
|---|
| 76 |  K ^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 77 |  S STATUS=""
 | 
|---|
| 78 |  F  S STATUS=$O(^PXRMINDX(9000011,"PSPI",DFN,STATUS)) Q:STATUS=""  D
 | 
|---|
| 79 |  . S PRIORITY=""
 | 
|---|
| 80 |  . F  S PRIORITY=$O(^PXRMINDX(9000011,"PSPI",DFN,STATUS,PRIORITY)) Q:PRIORITY=""  D
 | 
|---|
| 81 |  .. S ICD9=""
 | 
|---|
| 82 |  .. F  S ICD9=$O(^PXRMINDX(9000011,"PSPI",DFN,STATUS,PRIORITY,ICD9)) Q:ICD9=""  D
 | 
|---|
| 83 |  ... S OK=0
 | 
|---|
| 84 |  ... I FMT=6 D
 | 
|---|
| 85 |  .... S DATE=OLDEST
 | 
|---|
| 86 |  .... F  S DATE=$O(^PXRMINDX(9000011,"PSPI",DFN,STATUS,PRIORITY,ICD9,DATE)) Q:DATE=""  Q:DATE>NEWEST  D  Q:OK
 | 
|---|
| 87 |  ..... S CNT=CNT+1
 | 
|---|
| 88 |  ..... S OK=1
 | 
|---|
| 89 |  ..... S RESULT=9000011_U_ICD9
 | 
|---|
| 90 |  ... I FMT=3 D
 | 
|---|
| 91 |  .... S DATE=$O(^PXRMINDX(9000011,"PSPI",DFN,STATUS,PRIORITY,ICD9,""),-1)
 | 
|---|
| 92 |  .... I DATE S ^TMP("ORWGRPC TEMP",$J,ICD9,DATE)=""
 | 
|---|
| 93 |  ... I FMT=0 D
 | 
|---|
| 94 |  .... S CNT=CNT+1
 | 
|---|
| 95 |  .... S OK=1
 | 
|---|
| 96 |  .... S RESULT=9000011_U_ICD9_U_$$EVALUE^ORWGAPIU(ICD9,9000011,.01)
 | 
|---|
| 97 |  ... I OK D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 98 |  I FMT=3 D
 | 
|---|
| 99 |  . S ICD9=""
 | 
|---|
| 100 |  . F  S ICD9=$O(^TMP("ORWGRPC TEMP",$J,ICD9)) Q:ICD9=""  D
 | 
|---|
| 101 |  .. S DATE=$O(^TMP("ORWGRPC TEMP",$J,ICD9,""),-1)
 | 
|---|
| 102 |  .. I 'DATE Q
 | 
|---|
| 103 |  .. S CNT=CNT+1
 | 
|---|
| 104 |  .. S RESULT=9000011_U_ICD9_"^^"_$$EVALUE^ORWGAPIU(ICD9,9000011,.01)_"^^"_DATE
 | 
|---|
| 105 |  .. D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 106 |  K ^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 107 |  Q
 | 
|---|
| 108 |  ;
 | 
|---|
| 109 | PLX(ITEMS,DFN,FMT,OLDEST,NEWEST,CNT,TMP) ; from ORWGAPIR
 | 
|---|
| 110 |  D PLX2^ORWGAPID(.ITEMS,DFN,FMT,OLDEST,NEWEST,.CNT,.TMP)
 | 
|---|
| 111 |  Q
 | 
|---|
| 112 |  ;
 | 
|---|
| 113 | REG(ITEMS,DFN,FILE,FMT,OLDEST,NEWEST,CNT,TMP) ; from ORWGAPIR
 | 
|---|
| 114 |  N DATE,ICD,ITEM,NUM,OK,RESULT
 | 
|---|
| 115 |  K ^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 116 |  I $E(FILE,3,4)="DX" S ICD="ICD9"
 | 
|---|
| 117 |  I $E(FILE,3,4)="OP" S ICD="ICD0"
 | 
|---|
| 118 |  S NUM=""
 | 
|---|
| 119 |  F  S NUM=$O(^PXRMINDX(45,ICD,"PNI",DFN,NUM)) Q:NUM=""  D
 | 
|---|
| 120 |  . S ITEM=""
 | 
|---|
| 121 |  . F  S ITEM=$O(^PXRMINDX(45,ICD,"PNI",DFN,NUM,ITEM)) Q:ITEM=""  D
 | 
|---|
| 122 |  .. S OK=0
 | 
|---|
| 123 |  .. I FMT=6 D
 | 
|---|
| 124 |  ... S DATE=OLDEST
 | 
|---|
| 125 |  ... F  S DATE=$O(^PXRMINDX(45,ICD,"PNI",DFN,NUM,ITEM,DATE)) Q:DATE=""  Q:DATE>NEWEST  D  Q:OK
 | 
|---|
| 126 |  .... S CNT=CNT+1
 | 
|---|
| 127 |  .... S OK=1
 | 
|---|
| 128 |  .... S RESULT=FILE_U_ITEM
 | 
|---|
| 129 |  .. I FMT=3 D
 | 
|---|
| 130 |  ... S DATE=$O(^PXRMINDX(45,ICD,"PNI",DFN,NUM,ITEM,""),-1)
 | 
|---|
| 131 |  ... I DATE S ^TMP("ORWGRPC TEMP",$J,ITEM,DATE)=""
 | 
|---|
| 132 |  .. I FMT=0 D
 | 
|---|
| 133 |  ... S CNT=CNT+1
 | 
|---|
| 134 |  ... S OK=1
 | 
|---|
| 135 |  ... S RESULT=FILE_U_ITEM_U_$$EVALUE^ORWGAPIU(ITEM,45_";"_ICD,.01)
 | 
|---|
| 136 |  .. I OK D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 137 |  I FMT=3 D
 | 
|---|
| 138 |  . S ITEM=""
 | 
|---|
| 139 |  . F  S ITEM=$O(^TMP("ORWGRPC TEMP",$J,ITEM)) Q:ITEM=""  D
 | 
|---|
| 140 |  .. S DATE=$O(^TMP("ORWGRPC TEMP",$J,ITEM,""),-1)
 | 
|---|
| 141 |  .. I 'DATE Q
 | 
|---|
| 142 |  .. S CNT=CNT+1
 | 
|---|
| 143 |  .. S RESULT=FILE_U_ITEM_"^^"_$$EVALUE^ORWGAPIU(ITEM,45_";"_ICD,.01)_"^^"_DATE
 | 
|---|
| 144 |  .. D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 145 |  K ^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 146 |  Q
 | 
|---|
| 147 |  ;
 | 
|---|
| 148 | SURGERY(ITEMS,DFN,FMT,OLDEST,NEWEST,CNT,TMP) ; from ORWGAPIR
 | 
|---|
| 149 |  N CASE,DATE,PROC,RESULT,RESULTS,SURG,SURGPROC K SURG,SURGPROC
 | 
|---|
| 150 |  D SURG^ORWGAPIA(.SURG,DFN)
 | 
|---|
| 151 |  K SURG(0),SURG(1)
 | 
|---|
| 152 |  I FMT=6 D
 | 
|---|
| 153 |  . S CASE=0
 | 
|---|
| 154 |  . F  S CASE=$O(SURG(CASE)) Q:CASE<1  D
 | 
|---|
| 155 |  .. S RESULTS=SURG(CASE)
 | 
|---|
| 156 |  .. S PROC=$P(RESULTS,U,3)
 | 
|---|
| 157 |  .. I '$L(PROC) Q
 | 
|---|
| 158 |  .. S DATE=$P(RESULTS,U,5)
 | 
|---|
| 159 |  .. I DATE>NEWEST Q
 | 
|---|
| 160 |  .. I DATE<OLDEST Q
 | 
|---|
| 161 |  .. I $D(SURGPROC(PROC)) Q
 | 
|---|
| 162 |  .. S SURGPROC(PROC)=""
 | 
|---|
| 163 |  .. S CNT=CNT+1
 | 
|---|
| 164 |  .. S RESULT=130_U_PROC
 | 
|---|
| 165 |  .. D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 166 |  I FMT'=6 D
 | 
|---|
| 167 |  . S CASE=0
 | 
|---|
| 168 |  . F  S CASE=$O(SURG(CASE)) Q:CASE<1  D
 | 
|---|
| 169 |  .. S RESULTS=SURG(CASE)
 | 
|---|
| 170 |  .. S PROC=$P(RESULTS,U,3)
 | 
|---|
| 171 |  .. I '$L(PROC) Q
 | 
|---|
| 172 |  .. S SURGPROC(PROC)=RESULTS
 | 
|---|
| 173 |  . K SURG S PROC=""
 | 
|---|
| 174 |  . F  S PROC=$O(SURGPROC(PROC)) Q:PROC=""  D
 | 
|---|
| 175 |  .. S CNT=CNT+1
 | 
|---|
| 176 |  .. I FMT=3 S RESULT=130_U_PROC_"^^"_PROC_"^^"_$P(SURGPROC(PROC),U,5)
 | 
|---|
| 177 |  .. I FMT=0 S RESULT=130_U_PROC_U_PROC
 | 
|---|
| 178 |  .. D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 179 |  Q
 | 
|---|
| 180 |  ;
 | 
|---|
| 181 | TREAT(ITEMS,DFN,FMT,OLDEST,NEWEST,CNT,TMP) ; from ORWGAPIR ***** change to inverse dates
 | 
|---|
| 182 |  N DATE,IEN,ITEM,OLDEST1,RESULT
 | 
|---|
| 183 |  K ^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 184 |  I FMT=6 D
 | 
|---|
| 185 |  . S OLDEST1=9999999-OLDEST
 | 
|---|
| 186 |  . S DATE=9999999-NEWEST
 | 
|---|
| 187 |  . F  S DATE=$O(^AUPNVTRT("AA",DFN,DATE)) Q:DATE<1  Q:DATE>OLDEST1  D
 | 
|---|
| 188 |  .. S IEN=0
 | 
|---|
| 189 |  .. F  S IEN=$O(^AUPNVTRT("AA",DFN,DATE,IEN)) Q:IEN<1  D
 | 
|---|
| 190 |  ... S ITEM=+$G(^AUPNVTRT(IEN,0)) I 'ITEM Q
 | 
|---|
| 191 |  ... I $D(^TMP("ORWGRPC TEMP",$J,ITEM)) Q
 | 
|---|
| 192 |  ... S ^TMP("ORWGRPC TEMP",$J,ITEM)=""
 | 
|---|
| 193 |  ... S CNT=CNT+1
 | 
|---|
| 194 |  ... S RESULT="9000010.15^"_ITEM
 | 
|---|
| 195 |  ... D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 196 |  I FMT'=6 D
 | 
|---|
| 197 |  . S OLDEST1=9999999-OLDEST
 | 
|---|
| 198 |  . S DATE=9999999-NEWEST
 | 
|---|
| 199 |  . F  S DATE=$O(^AUPNVTRT("AA",DFN,DATE)) Q:DATE<1  Q:DATE>OLDEST  D
 | 
|---|
| 200 |  .. S IEN=0
 | 
|---|
| 201 |  .. F  S IEN=$O(^AUPNVTRT("AA",DFN,DATE,IEN)) Q:IEN<1  D
 | 
|---|
| 202 |  ... S ITEM=+$G(^AUPNVTRT(IEN,0)) I 'ITEM Q
 | 
|---|
| 203 |  ... I $D(^TMP("ORWGRPC TEMP",$J,ITEM)) Q
 | 
|---|
| 204 |  ... S ^TMP("ORWGRPC TEMP",$J,ITEM)=""
 | 
|---|
| 205 |  ... S CNT=CNT+1
 | 
|---|
| 206 |  ... I FMT=3 S RESULT="9000010.15^"_ITEM_"^^"_$$EVALUE^ORWGAPIU(ITEM,9000010.15)_"^^"_DATE
 | 
|---|
| 207 |  ... I FMT=0 S RESULT="9000010.15^"_ITEM_U_$$EVALUE^ORWGAPIU(ITEM,9000010.15)
 | 
|---|
| 208 |  ... D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 209 |  K ^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 210 |  Q
 | 
|---|
| 211 |  ;
 | 
|---|
| 212 | VISITS(ITEMS,DFN,FMT,OLDEST,NEWEST,CNT,TMP) ; from ORWGAPIR
 | 
|---|
| 213 |  N DATE,DATE2,ITEM,NODE,NUM,OK,RESULT
 | 
|---|
| 214 |  K ^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 215 |  I FMT=6 D
 | 
|---|
| 216 |  . S DATE=0
 | 
|---|
| 217 |  . F  S DATE=$O(^AUPNVSIT("AET",DFN,DATE)) Q:DATE<1  Q:DATE>NEWEST  D
 | 
|---|
| 218 |  .. S ITEM=""
 | 
|---|
| 219 |  .. F  S ITEM=$O(^AUPNVSIT("AET",DFN,DATE,ITEM)) Q:ITEM=""  D
 | 
|---|
| 220 |  ... S NODE=""
 | 
|---|
| 221 |  ... F  S NODE=$O(^AUPNVSIT("AET",DFN,DATE,ITEM,NODE)) Q:NODE=""  D
 | 
|---|
| 222 |  .... S NUM=0
 | 
|---|
| 223 |  .... F  S NUM=$O(^AUPNVSIT("AET",DFN,DATE,ITEM,NODE,NUM)) Q:NUM=""  D
 | 
|---|
| 224 |  ..... S DATE2=+$P($G(^AUPNVSIT(NUM,0)),U,18)
 | 
|---|
| 225 |  ..... I 'DATE2 S DATE2=DATE+.01
 | 
|---|
| 226 |  ..... I +$E($P(DATE2,".",2),1,2)>24 S DATE2=(DATE\1)+.2359
 | 
|---|
| 227 |  ..... S ^TMP("ORWGRPC TEMP",$J,ITEM,DATE)=DATE2
 | 
|---|
| 228 |  . S ITEM=0
 | 
|---|
| 229 |  . F  S ITEM=$O(^TMP("ORWGRPC TEMP",$J,ITEM)) Q:ITEM<1  D
 | 
|---|
| 230 |  .. S OK=0
 | 
|---|
| 231 |  .. S DATE=0
 | 
|---|
| 232 |  .. F  S DATE=$O(^TMP("ORWGRPC TEMP",$J,ITEM,DATE)) Q:DATE<1  Q:DATE>NEWEST  D  Q:OK
 | 
|---|
| 233 |  ... S DATE2=$G(^TMP("ORWGRPC TEMP",$J,ITEM,DATE))
 | 
|---|
| 234 |  ... I DATE2<OLDEST Q
 | 
|---|
| 235 |  ... S CNT=CNT+1
 | 
|---|
| 236 |  ... S OK=1
 | 
|---|
| 237 |  ... S RESULT="9000010^"_ITEM
 | 
|---|
| 238 |  ... D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 239 |  I FMT'=6 D
 | 
|---|
| 240 |  . S DATE=0
 | 
|---|
| 241 |  . F  S DATE=$O(^AUPNVSIT("AET",DFN,DATE)) Q:DATE<1  D
 | 
|---|
| 242 |  .. S ITEM=0
 | 
|---|
| 243 |  .. F  S ITEM=$O(^AUPNVSIT("AET",DFN,DATE,ITEM)) Q:ITEM<1  D
 | 
|---|
| 244 |  ... I $D(^TMP("ORWGRPC TEMP",$J,ITEM)) Q
 | 
|---|
| 245 |  ... S ^TMP("ORWGRPC TEMP",$J,ITEM)=""
 | 
|---|
| 246 |  ... S CNT=CNT+1
 | 
|---|
| 247 |  ... I FMT=3 S RESULT="9000010^"_ITEM_"^^"_$$EVALUE^ORWGAPIU(ITEM,9000010,.22)_"^^"_DATE
 | 
|---|
| 248 |  ... I FMT=0 S RESULT="9000010^"_ITEM_U_$$EVALUE^ORWGAPIU(ITEM,9000010,.22)
 | 
|---|
| 249 |  ... D SETUP^ORWGAPIU(.ITEMS,RESULT,TMP,.CNT)
 | 
|---|
| 250 |  K ^TMP("ORWGRPC TEMP",$J)
 | 
|---|
| 251 |  Q
 | 
|---|
| 252 |  ;
 | 
|---|