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

SDAMA305.m

Go to the documentation of this file.
  1. SDAMA305 ;BPOIFO/ACS-Filter API Get Data ; 6/21/05 1:50pm
  1. ;;5.3;Scheduling;**301,347,508,1015**;13 Aug 1993;Build 21
  1. ;PER VHA DIRECTIVE 2004-038, DO NOT MODIFY THIS ROUTINE
  1. ;
  1. ;*****************************************************************
  1. ; CHANGE LOG
  1. ;
  1. ; DATE PATCH DESCRIPTION
  1. ;-------- ---------- -----------------------------------------
  1. ;12/04/03 SD*5.3*301 ROUTINE COMPLETED
  1. ;08/06/04 SD*5.3*347 ADDITION OF A NEW FILTER - DATE APPOINTMENT
  1. ; MADE (FIELD #16) AND 2 NEW FIELDS TO RETURN:
  1. ; 1) AUTO-REBOOKED APPT DATE/TIME (FIELD #24)
  1. ; 2) NO-SHOW/CANCEL APPT DATE/TIME (FIELD #25)
  1. ; RENAME ENTRY POINT TO ROUTINE
  1. ;02/22/07 SD*5.3*508 SEE SDAMA301 FOR CHANGE LIST
  1. ;*****************************************************************
  1. ;
  1. ;*****************************************************************
  1. ; GET APPOINTMENT DATA FROM VISTA
  1. ;INPUT
  1. ; SDARRAY Appointment Filter array
  1. ;
  1. ;OUTPUT
  1. ; ^TMP($J,"SDAMA301",SORT1,SORT2,APPT D/T)
  1. ;*****************************************************************
  1. SETARRAY(SDARRAY) ;
  1. ;Initialize local variables
  1. N SDI,SDIEN,SDNAME,SDFLDS,SDDATA,SDCOUNT,SDFIELD,SDCLIEN,SDDV,SDSCRTCH
  1. S SDFLDS=SDARRAY("FLDS")
  1. S SDCOUNT=$L(SDFLDS,";")
  1. ;Add 1 to appointment count
  1. S SDARRAY("CNT")=(SDARRAY("CNT")+1)
  1. ;For each appoitment field requested
  1. F SDI=1:1:SDCOUNT D
  1. . S (SDIEN,SDNAME,SDDATA)=""
  1. . S SDFIELD=$P(SDFLDS,";",SDI)
  1. . ;get data
  1. . D @SDFIELD
  1. . ;nodes in output global can't be null
  1. . I $G(SDARRAY("SORT1"))="" S SDARRAY("SORT1")="X"_SDARRAY("CNT")
  1. . I $G(SDARRAY("SORT2"))="" S SDARRAY("SORT2")="Y"_SDARRAY("CNT")
  1. . ;add data to output array
  1. . ;Store information with just Patient IEN (No Clinic IEN) in the global reference
  1. . I $G(SDARRAY("SORT"))="P" D
  1. . .S:(SDFIELD<28) $P(^TMP($J,"SDAMA301",$G(SDARRAY("PAT")),SDARRAY("DATE")),"^",SDFIELD)=$S(SDFIELD=6:"",1:$G(SDDV(SDFIELD)))
  1. . .S:(SDFIELD>27) $P(^TMP($J,"SDAMA301",$G(SDARRAY("PAT")),SDARRAY("DATE"),0),"^",(SDFIELD#27))=$G(SDDV(SDFIELD))
  1. . .S:(SDFIELD=6) ^TMP($J,"SDAMA301",$G(SDARRAY("PAT")),SDARRAY("DATE"),"C")=$G(SDDV(SDFIELD))
  1. . ;Store information with Patient and Clinic IEN (Sort1, Sort2) in the global reference
  1. . I $G(SDARRAY("SORT"))'="P" D
  1. . .S:(SDFIELD<28) $P(^TMP($J,"SDAMA301",SDARRAY("SORT1"),SDARRAY("SORT2"),SDARRAY("DATE")),"^",SDFIELD)=$S(SDFIELD=6:"",1:$G(SDDV(SDFIELD)))
  1. . .S:(SDFIELD>27) $P(^TMP($J,"SDAMA301",SDARRAY("SORT1"),SDARRAY("SORT2"),SDARRAY("DATE"),0),"^",(SDFIELD#27))=$G(SDDV(SDFIELD))
  1. . .S:(SDFIELD=6) ^TMP($J,"SDAMA301",SDARRAY("SORT1"),SDARRAY("SORT2"),SDARRAY("DATE"),"C")=$G(SDDV(SDFIELD))
  1. Q
  1. 1 ;Appt date/time
  1. S SDDV(SDFIELD)=SDARRAY("DATE")
  1. Q
  1. 2 ;Clinic IEN and Name
  1. S SDIEN=+$G(SDARRAY("DPT0"))
  1. I '$G(SDIEN) S SDNAME=""
  1. E S SDNAME=$P($G(^SC(SDIEN,0)),"^",1)
  1. S SDDV(SDFIELD)=$G(SDIEN)_";"_$G(SDNAME)
  1. Q
  1. 3 ;Appt Status and Status Description
  1. N SDSTAT
  1. S SDSTAT=$P($G(SDARRAY("DPT0")),"^",2)
  1. I $G(SDSTAT)="" S SDDATA="R;SCHEDULED/KEPT"
  1. E D
  1. . S SDDATA=$S(SDSTAT="I":"I;INPATIENT",SDSTAT="C":"CC;CANCELLED BY CLINIC",1:"X")
  1. . I SDDATA="X" S SDDATA=$S(SDSTAT="CA":"CCR;CANCELLED BY CLINIC & RESCHEDULED",SDSTAT="PC":"CP;CANCELLED BY PATIENT",1:"X")
  1. . I SDDATA="X" S SDDATA=$S(SDSTAT="PCA":"CPR;CANCELLED BY PATIENT & RESCHEDULED",SDSTAT="N":"NS;NO-SHOW",1:"X")
  1. . I SDDATA="X" S SDDATA=$S(SDSTAT="NA":"NSR;NO-SHOW & RESCHEDULED",SDSTAT="NT":"NT;NO ACTION TAKEN",1:SDSTAT_";UNKNOWN")
  1. S SDDV(SDFIELD)=SDDATA
  1. Q
  1. 4 ;Patient IEN and Name
  1. S SDIEN=$G(SDARRAY("PAT"))
  1. S SDNAME=$P($G(^DPT(SDIEN,0)),"^",1)
  1. S SDDV(SDFIELD)=$G(SDIEN)_";"_$G(SDNAME)
  1. Q
  1. 5 ;Length of Appt
  1. S SDDV(SDFIELD)=$P($G(SDARRAY("SC0")),"^",2)
  1. Q
  1. 6 ;Comments
  1. S SDDV(SDFIELD)=$P($G(SDARRAY("SC0")),"^",4)
  1. Q
  1. 7 ;Overbook (return null if appt cancelled)
  1. I $G(SDARRAY("SC0"))'="" D
  1. . S SDDATA=$P($G(SDARRAY("SCOB")),"^",1)
  1. . S SDDV(SDFIELD)=$S($G(SDDATA)="O":"Y",1:"N")
  1. Q
  1. 8 ;Local & National Eligiblity of Visit Codes and Names
  1. N SDELIG,SDPELIG,SDASTS,DFN,VAROOT,VAERR
  1. S VAERR=0,SDDATA=$P($G(SDARRAY("SC0")),"^",10)
  1. S SDASTS=$P($G(SDARRAY("DPT0")),"^",2)
  1. ;if eligibility is null, get patients primary eligibility
  1. ; * only if appointment status is not cancelled *
  1. I (($G(SDDATA)']"")&($G(SDASTS)'["C")) D
  1. . S VAROOT="SDPELIG",DFN=$G(SDARRAY("PAT")) D ELIG^VADPT
  1. . S SDDATA=$P(SDPELIG(1),"^")
  1. ;get local/national eligibility to add to output if
  1. ;ELIG^VADPT did not error and the ien is not null
  1. I (('VAERR)&($G(SDDATA)]"")) D
  1. . S SDELIG=$G(^DIC(8,SDDATA,0))
  1. . ;Append Local Eligibility IEN and Name
  1. . S SDDV(SDFIELD)=$G(SDDATA)_";"_$P(SDELIG,"^")
  1. . ;Append National Eligibility IEN and Name
  1. . S SDIEN=$P(SDELIG,"^",9)
  1. . I $G(SDIEN) D
  1. .. S SDNAME=$P($G(^DIC(8.1,SDIEN,0)),"^",1)
  1. .. S SDDV(SDFIELD)=SDDV(SDFIELD)_";"_$G(SDIEN)_";"_$G(SDNAME)
  1. Q
  1. 9 ;Check-In Date/time
  1. S SDSCRTCH=$P($G(SDARRAY("SCC")),"^",1)
  1. S SDDV(SDFIELD)=$S($L(SDSCRTCH)<13:SDSCRTCH,1:$E(SDSCRTCH,1,12))
  1. Q
  1. 10 ;Appt Type IEN and Name
  1. S SDIEN=$P($G(SDARRAY("DPT0")),"^",16)
  1. I $G(SDIEN)]"" D
  1. . S SDNAME=$P($G(^SD(409.1,SDIEN,0)),"^",1)
  1. . S SDDV(SDFIELD)=$G(SDIEN)_";"_$G(SDNAME)
  1. Q
  1. 11 ;Check-Out date/time
  1. S SDSCRTCH=$P($G(SDARRAY("SCC")),"^",3)
  1. S SDDV(SDFIELD)=$S($L(SDSCRTCH)<13:SDSCRTCH,1:$E(SDSCRTCH,1,12))
  1. Q
  1. 12 ;Outpatient Encounter
  1. S SDDV(SDFIELD)=$P($G(SDARRAY("DPT0")),"^",20)
  1. Q
  1. 13 ;Primary Stop Code IEN and AMIS STOP CODE
  1. N SDCODES
  1. S SDCLIEN=+SDARRAY("DPT0")
  1. I $G(SDCLIEN)]"" D
  1. . S SDCODES=$$GETSTOP(SDCLIEN)
  1. . I SDCODES'=-1 S SDDV(SDFIELD)=$P(SDCODES,"^",1)
  1. Q
  1. 14 ;Credit Stop Code IEN and AMIS STOP CODE
  1. S SDCLIEN=+SDARRAY("DPT0")
  1. I $G(SDCLIEN)]"" D
  1. . S SDCODES=$$GETSTOP(SDCLIEN)
  1. . I SDCODES'=-1 S SDDV(SDFIELD)=$P(SDCODES,"^",2)
  1. Q
  1. 15 ;Workload Non-Count
  1. S SDCLIEN=+SDARRAY("DPT0")
  1. I $G(SDCLIEN)]"" D
  1. . S SDCODES=$$GETSTOP(SDCLIEN)
  1. . I SDCODES'=-1 S SDDV(SDFIELD)=$P($G(SDCODES),"^",3)
  1. Q
  1. 16 ;Date Appt Made
  1. S SDDV(SDFIELD)=$P($P($G(SDARRAY("DPT0")),"^",19),".")
  1. Q
  1. 17 ;Desired Date of Appt
  1. S SDDV(SDFIELD)=$P($P($G(SDARRAY("DPT1")),"^",1),".")
  1. Q
  1. 18 ;Purpose of Visit
  1. S SDDATA=$P($G(SDARRAY("DPT0")),"^",7)
  1. I $G(SDDATA)'="" D
  1. . S SDDATA=SDDATA_$S(SDDATA="1":";C&P",SDDATA="2":";10-10",SDDATA="3":";SV",SDDATA="4":";UV",1:";")
  1. . S SDDV(SDFIELD)=SDDATA
  1. Q
  1. 19 ;EKG Date/time
  1. S SDSCRTCH=$P($G(SDARRAY("DPT0")),"^",5)
  1. S SDDV(SDFIELD)=$S($L(SDSCRTCH)<13:SDSCRTCH,1:$E(SDSCRTCH,1,12))
  1. Q
  1. 20 ;X-Ray Date/time
  1. S SDSCRTCH=$P($G(SDARRAY("DPT0")),"^",4)
  1. S SDDV(SDFIELD)=$S($L(SDSCRTCH)<13:SDSCRTCH,1:$E(SDSCRTCH,1,12))
  1. Q
  1. 21 ;Lab Date/time
  1. S SDSCRTCH=$P($G(SDARRAY("DPT0")),"^",3)
  1. S SDDV(SDFIELD)=$S($L(SDSCRTCH)<13:SDSCRTCH,1:$E(SDSCRTCH,1,12))
  1. Q
  1. 22 ;Status
  1. ; (Status IEN; Status Description; Print Status; Checked In Date/Time;
  1. ; Checked Out Date/Time; Admission Movement IEN)
  1. ;convert to new appt status code
  1. D 3
  1. S SDDV(SDFIELD)=$$STATUS^SDAMA308(+$G(SDARRAY("PAT")),+$G(SDARRAY("DATE")),+$G(SDARRAY("DPT0")),$P(SDDV(SDFIELD),";"),$P($G(SDARRAY("SCC")),"^"),$P($G(SDARRAY("SCC")),"^",3),$P($G(SDARRAY("DPT0")),"^",20))
  1. Q
  1. 23 ;X-Ray Films
  1. N SDRECS
  1. ;Get Clinic IEN, X-Ray Films Required
  1. S SDIEN=+$G(SDARRAY("DPT0"))
  1. S SDRECS=$P($G(^SC(SDIEN,"RAD")),"^")
  1. ;Translate Lower Case to Upper
  1. S SDRECS=$TR(SDRECS,"ny","NY")
  1. S SDDATA=$S(SDRECS["Y":"Y",1:"N")
  1. S SDDV(SDFIELD)=SDDATA
  1. Q
  1. 24 ;Auto-Rebooked Appt. Date/Time
  1. S SDSCRTCH=$P($G(SDARRAY("DPT0")),"^",10)
  1. S SDDV(SDFIELD)=$S($L(SDSCRTCH)<13:SDSCRTCH,1:$E(SDSCRTCH,1,12))
  1. Q
  1. 25 ;No-Show/Cancel Date/Time
  1. S SDSCRTCH=$P($G(SDARRAY("DPT0")),"^",14)
  1. S SDDV(SDFIELD)=$S($L(SDSCRTCH)<13:SDSCRTCH,1:$E(SDSCRTCH,1,12))
  1. Q
  1. ;This field is only associated with appt info from RSA
  1. ;(No VistA Scheduling Value Exists)
  1. 26 ;RSA Appointment ID
  1. Q
  1. 27 ;2507 Request IEN
  1. ;N SDREQ
  1. ;retrieve 2507 request for patient's appt
  1. ;S SDREQ=$$GET2507^DVBCMKLK(+$G(SDARRAY("PAT")),$G(SDARRAY("DATE")))
  1. ;S SDDV(SDFIELD)=$S((SDREQ>0):SDREQ,1:"")
  1. Q
  1. 28 ;Data Entry Clerk DUZ and Name
  1. N SDSTAT
  1. S SDSTAT=$P($G(SDARRAY("DPT0")),"^",2) ;determine appt status
  1. ;Appt is deleted from ^SC when appt is cancelled
  1. S SDSCRTCH=$S(SDSTAT["C":$P($G(SDARRAY("DPT0")),"^",18),1:$P($G(SDARRAY("SC0")),"^",6))
  1. S:(+SDSCRTCH) SDDV(SDFIELD)=SDSCRTCH_";"_$$GET1^DIQ(200,SDSCRTCH,.01)
  1. Q
  1. 29 ;No-Show/Cancelled By DUZ and Name
  1. S SDSCRTCH=$P($G(SDARRAY("DPT0")),"^",12)
  1. S:(+SDSCRTCH) SDDV(SDFIELD)=SDSCRTCH_";"_$$GET1^DIQ(200,SDSCRTCH,.01)
  1. Q
  1. 30 ;Check-In User DUZ and Name
  1. S SDSCRTCH=$P($G(SDARRAY("SCC")),"^",2)
  1. S:(+SDSCRTCH) SDDV(SDFIELD)=SDSCRTCH_";"_$$GET1^DIQ(200,SDSCRTCH,.01)
  1. Q
  1. 31 ;Check-Out User DUZ and Name
  1. S SDSCRTCH=$P($G(SDARRAY("SCC")),"^",4)
  1. S:(+SDSCRTCH) SDDV(SDFIELD)=SDSCRTCH_";"_$$GET1^DIQ(200,SDSCRTCH,.01)
  1. Q
  1. 32 ;Cancellation Reason IEN and Name
  1. S SDSCRTCH=$P($G(SDARRAY("DPT0")),"^",15)
  1. S:(+SDSCRTCH) SDDV(SDFIELD)=SDSCRTCH_";"_$$GET1^DIQ(409.2,SDSCRTCH,.01)
  1. Q
  1. 33 ;Consult Link IEN
  1. S SDDV(SDFIELD)=$G(SDARRAY("SCONS"))
  1. Q
  1. GETSTOP(SDCLIEN) ;Primary Stop Code, Credit Stop Code, Non-Count
  1. ; return codes or -1 if bad clinic
  1. N SDPSC,SDPSCIEN,SDCSC,SDCSCIEN,SDNC,SDCODES
  1. I +$G(SDCLIEN)=0 S SDCODES=-1
  1. I +$G(SDCLIEN)'=0 D
  1. . ;make sure clinic is on ^SC
  1. . I '$D(^SC(SDCLIEN)) S SDCODES=-1 Q
  1. . ;get primary stop code ien
  1. . S SDPSCIEN=$P($G(^SC(SDCLIEN,0)),"^",7)
  1. . ;get credit stop code ien
  1. . S SDCSCIEN=$P($G(^SC(SDCLIEN,0)),"^",18)
  1. . I $G(SDPSCIEN) S SDPSC=$P($G(^DIC(40.7,SDPSCIEN,0)),"^",2)
  1. . I $G(SDCSCIEN) S SDCSC=$P($G(^DIC(40.7,SDCSCIEN,0)),"^",2)
  1. . ;get workload non-count
  1. . S SDNC=$P($G(^SC(SDCLIEN,0)),"^",17)
  1. . S SDNC=$S($G(SDNC)="Y":"Y",1:"N")
  1. . S SDCODES=$G(SDPSCIEN)_";"_$G(SDPSC)_"^"_$G(SDCSCIEN)_";"_$G(SDCSC)_"^"_SDNC
  1. Q SDCODES