| 1 | QANRPT1 ;HISC/GJC-SUMMARY OF INCIDENTS/WARD ;5/6/91
 | 
|---|
| 2 |  ;;2.0;Incident Reporting;**26,29**;08/07/1992
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  N QANINFLG,QANLCFLG
 | 
|---|
| 5 |  F  W !,"Do you wish to produce a report by Incident Location" S %=1 D YN^DICN Q:"-112"[%  W !,$C(7),"Enter ""Y""es to issue a report by Incident Location,",!,"""N""o to issue a report by Patient's Ward."
 | 
|---|
| 6 |  I %=-1 K % Q
 | 
|---|
| 7 |  S:%=2 QANCHOS="W" S:%=1 QANCHOS="I"
 | 
|---|
| 8 |  D DIV
 | 
|---|
| 9 | DATE ;
 | 
|---|
| 10 |  D ^QAQDATE I QAQQUIT W !!,$C(7),"Invalid date range, no report will be produced." D KILL Q
 | 
|---|
| 11 |  S (PAGE,QANTYPE)=0
 | 
|---|
| 12 |  I $D(QAQNBEG) S Y=QAQNBEG D DD^%DT S QANDATE(0)=Y
 | 
|---|
| 13 |  S:$D(QAQNBEG) QAQNBEG=QAQNBEG-.00000001
 | 
|---|
| 14 |  S:$D(QAQNEND) QAQNEND=QAQNEND_".99999999"
 | 
|---|
| 15 |  S QANHEAD(0)="QUALITY MANAGEMENT INCIDENT REPORT",QANHEAD(1)="SUMMARY OF INCIDENTS BY INCIDENT LOCATION",QANHEAD(2)="SUMMARY OF INCIDENTS BY PATIENT WARD"
 | 
|---|
| 16 |  S Y=$P(QAQNEND,".") D DD^%DT S QANDATE(1)=Y
 | 
|---|
| 17 |  S QANHEAD(3)="FOR THE PERIOD "_QANDATE(0)_" TO "_QANDATE(1)
 | 
|---|
| 18 |  D INCD^QANUTL4 I QANY D KILL Q
 | 
|---|
| 19 |  D:QANCHOS="I" QANLOC^QANUTL4 D:QANCHOS="W" WARD^QANUTL4 I QANY D KILL Q
 | 
|---|
| 20 | LOOP ;
 | 
|---|
| 21 |  N QANCC,QANEE
 | 
|---|
| 22 |  S QANEE=QAQNBEG
 | 
|---|
| 23 |  F  S QANEE=$O(^QA(742.4,"BDT",QANEE)) Q:QANEE'>0!(QANEE>QAQNEND)  D
 | 
|---|
| 24 |  . S QANCC=0
 | 
|---|
| 25 |  . F  S QANCC=$O(^QA(742.4,"BDT",QANEE,QANCC)) Q:QANCC'>0  D
 | 
|---|
| 26 |  . . S QANDD=0
 | 
|---|
| 27 |  . . F  S QANDD=$O(^QA(742,"BCS",QANCC,QANDD)) Q:QANDD'>0  D
 | 
|---|
| 28 |  . . . S QAN7424=^QA(742.4,QANCC,0) Q:$G(QAN7424)']""
 | 
|---|
| 29 |  . . . S QAN742=^QA(742,QANDD,0) Q:$G(QAN742)']""
 | 
|---|
| 30 |  . . . I $P(QAN7424,U,8)=2 Q
 | 
|---|
| 31 |  . . . S QANINC=$P(QAN7424,U,2) I $G(QANINC)']"" Q
 | 
|---|
| 32 |  . . . I $G(QANINFLG)'=1 I $G(^TMP("QANRPT1",$J,"INC",QANINC))']"" Q
 | 
|---|
| 33 |  . . . I $P(QAN742,U,5)'=1 Q
 | 
|---|
| 34 |  . . . S QANLCN=$S($G(QANCHOS)="I":$P(QAN7424,U,4),1:$P(QAN742,U,6)) Q:'$G(QANLCN)
 | 
|---|
| 35 |  . . . I $G(QANCHOS)="I" S QANLOC=$P(^QA(742.5,QANLCN,0),U)
 | 
|---|
| 36 |  . . . I $G(QANCHOS)="W" S QANLOC=$P(^SC($P(QAN742,U,6),0),U)
 | 
|---|
| 37 |  . . . I $G(QANLOC)']"" Q
 | 
|---|
| 38 |  . . . I $G(QANLCFLG)'=1 I $G(^TMP("QANRPT1",$J,"LOC",QANLCN))']"" Q
 | 
|---|
| 39 |  . . . S QANDIV=$P(QAN7424,U,22) I $G(QANDIV)']"" S QANDIV=0
 | 
|---|
| 40 |  . . . I $G(QAN1DIV)]"" Q:QAN1DIV'=QANDIV
 | 
|---|
| 41 |  . . . I '$D(^QA(740,1,"QAN2","B",QANDIV)) S QANDIV=0
 | 
|---|
| 42 |  . . . I $P($G(^QA(740,1,"QAN")),U,5)'=1 S QANDIV=0
 | 
|---|
| 43 |  . . . S QANINC=$P(^QA(742.1,QANINC,0),U)
 | 
|---|
| 44 |  . . . S QANINC=$TR(QANINC,"abcdefghijklmnopqrstuvwxyz","ABCDEFGHIJKLMNOPQRSTUVWXYZ")
 | 
|---|
| 45 |  . . . S ^TMP("QANRPT1",$J,"QAN",QANDIV,QANLOC,QANINC,QANCC,QANDD)=""
 | 
|---|
| 46 |  I '$D(^TMP("QANRPT1",$J)) W !!,$C(7),"No records found for the selected date range." D KILL Q
 | 
|---|
| 47 |  S QANWORD=$S($G(QANCHOS)="I":"Incident",1:"Ward")
 | 
|---|
| 48 |  I '$G(QANLCFLG),('$D(^TMP("QANRPT1",$J,"LOC"))) W !!,$C(7),QANWORD," location(s) not found, exiting the report." D KILL Q
 | 
|---|
| 49 |  I '$G(QANINFLG),('$D(^TMP("QANRPT1",$J,"INC"))) W !!,$C(7),"Incident(s) not found, exiting the report." D KILL Q
 | 
|---|
| 50 |  D TOTAL
 | 
|---|
| 51 | TASK S Y=DT X ^DD("DD") S TODAY=Y,$P(BNDRY,"-",$S(IOM=132:133,1:81))="",QANFIN=""
 | 
|---|
| 52 |  ;*** Choose device ***
 | 
|---|
| 53 |  K IOP,%ZIS S %ZIS("A")="Print on device: ",%ZIS="MQ" W ! D ^%ZIS W !!
 | 
|---|
| 54 |  G:POP KILL
 | 
|---|
| 55 |  I $D(IO("Q")) S ZTRTN="STRT^QANRPT1",ZTDESC="Generate Incident reports for incidents by type." D QLOOP^QANRPT2,^%ZTLOAD W !,$S($D(ZTSK):"Request queued!",1:"Request cancelled!"),! G EXIT
 | 
|---|
| 56 | STRT U IO
 | 
|---|
| 57 |  D:QANFIN'["^" PRINT
 | 
|---|
| 58 | EXIT W ! D ^%ZISC,HOME^%ZIS
 | 
|---|
| 59 | KILL ;Kill and quit.
 | 
|---|
| 60 |  D K^QAQDATE
 | 
|---|
| 61 |  K QAQNBEG,QAQNEND
 | 
|---|
| 62 |  K QAN742,QAN7424,QANAA,QANBB,QANCC,QANDD,QANEE,QANFF,QANXX,QANYY,QANZZ
 | 
|---|
| 63 |  K BNDRY,COUNT,LOOP,PAGE,TODAY,X,Y,%
 | 
|---|
| 64 |  K QANCDNT,QANCHOS,QANCNT,QANDAT1,QANDAT2,QANDATA1,QANDATA2,QANDATE
 | 
|---|
| 65 |  K QANDIV,QANDV,QANDVFLG,QANDVN,QANDVSN,QANFLG,QANFIN,QANINC,QANINFLG
 | 
|---|
| 66 |  K QANHEAD,QANINC,QANINCID,QAN,QANLCFLG,QANLOC,QANLOCA
 | 
|---|
| 67 |  K QANNODE,QANNUM,QANTYPE,QANY
 | 
|---|
| 68 |  K ^TMP("QANRPT1"),LP,LP0,LP1,LP2,QA,C
 | 
|---|
| 69 |  K DIROUT,DIRUT,DTOUT,DUOUT,D
 | 
|---|
| 70 |  Q
 | 
|---|
| 71 | FINAL ;Final data summation.
 | 
|---|
| 72 |  D:$Y>(IOSL-4) HDH,HDR^QANAUX1 Q:QANFIN["^"
 | 
|---|
| 73 |  I $G(COUNT("TOT"))'>0 W !!,"No incidents found, exiting the report." Q
 | 
|---|
| 74 |  S QANFF=""
 | 
|---|
| 75 |  F  S QANFF=$O(COUNT("LOC",QANAA,QANFF)) Q:QANFF']""  D
 | 
|---|
| 76 |  . S QANLOCA=QANFF
 | 
|---|
| 77 |  . W !,"Total number of incidents for "_$S(QANCHOS="W":"ward ",1:"incident location ")_QANLOCA_": "_COUNT("LOC",QANAA,QANFF)
 | 
|---|
| 78 |  I $G(QANDVFLG)=1 W !!,"Total number of Incidents for division "_QANDV_": "_COUNT("DIV",QANAA)
 | 
|---|
| 79 |  W !!,"Total number of incidents this reporting period: "_COUNT("TOT")
 | 
|---|
| 80 |  D HDH
 | 
|---|
| 81 |  Q
 | 
|---|
| 82 | TOTAL ;
 | 
|---|
| 83 |  N QANAA,QANBB,QANCC,QANDD
 | 
|---|
| 84 |  S QANAA=""
 | 
|---|
| 85 |  F  S QANAA=$O(^TMP("QANRPT1",$J,"QAN",QANAA)) Q:QANAA']""  D
 | 
|---|
| 86 |  . S QANBB=""
 | 
|---|
| 87 |  . F  S QANBB=$O(^TMP("QANRPT1",$J,"QAN",QANAA,QANBB)) Q:QANBB']""  D
 | 
|---|
| 88 |  . . S QANCC=""
 | 
|---|
| 89 |  . . F  S QANCC=$O(^TMP("QANRPT1",$J,"QAN",QANAA,QANBB,QANCC)) Q:QANCC']""  D
 | 
|---|
| 90 |  . . . S QANDD=0
 | 
|---|
| 91 |  . . . F  S QANDD=$O(^TMP("QANRPT1",$J,"QAN",QANAA,QANBB,QANCC,QANDD)) Q:QANDD'>0  D
 | 
|---|
| 92 |  . . . . S COUNT("INC",QANAA,QANBB,QANCC)=$G(COUNT("INC",QANAA,QANBB,QANCC))+1
 | 
|---|
| 93 |  . . . . S COUNT("TOT")=$G(COUNT("TOT"))+1
 | 
|---|
| 94 |  . . . . S COUNT("DIV",QANAA)=$G(COUNT("DIV",QANAA))+1
 | 
|---|
| 95 |  . . . . S COUNT("LOC",QANAA,QANBB)=$G(COUNT("LOC",QANAA,QANBB))+1
 | 
|---|
| 96 |  Q
 | 
|---|
| 97 | HDH ;
 | 
|---|
| 98 |  I $E(IOST)="C" K DIR S DIR(0)="E" D ^DIR K DIR S:+Y=0 QANFIN="^"
 | 
|---|
| 99 |  Q
 | 
|---|
| 100 | WARD ;
 | 
|---|
| 101 |  N QANCNT,QANDD
 | 
|---|
| 102 |  S QANDD=0
 | 
|---|
| 103 |  S QANCNT=1
 | 
|---|
| 104 |  F  S QANDD=$O(^QA(742,"BCS",QANIEN,QANDD)) Q:QANDD'>0  D
 | 
|---|
| 105 |  . Q:'$P($G(^QA(742,QANDD,0)),U,6)
 | 
|---|
| 106 |  . S QANLOC(QANCNT)=$P(^QA(742,QANDD,0),U,6)
 | 
|---|
| 107 |  . S QANCNT=QANCNT+1
 | 
|---|
| 108 |  Q
 | 
|---|
| 109 | INST(QANIEN,QANDV) ;api for getting division name
 | 
|---|
| 110 |  N DIC
 | 
|---|
| 111 |  K QANDV
 | 
|---|
| 112 |  S DIC="^DIC(4,"
 | 
|---|
| 113 |  S DIC(0)="NZX"
 | 
|---|
| 114 |  S DIC("S")="I $D(^QA(740,1,""QAN2"",""B"",X))"
 | 
|---|
| 115 |  S X=QANIEN
 | 
|---|
| 116 |  D ^DIC K DIC
 | 
|---|
| 117 |  I Y<0 S QANDV="Unknown" Q
 | 
|---|
| 118 |  S QANDV=Y(0,0)
 | 
|---|
| 119 |  Q
 | 
|---|
| 120 | PRINT ;print or display data
 | 
|---|
| 121 |  I '$D(COUNT) G FINAL
 | 
|---|
| 122 |  S QANAA=""
 | 
|---|
| 123 |  F  S QANAA=$O(COUNT("INC",QANAA)) Q:QANAA']""  D
 | 
|---|
| 124 |  . D INST(QANAA,.QANDV)
 | 
|---|
| 125 |  . I $G(QANDVFLG)=1 S QANHEAD(4)="REPORT FOR DIVISION: "_QANDV
 | 
|---|
| 126 |  . D HDR^QANAUX1
 | 
|---|
| 127 |  . S QANBB=""
 | 
|---|
| 128 |  . F  S QANBB=$O(COUNT("INC",QANAA,QANBB)) Q:QANBB']""  D
 | 
|---|
| 129 |  . . D:$Y>(IOSL-6) HDH,HDR^QANAUX1 Q:QANFIN["^"  W !!,$E(QANBB,1,32)
 | 
|---|
| 130 |  . . S QANCC=""
 | 
|---|
| 131 |  . . F  S QANCC=$O(COUNT("INC",QANAA,QANBB,QANCC)) Q:QANCC']""  D
 | 
|---|
| 132 |  . . . S QANDD=$O(^TMP("QANRPT1",$J,"QAN",QANAA,QANBB,QANCC,0)) Q:QANDD'>0
 | 
|---|
| 133 |  . . . S QANINCID=$P(^QA(742.1,$P(^QA(742.4,QANDD,0),U,2),0),U)
 | 
|---|
| 134 |  . . . S QANNUM=COUNT("INC",QANAA,QANBB,QANCC)
 | 
|---|
| 135 |  . . . D:$Y>(IOSL-4) HDH,HDR^QANAUX1 W ?35,$E(QANINCID,1,35),?72,QANNUM,!
 | 
|---|
| 136 |  . D FINAL
 | 
|---|
| 137 |  Q
 | 
|---|
| 138 | DIV ;
 | 
|---|
| 139 |  K QANDVFLG,QAN1DIV
 | 
|---|
| 140 |  S QANDVFLG=$P($G(^QA(740,1,"QAN")),U,5)
 | 
|---|
| 141 |  Q:$G(QANDVFLG)'=1
 | 
|---|
| 142 |  N DIR,DIRUT,DTOUT,DUOUT
 | 
|---|
| 143 |  S DIR(0)="YA"
 | 
|---|
| 144 |  S DIR("A")="Select ALL Divisions? "
 | 
|---|
| 145 |  S DIR("B")="YES"
 | 
|---|
| 146 |  D ^DIR K DIR I $D(DIRUT) S QANPOP=1 Q
 | 
|---|
| 147 |  I Y S QAN1DIV="" Q
 | 
|---|
| 148 |  N DIC
 | 
|---|
| 149 |  S DIC="^QA(740,1,""QAN2"","
 | 
|---|
| 150 |  S DIC(0)="AEMZQ"
 | 
|---|
| 151 |  S DIC("A")="Enter Division: "
 | 
|---|
| 152 |  S QANDVSN=$O(^QA(740,1,"QAN2",0)) Q:$G(QANDVSN)'>0
 | 
|---|
| 153 |  D INST($G(^QA(740,1,"QAN2",QANDVSN,0)),.QANDVN)
 | 
|---|
| 154 |  S DIC("B")=$G(QANDVN)
 | 
|---|
| 155 |  D ^DIC K DIC
 | 
|---|
| 156 |  I +Y>0 S QAN1DIV=Y(0)
 | 
|---|
| 157 |  Q
 | 
|---|