2013-08-07 01:47:32 +02:00
|
|
|
<?php
|
2013-08-07 10:53:44 +02:00
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
2013-10-23 15:10:33 +02:00
|
|
|
/**
|
|
|
|
* This file is part of Icinga Web 2.
|
|
|
|
*
|
|
|
|
* Icinga Web 2 - Head for multiple monitoring backends.
|
|
|
|
* Copyright (C) 2013 Icinga Development Team
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*
|
|
|
|
* @copyright 2013 Icinga Development Team <info@icinga.org>
|
|
|
|
* @license http://www.gnu.org/licenses/gpl-2.0.txt GPL, version 2
|
|
|
|
* @author Icinga Development Team <info@icinga.org>
|
|
|
|
*
|
|
|
|
*/
|
2013-08-07 10:53:44 +02:00
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
2013-08-07 01:47:32 +02:00
|
|
|
|
2014-04-17 13:03:30 +02:00
|
|
|
use Icinga\Application\Icinga;
|
|
|
|
use Icinga\Application\Config;
|
|
|
|
use Icinga\Util\DateTimeFactory;
|
|
|
|
use Icinga\Web\Form\Validator\DateTimeValidator;
|
2013-08-07 01:47:32 +02:00
|
|
|
|
2013-08-07 10:53:44 +02:00
|
|
|
/**
|
2013-08-12 14:18:58 +02:00
|
|
|
* Helper to format date and time. Utilizes DateTimeFactory to ensure time zone awareness
|
|
|
|
*
|
2013-09-04 11:24:08 +02:00
|
|
|
* @see DateTimeFactory::create()
|
2013-08-07 10:53:44 +02:00
|
|
|
*/
|
2013-08-07 01:47:32 +02:00
|
|
|
class Zend_View_Helper_DateFormat extends Zend_View_Helper_Abstract
|
|
|
|
{
|
2013-08-07 10:53:44 +02:00
|
|
|
/**
|
|
|
|
* Current request
|
2013-08-28 15:55:21 +02:00
|
|
|
*
|
2013-08-07 10:53:44 +02:00
|
|
|
* @var Zend_Controller_Request_Abstract
|
|
|
|
*/
|
2014-04-17 13:03:30 +02:00
|
|
|
protected $request;
|
2013-08-07 10:53:44 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*
|
2013-08-28 15:55:21 +02:00
|
|
|
* Retrieves the request from the application's front controller if not given.
|
|
|
|
*
|
|
|
|
* @param Zend_Controller_Request_Abstract $request The request to use
|
2013-08-07 10:53:44 +02:00
|
|
|
*/
|
2013-08-28 15:55:21 +02:00
|
|
|
public function __construct(Zend_Controller_Request_Abstract $request = null)
|
2013-08-07 10:53:44 +02:00
|
|
|
{
|
2013-08-28 15:55:21 +02:00
|
|
|
if ($request === null) {
|
|
|
|
$this->request = Icinga::app()->getFrontController()->getRequest();
|
|
|
|
} else {
|
|
|
|
$this->request = $request;
|
|
|
|
}
|
2013-08-07 10:53:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper entry point
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
2013-08-07 01:47:32 +02:00
|
|
|
public function dateFormat()
|
|
|
|
{
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-08-07 10:53:44 +02:00
|
|
|
/**
|
2013-08-07 17:13:47 +02:00
|
|
|
* Return date formatted according to given format respecting the user's timezone
|
|
|
|
*
|
|
|
|
* @param int $timestamp
|
|
|
|
* @param string $format
|
2014-04-17 13:03:30 +02:00
|
|
|
*
|
2013-08-07 17:13:47 +02:00
|
|
|
* @return string
|
|
|
|
*/
|
2013-08-28 10:50:10 +02:00
|
|
|
public function format($timestamp, $format)
|
2013-08-07 17:13:47 +02:00
|
|
|
{
|
2013-08-12 14:18:58 +02:00
|
|
|
$dt = DateTimeFactory::create();
|
2013-08-30 17:42:39 +02:00
|
|
|
if (DateTimeValidator::isUnixTimestamp($timestamp)) {
|
|
|
|
$dt->setTimestamp($timestamp);
|
|
|
|
} else {
|
|
|
|
return $timestamp;
|
|
|
|
}
|
2014-04-17 13:03:30 +02:00
|
|
|
|
2013-08-07 17:13:47 +02:00
|
|
|
return $dt->format($format);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format date according to user's format
|
2013-08-07 10:53:44 +02:00
|
|
|
*
|
|
|
|
* @param int $timestamp A unix timestamp
|
2014-04-17 13:03:30 +02:00
|
|
|
*
|
2013-08-07 10:53:44 +02:00
|
|
|
* @return string The formatted date string
|
|
|
|
*/
|
2013-08-07 01:47:32 +02:00
|
|
|
public function formatDate($timestamp)
|
|
|
|
{
|
2013-08-07 17:13:47 +02:00
|
|
|
return $this->format($timestamp, $this->getDateFormat());
|
2013-08-07 01:47:32 +02:00
|
|
|
}
|
|
|
|
|
2013-08-07 10:53:44 +02:00
|
|
|
/**
|
2013-08-07 17:13:47 +02:00
|
|
|
* Format time according to user's format
|
2013-08-07 10:53:44 +02:00
|
|
|
*
|
|
|
|
* @param int $timestamp A unix timestamp
|
2014-04-17 13:03:30 +02:00
|
|
|
*
|
2013-08-07 10:53:44 +02:00
|
|
|
* @return string The formatted time string
|
|
|
|
*/
|
|
|
|
public function formatTime($timestamp)
|
2013-08-07 01:47:32 +02:00
|
|
|
{
|
2013-08-07 17:13:47 +02:00
|
|
|
return $this->format($timestamp, $this->getTimeFormat());
|
2013-08-07 01:47:32 +02:00
|
|
|
}
|
|
|
|
|
2013-08-07 10:53:44 +02:00
|
|
|
/**
|
2013-08-07 17:13:47 +02:00
|
|
|
* Format datetime according to user's format
|
2013-08-07 10:53:44 +02:00
|
|
|
*
|
|
|
|
* @param int $timestamp A unix timestamp
|
|
|
|
* @return string The formatted datetime string
|
|
|
|
*/
|
2013-08-07 01:47:32 +02:00
|
|
|
public function formatDateTime($timestamp)
|
|
|
|
{
|
2013-08-07 17:13:47 +02:00
|
|
|
return $this->format($timestamp, $this->getDateTimeFormat());
|
2013-08-07 01:47:32 +02:00
|
|
|
}
|
|
|
|
|
2013-08-07 10:53:44 +02:00
|
|
|
/**
|
2013-08-07 17:13:47 +02:00
|
|
|
* Retrieve the user's date format string
|
2013-08-07 10:53:44 +02:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2013-08-07 01:47:32 +02:00
|
|
|
public function getDateFormat()
|
|
|
|
{
|
2013-08-07 10:53:44 +02:00
|
|
|
return $this->request->getUser()->getPreferences()->get(
|
2014-04-17 13:03:30 +02:00
|
|
|
'app.dateFormat',
|
|
|
|
Config::app()->global !== null ? Config::app()->global->get('dateFormat', 'd/m/Y') : 'd/m/Y'
|
2013-08-07 01:47:32 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2013-08-07 10:53:44 +02:00
|
|
|
/**
|
2013-08-07 17:13:47 +02:00
|
|
|
* Retrieve the user's time format string
|
2013-08-07 10:53:44 +02:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2013-08-07 01:47:32 +02:00
|
|
|
public function getTimeFormat()
|
|
|
|
{
|
2013-08-07 10:53:44 +02:00
|
|
|
return $this->request->getUser()->getPreferences()->get(
|
2014-04-17 13:03:30 +02:00
|
|
|
'app.timeFormat',
|
|
|
|
Config::app()->global !== null ? Config::app()->global->get('timeFormat', 'g:i A') : 'g:i A'
|
2013-08-07 01:47:32 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2013-08-07 10:53:44 +02:00
|
|
|
/**
|
2013-08-07 17:13:47 +02:00
|
|
|
* Retrieve the user's datetime format string
|
2013-08-07 10:53:44 +02:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2013-08-07 01:47:32 +02:00
|
|
|
public function getDateTimeFormat()
|
|
|
|
{
|
|
|
|
return $this->getDateFormat() . ' ' . $this->getTimeFormat();
|
|
|
|
}
|
|
|
|
}
|