USP_MKTSEGMENTATIONPASSIVESEGMENT_SAVE

Saves a public media marketing effort segment.

Parameters

Parameter Parameter Type Mode Description
@ID uniqueidentifier IN
@CHANGEAGENTID uniqueidentifier IN
@SEGMENTID uniqueidentifier IN
@CODEVALUEID uniqueidentifier IN
@CODE nvarchar(10) IN
@PACKAGEID uniqueidentifier IN
@PACKAGECODEVALUEID uniqueidentifier IN
@PACKAGECODE nvarchar(10) IN
@CHANNELCODEVALUEID uniqueidentifier IN
@CHANNELCODE nvarchar(10) IN
@EXPOSURESTARTDATE date IN
@EXPOSUREENDDATE date IN
@RESPONSERATE decimal(5, 2) IN
@GIFTAMOUNT money IN
@ITEMLIST xml IN
@CURRENTAPPUSERID uniqueidentifier IN

Definition

Copy


CREATE procedure dbo.[USP_MKTSEGMENTATIONPASSIVESEGMENT_SAVE]
(
  @ID uniqueidentifier,
  @CHANGEAGENTID uniqueidentifier = null,
  @SEGMENTID uniqueidentifier,
  @CODEVALUEID uniqueidentifier = null,
  @CODE nvarchar(10) = '',
  @PACKAGEID uniqueidentifier,
  @PACKAGECODEVALUEID uniqueidentifier = null,
  @PACKAGECODE nvarchar(10) = '',
  @CHANNELCODEVALUEID uniqueidentifier = null,
  @CHANNELCODE nvarchar(10) = '',
  @EXPOSURESTARTDATE date,
  @EXPOSUREENDDATE date,
  @RESPONSERATE decimal(5, 2),
  @GIFTAMOUNT money,
  @ITEMLIST xml,
  @CURRENTAPPUSERID uniqueidentifier = null
)
as
  set nocount on;

  declare @SEGMENTATIONID uniqueidentifier;
  declare @SOURCECODEID uniqueidentifier;
  declare @ACTIVE bit;
  declare @OLDSEGMENTID uniqueidentifier;
  declare @OLDPACKAGEID uniqueidentifier;
  declare @OLDSEGMENTATIONPACKAGEID uniqueidentifier;
  declare @OLDCODEVALUEID uniqueidentifier;
  declare @OLDCODE nvarchar(10);
  declare @OLDPACKAGECODEVALUEID uniqueidentifier;
  declare @OLDPACKAGECODE nvarchar(10);
  declare @OLDCHANNELCODEVALUEID uniqueidentifier;
  declare @OLDCHANNELCODE nvarchar(10);
  declare @CURRENTDATE datetime;
  declare @BASECURRENCYID uniqueidentifier;
  declare @ORGANIZATIONCURRENCYID uniqueidentifier;
  declare @ORGANIZATIONGIFTAMOUNT money;
  declare @ORGANIZATIONCURRENCYEXCHANGERATEID uniqueidentifier;
  declare @DATEADDED datetime;

  begin try
    select
      @SEGMENTATIONID = [MKTSEGMENTATION].[ID],
      @SOURCECODEID = [MKTSEGMENTATION].[SOURCECODEID],
      @ACTIVE = [MKTSEGMENTATION].[ACTIVE],
      @OLDSEGMENTID = [MKTSEGMENTATIONSEGMENT].[SEGMENTID],
      @OLDPACKAGEID = [MKTSEGMENTATIONSEGMENT].[PACKAGEID],
      @OLDSEGMENTATIONPACKAGEID = [MKTSEGMENTATIONPACKAGE].[ID],
      @OLDCODEVALUEID = [MKTSEGMENTATIONSEGMENT].[PARTDEFINITIONVALUESID],
      @OLDCODE = [MKTSEGMENTATIONSEGMENT].[CODE],
      @OLDPACKAGECODEVALUEID = isnull(case when [MKTSEGMENTATION].[ACTIVE] = 1 then [MKTSEGMENTATIONPACKAGE].[PARTDEFINITIONVALUESID] else [MKTPACKAGE].[PARTDEFINITIONVALUESID] end, '00000000-0000-0000-0000-0000000000000'),
      @OLDPACKAGECODE = case when [MKTSEGMENTATION].[ACTIVE] = 1 then [MKTSEGMENTATIONPACKAGE].[CODE] else [MKTPACKAGE].[CODE] end,
      @OLDCHANNELCODEVALUEID = isnull(case when [MKTSEGMENTATION].[ACTIVE] = 1 then [MKTSEGMENTATIONPACKAGE].[CHANNELPARTDEFINITIONVALUESID] else [MKTPACKAGE].[CHANNELPARTDEFINITIONVALUESID] end, '00000000-0000-0000-0000-0000000000000'),
      @OLDCHANNELCODE = case when [MKTSEGMENTATION].[ACTIVE] = 1 then [MKTSEGMENTATIONPACKAGE].[CHANNELSOURCECODE] else [MKTPACKAGE].[CHANNELSOURCECODE] end,
      @BASECURRENCYID = [MKTSEGMENTATIONSEGMENT].[BASECURRENCYID],
      @ORGANIZATIONCURRENCYEXCHANGERATEID = [MKTSEGMENTATIONSEGMENT].[CURRENCYEXCHANGERATEID],
      @DATEADDED = [MKTSEGMENTATIONSEGMENT].[DATEADDED]
    from dbo.[MKTSEGMENTATIONSEGMENT]
    inner join dbo.[MKTSEGMENTATION] on [MKTSEGMENTATION].[ID] = [MKTSEGMENTATIONSEGMENT].[SEGMENTATIONID]
    inner join dbo.[MKTPACKAGE] on [MKTPACKAGE].[ID] = [MKTSEGMENTATIONSEGMENT].[PACKAGEID]
    left outer join dbo.[MKTSEGMENTATIONPACKAGE] on [MKTSEGMENTATIONPACKAGE].[SEGMENTATIONID] = [MKTSEGMENTATIONSEGMENT].[SEGMENTATIONID] and [MKTSEGMENTATIONPACKAGE].[PACKAGEID] = [MKTSEGMENTATIONSEGMENT].[PACKAGEID]
    where [MKTSEGMENTATIONSEGMENT].[ID] = @ID;

    if @ACTIVE = 1
      if (select isnull(sum([RESPONSES]), 0) from dbo.[MKTSEGMENTATIONSEGMENTACTIVE] where [SEGMENTID] = @ID) > 0 and
         (@OLDSEGMENTID <> @SEGMENTID or @OLDPACKAGEID <> @PACKAGEID or
          (dbo.[UFN_MKTSOURCECODE_ITEMTYPEISVALID](@SOURCECODEID, 1) = 1 and (@OLDCODEVALUEID <> @CODEVALUEID or @OLDCODE <> @CODE)) or
          (dbo.[UFN_MKTSOURCECODE_ITEMTYPEISVALID](@SOURCECODEID, 2) = 1 and (@OLDPACKAGECODEVALUEID <> isnull(@PACKAGECODEVALUEID, '00000000-0000-0000-0000-000000000000') or @OLDPACKAGECODE <> @PACKAGECODE)) or
          (dbo.[UFN_MKTSOURCECODE_ITEMTYPEISVALID](@SOURCECODEID, 3) = 1 and (@OLDCHANNELCODEVALUEID <> isnull(@CHANNELCODEVALUEID, '00000000-0000-0000-0000-000000000000') or @OLDCHANNELCODE <> @CHANNELCODE)))
        begin
          raiserror('ERR_MKTSEGMENTATIONSEGMENTPASSIVE_HASRESPONSES', 13, 1);
          return 1;
        end
      else if dbo.[UFN_MKTSOURCECODE_ITEMTYPEISVALID](@SOURCECODEID, 2) = 1 and 
              dbo.[UFN_MKTSEGMENTATIONPACKAGEACTIVE_GETRESPONSECOUNT](@SEGMENTATIONID, @PACKAGEID) > 0 and
              (@OLDPACKAGECODEVALUEID <> isnull(@PACKAGECODEVALUEID, '00000000-0000-0000-0000-000000000000') or @OLDPACKAGECODE <> @PACKAGECODE)
        begin
          raiserror('ERR_MKTSEGMENTATIONSEGMENTPASSIVE_PACKAGECODEHASRESPONSES', 13, 1);
          return 1;
        end
      else if dbo.[UFN_MKTSOURCECODE_ITEMTYPEISVALID](@SOURCECODEID, 3) = 1 and 
              dbo.[UFN_MKTSEGMENTATIONPACKAGEACTIVE_GETRESPONSECOUNT](@SEGMENTATIONID, @PACKAGEID) > 0 and
              (@OLDCHANNELCODEVALUEID <> isnull(@CHANNELCODEVALUEID, '00000000-0000-0000-0000-000000000000') or @OLDCHANNELCODE <> @CHANNELCODE)
        begin
          raiserror('ERR_MKTSEGMENTATIONSEGMENTPASSIVE_CHANNELCODEHASRESPONSES', 13, 1);
          return 1;
        end

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

    set @CURRENTDATE = getdate();

      set @ORGANIZATIONCURRENCYID = dbo.[UFN_CURRENCY_GETORGANIZATIONCURRENCY]();

      if @ORGANIZATIONCURRENCYID = @BASECURRENCYID
          set @ORGANIZATIONGIFTAMOUNT = @GIFTAMOUNT;
      else
        begin
        if @ORGANIZATIONCURRENCYEXCHANGERATEID is null
              set @ORGANIZATIONCURRENCYEXCHANGERATEID = dbo.[UFN_CURRENCYEXCHANGERATE_GETLATEST](@BASECURRENCYID, @ORGANIZATIONCURRENCYID, @DATEADDED, 0, null);

            set @ORGANIZATIONGIFTAMOUNT = dbo.[UFN_CURRENCY_CONVERT](@GIFTAMOUNT, @ORGANIZATIONCURRENCYEXCHANGERATEID);
        end

    update dbo.[MKTSEGMENTATIONSEGMENT] set 
      [SEGMENTID] = @SEGMENTID,
      [PACKAGEID] = @PACKAGEID,
      [PARTDEFINITIONVALUESID] = @CODEVALUEID,
      [CODE] = @CODE,
      [EXPOSURESTARTDATE] = @EXPOSURESTARTDATE,
      [EXPOSUREENDDATE] = @EXPOSUREENDDATE,
      [RESPONSERATE] = @RESPONSERATE,
      [GIFTAMOUNT] = @GIFTAMOUNT,
      [CHANGEDBYID] = @CHANGEAGENTID,
      [DATECHANGED] = @CURRENTDATE,
      [ORGANIZATIONGIFTAMOUNT] = @ORGANIZATIONGIFTAMOUNT,
      [CURRENCYEXCHANGERATEID] = @ORGANIZATIONCURRENCYEXCHANGERATEID
    where [ID] = @ID;

    -- save the source code information

    exec dbo.[USP_MKTSOURCECODEPART_SEGMENTATIONSEGMENT_GETITEMLIST3_UPDATEFROMXML] @ID, @ITEMLIST, @CHANGEAGENTID, @CURRENTDATE;

    if @ACTIVE = 0
      begin
        -- update the segment with the selected code

        exec dbo.[USP_MKTSEGMENT_UPDATECODE] @SEGMENTID, @CODE, @CODEVALUEID, @CHANGEAGENTID, 0, @CURRENTAPPUSERID;

        -- update the package with the selected code

        exec dbo.[USP_MKTPACKAGE_UPDATECODE] @PACKAGEID, @PACKAGECODE, @PACKAGECODEVALUEID, @CHANNELCODE, @CHANNELCODEVALUEID, @CHANGEAGENTID, @CURRENTAPPUSERID;
      end

    if @OLDPACKAGEID <> @PACKAGEID
      begin
        -- remove the old package if is not being used by any other segments

        if not exists(select [ID] from dbo.[MKTSEGMENTATIONSEGMENT] where [SEGMENTATIONID] = @SEGMENTATIONID and [PACKAGEID] = @OLDPACKAGEID)
          exec dbo.[USP_MKTSEGMENTATIONPACKAGE_DELETE] @OLDSEGMENTATIONPACKAGEID, @CHANGEAGENTID;

        -- add the new package if it doesn't exist already

        if not exists(select [ID] from dbo.[MKTSEGMENTATIONPACKAGE] where [SEGMENTATIONID] = @SEGMENTATIONID and [PACKAGEID] = @PACKAGEID)
          begin
            exec dbo.[USP_DATAFORMTEMPLATE_ADD_MKTSEGMENTATIONPACKAGE] null, @CHANGEAGENTID, @SEGMENTATIONID, @PACKAGEID;

            if @ACTIVE = 1
              exec dbo.[USP_MKTSEGMENTATIONACTIVATE_CACHEPACKAGE] @SEGMENTATIONID, @PACKAGEID, @CHANGEAGENTID, @CURRENTDATE, @PACKAGECODEVALUEID, @PACKAGECODE, @CHANNELCODEVALUEID, @CHANNELCODE;
          end
      end
    else
      if @ACTIVE = 1
        update dbo.[MKTSEGMENTATIONPACKAGE] set
          [PARTDEFINITIONVALUESID] = @PACKAGECODEVALUEID,
          [CODE] = @PACKAGECODE,
          [CHANNELPARTDEFINITIONVALUESID] = @CHANNELCODEVALUEID,
          [CHANNELSOURCECODE] = @CHANNELCODE
        where [SEGMENTATIONID] = @SEGMENTATIONID
        and [PACKAGEID] = @PACKAGEID;
    end try

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

  return 0;