2024-09-30 17:11:56 +09:00
|
|
|
import type { BuildInfo } from './types'
|
2023-01-29 07:52:01 -08:00
|
|
|
import { createResolver, useNuxt } from '@nuxt/kit'
|
2023-01-16 09:48:57 +00:00
|
|
|
import { isCI, isDevelopment, isWindows } from 'std-env'
|
2023-01-08 12:17:09 +01:00
|
|
|
import { isPreview } from './config/env'
|
2024-02-24 17:46:14 +01:00
|
|
|
import { currentLocales } from './config/i18n'
|
2024-09-30 17:11:56 +09:00
|
|
|
import { pwa } from './config/pwa'
|
2022-12-08 11:50:44 +01:00
|
|
|
|
2023-01-12 16:31:18 +00:00
|
|
|
const { resolve } = createResolver(import.meta.url)
|
|
|
|
|
2022-11-13 13:34:43 +08:00
|
|
|
export default defineNuxtConfig({
|
2024-09-11 15:37:59 +01:00
|
|
|
compatibilityDate: '2024-09-11',
|
2022-12-18 00:29:16 +01:00
|
|
|
typescript: {
|
|
|
|
tsConfig: {
|
|
|
|
exclude: ['../service-worker'],
|
2023-01-08 15:49:32 +08:00
|
|
|
vueCompilerOptions: {
|
2024-09-11 15:37:59 +01:00
|
|
|
target: 3.5,
|
2023-01-08 15:49:32 +08:00
|
|
|
},
|
2022-12-18 00:29:16 +01:00
|
|
|
},
|
|
|
|
},
|
2022-11-13 13:34:43 +08:00
|
|
|
modules: [
|
|
|
|
'@vueuse/nuxt',
|
|
|
|
'@unocss/nuxt',
|
|
|
|
'@pinia/nuxt',
|
2022-11-23 16:07:28 +08:00
|
|
|
'@vue-macros/nuxt',
|
2022-11-28 18:24:05 +08:00
|
|
|
'@nuxtjs/i18n',
|
2022-12-29 13:26:08 +01:00
|
|
|
'@nuxtjs/color-mode',
|
2023-04-26 22:46:00 +02:00
|
|
|
'@unlazy/nuxt',
|
2023-12-14 11:45:52 +00:00
|
|
|
'@nuxt/test-utils/module',
|
2023-01-17 11:51:32 +01:00
|
|
|
...(isDevelopment || isWindows) ? [] : ['nuxt-security'],
|
2023-02-15 14:15:11 -05:00
|
|
|
'~/modules/emoji-mart-translation',
|
2022-11-25 14:42:26 +00:00
|
|
|
'~/modules/purge-comments',
|
2023-01-08 12:18:58 +01:00
|
|
|
'~/modules/build-env',
|
2022-12-20 23:56:57 +00:00
|
|
|
'~/modules/tauri/index',
|
2023-01-13 09:46:07 +01:00
|
|
|
'~/modules/pwa/index', // change to '@vite-pwa/nuxt' once released and remove pwa module
|
2023-02-17 15:17:41 +01:00
|
|
|
'stale-dep/nuxt',
|
2022-11-13 13:34:43 +08:00
|
|
|
],
|
2023-08-01 17:43:55 +08:00
|
|
|
vue: {
|
2024-02-21 16:20:08 +01:00
|
|
|
propsDestructure: true,
|
2023-08-01 17:43:55 +08:00
|
|
|
},
|
2023-07-04 13:18:36 +08:00
|
|
|
macros: {
|
|
|
|
setupSFC: true,
|
2023-08-01 17:43:55 +08:00
|
|
|
betterDefine: false,
|
|
|
|
defineModels: false,
|
2024-02-21 16:20:08 +01:00
|
|
|
reactivityTransform: false,
|
2023-07-04 13:18:36 +08:00
|
|
|
},
|
2023-04-12 14:35:35 +02:00
|
|
|
devtools: {
|
|
|
|
enabled: true,
|
|
|
|
},
|
2024-02-24 17:46:14 +01:00
|
|
|
features: {
|
|
|
|
inlineStyles: false,
|
|
|
|
},
|
2022-11-13 13:34:43 +08:00
|
|
|
experimental: {
|
2022-12-20 23:56:57 +00:00
|
|
|
payloadExtraction: false,
|
2023-04-12 14:35:35 +02:00
|
|
|
renderJsonPayloads: true,
|
2022-11-13 13:34:43 +08:00
|
|
|
},
|
|
|
|
css: [
|
|
|
|
'@unocss/reset/tailwind.css',
|
2022-11-24 21:34:35 +08:00
|
|
|
'floating-vue/dist/style.css',
|
2023-01-16 11:26:19 +01:00
|
|
|
'~/styles/default-theme.css',
|
2022-11-14 00:05:32 +08:00
|
|
|
'~/styles/vars.css',
|
2022-11-15 17:39:25 +01:00
|
|
|
'~/styles/global.css',
|
2023-01-21 15:55:20 +01:00
|
|
|
...process.env.TAURI_PLATFORM === 'macos'
|
|
|
|
? []
|
|
|
|
: ['~/styles/scrollbars.css'],
|
2022-11-25 21:21:02 +08:00
|
|
|
'~/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: {
|
2022-12-21 10:06:39 +09:00
|
|
|
'querystring': 'rollup-plugin-node-polyfills/polyfills/qs',
|
2022-12-22 14:22:56 +00:00
|
|
|
'change-case': 'scule',
|
2023-01-12 16:31:18 +00:00
|
|
|
'semver': resolve('./mocks/semver'),
|
2022-11-14 11:45:20 +08:00
|
|
|
},
|
2022-12-28 15:57:06 +01:00
|
|
|
imports: {
|
|
|
|
dirs: [
|
2023-01-07 02:35:45 +08:00
|
|
|
'./composables/masto',
|
2022-12-28 15:57:06 +01:00
|
|
|
'./composables/push-notifications',
|
2023-01-06 18:39:37 +01:00
|
|
|
'./composables/settings',
|
2023-01-16 12:42:48 +01:00
|
|
|
'./composables/tiptap/index.ts',
|
2022-12-28 15:57:06 +01:00
|
|
|
],
|
2024-02-24 13:24:21 +01:00
|
|
|
imports: [{
|
|
|
|
name: 'useI18n',
|
|
|
|
from: '~/utils/i18n',
|
|
|
|
priority: 100,
|
|
|
|
}],
|
2023-01-29 14:20:37 +01:00
|
|
|
injectAtEnd: true,
|
2022-12-28 15:57:06 +01:00
|
|
|
},
|
2022-11-16 01:14:10 +08:00
|
|
|
vite: {
|
|
|
|
define: {
|
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',
|
2023-01-15 19:09:01 +00:00
|
|
|
'process.test': 'false',
|
2022-11-16 01:14:10 +08:00
|
|
|
},
|
2022-11-23 07:27:01 +08:00
|
|
|
build: {
|
2022-12-20 23:56:57 +00:00
|
|
|
target: 'esnext',
|
2022-11-23 07:27:01 +08:00
|
|
|
},
|
2024-02-24 13:24:21 +01:00
|
|
|
optimizeDeps: {
|
|
|
|
include: [
|
2024-03-05 15:48:58 +01:00
|
|
|
'@tiptap/vue-3',
|
|
|
|
'string-length',
|
|
|
|
'vue-virtual-scroller',
|
|
|
|
'emoji-mart',
|
|
|
|
'iso-639-1',
|
|
|
|
'@tiptap/extension-placeholder',
|
|
|
|
'@tiptap/extension-document',
|
|
|
|
'@tiptap/extension-paragraph',
|
|
|
|
'@tiptap/extension-text',
|
|
|
|
'@tiptap/extension-mention',
|
|
|
|
'@tiptap/extension-hard-break',
|
|
|
|
'@tiptap/extension-bold',
|
|
|
|
'@tiptap/extension-italic',
|
|
|
|
'@tiptap/extension-code',
|
|
|
|
'@tiptap/extension-history',
|
|
|
|
'prosemirror-state',
|
|
|
|
'browser-fs-access',
|
|
|
|
'blurhash',
|
|
|
|
'@vueuse/integrations/useFocusTrap',
|
|
|
|
'@tiptap/extension-code-block',
|
|
|
|
'prosemirror-highlight',
|
|
|
|
'@tiptap/core',
|
|
|
|
'tippy.js',
|
|
|
|
'prosemirror-highlight/shiki',
|
|
|
|
'@fnando/sparkline',
|
|
|
|
'@vueuse/gesture',
|
|
|
|
'github-reserved-names',
|
|
|
|
'file-saver',
|
|
|
|
'slimeform',
|
|
|
|
'vue-advanced-cropper',
|
|
|
|
'workbox-window',
|
|
|
|
'workbox-precaching',
|
|
|
|
'workbox-routing',
|
|
|
|
'workbox-cacheable-response',
|
|
|
|
'workbox-strategies',
|
|
|
|
'workbox-expiration',
|
2024-02-24 13:24:21 +01:00
|
|
|
],
|
|
|
|
},
|
2022-11-16 01:14:10 +08:00
|
|
|
},
|
2022-11-14 11:33:09 +08:00
|
|
|
postcss: {
|
|
|
|
plugins: {
|
|
|
|
'postcss-nested': {},
|
|
|
|
},
|
|
|
|
},
|
2023-01-29 07:52:01 -08:00
|
|
|
appConfig: {
|
|
|
|
storage: {
|
|
|
|
driver: process.env.NUXT_STORAGE_DRIVER ?? (isCI ? 'cloudflare' : 'fs'),
|
|
|
|
},
|
|
|
|
},
|
2022-11-15 23:54:58 +08:00
|
|
|
runtimeConfig: {
|
2023-01-15 17:34:17 +08:00
|
|
|
adminKey: '',
|
2022-11-23 23:12:25 +00:00
|
|
|
cloudflare: {
|
|
|
|
accountId: '',
|
|
|
|
namespaceId: '',
|
|
|
|
apiToken: '',
|
|
|
|
},
|
2024-01-02 04:58:37 -06:00
|
|
|
vercel: {
|
|
|
|
url: '',
|
|
|
|
token: '',
|
|
|
|
env: '',
|
|
|
|
base: '',
|
|
|
|
},
|
2022-11-25 00:14:16 +00:00
|
|
|
public: {
|
2023-01-27 00:45:23 -08:00
|
|
|
privacyPolicyUrl: '',
|
2023-01-29 06:18:27 -08:00
|
|
|
// We use LibreTranslate (https://github.com/LibreTranslate/LibreTranslate) as
|
|
|
|
// our default translation server #76
|
2022-11-25 00:14:16 +00:00
|
|
|
translateApi: '',
|
2023-01-16 11:24:14 +01:00
|
|
|
// Use the instance where Elk has its Mastodon account as the default
|
2023-01-16 10:25:34 +00:00
|
|
|
defaultServer: 'm.webtoo.ls',
|
2023-02-07 04:10:43 -08:00
|
|
|
singleInstance: false,
|
2022-11-25 00:14:16 +00:00
|
|
|
},
|
2022-11-30 16:17:20 -05:00
|
|
|
storage: {
|
2023-01-29 07:52:01 -08:00
|
|
|
fsBase: 'node_modules/.cache/app',
|
2022-11-30 16:17:20 -05:00
|
|
|
},
|
2022-11-15 23:54:58 +08:00
|
|
|
},
|
2022-12-18 00:29:16 +01:00
|
|
|
routeRules: {
|
2023-02-08 18:12:51 +01:00
|
|
|
// Static generation
|
|
|
|
'/': { prerender: true },
|
|
|
|
'/settings/**': { prerender: false },
|
|
|
|
// incremental regeneration
|
2022-12-28 16:17:37 +01:00
|
|
|
'/api/list-servers': { swr: true },
|
2023-02-08 18:12:51 +01:00
|
|
|
// CDN cache rules
|
2022-12-18 00:29:16 +01:00
|
|
|
'/manifest.webmanifest': {
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/manifest+json',
|
2023-02-12 12:08:50 +01:00
|
|
|
'Cache-Control': 'public, max-age=0, must-revalidate',
|
2022-12-18 00:29:16 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-11-28 10:01:14 +01:00
|
|
|
nitro: {
|
2023-02-06 01:34:50 -08:00
|
|
|
alias: {
|
|
|
|
'isomorphic-ws': 'unenv/runtime/mock/proxy',
|
|
|
|
},
|
2023-01-25 01:52:22 +08:00
|
|
|
esbuild: {
|
|
|
|
options: {
|
|
|
|
target: 'esnext',
|
|
|
|
},
|
|
|
|
},
|
2022-11-28 10:01:14 +01:00
|
|
|
prerender: {
|
2023-01-11 14:50:47 +00:00
|
|
|
crawlLinks: true,
|
2022-11-28 10:01:14 +01:00
|
|
|
},
|
2023-03-26 16:53:07 +02:00
|
|
|
publicAssets: [
|
|
|
|
{
|
2024-04-05 16:34:42 +02:00
|
|
|
dir: resolve('./public/avatars'),
|
2023-03-26 16:53:07 +02:00
|
|
|
maxAge: 24 * 60 * 60 * 30, // 30 days
|
|
|
|
baseURL: '/avatars',
|
|
|
|
},
|
|
|
|
{
|
2024-04-05 16:34:42 +02:00
|
|
|
dir: resolve('./public/emojis'),
|
2023-03-26 16:53:07 +02:00
|
|
|
maxAge: 24 * 60 * 60 * 15, // 15 days, matching service worker
|
|
|
|
baseURL: '/emojis',
|
|
|
|
},
|
|
|
|
{
|
2024-04-05 16:34:42 +02:00
|
|
|
dir: resolve('./public/fonts'),
|
2023-03-26 16:53:07 +02:00
|
|
|
maxAge: 24 * 60 * 60 * 365, // 1 year (versioned)
|
|
|
|
baseURL: '/fonts',
|
|
|
|
},
|
|
|
|
],
|
2022-11-28 10:01:14 +01:00
|
|
|
},
|
2023-02-12 11:22:43 +01:00
|
|
|
sourcemap: isDevelopment,
|
2023-01-29 07:52:01 -08:00
|
|
|
hooks: {
|
2023-02-16 09:23:26 +00:00
|
|
|
'prepare:types': function ({ references }) {
|
|
|
|
references.push({ types: '@types/wicg-file-system-access' })
|
|
|
|
},
|
2023-01-29 07:52:01 -08:00
|
|
|
'nitro:config': function (config) {
|
|
|
|
const nuxt = useNuxt()
|
|
|
|
config.virtual = config.virtual || {}
|
|
|
|
config.virtual['#storage-config'] = `export const driver = ${JSON.stringify(nuxt.options.appConfig.storage.driver)}`
|
|
|
|
},
|
2023-02-06 01:34:50 -08:00
|
|
|
'vite:extendConfig': function (config, { isServer }) {
|
|
|
|
if (isServer) {
|
|
|
|
const alias = config.resolve!.alias as Record<string, string>
|
|
|
|
for (const dep of ['eventemitter3', 'isomorphic-ws'])
|
|
|
|
alias[dep] = resolve('./mocks/class')
|
2023-12-21 02:54:40 +08:00
|
|
|
for (const dep of ['fuse.js'])
|
2023-02-06 01:34:50 -08:00
|
|
|
alias[dep] = 'unenv/runtime/mock/proxy'
|
|
|
|
const resolver = createResolver(import.meta.url)
|
|
|
|
|
|
|
|
config.plugins!.unshift({
|
|
|
|
name: 'mock',
|
|
|
|
enforce: 'pre',
|
|
|
|
resolveId(id) {
|
|
|
|
if (id.match(/(^|\/)(@tiptap)\//))
|
|
|
|
return resolver.resolve('./mocks/tiptap.ts')
|
|
|
|
if (id.match(/(^|\/)(prosemirror)/))
|
|
|
|
return resolver.resolve('./mocks/prosemirror.ts')
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
const noExternal = config.ssr!.noExternal as string[]
|
|
|
|
noExternal.push('masto', '@fnando/sparkline', 'vue-i18n', '@mastojs/ponyfills')
|
|
|
|
}
|
|
|
|
},
|
2023-01-29 07:52:01 -08:00
|
|
|
},
|
2022-11-28 01:34:45 +08:00
|
|
|
app: {
|
|
|
|
keepalive: true,
|
2022-11-29 17:27:35 +01:00
|
|
|
head: {
|
2023-02-01 03:14:58 +08:00
|
|
|
viewport: 'width=device-width,initial-scale=1,viewport-fit=cover',
|
2022-12-08 11:50:44 +01:00
|
|
|
bodyAttrs: {
|
|
|
|
class: 'overflow-x-hidden',
|
|
|
|
},
|
|
|
|
link: [
|
2022-12-19 23:37:23 +01:00
|
|
|
{ rel: 'icon', href: '/favicon.ico', sizes: 'any' },
|
2023-01-03 01:14:53 +01:00
|
|
|
{ rel: 'icon', type: 'image/svg+xml', href: '/logo.svg' },
|
2022-12-19 23:37:23 +01:00
|
|
|
{ rel: 'apple-touch-icon', href: '/apple-touch-icon.png' },
|
2022-12-08 11:50:44 +01:00
|
|
|
],
|
2023-01-02 06:03:25 +08:00
|
|
|
meta: [
|
2024-08-09 07:58:49 +02:00
|
|
|
{ name: 'apple-mobile-web-app-status-bar-style', content: 'default' },
|
2023-01-11 22:42:52 +00:00
|
|
|
// open graph social image
|
|
|
|
{ property: 'og:title', content: 'Elk' },
|
2023-01-11 22:51:23 +00:00
|
|
|
{ property: 'og:description', content: 'A nimble Mastodon web client' },
|
2023-01-11 22:42:52 +00:00
|
|
|
{ property: 'og:type', content: 'website' },
|
2023-01-12 15:02:58 +00:00
|
|
|
{ property: 'og:image', content: 'https://elk.zone/elk-og.png' },
|
2023-01-11 22:42:52 +00:00
|
|
|
{ property: 'og:image:width', content: '3800' },
|
|
|
|
{ property: 'og:image:height', content: '1900' },
|
|
|
|
{ property: 'og:site_name', content: 'Elk' },
|
2024-06-10 22:20:54 +01:00
|
|
|
{ name: 'twitter:site', content: '@elk_zone' },
|
|
|
|
{ name: 'twitter:card', content: 'summary_large_image' },
|
2023-01-02 06:03:25 +08:00
|
|
|
],
|
2022-11-29 17:27:35 +01:00
|
|
|
},
|
2022-11-28 01:34:45 +08:00
|
|
|
},
|
2024-03-05 15:48:58 +01:00
|
|
|
|
2024-08-16 14:52:08 +00:00
|
|
|
// eslint-disable-next-line ts/ban-ts-comment
|
2023-01-17 11:51:32 +01:00
|
|
|
// @ts-ignore nuxt-security is conditional
|
2023-01-16 03:00:44 +02:00
|
|
|
security: {
|
|
|
|
headers: {
|
|
|
|
crossOriginEmbedderPolicy: false,
|
|
|
|
contentSecurityPolicy: {
|
2023-03-24 00:12:42 +00:00
|
|
|
'default-src': ['\'self\''],
|
|
|
|
'base-uri': ['\'self\''],
|
|
|
|
'connect-src': ['\'self\'', 'https:', 'http:', 'wss:', 'ws:'],
|
|
|
|
'font-src': ['\'self\''],
|
|
|
|
'form-action': ['\'none\''],
|
|
|
|
'frame-ancestors': ['\'none\''],
|
2023-11-12 07:42:02 +01:00
|
|
|
'frame-src': ['https:'],
|
2023-03-24 00:12:42 +00:00
|
|
|
'img-src': ['\'self\'', 'https:', 'http:', 'data:', 'blob:'],
|
2023-10-12 16:57:52 +02:00
|
|
|
'manifest-src': ['\'self\''],
|
2023-03-24 00:12:42 +00:00
|
|
|
'media-src': ['\'self\'', 'https:', 'http:'],
|
|
|
|
'object-src': ['\'none\''],
|
|
|
|
'script-src': ['\'self\'', '\'unsafe-inline\'', '\'wasm-unsafe-eval\''],
|
|
|
|
'script-src-attr': ['\'none\''],
|
|
|
|
'style-src': ['\'self\'', '\'unsafe-inline\''],
|
|
|
|
'upgrade-insecure-requests': true,
|
2023-01-16 03:00:44 +02:00
|
|
|
},
|
2023-07-30 02:45:30 +08:00
|
|
|
permissionsPolicy: {
|
2024-09-19 21:00:39 +09:00
|
|
|
fullscreen: '*',
|
2023-07-30 02:45:30 +08:00
|
|
|
},
|
2023-01-16 03:00:44 +02:00
|
|
|
},
|
|
|
|
rateLimiter: false,
|
|
|
|
},
|
2022-12-29 13:26:08 +01:00
|
|
|
colorMode: { classSuffix: '' },
|
2024-02-24 17:46:14 +01:00
|
|
|
i18n: {
|
|
|
|
locales: currentLocales,
|
|
|
|
lazy: true,
|
|
|
|
strategy: 'no_prefix',
|
|
|
|
detectBrowserLanguage: false,
|
|
|
|
langDir: 'locales',
|
|
|
|
defaultLocale: 'en-US',
|
|
|
|
vueI18n: './config/i18n.config.ts',
|
|
|
|
},
|
2022-12-18 00:29:16 +01:00
|
|
|
pwa,
|
2023-02-17 15:30:23 +01:00
|
|
|
staleDep: {
|
|
|
|
packageManager: 'pnpm',
|
|
|
|
},
|
2023-04-26 22:46:00 +02:00
|
|
|
unlazy: {
|
|
|
|
ssr: false,
|
|
|
|
},
|
2022-11-13 13:34:43 +08:00
|
|
|
})
|
2022-11-29 06:39:49 +00:00
|
|
|
|
|
|
|
declare global {
|
2024-03-05 15:48:58 +01:00
|
|
|
// eslint-disable-next-line ts/no-namespace
|
2022-11-29 06:39:49 +00:00
|
|
|
namespace NodeJS {
|
|
|
|
interface Process {
|
|
|
|
mock?: Record<string, any>
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-01-31 11:42:46 +08:00
|
|
|
|
2023-05-02 10:48:33 +01:00
|
|
|
declare module '#app' {
|
2024-08-16 23:33:39 +09:00
|
|
|
interface PageMeta {
|
|
|
|
wideLayout?: boolean
|
|
|
|
}
|
|
|
|
|
2023-01-31 11:42:46 +08:00
|
|
|
interface RuntimeNuxtHooks {
|
|
|
|
'elk-logo:click': () => void
|
|
|
|
}
|
|
|
|
}
|
2023-04-12 14:35:35 +02:00
|
|
|
|
|
|
|
declare module '@nuxt/schema' {
|
|
|
|
interface AppConfig {
|
|
|
|
storage: any
|
|
|
|
env: BuildInfo['env']
|
|
|
|
buildInfo: BuildInfo
|
|
|
|
}
|
|
|
|
}
|