USP_DATAFORMTEMPLATE_ADD_TEAMFUNDRAISINGTEAMMEMBERFROMREGISTRANTATROOT

The save procedure used by the add dataform template "Team Fundraising Team Member from Registrant at Root Add Form".

Parameters

Parameter Parameter Type Mode Description
@ID uniqueidentifier INOUT The output parameter indicating the ID of the record added.
@CHANGEAGENTID uniqueidentifier IN Input parameter indicating the ID of the change agent invoking the procedure.
@EVENTIDAPPEALID nvarchar(72) IN Input parameter indicating the context ID for the record being added.
@REGISTRANTID uniqueidentifier IN Team fundraiser
@GOAL money IN Goal

Definition

Copy


                    CREATE procedure dbo.USP_DATAFORMTEMPLATE_ADD_TEAMFUNDRAISINGTEAMMEMBERFROMREGISTRANTATROOT
                    (
                        @ID uniqueidentifier = null output,
                        @CHANGEAGENTID uniqueidentifier = null,
                        @EVENTIDAPPEALID nvarchar(72),
                        @REGISTRANTID uniqueidentifier,
                        @GOAL money = 0
                    )
                    as
                    begin
                        set nocount on;

                        declare @CURRENTDATE datetime;

                        IF @ID is null
                            set @ID = newid();

                        if @CHANGEAGENTID is null
                            exec dbo.USP_CHANGEAGENT_GETORCREATECHANGEAGENT @CHANGEAGENTID output;

                        set @CURRENTDATE = getdate();

                        begin try
                            declare @CONSTITUENTID uniqueidentifier;
                            select
                                @CONSTITUENTID = REGISTRANT.CONSTITUENTID
                            from
                                dbo.REGISTRANT
                            where
                                REGISTRANT.ID = @REGISTRANTID;

                            declare @TEAMFUNDRAISERID uniqueidentifier;
                            declare @CURRENTGOAL money;
                            select
                                @TEAMFUNDRAISERID = TEAMFUNDRAISER.ID,
                                @CURRENTGOAL = TEAMFUNDRAISER.GOAL
                            from
                                dbo.TEAMFUNDRAISER
                            where
                                TEAMFUNDRAISER.APPEALID = right(@EVENTIDAPPEALID, 36)
                                and TEAMFUNDRAISER.CONSTITUENTID = @CONSTITUENTID;

                            if @TEAMFUNDRAISERID is null
                            begin
                                set @TEAMFUNDRAISERID = newid();

                                insert into dbo.TEAMFUNDRAISER
                                    (ID,APPEALID,CONSTITUENTID,GOAL,ADDEDBYID,CHANGEDBYID,DATEADDED,DATECHANGED)
                                values
                                    (@TEAMFUNDRAISERID,right(@EVENTIDAPPEALID, 36),@CONSTITUENTID,@GOAL,@CHANGEAGENTID,@CHANGEAGENTID,@CURRENTDATE,@CURRENTDATE);
                            end
                            else
                                if @GOAL <> @CURRENTGOAL
                                    update
                                        dbo.TEAMFUNDRAISER
                                    set
                                        GOAL = @GOAL
                                    where
                                        ID = @TEAMFUNDRAISERID;

                            insert into dbo.TEAMFUNDRAISINGTEAMMEMBER
                                (ID,TEAMFUNDRAISINGTEAMID,TEAMFUNDRAISERID,ADDEDBYID,CHANGEDBYID,DATEADDED,DATECHANGED)
                            values
                                (@ID,null,@TEAMFUNDRAISERID,@CHANGEAGENTID,@CHANGEAGENTID,@CURRENTDATE,@CURRENTDATE);
                        end try

                        begin catch
                            exec dbo.USP_RAISE_ERROR;
                            return 1;
                        end catch

                        return 0;

                    end