build-bundle.js 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. const fs = require('fs')
  2. const chalk = require('chalk')
  3. const mkdirp = require('mkdirp')
  4. const babelify = require('babelify')
  5. const tinyify = require('tinyify')
  6. const browserify = require('browserify')
  7. const exorcist = require('exorcist')
  8. const glob = require('glob')
  9. const path = require('path')
  10. const { minify } = require('terser')
  11. const { transformFileAsync } = require('@babel/core')
  12. function handleErr (err) {
  13. console.error(chalk.red('✗ Error:'), chalk.red(err.message))
  14. }
  15. // eslint-disable-next-line no-shadow
  16. function buildBundle (srcFile, bundleFile, { minify = false, standalone = '' } = {}) {
  17. const b = browserify(srcFile, { debug: true, standalone })
  18. if (minify) {
  19. b.plugin(tinyify)
  20. }
  21. b.transform(babelify)
  22. b.on('error', handleErr)
  23. return new Promise((resolve) => {
  24. b.bundle()
  25. .pipe(exorcist(`${bundleFile}.map`))
  26. .pipe(fs.createWriteStream(bundleFile), 'utf8')
  27. .on('error', handleErr)
  28. .on('finish', () => {
  29. if (minify) {
  30. console.info(chalk.green(`✓ Built Minified Bundle [${standalone}]:`), chalk.magenta(bundleFile))
  31. } else {
  32. console.info(chalk.green(`✓ Built Bundle [${standalone}]:`), chalk.magenta(bundleFile))
  33. }
  34. resolve([bundleFile, standalone])
  35. })
  36. })
  37. }
  38. async function minifyBundle ([bundleFile, standalone]) {
  39. const minifiedFilePath = bundleFile.replace(/\.js$/, '.min.js')
  40. const sourceMapPath = `${minifiedFilePath}.map`
  41. const js = await fs.promises.readFile(bundleFile, 'utf-8')
  42. const { code, map } = await minify(js, {
  43. sourceMap: {
  44. content: fs.readFileSync(`${bundleFile}.map`, 'utf-8'),
  45. url:sourceMapPath,
  46. },
  47. toplevel: true,
  48. })
  49. return Promise.all([
  50. fs.promises.writeFile(minifiedFilePath, code),
  51. fs.promises.writeFile(sourceMapPath, map),
  52. ])
  53. .then(() => console.info(chalk.green(`✓ Built Minified Bundle [${standalone}]:`), chalk.magenta(minifiedFilePath)))
  54. }
  55. async function transpileDownForIE ([bundleFile, standalone]) {
  56. const minifiedFilePath = bundleFile.replace(/\.js$/, '.min.js')
  57. const sourceMapPath = `${minifiedFilePath}.map`
  58. const { code: js, map: inputMap } = await transformFileAsync(bundleFile, {
  59. compact: false,
  60. highlightCode: false,
  61. inputSourceMap: true,
  62. browserslistEnv: 'legacy',
  63. presets: [['@babel/preset-env', {
  64. modules: false,
  65. loose: true,
  66. targets: { ie:11 },
  67. }]],
  68. })
  69. const { code, map } = await minify(js, {
  70. sourceMap: {
  71. content: inputMap,
  72. url: sourceMapPath,
  73. },
  74. toplevel: true,
  75. })
  76. return Promise.all([
  77. fs.promises.writeFile(bundleFile, js),
  78. fs.promises.writeFile(`${bundleFile}.map`, JSON.stringify(inputMap)),
  79. fs.promises.writeFile(minifiedFilePath, code),
  80. fs.promises.writeFile(sourceMapPath, map),
  81. ]).then(() => {
  82. console.info(chalk.green(`✓ Built Bundle [${standalone} (ES5)]:`), chalk.magenta(bundleFile))
  83. console.info(chalk.green(`✓ Built Minified Bundle [${standalone} (ES5)]:`), chalk.magenta(minifiedFilePath))
  84. })
  85. }
  86. mkdirp.sync('./packages/uppy/dist')
  87. mkdirp.sync('./packages/@uppy/robodog/dist')
  88. mkdirp.sync('./packages/@uppy/locales/dist')
  89. const methods = [
  90. buildBundle(
  91. './packages/uppy/index.js',
  92. './packages/uppy/dist/uppy.js',
  93. { standalone: 'Uppy' }
  94. ).then(minifyBundle),
  95. buildBundle(
  96. './packages/uppy/bundle.js',
  97. './packages/uppy/dist/uppy.legacy.js',
  98. { standalone: 'Uppy (with polyfills)' }
  99. ).then(transpileDownForIE),
  100. buildBundle(
  101. './packages/@uppy/robodog/bundle.js',
  102. './packages/@uppy/robodog/dist/robodog.js',
  103. { standalone: 'Robodog' }
  104. ).then(minifyBundle),
  105. ]
  106. // Build minified versions of all the locales
  107. const localePackagePath = path.join(__dirname, '..', 'packages', '@uppy', 'locales', 'src', '*.js')
  108. glob.sync(localePackagePath).forEach((localePath) => {
  109. const localeName = path.basename(localePath, '.js')
  110. methods.push(
  111. buildBundle(
  112. `./packages/@uppy/locales/src/${localeName}.js`,
  113. `./packages/@uppy/locales/dist/${localeName}.min.js`,
  114. { minify: true }
  115. )
  116. )
  117. })
  118. // Add BUNDLE-README.MD
  119. methods.push(
  120. fs.promises.copyFile(
  121. `${__dirname}/../BUNDLE-README.md`,
  122. `./packages/uppy/dist/README.md`
  123. )
  124. )
  125. Promise.all(methods).then(() => {
  126. console.info(chalk.yellow('✓ JS bundles 🎉'))
  127. })