ECXDRUG2 ;ALB/TMD-Pharmacy Extracts Incomplete Feeder Key Report ;5/9/19  17:13
 ;;3.0;DSS EXTRACTS;**40,68,84,105,111,144,174,187**;Dec 22, 1997;Build 163
 ;
 ; Reference to ^PSDRUG( in ICR #4846
 ; Reference to EXTRACT^PSO52EX in ICR #4902
 ; Reference to $$RJ^XLFSTR in ICR #10104
 ; Reference to ^TMP($J in SACC 2.3.2.5.1
 ;
EN ; entry point
 N ECD,LINE,ECDRG,ECQTY,ECPRC
 I '$G(ECXPORT) K ^TMP($J) ;144 Already killed if exporting
 S ECD=ECSD1,ECED=ECED+.3
 S LINE=$S(ECXOPT=1:"PRE",ECXOPT=2:"IVP",ECXOPT=3:"UDP",1:"EXIT")
 D @LINE
 Q
 ;
PRE ; entry point for PRE data
 ; order through fills, refills and partial refills
 N ECRFL,ECRX,ECREF,ECDATA,ECDATA1
 K ^TMP($J,"ECXDSS")
 ;call pharmacy api pso52ex
 D EXTRACT^PSO52EX(ECD,ECED,"ECXDSS")
 S ECREF="RF"
 ;order thru fills and refills; refill values 0 thru 11
 ;     Note:  refill 0 = original fill
 F  S ECD=$O(^TMP($J,"ECXDSS","AL",ECD)),IEN=0 Q:'ECD  Q:ECD>ECED  Q:ECXERR  F  S IEN=$O(^(ECD,IEN)),ECRFL=""  Q:'IEN  Q:ECXERR  F  S ECRFL=$O(^(IEN,ECRFL)) Q:ECRFL']""  Q:ECXERR  D PRE2
 ;
 ;order thru partial fills
 S ECD=ECSD1,ECREF="P"
 F  S ECD=$O(^TMP($J,"ECXDSS","AM",ECD)),IEN=0 Q:'ECD  Q:ECD>ECED  Q:ECXERR  F  S IEN=$O(^(ECD,IEN)),ECRFL=""  Q:'IEN  Q:ECXERR  F  S ECRFL=$O(^(IEN,ECRFL)) Q:'ECRFL  Q:ECXERR  D PRE2
 K ^TMP($J,"ECXDSS")
 Q
 ;
PRE2 ; get Prescription data
 S ECDRG=+$P(^TMP($J,"ECXDSS",IEN,6),U)
 I ECRFL>0&(ECREF="RF") D
 .S ECQTY=^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,1),ECPRC=^(1.2)
 I ECRFL>0&(ECREF="P") D
 .S ECQTY=^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,.04),ECPRC=^(.042)
 I 'ECRFL S ECQTY=^TMP($J,"ECXDSS",IEN,7),ECPRC=^(17)
 D TEST
 Q
 ;
IVP ; entry point for IVP data
 N ON,DFN,DA,SA
 F  S ECD=$O(^ECX(728.113,"A",ECD)),DFN=0 Q:'ECD  Q:ECXERR  Q:ECD>ECED  F  S DFN=$O(^ECX(728.113,"A",ECD,DFN)),ON=0  Q:'DFN  Q:ECXERR  F  S ON=$O(^ECX(728.113,"A",ECD,DFN,ON)),DA=0 Q:'ON  K ^TMP($J,"A"),^("S") D
 .F  S DA=$O(^ECX(728.113,"A",ECD,DFN,ON,DA)) Q:'DA  I $D(^ECX(728.113,DA,0)) S EC=^(0) D
 ..S ECDRG=$P(EC,U,4)
 ..S SA=$S($P(EC,U,8)]"":"A",$P(EC,U,9):"S",1:"")
 ..I SA'="" D
 ...I '$D(^TMP($J,SA,ECDRG)) S ^(ECDRG)=0,$P(^(ECDRG),U,2)=$P(EC,U,12)
 ...S $P(^TMP($J,SA,ECDRG),U)=$P(^TMP($J,SA,ECDRG),U)+$S($P(EC,U,6)=1:1,$P(EC,U,6)=4:-1,1:-1) ;187 Deduct 1 if transaction type is cancel.
 .;looped thru all DAs for this order - now put it together
 .F SA="S","A" S ECDRG="" F  S ECDRG=$O(^TMP($J,SA,ECDRG)) Q:ECDRG=""  D
 ..S ECQTY=$P(^TMP($J,SA,ECDRG),U),ECPRC=$P(^(ECDRG),U,2)
 ..D TEST
 K ^TMP($J,"A"),^TMP($J,"S")
 Q
 ;
UDP ; entry point for UDP data
 N ECXJ,ECDATA
 F  S ECD=$O(^ECX(728.904,"A",ECD)) Q:'ECD  Q:ECD>ECED  Q:ECXERR  D
 .S ECXJ=0 F  S ECXJ=$O(^ECX(728.904,"A",ECD,ECXJ)) Q:'ECXJ  Q:ECXERR  I $D(^ECX(728.904,ECXJ,0)) D
 ..S DATA=^ECX(728.904,ECXJ,0)
 ..S ECDRG=$P(DATA,U,4),ECQTY=$P(DATA,U,5),ECCOST=$P(DATA,U,8)
 ..S ECPRC=ECCOST/ECQTY
 ..D TEST
 Q
 ;
TEST ; retrieve NDC and PSNDF VA Product Code Entry and test for missing NDC or VA Prod Code
 N ECTYPE,ECNDC,ECZERO,K,ECPROD,ECFCHAR,ECSTOCK,ECXPHA,LOCAL ;174
 S ECTYPE=0,ECXPHA=""
 ; call pharmacy drug file (#50) api via ecxutl5
 S ECXPHA=$$PHAAPI^ECXUTL5(ECDRG)
 S ECNDC=$P(ECXPHA,U,3)
 S ECNDC=$$RJ^XLFSTR($P(ECNDC,"-"),6,0)_$$RJ^XLFSTR($P(ECNDC,"-",2),4,0)_$$RJ^XLFSTR($P(ECNDC,"-",3),2,0),ECNDC=$TR(ECNDC,"*",0)
 S ECZERO=1,ECSTOCK=0,LOCAL=0 F K=1:1:$L(ECNDC) D  Q:'ECZERO!ECSTOCK!LOCAL  ;174
 .S ECFCHAR=$E(ECNDC,K)
 .I $E(ECNDC,1)="L" S LOCAL=1 Q  ;174 If NDC is blank and marked with LCL or LCD, stop processing
 .I ECFCHAR="S" S ECSTOCK=1 Q
 .I ECFCHAR'=0 S ECZERO=0 Q
 I ECZERO!ECSTOCK!(ECNDC["N/A") S ECTYPE=2
 S ECPROD=$P(ECXPHA,U,6),ECPROD=$$RJ^XLFSTR(ECPROD,5,0)
 I ECTYPE,'ECPROD S ECTYPE=3
 I 'ECTYPE,'ECPROD S ECTYPE=1
 I ECTYPE D FILE
 Q
 ;
FILE ; file record
 N ECFKEY,ECGNAME,STATS,ECCOUNT,QTY,COST,ECCOST
 ; create new record if none exists for this drug
 I '$D(^TMP($J,ECDRG)) D
 .S ECFKEY=ECPROD_ECNDC
 .S ECGNAME=$P($G(^PSDRUG(ECDRG,0)),U)
 .S ^TMP($J,ECDRG)=ECGNAME_U_ECFKEY_U_ECPRC_U_ECTYPE
 .S ^TMP($J,ECDRG,0)="0^0^0"
 ; add stats to record
 S STATS=^TMP($J,ECDRG,0)
 S ECCOUNT=$P(STATS,U),QTY=$P(STATS,U,2),COST=$P(STATS,U,3)
 S ECCOUNT=ECCOUNT+1
 S ECCOST=ECQTY*ECPRC
 S ECQTY=ECQTY+QTY,ECCOST=ECCOST+COST
 S ^TMP($J,ECDRG,0)=ECCOUNT_U_ECQTY_U_ECCOST
 Q
 ;
EXIT S ECXERR=1 Q
 
--- Routine Detail   --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HECXDRUG2   4357     printed  Sep 23, 2025@19:28:32                                                                                                                                                                                                    Page 2
ECXDRUG2  ;ALB/TMD-Pharmacy Extracts Incomplete Feeder Key Report ;5/9/19  17:13
 +1       ;;3.0;DSS EXTRACTS;**40,68,84,105,111,144,174,187**;Dec 22, 1997;Build 163
 +2       ;
 +3       ; Reference to ^PSDRUG( in ICR #4846
 +4       ; Reference to EXTRACT^PSO52EX in ICR #4902
 +5       ; Reference to $$RJ^XLFSTR in ICR #10104
 +6       ; Reference to ^TMP($J in SACC 2.3.2.5.1
 +7       ;
EN        ; entry point
 +1        NEW ECD,LINE,ECDRG,ECQTY,ECPRC
 +2       ;144 Already killed if exporting
           IF '$GET(ECXPORT)
               KILL ^TMP($JOB)
 +3        SET ECD=ECSD1
           SET ECED=ECED+.3
 +4        SET LINE=$SELECT(ECXOPT=1:"PRE",ECXOPT=2:"IVP",ECXOPT=3:"UDP",1:"EXIT")
 +5        DO @LINE
 +6        QUIT 
 +7       ;
PRE       ; entry point for PRE data
 +1       ; order through fills, refills and partial refills
 +2        NEW ECRFL,ECRX,ECREF,ECDATA,ECDATA1
 +3        KILL ^TMP($JOB,"ECXDSS")
 +4       ;call pharmacy api pso52ex
 +5        DO EXTRACT^PSO52EX(ECD,ECED,"ECXDSS")
 +6        SET ECREF="RF"
 +7       ;order thru fills and refills; refill values 0 thru 11
 +8       ;     Note:  refill 0 = original fill
 +9        FOR 
               SET ECD=$ORDER(^TMP($JOB,"ECXDSS","AL",ECD))
               SET IEN=0
               if 'ECD
                   QUIT 
               if ECD>ECED
                   QUIT 
               if ECXERR
                   QUIT 
               FOR 
                   SET IEN=$ORDER(^(ECD,IEN))
                   SET ECRFL=""
                   if 'IEN
                       QUIT 
                   if ECXERR
                       QUIT 
                   FOR 
                       SET ECRFL=$ORDER(^(IEN,ECRFL))
                       if ECRFL']""
                           QUIT 
                       if ECXERR
                           QUIT 
                       DO PRE2
 +10      ;
 +11      ;order thru partial fills
 +12       SET ECD=ECSD1
           SET ECREF="P"
 +13       FOR 
               SET ECD=$ORDER(^TMP($JOB,"ECXDSS","AM",ECD))
               SET IEN=0
               if 'ECD
                   QUIT 
               if ECD>ECED
                   QUIT 
               if ECXERR
                   QUIT 
               FOR 
                   SET IEN=$ORDER(^(ECD,IEN))
                   SET ECRFL=""
                   if 'IEN
                       QUIT 
                   if ECXERR
                       QUIT 
                   FOR 
                       SET ECRFL=$ORDER(^(IEN,ECRFL))
                       if 'ECRFL
                           QUIT 
                       if ECXERR
                           QUIT 
                       DO PRE2
 +14       KILL ^TMP($JOB,"ECXDSS")
 +15       QUIT 
 +16      ;
PRE2      ; get Prescription data
 +1        SET ECDRG=+$PIECE(^TMP($JOB,"ECXDSS",IEN,6),U)
 +2        IF ECRFL>0&(ECREF="RF")
               Begin DoDot:1
 +3                SET ECQTY=^TMP($JOB,"ECXDSS",IEN,ECREF,ECRFL,1)
                   SET ECPRC=^(1.2)
               End DoDot:1
 +4        IF ECRFL>0&(ECREF="P")
               Begin DoDot:1
 +5                SET ECQTY=^TMP($JOB,"ECXDSS",IEN,ECREF,ECRFL,.04)
                   SET ECPRC=^(.042)
               End DoDot:1
 +6        IF 'ECRFL
               SET ECQTY=^TMP($JOB,"ECXDSS",IEN,7)
               SET ECPRC=^(17)
 +7        DO TEST
 +8        QUIT 
 +9       ;
IVP       ; entry point for IVP data
 +1        NEW ON,DFN,DA,SA
 +2        FOR 
               SET ECD=$ORDER(^ECX(728.113,"A",ECD))
               SET DFN=0
               if 'ECD
                   QUIT 
               if ECXERR
                   QUIT 
               if ECD>ECED
                   QUIT 
               FOR 
                   SET DFN=$ORDER(^ECX(728.113,"A",ECD,DFN))
                   SET ON=0
                   if 'DFN
                       QUIT 
                   if ECXERR
                       QUIT 
                   FOR 
                       SET ON=$ORDER(^ECX(728.113,"A",ECD,DFN,ON))
                       SET DA=0
                       if 'ON
                           QUIT 
                       KILL ^TMP($JOB,"A"),^("S")
                       Begin DoDot:1
 +3                        FOR 
                               SET DA=$ORDER(^ECX(728.113,"A",ECD,DFN,ON,DA))
                               if 'DA
                                   QUIT 
                               IF $DATA(^ECX(728.113,DA,0))
                                   SET EC=^(0)
                                   Begin DoDot:2
 +4                                    SET ECDRG=$PIECE(EC,U,4)
 +5                                    SET SA=$SELECT($PIECE(EC,U,8)]"":"A",$PIECE(EC,U,9):"S",1:"")
 +6                                    IF SA'=""
                                           Begin DoDot:3
 +7                                            IF '$DATA(^TMP($JOB,SA,ECDRG))
                                                   SET ^(ECDRG)=0
                                                   SET $PIECE(^(ECDRG),U,2)=$PIECE(EC,U,12)
 +8       ;187 Deduct 1 if transaction type is cancel.
                                               SET $PIECE(^TMP($JOB,SA,ECDRG),U)=$PIECE(^TMP($JOB,SA,ECDRG),U)+$SELECT($PIECE(EC,U,6)=1:1,$PIECE(EC,U,6)=4:-1,1:-1)
                                           End DoDot:3
                                   End DoDot:2
 +9       ;looped thru all DAs for this order - now put it together
 +10                       FOR SA="S","A"
                               SET ECDRG=""
                               FOR 
                                   SET ECDRG=$ORDER(^TMP($JOB,SA,ECDRG))
                                   if ECDRG=""
                                       QUIT 
                                   Begin DoDot:2
 +11                                   SET ECQTY=$PIECE(^TMP($JOB,SA,ECDRG),U)
                                       SET ECPRC=$PIECE(^(ECDRG),U,2)
 +12                                   DO TEST
                                   End DoDot:2
                       End DoDot:1
 +13       KILL ^TMP($JOB,"A"),^TMP($JOB,"S")
 +14       QUIT 
 +15      ;
UDP       ; entry point for UDP data
 +1        NEW ECXJ,ECDATA
 +2        FOR 
               SET ECD=$ORDER(^ECX(728.904,"A",ECD))
               if 'ECD
                   QUIT 
               if ECD>ECED
                   QUIT 
               if ECXERR
                   QUIT 
               Begin DoDot:1
 +3                SET ECXJ=0
                   FOR 
                       SET ECXJ=$ORDER(^ECX(728.904,"A",ECD,ECXJ))
                       if 'ECXJ
                           QUIT 
                       if ECXERR
                           QUIT 
                       IF $DATA(^ECX(728.904,ECXJ,0))
                           Begin DoDot:2
 +4                            SET DATA=^ECX(728.904,ECXJ,0)
 +5                            SET ECDRG=$PIECE(DATA,U,4)
                               SET ECQTY=$PIECE(DATA,U,5)
                               SET ECCOST=$PIECE(DATA,U,8)
 +6                            SET ECPRC=ECCOST/ECQTY
 +7                            DO TEST
                           End DoDot:2
               End DoDot:1
 +8        QUIT 
 +9       ;
TEST      ; retrieve NDC and PSNDF VA Product Code Entry and test for missing NDC or VA Prod Code
 +1       ;174
           NEW ECTYPE,ECNDC,ECZERO,K,ECPROD,ECFCHAR,ECSTOCK,ECXPHA,LOCAL
 +2        SET ECTYPE=0
           SET ECXPHA=""
 +3       ; call pharmacy drug file (#50) api via ecxutl5
 +4        SET ECXPHA=$$PHAAPI^ECXUTL5(ECDRG)
 +5        SET ECNDC=$PIECE(ECXPHA,U,3)
 +6        SET ECNDC=$$RJ^XLFSTR($PIECE(ECNDC,"-"),6,0)_$$RJ^XLFSTR($PIECE(ECNDC,"-",2),4,0)_$$RJ^XLFSTR($PIECE(ECNDC,"-",3),2,0)
           SET ECNDC=$TRANSLATE(ECNDC,"*",0)
 +7       ;174
           SET ECZERO=1
           SET ECSTOCK=0
           SET LOCAL=0
           FOR K=1:1:$LENGTH(ECNDC)
               Begin DoDot:1
 +8                SET ECFCHAR=$EXTRACT(ECNDC,K)
 +9       ;174 If NDC is blank and marked with LCL or LCD, stop processing
                   IF $EXTRACT(ECNDC,1)="L"
                       SET LOCAL=1
                       QUIT 
 +10               IF ECFCHAR="S"
                       SET ECSTOCK=1
                       QUIT 
 +11               IF ECFCHAR'=0
                       SET ECZERO=0
                       QUIT 
               End DoDot:1
               if 'ECZERO!ECSTOCK!LOCAL
                   QUIT 
 +12       IF ECZERO!ECSTOCK!(ECNDC["N/A")
               SET ECTYPE=2
 +13       SET ECPROD=$PIECE(ECXPHA,U,6)
           SET ECPROD=$$RJ^XLFSTR(ECPROD,5,0)
 +14       IF ECTYPE
               IF 'ECPROD
                   SET ECTYPE=3
 +15       IF 'ECTYPE
               IF 'ECPROD
                   SET ECTYPE=1
 +16       IF ECTYPE
               DO FILE
 +17       QUIT 
 +18      ;
FILE      ; file record
 +1        NEW ECFKEY,ECGNAME,STATS,ECCOUNT,QTY,COST,ECCOST
 +2       ; create new record if none exists for this drug
 +3        IF '$DATA(^TMP($JOB,ECDRG))
               Begin DoDot:1
 +4                SET ECFKEY=ECPROD_ECNDC
 +5                SET ECGNAME=$PIECE($GET(^PSDRUG(ECDRG,0)),U)
 +6                SET ^TMP($JOB,ECDRG)=ECGNAME_U_ECFKEY_U_ECPRC_U_ECTYPE
 +7                SET ^TMP($JOB,ECDRG,0)="0^0^0"
               End DoDot:1
 +8       ; add stats to record
 +9        SET STATS=^TMP($JOB,ECDRG,0)
 +10       SET ECCOUNT=$PIECE(STATS,U)
           SET QTY=$PIECE(STATS,U,2)
           SET COST=$PIECE(STATS,U,3)
 +11       SET ECCOUNT=ECCOUNT+1
 +12       SET ECCOST=ECQTY*ECPRC
 +13       SET ECQTY=ECQTY+QTY
           SET ECCOST=ECCOST+COST
 +14       SET ^TMP($JOB,ECDRG,0)=ECCOUNT_U_ECQTY_U_ECCOST
 +15       QUIT 
 +16      ;
EXIT       SET ECXERR=1
           QUIT