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

ECXDRUG2.m

Go to the documentation of this file.
  1. 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
  1. ;
  1. ; Reference to ^PSDRUG( in ICR #4846
  1. ; Reference to EXTRACT^PSO52EX in ICR #4902
  1. ; Reference to $$RJ^XLFSTR in ICR #10104
  1. ; Reference to ^TMP($J in SACC 2.3.2.5.1
  1. ;
  1. EN ; entry point
  1. N ECD,LINE,ECDRG,ECQTY,ECPRC
  1. I '$G(ECXPORT) K ^TMP($J) ;144 Already killed if exporting
  1. S ECD=ECSD1,ECED=ECED+.3
  1. S LINE=$S(ECXOPT=1:"PRE",ECXOPT=2:"IVP",ECXOPT=3:"UDP",1:"EXIT")
  1. D @LINE
  1. Q
  1. ;
  1. PRE ; entry point for PRE data
  1. ; order through fills, refills and partial refills
  1. N ECRFL,ECRX,ECREF,ECDATA,ECDATA1
  1. K ^TMP($J,"ECXDSS")
  1. ;call pharmacy api pso52ex
  1. D EXTRACT^PSO52EX(ECD,ECED,"ECXDSS")
  1. S ECREF="RF"
  1. ;order thru fills and refills; refill values 0 thru 11
  1. ; Note: refill 0 = original fill
  1. 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
  1. ;
  1. ;order thru partial fills
  1. S ECD=ECSD1,ECREF="P"
  1. 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
  1. K ^TMP($J,"ECXDSS")
  1. Q
  1. ;
  1. PRE2 ; get Prescription data
  1. S ECDRG=+$P(^TMP($J,"ECXDSS",IEN,6),U)
  1. I ECRFL>0&(ECREF="RF") D
  1. .S ECQTY=^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,1),ECPRC=^(1.2)
  1. I ECRFL>0&(ECREF="P") D
  1. .S ECQTY=^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,.04),ECPRC=^(.042)
  1. I 'ECRFL S ECQTY=^TMP($J,"ECXDSS",IEN,7),ECPRC=^(17)
  1. D TEST
  1. Q
  1. ;
  1. IVP ; entry point for IVP data
  1. N ON,DFN,DA,SA
  1. 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
  1. .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
  1. ..S ECDRG=$P(EC,U,4)
  1. ..S SA=$S($P(EC,U,8)]"":"A",$P(EC,U,9):"S",1:"")
  1. ..I SA'="" D
  1. ...I '$D(^TMP($J,SA,ECDRG)) S ^(ECDRG)=0,$P(^(ECDRG),U,2)=$P(EC,U,12)
  1. ...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.
  1. .;looped thru all DAs for this order - now put it together
  1. .F SA="S","A" S ECDRG="" F S ECDRG=$O(^TMP($J,SA,ECDRG)) Q:ECDRG="" D
  1. ..S ECQTY=$P(^TMP($J,SA,ECDRG),U),ECPRC=$P(^(ECDRG),U,2)
  1. ..D TEST
  1. K ^TMP($J,"A"),^TMP($J,"S")
  1. Q
  1. ;
  1. UDP ; entry point for UDP data
  1. N ECXJ,ECDATA
  1. F S ECD=$O(^ECX(728.904,"A",ECD)) Q:'ECD Q:ECD>ECED Q:ECXERR D
  1. .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
  1. ..S DATA=^ECX(728.904,ECXJ,0)
  1. ..S ECDRG=$P(DATA,U,4),ECQTY=$P(DATA,U,5),ECCOST=$P(DATA,U,8)
  1. ..S ECPRC=ECCOST/ECQTY
  1. ..D TEST
  1. Q
  1. ;
  1. TEST ; retrieve NDC and PSNDF VA Product Code Entry and test for missing NDC or VA Prod Code
  1. N ECTYPE,ECNDC,ECZERO,K,ECPROD,ECFCHAR,ECSTOCK,ECXPHA,LOCAL ;174
  1. S ECTYPE=0,ECXPHA=""
  1. ; call pharmacy drug file (#50) api via ecxutl5
  1. S ECXPHA=$$PHAAPI^ECXUTL5(ECDRG)
  1. S ECNDC=$P(ECXPHA,U,3)
  1. 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)
  1. S ECZERO=1,ECSTOCK=0,LOCAL=0 F K=1:1:$L(ECNDC) D Q:'ECZERO!ECSTOCK!LOCAL ;174
  1. .S ECFCHAR=$E(ECNDC,K)
  1. .I $E(ECNDC,1)="L" S LOCAL=1 Q ;174 If NDC is blank and marked with LCL or LCD, stop processing
  1. .I ECFCHAR="S" S ECSTOCK=1 Q
  1. .I ECFCHAR'=0 S ECZERO=0 Q
  1. I ECZERO!ECSTOCK!(ECNDC["N/A") S ECTYPE=2
  1. S ECPROD=$P(ECXPHA,U,6),ECPROD=$$RJ^XLFSTR(ECPROD,5,0)
  1. I ECTYPE,'ECPROD S ECTYPE=3
  1. I 'ECTYPE,'ECPROD S ECTYPE=1
  1. I ECTYPE D FILE
  1. Q
  1. ;
  1. FILE ; file record
  1. N ECFKEY,ECGNAME,STATS,ECCOUNT,QTY,COST,ECCOST
  1. ; create new record if none exists for this drug
  1. I '$D(^TMP($J,ECDRG)) D
  1. .S ECFKEY=ECPROD_ECNDC
  1. .S ECGNAME=$P($G(^PSDRUG(ECDRG,0)),U)
  1. .S ^TMP($J,ECDRG)=ECGNAME_U_ECFKEY_U_ECPRC_U_ECTYPE
  1. .S ^TMP($J,ECDRG,0)="0^0^0"
  1. ; add stats to record
  1. S STATS=^TMP($J,ECDRG,0)
  1. S ECCOUNT=$P(STATS,U),QTY=$P(STATS,U,2),COST=$P(STATS,U,3)
  1. S ECCOUNT=ECCOUNT+1
  1. S ECCOST=ECQTY*ECPRC
  1. S ECQTY=ECQTY+QTY,ECCOST=ECCOST+COST
  1. S ^TMP($J,ECDRG,0)=ECCOUNT_U_ECQTY_U_ECCOST
  1. Q
  1. ;
  1. EXIT S ECXERR=1 Q