BSDX33 ; IHS/OIT/HMW - WINDOWS SCHEDULING RPCS ; 7/15/10 12:33pm ;;1.5;BSDX;;Jan 25, 2011 ; Mods by WV/STAR ; ; Change Log: ; July 13, 2010 ; v 1.3 adds fixes Rebooking behavior in application (see RBNEXT) ; also adds i18 support - Dates passed in FM format from application ; in tag SETRBK and RBNEXT ; ; Q RBNEXTD(BSDXY,BSDXDATE,BSDXRES,BSDXTPID) ;EP ;Entry point for debugging ; ;D DEBUG^%Serenji("RBNEXT^BSDX33(.BSDXY,BSDXDATE,BSDXRES,BSDXTPID)") Q ; RBNEXT(BSDXY,BSDXDATE,BSDXRES,BSDXTPID) ;EP ;Called by BSDX REBOOK NEXT BLOCK to find ;the next ACCESS BLOCK in resource BSDXRES after BSDXDATE ;Returns 1 in ERRORID and date in NEXTBLOCK if a block was found or NULL in NEXTBLOCK of no date found ;Otherwise, returns 0 and error message in ERRORTEXT ;If BSDXTPID = 0 then any access type match ; S X="ERROR2^BSDX33",@^%ZOSF("TRAP") N BSDXI,BSDXIENS,%DT,BSDXMSG,Y,BSDXRESD,BSDXFND,BSDXIEN,BSDXNOD,BSDXATID S BSDXY="^BSDXTMP("_$J_")" S BSDXI=0 S ^BSDXTMP($J,BSDXI)="I00020ERRORID^D00010NEXTBLOCK^T00030ERRORTEXT"_$C(30) ; I BSDXRES="" D ERR2("BSDX REBOOK NEXT BLOCK: Invalid resource name") Q I '$D(^BSDXRES("B",BSDXRES)) D ERR2("BSDX REBOOK NEXT BLOCK: Invalid resource name") Q S BSDXRESD=$O(^BSDXRES("B",BSDXRES,0)) I '+BSDXRESD D ERR2("BSDX REBOOK NEXT BLOCK: Invalid resource name") Q ; ; i18n fix ; S X=BSDXDATE,%DT="XT" D ^%DT ; I Y=-1 D ERR2(1,"BSDX REBOOK NEXT BLOCK: Invalid datetime") Q ; ; S BSDXDATE=$P(Y,".") ; S BSDXFND=0 F S BSDXDATE=$O(^BSDXAB("ARSCT",BSDXRESD,BSDXDATE)) Q:'+BSDXDATE D Q:BSDXFND . S BSDXIEN=0 F S BSDXIEN=$O(^BSDXAB("ARSCT",BSDXRESD,BSDXDATE,BSDXIEN)) Q:'+BSDXIEN D Q:BSDXFND . . Q:'$D(^BSDXAB(BSDXIEN,0)) . . S BSDXNOD=^BSDXAB(BSDXIEN,0) . . Q:+$P(BSDXNOD,U,4)=0 ;Slots . . S BSDXATID=$P(BSDXNOD,U,5) . . I BSDXTPID=0!(BSDXATID=BSDXTPID) S BSDXFND=$P(BSDXNOD,U,2) Q ; I BSDXFND=0 S BSDXFND="" E S Y=BSDXFND X ^DD("DD") S BSDXFND=Y S BSDXI=BSDXI+1 ;//smh - bug (V 1.3): Need to replace @ in FM date for C# to recognize it S BSDXFND=$TR(BSDXFND,"@"," ") ;//smh end fix S ^BSDXTMP($J,BSDXI)="1^"_BSDXFND_"^"_$C(30)_$C(31) Q SETRBKD(BSDXY,BSDXAPPT,BSDXDATE) ;EP ;Entry point for debugging ; ;D DEBUG^%Serenji("SETRBK^BSDX33(.BSDXY,BSDXAPPT,BSDXDATE)") Q ; SETRBK(BSDXY,BSDXAPPT,BSDXDATE) ;EP ; ;Sets rebook date into appointment ;BSDXAPPT - Appointment ID ;BSDXDATE - Rebook Datetime in internal format ;Called by BSDX REBOOK SET ; ;ErrorID: ; 0 if a problem. Message in ERRORTEXT ; 1 if OK ; S X="ERROR^BSDX33",@^%ZOSF("TRAP") N BSDXI,BSDXIENS,%DT,BSDXMSG,Y S BSDXY="^BSDXTMP("_$J_")" S BSDXI=0 S ^BSDXTMP($J,BSDXI)="I00020ERRORID^T00030ERRORTEXT"_$C(30) ; I '+BSDXAPPT I '$D(^BSDXAPPT(BSDXAPPT,0)) D ERR(1,"BSDX REBOOK SET: Invalid appointment ID") Q ; i18n (v 1.3) ;S X=BSDXDATE,%DT="XT" D ^%DT ;I Y=-1 D ERR(1,"BSDX REBOOK SET: Invalid rebook datetime") Q ;S BSDXDATE=Y S BSDXIENS=BSDXAPPT_"," S BSDXFDA(9002018.4,BSDXIENS,.11)=+BSDXDATE ; K BSDXMSG D FILE^DIE("","BSDXFDA","BSDXMSG") S BSDXI=BSDXI+1 S ^BSDXTMP($J,BSDXI)="1^"_$C(31) ; Q ; ERR(BSDXERID,ERRTXT) ;Error processing S:'+$G(BSDXI) BSDXI=999999 S BSDXI=BSDXI+1 S ^BSDXTMP($J,BSDXI)=BSDXERID_"^"_ERRTXT_$C(30) S BSDXI=BSDXI+1 S ^BSDXTMP($J,BSDXI)=$C(31) Q ; ERROR ; D ^%ZTER I '+$G(BSDXI) N BSDXI S BSDXI=999999 S BSDXI=BSDXI+1 D ERR(0,"BSDX33 M Error: <"_$G(%ZTERROR)_">") Q ; ERR2(BSDXERID,ERRTXT) ;Error processing S:'+$G(BSDXI) BSDXI=999999 S BSDXI=BSDXI+1 S ^BSDXTMP($J,BSDXI)=BSDXERID_"^^"_ERRTXT_$C(30) S BSDXI=BSDXI+1 S ^BSDXTMP($J,BSDXI)=$C(31) Q ; ERROR2 ; D ^%ZTER I '+$G(BSDXI) N BSDXI S BSDXI=999999 S BSDXI=BSDXI+1 D ERR2(0,"BSDX33 M Error: <"_$G(%ZTERROR)_">") Q