Sindbad~EG File Manager

Current Path : /var/www/html/ucsuenolar.sumar.com.py/grade/report/user/amd/build/
Upload File :
Current File : /var/www/html/ucsuenolar.sumar.com.py/grade/report/user/amd/build/user.min.js.map

{"version":3,"file":"user.min.js","sources":["../src/user.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 * A widget to search users within the gradebook.\n *\n * @module    gradereport_user/user\n * @copyright 2022 Mathew May <mathew.solutions>\n * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later\n */\n\nimport * as FocusLockManager from 'core/local/aria/focuslock';\nimport Pending from 'core/pending';\nimport * as Templates from 'core/templates';\nimport * as Repository from 'core_grades/searchwidget/repository';\nimport * as WidgetBase from 'core_grades/searchwidget/basewidget';\nimport {get_string as getString} from 'core/str';\nimport Url from 'core/url';\nimport $ from 'jquery';\nimport * as Selectors from 'core_grades/searchwidget/selectors';\n\n/**\n * Our entry point into starting to build the search widget.\n * It'll eventually, based upon the listeners, open the search widget and allow filtering.\n *\n * @method init\n */\nexport const init = () => {\n    const pendingPromise = new Pending();\n    registerListenerEvents();\n    pendingPromise.resolve();\n};\n\n/**\n * Register user search widget related event listeners.\n *\n * @method registerListenerEvents\n */\nconst registerListenerEvents = () => {\n    let {bodyPromiseResolver, bodyPromise} = WidgetBase.promisesAndResolvers();\n    const dropdownMenuContainer = document.querySelector(Selectors.elements.getSearchWidgetDropdownSelector('user'));\n    const menuContainer = document.querySelector(Selectors.elements.getSearchWidgetSelector('user'));\n    const inputElement = menuContainer.querySelector('input[name=\"userid\"]');\n\n    // Handle the 'shown.bs.dropdown' event (Fired when the dropdown menu is fully displayed).\n    $(menuContainer).on('show.bs.dropdown', async(e) => {\n        const courseID = e.relatedTarget.dataset.courseid;\n        const groupId = e.relatedTarget.dataset.groupid;\n        // Display a loading icon in the dropdown menu container until the body promise is resolved.\n        await WidgetBase.showLoader(dropdownMenuContainer);\n\n        // If an error occurs while fetching the data, display the error within the dropdown menu.\n        const data = await Repository.userFetch(courseID, groupId).catch(async(e) => {\n            const errorTemplateData = {\n                'errormessage': e.message\n            };\n            bodyPromiseResolver(\n                await Templates.render('core_grades/searchwidget/error', errorTemplateData)\n            );\n        });\n\n        // Early return if there is no module data.\n        if (data === []) {\n            return;\n        }\n\n        // The HTML for the 'All users' option which will be rendered in the non-searchable content are of the widget.\n        const allUsersOptionName = await getString('allusersnum', 'gradereport_user', data.users.length);\n        const allUsersOption = await Templates.render('gradereport_user/all_users_item', {\n            id: 0,\n            name: allUsersOptionName,\n            url: Url.relativeUrl('/grade/report/user/index.php', {id: courseID, userid: 0}, false),\n        });\n\n        await WidgetBase.init(\n            dropdownMenuContainer,\n            bodyPromise,\n            data.users,\n            searchUsers(),\n            allUsersOption,\n            afterSelect\n        );\n\n        // Resolvers for passed functions in the dropdown menu creation.\n        bodyPromiseResolver(Templates.render(\n            'core_grades/searchwidget/user/usersearch_body', {displayunsearchablecontent: true}\n        ));\n\n        // Lock tab control. It has to be locked because the dropdown's role is dialog.\n        FocusLockManager.trapFocus(dropdownMenuContainer);\n    });\n\n    // Handle the 'hide.bs.dropdown' event (Fired when the dropdown menu is being closed).\n    $(menuContainer).on('hide.bs.dropdown', () => {\n        FocusLockManager.untrapFocus();\n    });\n\n    inputElement.addEventListener('change', e => {\n        const toggle = menuContainer.querySelector('.dropdown-toggle');\n        const courseID = toggle.dataset.courseid;\n        const actionUrl = Url.relativeUrl('/grade/report/user/index.php', {id: courseID, userid: e.target.value}, false);\n        location.href = actionUrl;\n\n        e.stopPropagation();\n    });\n};\n\n/**\n * Define how we want to search and filter users when the user decides to input a search value.\n *\n * @method searchUsers\n * @returns {function(): function(*, *): (*)}\n */\nconst searchUsers = () => {\n    return () => {\n        return (users, searchTerm) => {\n            if (searchTerm === '') {\n                return users;\n            }\n            searchTerm = searchTerm.toLowerCase();\n            const searchResults = [];\n            users.forEach((user) => {\n                const userName = user.fullname.toLowerCase();\n                if (userName.includes(searchTerm)) {\n                    searchResults.push(user);\n                }\n            });\n            return searchResults;\n        };\n    };\n};\n\n/**\n * Define the action to be performed when an item is selected by the search widget.\n *\n * @param {String} selected The selected item's value.\n */\nconst afterSelect = (selected) => {\n    const menuContainer = document.querySelector(Selectors.elements.getSearchWidgetSelector('user'));\n    const inputElement = menuContainer.querySelector('input[name=\"userid\"]');\n\n    $(menuContainer).dropdown('hide'); // Otherwise the dropdown stays open when user choose an option using keyboard.\n\n    if (inputElement.value != selected) {\n        inputElement.value = selected;\n        inputElement.dispatchEvent(new Event('change', {bubbles: true}));\n    }\n};\n"],"names":["pendingPromise","Pending","registerListenerEvents","resolve","bodyPromiseResolver","bodyPromise","WidgetBase","promisesAndResolvers","dropdownMenuContainer","document","querySelector","Selectors","elements","getSearchWidgetDropdownSelector","menuContainer","getSearchWidgetSelector","inputElement","on","async","courseID","e","relatedTarget","dataset","courseid","groupId","groupid","showLoader","data","Repository","userFetch","catch","errorTemplateData","message","Templates","render","allUsersOptionName","users","length","allUsersOption","id","name","url","Url","relativeUrl","userid","init","searchUsers","afterSelect","displayunsearchablecontent","FocusLockManager","trapFocus","untrapFocus","addEventListener","actionUrl","target","value","location","href","stopPropagation","searchTerm","toLowerCase","searchResults","forEach","user","fullname","includes","push","selected","dropdown","dispatchEvent","Event","bubbles"],"mappings":";;;;;;;ucAuCoB,WACVA,eAAiB,IAAIC,iBAC3BC,yBACAF,eAAeG,iBAQbD,uBAAyB,SACvBE,oBAACA,oBAADC,YAAsBA,aAAeC,WAAWC,6BAC9CC,sBAAwBC,SAASC,cAAcC,UAAUC,SAASC,gCAAgC,SAClGC,cAAgBL,SAASC,cAAcC,UAAUC,SAASG,wBAAwB,SAClFC,aAAeF,cAAcJ,cAAc,4CAG/CI,eAAeG,GAAG,oBAAoBC,MAAAA,UAC9BC,SAAWC,EAAEC,cAAcC,QAAQC,SACnCC,QAAUJ,EAAEC,cAAcC,QAAQG,cAElCnB,WAAWoB,WAAWlB,6BAGtBmB,WAAaC,WAAWC,UAAUV,SAAUK,SAASM,OAAMZ,MAAAA,UACvDa,kBAAoB,cACNX,EAAEY,SAEtB5B,0BACU6B,UAAUC,OAAO,iCAAkCH,0BAK7DJ,OAAS,gBAKPQ,yBAA2B,mBAAU,cAAe,mBAAoBR,KAAKS,MAAMC,QACnFC,qBAAuBL,UAAUC,OAAO,kCAAmC,CAC7EK,GAAI,EACJC,KAAML,mBACNM,IAAKC,aAAIC,YAAY,+BAAgC,CAACJ,GAAIpB,SAAUyB,OAAQ,IAAI,WAG9EtC,WAAWuC,KACbrC,sBACAH,YACAsB,KAAKS,MACLU,cACAR,eACAS,aAIJ3C,oBAAoB6B,UAAUC,OAC1B,gDAAiD,CAACc,4BAA4B,KAIlFC,iBAAiBC,UAAU1C,8CAI7BM,eAAeG,GAAG,oBAAoB,KACpCgC,iBAAiBE,iBAGrBnC,aAAaoC,iBAAiB,UAAUhC,UAE9BD,SADSL,cAAcJ,cAAc,oBACnBY,QAAQC,SAC1B8B,UAAYX,aAAIC,YAAY,+BAAgC,CAACJ,GAAIpB,SAAUyB,OAAQxB,EAAEkC,OAAOC,QAAQ,GAC1GC,SAASC,KAAOJ,UAEhBjC,EAAEsC,sBAUJZ,YAAc,IACT,IACI,CAACV,MAAOuB,iBACQ,KAAfA,kBACOvB,MAEXuB,WAAaA,WAAWC,oBAClBC,cAAgB,UACtBzB,MAAM0B,SAASC,OACMA,KAAKC,SAASJ,cAClBK,SAASN,aAClBE,cAAcK,KAAKH,SAGpBF,eAUbd,YAAeoB,iBACXrD,cAAgBL,SAASC,cAAcC,UAAUC,SAASG,wBAAwB,SAClFC,aAAeF,cAAcJ,cAAc,4CAE/CI,eAAesD,SAAS,QAEtBpD,aAAauC,OAASY,WACtBnD,aAAauC,MAAQY,SACrBnD,aAAaqD,cAAc,IAAIC,MAAM,SAAU,CAACC,SAAS"}

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