. /** * Contains the class for the My overview block. * * @package block_myoverview * @copyright Mark Nelson * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ defined('MOODLE_INTERNAL') || die(); /** * My overview block class. * * @package block_myoverview * @copyright Mark Nelson * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class block_myoverview extends block_base { /** * Init. */ public function init() { $this->title = get_string('pluginname', 'block_myoverview'); } /** * Returns the contents. * * @return stdClass contents of block */ public function get_content() { if (isset($this->content)) { return $this->content; } // Check if the tab to select wasn't passed in the URL, if so see if the user has any preference. if (!$tab = optional_param('myoverviewtab', null, PARAM_ALPHA)) { // Check if the user has no preference, if so get the site setting. if (!$tab = get_user_preferences('block_myoverview_last_tab')) { $config = get_config('block_myoverview'); $tab = $config->defaulttab; } } $renderable = new \block_myoverview\output\main($tab); $renderer = $this->page->get_renderer('block_myoverview'); $this->content = new stdClass(); $this->content->text = $renderer->render($renderable); $this->content->footer = ''; return $this->content; } /** * Locations where block can be displayed. * * @return array */ public function applicable_formats() { return array('my' => true); } /** * This block does contain a configuration settings. * * @return boolean */ public function has_config() { return true; } }