USP_DATAFORMTEMPLATE_ADD_SCHEDULEDATEADJUSTMENT
The save procedure used by the add dataform template "Adjustment Add Form".
Parameters
Parameter | Parameter Type | Mode | Description |
---|---|---|---|
@ID | uniqueidentifier | INOUT | The output parameter indicating the ID of the record added. |
@SESSIONID | uniqueidentifier | IN | Input parameter indicating the context ID for the record being added. |
@DATE | date | IN | Date |
@NEXTTIMETABLEDAYID | uniqueidentifier | IN | Change to |
@ADJUSTEDTIMETABLEDAYID | uniqueidentifier | IN | Change to |
@DESCRIPTION | varchar(255) | IN | Notes |
@CHANGEAGENTID | uniqueidentifier | IN | Input parameter indicating the ID of the change agent invoking the procedure. |
Definition
Copy
CREATE procedure dbo.USP_DATAFORMTEMPLATE_ADD_SCHEDULEDATEADJUSTMENT
(
@ID uniqueidentifier = null output,
@SESSIONID uniqueidentifier,
@DATE date = null,
@NEXTTIMETABLEDAYID uniqueidentifier = null,
@ADJUSTEDTIMETABLEDAYID uniqueidentifier = null,
@DESCRIPTION varchar(255) = null,
@CHANGEAGENTID uniqueidentifier = null
)
as
set nocount on
if @ID is null
set @ID = newid()
if @CHANGEAGENTID is null
exec dbo.USP_CHANGEAGENT_GETORCREATECHANGEAGENT @CHANGEAGENTID output
declare @CURRENTDATE datetime
set @CURRENTDATE = getdate()
declare @SCHOOLID uniqueidentifier
select @SCHOOLID = SCHOOLID
from
SESSION
inner join ACADEMICYEAR
on SESSION.ACADEMICYEARID = ACADEMICYEAR.ID
where SESSION.ID = @SESSIONID
begin try
declare @contextCache varbinary(128)
-- cache current context information
set @contextCache = CONTEXT_INFO()
-- set CONTEXT_INFO to @CHANGEAGENTID
if not @CHANGEAGENTID is null
set CONTEXT_INFO @CHANGEAGENTID
-- delete existing adjustment if present
delete
SCHEDULEDATEADJUSTMENT
from
SCHEDULEDATEADJUSTMENT
where
DATE = @DATE AND SCHOOLID = @SCHOOLID
-- reset CONTEXT_INFO to previous value
if not @contextCache is null
set CONTEXT_INFO @contextCache
-- handle inserting the data
insert into dbo.SCHEDULEDATEADJUSTMENT
(ID, DATE, SCHOOLID, NEXTTIMETABLEDAYID, ADJUSTEDTIMETABLEDAYID, DESCRIPTION, ADDEDBYID, CHANGEDBYID, DATEADDED, DATECHANGED)
values
(@ID, @DATE, @SCHOOLID, @NEXTTIMETABLEDAYID, @ADJUSTEDTIMETABLEDAYID, @DESCRIPTION, @CHANGEAGENTID, @CHANGEAGENTID, @CURRENTDATE, @CURRENTDATE)
-- set this so the cleanup will see the new adjustment as valid
if @ADJUSTEDTIMETABLEDAYID is null
update SCHEDULEDATE set INSESSION = 0, TIMETABLEDAYID = null where DATE = @DATE and SCHOOLID = @SCHOOLID
else
update SCHEDULEDATE set INSESSION = 1, TIMETABLEDAYID = @ADJUSTEDTIMETABLEDAYID where DATE = @DATE and SCHOOLID = @SCHOOLID
declare @TERMID uniqueidentifier
set @TERMID = dbo.UFN_SCHEDULEDATE_GETTERM (@DATE, @SCHOOLID)
exec dbo.USP_SCHEDULEDATE_ADJUSTENTRIES @TERMID, @DATE, null, null, @CHANGEAGENTID
end try
begin catch
exec dbo.USP_RAISE_ERROR
return 1
end catch
return 0