From b6e84b302642bcfa7ed3c22dff90f9240cf1546e Mon Sep 17 00:00:00 2001 From: Alan Cole Date: Wed, 16 Oct 2024 15:56:36 +1100 Subject: [PATCH 1/7] [CIVIC-1946] Added new build system for starter-kit. --- .../civictheme/civictheme_starter_kit/.nvmrc | 2 +- .../civictheme_starter_kit/build.js | 311 ++++++++++++++++++ .../civictheme_starter_kit/package.json | 2 + 3 files changed, 314 insertions(+), 1 deletion(-) create mode 100644 web/themes/contrib/civictheme/civictheme_starter_kit/build.js diff --git a/web/themes/contrib/civictheme/civictheme_starter_kit/.nvmrc b/web/themes/contrib/civictheme/civictheme_starter_kit/.nvmrc index 2ef3430431..dc5f6a52b1 100644 --- a/web/themes/contrib/civictheme/civictheme_starter_kit/.nvmrc +++ b/web/themes/contrib/civictheme/civictheme_starter_kit/.nvmrc @@ -1 +1 @@ -18.14 +22.6.0 diff --git a/web/themes/contrib/civictheme/civictheme_starter_kit/build.js b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js new file mode 100644 index 0000000000..b23c9fbd28 --- /dev/null +++ b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js @@ -0,0 +1,311 @@ +/* +Civictheme build - version 0.0.1 (alpha). + +This is a simplified build system for civictheme, designed to: + +- Speed up build time +- Improve auditability by reducing dependencies / external code + +Build by calling: + + npm run build:new + +Build and watch by calling: + + npm run build:watch:new + +Notes: + +- Requires Node version 22 (for the built in glob feature). +- No Windows support (unless through WSL). +- This relies on command line rsync. +- This does not support uglify or minifying JS / CSS code. +- Watch does not trigger on a directory change, only on a (scss, twig, js) file change. +*/ + +const fs = require('fs') +const path = require('path') +const { globSync } = require('node:fs') +const { execSync } = require('child_process') +const sass = require('sass') + +// ----------------------------------------------------------------------------- UTILITIES + +function runCommand(command) { + execSync(command, (error, stdout, stderr) => { + if (error) { + console.log(`error: ${error.message}`) + return + } + if (stderr) { + console.log(`stderr: ${stderr}`) + return + } + if (stdout) { + console.log(stdout) + } + }) +} + +function getStyleImport(path, cwd) { + return globSync(path, { cwd }).sort((a, b) => a.localeCompare(b)).map(i => `@import "${i}";`).join('\n') +} + +function getStyleImports(paths, cwd) { + return paths.map(path => getStyleImport(path, cwd)).join('\n') +} + +function loadStyle(path, cwd) { + const result = [] + let data = fs.readFileSync(path, 'utf-8') + + data.split('\n').forEach(line => { + // Only glob imports with *!()| characters. + const match = /@import '(.*[\*!()|].*)'/.exec(line) + result.push(match ? getStyleImport(match[1], cwd) : line) + }) + + return result.join('\n') +} + +function fullPath(filepath) { + return path.resolve(PATH, filepath) +} + +// ----------------------------------------------------------------------------- CONFIGURATION + +const config = { + runBuild: false, + runWatch: false, + combineComponents: false, + compileStyles: false, + compileStylesEditor: false, + compileStylesAdmin: false, + compileStylesLayout: false, + compileStylesVariables: false, + compileJs: false, + compileAssets: false, +} + +const behaviourFlags = ['build', 'watch'] +const flags = process.argv.slice(2) +const buildWatchFlagCount = flags.filter(f => behaviourFlags.indexOf(f) >= 0).length + +if (buildWatchFlagCount <= 2) { + config.runBuild = buildWatchFlagCount === 0 || flags.indexOf('build') >= 0 + config.runWatch = flags.indexOf('watch') >= 0 + config.combineComponents = true + config.compileStyles = true + config.compileStylesEditor = true + config.compileStylesAdmin = false + config.compileStylesLayout = false + config.compileStylesVariables = true + config.compileJs = true + config.compileAssets = true +} else { + // Fully configured - everything disabled by default. + flags.forEach((flag) => { + switch (flag) { + case 'build': + config.runBuild = true + break + case 'watch': + config.runWatch = true + break + case 'combine': + config.combineComponents = true + break + case 'styles': + config.compileStyles = true + break + case 'styles-editor': + config.compileStylesEditor = true + break + case 'styles-admin': + config.compileStylesAdmin = true + break + case 'styles-layout': + config.compileStylesLayout = true + break + case 'styles-variables': + config.compileStylesVariables = true + break + case 'js': + config.compileJs = true + break + case 'assets': + config.compileAssets = true + break + } + }) +} + +// ----------------------------------------------------------------------------- PATHS + +const PATH = __dirname + +const THEME_NAME = PATH.split('/').reverse()[0] +const DIR_CIVICTHEME = fullPath('../../contrib/civictheme/') +const DIR_COMPONENTS_IN = fullPath('./components/') +const DIR_COMPONENTS_OUT = fullPath('./components_combined/') +const DIR_UIKIT_COMPONENTS_IN = `${DIR_CIVICTHEME}/lib/uikit/components/` +const DIR_UIKIT_COPY_OUT = fullPath('./.components-civictheme/') +const DIR_OUT = fullPath('./dist/') +const DIR_ASSETS_IN = fullPath('./assets/') +const DIR_ASSETS_OUT = fullPath('./dist/assets/') + +const STYLE_FILE_IN = `${DIR_COMPONENTS_OUT}/style.scss` +const STYLE_VARIABLE_FILE_IN = `${DIR_COMPONENTS_OUT}/style.css_variables.scss` +const STYLE_EDITOR_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.editor.scss` +const STYLE_ADMIN_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.admin.scss` +const STYLE_LAYOUT_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.layout.scss` +const STYLE_FILE_OUT = `${DIR_OUT}/styles.css` +const STYLE_EDITOR_FILE_OUT = `${DIR_OUT}/styles.editor.css` +const STYLE_VARIABLE_FILE_OUT = `${DIR_OUT}/styles.variables.css` +const STYLE_ADMIN_FILE_OUT = `${DIR_OUT}/styles.admin.css` +const STYLE_LAYOUT_FILE_OUT = `${DIR_OUT}/styles.layout.css` + +const VAR_CT_ASSETS_DIRECTORY = `$ct-assets-directory: '/themes/custom/${THEME_NAME}/dist/assets/';` + +const JS_FILE_OUT = `${DIR_OUT}/scripts.js` +const JS_CIVIC_IMPORTS = `${DIR_COMPONENTS_OUT}/**/!(*.stories|*.component|*.min|*.test|*.script|*.utils).js` +const JS_LIB_IMPORTS = [fullPath('./node_modules/@popperjs/core/dist/umd/popper.js')] +const JS_ASSET_IMPORTS = [ + `${DIR_CIVICTHEME}/assets/js/**/*.js`, + `${DIR_ASSETS_IN}/js/**/*.js`, +] + +function build(options = {}) { + const startTime = new Date().getTime() + + // --------------------------------------------------------------------------- CREATE DIR + if (!fs.existsSync(DIR_OUT)) { + fs.mkdirSync(DIR_OUT) + } + + // --------------------------------------------------------------------------- GULP + if (config.combineComponents) { + runCommand(`rsync -a --delete ${DIR_UIKIT_COMPONENTS_IN}/ ${DIR_UIKIT_COPY_OUT}/`) + runCommand(`rsync -a --delete ${DIR_UIKIT_COPY_OUT}/ ${DIR_COMPONENTS_OUT}/`) + runCommand(`rsync -a ${DIR_COMPONENTS_IN}/ ${DIR_COMPONENTS_OUT}/`) + console.log(`Saved: Combined folders`) + } + + // --------------------------------------------------------------------------- STYLES + if (config.compileStyles) { + const rootDir = DIR_COMPONENTS_OUT + const stylecss = [ + VAR_CT_ASSETS_DIRECTORY, + loadStyle(STYLE_FILE_IN, rootDir), + getStyleImports([ + 'style.css_variables.scss', + '../assets/sass/theme.scss', + ], rootDir) + ].join('\n') + + // Compile the styles. + const compiled = sass.compileString(stylecss, { loadPaths: [rootDir] }) + fs.writeFileSync(STYLE_FILE_OUT, compiled.css, 'utf-8') + console.log(`Saved: Component styles`) + } + + if (config.compileStylesEditor) { + const rootDir = PATH + const editorcss = [ + VAR_CT_ASSETS_DIRECTORY, + loadStyle(STYLE_EDITOR_FILE_IN, rootDir), + ].join('\n') + + const compiled = sass.compileString(editorcss, { loadPaths: [rootDir] }) + fs.writeFileSync(STYLE_EDITOR_FILE_OUT, compiled.css, 'utf-8') + console.log(`Saved: Editor styles`) + } + + if (config.compileStylesAdmin) { + const rootDir = PATH + const compiled = sass.compile(STYLE_ADMIN_FILE_IN, { loadPaths: [rootDir] }) + fs.writeFileSync(STYLE_ADMIN_FILE_OUT, compiled.css, 'utf-8') + console.log(`Saved: Admin styles`) + } + + if (config.compileStylesLayout) { + const rootDir = PATH + const layoutcss = [ + VAR_CT_ASSETS_DIRECTORY, + loadStyle(STYLE_LAYOUT_FILE_IN, rootDir), + ].join('\n') + + const compiled = sass.compileString(layoutcss, { loadPaths: [rootDir] }) + fs.writeFileSync(STYLE_LAYOUT_FILE_OUT, compiled.css, 'utf-8') + console.log(`Saved: Layout styles`) + } + + if (config.compileStylesVariables) { + const compiled = sass.compile(STYLE_VARIABLE_FILE_IN, { loadPaths: [DIR_COMPONENTS_OUT] }) + fs.writeFileSync(STYLE_VARIABLE_FILE_OUT, compiled.css, 'utf-8') + console.log(`Saved: Style variables`) + } + + // --------------------------------------------------------------------------- SCRIPTS + if (config.compileJs) { + const jsOutData = [] + + // Third party imports. + JS_LIB_IMPORTS.forEach(filename => { + jsOutData.push(fs.readFileSync(filename, 'utf-8')) + }) + + // Civictheme asset imports. + globSync(JS_ASSET_IMPORTS).forEach(filename => { + jsOutData.push(fs.readFileSync(filename, 'utf-8')) + }) + + // Civictheme component imports. + globSync(JS_CIVIC_IMPORTS).forEach(filename => { + const name = `${THEME_NAME}_${filename.split('/').reverse()[0].replace('.js', '').replace(/-/g, '_')}` + const body = fs.readFileSync(filename, 'utf-8') + const outBody = `Drupal.behaviors.${name} = {attach: function (context, settings) {\n${body}\n}};` + jsOutData.push(outBody) + }) + + fs.writeFileSync(JS_FILE_OUT, jsOutData.join('\n'), 'utf-8') + console.log(`Saved: Compiled javascript`) + } + + // --------------------------------------------------------------------------- ASSETS + if (config.compileAssets) { + runCommand(`rsync -a --delete --exclude js --exclude sass ${DIR_ASSETS_IN} ${DIR_ASSETS_OUT}`) + } + + // --------------------------------------------------------------------------- FINISH + console.log(`Time taken: ${new Date().getTime() - startTime} ms`) +} + +if (config.runBuild) { + build() +} + +if (config.runWatch) { + console.log(`Watching: ${path.relative(PATH, DIR_COMPONENTS_IN)}`) + const supportedExtensions = ['scss', 'js', 'twig'] + let lastModified = 0 + let timeout = null + const watcher = fs.watch(DIR_COMPONENTS_IN, { recursive: true }, (event, filename) => { + const ext = filename.split('.').pop() + if (supportedExtensions.indexOf(ext) >= 0) { + lastModified = new Date().getTime() + waitToProcess() + } + }) + function waitToProcess() { + const processStart = lastModified + clearTimeout(timeout) + timeout = setTimeout(() => { + // If last modified has changed, wait again. + (processStart !== lastModified) ? waitToProcess() : processWatch() + }, 300) + } + function processWatch () { + build() + } +} diff --git a/web/themes/contrib/civictheme/civictheme_starter_kit/package.json b/web/themes/contrib/civictheme/civictheme_starter_kit/package.json index bcef5e3e3b..4061e861e2 100644 --- a/web/themes/contrib/civictheme/civictheme_starter_kit/package.json +++ b/web/themes/contrib/civictheme/civictheme_starter_kit/package.json @@ -9,6 +9,8 @@ "scripts": { "add-lint-exclusions": "php scripts/add_phpcs_exclusions.php dist,storybook-static", "build": "npm run dist && export STORYBOOK_FULL=1 && npm run build-storybook -- --quiet && npm run add-lint-exclusions", + "build:new": "node build.js", + "build:watch:new": "node build.js build watch", "build-storybook": "export NODE_OPTIONS=--openssl-legacy-provider && npm run gulp:build && build-storybook -s .storybook/static", "dist": "export NODE_OPTIONS=--openssl-legacy-provider && npm run gulp:build && webpack --config ./webpack/webpack.prod.js", "dist:dev": "export NODE_OPTIONS=--openssl-legacy-provider && npm run gulp:build && webpack --config ./webpack/webpack.dev.js", From 96262404800b6c61e8a7f84c320b4b80b9d3ebdf Mon Sep 17 00:00:00 2001 From: Alan Cole Date: Wed, 16 Oct 2024 16:52:26 +1100 Subject: [PATCH 2/7] [CIVIC-1946] Added build system support for civictheme base. --- web/themes/contrib/civictheme/.nvmrc | 2 +- web/themes/contrib/civictheme/build.js | 276 ++++++++++++++++++ .../civictheme_starter_kit/build.js | 141 ++++----- web/themes/contrib/civictheme/package.json | 2 + 4 files changed, 332 insertions(+), 89 deletions(-) create mode 100644 web/themes/contrib/civictheme/build.js diff --git a/web/themes/contrib/civictheme/.nvmrc b/web/themes/contrib/civictheme/.nvmrc index 2ef3430431..dc5f6a52b1 100644 --- a/web/themes/contrib/civictheme/.nvmrc +++ b/web/themes/contrib/civictheme/.nvmrc @@ -1 +1 @@ -18.14 +22.6.0 diff --git a/web/themes/contrib/civictheme/build.js b/web/themes/contrib/civictheme/build.js new file mode 100644 index 0000000000..3d1da73f9e --- /dev/null +++ b/web/themes/contrib/civictheme/build.js @@ -0,0 +1,276 @@ +/* +Civictheme build - version 0.0.1 (alpha). + +This is a simplified build system for civictheme, designed to: + +- Speed up build time +- Improve auditability by reducing dependencies / external code + +Build by calling: + + npm run build:new + +Build and watch by calling: + + npm run build:watch:new + +Notes: + +- Requires Node version 22 (for the built in glob feature). +- No Windows support (unless through WSL). +- This relies on command line rsync. +- This does not support uglify or minifying JS / CSS code. +- Watch does not trigger on a directory change, only on a (scss, twig, js) file change. +*/ + +const fs = require('fs') +const path = require('path') +const { globSync } = require('node:fs') +const { execSync } = require('child_process') +const sass = require('sass') + +// ----------------------------------------------------------------------------- UTILITIES + +function runCommand(command) { + execSync(command, (error, stdout, stderr) => { + if (error) { + console.log(`error: ${error.message}`) + return + } + if (stderr) { + console.log(`stderr: ${stderr}`) + return + } + if (stdout) { + console.log(stdout) + } + }) +} + +function getStyleImport(path, cwd) { + return globSync(path, { cwd }).sort((a, b) => a.localeCompare(b)).map(i => `@import "${i}";`).join('\n') +} + +function getStyleImports(paths, cwd) { + return paths.map(path => getStyleImport(path, cwd)).join('\n') +} + +function loadStyle(path, cwd) { + const result = [] + let data = fs.readFileSync(path, 'utf-8') + + data.split('\n').forEach(line => { + // Only glob imports with *!()| characters. + const match = /@import '(.*[\*!()|].*)'/.exec(line) + result.push(match ? getStyleImport(match[1], cwd) : line) + }) + + return result.join('\n') +} + +function fullPath(filepath) { + return path.resolve(PATH, filepath) +} + +// ----------------------------------------------------------------------------- CONFIGURATION +const config = { + build: false, + watch: false, + combine: false, + styles: false, + styles_editor: false, + styles_admin: false, + styles_layout: false, + styles_variables: false, + js: false, + assets: false, + base: false, +} + +const flags = process.argv.slice(2) +const buildType = ['build', 'watch'] +const buildWatchFlagCount = flags.filter(f => buildType.indexOf(f) >= 0).length + +if (flags.length <= 2 && buildWatchFlagCount <= 2) { + // If build and/or watch, or neither.. + config.build = buildWatchFlagCount === 0 || flags.indexOf('build') >= 0 + config.watch = flags.indexOf('watch') >= 0 + config.combine = true + config.styles = true + config.styles_editor = true + config.styles_variables = true + config.js = true + config.assets = true +} else { + // Fully configured from command line - everything disabled by default. + flags.forEach((flag) => { + config[flag] = true + }) +} + +// ----------------------------------------------------------------------------- PATHS + +const PATH = __dirname + +const THEME_NAME = PATH.split('/').reverse()[0] +const DIR_CIVICTHEME = fullPath('../../contrib/civictheme/') +const DIR_COMPONENTS_IN = fullPath('./components/') +const DIR_COMPONENTS_OUT = fullPath('./components_combined/') +const DIR_UIKIT_COMPONENTS_IN = `${DIR_CIVICTHEME}/lib/uikit/components/` +const DIR_UIKIT_COPY_OUT = fullPath('./.components-civictheme/') +const DIR_OUT = fullPath('./dist/') +const DIR_ASSETS_IN = fullPath('./assets/') +const DIR_ASSETS_OUT = fullPath('./dist/assets/') + +const COMPONENT_DIR = config.base ? DIR_COMPONENTS_IN : DIR_COMPONENTS_OUT + +const STYLE_FILE_IN = `${COMPONENT_DIR}/style.scss` +const STYLE_VARIABLE_FILE_IN = `${COMPONENT_DIR}/style.css_variables.scss` +const STYLE_THEME_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.scss` +const STYLE_EDITOR_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.editor.scss` +const STYLE_ADMIN_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.admin.scss` +const STYLE_LAYOUT_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.layout.scss` +const STYLE_FILE_OUT = `${DIR_OUT}/styles.css` +const STYLE_EDITOR_FILE_OUT = `${DIR_OUT}/styles.editor.css` +const STYLE_VARIABLE_FILE_OUT = `${DIR_OUT}/styles.variables.css` +const STYLE_ADMIN_FILE_OUT = `${DIR_OUT}/styles.admin.css` +const STYLE_LAYOUT_FILE_OUT = `${DIR_OUT}/styles.layout.css` + +const VAR_CT_ASSETS_DIRECTORY = `$ct-assets-directory: '/themes/custom/${THEME_NAME}/dist/assets/';` + +const JS_FILE_OUT = `${DIR_OUT}/scripts.js` +const JS_CIVIC_IMPORTS = `${COMPONENT_DIR}/**/!(*.stories|*.component|*.min|*.test|*.script|*.utils).js` +const JS_LIB_IMPORTS = [fullPath('./node_modules/@popperjs/core/dist/umd/popper.js')] +const JS_ASSET_IMPORTS = [ + `${DIR_CIVICTHEME}/assets/js/**/*.js`, + `${DIR_ASSETS_IN}/js/**/*.js`, +] + +function build(options = {}) { + const startTime = new Date().getTime() + + // --------------------------------------------------------------------------- CREATE DIR + if (!fs.existsSync(DIR_OUT)) { + fs.mkdirSync(DIR_OUT) + } + + // --------------------------------------------------------------------------- GULP + if (config.combine && !config.base) { + runCommand(`rsync -a --delete ${DIR_UIKIT_COMPONENTS_IN}/ ${DIR_UIKIT_COPY_OUT}/`) + runCommand(`rsync -a --delete ${DIR_UIKIT_COPY_OUT}/ ${DIR_COMPONENTS_OUT}/`) + runCommand(`rsync -a ${DIR_COMPONENTS_IN}/ ${DIR_COMPONENTS_OUT}/`) + console.log(`Saved: Combined folders`) + } + + // --------------------------------------------------------------------------- STYLES + if (config.styles) { + const stylecss = [ + VAR_CT_ASSETS_DIRECTORY, + loadStyle(STYLE_FILE_IN, COMPONENT_DIR), + getStyleImport(STYLE_VARIABLE_FILE_IN, COMPONENT_DIR), + getStyleImport(STYLE_THEME_FILE_IN, PATH), + ].join('\n') + + // Compile the styles. + const compiled = sass.compileString(stylecss, { loadPaths: [COMPONENT_DIR, PATH] }) + fs.writeFileSync(STYLE_FILE_OUT, compiled.css, 'utf-8') + console.log(`Saved: Component styles`) + } + + if (config.styles_editor) { + const editorcss = [ + VAR_CT_ASSETS_DIRECTORY, + loadStyle(STYLE_EDITOR_FILE_IN, PATH), + ].join('\n') + + const compiled = sass.compileString(editorcss, { loadPaths: [PATH] }) + fs.writeFileSync(STYLE_EDITOR_FILE_OUT, compiled.css, 'utf-8') + console.log(`Saved: Editor styles`) + } + + if (config.styles_admin) { + const compiled = sass.compile(STYLE_ADMIN_FILE_IN, { loadPaths: [PATH] }) + fs.writeFileSync(STYLE_ADMIN_FILE_OUT, compiled.css, 'utf-8') + console.log(`Saved: Admin styles`) + } + + if (config.styles_layout) { + const layoutcss = [ + VAR_CT_ASSETS_DIRECTORY, + loadStyle(STYLE_LAYOUT_FILE_IN, PATH), + ].join('\n') + + const compiled = sass.compileString(layoutcss, { loadPaths: [PATH] }) + fs.writeFileSync(STYLE_LAYOUT_FILE_OUT, compiled.css, 'utf-8') + console.log(`Saved: Layout styles`) + } + + if (config.styles_variables) { + const compiled = sass.compile(STYLE_VARIABLE_FILE_IN, { loadPaths: [COMPONENT_DIR] }) + fs.writeFileSync(STYLE_VARIABLE_FILE_OUT, compiled.css, 'utf-8') + console.log(`Saved: Variable styles`) + } + + // --------------------------------------------------------------------------- SCRIPTS + if (config.js) { + const jsOutData = [] + + // Third party imports. + JS_LIB_IMPORTS.forEach(filename => { + jsOutData.push(fs.readFileSync(filename, 'utf-8')) + }) + + // Civictheme asset imports. + globSync(JS_ASSET_IMPORTS).forEach(filename => { + jsOutData.push(fs.readFileSync(filename, 'utf-8')) + }) + + // Civictheme component imports. + globSync(JS_CIVIC_IMPORTS).forEach(filename => { + const name = `${THEME_NAME}_${filename.split('/').reverse()[0].replace('.js', '').replace(/-/g, '_')}` + const body = fs.readFileSync(filename, 'utf-8') + const outBody = `Drupal.behaviors.${name} = {attach: function (context, settings) {\n${body}\n}};` + jsOutData.push(outBody) + }) + + fs.writeFileSync(JS_FILE_OUT, jsOutData.join('\n'), 'utf-8') + console.log(`Saved: Compiled javascript`) + } + + // --------------------------------------------------------------------------- ASSETS + if (config.assets) { + runCommand(`rsync -a --delete --exclude js --exclude sass ${DIR_ASSETS_IN} ${DIR_ASSETS_OUT}`) + } + + // --------------------------------------------------------------------------- FINISH + console.log(`Time taken: ${new Date().getTime() - startTime} ms`) +} + +if (config.build) { + build() +} + +if (config.watch) { + console.log(`Watching: ${path.relative(PATH, DIR_COMPONENTS_IN)}`) + const supportedExtensions = ['scss', 'js', 'twig'] + let lastModified = 0 + let timeout = null + const watcher = fs.watch(DIR_COMPONENTS_IN, { recursive: true }, (event, filename) => { + const ext = filename.split('.').pop() + if (supportedExtensions.indexOf(ext) >= 0) { + lastModified = new Date().getTime() + waitToProcess() + } + }) + function waitToProcess() { + const processStart = lastModified + clearTimeout(timeout) + timeout = setTimeout(() => { + // If last modified has changed, wait again. + (processStart !== lastModified) ? waitToProcess() : processWatch() + }, 300) + } + function processWatch () { + build() + } +} diff --git a/web/themes/contrib/civictheme/civictheme_starter_kit/build.js b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js index b23c9fbd28..3d1da73f9e 100644 --- a/web/themes/contrib/civictheme/civictheme_starter_kit/build.js +++ b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js @@ -73,70 +73,38 @@ function fullPath(filepath) { } // ----------------------------------------------------------------------------- CONFIGURATION - const config = { - runBuild: false, - runWatch: false, - combineComponents: false, - compileStyles: false, - compileStylesEditor: false, - compileStylesAdmin: false, - compileStylesLayout: false, - compileStylesVariables: false, - compileJs: false, - compileAssets: false, + build: false, + watch: false, + combine: false, + styles: false, + styles_editor: false, + styles_admin: false, + styles_layout: false, + styles_variables: false, + js: false, + assets: false, + base: false, } -const behaviourFlags = ['build', 'watch'] const flags = process.argv.slice(2) -const buildWatchFlagCount = flags.filter(f => behaviourFlags.indexOf(f) >= 0).length - -if (buildWatchFlagCount <= 2) { - config.runBuild = buildWatchFlagCount === 0 || flags.indexOf('build') >= 0 - config.runWatch = flags.indexOf('watch') >= 0 - config.combineComponents = true - config.compileStyles = true - config.compileStylesEditor = true - config.compileStylesAdmin = false - config.compileStylesLayout = false - config.compileStylesVariables = true - config.compileJs = true - config.compileAssets = true +const buildType = ['build', 'watch'] +const buildWatchFlagCount = flags.filter(f => buildType.indexOf(f) >= 0).length + +if (flags.length <= 2 && buildWatchFlagCount <= 2) { + // If build and/or watch, or neither.. + config.build = buildWatchFlagCount === 0 || flags.indexOf('build') >= 0 + config.watch = flags.indexOf('watch') >= 0 + config.combine = true + config.styles = true + config.styles_editor = true + config.styles_variables = true + config.js = true + config.assets = true } else { - // Fully configured - everything disabled by default. + // Fully configured from command line - everything disabled by default. flags.forEach((flag) => { - switch (flag) { - case 'build': - config.runBuild = true - break - case 'watch': - config.runWatch = true - break - case 'combine': - config.combineComponents = true - break - case 'styles': - config.compileStyles = true - break - case 'styles-editor': - config.compileStylesEditor = true - break - case 'styles-admin': - config.compileStylesAdmin = true - break - case 'styles-layout': - config.compileStylesLayout = true - break - case 'styles-variables': - config.compileStylesVariables = true - break - case 'js': - config.compileJs = true - break - case 'assets': - config.compileAssets = true - break - } + config[flag] = true }) } @@ -154,8 +122,11 @@ const DIR_OUT = fullPath('./dist/') const DIR_ASSETS_IN = fullPath('./assets/') const DIR_ASSETS_OUT = fullPath('./dist/assets/') -const STYLE_FILE_IN = `${DIR_COMPONENTS_OUT}/style.scss` -const STYLE_VARIABLE_FILE_IN = `${DIR_COMPONENTS_OUT}/style.css_variables.scss` +const COMPONENT_DIR = config.base ? DIR_COMPONENTS_IN : DIR_COMPONENTS_OUT + +const STYLE_FILE_IN = `${COMPONENT_DIR}/style.scss` +const STYLE_VARIABLE_FILE_IN = `${COMPONENT_DIR}/style.css_variables.scss` +const STYLE_THEME_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.scss` const STYLE_EDITOR_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.editor.scss` const STYLE_ADMIN_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.admin.scss` const STYLE_LAYOUT_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.layout.scss` @@ -168,7 +139,7 @@ const STYLE_LAYOUT_FILE_OUT = `${DIR_OUT}/styles.layout.css` const VAR_CT_ASSETS_DIRECTORY = `$ct-assets-directory: '/themes/custom/${THEME_NAME}/dist/assets/';` const JS_FILE_OUT = `${DIR_OUT}/scripts.js` -const JS_CIVIC_IMPORTS = `${DIR_COMPONENTS_OUT}/**/!(*.stories|*.component|*.min|*.test|*.script|*.utils).js` +const JS_CIVIC_IMPORTS = `${COMPONENT_DIR}/**/!(*.stories|*.component|*.min|*.test|*.script|*.utils).js` const JS_LIB_IMPORTS = [fullPath('./node_modules/@popperjs/core/dist/umd/popper.js')] const JS_ASSET_IMPORTS = [ `${DIR_CIVICTHEME}/assets/js/**/*.js`, @@ -184,7 +155,7 @@ function build(options = {}) { } // --------------------------------------------------------------------------- GULP - if (config.combineComponents) { + if (config.combine && !config.base) { runCommand(`rsync -a --delete ${DIR_UIKIT_COMPONENTS_IN}/ ${DIR_UIKIT_COPY_OUT}/`) runCommand(`rsync -a --delete ${DIR_UIKIT_COPY_OUT}/ ${DIR_COMPONENTS_OUT}/`) runCommand(`rsync -a ${DIR_COMPONENTS_IN}/ ${DIR_COMPONENTS_OUT}/`) @@ -192,62 +163,56 @@ function build(options = {}) { } // --------------------------------------------------------------------------- STYLES - if (config.compileStyles) { - const rootDir = DIR_COMPONENTS_OUT + if (config.styles) { const stylecss = [ VAR_CT_ASSETS_DIRECTORY, - loadStyle(STYLE_FILE_IN, rootDir), - getStyleImports([ - 'style.css_variables.scss', - '../assets/sass/theme.scss', - ], rootDir) + loadStyle(STYLE_FILE_IN, COMPONENT_DIR), + getStyleImport(STYLE_VARIABLE_FILE_IN, COMPONENT_DIR), + getStyleImport(STYLE_THEME_FILE_IN, PATH), ].join('\n') // Compile the styles. - const compiled = sass.compileString(stylecss, { loadPaths: [rootDir] }) + const compiled = sass.compileString(stylecss, { loadPaths: [COMPONENT_DIR, PATH] }) fs.writeFileSync(STYLE_FILE_OUT, compiled.css, 'utf-8') console.log(`Saved: Component styles`) } - if (config.compileStylesEditor) { - const rootDir = PATH + if (config.styles_editor) { const editorcss = [ VAR_CT_ASSETS_DIRECTORY, - loadStyle(STYLE_EDITOR_FILE_IN, rootDir), + loadStyle(STYLE_EDITOR_FILE_IN, PATH), ].join('\n') - const compiled = sass.compileString(editorcss, { loadPaths: [rootDir] }) + const compiled = sass.compileString(editorcss, { loadPaths: [PATH] }) fs.writeFileSync(STYLE_EDITOR_FILE_OUT, compiled.css, 'utf-8') console.log(`Saved: Editor styles`) } - if (config.compileStylesAdmin) { - const rootDir = PATH - const compiled = sass.compile(STYLE_ADMIN_FILE_IN, { loadPaths: [rootDir] }) + if (config.styles_admin) { + const compiled = sass.compile(STYLE_ADMIN_FILE_IN, { loadPaths: [PATH] }) fs.writeFileSync(STYLE_ADMIN_FILE_OUT, compiled.css, 'utf-8') console.log(`Saved: Admin styles`) } - if (config.compileStylesLayout) { - const rootDir = PATH + if (config.styles_layout) { const layoutcss = [ VAR_CT_ASSETS_DIRECTORY, - loadStyle(STYLE_LAYOUT_FILE_IN, rootDir), + loadStyle(STYLE_LAYOUT_FILE_IN, PATH), ].join('\n') - const compiled = sass.compileString(layoutcss, { loadPaths: [rootDir] }) + const compiled = sass.compileString(layoutcss, { loadPaths: [PATH] }) fs.writeFileSync(STYLE_LAYOUT_FILE_OUT, compiled.css, 'utf-8') console.log(`Saved: Layout styles`) } - if (config.compileStylesVariables) { - const compiled = sass.compile(STYLE_VARIABLE_FILE_IN, { loadPaths: [DIR_COMPONENTS_OUT] }) + if (config.styles_variables) { + const compiled = sass.compile(STYLE_VARIABLE_FILE_IN, { loadPaths: [COMPONENT_DIR] }) fs.writeFileSync(STYLE_VARIABLE_FILE_OUT, compiled.css, 'utf-8') - console.log(`Saved: Style variables`) + console.log(`Saved: Variable styles`) } // --------------------------------------------------------------------------- SCRIPTS - if (config.compileJs) { + if (config.js) { const jsOutData = [] // Third party imports. @@ -273,7 +238,7 @@ function build(options = {}) { } // --------------------------------------------------------------------------- ASSETS - if (config.compileAssets) { + if (config.assets) { runCommand(`rsync -a --delete --exclude js --exclude sass ${DIR_ASSETS_IN} ${DIR_ASSETS_OUT}`) } @@ -281,11 +246,11 @@ function build(options = {}) { console.log(`Time taken: ${new Date().getTime() - startTime} ms`) } -if (config.runBuild) { +if (config.build) { build() } -if (config.runWatch) { +if (config.watch) { console.log(`Watching: ${path.relative(PATH, DIR_COMPONENTS_IN)}`) const supportedExtensions = ['scss', 'js', 'twig'] let lastModified = 0 diff --git a/web/themes/contrib/civictheme/package.json b/web/themes/contrib/civictheme/package.json index 67e9b9b6ea..939327c4eb 100644 --- a/web/themes/contrib/civictheme/package.json +++ b/web/themes/contrib/civictheme/package.json @@ -13,6 +13,8 @@ "scripts": { "add-lint-exclusions": "php civictheme_starter_kit/scripts/add_phpcs_exclusions.php dist,storybook-static,lib/uikit", "build": "npm run dist && export STORYBOOK_FULL=1 && npm run build-storybook -- --quiet && npm run add-lint-exclusions", + "build:new": "node build.js base build styles styles_editor styles_admin styles_layout styles_variables js assets", + "build:watch:new": "node build.js base build watch styles styles_editor styles_admin styles_layout styles_variables js assets", "build-storybook": "export NODE_OPTIONS=--openssl-legacy-provider && build-storybook -s .storybook/static", "dist": "export NODE_OPTIONS=--openssl-legacy-provider && webpack --config ./webpack/webpack.prod.js", "dist:dev": "export NODE_OPTIONS=--openssl-legacy-provider && webpack --config ./webpack/webpack.dev.js", From f09b37d53cbd96e3018d58611c86f00975018c1b Mon Sep 17 00:00:00 2001 From: Alan Cole Date: Wed, 16 Oct 2024 17:09:47 +1100 Subject: [PATCH 3/7] [CIVIC-1946] Remove unused function. --- web/themes/contrib/civictheme/build.js | 4 ---- web/themes/contrib/civictheme/civictheme_starter_kit/build.js | 4 ---- 2 files changed, 8 deletions(-) diff --git a/web/themes/contrib/civictheme/build.js b/web/themes/contrib/civictheme/build.js index 3d1da73f9e..04bf766b64 100644 --- a/web/themes/contrib/civictheme/build.js +++ b/web/themes/contrib/civictheme/build.js @@ -51,10 +51,6 @@ function getStyleImport(path, cwd) { return globSync(path, { cwd }).sort((a, b) => a.localeCompare(b)).map(i => `@import "${i}";`).join('\n') } -function getStyleImports(paths, cwd) { - return paths.map(path => getStyleImport(path, cwd)).join('\n') -} - function loadStyle(path, cwd) { const result = [] let data = fs.readFileSync(path, 'utf-8') diff --git a/web/themes/contrib/civictheme/civictheme_starter_kit/build.js b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js index 3d1da73f9e..04bf766b64 100644 --- a/web/themes/contrib/civictheme/civictheme_starter_kit/build.js +++ b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js @@ -51,10 +51,6 @@ function getStyleImport(path, cwd) { return globSync(path, { cwd }).sort((a, b) => a.localeCompare(b)).map(i => `@import "${i}";`).join('\n') } -function getStyleImports(paths, cwd) { - return paths.map(path => getStyleImport(path, cwd)).join('\n') -} - function loadStyle(path, cwd) { const result = [] let data = fs.readFileSync(path, 'utf-8') From 09f8565bdf2b0b38f773238c9eda52e7e84f171e Mon Sep 17 00:00:00 2001 From: Alan Cole Date: Wed, 16 Oct 2024 17:15:42 +1100 Subject: [PATCH 4/7] [CIVIC-1946] Fixed asset nesting directory. --- web/themes/contrib/civictheme/build.js | 3 +-- web/themes/contrib/civictheme/civictheme_starter_kit/build.js | 3 +-- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/web/themes/contrib/civictheme/build.js b/web/themes/contrib/civictheme/build.js index 04bf766b64..1da1d41911 100644 --- a/web/themes/contrib/civictheme/build.js +++ b/web/themes/contrib/civictheme/build.js @@ -167,7 +167,6 @@ function build(options = {}) { getStyleImport(STYLE_THEME_FILE_IN, PATH), ].join('\n') - // Compile the styles. const compiled = sass.compileString(stylecss, { loadPaths: [COMPONENT_DIR, PATH] }) fs.writeFileSync(STYLE_FILE_OUT, compiled.css, 'utf-8') console.log(`Saved: Component styles`) @@ -235,7 +234,7 @@ function build(options = {}) { // --------------------------------------------------------------------------- ASSETS if (config.assets) { - runCommand(`rsync -a --delete --exclude js --exclude sass ${DIR_ASSETS_IN} ${DIR_ASSETS_OUT}`) + runCommand(`rsync -a --delete --exclude js --exclude sass ${DIR_ASSETS_IN}/ ${DIR_ASSETS_OUT}/`) } // --------------------------------------------------------------------------- FINISH diff --git a/web/themes/contrib/civictheme/civictheme_starter_kit/build.js b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js index 04bf766b64..1da1d41911 100644 --- a/web/themes/contrib/civictheme/civictheme_starter_kit/build.js +++ b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js @@ -167,7 +167,6 @@ function build(options = {}) { getStyleImport(STYLE_THEME_FILE_IN, PATH), ].join('\n') - // Compile the styles. const compiled = sass.compileString(stylecss, { loadPaths: [COMPONENT_DIR, PATH] }) fs.writeFileSync(STYLE_FILE_OUT, compiled.css, 'utf-8') console.log(`Saved: Component styles`) @@ -235,7 +234,7 @@ function build(options = {}) { // --------------------------------------------------------------------------- ASSETS if (config.assets) { - runCommand(`rsync -a --delete --exclude js --exclude sass ${DIR_ASSETS_IN} ${DIR_ASSETS_OUT}`) + runCommand(`rsync -a --delete --exclude js --exclude sass ${DIR_ASSETS_IN}/ ${DIR_ASSETS_OUT}/`) } // --------------------------------------------------------------------------- FINISH From d296f6a71c7e0efc52c4952b0cc887c18791dca8 Mon Sep 17 00:00:00 2001 From: Alan Cole Date: Wed, 16 Oct 2024 17:16:35 +1100 Subject: [PATCH 5/7] [CIVIC-1946] Rename combined folder comment. --- web/themes/contrib/civictheme/build.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/web/themes/contrib/civictheme/build.js b/web/themes/contrib/civictheme/build.js index 1da1d41911..1202b0e376 100644 --- a/web/themes/contrib/civictheme/build.js +++ b/web/themes/contrib/civictheme/build.js @@ -150,7 +150,7 @@ function build(options = {}) { fs.mkdirSync(DIR_OUT) } - // --------------------------------------------------------------------------- GULP + // --------------------------------------------------------------------------- COMBINED FOLDER if (config.combine && !config.base) { runCommand(`rsync -a --delete ${DIR_UIKIT_COMPONENTS_IN}/ ${DIR_UIKIT_COPY_OUT}/`) runCommand(`rsync -a --delete ${DIR_UIKIT_COPY_OUT}/ ${DIR_COMPONENTS_OUT}/`) From b99a2d79925a48ac041fe04385d79110c8b3dfb6 Mon Sep 17 00:00:00 2001 From: Alan Cole Date: Thu, 17 Oct 2024 12:46:25 +1100 Subject: [PATCH 6/7] [CIVIC-1946] Fixed civictheme builds; filenames and imports. - Simplified the watch - removing unnecessary logic. --- web/themes/contrib/civictheme/build.js | 37 ++++++++---------- .../civictheme_starter_kit/build.js | 39 ++++++++----------- 2 files changed, 33 insertions(+), 43 deletions(-) diff --git a/web/themes/contrib/civictheme/build.js b/web/themes/contrib/civictheme/build.js index 1202b0e376..23be2865dd 100644 --- a/web/themes/contrib/civictheme/build.js +++ b/web/themes/contrib/civictheme/build.js @@ -1,3 +1,4 @@ +// phpcs:ignoreFile /* Civictheme build - version 0.0.1 (alpha). @@ -119,6 +120,8 @@ const DIR_ASSETS_IN = fullPath('./assets/') const DIR_ASSETS_OUT = fullPath('./dist/assets/') const COMPONENT_DIR = config.base ? DIR_COMPONENTS_IN : DIR_COMPONENTS_OUT +const STYLE_NAME = config.base ? 'civictheme' : 'styles' +const SCRIPT_NAME = config.base ? 'civictheme' : 'scripts' const STYLE_FILE_IN = `${COMPONENT_DIR}/style.scss` const STYLE_VARIABLE_FILE_IN = `${COMPONENT_DIR}/style.css_variables.scss` @@ -126,15 +129,15 @@ const STYLE_THEME_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.scss` const STYLE_EDITOR_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.editor.scss` const STYLE_ADMIN_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.admin.scss` const STYLE_LAYOUT_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.layout.scss` -const STYLE_FILE_OUT = `${DIR_OUT}/styles.css` -const STYLE_EDITOR_FILE_OUT = `${DIR_OUT}/styles.editor.css` -const STYLE_VARIABLE_FILE_OUT = `${DIR_OUT}/styles.variables.css` -const STYLE_ADMIN_FILE_OUT = `${DIR_OUT}/styles.admin.css` -const STYLE_LAYOUT_FILE_OUT = `${DIR_OUT}/styles.layout.css` +const STYLE_FILE_OUT = `${DIR_OUT}/${STYLE_NAME}.css` +const STYLE_EDITOR_FILE_OUT = `${DIR_OUT}/${STYLE_NAME}.editor.css` +const STYLE_VARIABLE_FILE_OUT = `${DIR_OUT}/${STYLE_NAME}.variables.css` +const STYLE_ADMIN_FILE_OUT = `${DIR_OUT}/${STYLE_NAME}.admin.css` +const STYLE_LAYOUT_FILE_OUT = `${DIR_OUT}/${STYLE_NAME}.layout.css` const VAR_CT_ASSETS_DIRECTORY = `$ct-assets-directory: '/themes/custom/${THEME_NAME}/dist/assets/';` -const JS_FILE_OUT = `${DIR_OUT}/scripts.js` +const JS_FILE_OUT = `${DIR_OUT}/${SCRIPT_NAME}.js` const JS_CIVIC_IMPORTS = `${COMPONENT_DIR}/**/!(*.stories|*.component|*.min|*.test|*.script|*.utils).js` const JS_LIB_IMPORTS = [fullPath('./node_modules/@popperjs/core/dist/umd/popper.js')] const JS_ASSET_IMPORTS = [ @@ -165,6 +168,10 @@ function build(options = {}) { loadStyle(STYLE_FILE_IN, COMPONENT_DIR), getStyleImport(STYLE_VARIABLE_FILE_IN, COMPONENT_DIR), getStyleImport(STYLE_THEME_FILE_IN, PATH), + config.base ? [ + getStyleImport(STYLE_ADMIN_FILE_IN, PATH), + loadStyle(STYLE_LAYOUT_FILE_IN, PATH), + ].join('\n') : '' ].join('\n') const compiled = sass.compileString(stylecss, { loadPaths: [COMPONENT_DIR, PATH] }) @@ -246,26 +253,14 @@ if (config.build) { } if (config.watch) { - console.log(`Watching: ${path.relative(PATH, DIR_COMPONENTS_IN)}`) + console.log(`Watching: ${path.relative(PATH, DIR_COMPONENTS_IN)}/`) const supportedExtensions = ['scss', 'js', 'twig'] - let lastModified = 0 let timeout = null const watcher = fs.watch(DIR_COMPONENTS_IN, { recursive: true }, (event, filename) => { const ext = filename.split('.').pop() if (supportedExtensions.indexOf(ext) >= 0) { - lastModified = new Date().getTime() - waitToProcess() + clearTimeout(timeout) + timeout = setTimeout(build, 300) } }) - function waitToProcess() { - const processStart = lastModified - clearTimeout(timeout) - timeout = setTimeout(() => { - // If last modified has changed, wait again. - (processStart !== lastModified) ? waitToProcess() : processWatch() - }, 300) - } - function processWatch () { - build() - } } diff --git a/web/themes/contrib/civictheme/civictheme_starter_kit/build.js b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js index 1da1d41911..23be2865dd 100644 --- a/web/themes/contrib/civictheme/civictheme_starter_kit/build.js +++ b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js @@ -1,3 +1,4 @@ +// phpcs:ignoreFile /* Civictheme build - version 0.0.1 (alpha). @@ -119,6 +120,8 @@ const DIR_ASSETS_IN = fullPath('./assets/') const DIR_ASSETS_OUT = fullPath('./dist/assets/') const COMPONENT_DIR = config.base ? DIR_COMPONENTS_IN : DIR_COMPONENTS_OUT +const STYLE_NAME = config.base ? 'civictheme' : 'styles' +const SCRIPT_NAME = config.base ? 'civictheme' : 'scripts' const STYLE_FILE_IN = `${COMPONENT_DIR}/style.scss` const STYLE_VARIABLE_FILE_IN = `${COMPONENT_DIR}/style.css_variables.scss` @@ -126,15 +129,15 @@ const STYLE_THEME_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.scss` const STYLE_EDITOR_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.editor.scss` const STYLE_ADMIN_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.admin.scss` const STYLE_LAYOUT_FILE_IN = `${DIR_ASSETS_IN}/sass/theme.layout.scss` -const STYLE_FILE_OUT = `${DIR_OUT}/styles.css` -const STYLE_EDITOR_FILE_OUT = `${DIR_OUT}/styles.editor.css` -const STYLE_VARIABLE_FILE_OUT = `${DIR_OUT}/styles.variables.css` -const STYLE_ADMIN_FILE_OUT = `${DIR_OUT}/styles.admin.css` -const STYLE_LAYOUT_FILE_OUT = `${DIR_OUT}/styles.layout.css` +const STYLE_FILE_OUT = `${DIR_OUT}/${STYLE_NAME}.css` +const STYLE_EDITOR_FILE_OUT = `${DIR_OUT}/${STYLE_NAME}.editor.css` +const STYLE_VARIABLE_FILE_OUT = `${DIR_OUT}/${STYLE_NAME}.variables.css` +const STYLE_ADMIN_FILE_OUT = `${DIR_OUT}/${STYLE_NAME}.admin.css` +const STYLE_LAYOUT_FILE_OUT = `${DIR_OUT}/${STYLE_NAME}.layout.css` const VAR_CT_ASSETS_DIRECTORY = `$ct-assets-directory: '/themes/custom/${THEME_NAME}/dist/assets/';` -const JS_FILE_OUT = `${DIR_OUT}/scripts.js` +const JS_FILE_OUT = `${DIR_OUT}/${SCRIPT_NAME}.js` const JS_CIVIC_IMPORTS = `${COMPONENT_DIR}/**/!(*.stories|*.component|*.min|*.test|*.script|*.utils).js` const JS_LIB_IMPORTS = [fullPath('./node_modules/@popperjs/core/dist/umd/popper.js')] const JS_ASSET_IMPORTS = [ @@ -150,7 +153,7 @@ function build(options = {}) { fs.mkdirSync(DIR_OUT) } - // --------------------------------------------------------------------------- GULP + // --------------------------------------------------------------------------- COMBINED FOLDER if (config.combine && !config.base) { runCommand(`rsync -a --delete ${DIR_UIKIT_COMPONENTS_IN}/ ${DIR_UIKIT_COPY_OUT}/`) runCommand(`rsync -a --delete ${DIR_UIKIT_COPY_OUT}/ ${DIR_COMPONENTS_OUT}/`) @@ -165,6 +168,10 @@ function build(options = {}) { loadStyle(STYLE_FILE_IN, COMPONENT_DIR), getStyleImport(STYLE_VARIABLE_FILE_IN, COMPONENT_DIR), getStyleImport(STYLE_THEME_FILE_IN, PATH), + config.base ? [ + getStyleImport(STYLE_ADMIN_FILE_IN, PATH), + loadStyle(STYLE_LAYOUT_FILE_IN, PATH), + ].join('\n') : '' ].join('\n') const compiled = sass.compileString(stylecss, { loadPaths: [COMPONENT_DIR, PATH] }) @@ -246,26 +253,14 @@ if (config.build) { } if (config.watch) { - console.log(`Watching: ${path.relative(PATH, DIR_COMPONENTS_IN)}`) + console.log(`Watching: ${path.relative(PATH, DIR_COMPONENTS_IN)}/`) const supportedExtensions = ['scss', 'js', 'twig'] - let lastModified = 0 let timeout = null const watcher = fs.watch(DIR_COMPONENTS_IN, { recursive: true }, (event, filename) => { const ext = filename.split('.').pop() if (supportedExtensions.indexOf(ext) >= 0) { - lastModified = new Date().getTime() - waitToProcess() + clearTimeout(timeout) + timeout = setTimeout(build, 300) } }) - function waitToProcess() { - const processStart = lastModified - clearTimeout(timeout) - timeout = setTimeout(() => { - // If last modified has changed, wait again. - (processStart !== lastModified) ? waitToProcess() : processWatch() - }, 300) - } - function processWatch () { - build() - } } From dbd6f3c13e43c081332f49ebe07af00b336711a1 Mon Sep 17 00:00:00 2001 From: Alan Cole Date: Thu, 17 Oct 2024 13:30:12 +1100 Subject: [PATCH 7/7] [CIVIC-1946] Remove unused parameter from build. --- web/themes/contrib/civictheme/build.js | 2 +- web/themes/contrib/civictheme/civictheme_starter_kit/build.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/web/themes/contrib/civictheme/build.js b/web/themes/contrib/civictheme/build.js index 23be2865dd..3b47f8d24f 100644 --- a/web/themes/contrib/civictheme/build.js +++ b/web/themes/contrib/civictheme/build.js @@ -145,7 +145,7 @@ const JS_ASSET_IMPORTS = [ `${DIR_ASSETS_IN}/js/**/*.js`, ] -function build(options = {}) { +function build() { const startTime = new Date().getTime() // --------------------------------------------------------------------------- CREATE DIR diff --git a/web/themes/contrib/civictheme/civictheme_starter_kit/build.js b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js index 23be2865dd..3b47f8d24f 100644 --- a/web/themes/contrib/civictheme/civictheme_starter_kit/build.js +++ b/web/themes/contrib/civictheme/civictheme_starter_kit/build.js @@ -145,7 +145,7 @@ const JS_ASSET_IMPORTS = [ `${DIR_ASSETS_IN}/js/**/*.js`, ] -function build(options = {}) { +function build() { const startTime = new Date().getTime() // --------------------------------------------------------------------------- CREATE DIR