wu-framework 2.1.0 → 2.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. package/LICENSE +39 -39
  2. package/README.md +570 -570
  3. package/dist/adapters/angular/index.d.ts +154 -154
  4. package/dist/adapters/angular/index.js.map +1 -1
  5. package/dist/adapters/angular.d.ts +3 -3
  6. package/dist/adapters/index.js.map +1 -1
  7. package/dist/adapters/lit/index.d.ts +120 -120
  8. package/dist/adapters/lit/index.js.map +1 -1
  9. package/dist/adapters/lit.d.ts +3 -3
  10. package/dist/adapters/preact/index.d.ts +108 -108
  11. package/dist/adapters/preact/index.js.map +1 -1
  12. package/dist/adapters/preact.d.ts +3 -3
  13. package/dist/adapters/react/index.d.ts +246 -246
  14. package/dist/adapters/react/index.js.map +1 -1
  15. package/dist/adapters/react.d.ts +3 -3
  16. package/dist/adapters/shared.js.map +1 -1
  17. package/dist/adapters/solid/index.d.ts +101 -101
  18. package/dist/adapters/solid/index.js.map +1 -1
  19. package/dist/adapters/solid.d.ts +3 -3
  20. package/dist/adapters/svelte/index.d.ts +166 -166
  21. package/dist/adapters/svelte/index.js.map +1 -1
  22. package/dist/adapters/svelte.d.ts +3 -3
  23. package/dist/adapters/vanilla/index.d.ts +179 -179
  24. package/dist/adapters/vanilla/index.js.map +1 -1
  25. package/dist/adapters/vanilla.d.ts +3 -3
  26. package/dist/adapters/vue/index.d.ts +299 -299
  27. package/dist/adapters/vue/index.js.map +1 -1
  28. package/dist/adapters/vue.d.ts +3 -3
  29. package/dist/ai/wu-ai.js.map +1 -1
  30. package/dist/core/wu-html-parser.js +2 -0
  31. package/dist/core/wu-html-parser.js.map +1 -0
  32. package/dist/core/wu-iframe-sandbox.js +2 -0
  33. package/dist/core/wu-iframe-sandbox.js.map +1 -0
  34. package/dist/core/wu-loader.js +2 -0
  35. package/dist/core/wu-loader.js.map +1 -0
  36. package/dist/core/wu-mcp-bridge.js.map +1 -1
  37. package/dist/core/wu-script-executor.js +2 -0
  38. package/dist/core/wu-script-executor.js.map +1 -0
  39. package/dist/wu-ai-browser-primitives-BDKXJlwc.js.map +1 -1
  40. package/dist/wu-framework.cjs.js +2 -2
  41. package/dist/wu-framework.cjs.js.map +1 -1
  42. package/dist/wu-framework.dev.js +8697 -9142
  43. package/dist/wu-framework.dev.js.map +1 -1
  44. package/dist/wu-framework.esm.js +2 -2
  45. package/dist/wu-framework.esm.js.map +1 -1
  46. package/dist/wu-framework.umd.js +2 -2
  47. package/dist/wu-framework.umd.js.map +1 -1
  48. package/dist/wu-logger-fJfUHBGA.js.map +1 -1
  49. package/integrations/astro/README.md +127 -127
  50. package/integrations/astro/WuApp.astro +63 -63
  51. package/integrations/astro/WuShell.astro +39 -39
  52. package/integrations/astro/index.js +68 -68
  53. package/integrations/astro/package.json +38 -38
  54. package/integrations/astro/types.d.ts +53 -53
  55. package/package.json +218 -218
  56. package/dist/wu-html-parser.js +0 -2
  57. package/dist/wu-html-parser.js.map +0 -1
  58. package/dist/wu-iframe-sandbox.js +0 -2
  59. package/dist/wu-iframe-sandbox.js.map +0 -1
  60. package/dist/wu-script-executor.js +0 -2
  61. package/dist/wu-script-executor.js.map +0 -1
@@ -1,166 +1,166 @@
1
- /**
2
- * 🚀 WU-FRAMEWORK SVELTE ADAPTER - TypeScript Declarations
3
- */
4
-
5
- import type { WuCore } from '../core/wu-core';
6
-
7
- // Svelte types (generics to avoid hard dependency)
8
- type SvelteComponent = any;
9
- type ComponentConstructor<T = any> = new (options: any) => T;
10
-
11
- /**
12
- * Opciones para registrar un componente Svelte
13
- */
14
- export interface SvelteRegisterOptions {
15
- /** Props iniciales para el componente */
16
- props?: Record<string, any>;
17
- /** Contexto a pasar al componente */
18
- context?: Map<any, any>;
19
- /** Ejecutar transiciones de intro (default: false) */
20
- intro?: boolean;
21
- /** Callback después de montar */
22
- onMount?: (container: HTMLElement, instance: SvelteComponent) => void;
23
- /** Callback antes de desmontar */
24
- onUnmount?: (container: HTMLElement, instance: SvelteComponent) => void;
25
- /** Permitir ejecución standalone (default: true) */
26
- standalone?: boolean;
27
- /** Selector para modo standalone (default: '#app') */
28
- standaloneContainer?: string;
29
- }
30
-
31
- /**
32
- * Opciones para registrar un componente Svelte 5
33
- */
34
- export interface Svelte5RegisterOptions {
35
- /** Props iniciales para el componente */
36
- props?: Record<string, any>;
37
- /** Callback después de montar */
38
- onMount?: (container: HTMLElement, instance: any) => void;
39
- /** Callback antes de desmontar */
40
- onUnmount?: (container: HTMLElement, instance: any) => void;
41
- /** Permitir ejecución standalone (default: true) */
42
- standalone?: boolean;
43
- /** Selector para modo standalone (default: '#app') */
44
- standaloneContainer?: string;
45
- }
46
-
47
- /**
48
- * Store de Wu compatible con Svelte
49
- */
50
- export interface WuSvelteStore<T = any> {
51
- /** Suscribirse al store (Svelte store contract) */
52
- subscribe: (fn: (value: T) => void) => () => void;
53
- /** Establecer valor en path específico */
54
- set: (path: string, value: any) => void;
55
- /** Obtener valor de path específico */
56
- get: (path?: string) => any;
57
- /** Actualizar valor con función */
58
- update: (fn: (value: T) => T) => void;
59
- }
60
-
61
- /**
62
- * Store de eventos de Wu para Svelte
63
- */
64
- export interface WuEventStore<T = any> {
65
- /** Suscribirse al store (Svelte store contract) */
66
- subscribe: (fn: (value: T | null) => void) => () => void;
67
- /** Emitir evento */
68
- emit: (data: any, options?: any) => void;
69
- }
70
-
71
- /**
72
- * Helper de eventos para Svelte
73
- */
74
- export interface WuEventsHelper {
75
- /** Emitir evento */
76
- emit: (event: string, data?: any, options?: any) => void;
77
- /** Suscribirse a evento */
78
- on: (event: string, callback: (data: any) => void) => () => void;
79
- /** Suscribirse a evento una vez */
80
- once: (event: string, callback: (data: any) => void) => () => void;
81
- /** Desuscribirse de evento */
82
- off: (event: string, callback: (data: any) => void) => void;
83
- /** Limpiar todas las suscripciones */
84
- cleanup: () => void;
85
- }
86
-
87
- /**
88
- * Configuración del componente WuSlot para Svelte
89
- */
90
- export interface WuSlotConfig {
91
- props: string[];
92
- template: string;
93
- createInstance: (target: HTMLElement, props: {
94
- name: string;
95
- url: string;
96
- appName?: string;
97
- fallbackText?: string;
98
- onLoad?: (data: { name: string; url: string }) => void;
99
- onError?: (error: Error) => void;
100
- }) => { destroy: () => Promise<void> };
101
- }
102
-
103
- /**
104
- * Registra un componente Svelte como microfrontend
105
- */
106
- export function register(
107
- appName: string,
108
- Component: ComponentConstructor,
109
- options?: SvelteRegisterOptions
110
- ): Promise<boolean>;
111
-
112
- /**
113
- * Registra un componente Svelte 5 como microfrontend
114
- */
115
- export function registerSvelte5(
116
- appName: string,
117
- Component: ComponentConstructor,
118
- options?: Svelte5RegisterOptions
119
- ): Promise<boolean>;
120
-
121
- /**
122
- * Crea un store de Wu compatible con Svelte
123
- */
124
- export function createWuStore<T = any>(namespace?: string): WuSvelteStore<T>;
125
-
126
- /**
127
- * Crea un store de eventos de Wu para Svelte
128
- */
129
- export function createWuEventStore<T = any>(eventPattern: string): WuEventStore<T>;
130
-
131
- /**
132
- * Helper para usar eventos de Wu en Svelte
133
- */
134
- export function useWuEvents(): WuEventsHelper;
135
-
136
- /**
137
- * Crea la configuración para un componente WuSlot
138
- */
139
- export function createWuSlotConfig(): WuSlotConfig;
140
-
141
- /**
142
- * Obtiene la instancia de Wu Framework
143
- */
144
- export function getWuInstance(): WuCore | null;
145
-
146
- /**
147
- * Espera a que Wu Framework esté disponible
148
- */
149
- export function waitForWu(timeout?: number): Promise<WuCore>;
150
-
151
- /**
152
- * API del adapter Svelte
153
- */
154
- export interface WuSvelteAdapter {
155
- register: typeof register;
156
- registerSvelte5: typeof registerSvelte5;
157
- createWuStore: typeof createWuStore;
158
- createWuEventStore: typeof createWuEventStore;
159
- useWuEvents: typeof useWuEvents;
160
- createWuSlotConfig: typeof createWuSlotConfig;
161
- getWuInstance: typeof getWuInstance;
162
- waitForWu: typeof waitForWu;
163
- }
164
-
165
- export const wuSvelte: WuSvelteAdapter;
166
- export default wuSvelte;
1
+ /**
2
+ * 🚀 WU-FRAMEWORK SVELTE ADAPTER - TypeScript Declarations
3
+ */
4
+
5
+ import type { WuCore } from '../core/wu-core';
6
+
7
+ // Svelte types (generics to avoid hard dependency)
8
+ type SvelteComponent = any;
9
+ type ComponentConstructor<T = any> = new (options: any) => T;
10
+
11
+ /**
12
+ * Opciones para registrar un componente Svelte
13
+ */
14
+ export interface SvelteRegisterOptions {
15
+ /** Props iniciales para el componente */
16
+ props?: Record<string, any>;
17
+ /** Contexto a pasar al componente */
18
+ context?: Map<any, any>;
19
+ /** Ejecutar transiciones de intro (default: false) */
20
+ intro?: boolean;
21
+ /** Callback después de montar */
22
+ onMount?: (container: HTMLElement, instance: SvelteComponent) => void;
23
+ /** Callback antes de desmontar */
24
+ onUnmount?: (container: HTMLElement, instance: SvelteComponent) => void;
25
+ /** Permitir ejecución standalone (default: true) */
26
+ standalone?: boolean;
27
+ /** Selector para modo standalone (default: '#app') */
28
+ standaloneContainer?: string;
29
+ }
30
+
31
+ /**
32
+ * Opciones para registrar un componente Svelte 5
33
+ */
34
+ export interface Svelte5RegisterOptions {
35
+ /** Props iniciales para el componente */
36
+ props?: Record<string, any>;
37
+ /** Callback después de montar */
38
+ onMount?: (container: HTMLElement, instance: any) => void;
39
+ /** Callback antes de desmontar */
40
+ onUnmount?: (container: HTMLElement, instance: any) => void;
41
+ /** Permitir ejecución standalone (default: true) */
42
+ standalone?: boolean;
43
+ /** Selector para modo standalone (default: '#app') */
44
+ standaloneContainer?: string;
45
+ }
46
+
47
+ /**
48
+ * Store de Wu compatible con Svelte
49
+ */
50
+ export interface WuSvelteStore<T = any> {
51
+ /** Suscribirse al store (Svelte store contract) */
52
+ subscribe: (fn: (value: T) => void) => () => void;
53
+ /** Establecer valor en path específico */
54
+ set: (path: string, value: any) => void;
55
+ /** Obtener valor de path específico */
56
+ get: (path?: string) => any;
57
+ /** Actualizar valor con función */
58
+ update: (fn: (value: T) => T) => void;
59
+ }
60
+
61
+ /**
62
+ * Store de eventos de Wu para Svelte
63
+ */
64
+ export interface WuEventStore<T = any> {
65
+ /** Suscribirse al store (Svelte store contract) */
66
+ subscribe: (fn: (value: T | null) => void) => () => void;
67
+ /** Emitir evento */
68
+ emit: (data: any, options?: any) => void;
69
+ }
70
+
71
+ /**
72
+ * Helper de eventos para Svelte
73
+ */
74
+ export interface WuEventsHelper {
75
+ /** Emitir evento */
76
+ emit: (event: string, data?: any, options?: any) => void;
77
+ /** Suscribirse a evento */
78
+ on: (event: string, callback: (data: any) => void) => () => void;
79
+ /** Suscribirse a evento una vez */
80
+ once: (event: string, callback: (data: any) => void) => () => void;
81
+ /** Desuscribirse de evento */
82
+ off: (event: string, callback: (data: any) => void) => void;
83
+ /** Limpiar todas las suscripciones */
84
+ cleanup: () => void;
85
+ }
86
+
87
+ /**
88
+ * Configuración del componente WuSlot para Svelte
89
+ */
90
+ export interface WuSlotConfig {
91
+ props: string[];
92
+ template: string;
93
+ createInstance: (target: HTMLElement, props: {
94
+ name: string;
95
+ url: string;
96
+ appName?: string;
97
+ fallbackText?: string;
98
+ onLoad?: (data: { name: string; url: string }) => void;
99
+ onError?: (error: Error) => void;
100
+ }) => { destroy: () => Promise<void> };
101
+ }
102
+
103
+ /**
104
+ * Registra un componente Svelte como microfrontend
105
+ */
106
+ export function register(
107
+ appName: string,
108
+ Component: ComponentConstructor,
109
+ options?: SvelteRegisterOptions
110
+ ): Promise<boolean>;
111
+
112
+ /**
113
+ * Registra un componente Svelte 5 como microfrontend
114
+ */
115
+ export function registerSvelte5(
116
+ appName: string,
117
+ Component: ComponentConstructor,
118
+ options?: Svelte5RegisterOptions
119
+ ): Promise<boolean>;
120
+
121
+ /**
122
+ * Crea un store de Wu compatible con Svelte
123
+ */
124
+ export function createWuStore<T = any>(namespace?: string): WuSvelteStore<T>;
125
+
126
+ /**
127
+ * Crea un store de eventos de Wu para Svelte
128
+ */
129
+ export function createWuEventStore<T = any>(eventPattern: string): WuEventStore<T>;
130
+
131
+ /**
132
+ * Helper para usar eventos de Wu en Svelte
133
+ */
134
+ export function useWuEvents(): WuEventsHelper;
135
+
136
+ /**
137
+ * Crea la configuración para un componente WuSlot
138
+ */
139
+ export function createWuSlotConfig(): WuSlotConfig;
140
+
141
+ /**
142
+ * Obtiene la instancia de Wu Framework
143
+ */
144
+ export function getWuInstance(): WuCore | null;
145
+
146
+ /**
147
+ * Espera a que Wu Framework esté disponible
148
+ */
149
+ export function waitForWu(timeout?: number): Promise<WuCore>;
150
+
151
+ /**
152
+ * API del adapter Svelte
153
+ */
154
+ export interface WuSvelteAdapter {
155
+ register: typeof register;
156
+ registerSvelte5: typeof registerSvelte5;
157
+ createWuStore: typeof createWuStore;
158
+ createWuEventStore: typeof createWuEventStore;
159
+ useWuEvents: typeof useWuEvents;
160
+ createWuSlotConfig: typeof createWuSlotConfig;
161
+ getWuInstance: typeof getWuInstance;
162
+ waitForWu: typeof waitForWu;
163
+ }
164
+
165
+ export const wuSvelte: WuSvelteAdapter;
166
+ export default wuSvelte;
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../src/adapters/svelte/ai.js","../../../src/adapters/svelte/index.js"],"sourcesContent":["/**\r\n * WU-FRAMEWORK SVELTE AI INTEGRATION\r\n */\r\nfunction getWuInstance() {\r\n if (typeof window === 'undefined') return null;\r\n return window.wu || window.parent?.wu || window.top?.wu || null;\r\n}\r\n\r\nexport function createWuAIStore(options = {}) {\r\n const { namespace = 'default' } = options;\r\n const subscribers = new Set();\r\n let state = { messages: [], isStreaming: false, error: null };\r\n function notify() { subscribers.forEach(fn => fn(state)); }\r\n\r\n return {\r\n subscribe(fn) { subscribers.add(fn); fn(state); return () => subscribers.delete(fn); },\r\n async send(text) {\r\n if (!text?.trim()) return;\r\n const wu = getWuInstance();\r\n if (!wu?.ai) { state = { ...state, error: 'Wu AI not available' }; notify(); return; }\r\n state = { ...state, messages: [...state.messages, { id: `user-${Date.now()}`, role: 'user', content: text, timestamp: Date.now() }], isStreaming: true, error: null };\r\n notify();\r\n try {\r\n const res = await wu.ai.send(text, { namespace });\r\n state = { ...state, messages: [...state.messages, { id: `assistant-${Date.now()}`, role: 'assistant', content: res.content, timestamp: Date.now() }], isStreaming: false };\r\n } catch (err) { state = { ...state, isStreaming: false, error: err.message }; }\r\n notify();\r\n },\r\n clear() { state = { messages: [], isStreaming: false, error: null }; notify(); },\r\n };\r\n}\r\n","/**\r\n * 🚀 WU-FRAMEWORK SVELTE ADAPTER\r\n *\r\n * Simplifica la integración de Svelte con Wu Framework.\r\n * Convierte componentes Svelte en microfrontends con UNA línea de código.\r\n *\r\n * @example\r\n * // Microfrontend (main.js)\r\n * import { wuSvelte } from 'wu-framework/adapters/svelte';\r\n * import App from './App.svelte';\r\n *\r\n * wuSvelte.register('my-app', App);\r\n *\r\n * @example\r\n * // Shell (cargar microfrontend)\r\n * import WuSlot from 'wu-framework/adapters/svelte/WuSlot.svelte';\r\n *\r\n * <WuSlot name=\"my-app\" url=\"http://localhost:3001\" />\r\n */\r\n\r\n// Estado global del adapter\r\nconst adapterState = {\r\n apps: new Map(),\r\n initialized: false\r\n};\r\n\r\n/**\r\n * Obtiene la instancia de Wu Framework\r\n */\r\nfunction getWuInstance() {\r\n if (typeof window === 'undefined') return null;\r\n\r\n return window.wu\r\n || window.parent?.wu\r\n || window.top?.wu\r\n || null;\r\n}\r\n\r\n/**\r\n * Espera a que Wu Framework esté disponible\r\n */\r\nfunction waitForWu(timeout = 5000) {\r\n return new Promise((resolve, reject) => {\r\n const wu = getWuInstance();\r\n if (wu) {\r\n resolve(wu);\r\n return;\r\n }\r\n\r\n const startTime = Date.now();\r\n\r\n const handleWuReady = () => {\r\n cleanup();\r\n resolve(getWuInstance());\r\n };\r\n\r\n window.addEventListener('wu:ready', handleWuReady);\r\n window.addEventListener('wu:app:ready', handleWuReady);\r\n\r\n const checkInterval = setInterval(() => {\r\n const wu = getWuInstance();\r\n if (wu) {\r\n cleanup();\r\n resolve(wu);\r\n return;\r\n }\r\n\r\n if (Date.now() - startTime > timeout) {\r\n cleanup();\r\n reject(new Error(`Wu Framework not found after ${timeout}ms`));\r\n }\r\n }, 200);\r\n\r\n function cleanup() {\r\n clearInterval(checkInterval);\r\n window.removeEventListener('wu:ready', handleWuReady);\r\n window.removeEventListener('wu:app:ready', handleWuReady);\r\n }\r\n });\r\n}\r\n\r\n/**\r\n * Registra un componente Svelte como microfrontend\r\n *\r\n * @param {string} appName - Nombre único del microfrontend (debe coincidir con wu.json)\r\n * @param {typeof SvelteComponent} Component - Componente Svelte principal (App.svelte)\r\n * @param {Object} options - Opciones adicionales\r\n * @param {Object} options.props - Props iniciales para el componente\r\n * @param {Object} options.context - Contexto a pasar al componente\r\n * @param {boolean} options.intro - Ejecutar transiciones de intro (default: false)\r\n * @param {Function} options.onMount - Callback después de montar\r\n * @param {Function} options.onUnmount - Callback antes de desmontar\r\n * @param {boolean} options.standalone - Permitir ejecución standalone (default: true)\r\n * @param {string} options.standaloneContainer - Selector para modo standalone (default: '#app')\r\n *\r\n * @example\r\n * // Básico\r\n * wuSvelte.register('my-app', App);\r\n *\r\n * @example\r\n * // Con props y context\r\n * wuSvelte.register('my-app', App, {\r\n * props: { apiUrl: 'https://api.example.com' },\r\n * context: new Map([['theme', 'dark']]),\r\n * onMount: (container) => console.log('Mounted!')\r\n * });\r\n */\r\nasync function register(appName, Component, options = {}) {\r\n const {\r\n props = {},\r\n context = new Map(),\r\n intro = false,\r\n onMount = null,\r\n onUnmount = null,\r\n standalone = true,\r\n standaloneContainer = '#app'\r\n } = options;\r\n\r\n // Función de mount interna\r\n const mountApp = (container) => {\r\n if (!container) {\r\n console.error(`[WuSvelte] Mount failed for ${appName}: container is null`);\r\n return;\r\n }\r\n\r\n // Evitar doble mount\r\n if (adapterState.apps.has(appName)) {\r\n console.warn(`[WuSvelte] ${appName} already mounted, unmounting first`);\r\n unmountApp();\r\n }\r\n\r\n try {\r\n // Limpiar container\r\n container.innerHTML = '';\r\n\r\n // Crear instancia del componente Svelte\r\n const instance = new Component({\r\n target: container,\r\n props: {\r\n ...props,\r\n // Inyectar información de Wu\r\n wuAppName: appName,\r\n wuInstance: getWuInstance()\r\n },\r\n context,\r\n intro\r\n });\r\n\r\n // Guardar referencia\r\n adapterState.apps.set(appName, {\r\n instance,\r\n container,\r\n Component\r\n });\r\n\r\n console.log(`[WuSvelte] ✅ ${appName} mounted successfully`);\r\n\r\n if (onMount) {\r\n onMount(container, instance);\r\n }\r\n } catch (error) {\r\n console.error(`[WuSvelte] Mount error for ${appName}:`, error);\r\n throw error;\r\n }\r\n };\r\n\r\n // Función de unmount interna\r\n const unmountApp = (container) => {\r\n const appData = adapterState.apps.get(appName);\r\n\r\n if (appData) {\r\n try {\r\n if (onUnmount) {\r\n onUnmount(appData.container, appData.instance);\r\n }\r\n\r\n // Destruir instancia de Svelte\r\n appData.instance.$destroy();\r\n adapterState.apps.delete(appName);\r\n\r\n console.log(`[WuSvelte] ✅ ${appName} unmounted successfully`);\r\n } catch (error) {\r\n console.error(`[WuSvelte] Unmount error for ${appName}:`, error);\r\n }\r\n }\r\n\r\n // Limpiar container si se proporciona\r\n if (container) {\r\n container.innerHTML = '';\r\n }\r\n };\r\n\r\n // Intentar registrar con Wu Framework\r\n try {\r\n const wu = await waitForWu(3000);\r\n\r\n wu.define(appName, {\r\n mount: mountApp,\r\n unmount: unmountApp\r\n });\r\n\r\n console.log(`[WuSvelte] ✅ ${appName} registered with Wu Framework`);\r\n return true;\r\n\r\n } catch (error) {\r\n console.warn(`[WuSvelte] Wu Framework not available for ${appName}`);\r\n\r\n // Modo standalone si está habilitado\r\n if (standalone) {\r\n const containerElement = document.querySelector(standaloneContainer);\r\n\r\n if (containerElement) {\r\n console.log(`[WuSvelte] Running ${appName} in standalone mode`);\r\n mountApp(containerElement);\r\n return true;\r\n } else {\r\n console.warn(`[WuSvelte] Standalone container ${standaloneContainer} not found`);\r\n }\r\n }\r\n\r\n return false;\r\n }\r\n}\r\n\r\n/**\r\n * Registra un componente Svelte 5 con runes como microfrontend\r\n *\r\n * @param {string} appName - Nombre único del microfrontend\r\n * @param {typeof SvelteComponent} Component - Componente Svelte 5\r\n * @param {Object} options - Opciones adicionales\r\n *\r\n * @example\r\n * // Svelte 5 con mount API\r\n * import { wuSvelte } from 'wu-framework/adapters/svelte';\r\n * import App from './App.svelte';\r\n *\r\n * wuSvelte.registerSvelte5('my-app', App);\r\n */\r\nasync function registerSvelte5(appName, Component, options = {}) {\r\n const {\r\n props = {},\r\n onMount = null,\r\n onUnmount = null,\r\n standalone = true,\r\n standaloneContainer = '#app'\r\n } = options;\r\n\r\n // Función de mount para Svelte 5\r\n const mountApp = async (container) => {\r\n if (!container) {\r\n console.error(`[WuSvelte5] Mount failed for ${appName}: container is null`);\r\n return;\r\n }\r\n\r\n // Evitar doble mount\r\n if (adapterState.apps.has(appName)) {\r\n console.warn(`[WuSvelte5] ${appName} already mounted, unmounting first`);\r\n await unmountApp();\r\n }\r\n\r\n try {\r\n container.innerHTML = '';\r\n\r\n // Svelte 5 usa mount() del módulo svelte\r\n let mountFn;\r\n try {\r\n const svelte = await import('svelte');\r\n mountFn = svelte.mount;\r\n } catch (e) {\r\n // Fallback a API legacy\r\n console.warn('[WuSvelte5] Svelte 5 mount not available, using legacy API');\r\n return register(appName, Component, options);\r\n }\r\n\r\n // Montar con Svelte 5 API\r\n const instance = mountFn(Component, {\r\n target: container,\r\n props: {\r\n ...props,\r\n wuAppName: appName,\r\n wuInstance: getWuInstance()\r\n }\r\n });\r\n\r\n adapterState.apps.set(appName, {\r\n instance,\r\n container,\r\n Component,\r\n isSvelte5: true\r\n });\r\n\r\n console.log(`[WuSvelte5] ✅ ${appName} mounted successfully`);\r\n\r\n if (onMount) {\r\n onMount(container, instance);\r\n }\r\n } catch (error) {\r\n console.error(`[WuSvelte5] Mount error for ${appName}:`, error);\r\n throw error;\r\n }\r\n };\r\n\r\n // Función de unmount para Svelte 5\r\n const unmountApp = async (container) => {\r\n const appData = adapterState.apps.get(appName);\r\n\r\n if (appData) {\r\n try {\r\n if (onUnmount) {\r\n onUnmount(appData.container, appData.instance);\r\n }\r\n\r\n // Svelte 5 usa unmount()\r\n if (appData.isSvelte5) {\r\n try {\r\n const svelte = await import('svelte');\r\n if (svelte.unmount) {\r\n svelte.unmount(appData.instance);\r\n }\r\n } catch (e) {\r\n // Fallback\r\n if (appData.instance.$destroy) {\r\n appData.instance.$destroy();\r\n }\r\n }\r\n } else {\r\n appData.instance.$destroy();\r\n }\r\n\r\n adapterState.apps.delete(appName);\r\n console.log(`[WuSvelte5] ✅ ${appName} unmounted successfully`);\r\n } catch (error) {\r\n console.error(`[WuSvelte5] Unmount error for ${appName}:`, error);\r\n }\r\n }\r\n\r\n if (container) {\r\n container.innerHTML = '';\r\n }\r\n };\r\n\r\n // Intentar registrar con Wu Framework\r\n try {\r\n const wu = await waitForWu(3000);\r\n\r\n wu.define(appName, {\r\n mount: mountApp,\r\n unmount: unmountApp\r\n });\r\n\r\n console.log(`[WuSvelte5] ✅ ${appName} registered with Wu Framework`);\r\n return true;\r\n\r\n } catch (error) {\r\n console.warn(`[WuSvelte5] Wu Framework not available for ${appName}`);\r\n\r\n if (standalone) {\r\n const containerElement = document.querySelector(standaloneContainer);\r\n\r\n if (containerElement) {\r\n console.log(`[WuSvelte5] Running ${appName} in standalone mode`);\r\n await mountApp(containerElement);\r\n return true;\r\n }\r\n }\r\n\r\n return false;\r\n }\r\n}\r\n\r\n/**\r\n * Store reactivo para usar con Svelte\r\n * Compatible con la sintaxis $store de Svelte\r\n *\r\n * @param {string} namespace - Namespace en el store de Wu\r\n * @returns {Object} Store compatible con Svelte\r\n *\r\n * @example\r\n * <script>\r\n * import { createWuStore } from 'wu-framework/adapters/svelte';\r\n *\r\n * const userStore = createWuStore('user');\r\n *\r\n * // Usar con sintaxis reactiva\r\n * $: userName = $userStore?.name;\r\n *\r\n * function updateName(name) {\r\n * userStore.set('name', name);\r\n * }\r\n * </script>\r\n */\r\nfunction createWuStore(namespace = '') {\r\n const subscribers = new Set();\r\n let currentValue = null;\r\n let unsubscribeWu = null;\r\n\r\n // Obtener valor inicial\r\n const wu = getWuInstance();\r\n if (wu?.store) {\r\n currentValue = wu.store.get(namespace);\r\n\r\n // Suscribirse a cambios en Wu Store\r\n const pattern = namespace ? `${namespace}.*` : '*';\r\n unsubscribeWu = wu.store.on(pattern, () => {\r\n currentValue = wu.store.get(namespace);\r\n subscribers.forEach(fn => fn(currentValue));\r\n });\r\n }\r\n\r\n return {\r\n // Svelte store contract\r\n subscribe(fn) {\r\n subscribers.add(fn);\r\n fn(currentValue);\r\n\r\n return () => {\r\n subscribers.delete(fn);\r\n // Limpiar suscripción a Wu si no hay más subscribers\r\n if (subscribers.size === 0 && unsubscribeWu) {\r\n unsubscribeWu();\r\n unsubscribeWu = null;\r\n }\r\n };\r\n },\r\n\r\n // Métodos adicionales\r\n set(path, value) {\r\n const wu = getWuInstance();\r\n if (wu?.store) {\r\n const fullPath = namespace ? `${namespace}.${path}` : path;\r\n wu.store.set(fullPath, value);\r\n }\r\n },\r\n\r\n get(path = '') {\r\n const wu = getWuInstance();\r\n if (wu?.store) {\r\n const fullPath = namespace ? (path ? `${namespace}.${path}` : namespace) : path;\r\n return wu.store.get(fullPath);\r\n }\r\n return null;\r\n },\r\n\r\n update(fn) {\r\n const newValue = fn(currentValue);\r\n const wu = getWuInstance();\r\n if (wu?.store && namespace) {\r\n wu.store.set(namespace, newValue);\r\n }\r\n }\r\n };\r\n}\r\n\r\n/**\r\n * Store para eventos de Wu Framework\r\n * Permite usar eventos de forma reactiva en Svelte\r\n *\r\n * @example\r\n * <script>\r\n * import { createWuEventStore } from 'wu-framework/adapters/svelte';\r\n *\r\n * const userEvents = createWuEventStore('user:*');\r\n *\r\n * $: if ($userEvents) {\r\n * console.log('User event:', $userEvents);\r\n * }\r\n * </script>\r\n */\r\nfunction createWuEventStore(eventPattern) {\r\n const subscribers = new Set();\r\n let lastEvent = null;\r\n let unsubscribeWu = null;\r\n\r\n const wu = getWuInstance();\r\n if (wu?.eventBus) {\r\n unsubscribeWu = wu.eventBus.on(eventPattern, (event) => {\r\n lastEvent = event;\r\n subscribers.forEach(fn => fn(lastEvent));\r\n });\r\n }\r\n\r\n return {\r\n subscribe(fn) {\r\n subscribers.add(fn);\r\n fn(lastEvent);\r\n\r\n return () => {\r\n subscribers.delete(fn);\r\n if (subscribers.size === 0 && unsubscribeWu) {\r\n unsubscribeWu();\r\n unsubscribeWu = null;\r\n }\r\n };\r\n },\r\n\r\n emit(data, options) {\r\n const wu = getWuInstance();\r\n if (wu?.eventBus) {\r\n // Extraer nombre del evento del patrón (sin wildcard)\r\n const eventName = eventPattern.replace('*', 'custom');\r\n wu.eventBus.emit(eventName, data, options);\r\n }\r\n }\r\n };\r\n}\r\n\r\n/**\r\n * Helper para usar el EventBus de Wu en Svelte\r\n *\r\n * @example\r\n * <script>\r\n * import { useWuEvents } from 'wu-framework/adapters/svelte';\r\n * import { onDestroy } from 'svelte';\r\n *\r\n * const { emit, on, cleanup } = useWuEvents();\r\n *\r\n * on('user:login', (data) => {\r\n * console.log('User logged in:', data);\r\n * });\r\n *\r\n * onDestroy(cleanup);\r\n * </script>\r\n */\r\nfunction useWuEvents() {\r\n const subscriptions = [];\r\n\r\n const emit = (event, data, options) => {\r\n const wu = getWuInstance();\r\n if (wu?.eventBus) {\r\n wu.eventBus.emit(event, data, options);\r\n } else {\r\n console.warn('[useWuEvents] Wu Framework not available');\r\n }\r\n };\r\n\r\n const on = (event, callback) => {\r\n const wu = getWuInstance();\r\n if (wu?.eventBus) {\r\n const unsubscribe = wu.eventBus.on(event, callback);\r\n subscriptions.push(unsubscribe);\r\n return unsubscribe;\r\n }\r\n console.warn('[useWuEvents] Wu Framework not available');\r\n return () => {};\r\n };\r\n\r\n const once = (event, callback) => {\r\n const wu = getWuInstance();\r\n if (wu?.eventBus) {\r\n return wu.eventBus.once(event, callback);\r\n }\r\n return () => {};\r\n };\r\n\r\n const off = (event, callback) => {\r\n const wu = getWuInstance();\r\n if (wu?.eventBus) {\r\n wu.eventBus.off(event, callback);\r\n }\r\n };\r\n\r\n const cleanup = () => {\r\n subscriptions.forEach(unsub => unsub());\r\n subscriptions.length = 0;\r\n };\r\n\r\n return { emit, on, once, off, cleanup };\r\n}\r\n\r\n/**\r\n * Crea la configuración para un componente WuSlot en Svelte\r\n * Retorna el código del componente que se puede usar como referencia\r\n *\r\n * @example\r\n * // WuSlot.svelte - Crear manualmente basado en esta configuración\r\n * const config = createWuSlotConfig();\r\n * // Usar config.template como base para el componente\r\n */\r\nfunction createWuSlotConfig() {\r\n return {\r\n props: ['name', 'url', 'appName', 'fallbackText'],\r\n\r\n template: `\r\n<script>\r\n import { onMount, onDestroy, createEventDispatcher } from 'svelte';\r\n import { getWuInstance } from 'wu-framework/adapters/svelte';\r\n\r\n export let name;\r\n export let url;\r\n export let appName = null;\r\n export let fallbackText = null;\r\n\r\n const dispatch = createEventDispatcher();\r\n\r\n let container;\r\n let loading = true;\r\n let error = null;\r\n let appInstance = null;\r\n\r\n $: actualAppName = appName || name;\r\n\r\n onMount(async () => {\r\n await mountMicrofrontend();\r\n });\r\n\r\n onDestroy(() => {\r\n unmountMicrofrontend();\r\n });\r\n\r\n async function mountMicrofrontend() {\r\n try {\r\n loading = true;\r\n error = null;\r\n\r\n const wu = getWuInstance();\r\n if (!wu) {\r\n throw new Error('Wu Framework not initialized');\r\n }\r\n\r\n const containerId = \\`wu-slot-\\${actualAppName}-\\${Date.now()}\\`;\r\n const innerContainer = document.createElement('div');\r\n innerContainer.id = containerId;\r\n innerContainer.style.width = '100%';\r\n innerContainer.style.height = '100%';\r\n\r\n container.innerHTML = '';\r\n container.appendChild(innerContainer);\r\n\r\n const app = wu.app(actualAppName, {\r\n url,\r\n container: \\`#\\${containerId}\\`,\r\n autoInit: true\r\n });\r\n\r\n appInstance = app;\r\n await app.mount();\r\n\r\n loading = false;\r\n dispatch('load', { name: actualAppName, url });\r\n dispatch('mount', { name: actualAppName, container: innerContainer });\r\n\r\n } catch (err) {\r\n console.error(\\`[WuSlot] Error loading \\${actualAppName}:\\`, err);\r\n error = err.message || 'Failed to load microfrontend';\r\n loading = false;\r\n dispatch('error', err);\r\n }\r\n }\r\n\r\n async function unmountMicrofrontend() {\r\n if (appInstance) {\r\n dispatch('unmount', { name: actualAppName });\r\n\r\n try {\r\n await appInstance.unmount();\r\n } catch (err) {\r\n console.warn(\\`[WuSlot] Error unmounting \\${actualAppName}:\\`, err);\r\n }\r\n\r\n appInstance = null;\r\n }\r\n }\r\n</script>\r\n\r\n<div\r\n bind:this={container}\r\n class=\"wu-slot\"\r\n class:wu-slot-loading={loading}\r\n class:wu-slot-error={error}\r\n data-wu-app={actualAppName}\r\n data-wu-url={url}\r\n style=\"min-height: 100px; position: relative;\">\r\n\r\n {#if error}\r\n <div class=\"wu-slot-error-message\"\r\n style=\"padding: 1rem; border: 1px solid #f5c6cb; border-radius: 4px; background: #f8d7da; color: #721c24;\">\r\n <strong>Error loading {name}</strong>\r\n <p style=\"margin: 0.5rem 0 0 0;\">{error}</p>\r\n </div>\r\n {:else if loading}\r\n <div class=\"wu-slot-loading-message\"\r\n style=\"display: flex; align-items: center; justify-content: center; padding: 2rem; color: #666;\">\r\n {fallbackText || \\`Loading \\${name}...\\`}\r\n </div>\r\n {/if}\r\n</div>\r\n\r\n<style>\r\n .wu-slot {\r\n width: 100%;\r\n min-height: 100px;\r\n }\r\n</style>\r\n `.trim(),\r\n\r\n // Implementación JavaScript pura para usar sin .svelte\r\n createInstance: (target, props) => {\r\n const container = document.createElement('div');\r\n container.className = 'wu-slot';\r\n container.style.minHeight = '100px';\r\n container.style.position = 'relative';\r\n target.appendChild(container);\r\n\r\n let loading = true;\r\n let error = null;\r\n let appInstance = null;\r\n\r\n const actualAppName = props.appName || props.name;\r\n\r\n const updateUI = () => {\r\n if (error) {\r\n container.innerHTML = `\r\n <div style=\"padding: 1rem; border: 1px solid #f5c6cb; border-radius: 4px; background: #f8d7da; color: #721c24;\">\r\n <strong>Error loading ${props.name}</strong>\r\n <p style=\"margin: 0.5rem 0 0 0;\">${error}</p>\r\n </div>\r\n `;\r\n } else if (loading) {\r\n container.innerHTML = `\r\n <div style=\"display: flex; align-items: center; justify-content: center; padding: 2rem; color: #666;\">\r\n ${props.fallbackText || `Loading ${props.name}...`}\r\n </div>\r\n `;\r\n }\r\n };\r\n\r\n const mount = async () => {\r\n try {\r\n updateUI();\r\n\r\n const wu = getWuInstance();\r\n if (!wu) throw new Error('Wu Framework not initialized');\r\n\r\n const containerId = `wu-slot-${actualAppName}-${Date.now()}`;\r\n const innerContainer = document.createElement('div');\r\n innerContainer.id = containerId;\r\n innerContainer.style.cssText = 'width: 100%; height: 100%;';\r\n\r\n container.innerHTML = '';\r\n container.appendChild(innerContainer);\r\n\r\n const app = wu.app(actualAppName, {\r\n url: props.url,\r\n container: `#${containerId}`,\r\n autoInit: true\r\n });\r\n\r\n appInstance = app;\r\n await app.mount();\r\n\r\n loading = false;\r\n if (props.onLoad) props.onLoad({ name: actualAppName, url: props.url });\r\n\r\n } catch (err) {\r\n error = err.message;\r\n loading = false;\r\n updateUI();\r\n if (props.onError) props.onError(err);\r\n }\r\n };\r\n\r\n const destroy = async () => {\r\n if (appInstance) {\r\n try {\r\n await appInstance.unmount();\r\n } catch (e) {}\r\n appInstance = null;\r\n }\r\n container.remove();\r\n };\r\n\r\n mount();\r\n\r\n return { destroy };\r\n }\r\n };\r\n}\r\n\r\n// ============================================\r\n// AI INTEGRATION\r\n// ============================================\r\nimport { createWuAIStore } from './ai.js';\r\n\r\n// API pública del adapter\r\nexport const wuSvelte = {\r\n register,\r\n registerSvelte5,\r\n createWuStore,\r\n createWuEventStore,\r\n useWuEvents,\r\n createWuSlotConfig,\r\n createWuAIStore,\r\n getWuInstance,\r\n waitForWu\r\n};\r\n\r\nexport {\r\n register,\r\n registerSvelte5,\r\n createWuStore,\r\n createWuEventStore,\r\n useWuEvents,\r\n createWuSlotConfig,\r\n createWuAIStore,\r\n getWuInstance,\r\n waitForWu\r\n};\r\n\r\nexport default wuSvelte;\r\n"],"names":["createWuAIStore","options","namespace","subscribers","Set","state","messages","isStreaming","error","notify","forEach","fn","subscribe","add","delete","send","text","trim","wu","window","parent","top","ai","id","Date","now","role","content","timestamp","res","err","message","clear","adapterState","apps","Map","initialized","getWuInstance","waitForWu","timeout","Promise","resolve","reject","startTime","handleWuReady","cleanup","addEventListener","checkInterval","setInterval","Error","clearInterval","removeEventListener","async","register","appName","Component","props","context","intro","onMount","onUnmount","standalone","standaloneContainer","mountApp","container","has","console","warn","unmountApp","innerHTML","instance","target","wuAppName","wuInstance","set","log","appData","get","$destroy","define","mount","unmount","containerElement","document","querySelector","registerSvelte5","mountFn","import","e","isSvelte5","svelte","createWuStore","currentValue","unsubscribeWu","store","pattern","on","size","path","value","fullPath","update","newValue","createWuEventStore","eventPattern","lastEvent","eventBus","event","emit","data","eventName","replace","useWuEvents","subscriptions","callback","unsubscribe","push","once","off","unsub","length","createWuSlotConfig","template","createInstance","createElement","className","style","minHeight","position","appendChild","loading","appInstance","actualAppName","name","updateUI","fallbackText","containerId","innerContainer","cssText","app","url","autoInit","onLoad","onError","destroy","remove","wuSvelte"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../../src/adapters/svelte/ai.js","../../../src/adapters/svelte/index.js"],"sourcesContent":["/**\n * WU-FRAMEWORK SVELTE AI INTEGRATION\n */\nfunction getWuInstance() {\n if (typeof window === 'undefined') return null;\n return window.wu || window.parent?.wu || window.top?.wu || null;\n}\n\nexport function createWuAIStore(options = {}) {\n const { namespace = 'default' } = options;\n const subscribers = new Set();\n let state = { messages: [], isStreaming: false, error: null };\n function notify() { subscribers.forEach(fn => fn(state)); }\n\n return {\n subscribe(fn) { subscribers.add(fn); fn(state); return () => subscribers.delete(fn); },\n async send(text) {\n if (!text?.trim()) return;\n const wu = getWuInstance();\n if (!wu?.ai) { state = { ...state, error: 'Wu AI not available' }; notify(); return; }\n state = { ...state, messages: [...state.messages, { id: `user-${Date.now()}`, role: 'user', content: text, timestamp: Date.now() }], isStreaming: true, error: null };\n notify();\n try {\n const res = await wu.ai.send(text, { namespace });\n state = { ...state, messages: [...state.messages, { id: `assistant-${Date.now()}`, role: 'assistant', content: res.content, timestamp: Date.now() }], isStreaming: false };\n } catch (err) { state = { ...state, isStreaming: false, error: err.message }; }\n notify();\n },\n clear() { state = { messages: [], isStreaming: false, error: null }; notify(); },\n };\n}\n","/**\n * 🚀 WU-FRAMEWORK SVELTE ADAPTER\n *\n * Simplifica la integración de Svelte con Wu Framework.\n * Convierte componentes Svelte en microfrontends con UNA línea de código.\n *\n * @example\n * // Microfrontend (main.js)\n * import { wuSvelte } from 'wu-framework/adapters/svelte';\n * import App from './App.svelte';\n *\n * wuSvelte.register('my-app', App);\n *\n * @example\n * // Shell (cargar microfrontend)\n * import WuSlot from 'wu-framework/adapters/svelte/WuSlot.svelte';\n *\n * <WuSlot name=\"my-app\" url=\"http://localhost:3001\" />\n */\n\n// Estado global del adapter\nconst adapterState = {\n apps: new Map(),\n initialized: false\n};\n\n/**\n * Obtiene la instancia de Wu Framework\n */\nfunction getWuInstance() {\n if (typeof window === 'undefined') return null;\n\n return window.wu\n || window.parent?.wu\n || window.top?.wu\n || null;\n}\n\n/**\n * Espera a que Wu Framework esté disponible\n */\nfunction waitForWu(timeout = 5000) {\n return new Promise((resolve, reject) => {\n const wu = getWuInstance();\n if (wu) {\n resolve(wu);\n return;\n }\n\n const startTime = Date.now();\n\n const handleWuReady = () => {\n cleanup();\n resolve(getWuInstance());\n };\n\n window.addEventListener('wu:ready', handleWuReady);\n window.addEventListener('wu:app:ready', handleWuReady);\n\n const checkInterval = setInterval(() => {\n const wu = getWuInstance();\n if (wu) {\n cleanup();\n resolve(wu);\n return;\n }\n\n if (Date.now() - startTime > timeout) {\n cleanup();\n reject(new Error(`Wu Framework not found after ${timeout}ms`));\n }\n }, 200);\n\n function cleanup() {\n clearInterval(checkInterval);\n window.removeEventListener('wu:ready', handleWuReady);\n window.removeEventListener('wu:app:ready', handleWuReady);\n }\n });\n}\n\n/**\n * Registra un componente Svelte como microfrontend\n *\n * @param {string} appName - Nombre único del microfrontend (debe coincidir con wu.json)\n * @param {typeof SvelteComponent} Component - Componente Svelte principal (App.svelte)\n * @param {Object} options - Opciones adicionales\n * @param {Object} options.props - Props iniciales para el componente\n * @param {Object} options.context - Contexto a pasar al componente\n * @param {boolean} options.intro - Ejecutar transiciones de intro (default: false)\n * @param {Function} options.onMount - Callback después de montar\n * @param {Function} options.onUnmount - Callback antes de desmontar\n * @param {boolean} options.standalone - Permitir ejecución standalone (default: true)\n * @param {string} options.standaloneContainer - Selector para modo standalone (default: '#app')\n *\n * @example\n * // Básico\n * wuSvelte.register('my-app', App);\n *\n * @example\n * // Con props y context\n * wuSvelte.register('my-app', App, {\n * props: { apiUrl: 'https://api.example.com' },\n * context: new Map([['theme', 'dark']]),\n * onMount: (container) => console.log('Mounted!')\n * });\n */\nasync function register(appName, Component, options = {}) {\n const {\n props = {},\n context = new Map(),\n intro = false,\n onMount = null,\n onUnmount = null,\n standalone = true,\n standaloneContainer = '#app'\n } = options;\n\n // Función de mount interna\n const mountApp = (container) => {\n if (!container) {\n console.error(`[WuSvelte] Mount failed for ${appName}: container is null`);\n return;\n }\n\n // Evitar doble mount\n if (adapterState.apps.has(appName)) {\n console.warn(`[WuSvelte] ${appName} already mounted, unmounting first`);\n unmountApp();\n }\n\n try {\n // Limpiar container\n container.innerHTML = '';\n\n // Crear instancia del componente Svelte\n const instance = new Component({\n target: container,\n props: {\n ...props,\n // Inyectar información de Wu\n wuAppName: appName,\n wuInstance: getWuInstance()\n },\n context,\n intro\n });\n\n // Guardar referencia\n adapterState.apps.set(appName, {\n instance,\n container,\n Component\n });\n\n console.log(`[WuSvelte] ✅ ${appName} mounted successfully`);\n\n if (onMount) {\n onMount(container, instance);\n }\n } catch (error) {\n console.error(`[WuSvelte] Mount error for ${appName}:`, error);\n throw error;\n }\n };\n\n // Función de unmount interna\n const unmountApp = (container) => {\n const appData = adapterState.apps.get(appName);\n\n if (appData) {\n try {\n if (onUnmount) {\n onUnmount(appData.container, appData.instance);\n }\n\n // Destruir instancia de Svelte\n appData.instance.$destroy();\n adapterState.apps.delete(appName);\n\n console.log(`[WuSvelte] ✅ ${appName} unmounted successfully`);\n } catch (error) {\n console.error(`[WuSvelte] Unmount error for ${appName}:`, error);\n }\n }\n\n // Limpiar container si se proporciona\n if (container) {\n container.innerHTML = '';\n }\n };\n\n // Intentar registrar con Wu Framework\n try {\n const wu = await waitForWu(3000);\n\n wu.define(appName, {\n mount: mountApp,\n unmount: unmountApp\n });\n\n console.log(`[WuSvelte] ✅ ${appName} registered with Wu Framework`);\n return true;\n\n } catch (error) {\n console.warn(`[WuSvelte] Wu Framework not available for ${appName}`);\n\n // Modo standalone si está habilitado\n if (standalone) {\n const containerElement = document.querySelector(standaloneContainer);\n\n if (containerElement) {\n console.log(`[WuSvelte] Running ${appName} in standalone mode`);\n mountApp(containerElement);\n return true;\n } else {\n console.warn(`[WuSvelte] Standalone container ${standaloneContainer} not found`);\n }\n }\n\n return false;\n }\n}\n\n/**\n * Registra un componente Svelte 5 con runes como microfrontend\n *\n * @param {string} appName - Nombre único del microfrontend\n * @param {typeof SvelteComponent} Component - Componente Svelte 5\n * @param {Object} options - Opciones adicionales\n *\n * @example\n * // Svelte 5 con mount API\n * import { wuSvelte } from 'wu-framework/adapters/svelte';\n * import App from './App.svelte';\n *\n * wuSvelte.registerSvelte5('my-app', App);\n */\nasync function registerSvelte5(appName, Component, options = {}) {\n const {\n props = {},\n onMount = null,\n onUnmount = null,\n standalone = true,\n standaloneContainer = '#app'\n } = options;\n\n // Función de mount para Svelte 5\n const mountApp = async (container) => {\n if (!container) {\n console.error(`[WuSvelte5] Mount failed for ${appName}: container is null`);\n return;\n }\n\n // Evitar doble mount\n if (adapterState.apps.has(appName)) {\n console.warn(`[WuSvelte5] ${appName} already mounted, unmounting first`);\n await unmountApp();\n }\n\n try {\n container.innerHTML = '';\n\n // Svelte 5 usa mount() del módulo svelte\n let mountFn;\n try {\n const svelte = await import('svelte');\n mountFn = svelte.mount;\n } catch (e) {\n // Fallback a API legacy\n console.warn('[WuSvelte5] Svelte 5 mount not available, using legacy API');\n return register(appName, Component, options);\n }\n\n // Montar con Svelte 5 API\n const instance = mountFn(Component, {\n target: container,\n props: {\n ...props,\n wuAppName: appName,\n wuInstance: getWuInstance()\n }\n });\n\n adapterState.apps.set(appName, {\n instance,\n container,\n Component,\n isSvelte5: true\n });\n\n console.log(`[WuSvelte5] ✅ ${appName} mounted successfully`);\n\n if (onMount) {\n onMount(container, instance);\n }\n } catch (error) {\n console.error(`[WuSvelte5] Mount error for ${appName}:`, error);\n throw error;\n }\n };\n\n // Función de unmount para Svelte 5\n const unmountApp = async (container) => {\n const appData = adapterState.apps.get(appName);\n\n if (appData) {\n try {\n if (onUnmount) {\n onUnmount(appData.container, appData.instance);\n }\n\n // Svelte 5 usa unmount()\n if (appData.isSvelte5) {\n try {\n const svelte = await import('svelte');\n if (svelte.unmount) {\n svelte.unmount(appData.instance);\n }\n } catch (e) {\n // Fallback\n if (appData.instance.$destroy) {\n appData.instance.$destroy();\n }\n }\n } else {\n appData.instance.$destroy();\n }\n\n adapterState.apps.delete(appName);\n console.log(`[WuSvelte5] ✅ ${appName} unmounted successfully`);\n } catch (error) {\n console.error(`[WuSvelte5] Unmount error for ${appName}:`, error);\n }\n }\n\n if (container) {\n container.innerHTML = '';\n }\n };\n\n // Intentar registrar con Wu Framework\n try {\n const wu = await waitForWu(3000);\n\n wu.define(appName, {\n mount: mountApp,\n unmount: unmountApp\n });\n\n console.log(`[WuSvelte5] ✅ ${appName} registered with Wu Framework`);\n return true;\n\n } catch (error) {\n console.warn(`[WuSvelte5] Wu Framework not available for ${appName}`);\n\n if (standalone) {\n const containerElement = document.querySelector(standaloneContainer);\n\n if (containerElement) {\n console.log(`[WuSvelte5] Running ${appName} in standalone mode`);\n await mountApp(containerElement);\n return true;\n }\n }\n\n return false;\n }\n}\n\n/**\n * Store reactivo para usar con Svelte\n * Compatible con la sintaxis $store de Svelte\n *\n * @param {string} namespace - Namespace en el store de Wu\n * @returns {Object} Store compatible con Svelte\n *\n * @example\n * <script>\n * import { createWuStore } from 'wu-framework/adapters/svelte';\n *\n * const userStore = createWuStore('user');\n *\n * // Usar con sintaxis reactiva\n * $: userName = $userStore?.name;\n *\n * function updateName(name) {\n * userStore.set('name', name);\n * }\n * </script>\n */\nfunction createWuStore(namespace = '') {\n const subscribers = new Set();\n let currentValue = null;\n let unsubscribeWu = null;\n\n // Obtener valor inicial\n const wu = getWuInstance();\n if (wu?.store) {\n currentValue = wu.store.get(namespace);\n\n // Suscribirse a cambios en Wu Store\n const pattern = namespace ? `${namespace}.*` : '*';\n unsubscribeWu = wu.store.on(pattern, () => {\n currentValue = wu.store.get(namespace);\n subscribers.forEach(fn => fn(currentValue));\n });\n }\n\n return {\n // Svelte store contract\n subscribe(fn) {\n subscribers.add(fn);\n fn(currentValue);\n\n return () => {\n subscribers.delete(fn);\n // Limpiar suscripción a Wu si no hay más subscribers\n if (subscribers.size === 0 && unsubscribeWu) {\n unsubscribeWu();\n unsubscribeWu = null;\n }\n };\n },\n\n // Métodos adicionales\n set(path, value) {\n const wu = getWuInstance();\n if (wu?.store) {\n const fullPath = namespace ? `${namespace}.${path}` : path;\n wu.store.set(fullPath, value);\n }\n },\n\n get(path = '') {\n const wu = getWuInstance();\n if (wu?.store) {\n const fullPath = namespace ? (path ? `${namespace}.${path}` : namespace) : path;\n return wu.store.get(fullPath);\n }\n return null;\n },\n\n update(fn) {\n const newValue = fn(currentValue);\n const wu = getWuInstance();\n if (wu?.store && namespace) {\n wu.store.set(namespace, newValue);\n }\n }\n };\n}\n\n/**\n * Store para eventos de Wu Framework\n * Permite usar eventos de forma reactiva en Svelte\n *\n * @example\n * <script>\n * import { createWuEventStore } from 'wu-framework/adapters/svelte';\n *\n * const userEvents = createWuEventStore('user:*');\n *\n * $: if ($userEvents) {\n * console.log('User event:', $userEvents);\n * }\n * </script>\n */\nfunction createWuEventStore(eventPattern) {\n const subscribers = new Set();\n let lastEvent = null;\n let unsubscribeWu = null;\n\n const wu = getWuInstance();\n if (wu?.eventBus) {\n unsubscribeWu = wu.eventBus.on(eventPattern, (event) => {\n lastEvent = event;\n subscribers.forEach(fn => fn(lastEvent));\n });\n }\n\n return {\n subscribe(fn) {\n subscribers.add(fn);\n fn(lastEvent);\n\n return () => {\n subscribers.delete(fn);\n if (subscribers.size === 0 && unsubscribeWu) {\n unsubscribeWu();\n unsubscribeWu = null;\n }\n };\n },\n\n emit(data, options) {\n const wu = getWuInstance();\n if (wu?.eventBus) {\n // Extraer nombre del evento del patrón (sin wildcard)\n const eventName = eventPattern.replace('*', 'custom');\n wu.eventBus.emit(eventName, data, options);\n }\n }\n };\n}\n\n/**\n * Helper para usar el EventBus de Wu en Svelte\n *\n * @example\n * <script>\n * import { useWuEvents } from 'wu-framework/adapters/svelte';\n * import { onDestroy } from 'svelte';\n *\n * const { emit, on, cleanup } = useWuEvents();\n *\n * on('user:login', (data) => {\n * console.log('User logged in:', data);\n * });\n *\n * onDestroy(cleanup);\n * </script>\n */\nfunction useWuEvents() {\n const subscriptions = [];\n\n const emit = (event, data, options) => {\n const wu = getWuInstance();\n if (wu?.eventBus) {\n wu.eventBus.emit(event, data, options);\n } else {\n console.warn('[useWuEvents] Wu Framework not available');\n }\n };\n\n const on = (event, callback) => {\n const wu = getWuInstance();\n if (wu?.eventBus) {\n const unsubscribe = wu.eventBus.on(event, callback);\n subscriptions.push(unsubscribe);\n return unsubscribe;\n }\n console.warn('[useWuEvents] Wu Framework not available');\n return () => {};\n };\n\n const once = (event, callback) => {\n const wu = getWuInstance();\n if (wu?.eventBus) {\n return wu.eventBus.once(event, callback);\n }\n return () => {};\n };\n\n const off = (event, callback) => {\n const wu = getWuInstance();\n if (wu?.eventBus) {\n wu.eventBus.off(event, callback);\n }\n };\n\n const cleanup = () => {\n subscriptions.forEach(unsub => unsub());\n subscriptions.length = 0;\n };\n\n return { emit, on, once, off, cleanup };\n}\n\n/**\n * Crea la configuración para un componente WuSlot en Svelte\n * Retorna el código del componente que se puede usar como referencia\n *\n * @example\n * // WuSlot.svelte - Crear manualmente basado en esta configuración\n * const config = createWuSlotConfig();\n * // Usar config.template como base para el componente\n */\nfunction createWuSlotConfig() {\n return {\n props: ['name', 'url', 'appName', 'fallbackText'],\n\n template: `\n<script>\n import { onMount, onDestroy, createEventDispatcher } from 'svelte';\n import { getWuInstance } from 'wu-framework/adapters/svelte';\n\n export let name;\n export let url;\n export let appName = null;\n export let fallbackText = null;\n\n const dispatch = createEventDispatcher();\n\n let container;\n let loading = true;\n let error = null;\n let appInstance = null;\n\n $: actualAppName = appName || name;\n\n onMount(async () => {\n await mountMicrofrontend();\n });\n\n onDestroy(() => {\n unmountMicrofrontend();\n });\n\n async function mountMicrofrontend() {\n try {\n loading = true;\n error = null;\n\n const wu = getWuInstance();\n if (!wu) {\n throw new Error('Wu Framework not initialized');\n }\n\n const containerId = \\`wu-slot-\\${actualAppName}-\\${Date.now()}\\`;\n const innerContainer = document.createElement('div');\n innerContainer.id = containerId;\n innerContainer.style.width = '100%';\n innerContainer.style.height = '100%';\n\n container.innerHTML = '';\n container.appendChild(innerContainer);\n\n const app = wu.app(actualAppName, {\n url,\n container: \\`#\\${containerId}\\`,\n autoInit: true\n });\n\n appInstance = app;\n await app.mount();\n\n loading = false;\n dispatch('load', { name: actualAppName, url });\n dispatch('mount', { name: actualAppName, container: innerContainer });\n\n } catch (err) {\n console.error(\\`[WuSlot] Error loading \\${actualAppName}:\\`, err);\n error = err.message || 'Failed to load microfrontend';\n loading = false;\n dispatch('error', err);\n }\n }\n\n async function unmountMicrofrontend() {\n if (appInstance) {\n dispatch('unmount', { name: actualAppName });\n\n try {\n await appInstance.unmount();\n } catch (err) {\n console.warn(\\`[WuSlot] Error unmounting \\${actualAppName}:\\`, err);\n }\n\n appInstance = null;\n }\n }\n</script>\n\n<div\n bind:this={container}\n class=\"wu-slot\"\n class:wu-slot-loading={loading}\n class:wu-slot-error={error}\n data-wu-app={actualAppName}\n data-wu-url={url}\n style=\"min-height: 100px; position: relative;\">\n\n {#if error}\n <div class=\"wu-slot-error-message\"\n style=\"padding: 1rem; border: 1px solid #f5c6cb; border-radius: 4px; background: #f8d7da; color: #721c24;\">\n <strong>Error loading {name}</strong>\n <p style=\"margin: 0.5rem 0 0 0;\">{error}</p>\n </div>\n {:else if loading}\n <div class=\"wu-slot-loading-message\"\n style=\"display: flex; align-items: center; justify-content: center; padding: 2rem; color: #666;\">\n {fallbackText || \\`Loading \\${name}...\\`}\n </div>\n {/if}\n</div>\n\n<style>\n .wu-slot {\n width: 100%;\n min-height: 100px;\n }\n</style>\n `.trim(),\n\n // Implementación JavaScript pura para usar sin .svelte\n createInstance: (target, props) => {\n const container = document.createElement('div');\n container.className = 'wu-slot';\n container.style.minHeight = '100px';\n container.style.position = 'relative';\n target.appendChild(container);\n\n let loading = true;\n let error = null;\n let appInstance = null;\n\n const actualAppName = props.appName || props.name;\n\n const updateUI = () => {\n if (error) {\n container.innerHTML = `\n <div style=\"padding: 1rem; border: 1px solid #f5c6cb; border-radius: 4px; background: #f8d7da; color: #721c24;\">\n <strong>Error loading ${props.name}</strong>\n <p style=\"margin: 0.5rem 0 0 0;\">${error}</p>\n </div>\n `;\n } else if (loading) {\n container.innerHTML = `\n <div style=\"display: flex; align-items: center; justify-content: center; padding: 2rem; color: #666;\">\n ${props.fallbackText || `Loading ${props.name}...`}\n </div>\n `;\n }\n };\n\n const mount = async () => {\n try {\n updateUI();\n\n const wu = getWuInstance();\n if (!wu) throw new Error('Wu Framework not initialized');\n\n const containerId = `wu-slot-${actualAppName}-${Date.now()}`;\n const innerContainer = document.createElement('div');\n innerContainer.id = containerId;\n innerContainer.style.cssText = 'width: 100%; height: 100%;';\n\n container.innerHTML = '';\n container.appendChild(innerContainer);\n\n const app = wu.app(actualAppName, {\n url: props.url,\n container: `#${containerId}`,\n autoInit: true\n });\n\n appInstance = app;\n await app.mount();\n\n loading = false;\n if (props.onLoad) props.onLoad({ name: actualAppName, url: props.url });\n\n } catch (err) {\n error = err.message;\n loading = false;\n updateUI();\n if (props.onError) props.onError(err);\n }\n };\n\n const destroy = async () => {\n if (appInstance) {\n try {\n await appInstance.unmount();\n } catch (e) {}\n appInstance = null;\n }\n container.remove();\n };\n\n mount();\n\n return { destroy };\n }\n };\n}\n\n// ============================================\n// AI INTEGRATION\n// ============================================\nimport { createWuAIStore } from './ai.js';\n\n// API pública del adapter\nexport const wuSvelte = {\n register,\n registerSvelte5,\n createWuStore,\n createWuEventStore,\n useWuEvents,\n createWuSlotConfig,\n createWuAIStore,\n getWuInstance,\n waitForWu\n};\n\nexport {\n register,\n registerSvelte5,\n createWuStore,\n createWuEventStore,\n useWuEvents,\n createWuSlotConfig,\n createWuAIStore,\n getWuInstance,\n waitForWu\n};\n\nexport default wuSvelte;\n"],"names":["createWuAIStore","options","namespace","subscribers","Set","state","messages","isStreaming","error","notify","forEach","fn","subscribe","add","delete","send","text","trim","wu","window","parent","top","ai","id","Date","now","role","content","timestamp","res","err","message","clear","adapterState","apps","Map","initialized","getWuInstance","waitForWu","timeout","Promise","resolve","reject","startTime","handleWuReady","cleanup","addEventListener","checkInterval","setInterval","Error","clearInterval","removeEventListener","async","register","appName","Component","props","context","intro","onMount","onUnmount","standalone","standaloneContainer","mountApp","container","has","console","warn","unmountApp","innerHTML","instance","target","wuAppName","wuInstance","set","log","appData","get","$destroy","define","mount","unmount","containerElement","document","querySelector","registerSvelte5","mountFn","import","e","isSvelte5","svelte","createWuStore","currentValue","unsubscribeWu","store","pattern","on","size","path","value","fullPath","update","newValue","createWuEventStore","eventPattern","lastEvent","eventBus","event","emit","data","eventName","replace","useWuEvents","subscriptions","callback","unsubscribe","push","once","off","unsub","length","createWuSlotConfig","template","createInstance","createElement","className","style","minHeight","position","appendChild","loading","appInstance","actualAppName","name","updateUI","fallbackText","containerId","innerContainer","cssText","app","url","autoInit","onLoad","onError","destroy","remove","wuSvelte"],"mappings":"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"}
@@ -1,3 +1,3 @@
1
- // Re-export from folder structure — backward compatibility
2
- export * from './svelte/index';
3
- export { default } from './svelte/index';
1
+ // Re-export from folder structure — backward compatibility
2
+ export * from './svelte/index';
3
+ export { default } from './svelte/index';