Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: DVBAB58

DVBAB58.m

Go to the documentation of this file.
  1. DVBAB58 ;ALB/SPH - CAPRI INSUFF EXAM TRACKING REPORT ;09/06/00
  1. ;;2.7;AMIE;**35,193**;Apr 10, 1995;Build 84
  1. ;
  1. STRT(ZMSG,BEGDT,ENDDT,RPTTYPE) ;
  1. MAIN ;**Select Dte Rng & Rpt Type; call report routine
  1. F Q:$D(DVBAOUT) DO
  1. .;D HOME^%ZIS
  1. .;S TVAR(1,0)="0,0,1,2:2,1^Insufficient 2507 Exam Report"
  1. .;D WR^DVBAUTL4("TVAR")
  1. .;K TVAR
  1. .;S RPTTYPE=$$RPTTYPE^DVBCUTA1()
  1. .S:((RPTTYPE'="D")&(RPTTYPE'="S")) DVBAOUT=""
  1. .;W:'$D(DVBAOUT) !!
  1. .;D:'$D(DVBAOUT) DATE^DVBCUTL4(.BEGDT,.ENDDT)
  1. .I $D(ENDDT),(+ENDDT>0) DO
  1. ..S ENDDT=ENDDT_".2359"
  1. ..I RPTTYPE="S" DO
  1. ...D DEVSEL
  1. ...I POP D SUMKILL
  1. ...I 'POP DO
  1. ....I $D(IO("Q")) DO
  1. .....N DVBAI
  1. .....S ZTRTN="SUM^DVBCIRPT",ZTIO=ION
  1. .....S ZTDESC="Summary Insufficient Exam Report"
  1. .....F DVBAI="BEGDT","ENDDT" S ZTSAVE(DVBAI)=""
  1. .....D ^%ZTLOAD
  1. .....N TSK S TSK=$S($D(ZTSK)=0:"C",1:"Y")
  1. .....I TSK="Y" W !!,"Summary Report Queued. Task number: ",ZTSK
  1. .....K ZTSK D CONTMES^DVBCUTL4
  1. .....D SUMKILL
  1. ....I '$D(IO("Q")) D SUM
  1. ...D ^%ZISC
  1. ..I RPTTYPE="D" DO
  1. ...D DETSEL^DVBCIRP1 ;**Select the Reasons and Exams to report
  1. ...I '$D(DVBAQTSL) DO
  1. ....D DEVSEL
  1. ....I POP D KVARS^DVBCIRP1
  1. ....I 'POP DO
  1. .....I $D(IO("Q")) DO
  1. ......N DVBAI
  1. ......S ZTRTN="DETAIL^DVBCIRP1",ZTIO=ION
  1. ......S ZTDESC="Detailed Insufficient Exam Report"
  1. ......F DVBAI="BEGDT","ENDDT","DVBAARY(""REASON"",","^TMP($J,""XMTYPE""," S ZTSAVE(DVBAI)=""
  1. ......D ^%ZTLOAD
  1. ......N TSK S TSK=$S($D(ZTSK)=0:"C",1:"Y")
  1. ......I TSK="Y" W !!,"Detail Report Queued. Task number: ",ZTSK
  1. ......K ZTSK D CONTMES^DVBCUTL4
  1. ......D KVARS^DVBCIRP1
  1. .....I '$D(IO("Q")) W:IOST?1"C-".E @IOF D DETAIL^DVBCIRP1
  1. ....D ^%ZISC
  1. ...K DVBAQTSL
  1. ..D CLEANUP
  1. D KVARS
  1. Q
  1. ;
  1. KVARS ;** Kill the variables used in report
  1. K DVBAOUT,ENDDT,BEGDT,DTOUT,DUOUT,RPTTYPE,DVBACAN,DVBASTAT
  1. D CLEANUP
  1. Q
  1. ;
  1. CLEANUP ;** Kill the variables used by the device handler
  1. K %ZIS,POP,%IS,IOP
  1. Q
  1. ;
  1. DEVSEL ;** Select the device to report to
  1. S %ZIS="AEQ"
  1. S %ZIS("A")="Output device: "
  1. D ^%ZIS
  1. Q
  1. ;
  1. SUM ;** Set up reason counter array, count all 2507's received
  1. U IO
  1. S (DVBARQCT,DVBAINRQ,DVBAXMCT,DVBAINXM)=0
  1. S DVBACAN("REQ")=0,DVBACAN("EXM")=0
  1. S DVBAENDL=ENDDT
  1. ;
  1. ;** Initialize reason counter array
  1. F DVBARIFN=0:0 S DVBARIFN=$O(^DVB(396.94,DVBARIFN)) Q:+DVBARIFN'>0 DO
  1. .S DVBAINXM(DVBARIFN)=0
  1. S DVBAINXM("NO REASON")=0
  1. ;
  1. ;** Count the total and insufficient number of exams and 2507 requests
  1. S DVBADTLP=BEGDT-.0001
  1. F S DVBADTLP=$O(^DVB(396.3,"ADP",DVBADTLP)) Q:(DVBADTLP=""!(DVBADTLP>ENDDT)) DO
  1. .S DVBAPRIO=""
  1. .F S DVBAPRIO=$O(^DVB(396.3,"ADP",DVBADTLP,DVBAPRIO)) Q:DVBAPRIO="" DO
  1. ..S DVBADALP=""
  1. ..F S DVBADALP=$O(^DVB(396.3,"ADP",DVBADTLP,DVBAPRIO,DVBADALP)) Q:DVBADALP="" DO
  1. ...S DVBARQCT=DVBARQCT+1
  1. ...K DVBAINSF
  1. ...I DVBAPRIO="E" DO
  1. ....S DVBAINRQ=DVBAINRQ+1
  1. ....;AJF ;Request Status Convertion
  1. ....I $P(^DVB(396.3,DVBADALP,0),U,18)=7 S DVBACAN("REQ")=DVBACAN("REQ")+1
  1. ....S DVBAINSF=""
  1. ...S DVBAXMDA=""
  1. ...F S DVBAXMDA=$O(^DVB(396.4,"C",DVBADALP,DVBAXMDA)) Q:DVBAXMDA="" DO
  1. ....S DVBAXMCT=DVBAXMCT+1
  1. ....I $D(DVBAINSF) DO
  1. .....S DVBAINXM=DVBAINXM+1
  1. .....S DVBARIFN=$P(^DVB(396.4,DVBAXMDA,0),U,11),DVBASTAT=$P(^(0),U,4)
  1. .....S:DVBARIFN="" DVBARIFN="NO REASON"
  1. .....S DVBAINXM(DVBARIFN)=DVBAINXM(DVBARIFN)+1
  1. .....I DVBASTAT="RX" S DVBACAN("EXM")=DVBACAN("EXM")+1
  1. D SUMRPT^DVBCIRP1
  1. S:$D(ZTQUEUED) ZTREQ="@"
  1. D SUMKILL
  1. D ^%ZISC
  1. Q
  1. ;
  1. SUMKILL ;** Kill the variables used in the summary report
  1. K DVBADTLP,DVBAENDL,DVBARQCT,DVBAINRQ,DVBAXMCT,DVBAINXM
  1. K DVBAPRIO,DVBADALP,DVBAXMDA,DVBAINSF,DVBARIFN
  1. Q