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

BSDX33.m

Go to the documentation of this file.
  1. BSDX33 ; IHS/OIT/HMW/MSC/SAT - WINDOWS SCHEDULING RPCS ;
  1. ;;3.0;IHS WINDOWS SCHEDULING;;DEC 09, 2010
  1. ;
  1. ;
  1. Q
  1. RBNEXTD(BSDXY,BSDXDATE,BSDXRES,BSDXTPID) ;EP
  1. ;Entry point for debugging
  1. ;
  1. ;D DEBUG^%Serenji("RBNEXT^BSDX33(.BSDXY,BSDXDATE,BSDXRES,BSDXTPID)")
  1. Q
  1. ;
  1. RBNEXT(BSDXY,BSDXDATE,BSDXRES,BSDXTPID) ;EP
  1. ;Called by BSDX REBOOK NEXT BLOCK to find
  1. ;the next ACCESS BLOCK in resource BSDXRES after BSDXSTART
  1. ;Returns 1 in ERRORID and date in NEXTBLOCK if a block was found or NULL in NEXTBLOCK of no date found
  1. ;Otherwise, returns 0 and error message in ERRORTEXT
  1. ;If BSDXTPID = 0 then any access type match
  1. ;
  1. S X="ERROR2^BSDX33",@^%ZOSF("TRAP")
  1. N BSDXI,BSDXIENS,%DT,BSDXMSG,Y,BSDXRESD,BSDXFND,BSDXIEN,BSDXNOD,BSDXATID
  1. S BSDXY="^BSDXTMP("_$J_")"
  1. S BSDXI=0
  1. S ^BSDXTMP($J,BSDXI)="I00020ERRORID^D00010NEXTBLOCK^T00030ERRORTEXT"_$C(30)
  1. ;
  1. I BSDXRES="" D ERR2("BSDX REBOOK NEXT BLOCK: Invalid resource name") Q
  1. I '$D(^BSDXRES("B",BSDXRES)) D ERR2("BSDX REBOOK NEXT BLOCK: Invalid resource name") Q
  1. S BSDXRESD=$O(^BSDXRES("B",BSDXRES,0))
  1. I '+BSDXRESD D ERR2("BSDX REBOOK NEXT BLOCK: Invalid resource name") Q
  1. S X=BSDXDATE,%DT="XT" D ^%DT
  1. I Y=-1 D ERR2(1,"BSDX REBOOK NEXT BLOCK: Invalid datetime") Q
  1. S BSDXDATE=$P(Y,".")
  1. ;
  1. S BSDXFND=0
  1. F S BSDXDATE=$O(^BSDXAB("ARSCT",BSDXRESD,BSDXDATE)) Q:'+BSDXDATE D Q:BSDXFND
  1. . S BSDXIEN=0 F S BSDXIEN=$O(^BSDXAB("ARSCT",BSDXRESD,BSDXDATE,BSDXIEN)) Q:'+BSDXIEN D Q:BSDXFND
  1. . . Q:'$D(^BSDXAB(BSDXIEN,0))
  1. . . S BSDXNOD=^BSDXAB(BSDXIEN,0)
  1. . . Q:+$P(BSDXNOD,U,4)=0 ;Slots
  1. . . S BSDXATID=$P(BSDXNOD,U,5)
  1. . . I BSDXTPID=0!(BSDXATID=BSDXTPID) S BSDXFND=$P(BSDXNOD,U,2) Q
  1. ;
  1. I BSDXFND=0 S BSDXFND=""
  1. E S Y=BSDXFND X ^DD("DD") S BSDXFND=Y
  1. S BSDXFND=$TR(BSDXFND,"@"," ")
  1. S BSDXI=BSDXI+1
  1. S ^BSDXTMP($J,BSDXI)="1^"_BSDXFND_"^"_$C(30)_$C(31)
  1. Q
  1. SETRBKD(BSDXY,BSDXAPPT,BSDXDATE) ;EP
  1. ;Entry point for debugging
  1. ;
  1. ;D DEBUG^%Serenji("SETRBK^BSDX33(.BSDXY,BSDXAPPT,BSDXDATE)")
  1. Q
  1. ;
  1. SETRBK(BSDXY,BSDXAPPT,BSDXDATE) ;EP
  1. ;
  1. ;Sets rebook date into appointment
  1. ;BSDXAPPT - Appointment ID
  1. ;BSDXDATE - Rebook Datetime in external format
  1. ;Called by BSDX REBOOK SET
  1. ;
  1. ;ErrorID:
  1. ; 0 if a problem. Message in ERRORTEXT
  1. ; 1 if OK
  1. ;
  1. S X="ERROR^BSDX33",@^%ZOSF("TRAP")
  1. N BSDXI,BSDXIENS,%DT,BSDXMSG,Y
  1. S BSDXY="^BSDXTMP("_$J_")"
  1. S BSDXI=0
  1. S ^BSDXTMP($J,BSDXI)="I00020ERRORID^T00030ERRORTEXT"_$C(30)
  1. ;
  1. I '+BSDXAPPT
  1. I '$D(^BSDXAPPT(BSDXAPPT,0)) D ERR(1,"BSDX REBOOK SET: Invalid appointment ID") Q
  1. S X=BSDXDATE,%DT="XT" D ^%DT
  1. I Y=-1 D ERR(1,"BSDX REBOOK SET: Invalid rebook datetime") Q
  1. S BSDXDATE=Y
  1. S BSDXIENS=BSDXAPPT_","
  1. S BSDXFDA(9002018.4,BSDXIENS,.11)=BSDXDATE
  1. ;
  1. K BSDXMSG
  1. D FILE^DIE("","BSDXFDA","BSDXMSG")
  1. S BSDXI=BSDXI+1
  1. S ^BSDXTMP($J,BSDXI)="1^"_$C(31)
  1. ;
  1. Q
  1. ;
  1. ERR(BSDXERID,ERRTXT) ;Error processing
  1. S:'+$G(BSDXI) BSDXI=999999
  1. S BSDXI=BSDXI+1
  1. S ^BSDXTMP($J,BSDXI)=BSDXERID_"^"_ERRTXT_$C(30)
  1. S BSDXI=BSDXI+1
  1. S ^BSDXTMP($J,BSDXI)=$C(31)
  1. Q
  1. ;
  1. ERROR ;
  1. D ^%ZTER
  1. I '+$G(BSDXI) N BSDXI S BSDXI=999999
  1. S BSDXI=BSDXI+1
  1. D ERR(0,"BSDX33 M Error: <"_$G(%ZTERROR)_">")
  1. Q
  1. ;
  1. ERR2(BSDXERID,ERRTXT) ;Error processing
  1. S:'+$G(BSDXI) BSDXI=999999
  1. S BSDXI=BSDXI+1
  1. S ^BSDXTMP($J,BSDXI)=BSDXERID_"^^"_ERRTXT_$C(30)
  1. S BSDXI=BSDXI+1
  1. S ^BSDXTMP($J,BSDXI)=$C(31)
  1. Q
  1. ;
  1. ERROR2 ;
  1. D ^%ZTER
  1. I '+$G(BSDXI) N BSDXI S BSDXI=999999
  1. S BSDXI=BSDXI+1
  1. D ERR2(0,"BSDX33 M Error: <"_$G(%ZTERROR)_">")
  1. Q