<?xml version="1.0" encoding="utf-8" ?>
<otrs_package version="1.1">
    <Name>ProcessTicketTemplates</Name>
    <Version>11.0.4</Version>
    <Vendor>Rother OSS GmbH</Vendor>
    <URL>https://otobo.io/</URL>
    <License>GNU GENERAL PUBLIC LICENSE Version 3, 29 June 2007</License>
    <ChangeLog Date="2026-04-27 16:15:21" Version="11.0.4">Update to OTOBO 11.0.16.</ChangeLog>
    <ChangeLog Date="2026-02-05 13:22:19" Version="11.0.3">Update to OTOBO 11.0.15.</ChangeLog>
    <ChangeLog Date="2025-02-26 13:57:56" Version="11.0.2">Update to OTOBO 11.0.8.</ChangeLog>
    <ChangeLog Date="2024-12-19 08:05:53" Version="11.0.1">Initial release.</ChangeLog>
    <Description Lang="en">The package ProcessTicketTemplates enables standard templates for process management activity dialogs in the agent interface.</Description>
    <Framework>11.0.x</Framework>
    <BuildCommitID>6d094b577f46c2b3ebd915ea7c9dec2e66dd4a14</BuildCommitID>
    <BuildDate>2026-04-27 16:15:25</BuildDate>
    <BuildHost>opms.rother-oss.com</BuildHost>
    <Filelist>
        <File Location="Custom/Kernel/Modules/AdminProcessManagementActivityDialog.pm" Permission="660" Encode="Base64"># --
# OTOBO is a web-based ticketing system for service organisations.
# --
# Copyright (C) 2001-2020 OTRS AG, https://otrs.com/
# Copyright (C) 2019-2026 Rother OSS GmbH, https://otobo.io/
# --
# $origin: otobo - 6efdc7bf2a3325277cd79a60f0f2407f8ad59e87 - Kernel/Modules/AdminProcessManagementActivityDialog.pm
# --
# This program is free software: you can redistribute it and/or modify it under
# the terms of the GNU General Public License as published by the Free Software
# Foundation, either version 3 of the License, or (at your option) any later version.
# This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# --

package Kernel::Modules::AdminProcessManagementActivityDialog;

use strict;
use warnings;

use Kernel::System::VariableCheck qw(:all);
use Kernel::Language              qw(Translatable);

our $ObjectManagerDisabled = 1;

sub new {
    my ( $Type, %Param ) = @_;

    # allocate new hash for object
    my $Self = {%Param};
    bless( $Self, $Type );

    return $Self;
}

sub Run {
    my ( $Self, %Param ) = @_;

    my $ParamObject = $Kernel::OM->Get('Kernel::System::Web::Request');

    $Self->{Subaction} = $ParamObject->GetParam( Param => 'Subaction' ) || '';

    my $ActivityDialogID = $ParamObject->GetParam( Param => 'ID' )       || '';
    my $EntityID         = $ParamObject->GetParam( Param => 'EntityID' ) || '';

    my %SessionData = $Kernel::OM->Get('Kernel::System::AuthSession')->GetSessionIDData(
        SessionID => $Self->{SessionID},
    );

    # convert JSON string to array
    $Self->{ScreensPath} = $Kernel::OM->Get('Kernel::System::JSON')->Decode(
        Data => $SessionData{ProcessManagementScreensPath}
    );

    # get needed objects
    my $ConfigObject         = $Kernel::OM->Get('Kernel::Config');
    my $EntityObject         = $Kernel::OM->Get('Kernel::System::ProcessManagement::DB::Entity');
    my $ActivityDialogObject = $Kernel::OM->Get('Kernel::System::ProcessManagement::DB::ActivityDialog');
    my $LayoutObject         = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    # create available Fields list
    my $AvailableFieldsList = {
        Article     => 'Article',
        State       => 'StateID',
        Priority    => 'PriorityID',
        Lock        => 'LockID',
        Queue       => 'QueueID',
        CustomerID  => 'CustomerID',
        Owner       => 'OwnerID',
        PendingTime => 'PendingTime',
        Title       => 'Title',
    };

    # add service and SLA fields, if option is activated in sysconfig.
    if ( $ConfigObject->Get('Ticket::Service') ) {
        $AvailableFieldsList->{Service} = 'ServiceID';
        $AvailableFieldsList->{SLA}     = 'SLAID';
    }

    # add ticket type field, if option is activated in sysconfig.
    if ( $ConfigObject->Get('Ticket::Type') ) {
        $AvailableFieldsList->{Type} = 'TypeID';
    }

    # add responsible field, if option is activated in sysconfig.
    if ( $ConfigObject->Get('Ticket::Responsible') ) {
        $AvailableFieldsList->{Responsible} = 'ResponsibleID';
    }

    my $DynamicFieldList = $Kernel::OM->Get('Kernel::System::DynamicField')->DynamicFieldList(
        ObjectType => ['Ticket'],
        ResultType => 'HASH',
    );

    DYNAMICFIELD:
    for my $DynamicFieldName ( values %{$DynamicFieldList} ) {

        next DYNAMICFIELD if !$DynamicFieldName;

        # do not show internal fields for process management
        next DYNAMICFIELD if $DynamicFieldName eq 'ProcessManagementProcessID';
        next DYNAMICFIELD if $DynamicFieldName eq 'ProcessManagementActivityID';

        $AvailableFieldsList->{"DynamicField_$DynamicFieldName"} = $DynamicFieldName;
    }

    # ------------------------------------------------------------ #
    # ActivityDialogNew
    # ------------------------------------------------------------ #
    if ( $Self->{Subaction} eq 'ActivityDialogNew' ) {

        return $Self->_ShowEdit(
            %Param,
            Action => 'New',
        );
    }

    # ------------------------------------------------------------ #
    # ActivityDialogNewAction
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'ActivityDialogNewAction' ) {

        # challenge token check for write action
        $LayoutObject->ChallengeTokenCheck();

        # get Activity Dialog data
        my $ActivityDialogData;

        # get parameter from web browser
        my $GetParam = $Self->_GetParams();

        # set new confguration
        $ActivityDialogData->{Name}                           = $GetParam->{Name};
        $ActivityDialogData->{EntityID}                       = $GetParam->{EntityID};
        $ActivityDialogData->{Config}->{Interface}            = $GetParam->{Interface};
        $ActivityDialogData->{Config}->{DescriptionShort}     = $GetParam->{DescriptionShort};
        $ActivityDialogData->{Config}->{DescriptionLong}      = $GetParam->{DescriptionLong};
        $ActivityDialogData->{Config}->{Permission}           = $GetParam->{Permission};
        $ActivityDialogData->{Config}->{RequiredLock}         = $GetParam->{RequiredLock} || 0;
        $ActivityDialogData->{Config}->{SubmitAdviceText}     = $GetParam->{SubmitAdviceText};
        $ActivityDialogData->{Config}->{SubmitButtonText}     = $GetParam->{SubmitButtonText};
        $ActivityDialogData->{Config}->{InputFieldDefinition} = $GetParam->{InputFieldDefinition};
        $ActivityDialogData->{Config}->{DirectSubmit}         = $GetParam->{DirectSubmit} || 0;
        $ActivityDialogData->{Config}->{Fields}               = {};
        $ActivityDialogData->{Config}->{FieldOrder}           = [];

        if ( IsArrayRefWithData( $GetParam->{Fields} ) ) {

            FIELD:
            for my $FieldName ( @{ $GetParam->{Fields} } ) {
                next FIELD if !$FieldName;
                next FIELD if !$AvailableFieldsList->{$FieldName};

                # set fields hash
                $ActivityDialogData->{Config}->{Fields}->{$FieldName} = {};

                # set field order array
                push @{ $ActivityDialogData->{Config}->{FieldOrder} }, $FieldName;
            }
        }

        # add field detail config to fields
        if ( IsHashRefWithData( $GetParam->{FieldDetails} ) ) {
            FIELDDETAIL:
            for my $FieldDetail ( sort keys %{ $GetParam->{FieldDetails} } ) {
                next FIELDDETAIL if !$FieldDetail;
                next FIELDDETAIL if !$ActivityDialogData->{Config}->{Fields}->{$FieldDetail};

                $ActivityDialogData->{Config}->{Fields}->{$FieldDetail} = $GetParam->{FieldDetails}->{$FieldDetail};
            }
        }

        # set correct Interface value
        my %Interfaces = (
            AgentInterface    => ['AgentInterface'],
            CustomerInterface => ['CustomerInterface'],
            BothInterfaces    => [ 'AgentInterface', 'CustomerInterface' ],
        );
        $ActivityDialogData->{Config}->{Interface} = $Interfaces{ $ActivityDialogData->{Config}->{Interface} };

        if ( !$ActivityDialogData->{Config}->{Interface} ) {
            $ActivityDialogData->{Config}->{Interface} = $Interfaces{Agent};
        }

        # check required parameters
        my %Error;
        if ( !$GetParam->{Name} ) {

            # add server error error class
            $Error{NameServerError}        = 'ServerError';
            $Error{NameServerErrorMessage} = Translatable('This field is required');
        }

        if ( !$GetParam->{DescriptionShort} ) {

            # add server error error class
            $Error{DescriptionShortServerError} = 'ServerError';
            $Error{DecriptionShortErrorMessage} = Translatable('This field is required');
        }

        # check if permission exists
        if ( defined $GetParam->{Permission} && $GetParam->{Permission} ne '' ) {
            my $PermissionList = $ConfigObject->Get('System::Permission');

            my %PermissionLookup = map { $_ => 1 } @{$PermissionList};

            if ( !$PermissionLookup{ $GetParam->{Permission} } )
            {

                # add server error error class
                $Error{PermissionServerError} = 'ServerError';
            }
        }

        # check if required lock exists
        if ( $GetParam->{RequiredLock} && $GetParam->{RequiredLock} ne 1 ) {

            # add server error error class
            $Error{RequiredLockServerError} = 'ServerError';
        }

        # if there is an error return to edit screen
        if ( IsHashRefWithData( \%Error ) ) {
            return $Self->_ShowEdit(
                %Error,
                %Param,
                ActivityDialogData => $ActivityDialogData,
                Action             => 'New',
            );
        }

        # generate entity ID
        my $EntityID = $EntityObject->EntityIDGenerate(
            EntityType => 'ActivityDialog',
            UserID     => $Self->{UserID},
        );

        # show error if can't generate a new EntityID
        if ( !$EntityID ) {
            return $LayoutObject->ErrorScreen(
                Message => Translatable("There was an error generating a new EntityID for this ActivityDialog"),
            );
        }

        # otherwise save configuration and return process screen
        my $ActivityDialogID = $ActivityDialogObject->ActivityDialogAdd(
            Name     => $ActivityDialogData->{Name},
            EntityID => $EntityID,
            Config   => $ActivityDialogData->{Config},
            UserID   => $Self->{UserID},
        );

        # show error if can't create
        if ( !$ActivityDialogID ) {
            return $LayoutObject->ErrorScreen(
                Message => Translatable("There was an error creating the ActivityDialog"),
            );
        }

        # set entity sync state
        my $Success = $EntityObject->EntitySyncStateSet(
            EntityType => 'ActivityDialog',
            EntityID   => $EntityID,
            SyncState  => 'not_sync',
            UserID     => $Self->{UserID},
        );

        # show error if can't set
        if ( !$Success ) {
            return $LayoutObject->ErrorScreen(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'There was an error setting the entity sync status for ActivityDialog entity: %s',
                    $EntityID
                ),
            );
        }

        # remove this screen from session screen path
        $Self->_PopSessionScreen( OnlyCurrent => 1 );

        my $Redirect = $ParamObject->GetParam( Param => 'PopupRedirect' ) || '';

        # get latest config data to send it back to main window
        my $ActivityDialogConfig = $Self->_GetActivityDialogConfig(
            EntityID => $EntityID,
        );

        # check if needed to open another window or if popup should go back
        if ( $Redirect && $Redirect eq '1' ) {

            $Self->_PushSessionScreen(
                ID        => $ActivityDialogID,
                EntityID  => $ActivityDialogData->{EntityID},
                Subaction => 'ActivityDialogEdit'               # always use edit screen
            );

            my $RedirectField = $ParamObject->GetParam( Param => 'PopupRedirectID' ) || '';

            # redirect to another popup window
            return $Self->_PopupResponse(
                Redirect => 1,
                Screen   => {
                    Action    => 'AdminProcessManagementField',
                    Subaction => 'FieldEdit',
                    Field     => $RedirectField,
                },
                ConfigJSON => $ActivityDialogConfig,
            );
        }
        else {

            # remove last screen
            my $LastScreen = $Self->_PopSessionScreen();

            # check if needed to return to main screen or to be redirected to last screen
            if ( $LastScreen->{Action} eq 'AdminProcessManagement' ) {

                # close the popup
                return $Self->_PopupResponse(
                    ClosePopup => 1,
                    ConfigJSON => $ActivityDialogConfig,
                );
            }
            else {

                # redirect to last screen
                return $Self->_PopupResponse(
                    Redirect   => 1,
                    Screen     => $LastScreen,
                    ConfigJSON => $ActivityDialogConfig,
                );
            }
        }
    }

    # ------------------------------------------------------------ #
    # ActivityDialogEdit
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'ActivityDialogEdit' ) {

        # check for ActivityDialogID
        if ( !$ActivityDialogID ) {
            return $LayoutObject->ErrorScreen(
                Message => Translatable("Need ActivityDialogID!"),
            );
        }

        # remove this screen from session screen path
        $Self->_PopSessionScreen( OnlyCurrent => 1 );

        # get Activity Dialog data
        my $ActivityDialogData = $ActivityDialogObject->ActivityDialogGet(
            ID     => $ActivityDialogID,
            UserID => $Self->{UserID},
        );

        # check for valid Activity Dialog data
        if ( !IsHashRefWithData($ActivityDialogData) ) {
            return $LayoutObject->ErrorScreen(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'Could not get data for ActivityDialogID %s',
                    $ActivityDialogID
                ),
            );
        }

        return $Self->_ShowEdit(
            %Param,
            ActivityDialogID   => $ActivityDialogID,
            ActivityDialogData => $ActivityDialogData,
            Action             => 'Edit',
        );
    }

    # ------------------------------------------------------------ #
    # ActvityDialogEditAction
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'ActivityDialogEditAction' ) {

        # challenge token check for write action
        $LayoutObject->ChallengeTokenCheck();

        # get Activity Dialog Data
        my $ActivityDialogData;

        # get parameter from web browser
        my $GetParam = $Self->_GetParams();

        # set new confguration
        $ActivityDialogData->{Name}                           = $GetParam->{Name};
        $ActivityDialogData->{EntityID}                       = $GetParam->{EntityID};
        $ActivityDialogData->{Config}->{Interface}            = $GetParam->{Interface};
        $ActivityDialogData->{Config}->{DescriptionShort}     = $GetParam->{DescriptionShort};
        $ActivityDialogData->{Config}->{DescriptionLong}      = $GetParam->{DescriptionLong};
        $ActivityDialogData->{Config}->{Permission}           = $GetParam->{Permission};
        $ActivityDialogData->{Config}->{RequiredLock}         = $GetParam->{RequiredLock} || 0;
        $ActivityDialogData->{Config}->{SubmitAdviceText}     = $GetParam->{SubmitAdviceText};
        $ActivityDialogData->{Config}->{SubmitButtonText}     = $GetParam->{SubmitButtonText};
        $ActivityDialogData->{Config}->{InputFieldDefinition} = $GetParam->{InputFieldDefinition};
        $ActivityDialogData->{Config}->{DirectSubmit}         = $GetParam->{DirectSubmit} || 0;
        $ActivityDialogData->{Config}->{Fields}               = {};
        $ActivityDialogData->{Config}->{FieldOrder}           = [];

        if ( IsArrayRefWithData( $GetParam->{Fields} ) ) {

            FIELD:
            for my $FieldName ( @{ $GetParam->{Fields} } ) {
                next FIELD if !$FieldName;
                next FIELD if !$AvailableFieldsList->{$FieldName};

                # set fields hash
                $ActivityDialogData->{Config}->{Fields}->{$FieldName} = {};

                # set field order array
                push @{ $ActivityDialogData->{Config}->{FieldOrder} }, $FieldName;
            }
        }

        # add field detail config to fields
        if ( IsHashRefWithData( $GetParam->{FieldDetails} ) ) {
            FIELDDETAIL:
            for my $FieldDetail ( sort keys %{ $GetParam->{FieldDetails} } ) {
                next FIELDDETAIL if !$FieldDetail;
                next FIELDDETAIL if !$ActivityDialogData->{Config}->{Fields}->{$FieldDetail};

                $ActivityDialogData->{Config}->{Fields}->{$FieldDetail} = $GetParam->{FieldDetails}->{$FieldDetail};
            }
        }

        # set default values for fields in case they don't have details
        for my $FieldName ( sort keys %{ $ActivityDialogData->{Config}->{Fields} } ) {
            if ( !IsHashRefWithData( $ActivityDialogData->{Config}->{Fields}->{$FieldName} ) ) {
                $ActivityDialogData->{Config}->{Fields}->{$FieldName}->{DescriptionShort} = $FieldName;
            }
        }

        # set correct Interface value
        my %Interfaces = (
            AgentInterface    => ['AgentInterface'],
            CustomerInterface => ['CustomerInterface'],
            BothInterfaces    => [ 'AgentInterface', 'CustomerInterface' ],
        );
        $ActivityDialogData->{Config}->{Interface} = $Interfaces{ $ActivityDialogData->{Config}->{Interface} };

        if ( !$ActivityDialogData->{Config}->{Interface} ) {
            $ActivityDialogData->{Config}->{Interface} = $Interfaces{Agent};
        }

        # check required parameters
        my %Error;

        if ( !$GetParam->{Name} ) {

            # add server error error class
            $Error{NameServerError}        = 'ServerError';
            $Error{NameServerErrorMessage} = Translatable('This field is required');
        }

        if ( !$GetParam->{DescriptionShort} ) {

            # add server error error class
            $Error{DescriptionShortServerError} = 'ServerError';
            $Error{DecriptionShortErrorMessage} = Translatable('This field is required');
        }

        # check if permission exists
        if ( defined $GetParam->{Permission} && $GetParam->{Permission} ne '' ) {

            my $PermissionList = $ConfigObject->Get('System::Permission');

            my %PermissionLookup = map { $_ => 1 } @{$PermissionList};

            if ( !$PermissionLookup{ $GetParam->{Permission} } )
            {

                # add server error error class
                $Error{PermissionServerError} = 'ServerError';
            }
        }

        # check if required lock exists
        if ( $GetParam->{RequiredLock} && $GetParam->{RequiredLock} ne 1 ) {

            # add server error error class
            $Error{RequiredLockServerError} = 'ServerError';
        }

        # if there is an error return to edit screen
        if ( IsHashRefWithData( \%Error ) ) {
            return $Self->_ShowEdit(
                %Error,
                %Param,
                ActivityDialogData => $ActivityDialogData,
                Action             => 'Edit',
            );
        }

        # otherwise save configuration and return to overview screen
        my $Success = $ActivityDialogObject->ActivityDialogUpdate(
            ID       => $ActivityDialogID,
            Name     => $ActivityDialogData->{Name},
            EntityID => $ActivityDialogData->{EntityID},
            Config   => $ActivityDialogData->{Config},
            UserID   => $Self->{UserID},
        );

        # show error if can't update
        if ( !$Success ) {
            return $LayoutObject->ErrorScreen(
                Message => Translatable("There was an error updating the ActivityDialog"),
            );
        }

        # set entity sync state
        $Success = $EntityObject->EntitySyncStateSet(
            EntityType => 'ActivityDialog',
            EntityID   => $ActivityDialogData->{EntityID},
            SyncState  => 'not_sync',
            UserID     => $Self->{UserID},
        );

        # show error if can't set
        if ( !$Success ) {
            return $LayoutObject->ErrorScreen(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'There was an error setting the entity sync status for ActivityDialog entity: %s',
                    $ActivityDialogData->{EntityID}
                ),
            );
        }

        # remove this screen from session screen path
        $Self->_PopSessionScreen( OnlyCurrent => 1 );

        my $Redirect = $ParamObject->GetParam( Param => 'PopupRedirect' ) || '';

        # get latest config data to send it back to main window
        my $ActivityDialogConfig = $Self->_GetActivityDialogConfig(
            EntityID => $ActivityDialogData->{EntityID},
        );

        # check if needed to open another window or if popup should go back
        if ( $Redirect && $Redirect eq '1' ) {

            $Self->_PushSessionScreen(
                ID        => $ActivityDialogID,
                EntityID  => $ActivityDialogData->{EntityID},
                Subaction => 'ActivityDialogEdit'               # always use edit screen
            );

            my $RedirectField = $ParamObject->GetParam( Param => 'PopupRedirectID' ) || '';

            # redirect to another popup window
            return $Self->_PopupResponse(
                Redirect => 1,
                Screen   => {
                    Action    => 'AdminProcessManagementField',
                    Subaction => 'FieldEdit',
                    Field     => $RedirectField,
                },
                ConfigJSON => $ActivityDialogConfig,
            );
        }
        else {

            # remove last screen
            my $LastScreen = $Self->_PopSessionScreen();

            # check if needed to return to main screen or to be redirected to last screen
            if ( $LastScreen->{Action} eq 'AdminProcessManagement' ) {

                # close the popup
                return $Self->_PopupResponse(
                    ClosePopup => 1,
                    ConfigJSON => $ActivityDialogConfig,
                );
            }
            else {

                # redirect to last screen
                return $Self->_PopupResponse(
                    Redirect   => 1,
                    Screen     => $LastScreen,
                    ConfigJSON => $ActivityDialogConfig,
                );
            }
        }
    }

    # ------------------------------------------------------------ #
    # Close popup
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'ClosePopup' ) {

        # close the popup
        return $Self->_PopupResponse(
            ClosePopup => 1,
            ConfigJSON => '',
        );
    }

    # ------------------------------------------------------------ #
    # Error
    # ------------------------------------------------------------ #
    else {
        return $LayoutObject->ErrorScreen(
            Message => Translatable("This subaction is not valid"),
        );
    }
}

sub _GetActivityDialogConfig {
    my ( $Self, %Param ) = @_;

    # Get new ActivityDialog Config as JSON
    my $ProcessDump = $Kernel::OM->Get('Kernel::System::ProcessManagement::DB::Process')->ProcessDump(
        ResultType => 'HASH',
        UserID     => $Self->{UserID},
    );

    my %ActivityDialogConfig;
    $ActivityDialogConfig{ActivityDialog} = ();
    $ActivityDialogConfig{ActivityDialog}->{ $Param{EntityID} } = $ProcessDump->{ActivityDialog}->{ $Param{EntityID} };

    return \%ActivityDialogConfig;
}

sub _ShowEdit {
    my ( $Self, %Param ) = @_;

    # get Activity Dialog information
    my $ActivityDialogData = $Param{ActivityDialogData} || {};

    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    # check if last screen action is main screen
    if ( $Self->{ScreensPath}->[-1]->{Action} eq 'AdminProcessManagement' ) {

        # show close popup link
        $LayoutObject->Block(
            Name => 'ClosePopup',
            Data => {},
        );
    }
    else {

        # show go back link
        $LayoutObject->Block(
            Name => 'GoBack',
            Data => {
                Action    => $Self->{ScreensPath}->[-1]->{Action}    || '',
                Subaction => $Self->{ScreensPath}->[-1]->{Subaction} || '',
                ID        => $Self->{ScreensPath}->[-1]->{ID}        || '',
                EntityID  => $Self->{ScreensPath}->[-1]->{EntityID}  || '',
            },
        );
    }

    # create available Fields list
    my $AvailableFieldsList = {
        Article     => 'Article',
        State       => 'StateID',
        Priority    => 'PriorityID',
        Lock        => 'LockID',
        Queue       => 'QueueID',
        CustomerID  => 'CustomerID',
        Owner       => 'OwnerID',
        PendingTime => 'PendingTime',
        Title       => 'Title',
    };

    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');

    # add service and SLA fields, if option is activated in sysconfig.
    if ( $ConfigObject->Get('Ticket::Service') ) {
        $AvailableFieldsList->{Service} = 'ServiceID';
        $AvailableFieldsList->{SLA}     = 'SLAID';
    }

    # add ticket type field, if option is activated in sysconfig.
    if ( $ConfigObject->Get('Ticket::Type') ) {
        $AvailableFieldsList->{Type} = 'TypeID';
    }

    # add responsible field, if option is activated in sysconfig.
    if ( $ConfigObject->Get('Ticket::Responsible') ) {
        $AvailableFieldsList->{Responsible} = 'ResponsibleID';
    }

    my $DynamicFieldList = $Kernel::OM->Get('Kernel::System::DynamicField')->DynamicFieldList(
        ObjectType => ['Ticket'],
        ResultType => 'HASH',
    );

    DYNAMICFIELD:
    for my $DynamicFieldName ( values %{$DynamicFieldList} ) {

        next DYNAMICFIELD if !$DynamicFieldName;

        # do not show internal fields for process management
        next DYNAMICFIELD if $DynamicFieldName eq 'ProcessManagementProcessID';
        next DYNAMICFIELD if $DynamicFieldName eq 'ProcessManagementActivityID';

        $AvailableFieldsList->{"DynamicField_$DynamicFieldName"} = $DynamicFieldName;
    }

    # localize available fields
    my %AvailableFields = %{$AvailableFieldsList};

    if ( defined $Param{Action} && $Param{Action} eq 'Edit' ) {

        # get used fields by the activity dialog
        my %AssignedFields;

        if ( IsHashRefWithData( $ActivityDialogData->{Config}->{Fields} ) ) {
            FIELD:
            for my $Field ( sort keys %{ $ActivityDialogData->{Config}->{Fields} } ) {
                next FIELD if !$Field;
                next FIELD if !$ActivityDialogData->{Config}->{Fields}->{$Field};

                $AssignedFields{$Field} = 1;
            }
        }

        # remove used fields from available list
        for my $Field ( sort keys %AssignedFields ) {
            delete $AvailableFields{$Field};
        }

        # sort by translated field names
        my %AvailableFieldsTranslated;
        for my $Field ( sort keys %AvailableFields ) {
            my $Translation = $LayoutObject->{LanguageObject}->Translate($Field);
            $AvailableFieldsTranslated{$Field} = $Translation;
        }

        # display available fields
        for my $Field (
            sort { $AvailableFieldsTranslated{$a} cmp $AvailableFieldsTranslated{$b} }
            keys %AvailableFieldsTranslated
            )
        {
            $LayoutObject->Block(
                Name => 'AvailableFieldRow',
                Data => {
                    Field               => $Field,
                    FieldnameTranslated => $AvailableFieldsTranslated{$Field},
                },
            );
        }

        # display used fields
        ASSIGNEDFIELD:
        for my $Field ( @{ $ActivityDialogData->{Config}->{FieldOrder} } ) {
            next ASSIGNEDFIELD if !$AssignedFields{$Field};

            my $FieldConfig = $ActivityDialogData->{Config}->{Fields}->{$Field};

            my $FieldConfigJSON = $Kernel::OM->Get('Kernel::System::JSON')->Encode(
                Data => $FieldConfig,
            );

            $LayoutObject->Block(
                Name => 'AssignedFieldRow',
                Data => {
                    Field       => $Field,
                    FieldConfig => $FieldConfigJSON,
                },
            );
        }

        # display other affected processes by editing this activity (if applicable)
        my $AffectedActivities = $Self->_CheckActivityDialogUsage(
            EntityID => $ActivityDialogData->{EntityID},
        );

        if ( @{$AffectedActivities} ) {

            $LayoutObject->Block(
                Name => 'EditWarning',
                Data => {
                    ActivityList => join( ', ', @{$AffectedActivities} ),
                }
            );
        }

        $Param{Title} = $LayoutObject->{LanguageObject}->Translate(
            'Edit Activity Dialog "%s"',
            $ActivityDialogData->{Name}
        );
    }
    else {

        # sort by translated field names
        my %AvailableFieldsTranslated;
        for my $Field ( sort keys %AvailableFields ) {
            my $Translation = $LayoutObject->{LanguageObject}->Translate($Field);
            $AvailableFieldsTranslated{$Field} = $Translation;
        }

        # display available fields
        for my $Field (
            sort { $AvailableFieldsTranslated{$a} cmp $AvailableFieldsTranslated{$b} }
            keys %AvailableFieldsTranslated
            )
        {
            $LayoutObject->Block(
                Name => 'AvailableFieldRow',
                Data => {
                    Field               => $Field,
                    FieldnameTranslated => $AvailableFieldsTranslated{$Field},
                },
            );
        }

        $Param{Title} = Translatable('Create New Activity Dialog');
    }

    # get interface infos
    if ( defined $ActivityDialogData->{Config}->{Interface} ) {
        my $InterfaceLength = scalar @{ $ActivityDialogData->{Config}->{Interface} };
        if ( $InterfaceLength == 2 ) {
            $ActivityDialogData->{Config}->{Interface} = 'BothInterfaces';
        }
        elsif ( $InterfaceLength == 1 ) {
            $ActivityDialogData->{Config}->{Interface} = $ActivityDialogData->{Config}->{Interface}->[0];
        }
        else {
            $ActivityDialogData->{Config}->{Interface} = 'AgentInterface';
        }
    }
    else {
        $ActivityDialogData->{Config}->{Interface} = 'AgentInterface';
    }

    # create interface selection
    $Param{InterfaceSelection} = $LayoutObject->BuildSelection(
        Data => {
            AgentInterface    => Translatable('Agent Interface'),
            CustomerInterface => Translatable('Customer Interface'),
            BothInterfaces    => Translatable('Agent and Customer Interface'),
        },
        Name         => 'Interface',
        ID           => 'Interface',
        SelectedID   => $ActivityDialogData->{Config}->{Interface} || '',
        Sort         => 'AlphanumericKey',
        Translation  => 1,
        PossibleNone => 0,
        Class        => 'Modernize',
    );

    # create permission selection
    $Param{PermissionSelection} = $LayoutObject->BuildSelection(
        Data         => $Kernel::OM->Get('Kernel::Config')->Get('System::Permission') || ['rw'],
        Name         => 'Permission',
        ID           => 'Permission',
        SelectedID   => $ActivityDialogData->{Config}->{Permission} || '',
        Sort         => 'AlphanumericKey',
        Translation  => 1,
        PossibleNone => 1,
        Class        => 'Modernize' . ( $Param{PermissionServerError} || '' ),
    );

    # create "required lock" selection
    $Param{RequiredLockSelection} = $LayoutObject->BuildSelection(
        Data => {
            0 => Translatable('No'),
            1 => Translatable('Yes'),
        },
        Name        => 'RequiredLock',
        ID          => 'RequiredLock',
        SelectedID  => $ActivityDialogData->{Config}->{RequiredLock} || 0,
        Sort        => 'AlphanumericKey',
        Translation => 1,
        Class       => 'Modernize ' . ( $Param{RequiredLockServerError} || '' ),
    );

    # create Display selection
    $Param{DisplaySelection} = $LayoutObject->BuildSelection(
        Data => {
            0 => Translatable('Do not show Field'),
            1 => Translatable('Show Field'),
            2 => Translatable('Show Field As Mandatory'),
        },
        Name        => 'Display',
        ID          => 'Display',
        Sort        => 'AlphanumericKey',
        Translation => 1,
        Class       => 'Modernize',
    );

    my @ChannelList = $Kernel::OM->Get('Kernel::System::CommunicationChannel')->ChannelList();

    # Allow only Internal and Phone communication channels, this has to be hard coded at the moment.
    my %Channels = map { $_->{ChannelName} => $_->{DisplayName} }
        grep { $_->{ChannelName} eq 'Internal' || $_->{ChannelName} eq 'Phone' }
        @ChannelList;

    # create Communication Channel selection ()
    $Param{CommunicationChannelSelection} = $LayoutObject->BuildSelection(
        Data          => \%Channels,
        SelectedValue => 'Internal',
        Name          => 'CommunicationChannel',
        ID            => 'CommunicationChannel',
        Sort          => 'Alphanumeric',
        Translation   => 1,
        Class         => 'Modernize',
    );

    my %TimeUnitsSelectionList = (
        0 => Translatable('Do not show Field'),
        2 => Translatable('Show Field As Mandatory'),
    );

    if ( !$ConfigObject->Get('Ticket::Frontend::NeedAccountedTime') ) {
        $TimeUnitsSelectionList{1} = 'Show Field';
    }

    # create TimeUnits selection
    if ( $ConfigObject->Get('Ticket::Frontend::AccountTime') ) {

        $Param{TimeUnitsSelection} = $LayoutObject->BuildSelection(
            Data          => \%TimeUnitsSelectionList,
            SelectedValue => 0,
            Name          => 'TimeUnits',
            ID            => 'TimeUnits',
            Translation   => 1,
            Class         => 'Modernize',
        );

        $LayoutObject->Block(
            Name => 'TimeUnitsContainer',
            Data => \%Param,
        );
    }

# Rother OSS / ProcessTicketTemplates
    $LayoutObject->Block(
        Name => 'StandardTemplatesContainer',
    );

# EO ProcessTicketTemplates
    # extract parameters from config
    $Param{DescriptionShort}     = $Param{ActivityDialogData}->{Config}->{DescriptionShort};
    $Param{DescriptionLong}      = $Param{ActivityDialogData}->{Config}->{DescriptionLong};
    $Param{SubmitAdviceText}     = $Param{ActivityDialogData}->{Config}->{SubmitAdviceText};
    $Param{SubmitButtonText}     = $Param{ActivityDialogData}->{Config}->{SubmitButtonText};
    $Param{InputFieldDefinition} = $Param{ActivityDialogData}->{Config}->{InputFieldDefinition};
    $Param{DirectSubmit}         = $Param{ActivityDialogData}->{Config}->{DirectSubmit} ? ' checked' : '';

    # Add code mirror language mode.
    if ( $LayoutObject->{BrowserRichText} ) {
        $LayoutObject->AddJSData(
            Key   => 'EditorLanguageMode',
            Value => 'text/x-yaml',
        );
    }

    my $Output = $LayoutObject->Header(
        Value => $Param{Title},
        Type  => 'Small',
    );
    $Output .= $LayoutObject->Output(
        TemplateFile => "AdminProcessManagementActivityDialog",
        Data         => {
            %Param,
            %{$ActivityDialogData},
        },
    );

    $Output .= $LayoutObject->Footer();

    return $Output;
}

sub _GetParams {
    my ( $Self, %Param ) = @_;

    my $GetParam;
    my $ParamObject = $Kernel::OM->Get('Kernel::System::Web::Request');

    # get parameters from web browser
    for my $ParamName (
        qw( Name EntityID Interface DescriptionShort DescriptionLong Permission RequiredLock SubmitAdviceText
        SubmitButtonText InputFieldDefinition DirectSubmit )
        )
    {
        $GetParam->{$ParamName} = $ParamObject->GetParam( Param => $ParamName ) || '';
    }

    my $Fields     = $ParamObject->GetParam( Param => 'Fields' ) || '';
    my $JSONObject = $Kernel::OM->Get('Kernel::System::JSON');

    if ($Fields) {
        $GetParam->{Fields} = $JSONObject->Decode(
            Data => $Fields,
        );
    }
    else {
        $GetParam->{Fields} = '';
    }

    my $FieldDetails = $ParamObject->GetParam( Param => 'FieldDetails' ) || '';

    if ($FieldDetails) {
        $GetParam->{FieldDetails} = $JSONObject->Decode(
            Data => $FieldDetails,
        );
    }
    else {
        $GetParam->{FieldDetails} = '';
    }

    return $GetParam;
}

sub _PopSessionScreen {
    my ( $Self, %Param ) = @_;

    my $LastScreen;

    if ( defined $Param{OnlyCurrent} && $Param{OnlyCurrent} == 1 ) {

        # check if last screen action is current screen action
        if ( $Self->{ScreensPath}->[-1]->{Action} eq $Self->{Action} ) {

            # remove last screen
            $LastScreen = pop @{ $Self->{ScreensPath} };
        }
    }
    else {

        # remove last screen
        $LastScreen = pop @{ $Self->{ScreensPath} };
    }

    # convert screens path to string (JSON)
    my $JSONScreensPath = my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout')->JSONEncode(
        Data => $Self->{ScreensPath},
    );

    # update session
    $Kernel::OM->Get('Kernel::System::AuthSession')->UpdateSessionID(
        SessionID => $Self->{SessionID},
        Key       => 'ProcessManagementScreensPath',
        Value     => $JSONScreensPath,
    );

    return $LastScreen;
}

sub _PushSessionScreen {
    my ( $Self, %Param ) = @_;

    # add screen to the screen path
    push @{ $Self->{ScreensPath} }, {
        Action    => $Self->{Action} || '',
        Subaction => $Param{Subaction},
        ID        => $Param{ID},
        EntityID  => $Param{EntityID},
    };

    # convert screens path to string (JSON)
    my $JSONScreensPath = my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout')->JSONEncode(
        Data => $Self->{ScreensPath},
    );

    # update session
    $Kernel::OM->Get('Kernel::System::AuthSession')->UpdateSessionID(
        SessionID => $Self->{SessionID},
        Key       => 'ProcessManagementScreensPath',
        Value     => $JSONScreensPath,
    );

    return 1;
}

sub _PopupResponse {
    my ( $Self, %Param ) = @_;

    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    if ( $Param{Redirect} && $Param{Redirect} eq 1 ) {

        # send data to JS
        $LayoutObject->AddJSData(
            Key   => 'Redirect',
            Value => {
                ConfigJSON => $Param{ConfigJSON},
                %{ $Param{Screen} },
            }
        );
    }
    elsif ( $Param{ClosePopup} && $Param{ClosePopup} eq 1 ) {

        # send data to JS
        $LayoutObject->AddJSData(
            Key   => 'ClosePopup',
            Value => {
                ConfigJSON => $Param{ConfigJSON},
            }
        );
    }

    my $Output = $LayoutObject->Header( Type => 'Small' );
    $Output .= $LayoutObject->Output(
        TemplateFile => "AdminProcessManagementPopupResponse",
        Data         => {},
    );
    $Output .= $LayoutObject->Footer( Type => 'Small' );

    return $Output;
}

sub _CheckActivityDialogUsage {
    my ( $Self, %Param ) = @_;

    # get a list of parents with all the details
    my $List = $Kernel::OM->Get('Kernel::System::ProcessManagement::DB::Activity')->ActivityListGet(
        UserID => 1,
    );

    my @Usage;

    # search entity id in all parents
    PARENT:
    for my $ParentData ( @{$List} ) {
        next PARENT if !$ParentData;
        next PARENT if !$ParentData->{ActivityDialogs};
        ENTITY:
        for my $EntityID ( @{ $ParentData->{ActivityDialogs} } ) {
            if ( $EntityID eq $Param{EntityID} ) {
                push @Usage, $ParentData->{Name};
                last ENTITY;
            }
        }
    }

    return \@Usage;
}

1;
</File>
        <File Location="Custom/Kernel/Modules/AgentTicketProcess.pm" Permission="660" Encode="Base64"># --
# OTOBO is a web-based ticketing system for service organisations.
# --
# Copyright (C) 2001-2020 OTRS AG, https://otrs.com/
# Copyright (C) 2019-2026 Rother OSS GmbH, https://otobo.io/
# --
# $origin: otobo - ba2b8d4c3d1d2c75ac3e475af1adb5fafd50f378 - Kernel/Modules/AgentTicketProcess.pm
# --
# This program is free software: you can redistribute it and/or modify it under
# the terms of the GNU General Public License as published by the Free Software
# Foundation, either version 3 of the License, or (at your option) any later version.
# This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# --

package Kernel::Modules::AgentTicketProcess;

use strict;
use warnings;

# core modules
use List::Util qw(none);

# CPAN modules
use Mail::Address ();

# OTOBO modules
use Kernel::System::VariableCheck qw(:all);
use Kernel::Language              qw(Translatable);

our $ObjectManagerDisabled = 1;

sub new {
    my ( $Type, %Param ) = @_;

    # allocate new hash for object
    my $Self = {%Param};
    bless $Self, $Type;

    # global config hash for id dissolution
    $Self->{NameToID} = {
        Title          => 'Title',
        State          => 'StateID',
        StateID        => 'StateID',
        Priority       => 'PriorityID',
        PriorityID     => 'PriorityID',
        Lock           => 'LockID',
        LockID         => 'LockID',
        Queue          => 'QueueID',
        QueueID        => 'QueueID',
        Customer       => 'CustomerID',
        CustomerID     => 'CustomerID',
        CustomerNo     => 'CustomerID',
        CustomerUserID => 'CustomerUserID',
        Owner          => 'OwnerID',
        OwnerID        => 'OwnerID',
        Type           => 'TypeID',
        TypeID         => 'TypeID',
        SLA            => 'SLAID',
        SLAID          => 'SLAID',
        Service        => 'ServiceID',
        ServiceID      => 'ServiceID',
        Responsible    => 'ResponsibleID',
        ResponsibleID  => 'ResponsibleID',
        PendingTime    => 'PendingTime',
        Article        => 'Article',
    };

    return $Self;
}

sub Run {
    my ( $Self, %Param ) = @_;

    # get param object
    my $ParamObject = $Kernel::OM->Get('Kernel::System::Web::Request');

    my $TicketID               = $ParamObject->GetParam( Param => 'TicketID' );
    my $ActivityDialogEntityID = $ParamObject->GetParam( Param => 'ActivityDialogEntityID' );
    my $ActivityDialogHashRef;

    # get needed objects
    my $ActivityDialogObject = $Kernel::OM->Get('Kernel::System::ProcessManagement::ActivityDialog');
    my $LayoutObject         = $Kernel::OM->Get('Kernel::Output::HTML::Layout');
    my $TicketObject         = $Kernel::OM->Get('Kernel::System::Ticket');

    $Self->{FirstActivityDialog} = $ParamObject->GetParam( Param => 'FirstActivityDialog' );
    $Self->{LinkTicketID}        = $ParamObject->GetParam( Param => 'LinkTicketID' ) || '';
    $Self->{ArticleID}           = $ParamObject->GetParam( Param => 'ArticleID' )    || '';

    # get the ticket information on link actions
    if ( $Self->{LinkTicketID} ) {
        my %TicketData = $TicketObject->TicketGet(
            TicketID => $Self->{LinkTicketID},
            UserID   => $Self->{UserID},
            Extended => 1,
        );
        $Self->{LinkTicketData} = \%TicketData;

        # set LinkTicketID param for showing on main form
        $Param{LinkTicketID} = $Self->{LinkTicketID};
    }

    # get the article information on link actions
    if ( $Self->{ArticleID} ) {
        my $ArticleBackendObject = $Kernel::OM->Get('Kernel::System::Ticket::Article')->BackendForArticle(
            TicketID  => $Self->{LinkTicketID},
            ArticleID => $Self->{ArticleID},
        );

        my %Article = $ArticleBackendObject->ArticleGet(
            TicketID  => $Self->{LinkTicketID},
            ArticleID => $Self->{ArticleID},
        );

        $Self->{LinkArticleData} = \%Article;

        # set ArticleID param for showing on main form
        $Param{ArticleID} = $Self->{ArticleID};
    }

    if ($TicketID) {

        # check if there is a configured required permission
        # for the ActivityDialog (if there is one)
        my $ActivityDialogPermission = 'rw';
        if ($ActivityDialogEntityID) {
            $ActivityDialogHashRef = $ActivityDialogObject->ActivityDialogGet(
                ActivityDialogEntityID => $ActivityDialogEntityID,
                Interface              => 'AgentInterface',
            );

            if ( !IsHashRefWithData($ActivityDialogHashRef) ) {
                return $LayoutObject->ErrorScreen(
                    Message => $LayoutObject->{LanguageObject}->Translate(
                        'Couldn\'t get ActivityDialogEntityID "%s"!',
                        $ActivityDialogEntityID,
                    ),
                    Comment => Translatable('Please contact the administrator.'),
                );
            }

            if ( $ActivityDialogHashRef->{Permission} ) {
                $ActivityDialogPermission = $ActivityDialogHashRef->{Permission};
            }
        }

        # check permissions
        my $Access = $TicketObject->TicketPermission(
            Type     => $ActivityDialogPermission,
            TicketID => $Self->{TicketID},
            UserID   => $Self->{UserID}
        );

        # error screen, don't show ticket
        if ( !$Access ) {
            return $LayoutObject->NoPermission(
                Message =>
                    $LayoutObject->{LanguageObject}->Translate( 'You need %s permissions!', $ActivityDialogPermission ),
                WithHeader => 'yes',
            );
        }

        # get ACL restrictions
        my %PossibleActions = ( 1 => $Self->{Action} );

        my $ACL = $TicketObject->TicketAcl(
            Data          => \%PossibleActions,
            Action        => $Self->{Action},
            TicketID      => $Self->{TicketID},
            ReturnType    => 'Action',
            ReturnSubType => '-',
            UserID        => $Self->{UserID},
        );
        my %AclAction = $TicketObject->TicketAclActionData();

        # check if ACL restrictions exist
        if ($ACL) {

            my %AclActionLookup = reverse %AclAction;

            # show error screen if ACL prohibits this action
            if ( !$AclActionLookup{ $Self->{Action} } ) {
                return $LayoutObject->NoPermission( WithHeader => 'yes' );
            }
        }

        if ( IsHashRefWithData($ActivityDialogHashRef) ) {

            # check if it's already locked by somebody else
            if ( $ActivityDialogHashRef->{RequiredLock} ) {

                if ( $TicketObject->TicketLockGet( TicketID => $TicketID ) ) {
                    my $AccessOk = $TicketObject->OwnerCheck(
                        TicketID => $TicketID,
                        OwnerID  => $Self->{UserID},
                    );
                    if ( !$AccessOk ) {
                        my $Output = $LayoutObject->Header(
                            Type => 'Small',
                        );
                        $Output .= $LayoutObject->Warning(
                            Message => Translatable('Sorry, you need to be the ticket owner to perform this action.'),
                            Comment => Translatable('Please change the owner first.'),
                        );
                        $Output .= $LayoutObject->Footer(
                            Type => 'Small',
                        );
                        return $Output;
                    }
                }
                else {

                    my %Ticket = $TicketObject->TicketGet(
                        TicketID => $TicketID,
                    );

                    my $Lock = $TicketObject->TicketLockSet(
                        TicketID => $TicketID,
                        Lock     => 'lock',
                        UserID   => $Self->{UserID}
                    );

                    # Set new owner if ticket owner is different then logged user.
                    if ( $Lock && ( $Ticket{OwnerID} != $Self->{UserID} ) ) {

                        # Remember previous owner, which will be used to restore ticket owner on undo action.
                        $Param{PreviousOwner} = $Ticket{OwnerID};

                        my $Success = $TicketObject->TicketOwnerSet(
                            TicketID  => $TicketID,
                            UserID    => $Self->{UserID},
                            NewUserID => $Self->{UserID},
                        );

                        # Reload the parent window to show the updated lock state.
                        $Param{ParentReload} = 1;

                        # Show lock state link.
                        $Param{RenderLocked} = 1;
                    }

                    my $TicketNumber = $TicketObject->TicketNumberLookup(
                        TicketID => $TicketID,
                        UserID   => $Self->{UserID},
                    );

                    # notify the agent that the ticket was locked
                    push @{ $Param{Notify} }, {
                        Priority => 'Notice',
                        Data     => "$TicketNumber: " . $LayoutObject->{LanguageObject}->Translate("Ticket locked."),
                    };
                }
            }

            my $PossibleActivityDialogs = { 1 => $ActivityDialogEntityID };

            # get ACL restrictions
            my $ACL = $TicketObject->TicketAcl(
                Data                   => $PossibleActivityDialogs,
                ActivityDialogEntityID => $ActivityDialogEntityID,
                TicketID               => $TicketID,
                ReturnType             => 'ActivityDialog',
                ReturnSubType          => '-',
                Action                 => $Self->{Action},
                UserID                 => $Self->{UserID},
            );

            if ($ACL) {
                %{$PossibleActivityDialogs} = $TicketObject->TicketAclData();
            }

            # check if ACL restrictions exist
            if ( !IsHashRefWithData($PossibleActivityDialogs) )
            {
                return $LayoutObject->NoPermission( WithHeader => 'yes' );
            }
        }
    }

    # list only Active processes by default
    my @ProcessStates = ('Active');

    # set IsMainWindow, IsAjaxRequest, IsProcessEnroll for proper error responses, screen display
    # and process list
    $Self->{IsMainWindow}    = $ParamObject->GetParam( Param => 'IsMainWindow' )    || '';
    $Self->{IsAjaxRequest}   = $ParamObject->GetParam( Param => 'IsAjaxRequest' )   || '';
    $Self->{IsProcessEnroll} = $ParamObject->GetParam( Param => 'IsProcessEnroll' ) || '';

    # fetch also FadeAway processes to continue working with existing tickets, but not to start new
    #    ones
    if ( !$Self->{IsMainWindow} && $Self->{Subaction} ) {
        push @ProcessStates, 'FadeAway';
    }

    # create process object
    $Kernel::OM->ObjectParamAdd(
        'Kernel::System::ProcessManagement::Process' => {
            ActivityObject         => $Kernel::OM->Get('Kernel::System::ProcessManagement::Activity'),
            ActivityDialogObject   => $ActivityDialogObject,
            TransitionObject       => $Kernel::OM->Get('Kernel::System::ProcessManagement::Transition'),
            TransitionActionObject => $Kernel::OM->Get('Kernel::System::ProcessManagement::TransitionAction'),
        }
    );
    my $ProcessObject = $Kernel::OM->Get('Kernel::System::ProcessManagement::Process');

    # get processes
    my $ProcessList = $ProcessObject->ProcessList(
        ProcessState => \@ProcessStates,
        Interface    => ['AgentInterface'],
    );

    # also get the list of processes initiated by customers, as an activity dialog might be
    # configured for the agent interface
    my $FollowupProcessList = $ProcessObject->ProcessList(
        ProcessState => \@ProcessStates,
        Interface    => 'all',
    );

    my $ProcessEntityID = $ParamObject->GetParam( Param => 'ProcessEntityID' );

    if ( !IsHashRefWithData($ProcessList) && !IsHashRefWithData($FollowupProcessList) ) {
        return $LayoutObject->ErrorScreen(
            Message => Translatable('No Process configured!'),
            Comment => Translatable('Please contact the administrator.'),
        );
    }

    # prepare process list for ACLs, use only entities instead of names, convert from
    #   P1 => Name to P1 => P1. As ACLs should work only against entities
    my %ProcessListACL = map { $_ => $_ } sort keys %{$ProcessList};

    # validate the ProcessList with stored ACLs
    my $ACL = $TicketObject->TicketAcl(
        ReturnType    => 'Process',
        ReturnSubType => '-',
        Data          => \%ProcessListACL,
        Action        => $Self->{Action},
        UserID        => $Self->{UserID},
        TicketID      => $TicketID,
    );

    if ( IsHashRefWithData($ProcessList) && $ACL ) {

        # get ACL results
        my %ACLData = $TicketObject->TicketAclData();

        # recover process names
        my %ReducedProcessList = map { $_ => $ProcessList->{$_} } sort keys %ACLData;

        # replace original process list with the reduced one
        $ProcessList = \%ReducedProcessList;
    }

    # get form id
    $Self->{FormID} = $Kernel::OM->Get('Kernel::System::Web::FormCache')->PrepareFormID(
        ParamObject  => $ParamObject,
        LayoutObject => $LayoutObject,
    );

    # if we have no subaction display the process list to start a new one
    if ( !$Self->{Subaction} ) {

        # to display the process list is mandatory to have processes that agent can start
        if ( !IsHashRefWithData($ProcessList) ) {
            return $LayoutObject->ErrorScreen(
                Message => Translatable('No Process configured!'),
                Comment => Translatable('Please contact the administrator.'),
            );
        }

        # get process id (if any, a process should be pre-selected)
        $Param{ProcessID} = $ParamObject->GetParam( Param => 'ID' );
        if ( $Param{ProcessID} ) {
            $Param{PreSelectProcess} = 1;
        }

        return $Self->_DisplayProcessList(
            %Param,
            ProcessList     => $ProcessList,
            ProcessEntityID => $ProcessEntityID || $Param{ProcessID},
            TicketID        => $TicketID,
        );
    }

    # check if the selected process from the list is valid, prevent tamper with process selection
    #    list (not existing, invalid an fade away processes must not be able to start a new process
    #    ticket)
    elsif (
        $Self->{Subaction} eq 'DisplayActivityDialogAJAX'
        && !$ProcessList->{$ProcessEntityID}
        && $Self->{IsMainWindow}
        )
    {

        # translate the error message (as it will be injected in the HTML)
        my $ErrorMessage = $LayoutObject->{LanguageObject}->Translate("The selected process is invalid!");

        # return a predefined HTML structure as the AJAX call is expecting and HTML response
        return $LayoutObject->Attachment(
            ContentType => 'text/html; charset=' . $LayoutObject->{Charset},
            Content     => '<div class="ServerError" data-message="' . $ErrorMessage . '"></div>',
            Type        => 'inline',
            NoCache     => 1,
        );
    }

    # if invalid process is detected on a ActivityDilog pop-up screen show an error message
    elsif (
        $Self->{Subaction} eq 'DisplayActivityDialog'
        && !$FollowupProcessList->{$ProcessEntityID}
        && !$Self->{IsMainWindow}
        )
    {
        $LayoutObject->FatalError(
            Message => $LayoutObject->{LanguageObject}->Translate( 'Process %s is invalid!', $ProcessEntityID ),
            Comment => Translatable('Please contact the administrator.'),
        );
    }

    # Get the necessary parameters
    # collects a mixture of present values bottom to top:
    # SysConfig DefaultValues, ActivityDialog DefaultValues, TicketValues, SubmittedValues
    # including ActivityDialogEntityID and ProcessEntityID
    # also sets $Self->{DynamicField} which contains all DFs of the current Dialog
    # is used for:
    # - Parameter checking before storing
    # - will be used for ACL checking later on
    my $GetParam = $Self->_GetParam(
        ProcessEntityID => $ProcessEntityID,
    );

    if ( $Self->{Subaction} eq 'StoreActivityDialog' && $ProcessEntityID ) {
        $LayoutObject->ChallengeTokenCheck();

        return $Self->_StoreActivityDialog(
            %Param,
            ProcessName     => $ProcessList->{$ProcessEntityID},
            ProcessEntityID => $ProcessEntityID,
            GetParam        => $GetParam,
        );
    }
    if ( $Self->{Subaction} eq 'DisplayActivityDialog' && $ProcessEntityID ) {

        # initial rendering - pre-fill dynamic fields with ticket values
        my %Ticket;
        if ($TicketID) {
            %Ticket = $TicketObject->TicketGet(
                TicketID      => $TicketID,
                UserID        => $Self->{UserID},
                DynamicFields => 1,
            );
        }

        DYNAMICFIELD:
        for my $DynamicFieldConfig ( values $Self->{DynamicField}->%* ) {
            next DYNAMICFIELD unless IsHashRefWithData($DynamicFieldConfig);

            # This overwrites the values that might have been taken from the web request.
            # Note that there shouldn't be any values from the web request,
            # because submits, successful and unsuccessful have been handled already above.
            if ( ( $DynamicFieldConfig->{ObjectType} eq 'Ticket' ) && $TicketID ) {

                # Value is stored in the database from Ticket.
                $GetParam->{DynamicField}{ 'DynamicField_' . $DynamicFieldConfig->{Name} } = $Ticket{ 'DynamicField_' . $DynamicFieldConfig->{Name} };
            }
        }

        return $Self->_OutputActivityDialog(
            %Param,
            ProcessEntityID => $ProcessEntityID,
            GetParam        => $GetParam,
        );
    }
    if ( $Self->{Subaction} eq 'DisplayActivityDialogAJAX' && $ProcessEntityID ) {

        # delete visibility cache
        $Kernel::OM->Get('Kernel::System::Cache')->Delete(
            Type => 'HiddenFields',
            Key  => $Self->{FormID},
        );

        my $ActivityDialogHTML = $Self->_OutputActivityDialog(
            %Param,
            ProcessEntityID => $ProcessEntityID,
            GetParam        => $GetParam,
        );
        return $LayoutObject->Attachment(
            ContentType => 'text/html; charset=' . $LayoutObject->{Charset},
            Content     => $ActivityDialogHTML,
            Type        => 'inline',
            NoCache     => 1,
        );

    }

    elsif ( $Self->{Subaction} eq 'AJAXUpdate' ) {

        return $Self->_RenderAjax(
            %Param,
            ProcessEntityID => $ProcessEntityID,
            GetParam        => $GetParam,
        );
    }
    return $LayoutObject->ErrorScreen(
        Message => Translatable('Subaction is invalid!'),
        Comment => Translatable('Please contact the administrator.'),
    );
}

sub _RenderAjax {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    # FatalError is safe because a JSON structure is expecting, then it will result into a
    # communications error

    for my $Needed (qw(ProcessEntityID)) {
        if ( !$Param{$Needed} ) {
            $LayoutObject->FatalError(
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderAjax' ),
            );
        }
    }
    my $ActivityDialogEntityID = $Param{GetParam}{ActivityDialogEntityID};
    if ( !$ActivityDialogEntityID ) {
        $LayoutObject->FatalError(
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogEntityID', '_RenderAjax' ),
        );
    }
    my $ActivityDialog = $Kernel::OM->Get('Kernel::System::ProcessManagement::ActivityDialog')->ActivityDialogGet(
        ActivityDialogEntityID => $ActivityDialogEntityID,
        Interface              => 'AgentInterface',
    );

    if ( !IsHashRefWithData($ActivityDialog) ) {
        $LayoutObject->FatalError(
            Message => $LayoutObject->{LanguageObject}->Translate(
                'No ActivityDialog configured for %s in _RenderAjax!',
                $ActivityDialogEntityID,
            ),
        );
    }

    # get list type
    my $TreeView = 0;
    if ( $Kernel::OM->Get('Kernel::Config')->Get('Ticket::Frontend::ListType') eq 'tree' ) {
        $TreeView = 1;
    }

    my %FieldsProcessed;
    my @JSONCollector;
    my $Services;

    # get needed objects
    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');
    my $ParamObject  = $Kernel::OM->Get('Kernel::System::Web::Request');
    my $TicketObject = $Kernel::OM->Get('Kernel::System::Ticket');

    # Get the activity dialog's Submit Param's or Config Params
    DIALOGFIELD:
    for my $CurrentField ( @{ $ActivityDialog->{FieldOrder} } ) {

        # Skip if we're working on a field that was already done with or without ID
        if (
            $Self->{NameToID}{$CurrentField}
            && $FieldsProcessed{ $Self->{NameToID}{$CurrentField} }
            )
        {
            next DIALOGFIELD;
        }

        next DIALOGFIELD if $CurrentField =~ m{^DynamicField_(.*)}xms;

        if ( $Self->{NameToID}{$CurrentField} eq 'OwnerID' ) {
            next DIALOGFIELD if $FieldsProcessed{ $Self->{NameToID}{$CurrentField} };

            my $Data = $Self->_GetOwners(
                %{ $Param{GetParam} },
            );

            # add Owner to the JSONCollector
            push(
                @JSONCollector,
                {
                    Name         => $Self->{NameToID}{$CurrentField},
                    Data         => $Data,
                    SelectedID   => $Param{GetParam}{ $Self->{NameToID}{$CurrentField} },
                    PossibleNone => 1,
                    Translation  => 0,
                    Max          => 100,
                },
            );
            $FieldsProcessed{ $Self->{NameToID}{$CurrentField} } = 1;
        }
        elsif ( $Self->{NameToID}{$CurrentField} eq 'ResponsibleID' ) {
            next DIALOGFIELD if $FieldsProcessed{ $Self->{NameToID}{$CurrentField} };

            my $Data = $Self->_GetResponsibles(
                %{ $Param{GetParam} },
            );

            # add Responsible to the JSONCollector
            push(
                @JSONCollector,
                {
                    Name         => $Self->{NameToID}{$CurrentField},
                    Data         => $Data,
                    SelectedID   => $Param{GetParam}{ $Self->{NameToID}{$CurrentField} },
                    PossibleNone => 1,
                    Translation  => 0,
                    Max          => 100,
                },
            );
            $FieldsProcessed{ $Self->{NameToID}{$CurrentField} } = 1;
        }
        elsif ( $Self->{NameToID}{$CurrentField} eq 'QueueID' ) {
            next DIALOGFIELD if $FieldsProcessed{ $Self->{NameToID}{$CurrentField} };

            my $Data = $Self->_GetQueues(
                %{ $Param{GetParam} },
            );

            # add Queue to the JSONCollector
            push(
                @JSONCollector,
                {
                    Name         => $Self->{NameToID}{$CurrentField},
                    Data         => $Data,
                    SelectedID   => $Param{GetParam}{ $Self->{NameToID}{$CurrentField} },
                    PossibleNone => 1,
                    Translation  => $TreeView,
                    TreeView     => $TreeView,
                    Max          => 100,
                },
            );
            $FieldsProcessed{ $Self->{NameToID}{$CurrentField} } = 1;
        }

        elsif ( $Self->{NameToID}{$CurrentField} eq 'StateID' ) {
            next DIALOGFIELD if $FieldsProcessed{ $Self->{NameToID}{$CurrentField} };

            my $Data = $Self->_GetStates(
                %{ $Param{GetParam} },
            );

            # add State to the JSONCollector
            push(
                @JSONCollector,
                {
                    Name        => 'StateID',
                    Data        => $Data,
                    SelectedID  => $Param{GetParam}{ $Self->{NameToID}{$CurrentField} },
                    Translation => 1,
                    Max         => 100,
                },
            );
            $FieldsProcessed{ $Self->{NameToID}{$CurrentField} } = 1;
        }
        elsif ( $Self->{NameToID}{$CurrentField} eq 'PriorityID' ) {
            next DIALOGFIELD if $FieldsProcessed{ $Self->{NameToID}{$CurrentField} };

            my $Data = $Self->_GetPriorities(
                %{ $Param{GetParam} },
            );

            # add Priority to the JSONCollector
            push(
                @JSONCollector,
                {
                    Name        => $Self->{NameToID}{$CurrentField},
                    Data        => $Data,
                    SelectedID  => $Param{GetParam}{ $Self->{NameToID}{$CurrentField} },
                    Translation => 1,
                    Max         => 100,
                },
            );
            $FieldsProcessed{ $Self->{NameToID}{$CurrentField} } = 1;
        }
        elsif ( $Self->{NameToID}{$CurrentField} eq 'ServiceID' ) {
            next DIALOGFIELD if $FieldsProcessed{ $Self->{NameToID}{$CurrentField} };

            my $Data = $Self->_GetServices(
                %{ $Param{GetParam} },
            );
            $Services = $Data;

            # add Service to the JSONCollector (Use ServiceID from web request)
            push(
                @JSONCollector,
                {
                    Name         => $Self->{NameToID}{$CurrentField},
                    Data         => $Data,
                    SelectedID   => $ParamObject->GetParam( Param => 'ServiceID' ) || '',
                    PossibleNone => 1,
                    Translation  => $TreeView,
                    TreeView     => $TreeView,
                    Max          => 100,
                },
            );
            $FieldsProcessed{ $Self->{NameToID}{$CurrentField} } = 1;
        }
        elsif ( $Self->{NameToID}{$CurrentField} eq 'SLAID' ) {
            next DIALOGFIELD if $FieldsProcessed{ $Self->{NameToID}{$CurrentField} };

            # if SLA is render before service (by it order in the fields) it needs to create
            # the service list
            if ( !IsHashRefWithData($Services) ) {
                $Services = $Self->_GetServices(
                    %{ $Param{GetParam} },
                );
            }

            my $Data = $Self->_GetSLAs(
                %{ $Param{GetParam} },
                Services  => $Services,
                ServiceID => $ParamObject->GetParam( Param => 'ServiceID' ) || '',
            );

            # add SLA to the JSONCollector (Use SelectedID from web request)
            push(
                @JSONCollector,
                {
                    Name         => $Self->{NameToID}{$CurrentField},
                    Data         => $Data,
                    SelectedID   => $ParamObject->GetParam( Param => 'SLAID' ) || '',
                    PossibleNone => 1,
                    Translation  => 1,
                    Max          => 100,
                },
            );
            $FieldsProcessed{ $Self->{NameToID}{$CurrentField} } = 1;
        }
        elsif ( $Self->{NameToID}{$CurrentField} eq 'TypeID' ) {
            next DIALOGFIELD if $FieldsProcessed{ $Self->{NameToID}{$CurrentField} };

            my $Data = $Self->_GetTypes(
                %{ $Param{GetParam} },
            );

            # Add Type to the JSONCollector (Use SelectedID from web request).
            push(
                @JSONCollector,
                {
                    Name         => $Self->{NameToID}{$CurrentField},
                    Data         => $Data,
                    SelectedID   => $ParamObject->GetParam( Param => 'TypeID' ) || '',
                    PossibleNone => 1,
                    Translation  => 1,
                    Max          => 100,
                },
            );
            $FieldsProcessed{ $Self->{NameToID}{$CurrentField} } = 1;
        }
    }
# Rother OSS / ProcessTicketTemplates

    # activate standard templates if article is configured and standard templates are not explicitly set to 0
    my $ActivateStandardTemplates = 0;
    if ( $ActivityDialog->{Fields}{Article} ) {
        $ActivateStandardTemplates = defined $ActivityDialog->{Fields}{Article}{Config}{StandardTemplates} ? $ActivityDialog->{Fields}{Article}{Config}{StandardTemplates} : 1;
    }
    if ( $ActivateStandardTemplates ) {

            my $Data = $Self->_GetStandardTemplates(
                %{ $Param{GetParam} },
            );

            # Add StandardTemplate to the JSONCollector (Use SelectedID from web request).
            push(
                @JSONCollector,
                {
                    Name         => 'StandardTemplateID',
                    Data         => $Data,
                    SelectedID   => $ParamObject->GetParam( Param => 'StandardTemplateID' ) || '',
                    PossibleNone => 1,
                    Translation  => 1,
                    Max          => 100,
                },
            );
    }
# EO ProcessTicketTemplates

    my $DynamicFieldBackendObject = $Kernel::OM->Get('Kernel::System::DynamicField::Backend');
    my $FieldRestrictionsObject   = $Kernel::OM->Get('Kernel::System::Ticket::FieldRestrictions');

    # retrieve field restrictions for dynamic fields
    my $ACLPreselection;
    if ( $ConfigObject->Get('TicketACL::ACLPreselection') ) {

        # get cached preselection rules
        my $CacheObject = $Kernel::OM->Get('Kernel::System::Cache');
        $ACLPreselection = $CacheObject->Get(
            Type => 'TicketACL',
            Key  => 'Preselection',
        );
        if ( !$ACLPreselection ) {
            $ACLPreselection = $FieldRestrictionsObject->SetACLPreselectionCache();
        }
    }

    my $Autoselect      = $ConfigObject->Get('TicketACL::Autoselect') || undef;
    my $LoopProtection  = 100;
    my %ChangedElements = $Param{GetParam}{ElementChanged} ? ( $Param{GetParam}{ElementChanged} => 1 ) : ();
    if ( $ChangedElements{ServiceID} ) {
        $ChangedElements{CustomerUserID} = 1;
        $ChangedElements{CustomerID}     = 1;
    }

    # get values and visibility of dynamic fields
    my %DynFieldStates = $FieldRestrictionsObject->GetFieldStates(
        TicketObject              => $TicketObject,
        DynamicFields             => $Self->{DynamicField},
        DynamicFieldBackendObject => $Kernel::OM->Get('Kernel::System::DynamicField::Backend'),
        Action                    => $Self->{Action},
        ChangedElements           => \%ChangedElements,
        UserID                    => $Self->{UserID},
        TicketID                  => $Param{GetParam}{TicketID},
        FormID                    => $Self->{FormID},
        CustomerUser              => $Param{GetParam}{CustomerUserID} || '',
        GetParam                  => $Param{GetParam},
        Autoselect                => $Autoselect,
        ACLPreselection           => $ACLPreselection // '',
        LoopProtection            => \$LoopProtection,
    );
# Rother OSS / ProcessTicketTemplates

    if ( $ActivateStandardTemplates ) {
        my $StandardTemplates = $Self->_GetStandardTemplates( $Param{GetParam}->%* );

        # check whether current selected value is still valid for the field
        if (
            $Param{GetParam}{StandardTemplateID}
            && !$StandardTemplates->{ $Param{GetParam}{StandardTemplateID} }
            )
        {
            # if not empty the field
            $Param{GetParam}{StandardTemplateID} = '';
            $ChangedElements{StandardTemplateID} = 1;
        }
    }
# EO ProcessTicketTemplates

    $Param{GetParam}{DynamicField} //= {};

    # set new values
    my $DFParam = {
        $Param{GetParam}{DynamicField}->%*,
        $DynFieldStates{NewValues}->%*,
    };

    if ( IsHashRefWithData( $DynFieldStates{Visibility} ) ) {
        push @JSONCollector, {
            Name => 'Restrictions_Visibility',
            Data => $DynFieldStates{Visibility},
        };
    }

    DYNAMICFIELD:
    for my $Name ( keys $DynFieldStates{Fields}->%* ) {
        my $DynamicFieldConfig = $Self->{DynamicField}{$Name};

        next DYNAMICFIELD if !IsHashRefWithData($DynamicFieldConfig);

        if ( $DynamicFieldConfig->{Config}{MultiValue} && ref $DFParam->{"DynamicField_$DynamicFieldConfig->{Name}"} eq 'ARRAY' ) {
            for my $i ( 0 .. $#{ $DFParam->{"DynamicField_$DynamicFieldConfig->{Name}"} } ) {
                my $DataValues = $DynFieldStates{Fields}{$Name}{NotACLReducible}
                    ? ( $DFParam->{"DynamicField_$DynamicFieldConfig->{Name}"}[$i] // '' )
                    :
                    (
                        $DynamicFieldBackendObject->BuildSelectionDataGet(
                            DynamicFieldConfig => $DynamicFieldConfig,
                            PossibleValues     => $DynFieldStates{Fields}{$Name}{PossibleValues},
                            Value              => [ $DFParam->{"DynamicField_$DynamicFieldConfig->{Name}"}[$i] ],
                        )
                        || $DynFieldStates{Fields}{$Name}{PossibleValues}
                    );

                # add dynamic field to the list of fields to update
                push @JSONCollector, {
                    Name        => 'DynamicField_' . $DynamicFieldConfig->{Name} . "_$i",
                    Data        => $DataValues,
                    SelectedID  => $DFParam->{"DynamicField_$DynamicFieldConfig->{Name}"}[$i],
                    Translation => $DynamicFieldConfig->{Config}{TranslatableValues} || 0,
                    Max         => 100,
                };
            }

            # add template value for keeping templates in line with ACLs
            if ( !$DynFieldStates{Fields}{$Name}{NotACLReducible} ) {
                my $DataValues = (
                    $DynamicFieldBackendObject->BuildSelectionDataGet(
                        DynamicFieldConfig => $DynamicFieldConfig,
                        PossibleValues     => $DynFieldStates{Fields}{$Name}{PossibleValues},
                        Value              => [ $DynamicFieldConfig->{Config}{DefaultValue} // '' ],
                        )
                        || $DynFieldStates{Fields}{$Name}{PossibleValues}
                );

                # add dynamic field to the list of fields to update
                push @JSONCollector, {
                    Name        => 'DynamicField_' . $DynamicFieldConfig->{Name} . "_Template",
                    Data        => $DataValues,
                    SelectedID  => $DynamicFieldConfig->{Config}{DefaultValue} // '',
                    Translation => $DynamicFieldConfig->{Config}{TranslatableValues} || 0,
                    Max         => 100,
                };
            }

            next DYNAMICFIELD;
        }

        my $DataValues = $DynFieldStates{Fields}{$Name}{NotACLReducible}
            ? ( $DFParam->{"DynamicField_$DynamicFieldConfig->{Name}"} // '' )
            :
            (
                $DynamicFieldBackendObject->BuildSelectionDataGet(
                    DynamicFieldConfig => $DynamicFieldConfig,
                    PossibleValues     => $DynFieldStates{Fields}{$Name}{PossibleValues},
                    Value              => $DFParam->{"DynamicField_$DynamicFieldConfig->{Name}"},
                )
                || $DynFieldStates{Fields}{$Name}{PossibleValues}
            );

        # add dynamic field to the list of fields to update
        push @JSONCollector, {
            Name        => 'DynamicField_' . $DynamicFieldConfig->{Name},
            Data        => $DataValues,
            SelectedID  => $DFParam->{"DynamicField_$DynamicFieldConfig->{Name}"},
            Translation => $DynamicFieldConfig->{Config}{TranslatableValues} || 0,
            Max         => 100,
        };
    }

    for my $SetField ( values $DynFieldStates{Sets}->%* ) {
        my $DynamicFieldConfig = $SetField->{DynamicFieldConfig};

        # the frontend name is the name of the inner field including its index or the '_Template' suffix
        DYNAMICFIELD:
        for my $FrontendName ( keys $SetField->{FieldStates}->%* ) {

            if ( $DynamicFieldConfig->{Config}{MultiValue} && ref $SetField->{Values}{$FrontendName} eq 'ARRAY' ) {
                for my $i ( 0 .. $#{ $SetField->{Values}{$FrontendName} } ) {
                    my $DataValues = $SetField->{FieldStates}{$FrontendName}{NotACLReducible}
                        ? ( $SetField->{Values}{$FrontendName}[$i] // '' )
                        :
                        (
                            $DynamicFieldBackendObject->BuildSelectionDataGet(
                                DynamicFieldConfig => $DynamicFieldConfig,
                                PossibleValues     => $SetField->{FieldStates}{$FrontendName}{PossibleValues},
                                Value              => [ $SetField->{Values}{$FrontendName}[$i] ],
                            )
                            || $SetField->{FieldStates}{$FrontendName}{PossibleValues}
                        );

                    # add dynamic field to the list of fields to update
                    push @JSONCollector, {
                        Name        => 'DynamicField_' . $FrontendName . "_$i",
                        Data        => $DataValues,
                        SelectedID  => $SetField->{Values}{$FrontendName}[$i],
                        Translation => $DynamicFieldConfig->{Config}{TranslatableValues} || 0,
                        Max         => 100,
                    };
                }

                # add template value for keeping templates in line with ACLs
                if ( !$SetField->{FieldStates}{$FrontendName}{NotACLReducible} ) {
                    my $DataValues = (
                        $DynamicFieldBackendObject->BuildSelectionDataGet(
                            DynamicFieldConfig => $DynamicFieldConfig,
                            PossibleValues     => $SetField->{FieldStates}{$FrontendName}{PossibleValues},
                            Value              => [ $DynamicFieldConfig->{Config}{DefaultValue} // '' ],
                            )
                            || $SetField->{FieldStates}{$FrontendName}{PossibleValues}
                    );

                    # add dynamic field to the list of fields to update
                    push @JSONCollector, {
                        Name        => 'DynamicField_' . $FrontendName . "_Template",
                        Data        => $DataValues,
                        SelectedID  => $DynamicFieldConfig->{Config}{DefaultValue} // '',
                        Translation => $DynamicFieldConfig->{Config}{TranslatableValues} || 0,
                        Max         => 100,
                    };
                }

                next DYNAMICFIELD;
            }

            my $DataValues = $SetField->{FieldStates}{$FrontendName}{NotACLReducible}
                ? ( $SetField->{Values}{$FrontendName} // '' )
                :
                (
                    $DynamicFieldBackendObject->BuildSelectionDataGet(
                        DynamicFieldConfig => $DynamicFieldConfig,
                        PossibleValues     => $SetField->{FieldStates}{$FrontendName}{PossibleValues},
                        Value              => $SetField->{Values}{$FrontendName},
                    )
                    || $SetField->{FieldStates}{$FrontendName}{PossibleValues}
                );

            # add dynamic field to the list of fields to update
            push @JSONCollector, {
                Name        => 'DynamicField_' . $FrontendName,
                Data        => $DataValues,
                SelectedID  => $SetField->{Values}{$FrontendName},
                Translation => $DynamicFieldConfig->{Config}{TranslatableValues} || 0,
                Max         => 100,
            };
        }
    }

# Rother OSS / ProcessTicketTemplates
    # update ticket body and attachements if needed.
    if ( $ActivateStandardTemplates && $ChangedElements{StandardTemplateID} ) {
        my @TicketAttachments;
        my $TemplateText;

        my $UploadCacheObject = $Kernel::OM->Get('Kernel::System::Web::UploadCache');

        # remove all attachments from the Upload cache
        my $RemoveSuccess = $UploadCacheObject->FormIDRemove(
            FormID => $Self->{FormID},
        );
        if ( !$RemoveSuccess ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Form attachments could not be deleted!",
            );
        }

        # get the template text and set new attachments if a template is selected
        if ( IsPositiveInteger( $Param{GetParam}{StandardTemplateID} ) ) {
            my $TemplateGenerator = $Kernel::OM->Get('Kernel::System::TemplateGenerator');

            # set template text, replace smart tags
            $TemplateText = $TemplateGenerator->Template(
                TemplateID     => $Param{GetParam}{StandardTemplateID},
                UserID         => $Self->{UserID},
                TicketID       => $Param{GetParam}{TicketID},
                CustomerUserID => $Param{GetParam}{CustomerUserID} || '',
            );

            # create StdAttachmentObject
            my $StdAttachmentObject = $Kernel::OM->Get('Kernel::System::StdAttachment');

            # add std. attachments to ticket
            my %AllStdAttachments = $StdAttachmentObject->StdAttachmentStandardTemplateMemberList(
                StandardTemplateID => $Param{GetParam}{StandardTemplateID},
            );
            for ( sort keys %AllStdAttachments ) {
                my %AttachmentsData = $StdAttachmentObject->StdAttachmentGet( ID => $_ );
                $UploadCacheObject->FormIDAddFile(
                    FormID      => $Self->{FormID},
                    Disposition => 'attachment',
                    %AttachmentsData,
                );
            }

            # send a list of attachments in the upload cache back to the clientside JavaScript
            # which renders then the list of currently uploaded attachments
            @TicketAttachments = $UploadCacheObject->FormIDGetAllFilesMeta(
                FormID => $Self->{FormID},
            );

            for my $Attachment (@TicketAttachments) {
                $Attachment->{Filesize} = $LayoutObject->HumanReadableDataSize(
                    Size => $Attachment->{Filesize},
                );
            }
        }

        push @JSONCollector, (
            {
                Name => 'UseTemplateProcessDialog',
                Data => '0',
            },
            {
                Name => 'RichText',
                Data => $TemplateText || '',
            },
            {
                Name     => 'TicketAttachments',
                Data     => \@TicketAttachments,
                KeepData => 1,
            },
        );
    }

# EO ProcessTicketTemplates
    my $JSON = $LayoutObject->BuildSelectionJSON( [@JSONCollector] );

    return $LayoutObject->Attachment(
        ContentType => 'application/json',
        Content     => $JSON,
        Type        => 'inline',
        NoCache     => 1,
    );
}

# =cut
#
# _GetParam()
#
# returns the current data state of the submitted information
#
# This contains the following data for the different callers:
#
#     Initial call with selected Process:
#         ProcessEntityID
#         ActivityDialogEntityID
#         DefaultValues for the configured Fields in that ActivityDialog
#         DefaultValues for the 4 required Fields Queue State Lock Priority
#
#     First Store call submitting an Activity Dialog:
#         ProcessEntityID
#         ActivityDialogEntityID
#         SubmittedValues for the current ActivityDialog
#         ActivityDialog DefaultValues for invisible fields of that ActivityDialog
#         DefaultValues for the 4 required Fields Queue State Lock Priority
#             if not configured in the ActivityDialog
#
#     ActivityDialog fillout request on existing Ticket:
#         ProcessEntityID
#         ActivityDialogEntityID
#         TicketValues
#
#     ActivityDialog store request or AjaxUpdate request on existing Tickets:
#         ProcessEntityID
#         ActivityDialogEntityID
#         TicketValues for all not-Submitted Values
#         Submitted Values
#
#     my $GetParam = _GetParam(
#         ProcessEntityID => $ProcessEntityID,
#     );
#
# =cut

sub _GetParam {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(ProcessEntityID)) {
        if ( !$Param{$Needed} ) {
            $LayoutObject->FatalError(
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_GetParam' ),
            );
        }
    }

    # get param object
    my $ParamObject = $Kernel::OM->Get('Kernel::System::Web::Request');

    my %GetParam;
    my %Ticket;
    my $ProcessEntityID        = $Param{ProcessEntityID};
    my $TicketID               = $ParamObject->GetParam( Param => 'TicketID' );
    my $ActivityDialogEntityID = $ParamObject->GetParam(
        Param => 'ActivityDialogEntityID',
    );
    my $ActivityEntityID;
    my %ValuesGotten;
    my $Value;

    # get activity dialog object
    my $ActivityDialogObject = $Kernel::OM->Get('Kernel::System::ProcessManagement::ActivityDialog');

    # create process object
    $Kernel::OM->ObjectParamAdd(
        'Kernel::System::ProcessManagement::Process' => {
            ActivityObject         => $Kernel::OM->Get('Kernel::System::ProcessManagement::Activity'),
            ActivityDialogObject   => $ActivityDialogObject,
            TransitionObject       => $Kernel::OM->Get('Kernel::System::ProcessManagement::Transition'),
            TransitionActionObject => $Kernel::OM->Get('Kernel::System::ProcessManagement::TransitionAction'),
        }
    );
    my $ProcessObject = $Kernel::OM->Get('Kernel::System::ProcessManagement::Process');

    # If we got no ActivityDialogEntityID and no TicketID
    # we have to get the Processes' Startpoint
    if ( !$ActivityDialogEntityID && ( !$TicketID || $Self->{IsProcessEnroll} ) ) {
        my $ActivityActivityDialog = $ProcessObject->ProcessStartpointGet(
            ProcessEntityID => $ProcessEntityID,
        );
        if (
            !$ActivityActivityDialog->{ActivityDialog}
            || !$ActivityActivityDialog->{Activity}
            )
        {
            my $Message = $LayoutObject->{LanguageObject}->Translate(
                'Got no Start ActivityEntityID or Start ActivityDialogEntityID for Process: %s in _GetParam!',
                $ProcessEntityID,
            );

            # does not show header and footer again
            if ( $Self->{IsMainWindow} ) {
                return $LayoutObject->Error(
                    Message => $Message,
                );
            }

            $LayoutObject->FatalError(
                Message => $Message,
            );
        }
        $ActivityDialogEntityID = $ActivityActivityDialog->{ActivityDialog};
        $ActivityEntityID       = $ActivityActivityDialog->{Activity};
    }

    my $ActivityDialog = $ActivityDialogObject->ActivityDialogGet(
        ActivityDialogEntityID => $ActivityDialogEntityID,
        Interface              => 'AgentInterface',
    );

    if ( !IsHashRefWithData($ActivityDialog) ) {
        return $LayoutObject->ErrorScreen(
            Message => $LayoutObject->{LanguageObject}->Translate(
                'Couldn\'t get ActivityDialogEntityID "%s"!',
                $ActivityDialogEntityID,
            ),
            Comment => Translatable('Please contact the administrator.'),
        );
    }

    # get config object
    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');

    # if there is a ticket then is not an AJAX request
    if ($TicketID) {
        %Ticket = $Kernel::OM->Get('Kernel::System::Ticket')->TicketGet(
            TicketID      => $TicketID,
            UserID        => $Self->{UserID},
            DynamicFields => 1,
        );

        %GetParam = %Ticket;
        if ( !IsHashRefWithData( \%GetParam ) ) {
            $LayoutObject->FatalError(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'Couldn\'t get Ticket for TicketID: %s in _GetParam!',
                    $TicketID,
                ),
            );
        }

        if ( !$Self->{IsProcessEnroll} ) {
            $ActivityEntityID = $Ticket{
                'DynamicField_'
                    . $ConfigObject->Get("Process::DynamicFieldProcessManagementActivityID")
            };
            if ( !$ActivityEntityID ) {
                $LayoutObject->FatalError(
                    Message => Translatable(
                        'Couldn\'t determine ActivityEntityID. DynamicField or Config isn\'t set properly!'
                    ),
                );
            }
        }

    }
    $GetParam{ActivityDialogEntityID} = $ActivityDialogEntityID;
    $GetParam{ActivityEntityID}       = $ActivityEntityID // $ParamObject->GetParam( Param => 'ActivityEntityID' );
    $GetParam{ProcessEntityID}        = $ProcessEntityID;

    # Get the activitydialogs's Submit Param's or Config Params
    DIALOGFIELD:
    for my $CurrentField ( @{ $ActivityDialog->{FieldOrder} } ) {

        # Skip if we're working on a field that was already done with or without ID
        if ( $Self->{NameToID}{$CurrentField} && $ValuesGotten{ $Self->{NameToID}{$CurrentField} } )
        {
            next DIALOGFIELD;
        }

        # handle dynamic fields separately
        next DIALOGFIELD if $CurrentField =~ m{^DynamicField_(.*)}xms;

        # get article fields
        if ( $CurrentField eq 'Article' ) {

            $GetParam{Subject} = $ParamObject->GetParam( Param => 'Subject' );
            $GetParam{Body}    = $ParamObject->GetParam( Param => 'Body' );
# Rother OSS / ProcessTicketTemplates
            $GetParam{StandardTemplateID} = $ParamObject->GetParam( Param => 'StandardTemplateID' );
# EO ProcessTicketTemplates
            @{ $GetParam{InformUserID} } = $ParamObject->GetArray(
                Param => 'InformUserID',
            );

            $ValuesGotten{Article} = 1 if ( $GetParam{Subject} && $GetParam{Body} );

            $GetParam{TimeUnits} = $ParamObject->GetParam( Param => 'TimeUnits' );
        }

        if ( $CurrentField eq 'CustomerID' ) {
            $GetParam{Customer} = $ParamObject->GetParam(
                Param => 'SelectedCustomerUser',
            ) || '';
            $GetParam{CustomerUserID} = $ParamObject->GetParam(
                Param => 'SelectedCustomerUser',
            ) || '';
        }

        if ( $CurrentField eq 'PendingTime' ) {
            my $Prefix = 'PendingTime';

            # Ok, we need to try to find the target state now
            my %StateData;

            # get state object
            my $StateObject = $Kernel::OM->Get('Kernel::System::State');

            # Was something submitted from the GUI?
            my $TargetStateID = $ParamObject->GetParam( Param => 'StateID' );
            if ($TargetStateID) {
                %StateData = $StateObject->StateGet(
                    ID => $TargetStateID,
                );
            }

            # Fallback 1: default value of dialog field State
            if ( !%StateData && $ActivityDialog->{Fields}{State}{DefaultValue} ) {
                %StateData = $StateObject->StateGet(
                    Name => $ActivityDialog->{Fields}{State}{DefaultValue},
                );
            }

            # Fallback 2: default value of dialog field StateID
            if ( !%StateData && $ActivityDialog->{Fields}{StateID}{DefaultValue} ) {
                %StateData = $StateObject->StateGet(
                    ID => $ActivityDialog->{Fields}{StateID}{DefaultValue},
                );
            }

            # Fallback 3: existing ticket state
            if ( !%StateData && %Ticket ) {
                %StateData = $StateObject->StateGet(
                    ID => $Ticket{StateID},
                );
            }

            # get pending time values
            # depends on StateType containing '^pending'
            if (
                IsHashRefWithData( \%StateData )
                && $StateData{TypeName}
                && $StateData{TypeName} =~ /^pending/i
                )
            {

                # map the GetParam's Date Values to our DateParamHash
                my %DateParam = (
                    Prefix => $Prefix,
                    map {
                        ( $Prefix . $_ )
                            => $ParamObject->GetParam( Param => ( $Prefix . $_ ) )
                    }
                        qw(Year Month Day Hour Minute)
                );

                # if all values are present
                if (
                    defined $DateParam{ $Prefix . 'Year' }
                    && defined $DateParam{ $Prefix . 'Month' }
                    && defined $DateParam{ $Prefix . 'Day' }
                    && defined $DateParam{ $Prefix . 'Hour' }
                    && defined $DateParam{ $Prefix . 'Minute' }
                    )
                {

                    # recalculate time according to the user's timezone
                    %DateParam = $LayoutObject->TransformDateSelection(
                        %DateParam,
                    );

                    # reformat for storing (e.g. take out Prefix)
                    %{ $GetParam{$CurrentField} } = map { $_ => $DateParam{ $Prefix . $_ } } qw(Year Month Day Hour Minute);
                    $ValuesGotten{PendingTime} = 1;
                }
            }
        }

        # Non DynamicFields
        # 1. try to get the required param
        my $Value = $ParamObject->GetParam( Param => $Self->{NameToID}{$CurrentField} );

        if ($Value) {

            # if we have an ID field make sure the value without ID won't be in the
            # %GetParam Hash any more
            # exclude queue from this as we need it for script field evaluation
            if ( $CurrentField eq 'Queue' ) {
                my $Queue = $Kernel::OM->Get('Kernel::System::Queue')->QueueLookup( QueueID => $Value );
                if ($Queue) {
                    $GetParam{$CurrentField} = $Queue;
                }
            }
            elsif ( $Self->{NameToID}{$CurrentField} =~ m{(.*)ID$}xms ) {
                $GetParam{$1} = undef;
            }
            $GetParam{ $Self->{NameToID}{$CurrentField} }     = $Value;
            $ValuesGotten{ $Self->{NameToID}{$CurrentField} } = 1;
            next DIALOGFIELD;
        }

        # If we got ticket params, the GetParam Hash was already filled before the loop
        # and we can next out
        if ( $GetParam{ $Self->{NameToID}{$CurrentField} } ) {
            $ValuesGotten{ $Self->{NameToID}{$CurrentField} } = 1;
            next DIALOGFIELD;
        }

        if ( $CurrentField eq 'Queue' && !$GetParam{ $Self->{NameToID}{$CurrentField} } ) {
            my $UserDefaultQueue = $ConfigObject->Get('Ticket::Frontend::UserDefaultQueue') || '';
            if ($UserDefaultQueue) {
                my $QueueID = $Kernel::OM->Get('Kernel::System::Queue')->QueueLookup( Queue => $UserDefaultQueue );
                if ($QueueID) {
                    $GetParam{$CurrentField}                          = $UserDefaultQueue;
                    $GetParam{ $Self->{NameToID}{$CurrentField} }     = $QueueID;
                    $ValuesGotten{ $Self->{NameToID}{$CurrentField} } = 1;
                    next DIALOGFIELD;
                }
            }
        }

        # if no Submitted nor Ticket Param get ActivityDialog Config's Param
        if ( $CurrentField ne 'CustomerID' ) {
            $Value = $ActivityDialog->{Fields}{$CurrentField}{DefaultValue};
        }
        if ($Value) {
            $ValuesGotten{ $Self->{NameToID}{$CurrentField} } = 1;
            $GetParam{$CurrentField} = $Value;
            next DIALOGFIELD;
        }
    }

    REQUIREDFIELDLOOP:
    for my $CurrentField (qw(Queue State Lock Priority)) {
        $Value = undef;
        if ( !$ValuesGotten{ $Self->{NameToID}{$CurrentField} } ) {
            $Value = $ConfigObject->Get("Process::Default$CurrentField");
            if ( !$Value ) {

                my $Message = $LayoutObject->{LanguageObject}->Translate(
                    'Process::Default%s Config Value missing!',
                    $CurrentField,
                );

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Message,
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Message,
                );
            }
            $GetParam{$CurrentField} = $Value;
            $ValuesGotten{ $Self->{NameToID}{$CurrentField} } = 1;
        }
    }

    my $Dest = $ParamObject->GetParam( Param => 'Dest' ) || '';
    if ($Dest) {

        my @QueueParts = split( /\|\|/, $Dest );

        $GetParam{QueueID} = $QueueParts[0];
        $GetParam{Queue}   = $QueueParts[1];

        $ValuesGotten{QueueID} = 1;
    }

    # get also the IDs for the Required files (if they are not present)
    if ( $GetParam{Queue} && !$GetParam{QueueID} ) {
        $GetParam{QueueID} = $Kernel::OM->Get('Kernel::System::Queue')->QueueLookup( Queue => $GetParam{Queue} );
    }
    if ( $GetParam{State} && !$GetParam{StateID} ) {
        $GetParam{StateID} = $Kernel::OM->Get('Kernel::System::State')->StateLookup( State => $GetParam{State} );
    }
    if ( $GetParam{Lock} && !$GetParam{LockID} ) {
        $GetParam{LockID} = $Kernel::OM->Get('Kernel::System::Lock')->LockLookup( Lock => $GetParam{Lock} );
    }
    if ( $GetParam{Priority} && !$GetParam{PriorityID} ) {
        $GetParam{PriorityID} = $Kernel::OM->Get('Kernel::System::Priority')->PriorityLookup(
            Priority => $GetParam{Priority},
        );
    }

    # and almost finally we'll have the special parameters:
    $GetParam{ResponsibleAll} = $ParamObject->GetParam( Param => 'ResponsibleAll' );
    $GetParam{OwnerAll}       = $ParamObject->GetParam( Param => 'OwnerAll' );
    $GetParam{ElementChanged} = $ParamObject->GetParam( Param => 'ElementChanged' );

    # handle dynamic fields
    $Self->{DynamicField} = {};

    # Parse definition if present
    if ( $ActivityDialog->{InputFieldDefinition} ) {
        my $InputFieldDefinition = $Kernel::OM->Get('Kernel::System::YAML')->Load(
            Data => $ActivityDialog->{InputFieldDefinition},
        );

        my $DynamicFields = $Self->_GetInputDefinitionDynamicFields(
            InputFieldDefinition => $InputFieldDefinition,
        );

        $Self->{DynamicField} = $DynamicFields // {};
    }

    if ( IsHashRefWithData( $ActivityDialog->{Fields} ) ) {
        my $DynamicFieldObject = $Kernel::OM->Get('Kernel::System::DynamicField');

        DFNAME:
        for my $DFName ( map {/^DynamicField_(.+)$/} keys $ActivityDialog->{Fields}->%* ) {
            next DFNAME if $Self->{DynamicField}{$DFName};

            $Self->{DynamicField}{$DFName} = $DynamicFieldObject->DynamicFieldGet(
                Name => $DFName,
            );
        }
    }

    my $DynamicFieldBackendObject = $Kernel::OM->Get('Kernel::System::DynamicField::Backend');

    DYNAMICFIELD:
    for my $DynamicFieldName ( keys $Self->{DynamicField}->%* ) {

        # overwrite dynamic field config default value with activity dialog default value, if present
        if (
            $ActivityDialog->{Fields}{"DynamicField_$DynamicFieldName"}
            && $ActivityDialog->{Fields}{"DynamicField_$DynamicFieldName"}{DefaultValue}
            )
        {
            $Self->{DynamicField}{$DynamicFieldName}{Config}{DefaultValue} = $ActivityDialog->{Fields}{"DynamicField_$DynamicFieldName"}{DefaultValue};
        }

        # Get the Config of the current DynamicField
        my $DynamicFieldConfig = $Self->{DynamicField}{$DynamicFieldName};

        if ( !IsHashRefWithData($DynamicFieldConfig) ) {
            my $Message =
                "DynamicFieldConfig missing for field: $DynamicFieldName, or is not a Ticket Dynamic Field!";

            # log error but does not stop the execution as it could be an old Article
            # DynamicField, see bug#11666
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => $Message,
            );

            next DYNAMICFIELD;
        }

        # Get DynamicField Values
        $GetParam{ 'DynamicField_' . $DynamicFieldName } = $DynamicFieldBackendObject->EditFieldValueGet(
            DynamicFieldConfig => $DynamicFieldConfig,
            ParamObject        => $ParamObject,
            LayoutObject       => $LayoutObject,
        );

        # ACLCompat
        $GetParam{DynamicField}{ 'DynamicField_' . $DynamicFieldName } = $GetParam{ 'DynamicField_' . $DynamicFieldName };
    }

    return \%GetParam;
}

sub _OutputActivityDialog {
    my ( $Self, %Param ) = @_;
    my $TicketID               = $Param{GetParam}{TicketID};
    my $ActivityDialogEntityID = $Param{GetParam}{ActivityDialogEntityID};

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    # Check needed parameters:
    # ProcessEntityID only
    # TicketID ActivityDialogEntityID
    if ( !$Param{ProcessEntityID} || ( !$TicketID && !$ActivityDialogEntityID ) ) {
        my $Message = Translatable('Got no ProcessEntityID or TicketID and ActivityDialogEntityID!');

        # does not show header and footer again
        if ( $Self->{IsMainWindow} ) {
            return $LayoutObject->Error(
                Message => $Message,
            );
        }

        $LayoutObject->FatalError(
            Message => $Message,
        );
    }

    my $ActivityActivityDialog;
    my %Ticket;
    my %Error         = ();
    my %ErrorMessages = ();

    # If we had Errors, we got an Errorhash
    %Error         = %{ $Param{Error} }         if ( IsHashRefWithData( $Param{Error} ) );
    %ErrorMessages = %{ $Param{ErrorMessages} } if ( IsHashRefWithData( $Param{ErrorMessages} ) );

    # get needed objects
    my $ActivityObject       = $Kernel::OM->Get('Kernel::System::ProcessManagement::Activity');
    my $ActivityDialogObject = $Kernel::OM->Get('Kernel::System::ProcessManagement::ActivityDialog');

    # create process object
    $Kernel::OM->ObjectParamAdd(
        'Kernel::System::ProcessManagement::Process' => {
            ActivityObject         => $ActivityObject,
            ActivityDialogObject   => $ActivityDialogObject,
            TransitionObject       => $Kernel::OM->Get('Kernel::System::ProcessManagement::Transition'),
            TransitionActionObject => $Kernel::OM->Get('Kernel::System::ProcessManagement::TransitionAction'),
        }
    );
    my $ProcessObject = $Kernel::OM->Get('Kernel::System::ProcessManagement::Process');
    my $ConfigObject  = $Kernel::OM->Get('Kernel::Config');
    my $TicketObject  = $Kernel::OM->Get('Kernel::System::Ticket');

    # add rich text editor
    if ( $LayoutObject->{BrowserRichText} ) {

        # use height/width defined for this screen
        $Param{RichTextHeight} = $Self->{Config}{RichTextHeight} || 0;
        $Param{RichTextWidth}  = $Self->{Config}{RichTextWidth}  || 0;

        # set up rich text editor
        $LayoutObject->SetRichTextParameters(
            Data => \%Param,
        );
    }

    if ( !$TicketID || $Self->{IsProcessEnroll} ) {
        $ActivityActivityDialog = $ProcessObject->ProcessStartpointGet(
            ProcessEntityID => $Param{ProcessEntityID},
        );

        if ( !IsHashRefWithData($ActivityActivityDialog) ) {
            my $Message = $LayoutObject->{LanguageObject}->Translate(
                'Can\'t get StartActivityDialog and StartActivityDialog for the ProcessEntityID "%s"!',
                $Param{ProcessEntityID},
            );

            # does not show header and footer again
            if ( $Self->{IsMainWindow} ) {
                return $LayoutObject->Error(
                    Message => $Message,
                );
            }

            $LayoutObject->FatalError(
                Message => $Message,
            );
        }
    }
    else {

        # no AJAX update in this part
        %Ticket = $TicketObject->TicketGet(
            TicketID      => $TicketID,
            UserID        => $Self->{UserID},
            DynamicFields => 1,
        );

        if ( !IsHashRefWithData( \%Ticket ) ) {
            $LayoutObject->FatalError(
                Message => $LayoutObject->{LanguageObject}->Translate( 'Can\'t get Ticket "%s"!', $Param{TicketID} ),
            );
        }

        my $DynamicFieldProcessID = 'DynamicField_'
            . $ConfigObject->Get('Process::DynamicFieldProcessManagementProcessID');
        my $DynamicFieldActivityID = 'DynamicField_'
            . $ConfigObject->Get('Process::DynamicFieldProcessManagementActivityID');

        if ( !$Ticket{$DynamicFieldProcessID} || !$Ticket{$DynamicFieldActivityID} ) {
            $LayoutObject->FatalError(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'Can\'t get ProcessEntityID or ActivityEntityID for Ticket "%s"!',
                    $Param{TicketID},
                ),
            );
        }

        $ActivityActivityDialog = {
            Activity       => $Ticket{$DynamicFieldActivityID},
            ActivityDialog => $ActivityDialogEntityID,
        };
    }

    if ( !%Ticket && $Self->{IsProcessEnroll} ) {
        %Ticket = $TicketObject->TicketGet(
            TicketID      => $TicketID,
            UserID        => $Self->{UserID},
            DynamicFields => 1,
        );
    }

    my $Activity = $ActivityObject->ActivityGet(
        Interface        => 'AgentInterface',
        ActivityEntityID => $ActivityActivityDialog->{Activity}
    );
    if ( !$Activity ) {
        my $Message = $LayoutObject->{LanguageObject}->Translate(
            'Can\'t get Activity configuration for ActivityEntityID "%s"!',
            $ActivityActivityDialog->{Activity},
        );

        # does not show header and footer again
        if ( $Self->{IsMainWindow} ) {
            return $LayoutObject->Error(
                Message => $Message,
            );
        }

        $LayoutObject->FatalError(
            Message => $Message,
        );
    }

    my $ActivityDialog = $ActivityDialogObject->ActivityDialogGet(
        ActivityDialogEntityID => $ActivityActivityDialog->{ActivityDialog},
        Interface              => 'AgentInterface',
    );
    if ( !IsHashRefWithData($ActivityDialog) ) {
        my $Message = $LayoutObject->{LanguageObject}->Translate(
            'Can\'t get ActivityDialog configuration for ActivityDialogEntityID "%s"!',
            $ActivityActivityDialog->{ActivityDialog},
        );

        # does not show header and footer again
        if ( $Self->{IsMainWindow} ) {
            return $LayoutObject->Error(
                Message => $Message,
            );
        }

        $LayoutObject->FatalError(
            Message => $Message,
        );
    }

    # grep out Overwrites if defined on the Activity
    my @OverwriteActivityDialogNumber = grep {
        ref $Activity->{ActivityDialog}{$_} eq 'HASH'
            && $Activity->{ActivityDialog}{$_}{ActivityDialogEntityID}
            && $Activity->{ActivityDialog}{$_}{ActivityDialogEntityID} eq
            $ActivityActivityDialog->{ActivityDialog}
            && IsHashRefWithData( $Activity->{ActivityDialog}{$_}{Overwrite} )
    } keys %{ $Activity->{ActivityDialog} };

    # let the Overwrites Overwrite the ActivityDialog's Hash values
    if ( $OverwriteActivityDialogNumber[0] ) {
        %{$ActivityDialog} = (
            %{$ActivityDialog},
            %{ $Activity->{ActivityDialog}{ $OverwriteActivityDialogNumber[0] }{Overwrite} }
        );
    }

    # Add PageHeader, Navbar, Formheader (Process/ActivityDialogHeader)
    my $Output;
    my $MainBoxClass;

    if ( !$Self->{IsMainWindow} && !$Self->{IsProcessEnroll} ) {
        $Output = $LayoutObject->Header(
            Type  => 'Small',
            Value => $Ticket{Number},
        );

        # display given notify messages if this is not an AJAX request
        if ( IsArrayRefWithData( $Param{Notify} ) ) {

            for my $NotifyData ( @{ $Param{Notify} } ) {
                $Output .= $LayoutObject->Notify( %{$NotifyData} );
            }
        }

        $LayoutObject->Block(
            Name => 'Header',
            Data => {
                Name =>
                    $LayoutObject->{LanguageObject}->Translate( $ActivityDialog->{Name} )
                    || '',
            }
        );
    }
    elsif (
        ( $Self->{IsMainWindow} || $Self->{IsProcessEnroll} )
        && IsHashRefWithData( \%Error )
        )
    {

        # display complete header and navigation bar in AJAX dialogs when there is a server error
        #    unless we are in a process enrollment (only when IsMainWindow is active)
        my $Type = $Self->{IsMainWindow} ? '' : 'Small';
        $Output = $LayoutObject->Header(
            Type => $Type,
        );
        if ( $Self->{IsMainWindow} ) {
            $Output .= $LayoutObject->NavigationBar();
        }

        # display original header texts (the process list maybe is not necessary)
        $Output .= $LayoutObject->Output(
            TemplateFile => 'AgentTicketProcess' . $Type,
            Data         => {
                %Param,
                FormID          => $Self->{FormID},
                IsProcessEnroll => $Self->{IsProcessEnroll},
            },
        );

        # set the MainBox class to add correct borders to the screen
        $MainBoxClass = 'MainBox';
    }

    # display process information
    if ( $Self->{IsMainWindow} ) {

        # get process data
        my $Process = $ProcessObject->ProcessGet(
            ProcessEntityID => $Param{ProcessEntityID},
        );

        # output main process information
        $LayoutObject->Block(
            Name => 'ProcessInfoSidebar',
            Data => {
                Process        => $Process->{Name}        || '',
                Activity       => $Activity->{Name}       || '',
                ActivityDialog => $ActivityDialog->{Name} || '',
            },
        );

        # output activity dialog short description (if any)
        if (
            defined $ActivityDialog->{DescriptionShort}
            && $ActivityDialog->{DescriptionShort} ne ''
            )
        {
            $LayoutObject->Block(
                Name => 'ProcessInfoSidebarActivityDialogDesc',
                Data => {
                    ActivityDialogDescription => $ActivityDialog->{DescriptionShort} || '',
                },
            );
        }

        # output long description information if exists
        if (
            defined $ActivityDialog->{DescriptionLong}
            && length $ActivityDialog->{DescriptionLong}
            )
        {
            $LayoutObject->Block(
                Name => 'LongDescriptionSidebar',
                Data => {
                    Description => $ActivityDialog->{DescriptionLong},
                },
            );
        }
    }

    # show descriptions
    if ( $ActivityDialog->{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => 'DescriptionShort',
            Data => {
                DescriptionShort
                    => $LayoutObject->{LanguageObject}->Translate(
                        $ActivityDialog->{DescriptionShort},
                    ),
            },
        );
    }
    if ( $ActivityDialog->{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'DescriptionLong',
            Data => {
                DescriptionLong
                    => $LayoutObject->{LanguageObject}->Translate(
                        $ActivityDialog->{DescriptionLong},
                    ),
            },
        );
    }

    # show close & cancel link if necessary
    if ( !$Self->{IsMainWindow} && !$Self->{IsProcessEnroll} ) {
        if ( $Param{RenderLocked} ) {
            $LayoutObject->Block(
                Name => 'PropertiesLock',
                Data => {
                    %Param,
                    TicketID => $TicketID,
                },
            );
        }
        else {
            $LayoutObject->Block(
                Name => 'CancelLink',
            );
        }

    }

    # explanatory message about asterisk
    if ( $ConfigObject->Get('Ticket::Frontend::AsteriskExplanation') ) {
        $LayoutObject->Block(
            Name => 'AsteriskExplanation',
        );
    }

    $Output .= $LayoutObject->Output(
        TemplateFile => 'ProcessManagement/ActivityDialogHeader',
        Data         => {
            FormName               => 'ActivityDialogDialog' . $ActivityActivityDialog->{ActivityDialog},
            FormID                 => $Self->{FormID},
            Subaction              => 'StoreActivityDialog',
            TicketID               => $Ticket{TicketID} || '',
            LinkTicketID           => $Self->{LinkTicketID},
            ActivityDialogEntityID => $ActivityActivityDialog->{ActivityDialog},
            ActivityEntityID       => $Param{GetParam}{ActivityEntityID}
                || $Ticket{
                    'DynamicField_'
                    . $ConfigObject->Get(
                        'Process::DynamicFieldProcessManagementActivityID'
                    )
                },
            ProcessEntityID => $Param{ProcessEntityID}
                || $Ticket{
                    'DynamicField_'
                    . $ConfigObject->Get(
                        'Process::DynamicFieldProcessManagementProcessID'
                    )
                },
            IsMainWindow    => $Self->{IsMainWindow},
            IsProcessEnroll => $Self->{IsProcessEnroll},
            MainBoxClass    => $MainBoxClass || '',
        },
    );

    my %RenderedFields = ();

    my $InputDefinitionRendered = 0;
    my %DFPossibleValues        = %{ $Param{DFPossibleValues} // {} };
    my %Visibility              = %{ $Param{Visibility}       // {} };

    # if we are rendering a new mask and are not rerendering with errors get ticket and default dynamic field values
    if ( $Self->{Subaction} ne 'StoreActivityDialog' ) {

        my $DynamicFieldBackendObject = $Kernel::OM->Get('Kernel::System::DynamicField::Backend');
        my $NewTicket;

        # get stored dynamic field value (split)
        if ( $Self->{LinkTicketID} ) {

            DYNAMICFIELD:
            for my $DynamicFieldConfig ( values $Self->{DynamicField}->%* ) {
                next DYNAMICFIELD unless IsHashRefWithData($DynamicFieldConfig);

                $Param{GetParam}{ 'DynamicField_' . $DynamicFieldConfig->{Name} } = $DynamicFieldBackendObject->ValueGet(
                    DynamicFieldConfig => $DynamicFieldConfig,
                    ObjectID           => $Self->{LinkTicketID},
                    ProcessSuffix      => $Self->{IDSuffix},
                );
            }
        }

        # we are updating an existing ticket
        elsif (%Ticket) {

            DYNAMICFIELD:
            for my $Name ( keys $Self->{DynamicField}->%* ) {
                $Param{GetParam}{ 'DynamicField_' . $Name } = $Ticket{ 'DynamicField_' . $Name };
            }
        }

        else {
            $NewTicket = 1;
        }

        # retrieve field restrictions for dynamic fields
        my $FieldRestrictionsObject = $Kernel::OM->Get('Kernel::System::Ticket::FieldRestrictions');
        my $ACLPreselection;
        if ( $ConfigObject->Get('TicketACL::ACLPreselection') ) {

            # get cached preselection rules
            my $CacheObject = $Kernel::OM->Get('Kernel::System::Cache');
            $ACLPreselection = $CacheObject->Get(
                Type => 'TicketACL',
                Key  => 'Preselection',
            );
            if ( !$ACLPreselection ) {
                $ACLPreselection = $FieldRestrictionsObject->SetACLPreselectionCache();
            }
        }

        my $Autoselect     = $ConfigObject->Get('TicketACL::Autoselect') || undef;
        my $LoopProtection = 100;

        # get values and visibility of dynamic fields
        my %DynFieldStates = $FieldRestrictionsObject->GetFieldStates(
            TicketObject              => $TicketObject,
            DynamicFields             => $Self->{DynamicField},
            DynamicFieldBackendObject => $DynamicFieldBackendObject,
            Action                    => $Self->{Action},
            ChangedElements           => {},
            UserID                    => $Self->{UserID},
            TicketID                  => $TicketID,
            FormID                    => $Self->{FormID},
            CustomerUser              => $Param{GetParam}{CustomerUserID} || '',
            GetParam                  => $Param{GetParam},
            Autoselect                => $Autoselect,
            ACLPreselection           => $ACLPreselection,
            LoopProtection            => \$LoopProtection,
        );

        %DFPossibleValues = map { $_ => $DynFieldStates{Fields}{$_}{PossibleValues} } keys $Self->{DynamicField}->%*;
        %Visibility       = $DynFieldStates{Visibility}->%*;
    }

    # Parse definition if present
    my $InputFieldDefinition = $Kernel::OM->Get('Kernel::System::YAML')->Load(
        Data => $ActivityDialog->{InputFieldDefinition},
    );
    my %DefinedFieldsList;
    if ( IsArrayRefWithData($InputFieldDefinition) ) {
        for my $Row ( $InputFieldDefinition->@* ) {
            if ( $Row->{DF} ) {
                $DefinedFieldsList{ 'DynamicField_' . $Row->{DF} } = 1;
            }
            if ( $Row->{Grid} ) {
                for my $GridRow ( $Row->{Grid}{Rows}->@* ) {
                    for my $Field ( grep { $_->{DF} } $GridRow->@* ) {
                        $DefinedFieldsList{ 'DynamicField_' . $Field->{DF} } = 1;
                    }
                }
            }
        }
    }

    my %DynamicFieldValues = map { ( 'DynamicField_' . $_ => $Param{GetParam}{ 'DynamicField_' . $_ } ) } keys $Self->{DynamicField}->%*;

    # Loop through ActivityDialogFields and render their output
    DIALOGFIELD:
    for my $CurrentField ( @{ $ActivityDialog->{FieldOrder} } ) {
        if ( !IsHashRefWithData( $ActivityDialog->{Fields}{$CurrentField} ) ) {
            my $Message = $LayoutObject->{LanguageObject}->Translate(
                'Can\'t get data for Field "%s" of ActivityDialog "%s"!',
                $CurrentField,
                $ActivityActivityDialog->{ActivityDialog},
            );

            # does not show header and footer again
            if ( $Self->{IsMainWindow} ) {
                return $LayoutObject->Error(
                    Message => $Message,
                );
            }

            $LayoutObject->FatalError(
                Message => $Message,
            );
        }

        my %FieldData = %{ $ActivityDialog->{Fields}{$CurrentField} };

        # We render just visible ActivityDialogFields
        next DIALOGFIELD if !$FieldData{Display};

        # Handle multicolumn field rendering
        if ( $DefinedFieldsList{$CurrentField} ) {

            next DIALOGFIELD if $InputDefinitionRendered;

            $Output .= $Kernel::OM->Get('Kernel::Output::HTML::DynamicField::Mask')->EditSectionRender(
                Content              => $InputFieldDefinition,
                DynamicFields        => $Self->{DynamicField},
                LayoutObject         => $LayoutObject,
                ParamObject          => $Kernel::OM->Get('Kernel::System::Web::Request'),
                DynamicFieldValues   => \%DynamicFieldValues,
                PossibleValuesFilter => \%DFPossibleValues,
                Errors               => $Param{DFErrors},
                Visibility           => \%Visibility,
                Object               => {
                    CustomerID     => $Param{GetParam}{CustomerID},
                    CustomerUserID => $Param{GetParam}{CustomerUserID},
                    UserID         => $Self->{UserID},
                    %DynamicFieldValues,
                },
            );

            $InputDefinitionRendered = 1;

            next DIALOGFIELD;
        }

        # render DynamicFields
        if ( $CurrentField =~ m{^DynamicField_(.*)}xms ) {
            my $DynamicFieldName = $1;
            my $Response         = $Self->_RenderDynamicField(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $DynamicFieldName,
                Value               => $Param{GetParam}{ 'DynamicField_' . $DynamicFieldName },
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket        || {},
                Error               => \%Error         || {},
                ErrorMessages       => \%ErrorMessages || {},
                FormID              => $Self->{FormID},
                PossibleValues      => $DFPossibleValues{$DynamicFieldName},
                Visibility          => $Visibility{ 'DynamicField_' . $DynamicFieldName } // 0,
                Object              => {
                    CustomerID     => $Param{GetParam}{CustomerID},
                    CustomerUserID => $Param{GetParam}{CustomerUserID},
                    UserID         => $Self->{UserID},
                    %DynamicFieldValues,
                },
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{$CurrentField} = 1;
        }

        # render State
        elsif ( $Self->{NameToID}{$CurrentField} eq 'StateID' )
        {

            # We don't render Fields twice,
            # if there was already a Config without ID, skip this field
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderState(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{ $Self->{NameToID}{$CurrentField} } = 1;
        }

        # render Queue
        elsif ( $Self->{NameToID}{$CurrentField} eq 'QueueID' )
        {
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderQueue(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{ $Self->{NameToID}{$CurrentField} } = 1;
        }

        # render Priority
        elsif ( $Self->{NameToID}{$CurrentField} eq 'PriorityID' )
        {
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderPriority(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{ $Self->{NameToID}{$CurrentField} } = 1;
        }

        # render Lock
        elsif ( $Self->{NameToID}{$CurrentField} eq 'LockID' ) {
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderLock(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{ $Self->{NameToID}{$CurrentField} } = 1;
        }

        # render Service
        elsif ( $Self->{NameToID}{$CurrentField} eq 'ServiceID' ) {
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderService(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{$CurrentField} = 1;
        }

        # render SLA
        elsif ( $Self->{NameToID}{$CurrentField} eq 'SLAID' ) {
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderSLA(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{ $Self->{NameToID}{$CurrentField} } = 1;
        }

        # render Owner
        elsif ( $Self->{NameToID}{$CurrentField} eq 'OwnerID' ) {
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderOwner(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{ $Self->{NameToID}{$CurrentField} } = 1;
        }

        # render responsible
        elsif ( $Self->{NameToID}{$CurrentField} eq 'ResponsibleID' ) {
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderResponsible(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{ $Self->{NameToID}{$CurrentField} } = 1;
        }

        # render CustomerID
        elsif ( $Self->{NameToID}{$CurrentField} eq 'CustomerID' ) {
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderCustomer(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{ $Self->{NameToID}{$CurrentField} } = 1;
        }

        elsif ( $CurrentField eq 'PendingTime' ) {

            # PendingTime is just useful if we have State or StateID
            if ( none {m{^(StateID|State)$}xms} @{ $ActivityDialog->{FieldOrder} } ) {
                my $Message = $LayoutObject->{LanguageObject}->Translate(
                    'PendingTime can just be used if State or StateID is configured for the same ActivityDialog. ActivityDialog: %s!',
                    $ActivityActivityDialog->{ActivityDialog},
                );

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Message,
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Message,
                );
            }

            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderPendingTime(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{ $Self->{NameToID}{$CurrentField} } = 1;
        }

        # render Title
        elsif ( $Self->{NameToID}{$CurrentField} eq 'Title' ) {
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderTitle(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{$CurrentField} = 1;
        }

        # render Article
        elsif ( $Self->{NameToID}{$CurrentField} eq 'Article' ) {
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

# Rother OSS / ProcessTicketTemplates
            my $StandardTemplates = $Self->_GetStandardTemplates( $Param{GetParam}->%* );

# EO ProcessTicketTemplates
            my $Response = $Self->_RenderArticle(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
                InformAgents        => $ActivityDialog->{Fields}{Article}{Config}{InformAgents},
# Rother OSS / ProcessTicketTemplates
                StandardTemplates => $StandardTemplates,
# EO ProcessTicketTemplates
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{$CurrentField} = 1;
        }

        # render Type
        elsif ( $Self->{NameToID}{$CurrentField} eq 'TypeID' ) {

            # We don't render Fields twice,
            # if there was already a Config without ID, skip this field
            next DIALOGFIELD if $RenderedFields{ $Self->{NameToID}{$CurrentField} };

            my $Response = $Self->_RenderType(
                ActivityDialogField => $ActivityDialog->{Fields}{$CurrentField},
                FieldName           => $CurrentField,
                DescriptionShort    => $ActivityDialog->{Fields}{$CurrentField}{DescriptionShort},
                DescriptionLong     => $ActivityDialog->{Fields}{$CurrentField}{DescriptionLong},
                Ticket              => \%Ticket || {},
                Error               => \%Error  || {},
                FormID              => $Self->{FormID},
                GetParam            => $Param{GetParam},
            );

            if ( !$Response->{Success} ) {

                # does not show header and footer again
                if ( $Self->{IsMainWindow} ) {
                    return $LayoutObject->Error(
                        Message => $Response->{Message},
                    );
                }

                $LayoutObject->FatalError(
                    Message => $Response->{Message},
                );
            }

            $Output .= $Response->{HTML};

            $RenderedFields{ $Self->{NameToID}{$CurrentField} } = 1;
        }
    }

    my $FooterCSSClass = 'Footer';

    if ( $Self->{IsAjaxRequest} ) {

        # Due to the initial loading of
        # the first ActivityDialog after Process selection
        # we have to bind the AjaxUpdate Function on
        # the selects, so we get the complete JSOnDocumentComplete code
        # and deliver it in the FooterJS block.
        # This Javascript Part is executed in
        # AgentTicketProcess.tt
        $LayoutObject->Block(
            Name => 'FooterJS',
        );

        $FooterCSSClass = 'Centered';
    }

    # set submit button data
    my $ButtonText  = 'Submit';
    my $ButtonTitle = 'Save';
    my $ButtonID    = 'Submit' . $ActivityActivityDialog->{ActivityDialog};
    if ( $ActivityDialog->{SubmitButtonText} ) {
        $ButtonText  = $ActivityDialog->{SubmitButtonText};
        $ButtonTitle = $ActivityDialog->{SubmitButtonText};
    }

    $LayoutObject->Block(
        Name => 'Footer',
        Data => {
            FooterCSSClass => $FooterCSSClass,
            ButtonText     => $ButtonText,
            ButtonTitle    => $ButtonTitle,
            ButtonID       => $ButtonID
        },
    );

    if ( $ActivityDialog->{SubmitAdviceText} ) {
        $LayoutObject->Block(
            Name => 'SubmitAdviceText',
            Data => {
                AdviceText => $ActivityDialog->{SubmitAdviceText},
            },
        );
    }

    # reload parent window
    if ( $Param{ParentReload} ) {
        $LayoutObject->AddJSData(
            Key   => 'ParentReload',
            Value => 1,
        );
    }

    # Add the FormFooter
    $Output .= $LayoutObject->Output(
        TemplateFile => 'ProcessManagement/ActivityDialogFooter',
        Data         => {},
    );

    # display regular footer only in non-ajax case
    if ( !$Self->{IsAjaxRequest} ) {
        $Output .= $LayoutObject->Footer( Type => $Self->{IsMainWindow} ? '' : 'Small' );
    }

    return $Output;
}

sub _RenderPendingTime {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderPendingTime' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderPendingTime' ),
        };
    }

    my %Data = (
        Label => (
            $LayoutObject->{LanguageObject}->Translate('Pending Date')
                . ' ('
                . $LayoutObject->{LanguageObject}->Translate('for pending* states') . ')'
        ),
        FieldID => 'ResponsibleID',
        FormID  => $Param{FormID},
    );

    my $Error = '';
    if ( IsHashRefWithData( $Param{Error} ) ) {
        if ( $Param{Error}{'PendingtTimeDay'} ) {
            $Data{PendingtTimeDayError} = $LayoutObject->{LanguageObject}->Translate("Date invalid!");
            $Error = $Param{Error}{'PendingtTimeDay'};
        }
        if ( $Param{Error}{'PendingtTimeHour'} ) {
            $Data{PendingtTimeHourError} = $LayoutObject->{LanguageObject}->Translate("Date invalid!");
            $Error = $Param{Error}{'PendingtTimeDay'};
        }
    }

    my $Calendar = '';

    # get ticket object
    my $TicketObject = $Kernel::OM->Get('Kernel::System::Ticket');

    # get used calendar if we have ticket data
    if ( IsHashRefWithData( $Param{Ticket} ) ) {
        $Calendar = $TicketObject->TicketCalendarGet(
            %{ $Param{Ticket} },
        );
    }

    my $QuickDateButtons = $Kernel::OM->Get('Kernel::Config')->Get("Ticket::Frontend::$Self->{Action}")->{QuickDateButtons}
        // $Kernel::OM->Get('Kernel::Config')->Get('Ticket::Frontend::DefaultQuickDateButtons');

    $Data{Content} = $LayoutObject->BuildDateSelection(
        Prefix              => 'PendingTime',
        PendingTimeRequired =>
            (
                $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2
            ) ? 1 : 0,
        Format           => 'DateInputFormatLong',
        YearPeriodPast   => 0,
        YearPeriodFuture => 5,
        DiffTime         => $Param{ActivityDialogField}{DefaultValue}
            || $Kernel::OM->Get('Kernel::Config')->Get('Ticket::Frontend::PendingDiffTime')
            || 86400,
        Class                => $Error,
        Validate             => 1,
        ValidateDateInFuture => 1,
        Calendar             => $Calendar,
        QuickDateButtons     => $QuickDateButtons,
    );

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:PendingTime',
        Data => \%Data,
    );
    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:PendingTime:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:PendingTime:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/PendingTime' ),
    };
}

sub _RenderDynamicField {
    my ( $Self, %Param ) = @_;

    # get needed objects
    my $LayoutObject              = $Kernel::OM->Get('Kernel::Output::HTML::Layout');
    my $DynamicFieldBackendObject = $Kernel::OM->Get('Kernel::System::DynamicField::Backend');

    for my $Needed (qw(FormID FieldName)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderDynamicField' ),
            };
        }
    }

    my $DynamicFieldConfig = $Self->{DynamicField}{ $Param{FieldName} };

    if ( !IsHashRefWithData($DynamicFieldConfig) ) {

        my $Message = "DynamicFieldConfig missing for field: $Param{FieldName}, or is not a Ticket Dynamic Field!";

        # log error but does not stop the execution as it could be an old Article
        # DynamicField, see bug#11666
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => $Message,
        );

        return {
            Success => 1,
            HTML    => '',
        };
    }

    my $ServerError;
    if ( IsHashRefWithData( $Param{Error} ) ) {
        if (
            defined $Param{Error}{ $Param{FieldName} }
            && $Param{Error}{ $Param{FieldName} } ne ''
            )
        {
            $ServerError = 1;
        }
    }

    my $ErrorMessage = '';
    if ( IsHashRefWithData( $Param{ErrorMessages} ) ) {
        if (
            defined $Param{ErrorMessages}{ $Param{FieldName} }
            && $Param{ErrorMessages}{ $Param{FieldName} } ne ''
            )
        {
            $ErrorMessage = $Param{ErrorMessages}{ $Param{FieldName} };
        }
    }

    my $DynamicFieldHTML = $DynamicFieldBackendObject->EditFieldRender(
        DynamicFieldConfig   => $DynamicFieldConfig,
        PossibleValuesFilter => $Param{PossibleValues},
        Value                => $Param{Value},
        LayoutObject         => $LayoutObject,
        ParamObject          => $Kernel::OM->Get('Kernel::System::Web::Request'),
        AJAXUpdate           => 1,
        Mandatory            => $Param{ActivityDialogField}{Display} == 2,
        ACLHidden            => ( $Param{ActivityDialogField}{Display} == 2 && !$Param{Visibility} ),
        ServerError          => $ServerError,
        ErrorMessage         => $ErrorMessage,
        Object               => $Param{Object},
    );

    my $FieldClasses = 'Field' . ( $DynamicFieldConfig->{FieldType} eq 'RichText' ? ' RichTextField' : '' );

    my %Data = (
        Name         => $DynamicFieldConfig->{Name},
        Label        => $DynamicFieldHTML->{Label},
        HiddenClass  => !$Param{Visibility} ? ' oooACLHidden' : '',
        FieldClasses => $FieldClasses,
    );

    # handle multivalue field
    if ( $DynamicFieldHTML->{MultiValue} ) {

        $LayoutObject->Block(
            Name => 'Row_DynamicField',
            Data => {
                TemplateColumns => '1fr',
                RowClasses      => ' MultiValue',
                HiddenClass     => !$Param{Visibility} ? ' oooACLHidden' : '',
            },
        );

        # Create one block for each multivalue item
        for my $MultiValueIndex ( 0 .. $#{ $DynamicFieldHTML->{MultiValue} } ) {

            $Data{Content} = $DynamicFieldHTML->{MultiValue}[$MultiValueIndex];
            $LayoutObject->Block(
                Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:DynamicField',
                Data => {
                    %Data,
                    MultiValue => 1,

                    # TODO ask about this
                    # RowReadOnly   => $DynamicFieldConfig->{Readonly},
                    ColumnClasses => ' MultiValue_' . $MultiValueIndex,
                    ColumnStyle   => 'grid-column: 1 / span 1',
                },
            );

            # render short description once for first element
            if ( !$MultiValueIndex ) {
                if ( $Param{DescriptionLong} ) {
                    $LayoutObject->Block(
                        Name => 'rw:DynamicField:DescriptionLong',
                        Data => {
                            DescriptionLong => $Param{DescriptionLong},
                        },
                    );
                }
            }

            # render long description once for last element
            if ( $MultiValueIndex == $#{ $DynamicFieldHTML->{MultiValue} } ) {
                if ( $Param{DescriptionShort} ) {
                    $LayoutObject->Block(
                        Name => $Param{ActivityDialogField}{LayoutBlock}
                            || 'rw:DynamicField:DescriptionShort',
                        Data => {
                            DescriptionShort => $Param{DescriptionShort},
                        },
                    );
                }
            }
        }

        $LayoutObject->Block(
            Name => 'DynamicFieldMultiValueTemplate',
            Data => {
                Content     => $DynamicFieldHTML->{MultiValueTemplate},
                Label       => $DynamicFieldHTML->{Label},
                ColumnStyle => 'grid-column: 1 / span 1',
            },
        );

        # render short description once for first element
        if ( $Param{DescriptionLong} ) {
            $LayoutObject->Block(
                Name => 'rw:DynamicField:DescriptionLongTemplate',
                Data => {
                    DescriptionLong => $Param{DescriptionLong},
                },
            );
        }
    }
    else {
        $Data{Content} = $DynamicFieldHTML->{Field};

        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:DynamicField',
            Data => \%Data,
        );

        if ( $Param{DescriptionShort} ) {
            $LayoutObject->Block(
                Name => $Param{ActivityDialogField}{LayoutBlock}
                    || 'rw:DynamicField:DescriptionShort',
                Data => {
                    DescriptionShort => $Param{DescriptionShort},
                },
            );
        }

        if ( $Param{DescriptionLong} ) {
            $LayoutObject->Block(
                Name => 'rw:DynamicField:DescriptionLong',
                Data => {
                    DescriptionLong => $Param{DescriptionLong},
                },
            );
        }
    }

    my $TemplateFile = 'ProcessManagement/' . ( $DynamicFieldConfig->{Config}{MultiValue} ? 'RowDynamicField' : 'DynamicField' );

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => $TemplateFile ),
    };
}

sub _RenderTitle {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderTitle' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderTitle' ),
        };
    }

    my $Title = $Param{Ticket}{Title} // '';

    if ( !$Title && $Self->{LinkArticleData} ) {
        my %Ticket = $Kernel::OM->Get('Kernel::System::Ticket')->TicketGet(
            TicketID => $Self->{LinkArticleData}{TicketID},
            UserID   => $Self->{UserID},
        );
        $Title = $Ticket{Title};
    }

    $Param{GetParam}{Title} //= $Title;

    my %Data = (
        Label            => $LayoutObject->{LanguageObject}->Translate("Title"),
        FieldID          => 'Title',
        FormID           => $Param{FormID},
        Value            => $Param{GetParam}{Title},
        Name             => 'Title',
        MandatoryClass   => '',
        ValidateRequired => '',
    );

    # If field is required put in the necessary variables for
    # ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }

    # output server errors
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'Title'} ) {
        $Data{ServerError} = 'ServerError';
    }

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Title',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpan',
            Data => {},
        );
    }

    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Title:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Title:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/Title' ),
    };

}

sub _RenderArticle {
    my ( $Self, %Param ) = @_;

    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');
    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');

    for my $Needed (qw(FormID Ticket)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderArticle' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderArticle' ),
        };
    }

    if ( IsHashRefWithData( $Self->{LinkArticleData} ) ) {
        my $TicketObject = $Kernel::OM->Get('Kernel::System::Ticket');
        my $TicketNumber = $TicketObject->TicketNumberLookup(
            TicketID => $Self->{LinkArticleData}{TicketID},
        );

        # prepare subject
        $Param{GetParam}{Subject} = $TicketObject->TicketSubjectClean(
            TicketNumber => $TicketNumber,
            Subject      => $Self->{LinkArticleData}{Subject} || '',
        );

        # body preparation for plain text processing
        $Param{GetParam}{Body} = $LayoutObject->ArticleQuote(
            TicketID           => $Self->{LinkArticleData}{TicketID},
            ArticleID          => $Self->{LinkArticleData}{ArticleID},
            FormID             => $Self->{FormID},
            UploadCacheObject  => $Kernel::OM->Get('Kernel::System::Web::UploadCache'),
            AttachmentsInclude => 1,
        );

        my %SafetyCheckResult = $Kernel::OM->Get('Kernel::System::HTMLUtils')->Safety(
            String => $Param{GetParam}{Body},

            # Strip out external content if BlockLoadingRemoteContent is enabled.
            NoExtSrcLoad => $ConfigObject->Get('Ticket::Frontend::BlockLoadingRemoteContent'),

            # Disallow potentially unsafe content.
            NoApplet     => 1,
            NoObject     => 1,
            NoEmbed      => 1,
            NoSVG        => 1,
            NoJavaScript => 1,
        );
        $Param{GetParam}{Body} = $SafetyCheckResult{String};
    }

    # get all attachments meta data
    my @Attachments = $Kernel::OM->Get('Kernel::System::Web::UploadCache')->FormIDGetAllFilesMeta(
        FormID => $Self->{FormID},
    );

    # show attachments
    ATTACHMENT:
    for my $Attachment (@Attachments) {
        if (
            $Attachment->{ContentID}
            && $LayoutObject->{BrowserRichText}
            && ( $Attachment->{ContentType} =~ /image/i )
            && ( $Attachment->{Disposition} eq 'inline' )
            )
        {
            next ATTACHMENT;
        }

        push @{ $Param{AttachmentList} }, $Attachment;
    }

    my %Data = (
        Name             => 'Article',
        MandatoryClass   => '',
        ValidateRequired => '',
        Subject          => $Param{GetParam}{Subject},
        Body             => $Param{GetParam}{Body},
        LabelSubject     => $Param{ActivityDialogField}{Config}{LabelSubject}
            || $LayoutObject->{LanguageObject}->Translate("Subject"),
        LabelBody => $Param{ActivityDialogField}{Config}{LabelBody}
            || $LayoutObject->{LanguageObject}->Translate("Text"),
        AttachmentList => $Param{AttachmentList},
    );

    # If field is required put in the necessary variables for
    # ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }

    # output server errors
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'ArticleSubject'} ) {
        $Data{SubjectServerError} = 'ServerError';
    }
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'ArticleBody'} ) {
        $Data{BodyServerError} = 'ServerError';
    }

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Article',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpanSubject',
            Data => {},
        );
        $LayoutObject->Block(
            Name => 'LabelSpanBody',
            Data => {},
        );
    }

    # add rich text editor
    if ( $LayoutObject->{BrowserRichText} ) {

        # use height/width defined for this screen
        $Param{RichTextHeight} = $Self->{Config}{RichTextHeight} || 0;
        $Param{RichTextWidth}  = $Self->{Config}{RichTextWidth}  || 0;

        # set up rich text editor
        $LayoutObject->SetRichTextParameters(
            Data => \%Param,
        );
    }

    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => 'rw:Article:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:Article:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

# Rother OSS / ProcessTicketTemplates
    my $ActivateStandardTemplates = defined $Param{ActivityDialogField}{Config}{StandardTemplates} ? $Param{ActivityDialogField}{Config}{StandardTemplates} : 1;
    if ( $ActivateStandardTemplates ) {

        # check if exists create templates regardless the queue
        my $StandardTemplateObject = $Kernel::OM->Get('Kernel::System::StandardTemplate');
        my %StandardTemplates = $StandardTemplateObject->StandardTemplateList(
            Valid => 1,
            Type  => 'ProcessDialog',
        );

        # build text template string
        if ( IsHashRefWithData( \%StandardTemplates ) ) {

            my $SelectedValue;

            my $StandardTemplateIDParam = $Param{GetParam}{StandardTemplateID};
            if ($StandardTemplateIDParam) {
                $SelectedValue = $StandardTemplateObject->StandardTemplateLookup(
                    StandardTemplateID => $StandardTemplateIDParam,
                );
            }

            # set server errors
            my $ServerError = '';
            if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}->{'StandardTemplateID'} ) {
                $ServerError = 'ServerError';
            }

            $Param{StandardTemplateStrg} = $LayoutObject->BuildSelection(
                Data         => $Param{StandardTemplates} || {},
                Name         => 'StandardTemplateID',
                SelectedValue => $SelectedValue,
                Class        => "Modernize $ServerError",
                PossibleNone => 1,
                Sort         => 'AlphanumericValue',
                Translation  => 1,
                Max          => 200,
            );
            $LayoutObject->Block(
                Name => 'StandardTemplate',
                Data => {%Param},
            );
        }
    }

# EO ProcessTicketTemplates
    if ( $Param{InformAgents} ) {

        my %ShownUsers;
        my %AllGroupsMembers = $Kernel::OM->Get('Kernel::System::User')->UserList(
            Type  => 'Long',
            Valid => 1,
        );
        my $GID        = $Kernel::OM->Get('Kernel::System::Queue')->GetQueueGroupID( QueueID => $Param{Ticket}{QueueID} );
        my %MemberList = $Kernel::OM->Get('Kernel::System::Group')->PermissionGroupGet(
            GroupID => $GID,
            Type    => 'ro',
        );
        for my $UserID ( sort keys %MemberList ) {
            $ShownUsers{$UserID} = $AllGroupsMembers{$UserID};
        }
        $Param{OptionStrg} = $LayoutObject->BuildSelection(
            Data       => \%ShownUsers,
            SelectedID => '',
            Name       => 'InformUserID',
            Multiple   => 1,
            Size       => 3,
            Class      => 'Modernize',
        );
        $LayoutObject->Block(
            Name => 'rw:Article:InformAgent',
            Data => \%Param,
        );
    }

    # output server errors
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'TimeUnits'} ) {
        $Param{TimeUnitsInvalid} = 'ServerError';
    }

    # show time units
    if (
        $ConfigObject->Get('Ticket::Frontend::AccountTime')
        && $Param{ActivityDialogField}{Config}{TimeUnits}
        )
    {

        if ( $ConfigObject->Get('Ticket::Frontend::NeedAccountedTime') ) {

            $LayoutObject->Block(
                Name => 'TimeUnitsLabelMandatory',
                Data => \%Param,
            );
            $Param{TimeUnitsRequired} = 'Validate_Required';
        }
        elsif ( $Param{ActivityDialogField}{Config}{TimeUnits} == 1 ) {

            $LayoutObject->Block(
                Name => 'TimeUnitsLabel',
                Data => \%Param,
            );
            $Param{TimeUnitsRequired} = '';
        }
        else {

            $LayoutObject->Block(
                Name => 'TimeUnitsLabelMandatory',
                Data => \%Param,
            );
            $Param{TimeUnitsRequired} = 'Validate_Required';
        }

        # Get TimeUnits value.
        $Param{TimeUnits} = $Param{GetParam}{TimeUnits};

        if ( !defined $Param{TimeUnits} && $Self->{ArticleID} ) {
            $Param{TimeUnits} = $Self->_GetTimeUnits(
                ArticleID => $Self->{ArticleID},
            );
        }

        $LayoutObject->Block(
            Name => 'TimeUnits',
            Data => \%Param,
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/Article' ),
    };
}

sub _GetTimeUnits {
    my ( $Self, %Param ) = @_;

    my $AccountedTime = '';

    # Get accounted time if AccountTime config item is enabled.
    if ( $Kernel::OM->Get('Kernel::Config')->Get('Ticket::Frontend::AccountTime') && defined $Param{ArticleID} ) {
        $AccountedTime = $Kernel::OM->Get('Kernel::System::Ticket::Article')->ArticleAccountedTimeGet(
            ArticleID => $Param{ArticleID},
        );
    }

    return $AccountedTime ? $AccountedTime : '';
}

sub _RenderCustomer {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderCustomer' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderCustomer' ),
        };
    }

    my %CustomerUserData = ();

    my $SubmittedCustomerUserID = $Param{GetParam}{CustomerUserID};

    my %Data = (
        LabelCustomerUser => $LayoutObject->{LanguageObject}->Translate("Customer user"),
        LabelCustomerID   => $LayoutObject->{LanguageObject}->Translate("CustomerID"),
        FormID            => $Param{FormID},
        MandatoryClass    => '',
        ValidateRequired  => '',
    );

    # If field is required put in the necessary variables for
    # ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }

    # output server errors
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{CustomerUserID} ) {
        $Data{CustomerAutoCompleteServerError} = 'ServerError';
    }
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{CustomerID} ) {
        $Data{CustomerIDServerError} = 'ServerError';
    }

    if ( $Self->{LinkTicketData} ) {
        %CustomerUserData = $Kernel::OM->Get('Kernel::System::CustomerUser')->CustomerUserDataGet(
            User => $Self->{LinkTicketData}{CustomerUserID},
        );
    }

    if (
        ( IsHashRefWithData( $Param{Ticket} ) && $Param{Ticket}{CustomerUserID} )
        || $SubmittedCustomerUserID
        )
    {
        %CustomerUserData = $Kernel::OM->Get('Kernel::System::CustomerUser')->CustomerUserDataGet(
            User => $SubmittedCustomerUserID
                || $Param{Ticket}{CustomerUserID},
        );
    }

    # Customer user from article is preselected for new split ticket. See bug#12956.
    if (
        IsHashRefWithData( $Self->{LinkArticleData} )
        && $Self->{LinkArticleData}{From}
        && $Self->{LinkArticleData}{SenderType} eq 'customer'
        )
    {

        my @ArticleFromAddress = Mail::Address->parse( $Self->{LinkArticleData}{From} );

        my $CustomerUserObject = $Kernel::OM->Get('Kernel::System::CustomerUser');
        my %List               = $CustomerUserObject->CustomerSearch(
            PostMasterSearch => $ArticleFromAddress[0]->address(),
            Valid            => 1,
        );

        my @CustomerUser = sort keys %List;
        %CustomerUserData = $CustomerUserObject->CustomerUserDataGet(
            User => $CustomerUser[0],
        );
    }

    # show customer field as "FirstName Lastname" <MailAddress>
    if ( IsHashRefWithData( \%CustomerUserData ) ) {
        $Data{CustomerUserID}       = "\"$CustomerUserData{UserFullname}" . "\" <$CustomerUserData{UserEmail}>";
        $Data{CustomerID}           = $CustomerUserData{UserCustomerID} || '';
        $Data{SelectedCustomerUser} = $CustomerUserData{UserID}         || '';
    }

    # When there is no Customer in the DB, it could be unknown Customer, set it from the ticket.
    # See bug#12797 ( https://bugs.otrs.org/show_bug.cgi?id=12797 ).
    else {
        $Data{CustomerUserID} = $Param{Ticket}{CustomerUserID} || '';
        $Data{CustomerID}     = $Param{Ticket}{CustomerID}     || '';
    }

    if ( $Param{DescriptionShort} ) {
        $Data{DescriptionShort} = $Param{DescriptionShort};
    }

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Customer',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpanCustomerUser',
            Data => {},
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:Customer:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/Customer' ),
    };
}

sub _RenderResponsible {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderResponsible' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderResponsible' ),
        };
    }

    if ( $Self->{LinkTicketData} ) {
        $Param{GetParam}{ResponsibleAll} = 1;
    }

    my $Responsibles = $Self->_GetResponsibles( %{ $Param{GetParam} } );

    my %Data = (
        Label            => $LayoutObject->{LanguageObject}->Translate("Responsible"),
        FieldID          => 'ResponsibleID',
        FormID           => $Param{FormID},
        ResponsibleAll   => $Param{GetParam}{ResponsibleAll},
        MandatoryClass   => '',
        ValidateRequired => '',
    );

    # if field is required put in the necessary variables for
    #    ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }

    my $SelectedValue;

    # get user object
    my $UserObject = $Kernel::OM->Get('Kernel::System::User');

    if ( $Param{ActivityDialogField}{DefaultValue} ) {

        if ( $Param{FieldName} eq 'Responsible' ) {

            # Fetch DefaultValue from Config
            if ( !$SelectedValue ) {
                $SelectedValue = $UserObject->UserLookup(
                    UserLogin => $Param{ActivityDialogField}{DefaultValue} || '',
                );
                if ($SelectedValue) {
                    $SelectedValue = $Param{ActivityDialogField}{DefaultValue};
                }
            }
        }
        else {
            if ( !$SelectedValue ) {
                $SelectedValue = $UserObject->UserLookup(
                    UserID => $Param{ActivityDialogField}{DefaultValue} || '',
                );
            }
        }
    }

    my $ResponsibleIDParam = $Param{GetParam}{ResponsibleID};
    if ( $ResponsibleIDParam && !$SelectedValue ) {
        $SelectedValue = $UserObject->UserLookup( UserID => $ResponsibleIDParam );
    }

    # if there is no user from GetParam or default and the field is mandatory get it from the ticket
    #    (if any)
    if (
        !$SelectedValue
        && $Param{ActivityDialogField}{Display} == 2
        && IsHashRefWithData( $Param{Ticket} )
        )
    {
        $SelectedValue = $Param{Ticket}{Responsible};
    }

    # if we have a user already and the field is not mandatory and it is the same as in ticket, then
    #    set it to none (as it doesn't need to be changed afterall)
    elsif (
        $SelectedValue
        && $Param{ActivityDialogField}{Display} != 2
        && IsHashRefWithData( $Param{Ticket} )
        && $SelectedValue eq $Param{Ticket}{Responsible}
        )
    {
        $SelectedValue = '';
    }

    # set server errors
    my $ServerError = '';
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'ResponsibleID'} ) {
        $ServerError = 'ServerError';
    }

    # look up $SelectedID
    my $SelectedID;
    if ($SelectedValue) {
        $SelectedID = $UserObject->UserLookup(
            UserLogin => $SelectedValue,
        );
    }

    if ( $Self->{LinkTicketData} ) {
        $SelectedID = $Self->{LinkTicketData}{ResponsibleID};
    }

    # build Responsible string
    $Data{Content} = $LayoutObject->BuildSelection(
        Data         => $Responsibles,
        Name         => 'ResponsibleID',
        Translation  => 1,
        SelectedID   => $SelectedID,
        Class        => "Modernize FormUpdate $ServerError",
        PossibleNone => 1,
    );

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Responsible',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpan',
            Data => {},
        );
    }

    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Responsible:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:Responsible:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/Responsible' ),
    };

}

sub _RenderOwner {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderOwner' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderOwner' ),
        };
    }

    if ( $Self->{LinkTicketData} ) {
        $Param{GetParam}{OwnerAll} = 1;
    }

    my $Owners = $Self->_GetOwners( %{ $Param{GetParam} } );

    my %Data = (
        Label            => $LayoutObject->{LanguageObject}->Translate("Owner"),
        FieldID          => 'OwnerID',
        FormID           => $Param{FormID},
        OwnerAll         => $Param{GetParam}{OwnerAll},
        MandatoryClass   => '',
        ValidateRequired => '',
    );

    # if field is required put in the necessary variables for
    #    ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }

    my $SelectedValue;

    # get user object
    my $UserObject = $Kernel::OM->Get('Kernel::System::User');

    if ( $Param{ActivityDialogField}{DefaultValue} ) {

        if ( $Param{FieldName} eq 'Owner' ) {

            if ( !$SelectedValue ) {

                # Fetch DefaultValue from Config
                $SelectedValue = $UserObject->UserLookup(
                    UserLogin => $Param{ActivityDialogField}{DefaultValue} || '',
                );
                if ($SelectedValue) {
                    $SelectedValue = $Param{ActivityDialogField}{DefaultValue};
                }
            }
        }
        else {
            if ( !$SelectedValue ) {
                $SelectedValue = $UserObject->UserLookup(
                    UserID => $Param{ActivityDialogField}{DefaultValue} || '',
                );
            }
        }
    }

    my $OwnerIDParam = $Param{GetParam}{OwnerID};
    if ( $OwnerIDParam && !$SelectedValue ) {
        $SelectedValue = $UserObject->UserLookup(
            UserID => $OwnerIDParam,
        );
    }

    # if there is no user from GetParam or default and the field is mandatory get it from the ticket
    #    (if any)
    if (
        !$SelectedValue
        && $Param{ActivityDialogField}{Display} == 2
        && IsHashRefWithData( $Param{Ticket} )
        )
    {
        $SelectedValue = $Param{Ticket}{Owner};
    }

    # if we have a user already and the field is not mandatory and it is the same as in ticket, then
    #    set it to none (as it doesn't need to be changed afterall)
    elsif (
        $SelectedValue
        && $Param{ActivityDialogField}{Display} != 2
        && IsHashRefWithData( $Param{Ticket} )
        && $SelectedValue eq $Param{Ticket}{Owner}
        )
    {
        $SelectedValue = '';
    }

    # set server errors
    my $ServerError = '';
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'OwnerID'} ) {
        $ServerError = 'ServerError';
    }

    if ( $Self->{LinkTicketData} ) {
        $SelectedValue = $Self->{LinkTicketData}{OwnerID};
    }

    # look up $SelectedID
    my $SelectedID;
    if ($SelectedValue) {
        $SelectedID = $UserObject->UserLookup(
            UserLogin => $SelectedValue,
        );
    }

    # build Owner string
    $Data{Content} = $LayoutObject->BuildSelection(
        Data         => $Owners,
        Name         => 'OwnerID',
        Translation  => 1,
        SelectedID   => $SelectedID || '',
        Class        => "Modernize FormUpdate $ServerError",
        PossibleNone => 1,
    );

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Owner',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpan',
            Data => {},
        );
    }

    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Owner:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:Owner:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/Owner' ),
    };
}

sub _RenderSLA {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderSLA' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderSLA' ),
        };
    }

    if ( $Self->{LinkTicketData} ) {
        $Param{GetParam}{QueueID}        = $Self->{LinkTicketData}{QueueID};
        $Param{GetParam}{TicketID}       = $Self->{LinkTicketData}{TicketID};
        $Param{GetParam}{CustomerUserID} = $Self->{LinkTicketData}{CustomerUserID};
    }

    # create a local copy of the GetParam
    my %GetServicesParam = %{ $Param{GetParam} };

    # use ticket information as a fall back if customer was already set, otherwise when the
    # activity dialog displays the service list will be initially empty, see bug#10059
    if ( IsHashRefWithData( $Param{Ticket} ) ) {
        $GetServicesParam{CustomerUserID} ||= $Param{Ticket}{CustomerUserID} ||= '';
    }

    my $Services = $Self->_GetServices(
        %GetServicesParam,
    );

    if ( $Self->{LinkTicketData} ) {
        $Param{GetParam}{Services}  = $Services;
        $Param{GetParam}{ServiceID} = $Self->{LinkTicketData}{ServiceID};
    }

    my $SLAs = $Self->_GetSLAs(
        %{ $Param{GetParam} },
        Services => $Services,
    );

    my %Data = (
        Label            => $LayoutObject->{LanguageObject}->Translate("SLA"),
        FieldID          => 'SLAID',
        FormID           => $Param{FormID},
        MandatoryClass   => '',
        ValidateRequired => '',
    );

    # If field is required put in the necessary variables for
    # ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }

    my $SelectedValue;

    # get SLA object
    my $SLAObject = $Kernel::OM->Get('Kernel::System::SLA');

    my $SLAIDParam = $Param{GetParam}{SLAID};
    if ($SLAIDParam) {
        $SelectedValue = $SLAObject->SLALookup( SLAID => $SLAIDParam );
    }

    if ( $Param{FieldName} eq 'SLA' ) {

        if ( !$SelectedValue ) {

            # Fetch DefaultValue from Config
            if (
                defined $Param{ActivityDialogField}{DefaultValue}
                && $Param{ActivityDialogField}{DefaultValue} ne ''
                )
            {
                $SelectedValue = $SLAObject->SLALookup(
                    SLA => $Param{ActivityDialogField}{DefaultValue},
                );
            }

            if ($SelectedValue) {
                $SelectedValue = $Param{ActivityDialogField}{DefaultValue};
            }
        }
    }
    else {
        if ( !$SelectedValue ) {
            if (
                defined $Param{ActivityDialogField}{DefaultValue}
                && $Param{ActivityDialogField}{DefaultValue} ne ''
                )
            {
                $SelectedValue = $SLAObject->SLALookup(
                    SLA => $Param{ActivityDialogField}{DefaultValue},
                );
            }
        }
    }

    # Get TicketValue
    if ( IsHashRefWithData( $Param{Ticket} ) && !$SelectedValue ) {
        $SelectedValue = $Param{Ticket}{SLA};
    }

    # set server errors
    my $ServerError = '';
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'SLAID'} ) {
        $ServerError = 'ServerError';
    }

    if ( $Self->{LinkTicketData} ) {
        $SelectedValue = $Self->{LinkTicketData}{SLA};
    }

    # build SLA string
    $Data{Content} = $LayoutObject->BuildSelection(
        Data          => $SLAs,
        Name          => 'SLAID',
        SelectedValue => $SelectedValue,
        PossibleNone  => 1,
        Sort          => 'AlphanumericValue',
        Translation   => 1,
        Class         => "Modernize FormUpdate $ServerError",
        Max           => 200,
    );

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:SLA',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpan',
            Data => {},
        );
    }

    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:SLA:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:SLA:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/SLA' ),
    };
}

sub _RenderService {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderService' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderService' ),
        };
    }

    if ( $Self->{LinkTicketData} ) {
        $Param{GetParam}{QueueID}        = $Self->{LinkTicketData}{QueueID};
        $Param{GetParam}{TicketID}       = $Self->{LinkTicketData}{TicketID};
        $Param{GetParam}{CustomerUserID} = $Self->{LinkTicketData}{CustomerUserID};
    }

    # create a local copy of the GetParam
    my %GetServicesParam = %{ $Param{GetParam} };

    # use ticket information as a fall back if customer was already set, otherwise when the
    # activity dialog displays the service list will be initially empty, see bug#10059
    if ( IsHashRefWithData( $Param{Ticket} ) ) {
        $GetServicesParam{CustomerUserID} ||= $Param{Ticket}{CustomerUserID} ||= '';
    }

    my $Services = $Self->_GetServices(
        %GetServicesParam,
    );

    my %Data = (
        Label            => $LayoutObject->{LanguageObject}->Translate("Service"),
        FieldID          => 'ServiceID',
        FormID           => $Param{FormID},
        MandatoryClass   => '',
        ValidateRequired => '',
    );

    # If field is required put in the necessary variables for
    # ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }

    my $SelectedValue;

    # get service object
    my $ServiceObject = $Kernel::OM->Get('Kernel::System::Service');

    my $ServiceIDParam = $Param{GetParam}{ServiceID};
    if ($ServiceIDParam) {
        $SelectedValue = $ServiceObject->ServiceLookup(
            ServiceID => $ServiceIDParam,
        );
    }

    if ( $Param{FieldName} eq 'Service' ) {

        if ( !$SelectedValue ) {

            # Fetch DefaultValue from Config
            if (
                defined $Param{ActivityDialogField}{DefaultValue}
                && $Param{ActivityDialogField}{DefaultValue} ne ''
                )
            {
                $SelectedValue = $ServiceObject->ServiceLookup(
                    Name => $Param{ActivityDialogField}{DefaultValue},
                );
            }
            if ($SelectedValue) {
                $SelectedValue = $Param{ActivityDialogField}{DefaultValue};
            }
        }
    }
    else {
        if ( !$SelectedValue ) {
            if (
                defined $Param{ActivityDialogField}{DefaultValue}
                && $Param{ActivityDialogField}{DefaultValue} ne ''
                )
            {
                $SelectedValue = $ServiceObject->ServiceLookup(
                    Service => $Param{ActivityDialogField}{DefaultValue},
                );
            }
        }
    }

    # Get TicketValue
    if ( IsHashRefWithData( $Param{Ticket} ) && !$SelectedValue ) {
        $SelectedValue = $Param{Ticket}{Service};
    }

    # set server errors
    my $ServerError = '';
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'ServiceID'} ) {
        $ServerError = 'ServerError';
    }

    # get list type
    my $TreeView = 0;
    if ( $Kernel::OM->Get('Kernel::Config')->Get('Ticket::Frontend::ListType') eq 'tree' ) {
        $TreeView = 1;
    }

    if ( $Self->{LinkTicketData} ) {
        $SelectedValue = $Self->{LinkTicketData}{Service};
    }

    # build Service string
    $Data{Content} = $LayoutObject->BuildSelection(
        Data          => $Services,
        Name          => 'ServiceID',
        Class         => "Modernize FormUpdate $ServerError",
        SelectedValue => $SelectedValue,
        PossibleNone  => 1,
        TreeView      => $TreeView,
        Sort          => 'TreeView',
        Translation   => $TreeView,
        Max           => 200,
    );

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Service',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpan',
            Data => {},
        );
    }

    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Service:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:Service:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/Service' ),
    };

}

sub _RenderLock {

    # for lock states there's no ACL checking yet implemented so no checking...

    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderLock' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderLock' ),
        };
    }

    my $Locks = $Self->_GetLocks(
        %{ $Param{GetParam} },
    );

    my %Data = (
        Label            => $LayoutObject->{LanguageObject}->Translate("Lock state"),
        FieldID          => 'LockID',
        FormID           => $Param{FormID},
        MandatoryClass   => '',
        ValidateRequired => '',
    );

    # If field is required put in the necessary variables for
    # ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }

    my $SelectedValue;

    # get lock object
    my $LockObject = $Kernel::OM->Get('Kernel::System::Lock');

    my $LockIDParam = $Param{GetParam}{LockID};
    $SelectedValue = $LockObject->LockLookup( LockID => $LockIDParam )
        if ($LockIDParam);

    if ( $Param{FieldName} eq 'Lock' ) {

        if ( !$SelectedValue ) {

            # Fetch DefaultValue from Config
            $SelectedValue = $LockObject->LockLookup(
                Lock => $Param{ActivityDialogField}{DefaultValue} || '',
            );
            if ($SelectedValue) {
                $SelectedValue = $Param{ActivityDialogField}{DefaultValue};
            }
        }
    }
    else {
        $SelectedValue = $LockObject->LockLookup(
            LockID => $Param{ActivityDialogField}{DefaultValue} || ''
            )
            if !$SelectedValue;
    }

    # Get TicketValue
    if ( IsHashRefWithData( $Param{Ticket} ) && !$SelectedValue ) {
        $SelectedValue = $Param{Ticket}{Lock};
    }

    # set server errors
    my $ServerError = '';
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'LockID'} ) {
        $ServerError = 'ServerError';
    }

    if ( $Self->{LinkTicketData} ) {
        $SelectedValue = $Self->{LinkTicketData}{Lock};
    }

    # build lock string
    $Data{Content} = $LayoutObject->BuildSelection(
        Data          => $Locks,
        Name          => 'LockID',
        Translation   => 1,
        SelectedValue => $SelectedValue,
        Class         => "Modernize FormUpdate $ServerError",
    );

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Lock',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpan',
            Data => {},
        );
    }

    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Lock:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:Lock:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/Lock' ),
    };
}

sub _RenderPriority {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderPriority' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderPriority' ),
        };
    }

    my $Priorities = $Self->_GetPriorities(
        %{ $Param{GetParam} },
    );

    my %Data = (
        Label            => $LayoutObject->{LanguageObject}->Translate("Priority"),
        FieldID          => 'PriorityID',
        FormID           => $Param{FormID},
        MandatoryClass   => '',
        ValidateRequired => '',
    );

    # If field is required put in the necessary variables for
    # ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }

    my $SelectedValue;

    # get priority object
    my $PriorityObject = $Kernel::OM->Get('Kernel::System::Priority');

    my $PriorityIDParam = $Param{GetParam}{PriorityID};
    if ($PriorityIDParam) {
        $SelectedValue = $PriorityObject->PriorityLookup(
            PriorityID => $PriorityIDParam,
        );
    }

    if ( $Param{FieldName} eq 'Priority' ) {

        if ( !$SelectedValue ) {

            # Fetch DefaultValue from Config
            $SelectedValue = $PriorityObject->PriorityLookup(
                Priority => $Param{ActivityDialogField}{DefaultValue} || '',
            );
            if ($SelectedValue) {
                $SelectedValue = $Param{ActivityDialogField}{DefaultValue};
            }
        }
    }
    else {
        if ( !$SelectedValue ) {
            $SelectedValue = $PriorityObject->PriorityLookup(
                PriorityID => $Param{ActivityDialogField}{DefaultValue} || '',
            );
        }
    }

    # Get TicketValue
    if ( IsHashRefWithData( $Param{Ticket} ) && !$SelectedValue ) {
        $SelectedValue = $Param{Ticket}{Priority};
    }

    # set server errors
    my $ServerError = '';
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'PriorityID'} ) {
        $ServerError = 'ServerError';
    }

    if ( $Self->{LinkTicketData} ) {
        $SelectedValue = $Self->{LinkTicketData}{Priority};
    }

    # build next Priorities string
    $Data{Content} = $LayoutObject->BuildSelection(
        Data          => $Priorities,
        Name          => 'PriorityID',
        Translation   => 1,
        SelectedValue => $SelectedValue,
        Class         => "Modernize FormUpdate $ServerError",
    );

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Priority',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpan',
            Data => {},
        );
    }

    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Priority:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:Priority:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/Priority' ),
    };
}

sub _RenderQueue {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderQueue' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderQueue' ),
        };
    }

    my $Queues = $Self->_GetQueues(
        %{ $Param{GetParam} },
    );

    my %Data = (
        Label            => $LayoutObject->{LanguageObject}->Translate("To queue"),
        FieldID          => 'QueueID',
        FormID           => $Param{FormID},
        MandatoryClass   => '',
        ValidateRequired => '',
    );

    # If field is required put in the necessary variables for
    # ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }
    my $SelectedValue;

    # get queue object
    my $QueueObject = $Kernel::OM->Get('Kernel::System::Queue');

    # if we got QueueID as Param from the GUI
    my $QueueIDParam = $Param{GetParam}{QueueID};
    if ($QueueIDParam) {
        $SelectedValue = $QueueObject->QueueLookup(
            QueueID => $QueueIDParam,
        );
    }

    if ( $Param{FieldName} eq 'Queue' ) {

        if ( !$SelectedValue ) {

            # Fetch DefaultValue from Config
            $SelectedValue = $QueueObject->QueueLookup(
                Queue => $Param{ActivityDialogField}{DefaultValue} || '',
            );
            if ($SelectedValue) {
                $SelectedValue = $Param{ActivityDialogField}{DefaultValue};
            }
        }
    }
    else {
        if ( !$SelectedValue ) {
            $SelectedValue = $QueueObject->QueueLookup(
                QueueID => $Param{ActivityDialogField}{DefaultValue} || '',
            );
        }
    }

    # Get TicketValue
    if ( IsHashRefWithData( $Param{Ticket} ) && !$SelectedValue ) {
        $SelectedValue = $Param{Ticket}{Queue};
    }

    # set server errors
    my $ServerError = '';
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'QueueID'} ) {
        $ServerError = 'ServerError';
    }

    # get list type
    my $TreeView = 0;
    if ( $Kernel::OM->Get('Kernel::Config')->Get('Ticket::Frontend::ListType') eq 'tree' ) {
        $TreeView = 1;
    }

    if ( $Self->{LinkTicketData} ) {
        $SelectedValue = $Self->{LinkTicketData}{Queue};
    }

    # build next queues string
    $Data{Content} = $LayoutObject->BuildSelection(
        Data          => $Queues,
        Name          => 'QueueID',
        Translation   => $TreeView,
        SelectedValue => $SelectedValue,
        Class         => "Modernize FormUpdate $ServerError",
        TreeView      => $TreeView,
        Sort          => 'TreeView',
        PossibleNone  => 1,
    );

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Queue',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpan',
            Data => {},
        );
    }

    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Queue:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:Queue:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/Queue' ),
    };
}

sub _RenderState {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderState' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderState' ),
        };
    }

    my $States = $Self->_GetStates( %{ $Param{GetParam} } );

    my %Data = (
        Label            => $LayoutObject->{LanguageObject}->Translate("Next ticket state"),
        FieldID          => 'StateID',
        FormID           => $Param{FormID},
        MandatoryClass   => '',
        ValidateRequired => '',
    );

    # If field is required put in the necessary variables for
    # ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }
    my $SelectedValue;

    # get state object
    my $StateObject = $Kernel::OM->Get('Kernel::System::State');

    my $StateIDParam = $Param{GetParam}{StateID};
    if ($StateIDParam) {
        $SelectedValue = $StateObject->StateLookup( StateID => $StateIDParam );
    }

    if ( $Param{FieldName} eq 'State' ) {

        if ( !$SelectedValue ) {

            # Fetch DefaultValue from Config
            $SelectedValue = $StateObject->StateLookup(
                State => $Param{ActivityDialogField}{DefaultValue} || '',
            );
            if ($SelectedValue) {
                $SelectedValue = $Param{ActivityDialogField}{DefaultValue};
            }
        }
    }
    else {
        if ( !$SelectedValue ) {
            $SelectedValue = $StateObject->StateLookup(
                StateID => $Param{ActivityDialogField}{DefaultValue} || '',
            );
        }
    }

    # Get TicketValue
    if ( IsHashRefWithData( $Param{Ticket} ) && !$SelectedValue ) {
        $SelectedValue = $Param{Ticket}{State};
    }

    # set server errors
    my $ServerError = '';
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'StateID'} ) {
        $ServerError = 'ServerError';
    }

    # build next states string
    $Data{Content} = $LayoutObject->BuildSelection(
        Data          => $States,
        Name          => 'StateID',
        Translation   => 1,
        SelectedValue => $SelectedValue,
        Class         => "Modernize FormUpdate $ServerError",
    );

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:State',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpan',
            Data => {},
        );
    }

    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:State:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:State:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/State' ),
    };
}

sub _RenderType {
    my ( $Self, %Param ) = @_;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    for my $Needed (qw(FormID)) {
        if ( !$Param{$Needed} ) {
            return {
                Success => 0,
                Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', $Needed, '_RenderType' ),
            };
        }
    }
    if ( !IsHashRefWithData( $Param{ActivityDialogField} ) ) {
        return {
            Success => 0,
            Message => $LayoutObject->{LanguageObject}->Translate( 'Parameter %s is missing in %s.', 'ActivityDialogField', '_RenderType' ),
        };
    }

    my $Types = $Self->_GetTypes(
        %{ $Param{GetParam} },
    );

    my %Data = (
        Label            => $LayoutObject->{LanguageObject}->Translate("Type"),
        FieldID          => 'TypeID',
        FormID           => $Param{FormID},
        MandatoryClass   => '',
        ValidateRequired => '',
    );

    # If field is required put in the necessary variables for
    # ValidateRequired class input field, Mandatory class for the label
    if ( $Param{ActivityDialogField}{Display} && $Param{ActivityDialogField}{Display} == 2 ) {
        $Data{ValidateRequired} = 'Validate_Required';
        $Data{MandatoryClass}   = 'Mandatory';
    }

    my $SelectedValue;

    # get type object
    my $TypeObject = $Kernel::OM->Get('Kernel::System::Type');

    my $TypeIDParam = $Param{GetParam}{TypeID};
    if ($TypeIDParam) {
        $SelectedValue = $TypeObject->TypeLookup(
            TypeID => $TypeIDParam,
        );
    }

    if ( $Param{FieldName} eq 'Type' ) {

        if ( !$SelectedValue ) {

            # Fetch DefaultValue from Config
            if (
                defined $Param{ActivityDialogField}{DefaultValue}
                && $Param{ActivityDialogField}{DefaultValue} ne ''
                )
            {
                $SelectedValue = $TypeObject->TypeLookup(
                    Type => $Param{ActivityDialogField}{DefaultValue},
                );
            }
            if ($SelectedValue) {
                $SelectedValue = $Param{ActivityDialogField}{DefaultValue};
            }
        }
    }
    else {
        if ( !$SelectedValue ) {
            if (
                defined $Param{ActivityDialogField}{DefaultValue}
                && $Param{ActivityDialogField}{DefaultValue} ne ''
                )
            {
                $SelectedValue = $TypeObject->TypeLookup(
                    Type => $Param{ActivityDialogField}{DefaultValue},
                );
            }
        }
    }

    # Get TicketValue
    if ( IsHashRefWithData( $Param{Ticket} ) && !$SelectedValue ) {
        $SelectedValue = $Param{Ticket}{Type};
    }

    # set server errors
    my $ServerError = '';
    if ( IsHashRefWithData( $Param{Error} ) && $Param{Error}{'TypeID'} ) {
        $ServerError = 'ServerError';
    }

    if ( $Self->{LinkTicketData} ) {
        $SelectedValue = $Self->{LinkTicketData}{Type};
    }

    # build Service string
    $Data{Content} = $LayoutObject->BuildSelection(
        Data          => $Types,
        Name          => 'TypeID',
        Class         => "Modernize FormUpdate $ServerError",
        SelectedValue => $SelectedValue,
        PossibleNone  => 1,
        Sort          => 'AlphanumericValue',
        Translation   => 1,
        Max           => 200,
    );

    $LayoutObject->Block(
        Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Type',
        Data => \%Data,
    );

    # set mandatory label marker
    if ( $Data{MandatoryClass} && $Data{MandatoryClass} ne '' ) {
        $LayoutObject->Block(
            Name => 'LabelSpan',
            Data => {},
        );
    }

    if ( $Param{DescriptionShort} ) {
        $LayoutObject->Block(
            Name => $Param{ActivityDialogField}{LayoutBlock} || 'rw:Type:DescriptionShort',
            Data => {
                DescriptionShort => $Param{DescriptionShort},
            },
        );
    }

    if ( $Param{DescriptionLong} ) {
        $LayoutObject->Block(
            Name => 'rw:Type:DescriptionLong',
            Data => {
                DescriptionLong => $Param{DescriptionLong},
            },
        );
    }

    return {
        Success => 1,
        HTML    => $LayoutObject->Output( TemplateFile => 'ProcessManagement/Type' ),
    };
}

sub _StoreActivityDialog {
    my ( $Self, %Param ) = @_;

    my $TicketID = $Param{GetParam}{TicketID};
    my $ProcessStartpoint;
    my %Ticket;
    my $ProcessEntityID;
    my $ActivityEntityID;
    my %Error;
    my %ErrorMessages;

    my %TicketParam;

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    my $ActivityDialogEntityID = $Param{GetParam}{ActivityDialogEntityID};
    if ( !$ActivityDialogEntityID ) {
        $LayoutObject->FatalError(
            Message => Translatable('ActivityDialogEntityID missing!'),
        );
    }

    # get activity dialog object
    my $ActivityDialogObject = $Kernel::OM->Get('Kernel::System::ProcessManagement::ActivityDialog');
    my $ActivityDialog       = $ActivityDialogObject->ActivityDialogGet(
        ActivityDialogEntityID => $ActivityDialogEntityID,
        Interface              => 'AgentInterface',
    );

    if ( !IsHashRefWithData($ActivityDialog) ) {
        $LayoutObject->FatalError(
            Message => $LayoutObject->{LanguageObject}->Translate(
                'Couldn\'t get Config for ActivityDialogEntityID "%s"!',
                $ActivityDialogEntityID,
            ),
        );
    }

    # get param object
    my $ParamObject = $Kernel::OM->Get('Kernel::System::Web::Request');

    # get upload cache object
    my $UploadCacheObject = $Kernel::OM->Get('Kernel::System::Web::UploadCache');

    # check each Field of an Activity Dialog and fill the error hash if something goes horribly wrong
    my %CheckedFields;
    DIALOGFIELD:
    for my $CurrentField ( @{ $ActivityDialog->{FieldOrder} } ) {

        # handle dynamic fields separately
        next DIALOGFIELD if $CurrentField =~ m{^DynamicField_(.*)}xms;

        if (
            $Self->{NameToID}{$CurrentField} eq 'CustomerID'
            || $Self->{NameToID}{$CurrentField} eq 'CustomerUserID'
            )
        {

            next DIALOGFIELD if $CheckedFields{ $Self->{NameToID}{'CustomerID'} };

            # is not possible to a have an invisible field for this particular value
            # on agent interface
            if ( $ActivityDialog->{Fields}{$CurrentField}{Display} == 0 ) {
                $LayoutObject->FatalError(
                    Message => Translatable('Couldn\'t use CustomerID as an invisible field.'),
                    Comment => Translatable('Please contact the administrator.'),
                );
            }

            # CustomerID should not be mandatory as in other screens
            $TicketParam{CustomerID} = $Param{GetParam}{CustomerID} || '';

            # Unfortunately TicketCreate needs 'CustomerUser' as param instead of 'CustomerUserID'
            my $CustomerUserID = $ParamObject->GetParam( Param => 'SelectedCustomerUser' );

            # fall-back, if customer auto-complete does not shown any results, then try to use
            # the content of the original field as customer user id
            if ( !$CustomerUserID ) {

                $CustomerUserID = $ParamObject->GetParam( Param => 'CustomerAutoComplete' );

                # check email address
                for my $Email ( Mail::Address->parse($CustomerUserID) ) {
                    if (
                        !$Kernel::OM->Get('Kernel::System::CheckItem')->CheckEmail( Address => $Email->address() )
                        )
                    {
                        $Error{'CustomerUserID'} = 1;
                    }
                }
            }

            if ( !$CustomerUserID ) {
                $Error{'CustomerUserID'} = 1;
            }
            else {
                $TicketParam{CustomerUser} = $CustomerUserID;
            }
            $CheckedFields{ $Self->{NameToID}{'CustomerID'} }     = 1;
            $CheckedFields{ $Self->{NameToID}{'CustomerUserID'} } = 1;

        }
        elsif ( $CurrentField eq 'PendingTime' ) {

            # Make sure we have Values otherwise take an empty string
            if (
                IsHashRefWithData( $Param{GetParam}{PendingTime} )
                && defined $Param{GetParam}{PendingTime}{Year}
                && defined $Param{GetParam}{PendingTime}{Month}
                && defined $Param{GetParam}{PendingTime}{Day}
                && defined $Param{GetParam}{PendingTime}{Hour}
                && defined $Param{GetParam}{PendingTime}{Minute}
                )
            {
                $TicketParam{$CurrentField} = $Param{GetParam}{PendingTime};
            }

            # if we have no Pending status we have no time to set
            else {
                $TicketParam{$CurrentField} = '';
            }
            $CheckedFields{'PendingTime'} = 1;
        }

        else {

            # skip if we've already checked ID or Name
            next DIALOGFIELD if $CheckedFields{ $Self->{NameToID}{$CurrentField} };

            my $Result = $Self->_CheckField(
                Field => $Self->{NameToID}{$CurrentField},
                %{ $ActivityDialog->{Fields}{$CurrentField} },
            );

            if ( !$Result ) {

                # special case for Article (Subject & Body)
                if ( $CurrentField eq 'Article' ) {
                    for my $ArticlePart (qw(Subject Body)) {
                        if ( !$Param{GetParam}{$ArticlePart} ) {

                            # set error for each part (if any)
                            $Error{ 'Article' . $ArticlePart } = 1;
                        }
                    }
                }

                # all other fields
                elsif ( $ActivityDialog->{Fields}{$CurrentField}{Display} == 2 ) {
                    $Error{ $Self->{NameToID}{$CurrentField} } = 1;
                }
            }

            if (
                $CurrentField eq 'Article'
                && $ActivityDialog->{Fields}{$CurrentField}{Config}{TimeUnits}
                && $ActivityDialog->{Fields}{$CurrentField}{Config}{TimeUnits} == 2
                )
            {
                if ( !defined $Param{GetParam}{TimeUnits} ) {

                    # set error for the time-units (if any)
                    $Error{'TimeUnits'} = 1;
                }
            }

            elsif ($Result) {
                $TicketParam{ $Self->{NameToID}{$CurrentField} } = $Result;
            }
            $CheckedFields{ $Self->{NameToID}{$CurrentField} } = 1;
        }
    }

    # get dynamic field backend object
    my $DynamicFieldBackendObject = $Kernel::OM->Get('Kernel::System::DynamicField::Backend');

    # skip validation of hidden fields
    my %Visibility;

    # transform dynamic field data into DFName => DFName pair
    my %DynamicFieldAcl = map { $_ => $_ } keys $Self->{DynamicField}->%*;

    my $TicketObject = $Kernel::OM->Get('Kernel::System::Ticket');

    # call ticket ACLs for DynamicFields to check field visibility
    my $ACLResult = $TicketObject->TicketAcl(
        $Param{GetParam}->%*,
        Action        => $Self->{Action},
        ReturnType    => 'Form',
        ReturnSubType => '-',
        Data          => \%DynamicFieldAcl,
        UserID        => $Self->{UserID},
    );
    if ($ACLResult) {
        %Visibility = map { 'DynamicField_' . $_ => 0 } keys $Self->{DynamicField}->%*;
        my %AclData = $TicketObject->TicketAclData();
        for my $Field ( sort keys %AclData ) {
            $Visibility{ 'DynamicField_' . $Field } = 1;
        }
    }
    else {
        %Visibility = map { 'DynamicField_' . $_ => 1 } keys $Self->{DynamicField}->%*;
    }

    my %DynamicFieldValidationResult;
    my %DynamicFieldPossibleValues;

    DYNAMICFIELD:
    for my $DynamicFieldName ( keys $Self->{DynamicField}->%* ) {

        # Get the Config of the current DynamicField (the first element of the grep result array)
        my $DynamicFieldConfig = $Self->{DynamicField}{$DynamicFieldName};

        if ( !IsHashRefWithData($DynamicFieldConfig) ) {

            my $Message = "DynamicFieldConfig missing for field: $Param{FieldName}, or is not a Ticket Dynamic Field!";

            # log error but does not stop the execution as it could be an old Article
            # DynamicField, see bug#11666
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => $Message,
            );

            next DYNAMICFIELD;
        }

        # Will be extended later on for ACL Checking:
        my $PossibleValuesFilter;

        my $IsACLReducible = $DynamicFieldBackendObject->HasBehavior(
            DynamicFieldConfig => $DynamicFieldConfig,
            Behavior           => 'IsACLReducible',
        );

        if ($IsACLReducible) {

            # get PossibleValues
            my $PossibleValues = $DynamicFieldBackendObject->PossibleValuesGet(
                DynamicFieldConfig => $DynamicFieldConfig,
            );

            # check if field has PossibleValues property in its configuration
            if ( IsHashRefWithData($PossibleValues) ) {

                # convert possible values key => value to key => key for ACLs using a Hash slice
                my %AclData = %{$PossibleValues};
                @AclData{ keys %AclData } = keys %AclData;

                # set possible values filter from ACLs
                my $ACL = $TicketObject->TicketAcl(
                    $Param{GetParam}->%*,
                    Action        => $Self->{Action},
                    ReturnType    => 'Ticket',
                    ReturnSubType => 'DynamicField_' . $DynamicFieldConfig->{Name},
                    Data          => \%AclData,
                    UserID        => $Self->{UserID},
                );
                if ($ACL) {
                    my %Filter = $TicketObject->TicketAclData();

                    # convert Filer key => key back to key => value using map
                    %{$PossibleValuesFilter} = map { $_ => $PossibleValues->{$_} }
                        keys %Filter;
                }
                else {
                    $PossibleValuesFilter = $PossibleValues;
                }
            }
        }

        $DynamicFieldPossibleValues{ 'DynamicField_' . $DynamicFieldName } = $PossibleValuesFilter;

        # if we have an invisible field, use config's default value
        if ( $ActivityDialog->{Fields}{ 'DynamicField_' . $DynamicFieldName } && $ActivityDialog->{Fields}{ 'DynamicField_' . $DynamicFieldName }{Display} == 0 )
        {
            if (
                defined $ActivityDialog->{Fields}{ 'DynamicField_' . $DynamicFieldName }{DefaultValue}
                && length $ActivityDialog->{Fields}{ 'DynamicField_' . $DynamicFieldName }{DefaultValue}
                )
            {
                $TicketParam{ 'DynamicField_' . $DynamicFieldName } = $ActivityDialog->{Fields}{ 'DynamicField_' . $DynamicFieldName }{DefaultValue};
            }
            else {
                $TicketParam{ 'DynamicField_' . $DynamicFieldName } = '';
            }
        }

        # skip fields which are hidden by ACLs
        elsif ( !$Visibility{ 'DynamicField_' . $DynamicFieldConfig->{Name} } ) {
            next DYNAMICFIELD;
        }

        # only validate visible fields
        else {
            my $Mandatory = $ActivityDialog->{Fields}{ 'DynamicField_' . $DynamicFieldName }
                ? ( $ActivityDialog->{Fields}{ 'DynamicField_' . $DynamicFieldName }{Display} == 2 )
                : $DynamicFieldConfig->{Mandatory};

            # Check DynamicField Values
            my $ValidationResult = $DynamicFieldBackendObject->EditFieldValueValidate(
                DynamicFieldConfig   => $DynamicFieldConfig,
                PossibleValuesFilter => $PossibleValuesFilter,
                ParamObject          => $ParamObject,
                Mandatory            => $Mandatory,
            );

            if ( !IsHashRefWithData($ValidationResult) ) {
                $LayoutObject->FatalError(
                    Message => $LayoutObject->{LanguageObject}->Translate(
                        'Could not perform validation on field %s!',
                        $DynamicFieldConfig->{Label},
                    ),
                );
            }

            if ( $ValidationResult->{ServerError} ) {
                $Error{ $DynamicFieldConfig->{Name} }                        = 1;
                $ErrorMessages{ $DynamicFieldConfig->{Name} }                = $ValidationResult->{ErrorMessage};
                $DynamicFieldValidationResult{ $DynamicFieldConfig->{Name} } = $ValidationResult;
            }

            $TicketParam{ 'DynamicField_' . $DynamicFieldName } =
                $DynamicFieldBackendObject->EditFieldValueGet(
                    DynamicFieldConfig => $DynamicFieldConfig,
                    ParamObject        => $ParamObject,
                    LayoutObject       => $LayoutObject,
                );
        }
    }

    # create process object
    $Kernel::OM->ObjectParamAdd(
        'Kernel::System::ProcessManagement::Process' => {
            ActivityObject         => $Kernel::OM->Get('Kernel::System::ProcessManagement::Activity'),
            ActivityDialogObject   => $ActivityDialogObject,
            TransitionObject       => $Kernel::OM->Get('Kernel::System::ProcessManagement::Transition'),
            TransitionActionObject => $Kernel::OM->Get('Kernel::System::ProcessManagement::TransitionAction'),
        }
    );
    my $ProcessObject = $Kernel::OM->Get('Kernel::System::ProcessManagement::Process');

    my @Notify;

    my $NewTicketID;
    my $NewOwnerID;
    if ( !$TicketID ) {

        $ProcessEntityID = $Param{GetParam}{ProcessEntityID};
        if ( !$ProcessEntityID )
        {
            return $LayoutObject->FatalError(
                Message => Translatable('Missing ProcessEntityID, check your ActivityDialogHeader.tt!'),
            );
        }

        $ProcessStartpoint = $ProcessObject->ProcessStartpointGet(
            ProcessEntityID => $Param{ProcessEntityID},
        );

        if (
            !$ProcessStartpoint
            || !IsHashRefWithData($ProcessStartpoint)
            || !$ProcessStartpoint->{Activity} || !$ProcessStartpoint->{ActivityDialog}
            )
        {
            $LayoutObject->FatalError(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'No StartActivityDialog or StartActivityDialog for Process "%s" configured!',
                    $Param{ProcessEntityID},
                ),
            );
        }

        $ActivityEntityID = $ProcessStartpoint->{Activity};

        NEEDEDLOOP:
        for my $Needed (qw(Queue State Lock Priority)) {

            if ( !$TicketParam{ $Self->{NameToID}{$Needed} } ) {

                # if a required field has no value call _CheckField as filed is hidden
                # (No Display param = Display => 0) and no DefaultValue, to use global default as
                # fall-back. One reason for this to happen is that ActivityDialog DefaultValue tried
                # to set before, was not valid.
                my $Result = $Self->_CheckField(
                    Field => $Self->{NameToID}{$Needed},
                );

                if ( !$Result ) {
                    $Error{ $Self->{NameToID}{$Needed} } = ' ServerError';
                }
                elsif ($Result) {
                    $TicketParam{ $Self->{NameToID}{$Needed} } = $Result;
                }
            }
        }

        # If we had no Errors, we can create the Ticket and Set ActivityEntityID as well as
        # ProcessEntityID
        if ( !IsHashRefWithData( \%Error ) ) {

            $TicketParam{UserID} = $Self->{UserID};

            if ( $TicketParam{OwnerID} ) {
                $NewOwnerID = $TicketParam{OwnerID};
            }

            # Set OwnerID to 1 on TicketCreate. This will be updated later on, so events can be triggered.
            $TicketParam{OwnerID} = 1;

            # if StartActivityDialog does not provide a ticket title set a default value
            if ( !$TicketParam{Title} ) {

                # get the current server Time-stamp
                my $DateTimeObject   = $Kernel::OM->Create('Kernel::System::DateTime');
                my $CurrentTimeStamp = $DateTimeObject->ToString();
                my $OTOBOTimeZone    = $DateTimeObject->OTOBOTimeZoneGet();
                $TicketParam{Title} = "$Param{ProcessName} - $CurrentTimeStamp ($OTOBOTimeZone)";

                # use article subject from the web request if any
                if ( IsStringWithData( $Param{GetParam}{Subject} ) ) {
                    $TicketParam{Title} = $Param{GetParam}{Subject};
                }
            }

            # create a new ticket
            $TicketID = $TicketObject->TicketCreate(%TicketParam);

            if ( !$TicketID ) {
                $LayoutObject->FatalError(
                    Message => $LayoutObject->{LanguageObject}->Translate(
                        'Couldn\'t create ticket for Process with ProcessEntityID "%s"!',
                        $Param{ProcessEntityID},
                    ),
                );
            }

            my $Success = $ProcessObject->ProcessTicketProcessSet(
                ProcessEntityID => $Param{ProcessEntityID},
                TicketID        => $TicketID,
                UserID          => $Self->{UserID},
            );
            if ( !$Success ) {
                $LayoutObject->FatalError(
                    Message => $LayoutObject->{LanguageObject}->Translate(
                        'Couldn\'t set ProcessEntityID "%s" on TicketID "%s"!',
                        $Param{ProcessEntityID},
                        $TicketID,
                    ),
                );
            }

            $Success = undef;

            $Success = $ProcessObject->ProcessTicketActivitySet(
                ProcessEntityID  => $Param{ProcessEntityID},
                ActivityEntityID => $ProcessStartpoint->{Activity},
                TicketID         => $TicketID,
                UserID           => $Self->{UserID},
            );

            if ( !$Success ) {
                $LayoutObject->FatalError(
                    Message => $LayoutObject->{LanguageObject}->Translate(
                        'Couldn\'t set ActivityEntityID "%s" on TicketID "%s"!',
                        $Param{ProcessEntityID},
                        $TicketID,
                    ),
                    Comment => Translatable('Please contact the administrator.'),
                );
            }

            %Ticket = $TicketObject->TicketGet(
                TicketID      => $TicketID,
                UserID        => $Self->{UserID},
                DynamicFields => 1,
            );

            if ( !IsHashRefWithData( \%Ticket ) ) {
                $LayoutObject->FatalError(
                    Message => $LayoutObject->{LanguageObject}->Translate(
                        'Could not store ActivityDialog, invalid TicketID: %s!',
                        $TicketID,
                    ),
                    Comment => Translatable('Please contact the administrator.'),
                );
            }

            # remember new created TicketID
            $NewTicketID = $TicketID;
        }
    }

    elsif ( $TicketID && $Self->{IsProcessEnroll} ) {

        # use Error instead of FatalError as we are in a Pop-up window
        # Get Ticket to check TicketID was valid
        %Ticket = $TicketObject->TicketGet(
            TicketID      => $TicketID,
            UserID        => $Self->{UserID},
            DynamicFields => 0,
        );

        if ( !IsHashRefWithData( \%Ticket ) ) {
            $LayoutObject->Error(
                Message => $LayoutObject->{LanguageObject}->Translate( 'Invalid TicketID: %s!', $TicketID ),
            );
        }

        my $Success = $ProcessObject->ProcessTicketProcessSet(
            ProcessEntityID => $Param{ProcessEntityID},
            TicketID        => $TicketID,
            UserID          => $Self->{UserID},
        );
        if ( !$Success ) {
            $LayoutObject->Error(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'Couldn\'t set ProcessEntityID "%s" on TicketID "%s"!',
                    $Param{ProcessEntityID},
                    $TicketID,
                ),
            );
        }

        $Success = undef;

        $ProcessStartpoint = $ProcessObject->ProcessStartpointGet(
            ProcessEntityID => $Param{ProcessEntityID},
        );

        if (
            !$ProcessStartpoint
            || !IsHashRefWithData($ProcessStartpoint)
            || !$ProcessStartpoint->{Activity} || !$ProcessStartpoint->{ActivityDialog}
            )
        {
            $LayoutObject->Error(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'No StartActivityDialog or StartActivityDialog for Process "%s" configured!',
                    $Param{ProcessEntityID},
                ),
            );
        }

        $Success = $ProcessObject->ProcessTicketActivitySet(
            ProcessEntityID  => $Param{ProcessEntityID},
            ActivityEntityID => $ProcessStartpoint->{Activity},
            TicketID         => $TicketID,
            UserID           => $Self->{UserID},
        );

        if ( !$Success ) {
            $LayoutObject->Error(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'Couldn\'t set ActivityEntityID "%s" on TicketID "%s"!',
                    $Param{ProcessEntityID},
                    $TicketID,
                ),
                Comment => Translatable('Please contact the administrator.'),
            );
        }

        # use ProcessEntityID from the web request
        $ProcessEntityID = $Param{ProcessEntityID};
    }

    # If we had a TicketID, get the Ticket
    else {

        # Get Ticket to check TicketID was valid
        %Ticket = $TicketObject->TicketGet(
            TicketID      => $TicketID,
            UserID        => $Self->{UserID},
            DynamicFields => 1,
        );

        if ( !IsHashRefWithData( \%Ticket ) ) {
            $LayoutObject->FatalError(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'Could not store ActivityDialog, invalid TicketID: %s!',
                    $TicketID,
                ),
            );
        }

        # get config object
        my $ConfigObject = $Kernel::OM->Get('Kernel::Config');

        $ActivityEntityID = $Ticket{
            'DynamicField_'
                . $ConfigObject->Get('Process::DynamicFieldProcessManagementActivityID')
        };
        if ( !$ActivityEntityID )
        {

            return $Self->_ShowDialogError(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'Missing ActivityEntityID in Ticket %s!',
                    $Ticket{TicketID},
                ),
                Comment => Translatable('Please contact the administrator.'),
            );
        }

        # Make sure the activity dialog to save is still the correct activity
        my $Activity = $Kernel::OM->Get('Kernel::System::ProcessManagement::Activity')->ActivityGet(
            ActivityEntityID => $ActivityEntityID,
            Interface        => ['AgentInterface'],
        );
        my %ActivityDialogs = reverse %{ $Activity->{ActivityDialog} // {} };
        if ( !$ActivityDialogs{$ActivityDialogEntityID} ) {

            my $TicketHook        = $ConfigObject->Get('Ticket::Hook');
            my $TicketHookDivider = $ConfigObject->Get('Ticket::HookDivider');

            $Error{WrongActivity} = 1;
            push @Notify, {
                Priority => 'Error',
                Data     => $LayoutObject->{LanguageObject}->Translate(
                    'This step does not belong anymore to the current activity in process for ticket \'%s%s%s\'! Another user changed this ticket in the meantime. Please close this window and reload the ticket.',
                    $TicketHook,
                    $TicketHookDivider,
                    $Ticket{TicketNumber},
                ),
            };
        }

        $ProcessEntityID = $Ticket{
            'DynamicField_'
                . $ConfigObject->Get('Process::DynamicFieldProcessManagementProcessID')
        };

        if ( !$ProcessEntityID )
        {
            return $Self->_ShowDialogError(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'Missing ProcessEntityID in Ticket %s!',
                    $Ticket{TicketID},
                ),
                Comment => Translatable('Please contact the administrator.'),
            );
        }
    }

    # if we got errors go back to displaying the ActivityDialog
    if ( IsHashRefWithData( \%Error ) ) {
        return $Self->_OutputActivityDialog(
            ProcessEntityID        => $ProcessEntityID,
            TicketID               => $TicketID || undef,
            ActivityDialogEntityID => $ActivityDialogEntityID,
            Error                  => \%Error,
            ErrorMessages          => \%ErrorMessages,
            Visibility             => \%Visibility,
            DFErrors               => \%DynamicFieldValidationResult,
            DFPossibleValues       => \%DynamicFieldPossibleValues,
            GetParam               => $Param{GetParam},
            Notify                 => \@Notify,
        );
    }

    # Check if we deal with a Ticket Update
    my $UpdateTicketID = $Param{GetParam}{TicketID};

    # We save only once, no matter if one or more configurations are set for the same param
    my %StoredFields;

    # Save loop for storing Ticket Values that were not required on the initial TicketCreate
    DIALOGFIELD:
    for my $CurrentField ( @{ $ActivityDialog->{FieldOrder} } ) {

        if ( !IsHashRefWithData( $ActivityDialog->{Fields}{$CurrentField} ) ) {
            $LayoutObject->FatalError(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'Can\'t get data for Field "%s" of ActivityDialog "%s"!',
                    $CurrentField,
                    $ActivityDialogEntityID,
                ),
            );
        }

        next DIALOGFIELD if $CurrentField =~ m{^DynamicField_(.*)}xms;

        if ( $CurrentField eq 'PendingTime' ) {

            # This Value is just set if Status was on a Pending state
            # so it has to be possible to store the ticket if this one's empty
            if ( IsHashRefWithData( $TicketParam{'PendingTime'} ) ) {
                my $Success = $TicketObject->TicketPendingTimeSet(
                    UserID   => $Self->{UserID},
                    TicketID => $TicketID,
                    %{ $TicketParam{'PendingTime'} },
                );
                if ( !$Success ) {
                    $LayoutObject->FatalError(
                        Message => $LayoutObject->{LanguageObject}->Translate(
                            'Could not set PendingTime for Ticket with ID "%s" in ActivityDialog "%s"!',
                            $TicketID,
                            $ActivityDialogEntityID,
                        ),
                    );
                }
            }
        }

        elsif ( $CurrentField eq 'Article' && ( $UpdateTicketID || $NewTicketID ) ) {

            my $TicketID = $UpdateTicketID || $NewTicketID;

            if ( $Param{GetParam}{Subject} && $Param{GetParam}{Body} ) {

                # add note
                my $ArticleID = '';
                my $MimeType  = 'text/plain';

                # get pre loaded attachment
                my @Attachments = $UploadCacheObject->FormIDGetAllFilesData(
                    FormID => $Self->{FormID},
                );

                # get submit attachment
                my %UploadStuff = $ParamObject->GetUploadAll(
                    Param => 'FileUpload',
                );
                if (%UploadStuff) {
                    push @Attachments, \%UploadStuff;
                }

                if ( $LayoutObject->{BrowserRichText} ) {
                    $MimeType = 'text/html';

                    # write attachments
                    my @NewAttachmentData;
                    ATTACHMENT:
                    for my $Attachment (@Attachments) {

                        # skip, deleted not used inline images
                        my $ContentID = $Attachment->{ContentID};
                        if (
                            $ContentID
                            && ( $Attachment->{ContentType} =~ /image/i )
                            && ( $Attachment->{Disposition} eq 'inline' )
                            )
                        {
                            my $ContentIDHTMLQuote = $LayoutObject->Ascii2Html(
                                Text => $ContentID,
                            );

                            # workaround for link encode of rich text editor, see bug#5053
                            my $ContentIDLinkEncode = $LayoutObject->LinkEncode($ContentID);
                            $Param{GetParam}{Body} =~ s/(ContentID=)$ContentIDLinkEncode/$1$ContentID/g;

                            # ignore attachment if not linked in body
                            if ( $Param{GetParam}{Body} !~ /(\Q$ContentIDHTMLQuote\E|\Q$ContentID\E)/i )
                            {
                                next ATTACHMENT;
                            }
                        }

                        # Remember inline images and normal attachments.
                        push @NewAttachmentData, \%{$Attachment};
                    }

                    @Attachments = @NewAttachmentData;

                    # verify html document
                    $Param{GetParam}{Body} = $LayoutObject->RichTextDocumentComplete(
                        String => $Param{GetParam}{Body},
                    );
                }

                my $CommunicationChannel = $ActivityDialog->{Fields}{Article}{Config}{CommunicationChannel}
                    // 'Internal';

                my $ArticleBackendObject = $Kernel::OM->Get('Kernel::System::Ticket::Article')->BackendForChannel(
                    ChannelName => $CommunicationChannel,
                );

                # Change history type and comment accordingly to the process article.
                my $HistoryType    = 'AddNote';
                my $HistoryComment = '%%Note';
                if ( $CommunicationChannel eq 'Phone' ) {
                    $HistoryType    = 'PhoneCallAgent';
                    $HistoryComment = '%%';
                }

                my $From = "\"$Self->{UserFullname}\" <$Self->{UserEmail}>";
                $ArticleID = $ArticleBackendObject->ArticleCreate(
                    TicketID                  => $TicketID,
                    SenderType                => 'agent',
                    IsVisibleForCustomer      => $ActivityDialog->{Fields}{Article}{Config}{IsVisibleForCustomer} // 0,
                    From                      => $From,
                    MimeType                  => $MimeType,
                    Charset                   => $LayoutObject->{UserCharset},
                    UserID                    => $Self->{UserID},
                    HistoryType               => $HistoryType,
                    HistoryComment            => $HistoryComment,
                    Body                      => $Param{GetParam}{Body},
                    Subject                   => $Param{GetParam}{Subject},
                    ForceNotificationToUserID => $ActivityDialog->{Fields}{Article}{Config}{InformAgents}
                    ? $Param{GetParam}{InformUserID}
                    : [],
                );
                if ( !$ArticleID ) {
                    return $LayoutObject->ErrorScreen();
                }

                # write attachments
                for my $Attachment (@Attachments) {
                    $ArticleBackendObject->ArticleWriteAttachment(
                        %{$Attachment},
                        ArticleID => $ArticleID,
                        UserID    => $Self->{UserID},
                    );
                }

                # remove all form data
                $Kernel::OM->Get('Kernel::System::Web::FormCache')->FormIDRemove( FormID => $Self->{FormID} );

                # time accounting
                if ( $Param{GetParam}{TimeUnits} ) {
                    $TicketObject->TicketAccountTime(
                        TicketID  => $TicketID,
                        ArticleID => $ArticleID,
                        TimeUnit  => $Param{GetParam}{TimeUnits},
                        UserID    => $Self->{UserID},
                    );
                }
            }
        }

        # If we have to Update a ticket, update the transmitted values
        elsif ($UpdateTicketID) {

            my $Success;
            if ( $Self->{NameToID}{$CurrentField} eq 'Title' ) {

                # if there is no title, nothing is needed to be done
                if (
                    !defined $TicketParam{'Title'}
                    || ( defined $TicketParam{'Title'} && $TicketParam{'Title'} eq '' )
                    )
                {
                    $Success = 1;
                }

                # otherwise set the ticket title
                else {
                    $Success = $TicketObject->TicketTitleUpdate(
                        Title    => $TicketParam{'Title'},
                        TicketID => $TicketID,
                        UserID   => $Self->{UserID},
                    );
                }
            }
            elsif (
                (
                    $Self->{NameToID}{$CurrentField} eq 'CustomerID'
                    || $Self->{NameToID}{$CurrentField} eq 'CustomerUserID'
                )
                )
            {
                next DIALOGFIELD if $StoredFields{ $Self->{NameToID}{$CurrentField} };

                if ( $ActivityDialog->{Fields}{$CurrentField}{Display} == 1 ) {
                    $LayoutObject->FatalError(
                        Message => $LayoutObject->{LanguageObject}->Translate(
                            'Wrong ActivityDialog Field config: %s can\'t be Display => 1 / Show field (Please change its configuration to be Display => 0 / Do not show field or Display => 2 / Show field as mandatory)!',
                            $CurrentField,
                        ),
                    );
                }

                # skip TicketCustomerSet() if there is no change in the customer
                if (
                    $Ticket{CustomerID} eq $TicketParam{CustomerID}
                    && $Ticket{CustomerUserID} eq $TicketParam{CustomerUser}
                    )
                {

                    # In this case we don't want to call any additional stores
                    # on Customer, CustomerNo, CustomerID or CustomerUserID
                    # so make sure both fields are set to "Stored" ;)
                    $StoredFields{ $Self->{NameToID}{'CustomerID'} }     = 1;
                    $StoredFields{ $Self->{NameToID}{'CustomerUserID'} } = 1;
                    next DIALOGFIELD;
                }

                $Success = $TicketObject->TicketCustomerSet(
                    No => $TicketParam{CustomerID},

                    # here too: unfortunately TicketCreate takes Param 'CustomerUser'
                    # instead of CustomerUserID, so our TicketParam hash
                    # has the CustomerUser Key instead of 'CustomerUserID'
                    User     => $TicketParam{CustomerUser},
                    TicketID => $TicketID,
                    UserID   => $Self->{UserID},
                );

                # In this case we don't want to call any additional stores
                # on Customer, CustomerNo, CustomerID or CustomerUserID
                # so make sure both fields are set to "Stored" ;)
                $StoredFields{ $Self->{NameToID}{'CustomerID'} }     = 1;
                $StoredFields{ $Self->{NameToID}{'CustomerUserID'} } = 1;
            }
            else {
                next DIALOGFIELD if $StoredFields{ $Self->{NameToID}{$CurrentField} };

                my $TicketFieldSetSub = $CurrentField;
                $TicketFieldSetSub =~ s{ID$}{}xms;
                $TicketFieldSetSub = 'Ticket' . $TicketFieldSetSub . 'Set';

                if ( $TicketObject->can($TicketFieldSetSub) )
                {
                    my $UpdateFieldName;

                    # sadly we need an exception for Owner(ID) and Responsible(ID), because the
                    # Ticket*Set subs need NewUserID as param
                    if (
                        scalar grep { $Self->{NameToID}{$CurrentField} eq $_ }
                        qw( OwnerID ResponsibleID )
                        )
                    {
                        $UpdateFieldName = 'NewUserID';
                    }
                    else {
                        $UpdateFieldName = $Self->{NameToID}{$CurrentField};
                    }

                    # to store if the field needs to be updated
                    my $FieldUpdate;

                    # only Service and SLA fields accepts empty values if the hash key is not
                    # defined set it to empty so the Ticket*Set function call will get the empty
                    # value
                    if (
                        ( $UpdateFieldName eq 'ServiceID' || $UpdateFieldName eq 'SLAID' )
                        && !defined $TicketParam{ $Self->{NameToID}{$CurrentField} }
                        )
                    {
                        $TicketParam{ $Self->{NameToID}{$CurrentField} } = '';
                        $FieldUpdate = 1;
                    }

                    # update Service an SLA fields if they have a defined value (even empty)
                    elsif ( $UpdateFieldName eq 'ServiceID' || $UpdateFieldName eq 'SLAID' )
                    {
                        $FieldUpdate = 1;
                    }

                    # update any other field that its value is defined and not empty
                    elsif (
                        $UpdateFieldName ne 'ServiceID'
                        && $UpdateFieldName ne 'SLAID'
                        && defined $TicketParam{ $Self->{NameToID}{$CurrentField} }
                        && $TicketParam{ $Self->{NameToID}{$CurrentField} } ne ''
                        )
                    {
                        $FieldUpdate = 1;
                    }

                    $Success = 1;

                    # check if field needs to be updated
                    if ($FieldUpdate) {
                        $Success = $TicketObject->$TicketFieldSetSub(
                            $UpdateFieldName => $TicketParam{ $Self->{NameToID}{$CurrentField} },
                            TicketID         => $TicketID,
                            UserID           => $Self->{UserID},
                        );

                        # in case of a new service and no new SLA is to be set, check if current
                        # assigned SLA is still valid
                        if (
                            $UpdateFieldName eq 'ServiceID'
                            && !defined $TicketParam{SLAID}
                            )
                        {

                            # get ticket details
                            my %Ticket = $TicketObject->TicketGet(
                                TicketID      => $TicketID,
                                DynamicFields => 0,
                                UserID        => $Self->{UserID},
                            );

                            # if ticket already have an SLA assigned get the list SLAs for the new
                            # service
                            if ( IsPositiveInteger( $Ticket{SLAID} ) ) {
                                my %SLAList = $Kernel::OM->Get('Kernel::System::SLA')->SLAList(
                                    ServiceID => $TicketParam{ $Self->{NameToID}{$CurrentField} },
                                    UserID    => $Self->{UserID},
                                );

                                # if the current SLA is not in the list of SLA for new service
                                # remove SLA from ticket
                                if ( !$SLAList{ $Ticket{SLAID} } ) {
                                    $TicketObject->TicketSLASet(
                                        SLAID    => '',
                                        TicketID => $TicketID,
                                        UserID   => $Self->{UserID},
                                    );
                                }
                            }
                        }
                    }
                }
            }
            if ( !$Success ) {
                $LayoutObject->FatalError(
                    Message => $LayoutObject->{LanguageObject}->Translate(
                        'Could not set %s for Ticket with ID "%s" in ActivityDialog "%s"!',
                        $CurrentField,
                        $TicketID,
                        $ActivityDialogEntityID,
                    ),
                );
            }
        }
    }

    DYNAMICFIELD:
    for my $DynamicFieldName ( keys $Self->{DynamicField}->%* ) {

        my $DynamicFieldConfig = $Self->{DynamicField}{$DynamicFieldName};
        if ( !IsHashRefWithData($DynamicFieldConfig) ) {

            my $Message = "DynamicFieldConfig missing for field: $DynamicFieldName, or is not a Ticket Dynamic Field!";

            # log error but does not stop the execution as it could be an old Article
            # DynamicField, see bug#11666
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => $Message,
            );

            next DYNAMICFIELD;
        }

        # don't set value of dynamic field if it is hidden via ACL (and not via activity dialog definition)
        if (
            !$Visibility{ 'DynamicField_' . $DynamicFieldConfig->{Name} }
            && $ActivityDialog->{Fields}{ 'DynamicField_' . $DynamicFieldConfig->{Name} }{Display} != 0
            )
        {
            next DYNAMICFIELD;
        }

        my $Success = $DynamicFieldBackendObject->ValueSet(
            DynamicFieldConfig => $DynamicFieldConfig,
            ObjectID           => $TicketID,
            Value              => $TicketParam{ 'DynamicField_' . $DynamicFieldConfig->{Name} },
            UserID             => $Self->{UserID},
        );

        if ( !$Success ) {
            $LayoutObject->FatalError(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'Could not set DynamicField value for %s of Ticket with ID "%s" in ActivityDialog "%s"!',
                    $DynamicFieldName,
                    $TicketID,
                    $ActivityDialogEntityID,
                ),
            );
        }
    }

    # delete hidden fields cache
    $Kernel::OM->Get('Kernel::System::Cache')->Delete(
        Type => 'HiddenFields',
        Key  => $Self->{FormID},
    );

    # get the link ticket id if given
    my $LinkTicketID = $ParamObject->GetParam( Param => 'LinkTicketID' ) || '';

    # get screen config
    my $Config = $Kernel::OM->Get('Kernel::Config')->Get("Ticket::Frontend::$Self->{Action}");

    # link tickets
    if (
        $LinkTicketID
        && $Config->{SplitLinkType}
        && $Config->{SplitLinkType}{LinkType}
        && $Config->{SplitLinkType}{Direction}
        )
    {

        my $Access = $TicketObject->TicketPermission(
            Type     => 'ro',
            TicketID => $LinkTicketID,
            UserID   => $Self->{UserID}
        );

        if ( !$Access ) {
            return $LayoutObject->NoPermission(
                Message    => "You need ro permission!",
                WithHeader => 'yes',
            );
        }

        my $SourceKey = $LinkTicketID;
        my $TargetKey = $TicketID;

        if ( $Config->{SplitLinkType}{Direction} eq 'Source' ) {
            $SourceKey = $TicketID;
            $TargetKey = $LinkTicketID;
        }

        # link the tickets
        $Kernel::OM->Get('Kernel::System::LinkObject')->LinkAdd(
            SourceObject => 'Ticket',
            SourceKey    => $SourceKey,
            TargetObject => 'Ticket',
            TargetKey    => $TargetKey,
            Type         => $Config->{SplitLinkType}{LinkType} || 'Normal',
            State        => 'Valid',
            UserID       => $Self->{UserID},
        );
    }

    if ($NewOwnerID) {
        $TicketObject->TicketOwnerSet(
            TicketID  => $TicketID,
            NewUserID => $NewOwnerID,
            UserID    => $Self->{UserID},
        );
    }

    # Transitions will be handled by ticket event module (TicketProcessTransitions.pm).

    # if we were updating a ticket, close the pop-up and return to zoom
    # else (new ticket) just go to zoom to show the new ticket
    if ($UpdateTicketID) {

        # load new URL in parent window and close pop-up
        return $LayoutObject->PopupClose(
            URL => "Action=AgentTicketZoom;TicketID=$UpdateTicketID",
        );
    }

    return $LayoutObject->Redirect(
        OP => "Action=AgentTicketZoom;TicketID=$TicketID",
    );
}

sub _DisplayProcessList {
    my ( $Self, %Param ) = @_;

    # If we have a ProcessEntityID
    $Param{Errors}{ProcessEntityIDInvalid} = ' ServerError'
        if ( $Param{ProcessEntityID} && !$Param{ProcessList}{ $Param{ProcessEntityID} } );

    # get layout object
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    $Param{ProcessList} = $LayoutObject->BuildSelection(
        Class        => 'Modernize Validate_Required' . ( $Param{Errors}{ProcessEntityIDInvalid} || ' ' ),
        Data         => $Param{ProcessList},
        Name         => 'ProcessEntityID',
        SelectedID   => $Param{ProcessEntityID},
        PossibleNone => 1,
        Sort         => 'AlphanumericValue',
        Translation  => 1,
        AutoComplete => 'off',
    );

    # add rich text editor
    if ( $LayoutObject->{BrowserRichText} ) {

        # use height/width defined for this screen
        $Param{RichTextHeight} = $Self->{Config}{RichTextHeight} || 0;
        $Param{RichTextWidth}  = $Self->{Config}{RichTextWidth}  || 0;

        # set up rich text editor
        $LayoutObject->SetRichTextParameters(
            Data => \%Param,
        );
    }

    if ( $Param{PreSelectProcess} && $Param{ProcessID} ) {

        # send data to JS
        $LayoutObject->AddJSData(
            Key   => 'ProcessID',
            Value => $Param{ProcessID},
        );
    }

    $LayoutObject->Block(
        Name => 'ProcessList',
        Data => {
            %Param,
            FormID => $Self->{FormID},
        },
    );

    # on initial screen from navbar there is no IsMainWinow but also no IsProcessEnroll,
    # then it must be a MainWindow
    if ( !$Self->{IsMainWindow} && !$Self->{IsProcessEnroll} ) {
        $Self->{IsMainWindow} = 1;
    }

    my $Type = $Self->{IsMainWindow} ? '' : 'Small';

    my $Output = $LayoutObject->Header(
        Type => $Type,
    );
    if ( $Self->{IsMainWindow} ) {
        $Output .= $LayoutObject->NavigationBar();
    }

    # explanatory message about asterisk
    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');
    if ( $ConfigObject->Get('Ticket::Frontend::AsteriskExplanation') ) {
        $LayoutObject->Block(
            Name => 'AsteriskExplanation',
        );
    }

    $Output .= $LayoutObject->Output(
        TemplateFile => 'AgentTicketProcess' . $Type,
        Data         => {
            %Param,
            FormID          => $Self->{FormID},
            IsProcessEnroll => $Self->{IsProcessEnroll},
        },
    );

    # workaround when activity dialog is loaded by AJAX as first activity dialog, if there is
    # a date field like Pending Time or Dynamic Fields Date/Time or Date, there is no way to set
    # this options in the footer again
    $LayoutObject->{HasDatepicker} = 1;

    $Output .= $LayoutObject->Footer( Type => $Type );

    return $Output;
}

# =cut
#
# _CheckField()
#
# checks all the possible ticket fields and returns the ID (if possible) value of the field, if valid
# and checks are successful
#
# if Display param is set to 0 or not given, it uses ActivityDialog field default value for all fields
# or global default value as fallback only for certain fields
#
# if Display param is set to 1 or 2 it uses the value from the web request
#
#     my $PriorityID = $AgentTicketProcessObject->_CheckField(
#         Field        => 'PriorityID',
#         Display      => 1,                   # optional, 0 or 1 or 2
#         DefaultValue => '3 normal',          # ActivityDialog field default value (it uses global
#                                              #    default value as fall back for mandatory fields
#                                              #    (Queue, Sate, Lock and Priority)
#     );
#
# Returns:
#     $PriorityID = 1;                         # if PriorityID is set to 1 in the web request
#
#     my $PriorityID = $AgentTicketProcessObject->_CheckField(
#         Field        => 'PriorityID',
#         Display      => 0,
#         DefaultValue => '3 normal',
#     );
#
# Returns:
#     $PriorityID = 3;                        # since ActivityDialog default value is '3 normal' and
#                                             #     field is hidden
#
# =cut

sub _CheckField {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(Field)) {
        if ( !$Param{$Needed} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Needed!"
            );
            return;
        }
    }

    # remove the ID and check if the given field is required for creating a ticket
    my $FieldWithoutID = $Param{Field};
    $FieldWithoutID =~ s{ID$}{}xms;
    my $TicketRequiredField = scalar grep { $_ eq $FieldWithoutID } qw(Queue State Lock Priority);

    my $Value;

    # get needed objects
    my $ParamObject  = $Kernel::OM->Get('Kernel::System::Web::Request');
    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    # if no Display (or Display == 0) is committed
    if ( !$Param{Display} ) {

        # Check if a DefaultValue is given
        if ( $Param{DefaultValue} ) {

            # check if the given field param is valid
            $Value = $Self->_LookupValue(
                Field => $FieldWithoutID,
                Value => $Param{DefaultValue},
            );
        }

        # if we got a required ticket field, check if we got a valid DefaultValue in the SysConfig
        if ( !$Value && $TicketRequiredField ) {
            $Value = $Kernel::OM->Get('Kernel::Config')->Get("Process::Default$FieldWithoutID");

            if ( !$Value ) {
                $LayoutObject->FatalError(
                    Message => $LayoutObject->{LanguageObject}->Translate(
                        'Default Config for Process::Default%s missing!',
                        $FieldWithoutID,
                    ),
                );
            }
            else {

                # check if the given field param is valid
                $Value = $Self->_LookupValue(
                    Field => $FieldWithoutID,
                    Value => $Value,
                );
                if ( !$Value ) {
                    $LayoutObject->FatalError(
                        Message => $LayoutObject->{LanguageObject}->Translate(
                            'Default Config for Process::Default%s invalid!',
                            $FieldWithoutID,
                        ),
                    );
                }
            }
        }
    }
    elsif ( $Param{Display} == 1 ) {

        # Display == 1 is logicality not possible for a ticket required field
        if ($TicketRequiredField) {
            $LayoutObject->FatalError(
                Message => $LayoutObject->{LanguageObject}->Translate(
                    'Wrong ActivityDialog Field config: %s can\'t be Display => 1 / Show field (Please change its configuration to be Display => 0 / Do not show field or Display => 2 / Show field as mandatory)!',
                    $Param{Field},
                ),
            );
        }

        # check if the given field param is valid
        if ( $Param{Field} eq 'Article' ) {

            $Value = 1;

            my ( $Body, $Subject, $AttachmentExists, $TimeUnits ) = (
                $ParamObject->GetParam( Param => 'Body' ),
                $ParamObject->GetParam( Param => 'Subject' ),
                $ParamObject->GetParam( Param => 'AttachmentExists' ),
                $ParamObject->GetParam( Param => 'TimeUnits' )
            );

            # If attachment exists and body and subject not, it is error (see bug#13081).
            if ( $AttachmentExists && ( !$Body && !$Subject ) ) {
                $Value = 0;
            }

            # If time units exists and body and subject not, it is error (see bug#13266).
            if ( $TimeUnits && ( !$Body && !$Subject ) ) {
                $Value = 0;
            }
        }
        else {

            $Value = $Self->_LookupValue(
                Field => $Param{Field},
                Value => $ParamObject->GetParam( Param => $Param{Field} ) || '',
            );
        }
    }
    elsif ( $Param{Display} == 2 ) {

        # check if the given field param is valid
        if ( $Param{Field} eq 'Article' ) {

            my ( $Body, $Subject ) = (
                $ParamObject->GetParam( Param => 'Body' ),
                $ParamObject->GetParam( Param => 'Subject' )
            );

            $Value = 0;
            if ( $Body && $Subject ) {
                $Value = 1;
            }
        }
        else {
            $Value = $Self->_LookupValue(
                Field => $Param{Field},
                Value => $ParamObject->GetParam( Param => $Param{Field} ) || '',
            );
        }
    }

    return $Value;
}

# =cut
#
# _LookupValue()
#
# returns the ID (if possible) of nearly all ticket fields and/or checks if its valid.
# Can handle IDs or Strings.
# Currently working with: State, Queue, Lock, Priority (possible more).
#
#     my $PriorityID = $AgentTicketProcessObject->_LookupValue(
#         PriorityID => 1,
#     );
#     $PriorityID = 1;
#
#     my $StateID = $AgentTicketProcessObject->_LookupValue(
#         State => 'open',
#     );
#     $StateID = 3;
#
#     my $PriorityID = $AgentTicketProcessObject->_LookupValue(
#         Priority => 'unknownpriority1234',
#     );
#     $PriorityID = undef;
#
# =cut

sub _LookupValue {
    my ( $Self, %Param ) = @_;

    # get log object
    my $LogObject = $Kernel::OM->Get('Kernel::System::Log');

    # check needed stuff
    for my $Needed (qw(Field Value)) {
        if ( !defined $Param{$Needed} ) {
            $LogObject->Log(
                Priority => 'error',
                Message  => "Need $Needed!"
            );
            return;
        }
    }

    if ( !$Param{Field} ) {
        $LogObject->Log(
            Priority => 'error',
            Message  => "Field should not be empty!"
        );
        return;
    }

    # if there is no value, there is nothing to do
    return if !$Param{Value};

    # remove the ID for function name purpose
    my $FieldWithoutID = $Param{Field};
    $FieldWithoutID =~ s{ID$}{}xms;

    my $LookupFieldName;
    my $ObjectName;
    my $FunctionName;

    # owner(ID) and responsible(ID) lookup needs UserID as parameter
    if ( scalar grep { $Param{Field} eq $_ } qw( OwnerID ResponsibleID ) ) {
        $LookupFieldName = 'UserID';
        $ObjectName      = 'User';
        $FunctionName    = 'UserLookup';
    }

    # owner and responsible lookup needs UserLogin as parameter
    elsif ( scalar grep { $Param{Field} eq $_ } qw( Owner Responsible ) ) {
        $LookupFieldName = 'UserLogin';
        $ObjectName      = 'User';
        $FunctionName    = 'UserLookup';
    }

    # service and SLA lookup needs Name as parameter (While ServiceID an SLAID uses standard)
    elsif ( scalar grep { $Param{Field} eq $_ } qw( Service SLA ) ) {
        $LookupFieldName = 'Name';
        $ObjectName      = $FieldWithoutID;
        $FunctionName    = $FieldWithoutID . 'Lookup';
    }

    # other fields can use standard parameter names as Priority or PriorityID
    else {
        $LookupFieldName = $Param{Field};
        $ObjectName      = $FieldWithoutID;
        $FunctionName    = $FieldWithoutID . 'Lookup';
    }

    # get appropriate object of field
    my $FieldObject;
    if ( $Kernel::OM->Get('Kernel::System::Main')->Require( 'Kernel::System::' . $ObjectName, Silent => 1 ) ) {
        $FieldObject = $Kernel::OM->Get( 'Kernel::System::' . $ObjectName );
    }

    my $Value;

    # check if the backend module has the needed *Lookup sub
    if ( $FieldObject && $FieldObject->can($FunctionName) ) {

        # call the *Lookup sub and get the value
        $Value = $FieldObject->$FunctionName(
            $LookupFieldName => $Param{Value},
        );
    }

    # if we didn't have an object and the value has no ref a string e.g. Title and so on
    # return true
    elsif ( $Param{Field} eq $FieldWithoutID && !ref $Param{Value} ) {
        return $Param{Value};
    }
    else {
        $LogObject->Log(
            Priority => 'error',
            Message  => "Error while checking with " . $FieldWithoutID . "Object!"
        );
        return;
    }

    return if ( !$Value );

    # return the given ID value if the *Lookup result was a string
    if ( $Param{Field} ne $FieldWithoutID ) {
        return $Param{Value};
    }

    # return the *Lookup string return value
    return $Value;
}

sub _GetResponsibles {
    my ( $Self, %Param ) = @_;

    # get users
    my %ShownUsers;
    my %AllGroupsMembers = $Kernel::OM->Get('Kernel::System::User')->UserList(
        Type  => 'Long',
        Valid => 1,
    );

    # get needed objects
    my $TicketObject = $Kernel::OM->Get('Kernel::System::Ticket');
    my $QueueObject  = $Kernel::OM->Get('Kernel::System::Queue');
    my $GroupObject  = $Kernel::OM->Get('Kernel::System::Group');
    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');

    # Get available permissions and set permission group type accordingly.
    my $ConfigPermissions   = $ConfigObject->Get('System::Permission');
    my $PermissionGroupType = ( grep { $_ eq 'responsible' } @{$ConfigPermissions} ) ? 'responsible' : 'rw';

    # if we are updating a ticket show the full list of possible responsibles
    if ( $Param{TicketID} ) {
        if ( $Param{QueueID} && !$Param{AllUsers} ) {
            my $GID        = $QueueObject->GetQueueGroupID( QueueID => $Param{QueueID} );
            my %MemberList = $GroupObject->PermissionGroupGet(
                GroupID => $GID,
                Type    => $PermissionGroupType,
            );
            for my $UserID ( sort keys %MemberList ) {
                $ShownUsers{$UserID} = $AllGroupsMembers{$UserID};
            }
        }
    }
    else {

        # the StartActivityDialog does not provide a TicketID and it could be that also there
        # is no QueueID information. Get the default QueueID for this matters.
        if ( !$Param{QueueID} ) {
            my $Queue   = $ConfigObject->Get("Process::DefaultQueue");
            my $QueueID = $QueueObject->QueueLookup( Queue => $Queue );
            if ($QueueID) {
                $Param{QueueID} = $QueueID;
            }
        }

        # just show only users with selected custom queue
        if ( $Param{QueueID} && !$Param{ResponsibleAll} ) {
            my @UserIDs = $TicketObject->GetSubscribedUserIDsByQueueID(%Param);
            for my $KeyGroupMember ( sort keys %AllGroupsMembers ) {
                my $Hit = 0;
                for my $UID (@UserIDs) {
                    if ( $UID eq $KeyGroupMember ) {
                        $Hit = 1;
                    }
                }
                if ( !$Hit ) {
                    delete $AllGroupsMembers{$KeyGroupMember};
                }
            }
        }

        # show all system users
        if ( $ConfigObject->Get('Ticket::ChangeOwnerToEveryone') ) {
            %ShownUsers = %AllGroupsMembers;
        }

        # show all subscribed users who have the appropriate permission in the queue group
        elsif ( $Param{QueueID} ) {
            my $GID        = $QueueObject->GetQueueGroupID( QueueID => $Param{QueueID} );
            my %MemberList = $GroupObject->PermissionGroupGet(
                GroupID => $GID,
                Type    => $PermissionGroupType,
            );
            for my $KeyMember ( sort keys %MemberList ) {
                if ( $AllGroupsMembers{$KeyMember} ) {
                    $ShownUsers{$KeyMember} = $AllGroupsMembers{$KeyMember};
                }
            }
        }
    }

    # workflow
    my $ACL = $TicketObject->TicketAcl(
        %Param,
        Action        => $Self->{Action},
        ReturnType    => 'Ticket',
        ReturnSubType => 'Responsible',
        Data          => \%ShownUsers,
        UserID        => $Self->{UserID},
    );

    return { $TicketObject->TicketAclData() } if $ACL;

    return \%ShownUsers;
}

sub _GetOwners {
    my ( $Self, %Param ) = @_;

    # get users
    my %ShownUsers;
    my %AllGroupsMembers = $Kernel::OM->Get('Kernel::System::User')->UserList(
        Type  => 'Long',
        Valid => 1,
    );

    # get needed objects
    my $TicketObject = $Kernel::OM->Get('Kernel::System::Ticket');
    my $QueueObject  = $Kernel::OM->Get('Kernel::System::Queue');
    my $GroupObject  = $Kernel::OM->Get('Kernel::System::Group');
    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');

    # Get available permissions and set permission group type accordingly.
    my $ConfigPermissions   = $ConfigObject->Get('System::Permission');
    my $PermissionGroupType = ( grep { $_ eq 'owner' } @{$ConfigPermissions} ) ? 'owner' : 'rw';

    # if we are updating a ticket show the full list of possible owners
    if ( $Param{TicketID} ) {
        if ( $Param{QueueID} && !$Param{AllUsers} ) {
            my $GID        = $QueueObject->GetQueueGroupID( QueueID => $Param{QueueID} );
            my %MemberList = $GroupObject->PermissionGroupGet(
                GroupID => $GID,
                Type    => $PermissionGroupType,
            );
            for my $UserID ( sort keys %MemberList ) {
                $ShownUsers{$UserID} = $AllGroupsMembers{$UserID};
            }
        }
    }
    else {

        # the StartActivityDialog does not provide a TicketID and it could be that also there
        # is no QueueID information. Get the default QueueID for this matters.
        if ( !$Param{QueueID} ) {
            my $Queue   = $ConfigObject->Get("Process::DefaultQueue");
            my $QueueID = $QueueObject->QueueLookup( Queue => $Queue );
            if ($QueueID) {
                $Param{QueueID} = $QueueID;
            }
        }

        # just show only users with selected custom queue
        if ( $Param{QueueID} && !$Param{OwnerAll} ) {
            my @UserIDs = $TicketObject->GetSubscribedUserIDsByQueueID(%Param);
            for my $KeyGroupMember ( sort keys %AllGroupsMembers ) {
                my $Hit = 0;
                for my $UID (@UserIDs) {
                    if ( $UID eq $KeyGroupMember ) {
                        $Hit = 1;
                    }
                }
                if ( !$Hit ) {
                    delete $AllGroupsMembers{$KeyGroupMember};
                }
            }
        }

        # show all system users
        if ( $ConfigObject->Get('Ticket::ChangeOwnerToEveryone') ) {
            %ShownUsers = %AllGroupsMembers;
        }

        # show all subscribed users who have the appropriate permission in the queue group
        elsif ( $Param{QueueID} ) {
            my $GID        = $QueueObject->GetQueueGroupID( QueueID => $Param{QueueID} );
            my %MemberList = $GroupObject->PermissionGroupGet(
                GroupID => $GID,
                Type    => $PermissionGroupType,
            );
            for my $KeyMember ( sort keys %MemberList ) {
                if ( $AllGroupsMembers{$KeyMember} ) {
                    $ShownUsers{$KeyMember} = $AllGroupsMembers{$KeyMember};
                }
            }
        }
    }

    # workflow
    my $ACL = $TicketObject->TicketAcl(
        %Param,
        Action        => $Self->{Action},
        ReturnType    => 'Ticket',
        ReturnSubType => 'Owner',
        Data          => \%ShownUsers,
        UserID        => $Self->{UserID},
    );

    return { $TicketObject->TicketAclData() } if $ACL;

    return \%ShownUsers;
}

sub _GetSLAs {
    my ( $Self, %Param ) = @_;

    # get sla
    my %SLA;
    if ( $Param{ServiceID} && $Param{Services} && %{ $Param{Services} } ) {
        if ( $Param{Services}{ $Param{ServiceID} } ) {
            %SLA = $Kernel::OM->Get('Kernel::System::Ticket')->TicketSLAList(
                %Param,
                Action => $Self->{Action},
                UserID => $Self->{UserID},
            );
        }
    }
    return \%SLA;
}

sub _GetServices {
    my ( $Self, %Param ) = @_;

    # get service
    my %Service;

    # check needed
    return \%Service if !$Param{QueueID} && !$Param{TicketID};

    # get options for default services for unknown customers
    my $DefaultServiceUnknownCustomer = $Kernel::OM->Get('Kernel::Config')->Get('Ticket::Service::Default::UnknownCustomer');

    # check if no CustomerUserID is selected
    # if $DefaultServiceUnknownCustomer = 0 leave CustomerUserID empty, it will not get any services
    # if $DefaultServiceUnknownCustomer = 1 set CustomerUserID to get default services
    if ( !$Param{CustomerUserID} && $DefaultServiceUnknownCustomer ) {
        $Param{CustomerUserID} = '<DEFAULT>';
    }

    # get service list
    if ( $Param{CustomerUserID} ) {
        %Service = $Kernel::OM->Get('Kernel::System::Ticket')->TicketServiceList(
            %Param,
            Action => $Self->{Action},
            UserID => $Self->{UserID},
        );
    }
    return \%Service;
}

sub _GetLocks {
    my ( $Self, %Param ) = @_;

    my %Locks = $Kernel::OM->Get('Kernel::System::Lock')->LockList(
        UserID => $Self->{UserID},
    );

    return \%Locks;
}

sub _GetPriorities {
    my ( $Self, %Param ) = @_;

    my %Priorities;

    # Initially we have just the default Queue Parameter
    # so make sure to get the ID in that case
    my $QueueID;
    if ( !$Param{QueueID} && $Param{Queue} ) {
        $QueueID = $Kernel::OM->Get('Kernel::System::Queue')->QueueLookup( Queue => $Param{Queue} );
    }
    if ( $Param{QueueID} || $QueueID || $Param{TicketID} ) {
        %Priorities = $Kernel::OM->Get('Kernel::System::Ticket')->TicketPriorityList(
            %Param,
            Action => $Self->{Action},
            UserID => $Self->{UserID},
        );

    }
    return \%Priorities;
}

sub _GetQueues {
    my ( $Self, %Param ) = @_;

    # check which type of permission is needed: if the process ticket
    # already exists (= TicketID is present), we need the 'move_into'
    # permission otherwise the 'create' permission
    my $PermissionType = 'create';
    if ( $Param{TicketID} ) {
        $PermissionType = 'move_into';
    }

    # get config object
    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');

    # check own selection
    my %NewQueues;
    if ( $ConfigObject->Get('Ticket::Frontend::NewQueueOwnSelection') ) {
        %NewQueues = %{ $ConfigObject->Get('Ticket::Frontend::NewQueueOwnSelection') };
    }
    else {

        # SelectionType Queue or SystemAddress?
        my %Queues;
        if ( $ConfigObject->Get('Ticket::Frontend::NewQueueSelectionType') eq 'Queue' ) {
            %Queues = $Kernel::OM->Get('Kernel::System::Ticket')->MoveList(
                %Param,
                Type    => $PermissionType,
                Action  => $Self->{Action},
                QueueID => $Self->{QueueID},
                UserID  => $Self->{UserID},
            );
        }
        else {
            %Queues = $Kernel::OM->Get('Kernel::System::SystemAddress')->SystemAddressQueueList();
        }

        # get permission queues
        my %UserGroups = $Kernel::OM->Get('Kernel::System::Group')->PermissionUserGet(
            UserID => $Self->{UserID},
            Type   => $PermissionType,
        );

        # build selection string
        QUEUEID:
        for my $QueueID ( sort keys %Queues ) {
            my %QueueData = $Kernel::OM->Get('Kernel::System::Queue')->QueueGet( ID => $QueueID );

            # permission check, can we create new tickets in queue
            next QUEUEID if !$UserGroups{ $QueueData{GroupID} };

            my $String = $ConfigObject->Get('Ticket::Frontend::NewQueueSelectionString')
                || '<Realname> <<Email>> - Queue: <Queue>';
            $String =~ s/<Queue>/$QueueData{Name}/g;
            $String =~ s/<QueueComment>/$QueueData{Comment}/g;

            # remove trailing spaces
            $String =~ s{\s+\z}{} if !$QueueData{Comment};

            if ( $ConfigObject->Get('Ticket::Frontend::NewQueueSelectionType') ne 'Queue' )
            {
                my %SystemAddressData = $Self->{SystemAddress}->SystemAddressGet(
                    ID => $Queues{$QueueID},
                );
                $String =~ s/<Realname>/$SystemAddressData{Realname}/g;
                $String =~ s/<Email>/$SystemAddressData{Name}/g;
            }
            $NewQueues{$QueueID} = $String;
        }
    }

    return \%NewQueues;
}

sub _GetStates {
    my ( $Self, %Param ) = @_;

    my %States = $Kernel::OM->Get('Kernel::System::Ticket')->TicketStateList(
        %Param,

        # Set default values for new process ticket
        QueueID  => $Param{QueueID}  || 1,
        TicketID => $Param{TicketID} || '',

        # remove type, since if Ticket::Type is active in sysconfig, the Type parameter will
        # be sent and the TicketStateList will send the parameter as State Type
        Type => undef,

        Action => $Self->{Action},
        UserID => $Self->{UserID},
    );

    return \%States;
}

sub _GetTypes {
    my ( $Self, %Param ) = @_;

    # get type
    my %Type;
    if ( $Param{QueueID} || $Param{TicketID} ) {
        %Type = $Kernel::OM->Get('Kernel::System::Ticket')->TicketTypeList(
            %Param,
            Action => $Self->{Action},
            UserID => $Self->{UserID},
        );
    }
    return \%Type;
}

# Rother OSS / ProcessTicketTemplates
sub _GetStandardTemplates {
    my ( $Self, %Param ) = @_;

    my %Templates;
    my $QueueID = $Param{QueueID} || '';

    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');
    my $QueueObject  = $Kernel::OM->Get('Kernel::System::Queue');

    if ( !$QueueID ) {
        my $DefaultQueue   = $ConfigObject->Get("Process::DefaultQueue");
        my $DefaultQueueID = $QueueObject->QueueLookup( Queue => $DefaultQueue );
        if ($DefaultQueueID) {
            $QueueID = $DefaultQueueID;
        }
    }

    # check needed
    return \%Templates if !$QueueID && !$Param{TicketID};

    if ( !$QueueID && $Param{TicketID} ) {

        # get QueueID from the ticket
        my %Ticket = $Kernel::OM->Get('Kernel::System::Ticket')->TicketGet(
            TicketID      => $Param{TicketID},
            DynamicFields => 0,
            UserID        => $Self->{UserID},
        );
        $QueueID = $Ticket{QueueID} || '';
    }

    # fetch all std. templates
    my %StandardTemplates = $QueueObject->QueueStandardTemplateMemberList(
        QueueID       => $QueueID,
        TemplateTypes => 1,
    );

    # return empty hash if there are no templates for this screen
    return \%Templates if !IsHashRefWithData( $StandardTemplates{ProcessDialog} );

    # return just the templates for this screen
    return $StandardTemplates{ProcessDialog};
}

# EO ProcessTicketTemplates
sub _ShowDialogError {
    my ( $Self, %Param ) = @_;

    my $LayoutObject = $Kernel::OM->Get('Kernel::Output::HTML::Layout');

    my $Output = $LayoutObject->Header( Type => 'Small' );
    $Output .= $LayoutObject->Error(%Param);
    $Output .= $LayoutObject->Footer( Type => 'Small' );
    return $Output;
}

sub _GetInputDefinitionDynamicFields {
    my ( $Self, %Param ) = @_;

    my $DynamicFieldObject = $Kernel::OM->Get('Kernel::System::DynamicField');
    my %DynamicField;

    # This subroutine takes a DFEntry and the DynamicFieldObject as arguments
    # It retrieves the dynamic field definition for the given DFEntry
    # If the definition is not available, it retrieves it from the DynamicFieldObject
    # Returns the dynamic field definition
    my $GetDynamicField = sub {

        my ($DFEntry) = @_;

        my $DynamicField = $DFEntry->{Definition} // $DynamicFieldObject->DynamicFieldGet(
            Name => $DFEntry->{DF},
        );

        return $DynamicField;
    };

    ITEM:
    for my $IncludeItem ( @{ $Param{InputFieldDefinition} } ) {

        if ( $IncludeItem->{Grid} ) {

            for my $Row ( @{ $IncludeItem->{Grid}{Rows} } ) {

                DFENTRY:
                for my $DFEntry ( $Row->@* ) {

                    my $DynamicField = $GetDynamicField->($DFEntry);
                    if ( IsHashRefWithData($DynamicField) ) {
                        $DynamicField->{Mandatory}      = $DFEntry->{Mandatory};
                        $DynamicField->{Readonly}       = $DFEntry->{Readonly};
                        $DynamicField{ $DFEntry->{DF} } = $DynamicField;
                    }
                    else {
                        $Kernel::OM->Get('Kernel::System::Log')->Log(
                            Priority => 'error',
                            Message  => "DynamicFieldConfig missing for field: $DFEntry->{DF}, or is not a Ticket Dynamic Field!",
                        );

                        next DFENTRY;
                    }
                }
            }
        }
        elsif ( $IncludeItem->{DF} ) {

            my $DynamicField = $GetDynamicField->($IncludeItem);
            if ($DynamicField) {
                $DynamicField->{Mandatory}          = $IncludeItem->{Mandatory};
                $DynamicField->{Readonly}           = $IncludeItem->{Readonly};
                $DynamicField{ $IncludeItem->{DF} } = $DynamicField;
            }
            else {
                $Kernel::OM->Get('Kernel::System::Log')->Log(
                    Priority => 'error',
                    Message  => "DynamicFieldConfig missing for field: $IncludeItem->{DF}, or is not a Ticket Dynamic Field!",
                );
                next ITEM;
            }
        }
        else {
            next ITEM;
        }
    }

    return \%DynamicField;
}

1;
</File>
        <File Location="Custom/Kernel/Output/HTML/Templates/Standard/AdminProcessManagementActivityDialog.tt" Permission="660" Encode="Base64"># --
# OTOBO is a web-based ticketing system for service organisations.
# --
# Copyright (C) 2001-2020 OTRS AG, https://otrs.com/
# Copyright (C) 2019-2026 Rother OSS GmbH, https://otobo.io/
# --
# $origin: otobo - 6efdc7bf2a3325277cd79a60f0f2407f8ad59e87 - Kernel/Output/HTML/Templates/Standard/AdminProcessManagementActivityDialog.tt
# --
# This program is free software: you can redistribute it and/or modify it under
# the terms of the GNU General Public License as published by the Free Software
# Foundation, either version 3 of the License, or (at your option) any later version.
# This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# --

<div class="LayoutPopup ARIARoleMain">
    <div class="Header">
        <h1>[% Translate(Data.Title) | html %]</h1>
[% RenderBlockStart("ClosePopup") %]
        <p>
            <a href="[% Env("Baselink") %]Action=[% Env("Action") %];Subaction=ClosePopup" class="ClosePopup">[% Translate("Cancel & close") | html %]</a>
        </p>
[% RenderBlockEnd("ClosePopup") %]
[% RenderBlockStart("GoBack") %]
        <p>
            <a class="GoBack" href="[% Env("Baselink") %]Action=[% Data.Action | uri %];Subaction=[% Data.Subaction | uri %];ID=[% Data.ID | uri %];EntityID=[% Data.EntityID | uri %]">[% Translate("Go Back") | html %]</a>
        </p>
[% RenderBlockEnd("GoBack") %]
    </div>
    <div class="Content">
        <div class="ContentColumn">
            <form id='ActivityDialogForm' action="[% Env("CGIHandle") %]" method="post" class="Validate PreventMultipleSubmits">
                <input type="hidden" name="Action" value="[% Env("Action") %]"/>
                <input type="hidden" name="Subaction" value="ActivityDialog[% Data.Action | html %]Action"/>
                <input type="hidden" name="EntityID" value="[% Data.EntityID | html %]"/>
                <input type="hidden" name="ID" value="[% Data.ID | html %]"/>
                <input type="hidden" name="Fields" value=""/>
                <input type="hidden" name="FieldDetails" value=""/>
                <input type="hidden" name="PopupRedirect" value="" id="PopupRedirect"/>
                <input type="hidden" name="PopupRedirectAction" value="" id="PopupRedirectAction"/>
                <input type="hidden" name="PopupRedirectSubaction" value="" id="PopupRedirectSubaction"/>
                <input type="hidden" name="PopupRedirectID" value="" id="PopupRedirectID"/>
                <input type="hidden" name="PopupRedirectEntityID" value="" id="PopupRedirectEntityID"/>

[% RenderBlockStart("EditWarning") %]
                <div class="WidgetSimple Expanded WidgetNotice">
                    <div class="Content">[% Translate("Please note that changing this activity dialog will affect the following activities") | html %]: [% Data.ActivityList | html %]</div>
                </div>
[% RenderBlockEnd("EditWarning") %]

                <div class="WidgetSimple Expanded WidgetNotice">

                    <div class="Content">
                        [% Translate("Please note that customer users will not be able to see or use the following fields: Owner, Responsible, Lock, PendingTime and CustomerID.") | html %]
                        [% Translate("The Queue field can only be used by customers when creating a new ticket.") | html %]
                    </div>
                </div>

                <div class="WidgetSimple Expanded">
                    <div class="Header">
                        <div class="WidgetAction Toggle">
                            <a href="#" title="[% Translate("Show or hide the content") | html %]"><i class="fa fa-caret-right"></i><i class="fa fa-caret-down"></i></a>
                        </div>
                        <h2>[% Translate("Activity Dialog") | html %]</h2>
                    </div>
                    <div class="Content">
                        <fieldset class="TableLike">
                            <label class="Mandatory" for="Name"><span class="Marker">*</span> [% Translate("Activity dialog Name") | html %]:</label>
                            <div class="Field">
                                <input type="text" name="Name" id="Name" value="[% Data.Name | html %]" class="W50pc Validate_Required [% Data.NameServerError | html %]" maxlength="70"/>
                                <div id="NameError" class="TooltipErrorMessage">
                                    <p>[% Translate("This field is required.") | html %]</p>
                                </div>
                                <div id="NameServerError" class="TooltipErrorMessage">
                                    <p>[% Translate("This field is required.") | html %]</p>
                                </div>
                            </div>
                            <div class="Clear"></div>

                            <label class="Mandatory" for="Interface">[% Translate("Available in") | html %]:</label>
                            <div class="Field">
                                [% Data.InterfaceSelection %]
                            </div>
                            <div class="Clear"></div>

                            <label class="Mandatory" for="DescriptionShort"><span class="Marker">*</span> [% Translate("Description (short)") | html %]:</label>
                            <div class="Field">
                                <input type="text" name="DescriptionShort" id="DescriptionShort" value="[% Data.DescriptionShort | html %]" class="W50pc Validate_Required [% Data.DescriptionShortServerError | html %]" maxlength="70"/>
                                <div id="DescriptionShortError" class="TooltipErrorMessage">
                                    <p>[% Translate("This field is required.") | html %]</p>
                                </div>
                                <div id="DescriptionShortServerError" class="TooltipErrorMessage">
                                    <p>[% Translate("This field is required.") | html %]</p>
                                </div>
                            </div>
                            <div class="Clear"></div>

                            <label for="DescriptionLong">[% Translate("Description (long)") | html %]:</label>
                            <div class="Field">
                                <textarea name="DescriptionLong" id="DescriptionLong" class="W50pc" rows="10" cols="20">[% Data.DescriptionLong | html %]</textarea>
                            </div>
                            <div class="Clear"></div>

                            <label for="Permission">[% Translate("Permission") | html %]:</label>
                            <div class="Field">
                                [% Data.PermissionSelection %]
                            </div>
                            <div id="PermissionServerError" class="TooltipErrorMessage">
                                <p>[% Translate("The selected permission does not exist.") | html %]</p>
                            </div>
                            <div class="Clear"></div>

                            <label for="RequiredLock">[% Translate("Required Lock") | html %]:</label>
                            <div class="Field">
                                [% Data.RequiredLockSelection %]
                            </div>
                            <div id="RequiredLockServerError" class="TooltipErrorMessage">
                                <p>[% Translate("The selected required lock does not exist.") | html %]</p>
                            </div>
                            <div class="Clear"></div>

                            <label for="SubmitAdviceText">[% Translate("Submit Advice Text") | html %]:</label>
                            <div class="Field">
                                <input type="text" name="SubmitAdviceText" id="SubmitAdviceText" value="[% Data.SubmitAdviceText | html %]" class="W50pc" maxlength="70"/>
                            </div>
                            <div class="Clear"></div>

                            <label for="SubmitButtonText">[% Translate("Submit Button Text") | html %]:</label>
                            <div class="Field">
                                <input type="text" name="SubmitButtonText" id="SubmitButtonText" value="[% Data.SubmitButtonText | html %]" class="W50pc" maxlength="70"/>
                            </div>
                            <div class="Clear"></div>

                            <label for="InputFieldDefinition">[% Translate("Input Field Definition") | html %]:</label>
                            <div class="Field">
                                <div class="CodeMirrorContainer">
                                    <div id="CMToolbarContainer" class="CMToolbarContainer Hidden">
                                        <div id="CMToolbarIcons" class="CMToolbarIcons">
                                            <div title="[% Translate("Auto Indent Code") | html %]" class="CMIndent" onclick="Core.UI.CodeMirrorEditor.IndentCode();"></div>
                                            <div title="[% Translate("Comment/Uncomment Code") | html %]" class="CMComment" onclick="Core.UI.CodeMirrorEditor.ToogleComment();"></div>
                                            <div title="[% Translate("Search") | html %]" class="CMSearch" onclick="Core.UI.CodeMirrorEditor.Search();"></div>
                                            <div title="[% Translate("Search & Replace") | html %]" class="CMSearchReplace" onclick="Core.UI.CodeMirrorEditor.SearchReplace();"></div>
                                            <div title="[% Translate("Select All") | html %]" class="CMSelectAll" onclick="Core.UI.CodeMirrorEditor.SelectAll();"></div>
                                            <div title="[% Translate("Full Screen") | html %]" class="CMMaximize" onclick="Core.UI.CodeMirrorEditor.ToogleFullScreen('Maximize');"></div>
                                        </div>
                                    </div>

                                    <textarea name="InputFieldDefinition" id="InputFieldDefinition" class="CodeMirrorEditor W50pc" rows="10" cols="20">[% Data.InputFieldDefinition | html %]</textarea>
                                </div>
                                <p class="FieldExplanation">
                                    [% Translate("The editing field allows you to use different functions like automatic formatting, window resize as well as tag- and bracket-completion.") | html %]
                                </p>

                            </div>
                            <div class="Clear"></div>

                            <label for="DirectSubmit">[% Translate("Direct submit") | html %]:</label>
                            <div class="Field">
                                <input type="checkbox" name="DirectSubmit" id="DirectSubmit" value="1" [% Data.DirectSubmit | html %] />
                                <p class="Warning Hidden">[% Translate("This property won't take effect because there are fields configured as visible.") | html %]</p>
                            </div>
                            <div class="Clear"></div>
                        </fieldset>
                    </div>
                </div>

                <div class="WidgetSimple Expanded">
                    <div class="Header">
                        <div class="WidgetAction Toggle">
                            <a href="#" title="[% Translate("Show or hide the content") | html %]"><i class="fa fa-caret-right"></i><i class="fa fa-caret-down"></i></a>
                        </div>
                        <h2>[% Translate("Fields") | html %]</h2>
                    </div>
                    <div class="Content LayoutGrid">
                        <div class="Size1of1 SpacingBottom">
                            <p>
                                [% Translate("You can assign Fields to this Activity Dialog by dragging the elements with the mouse from the left list to the right list.") | html %]
                                [% Translate("Ordering the elements within the list is also possible by drag 'n' drop.") | html %]
                            </p>
                        </div>
                        <div class="Size1of2">
                            <input type="text" id="FilterAvailableFields" class="W75pc" name="FilterAvailableFields" value="" title="[% Translate("Filter available fields") | html %]" placeholder="[% Translate("Filter available fields") | html %]..." />
                            <ul class="Tablelike W90pc SpacingTop">
                                <li class="Header">
                                    [% Translate("Available Fields") | html %]
                                </li>
                            </ul>
                            <ul class="AllocationList Tablelike W90pc" id="AvailableFields">
[% RenderBlockStart("AvailableFieldRow") %]
                                <li title="[% Data.FieldnameTranslated | html %]" data-name-translated="[% Data.FieldnameTranslated | html %]" data-id="[% Data.Field | html %]" data-config="">
                                    [% Data.FieldnameTranslated | html %]
                                    <span class="Functions ShowOnAssignedList">
                                        <a href="#" data-id="[% Data.Field | html %]" data-entity="[% Data.Field | html %]" class="FieldDetailsOverlay Icon" title="[% Translate("Edit") | html %]">
                                            <i class="fa fa-edit"></i>
                                        </a>
                                    </span>
                                </li>
[% RenderBlockEnd("AvailableFieldRow") %]
                            </ul>
                        </div>
                        <div class="Size1of2">
                            <ul class="Tablelike W90pc">
                                <li class="Header">
                                    [% Translate("Assigned Fields") | html %]
                                </li>
                            </ul>
                            <ul class="AllocationList Tablelike W90pc" id="AssignedFields">
[% RenderBlockStart("AssignedFieldRow") %]
                                <li data-name-translated="[% Translate(Data.Field) | html %]" data-id="[% Data.Field | html %]" data-entity="[% Data.Field | html %]" data-config="[% Data.FieldConfig | html %]" title="Name: [% Translate(Data.Field) | html %]">
                                    [% Translate(Data.Field) | html %]
                                    <span class="Functions ShowOnAssignedList">
                                        <a href="#" data-id="[% Data.Field | html %]" data-entity="[% Data.Field | html %]" class="FieldDetailsOverlay Icon" title="[% Translate("Edit") | html %]">
                                            <i class="fa fa-edit"></i>
                                        </a>
                                    </span>
                                </li>
[% RenderBlockEnd("AssignedFieldRow") %]
                            </ul>
                        </div>
                    </div>
                </div>
<!-- Invisible submit button to allow form submit on pressing enter/return without javascript -->
                <input type="image" width="0" height="0" style="display: none;" />
            </form>
        </div>
    </div>
    <div class="Footer">
        <button class="Primary CallForAction" id="Submit" title="[% Translate("Save") | html %]" type="submit" value="[% Translate("Save") | html %]"><span>[% Translate("Save") | html %]</span></button>
    </div>
</div>

<div id="Dialogs" class="Hidden">
    <div id="FieldDetails">
        <div style="width: 500px;">
            <fieldset class="TableLike">
                <label for="DescShort">[% Translate("Description (short)") | html %]:</label>
                <div class="Field">
                    <input type="text" name="DescShort" id="DescShort" value="" class="W50pc" maxlength="70"/>
                </div>
                <div class="Clear"></div>

                <label for="DescLong">[% Translate("Description (long)") | html %]:</label>
                <div class="Field">
                    <textarea name="DescLong" id="DescLong" class="W50pc"></textarea>
                </div>
                <div class="Clear"></div>

                <label for="DefaultValue">[% Translate("Default value") | html %]:</label>
                <div class="Field">
                    <input type="text" name="DefaultValue" id="DefaultValue" value="" class="W50pc" />
                </div>
                <div class="Clear"></div>

                <label for="CommunicationChannel">[% Translate("Communication Channel") | html %]:</label>
                <div class="Field" id="CommunicationChannelContainer" class='Hidden'>
                    [% Data.CommunicationChannelSelection %]
                </div>
                <div class="Clear"></div>

                <label for="IsVisibleForCustomer">[% Translate("Is visible for customer") | html %]:</label>
                <div class="Field" id="IsVisibleForCustomerContainer" class='Hidden'>
                    <input type="checkbox" name="IsVisibleForCustomer" id="IsVisibleForCustomer"/>
                </div>
                <div class="Clear"></div>

[% RenderBlockStart("TimeUnitsContainer") %]
                <label for="TimeUnits">[% Translate("Time units") | html %]:</label>
                <div class="Field" id="TimeUnitsContainer" class="Hidden">
                    [% Data.TimeUnitsSelection %]
                </div>
                <div class="Clear"></div>
[% RenderBlockEnd("TimeUnitsContainer") %]

# Rother OSS / ProcessTicketTemplates
[% RenderBlockStart("StandardTemplatesContainer") %]
                <label for="StandardTemplates">[% Translate("Standard Templates") | html %]:</label>
                <div class="Field" id="StandardTemplatesContainer" class='Hidden'>
                    <input type="checkbox" name="StandardTemplates" id="StandardTemplates"/>
                </div>
                <div class="Clear"></div>
[% RenderBlockEnd("StandardTemplatesContainer") %]

# EO ProcessTicketTemplates
                <label for="Display">[% Translate("Display") | html %]:</label>
                <div class="Field">
                    [% Data.DisplaySelection %]
                </div>
                <div class="Clear"></div>
            </fieldset>
        </div>
    </div>
</div>
</File>
        <File Location="Custom/Kernel/Output/HTML/Templates/Standard/ProcessManagement/Article.tt" Permission="660" Encode="Base64">IyAtLQojIE9UT0JPIGlzIGEgd2ViLWJhc2VkIHRpY2tldGluZyBzeXN0ZW0gZm9yIHNlcnZpY2Ugb3JnYW5pc2F0aW9ucy4KIyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDIwIE9UUlMgQUcsIGh0dHBzOi8vb3Rycy5jb20vCiMgQ29weXJpZ2h0IChDKSAyMDE5LTIwMjYgUm90aGVyIE9TUyBHbWJILCBodHRwczovL290b2JvLmlvLwojIC0tCiMgJG9yaWdpbjogb3RvYm8gLSBmZjllMjk3YmFmMjg3ZTE2MDcxZDNhYzZhZDdmNmMxM2YxMWFjN2ZhIC0gS2VybmVsL091dHB1dC9IVE1ML1RlbXBsYXRlcy9TdGFuZGFyZC9Qcm9jZXNzTWFuYWdlbWVudC9BcnRpY2xlLnR0CiMgLS0KIyBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTogeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeSBpdCB1bmRlcgojIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMgcHVibGlzaGVkIGJ5IHRoZSBGcmVlIFNvZnR3YXJlCiMgRm91bmRhdGlvbiwgZWl0aGVyIHZlcnNpb24gMyBvZiB0aGUgTGljZW5zZSwgb3IgKGF0IHlvdXIgb3B0aW9uKSBhbnkgbGF0ZXIgdmVyc2lvbi4KIyBUaGlzIHByb2dyYW0gaXMgZGlzdHJpYnV0ZWQgaW4gdGhlIGhvcGUgdGhhdCBpdCB3aWxsIGJlIHVzZWZ1bCwgYnV0IFdJVEhPVVQKIyBBTlkgV0FSUkFOVFk7IHdpdGhvdXQgZXZlbiB0aGUgaW1wbGllZCB3YXJyYW50eSBvZiBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUwojIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gU2VlIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBmb3IgbW9yZSBkZXRhaWxzLgojIFlvdSBzaG91bGQgaGF2ZSByZWNlaXZlZCBhIGNvcHkgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlCiMgYWxvbmcgd2l0aCB0aGlzIHByb2dyYW0uIElmIG5vdCwgc2VlIDxodHRwczovL3d3dy5nbnUub3JnL2xpY2Vuc2VzLz4uCiMgLS0KWyUgUmVuZGVyQmxvY2tTdGFydCgicnc6QXJ0aWNsZSIpICVdCgpbJSBSZW5kZXJCbG9ja1N0YXJ0KCJydzpBcnRpY2xlOkluZm9ybUFnZW50IikgJV0KPGxhYmVsIGZvcj0iSW5mb3JtVXNlcklEIj5bJSBUcmFuc2xhdGUoIkluZm9ybSBBZ2VudCIpIHwgaHRtbCAlXTo8L2xhYmVsPgo8ZGl2IGNsYXNzPSJGaWVsZCI+CiAgICBbJSBEYXRhLk9wdGlvblN0cmcgJV0KPC9kaXY+CjxkaXYgY2xhc3M9IkNsZWFyIj48L2Rpdj4KWyUgUmVuZGVyQmxvY2tFbmQoInJ3OkFydGljbGU6SW5mb3JtQWdlbnQiKSAlXQoKPGxhYmVsIGNsYXNzPSJbJSBEYXRhLk1hbmRhdG9yeUNsYXNzIHwgaHRtbCAlXSIgZm9yPSJTdWJqZWN0Ij4KWyUgUmVuZGVyQmxvY2tTdGFydCgiTGFiZWxTcGFuU3ViamVjdCIpICVdCiAgICA8c3BhbiBjbGFzcz0iTWFya2VyIj4qPC9zcGFuPgpbJSBSZW5kZXJCbG9ja0VuZCgiTGFiZWxTcGFuU3ViamVjdCIpICVdCiAgICBbJSBEYXRhLkxhYmVsU3ViamVjdCB8IGh0bWwgJV06CjwvbGFiZWw+CjxkaXYgY2xhc3M9IkZpZWxkIj4KICAgIDxpbnB1dCB0eXBlPSJ0ZXh0IiBpZD0iU3ViamVjdCIgbmFtZT0iU3ViamVjdCIgdmFsdWU9IlslIERhdGEuU3ViamVjdCB8IGh0bWwgJV0iIGNsYXNzPSJXNzVwYyBbJSBEYXRhLlZhbGlkYXRlUmVxdWlyZWQgfCBodG1sICVdIFslIERhdGEuU3ViamVjdFNlcnZlckVycm9yIHwgaHRtbCAlXSBWYWxpZGF0ZV9EZXBlbmRpbmdSZXF1aXJlZEFORCBWYWxpZGF0ZV9EZXBlbmRpbmdfUmljaFRleHQgVmFsaWRhdGVfRGVwZW5kaW5nX0F0dGFjaG1lbnRFeGlzdHMgVmFsaWRhdGVfRGVwZW5kaW5nX1RpbWVVbml0cyIvPgogICAgPGRpdiBpZD0iU3ViamVjdEVycm9yIiBjbGFzcz0iVG9vbHRpcEVycm9yTWVzc2FnZSI+PHA+WyUgVHJhbnNsYXRlKCJUaGlzIGZpZWxkIGlzIHJlcXVpcmVkLiIpIHwgaHRtbCAlXTwvcD48L2Rpdj4KICAgIDxkaXYgaWQ9IlN1YmplY3RTZXJ2ZXJFcnJvciIgY2xhc3M9IlRvb2x0aXBFcnJvck1lc3NhZ2UiPjxwPlslIFRyYW5zbGF0ZSgiVGhpcyBmaWVsZCBpcyByZXF1aXJlZC4iKSB8IGh0bWwgJV08L3A+PC9kaXY+CjwvZGl2Pgo8ZGl2IGNsYXNzPSJDbGVhciI+PC9kaXY+CgpbJSBSZW5kZXJCbG9ja1N0YXJ0KCJydzpBcnRpY2xlOkRlc2NyaXB0aW9uU2hvcnQiKSAlXQo8ZGl2IGNsYXNzPSJGaWVsZCBGaWVsZEV4cGxhbmF0aW9uIj5bJSBUcmFuc2xhdGUoRGF0YS5EZXNjcmlwdGlvblNob3J0KSB8IGh0bWwgJV08L2Rpdj4KWyUgUmVuZGVyQmxvY2tFbmQoInJ3OkFydGljbGU6RGVzY3JpcHRpb25TaG9ydCIpICVdCgojIFJvdGhlciBPU1MgLyBQcm9jZXNzVGlja2V0VGVtcGxhdGVzClslIFJlbmRlckJsb2NrU3RhcnQoIlN0YW5kYXJkVGVtcGxhdGUiKSAlXQogICAgICAgICAgICAgICAgICAgIDxsYWJlbCBmb3I9IlN0YW5kYXJkVGVtcGxhdGVJRCI+WyUgVHJhbnNsYXRlKCJUZXh0IFRlbXBsYXRlIikgfCBodG1sICVdOjwvbGFiZWw+CiAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzcz0iRmllbGQiPgogICAgICAgICAgICAgICAgICAgICAgICBbJSBEYXRhLlN0YW5kYXJkVGVtcGxhdGVTdHJnICVdCiAgICAgICAgICAgICAgICAgICAgICAgIDxwIGNsYXNzPSJGaWVsZEV4cGxhbmF0aW9uIj5bJSBUcmFuc2xhdGUoIlNldHRpbmcgYSB0ZW1wbGF0ZSB3aWxsIG92ZXJ3cml0ZSBhbnkgdGV4dCBvciBhdHRhY2htZW50LiIpIHwgaHRtbCAlXTwvcD4KICAgICAgICAgICAgICAgICAgICA8L2Rpdj4KICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPSJDbGVhciI+PC9kaXY+ClslIFJlbmRlckJsb2NrRW5kKCJTdGFuZGFyZFRlbXBsYXRlIikgJV0KCiMgRU8gUHJvY2Vzc1RpY2tldFRlbXBsYXRlcwo8bGFiZWwgY2xhc3M9IlslIERhdGEuTWFuZGF0b3J5Q2xhc3MgfCBodG1sICVdIiBmb3I9IlJpY2hUZXh0Ij4KWyUgUmVuZGVyQmxvY2tTdGFydCgiTGFiZWxTcGFuQm9keSIpICVdCiAgICA8c3BhbiBjbGFzcz0iTWFya2VyIj4qPC9zcGFuPgpbJSBSZW5kZXJCbG9ja0VuZCgiTGFiZWxTcGFuQm9keSIpICVdClslIFJlbmRlckJsb2NrU3RhcnQoInJ3OkFydGljbGU6RGVzY3JpcHRpb25Mb25nIikgJV0KICAgIDxzcGFuIGNsYXNzPSJGaWVsZEhlbHBDb250YWluZXIiPgogICAgICAgIDxpIGNsYXNzPSJmYSBmYS1xdWVzdGlvbi1jaXJjbGUgRmllbGRIZWxwVHJpZ2dlciI+PC9pPgogICAgICAgIDxzcGFuPlslIFRyYW5zbGF0ZShEYXRhLkRlc2NyaXB0aW9uTG9uZykgfCBodG1sICVdPC9zcGFuPgogICAgPC9zcGFuPgpbJSBSZW5kZXJCbG9ja0VuZCgicnc6QXJ0aWNsZTpEZXNjcmlwdGlvbkxvbmciKSAlXQogICAgWyUgRGF0YS5MYWJlbEJvZHkgfCBodG1sICVdOgo8L2xhYmVsPgo8ZGl2IGNsYXNzPSJSaWNoVGV4dEZpZWxkIj4KICAgIDx0ZXh0YXJlYSBpZD0iUmljaFRleHQiIGNsYXNzPSJSaWNoVGV4dCBbJSBEYXRhLlZhbGlkYXRlUmVxdWlyZWQgfCBodG1sICVdIFslIERhdGEuQm9keVNlcnZlckVycm9yIHwgaHRtbCAlXSBWYWxpZGF0ZV9EZXBlbmRpbmdSZXF1aXJlZEFORCBWYWxpZGF0ZV9EZXBlbmRpbmdfU3ViamVjdCBWYWxpZGF0ZV9EZXBlbmRpbmdfQXR0YWNobWVudEV4aXN0cyBWYWxpZGF0ZV9EZXBlbmRpbmdfVGltZVVuaXRzIiBuYW1lPSJCb2R5IiByb3dzPSIxNSIgY29scz0iWyUgQ29uZmlnKCJUaWNrZXQ6OkZyb250ZW5kOjpUZXh0QXJlYU5vdGUiKSAlXSI+WyUgRGF0YS5Cb2R5IHwgaHRtbCAlXTwvdGV4dGFyZWE+CiAgICA8ZGl2IGlkPSJSaWNoVGV4dEVycm9yIiBjbGFzcz0iVG9vbHRpcEVycm9yTWVzc2FnZSI+PHA+WyUgVHJhbnNsYXRlKCJUaGlzIGZpZWxkIGlzIHJlcXVpcmVkLiIpIHwgaHRtbCAlXTwvcD48L2Rpdj4KICAgIDxkaXYgaWQ9IlJpY2hUZXh0U2VydmVyRXJyb3IiIGNsYXNzPSJUb29sdGlwRXJyb3JNZXNzYWdlIj48cD5bJSBUcmFuc2xhdGUoIlRoaXMgZmllbGQgaXMgcmVxdWlyZWQuIikgfCBodG1sICVdPC9wPjwvZGl2Pgo8L2Rpdj4KPGRpdiBjbGFzcz0iQ2xlYXIiPjwvZGl2PgoKPGxhYmVsPlslIFRyYW5zbGF0ZSgiQXR0YWNobWVudHMiKSB8IGh0bWwgJV06PC9sYWJlbD4KICAgIDxkaXYgY2xhc3M9IkZpZWxkIj4KICAgICAgICA8ZGl2IGNsYXNzPSJEbkRVcGxvYWRCb3giPgpbJSBJTkNMVURFICJGb3JtRWxlbWVudHMvQXR0YWNobWVudExpc3QudHQiICVdCiAgICAgICAgPC9kaXY+CiAgICA8L2Rpdj4KPGRpdiBjbGFzcz0iQ2xlYXIiPjwvZGl2PgoKWyUgUmVuZGVyQmxvY2tTdGFydCgiVGltZVVuaXRzTGFiZWwiKSAlXQo8bGFiZWwgZm9yPSJUaW1lVW5pdHMiPlslIFRyYW5zbGF0ZSgiVGltZSB1bml0cyIpIHwgaHRtbCAlXSBbJSBUcmFuc2xhdGUoQ29uZmlnKCJUaWNrZXQ6OkZyb250ZW5kOjpUaW1lVW5pdHMiKSkgfCBodG1sICVdOjwvbGFiZWw+ClslIFJlbmRlckJsb2NrRW5kKCJUaW1lVW5pdHNMYWJlbCIpICVdClslIFJlbmRlckJsb2NrU3RhcnQoIlRpbWVVbml0c0xhYmVsTWFuZGF0b3J5IikgJV0KPGxhYmVsIGNsYXNzPSJNYW5kYXRvcnkiIGZvcj0iVGltZVVuaXRzIj48c3BhbiBjbGFzcz0iTWFya2VyIj4qPC9zcGFuPiBbJSBUcmFuc2xhdGUoIlRpbWUgdW5pdHMiKSB8IGh0bWwgJV0gWyUgVHJhbnNsYXRlKENvbmZpZygiVGlja2V0OjpGcm9udGVuZDo6VGltZVVuaXRzIikpIHwgaHRtbCAlXTo8L2xhYmVsPgpbJSBSZW5kZXJCbG9ja0VuZCgiVGltZVVuaXRzTGFiZWxNYW5kYXRvcnkiKSAlXQpbJSBSZW5kZXJCbG9ja1N0YXJ0KCJUaW1lVW5pdHMiKSAlXQo8ZGl2IGNsYXNzPSJGaWVsZCI+CiAgICA8aW5wdXQgdHlwZT0idGV4dCIgY2xhc3M9Ilc1MHBjIFZhbGlkYXRlX1RpbWVVbml0cyBbJSBEYXRhLlRpbWVVbml0c1JlcXVpcmVkIHwgaHRtbCAlXSBbJSBEYXRhLlRpbWVVbml0c0ludmFsaWQgfCBodG1sICVdIiBuYW1lPSJUaW1lVW5pdHMiIGlkPSJUaW1lVW5pdHMiIHZhbHVlPSJbJSBEYXRhLlRpbWVVbml0cyB8IGh0bWwgJV0iIC8+CiAgICA8ZGl2IGlkPSJUaW1lVW5pdHNFcnJvciIgY2xhc3M9IlRvb2x0aXBFcnJvck1lc3NhZ2UiPjxwPlslIFRyYW5zbGF0ZSgiSW52YWxpZCB0aW1lISIpIHwgaHRtbCAlXTwvcD48L2Rpdj4KICAgIDxkaXYgaWQ9IlRpbWVVbml0c1NlcnZlckVycm9yIiBjbGFzcz0iVG9vbHRpcEVycm9yTWVzc2FnZSI+PHA+WyUgVHJhbnNsYXRlKCJUaGlzIGZpZWxkIGlzIHJlcXVpcmVkLiIpIHwgaHRtbCAlXTwvcD48L2Rpdj4KPC9kaXY+CjxkaXYgY2xhc3M9IkNsZWFyIj48L2Rpdj4KWyUgUmVuZGVyQmxvY2tFbmQoIlRpbWVVbml0cyIpICVdClslIFJlbmRlckJsb2NrRW5kKCJydzpBcnRpY2xlIikgJV0K</File>
        <File Location="Kernel/Config/Files/XML/ProcessTicketTemplates.xml" Permission="660" Encode="Base64">PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiID8+CjxvdG9ib19jb25maWcgdmVyc2lvbj0iMi4wIiBpbml0PSJDaGFuZ2VzIj4KICAgIDxTZXR0aW5nIE5hbWU9IlN0YW5kYXJkVGVtcGxhdGU6OlR5cGVzIiBSZXF1aXJlZD0iMCIgVmFsaWQ9IjEiPgogICAgICAgIDxEZXNjcmlwdGlvbiBUcmFuc2xhdGFibGU9IjEiPkRlZmluZXMgdGhlIGxpc3Qgb2YgdHlwZXMgZm9yIHRlbXBsYXRlcy48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxOYXZpZ2F0aW9uPkNvcmU6OlRpY2tldDwvTmF2aWdhdGlvbj4KICAgICAgICA8VmFsdWU+CiAgICAgICAgICAgIDxIYXNoPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJBbnN3ZXIiIFRyYW5zbGF0YWJsZT0iMSI+QW5zd2VyPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJDcmVhdGUiIFRyYW5zbGF0YWJsZT0iMSI+Q3JlYXRlPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJGb3J3YXJkIiBUcmFuc2xhdGFibGU9IjEiPkZvcndhcmQ8L0l0ZW0+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IkVtYWlsIiBUcmFuc2xhdGFibGU9IjEiPkVtYWlsPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJQaG9uZUNhbGwiIFRyYW5zbGF0YWJsZT0iMSI+UGhvbmUgY2FsbDwvSXRlbT4KICAgICAgICAgICAgICAgIDxJdGVtIEtleT0iTm90ZSIgVHJhbnNsYXRhYmxlPSIxIj5Ob3RlPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJQcm9jZXNzRGlhbG9nIiBUcmFuc2xhdGFibGU9IjEiPlByb2Nlc3MgZGlhbG9nPC9JdGVtPgogICAgICAgICAgICA8L0hhc2g+CiAgICAgICAgPC9WYWx1ZT4KICAgIDwvU2V0dGluZz4KPC9vdG9ib19jb25maWc+Cg==</File>
        <File Location="Kernel/Language/de_ProcessTicketTemplates.pm" Permission="660" Encode="Base64">IyAtLQojIE9UT0JPIGlzIGEgd2ViLWJhc2VkIHRpY2tldGluZyBzeXN0ZW0gZm9yIHNlcnZpY2Ugb3JnYW5pc2F0aW9ucy4KIyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDIwIE9UUlMgQUcsIGh0dHBzOi8vb3Rycy5jb20vCiMgQ29weXJpZ2h0IChDKSAyMDE5LTIwMjYgUm90aGVyIE9TUyBHbWJILCBodHRwczovL290b2JvLmlvLwojIC0tCiMgVGhpcyBwcm9ncmFtIGlzIGZyZWUgc29mdHdhcmU6IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9vciBtb2RpZnkgaXQgdW5kZXIKIyB0aGUgdGVybXMgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGFzIHB1Ymxpc2hlZCBieSB0aGUgRnJlZSBTb2Z0d2FyZQojIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uCiMgVGhpcyBwcm9ncmFtIGlzIGRpc3RyaWJ1dGVkIGluIHRoZSBob3BlIHRoYXQgaXQgd2lsbCBiZSB1c2VmdWwsIGJ1dCBXSVRIT1VUCiMgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YgTUVSQ0hBTlRBQklMSVRZIG9yIEZJVE5FU1MKIyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuIFNlZSB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy4KIyBZb3Ugc2hvdWxkIGhhdmUgcmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZQojIGFsb25nIHdpdGggdGhpcyBwcm9ncmFtLiBJZiBub3QsIHNlZSA8aHR0cHM6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy8+LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6TGFuZ3VhZ2U6OmRlX1Byb2Nlc3NUaWNrZXRUZW1wbGF0ZXM7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBZG1pblByb2Nlc3NNYW5hZ2VtZW50QWN0aXZpdHlEaWFsb2cKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N0YW5kYXJkIFRlbXBsYXRlcyd9ID0gJ1N0YW5kYXJkdm9ybGFnZW4nOwoKICAgICMgU3lzQ29uZmlnCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQcm9jZXNzIGRpYWxvZyd9ID0gJ1Byb3plc3MtRGlhbG9nJzsKCgogICAgcHVzaCBAeyAkU2VsZi0+e0phdmFTY3JpcHRTdHJpbmdzfSAvLyBbXSB9LCAoCiAgICAnQW4gdW5jb25uZWN0ZWQgdHJhbnNpdGlvbiBpcyBhbHJlYWR5IHBsYWNlZCBvbiB0aGUgY2FudmFzLiBQbGVhc2UgY29ubmVjdCB0aGlzIHRyYW5zaXRpb24gZmlyc3QgYmVmb3JlIHBsYWNpbmcgYW5vdGhlciB0cmFuc2l0aW9uLicsCiAgICAnQXMgc29vbiBhcyB5b3UgdXNlIHRoaXMgYnV0dG9uIG9yIGxpbmssIHlvdSB3aWxsIGxlYXZlIHRoaXMgc2NyZWVuIGFuZCBpdHMgY3VycmVudCBzdGF0ZSB3aWxsIGJlIHNhdmVkIGF1dG9tYXRpY2FsbHkuIERvIHlvdSB3YW50IHRvIGNvbnRpbnVlPycsCiAgICAnQ2FuY2VsJywKICAgICdDdXN0b21lciBpbnRlcmZhY2UgZG9lcyBub3Qgc3VwcG9ydCBhcnRpY2xlcyBub3QgdmlzaWJsZSBmb3IgY3VzdG9tZXJzLicsCiAgICAnRGVsZXRlJywKICAgICdEZWxldGUgRW50aXR5JywKICAgICdFZGl0IEZpZWxkIERldGFpbHMnLAogICAgJ0Vycm9yIGR1cmluZyBBSkFYIGNvbW11bmljYXRpb24nLAogICAgJ0hpZGUgRW50aXR5SURzJywKICAgICdTYXZlJywKICAgICdTaG93IEVudGl0eUlEcycsCiAgICAnU29ycnksIHRoZSBvbmx5IGV4aXN0aW5nIGNvbmRpdGlvbiBjYW5cJ3QgYmUgcmVtb3ZlZC4nLAogICAgJ1NvcnJ5LCB0aGUgb25seSBleGlzdGluZyBmaWVsZCBjYW5cJ3QgYmUgcmVtb3ZlZC4nLAogICAgJ1NvcnJ5LCB0aGUgb25seSBleGlzdGluZyBwYXJhbWV0ZXIgY2FuXCd0IGJlIHJlbW92ZWQuJywKICAgICdUaGlzIEFjdGl2aXR5IGlzIGFscmVhZHkgdXNlZCBpbiB0aGUgUHJvY2Vzcy4gWW91IGNhbm5vdCBhZGQgaXQgdHdpY2UhJywKICAgICdUaGlzIFRyYW5zaXRpb24gaXMgYWxyZWFkeSB1c2VkIGZvciB0aGlzIEFjdGl2aXR5LiBZb3UgY2Fubm90IHVzZSBpdCB0d2ljZSEnLAogICAgJ1RoaXMgVHJhbnNpdGlvbkFjdGlvbiBpcyBhbHJlYWR5IHVzZWQgaW4gdGhpcyBQYXRoLiBZb3UgY2Fubm90IHVzZSBpdCB0d2ljZSEnLAogICAgKTsKCn0KCjE7Cg==</File>
        <File Location="var/httpd/htdocs/js/Core.Agent.Admin.ProcessManagement.js" Permission="660" Encode="Base64">// --
// OTOBO is a web-based ticketing system for service organisations.
// --
// Copyright (C) 2001-2020 OTRS AG, https://otrs.com/
// Copyright (C) 2019-2026 Rother OSS GmbH, https://otobo.io/
// --
// $origin: otobo - 6efdc7bf2a3325277cd79a60f0f2407f8ad59e87 - var/httpd/htdocs/js/Core.Agent.Admin.ProcessManagement.js
// --
// This program is free software: you can redistribute it and/or modify it under
// the terms of the GNU General Public License as published by the Free Software
// Foundation, either version 3 of the License, or (at your option) any later version.
// This program is distributed in the hope that it will be useful, but WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
// FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
// --

/*eslint-disable otobo/no-window*/

"use strict";

var Core = Core || {};
Core.Agent = Core.Agent || {};
Core.Agent.Admin = Core.Agent.Admin || {};

/**
 * @namespace Core.Agent.Admin.ProcessManagement
 * @memberof Core.Agent.Admin
 * @author
 * @description
 *      This namespace contains the special module functions for the ProcessManagement module.
 */
Core.Agent.Admin.ProcessManagement = (function (TargetNS) {

    /**
     * @name Init
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      This function initializes the module functionality.
     */
    TargetNS.Init = function () {
        var Subaction = Core.Config.Get('Subaction');

        // Initialize Popup
        InitProcessPopups();

        // Initialize Popup response (Redirect and close Popup)
        InitProcessPopupsResponse();

        // Initialize table filter
        Core.UI.Table.InitTableFilter($('#Filter'), $('#Processes'), 0);

        // init checkbox to include invalid elements
        $('input#IncludeInvalid').off('change').on('change', function () {
            var URL = Core.Config.Get("Baselink") + 'Action=' + Core.Config.Get("Action") + ';IncludeInvalid=' + ( $(this).is(':checked') ? 1 : 0 );
            window.location.href = URL;
        });

        // Depending on Subaction initialize specific functions
        if (Subaction === 'ActivityNew' ||
            Subaction === 'ActivityNewAction' ||
            Subaction === 'ActivityEdit' ||
            Subaction === 'ActivityEditAction') {
            TargetNS.InitActivityEdit();
        }
        else if (Subaction === 'ActivityDialogNew' ||
            Subaction === 'ActivityDialogNewAction' ||
            Subaction === 'ActivityDialogEdit' ||
            Subaction === 'ActivityDialogEditAction') {
            TargetNS.InitActivityDialogEdit();
        }
        else if (Subaction === 'TransitionNew' ||
            Subaction === 'TransitionNewAction' ||
            Subaction === 'TransitionEdit' ||
            Subaction === 'TransitionEditAction') {
            TargetNS.InitTransitionEdit();
        }
        else if (Subaction === 'TransitionActionNew' ||
            Subaction === 'TransitionActionNewAction' ||
            Subaction === 'TransitionActionEdit' ||
            Subaction === 'TransitionActionEditAction') {
            TargetNS.InitTransitionActionEdit();
        }
        else if (Subaction === 'ProcessEdit' ||
            Subaction === 'ProcessEditAction') {
            TargetNS.InitProcessEdit();
        }
        else if (Subaction === 'ProcessPrint') {
            $('.ProcessPrint').on('click', function() {
                window.print();
                return false;
            });
        }

        // Depending on Action initialize specific functions
        if (Core.Config.Get('Action') === 'AdminProcessManagementPath' && Subaction !== 'ClosePopup') {
           TargetNS.InitPathEdit();
        }
    };

    /**
     * @private
     * @name InitProcessPopups
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Initializes needed popup handler.
     */
    function InitProcessPopups() {
        $('a.AsPopup').on('click', function () {
            var Matches,
                PopupType = 'Process';

            Matches = $(this).attr('class').match(/PopupType_(\w+)/);
            if (Matches) {
                PopupType = Matches[1];
            }

            if (PopupType !== 'ProcessOverview') {
                TargetNS.ShowOverlay();
            }

            Core.UI.Popup.OpenPopup($(this).attr('href'), PopupType);
            return false;
        });

        $('a.AsPopup_Redirect').on('click', function () {
            var $Form = $(this).closest('form');

            $('#PopupRedirect').val(1);
            $('#PopupRedirectAction').val($(this).data('action'));
            $('#PopupRedirectSubaction').val($(this).data('subaction'));
            $('#PopupRedirectID').val($(this).data('id'));
            $('#PopupRedirectEntityID').val($(this).data('entity'));
            // Only used for path popup
            $('#PopupRedirectStartActivityID').val($(this).data('startactivityid'));

            if ($(this).hasClass('Edit_Confirm')) {
                if (window.confirm(Core.Language.Translate('As soon as you use this button or link, you will leave this screen and its current state will be saved automatically. Do you want to continue?'))) {
                    // Remove onbeforeunload event only if there is no validation pending on form submit
                    if (!($Form.hasClass("Validate"))) {
                        $(window).off("beforeunload.PMPopup");
                    }
                    $(this).closest('form').submit();
                }
            }
            else {
                // Remove onbeforeunload event only if there is no validation pending on form submit
                if (!($Form.hasClass("Validate"))) {
                    $(window).off("beforeunload.PMPopup");
                }
                $(this).closest('form').submit();
            }
            return false;
        });

        $('a.GoBack').on('click', function () {
            // Remove onbeforeunload event (which is only needed if you close the popup via the window "X")
            $(window).off("beforeunload.PMPopup");
        });
    }

    /**
     * @private
     * @name InitProcessPopupsResponse
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Initializes redirect and close popups response.
     */
    function InitProcessPopupsResponse() {
        var Redirect = Core.Config.Get('Redirect'),
            ClosePopup = Core.Config.Get('ClosePopup'),
            Data;

        if (typeof Redirect !== 'undefined') {

            Data = {
                Action: Redirect.Action,
                Subaction: Redirect.Subaction,
                ID: Redirect.ID,
                EntityID: Redirect.EntityID,
                Field: Redirect.Field,
                StartActivityID: Redirect.StartActivityID
            };

            // send results to main window
            window.opener.Core.Agent.Admin.ProcessManagement.UpdateConfig(Redirect.ConfigJSON);

            // reload popup
            Core.App.InternalRedirect(Data);
        }
        else if (typeof ClosePopup !== 'undefined') {

            window.opener.Core.Agent.Admin.ProcessManagement.UpdateScreensPath(window, function (WindowObject) {
                //send results to main window
                WindowObject.opener.Core.Agent.Admin.ProcessManagement.UpdateConfig(ClosePopup.ConfigJSON);

                // update accordion
                WindowObject.opener.Core.Agent.Admin.ProcessManagement.UpdateAccordion();

                // update sync message
                WindowObject.opener.Core.Agent.Admin.ProcessManagement.UpdateSyncMessage();

                // redraw canvas
                WindowObject.opener.Core.Agent.Admin.ProcessManagement.Canvas.Redraw();

                // remove overlay
                WindowObject.opener.Core.Agent.Admin.ProcessManagement.HideOverlay();

                // remove onbeforeunload event (which is only needed if you close the popup via the window "X")
                $(WindowObject).off("beforeunload.PMPopup");

                // close popup
                WindowObject.close();
            });
        }
    }

    /**
     * @private
     * @name ShowDeleteProcessConfirmationDialog
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @param {jQueryObject} $Element
     * @description
     *      Shows a confirmation dialog to delete processes.
     */
    function ShowDeleteProcessConfirmationDialog($Element) {
        var DialogElement = $Element.data('dialog-element'),
            DialogTitle = $Element.data('dialog-title'),
            ProcessID = $Element.data('id');

        Core.UI.Dialog.ShowContentDialog(
            $('#Dialogs #' + DialogElement),
            DialogTitle,
            '240px',
            'Center',
            true,
            [
               {
                   Label: Core.Language.Translate('Cancel'),
                   Function: function () {
                       Core.UI.Dialog.CloseDialog($('.Dialog'));
                   }
               },
               {
                   Label: Core.Language.Translate('Delete'),
                   Class: 'Primary',
                   Function: function () {
                       var Data = {
                               Action: 'AdminProcessManagement',
                               Subaction: 'ProcessDelete',
                               ID: ProcessID
                           };

                       // Change the dialog to an ajax loader
                       $('.Dialog')
                           .find('.ContentFooter').empty().end()
                           .find('.InnerContent').empty().append('<div class="Spacing Center"><span class="AJAXLoader"></span></div>');

                       // Call the ajax function
                       Core.AJAX.FunctionCall(Core.Config.Get('CGIHandle'), Data, function (Response) {
                           if (!Response || !Response.Success) {
                               alert(Response.Message);
                               Core.UI.Dialog.CloseDialog($('.Dialog'));
                               return false;
                           }

                           Core.App.InternalRedirect({
                               Action: Data.Action
                           });
                       }, 'json');
                   }
               }
           ]
        );
    }

    /**
     * @private
     * @name ShowDeleteEntityConfirmationDialog
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @param {jQueryObject} $Element
     * @param {String} EntityType
     * @param {String} EntityName
     * @param {String} EntityID
     * @param {String} ItemID
     * @description
     *      Shows a confirmation dialog to delete entities.
     */
    function ShowDeleteEntityConfirmationDialog($Element, EntityType, EntityName, EntityID, ItemID) {
        var DialogID = 'Delete' + EntityType + 'ConfirmationDialog',
            $DialogElement = $('#Dialogs #' + DialogID);

        // Update EntityName in Dialog
        $DialogElement.find('span.EntityName').text(EntityName);

        Core.UI.Dialog.ShowContentDialog(
            $('#Dialogs #' + DialogID),
            Core.Language.Translate('Delete Entity'),
            '240px',
            'Center',
            true,
            [
               {
                   Label: Core.Language.Translate('Cancel'),
                   Function: function () {
                       Core.UI.Dialog.CloseDialog($('.Dialog'));
                   }
               },
               {
                   Label: Core.Language.Translate('Delete'),
                   Class: 'Primary',
                   Function: function () {
                       var Data = {
                               Action: 'AdminProcessManagement',
                               Subaction: 'EntityDelete',
                               EntityType: EntityType,
                               EntityID: EntityID,
                               ItemID: ItemID
                           };

                       // Change the dialog to an ajax loader
                       $('.Dialog')
                           .find('.ContentFooter').empty().end()
                           .find('.InnerContent').empty().append('<div class="Spacing Center"><span class="AJAXLoader"></span></div>');

                       // Call the ajax function
                       Core.AJAX.FunctionCall(Core.Config.Get('CGIHandle'), Data, function (Response) {
                           if (!Response || !Response.Success) {
                               alert(Response.Message);
                               Core.UI.Dialog.CloseDialog($('.Dialog'));
                               return false;
                           }

                           // Remove element from accordion
                           $Element.closest('li').remove();
                           Core.UI.Dialog.CloseDialog($('.Dialog'));
                       }, 'json');
                   }
               }
           ]
        );
    }

    /**
     * @private
     * @name InitDeleteEntity
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Initializes the event handler to delete entities.
     */
    function InitDeleteEntity() {
        $('a.DeleteEntity').on('click.DeleteEntity', function () {
            var EntityID = $(this).closest('li').data('entity'),
                EntityName = $(this).closest('li').clone().children().remove().end().text(),
                ItemID = $(this).closest('li').data('id'),
                EntityType;

            if (!EntityID.length) {
                return false;
            }

            if ($(this).hasClass('DeleteActivity')) {
                EntityType = 'Activity';
            }
            else if ($(this).hasClass('DeleteActivityDialog')) {
                EntityType = 'ActivityDialog';
            }
            else if ($(this).hasClass('DeleteTransition')) {
                EntityType = 'Transition';
            }
            else if ($(this).hasClass('DeleteTransitionAction')) {
                EntityType = 'TransitionAction';
            }

            ShowDeleteEntityConfirmationDialog($(this), EntityType, EntityName, EntityID, ItemID);

            return false;
        });
    }

    /**
     * @name ProcessData
     * @memberof Core.Agent.Admin.ProcessManagement
     * @member {Object}
     * @description
     *     Structure to save all process data.
     */
    TargetNS.ProcessData = {};

    /**
     * @name ProcessLayout
     * @memberof Core.Agent.Admin.ProcessManagement
     * @member {Object}
     * @description
     *     Structure to save all layout data for the process.
     */
    TargetNS.ProcessLayout = {};

    /**
     * @name InitAccordionDnD
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Initializes all event handler to drag and drop elements from the accordion to the canvas.
     */
    TargetNS.InitAccordionDnD = function () {
      /**
       * @private
       * @name GetMousePosition
       * @memberof Core.Agent.Admin.ProcessManagement.InitAccordionDND
       * @function
       * @returns {Object} Mouse position.
       * @param {Object} Event - The event object.
       * @description
       *      Calculates mouse position.
       */
        function GetMousePosition(Event) {
            var PosX = 0,
                PosY = 0;
            if (!Event) {
                Event = window.event;
            }
            if (Event.pageX || Event.pageY) {
                PosX = Event.pageX;
                PosY = Event.pageY;
            }
            else if (Event.clientX || Event.clientY) {
                PosX = Event.clientX + document.body.scrollLeft + document.documentElement.scrollLeft;
                PosY = Event.clientY + document.body.scrollTop + document.documentElement.scrollTop;
            }

            return {left: PosX, top: PosY};
        }

      /**
       * @private
       * @name GetPositionOnCanvas
       * @memberof Core.Agent.Admin.ProcessManagement.InitAccordionDND
       * @function
       * @returns {Object} Position of mouse on canvas.
       * @param {Object} Event - The event object.
       * @description
       *      Calculates mouse position relative to canvas object.
       */
        function GetPositionOnCanvas(Event) {
            var $Canvas = $('#Canvas'),
                CanvasPosition,
                MousePosition,
                PosX, PosY;

            CanvasPosition = $Canvas.offset();
            MousePosition = GetMousePosition(Event);

            PosX = MousePosition.left - CanvasPosition.left;
            PosY = MousePosition.top - CanvasPosition.top;

            return {left: PosX, top: PosY};
        }

      /**
       * @private
       * @name AddActivityToCanvas
       * @memberof Core.Agent.Admin.ProcessManagement.InitAccordionDND
       * @function
       * @param {Object} Event - The event object.
       * @param {Object} UI - jQuery UI object.
       * @description
       *      Adds activity to the canvas after drop event.
       */
        function AddActivityToCanvas(Event, UI) {
            var Position = GetPositionOnCanvas(Event),
                EntityID = $(UI.draggable).data('entity'),
                ActivityID = $(UI.draggable).data('id'),
                Entity = TargetNS.ProcessData.Activity[EntityID],
                ProcessEntityID = $('#ProcessEntityID').val(),
                Path, PathLength = 0, PathKey;

            if (typeof Entity !== 'undefined') {
                // Check if Activity is already placed
                // If so, it can't be placed again
                Path = TargetNS.ProcessData.Process[ProcessEntityID].Path;

                if (!Path[EntityID]) {
                    // Update Config
                    Path[EntityID] = {};
                    // Update Layout
                    TargetNS.ProcessLayout[EntityID] = {
                        left: Position.left,
                        top: Position.top
                    };
                    // Draw Entity
                    TargetNS.Canvas.CreateActivity(EntityID, Entity.Name, ActivityID, Position.left, Position.top);

                    // get Path length
                    for (PathKey in Path) {
                        if (Path.hasOwnProperty(PathKey)) {
                            PathLength++;
                        }
                    }

                    // if no other activity is on the canvas, make this activity to the startactivity
                    if (PathLength === 1) {
                        TargetNS.Canvas.SetStartActivity(EntityID);
                        TargetNS.ProcessData.Process[ProcessEntityID].StartActivity = EntityID;

                    }

                    TargetNS.Canvas.MakeDraggable();
                }
                else {
                    alert(Core.Language.Translate('This Activity is already used in the Process. You cannot add it twice!'));
                }
            }
            else {
                Core.Exception.Throw('Error: Entity not defined!', 'ProcessError');
            }
        }

      /**
       * @private
       * @name CheckIfMousePositionIsOverActivity
       * @memberof Core.Agent.Admin.ProcessManagement.InitAccordionDND
       * @function
       * @returns {String|Boolean} Returns ID of activity or false, if mouse is not over an activity.
       * @param {Object} Position - A mouse position object.
       * @description
       *      Checks if mouse position is over an activity (e.g. to drop activity dialogs to an activity).
       */
        function CheckIfMousePositionIsOverActivity(Position) {
            var ProcessEntityID = $('#ProcessEntityID').val(),
                Path = TargetNS.ProcessData.Process[ProcessEntityID].Path,
                ActivityMatch = false;

            // Loop over all assigned activities and check the position
            $.each(Path, function (Key) {
                var ActivityPosition = TargetNS.ProcessLayout[Key];
                if (
                        Position.left > parseInt(ActivityPosition.left, 10) &&
                        Position.left < parseInt(ActivityPosition.left, 10) + 110 &&
                        Position.top > parseInt(ActivityPosition.top, 10) &&
                        Position.top < parseInt(ActivityPosition.top, 10) + 80
                    ) {
                    ActivityMatch = Key;
                    return false;
                }
            });
            return ActivityMatch;
        }

      /**
       * @private
       * @name AddActivityDialogToCanvas
       * @memberof Core.Agent.Admin.ProcessManagement.InitAccordionDND
       * @function
       * @param {Object} Event - The event object.
       * @param {Object} UI - jQuery UI object.
       * @description
       *      Adds activity dialog to the canvas after drop event.
       */
        function AddActivityDialogToCanvas(Event, UI) {
            var Position = GetPositionOnCanvas(Event),
                EntityID = $(UI.draggable).data('entity'),
                Entity = TargetNS.ProcessData.ActivityDialog[EntityID],
                Activity, AJAXData;

            if (typeof Entity !== 'undefined') {
                // Check if mouse position is within an activity
                // If yes, add the Dialog to the Activity
                // if not, just cancel
                Activity = CheckIfMousePositionIsOverActivity(Position);
                if (Activity) {
                    // Remove Label, show Loader
                    TargetNS.Canvas.ShowActivityLoader(Activity);

                    // Call AJAX function to add ActivityDialog to Activity
                    AJAXData = {
                        Action: 'AdminProcessManagementActivity',
                        Subaction: 'AddActivityDialog',
                        EntityID: Activity,
                        ActivityDialog: EntityID
                    };

                    Core.AJAX.FunctionCall(Core.Config.Get('CGIHandle'), AJAXData, function (Response) {
                        if (!Response || !Response.Success) {
                            if (Response && Response.Message) {
                                alert(Response.Message);
                            }
                            else {
                                alert(Core.Language.Translate('Error during AJAX communication'));
                            }

                            TargetNS.Canvas.ShowActivityAddActivityDialogError(Activity);
                            return false;
                        }

                        TargetNS.Canvas.ShowActivityAddActivityDialogSuccess(Activity);

                        // Update Config
                        TargetNS.ProcessData.Activity[Activity] = Response.ActivityConfig.Activity[Activity];

                    }, 'json');
                }
            }
            else {
                Core.Exception.Throw('Error: Entity not defined!', 'ProcessError');
            }
        }

      /**
       * @private
       * @name DummyActivityConnected
       * @memberof Core.Agent.Admin.ProcessManagement.InitAccordionDND
       * @function
       * @returns {Boolean} True if a dummy endpoint was found, false otherwise.
       * @param {String} ProcessEntityID - The process ID.
       * @description
       *      Check if any transition has a dummy endpoint.
       */
        function DummyActivityConnected(ProcessEntityID) {
            var DummyFound = false;
            $.each(TargetNS.ProcessData.Process[ProcessEntityID].Path, function (Activity, ActivityData) {
                $.each(ActivityData, function (Transition, TransitionData) {
                    if (typeof TransitionData.ActivityEntityID === 'undefined') {
                        DummyFound = true;
                    }
                });
            });
            return DummyFound;
        }

      /**
       * @private
       * @name AddTransitionToCanvas
       * @memberof Core.Agent.Admin.ProcessManagement.InitAccordionDND
       * @function
       * @returns {Boolean} False if a another unconnected transition is on the canvas
       * @param {Object} Event - The event object.
       * @param {Object} UI - jQuery UI object.
       * @description
       *      Adds transition to the canvas after drop event.
       */
        function AddTransitionToCanvas(Event, UI) {
            var Position = GetPositionOnCanvas(Event),
                EntityID = $(UI.draggable).data('entity'),
                Entity = TargetNS.ProcessData.Transition[EntityID],
                ProcessEntityID = $('#ProcessEntityID').val(),
                Activity,
                Path = TargetNS.ProcessData.Process[ProcessEntityID].Path;

            // if a dummy activity exists, another transition was placed to the canvas but not yet
            // connected to an end point. One cannot place two unconnected transitions on the canvas.
            if ($('#Dummy').length && DummyActivityConnected(ProcessEntityID)) {
              alert(Core.Language.Translate('An unconnected transition is already placed on the canvas. Please connect this transition first before placing another transition.'));
              return false;
            }

            if (typeof Entity !== 'undefined') {
                // Check if mouse position is within an activity
                // If yes, add the Dialog to the Activity
                // if not, just cancel
                Activity = CheckIfMousePositionIsOverActivity(Position);

                // If this transition is already bind to this activity
                // you cannot bind it a second time
                if (Path[Activity] && typeof Path[Activity][EntityID] !== 'undefined') {
                    alert(Core.Language.Translate('This Transition is already used for this Activity. You cannot use it twice!'));
                    return false;
                }

                if (Activity) {
                    // Create dummy activity to use for initial transition
                    TargetNS.Canvas.CreateActivityDummy(Activity);

                    // Create transition between this Activity and DummyElement
                    TargetNS.Canvas.CreateTransition(Activity, 'Dummy', EntityID);

                    // Add Transition to Path
                    if (typeof Path[Activity] === 'undefined') {
                        Path[Activity] = {};
                    }
                    Path[Activity][EntityID] = {
                        ActivityEntityID: undefined
                    };
                }
            }
            else {
                Core.Exception.Throw('Error: Entity not defined!', 'ProcessError');
            }
        }

      /**
       * @private
       * @name AddTransitionActionToCanvas
       * @memberof Core.Agent.Admin.ProcessManagement.InitAccordionDND
       * @function
       * @returns {Boolean} Returns false, if transition is not defined.
       * @param {Object} Event - The event object.
       * @param {Object} UI - jQuery UI object.
       * @description
       *      Adds transition action to the canvas after drop event.
       */
        function AddTransitionActionToCanvas(Event, UI) {
            var EntityID = $(UI.draggable).data('entity'),
                Entity = TargetNS.ProcessData.TransitionAction[EntityID],
                Transition,
                ProcessEntityID = $('#ProcessEntityID').val(),
                Path = TargetNS.ProcessData.Process[ProcessEntityID].Path;

            if (typeof Entity !== 'undefined') {
                Transition = TargetNS.Canvas.DragTransitionActionTransition;

                if (!Transition.TransitionID) {
                    return false;
                }

                // If this action is already bound to this transition
                // you cannot bind it a second time
                if (Path[Transition.StartActivity] &&
                    typeof Path[Transition.StartActivity][Transition.TransitionID] !== 'undefined' &&
                    typeof Path[Transition.StartActivity][Transition.TransitionID].TransitionAction !== 'undefined' &&
                    ($.inArray(EntityID, Path[Transition.StartActivity][Transition.TransitionID].TransitionAction) >= 0)
                ) {
                    alert(Core.Language.Translate('This TransitionAction is already used in this Path. You cannot use it twice!'));
                    return false;
                }

                if (Transition) {
                    // Add Action to Path
                    if (typeof Path[Transition.StartActivity][Transition.TransitionID].TransitionAction === 'undefined') {
                        Path[Transition.StartActivity][Transition.TransitionID].TransitionAction = [];
                    }
                    Path[Transition.StartActivity][Transition.TransitionID].TransitionAction.push(EntityID);

                    // Show success icon in the label
                    $(Transition.Connection.canvas).append('<div class="Icon Success"></div>').find('.Icon').fadeIn().delay(1000).fadeOut();
                }
            }
            else {
                Core.Exception.Throw('Error: Entity not defined!', 'ProcessError');
            }
        }

        $('#Activities li.OneRow, #ActivityDialogs li.OneRow, #Transitions li.OneRow, #TransitionActions li.OneRow').draggable({
            revert: 'invalid',
            helper: function () {
                var $Clone = $(this).clone();
                $Clone.addClass('EntityDrag').find('span').remove();
                return $Clone[0];
            },
            start: function (Event, UI) {
                var $Source = $(this),
                    SourceID = $Source.closest('ul').attr('id');

                if (SourceID === 'ActivityDialogs' || SourceID === 'Transitions') {

                    // Set event flag
                    TargetNS.Canvas.DragActivityItem = true;

                    $('#Canvas .Activity').addClass('Highlighted');
                }
                else if (SourceID === 'TransitionActions') {
                    // Set event flag
                    TargetNS.Canvas.DragTransitionAction = true;

                    // Highlight all available Transitions
                    $('.TransitionLabel').addClass('Highlighted');
                }
                else {
                    UI.helper.css('z-index', 1000);
                }
            },
            stop: function () {
                var $Source = $(this),
                    SourceID = $Source.closest('ul').attr('id');

                if (SourceID === 'ActivityDialogs' || SourceID === 'Transitions') {

                    // Reset event flag
                    TargetNS.Canvas.DragActivityItem = false;

                    $('#Canvas .Activity').removeClass('Highlighted');
                }
                else if (SourceID === 'TransitionActions') {
                    // Reset event flag
                    TargetNS.Canvas.DragTransitionAction = false;

                    // Unhighlight all available Transitions
                    $('.TransitionLabel').removeClass('Highlighted');
                }
            }
        });

        $('#Canvas').droppable({
            accept: '#Activities li.OneRow, #ActivityDialogs li.OneRow, #Transitions li.OneRow, #TransitionActions li.OneRow',
            drop: function (Event, UI) {
                var $Source = $(UI.draggable),
                    SourceID = $Source.closest('ul').attr('id');

                if (SourceID === 'Activities') {
                    AddActivityToCanvas(Event, UI);
                }
                else if (SourceID === 'ActivityDialogs') {
                    AddActivityDialogToCanvas(Event, UI);
                }
                else if (SourceID === 'Transitions') {
                    AddTransitionToCanvas(Event, UI);
                }
                else if (SourceID === 'TransitionActions') {
                    AddTransitionActionToCanvas(Event, UI);
                }
                else {
                    Core.Exception.Throw('Error: No matching droppable found', 'ProcessError');
                }
            }
        });
    };

    /**
     * @name UpdateAccordion
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Update accordion data from server.
     */
    TargetNS.UpdateAccordion = function () {
        // get new Accordion HTML via AJAX and replace the accordion with this HTML
        // re-initialize accordion functions (accordion, filters, DnD)
        var Data = {
                Action: 'AdminProcessManagement',
                Subaction: 'UpdateAccordion'
            },
            ActiveElementIndex = parseInt($('ul#ProcessElements > li.Active').index(), 10),
            ActiveElementValue = $('ul#ProcessElements > li:eq(' + ActiveElementIndex + ') .ProcessElementFilter').val();

        // Call the ajax function
        Core.AJAX.FunctionCall(Core.Config.Get('CGIHandle'), Data, function (Response) {
            $('ul#ProcessElements').replaceWith(Response);

            // Initialize Accordion in the sidebar
            Core.UI.Accordion.Init($('ul#ProcessElements'), 'li.AccordionElement h2 a', 'div.Content');

            // Open accordion element again, which was active before the update.
            Core.UI.Accordion.OpenElement($('ul#ProcessElements > li:eq(' + ActiveElementIndex + ')'));

            // Initialize filters
            Core.UI.Table.InitTableFilter($('#ActivityFilter'), $('#Activities'));
            Core.UI.Table.InitTableFilter($('#ActivityDialogFilter'), $('#ActivityDialogs'));
            Core.UI.Table.InitTableFilter($('#TransitionFilter'), $('#Transitions'));
            Core.UI.Table.InitTableFilter($('#TransitionActionFilter'), $('#TransitionActions'));

            // Set previous value and filter.
            $('ul#ProcessElements > li:eq(' + ActiveElementIndex + ') .ProcessElementFilter').trigger('keydown').val(ActiveElementValue);

            // Init DnD on Accordion
            TargetNS.InitAccordionDnD();

            // Initialize the different create and edit links/buttons
            InitProcessPopups();

            // Initialize the different Delete Links
            InitDeleteEntity();
        }, 'html');
    };

    /**
     * @name UpdateSyncMessage
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Check if there is a 'dirty' sync state and show a message below the header.
     */
    TargetNS.UpdateSyncMessage = function () {
        // check if there is a 'dirty' sync state and show a message below the header
        var Data = {
                Action: 'AdminProcessManagement',
                Subaction: 'UpdateSyncMessage'
            };

        // Call the ajax function
        Core.AJAX.FunctionCall(Core.Config.Get('CGIHandle'), Data, function (Response) {

            if (!Response.length) {
                return true;
            }

            if ($('.MessageBox.Notice').length) {
                return true;
            }

            $(Response).insertBefore('div.MainBox');

        }, 'html');
    };

    /**
     * @name UpdateScreensPath
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @param {Object} WindowObject
     * @param {Function} Callback
     * @description
     *      Updates screen path.
     */
    TargetNS.UpdateScreensPath = function (WindowObject, Callback) {

        // Collect data for update of the screenspath
        var Data = {
                Action: 'AdminProcessManagement',
                Subaction: 'UpdateScreensPath',
                ProcessID: $('input[name=ID]').val(),
                ProcessEntityID: $('#ProcessEntityID').val()
            };

        // Call the ajax function
        Core.AJAX.FunctionCall(Core.Config.Get('CGIHandle'), Data, function (Response) {
            if (!Response || !Response.Success) {
                if (Response && Response.Message) {
                    alert(Response.Message);
                }
                else {
                    alert(Core.Language.Translate('Error during AJAX communication'));
                }
                return false;
            }
            else {
                if (typeof Callback !== 'undefined') {
                    Callback(WindowObject);
                }
            }
        }, 'json');
    };

    /**
     * @name HandlePopupClose
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Close overlay and re-initialize canvas and accordion.
     */
    TargetNS.HandlePopupClose = function () {
        // update accordion
        Core.Agent.Admin.ProcessManagement.UpdateAccordion();
        // redraw canvas
        Core.Agent.Admin.ProcessManagement.Canvas.Redraw();
        // remove overlay
        Core.Agent.Admin.ProcessManagement.HideOverlay();
    };

    /**
     * @name InitProcessEdit
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Initialize process edit screen.
     */
    TargetNS.InitProcessEdit = function () {
      var ConfigProcess = Core.Config.Get('ConfigProcess');

        // Get Process Data
        TargetNS.ProcessData = {
            Process: ConfigProcess.Process,
            Activity: ConfigProcess.Activity,
            ActivityDialog: ConfigProcess.ActivityDialog,
            Transition: ConfigProcess.Transition,
            TransitionAction: ConfigProcess.TransitionAction
        };

        TargetNS.ProcessLayout = ConfigProcess.ProcessLayout;

        // Initialize Accordion in the sidebar
        Core.UI.Accordion.Init($('ul#ProcessElements'), 'li.AccordionElement h2 a', 'div.Content');

        // Initialize filters
        Core.UI.Table.InitTableFilter($('#ActivityFilter'), $('#Activities'));
        Core.UI.Table.InitTableFilter($('#ActivityDialogFilter'), $('#ActivityDialogs'));
        Core.UI.Table.InitTableFilter($('#TransitionFilter'), $('#Transitions'));
        Core.UI.Table.InitTableFilter($('#TransitionActionFilter'), $('#TransitionActions'));

        // Init DnD on Accordion
        TargetNS.InitAccordionDnD();

        // Initialize the different Delete Links
        InitDeleteEntity();

        // Initialize DeleteProcess
        $('#ProcessDelete').on('click.ProcessDelete', function (Event) {
            ShowDeleteProcessConfirmationDialog($(Event.target).closest('a'));
            Event.stopPropagation();
            return false;
        });

        // Init submit function
        $('#Submit').on('click', function () {
            var ProcessEntityID = $('#ProcessEntityID').val(),
                StartActivity;

            // get process layout and store it into a hidden field as JSON string
            $('input[name=ProcessLayout]').val(Core.JSON.Stringify(TargetNS.ProcessLayout));

            // check if there are "open" transitions, e.g. transitions that have only a startpoint but no defined endpoint
            // these open transitions must be deleted before saving
            $.each(TargetNS.ProcessData.Process[ProcessEntityID].Path, function (Activity, ActivityData) {
                $.each(ActivityData, function (Transition, TransitionData) {
                    if (typeof TransitionData.ActivityEntityID === 'undefined') {
                        delete ActivityData[Transition];
                    }
                });
            });

            // get process path and store it into a hidden field as JSON string
            $('input[name=Path]').val(Core.JSON.Stringify(TargetNS.ProcessData.Process[ProcessEntityID].Path));

            // get start activity and dialogs and store it into hidden fields as JSON string
            StartActivity = TargetNS.ProcessData.Process[ProcessEntityID].StartActivity;
            if (StartActivity !== '') {
                $('input[name=StartActivity]').val(StartActivity);
                $('input[name=StartActivityDialog]').val(TargetNS.ProcessData.Activity[StartActivity].ActivityDialog["1"]);
            }
            $('#ProcessForm').submit();
            return false;
        });

        // Init Canvas Resizing Functions
        $('#ExtendCanvasHeight').on('click', function () {
            TargetNS.Canvas.Extend({
                Width: 0,
                Height: 150
            });
            return false;
        });

        $('#ExtendCanvasWidth').on('click', function () {
            TargetNS.Canvas.Extend({
                Width: 150,
                Height: 0
            });
            return false;
        });

        $('#ShowEntityIDs').on('click', function() {
            if ($(this).hasClass('Visible')) {
                $(this).removeClass('Visible').text(Core.Language.Translate('Show EntityIDs'));
                $('em.EntityID').remove();
            }
            else {
                $(this).addClass('Visible').text(Core.Language.Translate('Hide EntityIDs'));
                TargetNS.Canvas.ShowEntityIDs();
            }
            return false;
        });

        // Init Diagram Canvas
        TargetNS.Canvas.Init();
    };

    /**
     * @name InitActivityEdit
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Initialize activity edit screen.
     */
    TargetNS.InitActivityEdit = function () {
        function InitListFilter(Event, UI) {
         // only do something, if the element was removed from the right list
            if (UI.sender.attr('id') === 'AssignedActivityDialogs') {
                Core.UI.Table.InitTableFilter($('#FilterAvailableActivityDialogs'), $('#AvailableActivityDialogs'));
            }
        }

        // Initialize Allocation List
        Core.UI.AllocationList.Init("#AvailableActivityDialogs, #AssignedActivityDialogs", ".AllocationList", InitListFilter);

        // Initialize list filter
        Core.UI.Table.InitTableFilter($('#FilterAvailableActivityDialogs'), $('#AvailableActivityDialogs'));

        $('#Submit').on('click', function() {
            $('#ActivityForm').submit();
        });

        Core.Form.Validate.SetSubmitFunction($('#ActivityForm'), function (Form) {

            // get assigned activity dialogs
            $('input[name=ActivityDialogs]').val(Core.JSON.Stringify(Core.UI.AllocationList.GetResult('#AssignedActivityDialogs', 'id')));

            // not needed for normal submit
            $(window).off("beforeunload.PMPopup");

            Form.submit();
        });

        // Init handling of closing popup with the OS functionality ("X")
        $(window).off("beforeunload.PMPopup").on("beforeunload.PMPopup", function () {
            window.opener.Core.Agent.Admin.ProcessManagement.HandlePopupClose();
        });

        $('.ClosePopup').on("click", function () {
            $(window).off("beforeunload.PMPopup");
        });
    };

    /**
     * @name InitActivityDialogEdit
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Initialize activity dialog edit screen.
     */
    TargetNS.InitActivityDialogEdit = function () {
        var MandatoryFields = ['Queue', 'State', 'Lock', 'Priority', 'Type', 'CustomerID'],
            FieldsWithoutDefaultValue = ['CustomerID', 'Article'];

        function UpdateFields(Event, UI) {
            var Fieldname,
                DefaultFieldConfig = {};

            // if the element was removed from the AssignedFields list, remove FieldDetails data
            if (UI.sender.attr('id') === 'AssignedFields') {
                Core.UI.Table.InitTableFilter($('#FilterAvailableFields'), $('#AvailableFields'));
                $(UI.item)
                    .removeData('config')
                    .removeAttr('data-config');
            }
            // otherwise, force the user to enter data in the modal dialog
            else {
                Fieldname = $.trim($(UI.item).data('id'));

                // if Field is Mandatory set Display to "Show As Mandatory" as default
                if ($.inArray(Fieldname, MandatoryFields) > -1) {
                    DefaultFieldConfig.Display = "2";
                }
                else {
                    DefaultFieldConfig.Display = "1";
                }

                $(UI.item)
                    .data('config', Core.JSON.Stringify(DefaultFieldConfig))
                    .find('.FieldDetailsOverlay').trigger('click');
            }
            DirectSubmitCheck();
        }

        function DirectSubmitCheck() {
            var ShownFields = [];
            $('#AssignedFields').children('li').each(function () {
                var Config = Core.JSON.Parse($(this).data('config'));
                if (Config.Display != 0) {
                    ShownFields.push($(this));
                }
            });

            if ( $('#DirectSubmit').is(':checked') && ShownFields.length ) {
                $('#DirectSubmit ~ p.Warning').show();
            }
            else {
                $('#DirectSubmit ~ p.Warning').hide();
            }
        }

        // Initialize Allocation List
        Core.UI.AllocationList.Init("#AvailableFields, #AssignedFields", ".AllocationList", UpdateFields);

        // Initialize list filter
        Core.UI.Table.InitTableFilter($('#FilterAvailableFields'), $('#AvailableFields'));

        // Initialize direct submit tooltip
        $('#DirectSubmit').off('change').on('change', function() {
            DirectSubmitCheck();
        });

        // Execute check to get correct starting value
        DirectSubmitCheck();

        $('#Submit').on('click', function() {
            $('#ActivityDialogForm').submit();
            return false;
        });

        Core.Form.Validate.SetSubmitFunction($('#ActivityDialogForm'), function (Form) {
            var FieldConfig = Core.UI.AllocationList.GetResult('#AssignedFields', 'id'),
                FieldDetails = {};

            // get FieldDetails and add them to config
            $('#AssignedFields').find('li').each(function () {
                var Details,
                    ConfigValue = $(this).data('config'),
                    Field = $(this).data('id');

                if (typeof ConfigValue === 'string') {
                    Details = Core.JSON.Parse(ConfigValue);
                }
                else {
                    Details = ConfigValue;
                }

                FieldDetails[Field] = Details;
            });

            // get assigned activity dialogs
            $('input[name=Fields]').val(Core.JSON.Stringify(FieldConfig));
            $('input[name=FieldDetails]').val(Core.JSON.Stringify(FieldDetails));

            // not needed for normal submit
            $(window).off("beforeunload.PMPopup");

            Form.submit();
        });

        // Init Fields modal overlay
        $('.FieldDetailsOverlay').off('click').on('click', function () {
            var FieldConfig = $(this).closest('li').data('config'),
                $Element = $(this),
                Fieldname = $.trim($(this).closest('li').data('id')),
                FieldNameTranslated = $('.AllocationList').find('li[data-id="' + Fieldname + '"]').data('name-translated');

            if (typeof FieldConfig === 'string') {
                FieldConfig = Core.JSON.Parse(FieldConfig);
            }

            // Open dialog
            Core.UI.Dialog.ShowContentDialog(
                $('#Dialogs #FieldDetails'),
                Core.Language.Translate('Edit Field Details') + ': ' + FieldNameTranslated,
                '200px',
                'Center',
                true,
                [
                     {
                         Label: Core.Language.Translate('Save'),
                         Class: 'Primary',
                         Function: function () {
                             var FieldConfigElement = {};

                             FieldConfigElement.DescriptionShort = $('#DescShort').val();
                             FieldConfigElement.DescriptionLong = $('#DescLong').val();
                             FieldConfigElement.DefaultValue = $('#DefaultValue').val();
                             FieldConfigElement.Display = $('#Display').val();

                             if (Fieldname === 'Article') {
                                 if (typeof FieldConfigElement.Config === 'undefined'){
                                     FieldConfigElement.Config = {};
                                 }
                                 FieldConfigElement.Config.CommunicationChannel = $('#CommunicationChannel').val();

                                 FieldConfigElement.Config.IsVisibleForCustomer = '0';
                                 if ($('#IsVisibleForCustomer').prop('checked')) {
                                    FieldConfigElement.Config.IsVisibleForCustomer = '1';
                                 }

                                 // show error if not customer visible article is set for an interface different than AgentInterface
                                 if ($('#Interface').val() !== 'AgentInterface' && !$('#IsVisibleForCustomer').prop('checked')){
                                     window.alert(Core.Language.Translate('Customer interface does not support articles not visible for customers.'));
                                     return false;
                                 }

                                 // add the time units value to the fieldconfig
                                 FieldConfigElement.Config.TimeUnits = $('#TimeUnits').val();
// Rother OSS / ProcessTicketTemplates

                                 // add the standard template value to the fieldconfig
                                 FieldConfigElement.Config.StandardTemplates = '0';
                                 if ($('#StandardTemplates').prop('checked')) {
                                    FieldConfigElement.Config.StandardTemplates = '1';
                                 }
// EO ProcessTicketTemplates
                             }

                             $Element.closest('li').data('config', Core.JSON.Stringify(FieldConfigElement));

                             DirectSubmitCheck();

                             Core.UI.Dialog.CloseDialog($('.Dialog'));
                         }
                     },
                     {
                         Label: Core.Language.Translate('Cancel'),
                         Function: function () {
                             Core.UI.Dialog.CloseDialog($('.Dialog'));
                         }
                     }
                ]
            );

            // some fields must be mandatory, if they are present.
            // remove option from dropdown for these fields
            // set "Show As Mandatory" as default
            if ($.inArray(Fieldname, MandatoryFields) > -1) {
                $('#Display')
                    .find('option[value=1]').remove()
                    .end()
                    .val('2');
            }
            // otherwise set "Show Field" as default
            else {
                $('#Display').val('1');
            }

            // fields without default value can not be hidden
            if ($.inArray(Fieldname, FieldsWithoutDefaultValue) > -1) {
                $('#Display').find('option[value=0]').remove();
            }

            // if there is a field config already the default settings from above are now overwritten
            if (typeof FieldConfig !== 'undefined') {
                $('#DescShort').val(FieldConfig.DescriptionShort);
                $('#DescLong').val(FieldConfig.DescriptionLong);
                $('#DefaultValue').val(FieldConfig.DefaultValue);

                if (typeof FieldConfig.Display !== 'undefined') {
                    $('#Display').val(FieldConfig.Display);
                }

                if (Fieldname === 'Article') {
                    if (typeof FieldConfig.Config === 'undefined'){
                        FieldConfig.Config = {};
                    }
                    if (FieldConfig.Config.CommunicationChannel) {
                        $('#CommunicationChannel').val(FieldConfig.Config.CommunicationChannel);
                    }
                    if (FieldConfig.Config.IsVisibleForCustomer === '1') {
                        $('#IsVisibleForCustomer').prop("checked", true);
                    }
                    if (FieldConfig.Config.TimeUnits) {
                        $('#TimeUnits').val(FieldConfig.Config.TimeUnits);
                    }
// Rother OSS / ProcessTicketTemplates
                    if ((typeof FieldConfig.Config.StandardTemplates === 'undefined') || FieldConfig.Config.StandardTemplates === '1') {
                        $('#StandardTemplates').prop("checked", true);
                    }
// EO ProcessTicketTemplates
                }
            }

            // redraw display field
            $('#Display').trigger('redraw.InputField');

            // some fields do not have a default value.
            // disable the input field
            if ($.inArray(Fieldname, FieldsWithoutDefaultValue) > -1) {
                $('#DefaultValue').prop('readonly', true).prop('disabled', true);
            }

            // only article should show Communication channel select.
            if (Fieldname === 'Article') {

                $('#CommunicationChannelContainer').removeClass('Hidden');
                $('#CommunicationChannelContainer').prev('label').css('display', 'block');
                $('#CommunicationChannelContainer .Modernize').trigger('redraw.InputField');

                $('#IsVisibleForCustomerContainer').removeClass('Hidden');
                $('#IsVisibleForCustomerContainer').prev('label').css('display', 'block');

                $('#TimeUnitsContainer').removeClass('Hidden');
                $('#TimeUnitsContainer').prev('label').css('display', 'block');
                $('#TimeUnitsContainer .Modernize').trigger('redraw.InputField');
// Rother OSS / ProcessTicketTemplates

                $('#StandardTemplatesContainer').removeClass('Hidden');
                $('#StandardTemplatesContainer').prev('label').css('display', 'block');
// EO ProcessTicketTemplates
            }
            else {

                $('#CommunicationChannelContainer').addClass('Hidden');
                $('#CommunicationChannelContainer').prev('label').css('display', 'none');

                $('#IsVisibleForCustomerContainer').addClass('Hidden');
                $('#IsVisibleForCustomerContainer').prev('label').css('display', 'none');

                $('#TimeUnitsContainer').addClass('Hidden');
                $('#TimeUnitsContainer').prev('label').css('display', 'none');
// Rother OSS / ProcessTicketTemplates

                $('#StandardTemplatesContainer').addClass('Hidden');
                $('#StandardTemplatesContainer').prev('label').css('display', 'none');
// EO ProcessTicketTemplates
            }

            return false;
        });

        // Init handling of closing popup with the OS functionality ("X")
        $(window).off("beforeunload.PMPopup").on("beforeunload.PMPopup", function () {
            window.opener.Core.Agent.Admin.ProcessManagement.HandlePopupClose();
        });

        $('.ClosePopup').on("click", function () {
            $(window).off("beforeunload.PMPopup");
        });
    };

    /**
     * @name InitTransitionEdit
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Initialize transition edit screen.
     */
    TargetNS.InitTransitionEdit = function () {

        // Init addition of new conditions
        $('#ConditionAdd').on('click', function() {
            // get current parent index
            var CurrentParentIndex = parseInt($(this).prev('.WidgetSimple').first().attr('id').replace(/Condition\[/g, '').replace(/\]/g, ''), 10),
                // in case we add a whole new condition, the fieldindex must be 1
                LastKnownFieldIndex = 1,
                // get current index
                ConditionHTML = $('#ConditionContainer').html().replace(/_INDEX_/g, CurrentParentIndex + 1).replace(/_FIELDINDEX_/g, LastKnownFieldIndex);

            $($.parseHTML(ConditionHTML)).insertBefore($('#ConditionAdd'));
            Core.UI.InputFields.Init();
            return false;
        });

        // Init removal of conditions
        $('#PresentConditionsContainer').delegate('.ParentWidget > .Header .RemoveButton', 'click', function() {
            if ($('#PresentConditionsContainer').find('.ConditionField').length > 1) {

                $(this).closest('.WidgetSimple').remove();
            }
            else {
                alert(Core.Language.Translate("Sorry, the only existing condition can't be removed."));
            }

            return false;
        });

        // Init addition of new fields within conditions
        $('#PresentConditionsContainer').off('click.AddField').on('click.AddField', '.FieldWidget .AddButton', function() {
            // get current parent index
            var CurrentParentIndex = $(this).closest('.ParentWidget').attr('id').replace(/Condition\[/g, '').replace(/\]/g, ''),
                // get the index for the newly to be added element
                // therefore, we search the preceding fieldset and the first
                // label in it to get its "for"-attribute which contains the index
                LastKnownFieldIndex = parseInt($(this).closest('.WidgetSimple').find('.Content').find('label').first().attr('for').replace(/ConditionFieldName\[\d+\]\[/, '').replace(/\]/, ''), 10),
                // add new field
                ConditionFieldHTML = $('#ConditionFieldContainer').html().replace(/_INDEX_/g, CurrentParentIndex).replace(/_FIELDINDEX_/g, LastKnownFieldIndex + 1);

            $($.parseHTML(ConditionFieldHTML)).insertAfter($(this).closest('.WidgetSimple').find('fieldset').last());
            Core.UI.InputFields.Init();
            return false;
        });

        // Init removal of fields within conditions
        $('#PresentConditionsContainer').off('click.RemoveField').on('click.RemoveField', '.FieldWidget .RemoveButton', function() {
            if ($(this).closest('.Content').find('fieldset').length > 1) {
                $(this).parent().closest('fieldset').remove();
            }
            else {
                alert(Core.Language.Translate("Sorry, the only existing field can't be removed."));
            }

            return false;
        });

        $('#Submit').on('click', function() {
            $('#TransitionForm').submit();
            return false;
        });

        Core.Form.Validate.SetSubmitFunction($('#TransitionForm'), function (Form) {
            var ConditionConfig = TargetNS.GetConditionConfig($('#PresentConditionsContainer').find('.ConditionField'));
            $('input[name=ConditionConfig]').val(Core.JSON.Stringify(ConditionConfig));

            // not needed for normal submit
            $(window).off("beforeunload.PMPopup");

            Form.submit();
        });

        // Init handling of closing popup with the OS functionality ("X")
        $(window).off("beforeunload.PMPopup").on("beforeunload.PMPopup", function () {
            window.opener.Core.Agent.Admin.ProcessManagement.HandlePopupClose();
        });

        $('.ClosePopup').on("click", function () {
            $(window).off("beforeunload.PMPopup");
        });

        Core.UI.InputFields.Init();

    };

    /**
     * @name InitTransitionActionEdit
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Initialize transition action edit screen.
     */
    TargetNS.InitTransitionActionEdit = function () {
        // Init addition of new config parameters
        $('#ConfigAdd').on('click', function() {
            // get the index for the newly to be added element
            // therefore, we search the preceding fieldset and the first
            // label in it to get its "for"-attribute which contains the index
            var $PreviousField = $(this).closest('.WidgetSimple').find('.Content fieldset').last(),
                LastKnownFieldIndex,
                ConfigParamHTML;

            if ($PreviousField.length) {
                LastKnownFieldIndex = parseInt($PreviousField.find('label').first().attr('for').replace(/ConfigKey\[/, '').replace(/\]/, ''), 10);
            }
            else {
                LastKnownFieldIndex = 0;
            }

            // get current index
            ConfigParamHTML = $('#ConfigParamContainer').html().replace(/_INDEX_/g, LastKnownFieldIndex + 1);

            $($.parseHTML(ConfigParamHTML)).insertAfter($PreviousField);
            return false;
        });

        // Init removal of fields
        $('#ConfigParams').delegate('.RemoveButton', 'click', function() {
            if ($(this).closest('.Content').find('fieldset').length > 1) {
                $(this).closest('fieldset').remove();
            }
            else {
                alert(Core.Language.Translate("Sorry, the only existing parameter can't be removed."));
            }
            return false;
        });

        $('#Submit').on('click', function() {
            $('#TransitionForm').submit();
            return false;
        });

        Core.Form.Validate.SetSubmitFunction($('#TransitionForm'), function (Form) {
            // not needed for normal submit
            $(window).off("beforeunload.PMPopup");

            Form.submit();
        });

        // Init handling of closing popup with the OS functionality ("X")
        $(window).off("beforeunload.PMPopup").on("beforeunload.PMPopup", function () {
            window.opener.Core.Agent.Admin.ProcessManagement.HandlePopupClose();
        });

        $('.ClosePopup').on("click", function () {
            $(window).off("beforeunload.PMPopup");
        });
    };

    /**
     * @name InitPathEdit
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Initialize path edit screen.
     */
    TargetNS.InitPathEdit = function () {
        var CurrentProcessEntityID = Core.Config.Get('ProcessEntityID'),
            CurrentTransitionEntityID = Core.Config.Get('TransitionEntityID'),
            StartActivityID = Core.Config.Get('StartActivityID'),
            ActivityInfo = window.opener.Core.Agent.Admin.ProcessManagement.ProcessData.Activity,
            PathInfo = window.opener.Core.Agent.Admin.ProcessManagement.ProcessData.Process[CurrentProcessEntityID].Path,
            StartActivityEntityID = '', EndActivityEntityID = '',
            AssignedTransitionActions = [];

        // Initialize Allocation List
        Core.UI.AllocationList.Init("#AvailableTransitionActions, #AssignedTransitionActions", ".AllocationList");

        // Initialize list filter
        Core.UI.Table.InitTableFilter($('#FilterAvailableTransitionActions'), $('#AvailableTransitionActions'));

        // store process data to hidden field for later merging
        $('#ProcessData').val(Core.JSON.Stringify(window.opener.Core.Agent.Admin.ProcessManagement.ProcessData.Process));

        // set current start and end activity (just for information purposes, not changeable)
        $.each(PathInfo, function(Activity, Transition) {
            if (Activity === StartActivityID && typeof Transition[CurrentTransitionEntityID] !== 'undefined') {
                $('#StartActivity').attr('title', ActivityInfo[Activity].Name).text(ActivityInfo[Activity].Name);
                $('#EndActivity').attr('title', ActivityInfo[Transition[CurrentTransitionEntityID].ActivityEntityID].Name).text(ActivityInfo[Transition[CurrentTransitionEntityID].ActivityEntityID].Name);

                StartActivityEntityID = Activity;
                EndActivityEntityID = Transition[CurrentTransitionEntityID].ActivityEntityID;
                AssignedTransitionActions = Transition[CurrentTransitionEntityID].TransitionAction;

                return false;
            }
        });

        // Set chosen Startactivity, Endactivity and Transition
        $('#Transition').val(CurrentTransitionEntityID);
        $('#EditPath a').data('entity', CurrentTransitionEntityID);

        if (AssignedTransitionActions && AssignedTransitionActions.length) {
            // Display assigned Transition Actions
            $.each(AssignedTransitionActions, function(Index, TransitionActionEntityID) {
                $('#AvailableTransitionActions').find('#' + TransitionActionEntityID).remove().appendTo($('#AssignedTransitionActions'));
            });
        }

        // if transition select is updated, also update transition edit link
        $('#Transition').on('change', function () {
           $('#EditPath a').data('entity', $(this).val());
        });

        $('#Submit').on('click', function() {
            $('#PathForm').submit();
            return false;
        });

        // init submit
        Core.Form.Validate.SetSubmitFunction($('#PathForm'), function (Form) {

            var NewTransitionEntityID = $('#Transition').val(),
                NewTransitionActions = [],
                TransitionInfo;

            $('#AssignedTransitionActions li').each(function() {
                NewTransitionActions.push($(this).attr('id'));
            });

            // collection transition info for later merging
            TransitionInfo = {
                StartActivityEntityID: StartActivityEntityID,
                NewTransitionEntityID: NewTransitionEntityID,
                NewTransitionActions: NewTransitionActions,
                NewTransitionActivityID: EndActivityEntityID
            };

            $('#TransitionInfo').val(Core.JSON.Stringify(TransitionInfo));

            // not needed for normal submit
            $(window).off("beforeunload.PMPopup");

            Form.submit();
        });

        InitProcessPopups();

        // Init handling of closing popup with the OS functionality ("X")
        $(window).off("beforeunload.PMPopup").on("beforeunload.PMPopup", function () {
            window.opener.Core.Agent.Admin.ProcessManagement.HandlePopupClose();
        });

        $('.ClosePopup').on("click", function () {
            $(window).off("beforeunload.PMPopup");
        });
    };

    /**
     * @name ShowOverlay
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Opens overlay.
     */
    TargetNS.ShowOverlay = function () {
        $('<div id="Overlay" tabindex="-1">').appendTo('body');
        $('body').css({
            'overflow': 'hidden'
        });
        $('#Overlay').height($(document).height()).css('top', 0);

        // If the underlying page is perhaps to small, we extend the page to window height for the dialog
        $('body').css('min-height', $(window).height());
    };

    /**
     * @name HideOverlay
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @description
     *      Closes overlay and restores normal view.
     */
    TargetNS.HideOverlay = function () {
        $('#Overlay').remove();
        $('body').css({
            'overflow': 'visible',
            'min-height': 0
        });
    };

    /**
     * @name GetConditionConfig
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @returns {Object} Conditions and fields.
     * @param {jQueryObject} $Conditions - Conditions element in DOM.
     * @description
     *      Get all conditions and corresponding fields.
     */
    TargetNS.GetConditionConfig = function ($Conditions) {

        var Conditions = {},
            ConditionKey;

        if (!$Conditions.length) {
            return {};
        }

        $Conditions.each(function() {

            // get condition key
            ConditionKey = $(this).closest('.WidgetSimple').attr('id').replace(/(Condition\[|\])/g, '');

            // use condition key as key for our list
            Conditions[ConditionKey] = {
                Type: $(this).find('.Field > select').val(),
                Fields: {}
            };

            // get all fields of the current condition
            $(this).find('.FieldWidget fieldset').each(function() {
                Conditions[ConditionKey].Fields[$(this).find('input').first().val()] = {
                    Type: $(this).find('select').val(),
                    Match: $(this).find('input').last().val()
                };
            });

        });

        return Conditions;
    };

    /**
     * @name UpdateConfig
     * @memberof Core.Agent.Admin.ProcessManagement
     * @function
     * @returns {Boolean} Returns false, if Config is not defined.
     * @param {Object} Config
     * @description
     *      Update gloabl process config object after config change e.g. in popup windows.
     */
    TargetNS.UpdateConfig = function (Config) {
        if (typeof Config === 'undefined') {
            return false;
        }

        // IE (11) has some permission problems with objects from other windows
        // Therefore we "copy" the object if we are in IE
        if ($.browser.trident) {
            Config = Core.JSON.Parse(Core.JSON.Stringify(Config));
        }

        // Update config from e.g. popup windows

        // Update Process
        if (typeof Config.Process !== 'undefined') {
            TargetNS.ProcessData.Process = Config.Process;
        }

        // Update Activities
        if (typeof Config.Activity !== 'undefined') {
            $.each(Config.Activity, function (Key, Value) {
                TargetNS.ProcessData.Activity[Key] = Value;
            });
        }

        // Update Activity Dialogs
        if (typeof Config.ActivityDialog !== 'undefined') {
            $.each(Config.ActivityDialog, function (Key, Value) {
                TargetNS.ProcessData.ActivityDialog[Key] = Value;
            });
        }

        // Update Transitions
        if (typeof Config.Transition !== 'undefined') {
            $.each(Config.Transition, function (Key, Value) {
                TargetNS.ProcessData.Transition[Key] = Value;
            });
        }

        // Update Transition Actions
        if (typeof Config.TransitionAction !== 'undefined') {
            $.each(Config.TransitionAction, function (Key, Value) {
                TargetNS.ProcessData.TransitionAction[Key] = Value;
            });
        }
    };

    Core.Init.RegisterNamespace(TargetNS, 'APP_MODULE');

    return TargetNS;
}(Core.Agent.Admin.ProcessManagement || {}));

/*eslint-enable otobo/no-window*/
</File>
        <File Location="var/httpd/htdocs/js/Core.Agent.TicketProcess.js" Permission="660" Encode="Base64">// --
// OTOBO is a web-based ticketing system for service organisations.
// --
// Copyright (C) 2001-2020 OTRS AG, https://otrs.com/
// Copyright (C) 2019-2026 Rother OSS GmbH, https://otobo.io/
// --
// $origin: otobo - 6efdc7bf2a3325277cd79a60f0f2407f8ad59e87 - var/httpd/htdocs/js/Core.Agent.TicketProcess.js
// --
// This program is free software: you can redistribute it and/or modify it under
// the terms of the GNU General Public License as published by the Free Software
// Foundation, either version 3 of the License, or (at your option) any later version.
// This program is distributed in the hope that it will be useful, but WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
// FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
// --

"use strict";

var Core = Core || {};
Core.Agent = Core.Agent || {};

/**
 * @namespace Core.Agent.TicketProcess
 * @memberof Core.Agent
 * @author
 * @description
 *      This namespace contains the special module functions for TicketProcess.
 */
Core.Agent.TicketProcess = (function (TargetNS) {

    /**
     * @name Init
     * @memberof Core.Agent.TicketProcess
     * @function
     * @description
     *      This function initializes the special module functions.
     */
    TargetNS.Init = function () {

        var ProcessID = Core.Config.Get('ProcessID');

        if (typeof ProcessID !== 'undefined') {
            $('#ProcessEntityID').val(ProcessID);
        }

        if (typeof Core.Config.Get('ParentReload') !== 'undefined' && parseInt(Core.Config.Get('ParentReload'), 10) === 1){
            Core.UI.Popup.ExecuteInParentWindow(function(WindowObject) {
                if (WindowObject.Core.UI.Popup.GetWindowMode() !== 'Iframe') {
                    WindowObject.Core.UI.Popup.FirePopupEvent('Reload');
                }
            });
        }

        $('#ProcessEntityID').on('change', function () {
            var Data = {
                Action: 'AgentTicketProcess',
                Subaction: 'DisplayActivityDialogAJAX',
                ProcessEntityID: $('#ProcessEntityID').val(),
                LinkTicketID: $('#LinkTicketID').val(),
                ArticleID: $('#ArticleID').val(),
                FormID: $(this).closest('form').find('input:hidden[name=FormID]').val(),
                IsAjaxRequest: 1,
                IsMainWindow: 1
            };

            if ($('#IsProcessEnroll').val() !== 'undefined' && $('#IsProcessEnroll').val() === '1') {
                $.extend(Data, {
                    IsMainWindow: 0,
                    IsProcessEnroll: 1,
                    TicketID: $('#TicketID').val()
                });
            }


            if ($('#ProcessEntityID').val()) {

                // remove the content of the activity dialog
                $('#ActivityDialogContent').empty();

                // fade out the empty container so it will fade in again on processes change
                // is not recommended to empty after fade out at this point since the transition offect
                // will not look so nice
                $('#ActivityDialogContent').fadeOut('fast');

                // show loader icon
                $('#AJAXLoader').removeClass('Hidden');

                // get new ActivityDialog content
                Core.AJAX.FunctionCall(
                    Core.Config.Get('CGIHandle'),
                    Data,
                    function (Response) {
                    var $ElementToUpdate = $('#ActivityDialogContent'),
                        JavaScriptString = '',
                        ErrorMessage;

                    if (!Response) {

                        // We are out of the OTOBO App scope, that's why an exception would not be caught. Therefor we handle the error manually.
                        Core.Exception.HandleFinalError(new Core.Exception.ApplicationError("No content received.", 'CommunicationError'));
                        $('#AJAXLoader').addClass('Hidden');
                    }
                    else if ($ElementToUpdate && isJQueryObject($ElementToUpdate) && $ElementToUpdate.length) {
                        $ElementToUpdate.get(0).innerHTML = Response;
                        $ElementToUpdate.find('script').each(function() {
                            JavaScriptString += $(this).html();
                            $(this).remove();
                        });
                        $ElementToUpdate.fadeIn();
                        Core.UI.InputFields.Activate($ElementToUpdate);
                        try {
                            /*eslint-disable no-eval */
                            eval(JavaScriptString);
                            /*eslint-enable no-eval */
                        }
                        catch (Event) {
                            // do nothing here (code needed  to not have an empty block here)
                            $.noop(Event);
                        }

                        // Handle special server errors (Response = <div class="ServerError" data-message="Message"></div>)
                        // Check if first element has class 'ServerError'
                        if ($ElementToUpdate.children().first().hasClass('ServerError')) {
                            ErrorMessage = $ElementToUpdate.children().first().data('message');

                            // Add class ServerError to the process select element
                            $('#ProcessEntityID').addClass('ServerError');
                            // Set a custom error message to the proccess select element
                            $('#ProcessEntityIDServerError').children().first().text(ErrorMessage);
                        }

                        Core.Form.Validate.Init();

                        // Register event for tree selection dialog
                        Core.UI.TreeSelection.InitTreeSelection();

                        // initialize ajax dnd upload
                        Core.UI.InitAjaxDnDUpload();

                        // move help triggers into field rows for dynamic fields
                        $('.Row > .FieldCell > .FieldHelpContainer').each(function () {
                            if (!$(this).next('label').find('.Marker').length) {
                                $(this).prependTo($(this).next('label'));
                            }
                            else {
                                $(this).insertAfter($(this).next('label').find('.Marker'));
                            }
                        });


                        // Initially display dynamic fields with TreeMode = 1 correctly
                        Core.UI.TreeSelection.InitDynamicFieldTreeViewRestore();

                        // trigger again a responsive event
                        if (Core.App.Responsive.IsSmallerOrEqual(Core.App.Responsive.GetScreenSize(), 'ScreenL')) {
                            Core.App.Publish('Event.App.Responsive.SmallerOrEqualScreenL');
                        }

                        // trigget customer auto complete event if field is accesible
                        if ($ElementToUpdate.find('#CustomerAutoComplete').length) {
                            Core.Agent.CustomerSearchAutoComplete.Init();
                        }

                        $('#AJAXLoader').addClass('Hidden');
                        $('#AJAXDialog').val('1');

                        Core.TicketProcess.Init();

                        Core.UI.InputFields.InitMultiValueDynamicFields();

                        QuickDateButtons.Init();

// Rother OSS / ProcessTicketTemplates
                        // Bind event to StandardTemplate field.
                        $('#StandardTemplateID').on('change', function () {
                            Core.Agent.TicketAction.ConfirmTemplateOverwrite('RichText', $(this), function () {
                                Core.AJAX.FormUpdate($('#RichText').closest('form'), 'AJAXUpdate', 'StandardTemplateID');
                            });
                            return false;
                        });

// EO ProcessTicketTemplates
                        // Publish event when first activity dialog has loaded, so other code can know to execute again.
                        Core.App.Publish('TicketProcess.Init.FirstActivityDialog.Load', [$ElementToUpdate]);

                        // NOTE this code aims to resemble the functionality of the submit event in Core.UI.InputFields.Init(), currently located in var/https/htdocs/js/Core.UI.InputFields.js Line 320, which does not take effect in AgentTicketProcess for an yet unknown reason
                        $('button[type=submit]').on('click', function(Event) {
                            $('.DynamicFieldText').attr('disabled', false);
                            return true;
                        });
                    }
                    else {

                        // We are out of the OTOBO App scope, that's why an exception would not be caught. Therefor we handle the error manually.
                        Core.Exception.HandleFinalError(new Core.Exception.ApplicationError("No such element id: " + $ElementToUpdate.attr('id') + " in page!", 'CommunicationError'));
                        $('#AJAXLoader').addClass('Hidden');
                    }
                }, 'html');
            }
            else {
                $('#ActivityDialogContent').fadeOut(400, function() {
                    $('#ActivityDialogContent').empty();
                });
            }
            return false;
        });

// Rother OSS / ProcessTicketTemplates
        // Bind event to StandardTemplate field.
        $('#StandardTemplateID').on('change', function () {
            Core.Agent.TicketAction.ConfirmTemplateOverwrite('RichText', $(this), function () {
                Core.AJAX.FormUpdate($('#RichText').closest('form'), 'AJAXUpdate', 'StandardTemplateID');
            });
            return false;
        });

// EO ProcessTicketTemplates
        // If process is pre-selected trigger change event on ProcessEntityID field.
        if ($('#ProcessEntityID').val() !== "") {
            $('#ProcessEntityID').trigger('change');
        }
    };

    Core.Init.RegisterNamespace(TargetNS, 'APP_MODULE');

    return TargetNS;
}(Core.Agent.TicketProcess || {}));
</File>
        <File Location="doc/en/ProcessTicketTemplates.pdf" Permission="644" Encode="Base64">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ZUdyYXkvQml0c1BlckNvbXBvbmVudAo4L0RlY29kZVBhcm1zPDwvQml0c1BlckNvbXBvbmVudCA4L0NvbG9ycyAxL0NvbHVtbnMgMTAzNS9QcmVkaWN0b3IgMj4+L0ZpbHRlci9GbGF0ZURlY29kZS9MZW5ndGgKMTY1Nz4+CnN0cmVhbQp42u3UIQEAAADCMPqXhhS4LcLFG4BUAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACuQALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAokAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsAIJACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArEACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAK5AAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACiQArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAsAKACsArACwAgkAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsALACwAoAKwCsQALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAsALACgArAKwAOBu6iM5OCmVuZHN0cmVh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</File>
    </Filelist>
</otrs_package>