Hangar/frontend/vite.config.ts

128 lines
3.3 KiB
TypeScript

import VueI18n from "@intlify/vite-plugin-vue-i18n";
import Vue from "@vitejs/plugin-vue";
import path from "node:path";
import IconsResolver from "unplugin-icons/resolver";
import Icons from "unplugin-icons/vite";
import Components from "unplugin-vue-components/vite";
import { defineConfig } from "vite";
import EslintPlugin from "vite-plugin-eslint";
import Pages from "vite-plugin-pages";
import { VitePWA } from "vite-plugin-pwa";
import Layouts from "vite-plugin-vue-layouts";
import WindiCSS from "vite-plugin-windicss";
import viteSSR from "vite-ssr/plugin";
import prettier from "./src/lib/plugins/prettier";
// seriously? just shit up, lol
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
import { default as proxyConfig } from "./proxy.config";
export default defineConfig({
resolve: {
alias: {
"~/": `${path.resolve(__dirname, "src")}/`,
},
},
plugins: [
viteSSR(),
Vue({
include: [/\.vue$/, /\.md$/],
}),
// https://github.com/hannoeru/vite-plugin-pages
Pages({
extensions: ["vue", "md"],
}),
// https://github.com/JohnCampionJr/vite-plugin-vue-layouts
Layouts(),
// https://github.com/antfu/unplugin-vue-components
Components({
// we don't want to import components, just icons
dirs: ["none"],
// auto import icons
resolvers: [
// https://github.com/antfu/vite-plugin-icons
IconsResolver({
componentPrefix: "icon",
enabledCollections: ["mdi"],
}),
],
dts: "src/types/generated/icons.d.ts",
}),
// https://github.com/antfu/unplugin-icons
Icons({
autoInstall: true,
}),
// https://github.com/windicss/vite-plugin-windicss
WindiCSS({
safelist: "prose prose-sm m-auto",
}),
// https://github.com/antfu/vite-plugin-pwa
VitePWA({
includeAssets: ["favicon/*"],
strategies: "injectManifest",
disable: true,
manifest: {
name: "Hangar | PaperMC",
short_name: "Hangar",
description: "Plugin repository for Paper plugins and more!",
theme_color: "#ffffff",
icons: [
{
src: "/favicon/android-chrome-192x192.png",
sizes: "192x192",
type: "image/png",
},
{
src: "/favicon/android-chrome-512x512.png",
sizes: "512x512",
type: "image/png",
},
{
src: "/favicon/android-chrome-512x512.png",
sizes: "512x512",
type: "image/png",
purpose: "any maskable",
},
],
},
}),
// https://github.com/intlify/bundle-tools/tree/main/packages/vite-plugin-vue-i18n
VueI18n({
runtimeOnly: false,
include: [path.resolve(__dirname, "src/locales/*.json")],
}),
EslintPlugin({
fix: true,
}),
prettier(),
],
optimizeDeps: {
include: ["vue", "vue-router", "@vueuse/core", "@vueuse/head", "swagger-ui-dist"],
exclude: ["vue-demi"],
},
envDir: ".env",
envPrefix: "HANGAR",
server: {
proxy: proxyConfig.default,
},
// ssr options aren't part of release types for vite cause its still marked as experimental
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
ssr: {
noExternal: ["lodash-es"],
},
});