element-plus/packages/theme-chalk/gulpfile.ts

80 lines
1.7 KiB
TypeScript
Raw Normal View History

import chalk from 'chalk'
import gulp from 'gulp'
import gulpSass from 'gulp-sass'
import dartSass from 'sass'
import autoprefixer from 'gulp-autoprefixer'
import cleanCSS from 'gulp-clean-css'
import rename from 'gulp-rename'
import { buildOutput } from '../../build/paths'
import path from 'path'
const noElPrefixFile = /(index|base|display)/
const sass = gulpSass(dartSass)
export const distFolder = './lib'
/**
* compile theme-chalk scss & minify
* not use sass.sync().on('error', sass.logError) to throw exception
* @returns
*/
function compile() {
return gulp
.src('./src/*.scss')
.pipe(sass.sync())
.pipe(autoprefixer({ cascade: false }))
.pipe(
cleanCSS({}, details => {
console.log(
`${chalk.cyan(details.name)}: ${chalk.yellow(
details.stats.originalSize / 1000,
)} KB -> ${chalk.green(details.stats.minifiedSize / 1000)} KB`,
)
}),
)
.pipe(
rename(path => {
if (!noElPrefixFile.test(path.basename)) {
path.basename = `el-${path.basename}`
}
}),
)
.pipe(gulp.dest(distFolder))
}
/**
* copy font to lib/fonts
* @returns
*/
function copyFont() {
return gulp.src('./src/fonts/**').pipe(gulp.dest(`${distFolder}/fonts`))
}
const distBundle = path.resolve(buildOutput, './element-plus/theme-chalk')
/**
* copy from packages/theme-chalk/lib to dist/theme-chalk
*/
function copyToLib() {
return gulp.src(distFolder + '/**').pipe(gulp.dest(distBundle))
}
/**
* copy source file to packages
*/
function copySourceToLib() {
return gulp.src('./src/**').pipe(gulp.dest(path.resolve(distBundle, './src')))
}
export const build = gulp.series(
compile,
copyFont,
copyToLib,
copySourceToLib,
)
export default build