-
Notifications
You must be signed in to change notification settings - Fork 2
/
Gruntfile.js
81 lines (81 loc) · 1.71 KB
/
Gruntfile.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
module.exports = function(grunt) {
require("load-grunt-tasks")(grunt);
grunt.initConfig({
ts: {
default: {
tsconfig: "./tsconfig.json",
exclude: [
"src/example/**",
"src/bundle/**",
],
},
},
sass: {
options: {
implementation: require("node-sass"),
sourceMap: true,
importer: require("grunt-sass-tilde-importer"),
style: "compressed",
},
dist: {
files: {
"./dist/styles/index.css": "./src/styles/index.scss",
},
},
},
cssmin: {
options: {
mergeIntoShorthands: false,
roundingPrecision: -1,
},
target: {
files: {
"./dist/styles/index.css": "./dist/styles/index.css",
},
},
},
postcss: {
options: {
map: {
inline: false,
annotation: "./dist/styles",
},
processors: [
require("pixrem")(),
require("autoprefixer")({}),
],
},
dist: {
src: "./dist/styles/*.css",
},
},
shell: {
css2ts: {
command: `node ./node_modules/css-to-ts/dist/cli.js --rootDir "./dist/styles/" --outDir "./src/styles/" --pattern "index.css" --varName "STYLING"`,
},
},
"string-replace": {
inline: {
files: {
"./src/styles/index.ts": "./src/styles/index.ts",
},
options: {
replacements: [
{
pattern: /[\\]/ig,
replacement: `\\\\`,
},
],
},
},
},
});
grunt.loadNpmTasks("grunt-ts");
grunt.loadNpmTasks("grunt-sass");
grunt.loadNpmTasks("grunt-contrib-cssmin");
grunt.loadNpmTasks("grunt-postcss");
grunt.loadNpmTasks("grunt-string-replace");
grunt.loadNpmTasks("grunt-css-to-js");
grunt.registerTask("styles", ["sass", "postcss", "cssmin"]);
grunt.registerTask("default", ["styles", "shell:css2ts", "string-replace", "ts"]);
};