Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: ECMFDSSU

ECMFDSSU.m

Go to the documentation of this file.
  1. ECMFDSSU ;ALB/JAM-Event Capture Management Filer DSS Unit ;2/6/18 14:41
  1. ;;2.0;EVENT CAPTURE ;**25,30,33,126,131,139**;8 May 96;Build 7
  1. ;
  1. FILE ;Used by the RPC broker to file DSS Units in file #724
  1. ; Variables passed in
  1. ; ECIEN - IEN of #724, if editing
  1. ; ECDUNM - DSS Unit Name
  1. ; ECS - Service
  1. ; ECM - Medical Speciality
  1. ; ECTR - Cost Center
  1. ; ECUN - Unit Number
  1. ; ECST - Status Flag (Active/Inactive)
  1. ; ECASC - Associated Stop Code
  1. ; ECC - Category
  1. ; ECDFDT - Default Data Entry Date
  1. ; ECPCE - Send to PCE
  1. ; ECSCN - Event Code Screens status
  1. ; ECCSC - Credit stop code, can be used when PCE status is
  1. ; no records
  1. ; ECHAR4 - CHAR4 code, can be used when PCE status is no records
  1. ; ECADUP - DSS Unit allows duplicate records during upload
  1. ;
  1. ; Variable return
  1. ; ^TMP($J,"ECMSG",n)=Success or failure to file in #724^Message
  1. ;
  1. N ECERR,ECX,ECFLG,ECRES,ECONAM
  1. S ECERR=0 D CHKDT I ECERR Q
  1. D VALDATA I ECERR Q
  1. S ECIEN=$G(ECIEN),ECFLG=1,ECONAM="",ECC=$S(ECC="Y":1,1:0)
  1. I ECIEN'="" S ECFLG=0 D I ECERR D END Q
  1. . I '$D(^ECD(ECIEN,0)) D Q
  1. . . S ECERR=1,^TMP($J,"ECMSG",1)="0^DSS Unit Not on File" Q
  1. . D CATCHK^ECUMRPC1(.ECRES,ECIEN) I ECRES,ECC'=$P(^ECD(ECIEN,0),U,11) D
  1. . . I ECC=0 D FIXSCRNS Q ;131 If Category changed to no, update existing event code screens
  1. . . S ECERR=1,^TMP($J,"ECMSG",1)="0^Category Changed, EC Screen exist"
  1. . S ECONAM=$P($G(^ECD(ECIEN,0)),U)
  1. D I ECERR D END Q ;Check name
  1. . I (ECFLG)!((ECONAM'="")&(ECONAM'=ECDUNM)),$D(^ECD("B",ECDUNM)) D Q
  1. . . S ECERR=1,^TMP($J,"ECMSG",1)="0^DSS Unit Name already exist"
  1. . I 'ECFLG K DIE S DIE="^ECD(",DA=ECIEN,DR=".01////"_ECDUNM D ^DIE
  1. S ECPCE=$S(ECPCE="A":"A",ECPCE="OOS":"OOS",1:"N") ;139
  1. I ECPCE'="A",$G(ECASC)="" D D END Q ;139
  1. . S ECERR=1,^TMP($J,"ECMSG",1)="0^No associated stop code, send to PCE setting requires an associated stop code" ;126,139 Corrected error message
  1. I 'ECFLG,ECPCE'="A",$P($G(^ECD(+$G(ECIEN),0)),U,14)="A" D UPDSCRN ;131,139 If existing DSS Unit and PCE is changing from All records then update related EC screens
  1. I ECIEN="" D NEWIEN
  1. K DA,DR,DIE
  1. S ECST=$E($G(ECST)),ECST=$S(ECST="I":1,1:0),ECDFDT=$E($G(ECDFDT))
  1. S ECDFDT=$S(ECDFDT="N":"N",1:"X"),DIE="^ECD(",DA=ECIEN
  1. S DR="1////"_ECS_";2////"_ECM_";3////"_ECTR_";4////"_$G(ECUN)
  1. S DR=DR_";5////"_ECST_";7////1;9////"_$S(ECPCE="A":"@",1:$G(ECASC)) ;139
  1. S DR=DR_";10////"_ECC_";11////"_ECDFDT_";13////"_ECPCE
  1. S DR=DR_";14////"_$S(ECPCE="A":"@",$G(ECCSC)="":"@",1:$G(ECCSC))_";15////"_$S(ECPCE'="N":"@",$G(ECHAR4)="":"@",1:$G(ECHAR4)) ;126,139 Add credit stop and char4 fields, 139 Update logic for deleting stop code
  1. S DR=DR_";16////"_$G(ECADUP,"N") ;139 Does DSS Unit allow duplicate records to be uploaded
  1. D ^DIE I $D(DTOUT) D RECDEL D D END Q
  1. . S ^TMP($J,"ECMSG",1)="0^DSS Unit Record not Filed"
  1. I 'ECFLG D ECSCRNS
  1. S ^TMP($J,"ECMSG",1)="1^DSS Unit Record Filed"_U_ECIEN
  1. END K DIE,DIC,DR,DA,DO,ECIEN
  1. Q
  1. VALDATA ;validate data
  1. N ECRRX
  1. D CHK^DIE(724,.01,"E",ECDUNM,.ECRRX) I ECRRX'=ECDUNM D Q
  1. .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid DSS Unit Name"
  1. D CHK^DIE(724,1,"E","`"_ECS,.ECRRX) I ECRRX'=ECS D Q
  1. .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Service"
  1. D CHK^DIE(724,2,"E","`"_ECM,.ECRRX) I ECRRX'=ECM D Q
  1. .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Medical Speciality"
  1. D CHK^DIE(724,3,"E","`"_ECTR,.ECRRX) I ECRRX'=ECTR D Q
  1. .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Cost Center"
  1. I $G(ECUN)'="" D CHK^DIE(724,4,"E",ECUN,.ECRRX) I ECRRX'=ECUN D Q
  1. .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Unit Number"
  1. I $G(ECASC)'="" D CHK^DIE(724,9,"E","`"_ECASC,.ECRRX) I ECRRX'=ECASC D Q
  1. .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Associated Stop Code" ;126 Corrected error message
  1. I $G(ECCSC)'="" D CHK^DIE(724,14,"E","`"_ECCSC,.ECRRX) I ECRRX'=ECCSC S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Credit Stop Code" Q ;126
  1. I $G(ECHAR4)'="" D CHK^DIE(724,15,"E","`"_ECHAR4,.ECRRX) I ECRRX'=ECHAR4 S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid CHAR4 Code" Q ;126
  1. Q
  1. ECSCRNS ;Determine if event codes should be updated based on change of DSS Unit
  1. ;status
  1. ; DSS Unit status changed from Active to Inactive, if EC screen status
  1. ; A - retain, do nothing, B - inactiviate
  1. ; DSS Unit status changed from Inactive to Active, if EC screen status
  1. ; C - reactiviate, D - remain inactive
  1. ;
  1. N ECD,ECINC,ZTDESC,ZTSAVE,ZTIO,ZTRTN,ZTDTH
  1. I ($G(ECSCN)="")!(ECSCN="A")!(ECSCN="D") Q
  1. I "^B^C^"']"^"_ECSCN_"^" Q
  1. S ECD=ECIEN,ECINC=DT
  1. I ECSCN="B" D
  1. .S ZTDESC="DEALLOCATE DSS UNIT & INACTIVATE EVENT CODE SCREENS"
  1. I ECSCN="C" D
  1. .S ZTDESC="REACTIVIATE EVENT CODE SCREENS",ECINC="@"
  1. S ZTRTN=$S(ECSCN="B":"DIK",1:"INSCRN")_"^ECDEAL",ZTDTH=$H
  1. N ECSCN
  1. S ECSCN=1,(ZTSAVE("ECD"),ZTSAVE("ECSCN"),ZTSAVE("ECINC"))="",ZTIO=""
  1. D ^%ZTLOAD K ZTSK Q
  1. D @ZTRTN
  1. Q
  1. ;
  1. RECDEL ; Delete record
  1. I ECFLG S DA=ECIEN,DIK="^ECD(" D ^DIK K DA,DIK
  1. Q
  1. NEWIEN ;Create new IEN in file #724
  1. N DIC,DA,DD,DO
  1. L +^ECD(0):3 ;126 Added lock time out as required by standard
  1. S DIC=724,DIC(0)="L",X=ECDUNM
  1. D FILE^DICN
  1. L -^ECD(0)
  1. S ECIEN=+Y
  1. Q
  1. CHKDT ;Required Data Check
  1. N I,C
  1. S C=1
  1. F I="ECDUNM","ECS","ECM","ECTR","ECC" D
  1. .I $G(@I)="" S ^TMP($J,"ECMSG",C)="0^Key data missing "_I,C=C+1,ECERR=1
  1. Q
  1. USER ;Used by the RPC broker to allocate or de-allocate users for DSS Units
  1. ;in file #200
  1. ; Variables passed in
  1. ; ECIEN - IEN of DSS Unit in file #724
  1. ; ECUSR0..n - Users to allocate/deallocate to DSS Unit
  1. ;
  1. ; Variable return
  1. ; ^TMP($J,"ECMSG",n)=Success or failure to file in #724^Message
  1. ;
  1. N EDUZ,ECERR,ECI,ECX,USER,DIC,DIK,X,Y,DA
  1. S (EDUZ,ECERR)=0,ECIEN=$G(ECIEN)
  1. I ECIEN="" S ^TMP($J,"ECMSG",1)="0^DSS Unit missing" Q
  1. D I ECERR Q
  1. . I '$D(^ECD(ECIEN,0)) D
  1. . . S ECERR=1,^TMP($J,"ECMSG",1)="0^DSS Unit Not on File"
  1. F ECI=0:1 S ECX="ECUSR"_ECI Q:'$D(@ECX) S:@ECX'="" USER(@ECX)=""
  1. F S EDUZ=$O(^VA(200,EDUZ)) Q:'EDUZ I $D(^VA(200,EDUZ,"EC",ECIEN,0)) D
  1. . I $D(USER(EDUZ)) K USER(EDUZ) Q
  1. . K DA,DIK S DA(1)=EDUZ,DA=ECIEN,DIK="^VA(200,"_DA(1)_",""EC"","
  1. . D ^DIK K USER(EDUZ)
  1. ;add users for DSS Unit
  1. S EDUZ=0 F S EDUZ=$O(USER(EDUZ)) Q:'EDUZ D
  1. . K DIC,DD,DO S DIC=200,DIC(0)="QNMX",X=EDUZ D ^DIC I Y<0 Q
  1. . K DIC,DD,DO S DIC(0)="L",DA(1)=EDUZ,DIC("P")=$P(^DD(200,720,0),U,2)
  1. . S DINUM=ECIEN,DIC="^VA(200,"_DA(1)_",""EC"",",X=ECIEN
  1. . D FILE^DICN
  1. S ^TMP($J,"ECMSG",1)="1^Record Filed"_U_ECIEN K DINUM
  1. Q
  1. DSSU ;Used by the RPC broker to allocate or de-allocate DSS Units for a user
  1. ;in file #200
  1. ; Variables passed in
  1. ; ECIEN - User IEN in file #200
  1. ; ECD0..n - IEN of DSS Unit in file #724 to allocate/deallocate
  1. ;
  1. ;
  1. ; Variable return
  1. ; ^TMP($J,"ECMSG",n)=Success or failure to file in #200^Message
  1. ;
  1. N EDU,ECERR,ECI,ECX,ECDSSU,DIC,DIK,DA,X,Y
  1. S (EDU,ECERR)=0,ECIEN=$G(ECIEN)
  1. I ECIEN="" S ^TMP($J,"ECMSG",1)="0^User missing" Q
  1. D I ECERR Q
  1. . S DIC=200,DIC(0)="QNX",X=ECIEN D ^DIC D:Y<0
  1. . . S ECERR=1,^TMP($J,"ECMSG",1)="0^User Not on File"
  1. F ECI=0:1 S ECX="ECD"_ECI Q:'$D(@ECX) S:@ECX'="" ECDSSU(@ECX)=""
  1. F S EDU=$O(^VA(200,ECIEN,"EC",EDU)) Q:'EDU D
  1. . I $D(ECDSSU(EDU)) K ECDSSU(EDU) Q
  1. . K DA,DIK S DA(1)=ECIEN,DA=EDU,DIK="^VA(200,"_DA(1)_",""EC"","
  1. . D ^DIK
  1. ;add DSS Units for user
  1. S EDU=0 F S EDU=$O(ECDSSU(EDU)) Q:'EDU D
  1. . I '$D(^ECD(EDU,0)) Q
  1. . K DIC,DD,DO S DIC(0)="L",DA(1)=ECIEN,DIC("P")=$P(^DD(200,720,0),U,2)
  1. . S DINUM=EDU,DIC="^VA(200,"_DA(1)_",""EC"",",X=EDU
  1. . D FILE^DICN
  1. S ^TMP($J,"ECMSG",1)="1^Record Filed"_U_ECIEN
  1. Q
  1. ;
  1. UPDSCRN ;131 Section added to remove default associated clinic from event capture screens for a specific DSS Unit
  1. N LOC,CAT,PROC,DA,DIE,DR
  1. S LOC=0 F S LOC=$O(^ECJ("AP",LOC)) Q:'+LOC S CAT="" F S CAT=$O(^ECJ("AP",LOC,ECIEN,CAT)) Q:CAT="" S PROC="" F S PROC=$O(^ECJ("AP",LOC,ECIEN,CAT,PROC)) Q:PROC="" D
  1. .S DA=$O(^ECJ("AP",LOC,ECIEN,CAT,PROC,0)) Q:'+DA
  1. .S DIE="^ECJ("
  1. .S DR="55///@"
  1. .D ^DIE
  1. Q
  1. ;
  1. FIXSCRNS ;131 Section added to inactivate existing event code screens
  1. ;when category changed from yes to no. Equivalent event code screens
  1. ;without a category will either be reactivated or created, as needed
  1. ;
  1. N LOC,CAT,PROC,DR,DA,DIE,DSS,ECCH,ECL,ECD,ECC,ECP,ECST,ECSYN,ECVOL,ECAC,ECREAS,NODE
  1. S LOC=0 F S LOC=$O(^ECJ("AP",LOC)) Q:'+LOC S CAT=0 F S CAT=$O(^ECJ("AP",LOC,ECIEN,CAT)) Q:'+CAT S PROC="" F S PROC=$O(^ECJ("AP",LOC,ECIEN,CAT,PROC)) Q:PROC="" D
  1. .S DA=$O(^ECJ("AP",LOC,ECIEN,CAT,PROC,0)) Q:'+DA ;Get record # of existing event code screen
  1. .I $P(^ECJ(DA,0),U,2)'="" Q ;Screen is already inactive, no action needed
  1. .S DIE="^ECJ(",DR="1///"_$$DT^XLFDT D ^DIE ;Inactivate screen using today's date
  1. .;Create or activate/update equivalent event code screen without a category
  1. .S ECCH=LOC_"-"_ECIEN_"-"_0_"-"_PROC,DSS=ECIEN S ECIEN="" ;protecting ECIEN as it's used in another routine
  1. .I $D(^ECJ("B",ECCH)) S ECIEN=$O(^ECJ("B",ECCH,0)) Q:'+ECIEN ;Non-category event code screen exists, identify record number for updating
  1. .S ECL=LOC,ECD=DSS,ECC=0,ECP=PROC,ECST="A"
  1. .S NODE=$G(^ECJ(DA,"PRO")),ECSYN=$P(NODE,U,2),ECVOL=$P(NODE,U,3),ECAC=$P(NODE,U,4),ECREAS=$E($$GET1^DIQ(720.3,DA,56,"E"),1) ;Setting input variables needed for call to ECMFECS
  1. .D FILE^ECMFECS ;File update or create new event code screen
  1. .S ECIEN=DSS ;Reset ECIEN to DSS Unit IEN
  1. Q