Issues (59)

GoogleCharts/Charts/ComboChart.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\ChartOptionsInterface;
8
use CMEN\GoogleChartsBundle\GoogleCharts\Options\ComboChart\ComboChartOptions;
9
10
/**
11
 * @author Christophe Meneses
12
 */
13
class ComboChart extends Chart
14
{
15
    /**
16
     * @var ComboChartOptions
17
     */
18
    protected ChartOptionsInterface $options;
19
20 1
    public function __construct()
21
    {
22 1
        parent::__construct();
23
24 1
        $this->options = new ComboChartOptions();
25
    }
26
27
    public function getType(): string
28
    {
29
        return 'ComboChart';
30
    }
31
32
    public function getPackage(): string
33
    {
34
        return 'corechart';
35
    }
36
37 1
    public function getAvailableEventTypes(): array
38
    {
39 1
        return [
40 1
            EventType::ANIMATION_FINISH,
41 1
            EventType::CLICK,
42 1
            EventType::ERROR,
43 1
            EventType::ON_MOUSE_OUT,
44 1
            EventType::ON_MOUSE_OVER,
45 1
            EventType::READY,
46 1
            EventType::SELECT,
47 1
        ];
48
    }
49
50
    public function getOptions(): ComboChartOptions
51
    {
52
        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\...Chart\ComboChartOptions.
Loading history...
53
    }
54
55
    /**
56
     * @param ComboChartOptions $options
57
     */
58
    public function setOptions(ChartOptionsInterface $options): ComboChart
59
    {
60
        $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\...Chart\ComboChartOptions. 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...
61
62
        return $this;
63
    }
64
}
65