2023-08-25 22:46:27 +02:00
|
|
|
#!/usr/bin/env node
|
|
|
|
|
|
|
|
// This file is part of the Studyplan plugin for Moodle
|
|
|
|
//
|
|
|
|
// 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 <https://www.gnu.org/licenses/>.
|
|
|
|
/**
|
|
|
|
* This file compiles the scss files in the scss/ folder into either the main
|
|
|
|
* styles.css for production upon build or css/devstyles.css for development
|
2023-08-25 22:59:49 +02:00
|
|
|
*
|
|
|
|
* Most nice would be to integrate this action with grunt watch, but I am
|
|
|
|
* not familiar enough with grunt to know if I can extend moodle's grunt actions
|
|
|
|
* from a Gruntfile.js in this directory without modifying Moodle's Gruntfile.js
|
2023-08-25 22:46:27 +02:00
|
|
|
*
|
|
|
|
* @package local_treestudyplan
|
|
|
|
* @copyright 2023 P.M. Kuipers
|
|
|
|
* @license https://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*/
|
|
|
|
|
2023-08-25 22:59:49 +02:00
|
|
|
const sass = require('sass');
|
|
|
|
const path = require('path');
|
|
|
|
const fs = require('fs');
|
2023-08-25 22:46:27 +02:00
|
|
|
|
2023-08-25 22:59:49 +02:00
|
|
|
const output = 'css/devstyles.css';
|
|
|
|
|
|
|
|
let css = "";
|
|
|
|
let map = "";
|
|
|
|
//joining path of directory
|
|
|
|
const directoryPath = path.join(__dirname, 'scss');
|
|
|
|
//passsing directoryPath and callback function
|
|
|
|
fs.readdir(directoryPath, function (err, files) {
|
|
|
|
//handling error
|
|
|
|
if (err) {
|
|
|
|
return console.log('Unable to scan directory: ' + err);
|
|
|
|
}
|
|
|
|
//listing all files using forEach
|
|
|
|
files.forEach(function (file) {
|
2023-08-25 23:05:17 +02:00
|
|
|
const result = sass.compile(file);
|
2023-08-25 22:59:49 +02:00
|
|
|
console.info(`Processing ${file}...`)
|
|
|
|
if ( result ) {
|
2023-08-25 23:05:17 +02:00
|
|
|
css = css + `/**** ${file} ****/\n` + result.css + "\n";
|
2023-08-25 22:59:49 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2023-08-25 23:05:17 +02:00
|
|
|
console.info(`Storing ${output}`);
|
|
|
|
fs.writeFile(path.join(__dirname, output),css,(err) => {
|
|
|
|
if (err) throw err;
|
|
|
|
});
|
|
|
|
|
2023-08-25 22:46:27 +02:00
|
|
|
});
|
|
|
|
|