| 1 | ECXPHAA ;ALB/JRC Pharmacy DSS Extract UDP/IVP Source Audit Report ; 11/2/06 8:54am
 | 
|---|
| 2 |  ;;3.0;DSS EXTRACTS;**92**;Dec 22, 1997;Build 30
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | EN ;entry point from option
 | 
|---|
| 5 |  N SCRNARR,STOP,REPORT,DIVISION,SDATE,EDATE,X,TMP
 | 
|---|
| 6 |  S SCRNARR="^TMP($J,""ECXPHAA"")",STOP=0
 | 
|---|
| 7 |  K @SCRNARR
 | 
|---|
| 8 |  S STOP=0
 | 
|---|
| 9 |  ;Select report
 | 
|---|
| 10 |  D REPORT  Q:STOP
 | 
|---|
| 11 |  ;Select division
 | 
|---|
| 12 |  D DIVISION  Q:STOP
 | 
|---|
| 13 |  ;Select date range
 | 
|---|
| 14 |  D DATES  Q:STOP
 | 
|---|
| 15 |  ;Queue Report
 | 
|---|
| 16 |  N ZTDESC,ZTIO,ZTSAVE
 | 
|---|
| 17 |  F X="REPORT","SDATE","EDATE","STOP" S ZTSAVE(X)=""
 | 
|---|
| 18 |  S ZTSAVE("SCRNARR")=""
 | 
|---|
| 19 |  S TMP=$$OREF^DILF(SCRNARR)
 | 
|---|
| 20 |  S ZTSAVE(TMP)=""
 | 
|---|
| 21 |  I $D(@SCRNARR)#2 S ZTSAVE(SCRNARR)=""
 | 
|---|
| 22 |  S ZTIO=""
 | 
|---|
| 23 |  S ZTDESC="DSS UDP/IVP Source Audit Report"
 | 
|---|
| 24 |  D EN^XUTMDEVQ("EN1^ECXPHAA",ZTDESC,.ZTSAVE)
 | 
|---|
| 25 |  Q
 | 
|---|
| 26 |  ;
 | 
|---|
| 27 | EN1 ;Init variables
 | 
|---|
| 28 |  N PAGE,LN,SUB
 | 
|---|
| 29 |  S SUB="",PAGE=0
 | 
|---|
| 30 |  D HEADER I STOP D EXIT Q
 | 
|---|
| 31 |  S SUB=$S(REPORT=1:"GETUDATA",REPORT=2:"GETIDATA",1:"")
 | 
|---|
| 32 |  D @SUB I STOP D EXIT Q
 | 
|---|
| 33 |  I '$O(^TMP($J,"ECXPHAA",0)) D  Q
 | 
|---|
| 34 |  .W !
 | 
|---|
| 35 |  .W !,"************************************************************"
 | 
|---|
| 36 |  .W !,"*  NOTHING TO REPORT FOR PHARMACY "_$S(REPORT=1:"UDP",REPORT=2:"IVP",1:"")_" SOURCE AUDIT REPORT  *"
 | 
|---|
| 37 |  .W !,"************************************************************"
 | 
|---|
| 38 |  .D WAIT
 | 
|---|
| 39 |  .D EXIT
 | 
|---|
| 40 |  D DETAIL I STOP D EXIT Q
 | 
|---|
| 41 | EXIT K @SCRNARR Q
 | 
|---|
| 42 |  ;
 | 
|---|
| 43 | REPORT ;Select report
 | 
|---|
| 44 |  N DIR,DIRUT,DUOUT
 | 
|---|
| 45 |  ;Prepare choices
 | 
|---|
| 46 |  S DIR(0)="S^1:UDP;2:IVP"
 | 
|---|
| 47 |  S DIR("A")="Select Source Audit Report"
 | 
|---|
| 48 |  D ^DIR
 | 
|---|
| 49 |  I $D(DIRUT)!$D(DUOUT) S STOP=1 Q
 | 
|---|
| 50 |  S REPORT=Y
 | 
|---|
| 51 |  Q
 | 
|---|
| 52 |  ;
 | 
|---|
| 53 | DIVISION ;Prompt for division
 | 
|---|
| 54 |  ; Set Divisions into screen array (prompt is one/many/all)
 | 
|---|
| 55 |  ;Input  : SCRNARR - Screen array full global reference
 | 
|---|
| 56 |  ;Output : 1 = OK     0 = User abort/timeout
 | 
|---|
| 57 |  ;         @SCRNARR@("DIVISION") = User pick all divisions ?
 | 
|---|
| 58 |  ;           1 = Yes (all)     0 = No
 | 
|---|
| 59 |  ;         @SCRNARR@("DIVISION",PtrDiv) = Division name
 | 
|---|
| 60 |  ;Note   : @SCRNARR@("DIVISION") is initialized (KILLed) on input
 | 
|---|
| 61 |  ;       : @SCRNARR@("DIVISION",PtrDiv) is only set when the user
 | 
|---|
| 62 |  ;         picked individual divisions (i.e. didn't pick all)
 | 
|---|
| 63 |  ;
 | 
|---|
| 64 |  ;Declare variables
 | 
|---|
| 65 |  N VAUTD,Y,DIV,FAC
 | 
|---|
| 66 |  ;Get division selection
 | 
|---|
| 67 |  D DIVISION^VAUTOMA
 | 
|---|
| 68 |  I Y<0 S STOP=1 Q
 | 
|---|
| 69 |  M @SCRNARR@("DIVISION")=VAUTD
 | 
|---|
| 70 |  I VAUTD=0 D
 | 
|---|
| 71 |  .S DIV=0 F  S DIV=$O(VAUTD(DIV)) Q:DIV'>0  S FAC=$$GETDIV^ECXDEPT(DIV) S @SCRNARR@("DIVISION",FAC)=""
 | 
|---|
| 72 |  Q
 | 
|---|
| 73 |  ;
 | 
|---|
| 74 | DATES ;Prompt for start date
 | 
|---|
| 75 |  N DIR,DIRUT,X,Y
 | 
|---|
| 76 |  S DIR(0)="D^:NOW:EX"
 | 
|---|
| 77 |  S DIR("A")="Enter Report Start Date"
 | 
|---|
| 78 |  S DIR("B")=$$FMTE^XLFDT($$NOW^XLFDT,"1D")
 | 
|---|
| 79 |  D ^DIR
 | 
|---|
| 80 |  I $D(DIRUT) S STOP=1 Q
 | 
|---|
| 81 |  S SDATE=Y
 | 
|---|
| 82 |  ;Prompt for end date
 | 
|---|
| 83 |  K DIR,DIRUT,X,Y
 | 
|---|
| 84 |  S DIR(0)="D^:NOW:EX"
 | 
|---|
| 85 |  S DIR("A")="Enter Report End Date"
 | 
|---|
| 86 |  S DIR("B")=$$FMTE^XLFDT($$NOW^XLFDT,"1D")
 | 
|---|
| 87 |  D ^DIR
 | 
|---|
| 88 |  I $D(DIRUT) S STOP=1 Q
 | 
|---|
| 89 |  S EDATE=Y
 | 
|---|
| 90 |  Q
 | 
|---|
| 91 |  ;
 | 
|---|
| 92 | HEADER ;Print header
 | 
|---|
| 93 |  S PAGE=$G(PAGE)+1,$P(LN,"=",80)=""
 | 
|---|
| 94 |  W @IOF
 | 
|---|
| 95 |  W !,$S(REPORT=1:"UDP",REPORT=2:"IVP",1:"")_" Source Audit Report",?70,"PAGE: "_PAGE
 | 
|---|
| 96 |  W !!,"Run Date:   "_$$FMTE^XLFDT(DT)
 | 
|---|
| 97 |  W !!,"Start Date: "_$$FMTE^XLFDT(SDATE)
 | 
|---|
| 98 |  W !,"End Date:   "_$$FMTE^XLFDT(EDATE)
 | 
|---|
| 99 |  W !!,?1,"Division",?24,"Date",?39,"Record Count"
 | 
|---|
| 100 |  W !,LN
 | 
|---|
| 101 |  Q
 | 
|---|
| 102 |  ;
 | 
|---|
| 103 | GETIDATA ;Get data from pharmacy IVP intermediate files
 | 
|---|
| 104 |  ;Init variables
 | 
|---|
| 105 |  N DATE,FILE,DFN,ERROR,ON,DA,ECPAT,EC
 | 
|---|
| 106 |  S DATE=SDATE-.1,EDATE=EDATE+.999,FILE=728.113
 | 
|---|
| 107 |  F  S DATE=$O(^ECX(FILE,"A",DATE)) Q:'DATE!(DATE>EDATE)  D  Q:STOP
 | 
|---|
| 108 |  .S DFN=0 F  S DFN=$O(^ECX(FILE,"A",DATE,DFN)) Q:'DFN  D  Q:STOP
 | 
|---|
| 109 |  ..;Filter out test patients or bad records
 | 
|---|
| 110 |  ..S ERROR=0 D PAT^ECXNUT(DFN) Q:ERROR
 | 
|---|
| 111 |  ..S ON=0 F  S ON=$O(^ECX(FILE,"A",DATE,DFN,ON)) Q:'ON  D  Q:STOP
 | 
|---|
| 112 |  ...S DA=0 F  S DA=$O(^ECX(FILE,"A",DATE,DFN,ON,DA)) Q:'DA!(STOP)  D  Q:STOP
 | 
|---|
| 113 |  ....I $D(^ECX(728.113,DA,0)) S EC=^(0) D  Q:STOP
 | 
|---|
| 114 |  .....;get inpatient data if exist
 | 
|---|
| 115 |  .....N X,STATUS,MOVEMENT,ADMIT,SPECIAL,WARD,DIVISION,CLINIC
 | 
|---|
| 116 |  .....N DIC,DIQ,DR,ECXDIC,DA
 | 
|---|
| 117 |  .....S (X,STATUS,MOVEMENT,ADMIT,SPECIAL,WARD,DIVISION,CLINIC)=""
 | 
|---|
| 118 |  .....S X=$$INP^ECXUTL2(DFN,DATE),STATUS=$P(X,U,1)
 | 
|---|
| 119 |  .....I STATUS="I" D  Q:STOP
 | 
|---|
| 120 |  ......S WARD=$P(X,U,9),DIVISION=$$GETDIV^ECXDEPT($P(WARD,";",2))
 | 
|---|
| 121 |  .....I STATUS="O" D  Q:STOP
 | 
|---|
| 122 |  ......;Get division from  outpatient location file 44
 | 
|---|
| 123 |  ......S CLINIC=+$P(EC,U,13)
 | 
|---|
| 124 |  ......S DIC="^SC(",DIQ(0)="I",DIQ="ECXDIC",DR="3",DA=CLINIC
 | 
|---|
| 125 |  ......D EN^DIQ1
 | 
|---|
| 126 |  ......S DIVISION=$$RADDIV^ECXDEPT(+$G(ECXDIC(44,CLINIC,3,"I")))
 | 
|---|
| 127 |  ......S DIVISION=$S(DIVISION'="":DIVISION,1:"UNKNOWN")
 | 
|---|
| 128 |  .....;Save in temp global and filter division
 | 
|---|
| 129 |  .....I '@SCRNARR@("DIVISION")=1&'($D(@SCRNARR@("DIVISION",DIVISION))) Q
 | 
|---|
| 130 |  .....S ^TMP($J,"ECXPHAA",$P(DATE,".",1),DIVISION)=$G(^TMP($J,"ECXPHAA",$P(DATE,".",1),DIVISION))+1
 | 
|---|
| 131 |  Q
 | 
|---|
| 132 |  ;
 | 
|---|
| 133 | GETUDATA ;Get unit dose data from intermediate file 728.904
 | 
|---|
| 134 |  ;Init variables
 | 
|---|
| 135 |  N DATE,FILE,RECORD,DATA,DFN,ERROR,ON,WARD,DIVISION,X,STATUS,DIC,DIQ,DR,DA,ECPAT,CLINIC,CNT,FACILITY,L
 | 
|---|
| 136 |  S DATE=SDATE-.1,EDATE=EDATE+.999,STOP=0
 | 
|---|
| 137 |  S FILE=728.904
 | 
|---|
| 138 |  F  S DATE=$O(^ECX(FILE,"A",DATE)) Q:'DATE!(DATE>EDATE)  D  Q:STOP
 | 
|---|
| 139 |  .S RECORD=0 F  S RECORD=$O(^ECX(FILE,"A",DATE,RECORD)) Q:'RECORD  D  Q:STOP
 | 
|---|
| 140 |  ..S DATA=$G(^ECX(FILE,RECORD,0)),DFN=$P(DATA,U,2)
 | 
|---|
| 141 |  ..;Filter out test patients or bad records
 | 
|---|
| 142 |  ..S ERROR=0 D PAT^ECXNUT(DFN) Q:ERROR
 | 
|---|
| 143 |  ..S ON=$P(DATA,U,10),WARD=$P(DATA,U,6)
 | 
|---|
| 144 |  ..S DIVISION=$$GETDIV^ECXDEPT($P($G(^DIC(42,+WARD,0)),U,11))
 | 
|---|
| 145 |  ..S FACILITY=$P($G(^DIC(42,+WARD,0)),U,11)
 | 
|---|
| 146 |  ..S X=$$INP^ECXUTL2(DFN,DATE),STATUS=$P(X,U,1)
 | 
|---|
| 147 |  ..I STATUS="O"&(ON) D  Q:STOP
 | 
|---|
| 148 |  ...;Get division from  outpatient location from file 44
 | 
|---|
| 149 |  ...S DIC=55,DIQ(0)="I",DIQ="ECXDIC",DR="62",DR(55.06)="130",DA=DFN
 | 
|---|
| 150 |  ...S DA(55.06)=+ON D EN^DIQ1
 | 
|---|
| 151 |  ...S CLINIC=+$G(ECXDIC(55.06,DFN,130,"I"))
 | 
|---|
| 152 |  ...S DIVISION=$$RADDIV^ECXDEPT($G(ECXDIC(44,CLINIC,3,"I")))
 | 
|---|
| 153 |  ...S DIVISION=$S(DIVISION'="":DIVISION,1:"UNKNOWN")
 | 
|---|
| 154 |  ..;Save in temp global and filter division
 | 
|---|
| 155 |  ..I '@SCRNARR@("DIVISION")=1&'($D(@SCRNARR@("DIVISION",DIVISION))) Q
 | 
|---|
| 156 |  ..S ^TMP($J,"ECXPHAA",$P(DATE,".",1),DIVISION)=$G(^TMP($J,"ECXPHAA",$P(DATE,".",1),DIVISION))+1
 | 
|---|
| 157 |  Q
 | 
|---|
| 158 |  ;
 | 
|---|
| 159 | DETAIL ;Print report
 | 
|---|
| 160 |  ;Init variables
 | 
|---|
| 161 |  N DATE,DIV,CNT
 | 
|---|
| 162 |  S (DATE,CNT)=0,DIV=""
 | 
|---|
| 163 |  F  S DATE=$O(^TMP($J,"ECXPHAA",DATE)) Q:'DATE!(STOP)  F  S DIV=$O(^TMP($J,"ECXPHAA",DATE,DIV)) Q:DIV=""  S CNT=^(DIV) W !,?1,DIV,?20,$$FMTE^XLFDT(DATE),?45,CNT I $Y>(IOSL-5) D WAIT Q:STOP  D HEADER
 | 
|---|
| 164 |  Q
 | 
|---|
| 165 |  ;
 | 
|---|
| 166 | WAIT ;End of page logic
 | 
|---|
| 167 |  ;Input   ; None
 | 
|---|
| 168 |  ;Output  ; STOP - Flag indicating if printing should continue
 | 
|---|
| 169 |  ;                 1 = Stop     0 = Continue
 | 
|---|
| 170 |  ;
 | 
|---|
| 171 |  S STOP=0
 | 
|---|
| 172 |  ;CRT - Prompt for continue
 | 
|---|
| 173 |  I $E(IOST,1,2)="C-"&(IOSL'>24) D  Q
 | 
|---|
| 174 |  .F  Q:$Y>(IOSL-3)  W !
 | 
|---|
| 175 |  .N DIR,X,Y,DTOUT,DUOUT,DIRUT,DIROUT
 | 
|---|
| 176 |  .S DIR(0)="E"
 | 
|---|
| 177 |  .D ^DIR
 | 
|---|
| 178 |  .S STOP=$S(Y'=1:1,1:0)
 | 
|---|
| 179 |  ;Background task - check taskman
 | 
|---|
| 180 |  S STOP=$$S^%ZTLOAD()
 | 
|---|
| 181 |  I STOP D
 | 
|---|
| 182 |  .W !,"*********************************************"
 | 
|---|
| 183 |  .W !,"*  PRINTING OF REPORT STOPPED AS REQUESTED  *"
 | 
|---|
| 184 |  .W !,"*********************************************"
 | 
|---|
| 185 |  Q
 | 
|---|