Ignore:
Timestamp:
Dec 4, 2009, 12:11:15 AM (14 years ago)
Author:
George Lilly
Message:

revised back to 6/30/08 version

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
     1ECXDRUG2 ;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 ;
     4EN ; 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 ;
     12PRE ; 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 ;
     21PRE2 ; 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 ;
     31IVP ; 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 ;
     47UDP ; 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 ;
     57TEST ; 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 ;
     75FILE ; 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 ;
     92EXIT S ECXERR=1 Q
Note: See TracChangeset for help on using the changeset viewer.