2016-06-20 19:12:43 +08:00
|
|
|
<?php
|
|
|
|
// This file is part of Moodle - http://moodle.org/
|
|
|
|
//
|
|
|
|
// Moodle 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 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// Moodle 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 Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Chart series.
|
|
|
|
*
|
|
|
|
* @package core
|
|
|
|
* @copyright 2016 Frédéric Massart - FMCorz.net
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace core;
|
|
|
|
defined('MOODLE_INTERNAL') || die();
|
|
|
|
|
|
|
|
use coding_exception;
|
|
|
|
use JsonSerializable;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Chart series class.
|
|
|
|
*
|
|
|
|
* @package core
|
|
|
|
* @copyright 2016 Frédéric Massart - FMCorz.net
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*/
|
|
|
|
class chart_series implements JsonSerializable {
|
|
|
|
|
2016-07-04 12:01:25 +08:00
|
|
|
/** Default type for a series. */
|
2016-06-20 19:12:43 +08:00
|
|
|
const TYPE_DEFAULT = null;
|
2016-07-04 12:01:25 +08:00
|
|
|
/** Series of type line. */
|
2016-06-20 19:12:43 +08:00
|
|
|
const TYPE_LINE = 'line';
|
|
|
|
|
2016-07-05 18:29:18 +08:00
|
|
|
/** @var string[] Colors of the series. */
|
|
|
|
protected $colors = [];
|
2016-07-04 12:01:25 +08:00
|
|
|
/** @var string Label for this series. */
|
2016-06-20 19:12:43 +08:00
|
|
|
protected $label;
|
2016-07-22 14:45:39 +08:00
|
|
|
/** @var string[] Labels for the values of the series. */
|
|
|
|
protected $labels = null;
|
2016-07-06 12:26:53 +08:00
|
|
|
/** @var bool Whether the line of the serie should be smooth or not. */
|
|
|
|
protected $smooth = null;
|
2016-07-04 12:01:25 +08:00
|
|
|
/** @var string Type of the series. */
|
2016-06-20 19:12:43 +08:00
|
|
|
protected $type = self::TYPE_DEFAULT;
|
2016-07-04 12:01:25 +08:00
|
|
|
/** @var float[] Values of the series. */
|
2016-06-20 19:12:43 +08:00
|
|
|
protected $values = [];
|
2016-07-07 14:14:26 +08:00
|
|
|
/** @var int Index of the X axis. */
|
|
|
|
protected $xaxis = null;
|
|
|
|
/** @var int Index of the Y axis. */
|
|
|
|
protected $yaxis = null;
|
2016-06-20 19:12:43 +08:00
|
|
|
|
2016-07-04 12:01:25 +08:00
|
|
|
/**
|
|
|
|
* Constructor.
|
|
|
|
*
|
|
|
|
* @param string $label The label of the series.
|
|
|
|
* @param float[] $values The values of this series.
|
|
|
|
*/
|
2016-06-20 19:12:43 +08:00
|
|
|
public function __construct($label, $values) {
|
|
|
|
$this->values = $values;
|
|
|
|
$this->label = $label;
|
|
|
|
}
|
|
|
|
|
2016-07-04 12:01:25 +08:00
|
|
|
/**
|
|
|
|
* Get the color.
|
|
|
|
*
|
2016-07-05 18:29:18 +08:00
|
|
|
* @return string|null
|
2016-07-04 12:01:25 +08:00
|
|
|
*/
|
2016-06-27 18:40:05 +08:00
|
|
|
public function get_color() {
|
2016-07-05 18:29:18 +08:00
|
|
|
return isset($this->color[0]) ? $this->color[0] : null;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the colors for each value in the series.
|
|
|
|
*
|
|
|
|
* @return string[]
|
|
|
|
*/
|
|
|
|
public function get_colors() {
|
|
|
|
return $this->colors;
|
2016-06-27 18:40:05 +08:00
|
|
|
}
|
|
|
|
|
2016-07-04 12:01:25 +08:00
|
|
|
/**
|
|
|
|
* Get the number of values in this series.
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
2016-06-20 19:12:43 +08:00
|
|
|
public function get_count() {
|
|
|
|
return count($this->values);
|
|
|
|
}
|
|
|
|
|
2016-07-04 12:01:25 +08:00
|
|
|
/**
|
|
|
|
* Get the label of the series.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2016-06-20 19:12:43 +08:00
|
|
|
public function get_label() {
|
|
|
|
return $this->label;
|
|
|
|
}
|
|
|
|
|
2016-07-22 14:45:39 +08:00
|
|
|
/**
|
|
|
|
* Set labels for the values of the series.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function get_labels() {
|
|
|
|
return $this->labels;
|
|
|
|
}
|
|
|
|
|
2016-07-06 12:26:53 +08:00
|
|
|
/**
|
|
|
|
* Get whether the line of the serie should be smooth or not.
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function get_smooth() {
|
|
|
|
return $this->smooth;
|
|
|
|
}
|
|
|
|
|
2016-07-04 12:01:25 +08:00
|
|
|
/**
|
|
|
|
* Get the type of series.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2016-06-20 19:12:43 +08:00
|
|
|
public function get_type() {
|
|
|
|
return $this->type;
|
|
|
|
}
|
|
|
|
|
2016-07-04 12:01:25 +08:00
|
|
|
/**
|
|
|
|
* Get the values of the series.
|
|
|
|
*
|
2016-07-05 18:29:18 +08:00
|
|
|
* @return string[]
|
2016-07-04 12:01:25 +08:00
|
|
|
*/
|
2016-06-20 19:12:43 +08:00
|
|
|
public function get_values() {
|
|
|
|
return $this->values;
|
|
|
|
}
|
|
|
|
|
2016-07-07 14:14:26 +08:00
|
|
|
/**
|
|
|
|
* Get the index of the X axis.
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function get_xaxis() {
|
|
|
|
return $this->xaxis;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the index of the Y axis.
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function get_yaxis() {
|
|
|
|
return $this->yaxis;
|
|
|
|
}
|
|
|
|
|
2016-07-05 18:29:18 +08:00
|
|
|
/**
|
|
|
|
* Whether there is a color per value.
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function has_colored_values() {
|
|
|
|
return count($this->colors) == $this->get_count();
|
|
|
|
}
|
|
|
|
|
2016-07-04 12:01:25 +08:00
|
|
|
/**
|
|
|
|
* Serialize the object.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
2016-07-25 10:58:45 +01:00
|
|
|
public function jsonSerialize() { // @codingStandardsIgnoreLine (CONTRIB-6469).
|
2016-06-20 19:12:43 +08:00
|
|
|
$data = [
|
|
|
|
'label' => $this->label,
|
2016-07-22 14:45:39 +08:00
|
|
|
'labels' => $this->labels,
|
2016-06-20 19:12:43 +08:00
|
|
|
'type' => $this->type,
|
2016-06-27 18:40:05 +08:00
|
|
|
'values' => $this->values,
|
2016-07-05 18:29:18 +08:00
|
|
|
'colors' => $this->colors,
|
2016-07-07 14:14:26 +08:00
|
|
|
'axes' => [
|
|
|
|
'x' => $this->xaxis,
|
|
|
|
'y' => $this->yaxis,
|
2016-07-06 12:26:53 +08:00
|
|
|
],
|
|
|
|
'smooth' => $this->smooth
|
2016-06-20 19:12:43 +08:00
|
|
|
];
|
|
|
|
return $data;
|
|
|
|
}
|
|
|
|
|
2016-07-04 12:01:25 +08:00
|
|
|
/**
|
|
|
|
* Set the color of the series.
|
|
|
|
*
|
|
|
|
* @param string $color CSS compatible color.
|
|
|
|
*/
|
2016-06-20 19:12:43 +08:00
|
|
|
public function set_color($color) {
|
2016-07-05 18:29:18 +08:00
|
|
|
$this->colors = [$color];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a color for each value in the series.
|
|
|
|
*
|
|
|
|
* @param string[] $colors CSS compatible colors.
|
|
|
|
*/
|
|
|
|
public function set_colors(array $colors) {
|
|
|
|
$this->colors = $colors;
|
2016-06-20 19:12:43 +08:00
|
|
|
}
|
|
|
|
|
2016-07-22 14:45:39 +08:00
|
|
|
/**
|
|
|
|
* Set labels for the values of the series.
|
|
|
|
*
|
|
|
|
* @param array $labels The labels for the series values.
|
|
|
|
*/
|
|
|
|
public function set_labels($labels) {
|
|
|
|
$this->labels = $labels;
|
|
|
|
}
|
|
|
|
|
2016-07-06 12:26:53 +08:00
|
|
|
/**
|
|
|
|
* Set whether the line of the serie should be smooth or not.
|
|
|
|
*
|
|
|
|
* Only applicable for line chart or a line series, if null it assumes the chart default (not smooth).
|
|
|
|
*
|
2016-07-25 15:39:02 +08:00
|
|
|
* @param bool $smooth True if the line should be smooth, false for tensioned lines.
|
2016-07-06 12:26:53 +08:00
|
|
|
*/
|
|
|
|
public function set_smooth($smooth) {
|
|
|
|
$this->smooth = $smooth;
|
|
|
|
}
|
|
|
|
|
2016-07-04 12:01:25 +08:00
|
|
|
/**
|
|
|
|
* Set the type of the series.
|
|
|
|
*
|
|
|
|
* @param string $type Constant value from self::TYPE_*.
|
|
|
|
*/
|
2016-06-20 19:12:43 +08:00
|
|
|
public function set_type($type) {
|
|
|
|
if (!in_array($type, [self::TYPE_DEFAULT, self::TYPE_LINE])) {
|
|
|
|
throw new coding_exception('Invalid serie type.');
|
|
|
|
}
|
|
|
|
$this->type = $type;
|
|
|
|
}
|
|
|
|
|
2016-07-07 14:14:26 +08:00
|
|
|
/**
|
|
|
|
* Set the index of the X axis.
|
|
|
|
*
|
|
|
|
* @param int $index The index.
|
|
|
|
*/
|
|
|
|
public function set_xaxis($index) {
|
|
|
|
$this->xaxis = $index;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the index of the Y axis.
|
|
|
|
*
|
|
|
|
* @param int $index The index.
|
|
|
|
*/
|
|
|
|
public function set_yaxis($index) {
|
|
|
|
$this->yaxis = $index;
|
|
|
|
}
|
|
|
|
|
2016-06-20 19:12:43 +08:00
|
|
|
}
|