first commit

This commit is contained in:
CHIEFSOFT\ameye
2024-09-30 18:11:26 -04:00
commit e592ca6823
27270 changed files with 5002257 additions and 0 deletions
@@ -0,0 +1,65 @@
<?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/>.
/**
* Renderer class for tool customlang
*
* @package tool_customlang
* @category output
* @copyright 2019 Bas Brands <bas@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
namespace tool_customlang\output;
defined('MOODLE_INTERNAL') || die();
/**
* Renderer for the customlang tool.
*
* @copyright 2019 Bas Brands <bas@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class renderer extends \plugin_renderer_base {
/**
* Defer to template.
*
* @param tool_customlang_translator $translator
* @return string Html for the translator
*/
protected function render_tool_customlang_translator(\tool_customlang_translator $translator) {
$renderabletranslator = new translator($translator);
$templatevars = $renderabletranslator->export_for_template($this);
return $this->render_from_template('tool_customlang/translator', $templatevars);
}
/**
* Defer to template.
*
* @param tool_customlang_menu $menu
* @return string html the customlang menu buttons
*/
protected function render_tool_customlang_menu(\tool_customlang_menu $menu) {
$output = '';
foreach ($menu->get_items() as $item) {
$button = $this->single_button($item->url, $item->title, $item->method);
$output .= $this->box($button, 'menu');
}
return $output;
}
}
@@ -0,0 +1,93 @@
<?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/>.
/**
* customlang specific renderers.
*
* @package tool_customlang
* @copyright 2019 Moodle
* @author Bas Brands
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
namespace tool_customlang\output;
defined('MOODLE_INTERNAL') || die();
use renderable;
use templatable;
use renderer_base;
use stdClass;
/**
* Class containing data for customlang translator page
*
* @copyright 2019 Bas Brands
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class translator implements renderable, templatable {
/**
* @var tool_customlang_translator $translator object.
*/
private $translator;
/**
* Construct this renderable.
*
* @param tool_customlang_translator $translator The translator object.
*/
public function __construct(\tool_customlang_translator $translator) {
$this->translator = $translator;
}
/**
* Export the data.
*
* @param renderer_base $output
* @return stdClass
*/
public function export_for_template(renderer_base $output) {
$data = new stdClass();
$data->nostrings = $output->notification(get_string('nostringsfound', 'tool_customlang'));
$data->formurl = $this->translator->handler;
$data->currentpage = $this->translator->currentpage;
$data->sesskey = sesskey();
$data->strings = [];
if (!empty($this->translator->strings)) {
$data->hasstrings = true;
foreach ($this->translator->strings as $string) {
// Find strings that use placeholders.
if (preg_match('/\{\$a(->.+)?\}/', $string->master)) {
$string->placeholderhelp = $output->help_icon('placeholder', 'tool_customlang',
get_string('placeholderwarning', 'tool_customlang'));
}
if (!is_null($string->local) and $string->outdated) {
$string->outdatedhelp = $output->help_icon('markinguptodate', 'tool_customlang');
$string->checkupdated = true;
}
if ($string->original !== $string->master) {
$string->showoriginalvsmaster = true;
}
$string->local = s($string->local);
$data->strings[] = $string;
}
}
return $data;
}
}