wu-framework 1.1.7 → 1.1.9

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 (95) hide show
  1. package/LICENSE +19 -1
  2. package/README.md +257 -1122
  3. package/dist/wu-framework.cjs.js +3 -1
  4. package/dist/wu-framework.cjs.js.map +1 -0
  5. package/dist/wu-framework.dev.js +9867 -3183
  6. package/dist/wu-framework.dev.js.map +1 -1
  7. package/dist/wu-framework.esm.js +3 -0
  8. package/dist/wu-framework.esm.js.map +1 -0
  9. package/dist/wu-framework.umd.js +3 -1
  10. package/dist/wu-framework.umd.js.map +1 -0
  11. package/integrations/astro/README.md +127 -0
  12. package/integrations/astro/WuApp.astro +63 -0
  13. package/integrations/astro/WuShell.astro +39 -0
  14. package/integrations/astro/index.js +68 -0
  15. package/integrations/astro/package.json +38 -0
  16. package/integrations/astro/types.d.ts +53 -0
  17. package/package.json +96 -72
  18. package/src/adapters/angular/ai.js +30 -0
  19. package/src/adapters/angular/index.d.ts +154 -0
  20. package/src/adapters/angular/index.js +932 -0
  21. package/src/adapters/angular.d.ts +3 -154
  22. package/src/adapters/angular.js +3 -813
  23. package/src/adapters/index.js +35 -24
  24. package/src/adapters/lit/ai.js +20 -0
  25. package/src/adapters/lit/index.d.ts +120 -0
  26. package/src/adapters/lit/index.js +721 -0
  27. package/src/adapters/lit.d.ts +3 -120
  28. package/src/adapters/lit.js +3 -726
  29. package/src/adapters/preact/ai.js +33 -0
  30. package/src/adapters/preact/index.d.ts +108 -0
  31. package/src/adapters/preact/index.js +661 -0
  32. package/src/adapters/preact.d.ts +3 -108
  33. package/src/adapters/preact.js +3 -665
  34. package/src/adapters/react/ai.js +135 -0
  35. package/src/adapters/react/index.d.ts +246 -0
  36. package/src/adapters/react/index.js +694 -0
  37. package/src/adapters/react.d.ts +3 -212
  38. package/src/adapters/react.js +3 -513
  39. package/src/adapters/shared.js +64 -0
  40. package/src/adapters/solid/ai.js +32 -0
  41. package/src/adapters/solid/index.d.ts +101 -0
  42. package/src/adapters/solid/index.js +586 -0
  43. package/src/adapters/solid.d.ts +3 -101
  44. package/src/adapters/solid.js +3 -591
  45. package/src/adapters/svelte/ai.js +31 -0
  46. package/src/adapters/svelte/index.d.ts +166 -0
  47. package/src/adapters/svelte/index.js +798 -0
  48. package/src/adapters/svelte.d.ts +3 -166
  49. package/src/adapters/svelte.js +3 -803
  50. package/src/adapters/vanilla/ai.js +30 -0
  51. package/src/adapters/vanilla/index.d.ts +179 -0
  52. package/src/adapters/vanilla/index.js +785 -0
  53. package/src/adapters/vanilla.d.ts +3 -179
  54. package/src/adapters/vanilla.js +3 -791
  55. package/src/adapters/vue/ai.js +52 -0
  56. package/src/adapters/vue/index.d.ts +299 -0
  57. package/src/adapters/vue/index.js +608 -0
  58. package/src/adapters/vue.d.ts +3 -299
  59. package/src/adapters/vue.js +3 -611
  60. package/src/ai/wu-ai-actions.js +261 -0
  61. package/src/ai/wu-ai-agent.js +546 -0
  62. package/src/ai/wu-ai-browser-primitives.js +354 -0
  63. package/src/ai/wu-ai-browser.js +380 -0
  64. package/src/ai/wu-ai-context.js +332 -0
  65. package/src/ai/wu-ai-conversation.js +613 -0
  66. package/src/ai/wu-ai-orchestrate.js +1021 -0
  67. package/src/ai/wu-ai-permissions.js +381 -0
  68. package/src/ai/wu-ai-provider.js +700 -0
  69. package/src/ai/wu-ai-schema.js +225 -0
  70. package/src/ai/wu-ai-triggers.js +396 -0
  71. package/src/ai/wu-ai.js +804 -0
  72. package/src/core/wu-app.js +50 -8
  73. package/src/core/wu-cache.js +2 -3
  74. package/src/core/wu-core.js +648 -681
  75. package/src/core/wu-html-parser.js +121 -211
  76. package/src/core/wu-iframe-sandbox.js +328 -0
  77. package/src/core/wu-mcp-bridge.js +431 -0
  78. package/src/core/wu-overrides.js +510 -0
  79. package/src/core/wu-plugin.js +4 -1
  80. package/src/core/wu-prefetch.js +414 -0
  81. package/src/core/wu-proxy-sandbox.js +398 -75
  82. package/src/core/wu-sandbox.js +86 -268
  83. package/src/core/wu-script-executor.js +79 -182
  84. package/src/core/wu-snapshot-sandbox.js +149 -106
  85. package/src/core/wu-strategies.js +13 -0
  86. package/src/core/wu-style-bridge.js +23 -23
  87. package/src/index.js +162 -665
  88. package/dist/wu-framework.hex.js +0 -23
  89. package/dist/wu-framework.min.js +0 -1
  90. package/dist/wu-framework.obf.js +0 -1
  91. package/scripts/build-protected.js +0 -366
  92. package/scripts/build.js +0 -212
  93. package/scripts/rollup-plugin-hex.js +0 -143
  94. package/src/core/wu-registry.js +0 -60
  95. package/src/core/wu-sandbox-pool.js +0 -390
@@ -0,0 +1,127 @@
1
+ # @wu-framework/astro
2
+
3
+ Astro integration for **wu-framework** microfrontends. Mount wu micro-apps inside any Astro site with zero runtime overhead at build time.
4
+
5
+ ## Installation
6
+
7
+ ```bash
8
+ npm install @wu-framework/astro wu-framework
9
+ ```
10
+
11
+ ## Quick Start
12
+
13
+ ### 1. Add the integration
14
+
15
+ ```js
16
+ // astro.config.mjs
17
+ import { defineConfig } from 'astro/config';
18
+ import wu from '@wu-framework/astro';
19
+
20
+ export default defineConfig({
21
+ integrations: [
22
+ wu({
23
+ apps: [
24
+ { name: 'header', url: '/apps/header', strategy: 'eager' },
25
+ { name: 'dashboard', url: '/apps/dashboard' }
26
+ ]
27
+ })
28
+ ]
29
+ });
30
+ ```
31
+
32
+ The integration injects the wu-framework runtime and auto-calls `wu.init()` with your apps config.
33
+
34
+ ### 2. Mount micro-apps in pages
35
+
36
+ ```astro
37
+ ---
38
+ import WuApp from '@wu-framework/astro/WuApp.astro';
39
+ ---
40
+
41
+ <WuApp name="header" />
42
+ <WuApp name="dashboard" lazy />
43
+ ```
44
+
45
+ The `lazy` prop defers mounting until the element scrolls into view (uses `IntersectionObserver` with a 200px root margin).
46
+
47
+ ## Components
48
+
49
+ ### `WuApp`
50
+
51
+ Renders a mount point and calls `wu.mount()` on the client.
52
+
53
+ | Prop | Type | Default | Description |
54
+ | ------- | --------- | ------- | ---------------------------------------- |
55
+ | `name` | `string` | — | Name of the registered micro-app |
56
+ | `lazy` | `boolean` | `false` | Defer mount until visible |
57
+ | `class` | `string` | — | CSS class(es) for the container |
58
+ | `style` | `string` | — | Inline styles for the container |
59
+
60
+ ### `WuShell`
61
+
62
+ Layout wrapper that calls `wu.init()` on the client. Useful when you want page-level control instead of the global integration.
63
+
64
+ ```astro
65
+ ---
66
+ import WuShell from '@wu-framework/astro/WuShell.astro';
67
+ ---
68
+
69
+ <WuShell apps={[{ name: 'header', url: '/apps/header' }]}>
70
+ <main>Page content here</main>
71
+ </WuShell>
72
+ ```
73
+
74
+ | Prop | Type | Default | Description |
75
+ | --------- | -------------- | ------- | --------------------------- |
76
+ | `apps` | `WuAppConfig[]`| — | Micro-app definitions |
77
+ | `sandbox` | `string` | — | Sandbox mode |
78
+ | `debug` | `boolean` | `false` | Enable debug logging |
79
+
80
+ ## Integration Options
81
+
82
+ | Option | Type | Default | Description |
83
+ | --------- | --------------- | ------- | ----------------------------------------------- |
84
+ | `apps` | `WuAppConfig[]` | `[]` | Auto-register apps via `wu.init()` |
85
+ | `sandbox` | `string` | — | Global sandbox mode (`module`/`strict`/`eval`) |
86
+ | `cdn` | `string` | — | CDN URL for wu-framework UMD bundle |
87
+ | `debug` | `boolean` | `false` | Enable debug logging |
88
+
89
+ ## Usage Patterns
90
+
91
+ ### Integration only (auto-init)
92
+
93
+ Use the integration in `astro.config.mjs` to auto-init, then mount with `WuApp`:
94
+
95
+ ```astro
96
+ ---
97
+ import WuApp from '@wu-framework/astro/WuApp.astro';
98
+ ---
99
+ <WuApp name="header" />
100
+ ```
101
+
102
+ ### Shell layout (page-level init)
103
+
104
+ Skip the integration's `apps` option and use `WuShell` for per-page control:
105
+
106
+ ```astro
107
+ ---
108
+ import WuShell from '@wu-framework/astro/WuShell.astro';
109
+ import WuApp from '@wu-framework/astro/WuApp.astro';
110
+ ---
111
+ <WuShell apps={[{ name: 'nav', url: '/apps/nav' }]}>
112
+ <WuApp name="nav" />
113
+ <slot />
114
+ </WuShell>
115
+ ```
116
+
117
+ ### CDN mode
118
+
119
+ Load wu-framework from a CDN instead of bundling it:
120
+
121
+ ```js
122
+ wu({ cdn: 'https://cdn.example.com/wu-framework@1.1.8/dist/wu-framework.umd.js' })
123
+ ```
124
+
125
+ ## License
126
+
127
+ MIT
@@ -0,0 +1,63 @@
1
+ ---
2
+ /**
3
+ * WuApp — Mount point for a wu micro-app.
4
+ *
5
+ * Renders a <div> and runs wu.mount() on the client to hydrate
6
+ * the named micro-app into it. When `lazy` is true the mount
7
+ * is deferred until the element scrolls into view.
8
+ *
9
+ * @example
10
+ * ---
11
+ * import WuApp from '@wu-framework/astro/WuApp.astro';
12
+ * ---
13
+ * <WuApp name="header" />
14
+ * <WuApp name="dashboard" lazy />
15
+ */
16
+
17
+ interface Props {
18
+ /** Name of the registered wu micro-app */
19
+ name: string;
20
+ /** Defer mounting until the element is visible */
21
+ lazy?: boolean;
22
+ /** CSS class(es) for the container div */
23
+ class?: string;
24
+ /** Inline styles for the container div */
25
+ style?: string;
26
+ }
27
+
28
+ const { name, lazy = false } = Astro.props;
29
+ const id = `wu-app-${name}`;
30
+ ---
31
+
32
+ <div
33
+ id={id}
34
+ class={Astro.props.class}
35
+ style={Astro.props.style}
36
+ data-wu-app={name}
37
+ data-wu-lazy={lazy}
38
+ ></div>
39
+
40
+ <script define:vars={{ id, name, lazy }}>
41
+ async function mountApp() {
42
+ const { wu } = await import('wu-framework');
43
+ await wu.mount(name, `#${id}`);
44
+ }
45
+
46
+ if (lazy) {
47
+ const el = document.getElementById(id);
48
+ if (el) {
49
+ const observer = new IntersectionObserver(
50
+ (entries) => {
51
+ if (entries[0].isIntersecting) {
52
+ observer.disconnect();
53
+ mountApp();
54
+ }
55
+ },
56
+ { rootMargin: '200px' }
57
+ );
58
+ observer.observe(el);
59
+ }
60
+ } else {
61
+ mountApp();
62
+ }
63
+ </script>
@@ -0,0 +1,39 @@
1
+ ---
2
+ /**
3
+ * WuShell — Layout wrapper that initializes wu-framework on the client.
4
+ *
5
+ * Wraps page content in a <slot /> and runs wu.init() with the
6
+ * provided app configuration once the page loads.
7
+ *
8
+ * @example
9
+ * ---
10
+ * import WuShell from '@wu-framework/astro/WuShell.astro';
11
+ * ---
12
+ * <WuShell apps={[{ name: 'header', url: '/apps/header' }]}>
13
+ * <main>My page content</main>
14
+ * </WuShell>
15
+ */
16
+
17
+ interface Props {
18
+ /** Array of micro-app definitions to register with wu.init() */
19
+ apps: Array<{
20
+ name: string;
21
+ url: string;
22
+ strategy?: 'eager' | 'lazy' | 'manual';
23
+ }>;
24
+ /** Sandbox isolation mode */
25
+ sandbox?: 'module' | 'strict' | 'eval';
26
+ /** Enable debug logging */
27
+ debug?: boolean;
28
+ }
29
+
30
+ const { apps, sandbox, debug = false } = Astro.props;
31
+ ---
32
+
33
+ <slot />
34
+
35
+ <script define:vars={{ apps, sandbox, debug }}>
36
+ import('wu-framework').then(({ wu }) => {
37
+ wu.init({ apps, sandbox, debug });
38
+ });
39
+ </script>
@@ -0,0 +1,68 @@
1
+ /**
2
+ * @wu-framework/astro — Astro integration for wu-framework microfrontends.
3
+ *
4
+ * Injects the wu-framework runtime into Astro pages and optionally
5
+ * auto-initializes registered micro-apps via wu.init().
6
+ *
7
+ * @example
8
+ * // astro.config.mjs
9
+ * import wu from '@wu-framework/astro';
10
+ *
11
+ * export default defineConfig({
12
+ * integrations: [
13
+ * wu({
14
+ * apps: [
15
+ * { name: 'header', url: '/apps/header', strategy: 'eager' },
16
+ * { name: 'dashboard', url: '/apps/dashboard' }
17
+ * ]
18
+ * })
19
+ * ]
20
+ * });
21
+ */
22
+
23
+ /**
24
+ * @param {import('./types').WuIntegrationOptions} options
25
+ * @returns {import('astro').AstroIntegration}
26
+ */
27
+ export default function wuIntegration(options = {}) {
28
+ const {
29
+ apps = [],
30
+ sandbox,
31
+ cdn,
32
+ debug = false,
33
+ } = options;
34
+
35
+ return {
36
+ name: '@wu-framework/astro',
37
+ hooks: {
38
+ 'astro:config:setup': ({ injectScript, updateConfig }) => {
39
+ // 1. Inject wu-framework runtime
40
+ if (cdn) {
41
+ // Use external CDN script (client-only)
42
+ injectScript(
43
+ 'head-inline',
44
+ `(function(){var s=document.createElement('script');s.src='${cdn}';s.defer=true;document.head.appendChild(s);})()`
45
+ );
46
+ }
47
+
48
+ // 2. Auto-init if apps are provided (client-only via 'page')
49
+ if (apps.length > 0) {
50
+ const initConfig = JSON.stringify({ apps, sandbox, debug });
51
+ injectScript(
52
+ 'page',
53
+ `import('wu-framework').then(function(m){m.wu.init(${initConfig});});`
54
+ );
55
+ }
56
+
57
+ // 3. Ensure Vite resolves wu-framework correctly
58
+ updateConfig({
59
+ vite: {
60
+ optimizeDeps: {
61
+ include: ['wu-framework'],
62
+ },
63
+ },
64
+ });
65
+ },
66
+ },
67
+ };
68
+ }
@@ -0,0 +1,38 @@
1
+ {
2
+ "name": "@wu-framework/astro",
3
+ "version": "1.0.0",
4
+ "description": "Astro integration for wu-framework microfrontends",
5
+ "type": "module",
6
+ "main": "index.js",
7
+ "exports": {
8
+ ".": "./index.js",
9
+ "./WuApp.astro": "./WuApp.astro",
10
+ "./WuShell.astro": "./WuShell.astro"
11
+ },
12
+ "files": [
13
+ "index.js",
14
+ "WuApp.astro",
15
+ "WuShell.astro",
16
+ "types.d.ts",
17
+ "README.md"
18
+ ],
19
+ "keywords": [
20
+ "astro",
21
+ "astro-integration",
22
+ "wu-framework",
23
+ "microfrontends",
24
+ "micro-frontends"
25
+ ],
26
+ "author": "Wu Framework Team",
27
+ "license": "MIT",
28
+ "peerDependencies": {
29
+ "astro": ">=4.0.0",
30
+ "wu-framework": ">=1.1.0"
31
+ },
32
+ "repository": {
33
+ "type": "git",
34
+ "url": "https://github.com/wu-framework/wu-framework.git",
35
+ "directory": "integrations/astro"
36
+ },
37
+ "homepage": "https://wu-framework.dev/docs/integrations/astro"
38
+ }
@@ -0,0 +1,53 @@
1
+ import type { AstroIntegration } from 'astro';
2
+
3
+ /** Configuration for a single wu micro-app. */
4
+ export interface WuAppConfig {
5
+ /** Unique name used to reference this micro-app. */
6
+ name: string;
7
+ /** URL or path from which the micro-app is loaded. */
8
+ url: string;
9
+ /** Loading strategy. Defaults to the framework default. */
10
+ strategy?: 'eager' | 'lazy' | 'manual';
11
+ }
12
+
13
+ /** Options accepted by the wu Astro integration. */
14
+ export interface WuIntegrationOptions {
15
+ /** Micro-apps to auto-register via wu.init(). */
16
+ apps?: WuAppConfig[];
17
+ /** Global sandbox isolation mode. */
18
+ sandbox?: 'module' | 'strict' | 'eval';
19
+ /** CDN URL for the wu-framework UMD bundle. When omitted the local package is used. */
20
+ cdn?: string;
21
+ /** Enable debug logging. */
22
+ debug?: boolean;
23
+ }
24
+
25
+ /**
26
+ * Astro integration factory for wu-framework.
27
+ *
28
+ * @example
29
+ * import wu from '@wu-framework/astro';
30
+ * export default defineConfig({ integrations: [wu({ apps: [...] })] });
31
+ */
32
+ export default function wuIntegration(
33
+ options?: WuIntegrationOptions
34
+ ): AstroIntegration;
35
+
36
+ /** Props for the WuShell.astro layout component. */
37
+ export interface WuShellProps {
38
+ apps: WuAppConfig[];
39
+ sandbox?: 'module' | 'strict' | 'eval';
40
+ debug?: boolean;
41
+ }
42
+
43
+ /** Props for the WuApp.astro mount component. */
44
+ export interface WuAppProps {
45
+ /** Name of the registered wu micro-app. */
46
+ name: string;
47
+ /** Defer mounting until the element is visible (IntersectionObserver). */
48
+ lazy?: boolean;
49
+ /** CSS class(es) for the container div. */
50
+ class?: string;
51
+ /** Inline styles for the container div. */
52
+ style?: string;
53
+ }
package/package.json CHANGED
@@ -1,49 +1,41 @@
1
1
  {
2
2
  "name": "wu-framework",
3
- "version": "1.1.7",
4
- "description": "🚀 Universal Microfrontends Framework - 8 frameworks, zero config, Shadow DOM isolation",
5
- "main": "dist/wu-framework.min.js",
6
- "module": "dist/wu-framework.min.js",
3
+ "version": "1.1.9",
4
+ "description": "Universal Microfrontends Framework - 8 frameworks, zero config, Shadow DOM isolation",
5
+ "main": "dist/wu-framework.cjs.js",
6
+ "module": "src/index.js",
7
7
  "browser": "dist/wu-framework.umd.js",
8
8
  "type": "module",
9
9
  "exports": {
10
10
  ".": {
11
- "import": "./dist/wu-framework.min.js",
11
+ "import": "./src/index.js",
12
12
  "require": "./dist/wu-framework.cjs.js",
13
13
  "browser": "./dist/wu-framework.umd.js"
14
14
  },
15
- "./dev": "./dist/wu-framework.dev.js",
16
- "./min": "./dist/wu-framework.min.js",
17
- "./obf": "./dist/wu-framework.obf.js",
18
- "./hex": "./dist/wu-framework.hex.js",
19
- "./umd": "./dist/wu-framework.umd.js",
20
- "./cjs": "./dist/wu-framework.cjs.js",
15
+ "./src": "./src/index.js",
21
16
  "./adapters": "./src/adapters/index.js",
22
- "./adapters/react": "./src/adapters/react.js",
23
- "./adapters/vue": "./src/adapters/vue.js",
24
- "./adapters/angular": "./src/adapters/angular.js",
25
- "./adapters/svelte": "./src/adapters/svelte.js",
26
- "./adapters/preact": "./src/adapters/preact.js",
27
- "./adapters/solid": "./src/adapters/solid.js",
28
- "./adapters/lit": "./src/adapters/lit.js",
29
- "./adapters/vanilla": "./src/adapters/vanilla.js"
17
+ "./adapters/react": "./src/adapters/react/index.js",
18
+ "./adapters/vue": "./src/adapters/vue/index.js",
19
+ "./adapters/angular": "./src/adapters/angular/index.js",
20
+ "./adapters/svelte": "./src/adapters/svelte/index.js",
21
+ "./adapters/preact": "./src/adapters/preact/index.js",
22
+ "./adapters/solid": "./src/adapters/solid/index.js",
23
+ "./adapters/lit": "./src/adapters/lit/index.js",
24
+ "./adapters/vanilla": "./src/adapters/vanilla/index.js",
25
+ "./integrations/astro": "./integrations/astro/index.js",
26
+ "./integrations/astro/WuApp.astro": "./integrations/astro/WuApp.astro",
27
+ "./integrations/astro/WuShell.astro": "./integrations/astro/WuShell.astro"
30
28
  },
31
29
  "scripts": {
32
- "dev": "node examples/dev-server.js",
33
- "start": "npm run dev",
30
+ "dev": "rollup -c --watch",
34
31
  "build": "node scripts/build.js all --clean",
35
- "build:dev": "node scripts/build.js dev",
36
- "build:prod": "node scripts/build.js prod",
37
- "build:obf": "node scripts/build.js obfuscated",
38
- "build:hex": "node scripts/build.js hex",
39
- "build:umd": "node scripts/build.js umd",
40
- "build:cjs": "node scripts/build.js cjs",
32
+ "build:dev": "rollup -c --environment BUILD_TARGET:dev",
33
+ "build:prod": "rollup -c --environment BUILD_TARGET:prod",
41
34
  "build:all": "node scripts/build.js all --clean",
42
- "build:protected": "node scripts/build-protected.js",
43
- "build:watch": "node scripts/build.js dev --watch",
44
35
  "clean": "node -e \"require('fs').rmSync('dist',{recursive:true,force:true})\"",
45
- "test": "echo 'Tests coming soon'",
46
- "lint": "echo 'Linting coming soon'"
36
+ "test": "vitest run",
37
+ "test:watch": "vitest",
38
+ "test:coverage": "vitest run --coverage"
47
39
  },
48
40
  "keywords": [
49
41
  "microfrontends",
@@ -60,10 +52,14 @@
60
52
  "shadow-dom",
61
53
  "universal",
62
54
  "zero-config",
63
- "runtime-loading",
64
- "component-sharing"
55
+ "ai",
56
+ "llm",
57
+ "webmcp",
58
+ "mcp",
59
+ "tool-calling",
60
+ "byol"
65
61
  ],
66
- "author": "Wu Framework Team",
62
+ "author": "Luis Garcia",
67
63
  "license": "MIT",
68
64
  "repository": {
69
65
  "type": "git",
@@ -72,9 +68,9 @@
72
68
  "bugs": {
73
69
  "url": "https://github.com/wu-framework/wu-framework/issues"
74
70
  },
75
- "homepage": "https://wu-framework.dev",
71
+ "homepage": "https://www.wu-framework.com",
76
72
  "engines": {
77
- "node": ">=14.0.0"
73
+ "node": ">=16.0.0"
78
74
  },
79
75
  "browserslist": [
80
76
  "defaults",
@@ -84,54 +80,82 @@
84
80
  "files": [
85
81
  "src/",
86
82
  "dist/",
87
- "scripts/",
83
+ "integrations/",
88
84
  "README.md",
89
85
  "LICENSE"
90
86
  ],
91
87
  "typesVersions": {
92
88
  "*": {
93
- "adapters/react": ["src/adapters/react.d.ts"],
94
- "adapters/vue": ["src/adapters/vue.d.ts"],
95
- "adapters/angular": ["src/adapters/angular.d.ts"],
96
- "adapters/svelte": ["src/adapters/svelte.d.ts"],
97
- "adapters/preact": ["src/adapters/preact.d.ts"],
98
- "adapters/solid": ["src/adapters/solid.d.ts"],
99
- "adapters/lit": ["src/adapters/lit.d.ts"],
100
- "adapters/vanilla": ["src/adapters/vanilla.d.ts"]
89
+ "adapters/react": [
90
+ "src/adapters/react/index.d.ts"
91
+ ],
92
+ "adapters/vue": [
93
+ "src/adapters/vue/index.d.ts"
94
+ ],
95
+ "adapters/angular": [
96
+ "src/adapters/angular/index.d.ts"
97
+ ],
98
+ "adapters/svelte": [
99
+ "src/adapters/svelte/index.d.ts"
100
+ ],
101
+ "adapters/preact": [
102
+ "src/adapters/preact/index.d.ts"
103
+ ],
104
+ "adapters/solid": [
105
+ "src/adapters/solid/index.d.ts"
106
+ ],
107
+ "adapters/lit": [
108
+ "src/adapters/lit/index.d.ts"
109
+ ],
110
+ "adapters/vanilla": [
111
+ "src/adapters/vanilla/index.d.ts"
112
+ ]
101
113
  }
102
114
  },
103
- "dependencies": {},
104
115
  "devDependencies": {
105
- "rollup": "^4.9.0",
106
- "@rollup/plugin-node-resolve": "^15.2.3",
107
116
  "@rollup/plugin-commonjs": "^25.0.7",
117
+ "@rollup/plugin-node-resolve": "^15.2.3",
118
+ "@rollup/plugin-replace": "^5.0.5",
108
119
  "@rollup/plugin-terser": "^0.4.4",
109
- "terser": "^5.27.0",
110
- "rollup-plugin-obfuscator": "^1.1.0",
111
- "javascript-obfuscator": "^4.1.0"
120
+ "@vitest/coverage-v8": "^4.0.18",
121
+ "jsdom": "^28.0.0",
122
+ "rollup": "^4.9.0",
123
+ "vitest": "^4.0.18"
112
124
  },
113
- "peerDependencies": {},
114
- "optionalDependencies": {},
115
- "funding": {
116
- "type": "github",
117
- "url": "https://github.com/sponsors/wu-framework"
125
+ "peerDependencies": {
126
+ "@angular/core": ">=14.0.0",
127
+ "lit": ">=2.0.0",
128
+ "preact": ">=10.0.0",
129
+ "react": ">=16.8.0",
130
+ "react-dom": ">=16.8.0",
131
+ "solid-js": ">=1.0.0",
132
+ "svelte": ">=3.0.0",
133
+ "vue": ">=3.0.0"
118
134
  },
119
- "wu": {
120
- "framework": true,
121
- "version": "1.1.0",
122
- "features": [
123
- "universal-microfrontends",
124
- "shadow-dom-isolation",
125
- "zero-configuration",
126
- "framework-agnostic",
127
- "runtime-loading",
128
- "component-sharing",
129
- "8-framework-adapters"
130
- ],
131
- "compatibility": {
132
- "frameworks": ["react", "vue", "angular", "svelte", "preact", "solid", "lit", "vanilla"],
133
- "bundlers": ["vite", "webpack", "rollup", "parcel", "esbuild"],
134
- "browsers": ["chrome", "firefox", "safari", "edge"]
135
+ "peerDependenciesMeta": {
136
+ "react": {
137
+ "optional": true
138
+ },
139
+ "react-dom": {
140
+ "optional": true
141
+ },
142
+ "vue": {
143
+ "optional": true
144
+ },
145
+ "@angular/core": {
146
+ "optional": true
147
+ },
148
+ "svelte": {
149
+ "optional": true
150
+ },
151
+ "solid-js": {
152
+ "optional": true
153
+ },
154
+ "preact": {
155
+ "optional": true
156
+ },
157
+ "lit": {
158
+ "optional": true
135
159
  }
136
160
  }
137
161
  }
@@ -0,0 +1,30 @@
1
+ /**
2
+ * WU-FRAMEWORK ANGULAR AI INTEGRATION
3
+ */
4
+ function getWuInstance() {
5
+ if (typeof window === 'undefined') return null;
6
+ return window.wu || window.parent?.wu || window.top?.wu || null;
7
+ }
8
+
9
+ export function createWuAIService(options = {}) {
10
+ const { namespace = 'default' } = options;
11
+ const state = { messages: [], isStreaming: false, error: null };
12
+ return {
13
+ get messages() { return [...state.messages]; },
14
+ get isStreaming() { return state.isStreaming; },
15
+ get error() { return state.error; },
16
+ async send(text) {
17
+ if (!text?.trim()) return null;
18
+ const wu = getWuInstance();
19
+ if (!wu?.ai) { state.error = 'Wu AI not available'; return null; }
20
+ state.messages.push({ id: `user-${Date.now()}`, role: 'user', content: text, timestamp: Date.now() });
21
+ state.isStreaming = true; state.error = null;
22
+ try {
23
+ const res = await wu.ai.send(text, { namespace });
24
+ state.messages.push({ id: `assistant-${Date.now()}`, role: 'assistant', content: res.content, timestamp: Date.now() });
25
+ state.isStreaming = false; return res;
26
+ } catch (err) { state.error = err.message; state.isStreaming = false; return null; }
27
+ },
28
+ clear() { state.messages.length = 0; state.error = null; },
29
+ };
30
+ }