USP_DATAFORMTEMPLATE_EDIT_RELATIONSHIP_ORGTOIND

The save procedure used by the edit dataform template "Relationship Organization to Individual Edit Form".

Parameters

Parameter Parameter Type Mode Description
@ID uniqueidentifier IN The input ID parameter indicating the ID of the record being edited.
@CHANGEAGENTID uniqueidentifier IN Input parameter indicating the ID of the change agent invoking the procedure.
@RELATIONSHIPTYPECODEID uniqueidentifier IN Relationship type
@RECIPROCALTYPECODEID uniqueidentifier IN Reciprocal relationship type
@STARTDATE datetime IN Start date
@ENDDATE datetime IN End date
@ISCONTACT bit IN The individual is a contact for this organization
@ISPRIMARYCONTACT bit IN Primary contact
@CONTACTTYPECODEID uniqueidentifier IN Contact type
@POSITION nvarchar(50) IN Position
@ISPRIMARYBUSINESS bit IN Primary Business
@ISMATCHINGGIFTRELATIONSHIP bit IN Matching gift relationship

Definition

Copy


                    CREATE procedure dbo.USP_DATAFORMTEMPLATE_EDIT_RELATIONSHIP_ORGTOIND
                    (
                        @ID uniqueidentifier,
                        @CHANGEAGENTID uniqueidentifier = null,                                                                        
                        @RELATIONSHIPTYPECODEID uniqueidentifier,
                        @RECIPROCALTYPECODEID uniqueidentifier,                                                
                        @STARTDATE datetime,
                        @ENDDATE datetime,
                        @ISCONTACT bit,
                        @ISPRIMARYCONTACT bit,
                        @CONTACTTYPECODEID uniqueidentifier,
                        @POSITION nvarchar(50),
                        @ISPRIMARYBUSINESS bit,
                        @ISMATCHINGGIFTRELATIONSHIP bit
                    )    
                    as
                        set nocount on;

                        declare @CURRENTDATE datetime;
                        set @CURRENTDATE = getdate();

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

                        begin try
                            if @ISMATCHINGGIFTRELATIONSHIP = 1
                                update
                                    dbo.RELATIONSHIP
                                set
                                    ISMATCHINGGIFTRELATIONSHIP = 0,
                                    DATECHANGED = @CURRENTDATE,
                                    CHANGEDBYID = @CHANGEAGENTID
                                where
                                    ID in (
                                            select
                                                TOUPDATE.ID
                                            from
                                                dbo.RELATIONSHIP TOUPDATE
                                            left join
                                                dbo.RELATIONSHIP
                                            on
                                                RELATIONSHIP.ID = @ID
                                            where
                                                TOUPDATE.RELATIONSHIPCONSTITUENTID = RELATIONSHIP.RELATIONSHIPCONSTITUENTID and
                                                TOUPDATE.RECIPROCALCONSTITUENTID = RELATIONSHIP.RECIPROCALCONSTITUENTID and
                                                TOUPDATE.ISMATCHINGGIFTRELATIONSHIP = 1 and
                                                TOUPDATE.ID <> RELATIONSHIP.ID)

                            update
                                DBO.RELATIONSHIP    
                            set    
                                RELATIONSHIPTYPECODEID = @RELATIONSHIPTYPECODEID,
                                RECIPROCALTYPECODEID = @RECIPROCALTYPECODEID,
                                STARTDATE = @STARTDATE,
                                ENDDATE = @ENDDATE,
                                ISCONTACT = @ISCONTACT,
                                ISPRIMARYCONTACT = @ISPRIMARYCONTACT,
                                POSITION = @POSITION,
                                CONTACTTYPECODEID = @CONTACTTYPECODEID
                                ISPRIMARYBUSINESS = @ISPRIMARYBUSINESS,
                                ISMATCHINGGIFTRELATIONSHIP = @ISMATCHINGGIFTRELATIONSHIP,
                                CHANGEDBYID = @CHANGEAGENTID,
                                DATECHANGED = @CURRENTDATE
                            where 
                                ID = @ID;                
                        end try

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

                        return 0;