| 1 | ECXDRUG2 ;ALB/TMD-Pharmacy Extracts Incomplete Feeder Key Report ; 6/13/05 3:31pm
 | 
|---|
| 2 |  ;;3.0;DSS EXTRACTS;**40,68,84**;Dec 22, 1997
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | EN ; entry point
 | 
|---|
| 5 |  N ECD,LINE,ECDRG,ECQTY,ECPRC
 | 
|---|
| 6 |  K ^TMP($J)
 | 
|---|
| 7 |  S ECD=ECSD1,ECED=ECED+.3
 | 
|---|
| 8 |  S LINE=$S(ECXOPT=1:"PRE",ECXOPT=2:"IVP",ECXOPT=3:"UDP",1:"EXIT")
 | 
|---|
| 9 |  D @LINE
 | 
|---|
| 10 |  Q
 | 
|---|
| 11 |  ;
 | 
|---|
| 12 | PRE ; entry point for PRE data
 | 
|---|
| 13 |  ; order through fills, refills and partial refills
 | 
|---|
| 14 |  N ECRFL,ECRX,ECREF,ECDATA,ECDATA1
 | 
|---|
| 15 |  S ECREF=1
 | 
|---|
| 16 |  F  S ECD=$O(^PSRX("AL",ECD)),ECRX=0 Q:'ECD  Q:ECD>ECED   Q:ECXERR  F  S ECRX=$O(^PSRX("AL",ECD,ECRX)),ECRFL="" Q:'ECRX  F  S ECRFL=$O(^PSRX("AL",ECD,ECRX,ECRFL)) Q:ECRFL=""  Q:ECXERR  D PRE2
 | 
|---|
| 17 |  S ECD=ECSD1,ECREF="P"
 | 
|---|
| 18 |  F  S ECD=$O(^PSRX("AM",ECD)),ECRX=0 Q:'ECD  Q:ECD>ECED  Q:ECXERR  F  S ECRX=$O(^PSRX("AM",ECD,ECRX)),ECRFL="" Q:'ECRX  F  S ECRFL=$O(^PSRX("AM",ECD,ECRX,ECRFL)) Q:ECRFL=""  D PRE2
 | 
|---|
| 19 |  Q
 | 
|---|
| 20 |  ;
 | 
|---|
| 21 | PRE2 ; get Prescription data
 | 
|---|
| 22 |  S ECDATA=$G(^PSRX(ECRX,0))
 | 
|---|
| 23 |  S ECDRG=+$P(ECDATA,U,6)
 | 
|---|
| 24 |  I ECRFL D
 | 
|---|
| 25 |  .S ECDATA1=$G(^PSRX(ECRX,ECREF,ECRFL,0))
 | 
|---|
| 26 |  .S ECQTY=+$P(ECDATA1,U,4),ECPRC=+$P(ECDATA1,U,11)
 | 
|---|
| 27 |  I 'ECRFL S ECQTY=+$P(ECDATA,U,7),ECPRC=+$P(ECDATA,U,17)
 | 
|---|
| 28 |  D TEST
 | 
|---|
| 29 |  Q
 | 
|---|
| 30 |  ;
 | 
|---|
| 31 | IVP ; entry point for IVP data
 | 
|---|
| 32 |  N ON,DFN,DA,SA
 | 
|---|
| 33 |  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
 | 
|---|
| 34 |  .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
 | 
|---|
| 35 |  ..S ECDRG=$P(EC,U,4)
 | 
|---|
| 36 |  ..S SA=$S($P(EC,U,8)]"":"A",$P(EC,U,9):"S",1:"")
 | 
|---|
| 37 |  ..I SA'="" D
 | 
|---|
| 38 |  ...I '$D(^TMP($J,SA,ECDRG)) S ^(ECDRG)=0,$P(^(ECDRG),U,2)=$P(EC,U,12)
 | 
|---|
| 39 |  ...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:0,1:-1)
 | 
|---|
| 40 |  .;looped thru all DAs for this order - now put it together
 | 
|---|
| 41 |  .F SA="S","A" S ECDRG="" F  S ECDRG=$O(^TMP($J,SA,ECDRG)) Q:ECDRG=""  D
 | 
|---|
| 42 |  ..S ECQTY=$P(^TMP($J,SA,ECDRG),U),ECPRC=$P(^(ECDRG),U,2)
 | 
|---|
| 43 |  ..D TEST
 | 
|---|
| 44 |  K ^TMP($J,"A"),^TMP($J,"S")
 | 
|---|
| 45 |  Q
 | 
|---|
| 46 |  ;
 | 
|---|
| 47 | UDP ; entry point for UDP data
 | 
|---|
| 48 |  N ECXJ,ECDATA
 | 
|---|
| 49 |  F  S ECD=$O(^ECX(728.904,"A",ECD)) Q:'ECD  Q:ECD>ECED  Q:ECXERR  D
 | 
|---|
| 50 |  .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
 | 
|---|
| 51 |  ..S DATA=^ECX(728.904,ECXJ,0)
 | 
|---|
| 52 |  ..S ECDRG=$P(DATA,U,4),ECQTY=$P(DATA,U,5),ECCOST=$P(DATA,U,8)
 | 
|---|
| 53 |  ..S ECPRC=ECCOST/ECQTY
 | 
|---|
| 54 |  ..D TEST
 | 
|---|
| 55 |  Q
 | 
|---|
| 56 |  ;
 | 
|---|
| 57 | TEST ; retrieve NDC and PSNDF VA Product Code Entry and test for missing NDC or VA Prod Code
 | 
|---|
| 58 |  N ECTYPE,ECNDC,ECZERO,K,ECPROD,ECFCHAR,ECSTOCK,ECXPHA
 | 
|---|
| 59 |  S ECTYPE=0,ECXPHA=""
 | 
|---|
| 60 |  ; call pharmacy drug file (#50) api via ecxutl5
 | 
|---|
| 61 |  S ECXPHA=$$PHAAPI^ECXUTL5(ECDRG)
 | 
|---|
| 62 |  S ECNDC=$P(ECXPHA,U,3)
 | 
|---|
| 63 |  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)
 | 
|---|
| 64 |  S ECZERO=1,ECSTOCK=0 F K=1:1:$L(ECNDC) D  Q:'ECZERO!ECSTOCK
 | 
|---|
| 65 |  .S ECFCHAR=$E(ECNDC,K)
 | 
|---|
| 66 |  .I ECFCHAR="S" S ECSTOCK=1 Q
 | 
|---|
| 67 |  .I ECFCHAR'=0 S ECZERO=0 Q
 | 
|---|
| 68 |  I ECZERO!ECSTOCK!(ECNDC["N/A") S ECTYPE=2
 | 
|---|
| 69 |  S ECPROD=$P(ECXPHA,U,6),ECPROD=$$RJ^XLFSTR(ECPROD,5,0)
 | 
|---|
| 70 |  I ECTYPE,'ECPROD S ECTYPE=3
 | 
|---|
| 71 |  I 'ECTYPE,'ECPROD S ECTYPE=1
 | 
|---|
| 72 |  I ECTYPE D FILE
 | 
|---|
| 73 |  Q
 | 
|---|
| 74 |  ;
 | 
|---|
| 75 | FILE ; file record
 | 
|---|
| 76 |  N ECFKEY,ECGNAME,STATS,ECCOUNT,QTY,COST,ECCOST
 | 
|---|
| 77 |  ; create new record if none exists for this drug
 | 
|---|
| 78 |  I '$D(^TMP($J,ECDRG)) D
 | 
|---|
| 79 |  .S ECFKEY=ECPROD_ECNDC
 | 
|---|
| 80 |  .S ECGNAME=$P($G(^PSDRUG(ECDRG,0)),U)
 | 
|---|
| 81 |  .S ^TMP($J,ECDRG)=ECGNAME_U_ECFKEY_U_ECPRC_U_ECTYPE
 | 
|---|
| 82 |  .S ^TMP($J,ECDRG,0)="0^0^0"
 | 
|---|
| 83 |  ; add stats to record
 | 
|---|
| 84 |  S STATS=^TMP($J,ECDRG,0)
 | 
|---|
| 85 |  S ECCOUNT=$P(STATS,U),QTY=$P(STATS,U,2),COST=$P(STATS,U,3)
 | 
|---|
| 86 |  S ECCOUNT=ECCOUNT+1
 | 
|---|
| 87 |  S ECCOST=ECQTY*ECPRC
 | 
|---|
| 88 |  S ECQTY=ECQTY+QTY,ECCOST=ECCOST+COST
 | 
|---|
| 89 |  S ^TMP($J,ECDRG,0)=ECCOUNT_U_ECQTY_U_ECCOST
 | 
|---|
| 90 |  Q
 | 
|---|
| 91 |  ;
 | 
|---|
| 92 | EXIT S ECXERR=1 Q
 | 
|---|