X7ROOT File Manager
Current Path:
/home/cbholdings/pasukulu/.grunt/tasks
home
/
cbholdings
/
pasukulu
/
.grunt
/
tasks
/
📁
..
📄
componentlibrary.js
(4.18 KB)
📄
eslint.js
(2.55 KB)
📄
gherkinlint.js
(3.11 KB)
📄
ignorefiles.js
(3.11 KB)
📄
javascript.js
(7.93 KB)
📄
jsconfig.js
(1.86 KB)
📄
jsdoc.js
(1.14 KB)
📄
sass.js
(1.38 KB)
📄
shifter.js
(5.78 KB)
📄
startup.js
(1.61 KB)
📄
style.js
(1.16 KB)
📄
stylelint.js
(6.02 KB)
📄
upgradablelibs.js
(1.6 KB)
📄
watch.js
(10.73 KB)
Editing: componentlibrary.js
// 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/>. /* jshint node: true, browser: false */ /* eslint-env node */ /** * Component Library build tasks. * * @copyright 2021 Andrew Nicols * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ module.exports = grunt => { /** * Get a child path of the component library. * * @param {string} path * @returns {string} */ const getCLPath = path => `admin/tool/componentlibrary/${path}`; /** * Get a spawn handler. * * This is a generic function to write the spawn output, and then to exit if required and mark the async task as * complete. * * @param {Promise} done * @returns {function} */ const getSpawnHandler = done => (error, result, code) => { grunt.log.write(result); if (error) { grunt.log.error(result.stdout); process.exit(code); } done(); }; /** * Spawn a function against Node with the provided args. * * @param {array} args * @returns {object} */ const spawnNodeCall = (args) => grunt.util.spawn({ cmd: 'node', args, }, getSpawnHandler(grunt.task.current.async())); /** * Build the docs using Hugo. * * @returns {Object} Reference to the spawned task */ const docsBuild = () => spawnNodeCall([ 'node_modules/hugo-bin/cli.js', '--config', getCLPath('config.yml'), '--cleanDestinationDir', ]); /** * Build the docs index using the hugo-lunr-indexer. * * @returns {Object} Reference to the spawned task */ const indexBuild = () => spawnNodeCall([ 'node_modules/hugo-lunr-indexer/bin/hli.js', '-i', getCLPath('content/**'), '-o', getCLPath('hugo/site/data/my-index.json'), '-l', 'yaml', '-d', '---', ]); /** * Build the hugo CSS. * * @returns {Object} Reference to the spawned task */ const cssBuild = () => spawnNodeCall([ 'node_modules/sass/sass.js', '--style', 'expanded', '--source-map', '--embed-sources', '--precision', 6, '--load-path', process.cwd(), getCLPath('hugo/scss/docs.scss'), getCLPath('hugo/dist/css/docs.css'), ]); // Register the various component library tasks. grunt.registerTask('componentlibrary:docsBuild', 'Build the component library', docsBuild); grunt.registerTask('componentlibrary:cssBuild', 'Build the component library', cssBuild); grunt.registerTask('componentlibrary:indexBuild', 'Build the component library', indexBuild); grunt.registerTask('componentlibrary', 'Build the component library', [ 'componentlibrary:docsBuild', 'componentlibrary:cssBuild', 'componentlibrary:indexBuild', ]); grunt.config.merge({ watch: { componentLibraryDocs: { files: [ getCLPath('content/**/*.md'), getCLPath('hugo'), ], tasks: ['componentlibrary:docsBuild', 'componentlibrary:indexBuild'], }, componentLibraryCSS: { files: [ getCLPath('hugo/scss/**/*.scss'), 'hugo', ], tasks: ['componentlibrary:cssBuild'], }, }, }); // Add the 'componentlibrary' task as a startup task. grunt.moodleEnv.startupTasks.push('componentlibrary'); return { docsBuild, cssBuild, indexBuild, }; };
Upload File
Create Folder