| 1 | DVBCIRPT ;ALB/GTS-AMIE C&P INSUFF EXAM TRACKING RPT ; 11/9/94  2:00 PM
 | 
|---|
| 2 |  ;;2.7;AMIE;**13,19,27**;Apr 10, 1995
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  ;** Version Changes
 | 
|---|
| 5 |  ;   2.7 - New routine (Enhc 15)
 | 
|---|
| 6 |  ;
 | 
|---|
| 7 | MAIN ;**Select Dte Rng & Rpt Type; call report routine
 | 
|---|
| 8 |  F  Q:$D(DVBAOUT)  DO
 | 
|---|
| 9 |  .D HOME^%ZIS
 | 
|---|
| 10 |  .S TVAR(1,0)="0,0,1,2:2,1^Insufficient 2507 Exam Report"
 | 
|---|
| 11 |  .D WR^DVBAUTL4("TVAR")
 | 
|---|
| 12 |  .K TVAR
 | 
|---|
| 13 |  .S RPTTYPE=$$RPTTYPE^DVBCUTA1()
 | 
|---|
| 14 |  .S:((RPTTYPE'="D")&(RPTTYPE'="S")) DVBAOUT=""
 | 
|---|
| 15 |  .W:'$D(DVBAOUT) !!
 | 
|---|
| 16 |  .D:'$D(DVBAOUT) DATE^DVBCUTL4(.BEGDT,.ENDDT)
 | 
|---|
| 17 |  .I $D(ENDDT),(+ENDDT>0) DO
 | 
|---|
| 18 |  ..S ENDDT=ENDDT_".2359"
 | 
|---|
| 19 |  ..I RPTTYPE="S" DO
 | 
|---|
| 20 |  ...D DEVSEL
 | 
|---|
| 21 |  ...I POP D SUMKILL
 | 
|---|
| 22 |  ...I 'POP DO
 | 
|---|
| 23 |  ....I $D(IO("Q")) DO
 | 
|---|
| 24 |  .....N DVBAI
 | 
|---|
| 25 |  .....S ZTRTN="SUM^DVBCIRPT",ZTIO=ION
 | 
|---|
| 26 |  .....S ZTDESC="Summary Insufficient Exam Report"
 | 
|---|
| 27 |  .....F DVBAI="BEGDT","ENDDT" S ZTSAVE(DVBAI)=""
 | 
|---|
| 28 |  .....D ^%ZTLOAD
 | 
|---|
| 29 |  .....N TSK S TSK=$S($D(ZTSK)=0:"C",1:"Y")
 | 
|---|
| 30 |  .....I TSK="Y" W !!,"Summary Report Queued. Task number: ",ZTSK
 | 
|---|
| 31 |  .....K ZTSK D CONTMES^DVBCUTL4
 | 
|---|
| 32 |  .....D SUMKILL
 | 
|---|
| 33 |  ....I '$D(IO("Q")) D SUM
 | 
|---|
| 34 |  ...D ^%ZISC
 | 
|---|
| 35 |  ..I RPTTYPE="D" DO
 | 
|---|
| 36 |  ...D DETSEL^DVBCIRP1 ;**Select the Reasons and Exams to report
 | 
|---|
| 37 |  ...I '$D(DVBAQTSL) DO
 | 
|---|
| 38 |  ....D DEVSEL
 | 
|---|
| 39 |  ....I POP D KVARS^DVBCIRP1
 | 
|---|
| 40 |  ....I 'POP DO
 | 
|---|
| 41 |  .....I $D(IO("Q")) DO
 | 
|---|
| 42 |  ......N DVBAI
 | 
|---|
| 43 |  ......S ZTRTN="DETAIL^DVBCIRP1",ZTIO=ION
 | 
|---|
| 44 |  ......S ZTDESC="Detailed Insufficient Exam Report"
 | 
|---|
| 45 |  ......F DVBAI="BEGDT","ENDDT","DVBAARY(""REASON"",","^TMP($J,""XMTYPE""," S ZTSAVE(DVBAI)=""
 | 
|---|
| 46 |  ......D ^%ZTLOAD
 | 
|---|
| 47 |  ......N TSK S TSK=$S($D(ZTSK)=0:"C",1:"Y")
 | 
|---|
| 48 |  ......I TSK="Y" W !!,"Detail Report Queued. Task number: ",ZTSK
 | 
|---|
| 49 |  ......K ZTSK D CONTMES^DVBCUTL4
 | 
|---|
| 50 |  ......D KVARS^DVBCIRP1
 | 
|---|
| 51 |  .....I '$D(IO("Q")) W:IOST?1"C-".E @IOF D DETAIL^DVBCIRP1
 | 
|---|
| 52 |  ....D ^%ZISC
 | 
|---|
| 53 |  ...K DVBAQTSL
 | 
|---|
| 54 |  ..D CLEANUP
 | 
|---|
| 55 |  D KVARS
 | 
|---|
| 56 |  Q
 | 
|---|
| 57 |  ;
 | 
|---|
| 58 | KVARS ;** Kill the variables used in report
 | 
|---|
| 59 |  K DVBAOUT,ENDDT,BEGDT,DTOUT,DUOUT,RPTTYPE,DVBACAN,DVBASTAT
 | 
|---|
| 60 |  D CLEANUP
 | 
|---|
| 61 |  Q
 | 
|---|
| 62 |  ;
 | 
|---|
| 63 | CLEANUP ;** Kill the variables used by the device handler
 | 
|---|
| 64 |  K %ZIS,POP,%IS,IOP
 | 
|---|
| 65 |  K IOBS,IOHG,IOPAR,IOUPAR,IOXY,POP,%DT,%YY,%XX,ION,IOPAR
 | 
|---|
| 66 |  Q
 | 
|---|
| 67 |  ;
 | 
|---|
| 68 | DEVSEL ;** Select the device to report to
 | 
|---|
| 69 |  S %ZIS="AEQ"
 | 
|---|
| 70 |  S %ZIS("A")="Output device: "
 | 
|---|
| 71 |  D ^%ZIS
 | 
|---|
| 72 |  Q
 | 
|---|
| 73 |  ;
 | 
|---|
| 74 | SUM ;** Set up reason counter array, count all 2507's received
 | 
|---|
| 75 |  U IO
 | 
|---|
| 76 |  S (DVBARQCT,DVBAINRQ,DVBAXMCT,DVBAINXM)=0
 | 
|---|
| 77 |  S DVBACAN("REQ")=0,DVBACAN("EXM")=0
 | 
|---|
| 78 |  S DVBAENDL=ENDDT
 | 
|---|
| 79 |  ;
 | 
|---|
| 80 |  ;** Initialize reason counter array
 | 
|---|
| 81 |  F DVBARIFN=0:0 S DVBARIFN=$O(^DVB(396.94,DVBARIFN)) Q:+DVBARIFN'>0  DO
 | 
|---|
| 82 |  .S DVBAINXM(DVBARIFN)=0
 | 
|---|
| 83 |  S DVBAINXM("NO REASON")=0
 | 
|---|
| 84 |  ;
 | 
|---|
| 85 |  ;** Count the total and insufficient number of exams and 2507 requests
 | 
|---|
| 86 |  S DVBADTLP=BEGDT-.0001
 | 
|---|
| 87 |  F  S DVBADTLP=$O(^DVB(396.3,"ADP",DVBADTLP)) Q:(DVBADTLP=""!(DVBADTLP>ENDDT))  DO
 | 
|---|
| 88 |  .S DVBAPRIO=""
 | 
|---|
| 89 |  .F  S DVBAPRIO=$O(^DVB(396.3,"ADP",DVBADTLP,DVBAPRIO)) Q:DVBAPRIO=""  DO
 | 
|---|
| 90 |  ..S DVBADALP=""
 | 
|---|
| 91 |  ..F  S DVBADALP=$O(^DVB(396.3,"ADP",DVBADTLP,DVBAPRIO,DVBADALP)) Q:DVBADALP=""  DO
 | 
|---|
| 92 |  ...S DVBARQCT=DVBARQCT+1
 | 
|---|
| 93 |  ...K DVBAINSF
 | 
|---|
| 94 |  ...I DVBAPRIO="E" DO
 | 
|---|
| 95 |  ....S DVBAINRQ=DVBAINRQ+1
 | 
|---|
| 96 |  ....I $P(^DVB(396.3,DVBADALP,0),U,18)="RX" S DVBACAN("REQ")=DVBACAN("REQ")+1
 | 
|---|
| 97 |  ....S DVBAINSF=""
 | 
|---|
| 98 |  ...S DVBAXMDA=""
 | 
|---|
| 99 |  ...F  S DVBAXMDA=$O(^DVB(396.4,"C",DVBADALP,DVBAXMDA)) Q:DVBAXMDA=""  DO
 | 
|---|
| 100 |  ....S DVBAXMCT=DVBAXMCT+1
 | 
|---|
| 101 |  ....I $D(DVBAINSF) DO
 | 
|---|
| 102 |  .....S DVBAINXM=DVBAINXM+1
 | 
|---|
| 103 |  .....S DVBARIFN=$P(^DVB(396.4,DVBAXMDA,0),U,11),DVBASTAT=$P(^(0),U,4)
 | 
|---|
| 104 |  .....S:DVBARIFN="" DVBARIFN="NO REASON"
 | 
|---|
| 105 |  .....S DVBAINXM(DVBARIFN)=DVBAINXM(DVBARIFN)+1
 | 
|---|
| 106 |  .....I DVBASTAT="RX" S DVBACAN("EXM")=DVBACAN("EXM")+1
 | 
|---|
| 107 |  D SUMRPT^DVBCIRP1
 | 
|---|
| 108 |  S:$D(ZTQUEUED) ZTREQ="@"
 | 
|---|
| 109 |  D SUMKILL
 | 
|---|
| 110 |  D ^%ZISC
 | 
|---|
| 111 |  Q
 | 
|---|
| 112 |  ;
 | 
|---|
| 113 | SUMKILL ;** Kill the variables used in the summary report
 | 
|---|
| 114 |  K DVBADTLP,DVBAENDL,DVBARQCT,DVBAINRQ,DVBAXMCT,DVBAINXM
 | 
|---|
| 115 |  K DVBAPRIO,DVBADALP,DVBAXMDA,DVBAINSF,DVBARIFN
 | 
|---|
| 116 |  Q
 | 
|---|