Issues (59)

GoogleCharts/Charts/CalendarChart.php (2 issues)

1
<?php
2
3
namespace CMEN\GoogleChartsBundle\GoogleCharts\Charts;
4
5
use CMEN\GoogleChartsBundle\GoogleCharts\Chart;
6
use CMEN\GoogleChartsBundle\GoogleCharts\EventType;
7
use CMEN\GoogleChartsBundle\GoogleCharts\Options\CalendarChart\CalendarChartOptions;
8
use CMEN\GoogleChartsBundle\GoogleCharts\Options\ChartOptionsInterface;
9
10
/**
11
 * @author Christophe Meneses
12
 */
13
class CalendarChart extends Chart
14
{
15
    /**
16
     * @var CalendarChartOptions
17
     */
18
    protected ChartOptionsInterface $options;
19
20
    public function __construct()
21
    {
22
        parent::__construct();
23
24
        $this->options = new CalendarChartOptions();
25
    }
26
27
    public function getType(): string
28
    {
29
        return 'Calendar';
30
    }
31
32
    public function getPackage(): string
33
    {
34
        return 'calendar';
35
    }
36
37
    public function getAvailableEventTypes(): array
38
    {
39
        return [
40
            EventType::ERROR,
41
            EventType::ON_MOUSE_OUT,
42
            EventType::ON_MOUSE_OVER,
43
            EventType::READY,
44
            EventType::SELECT,
45
        ];
46
    }
47
48
    public function getOptions(): CalendarChartOptions
49
    {
50
        return $this->options;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $this->options returns the type CMEN\GoogleChartsBundle\...s\ChartOptionsInterface which includes types incompatible with the type-hinted return CMEN\GoogleChartsBundle\...rt\CalendarChartOptions.
Loading history...
51
    }
52
53
    /**
54
     * @param CalendarChartOptions $options
55
     */
56
    public function setOptions(ChartOptionsInterface $options): CalendarChart
57
    {
58
        $this->options = $options;
0 ignored issues
show
Documentation Bug introduced by
$options is of type CMEN\GoogleChartsBundle\...s\ChartOptionsInterface, but the property $options was declared to be of type CMEN\GoogleChartsBundle\...rt\CalendarChartOptions. Are you sure that you always receive this specific sub-class here, or does it make sense to add an instanceof check?

Our type inference engine has found a suspicous assignment of a value to a property. This check raises an issue when a value that can be of a given class or a super-class is assigned to a property that is type hinted more strictly.

Either this assignment is in error or an instanceof check should be added for that assignment.

class Alien {}

class Dalek extends Alien {}

class Plot
{
    /** @var  Dalek */
    public $villain;
}

$alien = new Alien();
$plot = new Plot();
if ($alien instanceof Dalek) {
    $plot->villain = $alien;
}
Loading history...
59
60
        return $this;
61
    }
62
}
63