Issues (59)

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