Your IP : 18.119.116.77


Current Path : /home/ncdcgo/ele.ncdc.go.ug/customfield/classes/
Upload File :
Current File : /home/ncdcgo/ele.ncdc.go.ug/customfield/classes/category_controller.php

<?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/>.

/**
 * Customfield catecory controller class
 *
 * @package   core_customfield
 * @copyright 2018 Toni Barbera <toni@moodle.com>
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

namespace core_customfield;

defined('MOODLE_INTERNAL') || die;

/**
 * Class category
 *
 * @package core_customfield
 * @copyright 2018 Toni Barbera <toni@moodle.com>
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class category_controller {

    /**
     * Category persistent
     *
     * @var category
     */
    protected $category;

    /**
     * @var field_controller[]
     */
    protected $fields = [];

    /** @var handler */
    protected $handler;

    /**
     * category constructor.
     *
     * This class is not abstract, however the constructor was made protected to be consistent with
     * field_controller and data_controller
     *
     * @param int $id
     * @param \stdClass|null $record
     */
    protected function __construct(int $id = 0, \stdClass $record = null) {
        $this->category = new category($id, $record);
    }

    /**
     * Creates an instance of category_controller
     *
     * Either $id or $record or $handler need to be specified
     * If handler is known pass it to constructor to avoid retrieving it later
     * Component, area and itemid must not conflict with the ones in handler
     *
     * @param int $id
     * @param \stdClass|null $record
     * @param handler|null $handler
     * @return category_controller
     * @throws \moodle_exception
     * @throws \coding_exception
     */
    public static function create(int $id, \stdClass $record = null, handler $handler = null) : category_controller {
        global $DB;
        if ($id && $record) {
            // This warning really should be in persistent as well.
            debugging('Too many parameters, either id need to be specified or a record, but not both.',
                DEBUG_DEVELOPER);
        }
        if ($id) {
            if (!$record = $DB->get_record(category::TABLE, array('id' => $id), '*', IGNORE_MISSING)) {
                throw new \moodle_exception('categorynotfound', 'core_customfield');
            }
        }
        if (empty($record->component)) {
            if (!$handler) {
                throw new \coding_exception('Not enough parameters to initialise category_controller - unknown component');
            }
            $record->component = $handler->get_component();
        }
        if (empty($record->area)) {
            if (!$handler) {
                throw new \coding_exception('Not enough parameters to initialise category_controller - unknown area');
            }
            $record->area = $handler->get_area();
        }
        if (!isset($record->itemid)) {
            if (!$handler) {
                throw new \coding_exception('Not enough parameters to initialise category_controller - unknown itemid');
            }
            $record->itemid = $handler->get_itemid();
        }
        $category = new self(0, $record);
        if (!$category->get('contextid')) {
            // If contextid was not present in the record we can find it out from the handler.
            $handlernew = $handler ?? $category->get_handler();
            $category->set('contextid', $handlernew->get_configuration_context()->id);
        }
        if ($handler) {
            $category->set_handler($handler);
        }
        return $category;
    }

    /**
     * Persistent getter parser.
     *
     * @param string $property
     * @return mixed
     */
    final public function get($property) {
        return $this->category->get($property);
    }

    /**
     * Persistent setter parser.
     *
     * @param string $property
     * @param mixed $value
     */
    final public function set($property, $value) {
        return $this->category->set($property, $value);
    }

    /**
     * Persistent delete parser.
     *
     * @return bool
     */
    final public function delete() {
        return $this->category->delete();
    }

    /**
     * Persistent save parser.
     *
     * @return void
     */
    final public function save() {
        $this->category->save();
    }

    /**
     * Return an array of field objects associated with this category.
     *
     * @return field_controller[]
     */
    public function get_fields() {
        return $this->fields;
    }

    /**
     * Adds a child field
     *
     * @param field_controller $field
     */
    public function add_field(field_controller $field) {
        $this->fields[$field->get('id')] = $field;
    }

    /**
     * Gets a handler, if not known retrieve it
     *
     * @return handler
     */
    public function get_handler() : handler {
        if ($this->handler === null) {
            $this->handler = handler::get_handler($this->get('component'), $this->get('area'), $this->get('itemid'));
        }
        return $this->handler;
    }

    /**
     * Allows to set handler so we don't need to retrieve it later
     *
     * @param handler $handler
     * @throws \coding_exception
     */
    public function set_handler(handler $handler) {
        // Make sure there are no conflicts.
        if ($this->get('component') !== $handler->get_component()) {
            throw new \coding_exception('Component of the handler does not match the one from the record');
        }
        if ($this->get('area') !== $handler->get_area()) {
            throw new \coding_exception('Area of the handler does not match the one from the record');
        }
        if ($this->get('itemid') != $handler->get_itemid()) {
            throw new \coding_exception('Itemid of the handler does not match the one from the record');
        }
        if ($this->get('contextid') != $handler->get_configuration_context()->id) {
            throw new \coding_exception('Context of the handler does not match the one from the record');
        }
        $this->handler = $handler;
    }

    /**
     * Persistent to_record parser.
     *
     * @return \stdClass
     */
    final public function to_record() {
        return $this->category->to_record();
    }

    /**
     * Returns the category name formatted according to configuration context.
     *
     * @return string
     */
    public function get_formatted_name() : string {
        $context = $this->get_handler()->get_configuration_context();
        return format_string($this->get('name'), true, ['context' => $context]);
    }
}