feat(front) : modular nuxt config with app/ shell dirs and modules/* layer auto-detection
This commit is contained in:
+45
-12
@@ -1,14 +1,32 @@
|
|||||||
|
import { existsSync, readdirSync } from 'node:fs'
|
||||||
|
import { resolve } from 'node:path'
|
||||||
|
|
||||||
|
const modulesDir = resolve(__dirname, 'modules')
|
||||||
|
const moduleDirs = existsSync(modulesDir)
|
||||||
|
? readdirSync(modulesDir, { withFileTypes: true })
|
||||||
|
.filter((d) => d.isDirectory())
|
||||||
|
.map((d) => d.name)
|
||||||
|
: []
|
||||||
|
const moduleLayers = moduleDirs.map((name) => `./modules/${name}`)
|
||||||
|
const moduleComposableDirs = moduleDirs
|
||||||
|
.map((name) => `modules/${name}/composables`)
|
||||||
|
.filter((path) => existsSync(resolve(__dirname, path)))
|
||||||
|
const moduleStoreDirs = moduleDirs
|
||||||
|
.map((name) => `modules/${name}/stores`)
|
||||||
|
.filter((path) => existsSync(resolve(__dirname, path)))
|
||||||
|
|
||||||
export default defineNuxtConfig({
|
export default defineNuxtConfig({
|
||||||
compatibilityDate: '2025-07-15',
|
compatibilityDate: '2025-07-15',
|
||||||
devtools: {enabled: false},
|
devtools: { enabled: false },
|
||||||
ssr: false,
|
ssr: false,
|
||||||
|
srcDir: '.',
|
||||||
css: ['~/assets/css/app.css', '~/assets/css/dark.css'],
|
css: ['~/assets/css/app.css', '~/assets/css/dark.css'],
|
||||||
app: {
|
app: {
|
||||||
baseURL: process.env.NODE_ENV === 'production'
|
baseURL: process.env.NODE_ENV === 'production'
|
||||||
? (process.env.NUXT_PUBLIC_APP_BASE || '/')
|
? (process.env.NUXT_PUBLIC_APP_BASE || '/')
|
||||||
: '/'
|
: '/',
|
||||||
},
|
},
|
||||||
extends: ['@malio/layer-ui'],
|
extends: ['@malio/layer-ui', ...moduleLayers],
|
||||||
modules: [
|
modules: [
|
||||||
'@nuxtjs/tailwindcss',
|
'@nuxtjs/tailwindcss',
|
||||||
'@pinia/nuxt',
|
'@pinia/nuxt',
|
||||||
@@ -16,16 +34,35 @@ export default defineNuxtConfig({
|
|||||||
'@nuxtjs/i18n',
|
'@nuxtjs/i18n',
|
||||||
'@nuxt/icon',
|
'@nuxt/icon',
|
||||||
],
|
],
|
||||||
|
dir: {
|
||||||
|
layouts: 'app/layouts',
|
||||||
|
middleware: 'app/middleware',
|
||||||
|
},
|
||||||
|
imports: {
|
||||||
|
dirs: [
|
||||||
|
'shared/composables',
|
||||||
|
'shared/stores',
|
||||||
|
'shared/utils',
|
||||||
|
'composables',
|
||||||
|
'stores',
|
||||||
|
'utils',
|
||||||
|
...moduleComposableDirs,
|
||||||
|
...moduleStoreDirs,
|
||||||
|
],
|
||||||
|
},
|
||||||
|
pinia: {
|
||||||
|
storesDirs: ['shared/stores/**', 'stores/**', 'modules/*/stores/**'],
|
||||||
|
},
|
||||||
runtimeConfig: {
|
runtimeConfig: {
|
||||||
public: {
|
public: {
|
||||||
apiBase: process.env.NUXT_PUBLIC_API_BASE
|
apiBase: process.env.NUXT_PUBLIC_API_BASE,
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
devServer: {
|
devServer: {
|
||||||
port: 3002,
|
port: 3002,
|
||||||
},
|
},
|
||||||
components: [
|
components: [
|
||||||
{path: '~/components', pathPrefix: false},
|
{ path: '~/components', pathPrefix: false },
|
||||||
],
|
],
|
||||||
vite: {
|
vite: {
|
||||||
server: {
|
server: {
|
||||||
@@ -56,10 +93,6 @@ export default defineNuxtConfig({
|
|||||||
{code: 'fr', file: 'fr.json', name: 'Français'}
|
{code: 'fr', file: 'fr.json', name: 'Français'}
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
typescript: {
|
typescript: { strict: true },
|
||||||
strict: true
|
build: { transpile: ['@vuepic/vue-datepicker'] },
|
||||||
},
|
|
||||||
build: {
|
|
||||||
transpile: ['@vuepic/vue-datepicker']
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user