refactor: module federation

Signed-off-by: Sebastian Krupinski <krupinski01@gmail.com>
This commit is contained in:
2026-02-22 16:49:24 -05:00
parent f5d8243ab5
commit 9f5716634f
3 changed files with 45 additions and 12 deletions

View File

@@ -1,8 +1,3 @@
import { useCollectionsStore } from '@/stores/collectionsStore'
import { useEntitiesStore } from '@/stores/entitiesStore'
import { useProvidersStore } from '@/stores/providersStore'
import { useServicesStore } from '@/stores/servicesStore'
/** /**
* Chrono Manager Module Boot Script * Chrono Manager Module Boot Script
* *
@@ -14,5 +9,10 @@ console.log('[Chrono Manager] Booting Chrono Manager module...')
console.log('[Chrono Manager] Chrono Manager module booted successfully') console.log('[Chrono Manager] Chrono Manager module booted successfully')
// Export store for external use if needed // CSS will be injected by build process
export { useCollectionsStore, useEntitiesStore, useProvidersStore, useServicesStore } //export const css = ['__CSS_FILENAME_PLACEHOLDER__']
// Export services, stores and models for external use
export * from '@/services'
export * from '@/stores'
export * from '@/models'

View File

@@ -3,7 +3,7 @@
* Provides a centralized way to make API calls with envelope wrapping/unwrapping * Provides a centralized way to make API calls with envelope wrapping/unwrapping
*/ */
import { createFetchWrapper } from '@KTXC/utils/helpers/fetch-wrapper-core'; import { createFetchWrapper } from '@KTXC';
import type { ApiRequest, ApiResponse } from '../types/common'; import type { ApiRequest, ApiResponse } from '../types/common';
const fetchWrapper = createFetchWrapper(); const fetchWrapper = createFetchWrapper();

View File

@@ -1,16 +1,38 @@
import { defineConfig } from 'vite' import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import path from 'path' import path from 'path'
// https://vite.dev/config/ // https://vite.dev/config/
export default defineConfig({ export default defineConfig({
plugins: [
vue(),
{
name: 'inject-css-filename',
enforce: 'post',
generateBundle(_options, bundle) {
const cssFile = Object.keys(bundle).find(name => name.endsWith('.css'))
if (!cssFile) return
for (const fileName of Object.keys(bundle)) {
const chunk = bundle[fileName]
if (chunk.type === 'chunk' && chunk.code.includes('__CSS_FILENAME_PLACEHOLDER__')) {
chunk.code = chunk.code.replace(/__CSS_FILENAME_PLACEHOLDER__/g, `static/${cssFile}`)
console.log(`Injected CSS filename "static/${cssFile}" into ${fileName}`)
}
}
}
}
],
resolve: { resolve: {
alias: { alias: {
'@': path.resolve(__dirname, './src'), '@': path.resolve(__dirname, './src'),
'@KTXC': path.resolve(__dirname, '../../core/src') '@KTXC': path.resolve(__dirname, '../../core/src'),
'@ChronoManager': path.resolve(__dirname, './src')
}, },
}, },
build: { build: {
outDir: 'static', outDir: 'static',
emptyOutDir: true,
sourcemap: true, sourcemap: true,
lib: { lib: {
entry: path.resolve(__dirname, 'src/main.ts'), entry: path.resolve(__dirname, 'src/main.ts'),
@@ -19,12 +41,23 @@ export default defineConfig({
}, },
rollupOptions: { rollupOptions: {
external: [ external: [
'pinia',
'vue', 'vue',
'vue-router', 'vue-router',
// Externalize shared utilities from core to avoid duplication 'pinia',
/^@KTXC\/utils\//, '@KTXC',
], ],
output: {
paths: (id) => {
if (id === '@KTXC') return '/js/ktxc.mjs'
return id
},
assetFileNames: (assetInfo) => {
if (assetInfo.name?.endsWith('.css')) {
return 'chrono_manager-[hash].css'
}
return '[name]-[hash][extname]'
}
}
}, },
}, },
}) })