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

SCAPMC18.m

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