| 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 | 
|---|