ECXAPHAP ;ALB/TMD-Pharmacy Extracts Unusual Volumes Report ;6/1/17  15:46
 ;;3.0;DSS EXTRACTS;**40,49,66,104,109,113,136,144,166**;Dec 22, 1997;Build 24
 ;
 ;This routine is new with patch 144 but is a copy of ECXAPHA before it
 ;was changed for the FY update.  This is now the previous fiscal year
 ;version of the routine
EN ; entry point
 N X,Y,DATE,ECRUN,ECXOPT,ECXDESC,ECXSAVE,ECXTL,ECTHLD,ECSD
 N ECSD1,ECSTART,ECED,ECEND,ECXERR,QFLG,ECXISIG
 S QFLG=0
 ; get today's date
 D NOW^%DTC S DATE=X,Y=$E(%,1,12) D DD^%DT S ECRUN=$P(Y,"@") K %DT
 D BEGIN Q:QFLG
 D SELECT Q:QFLG
PREV ;Line label added in patch 144.  Come here when running previous fiscal year logic for this report
 S ECXDESC=ECXTL_" Pre-Extract Unusual Volume Report"  ;tjl 166 Changed report title
 S ECXSAVE("EC*")=""
 W !!,"This report requires 132-column format."
 D EN^XUTMDEVQ("PROCESS^ECXAPHAP",ECXDESC,.ECXSAVE)
 I POP W !!,"No device selected...exiting.",! Q
 I IO'=IO(0) D ^%ZISC
 D HOME^%ZIS
 D AUDIT^ECXKILL
 Q
 ;
BEGIN ; display report description
 W @IOF
 W !,"This report prints a listing of unusual volumes that would be"
 W !,"generated by the pharmacy extracts (PRE, IVP and UDP) as"
 W !,"determined by a user defined threshold value.  It shoud be run"
 W !,"prior to the generation of the actual extract(s) to identify and"
 W !,"fix as necessary any volumes determined to be erroneous."
 W !!,"Unusual volumes are defined as follows:"
 W !!,"PRE Extract:  Quantity field greater than the threshold value."
 W !,"IVP Extract:  Total Doses Per Day field greater than the threshold"
 W !,?14,"or less than the negative of the threshold value."
 W !,"UDP Extract:  Quantity field greater than threshold value."
 W !!,"Note: The threshold can be set after a report is selected."
 W !!,"Run times for this report will vary depending upon the size of"
 W !,"the extract and could take as long as 30 minutes or more to"
 W !,"complete.  This report has no effect on the actual extracts and"
 W !,"can be run as needed."
 W !!,"The report is sorted by Feeder Key, descending Volume, and SSN."
 S DIR(0)="E" W ! D ^DIR K DIR I 'Y S QFLG=1 Q
 W:$Y!($E(IOST)="C") @IOF,!!
 Q
 ;
SELECT ; user inputs for report option, threshold volume and date range
 N DONE,OUT
 S ECXISIG=0
 ; allow user to select report option (PRE,IVP or UDP)
 W "Choose the report you would like to run."
 S DIR(0)="S^1:PRE;2:IVP;3:UDP",DIR("A")="Selection",DIR("B")=1 D ^DIR K DIR S ECXOPT=Y I X["^" S QFLG=1 Q
 S ECXTL=$S(ECXOPT=1:"Prescription",ECXOPT=2:"IV Detail",ECXOPT=3:"Unit Dose Local",1:"")
 ; allow user to set threshold volume
 S ECTHLD=$S(ECXOPT=2:1000,1:500)
 W !!,"The default threshold volume for the ",ECXTL," extract is ",ECTHLD,"."
 S DIR(0)="Y",DIR("A")="Would you like to change the threshold",DIR("B")="NO" D ^DIR K DIR I X["^" S QFLG=1 Q
 I Y D
 .W !!,$S(ECXOPT=2:"threshold > Total Doses Per Day < -threshold",1:"Quantity > threshold")
 .S DIR(0)="N^0:100000:0",DIR("A")="Enter the new threshold volume" D ^DIR K DIR S ECTHLD=Y I X["^" S QFLG=1 Q
 ; check to see if SIG should be place on the sec line of rpt cvw - *136 
 I ECXOPT=3 S DIR(0)="Y",DIR("A")="Include SIG/Order Direction on line 2 of report",DIR("B")="NO" D ^DIR K DIR S:Y ECXISIG=1 I X["^" S QFLG=1 Q
 ; get date range from user
 W !!,"Enter the date range for which you would like to scan the ",ECXTL,!,"Extract records."
 S DONE=0 F  S (ECED,ECSD)="" D  Q:QFLG!DONE
 .K %DT S %DT="AEX",%DT("A")="Starting with Date: ",%DT(0)=-DATE D ^%DT
 .I Y<0 S QFLG=1 Q
 .S ECSD=Y,ECSD1=ECSD-.1
 .D DD^%DT S ECSTART=Y
 .K %DT S %DT="AEX",%DT("A")="Ending with Date: ",%DT(0)=-DATE D ^%DT
 .I Y<0 S QFLG=1 Q
 .I Y<ECSD D  Q
 ..W !!,"The ending date cannot be earlier than the starting date."
 ..W !,"Please try again.",!!
 .I $E(Y,1,5)'=$E(ECSD,1,5) D  Q
 ..W !!,"Beginning and ending dates must be in the same month and year."
 ..W !,"Please try again.",!!
 .S ECED=Y
 .D DD^%DT S ECEND=Y
 .S DONE=1
 Q
 ;
PROCESS ; entry point for queued report
 S ZTREQ="@"
 S ECXERR=0 D EN^ECXAPHP2 Q:ECXERR
 S QFLG=0 D PRINT
 Q
 ;
PRINT ; process temp file and print report
 N PG,QFLG,GTOT,LN,COUNT,FKEY,QTY,SSN,REC,EDAY,ECXCOUNT
 U IO
 I $D(ZTQUEUED),$$S^%ZTLOAD S ZTSTOP=1 K ZTREQ Q
 S (PG,QFLG,GTOT)=0,$P(LN,"-",132)=""
 D HEADER Q:QFLG
 S COUNT=0,FKEY="" F  S FKEY=$O(^TMP($J,FKEY)) Q:FKEY=""!QFLG  D
 .S QTY="" F  S QTY=$O(^TMP($J,FKEY,QTY)) Q:QTY=""!QFLG  D
 ..S EDAY="" F  S EDAY=$O(^TMP($J,FKEY,QTY,EDAY)) Q:EDAY=""!QFLG  D
 ...S ECXCOUNT="" F  S ECXCOUNT=$O(^TMP($J,FKEY,QTY,EDAY,ECXCOUNT)) Q:ECXCOUNT=""!QFLG  D
 ....S SSN=""
 ....F  S SSN=$O(^TMP($J,FKEY,QTY,EDAY,ECXCOUNT,SSN)) Q:SSN=""!QFLG  S REC=^(SSN)  D
 .....S COUNT=COUNT+1
 .....I $Y+3>IOSL D HEADER Q:QFLG
 .....W !,$P(REC,U),?8,$P(REC,U,2),?20,$P(REC,U,3),?29,$E($P(REC,U,4),1,40)
 .....W ?71,$P(REC,U,5),?89,$$RJ^XLFSTR($P(REC,U,6),9)_" "_$E($P(REC,U,7),1,7)
 .....I ECXOPT=1 D
 ......W ?108,$$RJ^XLFSTR($P(REC,U,8),12),?125,$$RJ^XLFSTR($P(REC,U,9),3)
 .....I ECXOPT'=1 D
 ......W ?116,$$RJ^XLFSTR($P(REC,U,8),14)
 .....I ECXOPT=3&($G(ECXISIG)) D
 ......W !,?5,"SIG: ",$S($P(REC,U,10)="":"N/A",1:$P(REC,U,10)),! ;136
 Q:QFLG
 I COUNT=0 W !!,?8,"No unusual volumes to report for this extract"
CLOSE ;
 I $E(IOST)="C",'QFLG D
 .S SS=22-$Y F JJ=1:1:SS W !
 .S DIR(0)="E" W ! D ^DIR K DIR
 Q
 ;
 N SS,JJ
 I $E(IOST)="C" D
 .S SS=22-$Y F JJ=1:1:SS W !
 .I PG>0 S DIR(0)="E" W ! D ^DIR K DIR S:'Y QFLG=1
 Q:QFLG
 W:$Y!($E(IOST)="C") @IOF S PG=PG+1
 W !,ECXTL_" Pre-Extract Unusual Volume Report - Previous FY logic",?124,"Page: "_PG  ;tjl 166 Changed report title
 W !,"Start Date: ",ECSTART,?97,"Report Run Date/Time:  "_ECRUN
 W !,"End Date:   ",ECEND,?97,"Threshold Value = ",ECTHLD
 W !!,"Name",?11,"SSN",?21,"Day",?29,"Generic Name",?71,"Feeder Key"
 I ECXOPT=1 D
 .W ?95,"Quantity",?109,"Total Cost",?120,"Days Supply"
 E  D
 .I ECXOPT=2 W ?93,"Total Doses",?121,"Total Cost",!,?95,"Per Day"
 .I ECXOPT'=2 W ?96,"Quantity",?121,"Total Cost"
 W !,LN,!
 Q
 ;
SIG(ORDNO,PATNO) ;Get ordering instructions for unit dose order.  API added in patch 136
 N DATA,RECNO,I,SIG
 S SIG=""
 I ORDNO=""!(PATNO="") Q SIG
 S RECNO=ORDNO_","_PATNO_","
 D GETS^DIQ(55.06,RECNO,"26;120;121","E","DATA")
 F I=120,121,26 S SIG=$G(SIG)_$S($L(SIG)>0:" ",1:"")_$G(DATA(55.06,RECNO,I,"E"))
 Q SIG
 
--- Routine Detail   --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HECXAPHAP   6435     printed  Sep 23, 2025@19:28:11                                                                                                                                                                                                    Page 2
ECXAPHAP  ;ALB/TMD-Pharmacy Extracts Unusual Volumes Report ;6/1/17  15:46
 +1       ;;3.0;DSS EXTRACTS;**40,49,66,104,109,113,136,144,166**;Dec 22, 1997;Build 24
 +2       ;
 +3       ;This routine is new with patch 144 but is a copy of ECXAPHA before it
 +4       ;was changed for the FY update.  This is now the previous fiscal year
 +5       ;version of the routine
EN        ; entry point
 +1        NEW X,Y,DATE,ECRUN,ECXOPT,ECXDESC,ECXSAVE,ECXTL,ECTHLD,ECSD
 +2        NEW ECSD1,ECSTART,ECED,ECEND,ECXERR,QFLG,ECXISIG
 +3        SET QFLG=0
 +4       ; get today's date
 +5        DO NOW^%DTC
           SET DATE=X
           SET Y=$EXTRACT(%,1,12)
           DO DD^%DT
           SET ECRUN=$PIECE(Y,"@")
           KILL %DT
 +6        DO BEGIN
           if QFLG
               QUIT 
 +7        DO SELECT
           if QFLG
               QUIT 
PREV      ;Line label added in patch 144.  Come here when running previous fiscal year logic for this report
 +1       ;tjl 166 Changed report title
           SET ECXDESC=ECXTL_" Pre-Extract Unusual Volume Report"
 +2        SET ECXSAVE("EC*")=""
 +3        WRITE !!,"This report requires 132-column format."
 +4        DO EN^XUTMDEVQ("PROCESS^ECXAPHAP",ECXDESC,.ECXSAVE)
 +5        IF POP
               WRITE !!,"No device selected...exiting.",!
               QUIT 
 +6        IF IO'=IO(0)
               DO ^%ZISC
 +7        DO HOME^%ZIS
 +8        DO AUDIT^ECXKILL
 +9        QUIT 
 +10      ;
BEGIN     ; display report description
 +1        WRITE @IOF
 +2        WRITE !,"This report prints a listing of unusual volumes that would be"
 +3        WRITE !,"generated by the pharmacy extracts (PRE, IVP and UDP) as"
 +4        WRITE !,"determined by a user defined threshold value.  It shoud be run"
 +5        WRITE !,"prior to the generation of the actual extract(s) to identify and"
 +6        WRITE !,"fix as necessary any volumes determined to be erroneous."
 +7        WRITE !!,"Unusual volumes are defined as follows:"
 +8        WRITE !!,"PRE Extract:  Quantity field greater than the threshold value."
 +9        WRITE !,"IVP Extract:  Total Doses Per Day field greater than the threshold"
 +10       WRITE !,?14,"or less than the negative of the threshold value."
 +11       WRITE !,"UDP Extract:  Quantity field greater than threshold value."
 +12       WRITE !!,"Note: The threshold can be set after a report is selected."
 +13       WRITE !!,"Run times for this report will vary depending upon the size of"
 +14       WRITE !,"the extract and could take as long as 30 minutes or more to"
 +15       WRITE !,"complete.  This report has no effect on the actual extracts and"
 +16       WRITE !,"can be run as needed."
 +17       WRITE !!,"The report is sorted by Feeder Key, descending Volume, and SSN."
 +18       SET DIR(0)="E"
           WRITE !
           DO ^DIR
           KILL DIR
           IF 'Y
               SET QFLG=1
               QUIT 
 +19       if $Y!($EXTRACT(IOST)="C")
               WRITE @IOF,!!
 +20       QUIT 
 +21      ;
SELECT    ; user inputs for report option, threshold volume and date range
 +1        NEW DONE,OUT
 +2        SET ECXISIG=0
 +3       ; allow user to select report option (PRE,IVP or UDP)
 +4        WRITE "Choose the report you would like to run."
 +5        SET DIR(0)="S^1:PRE;2:IVP;3:UDP"
           SET DIR("A")="Selection"
           SET DIR("B")=1
           DO ^DIR
           KILL DIR
           SET ECXOPT=Y
           IF X["^"
               SET QFLG=1
               QUIT 
 +6        SET ECXTL=$SELECT(ECXOPT=1:"Prescription",ECXOPT=2:"IV Detail",ECXOPT=3:"Unit Dose Local",1:"")
 +7       ; allow user to set threshold volume
 +8        SET ECTHLD=$SELECT(ECXOPT=2:1000,1:500)
 +9        WRITE !!,"The default threshold volume for the ",ECXTL," extract is ",ECTHLD,"."
 +10       SET DIR(0)="Y"
           SET DIR("A")="Would you like to change the threshold"
           SET DIR("B")="NO"
           DO ^DIR
           KILL DIR
           IF X["^"
               SET QFLG=1
               QUIT 
 +11       IF Y
               Begin DoDot:1
 +12               WRITE !!,$SELECT(ECXOPT=2:"threshold > Total Doses Per Day < -threshold",1:"Quantity > threshold")
 +13               SET DIR(0)="N^0:100000:0"
                   SET DIR("A")="Enter the new threshold volume"
                   DO ^DIR
                   KILL DIR
                   SET ECTHLD=Y
                   IF X["^"
                       SET QFLG=1
                       QUIT 
               End DoDot:1
 +14      ; check to see if SIG should be place on the sec line of rpt cvw - *136 
 +15       IF ECXOPT=3
               SET DIR(0)="Y"
               SET DIR("A")="Include SIG/Order Direction on line 2 of report"
               SET DIR("B")="NO"
               DO ^DIR
               KILL DIR
               if Y
                   SET ECXISIG=1
               IF X["^"
                   SET QFLG=1
                   QUIT 
 +16      ; get date range from user
 +17       WRITE !!,"Enter the date range for which you would like to scan the ",ECXTL,!,"Extract records."
 +18       SET DONE=0
           FOR 
               SET (ECED,ECSD)=""
               Begin DoDot:1
 +19               KILL %DT
                   SET %DT="AEX"
                   SET %DT("A")="Starting with Date: "
                   SET %DT(0)=-DATE
                   DO ^%DT
 +20               IF Y<0
                       SET QFLG=1
                       QUIT 
 +21               SET ECSD=Y
                   SET ECSD1=ECSD-.1
 +22               DO DD^%DT
                   SET ECSTART=Y
 +23               KILL %DT
                   SET %DT="AEX"
                   SET %DT("A")="Ending with Date: "
                   SET %DT(0)=-DATE
                   DO ^%DT
 +24               IF Y<0
                       SET QFLG=1
                       QUIT 
 +25               IF Y<ECSD
                       Begin DoDot:2
 +26                       WRITE !!,"The ending date cannot be earlier than the starting date."
 +27                       WRITE !,"Please try again.",!!
                       End DoDot:2
                       QUIT 
 +28               IF $EXTRACT(Y,1,5)'=$EXTRACT(ECSD,1,5)
                       Begin DoDot:2
 +29                       WRITE !!,"Beginning and ending dates must be in the same month and year."
 +30                       WRITE !,"Please try again.",!!
                       End DoDot:2
                       QUIT 
 +31               SET ECED=Y
 +32               DO DD^%DT
                   SET ECEND=Y
 +33               SET DONE=1
               End DoDot:1
               if QFLG!DONE
                   QUIT 
 +34       QUIT 
 +35      ;
PROCESS   ; entry point for queued report
 +1        SET ZTREQ="@"
 +2        SET ECXERR=0
           DO EN^ECXAPHP2
           if ECXERR
               QUIT 
 +3        SET QFLG=0
           DO PRINT
 +4        QUIT 
 +5       ;
PRINT     ; process temp file and print report
 +1        NEW PG,QFLG,GTOT,LN,COUNT,FKEY,QTY,SSN,REC,EDAY,ECXCOUNT
 +2        USE IO
 +3        IF $DATA(ZTQUEUED)
               IF $$S^%ZTLOAD
                   SET ZTSTOP=1
                   KILL ZTREQ
                   QUIT 
 +4        SET (PG,QFLG,GTOT)=0
           SET $PIECE(LN,"-",132)=""
 +5        DO HEADER
           if QFLG
               QUIT 
 +6        SET COUNT=0
           SET FKEY=""
           FOR 
               SET FKEY=$ORDER(^TMP($JOB,FKEY))
               if FKEY=""!QFLG
                   QUIT 
               Begin DoDot:1
 +7                SET QTY=""
                   FOR 
                       SET QTY=$ORDER(^TMP($JOB,FKEY,QTY))
                       if QTY=""!QFLG
                           QUIT 
                       Begin DoDot:2
 +8                        SET EDAY=""
                           FOR 
                               SET EDAY=$ORDER(^TMP($JOB,FKEY,QTY,EDAY))
                               if EDAY=""!QFLG
                                   QUIT 
                               Begin DoDot:3
 +9                                SET ECXCOUNT=""
                                   FOR 
                                       SET ECXCOUNT=$ORDER(^TMP($JOB,FKEY,QTY,EDAY,ECXCOUNT))
                                       if ECXCOUNT=""!QFLG
                                           QUIT 
                                       Begin DoDot:4
 +10                                       SET SSN=""
 +11                                       FOR 
                                               SET SSN=$ORDER(^TMP($JOB,FKEY,QTY,EDAY,ECXCOUNT,SSN))
                                               if SSN=""!QFLG
                                                   QUIT 
                                               SET REC=^(SSN)
                                               Begin DoDot:5
 +12                                               SET COUNT=COUNT+1
 +13                                               IF $Y+3>IOSL
                                                       DO HEADER
                                                       if QFLG
                                                           QUIT 
 +14                                               WRITE !,$PIECE(REC,U),?8,$PIECE(REC,U,2),?20,$PIECE(REC,U,3),?29,$EXTRACT($PIECE(REC,U,4),1,40)
 +15                                               WRITE ?71,$PIECE(REC,U,5),?89,$$RJ^XLFSTR($PIECE(REC,U,6),9)_" "_$EXTRACT($PIECE(REC,U,7),1,7)
 +16                                               IF ECXOPT=1
                                                       Begin DoDot:6
 +17                                                       WRITE ?108,$$RJ^XLFSTR($PIECE(REC,U,8),12),?125,$$RJ^XLFSTR($PIECE(REC,U,9),3)
                                                       End DoDot:6
 +18                                               IF ECXOPT'=1
                                                       Begin DoDot:6
 +19                                                       WRITE ?116,$$RJ^XLFSTR($PIECE(REC,U,8),14)
                                                       End DoDot:6
 +20                                               IF ECXOPT=3&($GET(ECXISIG))
                                                       Begin DoDot:6
 +21      ;136
                                                           WRITE !,?5,"SIG: ",$SELECT($PIECE(REC,U,10)="":"N/A",1:$PIECE(REC,U,10)),!
                                                       End DoDot:6
                                               End DoDot:5
                                       End DoDot:4
                               End DoDot:3
                       End DoDot:2
               End DoDot:1
 +22       if QFLG
               QUIT 
 +23       IF COUNT=0
               WRITE !!,?8,"No unusual volumes to report for this extract"
CLOSE     ;
 +1        IF $EXTRACT(IOST)="C"
               IF 'QFLG
                   Begin DoDot:1
 +2                    SET SS=22-$Y
                       FOR JJ=1:1:SS
                           WRITE !
 +3                    SET DIR(0)="E"
                       WRITE !
                       DO ^DIR
                       KILL DIR
                   End DoDot:1
 +4        QUIT 
 +5       ;
 +1        NEW SS,JJ
 +2        IF $EXTRACT(IOST)="C"
               Begin DoDot:1
 +3                SET SS=22-$Y
                   FOR JJ=1:1:SS
                       WRITE !
 +4                IF PG>0
                       SET DIR(0)="E"
                       WRITE !
                       DO ^DIR
                       KILL DIR
                       if 'Y
                           SET QFLG=1
               End DoDot:1
 +5        if QFLG
               QUIT 
 +6        if $Y!($EXTRACT(IOST)="C")
               WRITE @IOF
           SET PG=PG+1
 +7       ;tjl 166 Changed report title
           WRITE !,ECXTL_" Pre-Extract Unusual Volume Report - Previous FY logic",?124,"Page: "_PG
 +8        WRITE !,"Start Date: ",ECSTART,?97,"Report Run Date/Time:  "_ECRUN
 +9        WRITE !,"End Date:   ",ECEND,?97,"Threshold Value = ",ECTHLD
 +10       WRITE !!,"Name",?11,"SSN",?21,"Day",?29,"Generic Name",?71,"Feeder Key"
 +11       IF ECXOPT=1
               Begin DoDot:1
 +12               WRITE ?95,"Quantity",?109,"Total Cost",?120,"Days Supply"
               End DoDot:1
 +13      IF '$TEST
               Begin DoDot:1
 +14               IF ECXOPT=2
                       WRITE ?93,"Total Doses",?121,"Total Cost",!,?95,"Per Day"
 +15               IF ECXOPT'=2
                       WRITE ?96,"Quantity",?121,"Total Cost"
               End DoDot:1
 +16       WRITE !,LN,!
 +17       QUIT 
 +18      ;
SIG(ORDNO,PATNO) ;Get ordering instructions for unit dose order.  API added in patch 136
 +1        NEW DATA,RECNO,I,SIG
 +2        SET SIG=""
 +3        IF ORDNO=""!(PATNO="")
               QUIT SIG
 +4        SET RECNO=ORDNO_","_PATNO_","
 +5        DO GETS^DIQ(55.06,RECNO,"26;120;121","E","DATA")
 +6        FOR I=120,121,26
               SET SIG=$GET(SIG)_$SELECT($LENGTH(SIG)>0:" ",1:"")_$GET(DATA(55.06,RECNO,I,"E"))
 +7        QUIT SIG