{"version":3,"file":"placeholder.min.js","sources":["https:\/\/e-learning.signwise.ch\/course\/format\/flextiles\/amd\/src\/local\/courseindex\/placeholder.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 .\n\nimport Templates from 'core\/templates';\nimport {getCurrentCourseEditor} from 'core_courseformat\/courseeditor';\nimport BasePlaceholder from 'core_courseformat\/local\/courseindex\/placeholder';\nimport Exporter from \"format_flextiles\/local\/courseeditor\/exporter\";\n\n\/**\n * Course index placeholder replacer.\n *\n * @module format_flextiles\/local\/courseindex\/placeholder\n * @copyright 2022 Marina Glancy\n * @license http:\/\/www.gnu.org\/copyleft\/gpl.html GNU GPL v3 or later\n *\/\nexport default class Component extends BasePlaceholder {\n \/\/ Extends course\/format\/amd\/src\/local\/courseindex\/placeholder.js\n\n \/**\n * Static method to create a component instance form the mustache template.\n *\n * @param {element|string} target the DOM main element or its ID\n * @param {object} selectors optional css selector overrides\n * @return {Component}\n *\/\n static init(target, selectors) {\n const courseEditor = getCurrentCourseEditor();\n courseEditor.getExporter = () => new Exporter(courseEditor);\n return new Component({\n element: document.getElementById(target),\n reactive: courseEditor,\n selectors,\n });\n }\n\n \/**\n * Load the course index template.\n *\n * @param {Object} state the initial state\n *\/\n async loadTemplateContent(state) {\n \/\/ Collect section information from the state.\n const exporter = this.reactive.getExporter();\n const data = exporter.course(state);\n try {\n \/\/ To render an HTML into our component we just use the regular Templates module.\n const {html, js} = await Templates.renderForPromise(\n 'format_flextiles\/local\/courseindex\/courseindex',\n data,\n );\n Templates.replaceNode(this.element, html, js);\n this.pendingContent.resolve();\n\n \/\/ Save the rendered template into the session cache.\n this.reactive.setStorageValue(`courseIndex`, {html, js});\n } catch (error) {\n this.pendingContent.resolve(error);\n throw error;\n }\n }\n}\n"],"names":["Component","BasePlaceholder","target","selectors","courseEditor","getExporter","Exporter","element","document","getElementById","reactive","state","data","this","course","html","js","Templates","renderForPromise","replaceNode","pendingContent","resolve","setStorageValue","error"],"mappings":";;;;;;;uOA2BqBA,kBAAkBC,iCAUvBC,OAAQC,iBACVC,cAAe,iDACrBA,aAAaC,YAAc,IAAM,IAAIC,kBAASF,cACvC,IAAIJ,UAAU,CACjBO,QAASC,SAASC,eAAeP,QACjCQ,SAAUN,aACVD,UAAAA,sCASkBQ,aAGhBC,KADWC,KAAKH,SAASL,cACTS,OAAOH,iBAGnBI,KAACA,KAADC,GAAOA,UAAYC,mBAAUC,iBAC\/B,oDACAN,yBAEMO,YAAYN,KAAKN,QAASQ,KAAMC,SACrCI,eAAeC,eAGfX,SAASY,8BAA+B,CAACP,KAAAA,KAAMC,GAAAA,KACtD,MAAOO,kBACAH,eAAeC,QAAQE,OACtBA"}