schon/storefront/nuxt.config.ts
Alexandr SaVBaD Waltz 4957039fc5 Features: 1) Integrate advanced Apollo link setup including error handling, authentication, and custom link chaining; 2) Replace apollo-upload-link.ts with revised client link configuration in apollo.ts; 3) Add @types/apollo-upload-client and @types/extract-files for enhanced TypeScript support;
Fixes: 1) Remove deprecated and redundant logic from `useAvatarUpload`; 2) Correct non-functional avatar upload and improve template handling in `settings.vue`;

Extra: 1) Cleanup unused imports, comments, and SCSS styles across files; 2) Simplify plugin configuration and migration to consolidated link logic; 3) Update package dependencies with precise resolution in `package-lock.json`.
2025-07-11 19:25:03 +03:00

97 lines
No EOL
2.4 KiB
TypeScript

import { defineNuxtConfig } from 'nuxt/config';
import { i18nConfig } from './config/i18n';
import {fileURLToPath, URL} from "node:url";
import { resolve } from 'node:path';
export default defineNuxtConfig({
ssr: true,
devtools: { enabled: true },
typescript: { strict: true },
modules: [
"@nuxtjs/i18n",
"@nuxt/icon",
"@pinia/nuxt",
"@nuxtjs/apollo",
"@vueuse/nuxt",
"@element-plus/nuxt",
"nuxt-marquee",
"@nuxt/image"
],
i18n: i18nConfig,
apollo: {
autoImports: true,
clients: {
default: {
httpEndpoint: `https://api.${process.env.EVIBES_BASE_DOMAIN}/graphql/`,
connectToDevTools: true,
authType: 'Bearer',
authHeader: 'X-EVIBES-AUTH',
tokenStorage: 'cookie',
tokenName: `${process.env.EVIBES_PROJECT_NAME?.toLowerCase()}-access`,
}
}
},
runtimeConfig: {
public: {
evibesProjectName: process.env.EVIBES_PROJECT_NAME,
evibesBaseDomain: process.env.EVIBES_BASE_DOMAIN
},
},
app: {
head: {
charset: "utf-8",
viewport: "width=device-width, initial-scale=1",
title: process.env.EVIBES_PROJECT_NAME,
titleTemplate: `${process.env.EVIBES_PROJECT_NAME} | %s`,
link: [
{ rel: 'icon', type: 'image/x-icon', href: '/favicon.ico' },
]
},
pageTransition: {
name: 'opacity',
mode: 'out-in'
}
},
css: [
'./assets/styles/main.scss',
'./assets/styles/global/fonts.scss'
],
alias: {
'styles': fileURLToPath(new URL("./assets/styles", import.meta.url)),
'images': fileURLToPath(new URL("./assets/images", import.meta.url)),
'icons': fileURLToPath(new URL("./assets/icons", import.meta.url)),
},
vite: {
envDir: '../',
envPrefix: 'EVIBES_',
css: {
preprocessorOptions: {
scss: {
additionalData: `
@use "@/assets/styles/global/variables.scss" as *;
@use "@/assets/styles/global/mixins.scss" as *;
`
}
}
}
},
image: {
domains: [`https://api.${process.env.EVIBES_BASE_DOMAIN}`]
},
hooks: {
'pages:extend'(pages) {
pages.push(
{
name: 'activate-user',
path: '/activate-user',
file: resolve(__dirname, 'pages/index.vue')
},
{
name: 'reset-password',
path: '/reset-password',
file: resolve(__dirname, 'pages/index.vue')
}
)
}
}
})