-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnuxt.config.js
125 lines (111 loc) · 3.31 KB
/
nuxt.config.js
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
require('dotenv').config()
const baseName = 'Clubhouse Icon Maker'
const baseDesc = 'Create icons with border and text'
const baseUrl = process.env.BASE_URL
export default {
// Disable server-side rendering (https://go.nuxtjs.dev/ssr-mode)
ssr: false,
// Target (https://go.nuxtjs.dev/config-target)
target: 'static',
// Global page headers (https://go.nuxtjs.dev/config-head)
head: {
title: baseName,
meta: [
{ charset: 'utf-8' },
{ name: 'viewport', content: 'width=device-width, initial-scale=1' },
{
hid: 'description',
name: 'description',
content: baseDesc,
},
{ hid: 'og:site_name', property: 'og:site_name', content: baseName },
{ hid: 'og:type', property: 'og:type', content: 'article' },
{ hid: 'og:url', property: 'og:url', content: baseUrl },
{ hid: 'og:title', property: 'og:title', content: baseName },
{
hid: 'og:description',
property: 'og:description',
content: baseDesc,
},
{
hid: 'og:image',
property: 'og:image',
content: baseUrl + '/images/ogp.png',
},
{ property: 'article:publisher', content: 'FacebookURL' },
{ property: 'fb:app_id', content: 'FacebookAppID' },
{
hid: 'twitter:card',
name: 'twitter:card',
content: 'summary_large_image',
},
{ name: 'twitter:site', content: '@retoruto_carry' },
],
link: [{ rel: 'icon', type: 'image/x-icon', href: '/favicon.ico' }],
},
// Global CSS (https://go.nuxtjs.dev/config-css)
css: [],
// Plugins to run before rendering page (https://go.nuxtjs.dev/config-plugins)
plugins: [],
// Auto import components (https://go.nuxtjs.dev/config-components)
components: true,
// Modules for dev and build (recommended) (https://go.nuxtjs.dev/config-modules)
buildModules: [
// https://go.nuxtjs.dev/typescript
'@nuxt/typescript-build',
// https://go.nuxtjs.dev/stylelint
'@nuxtjs/stylelint-module',
// https://go.nuxtjs.dev/tailwindcss
'@nuxtjs/tailwindcss',
[
'@nuxtjs/google-analytics',
{
id: 'UA-55008158-14',
},
],
],
// Modules (https://go.nuxtjs.dev/config-modules)
modules: [
// https://go.nuxtjs.dev/axios
'@nuxtjs/axios',
// https://go.nuxtjs.dev/pwa
'@nuxtjs/pwa',
[
'nuxt-i18n',
{
locales: [
{ code: 'ja', iso: 'ja-JP', name: '日本語' },
{ code: 'en', iso: 'en-US', name: 'English' },
],
detectBrowserLanguage: {
useCookie: true,
cookieKey: 'i18n_redirected',
onlyOnRoot: true,
},
defaultLocale: 'en',
strategy: 'no_prefix',
vueI18n: {
fallbackLocale: 'en',
},
vueI18nLoader: true,
},
],
],
// Axios module configuration (https://go.nuxtjs.dev/config-axios)
axios: {},
// Build Configuration (https://go.nuxtjs.dev/config-build)
build: {
extend: (config) => {
// https://github.com/visualfanatic/vue-svg-loader
const svgRule = config.module.rules.find((rule) => rule.test.test('.svg'))
svgRule.test = /\.(png|jpe?g|gif|webp)$/
config.module.rules.push({
test: /\.svg$/,
use: ['vue-loader', 'vue-svg-loader'],
})
},
},
env: {
BASE_URL: baseUrl,
},
}