UNPKG

tify

Version:

A slim and mobile-friendly IIIF document viewer

100 lines (89 loc) 3.05 kB
import { defineConfig } from 'vite'; import { readdirSync, readFileSync } from 'node:fs'; import { inspect } from 'node:util'; import vue from '@vitejs/plugin-vue'; import componentsAutoImport from 'unplugin-vue-components/vite'; // eslint-disable-line import/no-unresolved import banner from 'vite-plugin-banner'; import eslint from 'vite-plugin-eslint'; import sassGlobImport from 'vite-plugin-sass-glob-import'; import 'dotenv/config'; import pkg from './package.json'; const repositoryUrl = pkg.repository.url.replace(/git\+(.+)\.git/, '$1'); const transformIndexPlugin = () => ({ transformIndexHtml(html) { const translationsDir = './public/translations'; const petiteVue = readFileSync('./node_modules/petite-vue/dist/petite-vue.iife.js').toString().trim(); const languages = { en: 'English' }; readdirSync(translationsDir).forEach((file) => { languages[file.split('.')[0]] = JSON.parse(readFileSync(`${translationsDir}/${file}`)).$language; }); return html .replace(/\$VITE_PETITE_VUE;?/, petiteVue) .replace('$VITE_LANGUAGES', inspect(languages, { breakLength: Infinity, compact: true })); }, }); // https://vitejs.dev/config/ export default defineConfig({ base: process.env.BASE || '/', build: { outDir: process.env.OUTDIR || './dist', rollupOptions: { output: { // https://rollupjs.org/guide/en/#outputentryfilenames entryFileNames: process.env.HASHED ? 'tify.[hash].js' : 'tify.js', // https://rollupjs.org/guide/en/#outputassetfilenames assetFileNames: process.env.HASHED ? 'tify.[hash].[ext]' : 'tify.[ext]', }, }, }, // https://vitejs.dev/config/#environment-variables define: { ENV: { blobBaseUrl: `${repositoryUrl}/blob/v${pkg.version}`, bugsUrl: pkg.bugs.url, license: pkg.license, repositoryUrl, version: pkg.version, }, }, plugins: [ // Prepend copyright notice to each compiled file banner( '/*!' + `\nTIFY v${pkg.version}` + `\n(c) 2017-${new Date().getFullYear()}` + ' Göttingen State and University Library (https://www.sub.uni-goettingen.de/)' + `\n${pkg.license}` + `\n${pkg.homepage}` + '\n*/', ), componentsAutoImport({ dts: false, // disable generating components.d.ts file resolvers: [ (componentName) => { // NOTE: Full path required for unit tests with Vitest // Replacing "\" with "/" so it works on Windows; path.normalize cannot help here const baseDir = __dirname.replaceAll('\\', '/'); const dir = `${baseDir}/src/components${componentName.startsWith('Icon') ? '/icons' : ''}`; return { name: componentName, from: `${dir}/${componentName}.vue`, }; }, ], }), eslint({ cache: true, // Poor man's ignore file parser, since --ignore-path is not supported exclude: readFileSync('.gitignore') .toString() .split('\n') .filter((line) => line && !line.startsWith('#')) .map((line) => (!line.endsWith('*') ? `${line}/**` : line)), fix: true, }), sassGlobImport(), transformIndexPlugin(), vue(), ], });