-
Notifications
You must be signed in to change notification settings - Fork 53
/
Copy pathnuxt.config.js
125 lines (111 loc) · 3.3 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
export default {
// https://nuxtjs.org/deployments/netlify/
target: "static",
ssr: false,
generate: {
fallback: true,
},
// Headers of the page
head: {
title: "Browse Movies, TV Shows and People",
meta: [
{ charset: "utf-8" },
{ name: "viewport", content: "width=device-width, initial-scale=1" },
{
hid: "description",
name: "description",
content: "Browse Movies, TV Shows and People",
},
{ hid: "author", name: "author", content: "Jason Ujma-Alvis" },
{ hid: "og:locale", property: "og:locale", content: "en_GB" },
{ hid: "og:title", property: "og:title", content: "Movies App" },
{
hid: "og:description",
property: "og:description",
content: "Browse Movies, TV Shows and People",
},
{ hid: "og:type", property: "og:type", content: "website" },
{
hid: "og:url",
property: "og:url",
content: "https://movies.jason.codes/",
},
{ name: "twitter:card", content: "summary" },
{ name: "twitter:title", content: "Movies" },
{
name: "twitter:description",
content: "Browse Movies, TV Shows and People",
},
{ name: "twitter:site", content: "@jasonujmaalvis" },
{ name: "twitter:creator", content: "@jasonujmaalvis" },
{
name: "twitter:image",
content: "https://movies.jason.codes/icon-medium.png",
},
],
link: [
{ rel: "icon", type: "image/x-icon", href: "/favicon.ico" },
{
rel: "stylesheet",
href: "//fonts.googleapis.com/css?family=Roboto:300,400,500",
},
],
},
// Global CSS
css: ["@/assets/css/global.scss"],
// Plugins to run before rendering page: https://go.nuxtjs.dev/config-plugins
plugins: [
"~/plugins/lazyload.js",
"~/plugins/filters.js",
{ src: "~/plugins/ga.js", ssr: false },
],
// 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/eslint
"@nuxtjs/eslint-module",
],
modules: ["@nuxtjs/dotenv", "@nuxtjs/axios", "@nuxtjs/pwa"],
// Axios module configuration: https://go.nuxtjs.dev/config-axios
axios: {
// Workaround to avoid enforcing hard-coded localhost:3000: https://github.com/nuxt-community/axios-module/issues/308
baseURL: "/",
},
// PWA module configuration: https://go.nuxtjs.dev/pwa
pwa: {
manifest: {
lang: "en",
name: "Movies",
short_name: "Movies",
description: "Browse Movies, TV Shows and People",
theme_color: "#2196f3",
background_color: "#000000",
},
},
// Build Configuration: https://go.nuxtjs.dev/config-build
loaders: {
cssModules: {
camelCase: true,
localIdentName: "[local]_[hash:base64:5]",
},
},
vue: {
config: {
productionTip: false,
devtools: false,
},
},
env: {
FRONTEND_URL: process.env.FRONTEND_URL || "",
API_KEY: process.env.API_KEY || "",
API_LANG: process.env.API_LANG || "en-US",
API_COUNTRY: process.env.API_COUNTRY || "GB",
API_YOUTUBE_KEY: process.env.API_YOUTUBE_KEY || "",
GA: process.env.GA || "",
},
// Customize the progress bar color
loading: {
color: "#2196f3",
},
};