Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSODIR

PSODIR.m

Go to the documentation of this file.
  1. PSODIR ;BHAM ISC/SAB - asks data for rx order entry ;Oct 20, 2022@17:03
  1. ;;7.0;OUTPATIENT PHARMACY;**37,46,111,117,146,164,211,264,275,391,372,416,422,504,457,572,587,441,682,545**;DEC 1997;Build 270
  1. ;External reference PSDRUG( supported by DBIA 221
  1. ;External reference PS(50.7 supported by DBIA 2223
  1. ;External reference to VA(200 is supported by DBIA 10060
  1. ; Reference to ^XTV(8991.9) in ICR #7002
  1. ; Reference to ^VA(200.5321) in ICR #7000
  1. ;----------------------------------------------------------------
  1. ;
  1. PROV(PSODIR) ;
  1. PROVEN ; Entry point for failed lookup
  1. K DIC,X,Y S:$G(PSOFDR)&($G(OR0)) DIC("B")=$P(^VA(200,$P($G(OR0),"^",5),0),"^")
  1. I '$D(PSODIR("CS")),$D(PSODRUG("DEA")) D
  1. .N DEA S PSODIR("CS")=0 F DEA=1:1 Q:$E(PSODRUG("DEA"),DEA)="" I $E(+PSODRUG("DEA"),DEA)>1,$E(+PSODRUG("DEA"),DEA)<6 S PSODIR("CS")=1
  1. I $G(PSODIR("PROVIDER"))]"" S PSODIR("OLD VAL")=PSODIR("PROVIDER")
  1. S DIC="^VA(200,",DIC(0)="QEAM",PSODIR("FIELD")=0
  1. S DIC("W")="W "" "",$P($G(^(""PS"")),""^"",9)"
  1. S DIC("A")="PROVIDER: ",DIC("S")="I $D(^(""PS"")),$P(^(""PS""),""^""),$S('$P(^(""PS""),""^"",4):1,1:$P(^(""PS""),""^"",4)'<DT)"
  1. I $G(PSOTPBFG),$G(PSOFROM)="NEW" S DIC("S")=DIC("S")_",$P($G(^(""TPB"")),""^""),$P($G(^(""TPB"")),""^"",5)=0"
  1. ;p682 change condition for setting DIC("B"); do not overwrite
  1. ;S:$G(PSORX("PROVIDER NAME"))]"" DIC("B")=PSORX("PROVIDER NAME")
  1. S DIC("B")=$S($G(DIC("B"))]"":DIC("B"),1:$G(PSORX("PROVIDER NAME")))
  1. D ^DIC K DIC
  1. I X[U,$L(X)>1 D:'$G(PSOEDIT) JUMP G PROVX
  1. I $D(DTOUT)!$D(DUOUT) S PSODIR("DFLG")=1 G PROVX
  1. I '$G(SPEED),Y=-1 G PROVEN
  1. Q:$G(SPEED)&(Y=-1)
  1. L +^VA(200,+Y):1 I '$T D G PROVEN ;572
  1. . N PSOED S PSOED=$P($G(^VA(200,+Y,1)),"^",8)
  1. . I PSOED W $C(7),!!,"Provider is being edited by "_$P($G(^VA(200,PSOED,0)),"^") Q ;587
  1. . W $C(7),!!,"Provider is being edited by an unknown user or has been deleted"
  1. L -^VA(200,+Y) ;572
  1. ;PSO*7*211; ADD CHECK FOR DEA# AND VA#
  1. ;*545; DEA/VA selection
  1. I $$DETOX^PSSOPKI($G(PSODRUG("IEN"))) N DETX S DETX="" D G:'$L(DETX) PROVEN
  1. . S DETX=$$DETOX^XUSER(+Y) I '$L(DETX) W $C(7),!!,"Provider must have a DETOX# to order this drug.",! Q
  1. . S PSORX("DETX")=DETX
  1. I $P($G(PSODIR("CS")),"^",1)!($D(CLOZPAT)) N NDEA D I $L($P($G(NDEA),"^"))<3 G PROVEN
  1. . N SDEA S SDEA=$$DRGSCH()
  1. . N PSOPROVD S PSOPROVD=+Y S NDEA=$$SLDEA(PSOPROVD,.PSORX) Q
  1. . I NDEA=2 W $C(7),!!,"Provider not authorized to write Federal Schedule "_SDEA_" prescriptions." D Q
  1. . . W !,"Please contact the provider.",!
  1. . W $C(7),!!,"Provider must have a valid DEA# or VA# to write prescriptions for this drug.",!
  1. . Q
  1. ;PSO*7.0*391; Added check for DETOX#
  1. I $$DETOX^PSSOPKI($G(PSODRUG("IEN"))),$$DETOX^XUSER(+Y)="" W $C(7),!!,"Provider must have a DETOX# to order this drug.",! G PROVEN
  1. I $D(CLOZPAT),'$D(^XUSEC("YSCL AUTHORIZED",+Y)) D G PROVEN
  1. .W $C(7),!!,$$CLKEYWRN^PSOCLUTL,! ; PSO*7*457
  1. I '$G(PSODRUG("IEN")),'$G(PSORENW("DRUG IEN")) G NODRUG
  1. NODRUG S PSODIR("PROVIDER")=+Y
  1. S (PSODIR("PROVIDER NAME"),PSORX("PROVIDER NAME"))=$P(Y,"^",2)
  1. I $G(PSODIR("OLD VAL"))'=+Y K PSODIR("GENERIC PROVIDER"),PSODIR("COSIGNING PROVIDER")
  1. I $G(PSODIR("OLD VAL"))'=$G(PSODIR("PROVIDER")),$P(Y,"^",2)="PROVIDER,OTHER"!($P(Y,"^",2)="PROVIDER,OUTSIDE") D GENERIC
  1. I $P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",7),$P(^("PS"),"^",8) D COSIGN
  1. I $G(PSODIR("COSIGNING PROVIDER")),'$P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",7) K PSODIR("COSIGNING PROVIDER")
  1. PROVX K X,Y
  1. Q
  1. ;
  1. DRGSCH() ; determine the drug schedule
  1. N ND3,SCH
  1. S SCH="",ND3=$P($G(^PSDRUG(PSODRUG("IEN"),"ND")),"^",3) S:+ND3 SCH=$$GET1^DIQ(50.68,ND3,19,"I")
  1. I +SCH>0!($G(PSODRUG("DEA"))="") Q SCH
  1. I "^4^5^"[+PSODRUG("DEA") Q +PSODRUG("DEA")
  1. Q $S($G(PSODRUG("DEA"))["A":+PSODRUG("DEA"),1:+PSODRUG("DEA")_"n")
  1. ;
  1. GENERIC ;
  1. K DIR,DIC,PSODIR("GENERIC PROVIDER")
  1. S DIR(0)="52,30"
  1. D DIR G:PSODIR("DFLG")!PSODIR("FIELD") GENERICX
  1. S PSODIR("GENERIC PROVIDER")=Y
  1. GENERICX K X,Y
  1. Q
  1. ;
  1. COSIGN ;
  1. K DIC
  1. I '$G(PSODIR("COSIGNING PROVIDER")),$P($G(RX3),"^",3) S PSODIR("COSIGNING PROVIDER")=$P(RX3,"^",3) G COSIGN1
  1. I $P($G(RX3),"^",3),$P($G(RX3),"^",3)'=$P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",8) D
  1. .W !!,"Previous Co-Signing Provider: "_$P(^VA(200,$P(RX3,"^",3),0),"^")
  1. .S PSODIR("COSIGNING PROVIDER")=$S($P(RX3,"^",3)'=PSODIR("COSIGNING PROVIDER"):PSODIR("COSIGNING PROVIDER"),1:$P(^VA(200,PSODIR("PROVIDER"),"PS"),"^",8))
  1. 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))
  1. S DIC("S")="I $D(^(""PS"")),$P(^(""PS""),""^""),$S('$P(^(""PS""),""^"",4):1,1:$P(^(""PS""),""^"",4)'<DT)"
  1. S DIC("W")="W "" "",$P(^(""PS""),""^"",9)",DIC("S")=DIC("S")_",'$P(^(""PS""),""^"",7)"
  1. S DIC("A")="COSIGNING PROVIDER: " D ^DIC K DIC
  1. I $D(DTOUT)!$D(DUOUT) S PSODIR("DFLG")=1 G COSIGNX
  1. S:+Y>0 PSODIR("COSIGNING PROVIDER")=+Y G:Y<0 COSIGN
  1. COSIGNX K X,Y
  1. Q
  1. DOSE(PSODIR) ;add dosing info
  1. N PSODOSNW S PSODOSNW=1
  1. D DOSE1^PSOORED5(.PSODIR)
  1. EX K PSODOSE,PSOSCH,DOSE,DOOR,SCH,VERB,NOUN,DOSEOR,ENT,PSORTE,DRUA,DIR,X,Y,DIRUT,RTE,ERTE,DD,INS1,SINS1
  1. Q
  1. INS(PSODIR) ;patient instructions
  1. N DA
  1. K INS1,DD,DIR,DIRUT S D=0 F S D=$O(PSODIR("SIG",D)) Q:'D S DD=$G(DD)+1
  1. I $G(DD)=1 S PSODIR("INS")=$G(PSODIR("SIG",1)) G INSD
  1. ;PSO*7*275 remove check for PSOINSFL just check for multi line sig
  1. I $G(DD)>1 D G EX
  1. .K ^TMP($J) S D=0 F S D=$O(PSODIR("SIG",D)) Q:'D S ^TMP($J,"SIG",D,0)=PSODIR("SIG",D)
  1. .S DWPK=2,DWLW=80,DIC="^TMP($J,""SIG""," D EN^DIWE K PSODIR("SIG")
  1. .S D=0 F S D=$O(^TMP($J,"SIG",D)) Q:'D S PSODIR("SIG",D)=^TMP($J,"SIG",D,0)
  1. .D:'$P($G(^PS(55,PSODFN,"LAN")),"^") INDICAT^PSODIR(.PSODIR)
  1. .D EN^PSOFSIG(.PSODIR,1) K DWLW,D,DWPK,^TMP($J)
  1. I $G(PSOINSFL)=0 G INSD
  1. I $G(PSOFDR),$G(ORD),$P($G(^PS(52.41,+$G(ORD),"EXT")),"^")'="" G INSD
  1. I $G(PSODIR("INS"))']"",$G(^PS(50.7,PSODRUG("OI"),"INS"))]"",'$D(PSODIR("FLD",114)) S (DIR("B"),PSOOEINS)=^PS(50.7,PSODRUG("OI"),"INS") G INSD ;*422
  1. S (DIR("B"),PSOOEINS)=$G(PSODIR("SIG",1)) ;*422
  1. INSD S DIR(0)="52,114" S:$G(PSODIR("INS"))]"" DIR("B")=PSODIR("INS")
  1. K PSODIR("DFLG")
  1. D DIR
  1. I $G(PSODIR("DFLG")) S (PSODIR("INS"),PSODIR("SIG"),PSODIR("SIG",1))=$G(PSOOEINS),PSODIR("SINS")=$G(PSOOSINS) D EN^PSOFSIG(.PSODIR,0)
  1. G:$G(PSODIR("DFLG"))!(PSODIR("FIELD")) EX
  1. I X'="",X'="@" S PSODIR("INS")=Y D SIG^PSOHELP G INSD:'$D(X)
  1. I $G(INS1)]"" D EN^DDIOL($E(INS1,2,9999999)) S (PSODIR("SIG",1),PSODIR("SIG"))=$E(INS1,2,9999999)
  1. I X="@" S PSODELINS=1 D DELINS^PSOHELP3 I $G(PSODELINS) S (PSODIR("FLD",114),PSODIR("FLD",114.1))="" K PSODIR("INS"),PSODIR("SIG"),PSODIR("SINS") ;*422
  1. ;*441 - indication
  1. I '$P($G(^PS(55,PSODFN,"LAN")),"^") D INDICAT^PSODIR(.PSODIR) K DIRUT,DTOUT,DUOUT,DIROUT
  1. I '$G(PSOEDIT),$G(PSODIR("DFLG")) G EX
  1. D EN^PSOFSIG(.PSODIR,1) I $O(SIG(0)) S SIGOK=1
  1. G EX
  1. Q
  1. SINS(PSODIR) ;other lang. patient instructions
  1. K SINS1,DIR
  1. S DIR(0)="52,114.1" S:$G(PSODIR("SINS"))]"" DIR("B")=PSODIR("SINS")
  1. I $G(PSODIR("SINS"))']"",$G(^PS(50.7,PSODRUG("OI"),"INS1"))]"",'$D(PSODIR("FLD",114)),$G(PSOOEINS)]"" S (DIR("B"),PSOOSINS)=^PS(50.7,PSODRUG("OI"),"INS1")
  1. D DIR I $G(PSODIR("DFLG")) S (PSODIR("INS"),PSODIR("SIG"),PSODIR("SIG",1))=$G(PSOOEINS),PSODIR("SINS")=$G(PSOOSINS) D EN^PSOFSIG(.PSODIR,0) G EX
  1. I X'="",X'="@" S PSODIR("SINS")=Y D SSIG^PSOHELP
  1. I $G(SINS1)]"" D EN^DDIOL($E(SINS1,2,9999999)) S PSODIR("SINS")=$E(SINS1,2,9999999)
  1. I X="@" S PSODELINS=2 D DELINS^PSOHELP3 I $G(PSODELINS) S (PSODIR("FLD",114),PSODIR("FLD",114.1))="" K PSODIR("INS"),PSODIR("SIG"),PSODIR("SINS") D EN^PSOFSIG(.PSODIR,1) ;*422
  1. G EX
  1. Q
  1. ;
  1. DIR ;
  1. S PSODIR("FIELD")=0
  1. G:$G(DIR(0))']"" DIRX
  1. D ^DIR K DIR,DIE,DIC,DA
  1. I $D(DUOUT)!($D(DTOUT))!($D(DIROUT)),$L($G(X))'>1 S PSODIR("DFLG")=1 G DIRX
  1. I X[U,$L(X)>1 D:'$G(PSOEDIT) JUMP
  1. DIRX K DIRUT,DTOUT,DUOUT,DIROUT,PSOX
  1. Q
  1. ;
  1. JUMP ;
  1. I $G(PSOEDIT)!($G(OR0)) S PSODIR("DFLG")=1 Q
  1. S X=$P(X,"^",2),DIC="^DD(52,",DIC(0)="QM" D ^DIC K DIC
  1. I Y=-1 S PSODIR("FIELD")=$G(PSODIR("FLD")) G JUMPX
  1. I $G(PSONEW1)=0 D JUMP^PSONEW1 G JUMPX
  1. I $G(PSOREF1)=0 D JUMP^PSOREF1 G JUMPX
  1. I $G(PSONEW3)=0 D JUMP^PSONEW3 G JUMPX
  1. I $G(PSORENW3)=0 D JUMP^PSORENW3 G JUMPX
  1. JUMPX S X="^"_X
  1. Q
  1. ;
  1. INDICAT(PSODIR) ;*441
  1. N INDLST,DIR,SEL,I,INDCAT,CHK,CNT K DUOUT,DTOUT,DIROUT,DIRUT
  1. S (CHK,CNT,PSODIR("DFLG"),PSODIR("FIELD"))=0
  1. D INDCATN^PSS50P7(PSODRUG("OI"),"PSODIND")
  1. I '$O(^TMP($J,"PSODIND",0)) S Y=99 G INDICAT1
  1. S (SEL,I)="" F S I=$O(^TMP($J,"PSODIND",I)) Q:I="" D
  1. . S INDCAT=$P($G(^TMP($J,"PSODIND",I)),"^") Q:'$L(INDCAT)
  1. . I $G(PSODIR("IND"))]"",INDCAT=PSODIR("IND") S CHK=1
  1. . S CNT=CNT+1,INDLST(CNT)=INDCAT,DIR("L",CNT)=" "_CNT_" "_INDCAT S:CNT=1 SEL=CNT_":"_INDCAT S:CNT>1 SEL=SEL_";"_CNT_":"_INDCAT
  1. W !!,"INDICATION:"
  1. K DIRUT,DTOUT,DUOUT,DIROUT
  1. S DIR(0)="SO^"_SEL_";99:Free Text entry",DIR("A")="Select INDICATION from the list"
  1. S DIR("L")=" 99 Free Text entry"
  1. S:CHK DIR("B")=PSODIR("IND") S:'CHK&($G(PSODIR("IND"))]"") DIR("B")=99
  1. S DIR("?")="Answer must be 3-40 characters in length."
  1. S DIR("?",1)="This field contains the Indication For Use."
  1. D ^DIR
  1. I $D(DUOUT)!($D(DTOUT)) S PSODIR("DFLG")=1 Q
  1. I $G(PSOEDIT)!($G(PSOFDR))!($G(PSOCOPY)),X="" S:$G(PSODIR("IND"))]"" Y=99 G INDICAT1
  1. I X="@" N KF S KF=0 D:$G(PSOEDIT)!($G(PSOFDR))!($G(PSOCOPY)) K:'KF PSODIR("IND"),PSODIR("INDF"),PSODIR("INDO") Q
  1. . S PSODELINS=2,KF=1 D DELIND
  1. . I $G(PSODELINS) S (PSODIR("FLD",128),PSODIR("FLD",129),PSODIR("FLD",130))="" K PSODIR("IND"),PSODIR("INDF"),PSODIR("INDO")
  1. I Y=99 S:CHK PSODIR("IND")="" G INDICAT1
  1. I Y S PSODIR("IND")=Y(0) S:$G(PSOEDIT) PSODIR("FLD",128)=Y(0)
  1. INDICAT1 ;
  1. I Y=99 N I,J,IND,DA D G:$G(Y)=99 INDICAT1 Q:$G(PSODIR("DFLG"))!(X="")
  1. . K X,Y,DIRUT,DTOUT,DUOUT,DIROUT,DIR
  1. . S:$G(PSODIR("IND"))]"" DIR("B")=$G(PSODIR("IND"))
  1. . S DIR(0)="52,128",DIR("A")="INDICATION" D ^DIR
  1. . I $D(DUOUT)!($D(DTOUT)) S PSODIR("DFLG")=1 Q
  1. . I X="" S PSODIR("FLD",128)="" K PSODIR("IND") Q
  1. . I X="@" N KF S KF=0 D:$G(PSOEDIT)!($G(PSOFDR))!($G(PSOCOPY)) K:'KF PSODIR("IND"),PSODIR("INDF"),PSODIR("INDO") Q
  1. . . S PSODELINS=2,KF=1 D DELIND
  1. . . I $G(PSODELINS) S (PSODIR("FLD",128),PSODIR("FLD",129),PSODIR("FLD",130))="" K PSODIR("IND"),PSODIR("INDF"),PSODIR("INDO")
  1. . I $L(X," ")=1,$L(X)>32 W $C(7),!?5,"MAX OF 32 CHARACTERS ALLOWED WITHOUT SPACES.",! S Y=99 Q
  1. . S IND="" F I=1:1:$L(X," ") Q:I="" S J=$P(X," ",I) D I '$D(X) S Y=99 Q
  1. . .I $L(J)>32 W $C(7),!?5,"MAX OF 32 CHARACTERS ALLOWED BETWEEN SPACES.",! K X Q
  1. . .S:J]"" IND=$S($G(IND)]"":IND_" ",1:"")_J
  1. . Q:$G(Y)=99
  1. . S IND=$$UPPER^PSOSIG(IND),PSODIR("IND")=IND
  1. . I $L(IND) S:$G(PSOEDIT) PSODIR("FLD",128)=IND
  1. I $G(PSODIR("IND"))]"" D
  1. . W !,PSODIR("IND"),!
  1. . N DIR,PSOZ S PSOZ=$$GET1^DIQ(59.7,1,96),DIR("B")=$S(PSOZ]"":PSOZ,1:"YES")
  1. . S DIR(0)="Y",DIR("A")="Copy INDICATION into the Sig" D ^DIR
  1. . I $G(DIRUT) S PSODIR("DFLG")=1 Q
  1. . I Y>0 S PSODIR("INDF")=1 S:$G(PSOEDIT) PSODIR("FLD",129)=1
  1. . I 'Y S PSODIR("INDF")=0 S:$G(PSOEDIT) PSODIR("FLD",129)=""
  1. Q
  1. ;
  1. SIND(PSODIR) ;
  1. S (PSODONE,PSODELINS)=0
  1. F D Q:PSODONE
  1. . D INDICAT^PSODIR(.PSODIR)
  1. . I $G(PSODIR("DFLG")) D S PSODONE=1 Q
  1. . . I $G(PSODIR("IND"))="",$G(PSODIR("INDO"))="" Q
  1. . . I $G(PSODIR("IND"))]"",$G(PSODIR("INDO"))]"" Q
  1. . . I $G(PSODIR("IND"))]"",$G(PSODIR("INDO"))="" S PSODIR("IND")="" Q
  1. . . I $G(PSODIR("IND"))="",$G(PSODIR("INDO"))]"" S PSODIR("INDO")=""
  1. . Q:$G(PSODELINS)
  1. . D OIND
  1. . I $G(PSODIR("DFLG")) D S PSODONE=1 Q
  1. . . I $G(PSODIR("IND"))="",$G(PSODIR("INDO"))="" Q
  1. . . I $G(PSODIR("IND"))]"",$G(PSODIR("INDO"))]"" Q
  1. . . I $G(PSODIR("IND"))]"",$G(PSODIR("INDO"))="" S PSODIR("IND")="" Q
  1. . . I $G(PSODIR("IND"))="",$G(PSODIR("INDO"))]"" S PSODIR("INDO")=""
  1. . I $G(PSODIR("IND"))="",$G(PSODIR("INDO"))="" S PSODONE=1 Q
  1. . I $G(PSODIR("IND"))]"",$G(PSODIR("INDO"))]"" S PSODONE=1 Q
  1. . I $G(PSODIR("IND"))]"",$G(PSODIR("INDO"))="" W $C(7),!!?5,"OTHER INDICATION REQUIRED",! H 2 Q
  1. . I $G(PSODIR("IND"))="",$G(PSODIR("INDO"))]"" W $C(7),!!?5,"INDICATION REQUIRED",! H 2
  1. D EN^PSOFSIG(.PSODIR,1)
  1. Q
  1. ;
  1. OIND ;
  1. I '$D(^TMP($J,"PSODIND","OTH")) S Y=99 G OINDI1
  1. N SEL,I,INDCAT,CHK,CNT
  1. S (CHK,CNT,PSODIR("DFLG"))=0
  1. S (SEL,I)="" F S I=$O(^TMP($J,"PSODIND","OTH",I)) Q:I="" D
  1. . S INDCAT=$P($G(^TMP($J,"PSODIND","OTH",I)),"^") Q:'$L(INDCAT)
  1. . I $G(PSODIR("INDO"))]"",INDCAT=PSODIR("INDO") S CHK=1
  1. . S CNT=CNT+1,INDLST(CNT)=INDCAT,DIR("L",CNT)=" "_CNT_" "_INDCAT S:CNT=1 SEL=CNT_":"_INDCAT S:CNT>1 SEL=SEL_";"_CNT_":"_INDCAT
  1. W !!,"OTHER LANGUAGE INDICATION:"
  1. K DIRUT,DTOUT,DUOUT,DIROUT
  1. S DIR(0)="SO^"_SEL_";99:Free Text entry",DIR("A")="Select OTHER LANGUAGE INDICATION from the list"
  1. S DIR("L")=" 99 Free Text entry"
  1. S:CHK DIR("B")=PSODIR("INDO") S:'CHK&($G(PSODIR("INDO"))]"") DIR("B")=99
  1. S DIR("?")="Answer must be 3-40 characters in length."
  1. S DIR("?",1)="This field contains the Other Language Indication For Use."
  1. D ^DIR
  1. I $D(DUOUT)!($D(DTOUT)) S PSODIR("DFLG")=1 Q
  1. I '$G(PSOEDIT),X="" Q
  1. I $G(PSOEDIT),X="" S:$G(PSODIR("INDO"))]"" Y=99 G OINDI1
  1. I X="@" D:$G(PSOEDIT)!($G(PSOFDR))!($G(PSOCOPY)) Q ;K:'$G(PSOEDIT) PSODIR("IND"),PSODIR("INDF"),PSODIR("INDO") Q
  1. . S PSODELINS=1 D DELIND
  1. . I $G(PSODELINS) S (PSODIR("FLD",128),PSODIR("FLD",129),PSODIR("FLD",130))="" K PSODIR("IND"),PSODIR("INDF"),PSODIR("INDO")
  1. I Y=99 S:CHK PSODIR("INDO")="" G OINDI1
  1. I Y S PSODIR("INDO")=Y(0) S:$G(PSOEDIT) PSODIR("FLD",130)=Y(0)
  1. OINDI1 ;
  1. I Y=99 N I,J,IND,DA D G:$G(Y)=99 OINDI1 Q:$G(PSODIR("DFLG"))!(X="")
  1. . K X,Y,DIRUT,DTOUT,DUOUT,DIROUT,DIR
  1. . S:$G(PSODIR("INDO"))]"" DIR("B")=PSODIR("INDO")
  1. . S DIR(0)="52,130",DIR("A")="OTHER LANGUAGE INDICATION" D ^DIR
  1. . I $D(DUOUT)!($D(DTOUT)) S PSODIR("DFLG")=1 Q
  1. . I X="" S PSODIR("FLD",130)="" K PSODIR("INDO") Q
  1. . I X="@" D:$G(PSOEDIT)!($G(PSOCOPY)) K:'$G(PSOEDIT) PSODIR("IND"),PSODIR("INDF"),PSODIR("INDO") Q
  1. . . S PSODELINS=1 D DELIND
  1. . . I $G(PSODELINS) S (PSODIR("FLD",128),PSODIR("FLD",129),PSODIR("FLD",130))="" K PSODIR("IND"),PSODIR("INDF"),PSODIR("INDO")
  1. . I $L(X," ")=1,$L(X)>32 W $C(7),!?5,"MAX OF 32 CHARACTERS ALLOWED WITHOUT SPACES.",! S Y=99 Q
  1. . S IND="" F I=1:1:$L(X," ") Q:I="" S J=$P(X," ",I) D I '$D(X) S Y=99 Q
  1. . .I $L(J)>32 W $C(7),!?5,"MAX OF 32 CHARACTERS ALLOWED BETWEEN SPACES.",! K X Q
  1. . .S:J]"" IND=$S($G(IND)]"":IND_" ",1:"")_J
  1. . Q:$G(Y)=99
  1. . S IND=$$UPPER^PSOSIG(IND),PSODIR("INDO")=IND
  1. . I $L(IND) S:$G(PSOEDIT) PSODIR("FLD",130)=IND
  1. Q
  1. DELIND ;*441-IND-CONFIRM INDICATION DELETION
  1. I '$P($G(^PS(55,PSODFN,"LAN")),"^") Q
  1. N X,Y,DIR,DIRUT
  1. W $C(7),!!?5,"ANY DATA ENTERED FOR "_$S($G(PSODELINS)=2:"OTHER INDICATION",1:"INDICATION")
  1. W $C(7),!?5,"WILL ALSO BE DELETED.",!
  1. S DIR(0)="Y",DIR("B")="NO",DIR("A")="Continue with Deletion" D ^DIR
  1. S:$G(DIRUT) Y=0
  1. S (PSODONE,PSODELINS)=Y
  1. Q
  1. ;
  1. ;*545; DEA selection
  1. SLDEA(PROVIEN,PSORX,DFLTDEA,PSODRIEN) ; DEA Selection
  1. Q $$SLDEA^PSODIR5(PROVIEN,.PSORX,$G(DFLTDEA),$G(PSODRIEN))