-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
177 lines (154 loc) · 6.08 KB
/
gulpfile.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
import gulp from "gulp";
import { exec } from "node:child_process";
import { rm } from "node:fs/promises";
import { promisify } from "node:util";
import * as dartSass from 'sass';
import gulpSass from 'gulp-sass';
import imagemin, { gifsicle, mozjpeg, optipng, svgo } from 'gulp-imagemin';
import cleancss from "gulp-clean-css";
import concat from "gulp-concat";
import rename from "gulp-rename";
import PluginError from "plugin-error";
import gulpStylelint from "@ronilaukkarinen/gulp-stylelint";
const { src, watch, dest, parallel, lastRun, series } = gulp;
const sass = gulpSass(dartSass);
const promisedExec = promisify(exec);
const rootDir = new URL('./', import.meta.url)
const formatter = (results) => {
for (const result of results) {
if (result.errored) {
for (const warning of result.warnings) {
console.error(`[${warning.severity.toUpperCase()}: '${warning.rule}'] in ${result.source}:${warning.line} - ${warning.text}`);
}
}
};
return '';
}
const paths = {
src: {
src: "assets/src/",
images: "assets/src/images/",
scss: "assets/src/scss/",
fonts: "assets/src/fonts/",
javascript: "assets/src/javascript/",
fontawesome: "node_modules/@fortawesome/fontawesome-pro/",
},
ckanAssets: "ckan/ckanext/ckanext-restricteddata/ckanext/restricteddata/assets/",
ckanPublic: "ckan/ckanext/ckanext-restricteddata/ckanext/restricteddata/public/"
};
// Delete any previously generated assets
export async function clean() {
const removables = [
new URL(paths.ckanAssets + 'css/', rootDir),
new URL(paths.ckanAssets + 'javascript/', rootDir),
new URL(paths.ckanAssets + 'vendor/', rootDir),
new URL(paths.ckanPublic + 'css/', rootDir),
new URL(paths.ckanPublic + 'images/', rootDir),
new URL(paths.ckanPublic + 'fonts/', rootDir),
new URL(paths.ckanPublic + 'vendor/', rootDir),
];
const promises = removables.map((path) => {
rm(path, {
recursive: true,
force: true
});
})
await Promise.all(promises);
};
// Rebuild ckan webassets to see your changes as webassets are generated only once and cached
const rebuildCkanWebassets = async () => {
// Fetch docker container name with the subcommand $(docker ps -f "name=ckan-1" --format {{.Names}})
const container_name = (await promisedExec('docker ps -f "name=ckan-1" --format {{.Names}}')).stdout.trim();
// run ckan asset clean within the found container to wipe webassets cache
// await promisedExec(`docker exec ${container_name} ckan asset clean`);
// run ckan asset build within the found container to update webassets
// const build = (await promisedExec(`docker exec ${container_name} ckan asset build`)).stdout.trim();
// simple deletion of webassets folder seems to be the fastest and most reliable method...
const delete_out = (await promisedExec(`docker exec ${container_name} rm -rf data/webassets`));
console.log(` [rebuildCkanWebassets]: deleted data/webassets from ${container_name}`);
}
// Lint scss
export const lintStyles = () => {
return src(paths.src.scss + "**/*.scss")
.pipe(gulpStylelint({
reporters: [
{ formatter: formatter, console: true }
]
}))
};
// Preprocess our ckan sass
const ckanSass = () => {
return src(paths.src.scss + "ckan/main.scss", { sourcemaps: true })
.pipe(sass.sync({ includePaths: ["node_modules"], outputStyle: 'expanded', sourceMap: true }))
.on('error', function (error) {
throw new PluginError('sass', error.formatted);
})
.pipe(cleancss({ keepBreaks: false }))
.pipe(concat('restricteddata.css'))
.pipe(dest(paths.ckanAssets + "css", { sourcemaps: './maps' }))
};
// Separate fonts to their own css to optimize their loading
const fontsCss = () => {
return src(paths.src.scss + "fonts.scss", { since: lastRun(fontsCss) })
.pipe(sass.sync({ includePaths: ["node_modules"], outputStyle: 'expanded' }))
.on('error', function (error) {
throw new PluginError('sass', error.formatted);
})
.pipe(cleancss({ keepBreaks: false }))
.pipe(rename('fonts.css'))
.pipe(dest(paths.ckanPublic + "fonts"))
};
// Optimize images
const images = () => {
return src(paths.src.images + "**/*", { since: lastRun(images) })
.pipe(imagemin([
gifsicle({ interlaced: true }),
mozjpeg({ quality: 75, progressive: true }),
optipng({ optimizationLevel: 5 }),
svgo({
plugins: [
{
name: 'removeViewBox',
active: true
},
{
name: 'cleanupIDs',
active: false
}
]
})
]))
.pipe(dest(paths.ckanPublic + "images"))
};
// Copy fonts
const fonts = () => {
return src(paths.src.fonts + "**/*", { since: lastRun(fonts), encoding: false })
.pipe(dest(paths.ckanPublic + "fonts"))
};
// Copy src javascript
const javascript = () => {
return src([paths.src.javascript + "**/*"])
.pipe(dest(paths.ckanAssets + "javascript"))
};
const copyFontawesomeCss = () => {
return src([paths.src.fontawesome + "css/all.css", paths.src.fontawesome + "css/sharp-regular.css", paths.src.fontawesome + "css/sharp-solid.css"], { since: lastRun(copyFontawesomeCss), allowEmpty: true})
.pipe(concat('all.css'))
.pipe(dest(paths.ckanPublic + "/vendor/fontawesome/css/"))
}
const copyFontawesomeFonts = () => {
return src(paths.src.fontawesome + "webfonts/*", { since: lastRun(copyFontawesomeFonts), encoding: false })
.pipe(dest(paths.ckanPublic + "/vendor/fontawesome/webfonts/"))
}
const copyFontawesome = parallel(copyFontawesomeCss, copyFontawesomeFonts)
// Lint things (scss, js, etc)
export const lint = parallel(lintStyles)
// Simplified build (default export for CI)
export const build = parallel(ckanSass, javascript, images, fonts, fontsCss, copyFontawesome);
// Add linting and rebuilding ckan webassets when building locally
export const localBuild = series(lint, build, rebuildCkanWebassets);
// Watch for any file changes in the assets/src folder (javascript, css, images, fonts) and rebuild the assets
function watchFiles() {
watch(paths.src.src + "**/*", { ignoreInitial: false }, localBuild);
}
export { watchFiles as watch }
export default build