USP_DATAFORMTEMPLATE_VIEW_RECORDOPERATION

The load procedure used by the view dataform template "Record Operation 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
@OPERATIONTYPENAME nvarchar(6) INOUT Operation type
@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_RECORDOPERATION
(
    @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,
    @OPERATIONTYPENAME nvarchar(6) = 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_recordoperation' as tns, 'bb_appfx_commontypes' as common)
    select 
        @DATALOADED = 1,
        @SYSTEMRECORDID = @ID,
        @DESCRIPTION = R.DESCRIPTION,
        @AUTHOR = R.RECORDOPERATIONSPECXML.value('(tns:RecordOperationSpec/@Author)[1]', 'nvarchar(500)'),
        @DATEADDED = R.DATEADDED,
        @DATECHANGED = R.DATECHANGED,
        @OPERATIONTYPENAME = R.OPERATIONTYPENAME,
        @CONTEXTRECORDTYPENAME = coalesce(RT.NAME, ''),
        @IMPLEMENTATION = 
        case R.IMPLEMENTATIONTYPE
            when 0 then 'SP (' + R.PROCEDURENAME + ')'
            when 1 then 'CLR (' + R.ASSEMBLYNAME + ', ' + R.CLASSNAME + ')'
        end,
        @SECURITYUIFOLDER = R.SECURITYUIFOLDER,
        @INSTALLEDPRODUCTLIST = dbo.UFN_INSTALLEDPRODUCTS_TRANSLATELIST(R.RECORDOPERATIONSPECXML.query('tns:RecordOperationSpec/common:InstalledProductList')),
        @INSTALLED = dbo.UFN_INSTALLEDPRODUCTS_OPTIONALPRODUCTSINSTALLED(R.RECORDOPERATIONSPECXML.query('tns:RecordOperationSpec/common:InstalledProductList')),
        @NAME = R.DISPLAYNAME,
        @SPECUINAME = R.SPECUINAME,
        @UINAME = R.UINAME
    from dbo.RECORDOPERATIONCATALOG AS R
         left join dbo.RECORDTYPE as RT on R.RECORDTYPEID = RT.ID
    where R.ID = @ID;

    return 0;