VistA-WorldVistAEHR/r/SCHEDULING-SD-SC/SCAPMC18.m

77 lines
2.4 KiB
Mathematica

SCAPMC18 ;ALB/REW - Team APIs:ACPTCL ; 5 Jul 1995
;;5.3;Scheduling;**41,45,50,130,148**;AUG 13, 1993
;;1.0
ACPTCL(DFN,SCCL,SCFIELDA,SCACT,SCERR) ;add a patient to a clinic (enrollment)
; input:
; DFN = pointer to PATIENT file (#2)
; SCCL = pointer to HOSPITAL LOCATION file (#44)
; SCFIELDA= array of additional fields to be added
; SCACT = date to activate [default=DT]
; SCERR = array NAME to store error messages.
; [ex. ^TMP("ORXX",$J)]
;
; Output:
; Returned = ien of enrollment multiple - 0 if none after^new?
; SCERR() = Array of DIALOG file messages(errors).
; Foramt:
; Subscript: Sequential # from 1 to n
; Piece Description
; 1 IEN of DIALOG file
N SCPTCL,SCESEQ,SCPARM,SCIEN,SC,SCFLD,SCNEWCL,DIC,X,SCX,DLAYGO
G:'$$OKDATA APTCLQ ;check/setup variables
S SCPTCL=$$PTCLACT(DFN,SCCL,SCACT,.SCERR)
IF SCPTCL G APTCLQ
ELSE D
.D BEFORE^SCMCEV3(DFN) ;invoke clinic enrollment event driver
.S DIC="^DPT("_DFN_",""DE"","
.S SCX=DIC_"0)"
.L +@(SCX):5
.IF '$T D:'$G(DGQUIET) EN^DDIOL("Enrollment being edited") Q
.S DIC(0)="L"
.S DIC("P")="2.001P"
.S DA(1)=DFN
.S X=SCCL
.S DLAYGO=2
.D FILE^DICN
.IF (Y'>0) L -@(SCX)
.S DIC=DIC_+Y_",1,"
.S DIC("P")="2.011D"
.S DA(1)=+Y
.S DA(2)=DFN
.S X=SCACT
.IF $D(SCFIELDA) D
..K DIC("DR")
..S SCFLD=0
..F S SCFLD=$O(@SCFIELDA@(SCFLD)) Q:'SCFLD D
...S:'$D(DIC("DR")) DIC("DR")=SCFLD_"////"_@SCFIELDA@(SCFLD)
...S:$D(DIC("DR")) DIC("DR")=DIC("DR")_";"_SCFLD_"////"_@SCFIELDA@(SCFLD)
.D FILE^DICN
.S SCPTCL=$P(Y,U,2)
.S SCNEWCL=$P(Y,U,3)
.L -@(SCX)
.D AFTER^SCMCEV3(DFN),INVOKE^SCMCEV3(DFN)
APTCLQ Q +$G(SCPTCL)_U_+$G(SCNEWCL)
;
PTCLACT(DFN,SCCL,SCDT,SCERR) ;what is patient/clinic enrollment date on a given date-time? Return date or 0
N SCDATES,SCCLLST,SCOK,SCDATES
S SCOK=0
S (SCDATES("BEGIN"),SCDATES("END"))=SCDT
IF $$CLPT^SCAPMC(DFN,"SCDATES","","SCCLLST",.SCERR) S:$D(SCCLLST("SCCL",SCCL)) SCOK=$O(SCCLLST("SCCL",SCCL,0))
Q SCOK
;
OKDATA() ;setup/check variables
N SCOK
S SCOK=1
D INIT^SCAPMCU1(.SCOK)
IF +$G(SCCL)'=$G(SCCL) D S SCOK=0
. S SCPARM("CLINIC")=$G(SCCL,"Undefined")
. D ERR^SCAPMCU1(SCESEQ,4045101,.SCPARM,"",.SCERR)
IF '$D(^SC(+$G(SCCL),0)) D S SCOK=0
. S SCPARM("CLINIC")=$G(SCCL,"Undefined")
. D ERR^SCAPMCU1(SCESEQ,4045101,.SCPARM,"",.SCERR)
IF '$D(^DPT(DFN,0)) D S SCOK=0
. S SCPARM("PATIENT")=DFN
. D ERR^SCAPMCU1(SCESEQ,4045101,.SCPARM,"",.SCERR)
S:'$G(SCACT) SCACT=DT
Q SCOK