. /** * Class for exporting summary information for a course category. * * @package core * @copyright 2017 Andrew Nicols * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ namespace core\external; defined('MOODLE_INTERNAL') || die(); use renderer_base; use moodle_url; /** * Class for exporting a course summary from an stdClass. * * @copyright 2017 Andrew Nicols * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class coursecat_summary_exporter extends \core\external\exporter { /** * @var \core_course_category $category */ protected $category; public function __construct(\core_course_category $category, $related) { $this->category = $category; $data = []; // Specify some defaults. foreach ($category as $key => $value) { $data[$key] = $value; } return parent::__construct($data, $related); } protected static function define_related() { return [ 'context' => 'context', ]; } public static function define_other_properties() { return [ 'nestedname' => [ 'type' => PARAM_RAW, ], 'url' => [ 'type' => PARAM_URL, ], ]; } protected function get_other_values(renderer_base $output) { $return = [ 'nestedname' => $this->category->get_nested_name(), 'url' => (new moodle_url('/course/index.php', [ 'categoryid' => $this->category->id, ]))->out(false), ]; return $return; } public static function define_properties() { return [ 'id' => [ 'type' => PARAM_INT, ], 'name' => [ 'type' => PARAM_TEXT, 'default' => '', ], 'idnumber' => [ 'type' => PARAM_RAW, 'null' => NULL_ALLOWED, ], 'description' => [ 'type' => PARAM_RAW, 'optional' => true, ], 'parent' => [ 'type' => PARAM_INT, ], 'coursecount' => [ 'type' => PARAM_INT, 'default' => 0, ], 'visible' => [ 'type' => PARAM_INT, 'default' => 1, ], 'timemodified' => [ 'type' => PARAM_INT, 'default' => 0, ], 'depth' => [ 'type' => PARAM_INT, 'default' => 0, ], ]; } /** * Get the formatting parameters for the summary. * * @return array */ protected function get_format_parameters_for_description() { return [ 'component' => 'coursecat', 'filearea' => 'description', ]; } }