forked from nuxt/learn.nuxt.com
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnuxt.config.ts
126 lines (122 loc) · 2.36 KB
/
nuxt.config.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
import { execaSync } from 'execa'
// https://nuxt.com/docs/api/configuration/nuxt-config
export default defineNuxtConfig({
modules: [
'@vueuse/nuxt',
'@unocss/nuxt',
'@nuxt/content',
'@nuxtjs/color-mode',
'@pinia/nuxt',
'floating-vue/nuxt',
'@nuxtjs/seo',
'nuxt-icon',
// local
'~/modules/template-loader',
'~/modules/nuxt-link',
],
colorMode: {
classSuffix: '',
},
site: {
url: 'https://learn-dev.nuxt.com',
},
ogImage: {
defaults: {
component: 'NuxtSeo',
props: {
colorMode: 'dark',
},
},
componentOptions: {
global: true,
},
},
app: {
head: {
titleTemplate: '%s - Nuxt Tutorial',
htmlAttrs: {
lang: 'en-US',
},
link: [
{ rel: 'icon', type: 'image/x-icon', href: '/favicon.ico' },
],
},
},
typescript: {
includeWorkspace: true,
tsConfig: {
include: [
'../content/**/.template/**/*.ts',
],
},
},
features: {
inlineStyles: false,
},
runtimeConfig: {
public: {
buildTime: Date.now(),
gitSha: execaSync('git', ['rev-parse', 'HEAD']).stdout.trim(),
},
app: {
devtools: {
iframeProps: {
allow: 'cross-origin-isolated',
credentialless: true,
},
},
},
},
devtools: {
enabled: true,
},
nitro: {
routeRules: {
'/**': {
headers: {
'Cross-Origin-Embedder-Policy': 'require-corp',
'Cross-Origin-Opener-Policy': 'same-origin',
},
},
},
},
vite: {
build: {
minify: 'esbuild',
cssMinify: 'esbuild',
},
server: {
headers: {
'Cross-Origin-Embedder-Policy': 'require-corp',
'Cross-Origin-Opener-Policy': 'same-origin',
},
},
optimizeDeps: {
include: [
'monaco-editor/esm/vs/editor/editor.worker',
'monaco-editor-core/esm/vs/editor/editor.worker',
'typescript/lib/tsserverlibrary',
'@vue/language-service',
'@volar/monaco/worker',
'typescript',
],
},
},
vue: {
defineModel: true,
},
content: {
documentDriven: true,
highlight: {
theme: {
default: 'vitesse-light',
dark: 'vitesse-dark',
},
},
markdown: {
remarkPlugins: [
'remark-external-links',
],
},
},
})