| 1 | PSODIR ;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 |  ;
 | 
|---|
| 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 |  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")
 | 
|---|
| 76 | INSD 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
 | 
|---|
| 84 | SINS(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 |  ;
 | 
|---|
| 95 | DIR ;
 | 
|---|
| 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
 | 
|---|
| 101 | DIRX K DIRUT,DTOUT,DUOUT,DIROUT,PSOX
 | 
|---|
| 102 |  Q
 | 
|---|
| 103 |  ;
 | 
|---|
| 104 | JUMP ;
 | 
|---|
| 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
 | 
|---|
| 112 | JUMPX S X="^"_X
 | 
|---|
| 113 |  Q
 | 
|---|