build.js 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. const fs = require('fs')
  2. const path = require('path')
  3. const rollup = require('rollup')
  4. const babel = require('rollup-plugin-babel')
  5. const uglify = require('rollup-plugin-uglify')
  6. const resolve = require('rollup-plugin-node-resolve')
  7. const commonjs = require('rollup-plugin-commonjs')
  8. const version = process.env.VERSION || require('./package.json').version
  9. const banner =
  10. '/*!\n' +
  11. ' * Vue-Lazyload.js v' + version + '\n' +
  12. ' * (c) ' + new Date().getFullYear() + ' Awe <hilongjw@gmail.com>\n' +
  13. ' * Released under the MIT License.\n' +
  14. ' */\n'
  15. async function build (options, output) {
  16. try {
  17. const bundle = await rollup.rollup(options)
  18. let { code } = await bundle.generate({
  19. format: output.format,
  20. name: 'VueLazyload'
  21. })
  22. code = rewriteVersion(code)
  23. await write(path.resolve(__dirname, output.filename), code)
  24. } catch (e) {
  25. console.error(e)
  26. }
  27. }
  28. function rewriteVersion (code) {
  29. return code.replace('__VUE_LAZYLOAD_VERSION__', version)
  30. }
  31. function getSize (code) {
  32. return (code.length / 1024).toFixed(2) + 'kb'
  33. }
  34. function blue (str) {
  35. return '\x1b[1m\x1b[34m' + str + '\x1b[39m\x1b[22m'
  36. }
  37. function write (dest, code) {
  38. return new Promise(function (resolve, reject) {
  39. code = banner + code
  40. fs.writeFile(dest, code, function (err) {
  41. if (err) return reject(err)
  42. console.log(blue(dest) + ' ' + getSize(code))
  43. resolve()
  44. })
  45. })
  46. }
  47. build({
  48. input: path.resolve(__dirname, 'src/index.js'),
  49. plugins: [
  50. resolve(),
  51. commonjs(),
  52. babel({ runtimeHelpers: true }),
  53. uglify()
  54. ]
  55. }, {
  56. format: 'umd',
  57. filename: 'vue-lazyload.js'
  58. })
  59. build({
  60. input: path.resolve(__dirname, 'src/index.js'),
  61. plugins: [
  62. resolve(),
  63. commonjs(),
  64. babel({ runtimeHelpers: true })
  65. ]
  66. }, {
  67. format: 'es',
  68. filename: 'vue-lazyload.esm.js'
  69. })