USP_DATAFORMTEMPLATE_VIEW_KPI

The load procedure used by the view dataform template "KPI 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.
@SYSTEMRECORDID uniqueidentifier INOUT System record ID
@DESCRIPTION nvarchar(1000) INOUT Description
@AUTHOR nvarchar(500) INOUT Author
@DATEADDED datetime INOUT Date added
@DATECHANGED datetime INOUT Date changed
@CONTEXTRECORDTYPENAME nvarchar(50) INOUT Record type
@IMPLEMENTATION nvarchar(200) INOUT Implementation
@SECURITYUIFOLDER nvarchar(200) INOUT Security folder
@INSTALLEDPRODUCTLIST nvarchar(max) INOUT Installed products
@INSTALLED bit INOUT Installed

Definition

Copy


create procedure dbo.USP_DATAFORMTEMPLATE_VIEW_KPI
(
    @ID uniqueidentifier,
    @DATALOADED bit = 0 output,
    @SYSTEMRECORDID uniqueidentifier = null output,
    @DESCRIPTION nvarchar(1000) = null output,
    @AUTHOR nvarchar(500)  = null output,
    @DATEADDED datetime = null output,
    @DATECHANGED datetime = null output,
    @CONTEXTRECORDTYPENAME nvarchar(50) = null output,
    @IMPLEMENTATION nvarchar(200) = null output,
    @SECURITYUIFOLDER nvarchar(200) = null output,
    @INSTALLEDPRODUCTLIST nvarchar(max) = null output,
    @INSTALLED bit = null output
)
as
    set nocount on;
    set @DATALOADED = 0;

    with xmlnamespaces ('bb_appfx_kpi' as tns, 'bb_appfx_commontypes' as common)
    select 
        @DATALOADED = 1,
        @SYSTEMRECORDID = @ID,
        @DESCRIPTION = K.DESCRIPTION,
        @AUTHOR = K.SPECXML.value('(tns:KpiSpec/@Author)[1]', 'nvarchar(500)'),
        @DATEADDED = K.DATEADDED,
        @DATECHANGED = K.DATECHANGED,
        @CONTEXTRECORDTYPENAME = coalesce(RT.NAME, ''),
        @IMPLEMENTATION =
            case K.IMPLEMENTATIONTYPECODE
                when 1 then 'SP (' + K.SPNAME + ')'
                when 0 then 'CLR (' + K.ASSEMBLYNAME + ', ' + K.CLASSNAME + ')'
            end,
        @SECURITYUIFOLDER = K.SECURITYUIFOLDER,
        @INSTALLEDPRODUCTLIST = dbo.UFN_INSTALLEDPRODUCTS_TRANSLATELIST(K.SPECXML.query('tns:KpiSpec/common:InstalledProductList')),
        @INSTALLED = dbo.UFN_INSTALLEDPRODUCTS_OPTIONALPRODUCTSINSTALLED(K.SPECXML.query('tns:KpiSpec/common:InstalledProductList'))
    from dbo.KPICATALOG as K
        left join dbo.RECORDTYPE as RT on K.CONTEXTRECORDTYPEID = RT.ID
    where K.ID = @ID;

    return 0;