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

BSDX05.m

Go to the documentation of this file.
  1. BSDX05 ; IHS/OIT/HMW/MSC/SAT - WINDOWS SCHEDULING RPCS ;
  1. ;;3.0;IHS WINDOWS SCHEDULING;;DEC 09, 2010
  1. ;
  1. ;
  1. APBLKOV(BSDXY,BSDXSTART,BSDXEND,BSDXRES,BSDXWI) ;EP
  1. ;Called by BSDX APPT BLOCKS OVERLAP
  1. ;(Duplicates old qryAppointmentBlocksOverlapB)
  1. ;BSDXRES is resource name
  1. ;BSDXWI is for walk-in appointments. 1 - Include walkins, otherwise do not include them.
  1. ;
  1. ;Test lines:
  1. ;D APBLKOV^BSDX05(.RES,"11-8-2000","11-8-2004","WHITT") ZW RES
  1. ;BSDX APPT BLOCKS OVERLAP^11-8-2000^11-8-2004^WHITT
  1. ;S ^HW("BSDXD05")=BSDXSTART_U_BSDXEND_U_BSDXRES
  1. ;
  1. N BSDXERR,BSDXIEN,BSDXDEP,BSDXBS,BSDXI,BSDXNEND,BSDXNSTART,BSDXPEND,BSDXRESD,BSDXRESN,BSDXS,BSDXAD,BSDXNOD,BSDXPAT
  1. K ^BSDXTMP($J)
  1. S BSDXERR=""
  1. S BSDXY="^BSDXTMP("_$J_")"
  1. S ^BSDXTMP($J,0)="D00030START_TIME^D00030END_TIME^I00010PAT_ID"_$C(30)
  1. D
  1. . S BSDXBS=0
  1. . S:BSDXSTART["@0000" BSDXSTART=$P(BSDXSTART,"@")
  1. . S:BSDXEND["@0000" BSDXEND=$P(BSDXEND,"@")
  1. . S %DT="T",X=BSDXSTART D ^%DT S BSDXSTART=Y
  1. . I BSDXSTART=-1 S ^BSDXTMP($J,1)=$C(31) Q
  1. . S %DT="T",X=BSDXEND D ^%DT S BSDXEND=Y
  1. . I BSDXEND=-1 S ^BSDXTMP($J,1)=$C(31) Q
  1. . I $L(BSDXEND,".")=1 S BSDXEND=BSDXEND+.9999 ;Go to end of day
  1. . S BSDXRESN=BSDXRES
  1. . Q:BSDXRESN=""
  1. . Q:'$D(^BSDXRES("B",BSDXRESN))
  1. . S BSDXRESD=$O(^BSDXRES("B",BSDXRESN,0))
  1. . Q:'+BSDXRESD
  1. . Q:'$D(^BSDXAPPT("ARSRC",BSDXRESD))
  1. . D STRES(BSDXRESD,BSDXSTART,BSDXEND,$G(BSDXWI))
  1. . Q
  1. ;
  1. S BSDXI=$G(BSDXI)+1
  1. S ^BSDXTMP($J,BSDXI)=$C(31)
  1. Q
  1. ;
  1. APBLKALL(BSDXY,BSDXSTART,BSDXEND) ;EP
  1. ; List of all appointments for all resources. - BWF/MSC, added 3-1-2010
  1. ; Called by BSDX ALL APPOINTMENTS
  1. ;
  1. ; Input: BSDXSTART - Start Date
  1. ; BSDXEND - End Date
  1. ;
  1. ;Test Lines:
  1. ;D APBLKALL^BSDX05(.RES,"11-8-2000","11-8-2004") ZW RES
  1. ;BSDX ALL APPOINTMENTS^11-8-2000^11-8-2004
  1. ;
  1. N BSDXRIEN,BSDXRESN,BSDXI
  1. S BSDXRIEN=0 F S BSDXRIEN=$O(^BSDXRES(BSDXRIEN)) Q:'BSDXRIEN D
  1. .S BSDXRESN=$$GET1^DIQ(9002018.1,BSDXRIEN,.01,"E")
  1. .Q:BSDXRESN=""
  1. .; Call existing API to gather appointments for each resource found
  1. .D APBLKOV(.BSDXDATA,BSDXSTART,BSDXEND,BSDXRESN,1)
  1. .D GATHER(BSDXDATA,BSDXRESN)
  1. .K ^BSDXTMP($J)
  1. M ^BSDXTMP($J)=^BSDXTMP("BSDX05",$J)
  1. K ^BSDXTMP("BSDX05",$J)
  1. S BSDXY="^BSDXTMP("_$J_")"
  1. S ^BSDXTMP($J,0)="D00030START_TIME^D00030END_TIME^I00010PAT_ID^T00030RES_NAME"_$C(30)
  1. S BSDXI=$O(^BSDXTMP($J,""),-1),BSDXI=$G(BSDXI)+1
  1. S ^BSDXTMP($J,BSDXI)=$C(31)
  1. Q
  1. ;
  1. GATHER(BSDXDAT,BSDXRESN) ;
  1. ; Called by APBLKBR to retrieve data gathered for each resource.
  1. N X,BSDXADAT,BSDXI
  1. S X=0 F S X=$O(@BSDXDAT@(X)) Q:'X D
  1. .S BSDXADAT=$G(@BSDXDAT@(X)) Q:BSDXADAT=$C(31)
  1. .S BSDXI=$O(^BSDXTMP("BSDX05",$J,""),-1) S BSDXI=$G(BSDXI)+1
  1. .S ^BSDXTMP("BSDX05",$J,BSDXI)=$P(BSDXADAT,$C(30))_U_BSDXRESN_$C(30)
  1. Q
  1. ;
  1. STRES(BSDXRESD,BSDXSTART,BSDXEND,BSDXWI) ;
  1. ;$O THRU "ARSRC" XREF OF ^BSDXAPPT
  1. ;Start at the beginning of the day -- appts can't overlap days
  1. S BSDXS=$P(BSDXSTART,"."),BSDXS=BSDXS-.0001
  1. S BSDXI=0
  1. F S BSDXS=$O(^BSDXAPPT("ARSRC",BSDXRESD,BSDXS)) Q:'+BSDXS Q:BSDXS>BSDXEND D
  1. . S BSDXAD=0 F S BSDXAD=$O(^BSDXAPPT("ARSRC",BSDXRESD,BSDXS,BSDXAD)) Q:'+BSDXAD D STCOMM(BSDXAD,$G(BSDXWI)) ;BSDXAD Is the AppointmentID
  1. . Q
  1. Q
  1. ;
  1. STCOMM(BSDXAD,BSDXWI) ;
  1. S BSDXNEND=0,BSDXNSTART=0,BSDXPEND=0
  1. Q:'$D(^BSDXAPPT(BSDXAD,0))
  1. S BSDXNOD=^BSDXAPPT(BSDXAD,0)
  1. S BSDXPAT=$P(BSDXNOD,U,5)
  1. Q:$P(BSDXNOD,U,10)=1 ;NO-SHOW Flag
  1. Q:$P(BSDXNOD,U,12)]"" ;CANCELLED APPT
  1. I '$G(BSDXWI) Q:$P(BSDXNOD,U,13)="y" ;WALKIN
  1. S BSDXNSTART=$P(BSDXNOD,U)
  1. S BSDXNEND=$P(BSDXNOD,U,2)
  1. I BSDXNEND'>BSDXSTART Q ;End is less than start
  1. S Y=BSDXNSTART X ^DD("DD") S BSDXNSTART=$TR(Y,"@"," ")
  1. S Y=BSDXNEND X ^DD("DD") S BSDXNEND=$TR(Y,"@"," ")
  1. S BSDXI=BSDXI+1
  1. S ^BSDXTMP($J,BSDXI)=BSDXNSTART_U_BSDXNEND_U_BSDXPAT_$C(30)
  1. Q