source: FOIAVistA/trunk/r/TEXT_INTEGRATION_UTILITIES-GMRP-TIU/TIUSRVP1.m@ 1397

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

initial load of FOIAVistA 6/30/08 version

File size: 6.5 KB
Line 
1TIUSRVP1 ; SLC/JER - More API's in support of PUT ;11/01/03
2 ;;1.0;TEXT INTEGRATION UTILITIES;**19,59,89,100,109,167,113,112**;Jun 20, 1997
3SITEPARM(TIUY) ; Get site parameters for GUI
4 N TIUPRM0,TIUPRM1
5 D SETPARM^TIULE
6 S TIUY=TIUPRM0
7 Q
8DEFDOC(TIUY,HLOC,USER,TIUDT,TIUIEN) ; Get default primary provider
9 N TIUSPRM,TIUDDOC,TIUAUTH
10 D SITEPARM(.TIUSPRM)
11 S TIUDDOC=+$P(TIUSPRM,U,8)
12 S TIUAUTH=$S((+$G(USER)!('+$G(TIUIEN))):0,1:+$P($G(^TIU(8925,+$G(TIUIEN),12)),U,2))
13 S USER=$S(+$G(USER):+$G(USER),+$G(TIUAUTH):+$G(TIUAUTH),1:DUZ)
14 S TIUDT=$S(+$G(TIUDT):+$G(TIUDT),1:DT)
15 S TIUY=$S(TIUDDOC=1:$$DFLTDOC^TIUPXAPI(HLOC),TIUDDOC=2:$$CURDOC(USER),1:"0^")
16 Q
17CURDOC(USER,TIUDT) ; Is the current user a known Provider?
18 N TIUY,TIUPROV S TIUY="0^"
19 S USER=$S(+$G(USER):+$G(USER),1:DUZ)
20 S TIUDT=$S(+$G(TIUDT):+$G(TIUDT),1:DT)
21 S TIUPROV=$$PROVIDER^TIUPXAP1(USER,TIUDT)
22 I +TIUPROV S TIUY=USER_U_$$PERSNAME^TIULC1(USER)
23 Q TIUY
24ISAPROV(TIUY,USER,DATE) ; Is user a provider?
25 S USER=$G(USER,DUZ)
26 S DATE=$G(DATE,DT)
27 S TIUY=$$PROVIDER^TIUPXAP1(USER,DATE)
28 Q
29DOCPARM(TIUY,TIUDA,TIUTYP) ; Get document parameters for GUI
30 I '+$G(TIUTYP),+$G(TIUDA) S TIUTYP=+$G(^TIU(8925,+TIUDA,0))
31 I '+$G(TIUTYP) S TIUY(0)="" Q
32 D DOCPRM^TIULC1(TIUTYP,.TIUY,$G(TIUDA))
33 I '$D(TIUY) S TIUY(0)=""
34 Q
35CONSTUB(TIUDA,GMRCVP,DFN) ; Create a stub for a Consult Report
36 N DIE,DR,DA
37 D STUB(.TIUDA,"CONSULT REPORT",DFN)
38 I +TIUDA'>0 Q
39 S DIE=8925,DA=+TIUDA,DR="1405////^S X=GMRCVP"
40 D ^DIE
41 Q
42STUB(TIUDA,TIUTITL,DFN) ; Create a stub
43 N TIUVSIT,TIUFPRIV,DIC,DIE,DR,DA,DLAYGO,X,Y S TIUFPRIV=1
44 I +$G(TIUTITL)'>0 S TIUTITL=$$WHATITLE^TIUPUTU(TIUTITL)
45 I +TIUTITL'>0 S TIUDA=-1 Q
46 S (DIC,DLAYGO)=8925,DIC(0)="LF"
47 S X=""""_"`"_+TIUTITL_""""
48 D ^DIC S TIUDA=+Y Q:+Y'>0
49 D EVENT(.TIU,DFN) I $L($G(TIU("VSTR")))'>0 S TIUDA=-1 Q
50 S DIE=DIC,DA=TIUDA
51 S DR=".02////"_+DFN_";.03////"_$P($G(TIU("VISIT")),U)_";.04////"_+$$DOCCLASS^TIULC1(TIUTITL)_";.05///UNDICTATED;.13////E;1301////"_+$$NOW^XLFDT
52 D ^DIE
53 Q
54EVENT(TIUY,DFN) ; Create an Event-type Visit Entry
55 N VDT,VSTR,DGPM
56 S DGPM=$G(^DPT(DFN,.105))
57 I +DGPM'>0 D
58 . S VDT=$$NOW^XLFDT
59 . S VSTR=";"_VDT_";"_"E"
60 D PATVADPT^TIULV(.TIUY,+DFN,DGPM,$G(VSTR))
61 I $G(TIUY("LOC"))="",+DUZ D
62 .N TIUPREF,IDX
63 .S TIUPREF=$$PERSPRF^TIULE(DUZ)
64 .S IDX=+$P(TIUPREF,U,2)
65 .I IDX S TIUY("LOC")=IDX_U_$P($G(^SC(IDX,0)),U,1)
66 Q
67GETPNAME(TIUY,TIUTYPE) ; Get Print Name of a Document
68 S TIUY=$$PNAME^TIULC1(TIUTYPE)
69 Q
70SAVED(TIUY,TIUDA) ; Was the document committed to the database?
71 N TIUD12,TIUD13,TIUEBY,TIUAUT,TIUECS S TIUY=1
72 S TIUD12=$G(^TIU(8925,TIUDA,12)),TIUD13=$G(^(13))
73 S TIUEBY=$P(TIUD13,U,2),TIUAUT=$P(TIUD12,U,2),TIUECS=$P(TIUD12,U,8)
74 I $D(^TIU(8925,"ASAVE",+DUZ,TIUDA)) D Q
75 . S TIUY="0^You appear to have been disconnected..."
76 I DUZ'=TIUEBY,(TIUEBY'=TIUAUT),$D(^TIU(8925,"ASAVE",+TIUEBY,TIUDA)) D Q
77 . S TIUY="0^The transcriber appears to have been disconnected..."
78 I DUZ'=TIUAUT,$D(^TIU(8925,"ASAVE",+TIUAUT,TIUDA)) D Q
79 . S TIUY="0^The author appears to have been disconnected..."
80 I DUZ'=TIUECS,$D(^TIU(8925,"ASAVE",+TIUECS,TIUDA)) D Q
81 . S TIUY="0^The expected cosigner appears to have been disconnected..."
82 Q
83STUFREC(TIUDA,TIUREC,DFN,PARENT,TITLE,TIU) ; load TIUREC for create
84 N TIUREQCS,TIUSCAT,TIUSTAT,TIUCPF
85 ;Set a flag to indicate whether or not a Title is a member of the
86 ;Clinical Procedures Class (1=Yes and 0=No)
87 S TIUCPF=+$$ISA^TIULX(TITLE,+$$CLASS^TIUCP)
88 S TIUSTAT=$$STATUS(TIUDA,+$G(SUPPRESS),$G(TITLE))
89 D REQCOS^TIUSRVA(.TIUREQCS,+TITLE,"",$S(+$G(TIUREC(1202)):+$G(TIUREC(1202)),1:DUZ))
90 I +$G(PARENT)'>0 D
91 . S TIUREC(.02)=$G(DFN),TIUREC(.03)=$P($G(TIU("VISIT")),U)
92 . S TIUREC(.05)=$S(+$G(TIUREC(.05)):+$G(TIUREC(.05)),+TIUSTAT:TIUSTAT,1:5)
93 . S TIUREC(.07)=$P($G(TIU("EDT")),U),TIUREC(.08)=$P($G(TIU("LDT")),U)
94 . S TIUREC(1401)=$P($G(TIU("AD#")),U)
95 . S TIUREC(1402)=$P($G(TIU("TS")),U)
96 . S TIUREC(1404)=$P($G(TIU("SVC")),U)
97 I +$G(PARENT)>0 D
98 . S TIUREC(.02)=+$P($G(^TIU(8925,+PARENT,0)),U,2)
99 . S TIUREC(.03)=+$P($G(^TIU(8925,+PARENT,0)),U,3)
100 . S TIUREC(.05)=$S(+$G(TIUREC(.05)):+$G(TIUREC(.05)),+TIUSTAT:TIUSTAT,1:5)
101 . S TIUREC(.06)=PARENT,TIUREC(.07)=$P(TIU("EDT"),U)
102 . S TIUREC(.08)=$P(TIU("LDT"),U)
103 . S TIUREC(1401)=$P($G(^TIU(8925,+PARENT,14)),U)
104 . S TIUREC(1402)=$P($G(^TIU(8925,+PARENT,14)),U,2)
105 . S TIUREC(1404)=$P($G(^TIU(8925,+PARENT,14)),U,4)
106 . S TIUREC(1405)=$P($G(^TIU(8925,+PARENT,14)),U,5)
107 S TIUREC(.04)=$$DOCCLASS^TIULC1(TITLE)
108 S TIUSCAT=$S(+$L($P($G(TIU("CAT")),U)):$P($G(TIU("CAT")),U),+$L($P($G(TIU("VSTR")),";",3)):$P($G(TIU("VSTR")),";",3),1:"")
109 S TIUREC(.13)=TIUSCAT
110 ;If the document is a member of the Clinical Procedures Class, set the
111 ;Author/Dictator and the Expected Signer fields to Null
112 S (TIUREC(1202),TIUREC(1204))=$S(+$G(TIUREC(1202)):+$G(TIUREC(1202)),TIUCPF:"",1:+$G(DUZ))
113 S TIUREC(1212)=$P($G(TIU("INST")),U)
114 S TIUREC(1205)=$P($G(TIU("LOC")),U)
115 S TIUREC(1211)=$P($G(TIU("VLOC")),U)
116 S TIUREC(1201)=$$NOW^XLFDT
117 S TIUREC(1301)=$S($G(TIUREC(1301))]"":$P(TIUREC(1301),U),1:$$NOW^XLFDT)
118 I +$$ISDS^TIULX(TITLE) D
119 . I +$G(TIU("LDT"))'>0 S TIUREC(.12)=1
120 . S TIUREC(.13)="H"
121 . D REFDT(.TIUREC)
122 ;If the document is a member of the Clinical Procedures Class, set the
123 ;Entered By field to Null
124 S TIUREC(1303)="R",TIUREC(1302)=$S(TIUCPF:"",1:$G(DUZ))
125 I $S(+$G(TIUREC(1208))&(+$G(TIUREC(1204))'=+$G(TIUREC(1208))):1,+$G(TIUREQCS):1,1:0) S TIUREC(1506)=1
126 Q
127REFDT(TIUX) ; Hack Ref Date/time for DS's
128 S TIUX(1301)=$S(+$G(TIU("LDT")):+$G(TIU("LDT")),1:$G(TIUX(1301)))
129 Q
130STATUS(TIUDA,SUPPRESS,TITLE) ; Compute the status of the current record
131 N TIUDPRM,TIUY
132 ; If the document is an addendum, compute status based on processing
133 ; requirements of the Parent document or its ancestors
134 I +$$ISADDNDM^TIULC1(TIUDA) D
135 . S TIUDA=$S(+$P(^TIU(8925,TIUDA,0),U,6):$P(^(0),U,6),1:TIUDA)
136 . S TITLE=+$G(^TIU(8925,TIUDA,0))
137 D DOCPRM^TIULC1(TITLE,.TIUDPRM,$G(TIUDA))
138 I +$P(TIUDPRM(0),U,2),+$G(SUPPRESS) S TIUY=3 G STATUX
139 S TIUY=$S(+$$REQVER^TIULC(+TIUDA,+$P($G(TIUDPRM(0)),U,3)):4,1:5)
140STATUX Q TIUY
141IDATTCH(TIUY,TIUDA,TIUDAD) ; Attach TIUDA as ID Child entry to TIUDAD
142 N TIUX
143 S TIUX(2101)=TIUDAD
144 D FILE^TIUSRVP(.TIUY,TIUDA,.TIUX,1)
145 D AUDLINK^TIUGR1(TIUDA,"a",TIUDAD)
146 D SENDID^TIUALRT1(TIUDA)
147 Q
148IDDTCH(TIUY,TIUDA) ; Detach TIUDA from its ID Parent
149 N TIUX,IDDAD
150 I '+$G(^TIU(8925,TIUDA,21)) D Q
151 . S TIUY="0^Record #"_TIUDA_" is NOT an ID Entry."
152 S IDDAD=+$G(^TIU(8925,TIUDA,21))
153 S TIUX(2101)="@"
154 D FILE^TIUSRVP(.TIUY,TIUDA,.TIUX,1)
155 D AUDLINK^TIUGR1(TIUDA,"d",IDDAD)
156 D IDDEL^TIUALRT1(TIUDA)
157 Q
158CANDEL(TIUDA) ; Boolean function to evaluate delete request
159 Q $S($P(^TIU(8925,TIUDA,0),U,5)>3:0,'+$$EMPTYDOC^TIULF(TIUDA):0,1:1)
Note: See TracBrowser for help on using the repository browser.