-
Notifications
You must be signed in to change notification settings - Fork 0
/
taskfile.yml
149 lines (127 loc) · 3.67 KB
/
taskfile.yml
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
version: '3'
silent: true
env:
## CSS
CSS_SRC_FOLDER: sources/stylesheets
CSS_OUT_FOLDER: stylesheets
CSS_ENTRIES: main
SASS_FLAGS: -I node_modules/ --no-source-map
CUSTOM_STYLES_CSS_SRC_FOLDER: sources/components/custom-styles
CUSTOM_STYLES_CSS_OUT_FOLDER: components
## JS
JS_SRC_FOLDER: sources/javascripts
JS_OUT_FOLDER: javascripts
JS_ENTRIES: application editmode
ROLLUP_FLAGS: --format=umd -p @rollup/plugin-node-resolve
## ASSETS
ASSETS_SRC_FOLDER: sources/assets
ASSETS_MINIFY_FOLDER: minify
ASSETS_COPY_FOLDER: copy
ASSETS_OUT_FOLDER: assets
## IMAGES
IMAGES_SRC_FOLDER: sources/images
IMAGES_MINIFY_FOLDER: minify
IMAGES_COPY_FOLDER: copy
IMAGES_OUT_FOLDER: images
tasks:
build-css:
cmds:
- |
echo "Building CSS"
for entry in $CSS_ENTRIES; do
npx sass $SASS_FLAGS $CSS_SRC_FOLDER/$entry.scss:$CSS_OUT_FOLDER/$entry.css
done
minify-css:
cmds:
- |
echo "Minifying CSS"
for entry in $CSS_ENTRIES; do
npx sass $SASS_FLAGS --style=compressed $CSS_SRC_FOLDER/$entry.scss:$CSS_OUT_FOLDER/$entry.min.css
done
build-custom-styles-css:
cmds:
- |
echo "Building custom styles CSS"
if [ -e $CUSTOM_STYLES_CSS_SRC_FOLDER/*.scss ]; then
for entry in $CUSTOM_STYLES_CSS_SRC_FOLDER/*.scss; do
npx sass $SASS_FLAGS $entry:$CUSTOM_STYLES_CSS_OUT_FOLDER/$(basename "${entry%.*}").tpl
done
fi
css:
cmds:
- task: build-css
- task: minify-css
- task: build-custom-styles-css
- echo "CSS build done"
watch-css:
cmds:
- npx chokidar $CSS_SRC_FOLDER/* $CUSTOM_STYLES_CSS_SRC_FOLDER/* -c "npx task css"
build-js:
cmds:
- |
echo "Building JS"
npx rollup -c
for entry in $JS_ENTRIES; do
npx rollup $ROLLUP_FLAGS $JS_SRC_FOLDER/$entry.temp.js --file $JS_OUT_FOLDER/$entry.js
done
minify-js:
cmds:
- |
echo "Minifying JS"
npx rollup -c
for entry in $JS_ENTRIES; do
npx rollup $ROLLUP_FLAGS $JS_SRC_FOLDER/$entry.temp.js --file $JS_OUT_FOLDER/$entry.min.js --plugin terser
done
cleanup-temp-js:
cmds:
- del-cli $JS_SRC_FOLDER/*.temp.js $JS_SRC_FOLDER/temp.js
js:
cmds:
- task: build-js
- task: minify-js
- task: cleanup-temp-js
watch-js:
cmds:
- npx chokidar $JS_SRC_FOLDER/* -c "npx task js"
process-assets:
cmds:
- |
echo "Processing assets"
npx imagemin $ASSETS_SRC_FOLDER/$ASSETS_MINIFY_FOLDER/* --out-dir $ASSETS_OUT_FOLDER
echo "Copying assets"
cpy $ASSETS_SRC_FOLDER/$ASSETS_COPY_FOLDER/* $ASSETS_OUT_FOLDER --flat
process-images:
cmds:
- |
echo "Processing images"
npx imagemin $IMAGES_SRC_FOLDER/$IMAGES_MINIFY_FOLDER/* --out-dir $IMAGES_OUT_FOLDER
echo "Copying images"
cpy $IMAGES_SRC_FOLDER/$IMAGES_COPY_FOLDER/* $IMAGES_OUT_FOLDER --flat
watch-assets:
cmds:
- npx chokidar $ASSETS_SRC_FOLDER/* -c "npx task process-assets"
watch-images:
cmds:
- npx chokidar $IMAGES_SRC_FOLDER/* -c "npx task process-images"
dev:
cmds:
- echo "Running dev workflow"
- npx task watch-css &
npx task watch-js &
npx task watch-assets &
npx task watch-images
dev-kit:
cmds:
- echo "Running dev kit workflow"
- npx task watch-css &
npx task watch-js &
npx task watch-assets &
npx task watch-images &
kit watch
prod:
cmds:
- echo "Running prod workflow"
- task: css
- task: js
- task: process-assets
- task: process-images