Completed
Push — master ( a48b82...41a031 )
by Jan
04:01
created

LocaleDateTimeColumn   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 48
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 25
c 1
b 0
f 0
dl 0
loc 48
rs 10
wmc 4

2 Methods

Rating   Name   Duplication   Size   Complexity  
A normalize() 0 24 3
A configureOptions() 0 14 1
1
<?php
2
/**
3
 *
4
 * part-db version 0.1
5
 * Copyright (C) 2005 Christoph Lechner
6
 * http://www.cl-projects.de/
7
 *
8
 * part-db version 0.2+
9
 * Copyright (C) 2009 K. Jacobs and others (see authors.php)
10
 * http://code.google.com/p/part-db/
11
 *
12
 * Part-DB Version 0.4+
13
 * Copyright (C) 2016 - 2019 Jan Böhmer
14
 * https://github.com/jbtronics
15
 *
16
 * This program is free software; you can redistribute it and/or
17
 * modify it under the terms of the GNU General Public License
18
 * as published by the Free Software Foundation; either version 2
19
 * of the License, or (at your option) any later version.
20
 *
21
 * This program is distributed in the hope that it will be useful,
22
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
24
 * GNU General Public License for more details.
25
 *
26
 * You should have received a copy of the GNU General Public License
27
 * along with this program; if not, write to the Free Software
28
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA
29
 *
30
 */
31
32
namespace App\DataTables\Column;
33
34
35
use IntlDateFormatter;
36
use Omines\DataTablesBundle\Column\AbstractColumn;
37
use Symfony\Component\OptionsResolver\OptionsResolver;
38
39
/**
40
 * Similar to the built in DateTimeColumn, but the datetime is formatted using a IntlDateFormatter,
41
 * to get prettier locale based formatting.
42
 * @package App\DataTables\Column
43
 */
44
class LocaleDateTimeColumn extends AbstractColumn
45
{
46
    /**
47
     * {@inheritdoc}
48
     */
49
    public function normalize($value)
50
    {
51
        if (null === $value) {
52
            return $this->options['nullValue'];
53
        } elseif (!$value instanceof \DateTimeInterface) {
54
            $value = new \DateTime((string) $value);
55
        }
56
57
        $formatValues = array(
58
            'none' => IntlDateFormatter::NONE,
59
            'short' => IntlDateFormatter::SHORT,
60
            'medium' => IntlDateFormatter::MEDIUM,
61
            'long' => IntlDateFormatter::LONG,
62
            'full' => IntlDateFormatter::FULL,
63
        );
64
65
        $formatter = IntlDateFormatter::create(
66
            \Locale::getDefault(),
67
            $formatValues[$this->options['dateFormat']],
68
            $formatValues[$this->options['timeFormat']],
69
            $value->getTimezone()
0 ignored issues
show
Bug introduced by
$value->getTimezone() of type DateTimeZone is incompatible with the type string expected by parameter $timezone of IntlDateFormatter::create(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

69
            /** @scrutinizer ignore-type */ $value->getTimezone()
Loading history...
70
        );
71
72
        return $formatter->format($value->getTimestamp());
73
    }
74
75
    /**
76
     * {@inheritdoc}
77
     */
78
    protected function configureOptions(OptionsResolver $resolver)
79
    {
80
        parent::configureOptions($resolver);
81
82
        $resolver
83
            ->setDefaults([
84
                'dateFormat' => 'short',
85
                'timeFormat' => 'short',
86
                'nullValue' => ''
87
            ])
88
            ->setAllowedTypes('nullValue', 'string')
89
        ;
90
91
        return $this;
92
    }
93
}