166 lines
5.8 KiB
Mathematica
166 lines
5.8 KiB
Mathematica
BSDX04 ; IHS/OIT/HMW - WINDOWS SCHEDULING RPCS ; ; 4/28/11 10:15am
|
|
;;1.6T2;BSDX;;May 16, 2011
|
|
; Licensed under LGPL
|
|
; Change Log:
|
|
; July 11 2010: Pass BSDXSTART and END as FM dates rather than US formatted dates
|
|
; for i18n
|
|
; Feb 27 2010 (v. 1.5) SMH
|
|
; - Grab multiple resources instead of a single resource.
|
|
; --> Will be passed from C# as | delimited.
|
|
; - Change in algorithm. Padding part to pad start and end dates to coincide
|
|
; --> with schedule now not performed. C# won't need that anymore.
|
|
;
|
|
;
|
|
CASSCHD(BSDXY,BSDXRES,BSDXSTART,BSDXEND,BSDXTYPES,BSDXSRCH) ;EP
|
|
;
|
|
;D DEBUG^%Serenji("CASSCH^BSDX04(.BSDXY,BSDXRES,BSDXSTART,BSDXEND,BSDXTYPES,BSDXSRCH)")
|
|
;
|
|
Q
|
|
;
|
|
CASSET ;EP
|
|
;Error Trap
|
|
D ^%ZTER
|
|
I '$D(BSDXI) N BSDXI S BSDXI=99999
|
|
S BSDXI=BSDXI+1
|
|
S ^BSDXTMP($J,BSDXI)=$C(31)
|
|
Q
|
|
;
|
|
CASSCH(BSDXY,BSDXRES,BSDXSTART,BSDXEND,BSDXTYPES,BSDXSRCH) ;EP -- RPC: BSDX CREATE ASGND SLOT SCHED
|
|
;Create Assigned Slot Schedule recordset (Access Blocks, Availabilities, etc.)
|
|
;This call is used both to create a schedule of availability for the calendar display
|
|
;and to search for availability in the Find Appointment function
|
|
;
|
|
;BSDXRES is resources name, delimited by |
|
|
;
|
|
; BSDXSTART and BSDXEND both passed in FM Format.
|
|
; BSDXSTART is the Date Portion of FM Date
|
|
; BSDXEND -- pass date and h,m,s as well
|
|
;
|
|
;BSDXTYPES is |-delimited list of Access Type Names
|
|
;If BSDXTYPES is "" then the screen passes all types.
|
|
;
|
|
;BSDXSRCH is |-delimited search info for the Find Appointment function
|
|
;First piece is 1 if we are in a Find Appointment call
|
|
;Second piece is weekday info in the format MTWHFSU
|
|
;Third piece is AM PM info in the form AP
|
|
;If 2nd or 3rd pieces are null, the screen for that piece is skipped
|
|
;
|
|
;Test lines:
|
|
;D CASSCH^BSDX04(.RES,"REMILLARD,MIKE","<fmdate>","<fmdate>") ZW RES
|
|
;BSDX CREATE ASGND SLOT SCHED^ROGERS,BUCK^<fmdate>^<fmdate>^2
|
|
;S ^HW("BSDX04")=BSDXRES_U_BSDXSTART_U_BSDXEND
|
|
;
|
|
N BSDXERR,BSDXIEN,BSDXDEP,BSDXTYPED,BSDXTYPE,BSDXBS,BSDXI,BSDXNEND,BSDXNSTART,BSDXPEND,BSDXRESD,BSDXRESN,BSDXS,BSDXZ,BSDXTMP,BSDXQ,BSDXNOT,BSDXNOD,BSDXAD
|
|
N BSDXSUBCD
|
|
S X="CASSET^BSDX04",@^%ZOSF("TRAP")
|
|
K ^BSDXTMP($J)
|
|
S BSDXERR=""
|
|
S BSDXY="^BSDXTMP("_$J_")"
|
|
S ^BSDXTMP($J,0)="D00030START_TIME^D00030END_TIME^I00010SLOTS^T00030RESOURCE^T00010ACCESS_TYPE^T00250NOTE^I00030AVAILABILITYID"_$C(30)
|
|
S BSDXI=2
|
|
;
|
|
;Get Access Type IDs
|
|
N BSDXK,BSDXTYPED,BSDXL
|
|
I '+BSDXSRCH S BSDXTYPED=""
|
|
I +BSDXSRCH F BSDXK=1:1:$L(BSDXTYPES,"|") D
|
|
. S BSDXL=$P(BSDXTYPES,"|",BSDXK)
|
|
. I BSDXL="" S $P(BSDXTYPED,"|",BSDXK)=0 Q
|
|
. I '$D(^BSDXTYPE("B",BSDXL)) S $P(BSDXTYPED,"|",BSDXK)=0 Q
|
|
. S $P(BSDXTYPED,"|",BSDXK)=$O(^BSDXTYPE("B",BSDXL,0))
|
|
;
|
|
N BSDXCOUN ; Counter
|
|
FOR BSDXCOUN=1:1:$L(BSDXRES,"|") DO ;smh - d in algo to do multiple res
|
|
. S BSDXRESN=$P(BSDXRES,"|",BSDXCOUN)
|
|
. Q:BSDXRESN=""
|
|
. Q:'$D(^BSDXRES("B",BSDXRESN))
|
|
. S BSDXRESD=$O(^BSDXRES("B",BSDXRESN,0))
|
|
. Q:'+BSDXRESD
|
|
. Q:'$D(^BSDXAB("ARSCT",BSDXRESD))
|
|
. S BSDXBS=0
|
|
. D STRES(BSDXRESN,BSDXRESD)
|
|
. Q
|
|
;
|
|
; V 1.5 -- All of this commented out; algo changed on C# side.
|
|
;start, end, slots, resource, accesstype, note, availabilityid
|
|
;I '+BSDXSRCH,BSDXALO D
|
|
; I BSDXALO D
|
|
; . ;If first block start time > input start time then pad with new block
|
|
; . I BSDXBS>BSDXSTART K BSDXTMP D
|
|
; . . S Y=BSDXSTART X ^DD("DD") S Y=$TR(Y,"@"," ")
|
|
; . . S BSDXTMP=Y
|
|
; . . S Y=BSDXBS X ^DD("DD") S Y=$TR(Y,"@"," ")
|
|
; . . S BSDXTMP=BSDXTMP_"^"_Y_"^0^"_BSDXRESN_"^0^^0"_$C(30)
|
|
; . . S ^BSDXTMP($J,1)=BSDXTMP
|
|
; . ;
|
|
; . ;If first block start time < input start time then trim
|
|
; . I BSDXBS<BSDXSTART D
|
|
; . . S Y=BSDXSTART
|
|
; . . X ^DD("DD") S Y=$TR(Y,"@"," ")
|
|
; . . S $P(^BSDXTMP($J,2),U,1)=Y
|
|
; . ;
|
|
; . ;If last block end time < input end time then pad end with new block
|
|
; . I BSDXPEND<BSDXEND D
|
|
; . . S Y=BSDXPEND X ^DD("DD") S Y=$TR(Y,"@"," ")
|
|
; . . S BSDXTMP=Y
|
|
; . . S Y=BSDXEND X ^DD("DD") S Y=$TR(Y,"@"," ")
|
|
; . . S BSDXTMP=BSDXTMP_"^"_Y_"^0^"_BSDXRESN_"^0^^0"_$C(30)
|
|
; . . S ^BSDXTMP($J,BSDXI-1)=BSDXTMP
|
|
; . ;
|
|
S ^BSDXTMP($J,BSDXI)=$C(31)
|
|
Q
|
|
;
|
|
STRES(BSDXRESN,BSDXRESD) ;
|
|
;BSDXRESD is a Resource ID
|
|
;$O THRU "ARSCT" XREF OF ^BSDXAB
|
|
S BSDXS=$P(BSDXSTART,"."),BSDXS=BSDXS-.0001
|
|
S BSDXNEND=0,BSDXNSTART=0,BSDXPEND=0
|
|
F S BSDXS=$O(^BSDXAB("ARSCT",BSDXRESD,BSDXS)) Q:'+BSDXS Q:BSDXS>BSDXEND D
|
|
. S BSDXAD=0 F S BSDXAD=$O(^BSDXAB("ARSCT",BSDXRESD,BSDXS,BSDXAD)) Q:'+BSDXAD D STCOMM(BSDXRESN,BSDXRESD,BSDXS,BSDXAD) ;BSDXAD Is the AvailabilityID
|
|
. Q
|
|
Q
|
|
;
|
|
STCOMM(BSDXRESN,BSDXRESD,BSDXS,BSDXAD) ;
|
|
N BSDXNSTART,BSDXNEND,BSDXNOD,Y,BSDXQ,BSDXZ,BSDXATID,BSDXATOK
|
|
Q:'$D(^BSDXAB(BSDXAD,0))
|
|
S BSDXNOD=^BSDXAB(BSDXAD,0)
|
|
S BSDXATID=$P(BSDXNOD,U,5)
|
|
;
|
|
;Screen for Access Type
|
|
;S BSDXATOK=0
|
|
;I BSDXTYPED="" S BSDXATOK=1
|
|
;E D
|
|
;. F J=1:1:$L(BSDXTYPED,"|") I BSDXATID=$P(BSDXTYPED,"|",J) S BSDXATOK=1 Q
|
|
;Q:'BSDXATOK
|
|
;
|
|
;I +BSDXSRCH
|
|
;Screen for Weekday
|
|
;
|
|
;Screen for AM PM
|
|
;
|
|
S BSDXZ=""
|
|
S BSDXNSTART=$P(BSDXNOD,U,2)
|
|
S BSDXNEND=$P(BSDXNOD,U,3)
|
|
I BSDXNEND'>BSDXSTART Q ;End is less than start
|
|
I +BSDXBS=0 S BSDXBS=$P(BSDXNOD,U,2) ;First block start time
|
|
F BSDXQ=2:1:3 D ;Start and End times
|
|
. S Y=$P(BSDXNOD,U,BSDXQ)
|
|
. X ^DD("DD") S Y=$TR(Y,"@"," ")
|
|
. S BSDXZ=BSDXZ_Y_"^"
|
|
S BSDXZ=BSDXZ_$P(BSDXNOD,U,4)_"^" ;SLOTS
|
|
S BSDXZ=BSDXZ_BSDXRESN_"^" ;Resource name
|
|
S BSDXZ=BSDXZ_BSDXATID_"^" ;Access type ID
|
|
S BSDXNOT="",BSDXQ=0 F S BSDXQ=$O(^BSDXAB(BSDXAD,1,BSDXQ)) Q:'+BSDXQ D
|
|
. S BSDXNOT=BSDXNOT_$G(^BSDXAB(BSDXAD,1,BSDXQ,0))_" "
|
|
S BSDXZ=BSDXZ_BSDXNOT ;_"^"
|
|
;I '+BSDXSRCH,BSDXPEND,BSDXNSTART>BSDXPEND D ;Fill in gap between appointment
|
|
I BSDXPEND,BSDXNSTART>BSDXPEND D ;Fill in gap between appointment
|
|
. S Y=BSDXPEND X ^DD("DD") S Y=$TR(Y,"@"," ")
|
|
. S BSDXTMP=Y
|
|
. S Y=BSDXNSTART X ^DD("DD") S Y=$TR(Y,"@"," ")
|
|
. S BSDXTMP=BSDXTMP_"^"_Y_"^0^"_BSDXRESN_"^0^^0"_$C(30)
|
|
. S ^BSDXTMP($J,BSDXI-1)=BSDXTMP
|
|
S BSDXPEND=BSDXNEND
|
|
S ^BSDXTMP($J,BSDXI)=BSDXZ_"^"_BSDXAD_$C(30)
|
|
S BSDXI=BSDXI+2
|
|
Q
|