1 Star 0 Fork 864

fork / vxe-table

forked from xuliangzhan / vxe-table 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
gulpfile.js 5.24 KB
一键复制 编辑 原始数据 按行查看 历史
const fs = require('fs')
const gulp = require('gulp')
const XEUtils = require('xe-utils')
const del = require('del')
const babel = require('gulp-babel')
const uglify = require('gulp-uglify')
const rename = require('gulp-rename')
const replace = require('gulp-replace')
const clean = require('gulp-clean')
const sass = require('gulp-sass')
const cleanCSS = require('gulp-clean-css')
const prefixer = require('gulp-autoprefixer')
const merge = require('merge-stream')
const pack = require('./package.json')
const ts = require('gulp-typescript')
const time = Date.now()
const components = [
'v-x-e-table',
'vxe-table',
'icon',
'filter',
'menu',
'edit',
'export',
'keyboard',
'validator',
'header',
'footer',
'column',
'colgroup',
'toolbar',
'grid',
'pager',
'checkbox',
'checkbox-group',
'radio',
'radio-group',
'radio-button',
'input',
'textarea',
'button',
'modal',
'tooltip',
'form',
'form-item',
'form-gather',
'select',
'optgroup',
'option',
'switch',
'list',
'pulldown',
'table'
]
const languages = [
'zh-CN',
'zh-TC',
'zh-HK',
'zh-MO',
'zh-TW',
'en-US',
'ja-JP'
]
const styleCode = `require('./style.css')`
gulp.task('build_modules', () => {
return gulp.src('packages/**/*.ts')
.pipe(replace('process.env.VUE_APP_VXE_TABLE_VERSION', `"${pack.version}"`))
.pipe(replace('process.env.VUE_APP_VXE_TABLE_ENV', 'process.env.NODE_ENV'))
.pipe(ts({
strict: true,
moduleResolution: 'node',
noImplicitAny: true,
target: 'es5',
module: 'esnext',
lib: ['dom', 'esnext']
}))
.pipe(gulp.dest('es'))
.pipe(babel({
presets: [
'@babel/env'
],
plugins: []
}))
.pipe(gulp.dest('lib'))
.pipe(uglify())
.pipe(rename({
suffix: '.min',
extname: '.js'
}))
.pipe(gulp.dest('lib'))
})
gulp.task('build_i18n', () => {
languages.forEach(code => {
fs.writeFileSync(`lib/locale/lang/${code}.d.ts`, `declare const langMsgs: { [key: string]: any }\nexport default langMsgs`)
fs.writeFileSync(`es/locale/lang/${code}.d.ts`, `declare const langMsgs: { [key: string]: any }\nexport default langMsgs`)
})
const rest = languages.map(code => {
const name = XEUtils.camelCase(code).replace(/^[a-z]/, firstChat => firstChat.toUpperCase())
const isZHTC = ['zh-HK', 'zh-MO', 'zh-TW'].includes(code)
return gulp.src(`packages/locale/lang/${isZHTC ? 'zh-TC' : code}.ts`)
.pipe(ts({
strict: true,
moduleResolution: 'node',
noImplicitAny: true,
target: 'esnext',
lib: ['dom', 'esnext']
}))
.pipe(babel({
moduleId: `vxe-table-lang.${code}`,
presets: ['@babel/env'],
plugins: [
['@babel/transform-modules-umd', {
globals: {
[`vxe-table-language.${code}`]: `VXETableLang${name}`
},
exactGlobals: true
}]
]
}))
.pipe(rename({
basename: code,
suffix: '.umd',
extname: '.js'
}))
.pipe(gulp.dest('lib/locale/lang'))
.pipe(uglify())
.pipe(rename({
basename: code,
suffix: '.min',
extname: '.js'
}))
.pipe(gulp.dest('lib/locale/lang'))
})
return merge(...rest)
})
gulp.task('copy_ts', () => {
return gulp.src('packages/**/*.d.ts')
.pipe(gulp.dest('es'))
.pipe(gulp.dest('lib'))
})
gulp.task('build_lib', () => {
return merge(
gulp.src('es/index.common.js')
.pipe(rename({
basename: 'index',
suffix: '.esm',
extname: '.js'
}))
.pipe(gulp.dest('es')),
gulp.src('lib_temp/index.umd.js')
.pipe(gulp.dest('lib')),
gulp.src('lib_temp/index.umd.min.js')
.pipe(gulp.dest('lib')),
gulp.src('lib_temp/index.css')
.pipe(rename({
basename: 'style',
extname: '.css'
}))
.pipe(gulp.dest('es'))
.pipe(gulp.dest('lib'))
.pipe(rename({
basename: 'style',
suffix: '.min',
extname: '.css'
}))
.pipe(gulp.dest('es'))
.pipe(gulp.dest('lib'))
)
})
gulp.task('build_style', () => {
const rest = components.map(name => {
return gulp.src(`styles/${name}.scss`)
.pipe(replace(/(\/\*\*Variable\*\*\/)/, `@import './variable.scss';\n`))
.pipe(sass())
.pipe(prefixer({
borwsers: ['last 1 version', '> 1%', 'not ie <= 8'],
cascade: true,
remove: true
}))
.pipe(rename({
basename: 'style',
extname: '.css'
}))
.pipe(gulp.dest(`es/${name}`))
.pipe(rename({
basename: 'style',
extname: '.css'
}))
.pipe(gulp.dest(`lib/${name}/style`))
.pipe(cleanCSS())
.pipe(rename({
basename: 'style',
suffix: '.min',
extname: '.css'
}))
.pipe(gulp.dest(`lib/${name}/style`))
})
return merge(...rest)
})
gulp.task('build_clean', () => {
return del(['lib', 'es'])
})
gulp.task('build', gulp.series('build_clean', 'build_modules', 'build_i18n', 'copy_ts', 'build_style', 'build_lib', () => {
components.forEach(name => {
fs.writeFileSync(`lib/${name}/style/index.js`, styleCode)
})
return del([
'lib_temp',
'lib/index.esm.js',
'lib/index.esm.min.js',
'es/index.common.js'
])
}))
JavaScript
1
https://gitee.com/my_fork/vxe-table.git
git@gitee.com:my_fork/vxe-table.git
my_fork
vxe-table
vxe-table
master

搜索帮助