| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 | var gulp   = require('gulp')var $      = require('gulp-load-plugins')()var fs     = require('fs')var path   = require('path')var del    = require('del')//var colors = require('colors')var child_process = require('child_process')var theme            = {}var themeList        = require('./src/element-ui/config.js').filter(item => !item.hasBuild)var styleFileDir     = './src/assets/scss'var styleFileDirTemp = `${styleFileDir}-temp`var themeFileDir     = './public/element-theme'var et               = require('element-theme')var etOptions        = require('./package.json')['element-theme']var themeFileName    = etOptions.config.replace(/.*\/(.+\.scss)/, '$1')/** * 构建生成主题 */gulp.task('themes', () => {  if (themeList.length <= 0) { return del(styleFileDirTemp) }  // 删除临时文件,保证本次操作正常执行  //del(styleFileDirTemp)  console.log('del(styleFileDirTemp)');  // 拷贝一份scss样式文件夹,作为构建的临时处理文件夹  //child_process.spawnSync('cp', ['-r', styleFileDir, styleFileDirTemp])  console.log('copy styleFileDirTemp');  // 拷贝element组件scss变量样式文件至临时处理文件夹中,并修改相应配置信息  //child_process.spawnSync('cp', ['-r', etOptions.config, styleFileDirTemp])  etOptions.config = `${styleFileDirTemp}/${themeFileName}`  // 开始构建生成  fnCreate(themeList)  function fnCreate (themeList) {    if (themeList.length >= 1) {      // 保存当前构建生成的主题对象      theme = themeList[0]      console.log('\n')      console.log('-------------------- 待构建,主题 -------------------------')      console.log(themeList)      console.log('\n')      console.log('-------------------- 构建中,主题 -------------------------')      console.log(theme)      console.log('\n')      // 修改.scss临时文件中的$--color-primary主题变量值      var data = fs.readFileSync(etOptions.config, 'utf8')      var result = data.replace(/\$--color-primary:(.*) !default;/, `$--color-primary:${theme.color} !default;`)      fs.writeFileSync(path.resolve(etOptions.config), result)      // 修改aui.scss临时文件中引入element组件主题变量文件路径      var data = fs.readFileSync(`${styleFileDirTemp}/aui.scss`, 'utf8')      var result = data.replace(new RegExp(`(@import \")(.*\/)(${themeFileName}\";)`), '$1./$3')      fs.writeFileSync(path.resolve(`${styleFileDirTemp}/aui.scss`), result)      // 调用element-theme插件,生成element组件主题      etOptions.out = `${themeFileDir}/${theme.name}`      et.run(etOptions, () => {        // 生成后,构建同主题色aui.css项目主题        gulp.start(['styles'], () => {          // 递归下一步          themeList.splice(0, 1)          fnCreate(themeList)        })      })    } else {      // 删除临时文件      del(styleFileDirTemp)      console.log('\n')      console.log('-------------------- 构建完毕,删除临时文件 -------------------------')      console.log(styleFileDirTemp)      console.log('\n')      // 删除主题不需要的部分文件      var files = [        `${themeFileDir}/**/*.css`,        `!${themeFileDir}/**/index.css`,        `!${themeFileDir}/**/aui.css`,        `!${themeFileDir}/**/fonts`      ]      del(files)      console.log('-------------------- 构建完毕,删除主题独立组件文件 -------------------------')      console.log(files)      console.log('\n')    }  }})gulp.task('styles', () => {  return gulp.src([`${styleFileDirTemp}/aui.scss`])    .pipe($.sass().on('error', $.sass.logError))    .pipe($.autoprefixer({      browsers: etOptions.browsers,      cascade: false    }))    .pipe($.cleanCss())    .pipe($.rename('aui.css'))    .pipe(gulp.dest(`${themeFileDir}/${theme.name}`))})
 |