source: FOIAVistA/tag/r/INPATIENT_MEDICATIONS-PSJ-PSIV-PSG--PSGW/PSJHLV.m@ 636

Last change on this file since 636 was 628, checked in by George Lilly, 14 years ago

initial load of FOIAVistA 6/30/08 version

File size: 4.4 KB
Line 
1PSJHLV ;BIR/CML3-VERIFY (MAKE ACTIVE) ORDERS ;4/8/99 08:16
2 ;;5.0; INPATIENT MEDICATIONS ;**39,42,78,92,127,133**;16 DEC 97
3 ;
4 ; Reference to ^PS(50.7 is supported by DBIA# 2180.
5 ; Reference to ^PS(55 is supported by DBIA# 2191.
6 ; Reference to ^PSDRUG is supported by DBIA# 2192.
7 ; Reference to ^PSSLOCK is supported by DBIA# 2789.
8 ;
9EN(PSJHLDFN,PSGORD) ;
10VFY ; change status, move to 55, and change label record
11 N PSJPWD,VAIP,DFN,PSGP,PSGORDP S (DFN,PSGP)=PSJHLDFN D IN5^VADPT S:VAIP(5)]"" PSJPWD=+VAIP(5) G:VAIP(5)']"" DONE
12 I $P($G(^PS(53.1,+PSGORD,0)),U,4)'="U" D IV Q
13 N PSJSYSP S PSJSYSP=+NURSEACK
14 N PSGDT D NOW^%DTC S PSGDT=%
15 S CHK=0 D DDCHK G:CHK DONE
16 D CHK($G(^PS(53.1,+PSGORD,0)),$G(^(.2)),$G(^(2)))
17 G:CHK DONE
18 S PSGORDP=PSGORD
19 ;
20 N PSJRPND0 S PSJRPND0=^PS(53.1,+PSGORD,0) I $P(PSJRPND0,U,24)="R" D
21 .N PSGORDR,PSJPRIO,PSJSCHED,FILE55N0
22 .S PSGORDR=$P(PSJRPND0,U,25)
23 .Q:'$$LS^PSSLOCK(PSGP,PSGORDR)
24 .N OEORD,OOEORD,FILE55,FILE55N0,FILE55N2 S FILE55="^PS(55,"_PSJHLDFN_$S($P(PSJRPND0,U,4)="U":",5,",1:",""IV"","),FILE55N0=FILE55_+PSGORDR_",0)",FILE55N2=FILE55_+PSGORDR_",2)"
25 .S OEORD=$P(PSJRPND0,U,21) I PSGORDR S OOEORD=$P(@FILE55N0,"^",21) I OEORD'=OOEORD N PSGSD S PSGSD=$P(@FILE55N2,"^",2) D
26 ..D EXPOE^PSGOER(PSJHLDFN,PSGORD,+$$LASTREN^PSJLMPRI(PSJHLDFN,PSGORD))
27 .K DA,DR,DIE S PSGORDP=PSGORD,DIE="^PS(53.1,",DA=+PSGORD,DR="28////A;104////@" W "." D ^DIE
28 .D START^PSGOTR(PSGORD,+PSGORDR) I OEORD D
29 ..K DA,DR,DIE S DA(1)=PSJHLDFN,DA=+PSGORDR,DIE=FILE55,DR=$S(DIE["IV":110,1:66)_"////"_+OEORD D ^DIE S DIE=FILE55_+PSGORDR_",0)",$P(@DIE,U,21)=OEORD
30 ..D EN1^PSJHL2(PSJHLDFN,"SC",PSGORDR),UNL^PSSLOCK(PSGP,PSGORDR)
31 ..S PSGORD=PSGORDR
32 ;
33 S DIE="^PS(53.1,",DA=+PSGORD,DR="28////A" D ^DIE I $P(PSJRPND0,U,24)'="R" D ^PSGOT
34 S DA=+PSGORD,DA(1)=PSJHLDFN,PSGAL("C")=22010
35 D ^PSGAL5 S VND4=$G(^PS(55,PSJHLDFN,5,DA,4)) I $P(PSJRPND0,U,24)="R",$P(VND4,U,4) D
36 .K DA,DIE,DR I $P(VND4,U,4)<$$LASTREN^PSJLMPRI(PSJHLDFN,PSGORDP) S DIE="^PS(55,"_PSJHLDFN_",5,",DA(1)=PSJHLDFN,DA=+PSGORD,DR="18////@;19////@" D ^DIE
37 .S $P(VND4,U,3,4)=""
38 S $P(VND4,"^",10)=1
39 S:$P(VND4,"^",15)&'$P(VND4,"^",16) $P(VND4,"^",15)="" S:$P(VND4,"^",18)&'$P(VND4,"^",19) $P(VND4,"^",18)="" S:$P(VND4,"^",22)&'$P(VND4,"^",23) $P(VND4,"^",22)="" S $P(VND4,"^",1,2)=+NURSEACK_"^"_PSGDT,^PS(55,PSJHLDFN,5,+PSGORD,4)=VND4
40 I '$P(VND4,U,9) S ^PS(55,"APV",PSJHLDFN,+PSGORD)=""
41 I '$P(VND4,U,10) S ^PS(55,"ANV",PSJHLDFN,+PSGORD)=""
42 I $P(VND4,U,10) K ^PS(55,"ANV",PSJHLDFN,+PSGORD)
43 D:$D(PSGORDP) ACTLOG^PSGOEV(PSGORDP,PSJHLDFN,PSGORD)
44 D EN1^PSJHL2(PSJHLDFN,"SC",+PSGORD_"U")
45 Q
46 ;
47IV ;
48 NEW DRG,DRGI,DRGN,DRGT,FIL,ON,ON55,P,PSJORD,VADM,VAIN
49 S ON=PSGORD,PSIVCHG=0,PSJSYSU=1
50 D INP^VADPT
51 D GT531^PSIVORFA(PSJHLDFN,PSGORD),ACTIVE^PSIVORC2
52 K PSIVCHG,PSJIVORF,PSJORF,PSJORIFN,PSJORL,PSJORNP,PSJPINIT,PSJSYSL,PSJSYSU,PSJSYSW,PSJSYSW0
53 Q
54DONE ;
55 K CHK,DA,DIE,DRGF,DP,DR,ND,PSGAL,PSGODA,PSGPD,VND4 Q
56 ;
57CHK(ND,DRG,ND2) ; checks for data in required fields
58 ; Input: ND - ^(PS(53.1,PSGORD,0)
59 ; DRG - ^(.2)
60 ; ND2 - ^(2)
61 S CHK="" I DRG,$D(^PS(50.7,+DRG,0))
62 E S CHK=1
63 I ND="" S CHK=CHK_23
64 E S CHK=CHK_$S($P(ND,"^",3):"",1:2)_$S($P(ND,"^",7)]"":"",1:3)
65 ;The naked reference on the line below refers to the variable ND
66 ;which is ^PS(53.1,PSGORD,0).
67 I ND2="" S CHK=CHK_$S('$D(^(0)):4,$P(^(0),"^",7)="OC":"",1:4)_56
68 E S CHK=CHK_$S($P(ND2,"^")]"":"",ND="":4,$P(ND,"^",7)="OC":"",1:4)_$S($P(ND2,"^",2):"",1:5)_$S($P(ND2,"^",4):"",1:6)
69 I $$CHECK^PSGOE8(PSJSYSP),$P(DRG,U,2)="" S CHK=CHK_8
70 K PSGDFLG,PSGPFLG S PSGDI=0
71 S:'$$OIOK^PSGOE2(+DRG) PSGPFLG=1
72 Q
73 ;
74DDCHK ; dispense drug check
75 S DRGF="^PS("_$S(PSGORD["P":"53.1,"_+PSGORD,1:"55,"_PSJHLDFN_",5,"_+PSGORD)_",",CHK=$S('$O(@(DRGF_"1,0)")):7,1:0)
76 S PSGPD=$G(@(DRGF_".2)"))
77 S CHK=$S('$$DDOK(DRGF_"1,",PSGPD):7,1:0)
78 Q
79 ;
80DDOK(PSJF,OI) ;Check to be sure all dispense drugs that are active in the
81 ;order are valid.
82 ; Input: PSJF - File root of the order including all but the IEN of
83 ; the drug. (EX "^PS(53.1,X,1,")
84 ; OI - IEN of the order's orderable item
85 ; Output: 1 - all active DD's in the order are valid
86 ; 0 - no DD's active DD's or at least one active is invalid
87 N DDCNT,ND,PSJ,X S (X,DDCNT)=0
88 I '$O(@(PSJF_"0)")) Q 1
89 F PSJ=0:0 S PSJ=$O(@(PSJF_PSJ_")")) Q:'PSJ!X S ND=$G(@(PSJF_PSJ_",0)")) D
90 .I $P(ND,U,3),($P(ND,U,3)'>PSGDT) Q
91 .S DDCNT=DDCNT+1
92 .S X=$S('$D(^PSDRUG(+ND,0)):1,$P($G(^(2)),U,3)'["U":1,+$G(^(2))'=+OI:1,$G(^("I"))="":0,1:^("I")'>PSGDT)
93 Q $S('DDCNT:0,X=1:0,1:1)
Note: See TracBrowser for help on using the repository browser.