elk/nuxt.config.ts

134 lines
3.8 KiB
TypeScript
Raw Normal View History

import { fileURLToPath } from 'node:url'
2022-11-27 14:54:56 +08:00
import Inspect from 'vite-plugin-inspect'
2022-12-18 00:15:19 +00:00
import { isCI, isDevelopment } from 'std-env'
import { i18n } from './config/i18n'
import { pwa } from './config/pwa'
const isPreview = process.env.PULL_REQUEST === 'true'
2022-11-13 13:34:43 +08:00
export default defineNuxtConfig({
typescript: {
tsConfig: {
exclude: ['../service-worker'],
},
},
2022-11-13 13:34:43 +08:00
modules: [
'@vueuse/nuxt',
'@unocss/nuxt',
'@pinia/nuxt',
'@vue-macros/nuxt',
2022-11-28 18:24:05 +08:00
'@nuxtjs/i18n',
'~/modules/purge-comments',
'~/modules/setup-components',
'~/modules/pwa/index', // change to '@vite-pwa/nuxt' once released and remove pwa module
2022-11-13 13:34:43 +08:00
],
experimental: {
reactivityTransform: true,
inlineSSRStyles: false,
},
css: [
'@unocss/reset/tailwind.css',
2022-11-24 21:34:35 +08:00
'floating-vue/dist/style.css',
2022-11-14 00:05:32 +08:00
'~/styles/vars.css',
2022-11-15 17:39:25 +01:00
'~/styles/global.css',
'~/styles/tiptap.css',
2022-11-24 21:34:35 +08:00
'~/styles/dropdown.css',
2022-11-13 13:34:43 +08:00
],
2022-11-14 11:45:20 +08:00
alias: {
querystring: 'rollup-plugin-node-polyfills/polyfills/qs',
},
2022-11-16 01:14:10 +08:00
vite: {
// to make use of `TAURI_PLATFORM`, `TAURI_ARCH`, `TAURI_FAMILY`,
// `TAURI_PLATFORM_VERSION`, `TAURI_PLATFORM_TYPE` and `TAURI_DEBUG`
// env variables
envPrefix: ['VITE_', 'TAURI_'],
2022-11-16 01:14:10 +08:00
define: {
2022-11-27 16:54:00 +08:00
'import.meta.env.__BUILD_TIME__': JSON.stringify(new Date().toISOString()),
2022-12-05 02:18:39 +08:00
'import.meta.env.__BUILD_COMMIT__': JSON.stringify(process.env.COMMIT_REF || ''),
2022-11-24 11:42:03 +08:00
'process.env.VSCODE_TEXTMATE_DEBUG': 'false',
2022-12-11 23:18:09 +00:00
'process.mock': ((!isCI || isPreview) && process.env.MOCK_USER) || 'false',
2022-11-16 01:14:10 +08:00
},
2022-11-23 07:27:01 +08:00
build: {
target: process.env.TAURI_PLATFORM ? ['es2021', 'chrome100', 'safari13'] : 'esnext',
2022-11-23 07:27:01 +08:00
},
2022-11-27 14:54:56 +08:00
plugins: [
Inspect(),
],
2022-11-16 01:14:10 +08:00
},
2022-11-14 11:33:09 +08:00
postcss: {
plugins: {
'postcss-nested': {},
},
},
2022-11-15 23:54:58 +08:00
runtimeConfig: {
deployUrl: !isCI
? 'http://localhost:5314'
: isPreview
? process.env.DEPLOY_PRIME_URL
: 'https://elk.zone',
cloudflare: {
accountId: '',
namespaceId: '',
apiToken: '',
},
public: {
env: isCI ? isPreview ? 'staging' : 'production' : 'local',
2022-12-18 00:15:19 +00:00
pwaEnabled: !isDevelopment || process.env.VITE_DEV_PWA === 'true',
translateApi: '',
2022-11-30 21:28:55 +00:00
// Masto uses Mastodon version checks to see what features are enabled.
// Mastodon alternatives like GoToSocial will always fail these checks, so
// provide a way to disable them.
disableVersionCheck: false,
},
storage: {
driver: isCI ? 'cloudflare' : 'fs',
2022-11-30 21:28:55 +00:00
fsBase: 'node_modules/.cache/servers',
},
2022-11-15 23:54:58 +08:00
},
routeRules: {
'/manifest.webmanifest': {
headers: {
'Content-Type': 'application/manifest+json',
},
},
},
nitro: {
publicAssets: [
2022-12-08 14:24:36 +01:00
...(!isCI || isPreview ? [{ dir: fileURLToPath(new URL('./public-dev', import.meta.url)) }] : []),
],
prerender: {
crawlLinks: false,
2022-11-28 16:54:42 +00:00
routes: ['/', '/200.html'],
},
},
app: {
keepalive: true,
head: {
// Prevent arbitrary zooming on mobile devices
viewport: 'width=device-width,initial-scale=1,maximum-scale=1,user-scalable=0,viewport-fit=cover',
bodyAttrs: {
class: 'overflow-x-hidden',
},
link: [
{ rel: 'icon', type: 'image/png', href: '/favicon.png' },
{ rel: 'alternate icon', type: 'image/x-icon', href: '/favicon.ico' },
{ rel: 'icon', type: 'image/png', href: '/favicon-16x16.png', sizes: '16x16' },
{ rel: 'icon', type: 'image/png', href: '/favicon-32x32.png', sizes: '32x32' },
{ rel: 'mask-icon', href: '/safari-pinned-tab.svg', color: '#ffffff' },
{ rel: 'apple-touch-icon', href: '/apple-touch-icon.png', sizes: '180x180' },
],
meta: [{ name: 'theme-color', content: '#ffffff' }],
},
},
i18n,
pwa,
2022-11-13 13:34:43 +08:00
})
declare global {
namespace NodeJS {
interface Process {
mock?: Record<string, any>
}
}
}