elk/nuxt.config.ts

182 lines
4.9 KiB
TypeScript
Raw Normal View History

2023-01-12 17:31:18 +01:00
import { createResolver } from '@nuxt/kit'
2022-11-27 07:54:56 +01:00
import Inspect from 'vite-plugin-inspect'
2022-12-18 01:15:19 +01:00
import { isCI, isDevelopment } from 'std-env'
import { isPreview } from './config/env'
import { i18n } from './config/i18n'
import { pwa } from './config/pwa'
import type { BuildInfo } from './types'
2023-01-12 17:31:18 +01:00
const { resolve } = createResolver(import.meta.url)
2022-11-13 06:34:43 +01:00
export default defineNuxtConfig({
typescript: {
tsConfig: {
exclude: ['../service-worker'],
vueCompilerOptions: {
jsxTemplates: true,
experimentalRfc436: true,
},
},
},
2022-11-13 06:34:43 +01:00
modules: [
'@vueuse/nuxt',
'@unocss/nuxt',
'@pinia/nuxt',
'@vue-macros/nuxt',
2022-11-28 11:24:05 +01:00
'@nuxtjs/i18n',
'@nuxtjs/color-mode',
'nuxt-security',
'~/modules/purge-comments',
'~/modules/setup-components',
2023-01-08 12:18:58 +01:00
'~/modules/build-env',
'~/modules/tauri/index',
'~/modules/pwa/index', // change to '@vite-pwa/nuxt' once released and remove pwa module
2023-01-13 19:57:31 +01:00
'~/modules/stale-dep',
['unplugin-vue-inspector/nuxt', {
enabled: false,
toggleButtonVisibility: 'never',
}],
2022-11-13 06:34:43 +01:00
],
experimental: {
payloadExtraction: false,
2022-11-13 06:34:43 +01:00
reactivityTransform: true,
inlineSSRStyles: false,
},
css: [
'@unocss/reset/tailwind.css',
2022-11-24 14:34:35 +01:00
'floating-vue/dist/style.css',
2022-11-13 17:05:32 +01:00
'~/styles/vars.css',
2022-11-15 17:39:25 +01:00
'~/styles/global.css',
'~/styles/tiptap.css',
2022-11-24 14:34:35 +01:00
'~/styles/dropdown.css',
2022-11-13 06:34:43 +01:00
],
2022-11-14 04:45:20 +01:00
alias: {
2022-12-21 02:06:39 +01:00
'querystring': 'rollup-plugin-node-polyfills/polyfills/qs',
'change-case': 'scule',
2023-01-12 17:31:18 +01:00
'semver': resolve('./mocks/semver'),
2022-11-14 04:45:20 +01:00
},
imports: {
dirs: [
'./composables/masto',
'./composables/push-notifications',
'./composables/settings',
'./composables/tiptap',
],
},
2022-11-15 18:14:10 +01:00
vite: {
define: {
2022-11-24 04:42:03 +01:00
'process.env.VSCODE_TEXTMATE_DEBUG': 'false',
2022-12-12 00:18:09 +01:00
'process.mock': ((!isCI || isPreview) && process.env.MOCK_USER) || 'false',
'process.test': 'false',
2022-11-15 18:14:10 +01:00
},
2022-11-23 00:27:01 +01:00
build: {
target: 'esnext',
2022-11-23 00:27:01 +01:00
},
2022-11-27 07:54:56 +01:00
plugins: [
Inspect(),
],
2022-11-15 18:14:10 +01:00
},
2022-11-14 04:33:09 +01:00
postcss: {
plugins: {
'postcss-nested': {},
},
},
2022-11-15 16:54:58 +01:00
runtimeConfig: {
2023-01-15 10:34:17 +01:00
adminKey: '',
cloudflare: {
accountId: '',
namespaceId: '',
apiToken: '',
},
public: {
env: '', // set in build-env module
buildInfo: {} as BuildInfo, // set in build-env module
2022-12-18 01:15:19 +01:00
pwaEnabled: !isDevelopment || process.env.VITE_DEV_PWA === 'true',
translateApi: '',
defaultServer: 'mas.to',
},
storage: {
driver: isCI ? 'cloudflare' : 'fs',
2022-11-30 22:28:55 +01:00
fsBase: 'node_modules/.cache/servers',
},
2022-11-15 16:54:58 +01:00
},
routeRules: {
2022-12-28 16:17:37 +01:00
'/api/list-servers': { swr: true },
'/manifest.webmanifest': {
headers: {
'Content-Type': 'application/manifest+json',
},
},
},
nitro: {
prerender: {
crawlLinks: true,
routes: ['/'],
ignore: ['/settings'],
},
},
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', href: '/favicon.ico', sizes: 'any' },
{ rel: 'icon', type: 'image/svg+xml', href: '/logo.svg' },
{ rel: 'apple-touch-icon', href: '/apple-touch-icon.png' },
],
2023-01-01 23:03:25 +01:00
meta: [
{ name: 'apple-mobile-web-app-status-bar-style', content: 'black-translucent' },
2023-01-11 23:42:52 +01:00
// open graph social image
{ property: 'og:title', content: 'Elk' },
2023-01-11 23:51:23 +01:00
{ property: 'og:description', content: 'A nimble Mastodon web client' },
2023-01-11 23:42:52 +01:00
{ property: 'og:type', content: 'website' },
{ property: 'og:image', content: 'https://elk.zone/elk-og.png' },
2023-01-11 23:42:52 +01:00
{ property: 'og:image:width', content: '3800' },
{ property: 'og:image:height', content: '1900' },
{ property: 'og:site_name', content: 'Elk' },
{ property: 'twitter:site', content: '@elk_zone' },
2023-01-12 00:08:20 +01:00
{ property: 'twitter:card', content: 'summary_large_image' },
2023-01-01 23:03:25 +01:00
],
},
},
security: {
headers: {
crossOriginEmbedderPolicy: false,
contentSecurityPolicy: {
value: {
'default-src': ['\'self\''],
'base-uri': ['\'self\''],
'connect-src': ['\'self\'', 'https:', 'http:', 'wss:', 'ws:'],
'font-src': ['\'self\''],
'form-action': ['\'none\''],
'frame-ancestors': ['\'none\''],
'img-src': ['\'self\'', 'https:', 'http:', 'data:'],
'media-src': ['\'self\'', 'https:', 'http:'],
'object-src': ['\'none\''],
'script-src': ['\'self\'', '\'unsafe-inline\''],
'script-src-attr': ['\'none\''],
'style-src': ['\'self\'', '\'unsafe-inline\''],
'upgrade-insecure-requests': true,
},
route: '/**',
},
},
rateLimiter: false,
},
colorMode: { classSuffix: '' },
i18n,
pwa,
2022-11-13 06:34:43 +01:00
})
declare global {
namespace NodeJS {
interface Process {
mock?: Record<string, any>
}
}
}