TMT-Demo/vite.config.ts

65 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";
// 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-06-26 20:22:22 +00:00
tsconfigPaths(),
VitePWA({
2024-03-17 15:45:17 +00:00
registerType: 'autoUpdate',
2023-02-25 17:35:07 +00:00
workbox: {
globPatterns: ['**/*.{js,css,html,ico,png,svg}']
},
2022-06-26 20:22:22 +00:00
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"
}
]
}
})
2023-02-05 01:08:46 +00:00
]
});