USP_DATAFORMTEMPLATE_VIEW_GRANTAWARD

The load procedure used by the view dataform template "Grant Award View Form"

Parameters

Parameter Parameter Type Mode Description
@ID uniqueidentifier IN The input ID parameter used to load the fields defined on the form.
@DATALOADED bit INOUT Output parameter indicating whether or not data was actually loaded.
@OPPORTUNITYNAME nvarchar(500) INOUT Opportunity
@OPPORTUNITYID uniqueidentifier INOUT Opportunity ID
@FUNDINGREQUESTNAME nvarchar(150) INOUT Funding request
@FUNDINGREQUESTID uniqueidentifier INOUT Funding request ID
@ORGANIZATIONAMOUNT money INOUT Organization amount
@BASEEXCHANGERATE decimal(20, 8) INOUT Transaction to base exchange rate
@ORGANIZATIONEXCHANGERATE decimal(20, 8) INOUT Base to organization exchange rate

Definition

Copy


                create procedure dbo.USP_DATAFORMTEMPLATE_VIEW_GRANTAWARD
                (
                    @ID uniqueidentifier,
                    @DATALOADED bit = 0 output,
                    @OPPORTUNITYNAME nvarchar(500) = null output,
                    @OPPORTUNITYID uniqueidentifier = null output,
                    @FUNDINGREQUESTNAME nvarchar(150) = null output,
                    @FUNDINGREQUESTID uniqueidentifier = null output,
                    @ORGANIZATIONAMOUNT money = null output,
                    @BASEEXCHANGERATE decimal(20,8) = null output,
                    @ORGANIZATIONEXCHANGERATE decimal(20,8) = null output
                )
                as
                    set nocount on;

                    set @DATALOADED = 0;

                    select
                        @DATALOADED = 1,
                        @ORGANIZATIONAMOUNT = REVENUE.ORGANIZATIONAMOUNT
                    from 
                        dbo.REVENUE
                    where 
                        REVENUE.ID = @ID 
                        and REVENUE.TRANSACTIONTYPECODE = 6;

                    select
                        @BASEEXCHANGERATE = CURRENCYEXCHANGERATE.RATE
                    from 
                        dbo.REVENUE
                        left join dbo.CURRENCYEXCHANGERATE on REVENUE.BASEEXCHANGERATEID = CURRENCYEXCHANGERATE.ID
                    where 
                        REVENUE.ID = @ID;

                    select
                        @ORGANIZATIONEXCHANGERATE = CURRENCYEXCHANGERATE.RATE
                    from 
                        dbo.REVENUE
                        left join dbo.CURRENCYEXCHANGERATE on REVENUE.ORGANIZATIONEXCHANGERATEID = CURRENCYEXCHANGERATE.ID
                    where 
                        REVENUE.ID = @ID;

                    if @DATALOADED = 1
                    begin
                        select top 1
                            @OPPORTUNITYNAME = dbo.UFN_OPPORTUNITY_GETLONGDESCRIPTION(OPPORTUNITY.ID),
                            @OPPORTUNITYID = OPPORTUNITY.ID
                        from
                            dbo.OPPORTUNITY
                            inner join dbo.REVENUEOPPORTUNITY on REVENUEOPPORTUNITY.OPPORTUNITYID = OPPORTUNITY.ID
                        where
                            REVENUEOPPORTUNITY.ID in (select ID from dbo.REVENUESPLIT where REVENUESPLIT.REVENUEID = @ID);

                        select top 1
                            @FUNDINGREQUESTNAME = GRANTS.TITLE,
                            @FUNDINGREQUESTID = FUNDINGREQUEST.ID
                        from
                            dbo.FUNDINGREQUEST
                            inner join dbo.REVENUEFUNDINGREQUEST on REVENUEFUNDINGREQUEST.FUNDINGREQUESTID = FUNDINGREQUEST.ID
                            inner join dbo.GRANTS on FUNDINGREQUEST.GRANTSID = GRANTS.ID
                        where
                            REVENUEFUNDINGREQUEST.ID = @ID;
                    end
                  return 0;