USP_DATAFORMTEMPLATE_VIEW_DATALIST

The load procedure used by the view dataform template "Data List 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
@ISUSERDEFINED bit INOUT User defined
@CONTEXTRECORDTYPENAME nvarchar(50) INOUT Context record type
@IMPLEMENTATION nvarchar(200) INOUT Implementation
@SECURITYUIFOLDER nvarchar(200) INOUT Security folder
@INSTALLEDPRODUCTLIST nvarchar(max) INOUT Installed products
@INSTALLED bit INOUT Installed
@NAME nvarchar(60) INOUT Name
@SPECUINAME nvarchar(60) INOUT Name override
@UINAME nvarchar(60) INOUT Display name

Definition

Copy


CREATE procedure dbo.USP_DATAFORMTEMPLATE_VIEW_DATALIST
(
    @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,
    @ISUSERDEFINED bit = 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,
    @NAME nvarchar(60) = null output,
    @SPECUINAME nvarchar(60) = null output,
    @UINAME nvarchar(60) = null output
)
as
    set nocount on;
    set @DATALOADED = 0;

    with xmlnamespaces ('bb_appfx_datalist' as tns, 'bb_appfx_commontypes' as common)
    select 
        @DATALOADED = 1,
        @SYSTEMRECORDID = @ID,
        @DESCRIPTION = D.DESCRIPTION,
        @AUTHOR = D.DATALISTSPEC.value('(tns:DataListSpec/@Author)[1]', 'nvarchar(500)'),
        @DATEADDED = D.DATEADDED,
        @DATECHANGED = D.DATECHANGED,
        @ISUSERDEFINED = D.DATALISTSPEC.exist('tns:DataListSpec/common:MetaTags/AdHocQuerySaveDataListRequest'),
        @CONTEXTRECORDTYPENAME = coalesce(RT.NAME, ''),
        @IMPLEMENTATION = 
        case D.IMPLEMENTATIONTYPE
            when 0 then 'SP (' + D.PROCEDURENAME + ')'
            when 1 then 'CLR (' + D.ASSEMBLYNAME + ', ' + D.CLASSNAME + ')'
        end,
        @SECURITYUIFOLDER = D.SECURITYUIFOLDER,
        @INSTALLEDPRODUCTLIST = dbo.UFN_INSTALLEDPRODUCTS_TRANSLATELIST(D.DATALISTSPEC.query('tns:DataListSpec/common:InstalledProductList')),
        @INSTALLED = dbo.UFN_INSTALLEDPRODUCTS_OPTIONALPRODUCTSINSTALLED(D.DATALISTSPEC.query('tns:DataListSpec/common:InstalledProductList')),
        @NAME = D.NAME,
        @SPECUINAME = D.SPECUINAME,
        @UINAME = D.UINAME
    from dbo.DATALISTCATALOG as D
         left join dbo.RECORDTYPE as RT on D.RECORDTYPEID = RT.ID
    where D.ID = @ID;

    return 0;