Sindbad~EG File Manager
<?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/>.
/**
* Grid Format.
*
* @package format_grid
* @copyright © 2022 G J Barnard in respect to modifications of standard topics format.
* @author G J Barnard - {@link https://about.me/gjbarnard} and
* {@link https://moodle.org/user/profile.php?id=442195}
* @license https://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
namespace format_grid;
/**
* Setting that displays markdown files. Based on admin_setting_description in adminlib.php.
*
* @copyright © 2022-onwards G J Barnard.
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later.
*/
class admin_setting_markdown extends \admin_setting {
/** @var string Filename */
private $filename;
/**
* Not a setting, just markup.
*
* @param string $name Setting name.
* @param string $visiblename Setting name on the device.
* @param string $description Setting description on the device.
* @param string $filename The file to show.
*/
public function __construct($name, $visiblename, $description, $filename) {
$this->nosave = true;
$this->filename = $filename;
parent::__construct($name, $visiblename, $description, '');
}
/**
* Always returns true.
*
* @return bool Always returns true.
*/
public function get_setting() {
return true;
}
/**
* Always returns true.
*
* @return bool Always returns true.
*/
public function get_defaultsetting() {
return true;
}
/**
* Never write settings
*
* @param mixed $data Gets converted to str for comparison against yes value.
* @return string Always returns an empty string.
*/
public function write_setting($data) {
// Do not write any setting.
return '';
}
/**
* Returns an HTML string
*
* @param string $data
* @param string $query
* @return string Returns an HTML string
*/
public function output_html($data, $query='') {
global $CFG, $OUTPUT;
$context = new \stdClass();
$context->title = $this->visiblename;
$context->description = $this->description;
if (file_exists("{$CFG->dirroot}/course/format/grid/{$this->filename}")) {
$filecontents = file_get_contents($CFG->dirroot.'/course/format/grid/'.$this->filename);
} else {
$filecontents = 'Grid format admin_setting_markdown -> file not found: '.$this->filename;
}
$context->markdown = format_text($filecontents, FORMAT_MARKDOWN);
return $OUTPUT->render_from_template('format_grid/grid_admin_setting_markdown', $context);
}
}
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists