chromatic-lattice/vite.config.ts

67 lines
1.9 KiB
TypeScript
Raw Normal View History

import vue from "@vitejs/plugin-vue";
import vueJsx from "@vitejs/plugin-vue-jsx";
import { defineConfig } from "vite";
2022-06-26 20:22:22 +00:00
import { VitePWA } from "vite-plugin-pwa";
import tsconfigPaths from "vite-tsconfig-paths";
2022-06-26 20:22:22 +00:00
import projInfo from "./src/data/projInfo.json";
2022-10-14 12:57:18 +00:00
import jsonDts from "unplugin-json-dts/vite";
// https://vitejs.dev/config/
export default defineConfig({
base: "./",
build: {
rollupOptions: {
2022-07-26 20:37:38 +00:00
output: {
manualChunks(id) {
2022-07-26 20:37:38 +00:00
if (id.includes("node_modules")) {
return id.toString().split("node_modules/")[1].split("/")[0].toString();
}
}
}
}
},
2022-07-15 06:58:23 +00:00
resolve: {
alias: {
2022-07-26 20:37:38 +00:00
vue: "vue/dist/vue.esm-bundler.js"
2022-07-15 06:58:23 +00:00
}
},
plugins: [
vue(),
vueJsx({
// options are passed on to @vue/babel-plugin-jsx
}),
2022-10-14 12:57:18 +00:00
jsonDts(),
2022-06-26 20:22:22 +00:00
tsconfigPaths(),
VitePWA({
includeAssets: ["Logo.svg", "favicon.ico", "robots.txt", "apple-touch-icon.png"],
manifest: {
name: projInfo.title,
short_name: projInfo.title,
description: projInfo.description,
theme_color: "#2E3440",
icons: [
{
src: "pwa-192x192.png",
sizes: "192x192",
type: "image/png"
},
{
src: "pwa-512x512.png",
sizes: "512x512",
type: "image/png"
},
{
src: "pwa-512x512.png",
sizes: "512x512",
type: "image/png",
purpose: "any maskable"
}
]
}
})
],
test: {
environment: "jsdom"
}
});