gulpfile.js

 avatar
unknown
javascript
3 years ago
15 kB
5
Indexable
const gulp = require('gulp');
// gulp core function
const {src, dest, series, parallel, watch} = require('gulp');
// gulp compress js
const uglify = require('gulp-uglify');
// gulp judgment
const gulpif = require('gulp-if');
// gulp compress css
const cleanCSS = require('gulp-clean-css');
// Delete Files
const del = require('delete');
// Refresh the browser in real time
const browserSync = require('browser-sync').create();
const reload = browserSync.reload;
// proxy
const {createProxyMiddleware} = require('http-proxy-middleware');
// According to html reference, files are merged
// const useref = require('gulp-useref');
// File merge
const concat = require('gulp-concat');
// rollup packaging, processing es6 modules
const {rollup} = require('rollup');
// rollup looks for node_modules module
const {nodeResolve} = require('@rollup/plugin-node-resolve');
// rollup converts commonjs module to es6 module
const commonjs = require('@rollup/plugin-commonjs');
// rollup code compression
const terser = require('rollup-plugin-terser').terser;
// rollup babel plugin, support the latest ES grammar
const babel = require('@rollup/plugin-babel').default;
// const gulpBabel = require('gulp-babel');
// Distinguish development and production environments
const production = process.env.NODE_ENV === 'production' ? true : false;

const pkg = require('./package.json');
const banner = `/*! @preserve
 * ${pkg.name}
 * version: ${pkg.version}
 * https://github.com/mengshukeji/Luckysheet
 */`;

// uglify js Compression configuration https://github.com/mishoo/UglifyJS#minify-options
const uglifyOptions = {
  compress: {
    drop_console: true
  }
}

// babel config
const babelConfig = {
  compact: false,
  babelHelpers: 'bundled',
  exclude: 'node_modules/**', // Only compile our source code
  plugins: [],
  presets: [
    ['@babel/preset-env', {
      useBuiltIns: 'usage',
      corejs: 3,
      targets: {
        chrome: 58,
        ie: 11
      }
    }]
  ]
};

// file handler paths
const paths = {
  // static resources,contains index.html, fonts and images,and extension plugins dependency
  staticHtml: ['src/*.html'],
  staticFonts: ['src/fonts/**'],
  staticAssets: ['src/assets/**'],
  staticImages: ['src/plugins/images/*.png'],
  staticExpendPlugins: ['src/expendPlugins/**', '!src/expendPlugins/**/plugin.js'],
  staticDemoData: ['src/demoData/*.js'],
  staticCssImages: ['src/css/**', '!src/css/*.css'],

  staticSokrates: ['src/sokrates/**/*.js'],

  // static resources dest
  destStaticHtml: ['dist'],
  destStaticFonts: ['dist/fonts'],
  destStaticAssets: ['dist/assets'],
  destStaticImages: ['dist/plugins/images'],
  destStaticExpendPlugins: ['dist/expendPlugins'],
  destStaticCssImages: ['dist/css'],

  destStaticSokrates: ['dist/sokrates'],

  //core es module
  core: ['src/**/*.js', 'src/expendPlugins/**/plugin.js', '!src/plugins/js/*.js',
    '!src/sokrates/**/*.js'
  ],

  //plugins src
  pluginsCss: ['src/plugins/css/*.css'],
  plugins: ['src/plugins/*.css'],
  css: ['src/css/*.css', 'node_modules/flatpickr/dist/themes/light.css'],
  pluginsJs: [
    'node_modules/jquery/dist/jquery.min.js',
    'node_modules/uuid/dist/umd/uuid.min.js',
    'src/plugins/js/clipboard.min.js',
    'src/plugins/js/spectrum.min.js',
    'src/plugins/js/jquery-ui.min.js',
    'src/plugins/js/jquery.mousewheel.min.js',
    // 'src/plugins/js/numeral.min.js',
    'src/plugins/js/html2canvas.min.js',
    'src/plugins/js/localforage.min.js',
    'src/plugins/js/lodash.min.js',
    'src/plugins/js/jstat.min.js',
    'src/plugins/js/crypto-api.min.js',
    'src/plugins/js/jquery.sPage.min.js'
  ],

  //plugins concat
  concatPluginsCss: 'pluginsCss.css',
  concatPlugins: 'plugins.css',
  concatCss: 'luckysheet.css',
  concatPluginsJs: 'plugin.js',
  concatSokratesJs: 'sokrates.js',

  //plugins dest
  destPluginsCss: ['dist/plugins/css'],
  destPlugins: ['dist/plugins'],
  destCss: ['dist/css'],
  destPluginsJs: ['dist/plugins/js'],

  // Package directory
  dist: 'dist',
};

// Clear the dist directory
function clean() {
  return del([paths.dist]);
}

// proxy middleware
const apiProxy = createProxyMiddleware('/luckysheet/', {
  target: 'http://luckysheet.lashuju.com/', // set your server address
  changeOrigin: true, // for vhosted sites
  ws: true, // proxy websockets
});

// Static server
function serve(done) {
  browserSync.init({
    server: {
      baseDir: paths.dist,
      middleware: [apiProxy],//proxy
    },
    ghostMode: false, //默认true,滚动和表单在任何设备上输入将被镜像到所有设备里,会影响本地的协同编辑消息,故关闭
  }, done)
}

// Monitoring file changes
function watcher(done) {
  watch(paths.core, {delay: 500}, series(core, reloadBrowser));

  // watch plugins and css
  watch(paths.pluginsCss, {delay: 500}, series(pluginsCss, reloadBrowser));
  watch(paths.plugins, {delay: 500}, series(plugins, reloadBrowser));
  watch(paths.css, {delay: 500}, series(css, reloadBrowser));
  watch(paths.pluginsJs, {delay: 500}, series(pluginsJs, reloadBrowser));

  // watch static
  watch(paths.staticHtml, {delay: 500}, series(copyStaticHtml, reloadBrowser));
  watch(paths.staticFonts, {delay: 500}, series(copyStaticFonts, reloadBrowser));
  watch(paths.staticAssets, {delay: 500}, series(copyStaticAssets, reloadBrowser));
  watch(paths.staticImages, {delay: 500}, series(copyStaticImages, reloadBrowser));
  watch(paths.staticExpendPlugins, {delay: 500}, series(copyStaticExpendPlugins, reloadBrowser));
  watch(paths.staticCssImages, {delay: 500}, series(copyStaticCssImages, reloadBrowser));

  watch(paths.staticSokrates, {delay: 500}, series(copyStaticSokratesStudent, reloadBrowser));
  watch(paths.staticSokrates, {delay: 500}, series(copyStaticSokratesStaff, reloadBrowser));
  watch(paths.staticSokrates, {delay: 500}, series(copyStaticSokratesLtiMaster, reloadBrowser));
  watch(paths.staticSokrates, {delay: 500}, series(copyStaticSokratesEventCalendar, reloadBrowser));
  watch(paths.staticSokrates, {delay: 500}, series(copyStaticSokratesMasterExtracurricular, reloadBrowser));

  done();
}

// Refresh browser
function reloadBrowser(done) {
  reload();

  done();
}

//Package the core code
async function core_rollup() {
  const bundle = await rollup({
    input: 'src/index.js',
    plugins: [
      nodeResolve(), // tells Rollup how to find date-fns in node_modules
      commonjs(), // converts date-fns to ES modules
      // postcss({
      // 	plugins: [],
      // 	extract: true,
      // 	// minimize: isProductionEnv,
      // }),
      production && terser(), // minify, but only in production
      babel(babelConfig)
    ],
  });

  bundle.write({
    file: 'dist/luckysheet.umd.js',
    format: 'umd',
    name: 'luckysheet',
    sourcemap: true,
    inlineDynamicImports: true,
    banner: banner
  });

  if (production) {
    bundle.write({
      file: 'dist/luckysheet.esm.js',
      format: 'esm',
      name: 'luckysheet',
      sourcemap: true,
      inlineDynamicImports: true,
      banner: banner
    });
  }

}

async function core() {

  await require('esbuild').buildSync({
    format: 'iife',
    globalName: 'luckysheet',
    entryPoints: ['src/index.js'],
    bundle: true,
    minify: production,
    banner: {js: banner},
    target: ['es2015'],
    sourcemap: true,
    outfile: 'dist/luckysheet.umd.js',
    logLevel: 'error',
  })
}

// According to the build tag in html, package js and css
function pluginsCss() {
  return src(paths.pluginsCss)
    .pipe(concat(paths.concatPluginsCss))
    .pipe(gulpif(production, cleanCSS()))
    .pipe(dest(paths.destPluginsCss))

}

function plugins() {
  return src(paths.plugins)
    .pipe(concat(paths.concatPlugins))
    .pipe(gulpif(production, cleanCSS()))
    .pipe(dest(paths.destPlugins));
}

function css() {
  return src(paths.css)
    .pipe(concat(paths.concatCss))
    .pipe(gulpif(production, cleanCSS()))
    .pipe(dest(paths.destCss));
}

function pluginsJs() {
  return src(paths.pluginsJs)
    .pipe(concat(paths.concatPluginsJs))
    .pipe(gulpif(production, uglify(uglifyOptions)))
    .pipe(dest(paths.destPluginsJs));
}

// Copy static resources
function copyStaticHtml() {
  return src(paths.staticHtml)
    .pipe(dest(paths.destStaticHtml));
}

function copyStaticFonts() {
  return src(paths.staticFonts)
    .pipe(dest(paths.destStaticFonts));
}

function copyStaticAssets() {
  return src(paths.staticAssets)
    .pipe(dest(paths.destStaticAssets));
}

function copyStaticImages() {
  return src(paths.staticImages)
    .pipe(dest(paths.destStaticImages));
}

function copyStaticExpendPlugins() {
  return src(paths.staticExpendPlugins)
    .pipe(dest(paths.destStaticExpendPlugins));
}

function copyStaticCssImages() {
  return src(paths.staticCssImages)
    .pipe(dest(paths.destStaticCssImages));
}

async function copyStaticSokratesStudent() {

  const bundle = await rollup({
    input: 'src/sokrates/student.js',
    plugins: [
      nodeResolve(), // tells Rollup how to find date-fns in node_modules
      commonjs(), // converts date-fns to ES modules
      production && terser(), // minify, but only in production
      babel(babelConfig)
    ],
  });

  if (production) {
    return await bundle.write({
      file: './dist/sokrates/student.js',
      format: 'es',
      name: 'student',
      sourcemap: true,
      inlineDynamicImports: true,
    });
  }

  return await bundle.write({
    file: './dist/sokrates/student.js',
    format: 'es',
    name: 'student',
    sourcemap: true
  });
}

async function copyStaticSokratesStaff() {

  const bundle = await rollup({
    input: 'src/sokrates/staff.js',
    plugins: [
      nodeResolve(), // tells Rollup how to find date-fns in node_modules
      commonjs(), // converts date-fns to ES modules
      production && terser(), // minify, but only in production
      babel(babelConfig)
    ],
  });

  if (production) {
    return await bundle.write({
      file: './dist/sokrates/staff.js',
      format: 'es',
      name: 'student',
      sourcemap: true,
      inlineDynamicImports: true,
    });
  }

  return await bundle.write({
    file: './dist/sokrates/staff.js',
    format: 'es',
    name: 'student',
    sourcemap: true
  });
}

async function copyStaticSokratesLtiMaster() {

  const bundle = await rollup({
    input: 'src/sokrates/lti-master.js',
    plugins: [
      nodeResolve(), // tells Rollup how to find date-fns in node_modules
      commonjs(), // converts date-fns to ES modules
      production && terser(), // minify, but only in production
      babel(babelConfig)
    ],
  });

  if (production) {
    return await bundle.write({
      file: './dist/sokrates/lti-master.js',
      format: 'es',
      name: 'lti-master',
      sourcemap: true,
      inlineDynamicImports: true,
    });
  }

  return await bundle.write({
    file: './dist/sokrates/lti-master.js',
    format: 'es',
    name: 'lti-master',
    sourcemap: true
  });
}

async function copyStaticSokratesEventCalendar() {

  const bundle = await rollup({
    input: 'src/sokrates/event-calendar.js',
    plugins: [
      nodeResolve(), // tells Rollup how to find date-fns in node_modules
      commonjs(), // converts date-fns to ES modules
      production && terser(), // minify, but only in production
      babel(babelConfig)
    ],
  });

  if (production) {
    return await bundle.write({
      file: './dist/sokrates/event-calendar.js',
      format: 'es',
      name: 'event-calendar',
      sourcemap: true,
      inlineDynamicImports: true,
    });
  }

  return await bundle.write({
    file: './dist/sokrates/event-calendar.js',
    format: 'es',
    name: 'event-calendar',
    sourcemap: true
  });
}

async function copyStaticSokratesMasterExtracurricular() {

  const bundle = await rollup({
    input: 'src/sokrates/master-extracurricular.js',
    plugins: [
      nodeResolve(), // tells Rollup how to find date-fns in node_modules
      commonjs(), // converts date-fns to ES modules
      production && terser(), // minify, but only in production
      babel(babelConfig)
    ],
  });

  if (production) {
    return await bundle.write({
      file: './dist/sokrates/master-extracurricular.js',
      format: 'es',
      name: 'master-extracurricular',
      sourcemap: true,
      inlineDynamicImports: true,
    });
  }

  return await bundle.write({
    file: './dist/sokrates/master-extracurricular.js',
    format: 'es',
    name: 'master-extracurricular',
    sourcemap: true
  });
}

async function copyStaticSokratesExtracurricularAttendance() {

  const bundle = await rollup({
    input: 'src/sokrates/extracurricular-attendance.js',
    plugins: [
      nodeResolve(), // tells Rollup how to find date-fns in node_modules
      commonjs(), // converts date-fns to ES modules
      production && terser(), // minify, but only in production
      babel(babelConfig)
    ],
  });

  if (production) {
    return await bundle.write({
      file: './dist/sokrates/extracurricular-attendance.js',
      format: 'es',
      name: 'extracurricular-attendance',
      sourcemap: true,
      inlineDynamicImports: true,
    });
  }

  return await bundle.write({
    file: './dist/sokrates/extracurricular-attendance.js',
    format: 'es',
    name: 'extracurricular-attendance',
    sourcemap: true
  });
}

const dev = series(clean, parallel(pluginsCss, plugins, css, pluginsJs, copyStaticHtml, copyStaticFonts, copyStaticAssets, copyStaticImages, copyStaticExpendPlugins, copyStaticCssImages, core, copyStaticSokratesStudent, copyStaticSokratesStaff, copyStaticSokratesLtiMaster, copyStaticSokratesEventCalendar, copyStaticSokratesMasterExtracurricular, copyStaticSokratesExtracurricularAttendance), watcher, serve);
const build = series(clean, parallel(pluginsCss, plugins, css, pluginsJs, copyStaticHtml, copyStaticFonts, copyStaticAssets, copyStaticImages, copyStaticExpendPlugins, copyStaticCssImages, core, copyStaticSokratesStudent, copyStaticSokratesStaff, copyStaticSokratesLtiMaster, copyStaticSokratesEventCalendar, copyStaticSokratesMasterExtracurricular, copyStaticSokratesExtracurricularAttendance));

exports.dev = dev;
exports.build = build;
exports.default = dev;
Editor is loading...