-
Notifications
You must be signed in to change notification settings - Fork 0
/
Gruntfile.js
123 lines (122 loc) · 4.62 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
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
module.exports = function(grunt) {
grunt.initConfig({
copy: {
vue: {
options: {
process: function(content, srcpath) {
let componentName = srcpath.replace(/src\/components\/.*\//gm, '');
componentName = componentName.replace('.vue', '');
content = content.replace(/src=".*"/gm, '');
content = content.replace(/lang=".*"/gm, '');
content = content.replace(/ /gm, '');
content = content.replace("<template></template>", "<template>@@include('src/components/" + componentName + "/" + componentName + ".html')</template>")
content = content.replace("<script></script>", "<script>@@include('src/components/" + componentName + "/" + componentName + ".js')</script>")
content = content.replace("<style></style>", "<style>@@include('src/components/" + componentName + "/" + componentName + ".css')</style>")
content = content.replace("<stylescoped></style>", "<style scoped>@@include('src/components/" + componentName + "/" + componentName + ".css')</style>")
return content;
}
},
files: grunt.file.expand(['src/components/*/']).map(function(cwd) {
return {
expand: true,
cwd: cwd,
src: ['*.vue'],
dest: 'dist/src/components'
}
})
},
plugin: {
options: {
process: function(content, srcpath) {
return content.replace('skateui.js', 'skateui.min.js');
}
},
files: [
{ expand: true, src: ['src/plugins/skateui.js'], dest: 'dist/'}
]
},
assets: {
files: [
{ expand: true, src: ['src/assets/normalize.css'], dest: 'dist/'}
]
},
},
browserify: {
lib: {
files: [
{ src: ['src/lib/skateui.js'], dest: 'dist/src/lib/skateui.min.js' }
],
options: {
transform: [['babelify', {'presets': ['@babel/preset-env']}], 'uglifyify'],
browserifyOptions: {
debug: true
}
}
}
},
less: {
component_less: {
options: {
compress: true,
},
files: grunt.file.expand(['src/components/*/']).map(function(cwd) {
return {
expand: true,
cwd: cwd,
src: ['*.less'],
dest: cwd,
ext: '.css'
}
}),
},
},
pug: {
component_pug: {
options: {
doctype: "html"
},
files: grunt.file.expand(['src/components/*/']).map(function(cwd) {
return {
expand: true,
cwd: cwd,
src: ['*.pug'],
dest: cwd,
ext: '.html'
}
})
}
},
includereplace: {
fileBuild: {
options: {
includesDir: './'
},
files: grunt.file.expand(['dist/src/components/']).map(function(cwd) {
return {
cwd: cwd,
expand: true,
src: ['*.vue'],
dest: './' + cwd
}
})
}
},
replace: {
assets: {
src: ['dist/src/components/sui-app.vue'],
overwrite: true,
replacements: [{
from: '../../assets/normalize.css',
to: '../assets/normalize.css'
}]
},
}
});
grunt.loadNpmTasks('grunt-contrib-copy');
grunt.loadNpmTasks('grunt-browserify');
grunt.loadNpmTasks('grunt-contrib-less');
grunt.loadNpmTasks('grunt-contrib-pug');
grunt.loadNpmTasks('grunt-contrib-uglify-es');
grunt.loadNpmTasks('grunt-include-replace');
grunt.loadNpmTasks('grunt-text-replace');
};