-
Notifications
You must be signed in to change notification settings - Fork 0
/
nuxt.config.ts
110 lines (109 loc) · 2.33 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
import mongoose from 'mongoose';
import vuetify, { transformAssetUrls } from 'vite-plugin-vuetify';
// https://nuxt.com/docs/api/configuration/nuxt-config
export default defineNuxtConfig({
app: {
pageTransition: { name: 'fade', mode: 'out-in' },
layoutTransition: { name: 'fade', mode: 'out-in' },
head: {
htmlAttrs: {
lang: 'en',
},
},
},
runtimeConfig: {
cloudinaryCloudName: '',
cloudinaryApiKey: '',
cloudinaryApiSecret: '',
mongodbUrl: '',
public: {
appUrl: '',
},
},
devtools: { enabled: true },
modules: [
'@nuxt/content',
(_options, nuxt) => {
nuxt.hooks.hook('vite:extendConfig', (config) => {
config.plugins?.push(vuetify());
});
},
],
build: {
transpile: ['vuetify'],
},
css: ['vuetify/styles', '@fortawesome/fontawesome-free/css/all.css', '~/assets/styles/index.scss'],
typescript: {
typeCheck: true,
},
vite: {
vue: {
template: {
transformAssetUrls,
},
},
css: {
preprocessorOptions: {
scss: {
additionalData: '@import "~/assets/styles/variables.scss";',
},
},
},
build: {
rollupOptions: {
output: {
manualChunks(id) {
if (id.includes('Prose')) {
return 'prose';
}
},
},
},
},
},
routeRules: {
'/**': {
headers: {
'X-Robots-Tag': 'noindex',
},
},
'/signup': {
ssr: false,
},
'/login': {
ssr: false,
},
'/profile/**': {
ssr: false,
},
'/articles/**': {
swr: 60 * 15, // 10 minutes
},
},
content: {
highlight: {
theme: {
default: 'github-dark',
sepia: 'monokai',
},
},
},
imports: {
dirs: ['./composables', './composables/api', './utils'],
},
hooks: {
'build:manifest': (manifest) => {
// solve this issue with blocking stylesheets in rendered HTML with inline styles https://github.com/nuxt/nuxt/issues/21821
for (const item of Object.values(manifest)) {
// find the manifest item with css reference
if (item.css) {
// clear all references to exclude from the rendered HTML links
item.css = [];
}
}
},
close: () => {
mongoose.disconnect();
},
},
});