[613] | 1 | SCAPMC28 ;ALB/REW - Patients with an Appointment ; 1/10/05 2:49pm
|
---|
| 2 | ;;5.3;Scheduling;**41,140,346**;AUG 13, 1993
|
---|
| 3 | ;;1.0
|
---|
| 4 | PTAP(SCCL,SCDATES,SCMAXCNT,SCLIST,SCERR,MORE) ; -- list of patients with an appointment in a given clinic
|
---|
| 5 | ;
|
---|
| 6 | ; input:
|
---|
| 7 | ; SCCL = Pointer to File #44
|
---|
| 8 | ; SCDATES("BEGIN") = begin date to search (inclusive)
|
---|
| 9 | ; [default: TODAY]
|
---|
| 10 | ; ("END") = end date to search (inclusive)
|
---|
| 11 | ; [default: TODAY]
|
---|
| 12 | ; ("INCL") = 1: only use patients who were assigned to
|
---|
| 13 | ; team for entire date range
|
---|
| 14 | ; 0: anytime in date range
|
---|
| 15 | ; [default: 1]
|
---|
| 16 | ; SCMAXCNT - Maximum # of patients to return, default=99
|
---|
| 17 | ; SCLIST -array name to store list
|
---|
| 18 | ; [ex. ^TMP("SCPT",$J)]
|
---|
| 19 | ;
|
---|
| 20 | ; SCERR = array NAME to store error messages.
|
---|
| 21 | ; [ex. ^TMP("ORXX",$J)]
|
---|
| 22 | ; MORE - This is a flag that says that this list exists and has been
|
---|
| 23 | ; aborted because it reached the maxcount. If this =1 it means
|
---|
| 24 | ; 'kill the old list & start where you finished'
|
---|
| 25 | ; Note: Don't Return DFNs where $D(^TMP("SCMC",$J,"EXCLUDE PT","SCPTA",+DFN)) is true
|
---|
| 26 | ; Output:
|
---|
| 27 | ; SCLIST() = array of patients
|
---|
| 28 | ; Format:
|
---|
| 29 | ; Subscript: Sequential # from 1 to n
|
---|
| 30 | ; Piece Description
|
---|
| 31 | ; 1 IEN of PATIENT file entry
|
---|
| 32 | ; 2 Name of patient
|
---|
| 33 | ; 3 ien to 40.7 - Not Stop Code!! stp=$$intstp
|
---|
| 34 | ; 4 AMIS reporting stop code
|
---|
| 35 | ; 5 Patient's Long ID (SSN)
|
---|
| 36 | ;
|
---|
| 37 | ; SCEFFDT - negative of effective date
|
---|
| 38 | ; SCN - current subscript (counter) 1->n
|
---|
| 39 | ; SCPTA0 is 0 node of Patient Team Assignment file 1st piece is DFN
|
---|
| 40 | ; SCERR() = Array of DIALOG file messages(errors) .
|
---|
| 41 | ; @SCERR@(0)=number of errors, undefined if none
|
---|
| 42 | ; Foramt:
|
---|
| 43 | ; Subscript: Sequential # from 1 to n
|
---|
| 44 | ; Piece Description
|
---|
| 45 | ; 1 IEN of DIALOG file
|
---|
| 46 | ;
|
---|
| 47 | ; Returned: 1 if ok, 0 if error^More?
|
---|
| 48 | ;
|
---|
| 49 | ;
|
---|
| 50 | ST N SCEND,SCVSDT,SCSTART
|
---|
| 51 | N SCLSEQ,SCN,SCESEQ,SCPARM,SCP,SCBEGIN,SCEND,SCINCL,SCDTS
|
---|
| 52 | G:'$$OKDATA APQ ;check/setup variables
|
---|
| 53 | ; -- loop through visit file
|
---|
| 54 | LP S SCDT=SCBEGIN
|
---|
| 55 | S:'$P(SCEND,".",2) SCEND=$$FMADD^XLFDT(SCEND,1) ;ending is end of day
|
---|
| 56 | IF $G(MORE) D
|
---|
| 57 | .S SCSTART=$P($G(@SCLIST@(0)),U,2)
|
---|
| 58 | .S SCBEGIN=$P($G(@SCLIST@(0)),U,3)
|
---|
| 59 | .K @SCLIST
|
---|
| 60 | APQ Q $$PTAPX(.SCCL,.SCBEGIN,.SCEND,.SCMAXCNT,.SCLIST,.SCERR,.SCSTART)
|
---|
| 61 | ;
|
---|
| 62 | PTAPX(SCCL,SCBEGIN,SCEND,MAXCNT,SCLIST,SCERR,SCSTART) ;return appointments in dt range
|
---|
| 63 | ; Input: (As above plus:)
|
---|
| 64 | ; SCSTART - Continue with list at this point
|
---|
| 65 | ; output: SCN - COUNT OF PTS
|
---|
| 66 | ; returns: dfn^ptname^clinic^apptdt^long id
|
---|
| 67 | ;
|
---|
| 68 | ;initialize variables
|
---|
| 69 | N SCDT,SCARRAY,DFN,SDAPTCNT,SDARRAY,SDERR,SDX,SDY
|
---|
| 70 | K ^TMP($J,"SDAMA301")
|
---|
| 71 | ;setup call to SDAPI
|
---|
| 72 | S SDARRAY(1)=$G(SCBEGIN)_";"_$G(SCEND),SDARRAY(2)=$G(SCCL),SDARRAY("FLDS")=4
|
---|
| 73 | S SDARRAY("SORT")="P"
|
---|
| 74 | ;call SDAPI to retrieve appointments
|
---|
| 75 | S SDAPTCNT=$$SDAPI^SDAMA301(.SDARRAY)
|
---|
| 76 | ;handle errors if any returned from SDAPI and QUIT
|
---|
| 77 | I SDAPTCNT<0 D Q ($G(@SCERR@(0))<1)_U_(SCN'<SCMAXCNT)
|
---|
| 78 | .;call existing error handler
|
---|
| 79 | .D ERR^SCAPMCU1(.SCESEQ,,,"",.SCERR)
|
---|
| 80 | .K ^TMP($J,"SDAMA301")
|
---|
| 81 | ;if appointments returned
|
---|
| 82 | I SDAPTCNT>0 D
|
---|
| 83 | .;retrieve patient ID to start at if continuing list (was appt ifn)
|
---|
| 84 | .; * no code could be found to utilize continuation of a list
|
---|
| 85 | .; * if this changes this code should be revisited to ensure only 1
|
---|
| 86 | .; call to SDAPI is made.
|
---|
| 87 | .S DFN=+$G(SCSTART)
|
---|
| 88 | .S SCSTART=0
|
---|
| 89 | .S SCDT=0
|
---|
| 90 | .;resort appts to ensure same data is returned to user
|
---|
| 91 | .;only 1st appt date/time is needed for each patient
|
---|
| 92 | .;as patient can only be added to the list once.
|
---|
| 93 | .K ^TMP($J,"RE-SORT","SDAMA301")
|
---|
| 94 | .S (SDY,SDX)=0
|
---|
| 95 | .F S SDX=$O(^TMP($J,"SDAMA301",SDX)) Q:'SDX D
|
---|
| 96 | ..S SDY=$O(^TMP($J,"SDAMA301",SDX,""))
|
---|
| 97 | ..S ^TMP($J,"RE-SORT","SDAMA301",SDY,SDX)=""
|
---|
| 98 | .K ^TMP($J,"SDAMA301")
|
---|
| 99 | .;loop through re-sorted appts returned from SDAPI until
|
---|
| 100 | .; 1. no more patients with appointments exist
|
---|
| 101 | .; 2. number of patients found that match criteria is not less than max
|
---|
| 102 | .F S SCDT=$O(^TMP($J,"RE-SORT","SDAMA301",SCDT)) Q:'SCDT!(SCN'<SCMAXCNT) D
|
---|
| 103 | ..;get patient for the kept appointment in the re-sorted list
|
---|
| 104 | ..F S DFN=$O(^TMP($J,"RE-SORT","SDAMA301",SCDT,DFN)) Q:'DFN!(SCN'<SCMAXCNT) D
|
---|
| 105 | ...;quit if patient is found in either of the following lists
|
---|
| 106 | ...;this list may be used elsewhere, left in for compatibility
|
---|
| 107 | ...Q:$D(@SCLIST@("SCPTAP",+DFN))
|
---|
| 108 | ...Q:$D(^TMP("SCMC",$J,"EXCLUDE PT","SCPTA",+DFN))
|
---|
| 109 | ...;increment the patient counter and store in SCLIST
|
---|
| 110 | ...S SCN=$G(@SCLIST@(0))+1
|
---|
| 111 | ...S @SCLIST@(0)=SCN
|
---|
| 112 | ...;get the patient's long ID (SSN) and Name
|
---|
| 113 | ...D GETS^DIQ(2,+DFN,".01;.363","","SCARRAY")
|
---|
| 114 | ...;add the following appt info to SCLIST at the current Patient Counter
|
---|
| 115 | ...;1. Patient DFN 2. Patient Name 3. Clinic IEN 4. Appt DTM 5. Patients Long ID
|
---|
| 116 | ...S @SCLIST@(SCN)=DFN_U_$G(SCARRAY(2,+DFN_",",.01))_U_SCCL_U_SCDT_U_$G(SCARRAY(2,+DFN_",",.363))
|
---|
| 117 | ...;add the patient's DFN to the exclusion list
|
---|
| 118 | ...S @SCLIST@("SCPTAP",+DFN,+SCN)=""
|
---|
| 119 | ;kill the re-sorted appt global reference generated
|
---|
| 120 | K ^TMP($J,"RE-SORT","SDAMA301")
|
---|
| 121 | ;if # of patients found that match criteria is NOT LESS than the requested Max then
|
---|
| 122 | ;set SCLIST at the 0 Node to:
|
---|
| 123 | ;1.Current Patient Count 2. Current Patient Processing 3. Appt DTM 4. Clinic IEN
|
---|
| 124 | S:(SCN'<SCMAXCNT) @SCLIST@(0)=SCN_U_+$G(DFN)_U_+$G(SCDT)_U_+$G(SCCL)
|
---|
| 125 | Q ($G(@SCERR@(0))<1)_U_(SCN'<SCMAXCNT)
|
---|
| 126 | ;
|
---|
| 127 | OKDATA() ;check/setup variables
|
---|
| 128 | N SCOK
|
---|
| 129 | S SCOK=1
|
---|
| 130 | S SCMAXCNT=$G(SCMAXCNT,99)
|
---|
| 131 | D INIT^SCAPMCU1(.SCOK) ; set default dates & error array (if undefined)
|
---|
| 132 | IF '$D(^SC(+$G(SCCL),0)) D S SCOK=0
|
---|
| 133 | . S SCPARM("CLINIC")=$G(SCCL,"Undefined")
|
---|
| 134 | . D ERR^SCAPMCU1(.SCESEQ,4045101,.SCPARM,"",.SCERR)
|
---|
| 135 | ; -- is it a valid TEAM ien passed (Error # 4045101 in DIALOG file)
|
---|
| 136 | Q SCOK
|
---|