1 | TIURS1 ; SLC/JER - Additional /es/ actions ;1/18/05
|
---|
2 | ;;1.0;TEXT INTEGRATION UTILITIES;**7,36,58,100,109,142,156,184**;Jun 20, 1997
|
---|
3 | ;12/11/00 Moved ELSIG,MULTIPRN,LIST here from TIURS
|
---|
4 | ELSIG ; Sign rec
|
---|
5 | N TIULST,TIUSLST,TIURJCT,TIUES,TIUI,X,X1,Y,TIUDAARY,TIUCHNG
|
---|
6 | I '$D(TIUPRM0) D SETPARM^TIULE
|
---|
7 | I $P(TIUPRM0,U,2)'>0 W !,"Electronic signature not yet enabled." H 3 G ELSIGX
|
---|
8 | I '$D(VALMY) D EN^VALM2(XQORNOD(0))
|
---|
9 | S TIUI=0 I $D(VALMY)>9 D CLEAR^VALM1
|
---|
10 | F S TIUI=$O(VALMY(TIUI)) Q:+TIUI'>0 D
|
---|
11 | . N TIU0,TIU12,TIUSTAT,TIUEVNT,TIUTYPE,TIUPOP,TIU15,TIUDPRM
|
---|
12 | . N ASK,SIGNER,COSIGNER,XTRASGNR,TIUDATA,TIUDA,RSTRCTD
|
---|
13 | . S (ASK,TIUPOP)=0
|
---|
14 | . S TIUDATA=$G(^TMP("TIURIDX",$J,TIUI))
|
---|
15 | . S TIUDA=$P(TIUDATA,U,2) S RSTRCTD=$$DOCRES^TIULRR(TIUDA)
|
---|
16 | . I RSTRCTD D Q
|
---|
17 | . . W !!,$C(7),"Ok, no harm done...",! ; Echo denial message
|
---|
18 | . . I $$READ^TIUU("EA","RETURN to continue...") ; pause
|
---|
19 | . S TIU0=$G(^TIU(8925,+TIUDA,0)),TIU12=$G(^(12)),TIU15=$G(^(15))
|
---|
20 | . S SIGNER=$S(+$P(TIU12,U,4):$P(TIU12,U,4),1:$P(TIU12,U,2))
|
---|
21 | . S COSIGNER=$P(TIU12,U,8)
|
---|
22 | . I (DUZ'=SIGNER),(DUZ'=COSIGNER) S XTRASGNR=+$O(^TIU(8925.7,"AE",+TIUDA,+DUZ,0))
|
---|
23 | . S TIUSTAT=+$P(TIU0,U,5)
|
---|
24 | . S TIUTYPE=$$PNAME^TIULC1(+TIU0)
|
---|
25 | . S TIUEVNT=$S(TIUSTAT'>5:"SIGNATURE",+$G(XTRASGNR):"SIGNATURE",1:"COSIGNATURE")
|
---|
26 | . D DOCPRM^TIULC1(+TIU0,.TIUDPRM,TIUDA)
|
---|
27 | . S ASK=$$CANDO^TIULP(TIUDA,TIUEVNT)
|
---|
28 | . I +ASK>0 D
|
---|
29 | . . L +^TIU(8925,+TIUDA):1
|
---|
30 | . . E S ASK="0^ Another user is editing this entry."
|
---|
31 | . I +ASK'>0,$P(ASK,U,2)]"" D I 1
|
---|
32 | . . D FULL^VALM1
|
---|
33 | . . W !!,"Item #",TIUI,": ",$P(ASK,U,2),! K VALMY(TIUI)
|
---|
34 | . . W !,"Removed from signature list.",!
|
---|
35 | . . I $$READ^TIUU("FOA","Press RETURN to continue...")
|
---|
36 | . E D
|
---|
37 | . . ;If document is a clinical procedures title AND (P184) this is not an additional signature, check if clinical
|
---|
38 | . . ;procedure fields are required. If the fields are required, prompt for
|
---|
39 | . . ;them and don't permit the user to sign unless the fields are defined.
|
---|
40 | . . I '$G(XTRASGNR),+$$ISA^TIULX(+TIU0,+$$CLASS^TIUCP),$$REQCPF^TIULP(+$P($G(^TIU(8925,+TIUDA,14)),U,5)) D Q:+TIUPOP
|
---|
41 | . . . N TIUCPFLD
|
---|
42 | . . . W !!,"Item #",TIUI,": ",TIUTYPE," for "
|
---|
43 | . . . W $$PTNAME^TIULC1($P(TIU0,U,2))," will need Procedure Summary Code and Date/Time Performed..."
|
---|
44 | . . . I $G(^TIU(8925,+TIUDA,702)),$P(^(702),U)]"",$P(^(702),U,2)]"" S TIUCPFLD=1 Q
|
---|
45 | . . . S TIUCPFLD=$$ASKCPF^TIURS(TIUDA)
|
---|
46 | . . . I +TIUCPFLD'>0 D
|
---|
47 | . . . . S TIUPOP=1
|
---|
48 | . . . . W !!,"Item #",TIUI,": MUST have a Procedure Summary Code and Date/Time Performed",!,"before you may sign."
|
---|
49 | . . . . W !!,"Removed from signature list.",!
|
---|
50 | . . . . I $$READ^TIUU("FOA","Press RETURN to continue...")
|
---|
51 | . . I $S(+$$REQCOSIG^TIULP(+TIU0,+TIUDA,DUZ):1,+$P(TIU15,U,6):1,1:0),(+$P(TIU12,U,8)'>0) D Q:+TIUPOP
|
---|
52 | . . . N COSIGNER
|
---|
53 | . . . W !!,"Item #",TIUI,": ",TIUTYPE," for "
|
---|
54 | . . . W $$PTNAME^TIULC1($P(TIU0,U,2))," will need cosignature..."
|
---|
55 | . . . S COSIGNER=$$ASKCSNR^TIURS(TIUDA,DUZ)
|
---|
56 | . . . I +COSIGNER'>0 D
|
---|
57 | . . . . S TIUPOP=1
|
---|
58 | . . . . W !!,"Item #",TIUI,": MUST have a cosigner, before you may sign."
|
---|
59 | . . . . W !!,"Removed from signature list.",!
|
---|
60 | . . . . I $$READ^TIUU("FOA","Press RETURN to continue...")
|
---|
61 | . . N TIU,TIUY
|
---|
62 | . . D EN^VALM("TIU SIGN/COSIGN")
|
---|
63 | I $D(TIUSLST)'>9 D G ELSIGX
|
---|
64 | . S VALMSG="** Signature List Empty...Nothing signed. **"
|
---|
65 | I $D(TIUSLST)>9 D
|
---|
66 | . N TIUIO
|
---|
67 | . S TIUES=$$ASKSIG^TIULA1
|
---|
68 | . I '+TIUES S VALMSG="** Nothing Signed. **" D FIXLSTNW^TIULM Q
|
---|
69 | . D FULL^VALM1
|
---|
70 | . D MULTIPRN(.TIUSLST,.TIUIO)
|
---|
71 | . S TIUI=0 F S TIUI=$O(TIUSLST(TIUI)) Q:+TIUI'>0 D
|
---|
72 | . . N TIUPY,XTRASGNR
|
---|
73 | . . S TIUDATA=$G(^TMP("TIURIDX",$J,TIUI)),TIUDA=$P(TIUDATA,U,2)
|
---|
74 | . . S TIUDAARY(TIUI)=TIUDA
|
---|
75 | . . S TIULST=$G(TIULST)_$S($G(TIULST)]"":",",1:"")_TIUI
|
---|
76 | . . S XTRASGNR=+$P(TIUSLST(TIUI),U,3)
|
---|
77 | . . I +$G(XTRASGNR) D ADDSIG^TIURS1(TIUDA,XTRASGNR)
|
---|
78 | . . I '+$G(XTRASGNR) D ES^TIURS(TIUDA,TIUES)
|
---|
79 | . . I +TIUSLST(TIUI),(TIUIO]"") D RPC^TIUPD(.TIUPY,TIUDA,TIUIO,$P(TIUSLST(TIUI),U,2))
|
---|
80 | . D FULL^VALM1
|
---|
81 | ELSIGX I $G(TIUCHNG("ADDM"))!$G(TIUCHNG("DELETE")) S TIUCHNG("RBLD")=1
|
---|
82 | E S TIUCHNG("UPDATE")=1
|
---|
83 | D UPRBLD^TIURL(.TIUCHNG,.VALMY) K VALMY
|
---|
84 | S VALMBCK="R"
|
---|
85 | D VMSG($G(TIULST),.TIUDAARY,"signed")
|
---|
86 | Q
|
---|
87 | VMSG(TIULST,TIUDAARY,ACTION) ; Set VALMSG for messagebar, bold changed items
|
---|
88 | N TIUI,LINENO,ACTFIRST
|
---|
89 | S ACTFIRST=$S(ACTION="Encounter Data Edited":1,ACTION="Signers identified/edited":1,ACTION="Title changed":1,1:0)
|
---|
90 | I TIULST']"" D Q
|
---|
91 | . I ACTFIRST S VALMSG="** No changes made. **" Q
|
---|
92 | . S VALMSG="** Nothing "_ACTION_". **"
|
---|
93 | I ACTION="copied" S ACTION="copied; See end of list"
|
---|
94 | S TIULST=$$NEWLST(TIULST,.TIUDAARY)
|
---|
95 | I TIULST]"" D
|
---|
96 | . I ACTFIRST D Q
|
---|
97 | . . S VALMSG="** "_ACTION_" for item"_$S($L(TIULST,",")>1:"s ",$L(TIULST,"-")>1:"s ",1:" ")_TIULST_". **"
|
---|
98 | . S VALMSG="** Item"_$S($L(TIULST,",")>1:"s ",$L(TIULST,"-")>1:"s ",1:" ")_TIULST_" "_ACTION_". **"
|
---|
99 | I TIULST']"" D
|
---|
100 | . I ACTFIRST D Q
|
---|
101 | . . S VALMSG="** "_ACTION_"; item(s) no longer in list. **"
|
---|
102 | . S VALMSG="** Item"_$S($L(TIULST,",")>1:"s ",$L(TIULST,"-")>1:"s ",1:" ")_TIULST_" "_ACTION_", no longer in list. **"
|
---|
103 | . ;S VALMSG="** Item(s) "_ACTION_", no longer in list. **"
|
---|
104 | Q:$G(^TMP("TIUR",$J,"RTN"))="TIUROR"
|
---|
105 | F TIUI=1:1 S LINENO=$P(TIULST,", ",TIUI) Q:'LINENO D
|
---|
106 | . D CNTRL^VALM10(LINENO,1,$G(VALM("RM")),IOINHI,IOINORM)
|
---|
107 | Q
|
---|
108 | NEWLST(TIULST,TIUDAARY) ; Return TIULST with updated item numbers
|
---|
109 | N TIUI,TIULNO,TIUDA,TIUNLNO,TIUNLST
|
---|
110 | S TIUNLST=""
|
---|
111 | F TIUI=1:1 S TIULNO=$P(TIULST,",",TIUI) Q:'TIULNO D
|
---|
112 | . S TIUDA=TIUDAARY(TIULNO),TIUNLNO=$O(^TMP("TIUR",$J,"IEN",TIUDA,0))
|
---|
113 | . I TIUNLNO S TIUNLST=$G(TIUNLST)_$S($G(TIUNLST)]"":", ",1:"")_TIUNLNO
|
---|
114 | Q TIUNLST
|
---|
115 | ;
|
---|
116 | MULTIPRN(TIUSLST,TIUIO) ; ask device
|
---|
117 | N TIUI,TIUASK,TIUION,TIUPOK,IO,TIUPLIST,TIUSCRN S (TIUI,TIUPOK)=0
|
---|
118 | F S TIUI=$O(TIUSLST(TIUI)) Q:TIUI'>0!+TIUPOK S:+TIUSLST(TIUI) TIUPOK=1
|
---|
119 | I '+TIUPOK S TIUIO="" Q
|
---|
120 | S TIUPLIST=$$LIST(.TIUSLST)
|
---|
121 | W !!,"Please specify the device for printing item"
|
---|
122 | W $S(TIUPLIST[",":"s",TIUPLIST["-":"s",1:""),": ",TIUPLIST,!!
|
---|
123 | S TIUSCRN="I $L($G(^%ZIS(1,+Y,""TYPE""))),("";HFS;MT;BAR;VTRM;RES;CHAN;IMPC;""'[("";""_^(""TYPE"")_"";""))"
|
---|
124 | S TIUION=$$DEVICE^TIUDEV(.TIUIO,"LAST","N",TIUSCRN,"Q")
|
---|
125 | I '$L(TIUION) S TIUIO=""
|
---|
126 | D ^%ZISC
|
---|
127 | Q
|
---|
128 | LIST(LIST) ; build print list
|
---|
129 | N TIUY,TIUI S TIUI=0
|
---|
130 | F S TIUI=$O(LIST(TIUI)) Q:+TIUI'>0 D
|
---|
131 | . S:+LIST(TIUI) TIUY=$G(TIUY)_$S($G(TIUY)]"":", ",1:"")_TIUI
|
---|
132 | Q $G(TIUY)
|
---|
133 | ;
|
---|
134 | ADDSIG(TIUDA,DA) ; Apply extra signatures to a document
|
---|
135 | N DIE,DR
|
---|
136 | S DIE=8925.7
|
---|
137 | S DR=".04////"_$$NOW^TIULC_";.05////"_DUZ_";.06///^S X=$$SIGNAME^TIULS("_DUZ_");.07///^S X=$$SIGTITL^TIULS("_DUZ_");.08////E"
|
---|
138 | D ^DIE
|
---|
139 | D SEND^TIUALRT(TIUDA)
|
---|
140 | Q
|
---|
141 | CNVPOST ; Change Titles/Convert Postings
|
---|
142 | N TIUI,TIULST,Y,TIUVIEW,TIUCHNG,TIUDAARY
|
---|
143 | I $G(TIUGLINK) W !,"Please finish attaching the interdisciplinary note before changing title.",! H 3 Q
|
---|
144 | I '$D(VALMY) D EN^VALM2(XQORNOD(0))
|
---|
145 | S TIUI=0
|
---|
146 | I +$O(VALMY(0)) D FULL^VALM1
|
---|
147 | F S TIUI=$O(VALMY(TIUI)) Q:+TIUI'>0 D Q:$D(DIROUT)
|
---|
148 | . N TIU,TIUDA,DFN,TIUDATA,VALMY,XQORM,TIUVIEW,RSTRCTD
|
---|
149 | . S TIUDATA=$G(^TMP("TIURIDX",$J,TIUI))
|
---|
150 | . S TIUDA=+$P(TIUDATA,U,2) S RSTRCTD=$$DOCRES^TIULRR(TIUDA)
|
---|
151 | . I RSTRCTD D Q
|
---|
152 | . . W !!,$C(7),"Ok, no harm done...",! ; Echo denial message
|
---|
153 | . . I $$READ^TIUU("EA","RETURN to continue...") ; pause
|
---|
154 | . S TIUVIEW=$$CANDO^TIULP(TIUDA,"VIEW")
|
---|
155 | . I +TIUVIEW'>0 D Q ; Exclude records user can't view
|
---|
156 | . . W !!,$C(7),$P(TIUVIEW,U,2),! ; Echo denial message
|
---|
157 | . . I $$READ^TIUU("EA","RETURN to continue...") ; pause
|
---|
158 | . S TIUCHNG=0
|
---|
159 | . D EN^VALM("TIU CHANGE TITLE")
|
---|
160 | . S TIUDAARY(TIUI)=TIUDA
|
---|
161 | . I +$G(TIUCHNG) S TIULST=$G(TIULST)_$S($G(TIULST)]"":",",1:"")_TIUI
|
---|
162 | ; -- Update list: --
|
---|
163 | S TIUCHNG("UPDATE")=1
|
---|
164 | D UPRBLD^TIURL(.TIUCHNG,.VALMY) K VALMY
|
---|
165 | S VALMBCK="R"
|
---|
166 | D VMSG($G(TIULST),.TIUDAARY,"Title changed")
|
---|
167 | Q
|
---|
168 | CNVPOST1 ; Convert Single Posting to another title
|
---|
169 | N TIUD0,DIE,DR,TIUTITL,CHKSUM,TIUCHTTL,TIUCLSS,TIUCON,TIUQUIT
|
---|
170 | N DA,X,Y
|
---|
171 | ; Added TIUCON for **142
|
---|
172 | S TIUD0=$G(^TIU(8925,TIUDA,0)),TIUCHNG=0
|
---|
173 | ; Added TIUNOCS for **142
|
---|
174 | D FULL^VALM1
|
---|
175 | I +TIUD0=81 S TIUCHTTL="0^You may not change the TITLE of an ADDENDUM."
|
---|
176 | I '$D(TIUCHTTL) S TIUCHTTL=$$CANDO^TIULP(TIUDA,"CHANGE TITLE")
|
---|
177 | I +TIUCHTTL,$$DADORKID^TIUGBR(TIUDA) S TIUCHTTL="0^Interdisciplinary entries must be detached before changing titles." ;**100
|
---|
178 | I +TIUCHTTL'>0 D Q
|
---|
179 | . W !!,$C(7),$P(TIUCHTTL,U,2),! ; Echo denial
|
---|
180 | . I $$READ^TIUU("EA","RETURN to continue...") ; pause
|
---|
181 | L +^TIU(8925,TIUDA,0):1
|
---|
182 | E D Q
|
---|
183 | . W !!?5,$C(7),"Another user is editing this entry.",! ; Echo denial
|
---|
184 | . I $$READ^TIUU("EA","RETURN to continue...") ; pause
|
---|
185 | S TIUTITL=$$ASKTITLE^TIULA3(+$$CLINDOC^TIULC1(+TIUD0,TIUDA),+TIUD0)
|
---|
186 | S TIUCLSS=$$CLASS^TIUCNSLT()
|
---|
187 | S TIUCON=+$$ISA^TIULX(TIUTITL,TIUCLSS)
|
---|
188 | I TIUCON=1,+TIUD0'=TIUTITL D CHANGE^TIUCNSLT(TIUDA,"",.TIUNOCS)
|
---|
189 | I $G(TIUNOCS)=-1 D G POST1Q
|
---|
190 | . I $$READ^TIUU("EA","Press RETURN to continue...") ; **142
|
---|
191 | ;*184->
|
---|
192 | D CONSCT^TIUCNSLT(TIUDA,+TIUD0,TIUTITL)
|
---|
193 | D PRFCT^TIUPRF1(+TIUD0,TIUTITL,TIUDA)
|
---|
194 | ;<-*184
|
---|
195 | I $G(TIUQUIT)=1 G POST1Q
|
---|
196 | S DIE=8925,DA=TIUDA
|
---|
197 | S DR=".01////^S X="_TIUTITL_";.04////^S X="_$$DOCCLASS^TIULC1(TIUTITL)
|
---|
198 | D ^DIE
|
---|
199 | I +$G(^TIU(8925,+TIUDA,0))'=+TIUD0 S TIUCHNG=1
|
---|
200 | S CHKSUM=+$$CHKSUM^TIULC("^TIU(8925,"_+TIUDA_",""TEXT"")")
|
---|
201 | D AUDIT^TIUEDI1(TIUDA,CHKSUM,CHKSUM)
|
---|
202 | POST1Q ;clean up, linetag put in with *171
|
---|
203 | L -^TIU(8925,TIUDA,0)
|
---|
204 | K TIUNOCS
|
---|
205 | Q
|
---|