const path = require('path') const fs = require('fs-extra') const watch = require('gulp-watch') const glob = require('fast-glob') const locales = require('../../app/_locales/index.json') const { createTask, composeSeries } = require('./task') module.exports = createStaticAssetTasks const copyTargets = [ { src: `./app/_locales/`, dest: `_locales`, }, { src: `./app/images/`, dest: `images`, }, { src: `./node_modules/eth-contract-metadata/images/`, dest: `images/contract`, }, { src: `./app/fonts/`, dest: `fonts`, }, { src: `./app/vendor/`, dest: `vendor`, }, { src: `./node_modules/@fortawesome/fontawesome-free/webfonts/`, dest: `fonts/fontawesome`, }, { src: `./ui/app/css/output/`, pattern: `*.css`, dest: ``, }, { src: `./app/`, pattern: `*.html`, dest: ``, }, ] const languageTags = new Set() for (const locale of locales) { const { code } = locale const tag = code.split('_')[0] languageTags.add(tag) } for (const tag of languageTags) { copyTargets.push({ src: `./node_modules/@formatjs/intl-relativetimeformat/dist/locale-data/${tag}.json`, dest: `intl/${tag}/relative-time-format-data.json`, }) } const copyTargetsDev = [ ...copyTargets, { src: './app/scripts/', pattern: '/chromereload.js', dest: ``, }, ] function createStaticAssetTasks ({ livereload, browserPlatforms }) { const prod = createTask('static:prod', composeSeries(...copyTargets.map((target) => { return async function copyStaticAssets () { await performCopy(target) } }))) const dev = createTask('static:dev', composeSeries(...copyTargetsDev.map((target) => { return async function copyStaticAssets () { await setupLiveCopy(target) } }))) return { dev, prod } async function setupLiveCopy (target) { const pattern = target.pattern || '/**/*' watch(target.src + pattern, (event) => { livereload.changed(event.path) performCopy(target) }) await performCopy(target) } async function performCopy (target) { await Promise.all(browserPlatforms.map(async (platform) => { if (target.pattern) { await copyGlob(target.src, `${target.src}${target.pattern}`, `./dist/${platform}/${target.dest}`) } else { await copyGlob(target.src, `${target.src}`, `./dist/${platform}/${target.dest}`) } })) } async function copyGlob (baseDir, srcGlob, dest) { const sources = await glob(srcGlob, { onlyFiles: false }) await Promise.all(sources.map(async (src) => { const relativePath = path.relative(baseDir, src) await fs.copy(src, `${dest}${relativePath}`) })) } }