mirror of
https://github.com/HangarMC/Hangar.git
synced 2025-01-24 14:24:47 +08:00
128 lines
3.3 KiB
TypeScript
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"],
|
|
},
|
|
});
|