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/ECXAPHA2.m

    r613 r623  
    1 ECXAPHA2        ;ALB/TMD-Pharmacy Extracts Unusual Volumes Report ; 10/18/07 2:10pm
    2         ;;3.0;DSS EXTRACTS;**40,49,84,104,105**;Dec 22, 1997;Build 70
    3         ;
    4 EN      ; entry point
    5         N COUNT,ECUNIT,LINE,ECDFN,ECD,ECDRG,ECDAY,ECDFN,ECQTY,ECUNIT,ECCOST,ECDS
    6         K ^TMP($J)
    7         S (COUNT,ECDS)=0,ECUNIT=""
    8         S ECD=ECSD1,ECED=ECED+.3
    9         S LINE=$S(ECXOPT=1:"PRE",ECXOPT=2:"IVP",ECXOPT=3:"UDP",1:"EXIT")
    10         D @LINE
    11         Q
    12         ;
    13 PRE     ; entry point for PRE data
    14         N ECRFL,ECRX,ECREF,ECDATA,ECDATA1,ECPRC,IEN
    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         I (ECREF="RF")&(ECRFL) D
    31         .S ECQTY=+^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,1)
    32         .S ECDS=+^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,1.1)
    33         .S ECPRC=^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,1.2)
    34         I (ECREF="RF")&('ECRFL) D
    35         .S ECQTY=+^TMP($J,"ECXDSS",IEN,7)
    36         .S ECDS=+^TMP($J,"ECXDSS",IEN,8)
    37         .S ECPRC=+^TMP($J,"ECXDSS",IEN,17)
    38         I ECREF="P" D
    39         .S ECQTY=+^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,.04)
    40         .S ECDS=+^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,.041)
    41         .S ECPRC=+^TMP($J,"ECXDSS",IEN,ECREF,ECRFL,.042)
    42         ;check to see if quantity>threshold
    43         I ECQTY>ECTHLD D
    44         .S ECDAY=ECD
    45         .S ECDFN=$P(^TMP($J,"ECXDSS",IEN,2),U)
    46         .S ECDRG=+$P(^TMP($J,"ECXDSS",IEN,6),U)
    47         .S ECCOST=ECQTY*ECPRC
    48         .D FILE Q:ECXERR
    49         Q
    50         ;
    51 IVP     ; entry point for IVP Data
    52         N DFN,ON,DA,SA,ECCOUNT
    53         F  S ECD=$O(^ECX(728.113,"A",ECD)),DFN=0 Q:'ECD  Q:ECD>ECED  Q:ECXERR  F  S DFN=$O(^ECX(728.113,"A",ECD,DFN)),ON=0  Q:'DFN  F  S ON=$O(^ECX(728.113,"A",ECD,DFN,ON)),DA=0 Q:'ON  K ^TMP($J,"A"),^("S") D  Q:ECXERR
    54         .F  S DA=$O(^ECX(728.113,"A",ECD,DFN,ON,DA)) Q:'DA  Q:ECXERR  I $D(^ECX(728.113,DA,0)) S EC=^(0) Q:ECXERR  D
    55         ..S ECDRG=$P(EC,U,4)
    56         ..S SA=$S($P(EC,U,8)]"":"A",$P(EC,U,9):"S",1:"")
    57         ..; set up new record for first DA for this drug
    58         ..I '$D(^TMP($J,SA,ECDRG)) D
    59         ...S ECQTY=+$S(SA="A":+$P(EC,U,7),SA="S":+$P(EC,U,9),1:0)
    60         ...S ECUNIT=$S(SA="A":$P(EC,U,8),SA="S":"ML",1:"")
    61         ...S ECCOST=$P(EC,U,12),ECDFN=DFN
    62         ...S ^TMP($J,SA,ECDRG)=ECUNIT_U_ECD_U_ECDFN_U_ECCOST_U_ECQTY
    63         ...S ^(ECDRG,1)=0
    64         ..; add to qty (0,1, or -1) to total
    65         ..S ^TMP($J,SA,ECDRG,1)=^TMP($J,SA,ECDRG,1)+$S($P(EC,U,6)=1:1,$P(EC,U,6)=4:0,1:-1)
    66         .; looped thru all DAs for this order - now check for unusual volumes
    67         .F SA="S","A" S ECDRG="" F  S ECDRG=$O(^TMP($J,SA,ECDRG)) Q:ECDRG=""  Q:ECXERR  D
    68         ..S ECQTY=$P(^TMP($J,SA,ECDRG),U,5),ECCOUNT=^(ECDRG,1)
    69         ..S ECQTY=ECQTY*ECCOUNT
    70         ..; check to see if quantity is outside of threshold range
    71         ..I (ECQTY>ECTHLD)!(ECQTY<-ECTHLD) D
    72         ...S ECUNIT=$P(^TMP($J,SA,ECDRG),U)
    73         ...S ECDAY=$P(^(ECDRG),U,2)
    74         ...S ECDFN=$P(^(ECDRG),U,3)
    75         ...S ECCOST=$P(^(ECDRG),U,4)*ECCOUNT
    76         ...D FILE Q:ECXERR
    77         K ^TMP($J,"A"),^("S")
    78         Q
    79         ;
    80 UDP     ; entry point for UDP data
    81         N ECXJ,ECDATA
    82         F  S ECD=$O(^ECX(728.904,"A",ECD)) Q:'ECD  Q:ECD>ECED  Q:ECXERR  D
    83         .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
    84         ..S DATA=^ECX(728.904,ECXJ,0),ECQTY=$P(DATA,U,5)
    85         ..;check to see if quantity>threshold
    86         ..I ECQTY>ECTHLD D
    87         ...S ECDFN=$P(DATA,U,2),ECDRG=$P(DATA,U,4),ECCOST=$P(DATA,U,8),ECDAY=ECD
    88         ...D FILE Q:ECXERR
    89         Q
    90         ;
    91 FILE    ; put records in temp file to print later
    92         N OK,ECXPAT,ECNAME,ECSSN,ECGNAME,ECNDC,ECPROD,ECFKEY,ECXPHA
    93         ; get demographics
    94         S OK=$$PAT^ECXUTL3(ECDFN,$P(ECD,"."),"1;",.ECXPAT)
    95         I 'OK Q
    96         S ECNAME=ECXPAT("NAME")
    97         S ECSSN=ECXPAT("SSN")
    98         S ECDAY=$E(ECDAY,4,5)_"/"_$E(ECDAY,6,7)
    99         ; get drug file data
    100         S ECXPHA="",ECXPHA=$$PHAAPI^ECXUTL5(ECDRG)
    101         S ECGNAME=$P(ECXPHA,U)
    102         S ECNDC=$P(ECXPHA,U,3)
    103         S ECNDC=$$RJ^XLFSTR($P(ECNDC,"-"),6,0)_$$RJ^XLFSTR($P(ECNDC,"-",2),4,0)_$$RJ^XLFSTR($P(ECNDC,"-",3),2,0)
    104         S ECNDC=$TR(ECNDC,"*",0)
    105         S ECPROD=$P(ECXPHA,U,6)
    106         S ECPROD=$$RJ^XLFSTR(ECPROD,5,0)
    107         S ECFKEY=ECPROD_ECNDC
    108         I ECXOPT'=2 S ECUNIT=$P(ECXPHA,U,8)
    109         ; file
    110         S ^TMP($J,ECFKEY,-ECQTY,ECDAY,ECSSN)=ECNAME_U_ECSSN_U_ECDAY_U_ECGNAME_U_ECFKEY_U_ECQTY_U_ECUNIT_U_"$"_$FNUMBER(ECCOST,",",2)_U_ECDS
    111         S COUNT=COUNT+1
    112         I COUNT#100=0 I $$S^ZTLOAD S (ZSTOP,ECXERR)=1
    113         Q
    114         ;
    115 EXIT    S ECXERR=1 Q
     1ECXAPHA2 ;ALB/TMD-Pharmacy Extracts Unusual Volumes Report ; 2/06/07 10:36am
     2 ;;3.0;DSS EXTRACTS;**40,49,84,104**;Dec 22, 1997;Build 8
     3 ;
     4EN ; entry point
     5 N COUNT,ECUNIT,LINE,ECDFN,ECD,ECDRG,ECDAY,ECDFN,ECQTY,ECUNIT,ECCOST,ECDS
     6 K ^TMP($J)
     7 S (COUNT,ECDS)=0,ECUNIT=""
     8 S ECD=ECSD1,ECED=ECED+.3
     9 S LINE=$S(ECXOPT=1:"PRE",ECXOPT=2:"IVP",ECXOPT=3:"UDP",1:"EXIT")
     10 D @LINE
     11 Q
     12 ;
     13PRE ; entry point for PRE data
     14 ; order through fills, refills and partial refills
     15 N ECRFL,ECRX,ECREF,ECDATA,ECDATA1,ECPRC
     16 S ECREF=1
     17 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  Q:ECXERR  F  S ECRFL=$O(^PSRX("AL",ECD,ECRX,ECRFL)) Q:ECRFL=""  Q:ECXERR  D PRE2
     18 S ECD=ECSD1,ECREF="P"
     19 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=""  Q:ECXERR  D PRE2
     20 Q
     21 ;
     22PRE2 ; get Prescription data
     23 S ECDATA=$G(^PSRX(ECRX,0))
     24 I ECRFL D
     25 .S ECDATA1=$G(^PSRX(ECRX,ECREF,ECRFL,0))
     26 .S ECQTY=+$P(ECDATA1,U,4)
     27 .S ECDS=+$P(ECDATA1,U,10)
     28 .S ECPRC=+$P(ECDATA1,U,11)
     29 I 'ECRFL D
     30 .S ECQTY=+$P(ECDATA,U,7)
     31 .S ECDS=+$P(ECDATA,U,8)
     32 .S ECPRC=+$P(ECDATA,U,17)
     33 ;check to see if quantity>threshold
     34 I ECQTY>ECTHLD D
     35 .S ECDAY=ECD
     36 .S ECDFN=$P(ECDATA,U,2)
     37 .S ECDRG=+$P(ECDATA,U,6)
     38 .S ECCOST=ECQTY*ECPRC
     39 .D FILE Q:ECXERR
     40 Q
     41 ;
     42IVP ; entry point for IVP Data
     43 N DFN,ON,DA,SA,ECCOUNT
     44 F  S ECD=$O(^ECX(728.113,"A",ECD)),DFN=0 Q:'ECD  Q:ECD>ECED  Q:ECXERR  F  S DFN=$O(^ECX(728.113,"A",ECD,DFN)),ON=0  Q:'DFN  F  S ON=$O(^ECX(728.113,"A",ECD,DFN,ON)),DA=0 Q:'ON  K ^TMP($J,"A"),^("S") D  Q:ECXERR
     45 .F  S DA=$O(^ECX(728.113,"A",ECD,DFN,ON,DA)) Q:'DA  Q:ECXERR  I $D(^ECX(728.113,DA,0)) S EC=^(0) Q:ECXERR  D
     46 ..S ECDRG=$P(EC,U,4)
     47 ..S SA=$S($P(EC,U,8)]"":"A",$P(EC,U,9):"S",1:"")
     48 ..; set up new record for first DA for this drug
     49 ..I '$D(^TMP($J,SA,ECDRG)) D
     50 ...S ECQTY=+$S(SA="A":+$P(EC,U,7),SA="S":+$P(EC,U,9),1:0)
     51 ...S ECUNIT=$S(SA="A":$P(EC,U,8),SA="S":"ML",1:"")
     52 ...S ECCOST=$P(EC,U,12),ECDFN=DFN
     53 ...S ^TMP($J,SA,ECDRG)=ECUNIT_U_ECD_U_ECDFN_U_ECCOST_U_ECQTY
     54 ...S ^(ECDRG,1)=0
     55 ..; add to qty (0,1, or -1) to total
     56 ..S ^TMP($J,SA,ECDRG,1)=^TMP($J,SA,ECDRG,1)+$S($P(EC,U,6)=1:1,$P(EC,U,6)=4:0,1:-1)
     57 .; looped thru all DAs for this order - now check for unusual volumes
     58 .F SA="S","A" S ECDRG="" F  S ECDRG=$O(^TMP($J,SA,ECDRG)) Q:ECDRG=""  Q:ECXERR  D
     59 ..S ECQTY=$P(^TMP($J,SA,ECDRG),U,5),ECCOUNT=^(ECDRG,1)
     60 ..S ECQTY=ECQTY*ECCOUNT
     61 ..; check to see if quantity is outside of threshold range
     62 ..I (ECQTY>ECTHLD)!(ECQTY<-ECTHLD) D
     63 ...S ECUNIT=$P(^TMP($J,SA,ECDRG),U)
     64 ...S ECDAY=$P(^(ECDRG),U,2)
     65 ...S ECDFN=$P(^(ECDRG),U,3)
     66 ...S ECCOST=$P(^(ECDRG),U,4)*ECCOUNT
     67 ...D FILE Q:ECXERR
     68 K ^TMP($J,"A"),^("S")
     69 Q
     70 ;
     71UDP ; entry point for UDP data
     72 N ECXJ,ECDATA
     73 F  S ECD=$O(^ECX(728.904,"A",ECD)) Q:'ECD  Q:ECD>ECED  Q:ECXERR  D
     74 .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
     75 ..S DATA=^ECX(728.904,ECXJ,0),ECQTY=$P(DATA,U,5)
     76 ..;check to see if quantity>threshold
     77 ..I ECQTY>ECTHLD D
     78 ...S ECDFN=$P(DATA,U,2),ECDRG=$P(DATA,U,4),ECCOST=$P(DATA,U,8),ECDAY=ECD
     79 ...D FILE Q:ECXERR
     80 Q
     81 ;
     82FILE ; put records in temp file to print later
     83 N OK,ECXPAT,ECNAME,ECSSN,ECGNAME,ECNDC,ECPROD,ECFKEY,ECXPHA
     84 ; get demographics
     85 S OK=$$PAT^ECXUTL3(ECDFN,$P(ECD,"."),"1;",.ECXPAT)
     86 I 'OK Q
     87 S ECNAME=ECXPAT("NAME")
     88 S ECSSN=ECXPAT("SSN")
     89 S ECDAY=$E(ECDAY,4,5)_"/"_$E(ECDAY,6,7)
     90 ; get drug file data
     91 S ECXPHA="",ECXPHA=$$PHAAPI^ECXUTL5(ECDRG)
     92 S ECGNAME=$P(ECXPHA,U)
     93 S ECNDC=$P(ECXPHA,U,3)
     94 S ECNDC=$$RJ^XLFSTR($P(ECNDC,"-"),6,0)_$$RJ^XLFSTR($P(ECNDC,"-",2),4,0)_$$RJ^XLFSTR($P(ECNDC,"-",3),2,0)
     95 S ECNDC=$TR(ECNDC,"*",0)
     96 S ECPROD=$P(ECXPHA,U,6)
     97 S ECPROD=$$RJ^XLFSTR(ECPROD,5,0)
     98 S ECFKEY=ECPROD_ECNDC
     99 I ECXOPT'=2 S ECUNIT=$P(ECXPHA,U,8)
     100 ; file
     101 S ^TMP($J,ECFKEY,-ECQTY,ECDAY,ECSSN)=ECNAME_U_ECSSN_U_ECDAY_U_ECGNAME_U_ECFKEY_U_ECQTY_U_ECUNIT_U_"$"_$FNUMBER(ECCOST,",",2)_U_ECDS
     102 S COUNT=COUNT+1
     103 I COUNT#100=0 I $$S^ZTLOAD S (ZSTOP,ECXERR)=1
     104 Q
     105 ;
     106EXIT S ECXERR=1 Q
Note: See TracChangeset for help on using the changeset viewer.