| 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 | 
|---|