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

SDAMA202.m

Go to the documentation of this file.
  1. SDAMA202 ;BPOIFO/ACS-Scheduling Replacement APIs ; 12/13/04 3:15pm
  1. ;;5.3;Scheduling;**253,275,283,316,347**;13 Aug 1993
  1. ;
  1. ;GETPLIST - Returns appointment information for a clinic
  1. ;
  1. ;** BEFORE USING THE API IN THIS ROUTINE, PLEASE SUBSCRIBE **
  1. ;** TO DBIA #3869 **
  1. ;
  1. ;*******************************************************************
  1. ; CHANGE LOG
  1. ;
  1. ; DATE PATCH DESCRIPTION
  1. ;-------- ---------- -----------------------------------------
  1. ;09/20/02 SD*5.3*253 ROUTINE COMPLETED
  1. ;12/10/02 SD*5.3*275 ADDED PATIENT STATUS FILTER
  1. ;07/03/03 SD*5.3*283 REMOVED 'NO ACTION TAKEN' EDIT. REMOVED
  1. ; 'GETALLCL' API
  1. ;09/16/03 SD*5.3*316 EXCLUDE 'CANCELLED' APPTS. CHECK FOR
  1. ; CLINIC MATCH ON ^DPT
  1. ;07/26/04 SD*5.3*347 ADDED PATIENT VARIABLE CHECK TO ENSURE THAT
  1. ; VALUE RETURNED FROM $$GETPTIEN^SDAMA200 IS
  1. ; NOT NULL
  1. ; REMOVE DIRECT ACCESS TO DATA. ALL ACCESS
  1. ; THROUGH SDAPI ONLY
  1. ;********************************************************************
  1. ;
  1. GETPLIST(SDCLIEN,SDFIELDS,SDAPSTAT,SDSTART,SDEND,SDRESULT,SDIOSTAT) ;
  1. ;********************************************************************
  1. ;
  1. ; GET APPOINTMENTS FOR A CLINIC
  1. ;
  1. ;INPUT
  1. ; SDCLIEN Clinic IEN (required)
  1. ; SDFIELDS Fields requested (optional)
  1. ; SDAPSTAT Appointment Status filter (optional)
  1. ; SDSTART Start date/time (optional)
  1. ; SDEND End date/time (optional)
  1. ; SDRESULT Record count returned here (optional)
  1. ; SDIOSTAT Patient Status filter (optional)
  1. ;
  1. ;OUTPUT
  1. ; ^TMP($J,"SDAMA202","GETPLIST",X,Y)=FieldYdata
  1. ; where "X" is an incremental appointment counter and
  1. ; "Y" is the field number requested
  1. ;
  1. ;
  1. ;********************************************************************
  1. N SDAPINAM,SDRTNNAM
  1. S SDAPINAM="GETPLIST",SDRTNNAM="SDAMA202",SDRESULT=0
  1. K ^TMP($J,SDRTNNAM,SDAPINAM)
  1. S SDRESULT=$$VALIDATE^SDAMA200(.SDCLIEN,.SDFIELDS,.SDAPSTAT,.SDSTART,.SDEND,SDAPINAM,SDRTNNAM,.SDIOSTAT)
  1. I SDRESULT=-1 Q
  1. ;
  1. N SDCOUNT,SDNUM,SDTMP,SDI,SDARRAY,SDAPLST,SDX,SDY,SDCI,SDPI,SDTI,SDTR,SDF,SDA,SDR,SDO
  1. S (SDNUM,SDCOUNT,SDI)=0,(SDAPLST,SDTMP)=""
  1. F SDI="SDFIELDS","SDAPSTAT","SDSTART","SDEND","SDRESULT","SDIOSTAT" S @SDI=$G(@SDI)
  1. ; Quit if only status requested is "C"
  1. I SDAPSTAT="C"!(SDAPSTAT=";C;") S SDRESULT=0 Q
  1. I +SDSTART!(+SDEND) S SDARRAY(1)=SDSTART_";"_SDEND
  1. S SDARRAY(2)=SDCLIEN
  1. I $L($G(SDAPSTAT))>0 D
  1. . ;Remove a leading and a trailing semicolon
  1. . I $E(SDAPSTAT,$L(SDAPSTAT))=";" S SDAPSTAT=$E(SDAPSTAT,1,($L(SDAPSTAT)-1))
  1. . I $E(SDAPSTAT)=";" S SDAPSTAT=$E(SDAPSTAT,2,$L(SDAPSTAT))
  1. . ;IO/Appt Statuses have been validated by SDAMA200 to be I or O/R NT
  1. . I $L($G(SDIOSTAT))=1 S SDAPLST=$S(SDIOSTAT="I":"I;",SDIOSTAT="O":SDAPSTAT_";")
  1. . I $L($G(SDIOSTAT))'=1,$L($G(SDAPSTAT)) D
  1. .. ;Reset appointment status R=R;I N=NS,NSR
  1. .. S SDNUM=$L(SDAPSTAT,";") F SDI=1:1:SDNUM D
  1. ... S SDTMP=$P(SDAPSTAT,";",SDI) Q:SDTMP="C"
  1. ... S SDTMP=$S(SDTMP="R":"R;I",SDTMP="N":"NS;NSR",1:SDTMP)
  1. ... S SDAPLST=SDAPLST_SDTMP_";"
  1. . ;Remove trailing semicolon
  1. . S SDAPLST=$E(SDAPLST,1,($L(SDAPLST)-1))
  1. I $L($G(SDAPSTAT))=0 S SDAPLST="R;I;NS;NSR;NT"
  1. S SDARRAY(3)=SDAPLST
  1. ;Field List Conversion
  1. S SDARRAY("FLDS")=""
  1. F SDX=1:1 S SDY=$P(SDFIELDS,";",SDX) Q:SDY="" D
  1. . I SDY=12,SDFIELDS[3 Q ; if appt. stat. exists, pat. stat. not needed
  1. . I SDY=12 S SDY=3
  1. . S SDARRAY("FLDS")=SDARRAY("FLDS")_SDY_";"
  1. S:$L(SDARRAY("FLDS")) SDARRAY("FLDS")=$E(SDARRAY("FLDS"),1,$L(SDARRAY("FLDS"))-1)
  1. I '$L(SDFIELDS) S SDARRAY("FLDS")="1;2;3;4;5;6;7;8;9;10;11"
  1. ;
  1. ; Setup done, call SDAPI, quit if no appointment (SDCOUNT=0) and return 0
  1. SDAPI S (SDRESULT,SDCOUNT)=$$SDAPI^SDAMA301(.SDARRAY) I SDCOUNT=0 S SDRESULT=0 Q
  1. ;
  1. ;If we have an appointment, process it
  1. I SDCOUNT>0 S SDA=0,SDCI="" F S SDCI=$O(^TMP($J,"SDAMA301",SDCI)) Q:SDCI="" D
  1. . S SDPI="" F S SDPI=$O(^TMP($J,"SDAMA301",SDCI,SDPI)) Q:SDPI="" D
  1. .. S SDTI="" F S SDTI=$O(^TMP($J,"SDAMA301",SDCI,SDPI,SDTI)) Q:SDTI="" S SDTR=^(SDTI) D
  1. ... S SDA=SDA+1 F SDX=1:1 S SDF=$P(SDFIELDS,";",SDX),SDY=$P(SDTR,"^",SDF) Q:SDF="" D
  1. .... I "^1^5^9^11^"[(U_SDF_U) S SDO=SDY D OUT Q
  1. .... I "^2^4^8^10^"[(U_SDF_U) S SDO=$TR(SDY,";","^") D OUT Q
  1. .... I "^3^6^7^12^"[(U_SDF_U) D @("FLD"_SDF)
  1. ; Process errors if any
  1. I SDCOUNT<0 D
  1. .S SDRESULT=-1,SDX=$O(^TMP($J,"SDAMA301",""))
  1. .S SDX=$S(SDX=101:101,SDX=116:116,1:117)
  1. .D ERROR^SDAMA200(SDX,SDAPINAM,0,SDRTNNAM) Q
  1. K ^TMP($J,"SDAMA301")
  1. Q
  1. FLD3 S SDR=$P(SDY,";",1)
  1. S SDO=$S(SDR="I":"R",SDR?1(1"NS",1"NSR"):"N",1:SDR) D OUT
  1. Q
  1. FLD6 S SDO=$G(^TMP($J,"SDAMA301",SDCI,SDPI,SDTI,"C"))
  1. D OUT
  1. Q
  1. FLD7 S SDO=$S(SDY="":"N",1:SDY)
  1. D OUT
  1. Q
  1. FLD12 S SDR=$P($P(SDTR,U,3),";",1)
  1. S SDO=$S(SDR="I":"I",SDR="R":"O",SDR="NT":"O",1:"") D OUT
  1. Q
  1. OUT S ^TMP($J,"SDAMA202","GETPLIST",SDA,SDF)=SDO
  1. Q