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

PSGOEE.m

Go to the documentation of this file.
  1. PSGOEE ;BIR/CML3-EDIT ACTIVE OR NON-VERIFIED ORDERS ;29-May-2012 14:30;PLS
  1. ;;5.0; INPATIENT MEDICATIONS ;**4,7,29,47,64,58,82,91,1004,110,111,112,142,1015**;16 DEC 97;Build 62
  1. ;
  1. ; Reference to ^PS(55 is supported by DBIA# 2191.
  1. ; Reference to ^PSSLOCK is supported by DBIA# 2789.
  1. ;
  1. ; Modified - IHS/CIA/PLS - 10/14/05 - Line UPD+10
  1. ;
  1. D NOW^%DTC S PSGDT=% K PSGEFN,PSGOEEF S PSGOEEF=0 I PSGORD["A"!(PSGORD["O") G ACT
  1. 531 ; edit orders in 53.1
  1. ENF ;
  1. D EN2^PSGOEEW
  1. K PSJACEPT D EDLOOP G:'$G(PSJACEPT) OUT
  1. I $G(PSGOEENO) D
  1. . N PSGOEENO S PSGOEENO=1 D NEW
  1. E D
  1. . N PSGOEENO S PSGOEENO=0 D UPD
  1. I $G(PSGOEAV) D ACT1 Q
  1. D DONE1
  1. S PSGOEEF=0,PSJORD=PSGORD D GETUD^PSJLMGUD(PSGP,PSGORD),ENSFE^PSGOEE0(PSGP,PSGORD)
  1. Q
  1. ACT ;
  1. D EN2^PSGOEEW,EDLOOP G:'$G(PSJACEPT) OUT
  1. I $G(PSGOEENO) D
  1. . N PSGOEENO S PSGOEENO=1 D NEW
  1. E D
  1. . N PSGOEENO S PSGOEENO=0 D UPD
  1. S:$D(PSGOEF)!$G(PSGOEENO) PSGCANFL=-1
  1. ACT1 ;I 'PSGOEAV,PSJSYSL>1 S $P(@($S(PSGORD["U":"^PS(55,"_PSGP_",5,",1:"^PS(53.1,")_+PSGORD_",7)"),"^",1,2)=PSGDT_"^"_$E("D",PSGOEENO)_"E",PSGTOL=2,PSGUOW=DUZ,PSGTOO=PSGORD'["U"+1,DA=+PSGORD D ENL^PSGVDS
  1. D DONE1
  1. S PSGOEEF=0 D GETUD^PSJLMGUD(PSGP,PSGORD),ENSFE^PSGOEE0(PSGP,PSGORD) D:PSGOEAV UNL^PSSLOCK(PSGP,PSGORD)
  1. Q
  1. EDIT ;
  1. D FULL^VALM1
  1. W ! S PSGOEER="" F Q=1:1 S Q1=$P(Y,",",Q) Q:'Q1 S X=$P($T(@(PSGOEEG_Q1)),";",3),PSGOEER=PSGOEER_X_";",PSGOEEF(+X)=Q
  1. S LIMIT=$L(PSGOEER,";")-1,(PSGDEF,PSGOEE)=0 F S PSGOEE=PSGOEE+1 Q:PSGOEE>LIMIT I +$P(PSGOEER,";",PSGOEE)=101 S PSGDEF=1
  1. S PSGOEER=$E(PSGOEER,1,$L(PSGOEER)-1),(MSG,PSGOEE)=0 F S PSGOEE=PSGOEE+1 Q:PSGOEE>$L(PSGOEER,";") S F1=$S(PSGOEEG=3:53.1,1:55.06) I 'PSGDEF!((PSGDEF)&(+$P(PSGOEER,";",PSGOEE)'=2)) D @$P(PSGOEER,";",PSGOEE) Q:'PSGOEE
  1. Q
  1. EDLOOP ; Continue prompting for fields to edit.
  1. D:$G(Y) EDIT
  1. D ENNOU^PSGOEE0 I '$G(PSGOEENO),DR="" S VALMBCK="R" Q
  1. K VALMSG
  1. I '$G(PSGOEENO),$G(PSGPDNX) D CKDT
  1. I $G(PSGOEENO) D
  1. .S VALMSG="This change will cause a new order to be created." D GTSTATUS,CHKDD,CKDT
  1. .S PSGEBN=$$ENNPN^PSGMI(DUZ),PSGLIN=$$ENDD^PSGMI(PSGDT)_U_$$ENDTC^PSGMI(PSGDT)
  1. D CHK^PSGOEV("^^"_PSGMR_"^^^^"_PSGST,PSGPDRG_U_PSGDO,PSGSCH_U_PSGSD_"^^"_PSGFD)
  1. K VALMBCK,PSJACEPT,PSGPDNX D EN^VALM("PSJU LM ACCEPT") Q:'$G(PSJACEPT)
  1. I $G(PSGS0XT)="D",'$G(PSGS0Y) I ((",P,R,")'[(","_$G(PSGST)_",")) D Q
  1. .S PSJACEPT=0 W !!,"This is a 'DAY OF THE WEEK' schedule and MUST have admin times." D PAUSE^VALM1
  1. I $G(PSGOEENO) S PSJNOO=$$ENNOO^PSJUTL5("E")
  1. D K1 S PSJACEPT=$S($G(PSJNOO)<0:0,1:1)
  1. S VALMBCK=$S('PSJACEPT:"R",'PSGOEAV:"R",1:"Q")
  1. Q
  1. CHKDD ;*** Check inactive Dispense drug within the order.
  1. D CHKDRG^PSGOE2
  1. Q
  1. CKDT ; Check if new start/stop dates should be calculated.
  1. S PSGS0Y=$S($D(PSGS0Y):PSGS0Y,1:$G(PSGAT))
  1. I ('$G(PSGNEWDT)&(PSGSD=$G(PSGOSD))&(PSGFD=$G(PSGOFD)))!($G(PSGOST)'=PSGST)!(PSGSCH'=$G(PSGOSCH))!($G(PSGPDNX)) D
  1. .N PSGOES S PSGOES=1,PSGOFD=PSGFD D ^PSGNE3 S PSGSD=PSGNESD,PSGSDN=$$ENDD^PSGMI(PSGNESD)_U_$$ENDTC^PSGMI(PSGNESD),PSGFD=PSGNEFD,PSGFDN=$$ENDD^PSGMI(PSGNEFD)_U_$$ENDTC^PSGMI(PSGNEFD),PSGNEWDT=1
  1. .I $D(PSGOFD),PSGOFD]"",PSGFD'=PSGOFD S PSGOEEF(25)=1
  1. .I $D(PSGOSD),PSGOSD]"",PSGSD'=PSGOSD S PSGOEEF(10)=1
  1. Q
  1. NEW3 ;
  1. ;S:PSGOEAV PSGOEAV="0^1"
  1. NEW ;
  1. W !,"...discontinuing original order..."
  1. I PSGORD["P" S PSJCOM=+$P($G(^PS(53.1,+PSGORD,.2)),"^",8) I PSJCOM D NEW^PSJCOM1 Q
  1. ;DC and Unlock order.
  1. S PSGEDIT="DE" D ENOR^PSGOECS,UNL^PSSLOCK(PSGP,PSGORD) K PSGEDIT
  1. W !!," ...creating new order..." W:'PSGOEAV "(you will now work on this new order)"
  1. S PSGS0Y=PSGAT,PSGNESD=PSGSD,PSGNEFD=PSGFD,PSGOEPR=PSGPR,PSGPDRG=PSGPD,PSGPDRGN=PSGPDN,PSGOEE="E"
  1. S PSGOORD=PSGORD D ^PSGOETO K PSGOEOS
  1. I PSGOORD["U" S $P(^PS(55,PSGP,5,+PSGOORD,0),"^",26,27)=PSGORD_"^E"
  1. E S $P(^PS(53.1,+PSGOORD,0),"^",26,27)=PSGORD_"^E"
  1. I 'PSGOEAV,($G(PSGORD)["P"),'$G(^PS(53.1,+PSGORD,2.5)),$G(^PS(53.1,+PSGORD,0)) D
  1. . N DUR S DUR=$$GETDUR^PSJLIVMD(PSGP,PSGORD,$S(PSGORD["P":"P",1:5),1) I DUR]"" K DA,DR,DIE S DIE="^PS(53.1,",DA=+PSGORD,DR="116////"_DUR D ^DIE
  1. I PSGOEAV,+PSJSYSU=3,'$D(PSGOES) D EN^PSGPEN(PSGORD),UNL^PSSLOCK(PSGP,PSGORD) Q
  1. S PSJORD=PSGORD,PSGACT=$$ENACTION^PSGOE1(PSGP,PSGORD)
  1. Q
  1. UPD ;
  1. K DA W !!,"...updating order..."
  1. I PSGORD["P" S PSJCOM=+$P($G(^PS(53.1,+PSGORD,.2)),"^",8) I PSJCOM D UPD^PSJCOM Q
  1. ; Set trigger for FIELD (12) Dispense Drug to print a updated pick list.
  1. I PSGORD["U",$D(^PS(53.45,PSJSYSP,2,1,0)),$D(^PS(55,PSGP,5,+PSGORD,1,1,0)) D
  1. .N PSJX12,PSJF12 S PSJF12=0
  1. .F PSJX12=0:1 S PSJX12=$O(^PS(53.45,PSJSYSP,2,PSJX12)) Q:+PSJX12=0 S:$G(^PS(53.45,PSJSYSP,2,PSJX12,0))'=$G(^PS(55,PSGP,5,+PSGORD,1,PSJX12,0)) PSJF12=1
  1. .S:PSJF12 ^PS(55,"AUE",PSGP,+PSGORD)=""
  1. N TMP,PSGSIF S TMP=PSGOEENO N PSGOEENO S PSGOEENO=TMP
  1. N II F II=1:1:$L($G(DR),";") I $E($P($G(DR),";",II),1,7)="122////" S PSGSIF=$P(PSGSI,"^",2),PSGSI=$P(PSGSI,"^") Q
  1. I $G(PSJCOM),$G(PSJCOMSI) K PSJCOMSI N PSJCHILD,PSJOEORD S PSJOEORD=0 F S PSJOEORD=$O(^PS(55,"ACX",PSJCOM,PSJOEORD)) Q:'PSJOEORD D
  1. . S PSJCHILD=0 F S PSJCHILD=$O(^PS(55,"ACX",PSJCOM,PSJOEORD,PSJCHILD)) Q:'PSJCHILD D
  1. .. Q:PSJCHILD=PSGORD N DR,DA,DIE,ORD S DR=$S(PSJCHILD["V":"31////"_$G(P("OPI")),1:"8////"_$G(PSGSI)) S DR=DR_";"_$S(PSJCHILD["V":146,1:122)_"////"_+$G(PSGSIF)
  1. .. I $E(DR)'="*" S DA=+PSJCHILD,DIE=$S(PSJCHILD["U":"^PS(55,"_PSGP_",5,",1:"^PS(53.1,") S:DIE["^PS(55," DA(1)=PSGP D ^DIE W "." D EN1^PSJHL2(PSGP,"XX",+PSJCHILD_"U")
  1. I $E(DR)'="*" S DA=+PSGORD,DIE=$S(PSGORD["U":"^PS(55,"_PSGP_",5,",1:"^PS(53.1,") S:DIE["^PS(55," DA(1)=PSGP D ^DIE W "."
  1. F Q=1,3 K @(PSGOEEWF_Q_")") S %X="^PS(53.45,"_PSJSYSP_","_$S(Q=1:2,1:1)_",",%Y=PSGOEEWF_Q_"," K @(PSGOEEWF_Q_")") D %XY^%RCR W "."
  1. S $P(@(PSGOEEWF_"1,0)"),"^",2)=$S(PSGORD["U":55.07,1:53.11)_"P"
  1. ; Naked reference on the line below refers to full reference using indirection to either ^PS(55 or ^PS(53.1,
  1. S ND=$G(@($S(PSGORD["U":"^PS(55,"_PSGP_",5,",1:"^PS(53.1,")_+PSGORD_",0)")) I $P(ND,"^",21) S ORIFN=$P(ND,"^",21),ND1=$G(^(.2)),ND2=$G(^(2)) W !,"...updating OE/RR..." D EN1^PSJHL2(PSGP,"XX",PSGORD)
  1. I $$ENACTION^PSGOE1(PSGP,PSGORD)["V" S VALMBCK="R"
  1. I PSJSYSL,PSJSYSL<3 S $P(@($S(PSGORD["U":"^PS(55,"_PSGP_",5,",1:"^PS(53.1,")_+PSGORD_",7)"),"^",1,2)=PSGDT_"^"_$E("D",PSGOEENO)_"E",PSGTOL=2,PSGUOW=DUZ,PSGTOO=PSGORD'["U"+1,DA=+PSGORD D ENL^PSGVDS
  1. D CALLBOP ;IHS/CIA/PLS - 10/14/05 - Call to Automated Dispensing System
  1. Q
  1. ; Call Automated Dispensing System if present
  1. CALLBOP ;
  1. I $$PATCH^XPDUTL("BOP*1.0*1") D
  1. .D EDIT^BOPCP2
  1. .D ^BOPSD
  1. Q
  1. OUT ;
  1. D ABORT K PSGNEWDT S PSGCANFL=1 D GETUD^PSJLMGUD(PSGP,PSGORD),ENSFE^PSGOEE0(PSGP,PSGORD),INIT^PSJLMUDE(PSGP,PSGORD)
  1. Q
  1. DONE ;
  1. I PSGORD["P",'$D(PSGOEF),PSGSCH]"",$O(^PS(53.1,+PSGORD,1,0)) D ENF^PSGOEE0
  1. DONE1 ;
  1. I PSGORD["U" S X=+PSGORD L -^PS(55,PSGP,5,X)
  1. E L -^PS(53.1,+PSGORD)
  1. K ^PS(53.45,+PSJSYSP,1),^(2)
  1. I '$D(PSGOEF) K PSGSD,PSGSCH,PSGST,PSGFD
  1. K DA,DIE,DIR,DP,DR,DRG,ND,ND0,ND1,ND2,ORIFN,PSGAL,PSGALEF,PSGAT,PSGOEE,PSGOEEF,PSGOEEG,PSGOEEWF,PSGEFN,PSGTOL,PSGTOO,PSGUOW,XREF,PSGEFN,PSGMR,PSGMRN,PSGOROE1,PSGPD,PSGPDN,PSGSI,PSGPR,PSGSM,PSGHSM,PSGSTN,PSGSDN,PSGFDN,PSGPRN
  1. K PSGDO,PSGOEENO Q
  1. K1 ;
  1. K BACK,F1,F2,PSGF2,MSG,PSGEFN,PSGNEWDT,PSGOEEF,PSGOEEND,PSGOPD,PSGOPDN,PSGOMR,PSGOMRN,PSGOSCH,PSGOSI,PSGOPR,PSGOSM,PSGOHSM,PSGOSD,PSGOFD,PSGOST,PSGOPRN,PSGOSTN,PSGOSDN,PSGOFDN,PSGODO,PSGPDRG,PSGPDRGN,PSGOEER
  1. Q
  1. ;
  1. ABORT ; Display no change message and pause.
  1. S (PSGDI,PSGDFLG)='$$DDOK^PSGOE2(PSGOEEWF_"1,",+$G(@(PSGOEEWF_".2)")))
  1. S PSGPFLG='$$OIOK^PSGOE2(+$G(@(PSGOEEWF_".2)")))
  1. W !!,$C(7),"No changes made to this order." D PAUSE^VALM1 K PSGOEEF S PSGOEEF=0
  1. Q
  1. ;
  1. GTSTATUS ; Determine status of new order and set LM title.
  1. S PSGSTAT=$S($P($G(PSJSYSP0),U,9):"ACTIVE",1:"NON-VERIFIED")
  1. S VALM("TITLE")=PSGSTAT_" UNIT DOSE "_$S(PSGSTAT="PENDING":"("_PSGPRIO_")",1:"")
  1. Q
  1. FIELDS ;
  1. 31 ;;101^PSGOE8;PSGOPD;PSGPD;101;1
  1. 32 ;;109^PSGOE8;PSGODO;PSGDO;109;PSGODO]""
  1. 33 ;;10^PSGOE81;PSGOSD;PSGSD;10;0
  1. 34 ;;3^PSGOE8;PSGOMR;PSGMR;3;1
  1. 35 ;;25^PSGOE81;PSGOFD;PSGFD;25;0
  1. 36 ;;7^PSGOE8;PSGOST;PSGST;7;0
  1. 37 ;;5^PSGOE82;PSGOSM;PSGSM;5;0
  1. 38 ;;26^PSGOE8;PSGOSCH;PSGSCH;26;1
  1. 39 ;;39^PSGOE81;PSGOAT;PSGAT;39;0
  1. 310 ;;1^PSGOE82;PSGOPR;PSGPR;1;1
  1. 311 ;;8^PSGOE81;PSGOSI;PSGSI;8;0
  1. 312 ;;2^PSGOE82;;;2;0
  1. 313 ;;40^PSGOE82;;;40;0
  1. 51 ;;101^PSGOE9;PSGOPD;PSGPD;101;1
  1. 52 ;;109^PSGOE9;PSGODO;PSGDO;109;PSGODO]""
  1. 53 ;;10^PSGOE91;PSGOSD;PSGSD;10;1
  1. 54 ;;3^PSGOE9;PSGOMR;PSGMR;3;1
  1. 55 ;;34^PSGOE91;PSGOFD;PSGFD;34;1
  1. 56 ;;7^PSGOE9;PSGOST;PSGST;7;0
  1. 57 ;;5^PSGOE92;PSGOSM;PSGSM;5;0
  1. 58 ;;26^PSGOE9;PSGOSCH;PSGSCH;26;1
  1. 59 ;;41^PSGOE91;PSGOAT;PSGAT;41;0
  1. 510 ;;1^PSGOE92;PSGOPR;PSGPR;1;1
  1. 511 ;;8^PSGOE91;PSGOSI;PSGSI;8;0
  1. 512 ;;2^PSGOE92;;;2;0
  1. 513 ;;15^PSGOE92;;;15;0