-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathicon.js
More file actions
90 lines (86 loc) · 2.64 KB
/
icon.js
File metadata and controls
90 lines (86 loc) · 2.64 KB
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
var path = require('path'),
fs = require('fs'),
util = require('./util'),
Stream = require("stream")
file = require('./file.js')
;
var configs = {
'photon' : {
resolve : 'photon/package.json',
fonts : 'fonts',
css : 'dist/css/photon.css',
prefixFrom: 'icon',
prefixTo: 'pt',
name: 'photon',
sassFile : 'sass/elements/icons/_icons-photon.sass',
jsFile : 'src/icons/photon.js',
htmlFile : 'demo/src/DemoPhoton.vue',
htmlFormat : '<label title="%content"><i class="%name"></i><span>%name</span></label>',
},
'font-awesome' : {
resolve : 'font-awesome/package.json',
fonts : 'fonts',
css : 'css/font-awesome.css',
prefixFrom: 'fa',
prefixTo: 'fa',
name: 'font-awesome',
jsFile : 'src/icons/font-awesome.js',
sassFile : 'sass/elements/icons/_icons-font-awesome.sass',
htmlFile : 'demo/src/DemoFontAwesome.vue',
htmlFormat : '<label title="%content"><i class="%name"></i><span>%name</span></label>',
}
}
function getConfig(config) {
if (typeof config == 'string') {
config = configs[config];
}
return config;
}
function resolveIcon (config) {
config = getConfig(config)
let dir = require.resolve(config.resolve)
let stat = fs.statSync(dir)
if (!stat.isDirectory()) {
dir = path.dirname(dir)
}
let fontsDir = path.resolve(dir, config.fonts)
let cssFile = path.resolve(dir, config.css)
let distFonts = path.resolve(__dirname, '../dist/fonts')
let loadCss = () => file.readFileAsync(cssFile).then((ret) => {
ret = {content: ret.toString()}
ret.mat = util.matchIcon(config.prefixFrom, ret.content)
return ret
})
let ret = {
updateIcons() {
return loadCss().then((ret) => {
let {content, mat} = ret
let sassText = util.replaceIcon(mat, config.prefixTo);
sassText = '=make-icons-' + config.name + '\r\n' + sassText + '\r\n';
return file.writeFileAsync(config.sassFile, sassText).then(() => ret)
})
.then(({content, mat}) => {
let data = mat.map(it => `'${config.prefixTo}${it[0]}'`).join(',\n ')
data = `export default [\n ${data}\n]\n`
return file.writeFileAsync(config.jsFile, data)
})
// .then(({content, mat}) => {
// return file.readFileAsync(config.htmlFile).then((html) => {
// html = util.replaceHtmlBlock(html.toString(), mat, config.prefixTo, config.htmlFormat);
// return file.writeFileAsync(config.htmlFile, html)
// })
// })
},
copyFonts () {
return file.mkdirAsync(distFonts).then(() => {
return file.readdirAsync(fontsDir, true).then((ret) => {
return Promise.all(ret.map((it) => {
return file.copyFileAsync(it.filePath, path.resolve(distFonts, it.fileName))
}))
})
})
}
}
return ret
}
exports.resolveIcon = resolveIcon;