VistA-Scheduling/m/BSDX05.m

64 lines
2.0 KiB
Mathematica
Raw Normal View History

BSDX05 ; IHS/OIT/HMW - WINDOWS SCHEDULING RPCS ; 7/15/10 12:51pm
2010-09-29 03:48:57 -04:00
;;1.41;BSDX;;Sep 29, 2010
2009-11-30 03:53:28 -05:00
;
2010-07-18 09:58:35 -04:00
; Change Log:
; UJO/SMH - July 11 2010: pass FM Dates for Start and End rather than US Dates
2009-11-30 03:53:28 -05:00
;
APBLKOV(BSDXY,BSDXSTART,BSDXEND,BSDXRES) ;EP
;Called by BSDX APPT BLOCKS OVERLAP
2010-07-18 09:58:35 -04:00
; July 11 2010 - pass FM Dates for Start and End rather than US Dates
2009-11-30 03:53:28 -05:00
;(Duplicates old qryAppointmentBlocksOverlapB)
;BSDXRES is resource name
;
;Test lines:
;D APBLKOV^BSDX05(.RES,"11-8-2000","11-8-2004","WHITT") ZW RES
;BSDX APPT BLOCKS OVERLAP^11-8-2000^11-8-2004^WHITT
;S ^HW("BSDXD05")=BSDXSTART_U_BSDXEND_U_BSDXRES
;
N BSDXERR,BSDXIEN,BSDXDEP,BSDXBS,BSDXI,BSDXNEND,BSDXNSTART,BSDXPEND,BSDXRESD,BSDXRESN,BSDXS,BSDXAD,BSDXNOD
K ^BSDXTMP($J)
S BSDXERR=""
S BSDXY="^BSDXTMP("_$J_")"
S ^BSDXTMP($J,0)="D00030START_TIME^D00030END_TIME"_$C(30)
D
. S BSDXBS=0
2010-07-12 10:25:21 -04:00
. S BSDXEND=BSDXEND+.9999 ;Go to end of day
2009-11-30 03:53:28 -05:00
. S BSDXRESN=BSDXRES
. Q:BSDXRESN=""
. Q:'$D(^BSDXRES("B",BSDXRESN))
. S BSDXRESD=$O(^BSDXRES("B",BSDXRESN,0))
. Q:'+BSDXRESD
. Q:'$D(^BSDXAPPT("ARSRC",BSDXRESD))
. D STRES(BSDXRESD,BSDXSTART,BSDXEND)
. Q
;
S BSDXI=$G(BSDXI)+1
S ^BSDXTMP($J,BSDXI)=$C(31)
Q
;
STRES(BSDXRESD,BSDXSTART,BSDXEND) ;
;$O THRU "ARSRC" XREF OF ^BSDXAPPT
;Start at the beginning of the day -- appts can't overlap days
S BSDXS=$P(BSDXSTART,"."),BSDXS=BSDXS-.0001
S BSDXI=0
F S BSDXS=$O(^BSDXAPPT("ARSRC",BSDXRESD,BSDXS)) Q:'+BSDXS Q:BSDXS>BSDXEND D
. S BSDXAD=0 F S BSDXAD=$O(^BSDXAPPT("ARSRC",BSDXRESD,BSDXS,BSDXAD)) Q:'+BSDXAD D STCOMM(BSDXAD) ;BSDXAD Is the AppointmentID
. Q
Q
;
STCOMM(BSDXAD) ;
S BSDXNEND=0,BSDXNSTART=0,BSDXPEND=0
Q:'$D(^BSDXAPPT(BSDXAD,0))
S BSDXNOD=^BSDXAPPT(BSDXAD,0)
Q:$P(BSDXNOD,U,10)=1 ;NO-SHOW Flag
Q:$P(BSDXNOD,U,12)]"" ;CANCELLED APPT
Q:$P(BSDXNOD,U,13)="y" ;WALKIN
S BSDXNSTART=$P(BSDXNOD,U)
S BSDXNEND=$P(BSDXNOD,U,2)
I BSDXNEND'>BSDXSTART Q ;End is less than start
S Y=BSDXNSTART X ^DD("DD") S BSDXNSTART=$TR(Y,"@"," ")
S Y=BSDXNEND X ^DD("DD") S BSDXNEND=$TR(Y,"@"," ")
S BSDXI=BSDXI+1
S ^BSDXTMP($J,BSDXI)=BSDXNSTART_U_BSDXNEND_$C(30)
Q