1 | ECMFDSSU ;ALB/JAM-Event Capture Management Filer DSS Unit ;20 Nov 00
|
---|
2 | ;;2.0; EVENT CAPTURE ;**25,30,33**;8 May 96
|
---|
3 | ;
|
---|
4 | FILE ;Used by the RPC broker to file DSS Units in file #724
|
---|
5 | ; Variables passed in
|
---|
6 | ; ECIEN - IEN of #724, if editing
|
---|
7 | ; ECDUNM - DSS Unit Name
|
---|
8 | ; ECS - Service
|
---|
9 | ; ECM - Medical Speciality
|
---|
10 | ; ECTR - Cost Center
|
---|
11 | ; ECUN - Unit Number
|
---|
12 | ; ECST - Status Flag (Active/Inactive)
|
---|
13 | ; ECASC - Associated Stop Code
|
---|
14 | ; ECC - Category
|
---|
15 | ; ECDFDT - Default Data Entry Date
|
---|
16 | ; ECPCE - Send to PCE
|
---|
17 | ; ECSCN - Event Code Screens status
|
---|
18 | ;
|
---|
19 | ; Variable return
|
---|
20 | ; ^TMP($J,"ECMSG",n)=Success or failure to file in #724^Message
|
---|
21 | ;
|
---|
22 | N ECERR,ECX,ECFLG,ECRES,ECONAM
|
---|
23 | S ECERR=0 D CHKDT I ECERR Q
|
---|
24 | D VALDATA I ECERR Q
|
---|
25 | S ECIEN=$G(ECIEN),ECFLG=1,ECONAM="",ECC=$S(ECC="Y":1,1:0)
|
---|
26 | I ECIEN'="" S ECFLG=0 D I ECERR D END Q
|
---|
27 | . I '$D(^ECD(ECIEN,0)) D Q
|
---|
28 | . . S ECERR=1,^TMP($J,"ECMSG",1)="0^DSS Unit Not on File" Q
|
---|
29 | . D CATCHK^ECUMRPC1(.ECRES,ECIEN) I ECRES,ECC'=$P(^ECD(ECIEN,0),U,11) D
|
---|
30 | . . S ECERR=1,^TMP($J,"ECMSG",1)="0^Category Changed, EC Screen exist"
|
---|
31 | . S ECONAM=$P($G(^ECD(ECIEN,0)),U)
|
---|
32 | D I ECERR D END Q ;Check name
|
---|
33 | . I (ECFLG)!((ECONAM'="")&(ECONAM'=ECDUNM)),$D(^ECD("B",ECDUNM)) D Q
|
---|
34 | . . S ECERR=1,^TMP($J,"ECMSG",1)="0^DSS Unit Name already exist"
|
---|
35 | . I 'ECFLG K DIE S DIE="^ECD(",DA=ECIEN,DR=".01////"_ECDUNM D ^DIE
|
---|
36 | S ECPCE=$S(ECPCE="A":"A",ECPCE="O":"O",1:"N")
|
---|
37 | I ECPCE="N",$G(ECASC)="" D D END Q
|
---|
38 | . S ECERR=1,^TMP($J,"ECMSG",1)="0^No associated clinic, Send to PCE=N"
|
---|
39 | I ECIEN="" D NEWIEN
|
---|
40 | K DA,DR,DIE
|
---|
41 | S ECST=$E($G(ECST)),ECST=$S(ECST="I":1,1:0),ECDFDT=$E($G(ECDFDT))
|
---|
42 | S ECDFDT=$S(ECDFDT="N":"N",1:"X"),DIE="^ECD(",DA=ECIEN
|
---|
43 | S DR="1////"_ECS_";2////"_ECM_";3////"_ECTR_";4////"_$G(ECUN)
|
---|
44 | S DR=DR_";5////"_ECST_";7////1;9////"_$S(ECPCE'="N":"@",1:$G(ECASC))
|
---|
45 | S DR=DR_";10////"_ECC_";11////"_ECDFDT_";13////"_ECPCE
|
---|
46 | D ^DIE I $D(DTOUT) D RECDEL D D END Q
|
---|
47 | . S ^TMP($J,"ECMSG",1)="0^DSS Unit Record not Filed"
|
---|
48 | I 'ECFLG D ECSCRNS
|
---|
49 | S ^TMP($J,"ECMSG",1)="1^DSS Unit Record Filed"_U_ECIEN
|
---|
50 | END K DIE,DIC,DR,DA,DO,ECIEN
|
---|
51 | Q
|
---|
52 | VALDATA ;validate data
|
---|
53 | N ECRRX
|
---|
54 | D CHK^DIE(724,.01,"E",ECDUNM,.ECRRX) I ECRRX'=ECDUNM D Q
|
---|
55 | .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid DSS Unit Name"
|
---|
56 | D CHK^DIE(724,1,"E","`"_ECS,.ECRRX) I ECRRX'=ECS D Q
|
---|
57 | .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Service"
|
---|
58 | D CHK^DIE(724,2,"E","`"_ECM,.ECRRX) I ECRRX'=ECM D Q
|
---|
59 | .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Medical Speciality"
|
---|
60 | D CHK^DIE(724,3,"E","`"_ECTR,.ECRRX) I ECRRX'=ECTR D Q
|
---|
61 | .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Cost Center"
|
---|
62 | I $G(ECUN)'="" D CHK^DIE(724,4,"E",ECUN,.ECRRX) I ECRRX'=ECUN D Q
|
---|
63 | .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Unit Number"
|
---|
64 | I $G(ECASC)'="" D CHK^DIE(724,9,"E","`"_ECASC,.ECRRX) I ECRRX'=ECASC D Q
|
---|
65 | .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Associated Clinic"
|
---|
66 | Q
|
---|
67 | ECSCRNS ;Determine if event codes should be updated based on change of DSS Unit
|
---|
68 | ;status
|
---|
69 | ; DSS Unit status changed from Active to Inactive, if EC screen status
|
---|
70 | ; A - retain, do nothing, B - inactiviate
|
---|
71 | ; DSS Unit status changed from Inactive to Active, if EC screen status
|
---|
72 | ; C - reactiviate, D - remain inactive
|
---|
73 | ;
|
---|
74 | N ECD,ECINC,ZTDESC,ZTSAVE,ZTIO,ZTRTN,ZTDTH
|
---|
75 | I ($G(ECSCN)="")!(ECSCN="A")!(ECSCN="D") Q
|
---|
76 | I "^B^C^"']"^"_ECSCN_"^" Q
|
---|
77 | S ECD=ECIEN,ECINC=DT
|
---|
78 | I ECSCN="B" D
|
---|
79 | .S ZTDESC="DEALLOCATE DSS UNIT & INACTIVATE EVENT CODE SCREENS"
|
---|
80 | I ECSCN="C" D
|
---|
81 | .S ZTDESC="REACTIVIATE EVENT CODE SCREENS",ECINC="@"
|
---|
82 | S ZTRTN=$S(ECSCN="B":"DIK",1:"INSCRN")_"^ECDEAL",ZTDTH=$H
|
---|
83 | N ECSCN
|
---|
84 | S ECSCN=1,(ZTSAVE("ECD"),ZTSAVE("ECSCN"),ZTSAVE("ECINC"))="",ZTIO=""
|
---|
85 | D ^%ZTLOAD K ZTSK Q
|
---|
86 | D @ZTRTN
|
---|
87 | Q
|
---|
88 | ;
|
---|
89 | RECDEL ; Delete record
|
---|
90 | I ECFLG S DA=ECIEN,DIK="^ECD(" D ^DIK K DA,DIK
|
---|
91 | Q
|
---|
92 | NEWIEN ;Create new IEN in file #724
|
---|
93 | N DIC,DA,DD,DO
|
---|
94 | L +^ECD(0)
|
---|
95 | S DIC=724,DIC(0)="L",X=ECDUNM
|
---|
96 | D FILE^DICN
|
---|
97 | L -^ECD(0)
|
---|
98 | S ECIEN=+Y
|
---|
99 | Q
|
---|
100 | CHKDT ;Required Data Check
|
---|
101 | N I,C
|
---|
102 | S C=1
|
---|
103 | F I="ECDUNM","ECS","ECM","ECTR","ECC" D
|
---|
104 | .I $G(@I)="" S ^TMP($J,"ECMSG",C)="0^Key data missing "_I,C=C+1,ECERR=1
|
---|
105 | Q
|
---|
106 | USER ;Used by the RPC broker to allocate or de-allocate users for DSS Units
|
---|
107 | ;in file #200
|
---|
108 | ; Variables passed in
|
---|
109 | ; ECIEN - IEN of DSS Unit in file #724
|
---|
110 | ; ECUSR0..n - Users to allocate/deallocate to DSS Unit
|
---|
111 | ;
|
---|
112 | ; Variable return
|
---|
113 | ; ^TMP($J,"ECMSG",n)=Success or failure to file in #724^Message
|
---|
114 | ;
|
---|
115 | N EDUZ,ECERR,ECI,ECX,USER,DIC,DIK,X,Y,DA
|
---|
116 | S (EDUZ,ECERR)=0,ECIEN=$G(ECIEN)
|
---|
117 | I ECIEN="" S ^TMP($J,"ECMSG",1)="0^DSS Unit missing" Q
|
---|
118 | D I ECERR Q
|
---|
119 | . I '$D(^ECD(ECIEN,0)) D
|
---|
120 | . . S ECERR=1,^TMP($J,"ECMSG",1)="0^DSS Unit Not on File"
|
---|
121 | F ECI=0:1 S ECX="ECUSR"_ECI Q:'$D(@ECX) S:@ECX'="" USER(@ECX)=""
|
---|
122 | F S EDUZ=$O(^VA(200,EDUZ)) Q:'EDUZ I $D(^VA(200,EDUZ,"EC",ECIEN,0)) D
|
---|
123 | . I $D(USER(EDUZ)) K USER(EDUZ) Q
|
---|
124 | . K DA,DIK S DA(1)=EDUZ,DA=ECIEN,DIK="^VA(200,"_DA(1)_",""EC"","
|
---|
125 | . D ^DIK K USER(EDUZ)
|
---|
126 | ;add users for DSS Unit
|
---|
127 | S EDUZ=0 F S EDUZ=$O(USER(EDUZ)) Q:'EDUZ D
|
---|
128 | . K DIC,DD,DO S DIC=200,DIC(0)="QNMX",X=EDUZ D ^DIC I Y<0 Q
|
---|
129 | . K DIC,DD,DO S DIC(0)="L",DA(1)=EDUZ,DIC("P")=$P(^DD(200,720,0),U,2)
|
---|
130 | . S DINUM=ECIEN,DIC="^VA(200,"_DA(1)_",""EC"",",X=ECIEN
|
---|
131 | . D FILE^DICN
|
---|
132 | S ^TMP($J,"ECMSG",1)="1^Record Filed"_U_ECIEN K DINUM
|
---|
133 | Q
|
---|
134 | DSSU ;Used by the RPC broker to allocate or de-allocate DSS Units for a user
|
---|
135 | ;in file #200
|
---|
136 | ; Variables passed in
|
---|
137 | ; ECIEN - User IEN in file #200
|
---|
138 | ; ECD0..n - IEN of DSS Unit in file #724 to allocate/deallocate
|
---|
139 | ;
|
---|
140 | ;
|
---|
141 | ; Variable return
|
---|
142 | ; ^TMP($J,"ECMSG",n)=Success or failure to file in #200^Message
|
---|
143 | ;
|
---|
144 | N EDU,ECERR,ECI,ECX,ECDSSU,DIC,DIK,DA,X,Y
|
---|
145 | S (EDU,ECERR)=0,ECIEN=$G(ECIEN)
|
---|
146 | I ECIEN="" S ^TMP($J,"ECMSG",1)="0^User missing" Q
|
---|
147 | D I ECERR Q
|
---|
148 | . S DIC=200,DIC(0)="QNX",X=ECIEN D ^DIC D:Y<0
|
---|
149 | . . S ECERR=1,^TMP($J,"ECMSG",1)="0^User Not on File"
|
---|
150 | F ECI=0:1 S ECX="ECD"_ECI Q:'$D(@ECX) S:@ECX'="" ECDSSU(@ECX)=""
|
---|
151 | F S EDU=$O(^VA(200,ECIEN,"EC",EDU)) Q:'EDU D
|
---|
152 | . I $D(ECDSSU(EDU)) K ECDSSU(EDU) Q
|
---|
153 | . K DA,DIK S DA(1)=ECIEN,DA=EDU,DIK="^VA(200,"_DA(1)_",""EC"","
|
---|
154 | . D ^DIK
|
---|
155 | ;add DSS Units for user
|
---|
156 | S EDU=0 F S EDU=$O(ECDSSU(EDU)) Q:'EDU D
|
---|
157 | . I '$D(^ECD(EDU,0)) Q
|
---|
158 | . K DIC,DD,DO S DIC(0)="L",DA(1)=ECIEN,DIC("P")=$P(^DD(200,720,0),U,2)
|
---|
159 | . S DINUM=EDU,DIC="^VA(200,"_DA(1)_",""EC"",",X=EDU
|
---|
160 | . D FILE^DICN
|
---|
161 | S ^TMP($J,"ECMSG",1)="1^Record Filed"_U_ECIEN
|
---|
162 | Q
|
---|