Sindbad~EG File Manager

Current Path : /var/www/html/atlasseguros.sumar.com.py/course/format/grid/amd/build/local/
Upload File :
Current File : /var/www/html/atlasseguros.sumar.com.py/course/format/grid/amd/build/local/content.min.js.map

{"version":3,"file":"content.min.js","sources":["../../src/local/content.js"],"sourcesContent":["// This file is part of Moodle - http://moodle.org/\n//\n// Moodle is free software: you can redistribute it and/or modify\n// it under the terms of the GNU General Public License as published by\n// the Free Software Foundation, either version 3 of the License, or\n// (at your option) any later version.\n//\n// Moodle is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU General Public License for more details.\n//\n// You should have received a copy of the GNU General Public License\n// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.\n\n/**\n * Grid format Course index main component.\n *\n * @module     format_grid/local/content\n * @class      format_grid/local/content\n * @copyright  2023 G J Barnard based upon work done by:\n * @copyright  2020 Ferran Recio <ferran@moodle.com>\n * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later\n */\n\nimport BaseComponent from 'core_courseformat/local/content';\nimport {getCurrentCourseEditor} from 'core_courseformat/courseeditor';\nimport inplaceeditable from 'core/inplace_editable';\nimport Section from 'core_courseformat/local/content/section';\nimport CmItem from 'core_courseformat/local/content/section/cmitem';\n// Course actions is needed for actions that are not migrated to components.\nimport courseActions from 'core_course/actions';\nimport DispatchActions from 'core_courseformat/local/content/actions';\nimport * as CourseEvents from 'core_course/events';\n\nexport default class Component extends BaseComponent {\n\n    /**\n     * Constructor hook.\n     *\n     * @param {Object} descriptor the component descriptor\n     */\n    create(descriptor) {\n        // Optional component name for debugging.\n        this.name = 'grid_course_format';\n        // Default query selectors.\n        this.selectors = {\n            SECTION: `[data-for='section']`,\n            SECTION_ITEM: `[data-for='section_title']`,\n            SECTION_CMLIST: `[data-for='cmlist']`,\n            COURSE_SECTIONLIST: `[data-for='course_sectionlist']`,\n            CM: `[data-for='cmitem']`,\n            PAGE: `#page`,\n            // Formats can override the activity tag but a default one is needed to create new elements.\n            ACTIVITYTAG: 'li',\n            SECTIONTAG: 'li',\n        };\n        // Default classes to toggle on refresh.\n        this.classes = {\n            //COLLAPSED: `collapsed`,\n            // Course content classes.\n            ACTIVITY: `activity`,\n            STATEDREADY: `stateready`,\n            SECTION: `section`,\n        };\n        // Array to save dettached elements during element resorting.\n        this.dettachedCms = {};\n        this.dettachedSections = {};\n        // Index of sections and cms components.\n        this.sections = {};\n        this.cms = {};\n        // The page section return.\n        this.sectionReturn = descriptor.sectionReturn ?? 0;\n    }\n\n    /**\n     * Static method to create a component instance form the mustahce template.\n     *\n     * @param {string} target the DOM main element or its ID\n     * @param {object} selectors optional css selector overrides\n     * @param {number} sectionReturn the content section return\n     * @return {Component}\n     */\n    static init(target, selectors, sectionReturn) {\n        return new Component({\n            element: document.getElementById(target),\n            reactive: getCurrentCourseEditor(),\n            selectors,\n            sectionReturn,\n        });\n    }\n\n    /**\n     * Initial state ready method.\n     */\n    stateReady(/*state*/) {\n        this._indexContents();\n\n        if (this.reactive.supportComponents) {\n            // Actions are only available in edit mode.\n            if (this.reactive.isEditing) {\n                new DispatchActions(this);\n            }\n\n            // Mark content as state ready.\n            this.element.classList.add(this.classes.STATEDREADY);\n        }\n\n        // Capture completion events.\n        this.addEventListener(\n            this.element,\n            CourseEvents.manualCompletionToggled,\n            this._completionHandler\n        );\n\n        // Capture page scroll to update page item.\n        this.addEventListener(\n            document.querySelector(this.selectors.PAGE),\n            \"scroll\",\n            this._scrollHandler\n        );\n    }\n\n    /**\n     * Return the component watchers.\n     *\n     * @returns {Array} of watchers\n     */\n    getWatchers() {\n        // Section return is a global page variable but most formats define it just before start printing\n        // the course content. This is the reason why we define this page setting here.\n        this.reactive.sectionReturn = this.sectionReturn;\n\n        // Check if the course format is compatible with reactive components.\n        if (!this.reactive.supportComponents) {\n            return [];\n        }\n        return [\n            // State changes that require to reload some course modules.\n            {watch: `cm.visible:updated`, handler: this._reloadCm},\n            {watch: `cm.stealth:updated`, handler: this._reloadCm},\n            // Update section number and title.\n            {watch: `section.number:updated`, handler: this._refreshSectionNumber},\n            // Sections and cm sorting.\n            {watch: `transaction:start`, handler: this._startProcessing},\n            {watch: `course.sectionlist:updated`, handler: this._refreshCourseSectionlist},\n            {watch: `section.cmlist:updated`, handler: this._refreshSectionCmlist},\n            // Reindex sections and cms.\n            {watch: `state:updated`, handler: this._indexContents},\n            // State changes thaty require to reload course modules.\n            {watch: `cm.visible:updated`, handler: this._reloadCm},\n            {watch: `cm.sectionid:updated`, handler: this._reloadCm},\n        ];\n    }\n\n    /**\n     * Setup the component to start a transaction.\n     *\n     * Some of the course actions replaces the current DOM element with a new one before updating the\n     * course state. This means the component cannot preload any index properly until the transaction starts.\n     *\n     */\n    _startProcessing() {\n        // During a section or cm sorting, some elements could be dettached from the DOM and we\n        // need to store somewhare in case they are needed later.\n        this.dettachedCms = {};\n        this.dettachedSections = {};\n    }\n\n    /**\n     * Activity manual completion listener.\n     *\n     * @param {Event} event the custom ecent\n     */\n    _completionHandler({detail}) {\n        if (detail === undefined) {\n            return;\n        }\n        this.reactive.dispatch('cmCompletion', [detail.cmid], detail.completed);\n    }\n\n    /**\n     * Check the current page scroll and update the active element if necessary.\n     */\n    _scrollHandler() {\n        const pageOffset = document.querySelector(this.selectors.PAGE).scrollTop;\n        const items = this.reactive.getExporter().allItemsArray(this.reactive.state);\n        // Check what is the active element now.\n        let pageItem = null;\n        items.every(item => {\n            const index = (item.type === 'section') ? this.sections : this.cms;\n            if (index[item.id] === undefined) {\n                return true;\n            }\n\n            const element = index[item.id].element;\n            // Activities without url can only be page items in edit mode.\n            if (item.type === 'cm' && !item.url && !this.reactive.isEditing) {\n                return pageOffset >= element.offsetTop;\n            }\n            pageItem = item;\n            return pageOffset >= element.offsetTop;\n        });\n        if (pageItem) {\n            this.reactive.dispatch('setPageItem', pageItem.type, pageItem.id);\n        }\n    }\n\n    /**\n     * Update a course section when the section number changes.\n     *\n     * The courseActions module used for most course section tools still depends on css classes and\n     * section numbers (not id). To prevent inconsistencies when a section is moved, we need to refresh\n     * the\n     *\n     * Course formats can override the section title rendering so the frontend depends heavily on backend\n     * rendering. Luckily in edit mode we can trigger a title update using the inplace_editable module.\n     *\n     * @param {Object} param\n     * @param {Object} param.element details the update details.\n     */\n    _refreshSectionNumber({element}) {\n        // Find the element.\n        const target = this.getElement(this.selectors.SECTION, element.id);\n        if (!target) {\n            // Job done. Nothing to refresh.\n            return;\n        }\n        // Update section numbers in all data, css and YUI attributes.\n        target.id = `section-${element.number}`;\n        // YUI uses section number as section id in data-sectionid, in principle if a format use components\n        // don't need this sectionid attribute anymore, but we keep the compatibility in case some plugin\n        // use it for legacy purposes.\n        target.dataset.sectionid = element.number;\n        // The data-number is the attribute used by components to store the section number.\n        target.dataset.number = element.number;\n\n        // Update title and title inplace editable, if any.\n        const inplace = inplaceeditable.getInplaceEditable(target.querySelector(this.selectors.SECTION_ITEM));\n        if (inplace) {\n            // The course content HTML can be modified at any moment, so the function need to do some checkings\n            // to make sure the inplace editable still represents the same itemid.\n            const currentvalue = inplace.getValue();\n            const currentitemid = inplace.getItemId();\n            // Unnamed sections must be recalculated.\n            if (inplace.getValue() === '') {\n                // The value to send can be an empty value if it is a default name.\n                if (currentitemid == element.id && (currentvalue != element.rawtitle || element.rawtitle == '')) {\n                    inplace.setValue(element.rawtitle);\n                }\n            }\n        }\n    }\n\n    /**\n     * Refresh a section cm list.\n     *\n     * @param {Object} param\n     * @param {Object} param.element details the update details.\n     */\n    _refreshSectionCmlist({element}) {\n        const cmlist = element.cmlist ?? [];\n        const section = this.getElement(this.selectors.SECTION, element.id);\n        const listparent = section?.querySelector(this.selectors.SECTION_CMLIST);\n        // A method to create a fake element to be replaced when the item is ready.\n        const createCm = this._createCmItem.bind(this);\n        if (listparent) {\n            this._fixOrder(listparent, cmlist, this.selectors.CM, this.dettachedCms, createCm);\n        }\n    }\n\n    /**\n     * Refresh the section list.\n     *\n     * @param {Object} param\n     * @param {Object} param.element details the update details.\n     */\n    _refreshCourseSectionlist({element}) {\n        // If we have a section return means we only show a single section so no need to fix order.\n        if (this.reactive.sectionReturn != 0) {\n            return;\n        }\n        const sectionlist = element.sectionlist ?? [];\n        const listparent = this.getElement(this.selectors.COURSE_SECTIONLIST);\n        // For now section cannot be created at a frontend level.\n        const createSection = this._createSectionItem.bind(this);\n        if (listparent) {\n            this._fixOrder(listparent, sectionlist, this.selectors.SECTION, this.dettachedSections, createSection);\n        }\n    }\n\n    /**\n     * Regenerate content indexes.\n     *\n     * This method is used when a legacy action refresh some content element.\n     */\n    _indexContents() {\n        // Find unindexed sections.\n        this._scanIndex(\n            this.selectors.SECTION,\n            this.sections,\n            (item) => {\n                return new Section(item);\n            }\n        );\n\n        // Find unindexed cms.\n        this._scanIndex(\n            this.selectors.CM,\n            this.cms,\n            (item) => {\n                return new CmItem(item);\n            }\n        );\n    }\n\n    /**\n     * Reindex a content (section or cm) of the course content.\n     *\n     * This method is used internally by _indexContents.\n     *\n     * @param {string} selector the DOM selector to scan\n     * @param {*} index the index attribute to update\n     * @param {*} creationhandler method to create a new indexed element\n     */\n    _scanIndex(selector, index, creationhandler) {\n        const items = this.getElements(`${selector}:not([data-indexed])`);\n        items.forEach((item) => {\n            if (!item?.dataset?.id) {\n                return;\n            }\n            // Delete previous item component.\n            if (index[item.dataset.id] !== undefined) {\n                index[item.dataset.id].unregister();\n            }\n            // Create the new component.\n            index[item.dataset.id] = creationhandler({\n                ...this,\n                element: item,\n            });\n            // Mark as indexed.\n            item.dataset.indexed = true;\n        });\n    }\n\n    /**\n     * Reload a course module contents.\n     *\n     * Most course module HTML is still strongly backend dependant.\n     * Some changes require to get a new version of the module.\n     *\n     * @param {object} param0 the watcher details\n     * @param {object} param0.element the state object\n     */\n    _reloadCm({element}) {\n        const cmitem = this.getElement(this.selectors.CM, element.id);\n        if (cmitem) {\n            const promise = courseActions.refreshModule(cmitem, element.id);\n            promise.then(() => {\n                this._indexContents();\n                return;\n            }).catch();\n        }\n    }\n\n    /**\n     * Reload a course section contents.\n     *\n     * Section HTML is still strongly backend dependant.\n     * Some changes require to get a new version of the section.\n     *\n     * @param {details} param0 the watcher details\n     * @param {object} param0.element the state object\n     */\n    _reloadSection({element}) {\n        const sectionitem = this.getElement(this.selectors.SECTION, element.id);\n        if (sectionitem) {\n            const promise = courseActions.refreshSection(sectionitem, element.id);\n            promise.then(() => {\n                this._indexContents();\n                return;\n            }).catch();\n        }\n    }\n\n    /**\n     * Create a new course module item in a section.\n     *\n     * Thos method will append a fake item in the container and trigger an ajax request to\n     * replace the fake element by the real content.\n     *\n     * @param {Element} container the container element (section)\n     * @param {Number} cmid the course-module ID\n     * @returns {Element} the created element\n     */\n    _createCmItem(container, cmid) {\n        const newItem = document.createElement(this.selectors.ACTIVITYTAG);\n        newItem.dataset.for = 'cmitem';\n        newItem.dataset.id = cmid;\n        // The legacy actions.js requires a specific ID and class to refresh the CM.\n        newItem.id = `module-${cmid}`;\n        newItem.classList.add(this.classes.ACTIVITY);\n        container.append(newItem);\n        this._reloadCm({\n            element: this.reactive.get('cm', cmid),\n        });\n        return newItem;\n    }\n\n    /**\n     * Create a new section item.\n     *\n     * This method will append a fake item in the container and trigger an ajax request to\n     * replace the fake element by the real content.\n     *\n     * @param {Element} container the container element (section)\n     * @param {Number} sectionid the course-module ID\n     * @returns {Element} the created element\n     */\n    _createSectionItem(container, sectionid) {\n        const section = this.reactive.get('section', sectionid);\n        const newItem = document.createElement(this.selectors.SECTIONTAG);\n        newItem.dataset.for = 'section';\n        newItem.dataset.id = sectionid;\n        newItem.dataset.number = section.number;\n        // The legacy actions.js requires a specific ID and class to refresh the section.\n        newItem.id = `section-${sectionid}`;\n        newItem.classList.add(this.classes.SECTION);\n        container.append(newItem);\n        this._reloadSection({\n            element: section,\n        });\n        return newItem;\n    }\n\n    /**\n     * Fix/reorder the section or cms order.\n     *\n     * @param {Element} container the HTML element to reorder.\n     * @param {Array} neworder an array with the ids order\n     * @param {string} selector the element selector\n     * @param {Object} dettachedelements a list of dettached elements\n     * @param {function} createMethod method to create missing elements\n     */\n    async _fixOrder(container, neworder, selector, dettachedelements, createMethod) {\n        if (container === undefined) {\n            return;\n        }\n\n        // Empty lists should not be visible.\n        if (!neworder.length) {\n            container.classList.add('hidden');\n            container.innerHTML = '';\n            return;\n        }\n\n        // Grant the list is visible (in case it was empty).\n        container.classList.remove('hidden');\n\n        // Move the elements in order at the beginning of the list.\n        neworder.forEach((itemid, index) => {\n            let item = this.getElement(selector, itemid) ?? dettachedelements[itemid] ?? createMethod(container, itemid);\n            if (item === undefined) {\n                // Missing elements cannot be sorted.\n                return;\n            }\n            // Get the current elemnt at that position.\n            const currentitem = container.children[index];\n            if (currentitem === undefined) {\n                container.append(item);\n                return;\n            }\n            if (currentitem !== item) {\n                container.insertBefore(item, currentitem);\n            }\n        });\n\n        // Dndupload add a fake element we need to keep.\n        let dndFakeActivity;\n\n        // Remove the remaining elements.\n        while (container.children.length > neworder.length) {\n            const lastchild = container.lastChild;\n            if (lastchild?.classList?.contains('dndupload-preview')) {\n                dndFakeActivity = lastchild;\n            } else {\n                dettachedelements[lastchild?.dataset?.id ?? 0] = lastchild;\n            }\n            container.removeChild(lastchild);\n        }\n        // Restore dndupload fake element.\n        if (dndFakeActivity) {\n            container.append(dndFakeActivity);\n        }\n    }\n}\n"],"names":["Component","BaseComponent","create","descriptor","name","selectors","SECTION","SECTION_ITEM","SECTION_CMLIST","COURSE_SECTIONLIST","CM","PAGE","ACTIVITYTAG","SECTIONTAG","classes","ACTIVITY","STATEDREADY","dettachedCms","dettachedSections","sections","cms","sectionReturn","target","element","document","getElementById","reactive","stateReady","_indexContents","this","supportComponents","isEditing","DispatchActions","classList","add","addEventListener","CourseEvents","manualCompletionToggled","_completionHandler","querySelector","_scrollHandler","getWatchers","watch","handler","_reloadCm","_refreshSectionNumber","_startProcessing","_refreshCourseSectionlist","_refreshSectionCmlist","detail","undefined","dispatch","cmid","completed","pageOffset","scrollTop","items","getExporter","allItemsArray","state","pageItem","every","item","index","type","id","url","offsetTop","getElement","number","dataset","sectionid","inplace","inplaceeditable","getInplaceEditable","currentvalue","getValue","currentitemid","getItemId","rawtitle","setValue","cmlist","section","listparent","createCm","_createCmItem","bind","_fixOrder","sectionlist","createSection","_createSectionItem","_scanIndex","Section","CmItem","selector","creationhandler","getElements","forEach","_item$dataset","unregister","indexed","cmitem","courseActions","refreshModule","then","catch","_reloadSection","sectionitem","refreshSection","container","newItem","createElement","for","append","get","neworder","dettachedelements","createMethod","length","innerHTML","dndFakeActivity","remove","itemid","currentitem","children","insertBefore","lastchild","lastChild","_lastchild$classList","contains","_lastchild$dataset","removeChild"],"mappings":"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"}

Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists