Changeset 623 for WorldVistAEHR/trunk/r/DSS_EXTRACTS-ECX/ECXDRUG2.m
- Timestamp:
- Dec 4, 2009, 12:11:15 AM (14 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
WorldVistAEHR/trunk/r/DSS_EXTRACTS-ECX/ECXDRUG2.m
r613 r623 1 ECXDRUG2 ;ALB/TMD-Pharmacy Extracts Incomplete Feeder Key Report ; 2/19/08 3:44pm 2 ;;3.0;DSS EXTRACTS;**40,68,84,105,111**;Dec 22, 1997;Build 4 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 K ^TMP($J,"ECXDSS") 16 ;call pharmacy api pso52ex 17 D EXTRACT^PSO52EX(ECD,ECED,"ECXDSS") 18 S ECREF="RF" 19 ;order thru fills and refills; refill values 0 thru 11 20 ; Note: refill 0 = original fill 21 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 22 ; 23 ;order thru partial fills 24 S ECD=ECSD1,ECREF="P" 25 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 26 K ^TMP($J,"ECXDSS") 27 Q 28 ; 29 PRE2 ; get Prescription data 30 S ECDRG=+$P(^TMP($J,"ECXDSS",IEN,6),U) 31 I ECRFL>0&(ECREF="RF") D 32 .S ECQTY=^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,1),ECPRC=^(1.2) 33 I ECRFL>0&(ECREF="P") D 34 .S ECQTY=^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,.04),ECPRC=^(.042) 35 I 'ECRFL S ECQTY=^TMP($J,"ECXDSS",IEN,7),ECPRC=^(17) 36 D TEST 37 Q 38 ; 39 IVP ; entry point for IVP data 40 N ON,DFN,DA,SA 41 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 42 .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 43 ..S ECDRG=$P(EC,U,4) 44 ..S SA=$S($P(EC,U,8)]"":"A",$P(EC,U,9):"S",1:"") 45 ..I SA'="" D 46 ...I '$D(^TMP($J,SA,ECDRG)) S ^(ECDRG)=0,$P(^(ECDRG),U,2)=$P(EC,U,12) 47 ...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) 48 .;looped thru all DAs for this order - now put it together 49 .F SA="S","A" S ECDRG="" F S ECDRG=$O(^TMP($J,SA,ECDRG)) Q:ECDRG="" D 50 ..S ECQTY=$P(^TMP($J,SA,ECDRG),U),ECPRC=$P(^(ECDRG),U,2) 51 ..D TEST 52 K ^TMP($J,"A"),^TMP($J,"S") 53 Q 54 ; 55 UDP ; entry point for UDP data 56 N ECXJ,ECDATA 57 F S ECD=$O(^ECX(728.904,"A",ECD)) Q:'ECD Q:ECD>ECED Q:ECXERR D 58 .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 59 ..S DATA=^ECX(728.904,ECXJ,0) 60 ..S ECDRG=$P(DATA,U,4),ECQTY=$P(DATA,U,5),ECCOST=$P(DATA,U,8) 61 ..S ECPRC=ECCOST/ECQTY 62 ..D TEST 63 Q 64 ; 65 TEST ; retrieve NDC and PSNDF VA Product Code Entry and test for missing NDC or VA Prod Code 66 N ECTYPE,ECNDC,ECZERO,K,ECPROD,ECFCHAR,ECSTOCK,ECXPHA 67 S ECTYPE=0,ECXPHA="" 68 ; call pharmacy drug file (#50) api via ecxutl5 69 S ECXPHA=$$PHAAPI^ECXUTL5(ECDRG) 70 S ECNDC=$P(ECXPHA,U,3) 71 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) 72 S ECZERO=1,ECSTOCK=0 F K=1:1:$L(ECNDC) D Q:'ECZERO!ECSTOCK 73 .S ECFCHAR=$E(ECNDC,K) 74 .I ECFCHAR="S" S ECSTOCK=1 Q 75 .I ECFCHAR'=0 S ECZERO=0 Q 76 I ECZERO!ECSTOCK!(ECNDC["N/A") S ECTYPE=2 77 S ECPROD=$P(ECXPHA,U,6),ECPROD=$$RJ^XLFSTR(ECPROD,5,0) 78 I ECTYPE,'ECPROD S ECTYPE=3 79 I 'ECTYPE,'ECPROD S ECTYPE=1 80 I ECTYPE D FILE 81 Q 82 ; 83 FILE ; file record 84 N ECFKEY,ECGNAME,STATS,ECCOUNT,QTY,COST,ECCOST 85 ; create new record if none exists for this drug 86 I '$D(^TMP($J,ECDRG)) D 87 .S ECFKEY=ECPROD_ECNDC 88 .S ECGNAME=$P($G(^PSDRUG(ECDRG,0)),U) 89 .S ^TMP($J,ECDRG)=ECGNAME_U_ECFKEY_U_ECPRC_U_ECTYPE 90 .S ^TMP($J,ECDRG,0)="0^0^0" 91 ; add stats to record 92 S STATS=^TMP($J,ECDRG,0) 93 S ECCOUNT=$P(STATS,U),QTY=$P(STATS,U,2),COST=$P(STATS,U,3) 94 S ECCOUNT=ECCOUNT+1 95 S ECCOST=ECQTY*ECPRC 96 S ECQTY=ECQTY+QTY,ECCOST=ECCOST+COST 97 S ^TMP($J,ECDRG,0)=ECCOUNT_U_ECQTY_U_ECCOST 98 Q 99 ; 100 EXIT S ECXERR=1 Q 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
Note:
See TracChangeset
for help on using the changeset viewer.