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/OUTPATIENT_PHARMACY-PSO-APSP-HUIP/PSODIR.m

    r613 r623  
    1 PSODIR  ;BHAM ISC/SAB - asks data for rx order entry ; 9/17/07 5:03pm
    2         ;;7.0;OUTPATIENT PHARMACY;**37,46,111,117,146,164,211,264,275**;DEC 1997;Build 8
    3         ;External reference PSDRUG( supported by DBIA 221
    4         ;External reference PS(50.7 supported by DBIA 2223
    5         ;External reference to VA(200 is supported by DBIA 10060
    6         ;----------------------------------------------------------------
    7         ;
    8 PROV(PSODIR)    ;
    9 PROVEN  ; Entry point for failed lookup
    10         K DIC,X,Y S:$G(PSOFDR)&($G(OR0)) DIC("B")=$P(^VA(200,$P($G(OR0),"^",5),0),"^")
    11         I $G(PSODIR("PROVIDER"))]"" S PSODIR("OLD VAL")=PSODIR("PROVIDER")
    12         S DIC="^VA(200,",DIC(0)="QEAM",PSODIR("FIELD")=0
    13         S DIC("W")="W ""     "",$P(^(""PS""),""^"",9)"
    14         S DIC("A")="PROVIDER: ",DIC("S")="I $D(^(""PS"")),$P(^(""PS""),""^""),$S('$P(^(""PS""),""^"",4):1,1:$P(^(""PS""),""^"",4)'<DT)"
    15         I $G(PSOTPBFG),$G(PSOFROM)="NEW" S DIC("S")=DIC("S")_",$P($G(^(""TPB"")),""^""),$P($G(^(""TPB"")),""^"",5)=0"
    16         S:$G(PSORX("PROVIDER NAME"))]"" DIC("B")=PSORX("PROVIDER NAME")
    17         D ^DIC K DIC
    18         I X[U,$L(X)>1 D:'$G(PSOEDIT) JUMP G PROVX
    19         I $D(DTOUT)!$D(DUOUT) S PSODIR("DFLG")=1 G PROVX
    20         I '$G(SPEED),Y=-1 G PROVEN
    21         Q:$G(SPEED)&(Y=-1)
    22         ;PSO*7*211; ADD CHECK FOR DEA# AND VA#
    23         I $P($G(PSODIR("CS")),"^",1)!($D(CLOZPAT)) I '$L($P($G(^VA(200,+Y,"PS")),U,2)),'$L($P($G(^VA(200,+Y,"PS")),U,3)) D  G PROVEN
    24         .W $C(7),!!,"Provider must have a DEA# or VA#"_$S($D(CLOZPAT):" to write prescriptions for clozapine.",1:""),!
    25         I $D(CLOZPAT),'$D(^XUSEC("YSCL AUTHORIZED",+Y)) D  G PROVEN
    26         .W $C(7),!!,"Provider must hold YSCL AUTHORIZED key to write prescriptions for clozapine.",!
    27         I '$G(PSODRUG("IEN")),'$G(PSORENW("DRUG IEN")) G NODRUG
    28         ;I '$G(SPEED),$P($G(^PSDRUG($S($G(PSODRUG("IEN")):PSODRUG("IEN"),1:PSORENW("DRUG IEN")),"CLOZ1")),"^")="PSOCLO1",$P(^VA(200,+Y,"PS"),"^",2)'?2U7N D  K Y,PSORX("PROVIDER NAME"),DIC("B") G PROVEN
    29         ;.W $C(7),!!,"Only providers with DEA numbers can write prescriptions for clozapine.",!
    30 NODRUG  S PSODIR("PROVIDER")=+Y
    31         S (PSODIR("PROVIDER NAME"),PSORX("PROVIDER NAME"))=$P(Y,"^",2)
    32         I $G(PSODIR("OLD VAL"))'=+Y K PSODIR("GENERIC PROVIDER"),PSODIR("COSIGNING PROVIDER")
    33         I $G(PSODIR("OLD VAL"))'=$G(PSODIR("PROVIDER")),$P(Y,"^",2)="PROVIDER,OTHER"!($P(Y,"^",2)="PROVIDER,OUTSIDE") D GENERIC
    34         I $P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",7),$P(^("PS"),"^",8) D COSIGN
    35         I $G(PSODIR("COSIGNING PROVIDER")),'$P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",7) K PSODIR("COSIGNING PROVIDER")
    36 PROVX   K X,Y
    37         Q
    38         ;
    39 GENERIC ;
    40         K DIR,DIC,PSODIR("GENERIC PROVIDER")
    41         S DIR(0)="52,30"
    42         D DIR G:PSODIR("DFLG")!PSODIR("FIELD") GENERICX
    43         S PSODIR("GENERIC PROVIDER")=Y
    44 GENERICX        K X,Y
    45         Q
    46         ;
    47 COSIGN  ;
    48         K DIC
    49         I '$G(PSODIR("COSIGNING PROVIDER")),$P($G(RX3),"^",3) S PSODIR("COSIGNING PROVIDER")=$P(RX3,"^",3) G COSIGN1
    50         I $P($G(RX3),"^",3),$P($G(RX3),"^",3)'=$P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",8) D
    51         .W !!,"Previous Co-Signing Provider: "_$P(^VA(200,$P(RX3,"^",3),0),"^")
    52         .S PSODIR("COSIGNING PROVIDER")=$S($P(RX3,"^",3)'=PSODIR("COSIGNING PROVIDER"):PSODIR("COSIGNING PROVIDER"),1:$P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",8))
    53 COSIGN1 S DIC(0)="QEAM",DIC="^VA(200,",DIC("B")=$S($G(PSODIR("COSIGNING PROVIDER")):$P(^VA(200,PSODIR("COSIGNING PROVIDER"),0),"^"),1:$P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",8))
    54         S DIC("S")="I $D(^(""PS"")),$P(^(""PS""),""^""),$S('$P(^(""PS""),""^"",4):1,1:$P(^(""PS""),""^"",4)'<DT)"
    55         S DIC("W")="W ""     "",$P(^(""PS""),""^"",9)",DIC("S")=DIC("S")_",'$P(^(""PS""),""^"",7)"
    56         S DIC("A")="COSIGNING PROVIDER: " D ^DIC K DIC
    57         I $D(DTOUT)!$D(DUOUT) S PSODIR("DFLG")=1 G COSIGNX
    58         S:+Y>0 PSODIR("COSIGNING PROVIDER")=+Y G:Y<0 COSIGN
    59 COSIGNX K X,Y
    60         Q
    61 DOSE(PSODIR)    ;add dosing info
    62         D DOSE1^PSOORED5(.PSODIR)
    63 EX      K PSODOSE,PSOSCH,DOSE,DOOR,SCH,VERB,NOUN,DOSEOR,ENT,PSORTE,DRUA,DIR,X,Y,DIRUT,RTE,ERTE,DD,INS1,SINS1
    64         Q
    65 INS(PSODIR)     ;patient instructions
    66         N DA K INS1,DD,DIR,DIRUT S D=0 F  S D=$O(PSODIR("SIG",D)) Q:'D  S DD=$G(DD)+1
    67         I $G(DD)=1 S PSODIR("INS")=$G(PSODIR("SIG",1)) G INSD
    68         ;PSO*7*275 remove check for PSOINSFL just check for multi line sig
    69         I $G(DD)>1 D  G EX
    70         .K ^TMP($J) S D=0 F  S D=$O(PSODIR("SIG",D)) Q:'D  S ^TMP($J,"SIG",D,0)=PSODIR("SIG",D)
    71         .S DWPK=2,DWLW=80,DIC="^TMP($J,""SIG""," D EN^DIWE K PSODIR("SIG")
    72         .S D=0 F  S D=$O(^TMP($J,"SIG",D)) Q:'D  S PSODIR("SIG",D)=^TMP($J,"SIG",D,0)
    73         .D EN^PSOFSIG(.PSODIR,1) K DWLW,D,DWPK,^TMP($J)
    74         I $G(PSOINSFL)=0 G INSD
    75         I $G(PSOFDR),$G(ORD),$P($G(^PS(52.41,+$G(ORD),"EXT")),"^")'="" G INSD
    76         I $G(PSODIR("INS"))']"",$G(^PS(50.7,PSODRUG("OI"),"INS"))]"" S DIR("B")=^PS(50.7,PSODRUG("OI"),"INS")
    77 INSD    S DIR(0)="52,114" S:$G(PSODIR("INS"))]"" DIR("B")=PSODIR("INS")
    78         D DIR G:$G(PSODIR("DFLG"))!(PSODIR("FIELD")) EX
    79         I X'="",X'="@" S PSODIR("INS")=Y D SIG^PSOHELP G INSD:'$D(X)
    80         I $G(INS1)]"" D EN^DDIOL($E(INS1,2,9999999)) S (PSODIR("SIG",1),PSODIR("SIG"))=$E(INS1,2,9999999)
    81         I X="@" K PSODIR("INS"),PSODIR("SIG")
    82         D EN^PSOFSIG(.PSODIR,1) I $O(SIG(0)) S SIGOK=1
    83         G EX
    84         Q
    85 SINS(PSODIR)    ;other lang. patient instructions
    86         K SINS1,DIR
    87         S DIR(0)="52,114.1" S:$G(PSODIR("SINS"))]"" DIR("B")=PSODIR("SINS")
    88         I $G(PSODIR("SINS"))']"",$G(^PS(50.7,PSODRUG("OI"),"INS1"))]"" S DIR("B")=^PS(50.7,PSODRUG("OI"),"INS1")
    89         D DIR G:$G(PSODIR("DFLG")) EX
    90         I X'="",X'="@" S PSODIR("SINS")=Y D SSIG^PSOHELP
    91         I $G(SINS1)]"" D EN^DDIOL($E(SINS1,2,9999999)) S PSODIR("SINS")=$E(SINS1,2,9999999)
    92         I X="@" K PSODIR("SINS")
    93         G EX
    94         Q
    95         ;
    96 DIR     ;
    97         S PSODIR("FIELD")=0
    98         G:$G(DIR(0))']"" DIRX
    99         D ^DIR K DIR,DIE,DIC,DA
    100         I $D(DUOUT)!($D(DTOUT))!($D(DIROUT)),$L($G(X))'>1 S PSODIR("DFLG")=1 G DIRX
    101         I X[U,$L(X)>1 D:'$G(PSOEDIT) JUMP
    102 DIRX    K DIRUT,DTOUT,DUOUT,DIROUT,PSOX
    103         Q
    104         ;
    105 JUMP    ;
    106         I $G(PSOEDIT)!($G(OR0)) S PSODIR("DFLG")=1 Q
    107         S X=$P(X,"^",2),DIC="^DD(52,",DIC(0)="QM" D ^DIC K DIC
    108         I Y=-1 S PSODIR("FIELD")=$G(PSODIR("FLD")) G JUMPX
    109         I $G(PSONEW1)=0 D JUMP^PSONEW1 G JUMPX
    110         I $G(PSOREF1)=0 D JUMP^PSOREF1 G JUMPX
    111         I $G(PSONEW3)=0 D JUMP^PSONEW3 G JUMPX
    112         I $G(PSORENW3)=0 D JUMP^PSORENW3 G JUMPX
    113 JUMPX   S X="^"_X
    114         Q
     1PSODIR ;BHAM ISC/SAB - asks data for rx order entry ;02/12/93 8:49
     2 ;;7.0;OUTPATIENT PHARMACY;**37,46,111,117,146,164,211,264**;DEC 1997;Build 19
     3 ;External reference PSDRUG( supported by DBIA 221
     4 ;External reference PS(50.7 supported by DBIA 2223
     5 ;External reference to VA(200 is supported by DBIA 10060
     6 ;----------------------------------------------------------------
     7 ;
     8PROV(PSODIR) ;
     9PROVEN ; Entry point for failed lookup
     10 K DIC,X,Y S:$G(PSOFDR)&($G(OR0)) DIC("B")=$P(^VA(200,$P($G(OR0),"^",5),0),"^")
     11 I $G(PSODIR("PROVIDER"))]"" S PSODIR("OLD VAL")=PSODIR("PROVIDER")
     12 S DIC="^VA(200,",DIC(0)="QEAM",PSODIR("FIELD")=0
     13 S DIC("W")="W ""     "",$P(^(""PS""),""^"",9)"
     14 S DIC("A")="PROVIDER: ",DIC("S")="I $D(^(""PS"")),$P(^(""PS""),""^""),$S('$P(^(""PS""),""^"",4):1,1:$P(^(""PS""),""^"",4)'<DT)"
     15 I $G(PSOTPBFG),$G(PSOFROM)="NEW" S DIC("S")=DIC("S")_",$P($G(^(""TPB"")),""^""),$P($G(^(""TPB"")),""^"",5)=0"
     16 S:$G(PSORX("PROVIDER NAME"))]"" DIC("B")=PSORX("PROVIDER NAME")
     17 D ^DIC K DIC
     18 I X[U,$L(X)>1 D:'$G(PSOEDIT) JUMP G PROVX
     19 I $D(DTOUT)!$D(DUOUT) S PSODIR("DFLG")=1 G PROVX
     20 I '$G(SPEED),Y=-1 G PROVEN
     21 Q:$G(SPEED)&(Y=-1)
     22 ;PSO*7*211; ADD CHECK FOR DEA# AND VA#
     23 I $P($G(PSODIR("CS")),"^",1)!($D(CLOZPAT)) I '$L($P($G(^VA(200,+Y,"PS")),U,2)),'$L($P($G(^VA(200,+Y,"PS")),U,3)) D  G PROVEN
     24 .W $C(7),!!,"Provider must have a DEA# or VA#"_$S($D(CLOZPAT):" to write prescriptions for clozapine.",1:""),!
     25 I $D(CLOZPAT),'$D(^XUSEC("YSCL AUTHORIZED",+Y)) D  G PROVEN
     26 .W $C(7),!!,"Provider must hold YSCL AUTHORIZED key to write prescriptions for clozapine.",!
     27 I '$G(PSODRUG("IEN")),'$G(PSORENW("DRUG IEN")) G NODRUG
     28 ;I '$G(SPEED),$P($G(^PSDRUG($S($G(PSODRUG("IEN")):PSODRUG("IEN"),1:PSORENW("DRUG IEN")),"CLOZ1")),"^")="PSOCLO1",$P(^VA(200,+Y,"PS"),"^",2)'?2U7N D  K Y,PSORX("PROVIDER NAME"),DIC("B") G PROVEN
     29 ;.W $C(7),!!,"Only providers with DEA numbers can write prescriptions for clozapine.",!
     30NODRUG S PSODIR("PROVIDER")=+Y
     31 S (PSODIR("PROVIDER NAME"),PSORX("PROVIDER NAME"))=$P(Y,"^",2)
     32 I $G(PSODIR("OLD VAL"))'=+Y K PSODIR("GENERIC PROVIDER"),PSODIR("COSIGNING PROVIDER")
     33 I $G(PSODIR("OLD VAL"))'=$G(PSODIR("PROVIDER")),$P(Y,"^",2)="PROVIDER,OTHER"!($P(Y,"^",2)="PROVIDER,OUTSIDE") D GENERIC
     34 I $P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",7),$P(^("PS"),"^",8) D COSIGN
     35 I $G(PSODIR("COSIGNING PROVIDER")),'$P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",7) K PSODIR("COSIGNING PROVIDER")
     36PROVX K X,Y
     37 Q
     38 ;
     39GENERIC ;
     40 K DIR,DIC,PSODIR("GENERIC PROVIDER")
     41 S DIR(0)="52,30"
     42 D DIR G:PSODIR("DFLG")!PSODIR("FIELD") GENERICX
     43 S PSODIR("GENERIC PROVIDER")=Y
     44GENERICX K X,Y
     45 Q
     46 ;
     47COSIGN ;
     48 K DIC
     49 I '$G(PSODIR("COSIGNING PROVIDER")),$P($G(RX3),"^",3) S PSODIR("COSIGNING PROVIDER")=$P(RX3,"^",3) G COSIGN1
     50 I $P($G(RX3),"^",3),$P($G(RX3),"^",3)'=$P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",8) D
     51 .W !!,"Previous Co-Signing Provider: "_$P(^VA(200,$P(RX3,"^",3),0),"^")
     52 .S PSODIR("COSIGNING PROVIDER")=$S($P(RX3,"^",3)'=PSODIR("COSIGNING PROVIDER"):PSODIR("COSIGNING PROVIDER"),1:$P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",8))
     53COSIGN1 S DIC(0)="QEAM",DIC="^VA(200,",DIC("B")=$S($G(PSODIR("COSIGNING PROVIDER")):$P(^VA(200,PSODIR("COSIGNING PROVIDER"),0),"^"),1:$P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",8))
     54 S DIC("S")="I $D(^(""PS"")),$P(^(""PS""),""^""),$S('$P(^(""PS""),""^"",4):1,1:$P(^(""PS""),""^"",4)'<DT)"
     55 S DIC("W")="W ""     "",$P(^(""PS""),""^"",9)",DIC("S")=DIC("S")_",'$P(^(""PS""),""^"",7)"
     56 S DIC("A")="COSIGNING PROVIDER: " D ^DIC K DIC
     57 I $D(DTOUT)!$D(DUOUT) S PSODIR("DFLG")=1 G COSIGNX
     58 S:+Y>0 PSODIR("COSIGNING PROVIDER")=+Y G:Y<0 COSIGN
     59COSIGNX K X,Y
     60 Q
     61DOSE(PSODIR) ;add dosing info
     62 D DOSE1^PSOORED5(.PSODIR)
     63EX K PSODOSE,PSOSCH,DOSE,DOOR,SCH,VERB,NOUN,DOSEOR,ENT,PSORTE,DRUA,DIR,X,Y,DIRUT,RTE,ERTE,DD,INS1,SINS1
     64 Q
     65INS(PSODIR) ;patient instructions
     66 N DA K INS1,DD,DIR,DIRUT S D=0 F  S D=$O(PSODIR("SIG",D)) Q:'D  S DD=$G(DD)+1
     67 I $G(DD)=1 S PSODIR("INS")=$G(PSODIR("SIG",1)) G INSD
     68 I ($G(PSOINSFL)=1&($G(DD)>1))!($G(PSOFDR)&($G(ORD))&($P($G(^PS(52.41,+$G(ORD),"EXT")),"^")'="")&($G(DD)>1)) D  G EX
     69 .K ^TMP($J) S D=0 F  S D=$O(PSODIR("SIG",D)) Q:'D  S ^TMP($J,"SIG",D,0)=PSODIR("SIG",D)
     70 .S DWPK=2,DWLW=80,DIC="^TMP($J,""SIG""," D EN^DIWE K PSODIR("SIG")
     71 .S D=0 F  S D=$O(^TMP($J,"SIG",D)) Q:'D  S PSODIR("SIG",D)=^TMP($J,"SIG",D,0)
     72 .D EN^PSOFSIG(.PSODIR,1) K DWLW,D,DWPK,^TMP($J)
     73 I $G(PSOINSFL)=0 G INSD
     74 I $G(PSOFDR),$G(ORD),$P($G(^PS(52.41,+$G(ORD),"EXT")),"^")'="" G INSD
     75 I $G(PSODIR("INS"))']"",$G(^PS(50.7,PSODRUG("OI"),"INS"))]"" S DIR("B")=^PS(50.7,PSODRUG("OI"),"INS")
     76INSD S DIR(0)="52,114" S:$G(PSODIR("INS"))]"" DIR("B")=PSODIR("INS")
     77 D DIR G:$G(PSODIR("DFLG"))!(PSODIR("FIELD")) EX
     78 I X'="",X'="@" S PSODIR("INS")=Y D SIG^PSOHELP G INSD:'$D(X)
     79 I $G(INS1)]"" D EN^DDIOL($E(INS1,2,9999999)) S (PSODIR("SIG",1),PSODIR("SIG"))=$E(INS1,2,9999999)
     80 I X="@" K PSODIR("INS"),PSODIR("SIG")
     81 D EN^PSOFSIG(.PSODIR,1) I $O(SIG(0)) S SIGOK=1
     82 G EX
     83 Q
     84SINS(PSODIR) ;other lang. patient instructions
     85 K SINS1,DIR
     86 S DIR(0)="52,114.1" S:$G(PSODIR("SINS"))]"" DIR("B")=PSODIR("SINS")
     87 I $G(PSODIR("SINS"))']"",$G(^PS(50.7,PSODRUG("OI"),"INS1"))]"" S DIR("B")=^PS(50.7,PSODRUG("OI"),"INS1")
     88 D DIR G:$G(PSODIR("DFLG")) EX
     89 I X'="",X'="@" S PSODIR("SINS")=Y D SSIG^PSOHELP
     90 I $G(SINS1)]"" D EN^DDIOL($E(SINS1,2,9999999)) S PSODIR("SINS")=$E(SINS1,2,9999999)
     91 I X="@" K PSODIR("SINS")
     92 G EX
     93 Q
     94 ;
     95DIR ;
     96 S PSODIR("FIELD")=0
     97 G:$G(DIR(0))']"" DIRX
     98 D ^DIR K DIR,DIE,DIC,DA
     99 I $D(DUOUT)!($D(DTOUT))!($D(DIROUT)),$L($G(X))'>1 S PSODIR("DFLG")=1 G DIRX
     100 I X[U,$L(X)>1 D:'$G(PSOEDIT) JUMP
     101DIRX K DIRUT,DTOUT,DUOUT,DIROUT,PSOX
     102 Q
     103 ;
     104JUMP ;
     105 I $G(PSOEDIT)!($G(OR0)) S PSODIR("DFLG")=1 Q
     106 S X=$P(X,"^",2),DIC="^DD(52,",DIC(0)="QM" D ^DIC K DIC
     107 I Y=-1 S PSODIR("FIELD")=$G(PSODIR("FLD")) G JUMPX
     108 I $G(PSONEW1)=0 D JUMP^PSONEW1 G JUMPX
     109 I $G(PSOREF1)=0 D JUMP^PSOREF1 G JUMPX
     110 I $G(PSONEW3)=0 D JUMP^PSONEW3 G JUMPX
     111 I $G(PSORENW3)=0 D JUMP^PSORENW3 G JUMPX
     112JUMPX S X="^"_X
     113 Q
Note: See TracChangeset for help on using the changeset viewer.