TimeAccounting
4.0.1
OTRS AG
http://otrs.org/
GNU AFFERO GENERAL PUBLIC LICENSE Version 3, November 2007
Build for TimeAccounting 4.
Build for TimeAccounting 4 rc1.
Build for TimeAccounting 4 beta1.
A Time Registration Module.
Ein Zeiterfassungsmodul.
4.0.x
<br>
<b>WELCOME</b>
<br>
<br>
You are about to install the OTRS package TimeAccounting.<br>
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>WILLKOMMEN</b>
<br>
<br>
Sie sind im Begriff das OTRS-Paket TimeAccounting zu installieren.<br>
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>BIENVENIDO</b>
<br>
<br>
Ud. está a punto de instalar el paquete Contabilidad de Tiempo de OTRS.<br>
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>NOTICE</b>
<br>
<br>
In order to grant users access to the time accounting module, you need to add them as member to the group 'time_accounting'.
<br>
<br>
The menu items that were added by this package will be visible after you log-in to the system again.
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>HINWEIS</b>
<br>
<br>
Um Benutzern Zugriff auf die Zeiterfassung zu gewähren, müssen diese Mitglied der neuen Gruppe 'time_accounting' sein.
<br>
<br>
Die von diesem Paket hinzugefügten Menü-Punkte sind erst nach einem erneuten Anmeldevorgang im System sichtbar.
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>NOTA</b>
<br>
<br>
Para permitirles a los usuarios el acceso al módulo de contabilidad de tiempo, es necesario añadirlos como miembros del grupo 'time_accounting'.
<br>
<br>
Los elementos del menú agregados por este paquete, serán visibles luego de reiniciar sesión en el sistema.
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>ATTENTION</b>
<br>
<br>
If you uninstall this package, all database tables that were created during installation will be deleted.
All data from these tables will be irrevocably lost!
<br>
<br>
The group 'time_accounting' that was created during package installation will be deactivated.
You can activate this group again in the admin area.
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>ACHTUNG</b>
<br>
<br>
Bei der Deinstallation werden die von diesem Paket angelegten Datenbank-Tabellen gelöscht.
Alle darin enthaltenen Daten gehen unwiderruflich verloren!
<br>
<br>
Die von diesem Paket angelegte Gruppe 'time_accounting' wird deaktiviert.
Sie kann jederzeit im Admin-Bereich wieder aktiviert werden.
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>ATTENTION</b>
<br>
<br>
Si usted desinstala este paquete, todas las tablas de la base de datos que se crearon durante la instalación del mismo, se eliminarán y
el contenido de dichas tablas se perderá irrevocablemente.
<br>
<br>
El grupo 'time_accounting' que se dió de alta durante la instalación del paquete, se desactivará.
Es posible reactivar dicho grupo en el área de administración.
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>WELCOME</b>
<br>
<br>
You are about to upgrade the OTRS package TimeAccounting.<br>
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>WILLKOMMEN</b>
<br>
<br>
Sie sind im Begriff das OTRS-Paket TimeAccounting zu aktualisieren.<br>
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>BIENVENIDO</b>
<br>
<br>
Ud. está a punto de actualizar el paquete Contabilidad de Tiempo de OTRS.<br>
<br>
<br>
((enjoy))<br>
<br>
# create the package name
my $CodeModule = 'var::packagesetup::' . $Param{Structure}->{Name}->{Content};
$Kernel::OM->Get($CodeModule)->CodeInstall();
# create the package name
my $CodeModule = 'var::packagesetup::' . $Param{Structure}->{Name}->{Content};
$Kernel::OM->Get($CodeModule)->CodeUninstall();
2014-11-21 05:55:59
opms.otrs.com
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
<?xml version="1.0" encoding="utf-8" ?>
<otrs_config version="1.0" init="Application">
    <ConfigItem Name="Frontend::Module###AgentTimeAccountingEdit" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <Group>time_accounting</Group>
                <GroupRo>time_accounting</GroupRo>
                <Description Translatable="1">Time accounting edit.</Description>
                <NavBarName>TimeAccounting</NavBarName>
                <Title>Edit</Title>
                <NavBar>
                    <Description Translatable="1">Time accounting.</Description>
                    <Name>Time Accounting</Name>
                    <Link>Action=AgentTimeAccountingEdit</Link>
                    <NavBar>TimeAccounting</NavBar>
                    <Type>Menu</Type>
                    <Prio>6000</Prio>
                    <AccessKey></AccessKey>
                    <Block>ItemArea</Block>
                </NavBar>
                <NavBar>
                    <GroupRo>time_accounting</GroupRo>
                    <Description Translatable="1">Edit time record</Description>
                    <Name>Edit</Name>
                    <Link>Action=AgentTimeAccountingEdit</Link>
                    <Type></Type>
                    <Block></Block>
                    <NavBar>TimeAccounting</NavBar>
                    <AccessKey></AccessKey>
                    <Prio>200</Prio>
                </NavBar>
                <Loader>
                    <CSS>TimeAccounting.Defaults.css</CSS>
                    <CSS>TimeAccounting.Table.css</CSS>
                    <JavaScript>thirdparty/jquery-ui-button-1.10.3/jquery-ui-button.js</JavaScript>
                    <JavaScript>thirdparty/jquery-combobox/jquery-combobox.js</JavaScript>
                    <JavaScript>Core.UI.ComboBox.js</JavaScript>
                    <JavaScript>TimeAccounting.Agent.ConfirmationDialog.js</JavaScript>
                    <JavaScript>TimeAccounting.Agent.EditTimeRecords.js</JavaScript>
                    <JavaScript>TimeAccounting.Agent.Datepicker.js</JavaScript>
                </Loader>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Module###AgentTimeAccountingOverview" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <Group>time_accounting</Group>
                <GroupRo>time_accounting</GroupRo>
                <Description Translatable="1">Time accounting overview.</Description>
                <NavBarName>TimeAccounting</NavBarName>
                <Title>Overview</Title>
                <NavBar>
                    <GroupRo>time_accounting</GroupRo>
                    <Description Translatable="1">Overview</Description>
                    <Name>Overview</Name>
                    <Link>Action=AgentTimeAccountingOverview</Link>
                    <Type></Type>
                    <Block></Block>
                    <NavBar>TimeAccounting</NavBar>
                    <AccessKey></AccessKey>
                    <Prio>100</Prio>
                </NavBar>
                <Loader>
                    <CSS>TimeAccounting.Defaults.css</CSS>
                    <CSS>TimeAccounting.Table.css</CSS>
                </Loader>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Module###AgentTimeAccountingSetting" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <Group>time_accounting</Group>
                <GroupRo>time_accounting</GroupRo>
                <Description Translatable="1">Time accounting settings.</Description>
                <NavBarName>TimeAccounting</NavBarName>
                <Title>Settings</Title>
                <NavBar>
                    <Group>time_accounting</Group>
                    <Description Translatable="1">Edit time accounting settings</Description>
                    <Name>Settings</Name>
                    <Link>Action=AgentTimeAccountingSetting</Link>
                    <Type></Type>
                    <Block></Block>
                    <NavBar>TimeAccounting</NavBar>
                    <AccessKey></AccessKey>
                    <Prio>900</Prio>
                </NavBar>
                <Loader>
                    <CSS>TimeAccounting.Defaults.css</CSS>
                    <CSS>TimeAccounting.Table.css</CSS>
                    <JavaScript>TimeAccounting.Agent.Datepicker.js</JavaScript>
                </Loader>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Module###AgentTimeAccountingReporting" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <Group>time_accounting</Group>
                <GroupRo>time_accounting</GroupRo>
                <Description Translatable="1">Time accounting reporting.</Description>
                <NavBarName>TimeAccounting</NavBarName>
                <Title>Reporting</Title>
                <NavBar>
                    <Group>time_accounting</Group>
                    <Description Translatable="1">Project time reporting</Description>
                    <Name>Reporting</Name>
                    <Link>Action=AgentTimeAccountingReporting</Link>
                    <Type></Type>
                    <Block></Block>
                    <NavBar>TimeAccounting</NavBar>
                    <AccessKey></AccessKey>
                    <Prio>500</Prio>
                </NavBar>
               <Loader>
                    <CSS>TimeAccounting.Defaults.css</CSS>
                    <CSS>TimeAccounting.Table.css</CSS>
                </Loader>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Module###AgentTimeAccountingView" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <Group>time_accounting</Group>
                <GroupRo>time_accounting</GroupRo>
                <Description Translatable="1">Time accounting view.</Description>
                <NavBarName>TimeAccounting</NavBarName>
                <Title>View</Title>
                <NavBar>
                    <GroupRo>time_accounting</GroupRo>
                </NavBar>
                <Loader>
                    <CSS>TimeAccounting.Defaults.css</CSS>
                    <CSS>TimeAccounting.Table.css</CSS>
                </Loader>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>


    <ConfigItem Name="TimeAccounting::DefaultProjectName" Required="1" Valid="1">
        <Description Translatable="1">Default name for new projects.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex=""></String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::DefaultProjectStatus" Required="1" Valid="1">
        <Description Translatable="1">Default status for new projects.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <Option SelectedID="1">
                <Item Key="0">invalid</Item>
                <Item Key="1">valid</Item>
            </Option>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::DefaultActionName" Required="1" Valid="1">
        <Description Translatable="1">Default name for new actions.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex=""></String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::DefaultActionStatus" Required="1" Valid="1">
        <Description Translatable="1">Default status for new actions.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <Option SelectedID="1">
                <Item Key="0">invalid</Item>
                <Item Key="1">valid</Item>
            </Option>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::DefaultUserWeeklyHours" Required="1" Valid="1">
        <Description Translatable="1">Default setting for the standard weekly hours.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex="">40</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::DefaultUserLeaveDays" Required="1" Valid="1">
        <Description Translatable="1">Default setting for leave days.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex="">23</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::DefaultUserOvertime" Required="1" Valid="1">
        <Description Translatable="1">Default setting for overtime.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex="">0</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::DefaultUserDateStart" Required="1" Valid="1">
        <Description Translatable="1">Default setting for date start.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex="">2014-01-01</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::DefaultUserDateEnd" Required="1" Valid="1">
        <Description Translatable="1">Default setting for date end.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex="">2014-12-31</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::DefaultUserDescription" Required="1" Valid="1">
        <Description Translatable="1">Default setting for description.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex="">Put your description here.</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::DefaultUserStatus" Required="1" Valid="1">
        <Description Translatable="1">Default status for new users.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <Option SelectedID="1">
                <Item Key="0">invalid</Item>
                <Item Key="1">valid</Item>
            </Option>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::MaxIntervalOfIncompleteDays" Required="1" Valid="1">
        <Description Translatable="1">Maximum number of working days after which the working units have to be inserted.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex="">4</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::MaxIntervalOfIncompleteDaysBeforeWarning" Required="1" Valid="1">
        <Description Translatable="1">Maximum number of working days without working units entry after which a warning will be shown.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex="">2</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::NotifyModule###888-TimeAccounting" Required="1" Valid="1">
        <Description Translatable="1">This notification module gives a warning if there are too many incomplete working days.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent::ModuleNotify</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::NotificationTimeAccounting</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::MaxAllowedInsertDays" Required="1" Valid="1">
        <Description Translatable="1">For how many days ago you can insert working units.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex="">10</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::ReduceTime" Required="0" Valid="1">
        <Description Translatable="1">To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key =&gt; traveling; Content =&gt; 50).</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <Hash>
                <Item Key="traveling">50</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::InputHoursWithoutStartEndTime" Required="0" Valid="1">
        <Description Translatable="1">Specifies if working hours can be inserted without start and end times.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <Option SelectedID="1">
                <Item Key="0">No</Item>
                <Item Key="1">Yes</Item>
            </Option>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="PreApplicationModule###AgentTimeAccounting" Required="0" Valid="1">
        <Description Translatable="1">This module forces inserts in TimeAccounting.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex="">Kernel::Modules::AgentTimeAccountingEdit</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::Project2RemarkRegExp" Required="0" Valid="1">
        <Description Translatable="1">Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <String Regex="">^(?: PROJECT\# | INFRA: | PRODUCT: )</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::ProjectListConstraints" Required="0" Valid="1">
        <Description Translatable="1">Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <Hash>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::ActionListConstraints" Required="0" Valid="1">
        <Description Translatable="1">Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <Hash>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::EnableAutoCompletion" Required="0" Valid="1">
        <Description Translatable="1">If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <Option SelectedID="1">
                <Item Key="0">No</Item>
                <Item Key="1">Yes</Item>
            </Option>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::AllowMassEntryForUser" Required="0" Valid="1">
        <Description Translatable="1">If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent</SubGroup>
        <Setting>
            <Option SelectedID="0">
                <Item Key="0">No</Item>
                <Item Key="1">Yes</Item>
            </Option>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::ToolBarModule###201-TimeAccounting::IncompleteWorkingDays" Required="0" Valid="1">
        <Description Translatable="1">Agent interface notification module to see the number of incomplete working days for the user.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent::ToolBarModule</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::ToolBarIncompleteWorkingDays</Item>
                <Item Key="CssClass">IncompleteWorkingDays</Item>
                <Item Key="Icon">fa fa-clock-o</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Stats::DynamicObjectRegistration###TimeAccounting" Required="0" Valid="1">
        <Description Translatable="1">Determines if the statistics module may generate time accounting information.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Core::Stats</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::System::Stats::Dynamic::TimeAccounting</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="TimeAccounting::Frontend::ReportingProject###ShowOnlyActiveUsers" Required="0" Valid="1">
        <Description Translatable="1">If enabled, only users that has added working time to the selected project are shown.</Description>
        <Group>TimeAccounting</Group>
        <SubGroup>Frontend::Agent::TimeAccoutning::ViewReportingProject</SubGroup>
        <Setting>
            <Option SelectedID="1">
                <Item Key="0">No</Item>
                <Item Key="1">Yes</Item>
            </Option>
        </Setting>
    </ConfigItem>
</otrs_config>

# --
# Kernel/Language/de_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::de_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = 'Zeitabrechnung';
    $Self->{Translation}->{'Show valid projects'} = 'Gültige Projekte anzeigen';
    $Self->{Translation}->{'Show all projects'} = 'Alle Projekte anzeigen';
    $Self->{Translation}->{'TimeAccounting'} = 'ZeitAbrechnung';
    $Self->{Translation}->{'Reporting'} = 'Berichterstattung';
    $Self->{Translation}->{'Please insert your working hours!'} = 'Bitte die Arbeitsstunden eintragen!';
    $Self->{Translation}->{'Successful insert!'} = 'Eingaben gespeichert!';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = 'Fehler bei der Eingabe für mehrere Tage!';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = 'Daten für mehrere Tage erfolgreich erfasst!';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = 'Eingegebenes Datum ungültig! Datum wurde auf \'heute\' geändert.';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        'Möchten Sie wirklich den Eintrag für den aktuellen Tag löschen?';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = 'Zeitabrechnung bearbeiten';
    $Self->{Translation}->{'Go to settings'} = 'Gehe zu Einstellungen';
    $Self->{Translation}->{'Date Navigation'} = 'Datumsnavigation';
    $Self->{Translation}->{'Previous day'} = 'Vorheriger Tag';
    $Self->{Translation}->{'Next day'} = 'Nächster Tag';
    $Self->{Translation}->{'Go to this date'} = 'Gehe zu diesem Datum';
    $Self->{Translation}->{'Days without entries'} = 'Nicht ausgefüllte Tage';
    $Self->{Translation}->{'Select all days'} = 'Alle Tage auswählen';
    $Self->{Translation}->{'Mass entry'} = 'Masseneintrag';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        'Bitte wählen Sie den Grund für Ihre Abwesenheit für die ausgewählten Tage';
    $Self->{Translation}->{'On vacation'} = 'im Urlaub';
    $Self->{Translation}->{'On sick leave'} = 'Erkrankt';
    $Self->{Translation}->{'On overtime leave'} = 'Überstunden';
    $Self->{Translation}->{'Please choose at least one day!'} = 'Bitte wählen Sie mindestens einen Tag!';
    $Self->{Translation}->{'Please choose a reason for absence!'} = 'Bitte wählen Sie einen Grund für die Abwesenheit aus!';
    $Self->{Translation}->{'Mass Entry'} = 'Masseneintrag';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = 'Felder, die ausgefüllt werden müssen, sind mit einem Stern "*" gekennzeichnet.';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = 'Sie müssen eine Start- und Endzeit oder eine Zeitspanne angeben.';
    $Self->{Translation}->{'Project'} = 'Projekt';
    $Self->{Translation}->{'Task'} = 'Tätigkeit';
    $Self->{Translation}->{'Remark'} = 'Anmerkung';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = 'Bitte geben Sie eine Anmerkung mit mindestens 8 Zeichen Länge ein.';
    $Self->{Translation}->{'Start Time'} = 'Startzeit';
    $Self->{Translation}->{'Negative times are not allowed.'} = 'Negative Angaben sind nicht erlaubt.';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        'Diese Startzeit wurde bereits in einem anderen Eintrag angegeben.';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = 'Ungültiges Format! Bitte geben Sie eine Zeit im Format HH:MM ein.';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = 'Nur 24:00 ist als Endzeit erlaubt.';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = 'Ungültige Zeit! Ein Tag hat nur 24 Stunden';
    $Self->{Translation}->{'End Time'} = 'Endzeit';
    $Self->{Translation}->{'End time must be after start time.'} = 'Die Endzeit muss nach der Startzeit sein.';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        'Diese Endzeit wurde bereits in einem anderen Eintrag angegeben.';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = 'Ungültige Angabe. Ein Tag hat nur 24 Stunden.';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = 'Eine gültige Zeitdauer muss größer als Null sein.';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = 'Ungültige Angabe. Negative Zeitspannen sind nicht möglich.';
    $Self->{Translation}->{'Add one row'} = 'Eine Zeile hinzufügen';
    $Self->{Translation}->{'Total'} = 'Summe';
    $Self->{Translation}->{'You can only select one checkbox element!'} = 'Sie können nur eine Checkbox markieren!';
    $Self->{Translation}->{'Show all items'} = 'Alle Einträge anzeigen';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = 'Eintrag löschen';
    $Self->{Translation}->{'Confirm insert'} = 'Eingabe bestätigen';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = 'Sind Sie sicher, dass Sie gearbeitet haben, obwohl Sie erkrankt sind?';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = 'Sind Sie sicher, dass Sie gearbeitet haben, obwohl Sie im Urlaub sind?';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        'Sind Sie sicher, dass Sie gearbeitet haben, obwohl Sie Überstunden genommen haben?';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = 'Sind Sie sicher, dass Sie mehr als 16 Stunden gearbeitet haben?';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = 'Monatsübersicht Zeitberichterstattung';
    $Self->{Translation}->{'Overtime (Hours)'} = 'Überstunden (in Stunden)';
    $Self->{Translation}->{'Overtime (this month)'} = 'Überstunden (dieser Monat)';
    $Self->{Translation}->{'Overtime (total)'} = 'Überstunden (Summe)';
    $Self->{Translation}->{'Remaining overtime leave'} = 'Überstunden (verbleibend)';
    $Self->{Translation}->{'Vacation (Days)'} = 'Urlaub (in Tagen)';
    $Self->{Translation}->{'Vacation taken (this month)'} = 'Urlaubstage (dieser Monat)';
    $Self->{Translation}->{'Vacation taken (total)'} = 'Urlaubstage (Summe)';
    $Self->{Translation}->{'Remaining vacation'} = 'Urlaubstage (verbleibend)';
    $Self->{Translation}->{'Sick Leave (Days)'} = 'Erkrankt (in Tagen)';
    $Self->{Translation}->{'Sick leave taken (this month)'} = 'Erkrankt (dieser Monat)';
    $Self->{Translation}->{'Sick leave taken (total)'} = 'Erkrankt (Summe)';
    $Self->{Translation}->{'Previous month'} = 'Vorheriger Monat';
    $Self->{Translation}->{'Next month'} = 'Nächster Monat';
    $Self->{Translation}->{'Weekday'} = 'Wochentag';
    $Self->{Translation}->{'Working Hours'} = 'Arbeitsstunden';
    $Self->{Translation}->{'Total worked hours'} = 'Arbeitsstunden (gesamt)';
    $Self->{Translation}->{'User\'s project overview'} = 'Nutzerberichte';
    $Self->{Translation}->{'Hours (monthly)'} = 'Stunden (im Monat)';
    $Self->{Translation}->{'Hours (Lifetime)'} = 'Stunden (gesamt)';
    $Self->{Translation}->{'Grand total'} = 'Summe';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = 'Zeitberichterstattung';
    $Self->{Translation}->{'Month Navigation'} = 'Datumsauswahl';
    $Self->{Translation}->{'Go to date'} = 'Gehe zu Datum';
    $Self->{Translation}->{'User reports'} = 'Nutzerberichte';
    $Self->{Translation}->{'Monthly total'} = 'pro Monat';
    $Self->{Translation}->{'Lifetime total'} = 'Summe';
    $Self->{Translation}->{'Overtime leave'} = 'Überstunden';
    $Self->{Translation}->{'Vacation'} = 'Urlaub';
    $Self->{Translation}->{'Sick leave'} = 'Erkrankt';
    $Self->{Translation}->{'Vacation remaining'} = 'Verbleibende Urlaubstage';
    $Self->{Translation}->{'Project reports'} = 'Projektberichte';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = 'Projektübersicht';
    $Self->{Translation}->{'Go to reporting overview'} = 'Gehe zur Berichterstattungsübersicht';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        '';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        '';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = 'Zeitabrechnung-Projekteinstellungen bearbeiten';
    $Self->{Translation}->{'Add project'} = 'Projekt hinzufügen';
    $Self->{Translation}->{'Go to settings overview'} = 'Gehe zur Einstellungsübersicht';
    $Self->{Translation}->{'Add Project'} = 'Projekt hinzufügen';
    $Self->{Translation}->{'Edit Project Settings'} = 'Projekteinstellungen bearbeiten';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        'Ein Projekt mit gleichem Namen existiert bereits. Bitte wählen Sie einen anderen Namen.';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = 'Zeitabrechnungseinstellungen bearbeiten';
    $Self->{Translation}->{'Add task'} = 'Tätigkeit hinzufügen';
    $Self->{Translation}->{'New user'} = 'Neuer Benutzer';
    $Self->{Translation}->{'Filter for Projects'} = 'Filter für Projekte';
    $Self->{Translation}->{'Filter for Tasks'} = 'Filter für Tätigkeiten';
    $Self->{Translation}->{'Filter for Users'} = 'Filter für Benutzer';
    $Self->{Translation}->{'Project List'} = 'Projektliste';
    $Self->{Translation}->{'Task List'} = 'Tätigkeitsliste';
    $Self->{Translation}->{'Add Task'} = 'Tätigkeit hinzufügen';
    $Self->{Translation}->{'Edit Task Settings'} = 'Tätigkeitseinstellungen bearbeiten';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        'Eine Tätigkeit mit gleichem Namen existiert bereits. Bitte wählen Sie einen anderen Namen.';
    $Self->{Translation}->{'User List'} = 'Benutzerliste';
    $Self->{Translation}->{'New User Settings'} = 'Einstellungen für neuen Benutzer';
    $Self->{Translation}->{'Edit User Settings'} = 'Benutzereinstellungen bearbeiten';
    $Self->{Translation}->{'Comments'} = 'Kommentare';
    $Self->{Translation}->{'Show Overtime'} = 'Überstunden anzeigen';
    $Self->{Translation}->{'Allow project creation'} = 'Projekt erstellen';
    $Self->{Translation}->{'Period Begin'} = 'Datum Beginn';
    $Self->{Translation}->{'Period End'} = 'Datum Ende';
    $Self->{Translation}->{'Days of Vacation'} = 'Urlaubstage';
    $Self->{Translation}->{'Hours per Week'} = 'Wochenstunden';
    $Self->{Translation}->{'Authorized Overtime'} = 'Autorisierte Überstunden';
    $Self->{Translation}->{'Start Date'} = 'Startdatum';
    $Self->{Translation}->{'Please insert a valid date.'} = 'Bitte geben Sie ein gültiges Datum ein.';
    $Self->{Translation}->{'End Date'} = 'Enddatum';
    $Self->{Translation}->{'Period end must be after period begin.'} = 'Das Ende der Zeitspanne muss nach dem Anfang sein.';
    $Self->{Translation}->{'Leave Days'} = 'Urlaubstage';
    $Self->{Translation}->{'Weekly Hours'} = 'Wöchentliche Stunden';
    $Self->{Translation}->{'Overtime'} = 'Überstunden';
    $Self->{Translation}->{'No time periods found.'} = 'Keine Zeitspanne gefunden.';
    $Self->{Translation}->{'Add time period'} = 'Zeitspanne hinzufügen';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = 'Datensatz anzeigen';
    $Self->{Translation}->{'View of '} = 'Ansicht von';
    $Self->{Translation}->{'No data found for this day.'} = 'Kein Eintrag für diesen Tag gefunden.';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        'Modul zum Anzeigen der Anzahl der unvollständigen Arbeitstage des Benutzers.';
    $Self->{Translation}->{'Default name for new actions.'} = 'Standardname für neue Tätigkeiten.';
    $Self->{Translation}->{'Default name for new projects.'} = 'Anfangsstatus eines neuen Projekts.';
    $Self->{Translation}->{'Default setting for date end.'} = 'Standardeinstellung für Enddatum.';
    $Self->{Translation}->{'Default setting for date start.'} = 'Standardeinstellung für Startdatum.';
    $Self->{Translation}->{'Default setting for description.'} = 'Standardeinstellung für Beschreibungen.';
    $Self->{Translation}->{'Default setting for leave days.'} = 'Standardeinstellung für Urlaubstage.';
    $Self->{Translation}->{'Default setting for overtime.'} = 'Eventuell vorhandener Überstundenübertrag.';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = 'Standard Wochenarbeitszeit.';
    $Self->{Translation}->{'Default status for new actions.'} = 'Anfangsstatus einer neuen Tätigkeit.';
    $Self->{Translation}->{'Default status for new projects.'} = 'Anfangsstatus eines neuen Projekts.';
    $Self->{Translation}->{'Default status for new users.'} = 'Anfangsstatus eines neuen Benutzers.';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        'Innerhalb dieser Konfigurationsoption kann eine RegExp definiert werden, die festlegt, bei welchen Projekten eine Bemerkung eingetragen werden muss (die RegExp arbeitet mit smx-Parametern).';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        'Bestimmt, ob das Statistik-Modul Informationen zur Zeitabrechnung generieren kann.';
    $Self->{Translation}->{'Edit time accounting settings'} = 'Zeitabrechnungseinstellungen bearbeiten';
    $Self->{Translation}->{'Edit time record'} = 'Zeiterfassung bearbeiten';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = 'Legt fest, bis wann man in ältere Zeiteinträge bearbeiten kann (z. B. 10 Tage zurückliegend).';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        'Wenn aktiviert, werden nur User angezeigt die Arbeitszeiten zu dem gewählten Projekt hinzugefügt haben.';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        'Aktiviert die Autocompletion auf den Eingabefeldern im Bearbeiten-Bereich.';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        'Wenn aktiviert,  können Benutzer "im Urlaub", "Erkrankt" und "Überstunden" an mehreren Tagen auf einmal setzen.';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        'Maximale Anzahl von Arbeitstagen, nach der die Arbeitszeit eingetragen werden muss.';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        'Maximale Anzahl von Arbeitstagen ohne Arbeitszeiteinträge nach denen eine Warnung angezeigt wird.';
    $Self->{Translation}->{'Project time reporting'} = 'Projekt-Zeitberichterstattung';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        'Regulärer Ausdruck, um die Liste der Tätigkeiten bezüglich des ausgewählten Projekts einzuschränken. Der Schlüssel enthält einen Regulären Ausdruck für Projekte, der Wert einen Regulären Ausdruck für die Tätigkeiten.';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        'Regulärer Ausdruck, um die Liste der Projekte bezüglich des aktiven Benutzers einzuschränken. Der Schlüssel enthält einen Regulären Ausdruck für Projekte, der Wert enthält eine komma-separierte Liste von Benutzergruppen.';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        'Gibt an, ob Arbeitsstunden ohne Start- und Endzeit eingegeben werden können.';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = 'Dieses Modul zwingt zur Eingabe von Stunden.';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        'Modul, dass den Agent im Notification-Bereich des Agent-Interfaces darüber informiert, wenn schon zu lange keine Stunden mehr eingetragen wurden.';
    $Self->{Translation}->{'Time accounting edit.'} = 'Zeitabrechnung Bearbeitung.';
    $Self->{Translation}->{'Time accounting overview.'} = 'Zeitabrechnung Übersicht.';
    $Self->{Translation}->{'Time accounting reporting.'} = 'Zeitabrechnung Berichterstattung.';
    $Self->{Translation}->{'Time accounting settings.'} = 'Zeitabrechnung Einstellungen.';
    $Self->{Translation}->{'Time accounting view.'} = 'Zeitabrechnung Ansicht.';
    $Self->{Translation}->{'Time accounting.'} = 'Zeitabrechnung.';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        'Hier kann man eingeben, ob für eine bestimmte Tätigkeit, die zu verrechnenden Stunden gekürzt werden. Z. B wenn Reisezeiten nur zur Hälfte vergütet werden (Key =&gt; journey; Content =&gt; 50).';

}

1;

# --
# Kernel/Language/da_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::da_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = '';
    $Self->{Translation}->{'Show valid projects'} = '';
    $Self->{Translation}->{'Show all projects'} = '';
    $Self->{Translation}->{'TimeAccounting'} = '';
    $Self->{Translation}->{'Reporting'} = '';
    $Self->{Translation}->{'Please insert your working hours!'} = '';
    $Self->{Translation}->{'Successful insert!'} = '';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = '';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = '';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = '';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        'Vil du virkelig slette tidsregnskabet for denne dag?';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = 'Rediger tidsregistrering';
    $Self->{Translation}->{'Go to settings'} = '';
    $Self->{Translation}->{'Date Navigation'} = 'Datonavigation';
    $Self->{Translation}->{'Previous day'} = 'Forrige dag';
    $Self->{Translation}->{'Next day'} = 'Næste dag';
    $Self->{Translation}->{'Go to this date'} = '';
    $Self->{Translation}->{'Days without entries'} = 'Dage uden optegnelser';
    $Self->{Translation}->{'Select all days'} = '';
    $Self->{Translation}->{'Mass entry'} = '';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        '';
    $Self->{Translation}->{'On vacation'} = 'På ferie';
    $Self->{Translation}->{'On sick leave'} = 'Sygefravær';
    $Self->{Translation}->{'On overtime leave'} = 'Afspadsering';
    $Self->{Translation}->{'Please choose at least one day!'} = '';
    $Self->{Translation}->{'Please choose a reason for absence!'} = '';
    $Self->{Translation}->{'Mass Entry'} = '';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = 'De påkrævede felter er markeret med "*".';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = 'Du skal indtaste en start- og slutdato eller en tidsperiode.';
    $Self->{Translation}->{'Project'} = 'Projekt';
    $Self->{Translation}->{'Task'} = 'Opgave';
    $Self->{Translation}->{'Remark'} = 'Bemærkning';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = 'Tilføj venligst en bemærkning med mere end 8 tegn!';
    $Self->{Translation}->{'Start Time'} = '';
    $Self->{Translation}->{'Negative times are not allowed.'} = 'Negativ tid er ikke tilladt.';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        'Gentagne timer er ikke tilladt. Starttiden svarer til et andet interval.';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = '';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = '';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = '';
    $Self->{Translation}->{'End Time'} = '';
    $Self->{Translation}->{'End time must be after start time.'} = 'Sluttiden skal være senere end starttiden.';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        'Gentagne timer er ikke tilladt. Sluttiden svarer til et andet interval.';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = 'Ugyldig periode! En dag har kun 24 timer.';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = 'En gyldig periode skal være større end 0';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = 'Ugyldig periode! Negative perioder er ikke tilladt.';
    $Self->{Translation}->{'Add one row'} = 'Tilføj en række';
    $Self->{Translation}->{'Total'} = 'I alt';
    $Self->{Translation}->{'You can only select one checkbox element!'} = 'Du kan kun vælge et afkrydsningsfelt!';
    $Self->{Translation}->{'Show all items'} = 'Vis alle punkter';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = 'Slet tidsregnskabsindtastning';
    $Self->{Translation}->{'Confirm insert'} = 'Bekræft indsættelse';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = 'Er du sikker på, at du arbejdede under dit sygefravær?';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = 'Er du sikker på, at du arbejdede, mens du var på ferie?';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        'Er du sikker pá, at du arbejdede, mens du var på afspadsering?';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = 'Er du sikker på, at du arbejdede mere end 16 timer?';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = 'Månedlig oversigt over tidsraportering';
    $Self->{Translation}->{'Overtime (Hours)'} = 'Overtid (timer)';
    $Self->{Translation}->{'Overtime (this month)'} = 'Overtid (denne måned)';
    $Self->{Translation}->{'Overtime (total)'} = 'Overtid (i alt)';
    $Self->{Translation}->{'Remaining overtime leave'} = 'Resterende afspadsering';
    $Self->{Translation}->{'Vacation (Days)'} = 'Ferie (dage)';
    $Self->{Translation}->{'Vacation taken (this month)'} = 'Feriedage brugt (denne måned)';
    $Self->{Translation}->{'Vacation taken (total)'} = 'Feriedage brugt (i alt)';
    $Self->{Translation}->{'Remaining vacation'} = 'Resterende feriedage';
    $Self->{Translation}->{'Sick Leave (Days)'} = 'Sygefravær (dage)';
    $Self->{Translation}->{'Sick leave taken (this month)'} = 'Sygefravær brugt (denne måned)';
    $Self->{Translation}->{'Sick leave taken (total)'} = 'Sygefravær brugt (i alt)';
    $Self->{Translation}->{'Previous month'} = 'Forrige måned';
    $Self->{Translation}->{'Next month'} = 'Næste måned';
    $Self->{Translation}->{'Weekday'} = 'Ugedag';
    $Self->{Translation}->{'Working Hours'} = 'Arbejdstimer';
    $Self->{Translation}->{'Total worked hours'} = 'Arbejdstimer i alt';
    $Self->{Translation}->{'User\'s project overview'} = 'Brugers projektoverblik';
    $Self->{Translation}->{'Hours (monthly)'} = 'Timer (månedlig)';
    $Self->{Translation}->{'Hours (Lifetime)'} = 'Samlet antal timer';
    $Self->{Translation}->{'Grand total'} = 'Alt i alt';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = 'Tidsraportering';
    $Self->{Translation}->{'Month Navigation'} = 'Månedsnavigation';
    $Self->{Translation}->{'Go to date'} = '';
    $Self->{Translation}->{'User reports'} = 'Brugerrapporter';
    $Self->{Translation}->{'Monthly total'} = 'I alt for måned';
    $Self->{Translation}->{'Lifetime total'} = 'Samlet total';
    $Self->{Translation}->{'Overtime leave'} = 'Afspadsering';
    $Self->{Translation}->{'Vacation'} = 'Ferie';
    $Self->{Translation}->{'Sick leave'} = 'Sygefravær';
    $Self->{Translation}->{'Vacation remaining'} = 'Resterende fraværsdage';
    $Self->{Translation}->{'Project reports'} = 'Projektrapporter';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = 'Projektrapport';
    $Self->{Translation}->{'Go to reporting overview'} = '';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        '';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        '';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = 'Rediger indstillinger for tidsregnskabsprojekt';
    $Self->{Translation}->{'Add project'} = 'Tilføj projekt';
    $Self->{Translation}->{'Go to settings overview'} = '';
    $Self->{Translation}->{'Add Project'} = 'Tilføj projekt';
    $Self->{Translation}->{'Edit Project Settings'} = 'Rediger projektindstillinger';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        'Der er allerede et projekt med dette navn. Vælg venligst et andet.';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = 'Rediger tidsregnskabsindstilinger';
    $Self->{Translation}->{'Add task'} = 'Tilføj opgave';
    $Self->{Translation}->{'New user'} = 'Ny bruger';
    $Self->{Translation}->{'Filter for Projects'} = 'Filtrér projekter';
    $Self->{Translation}->{'Filter for Tasks'} = 'Filtrér opgaver';
    $Self->{Translation}->{'Filter for Users'} = 'Filtrér brugere';
    $Self->{Translation}->{'Project List'} = 'Projektliste';
    $Self->{Translation}->{'Task List'} = 'Opgaveliste';
    $Self->{Translation}->{'Add Task'} = 'Tilføj opgave';
    $Self->{Translation}->{'Edit Task Settings'} = 'Rediger opgaveindstillinger';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        'Der er allerede en opgave med dette navn. Vælg venligst et andet.';
    $Self->{Translation}->{'User List'} = 'Brugerliste';
    $Self->{Translation}->{'New User Settings'} = 'Nye brugerindstillinger';
    $Self->{Translation}->{'Edit User Settings'} = 'Rediger brugerindstillinger';
    $Self->{Translation}->{'Comments'} = 'Kommentarer';
    $Self->{Translation}->{'Show Overtime'} = 'Vis overtid';
    $Self->{Translation}->{'Allow project creation'} = 'Tillad oprettelse af projekt';
    $Self->{Translation}->{'Period Begin'} = 'Begynd periode';
    $Self->{Translation}->{'Period End'} = 'Afslut periode';
    $Self->{Translation}->{'Days of Vacation'} = 'Feriedage';
    $Self->{Translation}->{'Hours per Week'} = 'Timer pr. uge';
    $Self->{Translation}->{'Authorized Overtime'} = 'Godkendt overtid';
    $Self->{Translation}->{'Start Date'} = '';
    $Self->{Translation}->{'Please insert a valid date.'} = '';
    $Self->{Translation}->{'End Date'} = '';
    $Self->{Translation}->{'Period end must be after period begin.'} = 'Periodens afslutning skal være efter periodens start.';
    $Self->{Translation}->{'Leave Days'} = '';
    $Self->{Translation}->{'Weekly Hours'} = '';
    $Self->{Translation}->{'Overtime'} = '';
    $Self->{Translation}->{'No time periods found.'} = 'Ingen tidsperioder fundet.';
    $Self->{Translation}->{'Add time period'} = 'Tilføj tidsperiode';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = 'Se tidsregistrering';
    $Self->{Translation}->{'View of '} = 'Se ';
    $Self->{Translation}->{'No data found for this day.'} = 'Der er ikke fundet data for denne dag.';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        'Agent interface-notificationsmodulet skal se antallet af uafsluttede arbejdsdage for brugeren.';
    $Self->{Translation}->{'Default name for new actions.'} = 'Standardnavn for nye handlinger.';
    $Self->{Translation}->{'Default name for new projects.'} = 'Standardnavn for nye projekter.';
    $Self->{Translation}->{'Default setting for date end.'} = 'Standardindstilling for slutdato.';
    $Self->{Translation}->{'Default setting for date start.'} = 'Standardindstilling for begyndelsesdato.';
    $Self->{Translation}->{'Default setting for description.'} = '';
    $Self->{Translation}->{'Default setting for leave days.'} = 'Standardindstilling for fraværsdage.';
    $Self->{Translation}->{'Default setting for overtime.'} = 'Standardindstilling for overtid.';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = 'Standardindstilling for normale ugentlige timer.';
    $Self->{Translation}->{'Default status for new actions.'} = 'Standardindstilling for nye handlinger.';
    $Self->{Translation}->{'Default status for new projects.'} = 'Standardindstilling for nye projekter.';
    $Self->{Translation}->{'Default status for new users.'} = 'Standardindstilling for nye brugere.';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        'Definerer de projekter, for hvilke en bemærkning er påkrævet. Hvis RegExp matcher på projektet, skal du også indføje en bemærkning. RegExp bruger smx parameteret.';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        '';
    $Self->{Translation}->{'Edit time accounting settings'} = 'Rediger indstillinger for tidsregistrering';
    $Self->{Translation}->{'Edit time record'} = 'Rediger tidsoptegnelse';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = 'Angiver for hvor mange dage, du kan indsætte arbejdsenheder.';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        '';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        'Hvis denne er aktiveret, ændres dropdown-elementerne på redigeringsskærmbilledet til autofuldføringsfelter.';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        '';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        'Maksimalt antal af arbejdsdage efter hvilket arbejdsenhederne skal indsættes.';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        '';
    $Self->{Translation}->{'Project time reporting'} = 'Projekttidsrapportering';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        'Regulære udtryk for begrænsning af handlingsliste ifølge det valgte projekt. Nøglen indeholder et regulært udtryk for projekt(er), indholdet rummer regulære udtryk for handling(er).';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        'Regulære udtryk for begrænsning af projektliste ifølge brugergrupper. Nøglen indeholder et regulært udtryk for projekt(er), indholdet rummer kommasepareret liste over grupper.';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        'Angiver, om arbejdstimer kan indsættes uden start- og sluttider.';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = 'Dette modul gennemtvinger indsættelser i tidsregnskab.';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        'Dette adviseringsmodul giver en advarsel, hvis der er for mange ufuldstændige arbejdsdage.';
    $Self->{Translation}->{'Time accounting edit.'} = '';
    $Self->{Translation}->{'Time accounting overview.'} = '';
    $Self->{Translation}->{'Time accounting reporting.'} = '';
    $Self->{Translation}->{'Time accounting settings.'} = '';
    $Self->{Translation}->{'Time accounting view.'} = '';
    $Self->{Translation}->{'Time accounting.'} = 'Tidsregnskab';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        'Bruges, hvis nogle handlinger har reduceret arbejdstimerne (f.eks. hvis kun halvdelen af rejsetiden er betalt Key => traveling; Content => 50)';

}

1;

# --
# Kernel/Language/es_MX_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::es_MX_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = 'Contabilidad de Tiempo';
    $Self->{Translation}->{'Show valid projects'} = 'Mostrar proyectos válidos';
    $Self->{Translation}->{'Show all projects'} = 'Mostrar todos los proyectos';
    $Self->{Translation}->{'TimeAccounting'} = 'Contabilidad de Tiempo';
    $Self->{Translation}->{'Reporting'} = 'Reportes';
    $Self->{Translation}->{'Please insert your working hours!'} = 'Por favor inserte sus horas de trabajo!';
    $Self->{Translation}->{'Successful insert!'} = 'Inserción exitosa!';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = 'Error al insertar múltiples fechas!';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = 'Se insertaron satisfactoriamente las entradas de varias fechas! ';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = 'La fecha entrada es incorrecta! La fecha de ha cambiado a hoy.';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        '¿Realmente desea eliminar la Contabilidad de Tiempo de este día?';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = 'Modificar Registro de Horas';
    $Self->{Translation}->{'Go to settings'} = 'Ir a configuraciones';
    $Self->{Translation}->{'Date Navigation'} = 'Navegación por Fecha';
    $Self->{Translation}->{'Previous day'} = 'Día anterior';
    $Self->{Translation}->{'Next day'} = 'Día siguiente';
    $Self->{Translation}->{'Go to this date'} = 'Ir a esta fecha';
    $Self->{Translation}->{'Days without entries'} = 'Días sin registro';
    $Self->{Translation}->{'Select all days'} = 'Seleccionar todos los días';
    $Self->{Translation}->{'Mass entry'} = 'Registro masivo';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        'Por favor escoja una razón para su ausencia para los días seleccionados';
    $Self->{Translation}->{'On vacation'} = 'De vacaciones';
    $Self->{Translation}->{'On sick leave'} = 'Ausente por enfermedad';
    $Self->{Translation}->{'On overtime leave'} = 'Ausente por haber trabajado horas extras';
    $Self->{Translation}->{'Please choose at least one day!'} = 'Por favor seleccione al menos un día.';
    $Self->{Translation}->{'Please choose a reason for absence!'} = 'Por favor escoja una razón por ausencia.';
    $Self->{Translation}->{'Mass Entry'} = 'Registro Masivo';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = 'Los campos requeridos están marcados con un "*".';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = 'Es necesario que proporcione una hora de inicio y una de finalización o un periodo.';
    $Self->{Translation}->{'Project'} = 'Proyecto';
    $Self->{Translation}->{'Task'} = 'Tarea';
    $Self->{Translation}->{'Remark'} = 'Comentario';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = '¿Por favor, escriba un comentario de más de 8 caracteres!';
    $Self->{Translation}->{'Start Time'} = 'Hora de inicio';
    $Self->{Translation}->{'Negative times are not allowed.'} = 'No se permite la inserción de horas negativas.';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        'No se permite la inserción de horas repetidas. La hora de inicio está incluída en otro intervalo.';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = 'Formato inválido! Por favor introduzca las horas con el formato HH:MM.';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = '24:00 es solo permitido como tiempo final.';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = 'Hora inválida! Un día solo tiene 24 horas.';
    $Self->{Translation}->{'End Time'} = 'Hora de finalización';
    $Self->{Translation}->{'End time must be after start time.'} = 'La hora de finalización debe ser posterior a la de inicio.';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        'No se permite la inserción de horas repetidas. La hora de finalización está incluída en otro intervalo.';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = '¡Periodo inválido! Un día sólo tiene 24 horas.';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = 'Un periodo válido debe ser mayor a cero.';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = '¡Periodo inválido! No se permiten periodos negativos.';
    $Self->{Translation}->{'Add one row'} = 'Añadir una fila';
    $Self->{Translation}->{'Total'} = 'Total';
    $Self->{Translation}->{'You can only select one checkbox element!'} = '¡Sólo se permite elegir un elemento checkbox!';
    $Self->{Translation}->{'Show all items'} = 'Mostrar todos los elementos';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = 'Eliminar Registro de Contabilidad de Tiempo';
    $Self->{Translation}->{'Confirm insert'} = 'Confirmar inserción';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = '¿Está seguro que trabajó durante su ausencia por enfermedad?';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = '¿Está seguro que trabajó durante sus vacaciones?';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        '¿Está seguro que trabajó durante su ausencia por haber trabajado horas extras?';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = '¿Está seguro que trabajó más de 16 horas?';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = 'Vista mensual de tiempos reportados';
    $Self->{Translation}->{'Overtime (Hours)'} = 'Número de horas extras';
    $Self->{Translation}->{'Overtime (this month)'} = 'Horas extras trabajadas (este mes)';
    $Self->{Translation}->{'Overtime (total)'} = 'Total de horas extras';
    $Self->{Translation}->{'Remaining overtime leave'} = 'Horas restantes para ausentarse por haber trabajado horas extras';
    $Self->{Translation}->{'Vacation (Days)'} = 'Vacaciones (días)';
    $Self->{Translation}->{'Vacation taken (this month)'} = 'Vacaciones (este mes)';
    $Self->{Translation}->{'Vacation taken (total)'} = 'Vacaciones tomadas (total)';
    $Self->{Translation}->{'Remaining vacation'} = 'Días de vacaciones restantes';
    $Self->{Translation}->{'Sick Leave (Days)'} = 'Ausencia por enfermedad (días)';
    $Self->{Translation}->{'Sick leave taken (this month)'} = 'Ausencias por enfermedad (este mes)';
    $Self->{Translation}->{'Sick leave taken (total)'} = 'Ausencias por enfermedad (total)';
    $Self->{Translation}->{'Previous month'} = 'Mes anterior';
    $Self->{Translation}->{'Next month'} = 'Mes siguiente';
    $Self->{Translation}->{'Weekday'} = 'Día de la semana';
    $Self->{Translation}->{'Working Hours'} = 'Horas trabajadas';
    $Self->{Translation}->{'Total worked hours'} = 'Total de horas trabajadas';
    $Self->{Translation}->{'User\'s project overview'} = 'Vista de proyecto de usuario';
    $Self->{Translation}->{'Hours (monthly)'} = 'Horas (mensuales)';
    $Self->{Translation}->{'Hours (Lifetime)'} = 'Horas (tiempo de vida)';
    $Self->{Translation}->{'Grand total'} = 'Total neto';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = 'Reporte de horas';
    $Self->{Translation}->{'Month Navigation'} = 'Navegación por mes';
    $Self->{Translation}->{'Go to date'} = 'Ir a fecha';
    $Self->{Translation}->{'User reports'} = 'Reportes de usuario';
    $Self->{Translation}->{'Monthly total'} = 'Total mensual';
    $Self->{Translation}->{'Lifetime total'} = 'Tiempo total de vida';
    $Self->{Translation}->{'Overtime leave'} = 'Ausencia por haber trabajado horas extras';
    $Self->{Translation}->{'Vacation'} = 'Vacaciones';
    $Self->{Translation}->{'Sick leave'} = 'Ausencia por enfermedad';
    $Self->{Translation}->{'Vacation remaining'} = 'Días libres restantes';
    $Self->{Translation}->{'Project reports'} = 'Reportes de proyecto';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = 'Reporte de proyecto';
    $Self->{Translation}->{'Go to reporting overview'} = 'Ir al resumen de reportes';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        'Actualmente solo se muestran los usuarios activos en este proyecto. Para cambiar este comportamiento, por favor actualize la configuración:';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        'Actualmente se muestran todos los usuarios de contabilidad de tiempo. Para cambiar este comportamiento, por favor actualize la configuración:';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = 'Modificar la configuración del proyecto de contabilidad de tiempo';
    $Self->{Translation}->{'Add project'} = 'Agregar proyecto';
    $Self->{Translation}->{'Go to settings overview'} = 'Ir al resumen de configuración';
    $Self->{Translation}->{'Add Project'} = 'Agregar Proyecto';
    $Self->{Translation}->{'Edit Project Settings'} = 'Modificar la Configuración del Proyecto';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        'Ya existe un proyecto con este nombre. Por favor, elija uno diferente.';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = 'Modificar la Configuración de la Contabilidad de Tiempo';
    $Self->{Translation}->{'Add task'} = 'Agregar tarea';
    $Self->{Translation}->{'New user'} = 'Usuario nuevo';
    $Self->{Translation}->{'Filter for Projects'} = 'Filtro para Proyectos';
    $Self->{Translation}->{'Filter for Tasks'} = 'Filtro para Tareas';
    $Self->{Translation}->{'Filter for Users'} = 'Filtro para Usuarios';
    $Self->{Translation}->{'Project List'} = 'Lista de Proyectos';
    $Self->{Translation}->{'Task List'} = 'Lista de Tareas';
    $Self->{Translation}->{'Add Task'} = 'Agregar Tarea';
    $Self->{Translation}->{'Edit Task Settings'} = 'Modificar la Configuración de la Tarea';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        'Ya existe una tarea con este nombre. Por favor, elija uno diferente.';
    $Self->{Translation}->{'User List'} = 'Lista de Usuarios';
    $Self->{Translation}->{'New User Settings'} = 'Configuración de Usuario Nuevo';
    $Self->{Translation}->{'Edit User Settings'} = 'Modificar la Configuración del Usuario';
    $Self->{Translation}->{'Comments'} = 'Comentarios';
    $Self->{Translation}->{'Show Overtime'} = 'Mostrar horas extra';
    $Self->{Translation}->{'Allow project creation'} = 'Permitir creación de proyectos';
    $Self->{Translation}->{'Period Begin'} = 'Periodo de inicio';
    $Self->{Translation}->{'Period End'} = 'Periodo de finalización';
    $Self->{Translation}->{'Days of Vacation'} = 'Días de Vacaciones';
    $Self->{Translation}->{'Hours per Week'} = 'Horas por Semana';
    $Self->{Translation}->{'Authorized Overtime'} = 'Tiempo Extra Autorizado';
    $Self->{Translation}->{'Start Date'} = 'Fecha de inicio';
    $Self->{Translation}->{'Please insert a valid date.'} = 'Por favor inserte una fecha válida.';
    $Self->{Translation}->{'End Date'} = 'Fecha de finalización';
    $Self->{Translation}->{'Period end must be after period begin.'} = 'El periodo de finalización debe ser posterior al de inicio.';
    $Self->{Translation}->{'Leave Days'} = 'Días de ausencia';
    $Self->{Translation}->{'Weekly Hours'} = 'Horas semanales';
    $Self->{Translation}->{'Overtime'} = 'Horas extra';
    $Self->{Translation}->{'No time periods found.'} = 'No se encontraron periodos de tiempo.';
    $Self->{Translation}->{'Add time period'} = 'Agregar periodo de tiempo';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = 'Ver registro de tiempo';
    $Self->{Translation}->{'View of '} = 'Resumen de ';
    $Self->{Translation}->{'No data found for this day.'} = 'No se encontraron datos de este día.';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        'Módulo de notificación de la interfaz del agente, necesario para visualizar el número de días incompletos de un usuario.';
    $Self->{Translation}->{'Default name for new actions.'} = 'Nombre por defecto para acciones nuevas.';
    $Self->{Translation}->{'Default name for new projects.'} = 'Nombre por defecto para proyectos nuevos.';
    $Self->{Translation}->{'Default setting for date end.'} = 'Configuración por defecto para la fecha de finalización.';
    $Self->{Translation}->{'Default setting for date start.'} = 'Configuración por defecto para la fecha de inicio.';
    $Self->{Translation}->{'Default setting for description.'} = 'Configuración por defecto para la descripción.';
    $Self->{Translation}->{'Default setting for leave days.'} = 'Configuración por defecto para las faltas (días de ausencia).';
    $Self->{Translation}->{'Default setting for overtime.'} = 'Configuración por defecto para las horas extras.';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = 'Configuración por defecto para las horas semanales estándar.';
    $Self->{Translation}->{'Default status for new actions.'} = 'Estado por defecto para acciones nuevas.';
    $Self->{Translation}->{'Default status for new projects.'} = 'Estado por defecto para proyectos nuevos.';
    $Self->{Translation}->{'Default status for new users.'} = 'Estado por defecto para usuarios nuevos.';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        'Define para cuáles proyectos es obligatoria la inserción de comentarios. Si la expresión regular coincide con el proyecto, se tiene que escribir un comentario. La expresión regular usa el parámetro smx.';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        'Determina si el módulo de estadísticas debe generar información de contabilidad de tiempo.';
    $Self->{Translation}->{'Edit time accounting settings'} = 'Modificar la configuración de la contabilidad de tiempo';
    $Self->{Translation}->{'Edit time record'} = 'Modificar registro de tiempo';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = 'Especifica el número máximo de días para registrar horas de trabajo atrasadas (por ejemplo: 10 días de antigüedad).';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        'Si se habilita, solamente los usuarios que han registrado sus tiempos en el proyecto seleccionado serán mostrados';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        'Si se habilita, los elementos desplegables de la ventana de edición se cambian por campos de autocompletado.';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        'Si se habilita, se le permitirá al usuario registrar "vacaciones", "ausencia por enfermedad", "ausencia por haber trabajado horas extra" en múltiples fechas al mismo tiempo.';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        'Número máximo de días laborales después de los cuales es obligatorio reportar las horas trabajadas.';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        'Número máximo de días laborales sin registro de horas trabajadas después de los cuales se mostrará una advertencia';
    $Self->{Translation}->{'Project time reporting'} = 'Reporte de tiempos de proyecto';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        'Expresiones regulares para restringir la lista de acciones, de acuerdo al proyecto seleccionado. Key contiene la expresión regular para los proyectos y Content, las expresiones regulares para las acciones.';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        'Expresiones regulares para restringir la lista de proyectos, de acuerdo a los grupos de usuarios. Key contiene la expresión regular para los proyectos y Content, una lista de grupos, separados por comas.';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        'Especifica si es posible insertar las horas trabajadas sin definir los tiempos de inicio y finalización de las tareas.';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = 'Este módulo hace obligatoria la inserción de horas trabajadas.';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        'Módulo de notificación que muestra una advertencia si hay demasiados días sin registro de horas trabajadas.';
    $Self->{Translation}->{'Time accounting edit.'} = 'Editar contabilidad de tiempo';
    $Self->{Translation}->{'Time accounting overview.'} = 'Resumen de contabilidad de tiempo';
    $Self->{Translation}->{'Time accounting reporting.'} = 'Reporte de contabilidad de tiempo';
    $Self->{Translation}->{'Time accounting settings.'} = 'Ajustes de contabilidad de tiempo';
    $Self->{Translation}->{'Time accounting view.'} = 'Ver contabilidad de tiempo';
    $Self->{Translation}->{'Time accounting.'} = 'Contabilidad de tiempo.';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        'Se usa si algunas acciones reducen el número de horas trabajadas (por ejemplo: si sólo se paga la mitad del tiempo de viaje puede especificarse Key => Viaje; Content => 50).';

}

1;

# --
# Kernel/Language/es_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::es_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = 'Contabilidad de Tiempo';
    $Self->{Translation}->{'Show valid projects'} = 'Mostrar proyectos válidos';
    $Self->{Translation}->{'Show all projects'} = 'Mostrar todos los proyectos';
    $Self->{Translation}->{'TimeAccounting'} = 'Contabilidad de Tiempo';
    $Self->{Translation}->{'Reporting'} = 'Reportes';
    $Self->{Translation}->{'Please insert your working hours!'} = 'For favor inserte sus horas de trabajo!';
    $Self->{Translation}->{'Successful insert!'} = 'Inserción exitosa!';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = 'Error al insertar multiples fechas!';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = 'Se han insertado satisfactoriamente entradas para varias fechas!';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = 'La fecha errada es inválida! La fechas fue cambiada a hoy.';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        '¿Realmente desea eliminar la Contabilidad de Tiempo de este día?';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = 'Modificar Registro de Horas';
    $Self->{Translation}->{'Go to settings'} = 'Ir a configuraciones';
    $Self->{Translation}->{'Date Navigation'} = 'Navegación por Fecha';
    $Self->{Translation}->{'Previous day'} = 'Día anterior';
    $Self->{Translation}->{'Next day'} = 'Día siguiente';
    $Self->{Translation}->{'Go to this date'} = 'Ir a esta fecha';
    $Self->{Translation}->{'Days without entries'} = 'Días sin registro';
    $Self->{Translation}->{'Select all days'} = 'Seleccionar todos los días';
    $Self->{Translation}->{'Mass entry'} = 'Registro masivo';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        'Por favor escoja una razón para su ausencia para los días seleccionados';
    $Self->{Translation}->{'On vacation'} = 'De vacaciones';
    $Self->{Translation}->{'On sick leave'} = 'Ausente por enfermedad';
    $Self->{Translation}->{'On overtime leave'} = 'Ausente por haber trabajado horas extras';
    $Self->{Translation}->{'Please choose at least one day!'} = 'Por favor seleccione al menos un día.';
    $Self->{Translation}->{'Please choose a reason for absence!'} = 'Por favor escoja una razón por ausencia.';
    $Self->{Translation}->{'Mass Entry'} = 'Registro Masivo';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = 'Los campos requeridos están marcados con un "*".';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = 'Es necesario que proporcione una hora de inicio y una de finalización o un periodo.';
    $Self->{Translation}->{'Project'} = 'Proyecto';
    $Self->{Translation}->{'Task'} = 'Tarea';
    $Self->{Translation}->{'Remark'} = 'Comentario';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = '¿Por favor, escriba un comentario de más de 8 caracteres!';
    $Self->{Translation}->{'Start Time'} = 'Hora de inicio';
    $Self->{Translation}->{'Negative times are not allowed.'} = 'No se permite la inserción de horas negativas.';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        'No se permite la inserción de horas repetidas. La hora de inicio está incluída en otro intervalo.';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = 'Formato inválido! Por favor introduzca las horas con el formato HH:MM.';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = '24:00 es solo permitido como tiempo final.';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = 'Hora inválida! Un día solo tiene 24 horas.';
    $Self->{Translation}->{'End Time'} = 'Hora de finalización';
    $Self->{Translation}->{'End time must be after start time.'} = 'La hora de finalización debe ser posterior a la de inicio.';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        'No se permite la inserción de horas repetidas. La hora de finalización está incluída en otro intervalo.';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = '¡Periodo inválido! Un día sólo tiene 24 horas.';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = 'Un periodo válido debe ser mayor a cero.';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = '¡Periodo inválido! No se permiten periodos negativos.';
    $Self->{Translation}->{'Add one row'} = 'Añadir una fila';
    $Self->{Translation}->{'Total'} = 'Total';
    $Self->{Translation}->{'You can only select one checkbox element!'} = '¡Sólo se permite elegir un elemento checkbox!';
    $Self->{Translation}->{'Show all items'} = 'Mostrar todos los elementos';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = 'Eliminar Registro de Contabilidad de Tiempo';
    $Self->{Translation}->{'Confirm insert'} = 'Confirmar inserción';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = '¿Está seguro que trabajó durante su ausencia por enfermedad?';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = '¿Está seguro que trabajó durante sus vacaciones?';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        '¿Está seguro que trabajó durante su ausencia por haber trabajado horas extras?';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = '¿Está seguro que trabajó más de 16 horas?';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = 'Vista mensual de tiempos reportados';
    $Self->{Translation}->{'Overtime (Hours)'} = 'Número de horas extras';
    $Self->{Translation}->{'Overtime (this month)'} = 'Horas extras trabajadas (este mes)';
    $Self->{Translation}->{'Overtime (total)'} = 'Total de horas extras';
    $Self->{Translation}->{'Remaining overtime leave'} = 'Horas restantes para ausentarse por haber trabajado horas extras';
    $Self->{Translation}->{'Vacation (Days)'} = 'Vacaciones (días)';
    $Self->{Translation}->{'Vacation taken (this month)'} = 'Vacaciones (este mes)';
    $Self->{Translation}->{'Vacation taken (total)'} = 'Vacaciones tomadas (total)';
    $Self->{Translation}->{'Remaining vacation'} = 'Días de vacaciones restantes';
    $Self->{Translation}->{'Sick Leave (Days)'} = 'Ausencia por enfermedad (días)';
    $Self->{Translation}->{'Sick leave taken (this month)'} = 'Ausencias por enfermedad (este mes)';
    $Self->{Translation}->{'Sick leave taken (total)'} = 'Ausencias por enfermedad (total)';
    $Self->{Translation}->{'Previous month'} = 'Mes anterior';
    $Self->{Translation}->{'Next month'} = 'Mes siguiente';
    $Self->{Translation}->{'Weekday'} = 'Día de la semana';
    $Self->{Translation}->{'Working Hours'} = 'Horas trabajadas';
    $Self->{Translation}->{'Total worked hours'} = 'Total de horas trabajadas';
    $Self->{Translation}->{'User\'s project overview'} = 'Vista de proyecto de usuario';
    $Self->{Translation}->{'Hours (monthly)'} = 'Horas (mensuales)';
    $Self->{Translation}->{'Hours (Lifetime)'} = 'Horas (tiempo de vida)';
    $Self->{Translation}->{'Grand total'} = 'Total neto';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = 'Reporte de horas';
    $Self->{Translation}->{'Month Navigation'} = 'Navegación por mes';
    $Self->{Translation}->{'Go to date'} = 'Ir a fecha';
    $Self->{Translation}->{'User reports'} = 'Reportes de usuario';
    $Self->{Translation}->{'Monthly total'} = 'Total mensual';
    $Self->{Translation}->{'Lifetime total'} = 'Tiempo total de vida';
    $Self->{Translation}->{'Overtime leave'} = 'Ausencia por haber trabajado horas extras';
    $Self->{Translation}->{'Vacation'} = 'Vacaciones';
    $Self->{Translation}->{'Sick leave'} = 'Ausencia por enfermedad';
    $Self->{Translation}->{'Vacation remaining'} = 'Días libres restantes';
    $Self->{Translation}->{'Project reports'} = 'Reportes de proyecto';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = 'Reporte de proyecto';
    $Self->{Translation}->{'Go to reporting overview'} = 'Ir al resumen de reportes';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        'Actualmente solo se muestran los usuarios activos en este proyecto. Para cambiar este comportamiento, por favor actualize la configuración:';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        'Actualmente se muestran todos los usuarios de contabilidad de tiempo. Para cambiar este comportamiento, por favor actualize la configuración:';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = 'Modificar la configuración del proyecto de contabilidad de tiempo.';
    $Self->{Translation}->{'Add project'} = 'Agregar proyecto';
    $Self->{Translation}->{'Go to settings overview'} = 'Ir al resumen de configuración';
    $Self->{Translation}->{'Add Project'} = 'Agregar Proyecto';
    $Self->{Translation}->{'Edit Project Settings'} = 'Modificar la Configuración del Proyecto';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        'Ya existe un proyecto con este nombre. Por favor, elija uno diferente.';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = 'Modificar la Configuración de la Contabilidad de Tiempo';
    $Self->{Translation}->{'Add task'} = 'Agregar tarea';
    $Self->{Translation}->{'New user'} = 'Usuario nuevo';
    $Self->{Translation}->{'Filter for Projects'} = 'Filtro para Proyectos';
    $Self->{Translation}->{'Filter for Tasks'} = 'Filtro para Tareas';
    $Self->{Translation}->{'Filter for Users'} = 'Filtro para Usuarios';
    $Self->{Translation}->{'Project List'} = 'Lista de Proyectos';
    $Self->{Translation}->{'Task List'} = 'Lista de Tareas';
    $Self->{Translation}->{'Add Task'} = 'Agregar Tarea';
    $Self->{Translation}->{'Edit Task Settings'} = 'Modificar la Configuración de la Tarea';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        'Ya existe una tarea con este nombre. Por favor, elija uno diferente.';
    $Self->{Translation}->{'User List'} = 'Lista de Usuarios';
    $Self->{Translation}->{'New User Settings'} = 'Configuración de Usuario Nuevo';
    $Self->{Translation}->{'Edit User Settings'} = 'Modificar la Configuración del Usuario';
    $Self->{Translation}->{'Comments'} = 'Comentarios';
    $Self->{Translation}->{'Show Overtime'} = 'Mostrar horas extra';
    $Self->{Translation}->{'Allow project creation'} = 'Permitir creación de proyectos';
    $Self->{Translation}->{'Period Begin'} = 'Periodo de inicio';
    $Self->{Translation}->{'Period End'} = 'Periodo de finalización';
    $Self->{Translation}->{'Days of Vacation'} = 'Días de Vacaciones';
    $Self->{Translation}->{'Hours per Week'} = 'Horas por Semana';
    $Self->{Translation}->{'Authorized Overtime'} = 'Tiempo Extra Autorizado';
    $Self->{Translation}->{'Start Date'} = 'Fecha de inicio';
    $Self->{Translation}->{'Please insert a valid date.'} = 'Por favor inserte una fecha válida.';
    $Self->{Translation}->{'End Date'} = 'Fecha de finalización';
    $Self->{Translation}->{'Period end must be after period begin.'} = 'El periodo de finalización debe ser posterior al de inicio.';
    $Self->{Translation}->{'Leave Days'} = 'Días de ausencia';
    $Self->{Translation}->{'Weekly Hours'} = 'Horas semanales';
    $Self->{Translation}->{'Overtime'} = 'Horas extra';
    $Self->{Translation}->{'No time periods found.'} = 'No se encontraron periodos de tiempo.';
    $Self->{Translation}->{'Add time period'} = 'Agregar periodo de tiempo';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = 'Ver registro de tiempo';
    $Self->{Translation}->{'View of '} = 'Resumen de ';
    $Self->{Translation}->{'No data found for this day.'} = 'No se encontraron datos de este día.';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        'Módulo de notificación de la interfaz del agente, necesario para visualizar el número de días incompletos de un usuario.';
    $Self->{Translation}->{'Default name for new actions.'} = 'Nombre por defecto para acciones nuevas.';
    $Self->{Translation}->{'Default name for new projects.'} = 'Nombre por defecto para proyectos nuevos.';
    $Self->{Translation}->{'Default setting for date end.'} = 'Configuración por defecto para la fecha de finalización.';
    $Self->{Translation}->{'Default setting for date start.'} = 'Configuración por defecto para la fecha de inicio.';
    $Self->{Translation}->{'Default setting for description.'} = 'Configuración por defecto para la descripción.';
    $Self->{Translation}->{'Default setting for leave days.'} = 'Configuración por defecto para las faltas (días de ausencia).';
    $Self->{Translation}->{'Default setting for overtime.'} = 'Configuración por defecto para las horas extras.';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = 'Configuración por defecto para las horas semanales estándar.';
    $Self->{Translation}->{'Default status for new actions.'} = 'Estado por defecto para acciones nuevas.';
    $Self->{Translation}->{'Default status for new projects.'} = 'Estado por defecto para proyectos nuevos.';
    $Self->{Translation}->{'Default status for new users.'} = 'Estado por defecto para usuarios nuevos.';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        'Define para cuáles proyectos es obligatoria la inserción de comentarios. Si la expresión regular coincide con el proyecto, se tiene que escribir un comentario. La expresión regular usa el parámetro smx.';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        'Determina si el módulo de estadísticas debe generar información de contabilidad de tiempo.';
    $Self->{Translation}->{'Edit time accounting settings'} = 'Modificar la configuración de la contabilidad de tiempo';
    $Self->{Translation}->{'Edit time record'} = 'Modificar registro de tiempo';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = 'Especifica el número máximo de días para registrar horas de trabajo atrasadas (por ejemplo: 10 días de antigüedad).';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        'Si se habilita, solamente los usuarios que han registrado sus tiempos en el proyecto seleccionado serán mostrados';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        'Si se habilita, los elementos desplegables de la ventana de edición se cambian por campos de autocompletado.';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        'Si se habilita, se le permitirá al usuario registrar "vacaciones", "ausencia por enfermedad", "ausencia por haber trabajado horas extra" en múltiples fechas al mismo tiempo.';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        'Número máximo de días laborales después de los cuales es obligatorio reportar las horas trabajadas.';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        'Número máximo de días laborales sin registro de horas trabajadas después de los cuales se mostrará una advertencia';
    $Self->{Translation}->{'Project time reporting'} = 'Reporte de tiempos de proyecto';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        'Expresiones regulares para restringir la lista de acciones, de acuerdo al proyecto seleccionado. Key contiene la expresión regular para los proyectos y Content, las expresiones regulares para las acciones.';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        'Expresiones regulares para restringir la lista de proyectos, de acuerdo a los grupos de usuarios. Key contiene la expresión regular para los proyectos y Content, una lista de grupos, separados por comas.';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        'Especifica si es posible insertar las horas trabajadas sin definir los tiempos de inicio y finalización de las tareas.';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = 'Este módulo hace obligatoria la inserción de horas trabajadas.';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        'Módulo de notificación que muestra una advertencia si hay demasiados días sin registro de horas trabajadas.';
    $Self->{Translation}->{'Time accounting edit.'} = 'Editar contabilidad de tiempo';
    $Self->{Translation}->{'Time accounting overview.'} = 'Resumen de contabilidad de tiempo';
    $Self->{Translation}->{'Time accounting reporting.'} = 'Reporte de contabilidad de tiempo';
    $Self->{Translation}->{'Time accounting settings.'} = 'Ajustes de contabilidad de tiempo';
    $Self->{Translation}->{'Time accounting view.'} = 'Ver contabilidad de tiempo';
    $Self->{Translation}->{'Time accounting.'} = 'Contabilidad de tiempo.';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        'Se usa si algunas acciones reducen el número de horas trabajadas (por ejemplo: si sólo se paga la mitad del tiempo de viaje puede especificarse Key => Viaje; Content => 50).';

}

1;

# --
# Kernel/Language/hu_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::hu_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = '';
    $Self->{Translation}->{'Show valid projects'} = '';
    $Self->{Translation}->{'Show all projects'} = '';
    $Self->{Translation}->{'TimeAccounting'} = '';
    $Self->{Translation}->{'Reporting'} = '';
    $Self->{Translation}->{'Please insert your working hours!'} = '';
    $Self->{Translation}->{'Successful insert!'} = '';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = '';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = '';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = '';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        'Biztosan törölni akarja a mai nap IdõElszámolását?';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = 'Idõ bejegyzés szerkesztése';
    $Self->{Translation}->{'Go to settings'} = '';
    $Self->{Translation}->{'Date Navigation'} = 'Dátum navigáció';
    $Self->{Translation}->{'Previous day'} = 'Elõzõ nap';
    $Self->{Translation}->{'Next day'} = 'Következõ nap';
    $Self->{Translation}->{'Go to this date'} = '';
    $Self->{Translation}->{'Days without entries'} = 'Bejegyzés nélküli napok';
    $Self->{Translation}->{'Select all days'} = '';
    $Self->{Translation}->{'Mass entry'} = '';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        '';
    $Self->{Translation}->{'On vacation'} = 'Szabadságon';
    $Self->{Translation}->{'On sick leave'} = 'Betegszabadságon';
    $Self->{Translation}->{'On overtime leave'} = 'Túlóra letöltése';
    $Self->{Translation}->{'Please choose at least one day!'} = '';
    $Self->{Translation}->{'Please choose a reason for absence!'} = '';
    $Self->{Translation}->{'Mass Entry'} = '';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = 'A "*"-al jelölt mezõk kitöltése kötelezõ.';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = 'Ki kell töltenie a kezdõ és befejezõ idõpontot vagy az idõtartamot.';
    $Self->{Translation}->{'Project'} = 'Projekt';
    $Self->{Translation}->{'Task'} = 'Feladat';
    $Self->{Translation}->{'Remark'} = 'Megjegyzés';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = 'Kérem adjon meg egy 8 karakternél hosszabb megjegyzést!';
    $Self->{Translation}->{'Start Time'} = '';
    $Self->{Translation}->{'Negative times are not allowed.'} = 'Negatív idõk nem megengedettek.';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        'Ismétlõdõ órák megadása nem megengedett. A kezdõ idõpont egyezik egy másik intervalummal.';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = '';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = '';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = '';
    $Self->{Translation}->{'End Time'} = '';
    $Self->{Translation}->{'End time must be after start time.'} = 'A befejezõ idõpont késõbbi kell legyen, mint a kezdõ idõpont.';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        'Ismétlõdõ órák megadása nem lehetséges. A befejezõ idõpont egyezik más idõszakkal.';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = 'Érvénytelen idõtartam! A nap csak 24 órából áll!';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = 'Az érvényes idõtartamnak nagyobbnak kell lennie nullánál.';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = 'Érvénytelen idõtartam! Negatív idõtartam nem megengedett.';
    $Self->{Translation}->{'Add one row'} = 'Sor hozzáadása';
    $Self->{Translation}->{'Total'} = 'Összesen';
    $Self->{Translation}->{'You can only select one checkbox element!'} = 'Csak egy jelölõnégyzetet választhat!';
    $Self->{Translation}->{'Show all items'} = 'Összes bejegyzés megjelenítése';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = 'IdõElszámolás bejegyzés törlése';
    $Self->{Translation}->{'Confirm insert'} = 'Beszúrás jóváhagyása';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = 'Biztosan dolgozott, miközben betegszabadásgon volt?';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = 'Biztosan dolgozott, miközben betegszabadásgon volt?';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        'Biztosan dolgozott, miközben túlórát töltött le?';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = 'Biztosan többet dolgozott mint 16 óra?';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = 'Idõ-kimutatás havi összesítõ';
    $Self->{Translation}->{'Overtime (Hours)'} = 'Túlóra (órák)';
    $Self->{Translation}->{'Overtime (this month)'} = 'Túlóra (ebben a hónapban)';
    $Self->{Translation}->{'Overtime (total)'} = 'Túlóra (összesen)';
    $Self->{Translation}->{'Remaining overtime leave'} = 'Letölthetõ túlóra';
    $Self->{Translation}->{'Vacation (Days)'} = 'Szabadság (nap)';
    $Self->{Translation}->{'Vacation taken (this month)'} = 'Szabadság (ebben a hónapban)';
    $Self->{Translation}->{'Vacation taken (total)'} = 'Szabadság (összesen)';
    $Self->{Translation}->{'Remaining vacation'} = 'Fennmaradó szabadság';
    $Self->{Translation}->{'Sick Leave (Days)'} = 'Betegszabadság (nap)';
    $Self->{Translation}->{'Sick leave taken (this month)'} = 'Betegszabadság (ebben a hónapban)';
    $Self->{Translation}->{'Sick leave taken (total)'} = 'Betegszabadság (összesen)';
    $Self->{Translation}->{'Previous month'} = 'Elõzõ hónap';
    $Self->{Translation}->{'Next month'} = 'Következõ hónap';
    $Self->{Translation}->{'Weekday'} = 'Hétköznap';
    $Self->{Translation}->{'Working Hours'} = 'Munkaidõ';
    $Self->{Translation}->{'Total worked hours'} = 'Összes munkaidõ';
    $Self->{Translation}->{'User\'s project overview'} = 'Felhasználói projekt összefoglaló';
    $Self->{Translation}->{'Hours (monthly)'} = 'Órák (havi)';
    $Self->{Translation}->{'Hours (Lifetime)'} = 'Órák (élettartam)';
    $Self->{Translation}->{'Grand total'} = 'Mindösszesen';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = 'Idõ kimutatás';
    $Self->{Translation}->{'Month Navigation'} = 'Hónap navigáció';
    $Self->{Translation}->{'Go to date'} = '';
    $Self->{Translation}->{'User reports'} = 'Felhasználó kimutatás';
    $Self->{Translation}->{'Monthly total'} = 'Havi összesítõ';
    $Self->{Translation}->{'Lifetime total'} = 'Élettartam összesítõ';
    $Self->{Translation}->{'Overtime leave'} = 'Túlóra letöltés';
    $Self->{Translation}->{'Vacation'} = 'Szabadság';
    $Self->{Translation}->{'Sick leave'} = 'Betegszabadság';
    $Self->{Translation}->{'Vacation remaining'} = 'Hátralévõ távollét';
    $Self->{Translation}->{'Project reports'} = 'Projekt kimutatások';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = 'Projekt kuimutatás';
    $Self->{Translation}->{'Go to reporting overview'} = '';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        '';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        '';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = 'IdõElszámolás Projekt Beállítások';
    $Self->{Translation}->{'Add project'} = 'Új projekt';
    $Self->{Translation}->{'Go to settings overview'} = '';
    $Self->{Translation}->{'Add Project'} = 'Új Projekt';
    $Self->{Translation}->{'Edit Project Settings'} = 'Projekt Beállítások Szerkesztése';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        'Már van ilyen nevû projekt, válasszon más nevet.';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = 'IdõElszámolás Beállítások Szerkesztése';
    $Self->{Translation}->{'Add task'} = 'Új feladat';
    $Self->{Translation}->{'New user'} = 'Új felhasználó';
    $Self->{Translation}->{'Filter for Projects'} = 'Projektek Szûrése';
    $Self->{Translation}->{'Filter for Tasks'} = 'Feladatok Szûrése';
    $Self->{Translation}->{'Filter for Users'} = 'Felhasználók Szûrése';
    $Self->{Translation}->{'Project List'} = 'Projekt Lista';
    $Self->{Translation}->{'Task List'} = 'Feladat Lista';
    $Self->{Translation}->{'Add Task'} = 'Új Feladat';
    $Self->{Translation}->{'Edit Task Settings'} = 'Feladat Beállítások Szerkesztése';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        'Már van ilyen nevû feladat, válasszon más nevet.';
    $Self->{Translation}->{'User List'} = 'Felhasználó Lista';
    $Self->{Translation}->{'New User Settings'} = 'Új Felhasználó Beállításai';
    $Self->{Translation}->{'Edit User Settings'} = 'Felhasználói Beállítások Szerkesztése';
    $Self->{Translation}->{'Comments'} = 'Megjegyzések';
    $Self->{Translation}->{'Show Overtime'} = 'Mutassa a Túlórát';
    $Self->{Translation}->{'Allow project creation'} = 'Projekt létrehozásának engedélyezése';
    $Self->{Translation}->{'Period Begin'} = 'Idõszak Kezdete';
    $Self->{Translation}->{'Period End'} = 'Idõszak Vége';
    $Self->{Translation}->{'Days of Vacation'} = 'Szabadnapok';
    $Self->{Translation}->{'Hours per Week'} = 'Órák hetente';
    $Self->{Translation}->{'Authorized Overtime'} = 'Jóváhagyott Túlóra';
    $Self->{Translation}->{'Start Date'} = '';
    $Self->{Translation}->{'Please insert a valid date.'} = '';
    $Self->{Translation}->{'End Date'} = '';
    $Self->{Translation}->{'Period end must be after period begin.'} = 'Az idõszak végének a kezdete után kell lennie.';
    $Self->{Translation}->{'Leave Days'} = '';
    $Self->{Translation}->{'Weekly Hours'} = '';
    $Self->{Translation}->{'Overtime'} = '';
    $Self->{Translation}->{'No time periods found.'} = 'Idõszak nem található.';
    $Self->{Translation}->{'Add time period'} = 'Idõszak hozzáadása';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = 'Idõ Bejegyzés megtekintése';
    $Self->{Translation}->{'View of '} = 'Megtekintés ';
    $Self->{Translation}->{'No data found for this day.'} = 'Nincs adat ehhez a naphoz.';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        'Ügyintézõ interface figyelmeztetõ modul a kitöltetlen munkanapok megjelenítéséhez.';
    $Self->{Translation}->{'Default name for new actions.'} = 'Az új akciók alapértelmezett neve.';
    $Self->{Translation}->{'Default name for new projects.'} = 'Az új projektek alapértelmezett neve.';
    $Self->{Translation}->{'Default setting for date end.'} = 'Alapbeállítás a dátum végéhez.';
    $Self->{Translation}->{'Default setting for date start.'} = 'Alapbeállítás a dátum kezdetéhez.';
    $Self->{Translation}->{'Default setting for description.'} = '';
    $Self->{Translation}->{'Default setting for leave days.'} = 'Alapbeállítás a távollét napjaihoz.';
    $Self->{Translation}->{'Default setting for overtime.'} = 'Alapbeállítás a túlórához.';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = 'Alapbeállítás a normál heti órákhoz.';
    $Self->{Translation}->{'Default status for new actions.'} = 'Az új akciók alapértelmezett státusza.';
    $Self->{Translation}->{'Default status for new projects.'} = 'Az új projektek alapértelmezett státusza.';
    $Self->{Translation}->{'Default status for new users.'} = 'Az új felhasználók alapértelmezett státusza.';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        'Adja meg a projekteket, amelyekhez kötelezõ a megjegyzés. Ha a RegExp kifejezés illeszkedik egy projektre, meg kell adnia megjegyzést. A RegExp az smx paramétert használja.';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        'Meghatározza, ha a statisztika modul generálhat IdõElszámolás információkat.';
    $Self->{Translation}->{'Edit time accounting settings'} = 'IdõElszámolás beállítások szerkesztése';
    $Self->{Translation}->{'Edit time record'} = 'Idõ bejegyzés szerkesztése';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = 'Hány napra visszamenõleg tudja megadni a munkaidõt.';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        '';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        'Ha engedélyezett, a legördülõ elemek helyett automatikus kiegészítés lesz a mezõknél.';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        '';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        'Maximum hány nap után kötelezõ megadni a munkaidõt.';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        '';
    $Self->{Translation}->{'Project time reporting'} = 'Projekt idõ kimutatás';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        'Reguláris kifejezés a projekthez megfelelõ akciók listájának szükítéséhez. A kulcs reguláris kifejezést tartalmaz a projektekhez, a tartalom reguláris kifejezést tartalmaz az akciókhoz.';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        'Reguláris kifejezés a felhasználók csoportjának megfelelõ projektek listájának szükítéséhez. A kulcs reguláris kifejezést tartalmaz a projektekhez, a tartalom reguláris kifejezést tartalmaz a csoportok listájához.';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        'Adja meg, ha a munkaidõ megadható kezdõ és befejezõ idõpont nélkül.';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = 'Ez a modul kényszeríti az IdõElszámolás beszúrását..';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        'Ez a figyelmeztetõ modul jelzi, ha túl sok kitöltetlen munkanap van.';
    $Self->{Translation}->{'Time accounting edit.'} = '';
    $Self->{Translation}->{'Time accounting overview.'} = '';
    $Self->{Translation}->{'Time accounting reporting.'} = '';
    $Self->{Translation}->{'Time accounting settings.'} = '';
    $Self->{Translation}->{'Time accounting view.'} = '';
    $Self->{Translation}->{'Time accounting.'} = 'IdõElszámolás.';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        'Használja, ha valamelyik akció csökkenti a munkaórákat (például ha csak az utazás fele kerül kifizetésre, Kulcs => Utazás; Tartalom =>50).';

}

1;

# --
# Kernel/Language/it_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::it_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = 'Rendicontazione Temporale';
    $Self->{Translation}->{'Show valid projects'} = 'Mostra i progetti validi';
    $Self->{Translation}->{'Show all projects'} = 'Mostra tutti i progetti';
    $Self->{Translation}->{'TimeAccounting'} = 'TimeAccounting';
    $Self->{Translation}->{'Reporting'} = 'Reportistica';
    $Self->{Translation}->{'Please insert your working hours!'} = 'Inserire l\'orario lavorativo!';
    $Self->{Translation}->{'Successful insert!'} = 'Inserimento avvenuto con successo!';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = 'Si è verificato un errore nell\'inserimento di date multiple!';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = 'Inserimento di date multiple avvenuto con successo!';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = 'La data inserita non è valida! E\' stata impostata la data di oggi.';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        'Vuoi veramente cancellare la rendicontazione temporale di oggi ?';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = 'Modifica la rendicontazione';
    $Self->{Translation}->{'Go to settings'} = 'Vai alle impostazioni';
    $Self->{Translation}->{'Date Navigation'} = 'Navigazione per data';
    $Self->{Translation}->{'Previous day'} = 'Giorno precedente';
    $Self->{Translation}->{'Next day'} = 'Giorno successivo';
    $Self->{Translation}->{'Go to this date'} = 'Va a questa data';
    $Self->{Translation}->{'Days without entries'} = 'Giorni senza informazioni';
    $Self->{Translation}->{'Select all days'} = 'Seleziona tutti i giorni';
    $Self->{Translation}->{'Mass entry'} = 'Inserimento massivo';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        'Per favore seleziona il motivo della tua assenza per i giorni selezionati.';
    $Self->{Translation}->{'On vacation'} = 'Ferie';
    $Self->{Translation}->{'On sick leave'} = 'Assente per malattia';
    $Self->{Translation}->{'On overtime leave'} = 'Assente per recupero';
    $Self->{Translation}->{'Please choose at least one day!'} = 'Specificare almeno un giorno!';
    $Self->{Translation}->{'Please choose a reason for absence!'} = 'Selezionare un motivo per l\'assenza!';
    $Self->{Translation}->{'Mass Entry'} = 'Inserimento massivo';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = 'I campi obbligatori sono indicati con "*".';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = 'E\' obbligatorio inserire inizio e fine oppure un periodo.';
    $Self->{Translation}->{'Project'} = 'Progetto';
    $Self->{Translation}->{'Task'} = 'Compito';
    $Self->{Translation}->{'Remark'} = 'Commento';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = 'Inserire un commeto più lungo di 8 caratteri!';
    $Self->{Translation}->{'Start Time'} = 'Istante di Inizio';
    $Self->{Translation}->{'Negative times are not allowed.'} = 'Non possono essere inseriti valori negativi.';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        'Non è permesso inserire ore ripetute. L\'orario di inizio coincide con un altro intervallo.';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = 'Formato non valido. Inserire un orario nel formato HH:MM.';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = 'L\'ora 24:00 è consentita solo come ora di fine.';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = 'Orario non valido! In un giorno ci sono solo 24 ore.';
    $Self->{Translation}->{'End Time'} = 'Orario di termine';
    $Self->{Translation}->{'End time must be after start time.'} = 'L\'orario di fine è posteriore all\'orario di inizio.';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        'Non è permesso inserire ore ripetute. L\'orario di fine coincide con un altro intervallo.';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = 'Periodo non valido. Una giornata ha solo 24 ore.';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = 'Un periodo valido deve essere maggiore di zero.';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = 'Periodo non valido. Valori negativi non ammessi.';
    $Self->{Translation}->{'Add one row'} = 'Aggiungere una riga';
    $Self->{Translation}->{'Total'} = 'Totale';
    $Self->{Translation}->{'You can only select one checkbox element!'} = 'Puoi selezionare solo un elemento!';
    $Self->{Translation}->{'Show all items'} = 'Mostra tutti gli elementi';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = 'Cancellare voce di rendicontazione';
    $Self->{Translation}->{'Confirm insert'} = 'Confermare inserimento';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = 'Sei sicuro di aver lavorato mentre eri assente per malattia?';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = 'Sei sicuro di aver lavorato mentre eri in ferie?';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        'Sei sicuro di aver lavorato mentre eri assente per recupero ?';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = 'Sei sicuro di aver lavorato più di 16 ore?';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = 'Cruscotto mensile di rendicontazione temporale';
    $Self->{Translation}->{'Overtime (Hours)'} = 'Straordinario (ore)';
    $Self->{Translation}->{'Overtime (this month)'} = 'Straordinario (questo mese)';
    $Self->{Translation}->{'Overtime (total)'} = 'Straordinario (totale)';
    $Self->{Translation}->{'Remaining overtime leave'} = 'Totale ore di recupero disponibili';
    $Self->{Translation}->{'Vacation (Days)'} = 'Ferie (giorni)';
    $Self->{Translation}->{'Vacation taken (this month)'} = 'Ferie utilizzate (questo mese)';
    $Self->{Translation}->{'Vacation taken (total)'} = 'Ferie utilizzate (totale)';
    $Self->{Translation}->{'Remaining vacation'} = 'Ferie residue';
    $Self->{Translation}->{'Sick Leave (Days)'} = 'Assenze per malattia (giorni)';
    $Self->{Translation}->{'Sick leave taken (this month)'} = 'Assenze per malattia utilizzate (questo mese)';
    $Self->{Translation}->{'Sick leave taken (total)'} = 'Assenze per malattia (totale)';
    $Self->{Translation}->{'Previous month'} = 'Mese precedente';
    $Self->{Translation}->{'Next month'} = 'Mese seguente';
    $Self->{Translation}->{'Weekday'} = 'Giorno della settimana';
    $Self->{Translation}->{'Working Hours'} = 'Ore lavorative';
    $Self->{Translation}->{'Total worked hours'} = 'Totale ore lavorate';
    $Self->{Translation}->{'User\'s project overview'} = 'Visualizzazione del progetto - Utente';
    $Self->{Translation}->{'Hours (monthly)'} = 'Ore (mensili)';
    $Self->{Translation}->{'Hours (Lifetime)'} = 'Ore (globali)';
    $Self->{Translation}->{'Grand total'} = 'Totale omnicomprensivo';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = 'Report del tempo';
    $Self->{Translation}->{'Month Navigation'} = 'Navigazione per mese';
    $Self->{Translation}->{'Go to date'} = 'Vai alla data';
    $Self->{Translation}->{'User reports'} = 'Report utente';
    $Self->{Translation}->{'Monthly total'} = 'Totale mensile';
    $Self->{Translation}->{'Lifetime total'} = 'Totale gLobale';
    $Self->{Translation}->{'Overtime leave'} = 'Assenze per recupero';
    $Self->{Translation}->{'Vacation'} = 'Ferie';
    $Self->{Translation}->{'Sick leave'} = 'Malattia';
    $Self->{Translation}->{'Vacation remaining'} = 'Giorni rimanenti';
    $Self->{Translation}->{'Project reports'} = 'Riassunti progetto';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = 'Riassunto progetto';
    $Self->{Translation}->{'Go to reporting overview'} = 'Vai al riepilogo di reportistica';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        '';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        '';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = 'Modificare le configurazioni di gestione del tempo del progetto.';
    $Self->{Translation}->{'Add project'} = 'Aggiungere progetto';
    $Self->{Translation}->{'Go to settings overview'} = 'Vai al riepilogo impostazioni';
    $Self->{Translation}->{'Add Project'} = 'Aggiungere progetto';
    $Self->{Translation}->{'Edit Project Settings'} = 'Modificare la configurazione del progetto';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        'Esiste già un progetto con questo nome. Scegleire un nome diverso.';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = 'Modificare le configurazioni della rendicontazione';
    $Self->{Translation}->{'Add task'} = 'Aggiungere compito';
    $Self->{Translation}->{'New user'} = 'Nuovo utente';
    $Self->{Translation}->{'Filter for Projects'} = 'Filtro per progetti';
    $Self->{Translation}->{'Filter for Tasks'} = 'Filtro per compiti';
    $Self->{Translation}->{'Filter for Users'} = 'Filtro per utenti';
    $Self->{Translation}->{'Project List'} = 'Elenco dei progetti';
    $Self->{Translation}->{'Task List'} = 'Elenco dei compiti';
    $Self->{Translation}->{'Add Task'} = 'Aggiungere compito';
    $Self->{Translation}->{'Edit Task Settings'} = 'Modificare la configurazione dei compiti';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        'Esiste già un compito con questo nome. Scegliere un nome diverso.';
    $Self->{Translation}->{'User List'} = 'Elenco utenti';
    $Self->{Translation}->{'New User Settings'} = 'Configurazioni nuovo utente';
    $Self->{Translation}->{'Edit User Settings'} = 'Modificare configurazione utente';
    $Self->{Translation}->{'Comments'} = 'Commenti';
    $Self->{Translation}->{'Show Overtime'} = 'Mostrare straordinari';
    $Self->{Translation}->{'Allow project creation'} = 'Cosentire la creazione del progetto';
    $Self->{Translation}->{'Period Begin'} = 'Periodo di inizio';
    $Self->{Translation}->{'Period End'} = 'Periodo di termine';
    $Self->{Translation}->{'Days of Vacation'} = 'Giorni di Assenza';
    $Self->{Translation}->{'Hours per Week'} = 'Ore alla settimana';
    $Self->{Translation}->{'Authorized Overtime'} = 'Straordinari autorizzati';
    $Self->{Translation}->{'Start Date'} = 'Data di inizio';
    $Self->{Translation}->{'Please insert a valid date.'} = 'Inserire una data valida.';
    $Self->{Translation}->{'End Date'} = 'Data Fine';
    $Self->{Translation}->{'Period end must be after period begin.'} = 'Il periodo finale deve essere posteriore al periodo iniziale.';
    $Self->{Translation}->{'Leave Days'} = 'Giorni di assenza';
    $Self->{Translation}->{'Weekly Hours'} = 'Orari della Settimana';
    $Self->{Translation}->{'Overtime'} = 'Straordinario';
    $Self->{Translation}->{'No time periods found.'} = 'Non ci sono periodi.';
    $Self->{Translation}->{'Add time period'} = 'Aggiungi periodo';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = 'Visualizzare registro orario';
    $Self->{Translation}->{'View of '} = 'Visualizzazione di  ';
    $Self->{Translation}->{'No data found for this day.'} = 'Nessun dato trovato per questo giorno.';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        'Modulo di notifica dell\'interfaccia agente per vedere il numero di giorni lavorativi incompleti per l\'utente';
    $Self->{Translation}->{'Default name for new actions.'} = 'Nome predefinito per le nuove azioni.';
    $Self->{Translation}->{'Default name for new projects.'} = 'Nome predefinito per i nuovi progetti.';
    $Self->{Translation}->{'Default setting for date end.'} = 'Valore predefinito per la data di fine.';
    $Self->{Translation}->{'Default setting for date start.'} = 'Valore predefinito per la data di inizio.';
    $Self->{Translation}->{'Default setting for description.'} = 'Valore predefinito per la descrizione.';
    $Self->{Translation}->{'Default setting for leave days.'} = 'Valore predefinito per i giorni di assenza/vacanza.';
    $Self->{Translation}->{'Default setting for overtime.'} = 'Valore predefinito per lo straordinario.';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = 'Valore predefinito per l\'orario settimanale standard.';
    $Self->{Translation}->{'Default status for new actions.'} = 'Valore predefinito per le nuove azioni.';
    $Self->{Translation}->{'Default status for new projects.'} = 'Valore predefinito per i nuovi progetti.';
    $Self->{Translation}->{'Default status for new users.'} = 'Valore predefinito per i nuovi utenti.';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        'Definisce i progetti per i quali una annotazione è obbligatoria. Se la RegExp coincide il progetto si è obbligati ad inserire una annotazione. La RegExp utilizza il parametro smx.';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        'Determina se il modulo statistiche può generare informazioni di rendicontazione temporale.';
    $Self->{Translation}->{'Edit time accounting settings'} = 'Modifica le impostazioni della rendicontazione temporale';
    $Self->{Translation}->{'Edit time record'} = 'Modifica una voce';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = 'Numero massimo di giorni nel passato in cui è possibile inserire le unità di lavoro.';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        'Se abilitato, mostra solo gli utenti che hanno aggiunto voci di tempo lavoro al progetto selezionato.';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        'Se abilitato, modifica gli elementi nella schermata di modifica a campi con completamento automatico.';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        'Se abilitato, è possibile per gli utenti inserire i campi "periodo di vacanza", "periodo di malattia" e "straordinario" con date multiple.';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        'Numero massimo di giorni lavorativi in cui è possibile inserire le voci di unità di lavoro.';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        'Numero massimo di giorni lavorativi che non hanno voci di unità di lavoro oltre il quale verrà mostrato un avviso.';
    $Self->{Translation}->{'Project time reporting'} = 'Reportistica temporale del progetto';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        'Espressioni regolari per vincolare lista di azioni in base al progetto selezionato. La chiave contiene un\'espressione regolare per il/i progetto/i, il contenuto contiene espressioni regolari per le azioni.';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        'Espressioni regolari per vincolare lista di progetti in base ai gruppi utente. La chiave contiene un\'espressione regolare per il/i progetto/i, il contenuto contiene espressioni regolari per le azioni.';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        'Specifica se le ore lavorative possono essere inserite senza orari di inizio e di fine.';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = 'Questo modulo forza gli inserimenti in TimeAccounting.';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        'Questo modulo di notifica genera un avviso se ci sono troppi giorni lavorativi non completi.';
    $Self->{Translation}->{'Time accounting edit.'} = 'Modifica rendicontazione tempo.';
    $Self->{Translation}->{'Time accounting overview.'} = 'Panoramica sulla contabilizzazione tempo.';
    $Self->{Translation}->{'Time accounting reporting.'} = 'Reportistica sulla contabilizzazione tempo.';
    $Self->{Translation}->{'Time accounting settings.'} = 'Impostazioni per la contabilizzazione tempo.';
    $Self->{Translation}->{'Time accounting view.'} = 'Vista contabilizzazione tempo.';
    $Self->{Translation}->{'Time accounting.'} = 'Contabilizzazione tempo.';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        'Da utilizzare se alcune azioni hanno ridotto le ore lavorative (per esempio: se solo la metà del tempo di viaggio è pagato: Chiave => Viaggio; Contenuto => 50).';

}

1;

# --
# Kernel/Language/ja_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::ja_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = 'タイムアカウンティング';
    $Self->{Translation}->{'Show valid projects'} = '有効なプロジェクトを表示する';
    $Self->{Translation}->{'Show all projects'} = 'すべてのプロジェクトを表示する';
    $Self->{Translation}->{'TimeAccounting'} = 'タイムアカウンティング';
    $Self->{Translation}->{'Reporting'} = '報告する';
    $Self->{Translation}->{'Please insert your working hours!'} = '勤務実績を入力してください';
    $Self->{Translation}->{'Successful insert!'} = '入力に成功しました!';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = '複数日を入力中にエラーが発生しました !';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = '複数日にわたる稼働実績の入力に成功しました !';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = '入力された日付は不正です ! 日付は本日に変更されました';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        '本当に該当日の情報を削除しますか？';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = 'タイムレコードの編集';
    $Self->{Translation}->{'Go to settings'} = '設定へ';
    $Self->{Translation}->{'Date Navigation'} = '日別ナビゲーション';
    $Self->{Translation}->{'Previous day'} = '前の日';
    $Self->{Translation}->{'Next day'} = '次の日';
    $Self->{Translation}->{'Go to this date'} = 'この 日 に移動する';
    $Self->{Translation}->{'Days without entries'} = 'エントリーのない日';
    $Self->{Translation}->{'Select all days'} = '全ての日を選択';
    $Self->{Translation}->{'Mass entry'} = '全体入力';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        '該当の日の欠勤理由を入力してください';
    $Self->{Translation}->{'On vacation'} = '休暇取得中';
    $Self->{Translation}->{'On sick leave'} = '病欠中';
    $Self->{Translation}->{'On overtime leave'} = '代休中';
    $Self->{Translation}->{'Please choose at least one day!'} = '少なくとも一日は選択してください';
    $Self->{Translation}->{'Please choose a reason for absence!'} = '欠勤理由を選択してください';
    $Self->{Translation}->{'Mass Entry'} = '全体入力';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = '* の項目は入力必須です。';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = '開始時間と終了時間、または期間を指定してください。';
    $Self->{Translation}->{'Project'} = 'プロジェクト';
    $Self->{Translation}->{'Task'} = 'タスク';
    $Self->{Translation}->{'Remark'} = '注釈';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = '8文字以上の注釈を追加してください。';
    $Self->{Translation}->{'Start Time'} = 'スタート時間';
    $Self->{Translation}->{'Negative times are not allowed.'} = '－（マイナス）の時間は入力できません';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        '繰り返された時間は許可されません。開始時刻は別の間隔と一致します。';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = '不正なフォーマットです! 時間の入力はHH:MMのフォーマットに従ってください';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = '24:00は終了時間としてのみ入力可能です';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = '不正な時間です! 一日は24です';
    $Self->{Translation}->{'End Time'} = '終了時間';
    $Self->{Translation}->{'End time must be after start time.'} = '終了時間の前に開始時間を設定することはできません。';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        'Diese Endzeit wurde bereits in einem anderen Eintrag angegeben.';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = '「期間」の設定が不正です。（24時間以上は許可されません）';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = '「期間」の設定が不正です。（0は許可されません）';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = '「期間」の設定が不正です。（－（マイナス）は許可されません）';
    $Self->{Translation}->{'Add one row'} = '行の追加';
    $Self->{Translation}->{'Total'} = '計';
    $Self->{Translation}->{'You can only select one checkbox element!'} = '1項目のみ選択できます。';
    $Self->{Translation}->{'Show all items'} = 'すべてのアイテムを表示';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = 'エントリーを削除';
    $Self->{Translation}->{'Confirm insert'} = '挿入の確認';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = '病欠に設定された期間中に稼働しましたか？';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = '休暇に設定された期間中に稼働しましたか？';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        '代休に設定された期間中に稼働しましたか？';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = '16時間以上稼働しましたか？';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = '月別一覧';
    $Self->{Translation}->{'Overtime (Hours)'} = '超過勤務（：時間）';
    $Self->{Translation}->{'Overtime (this month)'} = '超過勤務（今月）';
    $Self->{Translation}->{'Overtime (total)'} = '超過勤務（累計）';
    $Self->{Translation}->{'Remaining overtime leave'} = '超過勤務可能残（時間）';
    $Self->{Translation}->{'Vacation (Days)'} = '休暇（日数）';
    $Self->{Translation}->{'Vacation taken (this month)'} = '休暇取得日数（今月）';
    $Self->{Translation}->{'Vacation taken (total)'} = '休暇取得日数（累計）';
    $Self->{Translation}->{'Remaining vacation'} = '休暇取得残日数';
    $Self->{Translation}->{'Sick Leave (Days)'} = '病欠（日数）';
    $Self->{Translation}->{'Sick leave taken (this month)'} = '病欠日数（今月）';
    $Self->{Translation}->{'Sick leave taken (total)'} = '病欠日数（累計）';
    $Self->{Translation}->{'Previous month'} = '前月';
    $Self->{Translation}->{'Next month'} = '次月';
    $Self->{Translation}->{'Weekday'} = '曜日';
    $Self->{Translation}->{'Working Hours'} = '稼働時間';
    $Self->{Translation}->{'Total worked hours'} = '総稼働時間';
    $Self->{Translation}->{'User\'s project overview'} = 'ユーザのプロジェクト一覧';
    $Self->{Translation}->{'Hours (monthly)'} = '時間（今月）';
    $Self->{Translation}->{'Hours (Lifetime)'} = '時間（通算）';
    $Self->{Translation}->{'Grand total'} = '合計';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = '時間会計レポート';
    $Self->{Translation}->{'Month Navigation'} = '月別ナビゲーション';
    $Self->{Translation}->{'Go to date'} = '日付に移動する';
    $Self->{Translation}->{'User reports'} = 'ユーザ・レポート';
    $Self->{Translation}->{'Monthly total'} = '月合計';
    $Self->{Translation}->{'Lifetime total'} = '通算合計';
    $Self->{Translation}->{'Overtime leave'} = '代休';
    $Self->{Translation}->{'Vacation'} = '休暇';
    $Self->{Translation}->{'Sick leave'} = '病欠';
    $Self->{Translation}->{'Vacation remaining'} = '休日残日数';
    $Self->{Translation}->{'Project reports'} = 'プロジェクト・レポート';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = 'プロジェクト・レポート';
    $Self->{Translation}->{'Go to reporting overview'} = '報告の概要に移動する';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        '';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        '';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = '時間会計 プロジェクト設定の編集';
    $Self->{Translation}->{'Add project'} = '新規プロジェクトの追加';
    $Self->{Translation}->{'Go to settings overview'} = '設定に移動する';
    $Self->{Translation}->{'Add Project'} = '新規プロジェクトの追加';
    $Self->{Translation}->{'Edit Project Settings'} = 'プロジェクトの編集';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        '同名のプロジェクトが存在します。名称を変更してください。';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = '設定の編集';
    $Self->{Translation}->{'Add task'} = '新規タスクの追加';
    $Self->{Translation}->{'New user'} = '新規ユーザ';
    $Self->{Translation}->{'Filter for Projects'} = 'プロジェクトの絞り込み';
    $Self->{Translation}->{'Filter for Tasks'} = 'タスクの絞り込み';
    $Self->{Translation}->{'Filter for Users'} = 'ユーザの絞り込み';
    $Self->{Translation}->{'Project List'} = 'プロジェクト一覧';
    $Self->{Translation}->{'Task List'} = 'タスク一覧';
    $Self->{Translation}->{'Add Task'} = '新規タスクの追加';
    $Self->{Translation}->{'Edit Task Settings'} = 'タスク設定';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        '同名のタスクが存在します。名称を変更してください。';
    $Self->{Translation}->{'User List'} = 'ユーザ一覧';
    $Self->{Translation}->{'New User Settings'} = '新規ユーザ設定';
    $Self->{Translation}->{'Edit User Settings'} = 'ユーザ設定の編集';
    $Self->{Translation}->{'Comments'} = 'コメント';
    $Self->{Translation}->{'Show Overtime'} = '超過勤務を表示';
    $Self->{Translation}->{'Allow project creation'} = 'プロジェクトの新規追加を許可する';
    $Self->{Translation}->{'Period Begin'} = '開始点';
    $Self->{Translation}->{'Period End'} = '終了点';
    $Self->{Translation}->{'Days of Vacation'} = '休暇';
    $Self->{Translation}->{'Hours per Week'} = '時間 / 週';
    $Self->{Translation}->{'Authorized Overtime'} = '承認済の超過勤務';
    $Self->{Translation}->{'Start Date'} = 'スタート日付';
    $Self->{Translation}->{'Please insert a valid date.'} = '正しい日付を入力してください';
    $Self->{Translation}->{'End Date'} = '終了時間';
    $Self->{Translation}->{'Period end must be after period begin.'} = '終了点の前に開始点を設定することはできません。';
    $Self->{Translation}->{'Leave Days'} = '休暇日数';
    $Self->{Translation}->{'Weekly Hours'} = '週あたりの時間';
    $Self->{Translation}->{'Overtime'} = '残業時間';
    $Self->{Translation}->{'No time periods found.'} = '期間が未設定です。';
    $Self->{Translation}->{'Add time period'} = '期間を追加してください。';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = 'タイム・レコードを表示';
    $Self->{Translation}->{'View of '} = '一覧';
    $Self->{Translation}->{'No data found for this day.'} = '該当するデータがありません。';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        'ユーザの不完全な稼働日数をカウントし通知するエージェント・インターフェイスです。';
    $Self->{Translation}->{'Default name for new actions.'} = '新規操作に対するデフォルトの名称';
    $Self->{Translation}->{'Default name for new projects.'} = '新規プロジェクトに対するデフォルトの名称';
    $Self->{Translation}->{'Default setting for date end.'} = '「終了日」のデフォルト値';
    $Self->{Translation}->{'Default setting for date start.'} = '「開始日」のデフォルト値';
    $Self->{Translation}->{'Default setting for description.'} = '「説明文」のデフォルト値';
    $Self->{Translation}->{'Default setting for leave days.'} = '「休暇」のデフォルト値';
    $Self->{Translation}->{'Default setting for overtime.'} = '「超過勤務」のデフォルト値';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = '週あたり基本稼働時間のデフォルト値';
    $Self->{Translation}->{'Default status for new actions.'} = '新規操作に対するデフォルトのステータス';
    $Self->{Translation}->{'Default status for new projects.'} = '新規プロジェクトに対するデフォルトのステータス';
    $Self->{Translation}->{'Default status for new users.'} = '新規ユーザに対するデフォルトのステータス';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        '「注釈」エントリーを必要とする項目を定義します。 もしプロジェクト名がここで設定した正規表現にマッチする場合、「注釈｝は必須項目となります。※正規表現にはSMXパラメータを使います。';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        '統計モジュールがタイムアカウンティング情報を生成するか選択してください';
    $Self->{Translation}->{'Edit time accounting settings'} = '時間会計の設定を編集';
    $Self->{Translation}->{'Edit time record'} = 'タイムレコードを編集';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = '何日前からワーキング・ユニットの新規登録が可能であるかの設定です。';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        '有効時には、該当のプロジェクトに稼働時間を投入しているユーザーのみ表示されます';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        'この項目を「許可」にすると、編集画面内のプルダウンメニューをオートコンプリート機能付きのフォームに変更します。';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        '有効にすれば一回の編集で、複数の日に渡り「休暇」「病欠」「代休」が選択できます';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        '1つ以上のワーキング・ユニットを設定すべき最大の稼働日数。';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        '警告が表示されることなくエントリ出来る、営業日の最大日数。';
    $Self->{Translation}->{'Project time reporting'} = 'プロジェクト別時間会計レポート';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        'プロジェクトによって行動リストを絞り込むための正規表現。「鍵」ではプロジェクトに対する正規表現を、「内容」では`行動`に対する正規表現を指定する。';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        'ユーザグループによってプロジェクトリストを絞り込むための正規表現。「鍵」ではプロジェクトに対する正規表現を、「内容」ではカンマ区切りのユーザリストを指定する。';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        '業務時間を「開始時間」と「終了時間」の指定ナシで新規登録できるかどうか指定する。';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = 'TimeAccountingモジュールと同等の項目が設定必須となります。';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        'あまりにも多くの不完全な稼働日がある場合、この通知モジュールは警告を与えます。';
    $Self->{Translation}->{'Time accounting edit.'} = 'タイムアカウンティングを編集する';
    $Self->{Translation}->{'Time accounting overview.'} = 'タイムアカウンティングの概要';
    $Self->{Translation}->{'Time accounting reporting.'} = 'タイムアカウンティングの報告';
    $Self->{Translation}->{'Time accounting settings.'} = 'タイムアカウンティングの設定';
    $Self->{Translation}->{'Time accounting view.'} = 'タイムアカウンティング ビュー';
    $Self->{Translation}->{'Time accounting.'} = '時間会計';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        '業務上の行動において、稼働時間として計上する時間を調整する必要がある場合に、この設定を使用します。（例：「移動時間」の50%のみ勤務時間相当とする場合「鍵」に`journey`、「内容」に`50`と設定)';

}

1;

# --
# Kernel/Language/pl_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::pl_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = '';
    $Self->{Translation}->{'Show valid projects'} = '';
    $Self->{Translation}->{'Show all projects'} = '';
    $Self->{Translation}->{'TimeAccounting'} = '';
    $Self->{Translation}->{'Reporting'} = '';
    $Self->{Translation}->{'Please insert your working hours!'} = '';
    $Self->{Translation}->{'Successful insert!'} = '';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = '';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = '';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = '';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        'Czy na pewno chcesz usunąć zaraportowany czas pracy dla tego dnia?';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = 'Edytuj wpis czasu';
    $Self->{Translation}->{'Go to settings'} = '';
    $Self->{Translation}->{'Date Navigation'} = 'Nawigacja po dacie';
    $Self->{Translation}->{'Previous day'} = 'Poprzedni dzień';
    $Self->{Translation}->{'Next day'} = 'Następny dzień';
    $Self->{Translation}->{'Go to this date'} = '';
    $Self->{Translation}->{'Days without entries'} = 'Dni bez raportów';
    $Self->{Translation}->{'Select all days'} = 'Zaznacz wszystkie dni';
    $Self->{Translation}->{'Mass entry'} = 'Masowy wpis';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        'Proszę wybrać powód braku obecności dla wybranych dni';
    $Self->{Translation}->{'On vacation'} = 'Urlop';
    $Self->{Translation}->{'On sick leave'} = 'Zwolnienie lekarskie';
    $Self->{Translation}->{'On overtime leave'} = 'Wolne za nadgodziny';
    $Self->{Translation}->{'Please choose at least one day!'} = 'Proszę wybrać conajmniej jeden dzień!';
    $Self->{Translation}->{'Please choose a reason for absence!'} = 'Proszę wybrać powód nieobecności!';
    $Self->{Translation}->{'Mass Entry'} = 'Masowy wpis';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = 'Wymagane pola są oznaczone "*".';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = 'Musisz wprowadzić dzień początku oraz końca lub czas trwania w okresie.';
    $Self->{Translation}->{'Project'} = 'Projekt';
    $Self->{Translation}->{'Task'} = 'Zadanie';
    $Self->{Translation}->{'Remark'} = 'Uwaga';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = 'Proszę dodać uwagę składającą się z więcej niż 8 znaków!';
    $Self->{Translation}->{'Start Time'} = '';
    $Self->{Translation}->{'Negative times are not allowed.'} = 'Ujemne czasy są niedozwolone.';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        'Powtarzające się czasy nie są dozwolone. Czas rozpoczęcia pasuje do innego przedziału.';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = 'Nieprawidłowy format! Proszę podać czas w godzinach GG:MM.';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = '24:00 jest dozwolone jedynie jako koniec czasu.';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = 'Nieprawidłowy czas! Dzień ma tylko 24 godziny.';
    $Self->{Translation}->{'End Time'} = '';
    $Self->{Translation}->{'End time must be after start time.'} = 'Czas zakończenia musi być po czasie rozpoczęcia.';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        'Powtarzające się czasy nie są dozwolone. Czas zakończenia pasuje do innego przedziału.';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = 'Nieprawidłowy okres! Dzień ma tylko 24 godziny.';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = 'Prawidłowy okres musi być większy niż zero.';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = 'Nieprawidłowy okres! Ujemny okres nie jest dozwolony.';
    $Self->{Translation}->{'Add one row'} = 'Dodaj jeden wiersz';
    $Self->{Translation}->{'Total'} = 'Suma';
    $Self->{Translation}->{'You can only select one checkbox element!'} = 'Możesz zaznaczyć tylko jeden element!';
    $Self->{Translation}->{'Show all items'} = 'Pokaż wszystkie elementy';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = 'Usuń pozycję zaraportowanego czasu';
    $Self->{Translation}->{'Confirm insert'} = 'Zatwierdź wstawienie';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = 'Jesteś pewien że pracowałeś na zwolnieniu lekarskim?';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = 'Jesteś pewien że pracowałeś podczas urlopu?';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        'Jesteś pewien że pracowałeś na wolnym z nadgodzin?';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = 'Jesteś pewien że pracowałeś więcej niż 16 godzin?';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = 'Przegląd miesięcznego raportu czasu';
    $Self->{Translation}->{'Overtime (Hours)'} = 'Nadgodziny (Godziny)';
    $Self->{Translation}->{'Overtime (this month)'} = 'Nadgodziny (ten misiąc)';
    $Self->{Translation}->{'Overtime (total)'} = 'Nadgodziny (łącznie)';
    $Self->{Translation}->{'Remaining overtime leave'} = 'Pozostałe nadgodziny do odebrania';
    $Self->{Translation}->{'Vacation (Days)'} = 'Urlop (Dni)';
    $Self->{Translation}->{'Vacation taken (this month)'} = 'Wykorzystane dni urlopu (ten miesiąc)';
    $Self->{Translation}->{'Vacation taken (total)'} = 'Wykorzystane dni urlopu (łącznie)';
    $Self->{Translation}->{'Remaining vacation'} = 'Pozostało urlopu';
    $Self->{Translation}->{'Sick Leave (Days)'} = 'Urlop chorobowy (Dni)';
    $Self->{Translation}->{'Sick leave taken (this month)'} = 'Wykorzystane dni urlopu chorobowego (ten miesiąc)';
    $Self->{Translation}->{'Sick leave taken (total)'} = 'Wykorzystane dni urlopu chorobowego (łącznie)';
    $Self->{Translation}->{'Previous month'} = 'Poprzedni miesiąc';
    $Self->{Translation}->{'Next month'} = 'Następny miesiąc';
    $Self->{Translation}->{'Weekday'} = 'Dzień tygodnia';
    $Self->{Translation}->{'Working Hours'} = 'Godziny pracy';
    $Self->{Translation}->{'Total worked hours'} = 'Łączne godziny wypracowane';
    $Self->{Translation}->{'User\'s project overview'} = 'Przegląd projektu użytkownika/ów';
    $Self->{Translation}->{'Hours (monthly)'} = 'Godziny (miesięcznie)';
    $Self->{Translation}->{'Hours (Lifetime)'} = 'Godziny (łącznie)';
    $Self->{Translation}->{'Grand total'} = 'Ogółem';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = 'Raport czasu';
    $Self->{Translation}->{'Month Navigation'} = 'Nawigacja miesięczna';
    $Self->{Translation}->{'Go to date'} = '';
    $Self->{Translation}->{'User reports'} = 'Raporty użytkownika';
    $Self->{Translation}->{'Monthly total'} = 'Łącznie - miesięcznie';
    $Self->{Translation}->{'Lifetime total'} = 'Łącznie - ogółem';
    $Self->{Translation}->{'Overtime leave'} = 'Wolne za nadgodziny';
    $Self->{Translation}->{'Vacation'} = 'Urlop';
    $Self->{Translation}->{'Sick leave'} = 'Urlop chorobowy';
    $Self->{Translation}->{'Vacation remaining'} = 'Pozostałe dni poza pracą';
    $Self->{Translation}->{'Project reports'} = 'Raporty projektu';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = 'Raport projektu';
    $Self->{Translation}->{'Go to reporting overview'} = '';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        '';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        '';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = 'Edytuj ustawienia Raportowania Czasu';
    $Self->{Translation}->{'Add project'} = 'Dodaj projekt';
    $Self->{Translation}->{'Go to settings overview'} = '';
    $Self->{Translation}->{'Add Project'} = 'Dodaj projekt';
    $Self->{Translation}->{'Edit Project Settings'} = 'Edytuj ustawienia projektu';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        'W systemie znajduje się już projekt o takiej nazwie. Wybierz inną nazwę.';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = 'Edytuj ustawienia Raportowania Czasu';
    $Self->{Translation}->{'Add task'} = 'Dodaj zadanie';
    $Self->{Translation}->{'New user'} = 'Nowy użytkownik';
    $Self->{Translation}->{'Filter for Projects'} = 'Filtr na projekty';
    $Self->{Translation}->{'Filter for Tasks'} = 'Filtr na zadania';
    $Self->{Translation}->{'Filter for Users'} = 'Filtr na użytkowników';
    $Self->{Translation}->{'Project List'} = 'Lista projektów';
    $Self->{Translation}->{'Task List'} = 'Lista zadań';
    $Self->{Translation}->{'Add Task'} = 'Dodaj zadanie';
    $Self->{Translation}->{'Edit Task Settings'} = 'Edytuj ustawienia zadania';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        'W systemie znajduje się już zadanie o takiej nazwie. Wybierz inną nazwę.';
    $Self->{Translation}->{'User List'} = 'Lista użytkowników';
    $Self->{Translation}->{'New User Settings'} = 'Ustawienia nowego użytkownika';
    $Self->{Translation}->{'Edit User Settings'} = 'Edytuj ustawienia użytkownika';
    $Self->{Translation}->{'Comments'} = 'Komentarz';
    $Self->{Translation}->{'Show Overtime'} = 'Pokaż nadgodziny';
    $Self->{Translation}->{'Allow project creation'} = 'Zezwól na tworzenie projektu';
    $Self->{Translation}->{'Period Begin'} = 'Okres -  początek';
    $Self->{Translation}->{'Period End'} = 'Okres - koniec';
    $Self->{Translation}->{'Days of Vacation'} = 'Dni urlopu';
    $Self->{Translation}->{'Hours per Week'} = 'Godzin w tygodniu';
    $Self->{Translation}->{'Authorized Overtime'} = 'Zezwól na nadgodziny';
    $Self->{Translation}->{'Start Date'} = '';
    $Self->{Translation}->{'Please insert a valid date.'} = '';
    $Self->{Translation}->{'End Date'} = '';
    $Self->{Translation}->{'Period end must be after period begin.'} = 'Okres końcowy musi być po okresie rozpoczęcia.';
    $Self->{Translation}->{'Leave Days'} = '';
    $Self->{Translation}->{'Weekly Hours'} = '';
    $Self->{Translation}->{'Overtime'} = '';
    $Self->{Translation}->{'No time periods found.'} = 'Brak okresów czasu.';
    $Self->{Translation}->{'Add time period'} = 'Dodaj okres czasu';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = 'Pokaż wpisz czasu';
    $Self->{Translation}->{'View of '} = 'Widok ';
    $Self->{Translation}->{'No data found for this day.'} = 'Brak danych odnośnie tego dnia.';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        'Interfejs agenta informujący o dniach bez zaraportowanego czasu pracy.';
    $Self->{Translation}->{'Default name for new actions.'} = 'Domyślna nazwa dla nowej akcji.';
    $Self->{Translation}->{'Default name for new projects.'} = 'Domyślna nazwa dla nowego projektu.';
    $Self->{Translation}->{'Default setting for date end.'} = 'Domyślna data zakończenia.';
    $Self->{Translation}->{'Default setting for date start.'} = 'Domyślna data rozpoczęcia.';
    $Self->{Translation}->{'Default setting for description.'} = 'Domyślne ustawienie dla opisu.';
    $Self->{Translation}->{'Default setting for leave days.'} = 'Domyślne ustawienie dla urlopu.';
    $Self->{Translation}->{'Default setting for overtime.'} = 'Domyślne ustawienie dla nadgodzin.';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = 'Domyślnie ustawienie dla standardowych godzin tygodniowych.';
    $Self->{Translation}->{'Default status for new actions.'} = 'Domyślny status dla nowej akcji.';
    $Self->{Translation}->{'Default status for new projects.'} = 'Domyślny status dla nowego projektu.';
    $Self->{Translation}->{'Default status for new users.'} = 'Domyślny status dla nowego użytkownika.';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        'Dentro desta opção de configuração, uma regexp pode ser definida que determina quais projetos são registrados com uma observação deve ser (o regexp funciona com SMX-parâmetros).';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        '';
    $Self->{Translation}->{'Edit time accounting settings'} = 'Edytuj ustawienia czasu raportowania';
    $Self->{Translation}->{'Edit time record'} = 'Edytuj wpis czasu';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = 'Dla ilu dni wstecz można wstawić jednostki czasu pracy';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        '';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        'Jeśli aktywowane, lista wybierana jest zastąpioną autowypełnianiem.';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        'Jeśli aktywowane, użytkownik może wstawić "urlop", "urlop chorobowy" oraz "urlop za nadgodziny" do kilku dat jednocześnie.';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        'Maksymalna liczba dni roboczych, po których jednostki czasu powinny zostać wprowadzone.';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        '';
    $Self->{Translation}->{'Project time reporting'} = 'O relatório de Tempo do projeto ';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        '';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        '';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        'Określa, czy czas pracy może zostać wprowadzony bez podawania czasu rozpoczęcia oraz zakończenia.';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = 'Ten moduł wymusza wprowadzenia w Raportach Czasu.';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        'Ten moduł daje ostrzeżenie, jeśli jest zbyt niepełnych dni roboczych.';
    $Self->{Translation}->{'Time accounting edit.'} = '';
    $Self->{Translation}->{'Time accounting overview.'} = '';
    $Self->{Translation}->{'Time accounting reporting.'} = '';
    $Self->{Translation}->{'Time accounting settings.'} = '';
    $Self->{Translation}->{'Time accounting view.'} = '';
    $Self->{Translation}->{'Time accounting.'} = '';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        'Używane jeśli niektóre działania zmniejszyły godziny pracy (np. jeśli tylko połowa czas podróży jest wypłacana klucz => podróże; Zawartość => 50).';

}

1;

# --
# Kernel/Language/pt_BR_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::pt_BR_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = 'Contabilidade Tempo';
    $Self->{Translation}->{'Show valid projects'} = 'Projeto válidos';
    $Self->{Translation}->{'Show all projects'} = 'Todos os projetos';
    $Self->{Translation}->{'TimeAccounting'} = 'TimeAccounting';
    $Self->{Translation}->{'Reporting'} = 'Relatórios';
    $Self->{Translation}->{'Please insert your working hours!'} = 'Por favor insira suas horas de trabalho!';
    $Self->{Translation}->{'Successful insert!'} = 'Inserido com sucesso!';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = 'Erro ao inserir múltiplas datas!';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = 'Entrada de várias datas inserida com sucesso!';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = 'Data inserida é inválida! Data foi alterada para hoje.';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        'Você realmente quer remover o apontamento de tempo deste dia ?';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = 'Editar esse registro';
    $Self->{Translation}->{'Go to settings'} = 'Ir para configurações';
    $Self->{Translation}->{'Date Navigation'} = 'Navegação de datas';
    $Self->{Translation}->{'Previous day'} = 'Dia anterior';
    $Self->{Translation}->{'Next day'} = 'Próximo dia';
    $Self->{Translation}->{'Go to this date'} = 'Ir para esta data';
    $Self->{Translation}->{'Days without entries'} = 'Dias sem apontamentos';
    $Self->{Translation}->{'Select all days'} = 'Selecionar todos os dias';
    $Self->{Translation}->{'Mass entry'} = 'Entrada em massa';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        'Por favor, escolha o motivo de sua ausência para os dias selecionados';
    $Self->{Translation}->{'On vacation'} = 'Em férias';
    $Self->{Translation}->{'On sick leave'} = 'Em licença médica';
    $Self->{Translation}->{'On overtime leave'} = 'Em licença de horas extras';
    $Self->{Translation}->{'Please choose at least one day!'} = 'Por favor, escolha pelo menos um dia!';
    $Self->{Translation}->{'Please choose a reason for absence!'} = 'Por favor escolha um motivo para a ausência';
    $Self->{Translation}->{'Mass Entry'} = 'Entrada em massa';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = 'Campos obrigatórios estão marcados com "*"';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = 'Você têm que preencher início e fim, ou um período de tempo.';
    $Self->{Translation}->{'Project'} = 'Projeto';
    $Self->{Translation}->{'Task'} = 'Tarefas';
    $Self->{Translation}->{'Remark'} = 'Observação';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = 'Por favor, adicione um comentário com mais de 8 caracteres!';
    $Self->{Translation}->{'Start Time'} = 'Tempo inicial ';
    $Self->{Translation}->{'Negative times are not allowed.'} = 'Datas negativas não são liberadas';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        'Horas repetidas não são liberadas. Inicie o apontamento em outro intervalo.';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = 'Formato inválido! Por favor, entre com um tempo no formato HH:MM';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = 'Apenas 24:00 são permitidas como tempo final';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = 'Tempo inválido! Um dia tem apenas 24 horas.';
    $Self->{Translation}->{'End Time'} = 'Tempo final';
    $Self->{Translation}->{'End time must be after start time.'} = 'Tempo final deve ser depois do tempo inicial.';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        'Horas repetidas não são liberadas. Inicie o apontamento em outro intervalo.';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = 'Período inválido! Um dia tem apenas 24 horas.';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = 'Um período válido deve ser maior que zero.';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = 'Período inválido! Períodos negativos não são liberados.';
    $Self->{Translation}->{'Add one row'} = 'Adicionar uma linha';
    $Self->{Translation}->{'Total'} = 'Total';
    $Self->{Translation}->{'You can only select one checkbox element!'} = 'Você pode selecionar apenas um elemento no checkbox!';
    $Self->{Translation}->{'Show all items'} = 'Mostrar todos os itens';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = 'Deletar entrada na Contabilidade de Tempo.';
    $Self->{Translation}->{'Confirm insert'} = 'Confirmar inserção';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = 'Tem certeza de que você trabalhou enquanto estava em licença médica?';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = 'Tem certeza de que você trabalhou enquanto estava de férias?';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        'Você tem certeza que trabalhou enquanto estava de licença de horas extras.';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = 'Você tem certeza que trabalhou mais que 16 horas?';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = 'Relatório de apontamento de tempo mensal';
    $Self->{Translation}->{'Overtime (Hours)'} = 'Horas extras (horas)';
    $Self->{Translation}->{'Overtime (this month)'} = 'Horas extras (este mês)';
    $Self->{Translation}->{'Overtime (total)'} = 'Horas extras (total)';
    $Self->{Translation}->{'Remaining overtime leave'} = 'Restante da licença de horas extras';
    $Self->{Translation}->{'Vacation (Days)'} = 'Férias (Dias)';
    $Self->{Translation}->{'Vacation taken (this month)'} = 'Férias tiradas (este mês)';
    $Self->{Translation}->{'Vacation taken (total)'} = 'Férias tiradas (total)';
    $Self->{Translation}->{'Remaining vacation'} = 'Férias restantes';
    $Self->{Translation}->{'Sick Leave (Days)'} = 'Licença Médica (Dias)';
    $Self->{Translation}->{'Sick leave taken (this month)'} = 'Licença médicas tiradas  ( este mês )';
    $Self->{Translation}->{'Sick leave taken (total)'} = 'Licença médicas tiradas  ( total )';
    $Self->{Translation}->{'Previous month'} = 'Mês anterior';
    $Self->{Translation}->{'Next month'} = 'Próximo mês';
    $Self->{Translation}->{'Weekday'} = 'Dia da semana';
    $Self->{Translation}->{'Working Hours'} = 'Horário de trabalho';
    $Self->{Translation}->{'Total worked hours'} = 'Total de horas trabalhadas';
    $Self->{Translation}->{'User\'s project overview'} = 'Visão de projeto de usuários';
    $Self->{Translation}->{'Hours (monthly)'} = 'Horas ( mensal )';
    $Self->{Translation}->{'Hours (Lifetime)'} = 'Horas ( Duração )';
    $Self->{Translation}->{'Grand total'} = 'Total geral';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = 'Relatório de tempo';
    $Self->{Translation}->{'Month Navigation'} = 'Navegação Mensal';
    $Self->{Translation}->{'Go to date'} = 'Ir para data';
    $Self->{Translation}->{'User reports'} = 'Relatórios de usuários';
    $Self->{Translation}->{'Monthly total'} = 'Total mensal';
    $Self->{Translation}->{'Lifetime total'} = 'Duração total';
    $Self->{Translation}->{'Overtime leave'} = 'Licença de horas extras';
    $Self->{Translation}->{'Vacation'} = 'Férias';
    $Self->{Translation}->{'Sick leave'} = 'Licença médica';
    $Self->{Translation}->{'Vacation remaining'} = 'Férias restante';
    $Self->{Translation}->{'Project reports'} = 'Relatórios de projeto';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = 'Relatório de projeto';
    $Self->{Translation}->{'Go to reporting overview'} = 'Ir para visão geral de relatórios';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        '';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        '';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = 'Editar configurações do Projeto';
    $Self->{Translation}->{'Add project'} = 'Adicionar projeto';
    $Self->{Translation}->{'Go to settings overview'} = 'Ir para configurações gerais';
    $Self->{Translation}->{'Add Project'} = 'Adicionar projeto';
    $Self->{Translation}->{'Edit Project Settings'} = 'Editar Configurações do Projeto';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        'Já existe um projeto com este nome. Por favor, escolha um diferente.';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = 'Editar Configurações da Contabilidade de Tempo.';
    $Self->{Translation}->{'Add task'} = 'Adicionar tarefa';
    $Self->{Translation}->{'New user'} = 'Novo usuário';
    $Self->{Translation}->{'Filter for Projects'} = 'Filtrar por Projetos';
    $Self->{Translation}->{'Filter for Tasks'} = 'Filtrar for Tarefas';
    $Self->{Translation}->{'Filter for Users'} = 'Filtrar por usuários';
    $Self->{Translation}->{'Project List'} = 'Lista de projetos';
    $Self->{Translation}->{'Task List'} = 'Lista de tarefas';
    $Self->{Translation}->{'Add Task'} = 'Adicionar tarefa';
    $Self->{Translation}->{'Edit Task Settings'} = 'Editar configurações da Tarefa';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        'Já existe uma tarefa com esse nome. Por favor, escolha um nome diferente.';
    $Self->{Translation}->{'User List'} = 'Lista de usuários';
    $Self->{Translation}->{'New User Settings'} = 'Configurações de novo usuário';
    $Self->{Translation}->{'Edit User Settings'} = 'Editar configurações de usuários';
    $Self->{Translation}->{'Comments'} = 'Comentários';
    $Self->{Translation}->{'Show Overtime'} = 'Mostrar horas extras';
    $Self->{Translation}->{'Allow project creation'} = 'Liberar criação de projetos';
    $Self->{Translation}->{'Period Begin'} = 'Período Inicial';
    $Self->{Translation}->{'Period End'} = 'Período Final';
    $Self->{Translation}->{'Days of Vacation'} = 'Dias de Férias';
    $Self->{Translation}->{'Hours per Week'} = 'Horas por Semana';
    $Self->{Translation}->{'Authorized Overtime'} = 'Horas extras autorizada';
    $Self->{Translation}->{'Start Date'} = 'Data inicial ';
    $Self->{Translation}->{'Please insert a valid date.'} = 'Por favor, insira uma data válida.';
    $Self->{Translation}->{'End Date'} = 'Data final';
    $Self->{Translation}->{'Period end must be after period begin.'} = 'Período final deve ser maior que  período inicial.';
    $Self->{Translation}->{'Leave Days'} = 'Dias de férias';
    $Self->{Translation}->{'Weekly Hours'} = 'Horas semanais';
    $Self->{Translation}->{'Overtime'} = 'Horas extras';
    $Self->{Translation}->{'No time periods found.'} = 'Período de tempo não encontrado.';
    $Self->{Translation}->{'Add time period'} = 'Adicionar período de tempo';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = 'Ver registro de tempo';
    $Self->{Translation}->{'View of '} = 'Visão de';
    $Self->{Translation}->{'No data found for this day.'} = 'Não foram encontrados dados para este dia.';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        'Módulo de notificação do Agente para ver o numero de dias incompletos do usuário.';
    $Self->{Translation}->{'Default name for new actions.'} = 'O nome padrão para novas ações.';
    $Self->{Translation}->{'Default name for new projects.'} = 'O nome padrão para novos projetos.';
    $Self->{Translation}->{'Default setting for date end.'} = 'Configuração padrão para data final';
    $Self->{Translation}->{'Default setting for date start.'} = 'Configuração padrão para data inicial.';
    $Self->{Translation}->{'Default setting for description.'} = 'Configuração padrão para descrição.';
    $Self->{Translation}->{'Default setting for leave days.'} = 'Configuração padrão para dias de férias.';
    $Self->{Translation}->{'Default setting for overtime.'} = 'Configuração padrão para horas extras,';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = 'Configuração padrão para horas semanais padrão';
    $Self->{Translation}->{'Default status for new actions.'} = 'Estado padrão para novas ações.';
    $Self->{Translation}->{'Default status for new projects.'} = 'Estado padrão para novos projetos';
    $Self->{Translation}->{'Default status for new users.'} = 'Estado para para novos usuários';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        'Define os projetos para os quais é necessária uma observação. Se o RegExp é encontrado no projeto, você tem que inserir uma observação. O RegExp usa o parâmetro smx.';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        'Determina se o módulo de estatísticas pode gerar informações do time accounting.';
    $Self->{Translation}->{'Edit time accounting settings'} = 'Editar configurações da contabilidade de tempo';
    $Self->{Translation}->{'Edit time record'} = 'Editar esse registro';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = 'Para quantos dias atrás você pode inserir unidades de trabalho.';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        '';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        'Se ativado, os elementos dropdown na tela de edição são alteradas para campos de autocompletion.';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        'Se ativado, o usuário tem permissão para entrar "em licença de férias", "em licença médica" e "em licença de horas extras" de uma só vez para várias datas.';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        'O número máximo de dias de trabalho após o qual as "unidades de trabalho" devem ser inseridos';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        'O número máximo de dias de trabalho sem "unidades de trabalho"  após o qual um aviso será mostrado.';
    $Self->{Translation}->{'Project time reporting'} = 'Relatório de tempos de projetos';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        'As expressões regulares para restringir lista de ações de acordo com o projeto selecionado. Chave contém expressão regular para o projeto(s), Conteúdo contém expressões regulares para a ação(s).';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        'As expressões regulares para restringir a lista de projeto de acordo com grupos de usuários. Chave contém expressão regular para o projeto (s), conteúdo contém lista  separada por vírgulas de grupos.';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        'Especifique se o horário de trabalho pode ser inserido sem horários de início e término.';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = 'Esse módulo força preencher o TimeAccounting.';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        'Este módulo de notificação dá um aviso se houver muitos dias de trabalho não registrados.';
    $Self->{Translation}->{'Time accounting edit.'} = 'Editar contabilidade de tempo';
    $Self->{Translation}->{'Time accounting overview.'} = 'Visão geral de contabilidade de tempo';
    $Self->{Translation}->{'Time accounting reporting.'} = 'Relatório de contabilidade de tempo';
    $Self->{Translation}->{'Time accounting settings.'} = 'Configurações de contabilidade de tempo';
    $Self->{Translation}->{'Time accounting view.'} = 'Ver contabilidade de tempo';
    $Self->{Translation}->{'Time accounting.'} = 'Contabilidade Tempo';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        'Usar para  algumas ações de reduzir as horas de trabalho (por exemplo, se apenas metade do tempo de viagem é pago Key => viajar; Content => 50)';

}

1;

# --
# Kernel/Language/ru_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::ru_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = 'Учет затраченного времени';
    $Self->{Translation}->{'Show valid projects'} = 'Показать действительные проекты';
    $Self->{Translation}->{'Show all projects'} = 'Показать все проекты';
    $Self->{Translation}->{'TimeAccounting'} = 'Учет затрат времени';
    $Self->{Translation}->{'Reporting'} = 'Отчетность';
    $Self->{Translation}->{'Please insert your working hours!'} = 'Введите Ваши рабочие часы!';
    $Self->{Translation}->{'Successful insert!'} = 'Данные занесены успешно!';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = 'Ошибка при вводе нескольких дат!';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = 'Данные для разных дат введены успешно!';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = 'Введенная дата неверна! Заменена на текущую!';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        'Вы действительно желаете удалить учтенные затраты времени для этого дня?';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = 'Редактировать запись времени';
    $Self->{Translation}->{'Go to settings'} = 'Перейти к настройкам';
    $Self->{Translation}->{'Date Navigation'} = 'Навигация по времени';
    $Self->{Translation}->{'Previous day'} = 'Предыдущий день';
    $Self->{Translation}->{'Next day'} = 'Следующий день';
    $Self->{Translation}->{'Go to this date'} = 'Перейти к этой дате';
    $Self->{Translation}->{'Days without entries'} = 'Дни без записей';
    $Self->{Translation}->{'Select all days'} = 'Выбрать все дни';
    $Self->{Translation}->{'Mass entry'} = 'Массовый ввод';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        'Выберите причину вашего отсутствия в выбранные дни';
    $Self->{Translation}->{'On vacation'} = 'В отпуске';
    $Self->{Translation}->{'On sick leave'} = 'По болезни';
    $Self->{Translation}->{'On overtime leave'} = 'В отгуле за переработку';
    $Self->{Translation}->{'Please choose at least one day!'} = 'Выберите хотя бы один день!';
    $Self->{Translation}->{'Please choose a reason for absence!'} = 'Выберите причину отсутствия!';
    $Self->{Translation}->{'Mass Entry'} = 'Массовый ввод';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = 'Обязательные поля помечены "*".';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = 'Необходимо заполнить время начала и окончания или период времени.';
    $Self->{Translation}->{'Project'} = 'Проект';
    $Self->{Translation}->{'Task'} = 'Задача';
    $Self->{Translation}->{'Remark'} = 'Примечание';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = 'Примечание должно быть не менее 8 символов.';
    $Self->{Translation}->{'Start Time'} = 'Время начала';
    $Self->{Translation}->{'Negative times are not allowed.'} = 'Отрицательное значение недопустимо.';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        'Не допускается повторение. Время начала соответствует другому интервалу.';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = 'Неверный формат! Введите время в формате HH:MM.';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = 'Только 24:00 разрешено в качестве времени окончания.';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = 'Неверное время! В сутках только 24 часа.';
    $Self->{Translation}->{'End Time'} = 'Время окончания';
    $Self->{Translation}->{'End time must be after start time.'} = 'Время окончания должно быть позже времени начала.';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        'Не допускается повторение. Время окончания соответствует другому интервалу.';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = 'Неверный период! В сутках только 24 часа.';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = 'Правильный период должен быть больше нуля.';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = 'Неверный период! Отрицательное значение не допускается.';
    $Self->{Translation}->{'Add one row'} = 'Добавить одну строку';
    $Self->{Translation}->{'Total'} = 'Итого';
    $Self->{Translation}->{'You can only select one checkbox element!'} = 'У вас есть возможность выбрать только один элемент!';
    $Self->{Translation}->{'Show all items'} = 'Показать все';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = 'Удалить запись затраченного времени';
    $Self->{Translation}->{'Confirm insert'} = 'Подтвердите вставку';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = 'Вы действительно работали в период болезни?';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = 'Вы действительно работали в период отпуска?';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        'Вы действительно работали в период отгулов?';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = 'Вы действительно работали более 16 часов?';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = 'Месячный отчет о затраченном времени';
    $Self->{Translation}->{'Overtime (Hours)'} = 'Переработка (часы)';
    $Self->{Translation}->{'Overtime (this month)'} = 'Переработка (этого месяца)';
    $Self->{Translation}->{'Overtime (total)'} = 'Переработка (всего)';
    $Self->{Translation}->{'Remaining overtime leave'} = 'Оставшееся время отгула';
    $Self->{Translation}->{'Vacation (Days)'} = 'Отпуск (дни)';
    $Self->{Translation}->{'Vacation taken (this month)'} = 'Использованные дни отпуска (в этом месяце)';
    $Self->{Translation}->{'Vacation taken (total)'} = 'Использованные дни отпуска (всего)';
    $Self->{Translation}->{'Remaining vacation'} = 'Оставшиеся дни отпуска';
    $Self->{Translation}->{'Sick Leave (Days)'} = 'Болезнь (дни)';
    $Self->{Translation}->{'Sick leave taken (this month)'} = 'Отсутствовал по болезни (в этом месяце)';
    $Self->{Translation}->{'Sick leave taken (total)'} = 'Отсутствовал по болезни (всего)';
    $Self->{Translation}->{'Previous month'} = 'Предыдущий месяц';
    $Self->{Translation}->{'Next month'} = 'Следующий месяц';
    $Self->{Translation}->{'Weekday'} = 'Неделя';
    $Self->{Translation}->{'Working Hours'} = 'Рабочие часы';
    $Self->{Translation}->{'Total worked hours'} = 'Всего отработанных часов';
    $Self->{Translation}->{'User\'s project overview'} = 'Обзор данных по проекту пользователя';
    $Self->{Translation}->{'Hours (monthly)'} = 'Часы (ежемесячно)';
    $Self->{Translation}->{'Hours (Lifetime)'} = 'Часы (за весь срок наблюдения)';
    $Self->{Translation}->{'Grand total'} = 'Всего';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = 'Отчет о времени';
    $Self->{Translation}->{'Month Navigation'} = 'Навигация по месяцам';
    $Self->{Translation}->{'Go to date'} = 'Перейти к дате';
    $Self->{Translation}->{'User reports'} = 'Отчет о пользователе';
    $Self->{Translation}->{'Monthly total'} = 'Итого за месяц';
    $Self->{Translation}->{'Lifetime total'} = 'Итого за все время';
    $Self->{Translation}->{'Overtime leave'} = 'Отгулы за переработку';
    $Self->{Translation}->{'Vacation'} = 'Отпуск';
    $Self->{Translation}->{'Sick leave'} = 'Отсутствие по болезни';
    $Self->{Translation}->{'Vacation remaining'} = 'Осталось дней отпуска';
    $Self->{Translation}->{'Project reports'} = 'Отчеты по проекту';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = 'Отчет по проекту';
    $Self->{Translation}->{'Go to reporting overview'} = 'Перейти к обзору отчетов';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        '';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        '';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = 'Редактировать настройки учета затраченного времени по проекту';
    $Self->{Translation}->{'Add project'} = 'Добавить проект';
    $Self->{Translation}->{'Go to settings overview'} = 'Перейти к обзору настроек';
    $Self->{Translation}->{'Add Project'} = 'Добавить проект';
    $Self->{Translation}->{'Edit Project Settings'} = 'Редактировать настройки проекта';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        'Уже есть проект с таким наименованием. Выберите другое.';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = 'Редактировать настройки учета затраченного времени';
    $Self->{Translation}->{'Add task'} = 'Добавить задачу';
    $Self->{Translation}->{'New user'} = 'Новый пользователь';
    $Self->{Translation}->{'Filter for Projects'} = 'Фильтр для Проектов';
    $Self->{Translation}->{'Filter for Tasks'} = 'Фильтр для задач';
    $Self->{Translation}->{'Filter for Users'} = 'Фильтр для пользователей';
    $Self->{Translation}->{'Project List'} = 'Список проектов';
    $Self->{Translation}->{'Task List'} = 'Список задач';
    $Self->{Translation}->{'Add Task'} = 'Добавить задачу';
    $Self->{Translation}->{'Edit Task Settings'} = 'Редактировать настройки задачи';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        'Уже есть задача с таким именем, Выберите другое.';
    $Self->{Translation}->{'User List'} = 'Список пользователей';
    $Self->{Translation}->{'New User Settings'} = 'Настройки нового пользователя';
    $Self->{Translation}->{'Edit User Settings'} = 'Редактировать настройки пользователя';
    $Self->{Translation}->{'Comments'} = 'Комментарии';
    $Self->{Translation}->{'Show Overtime'} = 'Показать переработку';
    $Self->{Translation}->{'Allow project creation'} = 'Разрешить создание проектов';
    $Self->{Translation}->{'Period Begin'} = 'Начало периода';
    $Self->{Translation}->{'Period End'} = 'Конец периода';
    $Self->{Translation}->{'Days of Vacation'} = 'Дни отпуска';
    $Self->{Translation}->{'Hours per Week'} = 'Часов в неделе';
    $Self->{Translation}->{'Authorized Overtime'} = 'Разрешенная переработка';
    $Self->{Translation}->{'Start Date'} = 'Дата начала';
    $Self->{Translation}->{'Please insert a valid date.'} = 'Введите правильную дату.';
    $Self->{Translation}->{'End Date'} = 'Дата окончания';
    $Self->{Translation}->{'Period end must be after period begin.'} = 'Время окончания периода должно быть позже времени его начала.';
    $Self->{Translation}->{'Leave Days'} = 'Осталось, дней';
    $Self->{Translation}->{'Weekly Hours'} = 'Часов в неделю';
    $Self->{Translation}->{'Overtime'} = 'Переработка/Сверхурочные';
    $Self->{Translation}->{'No time periods found.'} = 'Не заданы периоды времени.';
    $Self->{Translation}->{'Add time period'} = 'Добавить перид времени';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = 'Посмотреть запись времени';
    $Self->{Translation}->{'View of '} = 'Просмотр';
    $Self->{Translation}->{'No data found for this day.'} = 'Для этого дня данные не найдены.';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        'Модуль уведомлений, для отображения количества незавершенных рабочих дней пользователя в интерфейсе агента';
    $Self->{Translation}->{'Default name for new actions.'} = 'Имена по умолчанию для новых действий.';
    $Self->{Translation}->{'Default name for new projects.'} = 'Название нового проекта по-умолчанию.';
    $Self->{Translation}->{'Default setting for date end.'} = 'Значение по умолчанию для даты окончания.';
    $Self->{Translation}->{'Default setting for date start.'} = 'Значение по умолчанию для даты начала.';
    $Self->{Translation}->{'Default setting for description.'} = 'Значение по умолчанию для описания.';
    $Self->{Translation}->{'Default setting for leave days.'} = 'Значение по умолчанию для оставшихся дней.';
    $Self->{Translation}->{'Default setting for overtime.'} = 'Значение по умолчанию для переработки.';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = 'Значение по умолчанию для стандартных рабочих часов.';
    $Self->{Translation}->{'Default status for new actions.'} = 'Значение по умолчанию статуса новых действий.';
    $Self->{Translation}->{'Default status for new projects.'} = 'Значение по умолчанию для статуса новых проектов.';
    $Self->{Translation}->{'Default status for new users.'} = 'Значение по умолчанию для статуса новых пользователей.';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        'Задает проекты для которых требуется занесение замечаний. Если RegExp верно для проекта, вы должны добавить замечания тоже. Для RegExp используйте параметр smx.';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        'Задает, может ли модуль отчетов генерировать информацию по учету затраченного времени.';
    $Self->{Translation}->{'Edit time accounting settings'} = 'Редактировать настройки учета затраченного времени';
    $Self->{Translation}->{'Edit time record'} = 'Редактировать запись времени';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = 'Для какого количества прошедших дней вы можете внести данные о времени.';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        'Если включено, отображаются только пользователи, которые заносили затраты времени в выбранный проект.';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        'Если включено, для выбора полей списка на экране редактирования можно использовать автозавершение.';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        'Если включено, пользователю разрешено вводить значения "Осталось в отпске", "Осталось дней по болезни" и "Осталось переработки" по несколько дат сразу.';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        'Макс. количество рабочих дней, после которых рабочие единицы должны быть занесены.';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        'Максимально количество рабочих дней, после которого выдается предупреждение о том, что данные не вводились.';
    $Self->{Translation}->{'Project time reporting'} = 'Отчет о времени по проекту';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        'Регулярные выражения для составления списка действий в соответствии с выбранным проектом. Ключ должен содержать регулярное выражение для проекта(ов), Содержание - регулярные выражения для действия(й).';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        'Регулярные выражения для составления списка действий в зависимости от групп пользователей. Ключ должен содержать регулярное выражение для проекта(ов), Содержание - список групп, разделенных запятой.';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        'Задает, можно ли заносить рабочие часы без указания времени начала и окончания.';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = 'Этот модуль ускоряет ввод данных в TimeAccounting.';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        'Модуль уведомлений, для отображения количества незавершенных рабочих дней пользователя.';
    $Self->{Translation}->{'Time accounting edit.'} = 'Редактирование затрат времени.';
    $Self->{Translation}->{'Time accounting overview.'} = 'Обзор затрат времени.';
    $Self->{Translation}->{'Time accounting reporting.'} = 'Отчеты о затртах времени.';
    $Self->{Translation}->{'Time accounting settings.'} = 'Настройки учета затраченного времени.';
    $Self->{Translation}->{'Time accounting view.'} = 'Просмотр затрат времени.';
    $Self->{Translation}->{'Time accounting.'} = 'Учет затраченного времени';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        'Для использования, если некоторые действия уменьшают рабочие часы (например, если только половина времени в пути оплачивается - Key => traveling; Content => 50).';

}

1;

# --
# Kernel/Language/sv_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::sv_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = '';
    $Self->{Translation}->{'Show valid projects'} = '';
    $Self->{Translation}->{'Show all projects'} = '';
    $Self->{Translation}->{'TimeAccounting'} = '';
    $Self->{Translation}->{'Reporting'} = '';
    $Self->{Translation}->{'Please insert your working hours!'} = '';
    $Self->{Translation}->{'Successful insert!'} = '';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = '';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = '';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = '';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        '';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = '';
    $Self->{Translation}->{'Go to settings'} = '';
    $Self->{Translation}->{'Date Navigation'} = '';
    $Self->{Translation}->{'Previous day'} = '';
    $Self->{Translation}->{'Next day'} = '';
    $Self->{Translation}->{'Go to this date'} = '';
    $Self->{Translation}->{'Days without entries'} = '';
    $Self->{Translation}->{'Select all days'} = '';
    $Self->{Translation}->{'Mass entry'} = '';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        '';
    $Self->{Translation}->{'On vacation'} = 'På semester';
    $Self->{Translation}->{'On sick leave'} = '';
    $Self->{Translation}->{'On overtime leave'} = '';
    $Self->{Translation}->{'Please choose at least one day!'} = '';
    $Self->{Translation}->{'Please choose a reason for absence!'} = '';
    $Self->{Translation}->{'Mass Entry'} = '';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = '';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = '';
    $Self->{Translation}->{'Project'} = '';
    $Self->{Translation}->{'Task'} = '';
    $Self->{Translation}->{'Remark'} = '';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = '';
    $Self->{Translation}->{'Start Time'} = '';
    $Self->{Translation}->{'Negative times are not allowed.'} = '';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        '';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = '';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = '';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = '';
    $Self->{Translation}->{'End Time'} = '';
    $Self->{Translation}->{'End time must be after start time.'} = '';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        '';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = '';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = '';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = '';
    $Self->{Translation}->{'Add one row'} = '';
    $Self->{Translation}->{'Total'} = '';
    $Self->{Translation}->{'You can only select one checkbox element!'} = '';
    $Self->{Translation}->{'Show all items'} = '';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = '';
    $Self->{Translation}->{'Confirm insert'} = '';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = '';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = '';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        '';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = '';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = '';
    $Self->{Translation}->{'Overtime (Hours)'} = 'Övertid (Timmar)';
    $Self->{Translation}->{'Overtime (this month)'} = '';
    $Self->{Translation}->{'Overtime (total)'} = '';
    $Self->{Translation}->{'Remaining overtime leave'} = '';
    $Self->{Translation}->{'Vacation (Days)'} = 'Semester (Dagar)';
    $Self->{Translation}->{'Vacation taken (this month)'} = '';
    $Self->{Translation}->{'Vacation taken (total)'} = '';
    $Self->{Translation}->{'Remaining vacation'} = '';
    $Self->{Translation}->{'Sick Leave (Days)'} = '';
    $Self->{Translation}->{'Sick leave taken (this month)'} = '';
    $Self->{Translation}->{'Sick leave taken (total)'} = '';
    $Self->{Translation}->{'Previous month'} = '';
    $Self->{Translation}->{'Next month'} = '';
    $Self->{Translation}->{'Weekday'} = '';
    $Self->{Translation}->{'Working Hours'} = '';
    $Self->{Translation}->{'Total worked hours'} = '';
    $Self->{Translation}->{'User\'s project overview'} = '';
    $Self->{Translation}->{'Hours (monthly)'} = '';
    $Self->{Translation}->{'Hours (Lifetime)'} = '';
    $Self->{Translation}->{'Grand total'} = '';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = '';
    $Self->{Translation}->{'Month Navigation'} = '';
    $Self->{Translation}->{'Go to date'} = '';
    $Self->{Translation}->{'User reports'} = '';
    $Self->{Translation}->{'Monthly total'} = '';
    $Self->{Translation}->{'Lifetime total'} = '';
    $Self->{Translation}->{'Overtime leave'} = '';
    $Self->{Translation}->{'Vacation'} = '';
    $Self->{Translation}->{'Sick leave'} = '';
    $Self->{Translation}->{'Vacation remaining'} = '';
    $Self->{Translation}->{'Project reports'} = '';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = '';
    $Self->{Translation}->{'Go to reporting overview'} = '';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        '';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        '';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = '';
    $Self->{Translation}->{'Add project'} = '';
    $Self->{Translation}->{'Go to settings overview'} = '';
    $Self->{Translation}->{'Add Project'} = '';
    $Self->{Translation}->{'Edit Project Settings'} = '';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        '';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = '';
    $Self->{Translation}->{'Add task'} = '';
    $Self->{Translation}->{'New user'} = '';
    $Self->{Translation}->{'Filter for Projects'} = '';
    $Self->{Translation}->{'Filter for Tasks'} = '';
    $Self->{Translation}->{'Filter for Users'} = '';
    $Self->{Translation}->{'Project List'} = '';
    $Self->{Translation}->{'Task List'} = '';
    $Self->{Translation}->{'Add Task'} = '';
    $Self->{Translation}->{'Edit Task Settings'} = '';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        '';
    $Self->{Translation}->{'User List'} = '';
    $Self->{Translation}->{'New User Settings'} = '';
    $Self->{Translation}->{'Edit User Settings'} = '';
    $Self->{Translation}->{'Comments'} = '';
    $Self->{Translation}->{'Show Overtime'} = '';
    $Self->{Translation}->{'Allow project creation'} = '';
    $Self->{Translation}->{'Period Begin'} = '';
    $Self->{Translation}->{'Period End'} = '';
    $Self->{Translation}->{'Days of Vacation'} = '';
    $Self->{Translation}->{'Hours per Week'} = '';
    $Self->{Translation}->{'Authorized Overtime'} = '';
    $Self->{Translation}->{'Start Date'} = '';
    $Self->{Translation}->{'Please insert a valid date.'} = '';
    $Self->{Translation}->{'End Date'} = '';
    $Self->{Translation}->{'Period end must be after period begin.'} = '';
    $Self->{Translation}->{'Leave Days'} = '';
    $Self->{Translation}->{'Weekly Hours'} = '';
    $Self->{Translation}->{'Overtime'} = '';
    $Self->{Translation}->{'No time periods found.'} = '';
    $Self->{Translation}->{'Add time period'} = '';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = '';
    $Self->{Translation}->{'View of '} = '';
    $Self->{Translation}->{'No data found for this day.'} = '';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        '';
    $Self->{Translation}->{'Default name for new actions.'} = '';
    $Self->{Translation}->{'Default name for new projects.'} = '';
    $Self->{Translation}->{'Default setting for date end.'} = '';
    $Self->{Translation}->{'Default setting for date start.'} = '';
    $Self->{Translation}->{'Default setting for description.'} = '';
    $Self->{Translation}->{'Default setting for leave days.'} = '';
    $Self->{Translation}->{'Default setting for overtime.'} = '';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = '';
    $Self->{Translation}->{'Default status for new actions.'} = '';
    $Self->{Translation}->{'Default status for new projects.'} = '';
    $Self->{Translation}->{'Default status for new users.'} = '';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        '';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        '';
    $Self->{Translation}->{'Edit time accounting settings'} = '';
    $Self->{Translation}->{'Edit time record'} = '';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = '';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        '';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        '';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        '';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        '';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        '';
    $Self->{Translation}->{'Project time reporting'} = '';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        '';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        '';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        '';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = '';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        '';
    $Self->{Translation}->{'Time accounting edit.'} = '';
    $Self->{Translation}->{'Time accounting overview.'} = '';
    $Self->{Translation}->{'Time accounting reporting.'} = '';
    $Self->{Translation}->{'Time accounting settings.'} = '';
    $Self->{Translation}->{'Time accounting view.'} = '';
    $Self->{Translation}->{'Time accounting.'} = '';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        '';

}

1;

# --
# Kernel/Language/sw_TimeAccounting.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::sw_TimeAccounting;

use strict;
use warnings;
use utf8;

sub Data {
    my $Self = shift;

    # Template: AAATimeAccounting
    $Self->{Translation}->{'Time Accounting'} = 'Uhasibu wa muda';
    $Self->{Translation}->{'Show valid projects'} = 'Onyesha miradi iliyo halali';
    $Self->{Translation}->{'Show all projects'} = 'Onyesha miradi yote';
    $Self->{Translation}->{'TimeAccounting'} = 'Uhasibu wa muda';
    $Self->{Translation}->{'Reporting'} = 'Uarifu';
    $Self->{Translation}->{'Please insert your working hours!'} = 'Tafadhali ingiza massaa ya kazi!';
    $Self->{Translation}->{'Successful insert!'} = 'Ingizo limefanikiwa';
    $Self->{Translation}->{'Error while inserting multiple dates!'} = 'Kosa katika kuingiza tarehe zaidi ya moja!';
    $Self->{Translation}->{'Successfully inserted entries for several dates!'} = 'Maingizo yaliyofanikiwa kwa tarehe zaidi ya moja!';
    $Self->{Translation}->{'Entered date was invalid! Date was changed to today.'} = 'Ingizo la tarehe ni batili! Tarehe imebadilishwa leo.';

    # Template: AgentTimeAccountingDelete
    $Self->{Translation}->{'Do you really want to delete the Time Accounting of this day?'} =
        'Je unataka kufuta Uhasibu wa Muda kwa siku ya leo?';

    # Template: AgentTimeAccountingEdit
    $Self->{Translation}->{'Edit Time Record'} = 'Hariri rekodi ya muda';
    $Self->{Translation}->{'Go to settings'} = 'Nenda kwenye mpangilio';
    $Self->{Translation}->{'Date Navigation'} = 'Uabiri wa tarehe';
    $Self->{Translation}->{'Previous day'} = 'Siku iliyopita';
    $Self->{Translation}->{'Next day'} = 'Siku inayofwata';
    $Self->{Translation}->{'Go to this date'} = 'Nenda kwenye hii tarehe';
    $Self->{Translation}->{'Days without entries'} = 'Siku zisizokuwa na maingizo';
    $Self->{Translation}->{'Select all days'} = 'Chagua siku zote';
    $Self->{Translation}->{'Mass entry'} = 'Ingizo la pamoja';
    $Self->{Translation}->{'Please choose the reason for your absence for the selected days'} =
        'Tafadhali chagua sababu ya kutokuwepo kwa siku zilizo chaguliwa';
    $Self->{Translation}->{'On vacation'} = 'Katika likizo';
    $Self->{Translation}->{'On sick leave'} = 'Katika ruhusa ya wagonjwa';
    $Self->{Translation}->{'On overtime leave'} = 'Katika ruhusa ya muda wa nyongeza';
    $Self->{Translation}->{'Please choose at least one day!'} = 'Tafadhali chagua japo siku moja';
    $Self->{Translation}->{'Please choose a reason for absence!'} = 'Tafadhali chagua sababu ya kuto kuwepo!';
    $Self->{Translation}->{'Mass Entry'} = 'Ingizo la pamoja';
    $Self->{Translation}->{'Required fields are marked with a "*".'} = 'Sehemu zinazotakiwa zina alama "*"';
    $Self->{Translation}->{'You have to fill in start and end time or a time period.'} = 'Unatakiwa kujaza muda wa kuanza na kumaliza au muda uliotumika.';
    $Self->{Translation}->{'Project'} = 'Mradi';
    $Self->{Translation}->{'Task'} = 'Kazi';
    $Self->{Translation}->{'Remark'} = 'Maoni';
    $Self->{Translation}->{'Please add a remark with more than 8 characters!.'} = 'Tafadhali weka maoni yenye zaidi ya herufi 8!.';
    $Self->{Translation}->{'Start Time'} = 'Muda wa Kuanza';
    $Self->{Translation}->{'Negative times are not allowed.'} = 'Muda hasi hauruhusiwi.';
    $Self->{Translation}->{'Repeated hours are not allowed. Start time matches another interval.'} =
        'Muda uliojirudia hauruhusiwi. Muda wa kuanza unafanana na muda mwingine.';
    $Self->{Translation}->{'Invalid format! Please enter a time with the format HH:MM.'} = 'Muundo batili! Tafadhali ingiza muda na muundo HH:MM.';
    $Self->{Translation}->{'24:00 is only permitted as end time.'} = '24:00 inaruhusiwa katika muda wa kumaliza.';
    $Self->{Translation}->{'Invalid time! A day has only 24 hours.'} = 'Muda batili! Siku ina masaa 24 tu.';
    $Self->{Translation}->{'End Time'} = 'Muda wa kumaliza';
    $Self->{Translation}->{'End time must be after start time.'} = 'Muda wa kumaliza lazima uwe baada ya muda wa kuanza.';
    $Self->{Translation}->{'Repeated hours are not allowed. End time matches another interval.'} =
        'Masaa yaliyojirudia hayaruhusiwi. Muda wa kumaliza unafanana muda mwingine.';
    $Self->{Translation}->{'Invalid period! A day has only 24 hours.'} = 'Muda batili! Siku ina masaa 24 tu.';
    $Self->{Translation}->{'A valid period must be greater than zero.'} = 'Muda halali una masaa zaidi ya sifuri.';
    $Self->{Translation}->{'Invalid period! Negative periods are not allowed.'} = 'Kipindi batili! Vipindi hasi haviruhusiwi.';
    $Self->{Translation}->{'Add one row'} = 'Ongeza safu moja';
    $Self->{Translation}->{'Total'} = 'Jumla';
    $Self->{Translation}->{'You can only select one checkbox element!'} = 'Unaweza kuchagua elementi moja katika cheki boksi';
    $Self->{Translation}->{'Show all items'} = 'Onyesha vipengele vyote';
    $Self->{Translation}->{'Delete Time Accounting Entry'} = 'Futa ingizo la Uhasibu wa Muda';
    $Self->{Translation}->{'Confirm insert'} = 'Hakiki ingizo';
    $Self->{Translation}->{'Are you sure that you worked while you were on sick leave?'} = 'Una uhakika ulifanya kazi wakati upo likizo ya wagonjwa?';
    $Self->{Translation}->{'Are you sure that you worked while you were on vacation?'} = 'Una uhakika ulifanya kazi wakati upo likizo?';
    $Self->{Translation}->{'Are you sure that you worked while you were on overtime leave?'} =
        'Una uhakika ulifanya kazi wakati upo likizo ya muda wa nyongeza?';
    $Self->{Translation}->{'Are you sure that you worked more than 16 hours?'} = 'Una uhakika ulifanya kazi zaidi ya masaa 16?';

    # Template: AgentTimeAccountingOverview
    $Self->{Translation}->{'Time reporting monthly overview'} = 'Mapitio ya mwezi ya uarifu wa muda ';
    $Self->{Translation}->{'Overtime (Hours)'} = 'Muda wa nyogneza (Masaa)';
    $Self->{Translation}->{'Overtime (this month)'} = 'Muda wa nyongeza (mwezi huu)';
    $Self->{Translation}->{'Overtime (total)'} = 'Muda wa nyongeza (jumla)';
    $Self->{Translation}->{'Remaining overtime leave'} = 'Muda uliobaki wa likizo ya muda wa nyongeza';
    $Self->{Translation}->{'Vacation (Days)'} = 'Likizo (siku)';
    $Self->{Translation}->{'Vacation taken (this month)'} = 'Likizo iliyochukuliwa (mwezi huu)';
    $Self->{Translation}->{'Vacation taken (total)'} = 'Likizo iliyochukuliwa (jumla)';
    $Self->{Translation}->{'Remaining vacation'} = 'Likizo iliyobaki';
    $Self->{Translation}->{'Sick Leave (Days)'} = 'Likizo ya wagonjwa (siku)';
    $Self->{Translation}->{'Sick leave taken (this month)'} = 'Likizo ya wagonjwa iliyochukuliwa (mwezi huu)';
    $Self->{Translation}->{'Sick leave taken (total)'} = 'Likizo ya wagonjwa iliyochukuliwa (jumla)';
    $Self->{Translation}->{'Previous month'} = 'Mwezi uliopita';
    $Self->{Translation}->{'Next month'} = 'Mwezi ujao';
    $Self->{Translation}->{'Weekday'} = 'Siku za kazi';
    $Self->{Translation}->{'Working Hours'} = 'Masaa ya kazi';
    $Self->{Translation}->{'Total worked hours'} = 'Jumla ya masaa ya kazi';
    $Self->{Translation}->{'User\'s project overview'} = 'Mapitio ya mradi wa mtumiaji';
    $Self->{Translation}->{'Hours (monthly)'} = 'Masaa (kwa mwezi)';
    $Self->{Translation}->{'Hours (Lifetime)'} = 'Masaa (muda wote)';
    $Self->{Translation}->{'Grand total'} = 'Jumla kuu';

    # Template: AgentTimeAccountingReporting
    $Self->{Translation}->{'Time reporting'} = 'Uarifu wa muda';
    $Self->{Translation}->{'Month Navigation'} = 'Uabiri wa mwezi';
    $Self->{Translation}->{'Go to date'} = 'Nenda tarehe';
    $Self->{Translation}->{'User reports'} = 'Ripoti za mtumiaji';
    $Self->{Translation}->{'Monthly total'} = 'Jumla ya mwezi';
    $Self->{Translation}->{'Lifetime total'} = 'Jumla ya muda wote';
    $Self->{Translation}->{'Overtime leave'} = 'Likizo ya muda wa nyongeza';
    $Self->{Translation}->{'Vacation'} = 'Likizo';
    $Self->{Translation}->{'Sick leave'} = 'Likizo ya wagonjwa';
    $Self->{Translation}->{'Vacation remaining'} = 'Likizo iliyobaki';
    $Self->{Translation}->{'Project reports'} = 'Ripoti za mradi';

    # Template: AgentTimeAccountingReportingProject
    $Self->{Translation}->{'Project report'} = 'Ripoti ya mradi';
    $Self->{Translation}->{'Go to reporting overview'} = 'Nenda kwenye mapitio ya uarifu';
    $Self->{Translation}->{'Currently only active users in this project are shown. To change this behavior, please update setting:'} =
        '';
    $Self->{Translation}->{'Currently all time accounting users are shown. To change this behavior, please update setting:'} =
        '';

    # Template: AgentTimeAccountingSetting
    $Self->{Translation}->{'Edit Time Accounting Project Settings'} = 'Hariri Uhasibu wa Muda kwenye mipangilio ya mradi';
    $Self->{Translation}->{'Add project'} = 'Ongeza mradi';
    $Self->{Translation}->{'Go to settings overview'} = 'Nenda kwenye mapitio ya mpangiio';
    $Self->{Translation}->{'Add Project'} = 'Ongeza mradi';
    $Self->{Translation}->{'Edit Project Settings'} = 'Hariri mipangilio ya mradi';
    $Self->{Translation}->{'There is already a project with this name. Please, choose a different one.'} =
        'Tayari kuna mradi wenye hili jina. Tafadhali, chagua jengine.';
    $Self->{Translation}->{'Edit Time Accounting Settings'} = 'Hariri mipangilio ya Uhasubu wa Muda';
    $Self->{Translation}->{'Add task'} = 'Ongeza kazi';
    $Self->{Translation}->{'New user'} = 'Mtumiaji mpya';
    $Self->{Translation}->{'Filter for Projects'} = 'Kichujio cha Miradi';
    $Self->{Translation}->{'Filter for Tasks'} = 'Kichujio cha kazi';
    $Self->{Translation}->{'Filter for Users'} = 'Kichujio cha Watumiaji';
    $Self->{Translation}->{'Project List'} = 'Orodha ya miradi';
    $Self->{Translation}->{'Task List'} = 'Orodha ya kazi';
    $Self->{Translation}->{'Add Task'} = 'Ongeza kazi';
    $Self->{Translation}->{'Edit Task Settings'} = 'Hariri mipangilio ya kazi';
    $Self->{Translation}->{'There is already a task with this name. Please, choose a different one.'} =
        'Tayari kuna kazi yenye hili jina. Tafadhali chagua jengine.';
    $Self->{Translation}->{'User List'} = 'Orodha ya mtumiaji';
    $Self->{Translation}->{'New User Settings'} = 'Mipangilio ya mtumiaji mpya';
    $Self->{Translation}->{'Edit User Settings'} = 'Hariri mipangilio ya mtumiaji';
    $Self->{Translation}->{'Comments'} = 'Maoni';
    $Self->{Translation}->{'Show Overtime'} = 'Onyesha muda wa nyongeza';
    $Self->{Translation}->{'Allow project creation'} = 'Ruhusu utengenezaji wa mradi';
    $Self->{Translation}->{'Period Begin'} = 'Kuanza kwa kipengele';
    $Self->{Translation}->{'Period End'} = 'Kuisha kwa kipengele';
    $Self->{Translation}->{'Days of Vacation'} = 'Siku za likizo';
    $Self->{Translation}->{'Hours per Week'} = 'Masaa kwa wiki';
    $Self->{Translation}->{'Authorized Overtime'} = 'Muda wa nyongeza ulioruhusiwa';
    $Self->{Translation}->{'Start Date'} = 'Tarehe ya kuanza';
    $Self->{Translation}->{'Please insert a valid date.'} = 'Tafadhali ingiza tarehe halali';
    $Self->{Translation}->{'End Date'} = 'Tarehe ya kumaliza';
    $Self->{Translation}->{'Period end must be after period begin.'} = 'Mwisho wa kipengele lazima uwe baada ya mwanzo wa kipengele';
    $Self->{Translation}->{'Leave Days'} = 'Siku za likizo';
    $Self->{Translation}->{'Weekly Hours'} = 'Masaa ya wiki';
    $Self->{Translation}->{'Overtime'} = 'Muda wa nyongeza';
    $Self->{Translation}->{'No time periods found.'} = 'Hakuna vipengele vya muda vilivyopatikana';
    $Self->{Translation}->{'Add time period'} = 'Ongeza kipengele cha muda';

    # Template: AgentTimeAccountingView
    $Self->{Translation}->{'View Time Record'} = 'Onyesha kipengele cha muda';
    $Self->{Translation}->{'View of '} = 'Muonekano wa';
    $Self->{Translation}->{'No data found for this day.'} = 'Hakuna data zilizopatikana kwa siku hii';

    # SysConfig
    $Self->{Translation}->{'Agent interface notification module to see the number of incomplete working days for the user.'} =
        'Moduli ya taarifa kwa kiolesura cha wakala kuona idadi ya siku za kazi za mtumiaji zisizo kamili.';
    $Self->{Translation}->{'Default name for new actions.'} = 'Jina la chaguo-msingi kwa vitendo vipya.';
    $Self->{Translation}->{'Default name for new projects.'} = 'Jina la chaguo-msingi kwa miradi mipya';
    $Self->{Translation}->{'Default setting for date end.'} = 'Chaguo-msingi kwa mipangilio ya tarehe ya kumaliza';
    $Self->{Translation}->{'Default setting for date start.'} = 'Chaguo-msingi kwa mipangilio ya tarehe ya kuanza.';
    $Self->{Translation}->{'Default setting for description.'} = 'Chaguo-msingi kwa mipangilio ya maelezo';
    $Self->{Translation}->{'Default setting for leave days.'} = 'Chaguo-msingi la siku za likizo';
    $Self->{Translation}->{'Default setting for overtime.'} = 'Chaguo-msingi la muda wa nyongeza';
    $Self->{Translation}->{'Default setting for the standard weekly hours.'} = 'Chaguo-msingi la mipangilio ya siku za kawaida za wiki';
    $Self->{Translation}->{'Default status for new actions.'} = 'Hali ya chaguo-msingi kwa vitendo vipya.';
    $Self->{Translation}->{'Default status for new projects.'} = 'Hali ya chaguo-msingi kwa miradi mipya.';
    $Self->{Translation}->{'Default status for new users.'} = 'Hali ya chaguo-msingi kwa watumiaji wapya.';
    $Self->{Translation}->{'Defines the projects for which a remark is required. If the RegExp matches on the project, you have to insert a remark too. The RegExp use the smx parameter.'} =
        'Inafafanua miradi ambayo maoni yanahitajika. Kama RegExp inafanana katika mradi, unatakiwa kuweka maoni pia. RegExp inatumia parameta ya smx';
    $Self->{Translation}->{'Determines if the statistics module may generate time accounting information.'} =
        'Inahakiki kama moduli ya takwimu inaweza kutengeneza taarifa ya uhasibu wa muda.';
    $Self->{Translation}->{'Edit time accounting settings'} = 'Hariri mpangilio wa uhasibu wa muda';
    $Self->{Translation}->{'Edit time record'} = 'Hariri rekodi ya muda';
    $Self->{Translation}->{'For how many days ago you can insert working units.'} = 'Kwa siku ngapi zilizopita unaweza kuingiza vitengo vya kazi.';
    $Self->{Translation}->{'If enabled, only users that has added working time to the selected project are shown.'} =
        'Kama imewezeshwa, watumiaji walioweka muda wa kazi kwa mradi uliochaguliwa ndio wataonyeshwa';
    $Self->{Translation}->{'If enabled, the dropdown elements in the edit screen are changed to autocompletion fields.'} =
        'Kama imewezeshwa, elementi za kushuka chini kwenye skrini ya kuhariri zinajikamilisha moja kwa moja.';
    $Self->{Translation}->{'If enabled, the user is allowed to enter "on vacation leave", "on sick leave" and "on overtime leave" to multiple dates at once.'} =
        'Kama imewezeshwa, mtumiaji anaruhusiwa kuingiza "kwenye likizo", "kwenye likizo ya wagonjwa", "kwenye likizo ya siku za nyongeza" kwa tarehe zaidi ya moja kwa mkupuo.';
    $Self->{Translation}->{'Maximum number of working days after which the working units have to be inserted.'} =
        'Kima cha juu cha siku za kazi baada ya vitengo vya kazi kuingizwa.';
    $Self->{Translation}->{'Maximum number of working days without working units entry after which a warning will be shown.'} =
        'Kima cha juu cha siku za kazi bila ya vitengo vya kazi kuingizwa ambavyo  onyo litaonyeshwa.';
    $Self->{Translation}->{'Project time reporting'} = 'Uarifu wa muda wa mradi';
    $Self->{Translation}->{'Regular expressions for constraining action list according to selected project. Key contains regular expression for project(s), content contains regular expressions for action(s).'} =
        'Maneno ya kawaida yanayo kwamisha orodha ya vitendo kwa mradi uliochaguliwa. Ufunguo una maneno ya kawaida ya mradi (miradi), maudhui yana maneno ya kawaida ya kitendo (vitendo). ';
    $Self->{Translation}->{'Regular expressions for constraining project list according to user groups. Key contains regular expression for project(s), content contains comma separated list of groups.'} =
        'Maneno ya kawaida ya kuzuia orodha ya mradi kuendana na makundi ya watumiaji. Ufunguo una maneno ya kawaida ya mradi (miradi), maudhui yana makundi yaliyogawanywa kwa alama ya mkato.';
    $Self->{Translation}->{'Specifies if working hours can be inserted without start and end times.'} =
        'Inabainisha kama masaa ya kazi yanaweza kuingizwa bila ya muda wa kuanza na kumaliza.';
    $Self->{Translation}->{'This module forces inserts in TimeAccounting.'} = 'Hii moduli inaingiza Uhasibu wa Muda';
    $Self->{Translation}->{'This notification module gives a warning if there are too many incomplete working days.'} =
        'Hii moduli ya taarifa inatoa onyo endapo kuna siku nyingi za kazi ambazo hazijakamilika.';
    $Self->{Translation}->{'Time accounting edit.'} = 'Hariri uhasibu wa muda.';
    $Self->{Translation}->{'Time accounting overview.'} = 'Mapitio ya uhasibu wa muda.';
    $Self->{Translation}->{'Time accounting reporting.'} = 'Uarifu wa uhasibu wa muda.';
    $Self->{Translation}->{'Time accounting settings.'} = 'Mpangilio wa uhasibu wa muda.';
    $Self->{Translation}->{'Time accounting view.'} = 'Muonekano wa uhasibu wa muda ';
    $Self->{Translation}->{'Time accounting.'} = 'Uhasibu wa muda';
    $Self->{Translation}->{'To use if some actions reduced the working hours (for example, if only half of the traveling time is paid Key => traveling; Content => 50).'} =
        'Itatumika kama baadhi ya vitendo vitapunguza muda wa kazi (mfano, kama nusu ya muda wa kusafiri umelipwa Ufonguo=> kusafiri; maudhui=> 50).';

}

1;

# --
# Kernel/Modules/AgentTimeAccountingEdit.pm - time accounting edit module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AgentTimeAccountingEdit;

use strict;
use warnings;

use Date::Pcalc qw(Today Days_in_Month Day_of_Week Add_Delta_YMD check_date);
use Time::Local;

use Kernel::System::CheckItem;
use Kernel::System::TimeAccounting;

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

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

    # check needed Objects
    for my $Needed (
        qw(ParamObject DBObject ModuleReg LogObject UserObject
        ConfigObject TicketObject TimeObject GroupObject)
        )
    {
        $Self->{LayoutObject}->FatalError( Message => "Got no $Needed!" ) if !$Self->{$Needed};
    }

    # create required objects...
    $Self->{TimeAccountingObject} = Kernel::System::TimeAccounting->new(%Param);
    $Self->{CheckItemObject}      = Kernel::System::CheckItem->new(%Param);

    return $Self;
}

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

    # permission check
    return 1 if !$Self->{AccessRo};

    my ( $Sec, $Min, $Hour, $Day, $Month, $Year )
        = $Self->{TimeObject}->SystemTime2Date( SystemTime => $Self->{TimeObject}->SystemTime() );

    my %User = $Self->{TimeAccountingObject}->UserCurrentPeriodGet(
        Year  => $Year,
        Month => $Month,
        Day   => $Day,
    );

    return if !$User{ $Self->{UserID} };

    my %IncompleteWorkingDays = $Self->{TimeAccountingObject}->WorkingUnitsCompletnessCheck(
        UserID => $Self->{UserID},
    );

    # redirect if incomplete working day are out of range
    if (
        $IncompleteWorkingDays{EnforceInsert}
        && $Self->{Action} ne 'AgentTimeAccountingEdit'
        && $Self->{Action} ne 'AgentCalendarSmall'
        )
    {

        return $Self->{LayoutObject}->Redirect( OP => 'Action=AgentTimeAccountingEdit' );
    }

    return;
}

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

    my @MonthArray = (
        '',     'January', 'February', 'March',     'April',   'May',
        'June', 'July',    'August',   'September', 'October', 'November',
        'December',
    );
    my @WeekdayArray = ( 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun', );

    # ---------------------------------------------------------- #
    # show confirmation dialog to delete the entry of this day
    # ---------------------------------------------------------- #
    if ( $Self->{ParamObject}->GetParam( Param => 'DeleteDialog' ) ) {

        my ( $Sec, $Min, $Hour, $Day, $Month, $Year ) = $Self->{TimeObject}->SystemTime2Date(
            SystemTime => $Self->{TimeObject}->SystemTime(),
        );

        # get params
        for my $Parameter (qw(Status Year Month Day)) {
            $Param{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter );
        }

        # Check Date
        if ( !$Param{Year} || !$Param{Month} || !$Param{Day} ) {
            $Param{Year}  = $Year;
            $Param{Month} = $Month;
            $Param{Day}   = $Day;
        }
        else {
            $Param{Year}  = sprintf( "%02d", $Param{Year} );
            $Param{Month} = sprintf( "%02d", $Param{Month} );
            $Param{Day}   = sprintf( "%02d", $Param{Day} );
        }

        my $Output = $Self->{LayoutObject}->Output(
            Data         => {%Param},
            TemplateFile => 'AgentTimeAccountingDelete',
        );

        # build the returned data structure
        my %Data = (
            HTML       => $Output,
            DialogType => 'Confirmation',
        );

        # return JSON-String because of AJAX-Mode
        my $OutputJSON = $Self->{LayoutObject}->JSONEncode( Data => \%Data );

        return $Self->{LayoutObject}->Attachment(
            ContentType => 'application/json; charset=' . $Self->{LayoutObject}->{Charset},
            Content     => $OutputJSON,
            Type        => 'inline',
            NoCache     => 1,
        );
    }

    # ---------------------------------------------------------- #
    # delete object from database
    # ---------------------------------------------------------- #
    if ( $Self->{Subaction} eq 'Delete' ) {
        for my $Parameter (qw(Day Month Year)) {
            $Param{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter );
        }

        return $Self->{LayoutObject}->NoPermission( WithHeader => 'yes' ) if !$Self->{AccessRo};

        if (
            !$Self->{TimeAccountingObject}->WorkingUnitsDelete(
                Year   => $Param{Year},
                Month  => $Param{Month},
                Day    => $Param{Day},
                UserID => $Self->{UserID},
            )
            )
        {

            return $Self->{LayoutObject}->ErrorScreen();
        }

        return $Self->{LayoutObject}->Redirect(
            OP =>
                "Action=$Self->{Action};Year=$Param{Year};Month=$Param{Month};Day=$Param{Day}"
        );
    }

    #---------------------------------------------------------- #
    # mass entry
    # ---------------------------------------------------------- #
    elsif ( $Self->{Subaction} eq 'MassEntry' ) {

        # permission check
        return $Self->{LayoutObject}->NoPermission( WithHeader => 'yes' ) if !$Self->{AccessRo};

        # get params
        for my $Parameter (qw(Dates LeaveDay Sick Overtime)) {
            $Param{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter ) || '';
        }

        # split up dates
        my @Dates = split /[|]/, $Param{Dates};
        my $InsertError = 0;

        # save entries in the db
        for my $Date (@Dates) {

            my ( $Year, $Month, $Day ) = split /[-]/, $Date;

            if (
                !$Self->{TimeAccountingObject}->WorkingUnitsInsert(
                    Year     => $Year,
                    Month    => $Month,
                    Day      => $Day,
                    LeaveDay => $Param{LeaveDay} || 0,
                    Sick     => $Param{Sick} || 0,
                    Overtime => $Param{Overtime} || 0,
                    UserID   => $Self->{UserID},
                )
                )
            {
                $InsertError = 1;
            }

        }

        # redirect to edit screen with log message
        return $Self->{LayoutObject}->Redirect(
            OP => 'Action=AgentTimeAccountingEdit;Notification='
                . ( $InsertError ? 'Error' : 'Successful' )
        );

    }

    # ---------------------------------------------------------- #
    # edit the time accounting elements
    # ---------------------------------------------------------- #

    # permission check
    return $Self->{LayoutObject}->NoPermission( WithHeader => 'yes' ) if !$Self->{AccessRo};

    my %Frontend   = ();
    my %Data       = ();
    my %ActionList = $Self->_ActionList();
    my ( $Sec, $Min, $Hour, $Day, $Month, $Year ) = $Self->{TimeObject}->SystemTime2Date(
        SystemTime => $Self->{TimeObject}->SystemTime(),
    );

    # get params
    for my $Parameter (qw(Status Year Month Day Notification)) {
        $Param{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter ) || '';
    }
    $Param{RecordsNumber} = $Self->{ParamObject}->GetParam( Param => 'RecordsNumber' ) || 8;
    $Param{InsertWorkingUnits} = $Self->{ParamObject}->GetParam( Param => 'InsertWorkingUnits' );

    # Check Date
    if ( !$Param{Year} || !$Param{Month} || !$Param{Day} ) {
        $Param{Year}  = $Year;
        $Param{Month} = $Month;
        $Param{Day}   = $Day;
    }
    else {
        $Param{Year}  = sprintf( "%02d", $Param{Year} );
        $Param{Month} = sprintf( "%02d", $Param{Month} );
        $Param{Day}   = sprintf( "%02d", $Param{Day} );
    }

    # check if the given date is a valid date
    # if not valid, set the date to today
    if ( !check_date( $Param{Year}, $Param{Month}, $Param{Day} ) ) {
        $Param{Year}        = $Year;
        $Param{Month}       = $Month;
        $Param{Day}         = $Day;
        $Param{'WrongDate'} = 1;
    }

    my %User = $Self->{TimeAccountingObject}->UserCurrentPeriodGet(
        Year  => $Param{Year},
        Month => $Param{Month},
        Day   => $Param{Day},
    );

    # for initial use, the first agent with rw-right will be redirected
    # to 'Setting', so he can do the initial settings
    if ( !$User{ $Self->{UserID} } ) {

        return $Self->_FirstUserRedirect();
    }

    my %IncompleteWorkingDays = $Self->{TimeAccountingObject}->WorkingUnitsCompletnessCheck(
        UserID => $Self->{UserID},
    );
    my $MaxAllowedInsertDays = $Self->{ConfigObject}->Get('TimeAccounting::MaxAllowedInsertDays') || '10';
    ( $Param{YearAllowed}, $Param{MonthAllowed}, $Param{DayAllowed} )
        = Add_Delta_YMD( $Year, $Month, $Day, 0, 0, -$MaxAllowedInsertDays );
    if (
        timelocal( 1, 0, 0, $Param{Day}, $Param{Month} - 1, $Param{Year} - 1900 ) < timelocal(
            1, 0, 0, $Param{DayAllowed},
            $Param{MonthAllowed} - 1,
            $Param{YearAllowed} - 1900
        )
        )
    {
        if (
            !$IncompleteWorkingDays{Incomplete}{ $Param{Year} }{ $Param{Month} }
            { $Param{Day} }
            )
        {

            return $Self->{LayoutObject}->Redirect(
                OP =>
                    "Action=AgentTimeAccountingView;Year=$Param{Year};Month=$Param{Month};Day=$Param{Day}"
            );
        }
    }

    # store last screen
    $Self->{SessionObject}->UpdateSessionID(
        SessionID => $Self->{SessionID},
        Key       => 'LastScreen',
        Value =>
            "Action=$Self->{Action};Year=$Param{Year};Month=$Param{Month};Day=$Param{Day}",
    );

    $Param{Month_to_Text} = $MonthArray[ $Param{Month} ];

    ( $Param{YearBack}, $Param{MonthBack}, $Param{DayBack} )
        = Add_Delta_YMD( $Param{Year}, $Param{Month}, $Param{Day}, 0, 0, -1 );
    ( $Param{YearNext}, $Param{MonthNext}, $Param{DayNext} )
        = Add_Delta_YMD( $Param{Year}, $Param{Month}, $Param{Day}, 0, 0, 1 );

    my $ReduceTimeRef = $Self->{ConfigObject}->Get('TimeAccounting::ReduceTime');

    # hashes to store server side errors
    my %Errors          = ();
    my %ServerErrorData = ();
    my $ErrorIndex      = 1;

    # Edit Working Units
    if ( $Param{Status} ) {

        # arrays to save all start and end times for some checks
        my ( @StartTimes, @EndTimes );

        # delete previous entries for this day and user
        $Self->{TimeAccountingObject}->WorkingUnitsDelete(
            Year   => $Param{Year},
            Month  => $Param{Month},
            Day    => $Param{Day},
            UserID => $Self->{UserID},
        );

        my %CheckboxCheck = ();
        for my $Element (qw(LeaveDay Sick Overtime)) {
            my $Value = $Self->{ParamObject}->GetParam( Param => $Element );
            if ($Value) {
                $CheckboxCheck{$Element} = 1;
                $Param{$Element}         = 'checked="checked"';
            }
            else {
                $Param{$Element} = ''
            }
        }

        # if more than one check box was checked it is a server error
        if ( scalar keys %CheckboxCheck > 1 ) {
            for my $Checkbox ( sort keys %CheckboxCheck ) {
                $Errors{ $Checkbox . 'Invalid' } = 'ServerError';
            }
        }
        else {

            # insert values (if any)
            if ( scalar keys %CheckboxCheck > 0 ) {
                if (
                    !$Self->{TimeAccountingObject}->WorkingUnitsInsert(
                        Year     => $Param{Year},
                        Month    => $Param{Month},
                        Day      => $Param{Day},
                        LeaveDay => $CheckboxCheck{LeaveDay} || 0,
                        Sick     => $CheckboxCheck{Sick} || 0,
                        Overtime => $CheckboxCheck{Overtime} || 0,
                        UserID   => $Self->{UserID},
                    )
                    )
                {
                    return $Self->{LayoutObject}->ErrorScreen(
                        Message => 'Can\'t insert Working Units!'
                    );
                }
                $Param{SuccessfulInsert} = 1;
            }
        }

        ID:
        for my $ID ( 1 .. $Param{RecordsNumber} ) {

            # arrays to save the server errors block to show the error messages
            my ( @StartTimeServerErrorBlock, @EndTimeServerErrorBlock, @PeriodServerErrorBlock ) = ();

            for my $Parameter (qw(ProjectID ActionID Remark StartTime EndTime Period)) {
                $Param{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter . '[' . $ID . ']' );
                if ( $Param{$Parameter} ) {
                    my $ParamRef = \$Param{$Parameter};

                    # delete leading and tailing spaces
                    $ParamRef = $Self->{CheckItemObject}->StringClean(
                        StringRef => $ParamRef,
                        TrimLeft  => 1,
                        TrimRight => 1,
                    );
                }
            }

            next ID if !$Param{ProjectID} && !$Param{ActionID};

            # check for missing values
            if ( $Param{ProjectID} && !$Param{ActionID} ) {
                $Errors{$ErrorIndex}{ActionIDInvalid} = 'ServerError';
            }
            if ( !$Param{ProjectID} && $Param{ActionID} ) {
                $Errors{$ErrorIndex}{ProjectIDInvalid} = 'ServerError';
            }

            # create a valid period
            my $Period = $Param{Period};
            if ( $Period =~ /^(\d+),(\d+)/ ) {
                $Period = $1 . "." . $2;
            }

            #allow format hh:mm
            elsif ( $Param{Period} =~ /^(\d+):(\d+)/ ) {
                $Period = $1 + $2 / 60;
            }

            # if start or end times are missing, delete the other entry
            if ( !$Param{StartTime} || !$Param{EndTime} ) {
                $Param{StartTime} = '';
                $Param{EndTime}   = '';
            }

            # add ':00' to the time, if it doesn't have it yet
            if ( $Param{StartTime} && $Param{StartTime} !~ /^(\d+):(\d+)$/ ) {
                $Param{StartTime} .= ':00';
            }
            if ( $Param{EndTime} && $Param{EndTime} !~ /^(\d+):(\d+)$/ ) {
                $Param{EndTime} .= ':00';
            }
            if (
                ( $Param{StartTime} =~ /^(\d+):(\d+)$/ )
                && ( $Param{EndTime} =~ /^(\d+):(\d+)$/ )
                )
            {
                $Param{StartTime} =~ /^(\d+):(\d+)$/;
                my $StartTime = $1 * 60 + $2;
                $Param{EndTime} =~ /^(\d+):(\d+)$/;
                my $EndTime = $1 * 60 + $2;
                if ( $ReduceTimeRef->{ $ActionList{ $Param{ActionID} } } ) {
                    $Period = ( $EndTime - $StartTime ) / 60
                        * $ReduceTimeRef->{ $ActionList{ $Param{ActionID} } } / 100;
                }
                else {
                    $Period = ( $EndTime - $StartTime ) / 60;
                }

                # end time must be after start time
                if ( $EndTime <= $StartTime ) {
                    $Errors{$ErrorIndex}{EndTimeInvalid} = 'ServerError';
                    push @EndTimeServerErrorBlock, 'EndTimeBeforeStartTimeServerError';
                }

                $StartTimes[$ID] = $StartTime;
                $EndTimes[$ID]   = $EndTime;
            }
            else {
                if ( $Param{StartTime} && $Param{StartTime} !~ /^(\d+):(\d+)$/ ) {
                    $Errors{$ErrorIndex}{StartTimeInvalid} = 'ServerError';
                    push @StartTimeServerErrorBlock, 'StartTimeInvalidFormatServerError';
                }
                if ( $Param{EndTime} && $Param{EndTime} !~ /^(\d+):(\d+)$/ ) {
                    $Errors{$ErrorIndex}{EndTimeInvalid} = 'ServerError';
                    push @EndTimeServerErrorBlock, 'EndTimeInvalidFormatServerError';
                }
            }

            # negative times are not allowed
            if ( $Param{StartTime} =~ /^-(\d+):(\d+)$/ ) {
                $Errors{$ErrorIndex}{StartTimeInvalid} = 'ServerError';
                push @StartTimeServerErrorBlock, 'StartTimeNegativeServerError';
            }
            if ( $Param{EndTime} =~ /^-(\d+):(\d+)$/ ) {
                $Errors{$ErrorIndex}{EndTimeInvalid} = 'ServerError';
                push @EndTimeServerErrorBlock, 'EndTimeNegativeServerError';
            }

            # repeated hours are not allowed
            POSITION:
            for ( my $Position = $ID - 1; $Position >= 1; $Position-- ) {
                next POSITION if !defined $StartTimes[$Position] || !defined $StartTimes[$ID];

                if (
                    $StartTimes[$Position] > $StartTimes[$ID]
                    && $StartTimes[$Position] < $EndTimes[$ID]
                    )
                {
                    $Errors{$ErrorIndex}{EndTimeInvalid} = 'ServerError';
                    if ( !grep {/^EndTimeRepeatedHourServerError/} @EndTimeServerErrorBlock ) {
                        push @EndTimeServerErrorBlock, 'EndTimeRepeatedHourServerError';
                    }
                }

                if (
                    $EndTimes[$Position] > $StartTimes[$ID]
                    && $EndTimes[$Position] < $EndTimes[$ID]
                    )
                {
                    if ( $EndTimes[$ID] > $EndTimes[$Position] ) {
                        $Errors{$ErrorIndex}{StartTimeInvalid} = 'ServerError';
                        if (
                            !grep {/^StartTimeRepeatedHourServerError$/}
                            @StartTimeServerErrorBlock
                            )
                        {
                            push @StartTimeServerErrorBlock, 'StartTimeRepeatedHourServerError';
                        }
                    }
                    else {
                        $Errors{$ErrorIndex}{EndTimeInvalid} = 'ServerError';
                        if ( !grep {/^EndTimeRepeatedHourServerError$/} @EndTimeServerErrorBlock ) {
                            push @EndTimeServerErrorBlock, 'EndTimeRepeatedHourServerError';
                        }
                    }
                }

                if ( $StartTimes[$Position] == $StartTimes[$ID] ) {
                    $Errors{$ErrorIndex}{StartTimeInvalid} = 'ServerError';
                    if ( !grep {/^StartTimeRepeatedHourServerError$/} @StartTimeServerErrorBlock ) {
                        push @StartTimeServerErrorBlock, 'StartTimeRepeatedHourServerError';
                    }
                }

                if ( $EndTimes[$Position] == $EndTimes[$ID] ) {
                    $Errors{$ErrorIndex}{EndTimeInvalid} = 'ServerError';
                    if ( !grep {/^EndTimeRepeatedHourServerError$/} @EndTimeServerErrorBlock ) {
                        push @EndTimeServerErrorBlock, 'EndTimeRepeatedHourServerError';
                    }
                }

                if (
                    $StartTimes[$ID] > $StartTimes[$Position]
                    && $StartTimes[$ID] < $EndTimes[$Position]
                    )
                {
                    $Errors{$ErrorIndex}{StartTimeInvalid} = 'ServerError';
                    if ( !grep {/^StartTimeRepeatedHourServerError$/} @StartTimeServerErrorBlock ) {
                        push @StartTimeServerErrorBlock, 'StartTimeRepeatedHourServerError';
                    }
                }

                if (
                    $EndTimes[$ID] > $StartTimes[$Position]
                    && $EndTimes[$ID] < $EndTimes[$Position]
                    )
                {
                    $Errors{$ErrorIndex}{EndTimeInvalid} = 'ServerError';
                    if ( !grep {/^EndTimeRepeatedHourServerError$/} @EndTimeServerErrorBlock ) {
                        push @EndTimeServerErrorBlock, 'EndTimeRepeatedHourServerError';
                    }
                }
            }

            # '24:00' is only permitted as end time
            if ( $StartTimes[$ID] && $StartTimes[$ID] == 1440 ) {
                $Errors{$ErrorIndex}{StartTimeInvalid} = 'ServerError';
                push @StartTimeServerErrorBlock, 'StartTime24Hours';
            }

            # times superior to 24:00 are not allowed
            if ( $StartTimes[$ID] && $StartTimes[$ID] > 1440 ) {
                $Errors{$ErrorIndex}{StartTimeInvalid} = 'ServerError';
                push @StartTimeServerErrorBlock, 'StartTimeInvalid';
            }
            if ( $EndTimes[$ID] && $EndTimes[$ID] > 1440 ) {
                $Errors{$ErrorIndex}{EndTimeInvalid} = 'ServerError';
                push @EndTimeServerErrorBlock, 'EndTimeInvalid';
            }

            # add reference to the server error messages to be shown
            if ( $Errors{$ErrorIndex} && $Errors{$ErrorIndex}{StartTimeInvalid} ) {
                $Errors{$ErrorIndex}{StartTimeServerErrorBlock} = \@StartTimeServerErrorBlock;
            }
            if ( $Errors{$ErrorIndex} && $Errors{$ErrorIndex}{EndTimeInvalid} ) {
                $Errors{$ErrorIndex}{EndTimeServerErrorBlock} = \@EndTimeServerErrorBlock;
            }

            # overwrite period if there are start and end times
            if ( $StartTimes[$ID] && $EndTimes[$ID] ) {
                $Period = $EndTimes[$ID] - $StartTimes[$ID];

                # convert period from minutes to hours
                $Period /= 60;
            }

            # check for errors in the period
            if ( $Period == 0 ) {
                push @PeriodServerErrorBlock, 'ZeroHoursPeriodServerError';
                if (
                    $Self->{ConfigObject}->Get('TimeAccounting::InputHoursWithoutStartEndTime')
                    )
                {
                    $Errors{$ErrorIndex}{PeriodInvalid} = 'ServerError';
                }
                else {
                    $Errors{$ErrorIndex}{StartTimeInvalid} = 'ServerError';
                    $Errors{$ErrorIndex}{EndTimeInvalid}   = 'ServerError';
                }
            }
            else {
                if ( $Period < 0 ) {
                    $Errors{$ErrorIndex}{PeriodInvalid} = 'ServerError';
                    push @PeriodServerErrorBlock, 'NegativePeriodServerError';
                }
            }
            if ( $Period > 24 ) {
                $Errors{$ErrorIndex}{PeriodInvalid} = 'ServerError';
                push @PeriodServerErrorBlock, 'InvalidHoursPeriodServerError';
            }

            if ( $Errors{$ErrorIndex} && $Errors{$ErrorIndex}{PeriodInvalid} ) {
                $Errors{$ErrorIndex}{PeriodServerErrorBlock} = \@PeriodServerErrorBlock;
            }

            # if there was an error on this row, save all data in the server error hash
            if ( defined $Errors{$ErrorIndex} ) {
                for my $Parameter (qw(ProjectID ActionID Remark StartTime EndTime)) {
                    $ServerErrorData{$ErrorIndex}{$Parameter} = $Param{$Parameter};
                }
                $ServerErrorData{$ErrorIndex}{Period} = $Period;
            }

            # otherwise, save row on the DB
            else {

                # initialize the array of working units
                @{ $Data{WorkingUnits} } = ();

                # replace 24:00 for 23:59:59 to be a valid entry in the DB
                $Param{EndTime} = $Param{EndTime} eq '24:00' ? '23:59:59' : $Param{EndTime};

                my %WorkingUnit = (
                    ProjectID => $Param{ProjectID},
                    ActionID  => $Param{ActionID},
                    Remark    => $Param{Remark},
                    StartTime => $Param{StartTime},
                    EndTime   => $Param{EndTime},
                    Period    => $Period,
                );
                push @{ $Data{WorkingUnits} }, \%WorkingUnit;

                $Data{Year}   = $Param{Year};
                $Data{Month}  = $Param{Month};
                $Data{Day}    = $Param{Day};
                $Data{UserID} = $Self->{UserID};

                if ( !$Self->{TimeAccountingObject}->WorkingUnitsInsert(%Data) ) {

                    return $Self->{LayoutObject}->ErrorScreen(
                        Message => 'Can\'t insert Working Units!'
                    );
                }
                $Param{SuccessfulInsert} = 1;
            }

            # increment the error index if there was an error on this row
            $ErrorIndex++ if ( defined $Errors{$ErrorIndex} );
        }

        if (%ServerErrorData) {
            $Param{SuccessfulInsert} = undef;
        }
    }

    # Show Working Units
    # get existing working units
    %Data = $Self->{TimeAccountingObject}->WorkingUnitsGet(
        Year   => $Param{Year},
        Month  => $Param{Month},
        Day    => $Param{Day},
        UserID => $Self->{UserID},
    );

    # get number of working units (=records)
    #    if bigger than RecordsNumber, more than the number of default records were saved for
    #    this date
    if ( $Data{WorkingUnits} ) {
        my $WorkingUnitsCount = @{ $Data{WorkingUnits} };
        if ( $WorkingUnitsCount > $Param{RecordsNumber} ) {
            $Param{RecordsNumber} = $WorkingUnitsCount;
        }
    }

    if ( $Self->{ConfigObject}->Get('TimeAccounting::InputHoursWithoutStartEndTime') ) {
        $Param{PeriodBlock}   = 'UnitInputPeriod';
        $Frontend{PeriodNote} = '*';
    }
    else {
        $Param{PeriodBlock}   = 'UnitPeriodWithoutInput';
        $Frontend{PeriodNote} = '';
    }

    if (
        $Self->{TimeObject}->SystemTime()
        > timelocal( 1, 0, 0, $Param{Day}, $Param{Month} - 1, $Param{Year} - 1900 )
        )
    {
        $Self->{LayoutObject}->Block(
            Name => 'UnitBlock',
            Data => { %Param, %Frontend },
        );
    }

    # get sick, leave day and overtime
    $Param{Sick}     = $Data{Sick}     ? 'checked="checked"' : '';
    $Param{LeaveDay} = $Data{LeaveDay} ? 'checked="checked"' : '';
    $Param{Overtime} = $Data{Overtime} ? 'checked="checked"' : '';

    $Param{Total} = $Data{Total};

    # set action list and related constraints
    # generate a JavaScript Array which will be output to the template
    my @ActionIDs = sort { $ActionList{$a} cmp $ActionList{$b} } keys %ActionList;
    my @JSActions;
    for my $ActionID (@ActionIDs) {
        push @JSActions, "['$ActionID', '$ActionList{$ActionID}']";
    }
    $Param{JSActionList} = '[' . ( join ', ', @JSActions ) . ']';

    my $ActionListConstraints = $Self->{ConfigObject}->Get('TimeAccounting::ActionListConstraints');
    my @JSActionListConstraints;
    for my $ProjectNameRegExp ( sort keys %{$ActionListConstraints} ) {
        my $ActionNameRegExp = $ActionListConstraints->{$ProjectNameRegExp};
        s{(['"\\])}{\\$1}smxg for ( $ProjectNameRegExp, $ActionNameRegExp );
        push @JSActionListConstraints, "['$ProjectNameRegExp', '$ActionNameRegExp']";
    }
    $Param{JSActionListConstraints} = '[' . ( join ', ', @JSActionListConstraints ) . ']';

    # build a working unit array
    my @Units = (undef);
    if ( $Data{WorkingUnits} ) {
        push @Units, @{ $Data{WorkingUnits} }
    }

    $ErrorIndex = 0;

    # build units
    $Param{"JSProjectList"} = "var JSProjectList = new Array();\n";
    for my $ID ( 1 .. $Param{RecordsNumber} ) {
        $Param{ID} = $ID;
        my $UnitRef   = $Units[$ID];
        my $ShowError = 0;

        if ( !$UnitRef ) {
            $ErrorIndex++;
            $ShowError = 1;
        }

        # get data of projects
        my $ProjectList = $Self->_ProjectList(
            SelectedID => $UnitRef->{ProjectID}
                || $ServerErrorData{$ErrorIndex}{ProjectID}
                || '',
        );

        $Param{ProjectID} = $UnitRef->{ProjectID}
            || $ServerErrorData{$ErrorIndex}{ProjectID}
            || '';
        $Param{ProjectName} = '';

        # generate JavaScript array which will be output to the template
        my @JSProjectList;
        for my $Project ( @{$ProjectList} ) {
            push @JSProjectList,
                '{id:' . ( $Project->{Key} || '0' ) . ' , name:\'' . $Project->{Value} . '\'}';

            if ( $Project->{Key} eq $Param{ProjectID} ) {
                $Param{ProjectName} = $Project->{Value};
            }
        }
        $Param{"JSProjectList"}
            .= "JSProjectList[$ID] = [" . ( join ', ', @JSProjectList ) . "];\n";

        $Frontend{ProjectOption} = $Self->{LayoutObject}->BuildSelection(
            Data        => $ProjectList,
            Name        => "ProjectID[$ID]",
            ID          => "ProjectID$ID",
            Translation => 0,
            Class       => 'Validate_TimeAccounting_Project ProjectSelection '
                . ( $Errors{$ErrorIndex}{ProjectIDInvalid} || '' ),
            OnChange => "TimeAccounting.Agent.EditTimeRecords.FillActionList($ID);",
            Title    => $Self->{LayoutObject}->{LanguageObject}->Translate("Project"),
        );

        # action list initially only contains empty and selected element as well as elements
        #    configured for selected project
        #    if no constraints are configured, all actions will be displayed
        my $ActionData = $Self->_ActionListConstraints(
            ProjectID => $UnitRef->{ProjectID} || $ServerErrorData{$ErrorIndex}{ProjectID},
            ProjectList           => $ProjectList,
            ActionList            => \%ActionList,
            ActionListConstraints => $ActionListConstraints,
        );
        $ActionData->{''} = '';

        if ( $UnitRef && $UnitRef->{ActionID} && $ActionList{ $UnitRef->{ActionID} } ) {
            $ActionData->{ $UnitRef->{ActionID} } = $ActionList{ $UnitRef->{ActionID} };
        }
        elsif (
            $ServerErrorData{$ErrorIndex}
            && $ServerErrorData{$ErrorIndex}{ActionID}
            && $ActionList{ $ServerErrorData{$ErrorIndex}{ActionID} }
            )
        {
            $ActionData->{ $ServerErrorData{$ErrorIndex}{ActionID} }
                = $ActionList{ $ServerErrorData{$ErrorIndex}{ActionID} };
        }

        $Frontend{ActionOption} = $Self->{LayoutObject}->BuildSelection(

            Data        => $ActionData,
            SelectedID  => $UnitRef->{ActionID} || $ServerErrorData{$ErrorIndex}{ActionID} || '',
            Name        => "ActionID[$ID]",
            ID          => "ActionID$ID",
            Translation => 0,
            Class       => 'Validate_DependingRequiredAND Validate_Depending_ProjectID'
                . $ID
                . ' ActionSelection '
                . ( $Errors{$ErrorIndex}{ActionIDInvalid} || '' ),
            Title => $Self->{LayoutObject}->{LanguageObject}->Translate("Task"),
        );

        $Param{Remark} = $UnitRef->{Remark} || $ServerErrorData{$ErrorIndex}{Remark} || '';

        my $Period;
        if (
            ( $UnitRef->{Period} && $UnitRef->{Period} == 0 )
            || (
                defined $ServerErrorData{$ErrorIndex}{Period}
                && $ServerErrorData{$ErrorIndex}{Period} == 0
            )
            )
        {
            $Period = 0;
        }
        else {
            $Period = $UnitRef->{Period} || $ServerErrorData{$ErrorIndex}{Period} || '';
        }

        for my $TimePeriod (qw(StartTime EndTime)) {
            if ($ShowError) {
                $Param{$TimePeriod} = $ServerErrorData{$ErrorIndex}{$TimePeriod} // '';
            }
            else {
                $Param{$TimePeriod} = $UnitRef->{$TimePeriod} // '';
            }
        }

        if (
            $Period
            && $Param{StartTime} eq '00:00'
            && $Param{EndTime} eq '00:00'
            )
        {
            $Param{StartTime} = '';
            $Param{EndTime}   = '';
        }

        $Self->{LayoutObject}->Block(
            Name => 'Unit',
            Data => {
                %Param,
                %Frontend,
                %{ $Errors{$ErrorIndex} },
            },
        );

        # add proper server error message for the start and end times
        my $ServerErrorBlockName;
        if ( $Errors{$ErrorIndex} && $Errors{$ErrorIndex}{StartTimeInvalid} ) {
            if ( scalar @{ $Errors{$ErrorIndex}{StartTimeServerErrorBlock} } > 0 ) {
                while ( @{ $Errors{$ErrorIndex}{StartTimeServerErrorBlock} } ) {
                    $ServerErrorBlockName = shift @{ $Errors{$ErrorIndex}{StartTimeServerErrorBlock} };
                    $Self->{LayoutObject}->Block( Name => $ServerErrorBlockName );
                }
            }
            else {
                $Self->{LayoutObject}->Block( Name => 'StartTimeGenericServerError' );
            }
        }
        if ( $Errors{$ErrorIndex} && $Errors{$ErrorIndex}{EndTimeInvalid} ) {
            if ( scalar @{ $Errors{$ErrorIndex}{EndTimeServerErrorBlock} } > 0 ) {
                while ( @{ $Errors{$ErrorIndex}{EndTimeServerErrorBlock} } ) {
                    $ServerErrorBlockName = shift @{ $Errors{$ErrorIndex}{EndTimeServerErrorBlock} };
                    $Self->{LayoutObject}->Block( Name => $ServerErrorBlockName );
                }
            }
            else {
                $Self->{LayoutObject}->Block( Name => 'EndTimeGenericServerError' );
            }
        }

        $Self->{LayoutObject}->Block(
            Name => $Param{PeriodBlock},
            Data => {
                Period => $Period,
                ID     => $ID,
                %{ $Errors{$ErrorIndex} },
            },
        );

        # add proper server error message for the period
        if ( $Errors{$ErrorIndex} && $Errors{$ErrorIndex}{PeriodInvalid} ) {
            if ( scalar @{ $Errors{$ErrorIndex}{PeriodServerErrorBlock} } > 0 ) {
                while ( @{ $Errors{$ErrorIndex}{PeriodServerErrorBlock} } ) {
                    $ServerErrorBlockName = shift @{ $Errors{$ErrorIndex}{PeriodServerErrorBlock} };
                    $Self->{LayoutObject}->Block( Name => $ServerErrorBlockName );
                }
            }
            else {
                $Self->{LayoutObject}->Block( Name => 'PeriodGenericServerError' );
            }
        }
        else {
            $Self->{LayoutObject}->Block( Name => 'PeriodGenericServerError' );
        }

        # validity check
        if (
            $Param{InsertWorkingUnits}
            && $UnitRef->{ProjectID}
            && $UnitRef->{ActionID}
            && $Param{Sick}
            )
        {
            $Param{BlockName} = 'SickLeaveMessage';
        }
        elsif (
            $Param{InsertWorkingUnits}
            && $UnitRef->{ProjectID}
            && $UnitRef->{ActionID}
            && $Param{LeaveDay}
            )
        {
            $Param{BlockName} = 'VacationMessage';
        }
        elsif (
            $Param{InsertWorkingUnits}
            && $UnitRef->{ProjectID}
            && $UnitRef->{ActionID}
            && $Param{Overtime}
            )
        {
            $Param{BlockName} = 'OvertimeMessage';
        }
    }

    if (
        $Self->{TimeObject}->SystemTime()
        > timelocal( 1, 0, 0, $Param{Day}, $Param{Month} - 1, $Param{Year} - 1900 )
        )
    {
        $Param{Total} = sprintf( "%.2f", ( $Param{Total} || 0 ) );
        $Self->{LayoutObject}->Block(
            Name => 'Total',
            Data => { %Param, %Frontend },
        );
    }

    # validity checks start
    my $ErrorNote;
    if ( $Param{Total} && $Param{Total} > 24 ) {
        $ErrorNote = 'Can\'t save settings, because a day has only 24 hours!';
    }
    elsif ( $Param{InsertWorkingUnits} && $Param{Total} && $Param{Total} > 16 ) {
        $Param{BlockName} = 'More16HoursMessage';
    }
    if ($ErrorNote) {
        if (
            !$Self->{TimeAccountingObject}->WorkingUnitsDelete(
                Year   => $Param{Year},
                Month  => $Param{Month},
                Day    => $Param{Day},
                UserID => $Self->{UserID},
            )
            )
        {
            return $Self->{LayoutObject}->ErrorScreen(
                Message => 'Can\'t delete Working Units!'
            );
        }
    }

    if ( $Param{BlockName} && $Param{SuccessfulInsert} ) {
        $Self->{LayoutObject}->Block(
            Name => 'ShowConfirmation',
            Data => {
                BlockName => $Param{BlockName},
                Year      => $Param{Year},
                Month     => $Param{Month},
                Day       => $Param{Day},
            },
        );
    }

    $Param{Date} = $Self->{LayoutObject}->BuildDateSelection(
        %Param,
        Validate => 1,
        Prefix   => '',
        Format   => 'DateInputFormat',
    );

    if (
        timelocal( 1, 0, 0, $Param{Day}, $Param{Month} - 1, $Param{Year} - 1900 ) < timelocal(
            1, 0, 0, $Param{DayAllowed},
            $Param{MonthAllowed} - 1,
            $Param{YearAllowed} - 1900
        )
        )
    {
        if (
            $IncompleteWorkingDays{Incomplete}{ $Param{Year} }{ $Param{Month} }{ $Param{Day} }
            && !$Param{SuccessfulInsert}
            )
        {
            $Self->{LayoutObject}->Block(
                Name => 'Readonly',
                Data => {
                    Description =>
                        'This Date is out of limit, but you haven\'t insert this day yet, so you get one(!) chance to insert'
                },
            );
        }
    }

    # get incomplete working days
    my %IncompleteWorkingDaysList;
    %IncompleteWorkingDays = $Self->{TimeAccountingObject}->WorkingUnitsCompletnessCheck(
        UserID => $Self->{UserID},
    );

    for my $YearID ( sort keys %{ $IncompleteWorkingDays{Incomplete} } ) {
        for my $MonthID ( sort keys %{ $IncompleteWorkingDays{Incomplete}{$YearID} } ) {
            for my $DayID (
                sort keys %{ $IncompleteWorkingDays{Incomplete}{$YearID}{$MonthID} }
                )
            {
                $IncompleteWorkingDaysList{"$YearID-$MonthID-$DayID"} = "$YearID-$MonthID-$DayID";
                $Param{Incomplete} = 1;
            }
        }
    }

    # Show text, if incomplete working days are available
    if ( $Param{Incomplete} ) {

        # if mass entry option is enabled, show list of working days
        if ( $Self->{ConfigObject}->Get("TimeAccounting::AllowMassEntryForUser") ) {

            $Self->{LayoutObject}->Block(
                Name => 'IncompleteWorkingDaysMassEntry',
            );

            for my $WorkingDays ( sort keys %IncompleteWorkingDaysList ) {
                my ( $Year, $Month, $Day ) = split( /-/, $IncompleteWorkingDaysList{$WorkingDays} );
                $Self->{LayoutObject}->Block(
                    Name => 'IncompleteWorkingDaysMassEntrySingleDay',
                    Data => {
                        Date  => $IncompleteWorkingDaysList{$WorkingDays},
                        Year  => $Year,
                        Month => $Month,
                        Day   => $Day,
                    },
                );
            }

        }

        # otherwise show incomplete working days as a drop-down
        else {

            # check if current day is incomplete
            # if yes, select the current day in the drop-down
            # otherwise select the empty element
            my $SelectedID;

            if ( $IncompleteWorkingDaysList{"$Param{Year}-$Param{Month}-$Param{Day}"} ) {
                $SelectedID = "$Param{Year}-$Param{Month}-$Param{Day}";
            }

            my $IncompleWorkingDaysSelect = $Self->{LayoutObject}->BuildSelection(
                Data         => \%IncompleteWorkingDaysList,
                SelectedID   => $SelectedID,
                Name         => "IncompleteWorkingDaysList",
                PossibleNone => 1,
                Title =>
                    $Self->{LayoutObject}->{LanguageObject}->Translate("Incomplete Working Days"),
            );

            $Self->{LayoutObject}->Block(
                Name => 'IncompleteWorkingDays',
                Data => {
                    IncompleteWorkingDaysSelect => $IncompleWorkingDaysSelect,
                },
            );
        }
    }

    my %UserData = $Self->{TimeAccountingObject}->UserGet(
        UserID => $Self->{UserID},
    );

    my $VacationCheck = $Self->{TimeObject}->VacationCheck(
        Year     => $Param{Year},
        Month    => $Param{Month},
        Day      => $Param{Day},
        Calendar => $UserData{Calendar},
    );

    $Param{Weekday} = Day_of_Week( $Param{Year}, $Param{Month}, $Param{Day} );

    # get working days of the user's calendar
    my $CalendarName = 'TimeWorkingHours';
    $CalendarName .= $UserData{Calendar} ? "::Calendar$UserData{Calendar}" : '';
    my $CalendarWorkingHours = $Self->{ConfigObject}->Get($CalendarName);

    # show "other times" block, if necessary
    if (
        @{ $CalendarWorkingHours->{ $WeekdayArray[ $Param{Weekday} - 1 ] } }
        && !$VacationCheck
        )
    {
        $Self->{LayoutObject}->Block(
            Name => 'OtherTimes',
            Data => {
                %Param,
                %Frontend,
                %Errors,
            },
        );
    }

    $Param{Weekday_to_Text} = $WeekdayArray[ $Param{Weekday} - 1 ];

    # integrate the handling for required remarks in relation to projects
    $Param{RemarkRegExp} = $Self->_Project2RemarkRegExp();

    # enable auto-completion?
    $Param{EnableAutocompletion} = $Self->{ConfigObject}->Get("TimeAccounting::EnableAutoCompletion");

    # build output
    my $Output = $Self->{LayoutObject}->Header( Title => 'Edit' );

    if ( !$IncompleteWorkingDays{EnforceInsert} ) {
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Self->{LayoutObject}->Block(
            Name => 'OverviewProject',
            Data => { %Param, %Frontend },
        );

        # show create project link, if allowed
        my %UserData = $Self->{TimeAccountingObject}->UserGet(
            UserID => $Self->{UserID},
        );
        if ( $UserData{CreateProject} ) {
            $Self->{LayoutObject}->Block(
                Name => 'CreateProject',
            );
        }
    }
    else {
        if ( $IncompleteWorkingDays{Warning} ) {
            $Output .= $Self->{LayoutObject}->Notify(
                Info     => 'Please insert your working hours!',
                Priority => 'Error'
            );
        }
    }

    if ($ErrorNote) {
        $Output .= $Self->{LayoutObject}->Notify(
            Info     => $ErrorNote,
            Priority => 'Error'
        );
    }
    elsif ( defined $Param{SuccessfulInsert} )
    {
        $Output .= $Self->{LayoutObject}->Notify(
            Info => 'Successful insert!',
        );
    }

    # show mass entry notification
    if ( $Param{Notification} eq 'Error' ) {
        $Output .= $Self->{LayoutObject}->Notify(
            Info     => 'Error while inserting multiple dates!',
            Priority => 'Error'
        );
    }
    elsif ( $Param{Notification} eq 'Successful' ) {
        $Output .= $Self->{LayoutObject}->Notify(
            Info => 'Successfully inserted entries for several dates!',
        );
    }

    # show notification if wrong date was selected
    if ( $Param{WrongDate} ) {
        $Output .= $Self->{LayoutObject}->Notify(
            Info     => 'Entered date was invalid! Date was changed to today.',
            Priority => 'Error'
        );
    }

    $Output .= $Self->{LayoutObject}->Output(
        TemplateFile => 'AgentTimeAccountingEdit',
        Data         => {
            %Param,
            %Frontend,
        },
    );
    $Output .= $Self->{LayoutObject}->Footer();
    return $Output;

}

sub _FirstUserRedirect {
    my $Self = shift;

    # for initial using, the first agent with rw-right will be redirected
    # to 'Setting'. Then he can do the initial settings

    my %GroupList = $Self->{GroupObject}->GroupMemberList(
        UserID => $Self->{UserID},
        Type   => 'rw',
        Result => 'HASH',
    );
    for my $GroupKey ( sort keys %GroupList ) {
        if ( $GroupList{$GroupKey} eq 'time_accounting' ) {

            return $Self->{LayoutObject}->Redirect(
                OP => "Action=AgentTimeAccountingSetting"
            );
        }
    }

    return $Self->{LayoutObject}->ErrorScreen(
        Message => "No time period configured, or the specified date is outside of the defined "
            . "time periods. Please contact the time accounting admin to update your time periods!"
    );
}

sub _ActionList {
    my $Self = shift;

    my %ActionList;
    my %Action = $Self->{TimeAccountingObject}->ActionSettingsGet();

    # get action settings
    ACTIONID:
    for my $ActionID ( sort keys %Action ) {
        next ACTIONID if !$Action{$ActionID}{ActionStatus};
        next ACTIONID if !$Action{$ActionID}{Action};
        $ActionList{$ActionID} = $Action{$ActionID}{Action};
    }
    $ActionList{''} = '';

    return %ActionList;
}

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

    my %List;
    if ( $Param{ProjectID} && keys %{ $Param{ActionListConstraints} } ) {
        my $ProjectName;

        PROJECT:
        for my $Project ( @{ $Param{ProjectList} } ) {
            if ( $Project->{Key} eq $Param{ProjectID} ) {
                $ProjectName = $Project->{Value};
                last PROJECT;
            }
        }

        if ( defined($ProjectName) ) {

            # loop over actions to find matches for configured project
            # and action regexp pairs
            for my $ActionID ( sort keys %{ $Param{ActionList} } ) {

                my $ActionName = $Param{ActionList}->{$ActionID};

                REGEXP:
                for my $ProjectNameRegExp ( sort keys %{ $Param{ActionListConstraints} } ) {
                    my $ActionNameRegExp = $Param{ActionListConstraints}->{$ProjectNameRegExp};
                    if (
                        $ProjectName =~ m{$ProjectNameRegExp}smx
                        && $ActionName =~ m{$ActionNameRegExp}smx
                        )
                    {
                        $List{$ActionID} = $ActionName;
                        last REGEXP;
                    }
                }
            }
        }
    }

    # all available actions will be added if no action was added above (possible misconfiguration)
    if ( !keys %List ) {
        for my $ActionID ( sort keys %{ $Param{ActionList} } ) {
            my $ActionName = $Param{ActionList}->{$ActionID};
            $List{$ActionID} = $ActionName;
        }
    }

    return \%List;
}

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

    # at first a empty line
    my @List = (
        {
            Key   => '',
            Value => '',
        },
    );

    # get project settings
    my %Project = $Self->{TimeAccountingObject}->ProjectSettingsGet(
        Status => 'valid',
    );

    if ( !$Self->{LastProjectsRef} ) {

        # get the last projects
        my @LastProjects = $Self->{TimeAccountingObject}->LastProjectsOfUser(
            UserID => $Self->{UserID},
        );

        # add the favorites
        %{ $Self->{LastProjectsRef} } = map { $_ => 1 } @LastProjects;
    }

    PROJECTID:
    for my $ProjectID (
        sort { $Project{Project}{$a} cmp $Project{Project}{$b} }
        keys %{ $Project{Project} }
        )
    {
        next PROJECTID if !$Self->{LastProjectsRef}->{$ProjectID};
        my %Hash = (
            Key   => $ProjectID,
            Value => $Project{Project}{$ProjectID},
        );
        push @List, \%Hash;

        # at the moment it is not possible mark the selected project
        # in the favorite list (I think a bug in Build selection?!)
    }

    # add the separator
    push @List, {
        Key      => '0',
        Value    => '--------------------',
        Disabled => 1,
    };

    # add all allowed projects to the list
    PROJECTID:
    for my $ProjectID (
        sort { $Project{Project}{$a} cmp $Project{Project}{$b} }
        keys %{ $Project{Project} }
        )
    {
        next PROJECTID if !$Project{Project}{$ProjectID};
        my %Hash = (
            Key   => $ProjectID,
            Value => $Project{Project}{$ProjectID},
        );
        if ( $Param{SelectedID} && $Param{SelectedID} eq $ProjectID ) {
            $Hash{Selected} = 1;
        }

        push @List, \%Hash;
    }

    @List = $Self->_ProjectListConstraints(
        List       => \@List,
        SelectedID => $Param{SelectedID} || '',
    );

    return \@List;
}

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

    my @List;
    my $ProjectCount           = 0;
    my $ProjectListConstraints = $Self->{ConfigObject}->Get('TimeAccounting::ProjectListConstraints');

    if ( keys %{$ProjectListConstraints} ) {

        # get groups of current user
        my %Groups = $Self->{GroupObject}->GroupMemberList(
            UserID => $Self->{UserID},
            Type   => 'ro',
            Result => 'HASH',
        );
        %Groups = map { $Groups{$_} => 1 } keys %Groups;

        # get project list constraints
        my %ProjectRegex;
        for my $ProjectRegex ( sort keys %{$ProjectListConstraints} ) {
            for my $ProjectGroup ( split /,\s*/, $ProjectListConstraints->{$ProjectRegex} ) {
                if ( $Groups{$ProjectGroup} ) {
                    $ProjectRegex{$ProjectRegex} = 1;
                }
            }
        }
        my @ProjectRegex = keys %ProjectRegex;

        # reduce project list according to configuration
        if ( ref( $Param{List} ) && @ProjectRegex ) {

            my $ElementCount = 0;

            for my $Project ( @{ $Param{List} } ) {
                my $ProjectName = $Project->{Value};

                # empty first element, last projects separator and currently selected project
                if ( !$ElementCount || !$Project->{Key} || $Project->{Key} eq $Param{SelectedID} ) {
                    push @List, $Project;
                }
                else {
                    PROJECTREGEXP:
                    for my $ProjectRegex (@ProjectRegex) {
                        if ( $ProjectName =~ m{$ProjectRegex}smx ) {
                            push @List, $Project;
                            $ProjectCount++;
                            last PROJECTREGEXP;
                        }
                    }
                }
                $ElementCount++;
            }
        }
    }

# get full project list if constraints resulted in empty project list or if constraints aren't configured (possible misconfiguration)
    if ( !$ProjectCount ) {
        @List = @{ $Param{List} };
    }

    return @List;
}

# integrate the handling for required remarks in relation to projects

sub _Project2RemarkRegExp {
    my $Self = shift;

    my @Projects2Remark = ();
    my %ProjectData     = $Self->{TimeAccountingObject}->ProjectSettingsGet(
        Status => 'valid',
    );

    return '' if !$Self->{ConfigObject}->Get('TimeAccounting::Project2RemarkRegExp');

    my $Project2RemarkRegExp = $Self->{ConfigObject}->Get('TimeAccounting::Project2RemarkRegExp');

    for my $ProjectID ( sort keys %{ $ProjectData{Project} } ) {
        if ( $ProjectData{Project}{$ProjectID} =~ m{$Project2RemarkRegExp}smx ) {
            push @Projects2Remark, $ProjectID;
        }
    }

    return join '|', @Projects2Remark;
}

1;

# --
# Kernel/Modules/AgentTimeAccountingOverview.pm - time accounting overview module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AgentTimeAccountingOverview;

use strict;
use warnings;

use Date::Pcalc qw(Today Days_in_Month Day_of_Week Add_Delta_YMD check_date);
use Time::Local;

use Kernel::System::TimeAccounting;
use Kernel::System::VariableCheck qw(:all);

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

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

    # check needed Objects
    for my $Needed (
        qw(ParamObject DBObject ModuleReg LogObject UserObject
        ConfigObject TicketObject TimeObject GroupObject)
        )
    {
        $Self->{LayoutObject}->FatalError( Message => "Got no $Needed!" ) if !$Self->{$Needed};
    }

    # create required objects...
    $Self->{TimeAccountingObject} = Kernel::System::TimeAccounting->new(%Param);

    return $Self;
}

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

    my @MonthArray = (
        '',     'January', 'February', 'March',     'April',   'May',
        'June', 'July',    'August',   'September', 'October', 'November',
        'December',
    );
    my @WeekdayArray = ( 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun', );

    # ---------------------------------------------------------- #
    # overview about the users time accounting
    # ---------------------------------------------------------- #
    my ( $Sec, $Min, $Hour, $CurrentDay, $Month, $Year ) = $Self->{TimeObject}->SystemTime2Date(
        SystemTime => $Self->{TimeObject}->SystemTime(),
    );

    # permission check
    return $Self->{LayoutObject}->NoPermission( WithHeader => 'yes' ) if !$Self->{AccessRo};

    for my $Parameter (qw(Status Day Month Year UserID ProjectStatusShow)) {
        $Param{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter );
    }
    $Param{Action} = 'AgentTimeAccountingEdit';

    if ( !$Param{UserID} ) {
        $Param{UserID} = $Self->{UserID};
    }
    else {
        if ( $Param{UserID} != $Self->{UserID} && !$Self->{AccessRw} ) {

            return $Self->{LayoutObject}->NoPermission( WithHeader => 'yes' );
        }
        $Param{Action} = 'AgentTimeAccountingView';
    }
    if ( $Param{UserID} != $Self->{UserID} ) {
        my %ShownUsers = $Self->{UserObject}->UserList(
            Type  => 'Long',
            Valid => 1
        );
        $Param{User} = $ShownUsers{ $Param{UserID} };
        $Self->{LayoutObject}->Block(
            Name => 'User',
            Data => {%Param},
        );
    }

    # Check Date
    if ( !$Param{Year} || !$Param{Month} ) {
        $Param{Year}  = $Year;
        $Param{Month} = $Month;
    }
    else {
        $Param{Month} = sprintf( "%02d", $Param{Month} );
    }

    # store last screen
    $Self->{SessionObject}->UpdateSessionID(
        SessionID => $Self->{SessionID},
        Key       => 'LastScreen',
        Value =>
            "Action=$Self->{Action};Year=$Param{Year};Month=$Param{Month}",
    );

    $Param{Month_to_Text} = $MonthArray[ $Param{Month} ];

    ( $Param{YearBack}, $Param{MonthBack}, $Param{DayBack} )
        = Add_Delta_YMD( $Param{Year}, $Param{Month}, 1, 0, -1, 0 );
    ( $Param{YearNext}, $Param{MonthNext}, $Param{DayNext} ) = Add_Delta_YMD( $Param{Year}, $Param{Month}, 1, 0, 1, 0 );

    # Overview per day
    my $DaysOfMonth = Days_in_Month( $Param{Year}, $Param{Month} );

    my %UserData = $Self->{TimeAccountingObject}->UserGet(
        UserID => $Param{UserID},
    );

    for my $Day ( 1 .. $DaysOfMonth ) {
        $Param{Day} = sprintf( "%02d", $Day );
        $Param{Weekday} = Day_of_Week( $Param{Year}, $Param{Month}, $Day ) - 1;
        my $VacationCheck = $Self->{TimeObject}->VacationCheck(
            Year     => $Param{Year},
            Month    => $Param{Month},
            Day      => $Day,
            Calendar => $UserData{Calendar},
        );

        my $Date = sprintf( "%04d-%02d-%02d", $Param{Year}, $Param{Month}, $Day );
        my $DayStartTime = $Self->{TimeObject}->TimeStamp2SystemTime( String => $Date . ' 00:00:00' );
        my $DayStopTime  = $Self->{TimeObject}->TimeStamp2SystemTime( String => $Date . ' 23:59:59' );

        # add time zone to calculation
        my $UserCalendar = $UserData{Calendar} || '';
        my $Zone = $Self->{ConfigObject}->Get( "TimeZone::Calendar" . $UserCalendar );
        if ($Zone) {
            my $ZoneSeconds = $Zone * 60 * 60;
            $DayStartTime = $DayStartTime - $ZoneSeconds;
            $DayStopTime  = $DayStopTime - $ZoneSeconds;
        }

        my $ThisDayWorkingTime = $Self->{TimeObject}->WorkingTime(
            StartTime => $DayStartTime,
            StopTime  => $DayStopTime,
            Calendar  => $UserCalendar,
        ) || '0';

        if ( $Param{Year} eq $Year && $Param{Month} eq $Month && $CurrentDay eq $Day ) {
            $Param{Class} = 'Active';
        }
        elsif ($VacationCheck) {
            $Param{Class}   = 'Vacation';
            $Param{Comment} = $VacationCheck;
        }
        elsif ($ThisDayWorkingTime) {
            $Param{Class} = 'WorkingDay';
        }
        else {
            $Param{Class} = 'NonWorkingDay';
        }

        my %Data = $Self->{TimeAccountingObject}->WorkingUnitsGet(
            Year   => $Param{Year},
            Month  => $Param{Month},
            Day    => $Param{Day},
            UserID => $Param{UserID},
        );

        $Param{Comment} = $Data{Sick}
            ? 'Sick leave'
            : $Data{LeaveDay} ? 'On vacation'
            : $Data{Overtime} ? 'On overtime leave'
            :                   '';

        $Param{WorkingHours} = $Data{Total} ? sprintf( "%.2f", $Data{Total} ) : '';

        $Param{Weekday_to_Text} = $WeekdayArray[ $Param{Weekday} ];
        $Self->{LayoutObject}->Block(
            Name => 'Row',
            Data => {%Param},
        );
        $Param{Comment} = '';
    }

    my %UserReport = $Self->{TimeAccountingObject}->UserReporting(
        Year  => $Param{Year},
        Month => $Param{Month},
    );
    for my $ReportElement (
        qw(TargetState TargetStateTotal WorkingHoursTotal WorkingHours
        Overtime OvertimeTotal OvertimeUntil LeaveDay LeaveDayTotal
        LeaveDayRemaining Sick SickTotal SickRemaining)
        )
    {
        $UserReport{ $Param{UserID} }{$ReportElement} ||= 0;
        $Param{$ReportElement} = sprintf( "%.2f", $UserReport{ $Param{UserID} }{$ReportElement} );
    }

    if ( $UserData{ShowOvertime} ) {
        $Self->{LayoutObject}->Block(
            Name => 'Overtime',
            Data => \%Param,
        );
    }

    # Overview per project and action
    my %ProjectData = $Self->{TimeAccountingObject}->ProjectActionReporting(
        Year   => $Param{Year},
        Month  => $Param{Month},
        UserID => $Param{UserID},
    );

    if ( IsHashRefWithData( \%ProjectData ) ) {

        # show the report sort by projects
        if ( !$Param{ProjectStatusShow} || $Param{ProjectStatusShow} eq 'valid' ) {
            $Param{ProjectStatusShow} = 'all';
        }
        elsif ( $Param{ProjectStatusShow} eq 'all' ) {
            $Param{ProjectStatusShow} = 'valid';
        }

        $Param{ShowProjects} = 'Show ' . $Param{ProjectStatusShow} . ' projects';

        $Self->{LayoutObject}->Block(
            Name => 'ProjectTable',
            Data => {%Param},
        );

        PROJECTID:
        for my $ProjectID (
            sort { $ProjectData{$a}{Name} cmp $ProjectData{$b}{Name} }
            keys %ProjectData
            )
        {
            my $ProjectRef = $ProjectData{$ProjectID};
            my $ActionsRef = $ProjectRef->{Actions};

            $Param{Project} = '';
            $Param{Status} = $ProjectRef->{Status} ? '' : 'passiv';

            my $Total      = 0;
            my $TotalTotal = 0;

            next PROJECTID if $Param{ProjectStatusShow} eq 'all' && $Param{Status};

            if ($ActionsRef) {
                for my $ActionID (
                    sort { $ActionsRef->{$a}{Name} cmp $ActionsRef->{$b}{Name} }
                    keys %{$ActionsRef}
                    )
                {
                    my $ActionRef = $ActionsRef->{$ActionID};

                    $Param{Action}     = $ActionRef->{Name};
                    $Param{Hours}      = sprintf( "%.2f", $ActionRef->{PerMonth} || 0 );
                    $Param{HoursTotal} = sprintf( "%.2f", $ActionRef->{Total} || 0 );
                    $Total      += $Param{Hours};
                    $TotalTotal += $Param{HoursTotal};
                    $Self->{LayoutObject}->Block(
                        Name => 'Action',
                        Data => {%Param},
                    );
                    if ( !$Param{Project} ) {
                        $Param{Project} = $ProjectRef->{Name};
                        my $ProjectDescription = $Self->{LayoutObject}->Ascii2Html(
                            Text           => $ProjectRef->{Description},
                            HTMLResultMode => 1,
                            NewLine        => 50,
                        );

                        $Self->{LayoutObject}->Block(
                            Name => 'Project',
                            Data => {
                                RowSpan => ( 1 + scalar keys %{$ActionsRef} ),
                                Status  => $Param{Status},
                            },
                        );

                        if ($ProjectDescription) {
                            $Self->{LayoutObject}->Block(
                                Name => 'ProjectDescription',
                                Data => {
                                    ProjectDescription => $ProjectDescription,
                                },
                            );
                        }

                        if ( $UserData{CreateProject} ) {

                            # persons who are allowed to see the create object link are
                            # allowed to see the project reporting
                            $Self->{LayoutObject}->Block(
                                Name => 'ProjectLink',
                                Data => {
                                    Project   => $ProjectRef->{Name},
                                    ProjectID => $ProjectID,
                                },
                            );
                        }
                        else {
                            $Self->{LayoutObject}->Block(
                                Name => 'ProjectNoLink',
                                Data => { Project => $ProjectRef->{Name} },
                            );
                        }
                    }
                }

                # Now show row with total result of all actions of this project
                $Param{Hours}      = sprintf( "%.2f", $Total );
                $Param{HoursTotal} = sprintf( "%.2f", $TotalTotal );
                $Param{TotalHours}      += $Total;
                $Param{TotalHoursTotal} += $TotalTotal;
                $Self->{LayoutObject}->Block(
                    Name => 'ActionTotal',
                    Data => {%Param},
                );
            }
        }
        if ( defined( $Param{TotalHours} ) ) {
            $Param{TotalHours} = sprintf( "%.2f", $Param{TotalHours} );
        }
        if ( defined( $Param{TotalHoursTotal} ) ) {
            $Param{TotalHoursTotal} = sprintf( "%.2f", $Param{TotalHoursTotal} );
        }
        $Self->{LayoutObject}->Block(
            Name => 'GrandTotal',
            Data => {%Param},
        );
    }

    # build output
    my $Output = $Self->{LayoutObject}->Header( Title => 'Overview' );
    $Output .= $Self->{LayoutObject}->NavigationBar();
    $Output .= $Self->{LayoutObject}->Output(
        Data         => \%Param,
        TemplateFile => 'AgentTimeAccountingOverview'
    );
    $Output .= $Self->{LayoutObject}->Footer();

    return $Output;
}

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

    my %Errors = ();
    my %GetParam;

    for ( my $Period = 1; $Period <= $Param{Period}; $Period++ ) {

        # check for needed data
        for my $Parameter (qw(DateStart DateEnd LeaveDays)) {
            $GetParam{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter . "[$Period]" );
            if ( !$GetParam{$Parameter} ) {
                $Errors{ $Parameter . '-' . $Period . 'Invalid' }   = 'ServerError';
                $Errors{ $Parameter . '-' . $Period . 'ErrorType' } = 'MissingValue';
            }
        }
        my ( $Year, $Month, $Day ) = split( '-', $GetParam{DateStart} );
        my $StartDate = $Self->{TimeObject}->Date2SystemTime(
            Year   => $Year,
            Month  => $Month,
            Day    => $Day,
            Hour   => 0,
            Minute => 0,
            Second => 0,
        );
        ( $Year, $Month, $Day ) = split( '-', $GetParam{DateEnd} );
        my $EndDate = $Self->{TimeObject}->Date2SystemTime(
            Year   => $Year,
            Month  => $Month,
            Day    => $Day,
            Hour   => 0,
            Minute => 0,
            Second => 0,
        );
        if ( !$StartDate ) {
            $Errors{ 'DateStart-' . $Period . 'Invalid' }   = 'ServerError';
            $Errors{ 'DateStart-' . $Period . 'ErrorType' } = 'Invalid';
        }
        if ( !$EndDate ) {
            $Errors{ 'DateEnd-' . $Period . 'Invalid' }   = 'ServerError';
            $Errors{ 'DateEnd-' . $Period . 'ErrorType' } = 'Invalid';
        }
        if ( $StartDate && $EndDate && $StartDate >= $EndDate ) {
            $Errors{ 'DateEnd-' . $Period . 'Invalid' }   = 'ServerError';
            $Errors{ 'DateEnd-' . $Period . 'ErrorType' } = 'BeforeDateStart';
        }
    }

    return %Errors;
}

1;

# --
# Kernel/Modules/AgentTimeAccountingReporting.pm - time accounting reporting module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AgentTimeAccountingReporting;

use strict;
use warnings;

use Date::Pcalc qw(Today Days_in_Month Day_of_Week Add_Delta_YMD check_date);
use Time::Local;

use Kernel::System::TimeAccounting;
use Kernel::System::VariableCheck qw(:all);

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

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

    # check needed Objects
    for my $Needed (
        qw(ParamObject DBObject ModuleReg LogObject UserObject
        ConfigObject TicketObject TimeObject GroupObject)
        )
    {
        $Self->{LayoutObject}->FatalError( Message => "Got no $Needed!" ) if !$Self->{$Needed};
    }

    # create required objects...
    $Self->{TimeAccountingObject} = Kernel::System::TimeAccounting->new(%Param);

    return $Self;
}

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

    my @MonthArray = (
        '',     'January', 'February', 'March',     'April',   'May',
        'June', 'July',    'August',   'September', 'October', 'November',
        'December',
    );
    my @WeekdayArray = ( 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun', );

    # ---------------------------------------------------------- #
    # time accounting project reporting
    # ---------------------------------------------------------- #
    if ( $Self->{Subaction} eq 'ReportingProject' ) {

        my $Config = $Self->{ConfigObject}->Get("TimeAccounting::Frontend::$Self->{Subaction}");

        my %Frontend = ();

        # permission check
        return $Self->{LayoutObject}->NoPermission( WithHeader => 'yes' ) if !$Self->{AccessRo};

        # get params
        $Param{ProjectID} = $Self->{ParamObject}->GetParam( Param => 'ProjectID' );

        # check needed params
        if ( !$Param{ProjectID} ) {

            return $Self->{LayoutObject}->ErrorScreen(
                Message => 'ReportingProject: Need ProjectID'
            );
        }

        my %Action  = $Self->{TimeAccountingObject}->ActionSettingsGet();
        my %Project = $Self->{TimeAccountingObject}->ProjectSettingsGet();
        $Param{Project} = $Project{Project}->{ $Param{ProjectID} };

        # get system users
        my %ShownUsers = $Self->{UserObject}->UserList(
            Type  => 'Long',
            Valid => 0
        );

        $Param{ShowOnlyActiveUsers} = $Config->{ShowOnlyActiveUsers};

        if ( $Param{ShowOnlyActiveUsers} ) {

            # get registered users
            my %RegisteredUsers = $Self->{TimeAccountingObject}->UserList();

            # reduce shown users to only the ones that are registered in time accounting
            %ShownUsers = map { $_ => $ShownUsers{$_} } keys %RegisteredUsers;
        }

        # necessary because the ProjectActionReporting is not reworked
        my ( $Sec, $Min, $Hour, $CurrentDay, $Month, $Year ) = $Self->{TimeObject}->SystemTime2Date(
            SystemTime => $Self->{TimeObject}->SystemTime(),
        );
        my %ProjectData = ();
        my %ProjectTime = ();

        my @UserWhiteList;

        # Only one function should be enough
        for my $UserID ( sort keys %ShownUsers ) {

            # Overview per project and action
            # REMARK: This is the wrong function to get this information
            %ProjectData = $Self->{TimeAccountingObject}->ProjectActionReporting(
                Year   => $Year,
                Month  => $Month,
                UserID => $UserID,
            );
            if ( $ProjectData{ $Param{ProjectID} } ) {
                my $UserTotalHoursInProject;
                my $ActionsRef = $ProjectData{ $Param{ProjectID} }->{Actions};
                for my $ActionID ( sort keys %{$ActionsRef} ) {
                    $ProjectTime{$ActionID}->{$UserID}->{Hours} = $ActionsRef->{$ActionID}->{Total};

                    # remember the sum of all hours of all tasks
                    $UserTotalHoursInProject += $ActionsRef->{$ActionID}->{Total} || 0;
                }

                # remember only the users that has been added hours to this project
                if ( defined $UserTotalHoursInProject && $UserTotalHoursInProject > 0 ) {
                    push @UserWhiteList, $UserID;
                }
            }
        }

        if ( $Param{ShowOnlyActiveUsers} ) {

            # reduce shown users to only the ones that are active in the project (by adding hours)
            %ShownUsers = map { $_ => $ShownUsers{$_} } @UserWhiteList;
        }

        if ( !IsHashRefWithData( \%ShownUsers ) ) {
            $Self->{LayoutObject}->Block(
                Name => 'NoUserDataFoundMsg',
                Data => {},
            );
        }
        else {
            $Self->{LayoutObject}->Block(
                Name => 'UserTable',
                Data => {},
            );

            # show the header line
            for my $UserID ( sort { $ShownUsers{$a} cmp $ShownUsers{$b} } keys %ShownUsers ) {
                $Self->{LayoutObject}->Block(
                    Name => 'UserName',
                    Data => { User => $ShownUsers{$UserID} },
                );
            }

            # better solution for sort actions necessary
            my %NewAction = ();
            for my $ActionID ( sort keys %ProjectTime ) {
                $NewAction{$ActionID} = $Action{$ActionID}->{Action};
            }
            %Action = %NewAction;

            # show the results
            my %Total = ();
            for my $ActionID ( sort { $Action{$a} cmp $Action{$b} } keys %Action ) {
                my $TotalHours = 0;
                $Self->{LayoutObject}->Block(
                    Name => 'Action',
                    Data => {
                        Action => $Action{$ActionID},
                    },
                );
                for my $UserID ( sort { $ShownUsers{$a} cmp $ShownUsers{$b} } keys %ShownUsers ) {
                    $TotalHours += $ProjectTime{$ActionID}{$UserID}{Hours} || 0;
                    $Total{$UserID} += $ProjectTime{$ActionID}{$UserID}{Hours} || 0;
                    $Self->{LayoutObject}->Block(
                        Name => 'User',
                        Data => {
                            Hours =>
                                sprintf( "%.2f", $ProjectTime{$ActionID}{$UserID}{Hours} || 0 ),
                        },
                    );
                }

                # Total
                $Self->{LayoutObject}->Block(
                    Name => 'User',
                    Data => {
                        Hours => sprintf( "%.2f", $TotalHours ),
                    },
                );
            }
            $Param{TotalAll} = 0;
            for my $UserID ( sort { $ShownUsers{$a} cmp $ShownUsers{$b} } keys %ShownUsers ) {
                $Param{TotalAll} += $Total{$UserID};
                $Self->{LayoutObject}->Block(
                    Name => 'UserTotal',
                    Data => {
                        Total => sprintf( "%.2f", $Total{$UserID} ),
                    },
                );
            }

            $Self->{LayoutObject}->Block(
                Name => 'UserTotalAll',
                Data => {
                    TotalAll => sprintf( "%.2f", $Param{TotalAll} ),
                },
            );
        }
        my @ProjectHistoryArray = $Self->{TimeAccountingObject}->ProjectHistory(
            ProjectID => $Param{ProjectID},
        );

        if ( !IsArrayRefWithData( \@ProjectHistoryArray ) ) {
            $Self->{LayoutObject}->Block(
                Name => 'NoProjectDataFoundMsg',
                Data => {},
            );
        }
        else {
            $Self->{LayoutObject}->Block(
                Name => 'ProjectTable',
                Data => {
                    %Param,
                    %Frontend
                },
            );

            for my $Row (@ProjectHistoryArray) {
                $Self->{LayoutObject}->Block(
                    Name => 'Row',
                    Data => {
                        User   => $Row->{User},
                        Action => $Row->{Action},
                        Remark => $Row->{Remark} || '--',
                        Period => sprintf( "%.2f", $Row->{Period} ),
                        Date   => $Row->{Date},
                    },
                );
            }

            # show the total sum of hours at the end of the history list
            # I also can use $Param{TotalAll}
            my $ProjectTotalHours = sprintf(
                "%.2f",
                $Self->{TimeAccountingObject}->ProjectTotalHours(
                    ProjectID => $Param{ProjectID},
                    )
            );

            $Self->{LayoutObject}->Block(
                Name => 'HistoryTotal',
                Data => {
                    HistoryTotal => $ProjectTotalHours || 0,
                },
            );
        }

        # build output
        my $Output = $Self->{LayoutObject}->Header( Title => 'ReportingProject' );
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Output .= $Self->{LayoutObject}->Output(
            Data => {
                %Param,
                %Frontend,
            },
            TemplateFile => 'AgentTimeAccountingReportingProject',
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ---------------------------------------------------------- #
    # time accounting reporting
    # ---------------------------------------------------------- #
    my %Frontend   = ();
    my %ShownUsers = $Self->{UserObject}->UserList(
        Type  => 'Long',
        Valid => 0
    );
    my ( $Sec, $Min, $Hour, $CurrentDay, $Month, $Year ) = $Self->{TimeObject}->SystemTime2Date(
        SystemTime => $Self->{TimeObject}->SystemTime(),
    );

    # permission check
    return $Self->{LayoutObject}->NoPermission( WithHeader => 'yes' ) if !$Self->{AccessRw};

    for my $Parameter (qw(Status Month Year ProjectStatusShow)) {
        $Param{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter );
    }

    # Check Date
    if ( !$Param{Year} || !$Param{Month} ) {
        $Param{Year}  = $Year;
        $Param{Month} = $Month;
    }
    else {
        $Param{Month} = sprintf( "%02d", $Param{Month} );
    }

    # store last screen
    $Self->{SessionObject}->UpdateSessionID(
        SessionID => $Self->{SessionID},
        Key       => 'LastScreen',
        Value =>
            "Action=$Self->{Action};Year=$Param{Year};Month=$Param{Month}",
    );

    $Param{Month_to_Text} = $MonthArray[ $Param{Month} ];

    my %Month = ();
    for my $ID ( 1 .. 12 ) {
        $Month{ sprintf( "%02d", $ID ) } = $MonthArray[$ID];
    }

    $Frontend{MonthOption} = $Self->{LayoutObject}->BuildSelection(
        Data        => \%Month,
        SelectedID  => $Param{Month} || '',
        Name        => 'Month',
        Sort        => 'NumericKey',
        Translation => 1,
        Title       => $Self->{LayoutObject}->{LanguageObject}->Translate("Month"),
    );

    my @Year = ( $Year - 4 .. $Year + 1 );

    $Frontend{YearOption} = $Self->{LayoutObject}->BuildSelection(
        Data        => \@Year,
        SelectedID  => $Param{Year} || '',
        Name        => 'Year',
        Translation => 0,
        Title       => $Self->{LayoutObject}->{LanguageObject}->Translate("Year"),
    );

    ( $Param{YearBack}, $Param{MonthBack}, $Param{DayBack} )
        = Add_Delta_YMD( $Param{Year}, $Param{Month}, 1, 0, -1, 0 );
    ( $Param{YearNext}, $Param{MonthNext}, $Param{DayNext} ) = Add_Delta_YMD( $Param{Year}, $Param{Month}, 1, 0, 1, 0 );

    my %UserReport = $Self->{TimeAccountingObject}->UserReporting(
        Year   => $Param{Year},
        Month  => $Param{Month},
        UserID => $Param{UserID},
    );

    my %UserBasics = $Self->{TimeAccountingObject}->UserList();

    if ( !IsHashRefWithData( \%ShownUsers ) || !IsHashRefWithData( \%UserReport ) ) {
        $Self->{LayoutObject}->Block(
            Name => 'NoUserDataFoundMsg',
            Data => {},
        );
    }
    else {

        $Self->{LayoutObject}->Block(
            Name => 'UserTable',
            Data => { %Param, %Frontend },
        );

        USERID:
        for my $UserID ( sort { $ShownUsers{$a} cmp $ShownUsers{$b} } keys %ShownUsers ) {
            next USERID if !$UserReport{$UserID};

            for my $Parameter (
                qw(LeaveDay Overtime WorkingHours Sick LeaveDayRemaining OvertimeTotal)
                )
            {
                $Param{$Parameter} = sprintf( "%.2f", ( $UserReport{$UserID}{$Parameter} || 0 ) );
                $Param{ 'Total' . $Parameter } += $Param{$Parameter};
            }

            # Show Overtime if allowed
            if ( !$UserBasics{$UserID}{ShowOvertime} ) {
                $Param{Overtime}      = '';
                $Param{OvertimeTotal} = '';
            }

            $Param{User}   = $ShownUsers{$UserID};
            $Param{UserID} = $UserID;
            $Self->{LayoutObject}->Block(
                Name => 'User',
                Data => { %Param, %Frontend },
            );
        }

        for my $Parameter (
            qw(TotalLeaveDay TotalOvertime TotalWorkingHours
            TotalSick TotalLeaveDayRemaining TotalOvertimeTotal)
            )
        {
            $Param{$Parameter} = sprintf( "%.2f", ( $Param{$Parameter} ) || 0 );
        }

        $Self->{LayoutObject}->Block(
            Name => 'UserGrandTotal',
            Data => {%Param},
        );
    }

    # show the report sort by projects
    if ( !$Param{ProjectStatusShow} || $Param{ProjectStatusShow} eq 'valid' ) {
        $Param{ProjectStatusShow} = 'all';
    }
    elsif ( $Param{ProjectStatusShow} eq 'all' ) {
        $Param{ProjectStatusShow} = 'valid';
    }

    $Param{ShowProjects} = 'Show ' . $Param{ProjectStatusShow} . ' projects';

    my %ProjectData = $Self->{TimeAccountingObject}->ProjectActionReporting(
        Year  => $Param{Year},
        Month => $Param{Month},
    );

    if ( !IsHashRefWithData( \%ProjectData ) ) {
        $Self->{LayoutObject}->Block(
            Name => 'NoProjectDataFoundMsg',
            Data => {},
        );
        $Param{ProjectStatusLinkClass} = 'Hidden';
    }
    else {
        $Self->{LayoutObject}->Block(
            Name => 'ProjectTable',
            Data => { %Param, %Frontend },
        );

        # REMARK: merge this project reporting list with the list in overview
        PROJECTID:
        for my $ProjectID (
            sort { $ProjectData{$a}->{Name} cmp $ProjectData{$b}->{Name} }
            keys %ProjectData
            )
        {
            my $ProjectRef = $ProjectData{$ProjectID};
            my $ActionsRef = $ProjectRef->{Actions};

            $Param{Project} = '';
            $Param{Status} = $ProjectRef->{Status} ? '' : 'passiv';

            my $Total      = 0;
            my $TotalTotal = 0;

            next PROJECTID if $Param{ProjectStatusShow} eq 'all' && $Param{Status};

            for my $ActionID (
                sort { $ActionsRef->{$a}->{Name} cmp $ActionsRef->{$b}->{Name} }
                keys %{$ActionsRef}
                )
            {
                my $ActionRef = $ActionsRef->{$ActionID};

                $Param{ProjectID}  = $ProjectID;
                $Param{Action}     = $ActionRef->{Name};
                $Param{Hours}      = sprintf( "%.2f", $ActionRef->{PerMonth} || 0 );
                $Param{HoursTotal} = sprintf( "%.2f", $ActionRef->{Total} || 0 );
                $Total      += $Param{Hours};
                $TotalTotal += $Param{HoursTotal};
                $Self->{LayoutObject}->Block(
                    Name => 'Action',
                    Data => {%Param},
                );

                if ( !$Param{Project} ) {
                    $Param{Project} = $ProjectRef->{Name};
                    my $ProjectDescription = $Self->{LayoutObject}->Ascii2Html(
                        Text           => $ProjectRef->{Description},
                        HTMLResultMode => 1,
                        NewLine        => 50,
                    );

                    $Self->{LayoutObject}->Block(
                        Name => 'Project',
                        Data => {
                            RowSpan            => ( 1 + scalar keys %{$ActionsRef} ),
                            Status             => $Param{Status},
                            ProjectDescription => $ProjectDescription,
                            Project            => $ProjectRef->{Name},
                            ProjectID          => $ProjectID,
                            Class              => 'MasterActionLink' . $ProjectID,
                        },
                    );
                }
            }

            $Param{Hours}      = sprintf( "%.2f", $Total );
            $Param{HoursTotal} = sprintf( "%.2f", $TotalTotal );
            $Param{TotalHours}      += $Total;
            $Param{TotalHoursTotal} += $TotalTotal;
            $Self->{LayoutObject}->Block(
                Name => 'ActionTotal',
                Data => { %Param, %Frontend },
            );
        }

        $Param{TotalHours}      ||= 0;
        $Param{TotalHoursTotal} ||= 0;

        $Param{TotalHours}      = sprintf( "%.2f", $Param{TotalHours} );
        $Param{TotalHoursTotal} = sprintf( "%.2f", $Param{TotalHoursTotal} );

        $Self->{LayoutObject}->Block(
            Name => 'ProjectGrandTotal',
            Data => { %Param, %Frontend },
        );
    }

    # build output
    my $Output = $Self->{LayoutObject}->Header( Title => 'Reporting' );
    $Output .= $Self->{LayoutObject}->NavigationBar();
    $Output .= $Self->{LayoutObject}->Output(
        Data => { %Param, %Frontend },
        TemplateFile => 'AgentTimeAccountingReporting'
    );
    $Output .= $Self->{LayoutObject}->Footer();

    return $Output;
}

1;

# --
# Kernel/Modules/AgentTimeAccountingSetting.pm - time accounting setting module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AgentTimeAccountingSetting;

use strict;
use warnings;

use Time::Local;

use Kernel::System::TimeAccounting;

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

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

    # check needed Objects
    for my $Needed (
        qw(ParamObject DBObject ModuleReg LogObject UserObject
        ConfigObject TicketObject TimeObject GroupObject)
        )
    {
        $Self->{LayoutObject}->FatalError( Message => "Got no $Needed!" ) if !$Self->{$Needed};
    }

    # create required objects...
    $Self->{TimeAccountingObject} = Kernel::System::TimeAccounting->new(%Param);

    return $Self;
}

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

    # expression add time period was pressed
    if (
        $Self->{ParamObject}->GetParam( Param => 'AddPeriod' )
        || $Self->{ParamObject}->GetParam( Param => 'SubmitUserData' )
        )
    {
        my %GetParam = ();

        $GetParam{UserID} = $Self->{ParamObject}->GetParam( Param => 'UserID' );
        my $Periods = $Self->{TimeAccountingObject}->UserLastPeriodNumberGet( UserID => $GetParam{UserID} );

        # check validity of periods
        my %Errors = $Self->_CheckValidityUserPeriods( Period => $Periods );

        # if the period data is OK
        if ( !%Errors ) {

            # get all parameters
            for my $Parameter (qw(Subaction Description Calendar)) {
                $GetParam{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter );
            }
            for my $Parameter (qw(ShowOvertime CreateProject)) {
                $GetParam{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter ) || 0;
            }

            my $Period = 1;
            my %PeriodData;

            my %UserData = $Self->{TimeAccountingObject}->SingleUserSettingsGet(
                UserID => $GetParam{UserID}
            );

            # get parameters for all registered periods
            while ( $UserData{$Period} ) {
                for my $Parameter (qw(WeeklyHours Overtime DateStart DateEnd LeaveDays)) {
                    $PeriodData{$Period}{$Parameter}
                        = $Self->{ParamObject}->GetParam( Param => $Parameter . "[$Period]" )
                        || $UserData{$Period}{$Parameter};
                }
                $PeriodData{$Period}{UserStatus}
                    = $Self->{ParamObject}->GetParam( Param => "PeriodStatus[$Period]" ) || 0;
                $Period++;
            }
            $GetParam{Period} = \%PeriodData;

            # update periods
            if ( !$Self->{TimeAccountingObject}->UserSettingsUpdate(%GetParam) ) {

                return $Self->{LayoutObject}->ErrorScreen(
                    Message => 'Unable to update user settings! Please contact your administrator.'
                );
            }
            if ( $Self->{ParamObject}->GetParam( Param => 'AddPeriod' ) ) {

                # show the edit time settings again, but now with a new empty time period line
                return $Self->{LayoutObject}->Redirect(
                    OP =>
                        "Action=AgentTimeAccountingSetting;Subaction=$GetParam{Subaction};UserID=$GetParam{UserID};"
                        . "NewTimePeriod=1",
                );
            }
            else {

                # show the overview of tasks and users
                return $Self->{LayoutObject}->Redirect(
                    OP => "Action=AgentTimeAccountingSetting;User=$Self->{Subaction}",
                );
            }
        }
    }

    # ---------------------------------------------------------- #
    # add project
    # ---------------------------------------------------------- #
    if ( $Self->{Subaction} eq 'AddProject' ) {
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Self->_ProjectSettingsEdit( Action => 'AddProject' );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentTimeAccountingSetting',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();
        return $Output;
    }

    # ---------------------------------------------------------- #
    # add project action
    # ---------------------------------------------------------- #
    elsif ( $Self->{Subaction} eq 'AddProjectAction' ) {

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

        my $Note = '';
        my $ProjectID;
        my ( %GetParam, %Errors );

        # get parameters
        for my $Parameter (qw(Project ProjectDescription)) {
            $GetParam{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter ) || '';
        }
        $GetParam{ProjectStatus} = $Self->{ParamObject}->GetParam( Param => 'ProjectStatus' )
            || '0';

        # check for needed data
        if ( !$GetParam{Project} ) {
            $Errors{ProjectInvalid}   = 'ServerError';
            $Errors{ProjectErrorType} = 'ProjectMissingValue';
        }
        else {

            # check that the name is unique
            my %ExistingProject = $Self->{TimeAccountingObject}->ProjectGet( Project => $GetParam{Project} );
            if (%ExistingProject) {
                $Errors{ProjectInvalid}   = 'ServerError';
                $Errors{ProjectErrorType} = 'ProjectDuplicateName';
            }
        }

        # if no errors occurred
        if ( !%Errors ) {

            # add project
            $ProjectID = $Self->{TimeAccountingObject}->ProjectSettingsInsert(%GetParam);

            if ($ProjectID) {

                # build the output
                $Self->_SettingOverview();
                my $Output = $Self->{LayoutObject}->Header();
                $Output .= $Self->{LayoutObject}->NavigationBar();
                $Output .= $Self->{LayoutObject}->Notify( Info => 'Project added!' );
                $Output .= $Self->{LayoutObject}->Output(
                    TemplateFile => 'AgentTimeAccountingSetting',
                    Data         => {%GetParam},
                );
                $Output .= $Self->{LayoutObject}->Footer();

                return $Output;
            }
            else {
                $Note = $Self->{LogObject}->GetLogEntry(
                    Type => 'Error',
                    What => 'Message',
                );
            }
        }

        # something went wrong
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Output .= $Note
            ? $Self->{LayoutObject}->Notify(
            Priority => 'Error',
            Info     => $Note,
            )
            : '';
        $Self->_ProjectSettingsEdit(
            Action => 'AddProject',
            %GetParam,
            %Errors,
        );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentTimeAccountingSetting',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ---------------------------------------------------------- #
    # edit project
    # ---------------------------------------------------------- #
    elsif ( $Self->{Subaction} eq 'EditProject' ) {
        my $ID = $Self->{ParamObject}->GetParam( Param => 'ID' );

        # get project data
        my %Project = $Self->{TimeAccountingObject}->ProjectGet( ID => $ID );

        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Self->_ProjectSettingsEdit(
            Action => 'EditProject',
            %Project,
        );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentTimeAccountingSetting',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ---------------------------------------------------------- #
    # edit project action
    # ---------------------------------------------------------- #
    elsif ( $Self->{Subaction} eq 'EditProjectAction' ) {

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

        my $Note = '';
        my ( %GetParam, %Errors );

        # get parameters
        $GetParam{ID} = $Self->{ParamObject}->GetParam( Param => 'ID' ) || '';
        $GetParam{ProjectStatus} = $Self->{ParamObject}->GetParam( Param => 'ProjectStatus' )
            || '0';
        for my $Parameter (qw(Project ProjectDescription)) {
            $GetParam{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter ) || '';
        }

        # check for needed data
        if ( !$GetParam{Project} ) {
            $Errors{ProjectInvalid} = 'ServerError';
        }
        else {

            # check that the name is unique
            my %ExistingProject = $Self->{TimeAccountingObject}->ProjectGet( Project => $GetParam{Project} );

            # if the project name is found, check that the ID is different
            if ( %ExistingProject && $ExistingProject{ID} ne $GetParam{ID} ) {
                $Errors{ProjectInvalid}   = 'ServerError';
                $Errors{ProjectErrorType} = 'ProjectDuplicateName';
            }
        }

        # if no errors occurred
        if ( !%Errors ) {

            # edit project
            if ( $Self->{TimeAccountingObject}->ProjectSettingsUpdate(%GetParam) ) {

                $Self->_SettingOverview();
                my $Output = $Self->{LayoutObject}->Header();
                $Output .= $Self->{LayoutObject}->NavigationBar();
                $Output .= $Self->{LayoutObject}->Notify( Info => 'Project updated!' );
                $Output .= $Self->{LayoutObject}->Output(
                    TemplateFile => 'AgentTimeAccountingSetting',
                    Data         => \%Param,
                );
                $Output .= $Self->{LayoutObject}->Footer();

                return $Output;
            }
            else {
                $Note = $Self->{LogObject}->GetLogEntry(
                    Type => 'Error',
                    What => 'Message',
                );
            }
        }

        # something went wrong
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Output .= $Note
            ? $Self->{LayoutObject}->Notify(
            Priority => 'Error',
            Info     => $Note,
            )
            : '';
        $Self->_ProjectSettingsEdit(
            Action => 'EditProject',
            %GetParam,
            %Param,
            %Errors,
        );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentTimeAccountingSetting',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ---------------------------------------------------------- #
    # add task
    # ---------------------------------------------------------- #
    elsif ( $Self->{Subaction} eq 'AddTask' ) {
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Self->_TaskSettingsEdit( Action => 'AddTask' );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentTimeAccountingSetting',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ---------------------------------------------------------- #
    # add task action
    # ---------------------------------------------------------- #
    elsif ( $Self->{Subaction} eq 'AddTaskAction' ) {

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

        my $Note = '';
        my $TaskID;
        my ( %GetParam, %Errors );

        # get parameters
        $GetParam{Task} = $Self->{ParamObject}->GetParam( Param => 'Task' ) || '';
        $GetParam{TaskStatus} = $Self->{ParamObject}->GetParam( Param => 'TaskStatus' )
            || '0';

        # check for needed data
        if ( !$GetParam{Task} ) {
            $Errors{TaskInvalid}   = 'ServerError';
            $Errors{TaskErrorType} = 'TaskMissingValue';
        }
        else {

            # check that the name is unique
            my %ExistingTask = $Self->{TimeAccountingObject}->ActionGet( Action => $GetParam{Task} );
            if (%ExistingTask) {
                $Errors{TaskInvalid}   = 'ServerError';
                $Errors{TaskErrorType} = 'TaskDuplicateName';
            }
        }

        # if no errors occurred
        if ( !%Errors ) {

            # add task
            $TaskID = $Self->{TimeAccountingObject}->ActionSettingsInsert(
                Action       => $GetParam{Task},
                ActionStatus => $GetParam{TaskStatus},
            );

            if ($TaskID) {

                # build the output
                $Self->_SettingOverview();
                my $Output = $Self->{LayoutObject}->Header();
                $Output .= $Self->{LayoutObject}->NavigationBar();
                $Output .= $Self->{LayoutObject}->Notify( Info => 'Task added!' );
                $Output .= $Self->{LayoutObject}->Output(
                    TemplateFile => 'AgentTimeAccountingSetting',
                    Data         => {},
                );
                $Output .= $Self->{LayoutObject}->Footer();

                return $Output;
            }
            else {
                $Note = $Self->{LogObject}->GetLogEntry(
                    Type => 'Error',
                    What => 'Message',
                );
            }
        }

        # something went wrong
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Output .= $Note
            ? $Self->{LayoutObject}->Notify(
            Priority => 'Error',
            Info     => $Note,
            )
            : '';
        $Self->_TaskSettingsEdit(
            Action => 'AddTask',
            %GetParam,
            %Errors,
        );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentTimeAccountingSetting',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ---------------------------------------------------------- #
    # edit task
    # ---------------------------------------------------------- #
    elsif ( $Self->{Subaction} eq 'EditTask' ) {
        my $ID = $Self->{ParamObject}->GetParam( Param => 'ActionID' ) || '';

        # get project data
        my %Task = $Self->{TimeAccountingObject}->ActionGet( ID => $ID );

        my %TaskData = (
            Task       => $Task{Action},
            TaskStatus => $Task{ActionStatus},
        );

        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Self->_TaskSettingsEdit(
            Action   => 'EditTask',
            ActionID => $ID,
            %TaskData,
        );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentTimeAccountingSetting',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ---------------------------------------------------------- #
    # edit project action
    # ---------------------------------------------------------- #
    elsif ( $Self->{Subaction} eq 'EditTaskAction' ) {

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

        my $Note = '';
        my ( %GetParam, %Errors );

        # get parameters
        $GetParam{ActionID}   = $Self->{ParamObject}->GetParam( Param => 'ActionID' )   || '';
        $GetParam{TaskStatus} = $Self->{ParamObject}->GetParam( Param => 'TaskStatus' ) || '0';
        $GetParam{Task}       = $Self->{ParamObject}->GetParam( Param => 'Task' )       || '';

        # check for needed data
        if ( !$GetParam{Task} ) {
            $Errors{TaskInvalid} = 'ServerError';
        }
        else {

            # check that the name is unique
            my %ExistingTask = $Self->{TimeAccountingObject}->ActionGet( Action => $GetParam{Task} );

            # if the task name is found, check that the ID is different
            if ( %ExistingTask && $ExistingTask{ID} ne $GetParam{ActionID} ) {
                $Errors{TaskInvalid}   = 'ServerError';
                $Errors{TaskErrorType} = 'TaskDuplicateName';
            }
        }

        # if no errors occurred
        if ( !%Errors ) {

            # edit action (task)
            my $ActionUpdate = $Self->{TimeAccountingObject}->ActionSettingsUpdate(
                ActionID     => $GetParam{ActionID},
                Action       => $GetParam{Task},
                ActionStatus => $GetParam{TaskStatus},
            );

            if ($ActionUpdate) {
                $Self->_SettingOverview();
                my $Output = $Self->{LayoutObject}->Header();
                $Output .= $Self->{LayoutObject}->NavigationBar();
                $Output .= $Self->{LayoutObject}->Notify( Info => 'Task updated!' );
                $Output .= $Self->{LayoutObject}->Output(
                    TemplateFile => 'AgentTimeAccountingSetting',
                    Data         => \%Param,
                );
                $Output .= $Self->{LayoutObject}->Footer();

                return $Output;
            }
            else {
                $Note = $Self->{LogObject}->GetLogEntry(
                    Type => 'Error',
                    What => 'Message',
                );
            }
        }

        # something went wrong
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Output .= $Note
            ? $Self->{LayoutObject}->Notify(
            Priority => 'Error',
            Info     => $Note,
            )
            : '';
        $Self->_TaskSettingsEdit(
            Action => 'EditTask',
            %GetParam,
            %Param,
            %Errors,
        );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentTimeAccountingSetting',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ---------------------------------------------------------- #
    # add user
    # ---------------------------------------------------------- #
    elsif ( $Self->{Subaction} eq 'AddUser' ) {

        # get parameters
        my $NewUserID = $Self->{ParamObject}->GetParam( Param => 'NewUserID' )
            || $Self->{ParamObject}->GetParam( Param => 'UserID' )
            || '';
        if ( !$NewUserID ) {

            return $Self->{LayoutObject}->ErrorScreen(
                Message => 'The UserID is not valid!'
            );
        }

        my $NewTimePeriod = $Self->{ParamObject}->GetParam( Param => 'NewTimePeriod' );

        my $LastPeriodNumber = $Self->{TimeAccountingObject}->UserLastPeriodNumberGet(
            UserID => $NewUserID,
        );

        my $Success = $Self->{TimeAccountingObject}->UserSettingsInsert(
            UserID => $NewUserID,
            Period => $LastPeriodNumber + 1,
        );

        # if it is not an action about adding a new time period
        if ( !$NewTimePeriod ) {
            if ( !$Success ) {

                return $Self->{LayoutObject}->ErrorScreen(
                    Message => 'Can\'t insert user data!'
                );
            }

            my %Groups = $Self->{GroupObject}->GroupList( Valid => 1 );
            my %GroupData = $Self->{GroupObject}->GroupMemberList(
                UserID => $NewUserID,
                Type   => 'ro',
                Result => 'HASH',
            );
            for my $GroupKey ( sort keys %Groups ) {
                if ( $Groups{$GroupKey} eq 'time_accounting' && !$GroupData{$GroupKey} ) {

                    $Self->{GroupObject}->GroupMemberAdd(
                        GID        => $GroupKey,
                        UID        => $NewUserID,
                        Permission => {
                            ro        => 1,
                            move_into => 0,
                            create    => 0,
                            owner     => 0,
                            priority  => 0,
                            rw        => 0,
                        },
                        UserID => $Self->{UserID},
                    );
                }
            }
        }

        my %User = $Self->{UserObject}->GetUserData( UserID => $NewUserID );
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Self->_UserSettingsEdit(
            Action    => 'AddUser',
            Subaction => 'AddUser',
            %User,
        );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentTimeAccountingSetting',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ---------------------------------------------------------- #
    # edit user settings
    # ---------------------------------------------------------- #
    elsif ( $Self->{Subaction} eq 'EditUser' ) {
        my $ID = $Self->{ParamObject}->GetParam( Param => 'UserID' ) || '';
        if ( !$ID ) {

            return $Self->{LayoutObject}->ErrorScreen(
                Message => 'The UserID is not valid!'
            );
        }

        my $NewTimePeriod = $Self->{ParamObject}->GetParam( Param => 'NewTimePeriod' );
        my $LastPeriodNumber = $Self->{TimeAccountingObject}->UserLastPeriodNumberGet(
            UserID => $ID,
        );

        # if it is an action about adding a new time period, insert it
        if ($NewTimePeriod) {
            my $Success = $Self->{TimeAccountingObject}->UserSettingsInsert(
                UserID => $ID,
                Period => $LastPeriodNumber + 1,
            );
            if ( !$Success ) {

                return $Self->{LayoutObject}->ErrorScreen(
                    Message => 'Unable to add time period! Please contact your administrator.',
                );
            }
        }

        my %Errors = ();

        if (
            $Self->{ParamObject}->GetParam( Param => 'AddPeriod' )
            || $Self->{ParamObject}->GetParam( Param => 'SubmitUserData' )
            )
        {

            # check validity of periods
            %Errors = $Self->_CheckValidityUserPeriods( Period => $LastPeriodNumber );
        }

        # get user data
        my %User = $Self->{UserObject}->GetUserData( UserID => $ID );

        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();
        $Self->_UserSettingsEdit(
            Action    => 'EditUser',
            Subaction => 'EditUser',
            UserID    => $ID,
            Errors    => \%Errors,
            Periods   => $LastPeriodNumber,
            %User,
        );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentTimeAccountingSetting',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ---------------------------------------------------------- #
    # settings for handling time accounting
    # ---------------------------------------------------------- #

    # get user data
    my %UserData = $Self->{TimeAccountingObject}->UserGet(
        UserID => $Self->{UserID},
    );

    # permission check
    if ( $UserData{CreateProject} || $Self->{AccessRw} ) {

        # get the user action to show a message if an user was updated or added
        my $Note = $Self->{ParamObject}->GetParam( Param => 'User' );

        # build output
        $Self->_SettingOverview();
        my $Output = $Self->{LayoutObject}->Header( Title => 'Setting' );
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # show a notification message if proper
        if ($Note) {
            $Output .= $Note eq 'EditUser'
                ? $Self->{LayoutObject}->Notify( Info => 'User updated!' )
                : $Self->{LayoutObject}->Notify( Info => 'User added!' );
        }

        $Output .= $Self->{LayoutObject}->Output(
            Data         => \%Param,
            TemplateFile => 'AgentTimeAccountingSetting'
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # return no permission screen
    return $Self->{LayoutObject}->NoPermission( WithHeader => 'yes' );
}

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

    my %Errors = ();
    my %GetParam;

    for ( my $Period = 1; $Period <= $Param{Period}; $Period++ ) {

        # check for needed data
        for my $Parameter (qw(DateStart DateEnd LeaveDays)) {
            $GetParam{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter . "[$Period]" );
            if ( !$GetParam{$Parameter} ) {
                $Errors{ $Parameter . '-' . $Period . 'Invalid' }   = 'ServerError';
                $Errors{ $Parameter . '-' . $Period . 'ErrorType' } = 'MissingValue';
            }
        }
        my ( $Year, $Month, $Day ) = split( '-', $GetParam{DateStart} );
        my $StartDate = $Self->{TimeObject}->Date2SystemTime(
            Year   => $Year,
            Month  => $Month,
            Day    => $Day,
            Hour   => 0,
            Minute => 0,
            Second => 0,
        );
        ( $Year, $Month, $Day ) = split( '-', $GetParam{DateEnd} );
        my $EndDate = $Self->{TimeObject}->Date2SystemTime(
            Year   => $Year,
            Month  => $Month,
            Day    => $Day,
            Hour   => 0,
            Minute => 0,
            Second => 0,
        );
        if ( !$StartDate ) {
            $Errors{ 'DateStart-' . $Period . 'Invalid' }   = 'ServerError';
            $Errors{ 'DateStart-' . $Period . 'ErrorType' } = 'Invalid';
        }
        if ( !$EndDate ) {
            $Errors{ 'DateEnd-' . $Period . 'Invalid' }   = 'ServerError';
            $Errors{ 'DateEnd-' . $Period . 'ErrorType' } = 'Invalid';
        }
        if ( $StartDate && $EndDate && $StartDate >= $EndDate ) {
            $Errors{ 'DateEnd-' . $Period . 'Invalid' }   = 'ServerError';
            $Errors{ 'DateEnd-' . $Period . 'ErrorType' } = 'BeforeDateStart';
        }
    }

    return %Errors;
}

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

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

    $Self->{LayoutObject}->Block( Name => 'ActionListProject' );
    $Self->{LayoutObject}->Block( Name => 'ActionSettingOverview' );

    # define status list
    my %StatusList = (
        1 => 'valid',
        0 => 'invalid',
    );

    my $ProjectStatus = 1;
    if ( defined $Param{ProjectStatus} ) {
        $ProjectStatus = $Param{ProjectStatus}
    }

    $Param{StatusOption} = $Self->{LayoutObject}->BuildSelection(
        Data       => \%StatusList,
        SelectedID => $ProjectStatus,
        Name       => 'ProjectStatus',
    );

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

    # shows header
    if ( $Param{Action} eq 'EditProject' ) {
        $Self->{LayoutObject}->Block( Name => 'HeaderEditProject' );
    }
    else {
        $Self->{LayoutObject}->Block( Name => 'HeaderAddProject' );
    }

    # show server error message (if any) for the project name
    if ( $Param{ProjectErrorType} ) {
        $Self->{LayoutObject}->Block( Name => $Param{ProjectErrorType} );
    }

    return 1;
}

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

    my %Project = ();
    my %Data    = ();

    # build output
    $Self->{LayoutObject}->Block(
        Name => 'Setting',
    );
    $Self->{LayoutObject}->Block( Name => 'ActionListSetting' );
    $Self->{LayoutObject}->Block( Name => 'ActionAddProject' );

    # hash to save registered users
    my %User;

    if ( $Self->{AccessRw} ) {
        $Self->{LayoutObject}->Block( Name => 'ActionAddTask' );

        # get user data
        my %ShownUsers = $Self->{UserObject}->UserList(
            Type  => 'Long',
            Valid => 1,
        );

        # get list of registered users (if any)
        %User = $Self->{TimeAccountingObject}->UserList();

        USERID:
        for my $UserInfo ( sort { $ShownUsers{$a} cmp $ShownUsers{$b} } keys %ShownUsers ) {
            next USERID if !$User{$UserInfo};

            # delete already registered user from the 'new' list
            delete $ShownUsers{$UserInfo};
        }

        if (%ShownUsers) {
            my $NewUserOption = $Self->{LayoutObject}->BuildSelection(
                Data         => \%ShownUsers,
                SelectedID   => '',
                Name         => 'NewUserID',
                Translation  => 0,
                PossibleNone => 0,
                Title        => $Self->{LayoutObject}->{LanguageObject}->Translate("New User"),
            );
            $Self->{LayoutObject}->Block(
                Name => 'ActionAddUser',
                Data => {
                    NewUserOption => $NewUserOption,
                },
            );
        }
    }

    $Self->{LayoutObject}->Block( Name => 'ProjectFilter' );

    if ( $Self->{AccessRw} ) {
        $Self->{LayoutObject}->Block( Name => 'TaskFilter' );
        $Self->{LayoutObject}->Block( Name => 'UserFilter' );
    }

    # Show project data
    %Project = $Self->{TimeAccountingObject}->ProjectSettingsGet();

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

    # define status list
    my %StatusList = (
        1 => 'valid',
        0 => 'invalid',
    );

    # show list of available projects (if any)
    if ( $Project{Project} ) {

        $Self->{LayoutObject}->Block(
            Name => 'OverviewResultProjectTable',
            Data => {%Param},
        );

        for my $ProjectID (
            sort { $Project{Project}{$a} cmp $Project{Project}{$b} }
            keys %{ $Project{Project} }
            )
        {
            $Param{Project}            = $Project{Project}{$ProjectID};
            $Param{ProjectDescription} = $Project{ProjectDescription}{$ProjectID};
            $Param{ProjectID}          = $ProjectID;
            $Param{Status}             = $StatusList{ $Project{ProjectStatus}{$ProjectID} };

            $Self->{LayoutObject}->Block(
                Name => 'OverviewResultProjectRow',
                Data => {%Param},
            );
        }
    }

    # otherwise, show a no data found message
    else {
        $Self->{LayoutObject}->Block( Name => 'NoProjectDataFoundMsg' );
    }

    if ( $Self->{AccessRw} ) {

        # Show action data
        my %Action = $Self->{TimeAccountingObject}->ActionSettingsGet();

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

        # show list of available tasks/actions (if any)
        if (%Action) {

            $Self->{LayoutObject}->Block(
                Name => 'OverviewResultSettingTable',
                Data => {%Param},
            );

            for my $ActionID ( sort { $Action{$a}{Action} cmp $Action{$b}{Action} } keys %Action ) {
                $Param{Action}   = $Action{$ActionID}{Action};
                $Param{ActionID} = $ActionID;
                $Param{Status}   = $StatusList{ $Action{$ActionID}{ActionStatus} };

                $Self->{LayoutObject}->Block(
                    Name => 'OverviewResultSettingRow',
                    Data => {%Param},
                );
            }
        }

        # otherwise, show a no data found message
        else {
            $Self->{LayoutObject}->Block( Name => 'NoSettingDataFoundMsg' );
        }

        # show user data
        $Self->{LayoutObject}->Block(
            Name => 'OverviewResultUser',
            Data => \%Param,
        );

        # show list of registered users (if any)
        if (%User) {

            $Self->{LayoutObject}->Block(
                Name => 'OverviewResultUserTable',
                Data => {%Param},
            );

            for my $UserID ( sort { $User{$a} cmp $User{$b} } keys %User ) {

                # get missing user data
                my %UserData = $Self->{TimeAccountingObject}->UserGet( UserID => $UserID );
                my %UserGeneralData = $Self->{UserObject}->GetUserData( UserID => $UserID );

                $Param{User}
                    = "$UserGeneralData{UserFirstname} $UserGeneralData{UserLastname} ($UserGeneralData{UserLogin})";
                $Param{UserID}     = $UserID;
                $Param{Comment}    = $UserData{Description};
                $Param{CalendarNo} = $UserData{Calendar};
                $Param{Calendar}   = $Self->{ConfigObject}->Get(
                    "TimeZone::Calendar"
                        . ( $Param{CalendarNo} || '' ) . "Name"
                ) || 'Default';

                $Self->{LayoutObject}->Block(
                    Name => 'OverviewResultUserRow',
                    Data => {%Param},
                );
            }
        }

        # otherwise, show a no data found message
        else {
            $Self->{LayoutObject}->Block( Name => 'NoUserDataFoundMsg' );
        }
    }

    return 1;
}

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

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

    $Self->{LayoutObject}->Block( Name => 'ActionListSetting' );
    $Self->{LayoutObject}->Block( Name => 'ActionOverviewSetting' );

    # define status list
    my %StatusList = (
        1 => 'valid',
        0 => 'invalid',
    );

    my $TaskStatus = 1;
    if ( defined $Param{TaskStatus} ) {
        $TaskStatus = $Param{TaskStatus}
    }

    $Param{StatusOption} = $Self->{LayoutObject}->BuildSelection(
        Data       => \%StatusList,
        SelectedID => $TaskStatus,
        Name       => 'TaskStatus',
    );

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

    # shows header
    if ( $Param{Action} eq 'EditTask' ) {
        $Self->{LayoutObject}->Block( Name => 'HeaderEditTask' );
    }
    else {
        $Self->{LayoutObject}->Block( Name => 'HeaderAddTask' );
    }

    # show server error message (if any) for the task name
    if ( $Param{TaskErrorType} ) {
        $Self->{LayoutObject}->Block( Name => $Param{TaskErrorType} );
    }

    return 1;
}

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

    # get parameters
    for my $Parameter (qw(Description ShowOvertime CreateProject Calendar)) {
        $GetParam{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter );
    }

    # the datepicker used in this screen is non-standard
    # Therefor we have to define this var in the LayoutObject for automatic config generation in the JS footer
    $Self->{LayoutObject}->{HasDatepicker} = 1;

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

    $Self->{LayoutObject}->Block( Name => 'ActionListSetting' );
    $Self->{LayoutObject}->Block( Name => 'ActionOverviewSetting' );
    $Self->{LayoutObject}->Block( Name => 'Reference' );

    # define status list
    my %StatusList = (
        1 => 'valid',
        0 => 'invalid',
    );

    # fill up the calendar list
    my $CalendarListRef = { 0 => 'Default' };
    my $CalendarIndex = 1;
    while ( $Self->{ConfigObject}->Get( "TimeZone::Calendar" . $CalendarIndex . "Name" ) ) {
        $CalendarListRef->{$CalendarIndex}
            = $Self->{ConfigObject}->Get( "TimeZone::Calendar" . $CalendarIndex . "Name" );
        $CalendarIndex++;
    }

    # get user data
    my %UserData = $Self->{TimeAccountingObject}->UserGet( UserID => $Param{UserID} );

    $Param{CalendarOption} = $Self->{LayoutObject}->BuildSelection(
        Data        => $CalendarListRef,
        Name        => 'Calendar',
        Translation => 1,
        SelectedID  => $GetParam{Calendar} || $UserData{Calendar} || 0,
    );

    $Param{Description} = $GetParam{Description} || $UserData{Description} || '';

    $Self->{LayoutObject}->Block(
        Name => 'OverviewUpdateUser',
        Data => {
            %Param,
            ShowOvertime => ( $GetParam{ShowOvertime} || $UserData{ShowOvertime} )
            ? 'checked="checked"'
            : '',
            CreateProject => ( $GetParam{CreateProject} || $UserData{CreateProject} )
            ? 'checked="checked"'
            : '',
            }
    );

    # shows header
    if ( $Param{Action} eq 'EditUser' ) {
        $Self->{LayoutObject}->Block( Name => 'HeaderEditUser' );
    }
    else {
        $Self->{LayoutObject}->Block(
            Name => 'HeaderAddUser',
            Data => \%Param,
        );
    }

    # if there are errors to show
    if ( $Param{Errors} && %{ $Param{Errors} } ) {

        # show all existing periods
        for ( my $Period = 1; $Period <= $Param{Periods}; $Period++ ) {

            for my $Parameter (qw(DateStart DateEnd LeaveDays WeeklyHours Overtime PeriodStatus )) {
                $GetParam{$Parameter} = $Self->{ParamObject}->GetParam( Param => "$Parameter\[$Period\]" );
            }

            $Param{$Period}{PeriodStatusOption} = $Self->{LayoutObject}->BuildSelection(
                Data       => \%StatusList,
                SelectedID => $GetParam{PeriodStatus} || $Param{$Period}{PeriodStatus},
                Name       => "PeriodStatus[$Period]",
                ID         => "PeriodStatus-$Period",
                Title      => $Self->{LayoutObject}->{LanguageObject}->Translate("Period Status"),
            );

            $Self->{LayoutObject}->Block(
                Name => 'PeriodOverviewRow',
                Data => {
                    Period           => $Period,
                    DateStartInvalid => $Param{Errors}->{ 'DateStart-' . $Period . 'Invalid' }
                        || '',
                    DateEndInvalid => $Param{Errors}->{ 'DateEnd-' . $Period . 'Invalid' } || '',
                    LeaveDaysInvalid => $Param{Errors}->{ 'LeaveDays-' . $Period . 'Invalid' }
                        || '',
                    DateStart          => $GetParam{DateStart},
                    DateEnd            => $GetParam{DateEnd},
                    LeaveDays          => $GetParam{LeaveDays},
                    WeeklyHours        => $GetParam{WeeklyHours},
                    Overtime           => $GetParam{Overtime},
                    PeriodStatusOption => $Param{$Period}{PeriodStatusOption},
                },
            );

            $Self->{LayoutObject}->Block(
                Name => 'DateStart'
                    . (
                    $Param{Errors}->{ 'DateStart-' . $Period . 'ErrorType' }
                        || 'MissingValue'
                    ),
                Data => { Period => $Period },
            );
            $Self->{LayoutObject}->Block(
                Name => 'DateEnd'
                    . ( $Param{Errors}->{ 'DateEnd-' . $Period . 'ErrorType' } || 'MissingValue' ),
                Data => { Period => $Period },
            );
        }
    }
    else {
        my %User = $Self->{TimeAccountingObject}->SingleUserSettingsGet( UserID => $Param{UserID} );

        # show user data
        if (%User) {
            my $LastPeriodNumber = $Self->{TimeAccountingObject}->UserLastPeriodNumberGet(
                UserID => $Param{UserID}
            );

            for ( my $Period = 1; $Period <= $LastPeriodNumber; $Period++ ) {
                my %PeriodParam = ();

                # get all needed data to display
                for my $Parameter (qw(DateStart DateEnd LeaveDays WeeklyHours Overtime)) {
                    $PeriodParam{$Parameter} = $User{$Period}{$Parameter};
                }
                $PeriodParam{Period} = $Period;

                $PeriodParam{PeriodStatusOption} = $Self->{LayoutObject}->BuildSelection(
                    Data       => \%StatusList,
                    SelectedID => $User{$Period}{UserStatus},
                    Name       => "PeriodStatus[$Period]",
                    ID         => "PeriodStatus-$Period",
                    Title      => $Self->{LayoutObject}->{LanguageObject}->Translate("Period Status"),
                );

                $Self->{LayoutObject}->Block(
                    Name => 'PeriodOverviewRow',
                    Data => \%PeriodParam,
                );
            }
        }

        # show a no data found message
        else {
            $Self->{LayoutObject}->Block( Name => 'PeriodOverviewRowNoData' );
        }
    }

    return 1;
}

1;

# --
# Kernel/Modules/AgentTimeAccountingView.pm - time accounting view module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AgentTimeAccountingView;

use strict;
use warnings;

use Date::Pcalc qw(Today Days_in_Month Day_of_Week Add_Delta_YMD check_date);
use Time::Local;

use Kernel::System::TimeAccounting;

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

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

    # check needed Objects
    for my $Needed (
        qw(ParamObject DBObject ModuleReg LogObject UserObject
        ConfigObject TicketObject TimeObject GroupObject)
        )
    {
        $Self->{LayoutObject}->FatalError( Message => "Got no $Needed!" ) if !$Self->{$Needed};
    }

    # create required objects...
    $Self->{TimeAccountingObject} = Kernel::System::TimeAccounting->new(%Param);

    return $Self;
}

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

    my @MonthArray = (
        '',     'January', 'February', 'March',     'April',   'May',
        'June', 'July',    'August',   'September', 'October', 'November',
        'December',
    );
    my @WeekdayArray = ( 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun', );

    # ---------------------------------------------------------- #
    # view older day inserts
    # ---------------------------------------------------------- #

    # permission check
    return $Self->{LayoutObject}->NoPermission( WithHeader => 'yes' ) if !$Self->{AccessRo};

    # get params
    for my $Parameter (qw(Day Month Year UserID)) {
        $Param{$Parameter} = $Self->{ParamObject}->GetParam( Param => $Parameter );
    }

    # check needed params
    for my $Needed (qw(Day Month Year)) {
        if ( !$Param{$Needed} ) {

            return $Self->{LayoutObject}->ErrorScreen( Message => "View: Need $Needed" );
        }
    }

    # format the date parts
    $Param{Year}  = sprintf( "%02d", $Param{Year} );
    $Param{Month} = sprintf( "%02d", $Param{Month} );
    $Param{Day}   = sprintf( "%02d", $Param{Day} );

    # if no UserID posted use the current user
    $Param{UserID} ||= $Self->{UserID};

    # get current date and time
    my ( $Sec, $Min, $Hour, $Day, $Month, $Year ) = $Self->{TimeObject}->SystemTime2Date(
        SystemTime => $Self->{TimeObject}->SystemTime(),
    );

    my $MaxAllowedInsertDays = $Self->{ConfigObject}->Get('TimeAccounting::MaxAllowedInsertDays') || '10';
    ( $Param{YearAllowed}, $Param{MonthAllowed}, $Param{DayAllowed} )
        = Add_Delta_YMD( $Year, $Month, $Day, 0, 0, -$MaxAllowedInsertDays );

    # redirect to the edit screen, if necessary
    if (
        timelocal( 1, 0, 0, $Param{Day}, $Param{Month} - 1, $Param{Year} - 1900 ) > timelocal(
            1, 0, 0, $Param{DayAllowed},
            $Param{MonthAllowed} - 1,
            $Param{YearAllowed} - 1900
        ) && $Param{UserID} == $Self->{UserID}
        )
    {

        return $Self->{LayoutObject}->Redirect(
            OP =>
                "Action=AgentTimeAccountingEdit;Year=$Param{Year};Month=$Param{Month};Day=$Param{Day}"
        );
    }

    # show the naming of the agent which time accounting is visited
    if ( $Param{UserID} != $Self->{UserID} ) {
        my %ShownUsers = $Self->{UserObject}->UserList(
            Type  => 'Long',
            Valid => 1
        );
        $Param{User} = $ShownUsers{ $Param{UserID} };
        $Self->{LayoutObject}->Block(
            Name => 'User',
            Data => {%Param},
        );
    }

    $Param{Weekday}         = Day_of_Week( $Param{Year}, $Param{Month}, $Param{Day} );
    $Param{Weekday_to_Text} = $WeekdayArray[ $Param{Weekday} - 1 ];
    $Param{Month_to_Text}   = $MonthArray[ $Param{Month} ];

    # Values for the link icons <>
    ( $Param{YearBack}, $Param{MonthBack}, $Param{DayBack} )
        = Add_Delta_YMD( $Param{Year}, $Param{Month}, $Param{Day}, 0, 0, -1 );
    ( $Param{YearNext}, $Param{MonthNext}, $Param{DayNext} )
        = Add_Delta_YMD( $Param{Year}, $Param{Month}, $Param{Day}, 0, 0, 1 );

    $Param{DateSelection} = $Self->{LayoutObject}->BuildDateSelection(
        %Param,
        Prefix   => '',
        Format   => 'DateInputFormat',
        Validate => 1,
        Class    => $Param{Errors}->{DateInvalid},
    );

    # Show Working Units
    # get existing working units
    my %Data = $Self->{TimeAccountingObject}->WorkingUnitsGet(
        Year   => $Param{Year},
        Month  => $Param{Month},
        Day    => $Param{Day},
        UserID => $Param{UserID},
    );

    $Param{Date} = $Data{Date};

    # get project and action settings
    my %Project = $Self->{TimeAccountingObject}->ProjectSettingsGet();
    my %Action  = $Self->{TimeAccountingObject}->ActionSettingsGet();

    # get sick, leave day and overtime
    $Param{Sick}     = $Data{Sick}     ? 'checked' : '';
    $Param{LeaveDay} = $Data{LeaveDay} ? 'checked' : '';
    $Param{Overtime} = $Data{Overtime} ? 'checked' : '';

    # only show the unit block if there is some data
    my $UnitsRef = $Data{WorkingUnits};
    if ( $UnitsRef->[0] ) {

        for my $UnitRef ( @{$UnitsRef} ) {

            $Self->{LayoutObject}->Block(
                Name => 'Unit',
                Data => {
                    Project   => $Project{Project}{ $UnitRef->{ProjectID} },
                    Action    => $Action{ $UnitRef->{ActionID} }{Action},
                    Remark    => $UnitRef->{Remark},
                    StartTime => $UnitRef->{StartTime},
                    EndTime   => $UnitRef->{EndTime},
                    Period    => $UnitRef->{Period},
                    }
            );
        }

        $Self->{LayoutObject}->Block(
            Name => 'Total',
            Data => { Total => sprintf( "%.2f", $Data{Total} ) }
        );
    }
    else {
        $Self->{LayoutObject}->Block( Name => 'NoDataFound' );
    }

    if ( $Param{Sick} || $Param{LeaveDay} || $Param{Overtime} ) {
        $Self->{LayoutObject}->Block(
            Name => 'OtherTimes',
            Data => {
                Sick     => $Param{Sick},
                LeaveDay => $Param{LeaveDay},
                Overtime => $Param{Overtime},
                }
        );
    }

    my %UserData = $Self->{TimeAccountingObject}->UserGet(
        UserID => $Param{UserID},
    );

    my $Vacation = $Self->{TimeObject}->VacationCheck(
        Year     => $Param{Year},
        Month    => $Param{Month},
        Day      => $Param{Day},
        Calendar => $UserData{Calendar},
    );

    if ($Vacation) {
        $Self->{LayoutObject}->Block(
            Name => 'Vacation',
            Data => { Vacation => $Vacation },
        );
    }

    # presentation
    my $Output = $Self->{LayoutObject}->Header( Title => 'View' );
    $Output .= $Self->{LayoutObject}->NavigationBar();
    $Output .= $Self->{LayoutObject}->Output(
        Data         => \%Param,
        TemplateFile => 'AgentTimeAccountingView'
    );
    $Output .= $Self->{LayoutObject}->Footer();

    return $Output;
}

1;

IyAtLQojIEFBQVRpbWVBY2NvdW50aW5nLnR0IC0gJFRleHQgdmFyaWFibGUgZmlsZQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCiMgQ29tbW9uClslIFRyYW5zbGF0ZSgiVGltZSBBY2NvdW50aW5nIikgfCBodG1sICVdClslIFRyYW5zbGF0ZSgiU2hvdyB2YWxpZCBwcm9qZWN0cyIpIHwgaHRtbCAlXQpbJSBUcmFuc2xhdGUoIlNob3cgYWxsIHByb2plY3RzIikgfCBodG1sICVdClslIFRyYW5zbGF0ZSgiVGltZUFjY291bnRpbmciKSB8IGh0bWwgJV0KWyUgVHJhbnNsYXRlKCJSZXBvcnRpbmciKSB8IGh0bWwgJV0KWyUgVHJhbnNsYXRlKCJQbGVhc2UgaW5zZXJ0IHlvdXIgd29ya2luZyBob3VycyEiKSB8IGh0bWwgJV0KWyUgVHJhbnNsYXRlKCJTdWNjZXNzZnVsIGluc2VydCEiKSB8IGh0bWwgJV0KWyUgVHJhbnNsYXRlKCJFcnJvciB3aGlsZSBpbnNlcnRpbmcgbXVsdGlwbGUgZGF0ZXMhIikgfCBodG1sICVdClslIFRyYW5zbGF0ZSgiU3VjY2Vzc2Z1bGx5IGluc2VydGVkIGVudHJpZXMgZm9yIHNldmVyYWwgZGF0ZXMhIikgfCBodG1sICVdClslIFRyYW5zbGF0ZSgiRW50ZXJlZCBkYXRlIHdhcyBpbnZhbGlkISBEYXRlIHdhcyBjaGFuZ2VkIHRvIHRvZGF5LiIpIHwgaHRtbCAlXQo=
IyAtLQojIEFnZW50VGltZUFjY291bnRpbmdEZWxldGUudHQgLSBwcm92aWRlcyBIVE1MIGZvcm0gZm9yIGRlbGV0ZSBhIGRheSBvZiB0aW1lYWNjb3VudGluZwojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCjxmaWVsZHNldCBjbGFzcz0iVGFibGVMaWtlIFczMDBweCI+CiAgICA8bGFiZWw+WyUgVHJhbnNsYXRlKCJZZWFyIikgfCBodG1sICVdOjwvbGFiZWw+CiAgICA8cCBjbGFzcz0iVmFsdWUiPgogICAgICAgIFslIERhdGEuWWVhciB8IGh0bWwgJV0KICAgIDwvcD4KICAgIDxkaXYgY2xhc3M9IkNsZWFyIj48L2Rpdj4KCiAgICA8bGFiZWw+WyUgVHJhbnNsYXRlKCJNb250aCIpIHwgaHRtbCAlXTo8L2xhYmVsPgogICAgPHAgY2xhc3M9IlZhbHVlIj4KICAgICAgICBbJSBUcmFuc2xhdGUoRGF0YS5Nb250aCkgfCBodG1sICVdCiAgICA8L3A+CiAgICA8ZGl2IGNsYXNzPSJDbGVhciI+PC9kaXY+CgogICAgPGxhYmVsPlslIFRyYW5zbGF0ZSgiRGF5IikgfCBodG1sICVdOjwvbGFiZWw+CiAgICA8cCBjbGFzcz0iVmFsdWUiPgogICAgICAgIFslIERhdGEuRGF5IHwgaHRtbCAlXQogICAgPC9wPgogICAgPGRpdiBjbGFzcz0iQ2xlYXIiPjwvZGl2Pgo8L2ZpZWxkc2V0Pgo8cCBjbGFzcz0iU3BhY2luZ1RvcCBDZW50ZXIiPgogICAgWyUgVHJhbnNsYXRlKCJEbyB5b3UgcmVhbGx5IHdhbnQgdG8gZGVsZXRlIHRoZSBUaW1lIEFjY291bnRpbmcgb2YgdGhpcyBkYXk/IikgfCBodG1sICVdCjwvcD4K
# --
# AgentTimeAccountingEdit.tt - provides HTML form for time accounting edit
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

<div class="MainBox ARIARoleMain LayoutFixedSidebar SidebarFirst">
    <h1 class="Header">[% Translate("Edit Time Record") | html %]</h1>

    <div class="SidebarColumn">
[% RenderBlockStart("OverviewProject") %]
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Actions") | html %]</h2>
            </div>
            <div class="Content">
                <ul class="ActionList">
                    <li>
                        <a href="[% Env("Baselink") %]Action=AgentTimeAccountingOverview;Year=[% Data.Year | uri %];Month=[% Data.Month | uri %]" class="CallForAction Fullsize Center"><span><i class="fa fa-caret-left"></i>[% Translate("Go to overview") | html %]</span></a>
                    </li>
[% RenderBlockStart("CreateProject") %]
                    <li>
                        <a href="[% Env("Baselink") %]Action=AgentTimeAccountingSetting" class="CallForAction Fullsize Center"><span><i class="fa fa-gear"></i>[% Translate("Go to settings") | html %]</span></a>
                    </li>
[% RenderBlockEnd("CreateProject") %]
                </ul>
            </div>
        </div>
[% RenderBlockEnd("OverviewProject") %]

        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Date Navigation") | html %]</h2>
            </div>
            <div class="Content">
                <div class="MonthSelection">
                    <a class="Arrow" title="[% Translate("Previous day") | html %]" href="[% Env("Baselink") %]Action=[% Env("Action") %];Year=[% Data.YearBack | uri %];Month=[% Data.MonthBack | uri %];Day=[% Data.DayBack | uri %]">
                        <i class="fa fa-caret-left"></i>
                    </a>
                    [% Data.Year | html %]-[% Data.Month | html %]-[% Data.Day | html %]
                    <a class="Arrow" title="[% Translate("Next day") | html %]" href="[% Env("Baselink") %]Action=[% Env("Action") %];Year=[% Data.YearNext | uri %];Month=[% Data.MonthNext | uri %];Day=[% Data.DayNext | uri %]">
                        <i class="fa fa-caret-right"></i>
                    </a>
                </div>
                <form action="[% Env("CGIHandle") %]" method="post" enctype="multipart/form-data" class="Validate" name="DateSelection" id="DateSelectionForm">
                    <input type="hidden" name="Action" value="[% Env("Action") %]" />
                    <input type="hidden" name="Subaction" value="Edit" />
                    [% Data.Date %]
                </form>
                <a href="#" id="NavigationSelect" class="CallForAction SpacingTopSmall Fullsize Center">
                    <span><i class="fa fa-arrow-circle-o-right"></i>[% Translate("Go to this date") | html %]</span>
                </a>
[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
$('#NavigationSelect').bind('click', function(){
    $('#DateSelectionForm').submit();
});
//]]></script>
[% END %]
            </div>
        </div>

[% RenderBlockStart("IncompleteWorkingDays") %]
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Days without entries") | html %]</h2>
            </div>
            <div class="Content">
                [% Data.IncompleteWorkingDaysSelect %]
[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
    $('#IncompleteWorkingDaysList').unbind('change.IncompleteWorkingDays').bind('change.IncompleteWorkingDays', function () {
        var Date = $(this).val().split('-');
        if (Date[0] && Date[1] && Date[2]) {
            location.href = "[% Env("Baselink") %]Action=[% Env("Action") %];Year=" + Date[0] + ";Month=" + Date[1] + ";Day=" + Date[2];
        }
    });
//]]></script>
[% END %]
            </div>
        </div>
[% RenderBlockEnd("IncompleteWorkingDays") %]

[% RenderBlockStart("IncompleteWorkingDaysMassEntry") %]
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Days without entries") | html %]</h2>
            </div>
            <div class="Content">
                <ul class="IncompleteWorkingDays">
                    <li id="SelectAllDays"><input type="checkbox" id="IncompleteWorkingDay-All" name="IncompleteWorkingDay-All" /><label for="IncompleteWorkingDay-All"><em>[% Translate("Select all days") | html %]</em></label></li>
[% RenderBlockStart("IncompleteWorkingDaysMassEntrySingleDay") %]
                    <li><input type="checkbox" id="IncompleteWorkingDay-[% Data.Date | html %]" name="IncompleteWorkingDay-[% Data.Date | html %]" /><label for="IncompleteWorkingDay-[% Data.Date | html %]">[% Data.Date | html %]</label> - <a href="[% Env("Baselink") %]Action=[% Env("Action") %];Year=[% Data.Year | uri %];Month=[% Data.Month | uri %];Day=[% Data.Day | uri %]">[% Translate("Edit") | html %]</a></li>
[% RenderBlockEnd("IncompleteWorkingDaysMassEntrySingleDay") %]
                </ul>
                <form action="[% Env("CGIHandle") %]" method="post" enctype="multipart/form-data" id="MassEntry" name="MassEntry" class="SpacingTop">
                    <input type="hidden" name="Action" value="[% Env("Action") %]" />
                    <input type="hidden" name="Subaction" value="MassEntry" />
                    <input type="hidden" name="Dates" value="" />
                    <input type="hidden" name="LeaveDay" value="" />
                    <input type="hidden" name="Sick" value="" />
                    <input type="hidden" name="Overtime" value="" />
                    <a href="#" id="MassEntrySubmit" class="CallForAction Fullsize Center"><span><i class="fa fa-plus-square-o"> </i>[% Translate("Mass entry") | html %]</span></a>
                </form>
                <div id="MassEntryConfirmDialog" class="Hidden">
                    <h2>[% Translate("Please choose the reason for your absence for the selected days") | html %].</h2>
                    <ul id="MassEntryConfirmRadio">
                        <li><input type="radio" name="LeaveDay" id="ConfirmLeaveDay" /><label for="ConfirmLeaveDay">[% Translate("On vacation") | html %]</label></li>
                        <li><input type="radio" name="Sick" id="ConfirmSick" /><label for="ConfirmSick">[% Translate("On sick leave") | html %]</label></li>
                        <li><input type="radio" name="Overtime" id="ConfirmOvertime" /><label for="ConfirmOvertime">[% Translate("On overtime leave") | html %]</label></li>
                    </ul>
                </div>
[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
/*global TimeAccounting: true */
    TimeAccounting.Agent.EditTimeRecords.MassEntryInit({
        MsgChooseOneDay:    [% Translate("Please choose at least one day!") | JSON %],
        MsgAbsenceReason:   [% Translate("Please choose a reason for absence!") | JSON %],
        MassEntry:          [% Translate("Mass Entry") | JSON %],
        Submit:             [% Translate("Submit") | JSON %],
        Cancel:             [% Translate("Cancel") | JSON %]
    });
//]]></script>
[% END %]
            </div>
        </div>
[% RenderBlockEnd("IncompleteWorkingDaysMassEntry") %]

        <div class="WidgetSimple SpacingTop">
            <div class="Header">
                <h2>[% Translate("Reference") | html %]</h2>
            </div>
            <div class="Content">
                <p class="FieldExplanation">
                    [% Translate("Required fields are marked with a \"*\".") | html %]
                </p>
                <p class="FieldExplanation">
                    [% Translate("You have to fill in start and end time or a time period.") | html %]
                </p>
            </div>
        </div>
    </div>
    <div class="ContentColumn">
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Date") | html %]: [% Translate(Data.Weekday_to_Text) | html %] [% Data.Year | html %]-[% Data.Month | html %]-[% Data.Day | html %]</h2>
            </div>
            <div class="Content HorizontalScroll">
                <form action="[% Env("CGIHandle") %]" method="post" enctype="multipart/form-data" name="WorkingUnits" id="WorkingUnits" class="Validate PreventMultipleSubmits">
                    <input type="hidden" name="Action" value="[% Env("Action") %]" />
                    <input type="hidden" name="Subaction" value="Edit" />
                    <input type="hidden" name="RecordsNumber" id="RecordsNumber" value="[% Data.RecordsNumber | html %]" />
                    <input type="hidden" name="Status" value="Action" />
                    <input type="hidden" name="Year" value="[% Data.Year | html %]" />
                    <input type="hidden" name="Month" value="[% Data.Month | html %]" />
                    <input type="hidden" name="Day" value="[% Data.Day | html %]" />
[% RenderBlockStart("UnitBlock") %]
                    <table class="DataTable NoHover HighCells" id="InsertWorkingHours">
                        <thead>
                            <tr>
                                <th><span class="Marker">*</span> [% Translate("Project") | html %]</th>
                                <th><span class="Marker">*</span> [% Translate("Task") | html %]</th>
                                <th>[% Translate("Remark") | html %]</th>
                                <th>[% Translate("Start") | html %] (HH:MM)</th>
                                <th>[% Translate("End") | html %] (HH:MM)</th>
                                <th><span class="Marker">[% Data.PeriodNote | html %]</span> [% Translate("Period") | html %]</th>
                            </tr>
                        </thead>
                        <tbody>
[% RenderBlockStart("Unit") %]
                            <tr class="WorkingHours">
                                <td>
                                    [% Data.ProjectOption %]
                                    <div id="ProjectID[% Data.ID | html %]Error" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                                    <div id="ProjectID[% Data.ID | html %]ServerError" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                                    <div id="Combo_ProjectID[% Data.ID | html %]Error" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                                    <div id="Combo_ProjectID[% Data.ID | html %]ServerError" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                                </td>
                                <td>
                                    [% Data.ActionOption %]
                                    <div id="ActionID[% Data.ID | html %]Error" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                                    <div id="ActionID[% Data.ID | html %]ServerError" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                                    <div id="Combo_ActionID[% Data.ID | html %]Error" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                                    <div id="Combo_ActionID[% Data.ID | html %]ServerError" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                                </td>
                                <td>
                                    <input type="text" name="Remark[[% Data.ID | html %]]" id="Remark[% Data.ID | html %]" class="Validate_TimeAccounting_Remark [% Data.RemarkInvalid | html %]" value="[% Data.Remark | html %]" size="35" title="[% Translate("Remark") | html %]" />
                                    <div id="Remark[% Data.ID | html %]Error" class="TooltipErrorMessage"><p>[% Translate("Please add a remark with more than 8 characters!.") | html %]</p></div>
                                    <div id="Remark[% Data.ID | html %]ServerError" class="TooltipErrorMessage">
                                        <p>[% Translate("This field is required.") | html %]</p>
                                    </div>
                                </td>
                                <td>
                                    <input type="text" name="StartTime[[% Data.ID | html %]]" id="StartTime[% Data.ID | html %]" class="StartTime Validate_TimeAccounting_StartTime [% Data.StartTimeRequired | html %] [% Data.StartTimeInvalid | html %]" value="[% Data.StartTime | html %]" size="7" title="[% Translate("Start Time") | html %]" />
                                    <div id="StartTime[% Data.ID | html %]Error" class="TooltipErrorMessage">
                                        <p>[% Translate("You have to fill in start and end time or a time period.") | html %]</p>
                                    </div>
                                    <div id="StartTime[% Data.ID | html %]ServerError" class="TooltipErrorMessage">
[% RenderBlockStart("StartTimeGenericServerError") %]
                                        <p>[% Translate("This field is required.") | html %]</p>
[% RenderBlockEnd("StartTimeGenericServerError") %]
[% RenderBlockStart("StartTimeNegativeServerError") %]
                                        <p>[% Translate("Negative times are not allowed.") | html %]</p>
[% RenderBlockEnd("StartTimeNegativeServerError") %]
[% RenderBlockStart("StartTimeRepeatedHourServerError") %]
                                        <p>[% Translate("Repeated hours are not allowed. Start time matches another interval.") | html %]</p>
[% RenderBlockEnd("StartTimeRepeatedHourServerError") %]
[% RenderBlockStart("StartTimeInvalidFormatServerError") %]
                                        <p>[% Translate("Invalid format! Please enter a time with the format HH:MM.") | html %]</p>
[% RenderBlockEnd("StartTimeInvalidFormatServerError") %]
[% RenderBlockStart("StartTime24Hours") %]
                                        <p>[% Translate("24:00 is only permitted as end time.") | html %]</p>
[% RenderBlockEnd("StartTime24Hours") %]
[% RenderBlockStart("StartTimeInvalid") %]
                                        <p>[% Translate("Invalid time! A day has only 24 hours.") | html %]</p>
[% RenderBlockEnd("StartTimeInvalid") %]
                                    </div>
                                </td>
                                <td>
                                    <input type="text" name="EndTime[[% Data.ID | html %]]" id="EndTime[% Data.ID | html %]" class="EndTime Validate_DependingRequiredAND Validate_Depending_StartTime[% Data.ID | html %] [% Data.EndTimeRequired | html %] [% Data.EndTimeInvalid | html %]" value="[% Data.EndTime | html %]" size="7" title="[% Translate("End Time") | html %]" />
                                    <div id="EndTime[% Data.ID | html %]Error" class="TooltipErrorMessage">
                                        <p>[% Translate("You have to fill in start and end time or a time period.") | html %]</p>
                                    </div>
                                    <div id="EndTime[% Data.ID | html %]ServerError" class="TooltipErrorMessage">
[% RenderBlockStart("EndTimeGenericServerError") %]
                                        <p>[% Translate("This field is required.") | html %]</p>
[% RenderBlockEnd("EndTimeGenericServerError") %]
[% RenderBlockStart("EndTimeBeforeStartTimeServerError") %]
                                        <p>[% Translate("End time must be after start time.") | html %]</p>
[% RenderBlockEnd("EndTimeBeforeStartTimeServerError") %]
[% RenderBlockStart("EndTimeNegativeServerError") %]
                                        <p>[% Translate("Negative times are not allowed.") | html %]</p>
[% RenderBlockEnd("EndTimeNegativeServerError") %]
[% RenderBlockStart("EndTimeRepeatedHourServerError") %]
                                        <p>[% Translate("Repeated hours are not allowed. End time matches another interval.") | html %]</p>
[% RenderBlockEnd("EndTimeRepeatedHourServerError") %]
[% RenderBlockStart("EndTimeInvalidFormatServerError") %]
                                        <p>[% Translate("Invalid format! Please enter a time with the format HH:MM.") | html %]</p>
[% RenderBlockEnd("EndTimeInvalidFormatServerError") %]
[% RenderBlockStart("EndTimeInvalid") %]
                                        <p>[% Translate("Invalid time! A day has only 24 hours.") | html %]</p>
[% RenderBlockEnd("EndTimeInvalid") %]
                                    </div>
                                </td>
[% RenderBlockStart("UnitInputPeriod") %]
                                <td>
                                    <input type="text" name="Period[[% Data.ID | html %]]" id="Period[% Data.ID | html %]" class="Period Validate_TimeAccounting_Period Validate_TimeUnits [% Data.PeriodRequired | html %] [% Data.PeriodInvalid | html %]" value="[% Data.Period | html %]" size="7" title="[% Translate("Period") | html %]" />
                                    <div id="Period[% Data.ID | html %]Error" class="TooltipErrorMessage">
                                        <p>[% Translate("You have to fill in start and end time or a time period.") | html %]</p>
                                    </div>
                                    <div id="Period[% Data.ID | html %]ServerError" class="TooltipErrorMessage">
[% RenderBlockStart("PeriodGenericServerError") %]
                                        <p>[% Translate("This field is required.") | html %]</p>
[% RenderBlockEnd("PeriodGenericServerError") %]
[% RenderBlockStart("InvalidHoursPeriodServerError") %]
                                        <p>[% Translate("Invalid period! A day has only 24 hours.") | html %]</p>
[% RenderBlockEnd("InvalidHoursPeriodServerError") %]
[% RenderBlockStart("ZeroHoursPeriodServerError") %]
                                        <p>[% Translate("A valid period must be greater than zero.") | html %]</p>
[% RenderBlockEnd("ZeroHoursPeriodServerError") %]
[% RenderBlockStart("NegativePeriodServerError") %]
                                        <p>[% Translate("Invalid period! Negative periods are not allowed.") | html %]</p>
[% RenderBlockEnd("NegativePeriodServerError") %]
                                    </div>

                                </td>
[% RenderBlockEnd("UnitInputPeriod") %]
[% RenderBlockStart("UnitPeriodWithoutInput") %]
                                <td>[% Data.Period | html %]</td>
[% RenderBlockEnd("UnitPeriodWithoutInput") %]
                            </tr>
[% RenderBlockEnd("Unit") %]
                            <tr>
                                <td colspan="6" class="Right">
                                    <button class="CallForAction Plus" type="button" id="MoreInputFields" name="MoreInputFields"><span><i class="fa fa-plus-square"></i>[% Translate("Add one row") | html %]</span></button>
                                </td>
                            </tr>
[% RenderBlockEnd("UnitBlock") %]
                            <tr>
                                <td colspan="4"></td>
[% RenderBlockStart("Total") %]
                                <td>[% Translate("Total") | html %]:</td>
                                <td><span class="TotalHours">[% Data.Total | html %]</span></td>
[% RenderBlockEnd("Total") %]
                            </tr>
[% RenderBlockStart("Readonly") %]
                            <tr>
                                <td colspan="6">
                                    [% Translate(Data.Description) | html %]
                                </td>
                            </tr>
[% RenderBlockEnd("Readonly") %]
                        </tbody>
                    </table>
[% RenderBlockStart("OtherTimes") %]
                    <div class="SpacingTop">
                        <input type="checkbox" value="1" id="LeaveDay" name="LeaveDay" title="[% Translate("On vacation") | html %]" class="[% Data.LeaveDayInvalid %]" [% Data.LeaveDay %] />
                        <label for="LeaveDay">[% Translate("On vacation") | html %]</label>
                        <div id="LeaveDayServerError" class="TooltipErrorMessage">
                            <p>[% Translate("You can only select one checkbox element!") | html %]</p>
                        </div>
                        <input type="checkbox" value="1" id="Sick" name="Sick" title="[% Translate("On sick leave") | html %]" class="[% Data.SickInvalid %]" [% Data.Sick %] />
                        <label for="Sick">[% Translate("On sick leave") | html %]</label>
                        <div id="SickServerError" class="TooltipErrorMessage">
                            <p>[% Translate("You can only select one checkbox element!") | html %]</p>
                        </div>
                        <input type="checkbox" value="1" id="Overtime" name="Overtime" title="[% Translate("On overtime leave") | html %]" class="[% Data.OvertimeInvalid %]" [% Data.Overtime %] />
                        <label for="Overtime">[% Translate("On overtime leave") | html %]</label>
                        <div id="OvertimeServerError" class="TooltipErrorMessage">
                            <p>[% Translate("You can only select one checkbox element!") | html %]</p>
                        </div>
                    </div>
[% RenderBlockEnd("OtherTimes") %]
                    <div class="Center SpacingTop">
                        <button class="Primary CallForAction" type="submit" name="InsertWorkingUnits" value="[% Translate("Submit") | html %]"><span><i class="fa fa-check-square-o"></i> [% Translate("Submit") | html %]</span></button>
                        <a id="DeleteTimeAccountingEntry" href="#">
                            [% Translate("Delete") | html %]
                        </a>
                        [% Translate("or") | html %]
                        <a href="[% Env("Baselink") %]Action=[% Env("Action") %];">[% Translate("Cancel") | html %]</a>
                    </div>
                    <div class="Clear"></div>
[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
/*global TimeAccounting: true */
    TimeAccounting.Agent.EditTimeRecords.ActionList = [% Data.JSActionList | html %];
    TimeAccounting.Agent.EditTimeRecords.ActionListConstraints = [% Data.JSActionListConstraints | html %];
    TimeAccounting.Agent.EditTimeRecords.Init({
        RemarkRegExpContent: "[% Data.RemarkRegExp | html %]",
        Autocompletion: [% Data.EnableAutocompletion | html %],
        Language: {
            ShowAllItems: [% Translate("Show all items") | JSON %],
            ProjectTitle: [% Translate("Project") | JSON %],
            TaskTitle: [% Translate("Task") | JSON %]
        }
    });
    TimeAccounting.Agent.ConfirmationDialog.BindConfirmationDialog({
        ElementID:                  'DeleteTimeAccountingEntry',
        ElementSelector:            '#DeleteTimeAccountingEntry',
        DialogContentQueryString:   'Action=AgentTimeAccountingEdit;DeleteDialog=1;Year=[% Data.Year | html %];Month=[% Data.Month | html %];Day=[% Data.Day | html %]',
        ConfirmedActionQueryString: 'Action=AgentTimeAccountingEdit;Subaction=Delete;Year=[% Data.Year | html %];Month=[% Data.Month | html %];Day=[% Data.Day | html %]',
        DialogTitle:                [% Translate("Delete Time Accounting Entry") | JSON %],
        TranslatedText:             {
            Yes: [% Translate("Yes") | JSON %],
            No:  [% Translate("No") | JSON %]
        }
    });
//]]></script>
[% END %]

[% RenderBlockStart("ShowConfirmation") %]
[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
    // define yes and no buttons
    var Buttons = [{
        Label: [% Translate("Yes") | JSON %],
        Class: "Primary",
        Type: "Close",
        }, {
        Label: [% Translate("No") | JSON %],

        // define the function that is called when the 'No' button is pressed
        Function: function(){

            // disable Yes and No buttons to prevent multiple submits
            $('div.Dialog:visible div.ContentFooter button').attr('disabled', 'disabled');

            // redirect to the module that deletes the saved entry after pressing the No button
            location.href = Core.Config.Get('Baselink') + 'Action=AgentTimeAccountingEdit;Subaction=Delete;Year=[% Data.Year | html %];Month=[% Data.Month | html %];Day=[% Data.Day | html %]';
        }
    }];
    // show the confirmation dialog to confirm the action
    Core.UI.Dialog.ShowContentDialog($('#[% Data.BlockName | html %]'), [% Translate("Confirm insert") | JSON %], '20%', 'Center', true, Buttons);

//]]></script>
[% END %]
[% RenderBlockEnd("ShowConfirmation") %]

                </form>
            </div>
        </div>
    </div>
</div>

<p id="SickLeaveMessage" class="Hidden Center">
    [% Translate("Are you sure that you worked while you were on sick leave?") | html %]
</p>

<p id="VacationMessage" class="Hidden Center">
    [% Translate("Are you sure that you worked while you were on vacation?") | html %]
</p>

<p id="OvertimeMessage" class="Hidden Center">
    [% Translate("Are you sure that you worked while you were on overtime leave?") | html %]
</p>

<p id="More16HoursMessage" class="Hidden Center">
    [% Translate("Are you sure that you worked more than 16 hours?") | html %]
</p>

# --
# AgentTimeAccountingOverview.tt - provides HTML form for time accounting overview
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

<div class="MainBox ARIARoleMain">
    <h1 class="Header">[% Translate("Time reporting monthly overview") | html %]</h1>

    <div class="LayoutFixedSidebar SidebarLast">
        <div class="SidebarColumn">
[% RenderBlockStart("Overtime") %]
            <div class="WidgetSimple">
                <div class="Header">
                    <h2>[% Translate("Overtime (Hours)") | html %]</h2>
                </div>
                <div class="Content">
                    <fieldset class="TableLike FixedLabel">
                        <label>[% Translate("Overtime (this month)") | html %]:</label>
                        <p class="Value">[% Data.Overtime | html %]</p>
                        <div class="Clear"></div>

                        <label>[% Translate("Overtime (total)") | html %]:</label>
                        <p class="Value">[% Data.OvertimeUntil | html %]</p>
                        <div class="Clear"></div>

                        <label>[% Translate("Remaining overtime leave") | html %]:</label>
                        <p class="Value">[% Data.OvertimeTotal | html %]</p>
                        <div class="Clear"></div>
                    </fieldset>
                </div>
            </div>
[% RenderBlockEnd("Overtime") %]

            <div class="WidgetSimple">
                <div class="Header">
                    <h2>[% Translate("Vacation (Days)") | html %]</h2>
                </div>
                <div class="Content">
                    <fieldset class="TableLike FixedLabel">
                        <label>[% Translate("Vacation taken (this month)") | html %]:</label>
                        <p class="Value">[% Data.LeaveDay | html %]</p>
                        <div class="Clear"></div>

                        <label>[% Translate("Vacation taken (total)") | html %]:</label>
                        <p class="Value">[% Data.LeaveDayTotal | html %]</p>
                        <div class="Clear"></div>

                        <label>[% Translate("Remaining vacation") | html %]:</label>
                        <p class="Value">[% Data.LeaveDayRemaining | html %]</p>
                        <div class="Clear"></div>
                    </fieldset>
                </div>
            </div>

            <div class="WidgetSimple">
                <div class="Header">
                    <h2>[% Translate("Sick Leave (Days)") | html %]</h2>
                </div>
                <div class="Content">
                    <fieldset class="TableLike FixedLabel">
                        <label>[% Translate("Sick leave taken (this month)") | html %]:</label>
                        <p class="Value">[% Data.Sick | html %]</p>
                        <div class="Clear"></div>

                        <label>[% Translate("Sick leave taken (total)") | html %]:</label>
                        <p class="Value">[% Data.SickTotal | html %]</p>
                        <div class="Clear"></div>
                    </fieldset>
                </div>
            </div>
        </div>

        <div class="ContentColumn">
            <div class="WidgetSimple">
                <div class="Header">
                    <h2>[% Translate("Overview") | html %]
[% RenderBlockStart("User") %]
                        - [% Data.User | html %]
[% RenderBlockEnd("User") %]
                    </h2>
                    <div class="AdditionalInformation">
                        <a class="Arrow" title="[% Translate("Previous month") | html %]" href="[% Env("Baselink") %]Action=[% Env("Action") %];Year=[% Data.YearBack | uri %];Month=[% Data.MonthBack | uri %];UserID=[% Data.UserID | uri %]"><i class="fa fa-caret-left"></i></a>
                        <a class="Arrow" title="[% Translate("Next month") | html %]" href="[% Env("Baselink") %]Action=[% Env("Action") %];Year=[% Data.YearNext | uri %];Month=[% Data.MonthNext | uri %];UserID=[% Data.UserID | uri %]"><i class="fa fa-caret-right"></i></a>
                        [% Translate(Data.Month_to_Text) | html %] [% Data.Year | html %]
                    </div>
                </div>
                <div class="Content">
                    <table class="DataTable">
                        <thead>
                            <tr>
                                <th>[% Translate("Day") | html %]</th>
                                <th>[% Translate("Weekday") | html %]</th>
                                <th>[% Translate("Comment") | html %]</th>
                                <th>[% Translate("Working Hours") | html %]</th>
                            </tr>
                        </thead>
                        <tbody>
[% RenderBlockStart("Row") %]
                            <tr class="[% Data.Class | html %] MasterAction">
                                <td class="Fixed Day">
                                    <a href="[% Env("Baselink") %]Action=[% Data.Action | uri %];Year=[% Data.Year | uri %];Month=[% Data.Month | uri %];Day=[% Data.Day | uri %];UserID=[% Data.UserID | uri %]" class="MasterActionLink">
                                        [% Data.Day | html %]
                                    </a>
                                </td>
                                <td class="Fixed Weekday">[% Translate(Data.Weekday_to_Text) | html %]</td>
                                <td>[% Translate(Data.Comment) | html %]</td>
                                <td class="Right">[% Data.WorkingHours | html %]</td>
                            </tr>
[% RenderBlockEnd("Row") %]
                        </tbody>
                    </table>
                    <div class="SpacingTop Right"><strong>[% Translate("Total worked hours") | html %]:</strong> [% Data.WorkingHours | html %]</div>
                </div>
            </div>

[% RenderBlockStart("ProjectTable") %]
            <div class="WidgetSimple">
                <div class="Header">
                    <h2>
                        [% Translate("User's project overview") | html %]
                        <a href="[% Env("Baselink") %]Action=[% Env("Action") %];Year=[% Data.Year | uri %];Month=[% Data.Month | uri %];ProjectStatusShow=[% Data.ProjectStatusShow | uri %];UserID=[% Data.UserID | uri %]">
                            ([% Translate(Data.ShowProjects) | html %])
                        </a>
                    </h2>
                </div>
                <div class="Content">
                    <table class="DataTable NoHover HighCells">
                        <thead>
                            <tr>
                                <th>[% Translate("Project") | html %]</th>
                                <th>[% Translate("Task") | html %]</th>
                                <th>[% Translate("Hours (monthly)") | html %]</th>
                                <th>[% Translate("Hours (Lifetime)") | html %]</th>
                            </tr>
                        </thead>
                        <tbody>
[% RenderBlockStart("Action") %]
                            <tr>
[% RenderBlockStart("Project") %]
                                <td rowspan="[% Data.RowSpan %]" class="RowSpan">
                                    <strong>
[% RenderBlockStart("ProjectNoLink") %]
                                    [% Data.Project %]
[% RenderBlockEnd("ProjectNoLink") %]
[% RenderBlockStart("ProjectLink") %]
                                    <a href="[% Env("Baselink") %]Action=AgentTimeAccountingReporting;Subaction=ReportingProject;ProjectID=[% Data.ProjectID | uri %]">
                                        [% Data.Project %]
                                    </a>
[% RenderBlockEnd("ProjectLink") %]
                                    </strong>
[% RenderBlockStart("ProjectDescription") %]
                                    <br/>[% Data.ProjectDescription %]
[% RenderBlockEnd("ProjectDescription") %]
                                </td>
[% RenderBlockEnd("Project") %]
                                <td>[% Data.Action | html %]</td>
                                <td class="Right">[% Data.Hours | html %]</td>
                                <td class="Right">[% Data.HoursTotal | html %]</td>
                            </tr>
[% RenderBlockStart("ActionTotal") %]
                            <tr>
                                <td><strong>[% Translate("Total") | html %]</strong></td>
                                <td class="Right"><strong>[% Data.Hours | html %]</strong></td>
                                <td class="Right"><strong>[% Data.HoursTotal | html %]</strong></td>
                            </tr>
[% RenderBlockEnd("ActionTotal") %]
[% RenderBlockEnd("Action") %]
[% RenderBlockStart("GrandTotal") %]
                            <tr class="GrandTotal">
                                <td colspan="2"><strong>[% Translate("Grand total") | html %]</strong></td>
                                <td class="Right"><strong>[% Data.TotalHours | html %]</strong></td>
                                <td class="Right"><strong>[% Data.TotalHoursTotal | html %]</strong></td>
                            </tr>
[% RenderBlockEnd("GrandTotal") %]
                        </tbody>
                    </table>
                </div>
            </div>
[% RenderBlockEnd("ProjectTable") %]
        </div>
    </div>
</div>
[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
$('.MasterAction').bind('click', function (Event) {
    var $MasterActionLink = $(this).find('.MasterActionLink');
    // only act if the link was not clicked directly
    if (Event.target !== $MasterActionLink.get(0)) {
        window.location = $MasterActionLink.attr('href');
        return false;
    }
});
//]]></script>
[% END %]

# --
# AgentTimeAccountingReporting.tt - provides HTML form for time accounting reporting
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

<div class="MainBox ARIARoleMain LayoutFixedSidebar SidebarFirst">
    <h1 class="Header">[% Translate("Time reporting") | html %]: [% Translate(Data.Month_to_Text) | html %] [% Data.Year %]</h1>

    <div class="SidebarColumn">
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Month Navigation") | html %]</h2>
            </div>
            <div class="Content">
                <div class="MonthSelection">
                    <a class="Arrow Left" title="[% Translate("Previous month") | html %]" href="[% Env("Baselink") %]Action=[% Env("Action") %];Year=[% Data.YearBack | uri %];Month=[% Data.MonthBack | uri %]">
                        <i class="fa fa-caret-left"></i>
                    </a>
                    <a class="Arrow" title="[% Translate("Next month") | html %]" href="[% Env("Baselink") %]Action=[% Env("Action") %];Year=[% Data.YearNext | uri %];Month=[% Data.MonthNext | uri %]">
                        <i class="fa fa-caret-right"></i>
                    </a>
                    <strong>[% Translate(Data.Month_to_Text) | html %] [% Data.Year %]</strong>
                </div>
                <div class="Clear"></div>
                <form action="[% Env("CGIHandle") %]" method="post" enctype="multipart/form-data" name="compose" id="DateSelectionForm">
                    <input type="hidden" name="Action"    value="[% Env("Action") %]" />
                    <input type="hidden" name="Subaction" value="Reporting" />
                    [% Data.MonthOption %]
                    [% Data.YearOption %]
                </form>
                <a href="#" id="NavigationSelect" class="CallForAction Fullsize Center SpacingTop" accesskey="g"><span><i class="fa fa-arrow-circle-o-right"></i>[% Translate("Go to date") | html %]</span></a>
[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
$('#NavigationSelect').bind('click', function(){
    $('#DateSelectionForm').submit();
});
//]]></script>
[% END %]

            </div>
        </div>
    </div>

    <div class="ContentColumn">
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("User reports") | html %]</h2>
            </div>
            <div class="Content HorizontalScroll">

[% RenderBlockStart("NoUserDataFoundMsg") %]
                <div id="TimeAccountingEmptyMessageSmall">
                    [% Translate("No data found.") | html %]
                </div>
[% RenderBlockEnd("NoUserDataFoundMsg") %]

[% RenderBlockStart("UserTable") %]
                <table class="DataTable">
                    <thead class="TwoRows">
                        <tr>
                            <th></th>
                            <th class="Center" colspan="4">[% Translate("Monthly total") | html %]</th>
                            <th class="Center" colspan="2">[% Translate("Lifetime total") | html %]</th>
                        </tr>
                        <tr>
                            <th>[% Translate("User") | html %]</th>
                            <th>[% Translate("Working Hours") | html %]</th>
                            <th>[% Translate("Overtime leave") | html %]</th>
                            <th>[% Translate("Vacation") | html %]</th>
                            <th>[% Translate("Sick leave") | html %]</th>
                            <th>[% Translate("Overtime leave") | html %]</th>
                            <th>[% Translate("Vacation remaining") | html %]</th>
                        </tr>
                    </thead>
                    <tbody>
[% RenderBlockStart("User") %]
                        <tr class="MasterActionUser">
                            <td>
                                <a href="[% Env("Baselink") %]Action=AgentTimeAccountingOverview;Year=[% Data.Year | uri %];Month=[% Data.Month | uri %];UserID=[% Data.UserID | uri %]" class="MasterActionLink">
                                    [% Data.User | html %]
                                </a>
                            </td>
                            <td class="Right">[% Data.WorkingHours | html %]</td>
                            <td class="Right">[% Data.Overtime | html %]</td>
                            <td class="Right">[% Data.LeaveDay | html %]</td>
                            <td class="Right">[% Data.Sick | html %]</td>
                            <td class="Right">[% Data.OvertimeTotal | html %]</td>
                            <td class="Right">[% Data.LeaveDayRemaining | html %]</td>
                        </tr>
[% RenderBlockEnd("User") %]
[% RenderBlockStart("UserGrandTotal") %]
                        <tr class="GrandTotal">
                            <td><strong>[% Translate("Total") | html %]</strong></td>
                            <td class="Right"><strong>[% Data.TotalWorkingHours | html %]</strong></td>
                            <td class="Right"><strong>[% Data.TotalOvertime | html %]</strong></td>
                            <td class="Right"><strong>[% Data.TotalLeaveDay | html %]</strong></td>
                            <td class="Right"><strong>[% Data.TotalSick | html %]</strong></td>
                            <td class="Right"><strong>[% Data.TotalOvertimeTotal | html %]</strong></td>
                            <td class="Right"><strong>[% Data.TotalLeaveDayRemaining | html %]</strong></td>
                        </tr>
[% RenderBlockEnd("UserGrandTotal") %]
                    </tbody>
                </table>
 [% RenderBlockEnd("UserTable") %]

            </div>
        </div>

        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Project reports") | html %]
                    <a class="[% Data.ProjectStatusLinkClass %]" href="[% Env("Baselink") %]Action=[% Env("Action") %];Year=[% Data.Year | uri %];Month=[% Data.Month | uri %];ProjectStatusShow=[% Data.ProjectStatusShow | uri %]">
                        ([% Translate(Data.ShowProjects) | html %])
                    </a>
                </h2>
            </div>

            <div class="Content HorizontalScroll">

[% RenderBlockStart("NoProjectDataFoundMsg") %]
                <div id="TimeAccountingEmptyMessageSmall">
                    [% Translate("No data found.") | html %]
                </div>
[% RenderBlockEnd("NoProjectDataFoundMsg") %]

[% RenderBlockStart("ProjectTable") %]
                <table class="DataTable NoHover">
                    <thead>
                        <tr>
                            <th>[% Translate("Project") | html %]</th>
                            <th>[% Translate("Task") | html %]</th>
                            <th>[% Translate("Hours (monthly)") | html %]</th>
                            <th>[% Translate("Hours (Lifetime)") | html %]</th>
                        </tr>
                    </thead>
                    <tbody>
[% RenderBlockStart("Action") %]
                        <tr class="MasterAction" data-project-id="[% Data.ProjectID | html%]">
[% RenderBlockStart("Project") %]
                            <td rowspan="[% Data.RowSpan %]" class="RowSpan">
                                <strong><a href="[% Env("Baselink") %]Action=[% Env("Action") %];Subaction=ReportingProject;ProjectID=[% Data.ProjectID | uri %]" class="[% Data.Class %]">
                                [% Data.Project %]
                            </a></strong>
[% RenderBlockStart("ProjectDescription") %]
                            <br />[% Data.ProjectDescription %]
[% RenderBlockEnd("ProjectDescription") %]
                        </td>
[% RenderBlockEnd("Project") %]
                        <td>[% Data.Action | html %]</td>
                        <td class="Right">[% Data.Hours | html %]</td>
                        <td class="Right">[% Data.HoursTotal | html %]</td>
                    </tr>
[% RenderBlockStart("ActionTotal") %]
                    <tr>
                        <td><strong>[% Translate("Total") | html %]</strong></td>
                        <td class="Right"><strong>[% Data.Hours | html %]</strong></td>
                        <td class="Right"><strong>[% Data.HoursTotal | html %]</strong></td>
                    </tr>
[% RenderBlockEnd("ActionTotal") %]
[% RenderBlockEnd("Action") %]
[% RenderBlockStart("ProjectGrandTotal") %]
                    <tr class="GrandTotal">
                        <td colspan="2"><strong>[% Translate("Grand total") | html %]</strong></td>
                        <td class="Right"><strong>[% Data.TotalHours | html %]</strong></td>
                        <td class="Right"><strong>[% Data.TotalHoursTotal | html %]</strong></td>
                    </tr>
[% RenderBlockEnd("ProjectGrandTotal") %]
                </tbody>
            </table>
[% RenderBlockEnd("ProjectTable") %]

        </div>
    </div>
</div>
</div>
[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
$('.MasterAction').bind('click', function (Event) {
    var $MasterActionLink = $(this).parents().find('.MasterActionLink' + $(this).attr('data-project-id'));
    // only act if the link was not clicked directly
    if (Event.target !== $MasterActionLink.get(0)) {
        window.location = $MasterActionLink.attr('href');
        return false;
    }
});
$('.MasterActionUser').bind('click', function (Event) {
    var $MasterActionLink = $(this).find('.MasterActionLink');
    // only act if the link was not clicked directly
    if (Event.target !== $MasterActionLink.get(0)) {
        window.location = $MasterActionLink.attr('href');
        return false;
    }
});

//]]></script>
[% END %]

# --
# AgentTimeAccountingReportingProject.tt - provides HTML form for time project reporting
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

<div class="MainBox ARIARoleMain LayoutFixedSidebar SidebarFirst">
    <h1 class="Header">[% Translate("Project report") | html %]: [% Data.Project | html %]</h1>

    <div class="SidebarColumn">
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Actions") | html %]</h2>
            </div>
            <div class="Content">
                <ul class="ActionList">
                    <li>
                        <a href="[% Env("Baselink") %]Action=[% Env("Action") %]" class="CallForAction Fullsize Center"><span><i class="fa fa-caret-left"></i>[% Translate("Go to reporting overview") | html %]</span></a>
                    </li>
                </ul>
            </div>
        </div>
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Hint") | html %]</h2>
            </div>
            <div class="Content">
[% IF Data.ShowOnlyActiveUsers == '1' %]
                <p class="FieldExplanation">
                    [% Translate("Currently only active users in this project are shown. To change this behavior, please update setting:") | html %]
                    <a href="[% Env("Baselink") %]Action=AdminSysConfig;Subaction=Edit;SysConfigGroup=TimeAccounting;SysConfigSubGroup=Frontend::Agent::TimeAccoutning::ViewReportingProject">ShowOnlyActiveUsers</a>
                </p>
[% ELSE %]
                <p class="FieldExplanation">
                    [% Translate("Currently all time accounting users are shown. To change this behavior, please update setting:") | html %]
                    <a href="[% Env("Baselink") %]Action=AdminSysConfig;Subaction=Edit;SysConfigGroup=TimeAccounting;SysConfigSubGroup=Frontend::Agent::TimeAccoutning::ViewReportingProject">ShowOnlyActiveUsers</a>
                </p>
[% END %]
            </div>
        </div>
    </div>

    <div class="ContentColumn">
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Project report") | html %]: [% Data.Project | html %]</h2>
            </div>
            <div class="Content">

[% RenderBlockStart("NoUserDataFoundMsg") %]
                <div id="TimeAccountingEmptyMessageSmall">
                    [% Translate("No data found.") | html %]
                </div>
[% RenderBlockEnd("NoUserDataFoundMsg") %]

[% RenderBlockStart("UserTable") %]
                <table class="DataTable DataTableNoHighlight">
                    <thead>
                        <tr>
                            <th>[% Translate("Task") | html %]</th>
[% RenderBlockStart("UserName") %]
                            <th>[% Data.User | html %]</th>
[% RenderBlockEnd("UserName") %]
                            <th>[% Translate("Total") | html %]</th>
                        </tr>
                    </thead>
                    <tbody>
                        <tr>
[% RenderBlockStart("Action") %]
                            <td>[% Data.Action | html %]</td>
[% RenderBlockStart("User") %]
                            <td class="Right">[% Data.Hours | html %]</td>
[% RenderBlockEnd("User") %]
                        </tr>
[% RenderBlockEnd("Action") %]
                        <tr class="GrandTotal">
                            <td><strong>[% Translate("Total") | html %]</strong></td>
[% RenderBlockStart("UserTotal") %]
                            <td class="Right"><strong>[% Data.Total | html %]</strong></td>
[% RenderBlockEnd("UserTotal") %]
[% RenderBlockStart("UserTotalAll") %]
                            <td class="Right"><strong>[% Data.TotalAll | html %]</strong></td>
[% RenderBlockEnd("UserTotalAll") %]
                        </tr>
                    </tbody>
                </table>
 [% RenderBlockEnd("UserTable") %]

            </div>
        </div>

        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("History") | html %]: [% Data.Project | html %]</h2>
            </div>
            <div class="Content">

[% RenderBlockStart("NoProjectDataFoundMsg") %]
                <div id="TimeAccountingEmptyMessageSmall">
                    [% Translate("No data found.") | html %]
                </div>
[% RenderBlockEnd("NoProjectDataFoundMsg") %]

[% RenderBlockStart("ProjectTable") %]
                <table class="DataTable DataTableNoHighlight">
                    <thead>
                        <tr>
                            <th>[% Translate("Date") | html %]</th>
                            <th>[% Translate("User") | html %]</th>
                            <th>[% Translate("Task") | html %]</th>
                            <th>[% Translate("Remark") | html %]</th>
                            <th>[% Translate("Period") | html %]</th>
                        </tr>
                    </thead>
                    <tbody>
[% RenderBlockStart("Row") %]
                        <tr>
                            <td>[% Data.Date | html %]</td>
                            <td>[% Data.User | html %]</td>
                            <td>[% Data.Action | html %]</td>
                            <td>[% Data.Remark | html %]</td>
                            <td class="Right">[% Data.Period | html %]</td>
                        </tr>
[% RenderBlockEnd("Row") %]
                        <tr class="GrandTotal">
[% RenderBlockStart("HistoryTotal") %]
                            <td colspan="4"><strong>[% Translate("Total") | html %]</strong></td>
                            <td class="Right"><strong>[% Data.HistoryTotal | html %]</strong></td>
[% RenderBlockEnd("HistoryTotal") %]
                        </tr>
                    </tbody>
                </table>
[% RenderBlockEnd("ProjectTable") %]
            </div>
        </div>
    </div>
</div>

# --
# AgentTimeAccountingSetting.tt - provides HTML form for time accounting settings
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

[% RenderBlockStart("OverviewProject") %]
<div class="MainBox ARIARoleMain LayoutFixedSidebar SidebarFirst">
    <h1 class="Header">[% Translate("Edit Time Accounting Project Settings") | html %]</h1>

    <div class="SidebarColumn">
[% RenderBlockStart("ActionListProject") %]
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Actions") | html %]</h2>
            </div>
            <div class="Content">
                <ul class="ActionList">
[% RenderBlockStart("ActionAddProject") %]
                    <li>
                        <form action="[% Env("CGIHandle") %]" method="post">
                            <input type="hidden" name="Action" value="[% Env("Action") %]"/>
                            <input type="hidden" name="Subaction" value="AddProject"/>
                            <button class="CallForAction Fullsize Center" type="submit" value="[% Translate("Add") | html %]">
                                <span><i class="fa fa-plus-square"></i>[% Translate("Add project") | html %]</span>
                            </button>
                        </form>
                    </li>
[% RenderBlockEnd("ActionAddProject") %]

[% RenderBlockStart("ActionSettingOverview") %]
                    <li>
                        <a href="[% Env("Baselink") %]Action=[% Env("Action") %]" class="CallForAction Fullsize Center"><span><i class="fa fa-caret-left"></i>[% Translate("Go to settings overview") | html %]</span></a>
                    </li>
[% RenderBlockEnd("ActionSettingOverview") %]
                </ul>
            </div>
        </div>
[% RenderBlockEnd("ActionListProject") %]
    </div>

    <div class="ContentColumn">

[% RenderBlockStart("OverviewUpdateProject") %]
        <div class="WidgetSimple">
            <div class="Header">
[% RenderBlockStart("HeaderAddProject") %]
                <h2>[% Translate("Add Project") | html %]</h2>
[% RenderBlockEnd("HeaderAddProject") %]
[% RenderBlockStart("HeaderEditProject") %]
                <h2>[% Translate("Edit Project Settings") | html %]</h2>
[% RenderBlockEnd("HeaderEditProject") %]
            </div>
            <div class="Content">
                <form action="[% Env("CGIHandle") %]" method="post" name="ProjectUpdate" class="Validate PreventMultipleSubmits">
                    <input type="hidden" name="Action" value="[% Env("Action") %]">
                    <input type="hidden" name="Subaction" value="[% Data.Action | html %]Action">
                    <input type="hidden" name="ID" value="[% Data.ID | html %]"/>
                    <fieldset class="TableLike">

                        <label class="Mandatory" for="Project"><span class="Marker">*</span> [% Translate("Name") | html %]:</label>
                        <div class="Field">
                            <input type="text" name="Project" id="Project" value="[% Data.Project | html %]" class="W50pc Validate_Required [% Data.ProjectInvalid | html %]" maxlength="50"/>
                            <div id="ProjectError" class="TooltipErrorMessage">
                                <p>[% Translate("This field is required.") | html %]</p>
                            </div>

[% RenderBlockStart("ProjectMissingValue") %]
                            <div id="ProjectServerError" class="TooltipErrorMessage">
                                <p>[% Translate("This field is required.") | html %]</p>
                            </div>
[% RenderBlockEnd("ProjectMissingValue") %]

[% RenderBlockStart("ProjectDuplicateName") %]
                            <div id="ProjectServerError" class="TooltipErrorMessage">
                                <p>[% Translate("There is already a project with this name. Please, choose a different one.") | html %]</p>
                            </div>
[% RenderBlockEnd("ProjectDuplicateName") %]

                        </div>
                        <div class="Clear"></div>

                        <label for="ProjectDescription">[% Translate("Description") | html %]:</label>
                        <div class="Field">
                            <input type="text" name="ProjectDescription" id="ProjectDescription" value="[% Data.ProjectDescription | html %]" class="W50pc" maxlength="150"/>
                        </div>
                        <div class="Clear"></div>

                        <label for="ProjectStatus">[% Translate("Status") | html %]:</label>
                        <div class="Field">
                            [% Data.StatusOption %]
                        </div>
                        <div class="Clear"></div>

                        <div class="Field SpacingTop">
                            <button class="Primary CallForAction" type="submit" id="Submit" value="[% Translate("Submit") | html %]"><span><i class="fa fa-check-square-o"></i> [% Translate("Submit") | html %]</span></button>
                            [% Translate("or") | html %]
                            <a href="[% Env("Baselink") %]Action=[% Env("Action") %]">[% Translate("Cancel") | html %]</a>
                        </div>
                        <div class="Clear"></div>
                    </fieldset>
                </form>
            </div>
        </div>
[% RenderBlockEnd("OverviewUpdateProject") %]
    </div>
</div>
[% RenderBlockEnd("OverviewProject") %]

[% RenderBlockStart("Setting") %]
<div class="MainBox ARIARoleMain LayoutFixedSidebar SidebarFirst">
    <h1 class="Header">[% Translate("Edit Time Accounting Settings") | html %]</h1>

    <div class="SidebarColumn">

[% RenderBlockStart("ActionListSetting") %]
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Actions") | html %]</h2>
            </div>
            <div class="Content">
                <ul class="ActionList">
[% RenderBlockStart("ActionAddProject") %]
                    <li>
                        <form action="[% Env("CGIHandle") %]" method="post">
                            <input type="hidden" name="Action" value="[% Env("Action") %]"/>
                            <input type="hidden" name="Subaction" value="AddProject"/>
                            <button class="CallForAction Fullsize Center" type="submit" value="[% Translate("Add") | html %]">
                                <span><i class="fa fa-plus-square"></i>[% Translate("Add project") | html %]</span>
                            </button>
                        </form>
                    </li>
[% RenderBlockEnd("ActionAddProject") %]
[% RenderBlockStart("ActionAddTask") %]
                    <li>
                        <form action="[% Env("CGIHandle") %]" method="post">
                            <input type="hidden" name="Action" value="[% Env("Action") %]"/>
                            <input type="hidden" name="Subaction" value="AddTask"/>
                            <button class="CallForAction Fullsize Center" type="submit" value="[% Translate("Add task") | html %]">
                                <span><i class="fa fa-plus-square"></i>[% Translate("Add task") | html %]</span>
                            </button>
                        </form>
                    </li>
[% RenderBlockEnd("ActionAddTask") %]
[% RenderBlockStart("ActionAddUser") %]
                    <li>
                        <div class="SpacingTop"></div>
                        <form action="[% Env("CGIHandle") %]" method="post">
                            <input type="hidden" name="Action" value="[% Env("Action") %]"/>
                            <input type="hidden" name="Subaction" value="AddUser"/>
                            [% Data.NewUserOption %]
                            <button class="CallForAction Fullsize Center" type="submit" value="[% Translate("New user") | html %]">
                                <span><i class="fa fa-user"></i>[% Translate("New user") | html %]</span>
                            </button>
                        </form>
                    </li>
[% RenderBlockEnd("ActionAddUser") %]
[% RenderBlockStart("ActionOverviewSetting") %]
                    <li>
                        <a href="[% Env("Baselink") %]Action=[% Env("Action") %]" class="CallForAction Fullsize Center"><span><i class="fa fa-caret-left"></i>[% Translate("Go to settings overview") | html %]</span></a>
                    </li>
[% RenderBlockEnd("ActionOverviewSetting") %]

                </ul>
            </div>
        </div>
[% RenderBlockEnd("ActionListSetting") %]

[% RenderBlockStart("ProjectFilter") %]
        <div class="WidgetSimple">
            <div class="Header">
                <h2><label for="FilterProjects">[% Translate("Filter for Projects") | html %]</label></h2>
            </div>
            <div class="Content">
                <input type="text" id="FilterProjects" class="W50pc" name="FilterProjects" value="" title="[% Translate("Filter for Projects") | html %]" />
            </div>
        </div>
[% RenderBlockEnd("ProjectFilter") %]

[% RenderBlockStart("TaskFilter") %]
        <div class="WidgetSimple">
            <div class="Header">
                <h2><label for="FilterTasks">[% Translate("Filter for Tasks") | html %]</label></h2>
            </div>
            <div class="Content">
                <input type="text" id="FilterTasks" class="W50pc" name="FilterTasks" value="" title="[% Translate("Filter for Tasks") | html %]" />
            </div>
        </div>
[% RenderBlockEnd("TaskFilter") %]

[% RenderBlockStart("UserFilter") %]
        <div class="WidgetSimple">
            <div class="Header">
                <h2><label for="FilterUsers">[% Translate("Filter for Users") | html %]</label></h2>
            </div>
            <div class="Content">
                <input type="text" id="FilterUsers" class="W50pc" name="FilterUsers" value="" title="[% Translate("Filter for Users") | html %]" />
            </div>
        </div>
[% RenderBlockEnd("UserFilter") %]

[% RenderBlockStart("Reference") %]
        <div class="WidgetSimple SpacingTop">
            <div class="Header">
                <h2>[% Translate("Reference") | html %]</h2>
            </div>
            <div class="Content">
                <ul>
                    <li>[% Translate("Required fields are marked with a \"*\".") | html %]</li>
                </ul>
            </div>
        </div>
[% RenderBlockEnd("Reference") %]

    </div>

    <div class="ContentColumn">
[% RenderBlockStart("OverviewResultProject") %]
        <div class="WidgetSimple">
            <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("Project List") | html %]</h2>
            </div>
            <div class="Content">

[% RenderBlockStart("NoProjectDataFoundMsg") %]
                <div id="TimeAccountingEmptyMessageSmall">
                    [% Translate("No data found.") | html %]
                </div>
[% RenderBlockEnd("NoProjectDataFoundMsg") %]

[% RenderBlockStart("OverviewResultProjectTable") %]
                <table class="DataTable" id="Projects">
                    <thead>
                        <tr>
                            <th>[% Translate("Project") | html %]</th>
                            <th>[% Translate("Comment") | html %]</th>
                            <th>[% Translate("Status") | html %]</th>
                        </tr>
                    </thead>
                    <tbody>
                        <tr class="FilterMessage Hidden">
                            <td colspan="2">
                                [% Translate("No matches found.") | html %]
                            </td>
                        </tr>
[% RenderBlockStart("OverviewResultProjectRow") %]
                        <tr>
                            <td><a class="AsBlock" href="[% Env("Baselink") %]Action=[% Env("Action") %];Subaction=EditProject;ID=[% Data.ProjectID | uri %]">[% Data.Project | html %]</a></td>
                            <td title="[% Data.ProjectDescription | html %]">[% Data.ProjectDescription | truncate(40) | html %]</td>
                            <td>[% Translate(Data.Status) | html %]</td>
                        </tr>
[% RenderBlockEnd("OverviewResultProjectRow") %]
                    </tbody>
                </table>
[% RenderBlockEnd("OverviewResultProjectTable") %]
            </div>
        </div>
[% RenderBlockEnd("OverviewResultProject") %]

[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
    Core.UI.Table.InitTableFilter($('#FilterProjects'), $('#Projects'));
//]]></script>
[% END %]

[% RenderBlockStart("OverviewResultSetting") %]
        <div class="WidgetSimple">
            <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("Task List") | html %]</h2>
            </div>
            <div class="Content">

[% RenderBlockStart("NoSettingDataFoundMsg") %]
                <div id="TimeAccountingEmptyMessageSmall">
                    [% Translate("No data found.") | html %]
                </div>
[% RenderBlockEnd("NoSettingDataFoundMsg") %]

[% RenderBlockStart("OverviewResultSettingTable") %]
                <table class="DataTable" id="Tasks">
                    <thead>
                        <tr>
                            <th>[% Translate("Task") | html %]</th>
                            <th>[% Translate("Status") | html %]</th>
                        </tr>
                    </thead>
                    <tbody>
                        <tr class="FilterMessage Hidden">
                            <td colspan="2">
                                [% Translate("No matches found.") | html %]
                            </td>
                        </tr>

[% RenderBlockStart("OverviewResultSettingRow") %]
                        <tr>
                            <td><a class="AsBlock" href="[% Env("Baselink") %]Action=[% Env("Action") %];Subaction=EditTask;ActionID=[% Data.ActionID | uri %]">[% Data.Action | html %]</a></td>
                            <td>[% Translate(Data.Status) | html %]</td>
                        </tr>
[% RenderBlockEnd("OverviewResultSettingRow") %]
                    </tbody>
                </table>
[% RenderBlockEnd("OverviewResultSettingTable") %]
            </div>
        </div>
[% RenderBlockEnd("OverviewResultSetting") %]

[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
    Core.UI.Table.InitTableFilter($('#FilterTasks'), $('#Tasks'));
//]]></script>
[% END %]

[% RenderBlockStart("OverviewUpdateTask") %]
        <div class="WidgetSimple">
            <div class="Header">
[% RenderBlockStart("HeaderAddTask") %]
                <h2>[% Translate("Add Task") | html %]</h2>
[% RenderBlockEnd("HeaderAddTask") %]
[% RenderBlockStart("HeaderEditTask") %]
                <h2>[% Translate("Edit Task Settings") | html %]</h2>
[% RenderBlockEnd("HeaderEditTask") %]
            </div>
            <div class="Content">
                <form action="[% Env("CGIHandle") %]" method="post" name="TaskUpdate" class="Validate PreventMultipleSubmits">
                    <input type="hidden" name="Action" value="[% Env("Action") %]">
                    <input type="hidden" name="Subaction" value="[% Data.Action | html %]Action">
                    <input type="hidden" name="ActionID" value="[% Data.ActionID | html %]"/>
                    <fieldset class="TableLike">

                        <label class="Mandatory" for="Task"><span class="Marker">*</span> [% Translate("Task") | html %]:</label>
                        <div class="Field">
                            <input type="text" name="Task" id="Task" value="[% Data.Task | html %]" class="W50pc Validate_Required [% Data.TaskInvalid | html %]" maxlength="50"/>
                            <div id="TaskError" class="TooltipErrorMessage">
                                <p>[% Translate("This field is required.") | html %]</p>
                            </div>

[% RenderBlockStart("TaskMissingValue") %]
                            <div id="TaskServerError" class="TooltipErrorMessage">
                                <p>[% Translate("This field is required.") | html %]</p>
                            </div>
[% RenderBlockEnd("TaskMissingValue") %]

[% RenderBlockStart("TaskDuplicateName") %]
                            <div id="TaskServerError" class="TooltipErrorMessage">
                                <p>[% Translate("There is already a task with this name. Please, choose a different one.") | html %]</p>
                            </div>
[% RenderBlockEnd("TaskDuplicateName") %]
                        </div>
                        <div class="Clear"></div>

                        <label for="TaskStatus">[% Translate("Status") | html %]:</label>
                        <div class="Field">
                            [% Data.StatusOption %]
                        </div>
                        <div class="Clear"></div>

                        <div class="Field SpacingTop">
                            <button class="Primary CallForAction" type="submit" id="Submit" value="[% Translate("Submit") | html %]"><span><i class="fa fa-check-square-o"></i> [% Translate("Submit") | html %]</span></button>
                            [% Translate("or") | html %]
                            <a href="[% Env("Baselink") %]Action=[% Env("Action") %]">[% Translate("Cancel") | html %]</a>
                        </div>
                        <div class="Clear"></div>
                    </fieldset>
                </form>
            </div>
        </div>
[% RenderBlockEnd("OverviewUpdateTask") %]

[% RenderBlockStart("OverviewResultUser") %]
        <div class="WidgetSimple">
            <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("User List") | html %]</h2>
            </div>
            <div class="Content">

[% RenderBlockStart("NoUserDataFoundMsg") %]
                <div id="TimeAccountingEmptyMessageSmall">
                    [% Translate("No data found.") | html %]
                </div>
[% RenderBlockEnd("NoUserDataFoundMsg") %]

[% RenderBlockStart("OverviewResultUserTable") %]
                <table class="DataTable" id="Users">
                    <thead>
                        <tr>
                            <th>[% Translate("User") | html %]</th>
                            <th>[% Translate("Comment") | html %]</th>
                            <th>[% Translate("Calendar") | html %]</th>
                        </tr>
                    </thead>
                    <tbody>
                        <tr class="FilterMessage Hidden">
                            <td colspan="3">
                                [% Translate("No matches found.") | html %]
                            </td>
                        </tr>

[% RenderBlockStart("OverviewResultUserRow") %]
                        <tr>
                            <td><a class="AsBlock" href="[% Env("Baselink") %]Action=[% Env("Action") %];Subaction=EditUser;UserID=[% Data.UserID | uri %]">[% Data.User | html %]</a></td>
                            <td>[% Data.Comment %]</td>
                            <td>[% Translate(Data.Calendar) | html %]</td>
                        </tr>
[% RenderBlockEnd("OverviewResultUserRow") %]
                    </tbody>
                </table>
[% RenderBlockEnd("OverviewResultUserTable") %]
            </div>
        </div>
[% RenderBlockEnd("OverviewResultUser") %]

[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
    Core.UI.Table.InitTableFilter($('#FilterUsers'), $('#Users'));
    Core.UI.InitWidgetActionToggle();
//]]></script>
[% END %]

[% RenderBlockStart("OverviewUpdateUser") %]
        <div class="WidgetSimple">
            <div class="Header">
[% RenderBlockStart("HeaderAddUser") %]
                <h2>[% Translate("New User Settings") | html %]: [% Data.UserFirstname | html %] [% Data.UserLastname | html %] ([% Data.UserLogin | html %])</h2>
[% RenderBlockEnd("HeaderAddUser") %]
[% RenderBlockStart("HeaderEditUser") %]
                <h2>[% Translate("Edit User Settings") | html %]</h2>
[% RenderBlockEnd("HeaderEditUser") %]
            </div>
            <div class="Content">
                <form action="[% Env("CGIHandle") %]" method="post" name="UserUpdate" class="Validate PreventMultipleSubmits">
                    <input type="hidden" name="Action" value="[% Env("Action") %]" />
                    <input type="hidden" name="Subaction" value="[% Data.Subaction | html %]" />
                    <input type="hidden" name="UserID" value="[% Data.UserID | html %]" />

                    <fieldset class="TableLike">
                        <label for="Name">[% Translate("Name") | html %]:</label>
                        <div class="Value">[% Data.UserFirstname | html %] [% Data.UserLastname | html %]</div>
                        <div class="Clear"></div>

                        <label for="Name">[% Translate("Username") | html %]:</label>
                        <div class="Value">[% Data.UserLogin | html %]</div>
                        <div class="Clear"></div>

                        <label for="Description">[% Translate("Comments") | html %]:</label>
                        <div class="Field">
                            <textarea rows="1" name="Description" id="Description" cols="40">[% Data.Description %]</textarea>
                        </div>
                        <div class="Clear"></div>

                        <div class="Field">
                            <input type="checkbox" name="ShowOvertime" id="ShowOvertime" value="1" title="[% Translate("Show Overtime") | html %]" [% Data.ShowOvertime %] />[% Translate("Show Overtime") | html %]
                        </div>
                        <div class="Clear"></div>

                        <div class="Field">
                            <input type="checkbox" name="CreateProject" id="CreateProject" value="1" title="Translate("Allow project creation") | html %]" [% Data.CreateProject %] />[% Translate("Allow project creation") | html %]
                        </div>
                        <div class="Clear"></div>

                        <label for="Calendar">[% Translate("Calendar") | html %]:</label>
                        <div class="Field">
                            [% Data.CalendarOption %]
                        </div>
                        <div class="Clear"></div>
                    </fieldset>

                    <table class="DataTable NoHover">
                        <thead>
                            <tr>
                                <th><span class="Marker">*</span> [% Translate("Period Begin") | html %]</th>
                                <th><span class="Marker">*</span> [% Translate("Period End") | html %]</th>
                                <th><span class="Marker">*</span> [% Translate("Days of Vacation") | html %]</th>
                                <th>[% Translate("Hours per Week") | html %]</th>
                                <th>[% Translate("Authorized Overtime") | html %]</th>
                                <th>[% Translate("Status") | html %]</th>
                            </tr>
                        </thead>
                        <tbody>
[% RenderBlockStart("PeriodOverviewRow") %]
                            <tr>
                                <td>
                                    <input type="text" id="DateStart-[% Data.Period | html %]" name="DateStart[[% Data.Period | html %]]" value="[% Data.DateStart | html %]" class="DatepickerElement Validate_Required [% Data.DateStartInvalid | html %]" title="[% Translate("Start Date") | html %]" />
                                    <div id="DateStart-[% Data.Period | html %]Error" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %] [% Translate("Please insert a valid date.") | html %]</p></div>
[% RenderBlockStart("DateStartInvalid") %]
                                    <div id="DateStart-[% Data.Period | html %]ServerError" class="TooltipErrorMessage"><p>[% Translate("Invalid date!") | html %]</p></div>
[% RenderBlockEnd("DateStartInvalid") %]
[% RenderBlockStart("DateStartMissingValue") %]
                                    <div id="DateStart-[% Data.Period | html %]ServerError" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
[% RenderBlockEnd("DateStartMissingValue") %]
                                </td>
                                <td>
                                    <input type="text" id="DateEnd-[% Data.Period | html %]" name="DateEnd[[% Data.Period | html %]]" value="[% Data.DateEnd | html %]" class="DatepickerElement Validate_Required [% Data.DateEndInvalid | html %]" title="[% Translate("End Date") | html %]" />
                                    <div id="DateEnd-[% Data.Period | html %]Error" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %] [% Translate("Please insert a valid date.") | html %]</p></div>
[% RenderBlockStart("DateEndInvalid") %]
                                    <div id="DateEnd-[% Data.Period | html %]ServerError" class="TooltipErrorMessage"><p>[% Translate("Invalid date!") | html %]</p></div>
[% RenderBlockEnd("DateEndInvalid") %]
[% RenderBlockStart("DateEndMissingValue") %]
                                    <div id="DateEnd-[% Data.Period | html %]ServerError" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
[% RenderBlockEnd("DateEndMissingValue") %]
[% RenderBlockStart("DateEndBeforeDateStart") %]
                                    <div id="DateEnd-[% Data.Period | html %]ServerError" class="TooltipErrorMessage"><p>[% Translate("Period end must be after period begin.") | html %]</p></div>
[% RenderBlockEnd("DateEndBeforeDateStart") %]
                                </td>
                                <td>
                                    <input type="text" id="LeaveDays-[% Data.Period | html %]" name="LeaveDays[[% Data.Period | html %]]" value="[% Data.LeaveDays | html %]" class="Validate_Required [% Data.LeaveDaysInvalid | html %]" title="[% Translate("Leave Days") | html %]" />
                                    <div id="LeaveDays-[% Data.Period | html %]Error" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                                    <div id="LeaveDays-[% Data.Period | html %]ServerError" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                                </td>
                                <td>
                                    <input type="text" id="WeeklyHours-[% Data.Period | html %]" name="WeeklyHours[[% Data.Period | html %]]" value="[% Data.WeeklyHours | html %]" title="[% Translate("Weekly Hours") | html %]" />
                                </td>
                                <td>
                                    <input type="text" id="Overtime-[% Data.Period | html %]" name="Overtime[[% Data.Period | html %]]" value="[% Data.Overtime | html %]" title="[% Translate("Overtime") | html %]" />
                                </td>
                                <td>
                                    [% Data.PeriodStatusOption %]
                                </td>
                            </tr>
[% RenderBlockEnd("PeriodOverviewRow") %]

[% RenderBlockStart("PeriodOverviewRowNoData") %]
                            <tr>
                                <td colspan="6">
                                    [% Translate("No time periods found.") | html %]
                                </td>
                            </tr>
[% RenderBlockEnd("PeriodOverviewRowNoData") %]
                        </tbody>
                    </table>

                    <div class="W100pc Right SpacingTopSmall">
                        <button type="submit" title="[% Translate("Add time period") | html %]" value="[% Translate("Add time period") | html %]" name="AddPeriod" class="CallForAction Plus"><span><i class="fa fa-plus-square"></i> [% Translate("Add time period") | html %]</span></button>
                    </div>

                    <fieldset class="TableLike">
                        <div class="Field SpacingTop">
                            <button class="Primary CallForAction" type="submit" value="[% Translate("Submit") | html %]" name="SubmitUserData"><span><i class="fa fa-check-square-o"></i> [% Translate("Submit") | html %]</span></button>
                            [% Translate("or") | html %]
                            <a href="[% Env("Baselink") %]Action=[% Env("Action") %]">[% Translate("Cancel") | html %]</a>
                        </div>
                    </fieldset>
                </form>
            </div>
        </div>
[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
/*global TimeAccounting: true */
    TimeAccounting.Agent.Datepicker.Init($('.DatepickerElement'), {
        DateInFuture: false,
        WeekDayStart: 1
    });
//]]></script>
[% END %]
[% RenderBlockEnd("OverviewUpdateUser") %]
    </div>
</div>

[% RenderBlockEnd("Setting") %]

# --
# AgentTimeAccountingView.tt - provides HTML for view inserts of one day
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

<div class="MainBox ARIARoleMain LayoutFixedSidebar SidebarFirst">
    <h1 class="Header">[% Translate("View Time Record") | html %]
[% RenderBlockStart("User") %]
        - [% Translate("View of ") | html %] [% Data.User | html %]
[% RenderBlockEnd("User") %]
    </h1>

    <div class="SidebarColumn">
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Actions") | html %]</h2>
            </div>
            <div class="Content">
                <ul class="ActionList">
                    <li>
                        <a href="[% Env("Baselink") %]Action=AgentTimeAccountingOverview;Year=[% Data.Year | uri %];Month=[% Data.Month | uri %]" class="CallForAction Fullsize Center"><span><i class="fa fa-caret-left"></i>[% Translate("Go to overview") | html %]</span></a>
                    </li>
                </ul>
            </div>
        </div>
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Date Navigation") | html %]</h2>
            </div>
            <div class="Content">
                <div class="MonthSelection">
                    <a class="Arrow" title="[% Translate("Previous day") | html %]" href="[% Env("Baselink") %]Action=[% Env("Action") %];Year=[% Data.YearBack | uri %];Month=[% Data.MonthBack | uri %];Day=[% Data.DayBack | uri %];UserID=[% Data.UserID | uri %]"><i class="fa fa-caret-left"></i></a>
                    <a class="Arrow" title="[% Translate("Next day") | html %]" href="[% Env("Baselink") %]Action=[% Env("Action") %];Year=[% Data.YearNext | uri %];Month=[% Data.MonthNext | uri %];Day=[% Data.DayNext | uri %];UserID=[% Data.UserID | uri %]"><i class="fa fa-caret-right"></i></a>
                    [% Data.Year | html %]-[% Data.Month | html %]-[% Data.Day | html %]
                </div>
                <div class="Clear"></div>
                <form action="[% Env("CGIHandle") %]" method="post" enctype="multipart/form-data" name="DateSelection" class="Validate" id="DateSelectionForm">
                    <input type="hidden" name="Action" value="[% Env("Action") %]" />
                    <input type="hidden" name="Subaction" value="View" />
                    <input type="hidden" name="UserID"    value="[% Data.UserID | html %]" />
                    [% Data.DateSelection %]
                </form>
                <a href="#" id="NavigationSelect" class="CallForAction Fullsize Center SpacingTop"><span><i class="fa fa-arrow-circle-o-right"></i>[% Translate("Go to date") | html %]</span></a>
[% WRAPPER JSOnDocumentComplete %]
<script type="text/javascript">//<![CDATA[
$('#NavigationSelect').bind('click', function(){
    $('#DateSelectionForm').submit();
});
//]]></script>
[% END %]

            </div>
        </div>
    </div>

    <div class="ContentColumn">
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Date") | html %]: [% Translate(Data.Weekday_to_Text) | html %] [% Data.Date | html %]</h2>
            </div>
            <div class="Content">
                <table class="DataTable DataTableNoHighlight">
                    <thead>
                        <tr>
                            <th>[% Translate("Project") | html %]</th>
                            <th>[% Translate("Task") | html %]</th>
                            <th>[% Translate("Remark") | html %]</th>
                            <th>[% Translate("Start") | html %]</th>
                            <th>[% Translate("End") | html %]</th>
                            <th>[% Translate("Period") | html %]</th>
                        </tr>
                    </thead>
                    <tbody>
[% RenderBlockStart("Unit") %]
                        <tr>
                            <td>[% Data.Project | html %]</td>
                            <td>[% Data.Action | html %]</td>
                            <td>[% Data.Remark | html %]</td>
                            <td class="Right">[% Data.StartTime | html %]</td>
                            <td class="Right">[% Data.EndTime | html %]</td>
                            <td class="Right">[% Data.Period | html %]</td>
                        </tr>
[% RenderBlockEnd("Unit") %]

[% RenderBlockStart("Total") %]
                        <tr>
                            <td colspan="4"></td>
                            <td><strong>[% Translate("Total") | html %]:</strong></td>
                            <td class="Right"><strong>[% Data.Total | html %]</strong></td>

                        </tr>
[% RenderBlockEnd("Total") %]

[% RenderBlockStart("NoDataFound") %]
                        <tr>
                            <td colspan="6">[% Translate("No data found for this day.") | html %]</td>
                        </tr>
[% RenderBlockEnd("NoDataFound") %]

                    </tbody>
                </table>

[% RenderBlockStart("OtherTimes") %]
                <div>
                    <input type="checkbox" value="-2" id="LeaveDay" name="LeaveDay" title="[% Translate("On vacation") | html %]" [% Data.LeaveDay %] disabled />
                    <label for="LeaveDay">[% Translate("On vacation") | html %]</label>
                    <input type="checkbox" value="-1" id="Sick" name="Sick" title="[% Translate("On sick leave") | html %]" [% Data.Sick %] disabled />
                    <label for="Sick">[% Translate("On sick leave") | html %]</label>
                    <input type="checkbox" value="-3" id="Overtime" name="Overtime" title="[% Translate("On overtime leave") | html %]" [% Data.Overtime %] disabled />
                    <label for="Overtime">[% Translate("On overtime leave") | html %]</label>
                </div>
[% RenderBlockEnd("OtherTimes") %]

                <div class="Clear"></div>
[% RenderBlockStart("Vacation") %]
                <div class="SpacingTopSmall">
                    <p>
                        [% Data.Vacation | html %]
                    </p>
                </div>
[% RenderBlockEnd("Vacation") %]
                <div class="Clear"></div>
            </div>
        </div>
    </div>
</div>

IyAtLQojIEtlcm5lbC9PdXRwdXQvSFRNTC9Ob3RpZmljYXRpb25UaW1lQWNjb3VudGluZy5wbQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpPdXRwdXQ6OkhUTUw6Ok5vdGlmaWNhdGlvblRpbWVBY2NvdW50aW5nOwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKb3VyIEBPYmplY3REZXBlbmRlbmNpZXMgPSAoCiAgICAnS2VybmVsOjpTeXN0ZW06OlRpbWUnLAogICAgJ0tlcm5lbDo6U3lzdGVtOjpUaW1lQWNjb3VudGluZycsCik7CgpzdWIgbmV3IHsKICAgIG15ICggJFR5cGUsICVQYXJhbSApID0gQF87CgogICAgIyBhbGxvY2F0ZSBuZXcgaGFzaCBmb3Igb2JqZWN0CiAgICBteSAkU2VsZiA9IHt9OwogICAgYmxlc3MoICRTZWxmLCAkVHlwZSApOwoKICAgICMgZ2V0IG5lZWRlZCBvYmplY3RzCiAgICBmb3IgbXkgJE5lZWRlZCAocXcoTGF5b3V0T2JqZWN0IFVzZXJJRCkpIHsKICAgICAgICAkU2VsZi0+eyROZWVkZWR9ID0gJFBhcmFteyROZWVkZWR9IHx8IGRpZSAiR290IG5vICROZWVkZWQhIjsKICAgIH0KCiAgICByZXR1cm4gJFNlbGY7Cn0KCnN1YiBSdW4gewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGdldCB0aW1lIG9iamVjdAogICAgbXkgJFRpbWVPYmplY3QgPSAkS2VybmVsOjpPTS0+R2V0KCdLZXJuZWw6OlN5c3RlbTo6VGltZScpOwoKICAgIG15ICggJFNlYywgJE1pbiwgJEhvdXIsICREYXksICRNb250aCwgJFllYXIgKSA9ICRUaW1lT2JqZWN0LT5TeXN0ZW1UaW1lMkRhdGUoCiAgICAgICAgU3lzdGVtVGltZSA9PiAkVGltZU9iamVjdC0+U3lzdGVtVGltZSgpCiAgICApOwoKICAgICMgZ2V0IHRpbWUgYWNjb3VudGluZyBvYmplY3QKICAgIG15ICRUaW1lQWNjb3VudGluZ09iamVjdCA9ICRLZXJuZWw6Ok9NLT5HZXQoJ0tlcm5lbDo6U3lzdGVtOjpUaW1lQWNjb3VudGluZycpOwoKICAgIG15ICVVc2VyID0gJFRpbWVBY2NvdW50aW5nT2JqZWN0LT5Vc2VyQ3VycmVudFBlcmlvZEdldCgKICAgICAgICBZZWFyICA9PiAkWWVhciwKICAgICAgICBNb250aCA9PiAkTW9udGgsCiAgICAgICAgRGF5ICAgPT4gJERheSwKICAgICk7CiAgICBpZiAoICRVc2VyeyAkU2VsZi0+e1VzZXJJRH0gfSApIHsKICAgICAgICBteSAlSW5jb21wbGV0ZVdvcmtpbmdEYXlzID0gJFRpbWVBY2NvdW50aW5nT2JqZWN0LT5Xb3JraW5nVW5pdHNDb21wbGV0bmVzc0NoZWNrKAogICAgICAgICAgICBVc2VySUQgPT4gJFNlbGYtPntVc2VySUR9LAogICAgICAgICk7CgogICAgICAgICMgcmVkaXJlY3QgaWYgaW5jb21wbGV0ZSB3b3JraW5nIGRheSBhcmUgb3V0IG9mIHJhbmdlCiAgICAgICAgaWYgKCAkSW5jb21wbGV0ZVdvcmtpbmdEYXlze1dhcm5pbmd9ICkgewoKICAgICAgICAgICAgcmV0dXJuICRTZWxmLT57TGF5b3V0T2JqZWN0fS0+Tm90aWZ5KAogICAgICAgICAgICAgICAgSW5mbyAgICAgPT4gJ1BsZWFzZSBpbnNlcnQgeW91ciB3b3JraW5nIGhvdXJzIScsCiAgICAgICAgICAgICAgICBQcmlvcml0eSA9PiAnRXJyb3InCiAgICAgICAgICAgICk7CiAgICAgICAgfQogICAgfQoKICAgIHJldHVybiAnJzsKfQoKMTsK
IyAtLQojIEtlcm5lbC9PdXRwdXQvSFRNTC9Ub29sQmFySW5jb21wbGV0ZVdvcmtpbmdEYXlzLnBtCiMgQ29weXJpZ2h0IChDKSAyMDAxLTIwMTQgT1RSUyBBRywgaHR0cDovL290cnMuY29tLwojIC0tCiMgVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKIyB0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CiMgZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dC4KIyAtLQoKcGFja2FnZSBLZXJuZWw6Ok91dHB1dDo6SFRNTDo6VG9vbEJhckluY29tcGxldGVXb3JraW5nRGF5czsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnVzZSBLZXJuZWw6OlN5c3RlbTo6VGltZUFjY291bnRpbmc7CgpzdWIgbmV3IHsKICAgIG15ICggJFR5cGUsICVQYXJhbSApID0gQF87CgogICAgIyBhbGxvY2F0ZSBuZXcgaGFzaCBmb3Igb2JqZWN0CiAgICBteSAkU2VsZiA9IHt9OwogICAgYmxlc3MoICRTZWxmLCAkVHlwZSApOwoKICAgICMgZ2V0IG5lZWRlZCBvYmplY3RzCiAgICBmb3IgbXkgJE5lZWRlZCAoCiAgICAgICAgcXcoCiAgICAgICAgQ29uZmlnT2JqZWN0IExvZ09iamVjdCBEQk9iamVjdCBUaWNrZXRPYmplY3QgVXNlck9iamVjdCBHcm91cE9iamVjdCBMYXlvdXRPYmplY3QgVXNlcklECiAgICAgICAgVGltZU9iamVjdAogICAgICAgICkKICAgICAgICApCiAgICB7CiAgICAgICAgJFNlbGYtPnskTmVlZGVkfSA9ICRQYXJhbXskTmVlZGVkfSB8fCBkaWUgIkdvdCBubyAkTmVlZGVkISI7CiAgICB9CgogICAgIyBjcmVhdGUgbmVlZGVkIG9iamVjdHMKICAgICRTZWxmLT57VGltZUFjY291bnRpbmdPYmplY3R9ID0gS2VybmVsOjpTeXN0ZW06OlRpbWVBY2NvdW50aW5nLT5uZXcoJVBhcmFtKTsKCiAgICByZXR1cm4gJFNlbGY7Cn0KCnN1YiBSdW4gewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGRlZmluZSBhY3Rpb24sIGdyb3VwLCBsYWJlbCwgaW1hZ2UgYW5kIHByaW8KICAgIG15ICRBY3Rpb24gPSAnQWdlbnRUaW1lQWNjb3VudGluZ0VkaXQnOwogICAgbXkgJEdyb3VwICA9ICd0aW1lX2FjY291bnRpbmcnOwoKICAgICMgZG8gbm90IHNob3cgaWNvbiBpZiBmcm9udGVuZCBtb2R1bGUgaXMgbm90IHJlZ2lzdGVyZWQKICAgIHJldHVybiBpZiAhJFNlbGYtPntDb25maWdPYmplY3R9LT5HZXQoJ0Zyb250ZW5kOjpNb2R1bGUnKS0+eyRBY3Rpb259OwoKICAgICMgZ2V0IHRoZSBncm91cCBpZAogICAgbXkgJEdyb3VwSUQgPSAkU2VsZi0+e0dyb3VwT2JqZWN0fS0+R3JvdXBMb29rdXAoIEdyb3VwID0+ICRHcm91cCApOwoKICAgICMgZGVueSBhY2Nlc3MsIHdoZW4gdGhlIGdyb3VwIGlzIG5vdCBmb3VuZAogICAgcmV0dXJuIGlmICEkR3JvdXBJRDsKCiAgICAjIGdldCB1c2VyIGdyb3Vwcywgd2hlcmUgdGhlIHVzZXIgaGFzIHRoZSBhcHByb3ByaWF0ZSBwcml2aWxlZ2UKICAgIG15ICVHcm91cHMgPSAkU2VsZi0+e0dyb3VwT2JqZWN0fS0+R3JvdXBNZW1iZXJMaXN0KAogICAgICAgIFVzZXJJRCA9PiAkU2VsZi0+e1VzZXJJRH0sCiAgICAgICAgVHlwZSAgID0+ICdydycsCiAgICAgICAgUmVzdWx0ID0+ICdIQVNIJywKICAgICk7CgogICAgIyBkZW55IGFjY2VzcyBpZiB0aGUgYWdlbnQgZG9lc24ndCBoYXZlIHRoZSBhcHByb3ByaWF0ZSB0eXBlIGluIHRoZSBhcHByb3ByaWF0ZSBncm91cAogICAgcmV0dXJuIGlmICEkR3JvdXBzeyRHcm91cElEfTsKCiAgICBteSAoICRTZWMsICRNaW4sICRIb3VyLCAkRGF5LCAkTW9udGgsICRZZWFyICkgPSAkU2VsZi0+e1RpbWVPYmplY3R9LT5TeXN0ZW1UaW1lMkRhdGUoCiAgICAgICAgU3lzdGVtVGltZSA9PiAkU2VsZi0+e1RpbWVPYmplY3R9LT5TeXN0ZW1UaW1lKCksCiAgICApOwoKICAgIG15ICVVc2VyQ3VycmVudFBlcmlvZCA9ICRTZWxmLT57VGltZUFjY291bnRpbmdPYmplY3R9LT5Vc2VyQ3VycmVudFBlcmlvZEdldCgKICAgICAgICBZZWFyICA9PiAkWWVhciwKICAgICAgICBNb250aCA9PiAkTW9udGgsCiAgICAgICAgRGF5ICAgPT4gJERheSwKICAgICk7CgogICAgIyBkZW55IGFjY2VzcywgaWYgdXNlciBoYXMgbm8gdmFsaWQgcGVyaW9kCiAgICByZXR1cm4gaWYgISRVc2VyQ3VycmVudFBlcmlvZHsgJFNlbGYtPntVc2VySUR9IH07CgogICAgIyBnZXQgdGhlIG51bWJlciBvZiBpbmNvbXBsZXRlIHdvcmtpbmcgZGF5cwogICAgbXkgJENvdW50ICAgICAgICAgICAgICAgICA9IDA7CiAgICBteSAlSW5jb21wbGV0ZVdvcmtpbmdEYXlzID0gJFNlbGYtPntUaW1lQWNjb3VudGluZ09iamVjdH0tPldvcmtpbmdVbml0c0NvbXBsZXRuZXNzQ2hlY2soCiAgICAgICAgVXNlcklEID0+ICRTZWxmLT57VXNlcklEfSwKICAgICk7CgogICAgWUVBUklEOgogICAgZm9yIG15ICRZZWFySUQgKCBzb3J0IGtleXMgJXsgJEluY29tcGxldGVXb3JraW5nRGF5c3tJbmNvbXBsZXRlfSB9ICkgewoKICAgICAgICBuZXh0IFlFQVJJRCBpZiAhJFllYXJJRDsKICAgICAgICBuZXh0IFlFQVJJRCBpZiAhJEluY29tcGxldGVXb3JraW5nRGF5c3tJbmNvbXBsZXRlfXskWWVhcklEfTsKICAgICAgICBuZXh0IFlFQVJJRCBpZiByZWYgJEluY29tcGxldGVXb3JraW5nRGF5c3tJbmNvbXBsZXRlfXskWWVhcklEfSBuZSAnSEFTSCc7CgogICAgICAgICMgZXh0cmFjdCB5ZWFyCiAgICAgICAgbXkgJVllYXIgPSAleyAkSW5jb21wbGV0ZVdvcmtpbmdEYXlze0luY29tcGxldGV9eyRZZWFySUR9IH07CgogICAgICAgIE1PTlRIOgogICAgICAgIGZvciBteSAkTW9udGhJRCAoIHNvcnQga2V5cyAlWWVhciApIHsKCiAgICAgICAgICAgIG5leHQgTU9OVEggaWYgISRNb250aElEOwogICAgICAgICAgICBuZXh0IE1PTlRIIGlmICEkWWVhcnskTW9udGhJRH07CiAgICAgICAgICAgIG5leHQgTU9OVEggaWYgcmVmICRZZWFyeyRNb250aElEfSBuZSAnSEFTSCc7CgogICAgICAgICAgICAjIGV4dHJhY3QgbW9udGgKICAgICAgICAgICAgbXkgJU1vbnRoID0gJXsgJFllYXJ7JE1vbnRoSUR9IH07CgogICAgICAgICAgICAkQ291bnQgKz0gc2NhbGFyIGtleXMgJU1vbnRoOwogICAgICAgIH0KICAgIH0KCiAgICAjIHJlbW92ZSBjdXJyZW50IGRheSBiZWNhdXNlIGl0IG1ha2VzIG5vIHNlbnNlIHRvIHNob3cgdGhlIGN1cnJlbnQgZGF5IGFzIGluY29tcGxldGVkCiAgICBpZiAoICRDb3VudCA+IDAgKSB7CiAgICAgICAgJENvdW50LS07CiAgICB9CgogICAgIyBnZXQgVG9vbEJhciBvYmplY3QgcGFyYW1ldGVycwogICAgbXkgJENsYXNzID0gJFBhcmFte0NvbmZpZ30tPntDc3NDbGFzc307CiAgICBteSAkVGV4dCAgPSAkU2VsZi0+e0xheW91dE9iamVjdH0tPntMYW5ndWFnZU9iamVjdH0tPkdldCgnSW5jb21wbGV0ZSB3b3JraW5nIGRheXMnKTsKICAgIG15ICRVUkwgICA9ICRTZWxmLT57TGF5b3V0T2JqZWN0fS0+e0Jhc2VsaW5rfTsKICAgIG15ICRJY29uICA9ICRQYXJhbXtDb25maWd9LT57SWNvbn07CgogICAgcmV0dXJuICgpIGlmICEkQ291bnQ7CgogICAgbXkgJVJldHVybiA9ICgKICAgICAgICAxMDAwODEwID0+IHsKICAgICAgICAgICAgQmxvY2sgICAgICAgPT4gJ1Rvb2xCYXJJdGVtJywKICAgICAgICAgICAgRGVzY3JpcHRpb24gPT4gJFRleHQsCiAgICAgICAgICAgIENvdW50ICAgICAgID0+ICRDb3VudCwKICAgICAgICAgICAgQ2xhc3MgICAgICAgPT4gJENsYXNzLAogICAgICAgICAgICBJY29uICAgICAgICA9PiAkSWNvbiwKICAgICAgICAgICAgTGluayAgICAgICAgPT4gJFVSTCAuICdBY3Rpb249JyAuICRBY3Rpb24sCiAgICAgICAgICAgIEFjY2Vzc0tleSAgID0+ICcnLAogICAgICAgICAgICB9CiAgICApOwoKICAgIHJldHVybiAlUmV0dXJuOwp9CgoxOwo=
#--
# Kernel/System/TimeAccounting.pm - all time accounting functions
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::TimeAccounting;

use strict;
use warnings;

use Date::Pcalc qw(Today Days_in_Month Day_of_Week check_date);

our @ObjectDependencies = (
    'Kernel::Config',
    'Kernel::System::DB',
    'Kernel::System::Log',
    'Kernel::System::Time',
    'Kernel::System::User',
);

=head1 NAME

Kernel::System::TimeAccounting - time accounting lib

=head1 SYNOPSIS

All time accounting functions

=head1 PUBLIC INTERFACE

=over 4

=item new()

create an object

    use Kernel::System::ObjectManager;
    local $Kernel::OM = Kernel::System::ObjectManager->new();
    my $FAQObject = $Kernel::OM->Get('Kernel::System::TimeAccounting');

=cut

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

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

    return $Self;
}

=item UserCurrentPeriodGet()

returns a hash with the current period data of the specified user

    my %UserData = $TimeAccountingObject->UserCurrentPeriodGet(
        Year  => '2005',
        Month => '12',
        Day   => '24',
    );

The returned hash contains the following elements:

    %UserData = (
        1 => {
            UserID      => 1,
            Period      => 123,
            DateStart   => '2005-12-24',
            DateEnd     => '2005-12-24',
            WeeklyHours => 40.4,
            LeaveDays   => 12,
            OverTime    => 34,
        },
    );

=cut

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

    # check needed params
    for my $NeededParam (qw(Year Month Day)) {
        if ( !$Param{$NeededParam} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "UserCurrentPeriodGet: Need $NeededParam!",
            );

            return;
        }
    }

    # build date string for given params
    my $Date = sprintf( "%04d-%02d-%02d", $Param{Year}, $Param{Month}, $Param{Day} ) . ' 00:00:00';

    # check cache
    if ( $Self->{'Cache::UserCurrentPeriodGet'}{$Date} ) {

        return %{ $Self->{'Cache::UserCurrentPeriodGet'}{$Date} };
    }

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db select
    return if !$DBObject->Prepare(
        SQL => '
            SELECT user_id, preference_period, date_start, date_end, weekly_hours, leave_days,
                overtime
            FROM time_accounting_user_period
            WHERE date_start <= ?
                AND date_end  >= ?
                AND status = ?',
        Bind => [ \$Date, \$Date, \1, ],
    );

    # fetch the data
    my %Data;
    while ( my @Row = $DBObject->FetchrowArray() ) {
        my $UserRef = {
            UserID      => $Row[0],
            Period      => $Row[1],
            DateStart   => substr( $Row[2], 0, 10 ),
            DateEnd     => substr( $Row[3], 0, 10 ),
            WeeklyHours => $Row[4],
            LeaveDays   => $Row[5],
            Overtime    => $Row[6],
        };
        $Data{ $Row[0] } = $UserRef;
    }

    # check for valid user data
    return if !%Data;

    # store user data in cache
    $Self->{'Cache::UserCurrentPeriodGet'}{$Date} = \%Data;

    return %Data;
}

=item UserReporting()

returns a hash with information about leave days, overtimes,
working hours etc. of all users

    my %Data = $TimeAccountingObject->UserReporting(
        Year  => '2005',
        Month => '12',
        Day   => '12',      # Optional
    );

=cut

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

    # get log object
    my $LogObject = $Kernel::OM->Get('Kernel::System::Log');

    # check needed params
    for my $NeededParam (qw(Year Month Day)) {
        if ( !$Param{$NeededParam} && $NeededParam ne 'Day' ) {
            $LogObject->Log(
                Priority => 'error',
                Message  => "UserReporting: Need $NeededParam!"
            );

            return;
        }
    }

    # check valid date values
    return if !check_date( $Param{Year}, $Param{Month}, $Param{Day} || 1 );

    # get days of month if not provided
    $Param{Day} ||= Days_in_Month( $Param{Year}, $Param{Month} );

    my %UserCurrentPeriod = $Self->UserCurrentPeriodGet(%Param);
    my $YearStart         = 1970;
    my $MonthStart        = 1;
    my $DayStart          = 1;
    my $YearEnd           = $Param{Year};
    my $MonthEnd          = $Param{Month};
    my $DayEnd            = $Param{Day};

    my %Data;

    USERID:
    for my $UserID ( sort keys %UserCurrentPeriod ) {

        if ( $UserCurrentPeriod{$UserID}{DateStart} =~ m{ \A (\d{4})-(\d{2})-(\d{2}) }xms ) {
            $YearStart  = $1;
            $MonthStart = $2;
            $DayStart   = $3;
        }

        if ( !check_date( $YearStart, $MonthStart, $DayStart ) ) {

            $LogObject->Log(
                Priority => 'notice',
                Message  => 'UserReporting: Invalid start date for user '
                    . "$UserID: $UserCurrentPeriod{$UserID}{DateStart}",
            );

            next USERID;
        }

        my %CurrentUserData = (
            LeaveDate        => 0,
            Sick             => 0,
            Overtime         => 0,
            TargetState      => 0,
            LeaveDayTotal    => 0,
            SickTotal        => 0,
            SickTotal        => 0,
            TargetStateTotal => 0,
        );

        my $Calendar = { $Self->UserGet( UserID => $UserID ) }->{Calendar};

        YEAR:
        for my $Year ( $YearStart .. $YearEnd ) {

            my $MonthStartPoint = $Year == $YearStart ? $MonthStart : 1;
            my $MonthEndPoint   = $Year == $YearEnd   ? $MonthEnd   : 12;

            MONTH:
            for my $Month ( $MonthStartPoint .. $MonthEndPoint ) {

                my $DayStartPoint =
                    $Year == $YearStart && $Month == $MonthStart
                    ? $DayStart
                    : 1
                    ;

                my $DayEndPoint =
                    $Year == $YearEnd && $Month == $MonthEnd
                    ? $DayEnd
                    : Days_in_Month( $Year, $Month )
                    ;

                DAY:
                for my $Day ( $DayStartPoint .. $DayEndPoint ) {

                    my %WorkingUnit = $Self->WorkingUnitsGet(
                        Year   => $Year,
                        Month  => $Month,
                        Day    => $Day,
                        UserID => $UserID,
                    );

                    my $LeaveDay    = 0;
                    my $Sick        = 0;
                    my $Overtime    = 0;
                    my $TargetState = 0;

                    if ( $WorkingUnit{LeaveDay} ) {
                        $CurrentUserData{LeaveDayTotal}++;
                        $LeaveDay = 1;
                    }
                    elsif ( $WorkingUnit{Sick} ) {
                        $CurrentUserData{SickTotal}++;
                        $Sick = 1;
                    }
                    elsif ( $WorkingUnit{Overtime} ) {
                        $CurrentUserData{OvertimeTotal}++;
                        $Overtime = 1;
                    }

                    $CurrentUserData{WorkingHoursTotal} += $WorkingUnit{Total};
                    my $VacationCheck = $Kernel::OM->Get('Kernel::System::Time')->VacationCheck(
                        Year     => $Year,
                        Month    => $Month,
                        Day      => $Day,
                        Calendar => $Calendar || '',
                    );
                    my $Weekday = Day_of_Week( $Year, $Month, $Day );
                    if (
                        $Weekday != 6
                        && $Weekday != 7
                        && !$VacationCheck
                        && !$Sick
                        && !$LeaveDay
                        )
                    {
                        $CurrentUserData{TargetStateTotal}
                            += $UserCurrentPeriod{$UserID}{WeeklyHours} / 5;
                        $TargetState = $UserCurrentPeriod{$UserID}{WeeklyHours} / 5;
                    }

                    if ( $Month == $MonthEnd && $Year == $YearEnd ) {
                        $CurrentUserData{TargetState}  += $TargetState;
                        $CurrentUserData{WorkingHours} += $WorkingUnit{Total};
                        $CurrentUserData{LeaveDay}     += $LeaveDay;
                        $CurrentUserData{Sick}         += $Sick;
                    }
                }
            }
        }

        $CurrentUserData{Overtime}      = $CurrentUserData{WorkingHours} - $CurrentUserData{TargetState};
        $CurrentUserData{OvertimeTotal} = $UserCurrentPeriod{$UserID}{Overtime}
            + $CurrentUserData{WorkingHoursTotal}
            - $CurrentUserData{TargetStateTotal};
        $CurrentUserData{OvertimeUntil}     = $CurrentUserData{OvertimeTotal} - $CurrentUserData{Overtime};
        $CurrentUserData{LeaveDayRemaining} = $UserCurrentPeriod{$UserID}{LeaveDays} - $CurrentUserData{LeaveDayTotal};

        $Data{$UserID} = \%CurrentUserData;
    }

    return %Data;
}

=item ProjectSettingsGet()

returns a hash with all the projects' data

    my %ProjectData = $TimeAccountingObject->ProjectSettingsGet(
        Status => 'valid' || 'invalid', optional default valid && invalid
    );

=cut

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

    my $Where = '';
    if ( $Param{Status} ) {
        $Where = ' WHERE status = ';
        $Where .= $Param{Status} eq 'invalid' ? "'0'" : "'1'";
    }

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db select
    $DBObject->Prepare(
        SQL => "
            SELECT id, project, description, status
            FROM time_accounting_project
            $Where",
    );

    # fetch the data
    my %Data;
    while ( my @Row = $DBObject->FetchrowArray() ) {
        my $ID = $Row[0];
        $Data{Project}{$ID}            = $Row[1];
        $Data{ProjectDescription}{$ID} = $Row[2];
        $Data{ProjectStatus}{$ID}      = $Row[3];
    }

    return %Data;
}

=item ProjectGet()

returns a hash with the requested project data

    my %ProjectData = $TimeAccountingObject->ProjectGet( ID => 2 );

This returns something like:

    $TimeAccountingObject = (
        Project            => 'internal',
        ProjectDescription => 'description',
        ProjectStatus      => 1,
    );

    or

    my %ProjectData = $TimeAccountingObject->ProjectGet( Project => 'internal' );

This returns something like:

    $TimeAccountingObject = (
        ID                 => 2,
        ProjectDescription => 'description',
        ProjectStatus      => 1,
    );

=cut

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

    # check needed stuff
    if ( !$Param{ID} && !$Param{Project} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'Need ID or project name!'
        );

        return;
    }

    my %Project;

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # look for the task data with the ID
    if ( $Param{ID} ) {

        # SQL
        return if !$DBObject->Prepare(
            SQL => '
                SELECT project, description, status
                FROM time_accounting_project
                WHERE id = ?',
            Bind => [ \$Param{ID} ],
        );
        while ( my @Data = $DBObject->FetchrowArray() ) {
            %Project = (
                ID                 => $Param{ID},
                Project            => $Data[0],
                ProjectDescription => $Data[1],
                ProjectStatus      => $Data[2],
            );
        }
    }

    # look for the task data with the task name
    else {

        # SQL
        return if !$DBObject->Prepare(
            SQL => '
                SELECT id, description, status
                FROM time_accounting_project
                WHERE project = ?',
            Bind => [ \$Param{Project} ],
        );
        while ( my @Data = $DBObject->FetchrowArray() ) {
            %Project = (
                Project            => $Param{Project},
                ID                 => $Data[0],
                ProjectDescription => $Data[1],
                ProjectStatus      => $Data[2],
            );
        }
    }

    return %Project;
}

=item ProjectSettingsInsert()

inserts a new project in the db

    $TimeAccountingObject->ProjectSettingsInsert(
        Project            => 'internal',    # optional
        ProjectDescription => 'description', # optional
        ProjectStatus      => 1 || 0,        # optional
    );

    returns ID of created project

=cut

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

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

    $Param{Project} ||= $ConfigObject->Get('TimeAccounting::DefaultProjectName');
    $Param{ProjectDescription} ||= '';

    if ( $Param{ProjectStatus} ne '0' && $Param{ProjectStatus} ne '1' ) {
        $Param{ProjectStatus} = $ConfigObject->Get('TimeAccounting::DefaultProjectStatus');
    }

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # insert project record
    return if !$DBObject->Do(
        SQL => '
            INSERT INTO time_accounting_project (project, description, status)
            VALUES (?, ?, ?)',
        Bind => [ \$Param{Project}, \$Param{ProjectDescription}, \$Param{ProjectStatus} ],
    );

    # get id of newly created project record
    return if !$DBObject->Prepare(
        SQL => '
            SELECT id
            FROM time_accounting_project
            WHERE project = ?',
        Bind  => [ \$Param{Project} ],
        Limit => 1,
    );

    # fetch the data
    my $ProjectID;
    while ( my @Row = $DBObject->FetchrowArray() ) {
        $ProjectID = $Row[0];
    }

    return $ProjectID;
}

=item ProjectSettingsUpdate()

updates a project

    my $Success = $TimeAccountingObject->ProjectSettingsUpdate(
        ID                 => 123,
        Project            => 'internal',
        ProjectDescription => 'description',
        ProjectStatus      => 1,
    );

=cut

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

    # check needed stuff
    for my $Needed (qw(ID Project)) {
        if ( !$Param{$Needed} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Needed!"
            );

            return;
        }
    }

    # SQL
    return if !$Kernel::OM->Get('Kernel::System::DB')->Do(
        SQL => '
            UPDATE time_accounting_project
            SET project = ?, description = ?, status = ?
            WHERE id = ?',
        Bind => [
            \$Param{Project}, \$Param{ProjectDescription}, \$Param{ProjectStatus}, \$Param{ID},
        ],
    );

    return 1;
}

=item ActionSettingsGet()

returns a hash with all the actions settings

    my %ActionData = $TimeAccountingObject->ActionSettingsGet();

=cut

sub ActionSettingsGet {
    my $Self = shift;

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db select
    return if !$DBObject->Prepare(
        SQL => '
            SELECT id, action, status
            FROM time_accounting_action',
    );

    # fetch the data
    my %Data;
    while ( my @Row = $DBObject->FetchrowArray() ) {
        $Data{ $Row[0] }{Action}       = $Row[1];
        $Data{ $Row[0] }{ActionStatus} = $Row[2];
    }

    return %Data;
}

=item ActionGet()

returns a hash with the requested action (task) data

    my %ActionData = $TimeAccountingObject->ActionGet( ID => 2 );

This returns something like:

    $TimeAccountingObject = (
        Action       => 'My task',
        ActionStatus => 1,
    );

    or

    my %ActionData = $TimeAccountingObject->ActionGet( Action => 'My task' );

This returns something like:

    $TimeAccountingObject = (
        ID           => 2,
        ActionStatus => 1,
    );

=cut

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

    # check needed stuff
    if ( !$Param{ID} && !$Param{Action} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'Need ID or Action!'
        );

        return;
    }

    my %Task;

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # look for the task data with the ID
    if ( $Param{ID} ) {

        # SQL
        return if !$DBObject->Prepare(
            SQL => '
                SELECT action, status
                FROM time_accounting_action
                WHERE id = ?',
            Bind => [ \$Param{ID} ],
        );
        while ( my @Data = $DBObject->FetchrowArray() ) {
            %Task = (
                ID           => $Param{ID},
                Action       => $Data[0],
                ActionStatus => $Data[1],
            );
        }
    }

    # look for the task data with the task name
    else {

        # SQL
        return if !$DBObject->Prepare(
            SQL => '
                SELECT id, status
                FROM time_accounting_action
                WHERE action = ?',
            Bind => [ \$Param{Action} ],
        );
        while ( my @Data = $DBObject->FetchrowArray() ) {
            %Task = (
                Action       => $Param{Action},
                ID           => $Data[0],
                ActionStatus => $Data[1],
            );
        }
    }

    return %Task;
}

=item ActionSettingsInsert()

inserts a new action in the db

    $TimeAccountingObject->ActionSettingsInsert(
        Action       => 'meeting',   # optional
        ActionStatus => 1 || 0,      # optional
    );

=cut

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

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

    $Param{Action} ||= $ConfigObject->Get('TimeAccounting::DefaultActionName') || '';
    if ( $Param{ActionStatus} ne '0' && $Param{ActionStatus} ne '1' ) {
        $Param{ActionStatus} = $ConfigObject->Get('TimeAccounting::DefaultActionStatus');
    }

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db insert
    return if !$DBObject->Do(
        SQL => '
            INSERT INTO time_accounting_action (action, status)
            VALUES (?, ?)',
        Bind => [ \$Param{Action}, \$Param{ActionStatus}, ],
    );

    return 1;
}

=item ActionSettingsUpdate()

updates an action (task)

    my $Success = $TimeAccountingObject->ActionSettingsUpdate(
        ActionID     => 123,
        Action       => 'internal',
        ActionStatus => 1,
    );

=cut

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

    # check needed stuff
    for my $Needed (qw(ActionID Action)) {
        if ( !$Param{$Needed} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Needed!"
            );

            return;
        }
    }

    # SQL
    return if !$Kernel::OM->Get('Kernel::System::DB')->Do(
        SQL => '
            UPDATE time_accounting_action
            SET action = ?, status = ?
            WHERE id = ?',
        Bind => [
            \$Param{Action}, \$Param{ActionStatus}, \$Param{ActionID}
        ],
    );

    return 1;
}

=item UserList()

returns a hash with the user data of all users

    my %UserData = $TimeAccountingObject->UserList();

=cut

sub UserList {
    my $Self = shift;

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db select
    $DBObject->Prepare(
        SQL => '
            SELECT user_id, description, show_overtime, create_project, calendar
            FROM time_accounting_user',
    );

    # fetch the data
    my %Data;
    while ( my @Row = $DBObject->FetchrowArray() ) {
        $Data{ $Row[0] }{UserID}        = $Row[0];
        $Data{ $Row[0] }{Description}   = $Row[1];
        $Data{ $Row[0] }{ShowOvertime}  = $Row[2];
        $Data{ $Row[0] }{CreateProject} = $Row[3];
        $Data{ $Row[0] }{Calendar}      = $Row[4];
    }

    return %Data;
}

=item UserGet()

returns a hash with the user data of one user

    my %UserData = $TimeAccountingObject->UserGet(
        UserID => 15,
    );

=cut

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

    # check needed data
    if ( !$Param{UserID} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'UserGet: Need UserID!',
        );

        return;
    }

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db select
    $DBObject->Prepare(
        SQL => '
            SELECT description, show_overtime, create_project, calendar
            FROM time_accounting_user
            WHERE user_id = ?',
        Bind => [ \$Param{UserID} ],
    );

    # fetch the data
    my %Data;
    while ( my @Row = $DBObject->FetchrowArray() ) {
        $Data{UserID}        = $Param{UserID};
        $Data{Description}   = $Row[0];
        $Data{ShowOvertime}  = $Row[1];
        $Data{CreateProject} = $Row[2];
        $Data{Calendar}      = $Row[3];
    }

    return %Data;
}

=item UserSettingsGet()

returns a hash with the complete user period data for all users

    my %UserData = $TimeAccountingObject->UserSettingsGet();

returns:
    %UserData = (
        3 => {
            1 => {
                DateEnd     => "2012-12-31",
                DateStart   => "2012-10-01",
                LeaveDays   => "23.00",
                Overtime    => "0.00",
                Period      => 1,
                UserID      => 3,
                UserStatus  => 1,
                WeeklyHours => "40.00",
            },
            2 => {
                DateEnd     => "2013-12-31",
                DateStart   => "2013-01-01",
                LeaveDays   => "23.00",
                Overtime    => "0.00",
                Period      => 2,
                UserID      => 3,
                UserStatus  => 1,
                WeeklyHours => "32.00",
            },
        },
        4 => {
            1 => {
                DateEnd     => "2013-12-31",
                DateStart   => "2012-01-01",
                LeaveDays   => "23.00",
                Overtime    => "0.00",
                Period      => 1,
                UserID      => 4,
                UserStatus  => 1,
                WeeklyHours => "40.00",
            },
        },
    };

=cut

sub UserSettingsGet {
    my $Self = shift;

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db select
    $DBObject->Prepare(
        SQL => '
            SELECT user_id, preference_period, date_start, date_end, weekly_hours, leave_days,
                overtime, status
            FROM time_accounting_user_period'
    );

    # fetch the data
    my %Data;
    while ( my @Row = $DBObject->FetchrowArray() ) {
        $Data{ $Row[0] }{ $Row[1] }{UserID}      = $Row[0];
        $Data{ $Row[0] }{ $Row[1] }{Period}      = $Row[1];
        $Data{ $Row[0] }{ $Row[1] }{DateStart}   = substr( $Row[2], 0, 10 );
        $Data{ $Row[0] }{ $Row[1] }{DateEnd}     = substr( $Row[3], 0, 10 );
        $Data{ $Row[0] }{ $Row[1] }{WeeklyHours} = $Row[4];
        $Data{ $Row[0] }{ $Row[1] }{LeaveDays}   = $Row[5];
        $Data{ $Row[0] }{ $Row[1] }{Overtime}    = $Row[6];
        $Data{ $Row[0] }{ $Row[1] }{UserStatus}  = $Row[7];
    }

    return %Data;
}

=item SingleUserSettingsGet()

returns a hash with the requested user's period data

    my %UserData = $TimeAccountingObject->SingleUserSettingsGet( UserID => 1 );

=cut

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

    # check needed stuff
    if ( !$Param{UserID} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'Need UserID!'
        );

        return;
    }

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db select
    $DBObject->Prepare(
        SQL => '
            SELECT user_id, preference_period, date_start, date_end, weekly_hours, leave_days,
                overtime, status
            FROM time_accounting_user_period WHERE user_id = ?',
        Bind => [ \$Param{UserID} ],
    );

    # fetch the data
    my %UserData;
    while ( my @Row = $DBObject->FetchrowArray() ) {
        $UserData{ $Row[1] }{UserID}      = $Row[0];
        $UserData{ $Row[1] }{Period}      = $Row[1];
        $UserData{ $Row[1] }{DateStart}   = substr( $Row[2], 0, 10 );
        $UserData{ $Row[1] }{DateEnd}     = substr( $Row[3], 0, 10 );
        $UserData{ $Row[1] }{WeeklyHours} = $Row[4];
        $UserData{ $Row[1] }{LeaveDays}   = $Row[5];
        $UserData{ $Row[1] }{Overtime}    = $Row[6];
        $UserData{ $Row[1] }{UserStatus}  = $Row[7];
    }

    return %UserData;
}

=item UserLastPeriodNumberGet()

returns the number of the last registered period for the specified user

    my $LastPeriodNumber = $TimeAccountingObject->UserLastPeriodNumberGet( UserID => 1 );

=cut

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

    # check needed stuff
    if ( !$Param{UserID} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'Need UserID!'
        );

        return;
    }

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db select
    $DBObject->Prepare(
        SQL => '
            SELECT max(preference_period)
            FROM time_accounting_user_period
            WHERE user_id = ?',
        Bind => [ \$Param{UserID} ],
    );

    # fetch the data
    my @Row = $DBObject->FetchrowArray();
    my $LastPeriodNumber = $Row[0] || 0;

    return $LastPeriodNumber;
}

=item UserSettingsInsert()

insert new user data in the db

    $TimeAccountingObject->UserSettingsInsert(
        UserID       => '2',
        Period       => '2',
    );

=cut

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

    # check needed stuff
    for my $Needed (qw (UserID Period)) {
        if ( !$Param{$Needed} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Needed"
            );

            return;
        }
    }

    # check if user exists
    if ( !$Kernel::OM->Get('Kernel::System::User')->UserLookup( UserID => $Param{UserID} ) ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => "UserID $Param{UserID} does not exist!"
        );

        return;
    }

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

    $Param{WeeklyHours} = $ConfigObject->Get('TimeAccounting::DefaultUserWeeklyHours')
        || '40';
    $Param{LeaveDays}  = $ConfigObject->Get('TimeAccounting::DefaultUserLeaveDays') || '25';
    $Param{UserStatus} = $ConfigObject->Get('TimeAccounting::DefaultUserStatus')    || '1';
    $Param{Overtime}   = $ConfigObject->Get('TimeAccounting::DefaultUserOvertime')  || '0';
    $Param{DateEnd}    = $ConfigObject->Get('TimeAccounting::DefaultUserDateEnd')
        || '2011-12-31';
    $Param{DateStart} = $ConfigObject->Get('TimeAccounting::DefaultUserDateStart')
        || '2011-01-01';
    $Param{Description} = $ConfigObject->Get('TimeAccounting::DefaultUserDescription')
        || 'Put your description here.';

    $Param{DateStart} .= ' 00:00:00';
    $Param{DateEnd}   .= ' 00:00:00';

    # delete cache
    delete $Self->{'Cache::UserCurrentPeriodGet'};

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db insert
    return if !$DBObject->Do(
        SQL => '
            INSERT INTO time_accounting_user_period (user_id, preference_period, date_start,
                date_end, weekly_hours, leave_days, overtime, status)
            VALUES (?, ?, ?, ?, ?, ?, ?, ?)',
        Bind => [
            \$Param{UserID},      \$Param{Period},    \$Param{DateStart}, \$Param{DateEnd},
            \$Param{WeeklyHours}, \$Param{LeaveDays}, \$Param{Overtime},  \$Param{UserStatus},
        ],
    );

    # select UserID
    $DBObject->Prepare(
        SQL => '
            SELECT user_id
            FROM time_accounting_user
            WHERE user_id = ?',
        Bind  => [ \$Param{UserID}, ],
        Limit => 1,
    );

    # fetch the data
    my $UserID;
    while ( my @Row = $DBObject->FetchrowArray() ) {
        $UserID = $Row[0];
    }

    if ( !defined $UserID ) {

        # db insert
        return if !$DBObject->Do(
            SQL => '
                INSERT INTO time_accounting_user (user_id, description)
                VALUES (?, ?)',
            Bind => [ \$Param{UserID}, \$Param{Description}, ],
        );
    }

    return 1;
}

=item UserSettingsUpdate()

updates user data in the db

    $TimeAccountingObject->UserSettingsUpdate(
        UserID        => 1,
        Description   => 'Some Text',
        CreateProject => 1 || 0,
        ShowOvertime  => 1 || 0,
        Period        => {
            1 => {
                DateStart    => '2010-12-12',
                DateEnd      => '2010-12-31',
                WeeklyHours  => '38',
                LeaveDays    => '25',
                Overtime     => '38',
                UserStatus   => 1 || 0,
            },
            2 => {
                DateStart    => '2010-12-12',
                DateEnd      => '2010-12-31',
                WeeklyHours  => '38',
                LeaveDays    => '25',
                Overtime     => '38',
                UserStatus   => 1 || 0,
            },
            3 => ......
        }
    );

=cut

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

    # delete cache
    delete $Self->{'Cache::UserCurrentPeriodGet'};

    my $UserID = $Param{UserID};

    if ( !defined $Param{Period}->{1}{DateStart} && !defined $Param{Period}->{1}{DateEnd} ) {

        return $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => "UserSettingUpdate: No data for user id $UserID!"
        );
    }

    # set default values
    $Param{ShowOvertime}  ||= 0;
    $Param{CreateProject} ||= 0;
    $Param{Calendar}      ||= 0;

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db insert
    return if !$DBObject->Do(
        SQL => '
            UPDATE time_accounting_user
            SET description = ?, show_overtime = ?, create_project = ?, calendar = ?
            WHERE user_id = ?',
        Bind => [
            \$Param{Description}, \$Param{ShowOvertime},
            \$Param{CreateProject}, \$Param{Calendar}, \$Param{UserID}
        ],
    );

    # update all periods
    for my $Period ( sort keys %{ $Param{Period} } ) {

        # db insert
        return if !$DBObject->Do(
            SQL => '
                UPDATE time_accounting_user_period
                SET leave_days = ?, date_start = ?, date_end = ?, overtime = ?, weekly_hours = ?,
                    status = ?
                WHERE user_id = ?
                    AND preference_period = ?',
            Bind => [
                \$Param{Period}->{$Period}{LeaveDays},   \$Param{Period}->{$Period}{DateStart},
                \$Param{Period}->{$Period}{DateEnd},     \$Param{Period}->{$Period}{Overtime},
                \$Param{Period}->{$Period}{WeeklyHours}, \$Param{Period}->{$Period}{UserStatus},
                \$UserID, \$Period,
                ]
        );
    }

    return 1;
}

=item WorkingUnitsCompletnessCheck()

returns a hash with the incomplete working days and
the information if the incomplete working days are in the allowed
range.

    my %WorkingUnitsCheck = $TimeAccountingObject->WorkingUnitsCompletnessCheck(
        UserID => 123,
    );

=cut

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

    if ( !$Param{UserID} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => "Need UserID"
        );

        return;
    }

    my %Data                = ();
    my $WorkingUnitID       = 0;
    my %CompleteWorkingDays = ();

    # get time object
    my $TimeObject = $Kernel::OM->Get('Kernel::System::Time');

    my ( $Sec, $Min, $Hour, $Day, $Month, $Year ) = $TimeObject->SystemTime2Date(
        SystemTime => $TimeObject->SystemTime(),
    );

    my $UserID = $Param{UserID};

    # TODO: Search only in the CurrentUserPeriod
    # TODO: Search only working units where action_id and project_id is true

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    $DBObject->Prepare(
        SQL => '
            SELECT DISTINCT time_start
            FROM time_accounting_table
            WHERE user_id = ?',
        Bind => [ \$UserID ],
    );

    # fetch the data
    while ( my @Row = $DBObject->FetchrowArray() ) {
        if ( $Row[0] =~ /^(\d+)-(\d+)-(\d+)/ ) {
            $CompleteWorkingDays{$1}{$2}{$3} = 1;
        }
    }

    my %UserCurrentPeriod = $Self->UserCurrentPeriodGet(
        Year  => $Year,
        Month => $Month,
        Day   => $Day,
    );

    my $WorkingDays = 0;
    my $YearStart   = 1970;
    my $MonthStart  = 1;
    my $DayStart    = 1;
    my $YearEnd     = $Year;
    my $MonthEnd    = $Month;
    my $DayEnd      = $Day;

    if (
        $UserCurrentPeriod{$UserID}->{DateStart}
        && $UserCurrentPeriod{$UserID}->{DateStart} =~ /^(\d+)-(\d+)-(\d+)/
        )
    {
        $YearStart  = $1;
        $MonthStart = $2;
        $DayStart   = $3;
    }

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

    my $Calendar = { $Self->UserGet( UserID => $UserID ) }->{Calendar};

    for my $Year ( $YearStart .. $YearEnd ) {

        my $MonthStartPoint = $Year == $YearStart ? $MonthStart : 1;
        my $MonthEndPoint   = $Year == $YearEnd   ? $MonthEnd   : 12;

        for my $Month ( $MonthStartPoint .. $MonthEndPoint ) {

            my $DayStartPoint = $Year == $YearStart && $Month == $MonthStart ? $DayStart : 1;
            my $DayEndPoint = $Year == $YearEnd
                && $Month == $MonthEnd ? $DayEnd : Days_in_Month( $Year, $Month );
            my $MonthString = sprintf( "%02d", $Month );

            for my $Day ( $DayStartPoint .. $DayEndPoint ) {

                my $VacationCheck = $TimeObject->VacationCheck(
                    Year     => $Year,
                    Month    => $Month,
                    Day      => $Day,
                    Calendar => $Calendar || '',
                );

                my $Date = sprintf( "%04d-%02d-%02d", $Year, $Month, $Day );
                my $DayStartTime = $TimeObject->TimeStamp2SystemTime( String => $Date . ' 00:00:00' );
                my $DayStopTime  = $TimeObject->TimeStamp2SystemTime( String => $Date . ' 23:59:59' );

                # add time zone to calculation
                my $Zone = $ConfigObject->Get( "TimeZone::Calendar" . ( $Calendar || '' ) );
                if ($Zone) {
                    my $ZoneSeconds = $Zone * 60 * 60;
                    $DayStartTime = $DayStartTime - $ZoneSeconds;
                    $DayStopTime  = $DayStopTime - $ZoneSeconds;
                }

                my $ThisDayWorkingTime = $TimeObject->WorkingTime(
                    StartTime => $DayStartTime,
                    StopTime  => $DayStopTime,
                    Calendar  => $Calendar || '',
                ) || '0';

                my $DayString = sprintf( "%02d", $Day );

                if ( $ThisDayWorkingTime && !$VacationCheck ) {
                    $WorkingDays++;
                }
                if (
                    $ThisDayWorkingTime
                    && !$VacationCheck
                    && !$CompleteWorkingDays{$Year}{$MonthString}{$DayString}
                    )
                {
                    $Data{Incomplete}{$Year}{$MonthString}{$DayString} = $WorkingDays;
                }
            }
        }
    }
    my $MaxIntervallOfIncompleteDays = $ConfigObject->Get('TimeAccounting::MaxIntervalOfIncompleteDays') || '5';
    my $MaxIntervallOfIncompleteDaysBeforeWarning
        = $ConfigObject->Get('TimeAccounting::MaxIntervalOfIncompleteDaysBeforeWarning')
        || '3';
    for my $Year ( sort keys %{ $Data{Incomplete} } ) {

        for my $Month ( sort keys %{ $Data{Incomplete}{$Year} } ) {

            for my $Day ( sort keys %{ $Data{Incomplete}{$Year}{$Month} } ) {

                if (
                    $Data{Incomplete}{$Year}{$Month}{$Day}
                    < $WorkingDays - $MaxIntervallOfIncompleteDays
                    )
                {
                    $Data{EnforceInsert} = 1;
                }
                elsif (
                    $Data{Incomplete}{$Year}{$Month}{$Day}
                    < $WorkingDays - $MaxIntervallOfIncompleteDaysBeforeWarning
                    )
                {
                    $Data{Warning} = 1;
                }
            }
        }
    }

    return %Data;
}

=item WorkingUnitsGet()

returns a hash with the working units data

    my %WorkingUnitsData = $TimeAccountingObject->WorkingUnitsGet(
        Year   => '2005',
        Month  => '7',
        Day    => '13',
        UserID => '123',
    );

=cut

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

    if ( !$Param{UserID} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => "Need UserID"
        );

        return;
    }

    my $Date      = sprintf "%04d-%02d-%02d", $Param{Year}, $Param{Month}, $Param{Day};
    my $DateStart = $Date . " 00:00:00";
    my $DateStop  = $Date . " 23:59:59";

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # ask the database
    $DBObject->Prepare(
        SQL => '
            SELECT user_id, project_id, action_id, remark, time_start, time_end, period
            FROM time_accounting_table
            WHERE time_start >= ?
                AND time_start <= ?
                AND user_id = ?
            ORDER by id',
        Bind => [ \$DateStart, \$DateStop, \$Param{UserID} ],
    );

    my %Data = (
        Total => 0,
        Date  => $Date,
    );

    # fetch the result
    ROW:
    while ( my @Row = $DBObject->FetchrowArray() ) {

        next ROW if $Row[4] !~ m{^ (.+?) \s (\d+:\d+) : (\d+) }xms;

        # check if it is a special working unit
        if ( $Row[1] == -1 ) {
            my $ActionID = $Row[2];

            $Data{Sick}     = $ActionID == -1 ? 1 : 0;
            $Data{LeaveDay} = $ActionID == -2 ? 1 : 0;
            $Data{Overtime} = $ActionID == -3 ? 1 : 0;

            next ROW;
        }

        my $StartTime = $2;
        my $EndTime   = '';
        if ( $Row[5] =~ m{^(.+?)\s(\d+:\d+):(\d+)}xms ) {
            $EndTime = $2;

            # replace 23:59:59 with 24:00
            if ( $EndTime eq '23:59' && $3 eq '59' ) {
                $EndTime = '24:00';
            }
        }

        my %WorkingUnit = (
            UserID    => $Row[0],
            ProjectID => $Row[1],
            ActionID  => $Row[2],
            Remark    => $Row[3],
            StartTime => $StartTime,
            EndTime   => $EndTime,
            Period    => defined( $Row[6] ) ? sprintf( "%.2f", $Row[6] ) : 0,
        );

        # only count complete working units
        if ( $Row[1] && $Row[2] ) {
            $Data{Total} += $WorkingUnit{Period};
        }

        push @{ $Data{WorkingUnits} }, \%WorkingUnit;
    }

    return %Data;
}

=item WorkingUnitsInsert()

insert working units in the db

    $TimeAccountingObject->WorkingUnitsInsert(
        Year  => '2005',
        Month => '07',
        Day   => '02',
        LeaveDay => 1, || 0
        Sick     => 1, || 0
        Overtime => 1, || 0
        WorkingUnits => [
            {
                ProjectID => 1,
                ActionID  => 23,
                Remark    => 'SomeText',
                StartTime => '7:30',
                EndTime   => '11:00',
                Period    => '8.5',
            },
            { ...... },
        ],
        UserID => 123,
    );

=cut

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

    for my $Needed (qw(Year Month Day UserID)) {
        if ( !$Param{$Needed} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "WorkingUnitsInsert: Need $Needed!"
            );

            return;
        }
    }

    my $Date = sprintf "%04d-%02d-%02d", $Param{Year}, $Param{Month}, $Param{Day};

    # add special time working units
    my %SpecialAction = (
        'Sick'     => '-1',
        'LeaveDay' => '-2',
        'Overtime' => '-3',
    );

    ELEMENT:
    for my $Element (qw(LeaveDay Sick Overtime)) {

        next ELEMENT if !$Param{$Element};

        my %Unit = (
            ProjectID => -1,
            ActionID  => $SpecialAction{$Element},
            Remark    => '',
            StartTime => '',
            EndTime   => '',
            Period    => 0,
        );

        push @{ $Param{WorkingUnits} }, \%Unit;
    }

    # insert new working units
    UNITREF:
    for my $UnitRef ( @{ $Param{WorkingUnits} } ) {

        my $StartTime = $Date . ' ' . ( $UnitRef->{StartTime} || '00:00' ) . ':00';
        my $EndTime   = $Date . ' ' . ( $UnitRef->{EndTime}   || '00:00' ) . ':00';

        # '' does not work in integer field of PostgreSQL
        $UnitRef->{ProjectID} ||= 0;
        $UnitRef->{ActionID}  ||= 0;
        $UnitRef->{Period}    ||= 0;

        # build DQL
        my $SQL = '
            INSERT INTO time_accounting_table (user_id, project_id, action_id, remark, time_start,
                time_end, period, created )
            VALUES  ( ?, ?, ?, ?, ?, ?, ?, current_timestamp)';
        my $Bind = [
            \$Param{UserID}, \$UnitRef->{ProjectID}, \$UnitRef->{ActionID},
            \$UnitRef->{Remark}, \$StartTime, \$EndTime, \$UnitRef->{Period},
        ];

        # db insert
        return if !$Kernel::OM->Get('Kernel::System::DB')->Do(
            SQL  => $SQL,
            Bind => $Bind
        );
    }

    return 1;
}

=item WorkingUnitsDelete()

deletes working units in the db

    $TimeAccountingObject->WorkingUnitsDelete(
        Year   => '2005',
        Month  => '7',
        Day    => '13',
        UserID => 123,
    );

=cut

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

    for my $Needed (qw(Year Month Day UserID)) {
        if ( !$Param{$Needed} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "WorkingUnitsInsert: Need $Needed!"
            );

            return;
        }
    }

    my $Date      = sprintf "%04d-%02d-%02d", $Param{Year}, $Param{Month}, $Param{Day};
    my $StartTime = $Date . ' 00:00:00';
    my $EndTime   = $Date . ' 23:59:59';

    return if !$Kernel::OM->Get('Kernel::System::DB')->Do(
        SQL => '
            DELETE FROM time_accounting_table
            WHERE time_start >= ?
                AND time_start <= ?
                AND user_id = ?',
        Bind => [ \$StartTime, \$EndTime, \$Param{UserID}, ],
    );

    return 1;
}

=item ProjectActionReporting()

returns a hash with the hours dependent project and action data

    my %ProjectData = $TimeAccountingObject->ProjectActionReporting(
        Year  => 2005,
        Month => 7,
        UserID => 123, # optional; no UserID means 'of all users'
    );

=cut

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

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    for my $Parameter (qw(Year Month)) {
        $Param{$Parameter} = $DBObject->Quote( $Param{$Parameter} ) || '';
        if ( !$Param{$Parameter} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "ProjectActionReporting: Need $Parameter!"
            );

            return;
        }
    }

    # hours per month
    my $DaysInMonth = Days_in_Month( $Param{Year}, $Param{Month} );
    my $DateString = $Param{Year} . "-" . sprintf( "%02d", $Param{Month} );
    my $SQLDate = "$DateString-$DaysInMonth 23:59:59";

    my $SQL = '
        SELECT project_id, action_id, period
        FROM time_accounting_table
        WHERE project_id != -1
            AND time_start <= ?';
    my @Bind = ( \$SQLDate );

    if ( $Param{UserID} ) {
        $SQL .= ' AND user_id = ?';
        push @Bind, \$Param{UserID};
    }

    # total hours
    $DBObject->Prepare(
        SQL  => $SQL,
        Bind => \@Bind,
    );

    # fetch the data
    my %Data;
    ROW:
    while ( my @Row = $DBObject->FetchrowArray() ) {

        next ROW if !$Row[2];

        $Data{ $Row[0] }->{Actions}->{ $Row[1] }->{Total} += $Row[2];
    }

    my $SQLDateStart = "$DateString-01 00:00:00";

    $SQL = '
        SELECT project_id, action_id, period
        FROM time_accounting_table
        WHERE project_id != -1
            AND time_start >= ?
            AND time_start <= ?';

    $DBObject->Prepare(
        SQL  => $SQL,
        Bind => [ \$SQLDateStart, \$SQLDate ],
    );

    # fetch the data
    ROW:
    while ( my @Row = $DBObject->FetchrowArray() ) {

        next ROW if !$Row[2];

        $Data{ $Row[0] }->{Actions}->{ $Row[1] }->{PerMonth} += $Row[2];
    }

    # add readable components
    my %Project = $Self->ProjectSettingsGet();
    my %Action  = $Self->ActionSettingsGet();

    for my $ProjectID ( sort keys %Data ) {

        $Data{$ProjectID}->{Name}        = $Project{Project}->{$ProjectID} || '';
        $Data{$ProjectID}->{Status}      = $Project{ProjectStatus}->{$ProjectID};
        $Data{$ProjectID}->{Description} = $Project{ProjectDescription}->{$ProjectID};

        my $ActionsRef = $Data{$ProjectID}->{Actions};

        for my $ActionID ( sort keys %{$ActionsRef} ) {
            $Data{$ProjectID}->{Actions}->{$ActionID}->{Name} = $Action{$ActionID}->{Action} || '';
        }
    }

    return %Data;
}

=item ProjectTotalHours()

returns the sum of all hours related to a project

    my $ProjectTotalHours = $TimeAccountingObject->ProjectTotalHours(
        ProjectID  => 15,
    );

=cut

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

    # check needed param
    if ( !$Param{ProjectID} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'ProjectActionReporting: Need ProjectID!'
        );

        return;
    }

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # ask the database
    return if !$DBObject->Prepare(
        SQL => '
            SELECT SUM(period)
            FROM time_accounting_table
            WHERE project_id = ?',
        Bind  => [ \$Param{ProjectID} ],
        Limit => 1,
    );

    # fetch the result
    my $Total = 0;
    while ( my @Row = $DBObject->FetchrowArray() ) {
        $Total = $Row[0];
    }

    return $Total;
}

=item ProjectHistory()

returns an array with all WorkingUnits related to a project

    my @ProjectHistoryArray = $TimeAccountingObject->ProjectHistory(
        ProjectID  => 15,
    );

This would return

    @ProjectHistoryArray = (
        {
            ID        => 999,
            UserID    => 15,
            User      => 'Tom',
            ActionID  => 6,
            Action    => 'misc',
            Remark    => 'remark',
            TimeStart => '7:00',
            TimeEnd   => '18:00',
            Date      => '2008-10-31', # the date of the working unit
            Period    => 11,
            Created   => '2008-11-01', # the insert time of the working unit
        },
        {
            ID        => 999,
            UserID    => 16,
            User      => 'Mane',
            ActionID  => 7,
            Action    => 'development',
            Remark    => 'remark',
            TimeStart => '7:00',
            TimeEnd   => '18:00',
            Period    => 11,
            Date      => '2008-11-03',
            Created   => '2008-11-03',
        }
    );

=cut

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

    # check needed param
    if ( !$Param{ProjectID} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'ProjectActionReporting: Need ProjectID!',
        );
        return;
    }

    # call action data to get the readable name of the action
    my %ActionData = $Self->ActionSettingsGet();

    # get user list
    my %ShownUsers = $Kernel::OM->Get('Kernel::System::User')->UserList(
        Type  => 'Long',
        Valid => 0,
    );

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # ask the database
    $DBObject->Prepare(
        SQL => '
            SELECT id, user_id, action_id, remark, time_start, time_end, period, created
            FROM time_accounting_table
            WHERE project_id = ?
            ORDER BY time_start',
        Bind => [ \$Param{ProjectID} ],
    );

    # fetch the result
    my @Data;
    while ( my @Row = $DBObject->FetchrowArray() ) {

        my $UserRef = {
            ID        => $Row[0],
            UserID    => $Row[1],
            User      => $ShownUsers{ $Row[1] },
            ActionID  => $Row[2],
            Action    => $ActionData{ $Row[2] }{Action},
            Remark    => $Row[3] || '',
            TimeStart => $Row[4],
            TimeEnd   => $Row[5],
            Date      => $Row[4],
            Period    => $Row[6],
            Created   => $Row[7],
        };
        $UserRef->{Date} =~ s{(\d\d\d\d-\d\d-\d\d) \s .+ }{$1}xms;

        push @Data, $UserRef;
    }

    return @Data;
}

=item LastProjectsOfUser()

returns an array with the last projects of the current user

    my @LastProjects = $TimeAccountingObject->LastProjectsOfUser(
        UserID => 123,
    );

=cut

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

    if ( !$Param{UserID} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => "Need UserID"
        );

        return;
    }

    # get database object
    my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

    # db select
    # I don't use distinct because of ORDER BY problems of PostgreSQL
    return if !$DBObject->Prepare(
        SQL => '
            SELECT project_id FROM time_accounting_table
            WHERE user_id = ?
                AND project_id <> -1
            ORDER BY time_start DESC',
        Bind  => [ \$Param{UserID} ],
        Limit => 40,
    );

    # fetch the result
    my %Projects;
    my $Counter = 0;
    ROW:
    while ( my @Row = $DBObject->FetchrowArray() ) {

        next ROW if $Counter > 7;
        next ROW if $Projects{ $Row[0] };

        $Projects{ $Row[0] } = 1;
        $Counter++;
    }

    return keys %Projects;
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

# --
# Kernel/System/Stats/Dynamic/TimeAccounting.pm - all advice functions
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::Stats::Dynamic::TimeAccounting;

use strict;
use warnings;

use Date::Pcalc qw( Add_Delta_Days Add_Delta_YMD );

our @ObjectDependencies = (
    'Kernel::System::Log',
    'Kernel::System::Time',
    'Kernel::System::TimeAccounting',
    'Kernel::System::User',
);

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

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

    return $Self;
}

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

    return 'TimeAccounting';
}

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

    # set predefined start time
    my $TimeStamp = $Kernel::OM->Get('Kernel::System::Time')->CurrentTimestamp();
    my ($Date) = split /\s+/, $TimeStamp;
    my $Today = sprintf "%s 23:59:59", $Date;

    # get time accounting object
    my $TimeAccountingObject = $Kernel::OM->Get('Kernel::System::TimeAccounting');

    # get project list
    my %ProjectList = $TimeAccountingObject->ProjectSettingsGet(
        Status => 'valid',
    );

    # get action list
    my %ActionListSource = $TimeAccountingObject->ActionSettingsGet();
    my %ActionList;

    for my $Action ( sort keys %ActionListSource ) {
        $ActionList{$Action} = $ActionListSource{$Action}->{Action};
    }

    # get user list
    my %UserList = $Kernel::OM->Get('Kernel::System::User')->UserList(
        Type  => 'Long',
        Valid => 0,
    );

    my @Attributes = (
        {
            Name             => 'Project',
            UseAsXvalue      => 1,
            UseAsValueSeries => 0,
            UseAsRestriction => 1,
            Element          => 'Project',
            Block            => 'MultiSelectField',
            Translation      => 0,
            Values           => $ProjectList{Project},
        },
        {
            Name             => 'User',
            UseAsXvalue      => 1,
            UseAsValueSeries => 0,
            UseAsRestriction => 1,
            Element          => 'User',
            Block            => 'MultiSelectField',
            Translation      => 0,
            Values           => \%UserList,
        },
        {
            Name             => 'Sort sequence',
            UseAsXvalue      => 0,
            UseAsValueSeries => 1,
            UseAsRestriction => 0,
            Element          => 'SortSequence',
            Block            => 'SelectField',
            Translation      => 0,
            Values           => {
                Up   => 'ascending',
                Down => 'descending',
            },
        },
        {
            Name             => 'Task',
            UseAsXvalue      => 0,
            UseAsValueSeries => 0,
            UseAsRestriction => 1,
            Element          => 'ProjectAction',
            Block            => 'MultiSelectField',
            Translation      => 0,
            Values           => \%ActionList,
        },
        {
            Name             => 'Period',
            UseAsXvalue      => 0,
            UseAsValueSeries => 0,
            UseAsRestriction => 1,
            Element          => 'Period',
            TimePeriodFormat => 'DateInputFormat',    # 'DateInputFormatLong',
            Block            => 'Time',
            Values           => {
                TimeStart => 'TimeAccountingPeriodStart',
                TimeStop  => 'TimeAccountingPeriodStop',
            },
        },
    );

    return @Attributes;
}

sub GetHeaderLine {
    my ( $Self, %Param ) = @_;
    my @HeaderLine = ("");

    # Users as X-value
    if ( $Param{XValue}{Element} && $Param{XValue}{Element} eq 'User' ) {

        # user have been selected as x-value
        my @UserIDs = @{ $Param{XValue}{SelectedValues} };

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

        # iterate over selected users
        USERID:
        for my $UserID (@UserIDs) {
            my $UserName = $UserObject->UserName(
                UserID => $UserID,
            );

            push @HeaderLine, $UserName;
        }
    }

    # Projects as X-value
    else {
        # projects have been selected as x-value
        my @ProjectIDs = @{ $Param{XValue}{SelectedValues} };

        # get time accounting object
        my $TimeAccountingObject = $Kernel::OM->Get('Kernel::System::TimeAccounting');

        # iterate over selected projects
        PROJECTID:
        for my $ProjectID (@ProjectIDs) {
            my %ProjectData = $TimeAccountingObject->ProjectGet(
                ID => $ProjectID,
            );

            push @HeaderLine, $ProjectData{Project};
        }
    }

    return \@HeaderLine;
}

sub GetStatTable {
    my ( $Self, %Param ) = @_;
    my @StatArray;
    my @UserIDs;

    # Users as X-value
    if ( $Param{XValue}{Element} && $Param{XValue}{Element} eq 'User' ) {

        # user have been selected as x-value
        @UserIDs = @{ $Param{XValue}{SelectedValues} };

        # get stat data
        my $StatData = $Self->_GetStatData(
            Param   => \%Param,
            UserIDs => \@UserIDs,
        );

        # check stat data
        return if !$StatData;
        return if ref $StatData ne 'ARRAY';

        my @RawStatArray = @{$StatData};
        return if !@RawStatArray;

        # get time accounting object
        my $TimeAccountingObject = $Kernel::OM->Get('Kernel::System::TimeAccounting');

        # get list of needed data
        my %ProjectData = $TimeAccountingObject->ProjectSettingsGet();
        my %ProjectList = %{ $ProjectData{Project} || {} };

        my %ActionData = $TimeAccountingObject->ActionSettingsGet();
        my %ActionList = map { ( $_ => $ActionData{$_}->{Action} ) } keys %ActionData;

        my @SortedProjectIDs = sort { $ProjectList{$a} cmp $ProjectList{$b} } keys %ProjectList;
        my @SortedActionIDs  = sort { $ActionList{$a} cmp $ActionList{$b} } keys %ActionList;

        # re-sort projects depending on selected sequence
        if ( $Param{ValueSeries} && $Param{ValueSeries}[0]{SelectedValues}[0] eq 'Down' ) {
            @SortedProjectIDs = reverse @SortedProjectIDs;
        }

        # iterate over sorted project list
        SORTEDPROJECTID:
        for my $SortedProjectID (@SortedProjectIDs) {

            # check for unselected projects
            next SORTEDPROJECTID if $Param{Restrictions}->{Project} && !grep {
                $_ == $SortedProjectID
            } @{ $Param{Restrictions}->{Project} || [] };

            # get the current project data of current project
            my @ProjectStatData = grep { $_->{ProjectID} == $SortedProjectID } @RawStatArray;

            # iterate over sorted action list
            SORTEDACTIONID:
            for my $SortedActionID (@SortedActionIDs) {

                # check for unselected actions
                next SORTEDACTIONID if $Param{Restrictions}->{ProjectAction} && !grep {
                    $_ == $SortedActionID
                } @{ $Param{Restrictions}->{ProjectAction} || [] };

                # get the current action out of the current project
                my @ActionStatData = grep { $_->{ActionID} == $SortedActionID } @ProjectStatData;

                my @RowData;

                # add descriptive first column
                my $RowLabel = "$ProjectList{$SortedProjectID}::$ActionList{$SortedActionID}";
                push @RowData, $RowLabel;

                # iterate over selected users
                USERID:
                for my $UserID (@UserIDs) {

                    # at least get '0' for user data
                    my $UserPeriodSum = 0;

                    # iterate over period data of user
                    for my $PeriodData ( grep { $_->{UserID} == $UserID } @ActionStatData ) {
                        $UserPeriodSum += $PeriodData->{Period};
                    }

                    # safe user data to row data
                    push @RowData, $UserPeriodSum;
                }

                # store current row to global stat array
                push @StatArray, \@RowData;
            }
        }
    }

    # Projects as X-value
    else {

        # projects have been selected as x-value
        my @ProjectIDs = @{ $Param{XValue}{SelectedValues} };

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

        # we need to get all users
        my %UserIDs = $UserObject->UserList(
            Type  => 'Short',
            Valid => 1,
        );

        @UserIDs = keys %UserIDs;

        # get calculated stats data
        my $StatData = $Self->_GetStatData(
            Param   => \%Param,
            UserIDs => \@UserIDs,
        );

        # check stat data
        return if !$StatData;
        return if ref $StatData ne 'ARRAY';

        my @RawStatArray = @{$StatData};
        return if !@RawStatArray;

        # get list of needed data
        my %UserList = $UserObject->UserList(
            Type  => 'Long',
            Valid => 1,
        );

        my @SortedUserIDs = sort { $UserList{$a} cmp $UserList{$b} } keys %UserList;

        # re-sort users depending on selected sequence
        if ( $Param{ValueSeries} && $Param{ValueSeries}[0]{SelectedValues}[0] eq 'Down' ) {
            @SortedUserIDs = reverse @SortedUserIDs;
        }

        # iterate over sorted user list
        SORTEDUSERID:
        for my $SortedUserID (@SortedUserIDs) {

            # check for unselected users
            next SORTEDUSERID if $Param{Restrictions}->{User} && !grep {
                $_ == $SortedUserID
            } @{ $Param{Restrictions}->{User} || [] };

            # get the current user data of current user
            my @UserStatData = grep { $_->{UserID} == $SortedUserID } @RawStatArray;

            my @RowData;

            # add descriptive first column
            my $RowLabel = $UserList{$SortedUserID};
            push @RowData, $RowLabel;

            # iterate over selected projects
            PROJECTID:
            for my $ProjectID (@ProjectIDs) {

                # at least get '0' for user data
                my $ProjectPeriodSum = 0;

                # iterate over period data of user
                for my $PeriodData ( grep { $_->{ProjectID} == $ProjectID } @UserStatData ) {
                    $ProjectPeriodSum += $PeriodData->{Period};
                }

                # safe user data to row data
                push @RowData, $ProjectPeriodSum;
            }

            # store current row to global stat array
            push @StatArray, \@RowData;
        }

    }

    return @StatArray;
}

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

    # get needed objects
    my $UserObject           = $Kernel::OM->Get('Kernel::System::User');
    my $TimeAccountingObject = $Kernel::OM->Get('Kernel::System::TimeAccounting');

    # wrap ids to used spelling
    for my $Use (qw(UseAsValueSeries UseAsRestriction UseAsXvalue)) {
        ELEMENT:
        for my $Element ( @{ $Param{$Use} } ) {
            next ELEMENT if !$Element || !$Element->{SelectedValues};
            my $ElementName = $Element->{Element};
            my $Values      = $Element->{SelectedValues};

            if ( $ElementName eq 'User' ) {
                ID:
                for my $ID ( @{$Values} ) {
                    next ID if !$ID;

                    $ID->{Content} = $UserObject->UserLookup( UserID => $ID->{Content} );
                }
            }
            elsif ( $ElementName eq 'Project' ) {
                ID:
                for my $ID ( @{$Values} ) {
                    next ID if !$ID;

                    my %TmpProjectData = $TimeAccountingObject->ProjectGet( ID => $ID->{Content} );
                    $ID->{Content} = $TmpProjectData{Project};
                }
            }
            elsif ( $ElementName eq 'ProjectAction' ) {
                ID:
                for my $ID ( @{$Values} ) {
                    next ID if !$ID;

                    my %TmpActionData = $TimeAccountingObject->ActionGet( ID => $ID->{Content} );
                    $ID->{Content} = $TmpActionData{Action};
                }
            }
        }
    }
    return \%Param;
}

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

    # get needed objects
    my $UserObject           = $Kernel::OM->Get('Kernel::System::User');
    my $LogObject            = $Kernel::OM->Get('Kernel::System::Log');
    my $TimeAccountingObject = $Kernel::OM->Get('Kernel::System::TimeAccounting');

    # wrap used spelling to ids
    for my $Use (qw(UseAsValueSeries UseAsRestriction UseAsXvalue)) {
        ELEMENT:
        for my $Element ( @{ $Param{$Use} } ) {
            next ELEMENT if !$Element || !$Element->{SelectedValues};

            my $ElementName = $Element->{Element};
            my $Values      = $Element->{SelectedValues};

            if ( $ElementName eq 'User' ) {
                ID:
                for my $ID ( @{$Values} ) {
                    next ID if !$ID;

                    if ( $UserObject->UserLookup( UserLogin => $ID->{Content} ) ) {
                        $ID->{Content} = $UserObject->UserLookup( UserLogin => $ID->{Content} );
                    }
                    else {
                        $LogObject->Log(
                            Priority => 'error',
                            Message  => "Import: Can' find the user $ID->{Content}!"
                        );
                        $ID = undef;
                    }
                }
            }
            elsif ( $ElementName eq 'Project' ) {
                ID:
                for my $ID ( @{$Values} ) {
                    next ID if !$ID;

                    my %Project = $TimeAccountingObject->ProjectGet(
                        Project => $ID->{Content},
                    );
                    if ( $Project{ID} ) {
                        $ID->{Content} = $Project{ID};
                    }
                    else {
                        $LogObject->Log(
                            Priority => 'error',
                            Message  => "Import: Can' find project $ID->{Content}!"
                        );
                        $ID = undef;
                    }
                }
            }
            elsif ( $ElementName eq 'ProjectAction' ) {
                ID:
                for my $ID ( @{$Values} ) {
                    next ID if !$ID;

                    my %Action = $TimeAccountingObject->ActionGet(
                        Action => $ID->{Content},
                    );
                    if ( $Action{ID} ) {
                        $ID->{Content} = $Action{ID};
                    }
                    else {
                        $LogObject->Log(
                            Priority => 'error',
                            Message  => "Import: Can' find action $ID->{Content}!"
                        );
                        $ID = undef;
                    }
                }
            }
        }
    }
    return \%Param;
}

sub _GetStatData {

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

    my @Return;
    my @UserIDs = @{ $Param{UserIDs} || [] };

    my %DateIndexToName = (
        'Second' => 0,
        'Minute' => 1,
        'Hour'   => 2,
        'Day'    => 3,
        'Month'  => 4,
        'Year'   => 5,
    );

    # looping over all or selected users
    for my $UserID (@UserIDs) {

        my $StartDate;
        my $StopDate;

        # get time object
        my $TimeObject = $Kernel::OM->Get('Kernel::System::Time');

        # check if time period has been selected
        if ( $Param{Param}{Restrictions}{TimeAccountingPeriodStart} ) {

            # get UNIX time-stamp of start and end values
            $StartDate = $TimeObject->TimeStamp2SystemTime(
                String => $Param{Param}{Restrictions}{TimeAccountingPeriodStart},
            );
            $StopDate = $TimeObject->TimeStamp2SystemTime(
                String => $Param{Param}{Restrictions}{TimeAccountingPeriodStop},
            );
        }
        else {

            # IMPORTANT:
            # If no time period had been selected previous month will be used as period!

            # get current date values
            my @CurrentDate = $TimeObject->SystemTime2Date(
                SystemTime => $TimeObject->SystemTime(),
            );

            # get first day of previous month
            my @NewStartDate = Add_Delta_YMD(
                $CurrentDate[ $DateIndexToName{'Year'} ],
                $CurrentDate[ $DateIndexToName{'Month'} ],
                1,
                0,
                -1,
                0,
            );

            # get first day of next month relative to previous month
            my @NewStopDate = Add_Delta_YMD(
                $NewStartDate[0],
                $NewStartDate[1],
                $NewStartDate[2],
                0,
                +1,
                0,
            );

            # get last of day previous month
            @NewStopDate = Add_Delta_YMD(
                $NewStopDate[0],
                $NewStopDate[1],
                $NewStopDate[2],
                0,
                0,
                -1,
            );

            # calculate unix timestamp for start and stop date
            $StartDate = $TimeObject->Date2SystemTime(
                Year   => $NewStartDate[0],
                Month  => $NewStartDate[1],
                Day    => $NewStartDate[2],
                Hour   => 0,
                Minute => 0,
                Second => 0,
            );
            $StopDate = $TimeObject->Date2SystemTime(
                Year   => $NewStopDate[0],
                Month  => $NewStopDate[1],
                Day    => $NewStopDate[2],
                Hour   => 23,
                Minute => 59,
                Second => 59,
            );
        }

        # calculate number of days within the given range
        my $Days = int( ( $StopDate - $StartDate ) / 86400 ) + 1;

        # get time accounting object
        my $TimeAccountingObject = $Kernel::OM->Get('Kernel::System::TimeAccounting');

        DAY:
        for my $Day ( 0 .. $Days ) {

            # get day relative to start date
            my $DateOfPeriod = $StartDate + $Day * 86400;

            # get needed date values out of time-stamp
            my @DateValues = $TimeObject->SystemTime2Date(
                SystemTime => $DateOfPeriod,
            );

            # get working unit for user and day
            my %WorkingUnit = $TimeAccountingObject->WorkingUnitsGet(
                Year   => $DateValues[ $DateIndexToName{'Year'} ],
                Month  => $DateValues[ $DateIndexToName{'Month'} ],
                Day    => $DateValues[ $DateIndexToName{'Day'} ],
                UserID => $UserID,
            );

            # extract detailed information
            my @DayWorkingUnits = @{ $WorkingUnit{WorkingUnits} || [] };

            # check for project restrictions
            if (
                $Param{Param}{Restrictions}->{Project}
                && ref $Param{Param}{Restrictions}->{Project} eq 'ARRAY'
                )
            {

                # build matching hash for selected projects
                my %SelectedProjectIDs = map { ( $_ => 1 ) } @{ $Param{Param}{Restrictions}->{Project} };

                # filter only selected projects
                my @FilteredProjectWUs = grep {
                    $SelectedProjectIDs{ $_->{ProjectID} }
                } @DayWorkingUnits;

                @DayWorkingUnits = @FilteredProjectWUs;
            }

            # check for task restrictions
            if (
                $Param{Param}{Restrictions}->{ProjectAction}
                && ref $Param{Param}{Restrictions}->{ProjectAction} eq 'ARRAY'
                )
            {

                # build matching hash for selected actions
                my %SelectedActionIDs = map { ( $_ => 1 ) } @{ $Param{Param}{Restrictions}->{ProjectAction} };

                # filter only selected actions
                my @FilteredActionWUs = grep {
                    $SelectedActionIDs{ $_->{ActionID} }
                } @DayWorkingUnits;

                @DayWorkingUnits = @FilteredActionWUs;
            }

            # check for user restrictions
            if (
                $Param{Param}{Restrictions}->{User}
                && ref $Param{Param}{Restrictions}->{User} eq 'ARRAY'
                )
            {

                # build matching hash for selected actions
                my %SelectedUserIDs = map { ( $_ => 1 ) } @{ $Param{Param}{Restrictions}->{User} };

                # filter only selected actions
                my @FilteredUserWUs = grep {
                    $SelectedUserIDs{ $_->{UserID} }
                } @DayWorkingUnits;

                @DayWorkingUnits = @FilteredUserWUs;
            }

            # do not store data if no data is available
            next DAY if !@DayWorkingUnits;

            # add data to global result set
            push @Return, @DayWorkingUnits;
        }
    }

    return \@Return;

}

1;

# --
# scripts/test/TimeAccounting.t - TimeAccounting test script
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

## no critic (Modules::RequireExplicitPackage)
use strict;
use warnings;

# declare externally defined variables to avoid errors under 'use strict'
use vars qw($Self);

my $RandomNumber = int( rand(10000) );

# data for the new action (task)
my %NewActionData = (
    Action       => 'TestAction' . $RandomNumber,
    ActionStatus => 1,
);

# get time accounting object
my $TimeAccountingObject = $Kernel::OM->Get('Kernel::System::TimeAccounting');

# create a new action (task)
my $Insert = $TimeAccountingObject->ActionSettingsInsert(%NewActionData);

# verify that the action was successfully inserted
$Self->True(
    $Insert,
    'Insert test action settings into database',
);

# get the action data that was inserted above
my %ActionData = $TimeAccountingObject->ActionGet( Action => $NewActionData{Action} );

# verify that the data saved in the DB is the same that was inserted
$Self->Is(
    $ActionData{ActionStatus},
    $NewActionData{ActionStatus},
    'Compare action status saved in DB with the inserted one',
);

# modify the action name
my $Update = $TimeAccountingObject->ActionSettingsUpdate(
    ActionID     => $ActionData{ID},
    Action       => $NewActionData{Action} . 'modified',
    ActionStatus => 1,
);

# verify that the action was updated
$Self->True(
    $Update,
    'Update test action settings',
);

# get all actions data
my %AllActions = $TimeAccountingObject->ActionSettingsGet();

# verify the last modification
$Self->Is(
    $AllActions{ $ActionData{ID} }{Action},
    $NewActionData{Action} . 'modified',
    'Compare action name saved in DB with the specified in the update',
);

# data for the new project
my %NewProjectData = (
    Project            => 'TestProject' . $RandomNumber,
    ProjectDescription => 'Test',
    ProjectStatus      => 1,
);

# create a new project
my $ProjectID = $TimeAccountingObject->ProjectSettingsInsert(%NewProjectData);

# verify that the action was successfully inserted
$Self->True(
    $ProjectID,
    'Insert test project settings into database',
);

# get the action data that was inserted above
my %ProjectData = $TimeAccountingObject->ProjectGet( ID => $ProjectID );

# verify that the data saved in the DB is the same that was inserted
$Self->Is(
    $ProjectData{Project},
    $NewProjectData{Project},
    'Compare project name saved in DB with the inserted one',
);
$Self->Is(
    $ProjectData{ProjectDescription},
    $NewProjectData{ProjectDescription},
    'Compare project description saved in DB with the inserted one',
);
$Self->Is(
    $ProjectData{ProjectStatus},
    $NewProjectData{ProjectStatus},
    'Compare project status saved in DB with the inserted one',
);

# modify the project name
$Update = $TimeAccountingObject->ProjectSettingsUpdate(
    ID                 => $ProjectID,
    Project            => $NewProjectData{Project} . 'modified',
    ProjectDescription => 'Test',
    ProjectStatus      => 1,
);

# verify that the action was updated
$Self->True(
    $Update,
    'Update test project settings',
);

# get all projects data
my %AllProjects = $TimeAccountingObject->ProjectSettingsGet( Status => 'valid' );

# verify the last modification
$Self->Is(
    $AllProjects{Project}{$ProjectID},
    $NewProjectData{Project} . 'modified',
    'Compare project name saved in DB with the specified in the update',
);

# create new user
my $UserLogin = $Kernel::OM->Get('Kernel::System::UnitTest::Helper')->TestUserCreate();
my $UserID    = $Kernel::OM->Get('Kernel::System::User')->UserLookup(
    UserLogin => $UserLogin,
);

# obtain the last registered period of the test user
my $LastPeriodNumber = $TimeAccountingObject->UserLastPeriodNumberGet( UserID => $UserID ) + 1;

# create registry for the new user in TA
$Insert = $TimeAccountingObject->UserSettingsInsert(
    UserID => $UserID,
    Period => $LastPeriodNumber,
);

# verify that the user was successfully inserted
$Self->True(
    $Insert,
    'Insert test user settings into database',
);

# insert another period entry for the same user
$Insert = $TimeAccountingObject->UserSettingsInsert(
    UserID => $UserID,
    Period => $LastPeriodNumber + 1,
);

# verify that the user was successfully inserted
$Self->True(
    $Insert,
    'Insert time period for test user settings into database',
);

$RandomNumber = int( rand(100) );

# update user data
$Update = $TimeAccountingObject->UserSettingsUpdate(
    UserID        => $UserID,
    Description   => 'Test user' . $RandomNumber,
    CreateProject => 1,
    ShowOvertime  => 1,
    Period        => {
        1 => {
            DateStart   => '2011-01-01',
            DateEnd     => '2011-01-31',
            WeeklyHours => $RandomNumber,
            LeaveDays   => '10',
            Overtime    => '20',
            UserStatus  => 1,
        },
        2 => {
            DateStart   => '2011-02-01',
            DateEnd     => '2011-12-31',
            WeeklyHours => $RandomNumber + 10,
            LeaveDays   => '5',
            Overtime    => '10',
            UserStatus  => 1,
        },
    },
);

# verify that the action was updated
$Self->True(
    $Update,
    'Update test user settings',
);

# get user settings
my %SingleUserData = $TimeAccountingObject->SingleUserSettingsGet( UserID => $UserID );

# verify the last modification
$Self->Is(
    int $SingleUserData{1}{WeeklyHours},
    $RandomNumber,
    'Compare weekly hours for period 1 saved in DB with the specified in the update',
);

$Self->Is(
    int $SingleUserData{2}{WeeklyHours},
    $RandomNumber + 10,
    'Compare weekly hours for period 2 saved in DB with the specified in the update',
);

# get user data
%SingleUserData = $TimeAccountingObject->UserGet( UserID => $UserID );

# compare data saved on the DB with the inserted one
$Self->Is(
    $SingleUserData{Description},
    'Test user' . $RandomNumber,
    'Compare description saved on the DB with the specified in the insertion',
);

# get all users data
my %AllUsersData = $TimeAccountingObject->UserList();

# verify that the test user is in the list
$Self->True(
    $AllUsersData{$UserID}{Description},
    'Verify the existence of the test user in the list'
);

# get all periods of data of all users
my %AllUsersPeriodData = $TimeAccountingObject->UserSettingsGet();

# verify the period data of the test user
my $CorrectUserData =
    (
    $AllUsersPeriodData{$UserID}{1}{WeeklyHours} == $RandomNumber
        && $AllUsersPeriodData{$UserID}{1}{LeaveDays} == 10
        && $AllUsersPeriodData{$UserID}{1}{Overtime} == 20
        && $AllUsersPeriodData{$UserID}{1}{UserStatus}
        && $AllUsersPeriodData{$UserID}{2}{WeeklyHours} == $RandomNumber + 10
        && $AllUsersPeriodData{$UserID}{2}{LeaveDays} == 5
        && $AllUsersPeriodData{$UserID}{2}{Overtime} == 10
        && $AllUsersPeriodData{$UserID}{2}{UserStatus}
    ) ? 1 : 0;

$Self->True(
    $CorrectUserData,
    'Verify the period data of the test user in the list'
);

# get current period of user
my %UserCurrentPeriod = $TimeAccountingObject->UserCurrentPeriodGet(
    Year  => '2011',
    Month => '01',
    Day   => '15',
);

# check the period
$Self->Is(
    $UserCurrentPeriod{$UserID}->{Period},
    1,
    'Verify current period',
);

$Self->Is(
    $UserCurrentPeriod{$UserID}->{DateStart},
    '2011-01-01',
    'Verify start date of current period',
);

$Self->Is(
    $UserCurrentPeriod{$UserID}->{DateEnd},
    '2011-01-31',
    'Verify end date of current period',
);

# hash with the working units for Jan. 15th, 2011
my %WorkingUnits = (
    Year         => '2011',
    Month        => '01',
    Day          => '15',
    LeaveDay     => 0,
    Sick         => 0,
    Overtime     => 0,
    WorkingUnits => [
        {
            ProjectID => $ProjectID,
            ActionID  => $ActionData{ID},
            Remark    => 'My comment',
            StartTime => '7:00',
            EndTime   => '10:00',
            Period    => 3.0,
        },
        {
            ProjectID => $ProjectID,
            ActionID  => $ActionData{ID},
            Remark    => 'My comment',
            StartTime => '13:00',
            EndTime   => '15:00',
            Period    => 2.0,
        },
    ],
    UserID => $UserID,
);

# insert working units in the DB
$Insert = $TimeAccountingObject->WorkingUnitsInsert(%WorkingUnits);

# verify that the working units were successfully inserted
$Self->True(
    $Insert,
    'Insert working units for test user into database',
);

# get all days without working units entry
my %WorkingUnitsCheck = $TimeAccountingObject->WorkingUnitsCompletnessCheck(
    UserID => $UserID,
);

# verify that Jan 15th, 2011 is not in the list of days without entry
$Self->False(
    defined $WorkingUnitsCheck{'Incomplete'}{'2011'}{'01'}{'15'},
    'Verify completion of working units'
);

# get working units of all users
my %Data = $TimeAccountingObject->UserReporting(
    Year  => '2011',
    Month => '01',
    Day   => '15',
);

# verify the correctness of the working units for the test user
$Self->Is(
    $Data{$UserID}{WorkingHoursTotal},
    5,
    'Verify number of working hours of the test user',
);

# get projects in which the test user has worked on
my @LastProjects = $TimeAccountingObject->LastProjectsOfUser(
    UserID => $UserID,
);

my $TestProjectExistence;

ID:
for my $ID (@LastProjects) {
    next ID if $ID != $ProjectID;
    $TestProjectExistence = 1;
}

# verify that existence of the test project into the user's list
$Self->True(
    $TestProjectExistence,
    'Verify that existence of the test project into the user\'s list',
);

# get project - action working hours
my %ProjectActionWorkingHours = $TimeAccountingObject->ProjectActionReporting(
    Year   => 2011,
    Month  => 1,
    UserID => $UserID,
);

# verify total reported hours for the test action (task) and test project
$Self->Is(
    $ProjectActionWorkingHours{$ProjectID}{Actions}{ $ActionData{ID} }{Total},
    '5',
    'Verify total reported hours for the test action (task) and test project',
);

# get project working units
my @ProjectHistoryArray = $TimeAccountingObject->ProjectHistory( ProjectID => $ProjectID );

my $TotalHours;

# get sum of all working unit for the test project
for my $Project (@ProjectHistoryArray) {
    $TotalHours += $Project->{Period};
}

my $TestProjectTotalHours = $TimeAccountingObject->ProjectTotalHours(
    ProjectID => $ProjectID,
);

# verify total working units for the test project
$Self->Is(
    int $TotalHours,
    int $TestProjectTotalHours,
    'Verify total hours of test project',
);

# delete working units for Jan. 15th, 2011
my $Delete = $TimeAccountingObject->WorkingUnitsDelete(
    Year   => '2011',
    Month  => '1',
    Day    => '15',
    UserID => $UserID,
);

# verify that the working units were successfully deleted
$Self->True(
    $Delete,
    'Delete working units for test',
);

# get working units for Jan. 15th, 2011
my %WorkingUnitsData = $TimeAccountingObject->WorkingUnitsGet(
    Year   => '2011',
    Month  => '1',
    Day    => '15',
    UserID => $UserID,
);

# verify inexistence of the deleted working units
$Self->Is(
    $WorkingUnitsData{Total},
    '0',
    'Verify inexistence of the deleted working units',
);

# set to invalid all registries used for the tests
$TimeAccountingObject->ActionSettingsUpdate(
    ActionID     => $ActionData{ID},
    Action       => $NewActionData{Action} . 'modified',
    ActionStatus => 0,
);

$TimeAccountingObject->ProjectSettingsUpdate(
    ID                 => $ProjectID,
    Project            => $NewProjectData{Project} . 'modified',
    ProjectDescription => 'Test',
    ProjectStatus      => 0,
);

$TimeAccountingObject->UserSettingsUpdate(
    UserID        => $UserID,
    Description   => 'Test user',
    CreateProject => 0,
    ShowOvertime  => 0,
    Period        => {
        1 => {
            DateStart   => '2011-01-01',
            DateEnd     => '2011-01-31',
            WeeklyHours => '50',
            LeaveDays   => '10',
            Overtime    => '20',
            UserStatus  => 0,
        },
        2 => {
            DateStart   => '2011-02-01',
            DateEnd     => '2011-02-28',
            WeeklyHours => '30',
            LeaveDays   => '5',
            Overtime    => '10',
            UserStatus  => 0,
        },
    },
);

1;

Ly8gLS0KLy8ganF1ZXJ5LWNvbWJvYm94LmpzIC0gc3BlY2lhbCBqcXVlcnkgdWkgY29tYm9ib3gKLy8gQ29weXJpZ2h0IChDKSAyMDAxLTIwMTQgT1RSUyBBRywgaHR0cDovL290cnMuY29tL1xuIjsKLy8gLS0KLy8gVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKLy8gdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQovLyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgovLyAtLQoKKGZ1bmN0aW9uKCQpIHsKICAgICQud2lkZ2V0KCJ1aS5jb21ib2JveCIsIHsKICAgICAgICBvcHRpb25zOiB7CiAgICAgICAgICAgIENsYXNzOiAnJywKICAgICAgICAgICAgSURQcmVmaXhJbnB1dDogJ0NvbWJvXycsCiAgICAgICAgICAgIElEUHJlZml4QnV0dG9uOiAnQ29tYm9CdG5fJywKICAgICAgICAgICAgVmFsaWRhdGlvblRvb2x0aXA6ICcnLAogICAgICAgICAgICBMYW5nOiB7CiAgICAgICAgICAgICAgICBTaG93QWxsSXRlbXM6ICdTaG93IGFsbCBpdGVtcycsCiAgICAgICAgICAgICAgICBJbnB1dFRpdGxlOiAnVGl0bGUnCiAgICAgICAgICAgIH0KICAgICAgICB9LAogICAgICAgIF9jcmVhdGU6IGZ1bmN0aW9uKCkgewogICAgICAgICAgICB2YXIgU2VsZiA9IHRoaXMsCiAgICAgICAgICAgICAgICAkU2VsZWN0ID0gdGhpcy5lbGVtZW50LmhpZGUoKSwKICAgICAgICAgICAgICAgICRTZWxlY3RlZCA9ICRTZWxlY3QuY2hpbGRyZW4oIjpzZWxlY3RlZCIpLAogICAgICAgICAgICAgICAgVmFsdWUgPSAkU2VsZWN0ZWQudmFsKCkgPyAkU2VsZWN0ZWQudGV4dCgpIDogIiIsCiAgICAgICAgICAgICAgICAkSW5wdXQgPSB0aGlzLmlucHV0ID0gJCgiPGlucHV0PiIpCiAgICAgICAgICAgICAgICAuYWRkQ2xhc3ModGhpcy5vcHRpb25zLkNsYXNzKQogICAgICAgICAgICAgICAgLmF0dHIoJ2lkJywgdGhpcy5vcHRpb25zLklEUHJlZml4SW5wdXQgKyAkU2VsZWN0WzBdLmlkKQogICAgICAgICAgICAgICAgLmF0dHIoJ3RpdGxlJywgdGhpcy5vcHRpb25zLkxhbmcuSW5wdXRUaXRsZSkKICAgICAgICAgICAgICAgIC5pbnNlcnRBZnRlcigkU2VsZWN0KQogICAgICAgICAgICAgICAgLmNzcygnd2lkdGgnLCAkU2VsZWN0LndpZHRoKCkpCiAgICAgICAgICAgICAgICAudmFsKFZhbHVlKQogICAgICAgICAgICAgICAgLmF1dG9jb21wbGV0ZSh7CiAgICAgICAgICAgICAgICAgICAgZGVsYXk6IDAsCiAgICAgICAgICAgICAgICAgICAgbWluTGVuZ3RoOiAwLAogICAgICAgICAgICAgICAgICAgIHNvdXJjZTogZnVuY3Rpb24oUmVxdWVzdCwgUmVzcG9uc2UpIHsKICAgICAgICAgICAgICAgICAgICAgICAgdmFyIE1hdGNoZXIgPSBuZXcgUmVnRXhwKCQudWkuYXV0b2NvbXBsZXRlLmVzY2FwZVJlZ2V4KFJlcXVlc3QudGVybSksICJpIiApOwoKICAgICAgICAgICAgICAgICAgICAgICAgUmVzcG9uc2UoJFNlbGVjdC5jaGlsZHJlbigib3B0aW9uIikubWFwKGZ1bmN0aW9uKCkgewogICAgICAgICAgICAgICAgICAgICAgICAgICAgdmFyIFRleHQgPSAkKHRoaXMpLnRleHQoKTsKICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmICh0aGlzLnZhbHVlICYmICghUmVxdWVzdC50ZXJtIHx8IE1hdGNoZXIudGVzdChUZXh0KSkpCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHsKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWw6IFRleHQucmVwbGFjZSgKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ldyBSZWdFeHAoCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIig/IVteJjtdKzspKD8hPFtePD5dKikoIiArCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgJC51aS5hdXRvY29tcGxldGUuZXNjYXBlUmVnZXgoUmVxdWVzdC50ZXJtKSArCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIikoPyFbXjw+XSo+KSg/IVteJjtdKzspIiwgImdpIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKSwgIjxzdHJvbmc+JDE8L3N0cm9uZz4iICksCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZhbHVlOiBUZXh0LAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBvcHRpb246IHRoaXMKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB9OwogICAgICAgICAgICAgICAgICAgICAgICB9KSk7CiAgICAgICAgICAgICAgICAgICAgfSwKICAgICAgICAgICAgICAgICAgICBzZWxlY3Q6IGZ1bmN0aW9uKEV2ZW50LCBVSSkgewogICAgICAgICAgICAgICAgICAgICAgICBpZiAoVUkuaXRlbS5vcHRpb24uZGlzYWJsZWQpIHsKICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTsKICAgICAgICAgICAgICAgICAgICAgICAgfQogICAgICAgICAgICAgICAgICAgICAgICBVSS5pdGVtLm9wdGlvbi5zZWxlY3RlZCA9IHRydWU7CiAgICAgICAgICAgICAgICAgICAgICAgIFNlbGYuX3RyaWdnZXIoInNlbGVjdGVkIiwgRXZlbnQsIHsKICAgICAgICAgICAgICAgICAgICAgICAgICAgIGl0ZW06IFVJLml0ZW0ub3B0aW9uCiAgICAgICAgICAgICAgICAgICAgICAgIH0pOwogICAgICAgICAgICAgICAgICAgIH0sCiAgICAgICAgICAgICAgICAgICAgb3BlbjogZnVuY3Rpb24oRXZlbnQsIFVJKSB7CiAgICAgICAgICAgICAgICAgICAgICAgICQoJ3VsLnVpLWF1dG9jb21wbGV0ZS51aS1tZW51JykuZWFjaChmdW5jdGlvbiAoKSB7CiAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YXIgd2lkdGggPSAkKHRoaXMpLndpZHRoKCk7CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAkKHRoaXMpLndpZHRoKHdpZHRoICsgMzApOwogICAgICAgICAgICAgICAgICAgICAgICB9KTsKICAgICAgICAgICAgICAgICAgICB9LAogICAgICAgICAgICAgICAgICAgIGNoYW5nZTogZnVuY3Rpb24oRXZlbnQsIFVJKSB7CiAgICAgICAgICAgICAgICAgICAgICAgIGlmICghVUkuaXRlbSkgewogICAgICAgICAgICAgICAgICAgICAgICAgICAgdmFyIE1hdGNoZXIgPSBuZXcgUmVnRXhwKCAiXiIgKyAkLnVpLmF1dG9jb21wbGV0ZS5lc2NhcGVSZWdleCggJCh0aGlzKS52YWwoKSApICsgIiQiLCAiaSIgKSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBWYWxpZCA9IGZhbHNlOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgJFNlbGVjdC5jaGlsZHJlbigib3B0aW9uIikuZWFjaChmdW5jdGlvbigpIHsKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZiAoJCh0aGlzKS50ZXh0KCkubWF0Y2goTWF0Y2hlcikpIHsKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5zZWxlY3RlZCA9IFZhbGlkID0gdHJ1ZTsKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGZhbHNlOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKCFWYWxpZCkgewogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8vIHJlbW92ZSBpbnZhbGlkIHZhbHVlLCBhcyBpdCBkaWRuJ3QgbWF0Y2ggYW55dGhpbmcKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAkKHRoaXMpLnZhbCgiIik7CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgJFNlbGVjdC52YWwoIiIpOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICRJbnB1dC5kYXRhKCJ1aUF1dG9jb21wbGV0ZSIpLnRlcm0gPSAiIjsKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByZXR1cm4gZmFsc2U7CiAgICAgICAgICAgICAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICB9KQogICAgICAgICAgICAgICAgLmFkZENsYXNzKCJ1aS13aWRnZXQgdWktd2lkZ2V0LWNvbnRlbnQgdWktY29ybmVyLWxlZnQiKQogICAgICAgICAgICAgICAgLmFmdGVyKHRoaXMub3B0aW9ucy5WYWxpZGF0aW9uVG9vbHRpcCk7CgogICAgICAgICAgICAkSW5wdXQuZGF0YSgidWlBdXRvY29tcGxldGUiKS5fcmVuZGVySXRlbSA9IGZ1bmN0aW9uKFVMLCBJdGVtKSB7CiAgICAgICAgICAgICAgICByZXR1cm4gJCgiPGxpPjwvbGk+IikKICAgICAgICAgICAgICAgICAgICAuZGF0YSgiaXRlbS5hdXRvY29tcGxldGUiLCBJdGVtKQogICAgICAgICAgICAgICAgICAgIC5hcHBlbmQoIjxhPiIgKyBJdGVtLmxhYmVsICsgIjwvYT4iKQogICAgICAgICAgICAgICAgICAgIC5hcHBlbmRUbyhVTCk7CiAgICAgICAgICAgIH07CgogICAgICAgICAgICB0aGlzLmJ1dHRvbiA9ICQoIjxidXR0b24gdHlwZT0nYnV0dG9uJz4mbmJzcDs8L2J1dHRvbj4iKQogICAgICAgICAgICAgICAgLmF0dHIoInRhYkluZGV4IiwgLTEpCiAgICAgICAgICAgICAgICAuYXR0cigidGl0bGUiLCB0aGlzLm9wdGlvbnMuTGFuZy5TaG93QWxsSXRlbXMpCiAgICAgICAgICAgICAgICAuYXR0cignaWQnLCB0aGlzLm9wdGlvbnMuSURQcmVmaXhCdXR0b24gKyAkU2VsZWN0WzBdLmlkKQogICAgICAgICAgICAgICAgLmluc2VydEFmdGVyKCRJbnB1dCkKICAgICAgICAgICAgICAgIC5idXR0b24oewogICAgICAgICAgICAgICAgICAgIGljb25zOiB7CiAgICAgICAgICAgICAgICAgICAgICAgIHByaW1hcnk6ICJ1aS1pY29uLXRyaWFuZ2xlLTEtcyIKICAgICAgICAgICAgICAgICAgICB9LAogICAgICAgICAgICAgICAgICAgIHRleHQ6IGZhbHNlCiAgICAgICAgICAgICAgICB9KQogICAgICAgICAgICAgICAgLnJlbW92ZUNsYXNzKCJ1aS1jb3JuZXItYWxsIikKICAgICAgICAgICAgICAgIC5hZGRDbGFzcygidWktY29ybmVyLXJpZ2h0IHVpLWJ1dHRvbi1pY29uIikKICAgICAgICAgICAgICAgIC5jbGljayhmdW5jdGlvbihFdmVudCkgewogICAgICAgICAgICAgICAgICAgIC8vIGNsb3NlIGlmIGFscmVhZHkgdmlzaWJsZQogICAgICAgICAgICAgICAgICAgIGlmICgkSW5wdXQuYXV0b2NvbXBsZXRlKCJ3aWRnZXQiKS5pcygiOnZpc2libGUiKSkgewogICAgICAgICAgICAgICAgICAgICAgICAkSW5wdXQuYXV0b2NvbXBsZXRlKCJjbG9zZSIpOwogICAgICAgICAgICAgICAgICAgICAgICByZXR1cm47CiAgICAgICAgICAgICAgICAgICAgfQoKICAgICAgICAgICAgICAgICAgICAvLyBwYXNzIGVtcHR5IHN0cmluZyBhcyB2YWx1ZSB0byBzZWFyY2ggZm9yLCBkaXNwbGF5aW5nIGFsbCByZXN1bHRzCiAgICAgICAgICAgICAgICAgICAgJElucHV0LmF1dG9jb21wbGV0ZSgic2VhcmNoIiwgIiIpLmZvY3VzKCk7CiAgICAgICAgICAgICAgICAgICAgRXZlbnQucHJldmVudERlZmF1bHQoKTsKICAgICAgICAgICAgICAgICAgICBFdmVudC5zdG9wUHJvcGFnYXRpb24oKTsKICAgICAgICAgICAgICAgICAgICByZXR1cm4gZmFsc2U7CiAgICAgICAgICAgICAgICB9KTsKICAgICAgICB9LAoKICAgICAgICBkZXN0cm95OiBmdW5jdGlvbigpIHsKICAgICAgICAgICAgdGhpcy5pbnB1dC5yZW1vdmUoKTsKICAgICAgICAgICAgdGhpcy5idXR0b24ucmVtb3ZlKCk7CiAgICAgICAgICAgIHRoaXMuZWxlbWVudC5zaG93KCk7CiAgICAgICAgICAgICQuV2lkZ2V0LnByb3RvdHlwZS5kZXN0cm95LmNhbGwodGhpcyk7CiAgICAgICAgfQogICAgfSk7Cn0pKGpRdWVyeSk7
/*! jQuery UI - v1.10.3 - 2013-08-27
* http://jqueryui.com
* Includes: jquery.ui.button.js
* Copyright 2013 jQuery Foundation and other contributors Licensed MIT */

(function( $, undefined ) {

var lastActive, startXPos, startYPos, clickDragged,
	baseClasses = "ui-button ui-widget ui-state-default ui-corner-all",
	stateClasses = "ui-state-hover ui-state-active ",
	typeClasses = "ui-button-icons-only ui-button-icon-only ui-button-text-icons ui-button-text-icon-primary ui-button-text-icon-secondary ui-button-text-only",
	formResetHandler = function() {
		var form = $( this );
		setTimeout(function() {
			form.find( ":ui-button" ).button( "refresh" );
		}, 1 );
	},
	radioGroup = function( radio ) {
		var name = radio.name,
			form = radio.form,
			radios = $( [] );
		if ( name ) {
			name = name.replace( /'/g, "\\'" );
			if ( form ) {
				radios = $( form ).find( "[name='" + name + "']" );
			} else {
				radios = $( "[name='" + name + "']", radio.ownerDocument )
					.filter(function() {
						return !this.form;
					});
			}
		}
		return radios;
	};

$.widget( "ui.button", {
	version: "1.10.3",
	defaultElement: "<button>",
	options: {
		disabled: null,
		text: true,
		label: null,
		icons: {
			primary: null,
			secondary: null
		}
	},
	_create: function() {
		this.element.closest( "form" )
			.unbind( "reset" + this.eventNamespace )
			.bind( "reset" + this.eventNamespace, formResetHandler );

		if ( typeof this.options.disabled !== "boolean" ) {
			this.options.disabled = !!this.element.prop( "disabled" );
		} else {
			this.element.prop( "disabled", this.options.disabled );
		}

		this._determineButtonType();
		this.hasTitle = !!this.buttonElement.attr( "title" );

		var that = this,
			options = this.options,
			toggleButton = this.type === "checkbox" || this.type === "radio",
			activeClass = !toggleButton ? "ui-state-active" : "",
			focusClass = "ui-state-focus";

		if ( options.label === null ) {
			options.label = (this.type === "input" ? this.buttonElement.val() : this.buttonElement.html());
		}

		this._hoverable( this.buttonElement );

		this.buttonElement
			.addClass( baseClasses )
			.attr( "role", "button" )
			.bind( "mouseenter" + this.eventNamespace, function() {
				if ( options.disabled ) {
					return;
				}
				if ( this === lastActive ) {
					$( this ).addClass( "ui-state-active" );
				}
			})
			.bind( "mouseleave" + this.eventNamespace, function() {
				if ( options.disabled ) {
					return;
				}
				$( this ).removeClass( activeClass );
			})
			.bind( "click" + this.eventNamespace, function( event ) {
				if ( options.disabled ) {
					event.preventDefault();
					event.stopImmediatePropagation();
				}
			});

		this.element
			.bind( "focus" + this.eventNamespace, function() {
				// no need to check disabled, focus won't be triggered anyway
				that.buttonElement.addClass( focusClass );
			})
			.bind( "blur" + this.eventNamespace, function() {
				that.buttonElement.removeClass( focusClass );
			});

		if ( toggleButton ) {
			this.element.bind( "change" + this.eventNamespace, function() {
				if ( clickDragged ) {
					return;
				}
				that.refresh();
			});
			// if mouse moves between mousedown and mouseup (drag) set clickDragged flag
			// prevents issue where button state changes but checkbox/radio checked state
			// does not in Firefox (see ticket #6970)
			this.buttonElement
				.bind( "mousedown" + this.eventNamespace, function( event ) {
					if ( options.disabled ) {
						return;
					}
					clickDragged = false;
					startXPos = event.pageX;
					startYPos = event.pageY;
				})
				.bind( "mouseup" + this.eventNamespace, function( event ) {
					if ( options.disabled ) {
						return;
					}
					if ( startXPos !== event.pageX || startYPos !== event.pageY ) {
						clickDragged = true;
					}
			});
		}

		if ( this.type === "checkbox" ) {
			this.buttonElement.bind( "click" + this.eventNamespace, function() {
				if ( options.disabled || clickDragged ) {
					return false;
				}
			});
		} else if ( this.type === "radio" ) {
			this.buttonElement.bind( "click" + this.eventNamespace, function() {
				if ( options.disabled || clickDragged ) {
					return false;
				}
				$( this ).addClass( "ui-state-active" );
				that.buttonElement.attr( "aria-pressed", "true" );

				var radio = that.element[ 0 ];
				radioGroup( radio )
					.not( radio )
					.map(function() {
						return $( this ).button( "widget" )[ 0 ];
					})
					.removeClass( "ui-state-active" )
					.attr( "aria-pressed", "false" );
			});
		} else {
			this.buttonElement
				.bind( "mousedown" + this.eventNamespace, function() {
					if ( options.disabled ) {
						return false;
					}
					$( this ).addClass( "ui-state-active" );
					lastActive = this;
					that.document.one( "mouseup", function() {
						lastActive = null;
					});
				})
				.bind( "mouseup" + this.eventNamespace, function() {
					if ( options.disabled ) {
						return false;
					}
					$( this ).removeClass( "ui-state-active" );
				})
				.bind( "keydown" + this.eventNamespace, function(event) {
					if ( options.disabled ) {
						return false;
					}
					if ( event.keyCode === $.ui.keyCode.SPACE || event.keyCode === $.ui.keyCode.ENTER ) {
						$( this ).addClass( "ui-state-active" );
					}
				})
				// see #8559, we bind to blur here in case the button element loses
				// focus between keydown and keyup, it would be left in an "active" state
				.bind( "keyup" + this.eventNamespace + " blur" + this.eventNamespace, function() {
					$( this ).removeClass( "ui-state-active" );
				});

			if ( this.buttonElement.is("a") ) {
				this.buttonElement.keyup(function(event) {
					if ( event.keyCode === $.ui.keyCode.SPACE ) {
						// TODO pass through original event correctly (just as 2nd argument doesn't work)
						$( this ).click();
					}
				});
			}
		}

		// TODO: pull out $.Widget's handling for the disabled option into
		// $.Widget.prototype._setOptionDisabled so it's easy to proxy and can
		// be overridden by individual plugins
		this._setOption( "disabled", options.disabled );
		this._resetButton();
	},

	_determineButtonType: function() {
		var ancestor, labelSelector, checked;

		if ( this.element.is("[type=checkbox]") ) {
			this.type = "checkbox";
		} else if ( this.element.is("[type=radio]") ) {
			this.type = "radio";
		} else if ( this.element.is("input") ) {
			this.type = "input";
		} else {
			this.type = "button";
		}

		if ( this.type === "checkbox" || this.type === "radio" ) {
			// we don't search against the document in case the element
			// is disconnected from the DOM
			ancestor = this.element.parents().last();
			labelSelector = "label[for='" + this.element.attr("id") + "']";
			this.buttonElement = ancestor.find( labelSelector );
			if ( !this.buttonElement.length ) {
				ancestor = ancestor.length ? ancestor.siblings() : this.element.siblings();
				this.buttonElement = ancestor.filter( labelSelector );
				if ( !this.buttonElement.length ) {
					this.buttonElement = ancestor.find( labelSelector );
				}
			}
			this.element.addClass( "ui-helper-hidden-accessible" );

			checked = this.element.is( ":checked" );
			if ( checked ) {
				this.buttonElement.addClass( "ui-state-active" );
			}
			this.buttonElement.prop( "aria-pressed", checked );
		} else {
			this.buttonElement = this.element;
		}
	},

	widget: function() {
		return this.buttonElement;
	},

	_destroy: function() {
		this.element
			.removeClass( "ui-helper-hidden-accessible" );
		this.buttonElement
			.removeClass( baseClasses + " " + stateClasses + " " + typeClasses )
			.removeAttr( "role" )
			.removeAttr( "aria-pressed" )
			.html( this.buttonElement.find(".ui-button-text").html() );

		if ( !this.hasTitle ) {
			this.buttonElement.removeAttr( "title" );
		}
	},

	_setOption: function( key, value ) {
		this._super( key, value );
		if ( key === "disabled" ) {
			if ( value ) {
				this.element.prop( "disabled", true );
			} else {
				this.element.prop( "disabled", false );
			}
			return;
		}
		this._resetButton();
	},

	refresh: function() {
		//See #8237 & #8828
		var isDisabled = this.element.is( "input, button" ) ? this.element.is( ":disabled" ) : this.element.hasClass( "ui-button-disabled" );

		if ( isDisabled !== this.options.disabled ) {
			this._setOption( "disabled", isDisabled );
		}
		if ( this.type === "radio" ) {
			radioGroup( this.element[0] ).each(function() {
				if ( $( this ).is( ":checked" ) ) {
					$( this ).button( "widget" )
						.addClass( "ui-state-active" )
						.attr( "aria-pressed", "true" );
				} else {
					$( this ).button( "widget" )
						.removeClass( "ui-state-active" )
						.attr( "aria-pressed", "false" );
				}
			});
		} else if ( this.type === "checkbox" ) {
			if ( this.element.is( ":checked" ) ) {
				this.buttonElement
					.addClass( "ui-state-active" )
					.attr( "aria-pressed", "true" );
			} else {
				this.buttonElement
					.removeClass( "ui-state-active" )
					.attr( "aria-pressed", "false" );
			}
		}
	},

	_resetButton: function() {
		if ( this.type === "input" ) {
			if ( this.options.label ) {
				this.element.val( this.options.label );
			}
			return;
		}
		var buttonElement = this.buttonElement.removeClass( typeClasses ),
			buttonText = $( "<span></span>", this.document[0] )
				.addClass( "ui-button-text" )
				.html( this.options.label )
				.appendTo( buttonElement.empty() )
				.text(),
			icons = this.options.icons,
			multipleIcons = icons.primary && icons.secondary,
			buttonClasses = [];

		if ( icons.primary || icons.secondary ) {
			if ( this.options.text ) {
				buttonClasses.push( "ui-button-text-icon" + ( multipleIcons ? "s" : ( icons.primary ? "-primary" : "-secondary" ) ) );
			}

			if ( icons.primary ) {
				buttonElement.prepend( "<span class='ui-button-icon-primary ui-icon " + icons.primary + "'></span>" );
			}

			if ( icons.secondary ) {
				buttonElement.append( "<span class='ui-button-icon-secondary ui-icon " + icons.secondary + "'></span>" );
			}

			if ( !this.options.text ) {
				buttonClasses.push( multipleIcons ? "ui-button-icons-only" : "ui-button-icon-only" );

				if ( !this.hasTitle ) {
					buttonElement.attr( "title", $.trim( buttonText ) );
				}
			}
		} else {
			buttonClasses.push( "ui-button-text-only" );
		}
		buttonElement.addClass( buttonClasses.join( " " ) );
	}
});

$.widget( "ui.buttonset", {
	version: "1.10.3",
	options: {
		items: "button, input[type=button], input[type=submit], input[type=reset], input[type=checkbox], input[type=radio], a, :data(ui-button)"
	},

	_create: function() {
		this.element.addClass( "ui-buttonset" );
	},

	_init: function() {
		this.refresh();
	},

	_setOption: function( key, value ) {
		if ( key === "disabled" ) {
			this.buttons.button( "option", key, value );
		}

		this._super( key, value );
	},

	refresh: function() {
		var rtl = this.element.css( "direction" ) === "rtl";

		this.buttons = this.element.find( this.options.items )
			.filter( ":ui-button" )
				.button( "refresh" )
			.end()
			.not( ":ui-button" )
				.button()
			.end()
			.map(function() {
				return $( this ).button( "widget" )[ 0 ];
			})
				.removeClass( "ui-corner-all ui-corner-left ui-corner-right" )
				.filter( ":first" )
					.addClass( rtl ? "ui-corner-right" : "ui-corner-left" )
				.end()
				.filter( ":last" )
					.addClass( rtl ? "ui-corner-left" : "ui-corner-right" )
				.end()
			.end();
	},

	_destroy: function() {
		this.element.removeClass( "ui-buttonset" );
		this.buttons
			.map(function() {
				return $( this ).button( "widget" )[ 0 ];
			})
				.removeClass( "ui-corner-left ui-corner-right" )
			.end()
			.button( "destroy" );
	}
});

}( jQuery ) );

Ly8gLS0KLy8gQ29yZS5VSS5Db21ib0JveC5qcyAtIHByb3ZpZGVzIENvbWJvQm94IGZ1bmN0aW9uYWxpdHkKLy8gQ29weXJpZ2h0IChDKSAyMDAxLTIwMTEgT1RSUyBBRywgaHR0cDovL290cnMub3JnL1xuIjsKLy8gLS0KLy8gVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKLy8gdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQovLyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgovLyAtLQoKInVzZSBzdHJpY3QiOwoKdmFyIENvcmUgPSBDb3JlIHx8IHt9OwpDb3JlLlVJID0gQ29yZS5VSSB8fCB7fTsKCi8qKgogKiBAbmFtZXNwYWNlCiAqIEBleHBvcnRzIFRhcmdldE5TIGFzIENvcmUuVUkuQ29tYm9Cb3gKICogQGRlc2NyaXB0aW9uCiAqICAgICAgVGhpcyBuYW1lc3BhY2UgY29udGFpbnMgdGhlIGZ1bmN0aW9ucyBmb3IgdGhlIGNvbWJvYm94IGVsZW1lbnQuCiAqLwpDb3JlLlVJLkNvbWJvQm94ID0gKGZ1bmN0aW9uIChUYXJnZXROUykgewogICAgLyoqCiAgICAgKiBAZnVuY3Rpb24KICAgICAqIEBwYXJhbSB7U3RyaW5nfSBTZWxlY3RvciBUaGUgalF1ZXJ5IHNlbGVjdG9yIGZvciB0aGUgZWxlbWVudHMgdGhhdCBzaG91bGQgYmUgaW5pdGlhbGl6ZWQgYXMgY29tYm9ib3hlcwogICAgICogQHBhcmFtIHtPYmplY3R9IE9wdGlvbnMgVGhlIGFkZGl0aW9uYWwgb3B0aW9ucyBmb3IgdGhlIGNvbWJvYm94OgogICAgICogICAgICAgICAgICAgICAgICAgICAgQ2xhc3M6IGEgc3RyaW5nIHdpdGggdGhlIGNsYXNzKGVzKSB0byBiZSBhZGRlZCB0byB0aGUgaW5wdXQgZmllbGQgb2YgdGhlIGNvbWJvYm94CiAgICAgKiAgICAgICAgICAgICAgICAgICAgICBMYW5nOiBhbiBvYmplY3Qgd2l0aCBrZXkvdmFsdWUgcGFpcnMgb2YgdHJhbnNsYXRpb25zIGZvciB0aGUgY29tYm9ib3gKICAgICAqIEBkZXNjcmlwdGlvbgogICAgICogICAgICBUaGlzIGZ1bmN0aW9uIGluaXRpYWxpemVzIHRoZSBjb21ib2JveGVzCiAgICAgKiBAcmV0dXJuIG5vdGhpbmcKICAgICAqLwogICAgVGFyZ2V0TlMuSW5pdCA9IGZ1bmN0aW9uIChTZWxlY3RvciwgT3B0aW9ucykgewogICAgICAgIFNlbGVjdG9yID0gU2VsZWN0b3IgfHwgJ3NlbGVjdCc7CiAgICAgICAgJChTZWxlY3RvcikuY29tYm9ib3goT3B0aW9ucyk7CiAgICB9OwoKICAgIHJldHVybiBUYXJnZXROUzsKfShDb3JlLlVJLkNvbWJvQm94IHx8IHt9KSk7Cg==
Ly8gLS0KLy8gVGltZUFjY291bnRpbmcuQWdlbnQuQ29uZmlybWF0aW9uRGlhbG9nLmpzIC0gcHJvdmlkZXMgdGhlIHNwZWNpYWwgbW9kdWxlIGZ1bmN0aW9ucyBmb3IgdGhlCi8vIGNvbmZpcm1hdGlvbiBkaWFsb2dzCi8vIENvcHlyaWdodCAoQykgMjAwMS0yMDEwIE9UUlMgQUcsIGh0dHA6Ly9vdHJzLm9yZy9cbiI7Ci8vIC0tCi8vIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCi8vIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKLy8gZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dC4KLy8gLS0KCiJ1c2Ugc3RyaWN0IjsKCnZhciBUaW1lQWNjb3VudGluZyA9IFRpbWVBY2NvdW50aW5nIHx8IHt9OwpUaW1lQWNjb3VudGluZy5BZ2VudCA9IFRpbWVBY2NvdW50aW5nLkFnZW50IHx8IHt9OwoKLyoqCiAqIEBuYW1lc3BhY2UKICogQGV4cG9ydHMgVGFyZ2V0TlMgYXMgVGltZUFjY291bnRpbmcuQWdlbnQuQ29uZmlybWF0aW9uRGlhbG9nCiAqIEBkZXNjcmlwdGlvbgogKiAgICAgIFRoaXMgbmFtZXNwYWNlIGNvbnRhaW5zIHRoZSBzcGVjaWFsIG1vZHVsZSBmdW5jdGlvbnMgZm9yIENvbmZpcm1hdGlvbkRpYWxvZy4KICovClRpbWVBY2NvdW50aW5nLkFnZW50LkNvbmZpcm1hdGlvbkRpYWxvZyA9IChmdW5jdGlvbiAoVGFyZ2V0TlMpIHsKCiAgICAvKioKICAgICAqIEB2YXJpYWJsZQogICAgICogQHByaXZhdGUKICAgICAqICAgICBUaGlzIHZhcmlhYmxlIHN0b3JlcyB0aGUgcGFyYW1ldGVycyB0aGF0IGFyZSBwYXNzZWQgZnJvbSB0aGUgRFRMIGFuZCBjb250YWluIGFsbCB0aGUgZGF0YSB0aGF0IHRoZSBkaWFsb2cgbmVlZHMuCiAgICAgKi8KICAgIHZhciBEaWFsb2dEYXRhID0gW107CgogICAgLyoqCiAgICAgKiBAZnVuY3Rpb24KICAgICAqIEBwcml2YXRlCiAgICAgKiBAcmV0dXJuIG5vdGhpbmcKICAgICAqIEBkZXNjcmlwdGlvbiBTaG93cyB3YWl0aW5nIGRpYWxvZyB1bnRpbCBzZWFyY2ggc2NyZWVuIGlzIHJlYWR5LgogICAgICovCiAgICBmdW5jdGlvbiBTaG93V2FpdGluZ0RpYWxvZyhQb3NpdGlvblRvcCl7CiAgICAgICAgQ29yZS5VSS5EaWFsb2cuU2hvd0NvbnRlbnREaWFsb2coJzxkaXYgY2xhc3M9IlNwYWNpbmcgQ2VudGVyIj48c3BhbiBjbGFzcz0iQUpBWExvYWRlciIgdGl0bGU9IicgKyBDb3JlLkNvbmZpZy5HZXQoJ0xvYWRpbmdNc2cnKSArICciPjwvc3Bhbj48L2Rpdj4nLCAnJywgUG9zaXRpb25Ub3AsICdDZW50ZXInLCB0cnVlKTsKICAgIH0KCiAgICAvKioKICAgICAqIEBmdW5jdGlvbgogICAgICogQHBhcmFtIHtFdmVudE9iamVjdH0gZXZlbnQgb2JqZWN0IG9mIHRoZSBjbGlja2VkIGVsZW1lbnQuCiAgICAgKiBAcmV0dXJuIG5vdGhpbmcKICAgICAqICAgICAgVGhpcyBmdW5jdGlvbiBzaG93cyBhIGNvbmZpcm1hdGlvbiBkaWFsb2cgd2l0aCAyIGJ1dHRvbnM6IFllcyBhbmQgTm8gb3IgYSBtZXNzYWdlIGRpYWxvZyB3aXRoIG9uZSBidXR0b246IE9rLgogICAgICovCiAgICBUYXJnZXROUy5TaG93Q29uZmlybWF0aW9uRGlhbG9nID0gZnVuY3Rpb24gKEV2ZW50KSB7CgogICAgICAgIHZhciBMb2NhbERpYWxvZ0RhdGEsCiAgICAgICAgICAgIFBvc2l0aW9uVG9wLAogICAgICAgICAgICBEYXRhLAogICAgICAgICAgICBCdXR0b25zOwoKICAgICAgICAvLyBnZXQgZ2xvYmFsIHNhdmVkIERpYWxvZ0RhdGEgZm9yIHRoaXMgZnVuY3Rpb24KICAgICAgICBMb2NhbERpYWxvZ0RhdGEgPSBEaWFsb2dEYXRhWyQoRXZlbnQudGFyZ2V0KS5hdHRyKCdpZCcpXTsKCiAgICAgICAgLy8gZGVmaW5lIHRoZSBwb3NpdGlvbiBvZiB0aGUgZGlhbG9nCiAgICAgICAgUG9zaXRpb25Ub3AgPSAkKHdpbmRvdykuaGVpZ2h0KCkgKiAwLjM7CgogICAgICAgIC8vIHNob3cgd2FpdGluZyBkaWFsb2cKICAgICAgICBTaG93V2FpdGluZ0RpYWxvZyhQb3NpdGlvblRvcCk7CgogICAgICAgIC8vIGFqYXggY2FsbCB0byB0aGUgbW9kdWxlIHRoYXQgZXhlY3V0ZXMgdGhlIGFjdGlvbiB3aGVuIHByZXNzaW5nIHRoZSBjb25maXJtYXRpb24gYnV0dG9uCiAgICAgICAgRGF0YSA9IExvY2FsRGlhbG9nRGF0YS5EaWFsb2dDb250ZW50UXVlcnlTdHJpbmc7CiAgICAgICAgQ29yZS5BSkFYLkZ1bmN0aW9uQ2FsbChDb3JlLkNvbmZpZy5HZXQoJ0Jhc2VsaW5rJyksIERhdGEsIGZ1bmN0aW9uIChSZXNwb25zZSkgewoKICAgICAgICAgICAgLy8gJ0NvbmZpcm1hdGlvbicgb3BlbnMgYSBkaWFsb2cgd2l0aCAyIGJ1dHRvbnM6IFllcyBhbmQgTm8KICAgICAgICAgICAgaWYgKFJlc3BvbnNlLkRpYWxvZ1R5cGUgPT09ICdDb25maXJtYXRpb24nKSB7CgogICAgICAgICAgICAgICAgLy8gZGVmaW5lIHllcyBhbmQgbm8gYnV0dG9ucwogICAgICAgICAgICAgICAgQnV0dG9ucyA9IFt7CiAgICAgICAgICAgICAgICAgICAgTGFiZWw6IExvY2FsRGlhbG9nRGF0YS5UcmFuc2xhdGVkVGV4dC5ZZXMsCiAgICAgICAgICAgICAgICAgICAgQ2xhc3M6ICJQcmltYXJ5IiwKCiAgICAgICAgICAgICAgICAgICAgLy8gZGVmaW5lIHRoZSBmdW5jdGlvbiB0aGF0IGlzIGNhbGxlZCB3aGVuIHRoZSAnWWVzJyBidXR0b24gaXMgcHJlc3NlZAogICAgICAgICAgICAgICAgICAgIEZ1bmN0aW9uOiBmdW5jdGlvbigpewoKICAgICAgICAgICAgICAgICAgICAgICAgLy8gZGlzYWJsZSBZZXMgYW5kIE5vIGJ1dHRvbnMgdG8gcHJldmVudCBtdWx0aXBsZSBzdWJtaXRzCiAgICAgICAgICAgICAgICAgICAgICAgICQoJ2Rpdi5EaWFsb2c6dmlzaWJsZSBkaXYuQ29udGVudEZvb3RlciBidXR0b24nKS5hdHRyKCdkaXNhYmxlZCcsICdkaXNhYmxlZCcpOwoKICAgICAgICAgICAgICAgICAgICAgICAgLy8gcmVkaXJlY3QgdG8gdGhlIG1vZHVsZSB0aGF0IGRvZXMgdGhlIGNvbmZpcm1lZCBhY3Rpb24gYWZ0ZXIgcHJlc3NpbmcgdGhlIFllcyBidXR0b24KICAgICAgICAgICAgICAgICAgICAgICAgbG9jYXRpb24uaHJlZiA9IENvcmUuQ29uZmlnLkdldCgnQmFzZWxpbmsnKSArIExvY2FsRGlhbG9nRGF0YS5Db25maXJtZWRBY3Rpb25RdWVyeVN0cmluZzsKICAgICAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICB9LCB7CiAgICAgICAgICAgICAgICAgICAgTGFiZWw6IExvY2FsRGlhbG9nRGF0YS5UcmFuc2xhdGVkVGV4dC5ObywKICAgICAgICAgICAgICAgICAgICBUeXBlOiAiQ2xvc2UiCiAgICAgICAgICAgICAgICB9XTsKICAgICAgICAgICAgfQoKICAgICAgICAgICAgLy8gJ01lc3NhZ2UnIG9wZW5zIGEgZGlhbG9nIHdpdGggMSBidXR0b246IE9rCiAgICAgICAgICAgIGVsc2UgaWYgKFJlc3BvbnNlLkRpYWxvZ1R5cGUgPT09ICdNZXNzYWdlJykgewoKICAgICAgICAgICAgICAgIC8vIGRlZmluZSBPayBidXR0b24KICAgICAgICAgICAgICAgIEJ1dHRvbnMgPSBbewogICAgICAgICAgICAgICAgICAgIExhYmVsOiBMb2NhbERpYWxvZ0RhdGEuVHJhbnNsYXRlZFRleHQuT2ssCiAgICAgICAgICAgICAgICAgICAgQ2xhc3M6ICJQcmltYXJ5IiwKICAgICAgICAgICAgICAgICAgICBUeXBlOiAiQ2xvc2UiCiAgICAgICAgICAgICAgICB9XTsKICAgICAgICAgICAgfQoKICAgICAgICAgICAgLy8gc2hvdyB0aGUgY29uZmlybWF0aW9uIGRpYWxvZyB0byBjb25maXJtIHRoZSBhY3Rpb24KICAgICAgICAgICAgQ29yZS5VSS5EaWFsb2cuU2hvd0NvbnRlbnREaWFsb2coUmVzcG9uc2UuSFRNTCwgTG9jYWxEaWFsb2dEYXRhLkRpYWxvZ1RpdGxlLCBQb3NpdGlvblRvcCwgIkNlbnRlciIsIHRydWUsIEJ1dHRvbnMpOwogICAgICAgIH0sICdqc29uJyk7CiAgICAgICAgcmV0dXJuIGZhbHNlOwogICAgfTsKCiAgICAvKioKICAgICAqIEBmdW5jdGlvbgogICAgICogQHBhcmFtIHtFdmVudE9iamVjdH0gZXZlbnQgb2JqZWN0IG9mIHRoZSBjbGlja2VkIGVsZW1lbnQuCiAgICAgKiBAcmV0dXJuIG5vdGhpbmcKICAgICAqICAgICAgVGhpcyBmdW5jdGlvbiBzaG93cyBhIGNvbmZpcm1hdGlvbiBkaWFsb2cgd2l0aCAyIGJ1dHRvbnM6IFllcyBhbmQgTm8KICAgICAqLwogICAgVGFyZ2V0TlMuQmluZENvbmZpcm1hdGlvbkRpYWxvZyA9IGZ1bmN0aW9uIChEYXRhKSB7CiAgICAgICAgRGlhbG9nRGF0YVtEYXRhLkVsZW1lbnRJRF0gPSBEYXRhOwoKICAgICAgICAvLyBiaW5kaW5nIGEgY2xpY2sgZXZlbnQgdG8gdGhlIGRlZmluZWQgZWxlbWVudAogICAgICAgICQoRGlhbG9nRGF0YVtEYXRhLkVsZW1lbnRJRF0uRWxlbWVudFNlbGVjdG9yKS5iaW5kKCdjbGljaycsIFRpbWVBY2NvdW50aW5nLkFnZW50LkNvbmZpcm1hdGlvbkRpYWxvZy5TaG93Q29uZmlybWF0aW9uRGlhbG9nKTsKICAgIH07CgogICAgcmV0dXJuIFRhcmdldE5TOwp9KFRpbWVBY2NvdW50aW5nLkFnZW50LkNvbmZpcm1hdGlvbkRpYWxvZyB8fCB7fSkpOwo=
// --
// TimeAccounting.Agent.Datepicker.js - provides the special datepicker functions for TA
// Copyright (C) 2001-2011 OTRS AG, http://otrs.org/\n";
// --
// This software comes with ABSOLUTELY NO WARRANTY. For details, see
// the enclosed file COPYING for license information (AGPL). If you
// did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
// --

"use strict";

var TimeAccounting = TimeAccounting || {};
TimeAccounting.Agent = TimeAccounting.Agent || {};

/**
 * @namespace
 * @exports TargetNS as TimeAccounting.Agent.Datepicker
 * @description
 *      This namespace contains the special datepicker functiond for TA.
 */
TimeAccounting.Agent.Datepicker = (function (TargetNS) {

    var VacationDays,
        VacationDaysOneTime,
        LocalizationData,
        DatepickerCount = 0;

    if (!Core.Debug.CheckDependency('Core.UI.Datepicker', '$([]).datepicker', 'jQuery UI datepicker')) {
        return;
    }

    /**
     * @function
     * @private
     * @param A boolean value
     * @param {jQueryObject} Element that will be checked
     * @description Review if a date object have correct values
     */
    function CheckDate(DateObject) {
        var DayDescription = '',
            DayClass = '';

        // Get defined days from Config, if not done already
        if (typeof VacationDays === 'undefined') {
            VacationDays = Core.Config.Get('Datepicker.VacationDays').TimeVacationDays;
        }
        if (typeof VacationDaysOneTime === 'undefined') {
            VacationDaysOneTime = Core.Config.Get('Datepicker.VacationDays').TimeVacationDaysOneTime;
        }

        // Check if date is one of the vacation days
        if (typeof VacationDays[DateObject.getMonth() + 1] !== 'undefined' &&
            typeof VacationDays[DateObject.getMonth() + 1][DateObject.getDate()] !== 'undefined') {
            DayDescription += VacationDays[DateObject.getMonth() + 1][DateObject.getDate()];
            DayClass = 'Highlight ';
        }

        // Check if date is one of the one time vacation days
        if (typeof VacationDaysOneTime[DateObject.getFullYear()] !== 'undefined' &&
            typeof VacationDaysOneTime[DateObject.getFullYear()][DateObject.getMonth() + 1] !== 'undefined' &&
            typeof VacationDaysOneTime[DateObject.getFullYear()][DateObject.getMonth() + 1][DateObject.getDate()] !== 'undefined') {
            DayDescription += VacationDaysOneTime[DateObject.getFullYear()][DateObject.getMonth() + 1][DateObject.getDate()];
            DayClass = 'Highlight ';
        }

        if (DayClass.length) {
            return [true, DayClass, DayDescription];
        }
        else {
            return [true, ''];
        }
    }

    /**
     * @function
     * @description
     *      This function initializes the datepicker on single elements for TA.
     *      This function is not yet available in the OTRS Core.
     *      If it will be implemented in OTRS Core we could remove this file here.
     * @param {Object} $Element The jQuery object(s) of a text input field which should get a datepicker.
     * @param {Object} DatepickerOptions Object with two possible keys:
     *                      DateInFuture: true|false,
     *                      WeekDayStart: 0-7 (sunday - saturday)
     * @return nothing
     */
    TargetNS.Init = function ($Element, DatepickerOptions) {
        function LeadingZero(Number) {
            if (Number.toString().length === 1) {
                return '0' + Number;
            }
            else {
                return Number;
            }
        }

        var $DatepickerElement,
            Options,
            I,
            ErrorMessage;

        if (typeof LocalizationData === 'undefined') {
            LocalizationData = Core.Config.Get('Datepicker.Localization');
            if (typeof LocalizationData === 'undefined') {
                throw new Core.Exception.ApplicationError('Datepicker localization data could not be found!', 'InternalError');
            }
        }

        // Define options hash
        Options = {
                beforeShowDay: function (DateObject) {
                    return CheckDate(DateObject);
                },
                showOn: 'focus',
                prevText: LocalizationData.PrevText,
                nextText: LocalizationData.NextText,
                showMonthAfterYear: 0,
                dateFormat: 'yy-mm-dd',
                monthNames: LocalizationData.MonthNames,
                monthNamesShort: LocalizationData.MonthNamesShort,
                dayNames: LocalizationData.DayNames,
                dayNamesShort: LocalizationData.DayNamesShort,
                dayNamesMin: LocalizationData.DayNamesMin,
                isRTL: LocalizationData.IsRTL
        };

        Options.beforeShow = function (Input, Instance) {
            var Value = $(Input).prevAll('input:text').val();
            $(Input).val('');
            return {
                defaultDate: new Date(Value)
            };
        };

        Options.onSelect = function (DateText, Instance) {
            $(this).prevAll('input:text').val(DateText);
        };

        if (isJQueryObject($Element)) {
            $Element.each(function () {
                var $SingleElement = $(this);
                if ($SingleElement.is('input:text')) {
                    // Increment number of initialized datepickers on this site
                    DatepickerCount++;

                    $DatepickerElement = $('<input>').attr('type', 'hidden').attr('id', 'Datepicker' + DatepickerCount);
                    $SingleElement.after($DatepickerElement);

                    Options.firstDay = DatepickerOptions.WeekDayStart;
                    $DatepickerElement.datepicker(Options);

                    // add datepicker icon and click event
                    $DatepickerElement.after('<a href="#" class="DatepickerIcon DatepickerNumber' + DatepickerCount + '" title="' + LocalizationData.IconText + '"><span><i class="fa fa-calendar"></i></span></a>');
                    $DatepickerElement.next('a.DatepickerIcon').click(function () {
                        var Classes = $(this).attr('class'),
                            DatepickerNumber = Classes.replace(/^.*DatepickerNumber([0-9]+).*/g, "$1");

                        $('#Datepicker' + DatepickerNumber).datepicker('show');
                        return false;
                    });

                    // do not show the datepicker container div.
                    $('#ui-datepicker-div').hide();
                }
            });
        }
    };

    return TargetNS;
}(TimeAccounting.Agent.Datepicker || {}));

// --
// TimeAccounting.Agent.EditTimeRecords.js - provides the special module functions for the
// edit screen
// Copyright (C) 2001-2011 OTRS AG, http://otrs.org/\n";
// --
// This software comes with ABSOLUTELY NO WARRANTY. For details, see
// the enclosed file COPYING for license information (AGPL). If you
// did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
// --

"use strict";

var TimeAccounting = TimeAccounting || {};
TimeAccounting.Agent = TimeAccounting.Agent || {};

/**
 * @namespace
 * @exports TargetNS as TimeAccounting.Agent.EditTimeRecords
 * @description
 *      This namespace contains the special module functions for the edit screen.
 */
TimeAccounting.Agent.EditTimeRecords = (function (TargetNS) {

    TargetNS.ActionList = "";
    TargetNS.ActionListConstraints = "";
    // Adds option to a selection

    function AddSelectionOption($SelectionElement, OptionText, OptionValue, SelectedOption) {
        var $Option = $('<option value="' + OptionValue + '">' + OptionText + '</option>');

        if (OptionValue === SelectedOption) {
            $Option.prop('selected', true);
        }

        $SelectionElement.append($Option);
    }

    /**
     * @function
     * @param {String} The ID of the working unit we are in
     * @return nothing
     *      Fills options of action selection according to selected project
     */
    TargetNS.FillActionList = function (WorkingUnitID) {
        var ProjectName = $('#ProjectID' + WorkingUnitID + ' option:selected').text(),
            ActionList = TargetNS.ActionList,
            ActionListConstraints = TargetNS.ActionListConstraints,
            $ActionSelection = $("#ActionID" + WorkingUnitID),
            SelectedActionID = $ActionSelection.val(),
            OptionCount = 0;

        // remove previous actions, leave first element (empty element)
        $ActionSelection.find('option').filter(':not(:first)').remove();


        $.each(ActionList, function () {
            var ActionID = this[0],
                ActionName = this[1];

            $.each(ActionListConstraints, function () {
                var ProjectNameRegExp = new RegExp(this[0]),
                    ActionNameRegExp = new RegExp(this[1]);

                // add action to selection
                if (ProjectNameRegExp.test(ProjectName) && ActionNameRegExp.test(ActionName)) {
                    AddSelectionOption($ActionSelection, ActionName, ActionID, SelectedActionID);
                    OptionCount++;
                }
            });
        });

        // all actions will be added if no action was added above (possible misconfiguration)
        if (!OptionCount) {
            // ignore first element because it's the empty element which is already part of the list
            $.each(ActionList, function (Index) {
                var ActionID = this[0],
                    ActionName = this[1];
                if (Index > 0) {
                    AddSelectionOption($ActionSelection, ActionName, ActionID, SelectedActionID);
                }
            });
        }
    };


    function InitAutoCompletion(Language) {
        // Initialize ComboBox on Project dropdown
        Core.UI.ComboBox.Init('.ProjectSelection', {
            Class: "Validate_TimeAccounting_Project",
            Lang: {
                ShowAllItems: Language.ShowAllItems,
                InputTitle: Language.ProjectTitle
            }
        });
        // Initialize ComboBox on task dropdown
        Core.UI.ComboBox.Init('.ActionSelection', {
            Class: "Validate_DependingRequiredAND",
            Lang: {
                ShowAllItems: Language.ShowAllItems,
                InputTitle: Language.TaskTitle
            }
        });
        // Add special validation class to ActionSelection
        $('.ActionSelection').next('input:text').each(function () {
            var ID = this.id.replace('Combo_ActionID', '');
            $(this).addClass('Validate_Depending_Combo_ProjectID' + ID);
        });
        // Remove validation classes from underlying select
        $('.ProjectSelection').removeClass('Validate_TimeAccounting_Project');
        $('.ActionSelection').removeClass('Validate_DependingRequiredAND');

        // Copy ServerError classes to according comboboxes
        $('.ProjectSelection.ServerError').next('input[id^=Combo_]').addClass('ServerError');
        $('.ActionSelection.ServerError').next('input[id^=Combo_]').addClass('ServerError');

        Core.Form.Validate.Init();
    }

    function InitAddRow(Language) {
        $('#MoreInputFields').unbind('click.MoreInputFields').bind('click.MoreInputFields', function () {
            var $LastRow = $('#InsertWorkingHours tbody tr.WorkingHours:last'),
                $NewRow = $LastRow.clone(),
                NewRowHTML = $NewRow.html(),
                RecordNumber = parseInt($('#RecordsNumber').val(), 10) + 1;

            // Now take the last row and replace all numbers with the new record number
            NewRowHTML = NewRowHTML.replace(/ProjectID[0-9]+/g, 'ProjectID' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/ProjectID\[[0-9]+/g, 'ProjectID[' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/FillActionList\([0-9]+/g, 'FillActionList(' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/ActionID[0-9]+/g, 'ActionID' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/ActionID\[[0-9]+/g, 'ActionID[' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/Remark[0-9]+/g, 'Remark' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/Remark\[[0-9]+/g, 'Remark[' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/StartTime[0-9]+/g, 'StartTime' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/StartTime\[[0-9]+/g, 'StartTime[' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/EndTime[0-9]+/g, 'EndTime' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/EndTime\[[0-9]+/g, 'EndTime[' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/Period[0-9]+/g, 'Period' + RecordNumber);
            NewRowHTML = NewRowHTML.replace(/Period\[[0-9]+/g, 'Period[' + RecordNumber);

            // Now write this HTML back to the jquery object
            $NewRow.html(NewRowHTML);

            // If last row contained values, these must be removed
            $NewRow
                .find('input:text').val('').end()
                .find('select option').prop('selected', false);

            // Remove autocompletion from this row (will be re-initiated later)
            $NewRow
                .find('input[id^=Combo_]').remove().end()
                .find('button[id^=ComboBtn_]').remove();

            // Now add this row to the table
            $LastRow.after($NewRow);

            // Save new RecordNumber
            $('#RecordsNumber').val(RecordNumber);

            // Re-initiate the 'odd/even' colours of the table
            $('#InsertWorkingHours tbody tr')
                .removeClass('Even')
                .filter(':odd').addClass('Even');

            // Re-initiate autocompletion combobox
            if (TargetNS.Autocompletion) {
                InitAutoCompletion(Language);
            }
        });
    }

    function RecalculateTotalHours() {
        var Total = 0;
        $('.Period').each(function () {
            var Value = parseFloat($(this).val());
            if (!isNaN(Value)) {
                Total += Value;
            }
        });
        $('.TotalHours').text(Total.toFixed(2));
    }

    function InitPeriodCalculation() {
        // init calculation of period field after working hours where added/substracted/whatever...
        $('.Period').unbind('change.PeriodCalculation').bind('change.PeriodCalculation', function () {
           var FieldValue = $(this).val();

           // replace , with .
           FieldValue = FieldValue.replace(/,/g, ".");

           // check if the entered value only consists of allowed values
           // if not, we do not eval for security reasons
           if (FieldValue.match(/^[0-9\.+\- ]+$/)) {
               // Calculation
               try {
                   FieldValue = eval(FieldValue);
               }
               catch (CalcError) {
                   FieldValue = 0;
               }

               // set new value
               $(this).val(FieldValue.toFixed(2));

               // now StartTime and EndTime will not match the period anymore
               // delete these entries
               $(this).closest('tr').find('.StartTime, .EndTime').val('');

           }
           else {
               $(this).val('');
           }

           // now re-calculate the total hours sum
           RecalculateTotalHours();
        });

        // init period calculation on starttime and endtime fields
        $('.StartTime, .EndTime').unbind('change.PeriodCalculation').bind('change.PeriodCalculation', function () {
            var $StartTime, $EndTime,
                StartTimeHour, StartTimeMinute, EndTimeHour, EndTimeMinute,
                StartDate, EndDate, Today,
                Period, PeriodHour, PeriodMinute;

            if ($(this).hasClass('StartTime')) {
                $StartTime = $(this);
                $EndTime = $StartTime.closest('tr').find('.EndTime');
            }
            else {
                $StartTime = $(this).closest('tr').find('.StartTime');
                $EndTime = $(this);
            }

            // only calculate if both fields are filled
            if ($StartTime.val() && $EndTime.val()) {
                // extract hours and minutes
                StartTimeHour = $StartTime.val().split(/:/)[0] || 0;
                StartTimeMinute = $StartTime.val().split(/:/)[1] || 0;
                EndTimeHour = $EndTime.val().split(/:/)[0] || 0;
                EndTimeMinute = $EndTime.val().split(/:/)[1] || 0;

                // define date objects
                Today = new Date();
                StartDate = new Date(Today.getYear(), Today.getMonth(), Today.getDate(), StartTimeHour, StartTimeMinute, 0);
                EndDate = new Date(Today.getYear(), Today.getMonth(), Today.getDate(), EndTimeHour, EndTimeMinute, 0);

                // calculate differences
                Period = EndDate.getTime() - StartDate.getTime();
                Period = Period / (1000 * 60 * 60);

                // set new value
                if (!isNaN(Period)) {
                    $StartTime.closest('tr').find('.Period').val(Period.toFixed(2));
                }
                else {
                    $StartTime.closest('tr').find('.Period').val('');
                }

                RecalculateTotalHours();
            }
        });
    }

    TargetNS.Autocompletion = true;

    /**
     * @function
     * @param {Object} Options the different possible options:
     *                  RemarkRegExpContent - the regular expression for the remark validation check
     *                  Language - object with text translations
     *                  Autocompletion - boolean
     * @return nothing
     *      This function initializes all needed JS for the Edit screen
     */
    TargetNS.Init = function (Options) {
        var LocalOptions = Options || {},
            RemarkRegExpContent = LocalOptions.RemarkRegExpContent,
            Language = LocalOptions.Language,
            // Add some special validation methods for the edit screen
            // Define all available elements (only the prefixes) in a row
            ElementPrefixes = ['ProjectID', 'ActionID', 'Remark', 'StartTime', 'EndTime', 'Period'];

        // Validates the project: if some other field in this row is filled, the project select must be filled, too
        Core.Form.Validate.AddMethod('Validate_TimeAccounting_Project', function (Value, Element) {
            var ID,
                Result = true;

            // Get ID
            // Our Element can be the select element or the autocompletion input field
            if ($(Element).is('select')) {
                ID = $(Element).attr('id').replace('ProjectID', '');
            }
            else {
                ID = $(Element).prevAll('select').attr('id').replace('ProjectID', '');
            }

            if (!Value) {
                $.each(ElementPrefixes, function () {
                    if (!Result) {
                        return;
                    }

                    if (this !== 'ProjectID' && $('#' + this + ID).val()) {
                        Result = false;
                    }
                });
            }

            return Result;
        });

        Core.Form.Validate.AddRule('Validate_TimeAccounting_Project', { Validate_TimeAccounting_Project: true });

        // Validates the remarks: depending on the project, remarks must be entered or not
        Core.Form.Validate.AddMethod('Validate_TimeAccounting_Remark', function (Value, Element) {
            var ID = $(Element).attr('id').replace('Remark', ''),
                RemarkRegExp = new RegExp("^(" + RemarkRegExpContent + ")$"),
                RemarkCheck = RemarkRegExp.test($('#ProjectID' + ID).val());

            if ($('#ProjectID' + ID).val()) {
                return !(RemarkCheck && Value.length < 8);
            }

            return true;
        });

        Core.Form.Validate.AddRule('Validate_TimeAccounting_Remark', { Validate_TimeAccounting_Remark: true });

        // Validates the start time: if a project is given and no time period is given, this field is required
        Core.Form.Validate.AddMethod('Validate_TimeAccounting_StartTime', function (Value, Element) {
            var ID = $(Element).attr('id').replace('StartTime', '');

            if (!Value && $('#ProjectID' + ID).val() && !$('#Period' + ID).val()) {
                return false;
            }

            return true;
        });

        Core.Form.Validate.AddRule('Validate_TimeAccounting_StartTime', { Validate_TimeAccounting_StartTime: true });

        // Validates the time period: if a project is given and no start time is given, this field is required
        Core.Form.Validate.AddMethod('Validate_TimeAccounting_Period', function (Value, Element) {
            var ID = $(Element).attr('id').replace('Period', '');

            if (!Value && $('#ProjectID' + ID).val() && !$('#StartTime' + ID).val()) {
                return false;
            }

            return true;
        });

        Core.Form.Validate.AddRule('Validate_TimeAccounting_Period', { Validate_TimeAccounting_Period: true });

        // Enable autocompletion, if configured
        TargetNS.Autocompletion = LocalOptions.Autocompletion;
        if (LocalOptions.Autocompletion) {
            InitAutoCompletion(Language);
        }

        // initiate "more input fields" functionality
        InitAddRow(Language);

        // initiate period calculation
        InitPeriodCalculation();
    };

    /**
     * @function
     * @param {Object} Language object with text translations
     * @return nothing
     *      This function initializes the javascript for the mass entry functionality
     */
    TargetNS.MassEntryInit = function(Language) {
        $('#IncompleteWorkingDay-All').unbind('click.SelectAllDays').bind('click.SelectAllDays', function (Event) {
            var State = $(this).prop('checked');
            $('ul.IncompleteWorkingDays li input:checkbox').prop('checked', State);
        });
        $('#MassEntrySubmit').unbind('click.MassEntrySubmit').bind('click.MassEntrySubmit', function () {
            var $WorkingDayCheckboxes = $('ul.IncompleteWorkingDays li input:checkbox:checked').filter('[name!=IncompleteWorkingDay-All]');

            if (!$WorkingDayCheckboxes.length) {
                alert(Language.MsgChooseOneDay);
                return false;
            }

            // Show overlay
            Core.UI.Dialog.ShowContentDialog($('#MassEntryConfirmDialog'), Language.MassEntry, '150px', 'Center', true, [
                {
                    Label: Language.Submit,
                    Function: function () {
                        var $SelectedRadio = $('#MassEntryConfirmRadio li input:radio:checked'),
                            AbsenceReason,
                            CollectedDates = '';

                        if (!$SelectedRadio.length) {
                            alert(Language.MsgAbsenceReason);
                            return false;
                        }

                        // set absence reason
                        AbsenceReason = $SelectedRadio.attr('name');
                        if (AbsenceReason === 'LeaveDay') {
                            $('#MassEntry input[name=LeaveDay]').val(1);
                        }
                        else if (AbsenceReason === 'Sick') {
                            $('#MassEntry input[name=Sick]').val(1);
                        }
                        else if (AbsenceReason === 'Overtime') {
                            $('#MassEntry input[name=Overtime]').val(1);
                        }

                        // collect dates
                        $('ul.IncompleteWorkingDays li input:checkbox:checked').each(function () {
                            var Date = $(this).attr('name').replace(/IncompleteWorkingDay-/, "");
                            if (Date !== 'All') {
                                CollectedDates += Date + '|';
                            }
                        });
                        $('#MassEntry input[name=Dates]').val(CollectedDates);

                        // Show waiting icon
                        $('.Dialog:visible')
                        .find('.ContentFooter')
                        .empty()
                        .end()
                        .find('.InnerContent')
                        .width($('.Dialog:visible').find('.InnerContent').width())
                        .empty()
                        .append('<span class="AJAXLoader"></span>');

                        // Submit form
                        $('#MassEntry').submit();
                    },
                    Class: 'Primary'
                },
                {
                    Label: Language.Cancel,
                    Function: function () {
                        Core.UI.Dialog.CloseDialog($('.Dialog:visible'));
                    }
                }
            ]);
            return false;
        });
    };

    return TargetNS;
}(TimeAccounting.Agent.EditTimeRecords || {}));

PCFET0NUWVBFIGh0bWwgUFVCTElDICItLy9XM0MvL0RURCBYSFRNTCAxLjAgVHJhbnNpdGlvbmFsLy9FTiIKICAgICJodHRwOi8vd3d3LnczLm9yZy9UUi94aHRtbDEvRFREL3hodG1sMS10cmFuc2l0aW9uYWwuZHRkIj4KPGh0bWwgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGh0bWwiIHhtbDpsYW5nPSJlbiIgbGFuZz0iZW4iPgo8aGVhZD4KICAgIDxsaW5rIHJlbD0ic3R5bGVzaGVldCIgaHJlZj0iLi4vdGhpcmRwYXJ0eS9xdW5pdC0xLjExLjAvcXVuaXQtMS4xMS4wLmNzcyIgdHlwZT0idGV4dC9jc3MiLz4KCiAgICA8dGl0bGU+VGltZUFjY291bnRpbmcgZm9yIE9UUlMgMy4wICZuZGFzaDsgVW5pdFRlc3QgUmVzdWx0czwvdGl0bGU+CjwvaGVhZD4KPGJvZHk+CiAgICA8aDEgaWQ9InF1bml0LWhlYWRlciI+VGltZUFjY291bnRpbmcgZm9yIE9UUlMgMy4wICZuZGFzaDsgVW5pdFRlc3QgUmVzdWx0czwvaDE+CiAgICA8aDIgaWQ9InF1bml0LWJhbm5lciI+PC9oMj4KICAgIDxoMiBpZD0icXVuaXQtdXNlckFnZW50Ij48L2gyPgogICAgPG9sIGlkPSJxdW5pdC10ZXN0cyI+PC9vbD4KCgogICAgPCEtLSBVbml0VGVzdCBjb2RlIGdvZXMgaGVyZSAtLT4KICAgIDxzY3JpcHQgdHlwZT0idGV4dC9qYXZhc2NyaXB0IiBzcmM9Ii4uL3RoaXJkcGFydHkvcXVuaXQtMS4xMS4wL3F1bml0LTEuMTEuMC5qcyI+PC9zY3JpcHQ+CiAgICA8IS0tCiAgICAgICAgTm93IGFsd2F5cyBsb2FkIGxpYnJhcnkgZmlyc3QgYW5kIHRoZW4gdGhlIFVuaXRUZXN0IGZpbGUgZm9yIGl0LgogICAgICAgIFRoZSBVbml0VGVzdCBmaWxlIGlzIHJlc3BvbnNpYmxlIGZvciBydW5uaW50IHRoZSB0ZXN0cy4KICAgIC0tPgogICAgPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiIHNyYz0iLi4vdGhpcmRwYXJ0eS9qcXVlcnktMS4xMC4wL2pxdWVyeS5qcyI+PC9zY3JpcHQ+CgogICAgPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiIHNyYz0iLi4vQ29yZS5FeGNlcHRpb24uanMiPjwvc2NyaXB0PgogICAgPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiIHNyYz0iLi4vQ29yZS5EZWJ1Zy5qcyI+PC9zY3JpcHQ+CiAgICA8c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCIgc3JjPSIuLi9Db3JlLkRhdGEuanMiPjwvc2NyaXB0PgoKICAgIDxzY3JpcHQgdHlwZT0idGV4dC9qYXZhc2NyaXB0IiBzcmM9Ii4uL3RoaXJkcGFydHkvanNvbi9qc29uMi5qcyI+PC9zY3JpcHQ+CiAgICA8c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCIgc3JjPSIuLi9Db3JlLkpTT04uanMiPjwvc2NyaXB0PgogICAgPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiIHNyYz0iLi4vQ29yZS5Db25maWcuanMiPjwvc2NyaXB0PgoKICAgIDxzY3JpcHQgdHlwZT0idGV4dC9qYXZhc2NyaXB0IiBzcmM9Ii4uL3RoaXJkcGFydHkvanF1ZXJ5LXVpLTEuMTAuMy9qcXVlcnktdWkuanMiPjwvc2NyaXB0PgogICAgPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiIHNyYz0iLi4vdGhpcmRwYXJ0eS9qcXVlcnktdmFsaWRhdGUtMS4xMS4xL2pxdWVyeS52YWxpZGF0ZS5qcyI+PC9zY3JpcHQ+CiAgICA8c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCIgc3JjPSIuLi9Db3JlLkFwcC5qcyI+PC9zY3JpcHQ+CiAgICA8c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCIgc3JjPSIuLi9Db3JlLlVJLkRpYWxvZy5qcyI+PC9zY3JpcHQ+CiAgICA8c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCIgc3JjPSIuLi9Db3JlLkZvcm0uRXJyb3JUb29sdGlwcy5qcyI+PC9zY3JpcHQ+CiAgICA8c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCIgc3JjPSIuLi9Db3JlLlVJLkFjY2Vzc2liaWxpdHkuanMiPjwvc2NyaXB0PgogICAgPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiIHNyYz0iLi4vQ29yZS5VSS5SaWNoVGV4dEVkaXRvci5qcyI+PC9zY3JpcHQ+CiAgICA8c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCIgc3JjPSIuLi9Db3JlLkZvcm0uVmFsaWRhdGUuanMiPjwvc2NyaXB0PgogICAgPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiIHNyYz0iLi4vVGltZUFjY291bnRpbmcuQWdlbnQuRWRpdFRpbWVSZWNvcmRzLmpzIj48L3NjcmlwdD4KICAgIDxzY3JpcHQgdHlwZT0idGV4dC9qYXZhc2NyaXB0IiBzcmM9IlRpbWVBY2NvdW50aW5nLkFnZW50LkVkaXRUaW1lUmVjb3Jkcy5Vbml0VGVzdC5qcyI+PC9zY3JpcHQ+CiAgICA8c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCI+CiAgICAgICAgVGltZUFjY291bnRpbmcuQWdlbnQuRWRpdFRpbWVSZWNvcmRzLlJ1blVuaXRUZXN0cygpOwogICAgPC9zY3JpcHQ+CjwvYm9keT4KPC9odG1sPgo=
// --
// TimeAccounting.Agent.EditTimeRecords.UnitTest.js - UnitTests
// Copyright (C) 2001-2011 OTRS AG, http://otrs.org/\n";
// --
// This software comes with ABSOLUTELY NO WARRANTY. For details, see
// the enclosed file COPYING for license information (AGPL). If you
// did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
// --

"use strict";

var TimeAccounting = TimeAccounting || {};
TimeAccounting.Agent = TimeAccounting.Agent || {};

TimeAccounting.Agent.EditTimeRecords = (function (Namespace) {
    Namespace.RunUnitTests = function(){
        module('TimeAccounting.Agent.EditTimeRecords');
        test('client-side time period calculations', function(){

            expect(20);

            /*
             * Create a form container for the tests
             */
            var $TestForm = $('<form id="TestForm"></form>'),
                $Table;
            $TestForm.append('<table><tr><td></td></tr><tr><td></td></tr><tr><td></td></tr></table>');
            $Table = $TestForm.find('tr:eq(0) td');
            $Table.append('<input type="text" value="" id="StartTime1" name="StartTime1" class="StartTime" />');
            $Table.append('<input type="text" value="" id="EndTime1" name="EndTime1" class="EndTime" />');
            $Table.append('<input type="text" value="" id="Period1" name="Period1" class="Period" />');
            $Table = $TestForm.find('tr:eq(1) td');
            $Table.append('<input type="text" value="" id="StartTime2" name="StartTime2" class="StartTime" />');
            $Table.append('<input type="text" value="" id="EndTime2" name="EndTime2" class="EndTime" />');
            $Table.append('<input type="text" value="" id="Period2" name="Period2" class="Period" />');
            $Table = $TestForm.find('tr:eq(2) td');
            $Table.append('<input type="text" value="" id="StartTime3" name="StartTime3" class="StartTime" />');
            $Table.append('<input type="text" value="" id="EndTime3" name="EndTime3" class="EndTime" />');
            $Table.append('<input type="text" value="" id="Period3" name="Period3" class="Period" />');
            $Table.append('<span id="TotalHours" name="TotalHours" class="TotalHours"></span>');
            $('body').append($TestForm);

            /*
             * Run the tests
             */

            TimeAccounting.Agent.EditTimeRecords.Init();

            // Test: time calculation on time period field
            $('#Period1').val('2');
            $('#Period1').trigger('change');
            equal($('#Period1').val(), '2.00', 'Normal number entry');

            $('#Period1').val('foobar');
            $('#Period1').trigger('change');
            equal($('#Period1').val(), '', 'Not a number (="foobar")');

            $('#Period1').val('2 + 3');
            $('#Period1').trigger('change');
            equal($('#Period1').val(), '5.00', 'Easy calculation');

            $('#Period1').val('alert("huhu");');
            $('#Period1').trigger('change');
            equal($('#Period1').val(), '', 'Evil javascript code');

            $('#Period1').val('2.23 + 1.09');
            $('#Period1').trigger('change');
            equal($('#Period1').val(), '3.32', 'Calculation with non-integers');

            $('#Period1').val('2.0001 + 1.5');
            $('#Period1').trigger('change');
            equal($('#Period1').val(), '3.50', 'Calculation with a number with more than 2 decimals');

            $('#Period1').val('1,2 + 1,3');
            $('#Period1').trigger('change');
            equal($('#Period1').val(), '2.50', 'Numbers with , instead of .');

            $('#Period1').val('5.8 - 1.2');
            $('#Period1').trigger('change');
            equal($('#Period1').val(), '4.60', 'Substraction');

            $('#Period1').val('');

            // Test: calculate period from entered start and end time
            $('#StartTime1').val('1');
            $('#StartTime1').trigger('change');
            $('#EndTime1').val('');
            $('#EndTime1').trigger('change');
            equal($('#Period1').val(), '', 'Only start time entered');

            $('#StartTime1').val('');
            $('#StartTime1').trigger('change');
            $('#EndTime1').val('2');
            $('#EndTime1').trigger('change');
            equal($('#Period1').val(), '', 'Only end time entered');

            $('#StartTime1').val('1');
            $('#StartTime1').trigger('change');
            $('#EndTime1').val('2');
            $('#EndTime1').trigger('change');
            equal($('#Period1').val(), '1.00', 'Both times entered');

            $('#StartTime1').val('9:06');
            $('#StartTime1').trigger('change');
            $('#EndTime1').val('10:00');
            $('#EndTime1').trigger('change');
            equal($('#Period1').val(), '0.90', 'Easy calculation with two times of the format HH:MM');

            $('#StartTime1').val('9:00');
            $('#StartTime1').trigger('change');
            $('#EndTime1').val('11:30');
            $('#EndTime1').trigger('change');
            equal($('#Period1').val(), '2.50', 'Easy calculation with two times of the format HH:MM');

            $('#StartTime1').val('9,5');
            $('#StartTime1').trigger('change');
            $('#EndTime1').val('10,5');
            $('#EndTime1').trigger('change');
            equal($('#Period1').val(), '', 'StartTime and EndTime format are wrong');

            $('#StartTime1').val('9:5');
            $('#StartTime1').trigger('change');
            $('#EndTime1').val('10:5');
            $('#EndTime1').trigger('change');
            equal($('#Period1').val(), '1.00', 'StartTime and EndTime format are slightly wrong');

            // Test: Calculation of total hours
            $('#StartTime1').val('9:5');
            $('#StartTime1').trigger('change');
            $('#EndTime1').val('10:5');
            $('#EndTime1').trigger('change');
            equal($('#TotalHours').text(), '1.00', 'Easy start');

            $('#Period2').val('2.5');
            $('#Period2').trigger('change');
            equal($('#TotalHours').text(), '3.50', 'Second period field');

            $('#Period2').val('1.5 + 9,5');
            $('#Period2').trigger('change');
            equal($('#TotalHours').text(), '12.00', 'Second period field gets an additional calculation with one wrong comma');

            $('#Period3').val('4.35');
            $('#Period3').trigger('change');
            equal($('#TotalHours').text(), '16.35', 'Third field');

            $('#StartTime1').val('14:00');
            $('#StartTime1').trigger('change');
            $('#EndTime1').val('openend');
            $('#EndTime1').trigger('change');
            equal($('#TotalHours').text(), '15.35', 'First row: starttime and endtime fields have wrong input');


            /*
             * Cleanup div container and contents
             */
            $('#TestForm').remove();
        });
    };

    return Namespace;
}(TimeAccounting.Agent.EditTimeRecords || {}));
LyoqCiAqIEBwcm9qZWN0ICAgICBPVFJTIChodHRwOi8vd3d3Lm90cnMub3JnKSAtIEFnZW50IEZyb250ZW5kCiAqIEBjb3B5cmlnaHQgICBPVFJTIEFHCiAqIEBsaWNlbnNlICAgICBBR1BMIChodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQpCiAqLwoKLyoqCiAqIEBwYWNrYWdlICAgICBTa2luICJEZWZhdWx0IgogKiBAc2VjdGlvbiAgICAgVGltZSBBY2NvdW50aW5nIERlZmF1bHQgQ1NTCiAqLwoKQG1lZGlhIHNjcmVlbixwcm9qZWN0aW9uLHR2LGhhbmRoZWxkIHsKCi8qKgogKiBAc3Vic2VjdGlvbiAgbGVmdCBhbmQgcmlnaHQgYXJyb3dzCiAqLwoKLkFycm93IHsKICAgIGRpc3BsYXk6IGJsb2NrOwogICAgd2lkdGg6IDEwcHg7CiAgICBoZWlnaHQ6IDEycHg7CiAgICBmbG9hdDogbGVmdDsKICAgIG1hcmdpbi10b3A6IC0ycHg7CiAgICBtYXJnaW4tcmlnaHQ6IDRweDsKfQoKLkFycm93IGkgewogICAgZm9udC1zaXplOiAxNnB4OwogICAgY29sb3I6ICM1NTU7Cn0KCi8qKgogKiBAc3Vic2VjdGlvbiAgc3BlY2lhbCBzZXR0aW5nczogcmVwb3J0aW5nCiAqLwoKZGl2Lk1vbnRoU2VsZWN0aW9uIHsKICAgIGxpbmUtaGVpZ2h0OiAyNHB4OwogICAgbWFyZ2luLWJvdHRvbTogMTBweDsKfQoKLk1vbnRoU2VsZWN0aW9uIC5BcnJvdyB7CiAgICBtYXJnaW4tdG9wOiAxcHg7Cn0KCi8qKgogKiBAc3Vic2VjdGlvbiAgc3BlY2lhbCBvdmVyd3JpdGluZyBzZXR0aW5ncyBmb3IgYXV0b2NvbXBsZXRpb24gYnV0dG9uCiAqLwoKdGFibGUjSW5zZXJ0V29ya2luZ0hvdXJzIHRib2R5IHRkIHsKICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7CiAgICBoZWlnaHQ6IDM1cHg7Cn0KCnRhYmxlI0luc2VydFdvcmtpbmdIb3VycyB0Ym9keSB0ZCBpbnB1dC51aS13aWRnZXQgewogICAgaGVpZ2h0OiAxN3B4OwogICAgcGFkZGluZzogMHB4OwogICAgZm9udC1zaXplOiAxMnB4Owp9CgoudWktYnV0dG9uLWljb24tb25seSAudWktYnV0dG9uLXRleHQgewogICAgcGFkZGluZzogMCAhaW1wb3J0YW50OwogICAgaGVpZ2h0OiAxOHB4ICFpbXBvcnRhbnQ7Cn0KCi51aS1idXR0b24gLnVpLWJ1dHRvbi10ZXh0IHsKICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTsKICAgIGxlZnQ6IC05OTk5cHg7CiAgICB0b3A6IC05OTk5cHg7Cn0KCmJ1dHRvbi51aS1idXR0b24taWNvbi1vbmx5IHsKICAgIHdpZHRoOiAyNHB4ICFpbXBvcnRhbnQ7CiAgICBoZWlnaHQ6IDE3cHg7CiAgICBwYWRkaW5nOiAwcHggIWltcG9ydGFudDsKICAgIHdpZHRoOiAyNHB4ICFpbXBvcnRhbnQ7CiAgICBib3gtc2l6aW5nOiBpbml0aWFsOwogICAgdmVydGljYWwtYWxpZ246IHRvcDsKfQoKLnVpLWF1dG9jb21wbGV0ZSAudWktbWVudS1pZXRtIHsKICAgIGZvbnQtZmFtaWx5OiAiSGVsdmV0aWNhIE5ldWUiLCBIZWx2ZXRpY2EsIEFyaWFsLCBzYW5zLXNlcmlmOwogICAgZm9udC1zaXplOiAxMnB4OwogICAgdGV4dC1hbGlnbjogbGVmdDsKfQoKLkhvcml6b250YWxTY3JvbGwgewogICAgb3ZlcmZsb3cteDogc2Nyb2xsOwp9CgovKioKICogQHN1YnNlY3Rpb24gIEluY29tcGxldGVXb3JraW5nRGF5cyBzZWxlY3QKICovCiNJbmNvbXBsZXRlV29ya2luZ0RheXNMaXN0IG9wdGlvbltzZWxlY3RlZD1zZWxlY3RlZF0gewogICAgZm9udC13ZWlnaHQ6IGJvbGQ7Cn0KCi8qKgogKiBAc3Vic2VjdGlvbiAgcHJvamVjdCBhbmQgYWN0aW9uIGRyb3Bkb3ducwogKi8KLlByb2plY3RTZWxlY3Rpb24gewogICAgd2lkdGg6IDMwMHB4Owp9CgouQWN0aW9uU2VsZWN0aW9uIHsKICAgIHdpZHRoOiAzMDBweDsKfQoKdWwudWktYXV0b2NvbXBsZXRlLnVpLW1lbnUgewogICAgbWF4LWhlaWdodDogMzAwcHg7CiAgICBvdmVyZmxvdy15OiBhdXRvOwp9Cgp9IC8qIGVuZCBAbWVkaWEgKi8=
LyoqCiAqIEBwcm9qZWN0ICAgICBPVFJTIChodHRwOi8vd3d3Lm90cnMub3JnKSAtIEFnZW50IEZyb250ZW5kCiAqIEBjb3B5cmlnaHQgICBPVFJTIEFHCiAqIEBsaWNlbnNlICAgICBBR1BMIChodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQpCiAqLwoKLyoqCiAqIEBwYWNrYWdlICAgICBTa2luICJEZWZhdWx0IgogKiBAc2VjdGlvbiAgICAgVGltZSBBY2NvdW50aW5nIEFkZGl0aW9uYWwgVGFibGUgU2V0dGluZ3MKICovCgpAbWVkaWEgc2NyZWVuLHByb2plY3Rpb24sdHYsaGFuZGhlbGQgewoKLyoqCiAqIEBzdWJzZWN0aW9uICBkYXRhIHRhYmxlIGVsZW1lbnRzIHdpdGhvdXQgaG92ZXIKICovCgouTm9Ib3ZlciB0Ym9keSB0cjpob3ZlciB0ZCB7CiAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDsKICAgIC13ZWJraXQtYm94LXNoYWRvdzogbm9uZTsKICAgIGJveC1zaGFkb3c6IG5vbmU7Cn0KCi5Ob0hvdmVyIHRyLkV2ZW46aG92ZXIgdGQgewogICAgYmFja2dyb3VuZC1jb2xvcjogI0Y1RjVGNTsKfQoKLk5vSG92ZXIgdHIuR3JhbmRUb3RhbDpob3ZlciB0ZCB7CiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjQ0ZDRkNGOwp9CgovKioKICogQHN1YnNlY3Rpb24gIHNwZWNpYWwgdGFibGUgaGVpZ2h0CiAqLwoKLkhpZ2hDZWxscyB0Ym9keSB0ZCB7CiAgICBoZWlnaHQ6IDMwcHg7Cn0KCi8qKgogKiBAc3Vic2VjdGlvbiAgZml4ZWQgZGF0YSB0YWJsZSB3aWR0aHMKICovCgouRGF0YVRhYmxlIHRkLkZpeGVkLkRheSB7CiAgICB3aWR0aDogNTBweDsKfQoKLkRhdGFUYWJsZSB0ZC5GaXhlZC5XZWVrZGF5IHsKICAgIHdpZHRoOiA4MHB4Owp9CgovKioKICogQHN1YnNlY3Rpb24gIHRhYmxlIGNvbG91cnMgZm9yIG92ZXJ2aWV3CiAqLwoKLkRhdGFUYWJsZSB0ci5WYWNhdGlvbiB0ZCB7CiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjRUJDQ0NDOwp9CgouRGF0YVRhYmxlIHRyLk5vbldvcmtpbmdEYXkgdGQgewogICAgYmFja2dyb3VuZC1jb2xvcjogI0ZGRTBFMDsKfQoKLkRhdGFUYWJsZSB0ci5BY3RpdmUgdGQgewogICAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICMwMDAwMDA7CiAgICBib3JkZXItdG9wOiAxcHggc29saWQgIzAwMDAwMDsKICAgIGNvbG9yOiAjMUExQTFBOwp9CgouRGF0YVRhYmxlIHRyLkFjdGl2ZSB0ZDpmaXJzdC1jaGlsZCB7CiAgICBib3JkZXItbGVmdDogMXB4IHNvbGlkICMwMDAwMDA7Cn0KCi5EYXRhVGFibGUgdHIuQWN0aXZlIHRkOmxhc3QtY2hpbGQsCi5EYXRhVGFibGUgdHIuQWN0aXZlIHRkLkxhc3QgewogICAgYm9yZGVyLXJpZ2h0OiAxcHggc29saWQgIzAwMDAwMDsKfQoKLkRhdGFUYWJsZSB0ci5HcmFuZFRvdGFsIHRkIHsKICAgIGJhY2tncm91bmQtY29sb3I6ICNDRkNGQ0Y7Cn0KCi8qKgogKiBAc3Vic2VjdGlvbiAgZGF0YSB0YWJsZSB3aXRoIHR3byBoZWFkZXIgcm93cwogKi8KCi5EYXRhVGFibGUgdGhlYWQuVHdvUm93cyB7CiAgICBiYWNrZ3JvdW5kOiBub25lOwp9CgouRGF0YVRhYmxlIHRoZWFkLlR3b1Jvd3MgdHIgewogICAgYmFja2dyb3VuZDogI2VlZWVlZTsKfQoKLkRhdGFUYWJsZSB0aGVhZC5Ud29Sb3dzIHRyOmZpcnN0LWNoaWxkIHRoIHsKICAgIGJvcmRlci1ib3R0b206IG5vbmU7CiAgICBwYWRkaW5nLWJvdHRvbTogMnB4Owp9CgouRGF0YVRhYmxlIHRoZWFkLlR3b1Jvd3MgdHI6bGFzdC1jaGlsZCB0aCwKLkRhdGFUYWJsZSB0aGVhZC5Ud29Sb3dzIHRyLkxhc3QgdGggewogICAgYm9yZGVyLXRvcDogbm9uZTsKICAgIHBhZGRpbmctdG9wOiAzcHg7Cn0KCnRyLk1hc3RlckFjdGlvbiB0ZC5Sb3dTcGFuIHsKICAgIHZlcnRpY2FsLWFsaWduOiB0b3A7Cn0KCi5EYXRhVGFibGUgYS5EYXRlcGlja2VySWNvbiBpIHsKICAgIGNvbG9yOiAjMDAwOwogICAgbWFyZ2luLWxlZnQ6IDJweDsKfQoKLkRhdGFUYWJsZSBhLkRhdGVwaWNrZXJJY29uOmhvdmVyIGkgewogICAgY29sb3I6ICNmNzI7Cn0KCiNUaW1lQWNjb3VudGluZ0VtcHR5TWVzc2FnZVNtYWxsIHsKICAgIGJvcmRlci1jb2xvcjogI2RkZDsKICAgIGJvcmRlci1pbWFnZTogbm9uZTsKICAgIGJvcmRlci1zdHlsZTogc29saWQ7CiAgICBib3JkZXItd2lkdGg6IDFweDsKICAgIHBhZGRpbmc6IDdweDsKICAgIGJhY2tncm91bmQtY29sb3I6IHdoaXRlOwp9Ci8qIGVuZCBAbWVkaWEgKi8=
# --
# TimeAccounting.pm - code to execute during package installation
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package var::packagesetup::TimeAccounting;

use strict;
use warnings;

our @ObjectDependencies = (
    'Kernel::System::Cache',
    'Kernel::System::Group',
    'Kernel::System::SysConfig',
    'Kernel::System::Valid',
);

=head1 NAME

TimeAccounting.pm - code to execute during package installation

=head1 SYNOPSIS

All functions

=head1 PUBLIC INTERFACE

=over 4

=cut

=item new()

create an object

    use Kernel::System::ObjectManager;
    local $Kernel::OM = Kernel::System::ObjectManager->new();
    my $CodeObject = $Kernel::OM->Get('var::packagesetup::TimeAccounting');

=cut

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

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

    # rebuild ZZZ* files
    $Kernel::OM->Get('Kernel::System::SysConfig')->WriteDefault();

    # define the ZZZ files
    my @ZZZFiles = (
        'ZZZAAuto.pm',
        'ZZZAuto.pm',
    );

    # reload the ZZZ files (mod_perl workaround)
    for my $ZZZFile (@ZZZFiles) {

        PREFIX:
        for my $Prefix (@INC) {
            my $File = $Prefix . '/Kernel/Config/Files/' . $ZZZFile;
            next PREFIX if !-f $File;
            do $File;
            last PREFIX;
        }
    }

    # always discard the config object before package code is executed,
    # to make sure that the config object will be created newly, so that it
    # will use the recently written new config from the package
    $Kernel::OM->ObjectsDiscard(
        Objects => ['Kernel::Config'],
    );

    return $Self;
}

=item CodeInstall()

run the code install part

    my $Result = $CodeObject->CodeInstall();

=cut

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

    # add the group time_accounting
    $Self->_GroupAdd(
        Name        => 'time_accounting',
        Description => 'Group for all time accounting user.',
    );

    # delete the group cache to avoid permission problems
    $Kernel::OM->Get('Kernel::System::Cache')->CleanUp( Type => 'Group' );

    return 1;
}

=item CodeUninstall()

run the code uninstall part

    my $Result = $CodeObject->CodeUninstall();

=cut

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

    # deactivate the group time_accounting
    $Self->_GroupDeactivate(
        Name => 'time_accounting',
    );

    return 1;
}

=item _GroupAdd()

add a group

    my $Result = $CodeObject->_GroupAdd(
        Name        => 'the-group-name',
        Description => 'The group description.',
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(Name Description)) {
        if ( !$Param{$Argument} ) {
            Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # get valid list
    my %ValidList = $Kernel::OM->Get('Kernel::System::Valid')->ValidList(
        UserID => 1,
    );
    my %ValidListReverse = reverse %ValidList;

    # get group object
    my $GroupObject = $Kernel::OM->Get('Kernel::System::Group');

    # get list of all groups
    my %GroupList = $GroupObject->GroupList();

    # reverse the group list for easier lookup
    my %GroupListReverse = reverse %GroupList;

    # check if group already exists
    my $GroupID = $GroupListReverse{ $Param{Name} };

    # reactivate the group
    if ($GroupID) {

        # get current group data
        my %GroupData = $GroupObject->GroupGet(
            ID     => $GroupID,
            UserID => 1,
        );

        # reactivate group
        $GroupObject->GroupUpdate(
            %GroupData,
            ValidID => $ValidListReverse{valid},
            UserID  => 1,
        );

        return 1;
    }

    # add the group
    else {
        return if !$GroupObject->GroupAdd(
            Name    => $Param{Name},
            Comment => $Param{Description},
            ValidID => $ValidListReverse{valid},
            UserID  => 1,
        );
    }

    # lookup the new group id
    my $NewGroupID = $GroupObject->GroupLookup(
        Group  => $Param{Name},
        UserID => 1,
    );

    # add user root to the group
    $GroupObject->GroupMemberAdd(
        GID        => $NewGroupID,
        UID        => 1,
        Permission => {
            ro        => 1,
            move_into => 1,
            create    => 1,
            owner     => 1,
            priority  => 1,
            rw        => 1,
        },
        UserID => 1,
    );

    return 1;
}

=item _GroupDeactivate()

deactivate a group

    my $Result = $CodeObject->_GroupDeactivate(
        Name => 'the-group-name',
    );

=cut

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

    # check needed stuff
    if ( !$Param{Name} ) {
        Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'Need Name!',
        );
        return;
    }

    # get group object
    my $GroupObject = $Kernel::OM->Get('Kernel::System::Group');

    # lookup group id
    my $GroupID = $GroupObject->GroupLookup(
        Group => $Param{Name},
    );

    return if !$GroupID;

    # get valid list
    my %ValidList = $Kernel::OM->Get('Kernel::System::Valid')->ValidList(
        UserID => 1,
    );
    my %ValidListReverse = reverse %ValidList;

    # get current group data
    my %GroupData = $GroupObject->GroupGet(
        ID     => $GroupID,
        UserID => 1,
    );

    # deactivate group
    $GroupObject->GroupUpdate(
        %GroupData,
        ValidID => $ValidListReverse{invalid},
        UserID  => 1,
    );

    return 1;
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

JVBERi0xLjQKJaqrrK0KNCAwIG9iago8PAovQ3JlYXRvciAoQXBhY2hlIEZPUCBWZXJzaW9uIDEuMSkKL1Byb2R1Y2VyIChBcGFjaGUgRk9QIFZlcnNpb24gMS4xKQovQ3JlYXRpb25EYXRlIChEOjIwMTQxMTIxMDU1NTU2KzAxJzAwJykKPj4KZW5kb2JqCjUgMCBvYmoKPDwKICAvTiAzCiAgL0xlbmd0aCAxMiAwIFIKICAvRmlsdGVyIC9GbGF0ZURlY29kZQo+PgpzdHJlYW0KeJydlndYU+cex99zTvZgJCFsCHuGpUAAkRGmgAzZohCSAAESICQM90BUsKKoyFIEKYpYsFqG1IkoDori3g1SBJRarOLC0USep/X29t7b2+8f53ye3/v7vef9jfd5DgCkgEyuMBdWAUAokogj/L0ZsXHxDOwAgAEeYIA9ABxubrZXWFgwkCvQl83IlTuBf9GrmwBSvK8xFXuB/0+q3GyxBAAoTM6zePxcrpyL5JyZL8lW2CflTEvOUDCMUrBYfkA5ayg4dYatP/vMsKeCeUIRT86Rcs7mCXkK7pXzhjwpX86IIpfiPAE/X87X5WycKRUK5PxGESvkc+Q5oEgKu4TPTZOznZxJ4sgItpznAIAjpX7ByV+whF8gUSTFzsouFAtS0yQMc64Fw97FhcUI4Odn8iUSZhiHm8ER8xjsLGE2R1QIwEzOn0VR1JYhL7KTvYuTE9PBxv6LQv3Xxb8pRW9n6EX4555B9P4/bH/ll9UAAGtKXpstf9iSqwDoXAeAxt0/bMZ7AFCW963j8hf50BXzkiaRZLva2ubn59sI+FwbRUF/1/90+Bv64ns2iu1+Lw/Dh5/CkWZKGIq6cbMys6RiRm42h8tnMP88xP848K/PYR3BT+GL+SJ5RLR8ygSiVHm7RTyBRJAlYghE/6mJ/zDsT5qZa7mojR8BLdEGqFymAeTnfoCiEgGSsFu+Av3et2B8NFDcvBj90Zm5/yzo33eFyxSPXEHq5zh2RCSDKxXnzawpriVAAwJQBjSgCfSAETAHTOAAnIEb8AS+YB4IBZEgDiwGXJAGhEAM8sEysBoUg1KwBewA1aAONIJm0AoOg05wDJwG58AlcAXcAPeADIyAp2ASvALTEARhITJEhTQhfcgEsoIcIBY0F/KFgqEIKA5KglIhESSFlkFroVKoHKqG6qFm6FvoKHQaugANQnegIWgc+hV6ByMwCabBurApbAuzYC84CI6EF8GpcA68BC6CN8OVcAN8EO6AT8OX4BuwDH4KTyEAISJ0xABhIiyEjYQi8UgKIkZWICVIBdKAtCLdSB9yDZEhE8hbFAZFRTFQTJQbKgAVheKiclArUJtQ1aj9qA5UL+oaagg1ifqIJqN10FZoV3QgOhadis5HF6Mr0E3odvRZ9A30CPoVBoOhY8wwzpgATBwmHbMUswmzC9OGOYUZxAxjprBYrCbWCuuODcVysBJsMbYKexB7EnsVO4J9gyPi9HEOOD9cPE6EW4OrwB3AncBdxY3ipvEqeBO8Kz4Uz8MX4svwjfhu/GX8CH6aoEowI7gTIgnphNWESkIr4SzhPuEFkUg0JLoQw4kC4ipiJfEQ8TxxiPiWRCFZktikBJKUtJm0j3SKdIf0gkwmm5I9yfFkCXkzuZl8hvyQ/EaJqmSjFKjEU1qpVKPUoXRV6ZkyXtlE2Ut5sfIS5QrlI8qXlSdU8CqmKmwVjsoKlRqVoyq3VKZUqar2qqGqQtVNqgdUL6iOUbAUU4ovhUcpouylnKEMUxGqEZVN5VLXUhupZ6kjNAzNjBZIS6eV0r6hDdAm1Shqs9Wi1QrUatSOq8noCN2UHkjPpJfRD9Nv0t+p66p7qfPVN6q3ql9Vf62hreGpwdco0WjTuKHxTpOh6auZoblVs1PzgRZKy1IrXCtfa7fWWa0JbZq2mzZXu0T7sPZdHVjHUidCZ6nOXp1+nSldPV1/3WzdKt0zuhN6dD1PvXS97Xon9Mb1qfpz9QX62/VP6j9hqDG8GJmMSkYvY9JAxyDAQGpQbzBgMG1oZhhluMawzfCBEcGIZZRitN2ox2jSWN84xHiZcYvxXRO8CcskzWSnSZ/Ja1Mz0xjT9aadpmNmGmaBZkvMWszum5PNPcxzzBvMr1tgLFgWGRa7LK5YwpaOlmmWNZaXrWArJyuB1S6rQWu0tYu1yLrB+haTxPRi5jFbmEM2dJtgmzU2nTbPbI1t42232vbZfrRztMu0a7S7Z0+xn2e/xr7b/lcHSweuQ43D9VnkWX6zVs7qmvV8ttVs/uzds287Uh1DHNc79jh+cHJ2Eju1Oo07GzsnOdc632LRWGGsTazzLmgXb5eVLsdc3ro6uUpcD7v+4sZ0y3A74DY2x2wOf07jnGF3Q3eOe727bC5jbtLcPXNlHgYeHI8Gj0eeRp48zybPUS8Lr3Svg17PvO28xd7t3q/Zruzl7FM+iI+/T4nPgC/FN8q32vehn6Ffql+L36S/o/9S/1MB6ICggK0BtwJ1A7mBzYGT85znLZ/XG0QKWhBUHfQo2DJYHNwdAofMC9kWcn++yXzR/M5QEBoYui30QZhZWE7Y9+GY8LDwmvDHEfYRyyL6FlAXJC44sOBVpHdkWeS9KPMoaVRPtHJ0QnRz9OsYn5jyGFmsbezy2EtxWnGCuK54bHx0fFP81ELfhTsWjiQ4JhQn3Fxktqhg0YXFWoszFx9PVE7kJB5JQifFJB1Ies8J5TRwppIDk2uTJ7ls7k7uU54nbztvnO/OL+ePprinlKeMpbqnbksdT/NIq0ibELAF1YLn6QHpdemvM0Iz9mV8yozJbBPihEnCoyKKKEPUm6WXVZA1mG2VXZwty3HN2ZEzKQ4SN+VCuYtyuyQ0+c9Uv9Rcuk46lDc3rybvTX50/pEC1QJRQX+hZeHGwtElfku+Xopayl3as8xg2eplQ8u9ltevgFYkr+hZabSyaOXIKv9V+1cTVmes/mGN3ZryNS/XxqztLtItWlU0vM5/XUuxUrG4+NZ6t/V1G1AbBBsGNs7aWLXxYwmv5GKpXWlF6ftN3E0Xv7L/qvKrT5tTNg+UOZXt3oLZItpyc6vH1v3lquVLyoe3hWzr2M7YXrL95Y7EHRcqZlfU7STslO6UVQZXdlUZV22pel+dVn2jxrumrVandmPt6128XVd3e+5urdOtK617t0ew53a9f31Hg2lDxV7M3ry9jxujG/u+Zn3d3KTVVNr0YZ9on2x/xP7eZufm5gM6B8pa4BZpy/jBhINXvvH5pquV2VrfRm8rPQQOSQ89+Tbp25uHgw73HGEdaf3O5Lvadmp7SQfUUdgx2ZnWKeuK6xo8Ou9oT7dbd/v3Nt/vO2ZwrOa42vGyE4QTRSc+nVxycupU9qmJ06mnh3sSe+6diT1zvTe8d+Bs0Nnz5/zOnenz6jt53v38sQuuF45eZF3svOR0qaPfsb/9B8cf2gecBjouO1/uuuJypXtwzuCJqx5XT1/zuXbueuD1Szfm3xi8GXXz9q2EW7LbvNtjdzLvPL+bd3f63qr76PslD1QeVDzUedjwo8WPbTIn2fEhn6H+Rwse3RvmDj/9Kfen9yNFj8mPK0b1R5vHHMaOjfuNX3my8MnI0+yn0xPFP6v+XPvM/Nl3v3j+0j8ZOznyXPz806+bXmi+2Pdy9sueqbCph6+Er6Zfl7zRfLP/Lett37uYd6PT+e+x7ys/WHzo/hj08f4n4adPvwHJ4vTiCmVuZHN0cmVhbQplbmRvYmoKNiAwIG9iagpbL0lDQ0Jhc2VkIDUgMCBSXQplbmRvYmoKNyAwIG9iago8PAogIC9UeXBlIC9NZXRhZGF0YQogIC9TdWJ0eXBlIC9YTUwKICAvTGVuZ3RoIDEzIDAgUgo+PgpzdHJlYW0KPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz48eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIj4KPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4KPHJkZjpEZXNjcmlwdGlvbiB4bWxuczpkYz0iaHR0cDovL3B1cmwub3JnL2RjL2VsZW1lbnRzLzEuMS8iIHJkZjphYm91dD0iIj4KPGRjOmxhbmd1YWdlPmVuPC9kYzpsYW5ndWFnZT4KPGRjOmZvcm1hdD5hcHBsaWNhdGlvbi9wZGY8L2RjOmZvcm1hdD4KPGRjOmRhdGU+MjAxNC0xMS0yMVQwNTo1NTo1NiswMTowMDwvZGM6ZGF0ZT4KPC9yZGY6RGVzY3JpcHRpb24+CjxyZGY6RGVzY3JpcHRpb24geG1sbnM6cGRmPSJodHRwOi8vbnMuYWRvYmUuY29tL3BkZi8xLjMvIiByZGY6YWJvdXQ9IiI+CjxwZGY6UERGVmVyc2lvbj4xLjQ8L3BkZjpQREZWZXJzaW9uPgo8cGRmOlByb2R1Y2VyPkFwYWNoZSBGT1AgVmVyc2lvbiAxLjE8L3BkZjpQcm9kdWNlcj4KPC9yZGY6RGVzY3JpcHRpb24+CjxyZGY6RGVzY3JpcHRpb24geG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiByZGY6YWJvdXQ9IiI+Cjx4bXA6Q3JlYXRlRGF0ZT4yMDE0LTExLTIxVDA1OjU1OjU2KzAxOjAwPC94bXA6Q3JlYXRlRGF0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Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgODAuMCA2NzkuNjI5IDExNy4xOSA2ODkuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDU2IDAgUgovSCAvSQoKPj4KZW5kb2JqCjU5IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNy4wNjggNjc5LjYyOSA1NDIuOTc4IDY4OS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgNTYgMCBSCi9IIC9JCgo+PgplbmRvYmoKNjAgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbMjggMCBSIC9YWVogNzIuMCA3MjAuMCBudWxsXQo+PgplbmRvYmoKNjEgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgODAuMCA2NjcuNjI5IDE1My44MTEgNjc3LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSA2MCAwIFIKL0ggL0kKCj4+CmVuZG9iago2MiAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzYuMzM4IDY2Ny42MjkgNTQyLjY5OCA2NzcuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDYwIDAgUgovSCAvSQoKPj4KZW5kb2JqCjYzIDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzI4IDAgUiAvWFlaIDcyLjAgNzAwLjggbnVsbF0KPj4KZW5kb2JqCjY0IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDY1NS42MjkgMjUzLjQzMiA2NjUuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDYzIDAgUgovSCAvSQoKPj4KZW5kb2JqCjY1IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS43MTIgNjU1LjYyOSA1NDIuMDcyIDY2NS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgNjMgMCBSCi9IIC9JCgo+PgplbmRvYmoKNjYgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbMjggMCBSIC9YWVogNzIuMCA2MzQuNCBudWxsXQo+PgplbmRvYmoKNjcgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgNjQzLjYyOSAyMjYuMDU4IDY1My42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgNjYgMCBSCi9IIC9JCgo+PgplbmRvYmoKNjggMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM1LjkyOCA2NDMuNjI5IDU0Mi4yODggNjUzLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSA2NiAwIFIKL0ggL0kKCj4+CmVuZG9iago2OSAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFsyOCAwIFIgL1hZWiA3Mi4wIDU0Ni4wIG51bGxdCj4+CmVuZG9iago3MCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCA2MzEuNjI5IDI1NC45NDQgNjQxLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSA2OSAwIFIKL0ggL0kKCj4+CmVuZG9iago3MSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzUuNyA2MzEuNjI5IDU0Mi4wNiA2NDEuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDY5IDAgUgovSCAvSQoKPj4KZW5kb2JqCjcyIDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzI4IDAgUiAvWFlaIDcyLjAgNDc5LjYgbnVsbF0KPj4KZW5kb2JqCjczIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDYxOS42MjkgMjQ3LjQzNCA2MjkuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDcyIDAgUgovSCAvSQoKPj4KZW5kb2JqCjc0IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS43NiA2MTkuNjI5IDU0Mi4xMiA2MjkuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDcyIDAgUgovSCAvSQoKPj4KZW5kb2JqCjc1IDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzI4IDAgUiAvWFlaIDcyLjAgNDAxLjIgbnVsbF0KPj4KZW5kb2JqCjc2IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDYwNy42MjkgMjUyLjA1OSA2MTcuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDc1IDAgUgovSCAvSQoKPj4KZW5kb2JqCjc3IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS43MjIgNjA3LjYyOSA1NDIuMDgyIDYxNy42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgNzUgMCBSCi9IIC9JCgo+PgplbmRvYmoKNzggMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbMjggMCBSIC9YWVogNzIuMCAzNTguOCBudWxsXQo+PgplbmRvYmoKNzkgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgNTk1LjYyOSAyNjMuNTgyIDYwNS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgNzggMCBSCi9IIC9JCgo+PgplbmRvYmoKODAgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM1LjYzMiA1OTUuNjI5IDU0MS45OTIgNjA1LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSA3OCAwIFIKL0ggL0kKCj4+CmVuZG9iago4MSAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFsyOCAwIFIgL1hZWiA3Mi4wIDMwNC40IG51bGxdCj4+CmVuZG9iago4MiAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCA1ODMuNjI5IDQwNy4yNTMgNTkzLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSA4MSAwIFIKL0ggL0kKCj4+CmVuZG9iago4MyAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzQuNDkxIDU4My42MjkgNTQwLjg1MSA1OTMuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDgxIDAgUgovSCAvSQoKPj4KZW5kb2JqCjg0IDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzI4IDAgUiAvWFlaIDcyLjAgMjI2LjAgbnVsbF0KPj4KZW5kb2JqCjg1IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDU3MS42MjkgMzMzLjUyIDU4MS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgODQgMCBSCi9IIC9JCgo+PgplbmRvYmoKODYgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM1LjA3OCA1NzEuNjI5IDU0MS40MzggNTgxLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSA4NCAwIFIKL0ggL0kKCj4+CmVuZG9iago4NyAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFsyOCAwIFIgL1hZWiA3Mi4wIDE1OS42IG51bGxdCj4+CmVuZG9iago4OCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCA1NTkuNjI5IDE4Mi40MzcgNTY5LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSA4NyAwIFIKL0ggL0kKCj4+CmVuZG9iago4OSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzYuMjc0IDU1OS42MjkgNTQyLjYzNCA1NjkuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDg3IDAgUgovSCAvSQoKPj4KZW5kb2JqCjkwIDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzMxIDAgUiAvWFlaIDcyLjAgNzIwLjAgbnVsbF0KPj4KZW5kb2JqCjkxIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDgwLjAgNTQ3LjYyOSAyMDQuOTI5IDU1Ny42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgOTAgMCBSCi9IIC9JCgo+PgplbmRvYmoKOTIgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM1Ljk1NiA1NDcuNjI5IDU0Mi4zMTYgNTU3LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSA5MCAwIFIKL0ggL0kKCj4+CmVuZG9iago5MyAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFszMSAwIFIgL1hZWiA3Mi4wIDcwMC44IG51bGxdCj4+CmVuZG9iago5NCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCA1MzUuNjI5IDE3My4zODMgNTQ1LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSA5MyAwIFIKL0ggL0kKCj4+CmVuZG9iago5NSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzYuMzQ0IDUzNS42MjkgNTQyLjcwNCA1NDUuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDkzIDAgUgovSCAvSQoKPj4KZW5kb2JqCjk2IDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzMxIDAgUiAvWFlaIDcyLjAgNjI2LjQgbnVsbF0KPj4KZW5kb2JqCjk3IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDUyMy42MjkgMTY0Ljg4OCA1MzMuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDk2IDAgUgovSCAvSQoKPj4KZW5kb2JqCjk4IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNi41ODMgNTIzLjYyOSA1NDIuOTQzIDUzMy42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgOTYgMCBSCi9IIC9JCgo+PgplbmRvYmoKOTkgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbMzEgMCBSIC9YWVogNzIuMCA1NTguMCBudWxsXQo+PgplbmRvYmoKMTAwIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDUxMS42MjkgMjA5LjUwMyA1MjEuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDk5IDAgUgovSCAvSQoKPj4KZW5kb2JqCjEwMSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzYuMDYgNTExLjYyOSA1NDIuNDIgNTIxLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSA5OSAwIFIKL0ggL0kKCj4+CmVuZG9iagoxMDIgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbMzEgMCBSIC9YWVogNzIuMCA0ODkuNiBudWxsXQo+PgplbmRvYmoKMTAzIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDQ5OS42MjkgMjIxLjcxOSA1MDkuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDEwMiAwIFIKL0ggL0kKCj4+CmVuZG9iagoxMDQgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM1Ljk2MiA0OTkuNjI5IDU0Mi4zMjIgNTA5LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxMDIgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTA1IDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzM0IDAgUiAvWFlaIDcyLjAgNzIwLjAgbnVsbF0KPj4KZW5kb2JqCjEwNiAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA4MC4wIDQ4Ny42MjkgMTQ5LjM2NyA0OTcuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDEwNSAwIFIKL0ggL0kKCj4+CmVuZG9iagoxMDcgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM2LjM3MiA0ODcuNjI5IDU0Mi43MzIgNDk3LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxMDUgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTA4IDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzM0IDAgUiAvWFlaIDcyLjAgNjQ0LjggbnVsbF0KPj4KZW5kb2JqCjEwOSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCA0NzUuNjI5IDE5OC45NTYgNDg1LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxMDggMCBSCi9IIC9JCgo+PgplbmRvYmoKMTEwIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNi4xNDIgNDc1LjYyOSA1NDIuNTAyIDQ4NS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTA4IDAgUgovSCAvSQoKPj4KZW5kb2JqCjExMSAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFszNCAwIFIgL1hZWiA3Mi4wIDU2OC40IG51bGxdCj4+CmVuZG9iagoxMTIgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgNDYzLjYyOSAxOTQuNTkxIDQ3My42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTExIDAgUgovSCAvSQoKPj4KZW5kb2JqCjExMyAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzYuMTc4IDQ2My42MjkgNTQyLjUzOCA0NzMuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDExMSAwIFIKL0ggL0kKCj4+CmVuZG9iagoxMTQgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDAgMCBSIC9YWVogNzIuMCA3MjAuMCBudWxsXQo+PgplbmRvYmoKMTE1IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDgwLjAgNDUxLjYyOSAxNjEuNzYgNDYxLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxMTQgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTE2IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNi4yNzggNDUxLjYyOSA1NDIuNjM4IDQ2MS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTE0IDAgUgovSCAvSQoKPj4KZW5kb2JqCjExNyAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs0MCAwIFIgL1hZWiA3Mi4wIDY2Ny4yNTkgbnVsbF0KPj4KZW5kb2JqCjExOCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCA0MzkuNjI5IDM2MS44OTYgNDQ5LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxMTcgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTE5IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNC44NSA0MzkuNjI5IDU0MS4yMSA0NDkuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDExNyAwIFIKL0ggL0kKCj4+CmVuZG9iagoxMjAgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDAgMCBSIC9YWVogNzIuMCA2MDQuMDUyIG51bGxdCj4+CmVuZG9iagoxMjEgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgNDI3LjYyOSAzODguNTgxIDQzNy42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTIwIDAgUgovSCAvSQoKPj4KZW5kb2JqCjEyMiAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzQuNjM5IDQyNy42MjkgNTQwLjk5OSA0MzcuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDEyMCAwIFIKL0ggL0kKCj4+CmVuZG9iagoxMjMgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDAgMCBSIC9YWVogNzIuMCA1NDAuODQ1IG51bGxdCj4+CmVuZG9iagoxMjQgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgNDE1LjYyOSAzOTEuMDExIDQyNS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTIzIDAgUgovSCAvSQoKPj4KZW5kb2JqCjEyNSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzQuNjE5IDQxNS42MjkgNTQwLjk3OSA0MjUuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDEyMyAwIFIKL0ggL0kKCj4+CmVuZG9iagoxMjYgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDAgMCBSIC9YWVogNzIuMCA0NzcuNjM4IG51bGxdCj4+CmVuZG9iagoxMjcgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgNDAzLjYyOSAzNzguMjYyIDQxMy42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTI2IDAgUgovSCAvSQoKPj4KZW5kb2JqCjEyOCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzQuNzIxIDQwMy42MjkgNTQxLjA4MSA0MTMuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDEyNiAwIFIKL0ggL0kKCj4+CmVuZG9iagoxMjkgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDAgMCBSIC9YWVogNzIuMCA0MTQuNDMxIG51bGxdCj4+CmVuZG9iagoxMzAgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgMzkxLjYyOSAzNjUuMzUzIDQwMS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTI5IDAgUgovSCAvSQoKPj4KZW5kb2JqCjEzMSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzQuODIzIDM5MS42MjkgNTQxLjE4MyA0MDEuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDEyOSAwIFIKL0ggL0kKCj4+CmVuZG9iagoxMzIgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDAgMCBSIC9YWVogNzIuMCAzNTEuMjI0IG51bGxdCj4+CmVuZG9iagoxMzMgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgMzc5LjYyOSAzNjUuMTgzIDM4OS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTMyIDAgUgovSCAvSQoKPj4KZW5kb2JqCjEzNCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzQuODI0IDM3OS42MjkgNTQxLjE4NCAzODkuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDEzMiAwIFIKL0ggL0kKCj4+CmVuZG9iagoxMzUgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDAgMCBSIC9YWVogNzIuMCAyODguMDE3IG51bGxdCj4+CmVuZG9iagoxMzYgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgMzY3LjYyOSA0OTkuMDM0IDM3Ny42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTM1IDAgUgovSCAvSQoKPj4KZW5kb2JqCjEzNyAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzMuODMyIDM2Ny42MjkgNTQwLjE5MiAzNzcuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDEzNSAwIFIKL0ggL0kKCj4+CmVuZG9iagoxMzggMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDAgMCBSIC9YWVogNzIuMCAxOTguNDEgbnVsbF0KPj4KZW5kb2JqCjEzOSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCAzNTUuNjI5IDM2My40MyAzNjUuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDEzOCAwIFIKL0ggL0kKCj4+CmVuZG9iagoxNDAgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM0LjgzOCAzNTUuNjI5IDU0MS4xOTggMzY1LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxMzggMCBSCi9IIC9JCgo+PgplbmRvYmoKMTQxIDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzQwIDAgUiAvWFlaIDcyLjAgMTM1LjIwMyBudWxsXQo+PgplbmRvYmoKMTQyIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDM0My42MjkgMzk0Ljc1NiAzNTMuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDE0MSAwIFIKL0ggL0kKCj4+CmVuZG9iagoxNDMgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM0LjU4OSAzNDMuNjI5IDU0MC45NDkgMzUzLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxNDEgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTQ0IDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzQzIDAgUiAvWFlaIDcyLjAgNzIwLjAgbnVsbF0KPj4KZW5kb2JqCjE0NSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCAzMzEuNjI5IDMxOS43MDQgMzQxLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxNDQgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTQ2IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS4xODUgMzMxLjYyOSA1NDEuNTQ1IDM0MS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTQ0IDAgUgovSCAvSQoKPj4KZW5kb2JqCjE0NyAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs0MyAwIFIgL1hZWiA3Mi4wIDY0OC45NDYgbnVsbF0KPj4KZW5kb2JqCjE0OCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCAzMTkuNjI5IDMyOS43ODQgMzI5LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxNDcgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTQ5IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS4xMDUgMzE5LjYyOSA1NDEuNDY1IDMyOS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTQ3IDAgUgovSCAvSQoKPj4KZW5kb2JqCjE1MCAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs0MyAwIFIgL1hZWiA3Mi4wIDU3MS42OTYgbnVsbF0KPj4KZW5kb2JqCjE1MSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCAzMDcuNjI5IDMxMS4yODcgMzE3LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxNTAgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTUyIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS4yNTEgMzA3LjYyOSA1NDEuNjExIDMxNy42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTUwIDAgUgovSCAvSQoKPj4KZW5kb2JqCjE1MyAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs0MyAwIFIgL1hZWiA3Mi4wIDUwNi40NDYgbnVsbF0KPj4KZW5kb2JqCjE1NCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCAyOTUuNjI5IDMxMy42MTggMzA1LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxNTMgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTU1IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS4yMzMgMjk1LjYyOSA1NDEuNTkzIDMwNS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTUzIDAgUgovSCAvSQoKPj4KZW5kb2JqCjE1NiAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs0MyAwIFIgL1hZWiA3Mi4wIDQ0MS4xOTYgbnVsbF0KPj4KZW5kb2JqCjE1NyAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCAyODMuNjI5IDMxNC4xODUgMjkzLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxNTYgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTU4IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS4yMjggMjgzLjYyOSA1NDEuNTg4IDI5My42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTU2IDAgUgovSCAvSQoKPj4KZW5kb2JqCjE1OSAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs0MyAwIFIgL1hZWiA3Mi4wIDM3NS45NDYgbnVsbF0KPj4KZW5kb2JqCjE2MCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCAyNzEuNjI5IDMxNi41MTYgMjgxLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxNTkgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTYxIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS4yMSAyNzEuNjI5IDU0MS41NyAyODEuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDE1OSAwIFIKL0ggL0kKCj4+CmVuZG9iagoxNjIgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDMgMCBSIC9YWVogNzIuMCAzMTAuNjk2IG51bGxdCj4+CmVuZG9iagoxNjMgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgMjU5LjYyOSAzMTYuMTI4IDI2OS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTYyIDAgUgovSCAvSQoKPj4KZW5kb2JqCjE2NCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzUuMjEzIDI1OS42MjkgNTQxLjU3MyAyNjkuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDE2MiAwIFIKL0ggL0kKCj4+CmVuZG9iagoxNjUgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDMgMCBSIC9YWVogNzIuMCAyNDUuNDQ2IG51bGxdCj4+CmVuZG9iagoxNjYgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgMjQ3LjYyOSAzMjEuNTM2IDI1Ny42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTY1IDAgUgovSCAvSQoKPj4KZW5kb2JqCjE2NyAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzUuMTcgMjQ3LjYyOSA1NDEuNTMgMjU3LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxNjUgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTY4IDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzQzIDAgUiAvWFlaIDcyLjAgMTgwLjE5NiBudWxsXQo+PgplbmRvYmoKMTY5IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDIzNS42MjkgMzMwLjA5MiAyNDUuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDE2OCAwIFIKL0ggL0kKCj4+CmVuZG9iagoxNzAgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM1LjEwMiAyMzUuNjI5IDU0MS40NjIgMjQ1LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxNjggMCBSCi9IIC9JCgo+PgplbmRvYmoKMTcxIDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzQzIDAgUiAvWFlaIDcyLjAgMTE0Ljk0NiBudWxsXQo+PgplbmRvYmoKMTcyIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDIyMy42MjkgMzI3Ljg3MSAyMzMuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDE3MSAwIFIKL0ggL0kKCj4+CmVuZG9iagoxNzMgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM1LjEyIDIyMy42MjkgNTQxLjQ4IDIzMy42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTcxIDAgUgovSCAvSQoKPj4KZW5kb2JqCjE3NCAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs0NiAwIFIgL1hZWiA3Mi4wIDcwOC4wIG51bGxdCj4+CmVuZG9iagoxNzUgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgMjExLjYyOSAzMTkuODYzIDIyMS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTc0IDAgUgovSCAvSQoKPj4KZW5kb2JqCjE3NiAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzUuMTgzIDIxMS42MjkgNTQxLjU0MyAyMjEuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDE3NCAwIFIKL0ggL0kKCj4+CmVuZG9iagoxNzcgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDYgMCBSIC9YWVogNzIuMCA2NDQuNjQgbnVsbF0KPj4KZW5kb2JqCjE3OCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCAxOTkuNjI5IDMwNS4xMzEgMjA5LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxNzcgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTc5IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS4zIDE5OS42MjkgNTQxLjY2IDIwOS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTc3IDAgUgovSCAvSQoKPj4KZW5kb2JqCjE4MCAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs0NiAwIFIgL1hZWiA3Mi4wIDU4MS4yOCBudWxsXQo+PgplbmRvYmoKMTgxIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDE4Ny42MjkgMzM4LjQ5OSAxOTcuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDE4MCAwIFIKL0ggL0kKCj4+CmVuZG9iagoxODIgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM1LjAzNSAxODcuNjI5IDU0MS4zOTUgMTk3LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxODAgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTgzIDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzQ2IDAgUiAvWFlaIDcyLjAgNTE3LjkyIG51bGxdCj4+CmVuZG9iagoxODQgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgMTc1LjYyOSAzMjguMzY5IDE4NS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTgzIDAgUgovSCAvSQoKPj4KZW5kb2JqCjE4NSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzUuMTE1IDE3NS42MjkgNTQxLjQ3NSAxODUuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDE4MyAwIFIKL0ggL0kKCj4+CmVuZG9iagoxODYgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDYgMCBSIC9YWVogNzIuMCA0NTQuNTYgbnVsbF0KPj4KZW5kb2JqCjE4NyAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCAxNjMuNjI5IDM3NS43NjEgMTczLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxODYgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTg4IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNC43NCAxNjMuNjI5IDU0MS4xIDE3My42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTg2IDAgUgovSCAvSQoKPj4KZW5kb2JqCjE4OSAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs0NiAwIFIgL1hZWiA3Mi4wIDM5MS4yIG51bGxdCj4+CmVuZG9iagoxOTAgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgMTUxLjYyOSAzMjcuMzEzIDE2MS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTg5IDAgUgovSCAvSQoKPj4KZW5kb2JqCjE5MSAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzUuMTI0IDE1MS42MjkgNTQxLjQ4NCAxNjEuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDE4OSAwIFIKL0ggL0kKCj4+CmVuZG9iagoxOTIgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDYgMCBSIC9YWVogNzIuMCAzMjcuODQgbnVsbF0KPj4KZW5kb2JqCjE5MyAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCAxMzkuNjI5IDM2NC45NDQgMTQ5LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxOTIgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTk0IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNC44MjYgMTM5LjYyOSA1NDEuMTg2IDE0OS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTkyIDAgUgovSCAvSQoKPj4KZW5kb2JqCjE5NSAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs0NiAwIFIgL1hZWiA3Mi4wIDI2NC40OCBudWxsXQo+PgplbmRvYmoKMTk2IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDEyNy42MjkgNDM4LjQyMyAxMzcuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDE5NSAwIFIKL0ggL0kKCj4+CmVuZG9iagoxOTcgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM0LjI0MyAxMjcuNjI5IDU0MC42MDMgMTM3LjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAxOTUgMCBSCi9IIC9JCgo+PgplbmRvYmoKMTk4IDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzQ2IDAgUiAvWFlaIDcyLjAgMTg5LjEyIG51bGxdCj4+CmVuZG9iagoxOTkgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgMTE1LjYyOSAzMzAuNDQxIDEyNS42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMTk4IDAgUgovSCAvSQoKPj4KZW5kb2JqCjIwMCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzUuMDk5IDExNS42MjkgNTQxLjQ1OSAxMjUuNjE5IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDE5OCAwIFIKL0ggL0kKCj4+CmVuZG9iagoyMDEgMCBvYmoKPDwgL1R5cGUgL0FjdGlvbgovUyAvR29UbwovRCBbNDYgMCBSIC9YWVogNzIuMCAxMTMuNzYgbnVsbF0KPj4KZW5kb2JqCjIwMiAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCAxMDMuNjI5IDMyMi42MDIgMTEzLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAyMDEgMCBSCi9IIC9JCgo+PgplbmRvYmoKMjAzIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS4xNjEgMTAzLjYyOSA1NDEuNTIxIDExMy42MTkgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMjAxIDAgUgovSCAvSQoKPj4KZW5kb2JqCjIwNCAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs0OSAwIFIgL1hZWiA3Mi4wIDY5Ni4wIG51bGxdCj4+CmVuZG9iagoyMDUgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgOTEuNjI5IDI3NS41NTkgMTAxLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAyMDQgMCBSCi9IIC9JCgo+PgplbmRvYmoKMjA2IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNS41MzUgOTEuNjI5IDU0MS44OTUgMTAxLjYxOSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAyMDQgMCBSCi9IIC9JCgo+PgplbmRvYmoKMjA3IDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzUyIDAgUiAvWFlaIDcyLjAgNzIwLjAgbnVsbF0KPj4KZW5kb2JqCjIwOCAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUg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bm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM1LjkyIDcwOS4wMDUgNTQyLjI4IDcxOC45OTUgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMjM4IDAgUgovSCAvSQoKPj4KZW5kb2JqCjI0MiAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFs1MiAwIFIgL1hZWiA3Mi4wIDMzOS4xNjMgbnVsbF0KPj4KZW5kb2JqCjI0MyAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyAxMDQuMCA2OTcuMDA1IDIxNC4zOTkgNzA2Ljk5NSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAyNDIgMCBSCi9IIC9JCgo+PgplbmRvYmoKMjQ0IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzNi4wMjIgNjk3LjAwNSA1NDIuMzgyIDcwNi45OTUgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMjQyIDAgUgovSCAvSQoKPj4KZW5kb2JqCjI0NSAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFsyMTIgMCBSIC9YWVogNzIuMCA3MjAuMCBudWxsXQo+PgplbmRvYmoKMjQ2IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDY4NS4wMDUgMTc1LjMyMSA2OTQuOTk1IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDI0NSAwIFIKL0ggL0kKCj4+CmVuZG9iagoyNDcgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM2LjMzIDY4NS4wMDUgNTQyLjY5IDY5NC45OTUgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMjQ1IDAgUgovSCAvSQoKPj4KZW5kb2JqCjI0OCAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFsyMTIgMCBSIC9YWVogNzIuMCA0MjQuMyBudWxsXQo+PgplbmRvYmoKMjQ5IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDY3My4wMDUgMjYyLjY5MyA2ODIuOTk1IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDI0OCAwIFIKL0ggL0kKCj4+CmVuZG9iagoyNTAgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTM1LjYzNiA2NzMuMDA1IDU0MS45OTYgNjgyLjk5NSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAyNDggMCBSCi9IIC9JCgo+PgplbmRvYmoKMjUxIDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzIyNSAwIFIgL1hZWiA3Mi4wIDcyMC4wIG51bGxdCj4+CmVuZG9iagoyNTIgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgODAuMCA2NjEuMDA1IDEzMi44NjEgNjcwLjk5NSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAyNTEgMCBSCi9IIC9JCgo+PgplbmRvYmoKMjUzIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUzMC4wODggNjYxLjAwNSA1NDIuODA4IDY3MC45OTUgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMjUxIDAgUgovSCAvSQoKPj4KZW5kb2JqCjI1NCAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFsyMzEgMCBSIC9YWVogNzIuMCA3MjAuMCBudWxsXQo+PgplbmRvYmoKMjU1IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDgwLjAgNjQ5LjAwNSAxMTkuMDM2IDY1OC45OTUgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMjU0IDAgUgovSCAvSQoKPj4KZW5kb2JqCjI1NiAwIG9iago8PCAvVHlwZSAvQW5ub3QKL1N1YnR5cGUgL0xpbmsKL1JlY3QgWyA1MzAuMTkgNjQ5LjAwNSA1NDIuOTEgNjU4Ljk5NSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAyNTQgMCBSCi9IIC9JCgo+PgplbmRvYmoKMjU3IDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzIzMSAwIFIgL1hZWiA3Mi4wIDY3OC44IG51bGxdCj4+CmVuZG9iagoyNTggMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgMTA0LjAgNjM3LjAwNSAxNzEuODcgNjQ2Ljk5NSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAyNTcgMCBSCi9IIC9JCgo+PgplbmRvYmoKMjU5IDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDUyOS45NDYgNjM3LjAwNSA1NDIuNjY2IDY0Ni45OTUgXQovQyBbIDAgMCAwIF0KL0JvcmRlciBbIDAgMCAwIF0KL0EgMjU3IDAgUgovSCAvSQoKPj4KZW5kb2JqCjI2MCAwIG9iago8PCAvVHlwZSAvQWN0aW9uCi9TIC9Hb1RvCi9EIFsyMzEgMCBSIC9YWVogNzIuMCA2MjQuNCBudWxsXQo+PgplbmRvYmoKMjYxIDAgb2JqCjw8IC9UeXBlIC9Bbm5vdAovU3VidHlwZSAvTGluawovUmVjdCBbIDEwNC4wIDYyNS4wMDUgMTY3Ljc4MyA2MzQuOTk1IF0KL0MgWyAwIDAgMCBdCi9Cb3JkZXIgWyAwIDAgMCBdCi9BIDI2MCAwIFIKL0ggL0kKCj4+CmVuZG9iagoyNjIgMCBvYmoKPDwgL1R5cGUgL0Fubm90Ci9TdWJ0eXBlIC9MaW5rCi9SZWN0IFsgNTI5Ljk4IDYyNS4wMDUgNTQyLjcgNjM0Ljk5NSBdCi9DIFsgMCAwIDAgXQovQm9yZGVyIFsgMCAwIDAgXQovQSAyNjAgMCBSCi9IIC9JCgo+PgplbmRvYmoKMjYzIDAgb2JqCjw8IC9UeXBlIC9BY3Rpb24KL1MgL0dvVG8KL0QgWzIzNCAwIFIgL1hZWiA3Mi4w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agoyODggMCBvYmoKMzc0CmVuZG9iagoyODkgMCBvYmoKMTU5MjAKZW5kb2JqCjI5MCAwIG9iagoyNwplbmRvYmoKMjkxIDAgb2JqCjU2MQplbmRvYmoKMjkyIDAgb2JqCjE0NDI4CmVuZG9iagoyOTMgMCBvYmoKMjIKZW5kb2JqCjI5NCAwIG9iago1MDIKZW5kb2JqCjEgMCBvYmoKPDwgL1R5cGUgL1BhZ2VzCi9Db3VudCAxOQovS2lkcyBbOCAwIFIgNTUgMCBSIDIzNyAwIFIgMjE1IDAgUiAxOCAwIFIgMjggMCBSIDMxIDAgUiAzNCAwIFIgNDAgMCBSIDQzIDAgUiA0NiAwIFIgNDkgMCBSIDUyIDAgUiAyMTIgMCBSIDIyMiAwIFIgMjI1IDAgUiAyMjggMCBSIDIzMSAwIFIgMjM0IDAgUiBdID4+CmVuZG9iagoyIDAgb2JqCjw8CiAgL1R5cGUgL0NhdGFsb2cKICAvUGFnZXMgMSAwIFIKICAvTGFuZyAoZW4pCiAgL01ldGFkYXRhIDcgMCBSCiAgL1BhZ2VMYWJlbHMgOSAwIFIKPj4KCmVuZG9iagozIDAgb2JqCjw8CiAgL0ZvbnQgPDwKICAvRjE5IDI3MSAwIFIKICAvRjE1IDI3NyAwIFIKICAvRjE2IDI4MyAwIFIKPj4KCiAgL1Byb2NTZXQgWy9QREYgL0ltYWdlQiAvSW1hZ2VDIC9UZXh0XQogIC9YT2JqZWN0IDw8CiAgL0ltMSAxMCAwIFIKICAvSW0yIDExIDAgUgogIC9JbTMgMTkgMCBSCiAgL0ltNCAyMCAwIFIKPj4KCiAgL0NvbG9yU3BhY2UgPDwgL0RlZmF1bHRSR0IgNiAwIFIgPj4KCj4+CgplbmRvYmoKOSAwIG9iago8PCAvTnVtcyBbMCA8PCAvUCAoMSkgPj4KIDEgPDwgL1AgKGlpKSA+PgogMiA8PCAvUCAoaWlpKSA+PgogMyA8PCAvUCAoaXYpID4+CiA0IDw8IC9QICh2KSA+PgogNSA8PCAvUCAoMSkgPj4KIDYgPDwgL1AgKDIpID4+CiA3IDw8IC9QICgzKSA+PgogOCA8PCAvUCAoNCkgPj4KIDkgPDwgL1AgKDUpID4+CiAxMCA8PCAvUCAoNikgPj4KIDExIDw8IC9QICg3KSA+PgogMTIgPDwgL1AgKDgpID4+CiAxMyA8PCAvUCAoOSkgPj4KIDE0IDw8IC9QICgxMCkgPj4KIDE1IDw8IC9QICgxMSkgPj4KIDE2IDw8IC9QICgxMikgPj4KIDE3IDw8IC9QICgxMykgPj4KIDE4IDw8IC9QICgxNCkgPj4KXSA+PgoKZW5kb2JqCnhyZWYKMCAyOTUKMDAwMDAwMDAwMCA2NTUzNSBmIAowMDAwMjQ3NjUxIDAwMDAwIG4gCjAwMDAyNDc4NDQgMDAwMDAgbiAKMDAwMDI0Nzk0OSAwMDAwMCBuIAowMDAwMDAwMDE1IDAwMDAwIG4gCjAwMDAwMDAxNDUgMDAwMDAgbiAKMDAwMDAwMjgyMyAwMDAwMCBuIAowMDAwMDAyODU2IDAwMDAwIG4gCjAwMDAxMDYxNzYgMDAwMDAgbiAKMDAwMDI0ODE4NCAwMDAwMCBuIAowMDAwMDAzODA0IDAwMDAwIG4gCjAwMDAwNTIzMzEgMDAwMDAgbiAKMDAwMDEwNTU5MyAwMDAwMCBuIAowMDAwMTA1NjE0IDAwMDAwIG4gCjAwMDAxMDU2MzQgMDAwMDAgbiAKMDAwMDEwNTY1NiAwMDAwMCBuIAowMDAwMTA1Njc4IDAwMDAwIG4gCjAwMDAxMDYzNjggMDAwMDAgbiAKMDAwMDEyMDk3MCAwMDAwMCBuIAowMDAwMTA2Mzg4IDAwMDAwIG4gCjAwMDAxMTI1NTkgMDAwMDAgbiAKMDAwMDExOTczOSAwMDAwMCBuIAowMDAwMTE5NzYwIDAwMDAwIG4gCjAwMDAxMTk3ODEgMDAwMDAgbiAKMDAwMDExOTg2NiAwMDAwMCBuIAowMDAwMTIwOTQzIDAwMDAwIG4gCjAwMDAxMjAwMDQgMDAwMDAgbiAKMDAwMDEyMTE4MCAwMDAwMCBuIAowMDAwMTIzOTMzIDAwMDAwIG4gCjAwMDAxMjEyMDAgMDAwMDAgbiAKMDAwMDEyNDEyNiAwMDAwMCBuIAowMDAwMTI1MDEzIDAwMDAwIG4gCjAwMDAxMjQxNDcgMDAwMDAgbiAKMDAwMDEyNTIwNiAwMDAwMCBuIAowMDAwMTI2ODcxIDAwMDAwIG4gCjAwMDAxMjUyMjYgMDAwMDAgbiAKMDAwMDEyNTMyMSAwMDAwMCBuIAowMDAwMTI2ODQ0IDAwMDAwIG4gCjAwMDAxMjU0NTcgMDAwMDAgbiAKMDAwMDEyNzA4MSAwMDAwMCBuIAowMDAwMTI4NzUwIDAwMDAwIG4gCjAwMDAxMjcxMDIgMDAwMDAgbiAKMDAwMDEyODk0MyAwMDAwMCBuIAowMDAwMTMwMzE2IDAwMDAwIG4gCjAwMDAxMjg5NjQgMDAwMDAgbiAKMDAwMDEzMDUwOSAwMDAwMCBuIAowMDAwMTMyMjE1IDAwMDAwIG4gCjAwMDAxMzA1MzAgMDAwMDAgbiAKMDAwMDEzMjQwOCAwMDAwMCBuIAowMDAwMTMzMzMwIDAwMDAwIG4gCjAwMDAxMzI0MjkgMDAwMDAgbiAKMDAwMDEzMzUyMyAwMDAwMCBuIAowMDAwMTM1NTg0IDAwMDAwIG4gCjAwMDAxMzM1NDMgMDAwMDAgbiAKMDAwMDEzNTc3NyAwMDAwMCBuIAowMDAwMTgxMjc5IDAwMDAwIG4gCjAwMDAxMzU3OTggMDAwMDAgbiAKMDAwMDEzNTg3NiAwMDAwMCBuIAowMDAwMTgwNDcxIDAwMDAwIG4gCjAwMDAxMzYwMTIgMDAwMDAgbiAKMDAwMDEzNjE1MiAwMDAwMCBuIAowMDAwMTM2MjMwIDAwMDAwIG4gCjAwMDAxMzYzNjcgMDAwMDAgbiAKMDAwMDEzNjUwNyAwMDAwMCBuIAowMDAwMTM2NTg1IDAwMDAwIG4gCjAwMDAxMzY3MjMgMDAwMDAgbiAKMDAwMDEzNjg2MyAwMDAwMCBuIAowMDAwMTM2OTQxIDAwMDAwIG4gCjAwMDAxMzcwNzkgMDAwMDAgbiAKMDAwMDEzNzIxOSAwMDAwMCBuIAowMDAwMTM3Mjk3IDAwMDAwIG4gCjAwMDAxMzc0MzUgMDAwMDAgbiAKMDAwMDEzNzU3MiAwMDAwMCBuIAowMDAwMTM3NjUwIDAwMDAwIG4gCjAwMDAxMzc3ODggMDAwMDAgbiAKMDAwMDEzNzkyNiAwMDAwMCBuIAowMDAwMTM4MDA0IDAwMDAwIG4gCjAwMDAxMzgxNDIgMDAwMDAgbiAKMDAwMDEzODI4MiAwMDAwMCBuIAowMDAwMTM4MzYwIDAwMDAwIG4gCjAwMDAxMzg0OTggMDAwMDAgbiAKMDAwMDEzODYzOCAwMDAwMCBuIAowMDAwMTM4NzE2IDAwMDAwIG4gCjAwMDAxMzg4NTQgMDAwMDAgbiAKMDAwMDEzODk5NCAwMDAwMCBuIAowMDAwMTM5MDcyIDAwMDAwIG4gCjAwMDAxMzkyMDkgMDAwMDAgbiAKMDAwMDEzOTM0OSAwMDAwMCBuIAowMDAwMTM5NDI3IDAwMDAwIG4gCjAwMDAxMzk1NjUgMDAwMDAgbiAKMDAwMDEzOTcwNSAwMDAwMCBuIAowMDAwMTM5NzgzIDAwMDAwIG4gCjAwMDAxMzk5MjAgMDAwMDAgbiAKMDAwMDE0MDA2MCAwMDAwMCBuIAowMDAwMTQwMTM4IDAwMDAwIG4gCjAwMDAxNDAyNzYgMDAwMDAgbiAKMDAwMDE0MDQxNiAwMDAwMCBuIAowMDAwMTQwNDk0IDAwMDAwIG4gCjAwMDAxNDA2MzIgMDAwMDAgbiAKMDAwMDE0MDc3MiAwMDAwMCBuIAowMDAwMTQwODUwIDAwMDAwIG4gCjAwMDAxNDA5ODkgMDAwMDAgbiAKMDAwMDE0MTEyOCAwMDAwMCBuIAowMDAwMTQxMjA3IDAwMDAwIG4gCjAwMDAxNDEzNDcgMDAwMDAgbiAKMDAwMDE0MTQ4OSAwMDAwMCBuIAowMDAwMTQxNTY4IDAwMDAwIG4gCjAwMDAxNDE3MDcgMDAwMDAgbiAKMDAwMDE0MTg0OSAwMDAwMCBuIAowMDAwMTQxOTI4IDAwMDAwIG4gCjAwMDAxNDIwNjggMDAwMDAgbiAKMDAwMDE0MjIxMCAwMDAwMCBuIAowMDAwMTQyMjg5IDAwMDAwIG4gCjAwMDAxNDI0MjkgMDAwMDAgbiAKMDAwMDE0MjU3MSAwMDAwMCBuIAowMDAwMTQyNjUwIDAwMDAwIG4gCjAwMDAxNDI3ODggMDAwMDAgbiAKMDAwMDE0MjkzMCAwMDAwMCBuIAowMDAwMTQzMDExIDAwMDAwIG4gCjAwMDAxNDMxNTEgMDAwMDAgbiAKMDAwMDE0MzI5MSAwMDAwMCBuIAowMDAwMTQzMzcyIDAwMDAwIG4gCjAwMDAxNDM1MTIgMDAwMDAgbiAKMDAwMDE0MzY1NCAwMDAwMCBuIAowMDAwMTQzNzM1IDAwMDAwIG4gCjAwMDAxNDM4NzUgMDAwMDAgbiAKMDAwMDE0NDAxNyAwMDAwMCBuIAowMDAwMTQ0MDk4IDAwMDAwIG4gCjAwMDAxNDQyMzggMDAwMDAgbiAKMDAwMDE0NDM4MCAwMDAwMCBuIAowMDAwMTQ0NDYxIDAwMDAwIG4gCjAwMDAxNDQ2MDEgMDAwMDAgbiAKMDAwMDE0NDc0MyAwMDAwMCBuIAowMDAwMTQ0ODI0IDAwMDAwIG4gCjAwMDAxNDQ5NjQgMDAwMDAgbiAKMDAwMDE0NTEwNiAwMDAwMCBuIAowMDAwMTQ1MTg3IDAwMDAwIG4gCjAwMDAxNDUzMjcgMDAwMDAgbiAKMDAwMDE0NTQ2OSAwMDAwMCBuIAowMDAwMTQ1NTQ5IDAwMDAwIG4gCjAwMDAxNDU2ODggMDAwMDAgbiAKMDAwMDE0NTgzMCAwMDAwMCBuIAowMDAwMTQ1OTExIDAwMDAwIG4gCjAwMDAxNDYwNTEgMDAwMDAgbiAKMDAwMDE0NjE5MyAwMDAwMCBuIAowMDAwMTQ2MjcyIDAwMDAwIG4gCjAwMDAxNDY0MTIgMDAwMDAgbiAKMDAwMDE0NjU1NCAwMDAwMCBuIAowMDAwMTQ2NjM1IDAwMDAwIG4gCjAwMDAxNDY3NzUgMDAwMDAgbiAKMDAwMDE0NjkxNyAwMDAwMCBuIAowMDAwMTQ2OTk4IDAwMDAwIG4gCjAwMDAxNDcxMzggMDAwMDAgbiAKMDAwMDE0NzI4MCAwMDAwMCBuIAowMDAwMTQ3MzYxIDAwMDAwIG4gCjAwMDAxNDc1MDEgMDAwMDAgbiAKMDAwMDE0NzY0MyAwMDAwMCBuIAowMDAwMTQ3NzI0IDAwMDAwIG4gCjAwMDAxNDc4NjQgMDAwMDAgbiAKMDAwMDE0ODAwNiAwMDAwMCBuIAowMDAwMTQ4MDg3IDAwMDAwIG4gCjAwMDAxNDgyMjcgMDAwMDAgbiAKMDAwMDE0ODM2NyAwMDAwMCBuIAowMDAwMTQ4NDQ4IDAwMDAwIG4gCjAwMDAxNDg1ODggMDAwMDAgbiAKMDAwMDE0ODczMCAwMDAwMCBuIAowMDAwMTQ4ODExIDAwMDAwIG4gCjAwMDAxNDg5NTEgMDAwMDAgbiAKMDAwMDE0OTA5MSAwMDAwMCBuIAowMDAwMTQ5MTcyIDAwMDAwIG4gCjAwMDAxNDkzMTIgMDAwMDAgbiAKMDAwMDE0OTQ1NCAwMDAwMCBuIAowMDAwMTQ5NTM1IDAwMDAwIG4gCjAwMDAxNDk2NzUgMDAwMDAgbiAKMDAwMDE0OTgxNSAwMDAwMCBuIAowMDAwMTQ5ODk0IDAwMDAwIG4gCjAwMDAxNTAwMzQgMDAwMDAgbiAKMDAwMDE1MDE3NiAwMDAwMCBuIAowMDAwMTUwMjU2IDAwMDAwIG4gCjAwMDAxNTAzOTYgMDAwMDAgbiAKMDAwMDE1MDUzNSAwMDAwMCBuIAowMDAwMTUwNjE1IDAwMDAwIG4gCjAwMDAxNTA3NTUgMDAwMDAgbiAKMDAwMDE1MDg5NyAwMDAwMCBuIAowMDAwMTUwOTc3IDAwMDAwIG4gCjAwMDAxNTExMTcgMDAwMDAgbiAKMDAwMDE1MTI1OSAwMDAwMCBuIAowMDAwMTUxMzM5IDAwMDAwIG4gCjAwMDAxNTE0NzkgMDAwMDAgbiAKMDAwMDE1MTYxOCAwMDAwMCBuIAowMDAwMTUxNjk3IDAwMDAwIG4gCjAwMDAxNTE4MzcgMDAwMDAgbiAKMDAwMDE1MTk3OSAwMDAwMCBuIAowMDAwMTUyMDU5IDAwMDAwIG4gCjAwMDAxNTIxOTkgMDAwMDAgbiAKMDAwMDE1MjM0MSAwMDAwMCBuIAowMDAwMTUyNDIxIDAwMDAwIG4gCjAwMDAxNTI1NjEgMDAwMDAgbiAKMDAwMDE1MjcwMyAwMDAwMCBuIAowMDAwMTUyNzgzIDAwMDAwIG4gCjAwMDAxNTI5MjMgMDAwMDAgbiAKMDAwMDE1MzA2NSAwMDAwMCBuIAowMDAwMTUzMTQ1IDAwMDAwIG4gCjAwMDAxNTMyODUgMDAwMDAgbiAKMDAwMDE1MzQyNyAwMDAwMCBuIAowMDAwMTUzNTA2IDAwMDAwIG4gCjAwMDAxNTM2NDUgMDAwMDAgbiAKMDAwMDE1Mzc4NiAwMDAwMCBuIAowMDAwMTUzODY1IDAwMDAwIG4gCjAwMDAxNTQwMDIgMDAwMDAgbiAKMDAwMDE1NDE0MiAwMDAwMCBuIAowMDAwMTgxNDkwIDAwMDAwIG4gCjAwMDAxODQwNzQgMDAwMDAgbiAKMDAwMDE4MTUxMyAwMDAwMCBuIAowMDAwMTg0MjY5IDAwMDAwIG4gCjAwMDAxODU2NjIgMDAwMDAgbiAKMDAwMDE4NDI5MSAwMDAwMCBuIAowMDAwMTg0MzcxIDAwMDAwIG4gCjAwMDAxODU2MjUgMDAwMDAgbiAKMDAwMDE4NDUxMCAwMDAwMCBuIAowMDAwMTg0NjUwIDAwMDAwIG4gCjAwMDAxODU4NzUgMDAwMDAgbiAKMDAwMDE4NjU5MiAwMDAwMCBuIAowMDAwMTg1ODk2IDAwMDAwIG4gCjAwMDAxODY3ODcgMDAwMDAgbiAKMDAwMDE4ODExNiAwMDAwMCBuIAowMDAwMTg2ODA4IDAwMDAwIG4gCjAwMDAxODgzMTEgMDAwMDAgbiAKMDAwMDE4OTM1NyAwMDAwMCBuIAowMDAwMTg4MzMzIDAwMDAwIG4gCjAwMDAxODk1NTIgMDAwMDAgbiAKMDAwMDE5MTI0OCAwMDAwMCBuIAowMDAwMTg5NTczIDAwMDAwIG4gCjAwMDAxOTE0NDMgMDAwMDAgbiAKMDAwMDE5MjE0MSAwMDAwMCBuIAowMDAwMTkxNDY1IDAwMDAwIG4gCjAwMDAxOTIzMzYgMDAwMDAgbiAKMDAwMDIwMzAwOCAwMDAwMCBuIAowMDAwMTkyMzU3IDAwMDAwIG4gCjAwMDAxOTI0MzggMDAwMDAgbiAKMDAwMDIwMjg0MyAwMDAwMCBuIAowMDAwMTkyNTc4IDAwMDAwIG4gCjAwMDAxOTI3MTggMDAwMDAgbiAKMDAwMDE5Mjc5OSAwMDAwMCBuIAowMDAwMTkyOTM5IDAwMDAwIG4gCjAwMDAxOTMwODEgMDAwMDAgbiAKMDAwMDE5MzE2MSAwMDAwMCBuIAowMDAwMTkzMzAxIDAwMDAwIG4gCjAwMDAxOTM0NDEgMDAwMDAgbiAKMDAwMDE5MzUyMSAwMDAwMCBuIAowMDAwMTkzNjYxIDAwMDAwIG4gCjAwMDAxOTM4MDMgMDAwMDAgbiAKMDAwMDE5Mzg4MyAwMDAwMCBuIAowMDAwMTk0MDIyIDAwMDAwIG4gCjAwMDAxOTQxNjQgMDAwMDAgbiAKMDAwMDE5NDI0NCAwMDAwMCBuIAowMDAwMTk0MzgzIDAwMDAwIG4gCjAwMDAxOTQ1MjMgMDAwMDAgbiAKMDAwMDE5NDYwMyAwMDAwMCBuIAowMDAwMTk0NzQyIDAwMDAwIG4gCjAwMDAxOTQ4ODQgMDAwMDAgbiAKMDAwMDE5NDk2NCAwMDAwMCBuIAowMDAwMTk1MTA0IDAwMDAwIG4gCjAwMDAxOTUyNDMgMDAwMDAgbiAKMDAwMDE5NTMyMyAwMDAwMCBuIAowMDAwMTk1NDYxIDAwMDAwIG4gCjAwMDAxOTU2MDMgMDAwMDAgbiAKMDAwMDIwMzIyMSAwMDAwMCBuIAowMDAwMjAzMjQzIDAwMDAwIG4gCjAwMDAyMDM1MDYgMDAwMDAgbiAKMDAwMDIxMjU1MyAwMDAwMCBuIAowMDAwMjEyNjUxIDAwMDAwIG4gCjAwMDAyMTI4MTYgMDAwMDAgbiAKMDAwMDIxMzE3MSAwMDAwMCBuIAowMDAwMjEzNjIzIDAwMDAwIG4gCjAwMDAyMTM4ODQgMDAwMDAgbiAKMDAwMDIyOTkwMyAwMDAwMCBuIAowMDAwMjMwMDA4IDAwMDAwIG4gCjAwMDAyMzAxNjkgMDAwMDAgbiAKMDAwMDIzMDcwMCAwMDAwMCBuIAowMDAwMjMxMzM5IDAwMDAwIG4gCjAwMDAyMzE2MDUgMDAwMDAgbiAKMDAwMDI0NjEzMiAwMDAwMCBuIAowMDAwMjQ2MjMyIDAwMDAwIG4gCjAwMDAyNDYzOTggMDAwMDAgbiAKMDAwMDI0Njg4MCAwMDAwMCBuIAowMDAwMjQ3NDYwIDAwMDAwIG4gCjAwMDAyNDc0ODIgMDAwMDAgbiAKMDAwMDI0NzUwMiAwMDAwMCBuIAowMDAwMjQ3NTIzIDAwMDAwIG4gCjAwMDAyNDc1NDYgMDAwMDAgbiAKMDAwMDI0NzU2NiAwMDAwMCBuIAowMDAwMjQ3NTg3IDAwMDAwIG4gCjAwMDAyNDc2MTAgMDAwMDAgbiAKMDAwMDI0NzYzMCAwMDAwMCBuIAp0cmFpbGVyCjw8CiAgL1Jvb3QgMiAwIFIKICAvSW5mbyA0IDAgUgogIC9JRCBbPDdDNzA2NEZCNkNEQTBERTgxMjUwQjVDRUMwMzhFRDI3PiA8N0M3MDY0RkI2Q0RBMERFODEyNTBCNUNFQzAzOEVEMjc+XQogIC9TaXplIDI5NQo+PgpzdGFydHhyZWYKMjQ4NTM2CiUlRU9GCg==