@mihcm/ai-ui 0.14.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.
- package/README.md +100 -0
- package/dist/coverage.d.ts +17 -0
- package/dist/coverage.d.ts.map +1 -0
- package/dist/coverage.js +320 -0
- package/dist/coverage.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -0
- package/dist/renderer.d.ts +36 -0
- package/dist/renderer.d.ts.map +1 -0
- package/dist/renderer.js +413 -0
- package/dist/renderer.js.map +1 -0
- package/dist/schemas/Accordion.d.ts +25 -0
- package/dist/schemas/Accordion.d.ts.map +1 -0
- package/dist/schemas/Accordion.js +26 -0
- package/dist/schemas/Accordion.js.map +1 -0
- package/dist/schemas/Alert.d.ts +24 -0
- package/dist/schemas/Alert.d.ts.map +1 -0
- package/dist/schemas/Alert.js +20 -0
- package/dist/schemas/Alert.js.map +1 -0
- package/dist/schemas/AlertDialog.d.ts +29 -0
- package/dist/schemas/AlertDialog.d.ts.map +1 -0
- package/dist/schemas/AlertDialog.js +22 -0
- package/dist/schemas/AlertDialog.js.map +1 -0
- package/dist/schemas/Avatar.d.ts +29 -0
- package/dist/schemas/Avatar.d.ts.map +1 -0
- package/dist/schemas/Avatar.js +21 -0
- package/dist/schemas/Avatar.js.map +1 -0
- package/dist/schemas/AvatarGroup.d.ts +22 -0
- package/dist/schemas/AvatarGroup.d.ts.map +1 -0
- package/dist/schemas/AvatarGroup.js +23 -0
- package/dist/schemas/AvatarGroup.js.map +1 -0
- package/dist/schemas/Badge.d.ts +23 -0
- package/dist/schemas/Badge.d.ts.map +1 -0
- package/dist/schemas/Badge.js +19 -0
- package/dist/schemas/Badge.js.map +1 -0
- package/dist/schemas/Banner.d.ts +23 -0
- package/dist/schemas/Banner.d.ts.map +1 -0
- package/dist/schemas/Banner.js +20 -0
- package/dist/schemas/Banner.js.map +1 -0
- package/dist/schemas/Breadcrumb.d.ts +20 -0
- package/dist/schemas/Breadcrumb.d.ts.map +1 -0
- package/dist/schemas/Breadcrumb.js +25 -0
- package/dist/schemas/Breadcrumb.js.map +1 -0
- package/dist/schemas/Button.d.ts +40 -0
- package/dist/schemas/Button.d.ts.map +1 -0
- package/dist/schemas/Button.js +26 -0
- package/dist/schemas/Button.js.map +1 -0
- package/dist/schemas/Card.d.ts +21 -0
- package/dist/schemas/Card.d.ts.map +1 -0
- package/dist/schemas/Card.js +22 -0
- package/dist/schemas/Card.js.map +1 -0
- package/dist/schemas/Checkbox.d.ts +18 -0
- package/dist/schemas/Checkbox.d.ts.map +1 -0
- package/dist/schemas/Checkbox.js +19 -0
- package/dist/schemas/Checkbox.js.map +1 -0
- package/dist/schemas/Dialog.d.ts +24 -0
- package/dist/schemas/Dialog.d.ts.map +1 -0
- package/dist/schemas/Dialog.js +20 -0
- package/dist/schemas/Dialog.js.map +1 -0
- package/dist/schemas/DropdownMenu.d.ts +25 -0
- package/dist/schemas/DropdownMenu.d.ts.map +1 -0
- package/dist/schemas/DropdownMenu.js +29 -0
- package/dist/schemas/DropdownMenu.js.map +1 -0
- package/dist/schemas/EmptyState.d.ts +16 -0
- package/dist/schemas/EmptyState.d.ts.map +1 -0
- package/dist/schemas/EmptyState.js +17 -0
- package/dist/schemas/EmptyState.js.map +1 -0
- package/dist/schemas/Input.d.ts +42 -0
- package/dist/schemas/Input.d.ts.map +1 -0
- package/dist/schemas/Input.js +31 -0
- package/dist/schemas/Input.js.map +1 -0
- package/dist/schemas/Label.d.ts +24 -0
- package/dist/schemas/Label.d.ts.map +1 -0
- package/dist/schemas/Label.js +21 -0
- package/dist/schemas/Label.js.map +1 -0
- package/dist/schemas/Link.d.ts +30 -0
- package/dist/schemas/Link.d.ts.map +1 -0
- package/dist/schemas/Link.js +22 -0
- package/dist/schemas/Link.js.map +1 -0
- package/dist/schemas/Pagination.d.ts +19 -0
- package/dist/schemas/Pagination.d.ts.map +1 -0
- package/dist/schemas/Pagination.js +20 -0
- package/dist/schemas/Pagination.js.map +1 -0
- package/dist/schemas/Progress.d.ts +27 -0
- package/dist/schemas/Progress.d.ts.map +1 -0
- package/dist/schemas/Progress.js +20 -0
- package/dist/schemas/Progress.js.map +1 -0
- package/dist/schemas/RadioGroup.d.ts +25 -0
- package/dist/schemas/RadioGroup.d.ts.map +1 -0
- package/dist/schemas/RadioGroup.js +26 -0
- package/dist/schemas/RadioGroup.js.map +1 -0
- package/dist/schemas/SectionHeader.d.ts +160 -0
- package/dist/schemas/SectionHeader.d.ts.map +1 -0
- package/dist/schemas/SectionHeader.js +52 -0
- package/dist/schemas/SectionHeader.js.map +1 -0
- package/dist/schemas/Select.d.ts +38 -0
- package/dist/schemas/Select.d.ts.map +1 -0
- package/dist/schemas/Select.js +36 -0
- package/dist/schemas/Select.js.map +1 -0
- package/dist/schemas/Separator.d.ts +16 -0
- package/dist/schemas/Separator.d.ts.map +1 -0
- package/dist/schemas/Separator.js +14 -0
- package/dist/schemas/Separator.js.map +1 -0
- package/dist/schemas/Sheet.d.ts +28 -0
- package/dist/schemas/Sheet.d.ts.map +1 -0
- package/dist/schemas/Sheet.js +20 -0
- package/dist/schemas/Sheet.js.map +1 -0
- package/dist/schemas/Stack.d.ts +58 -0
- package/dist/schemas/Stack.d.ts.map +1 -0
- package/dist/schemas/Stack.js +80 -0
- package/dist/schemas/Stack.js.map +1 -0
- package/dist/schemas/StatCard.d.ts +30 -0
- package/dist/schemas/StatCard.d.ts.map +1 -0
- package/dist/schemas/StatCard.js +26 -0
- package/dist/schemas/StatCard.js.map +1 -0
- package/dist/schemas/StatusBadge.d.ts +25 -0
- package/dist/schemas/StatusBadge.d.ts.map +1 -0
- package/dist/schemas/StatusBadge.js +20 -0
- package/dist/schemas/StatusBadge.js.map +1 -0
- package/dist/schemas/Switch.d.ts +23 -0
- package/dist/schemas/Switch.d.ts.map +1 -0
- package/dist/schemas/Switch.js +20 -0
- package/dist/schemas/Switch.js.map +1 -0
- package/dist/schemas/Table.d.ts +20 -0
- package/dist/schemas/Table.d.ts.map +1 -0
- package/dist/schemas/Table.js +24 -0
- package/dist/schemas/Table.js.map +1 -0
- package/dist/schemas/Tabs.d.ts +21 -0
- package/dist/schemas/Tabs.d.ts.map +1 -0
- package/dist/schemas/Tabs.js +25 -0
- package/dist/schemas/Tabs.js.map +1 -0
- package/dist/schemas/Tag.d.ts +29 -0
- package/dist/schemas/Tag.d.ts.map +1 -0
- package/dist/schemas/Tag.js +21 -0
- package/dist/schemas/Tag.js.map +1 -0
- package/dist/schemas/Text.d.ts +51 -0
- package/dist/schemas/Text.d.ts.map +1 -0
- package/dist/schemas/Text.js +21 -0
- package/dist/schemas/Text.js.map +1 -0
- package/dist/schemas/Textarea.d.ts +25 -0
- package/dist/schemas/Textarea.d.ts.map +1 -0
- package/dist/schemas/Textarea.js +24 -0
- package/dist/schemas/Textarea.js.map +1 -0
- package/dist/schemas/TitleBar.d.ts +18 -0
- package/dist/schemas/TitleBar.d.ts.map +1 -0
- package/dist/schemas/TitleBar.js +19 -0
- package/dist/schemas/TitleBar.js.map +1 -0
- package/dist/schemas/Toggle.d.ts +28 -0
- package/dist/schemas/Toggle.d.ts.map +1 -0
- package/dist/schemas/Toggle.js +22 -0
- package/dist/schemas/Toggle.js.map +1 -0
- package/dist/schemas/index.d.ts +694 -0
- package/dist/schemas/index.d.ts.map +1 -0
- package/dist/schemas/index.js +160 -0
- package/dist/schemas/index.js.map +1 -0
- package/dist/schemas/shared.d.ts +4 -0
- package/dist/schemas/shared.d.ts.map +1 -0
- package/dist/schemas/shared.js +23 -0
- package/dist/schemas/shared.js.map +1 -0
- package/dist/tools.d.ts +1293 -0
- package/dist/tools.d.ts.map +1 -0
- package/dist/tools.js +40 -0
- package/dist/tools.js.map +1 -0
- package/package.json +59 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tools.d.ts","sourceRoot":"","sources":["../src/tools.ts"],"names":[],"mappings":"AAyBA;;;GAGG;AACH,eAAO,MAAM,uBAAuB,QAK5B,CAAC;AAET,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAA4B,CAAC;AAE5D;;;GAGG;AACH,eAAO,MAAM,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAGxB,CAAC"}
|
package/dist/tools.js
ADDED
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Vercel AI SDK tool definitions for "render a UI".
|
|
3
|
+
*
|
|
4
|
+
* Use with the AI SDK on the server:
|
|
5
|
+
*
|
|
6
|
+
* import { tool } from 'ai';
|
|
7
|
+
* import { uiTools } from '@mihcm/ai-ui/tools';
|
|
8
|
+
*
|
|
9
|
+
* const result = streamText({
|
|
10
|
+
* model: 'anthropic/claude-sonnet-4-6',
|
|
11
|
+
* tools: uiTools,
|
|
12
|
+
* ...
|
|
13
|
+
* });
|
|
14
|
+
*
|
|
15
|
+
* The model's tool call returns a JSON descriptor. The server validates it
|
|
16
|
+
* with `componentDescriptorSchema`, then ships it to the client where
|
|
17
|
+
* `renderDescriptor` produces React nodes.
|
|
18
|
+
*/
|
|
19
|
+
import { ALLOWED_COMPONENTS, componentDescriptorSchema, } from './schemas/index.js';
|
|
20
|
+
const allowedComponentList = ALLOWED_COMPONENTS.join(', ');
|
|
21
|
+
/**
|
|
22
|
+
* Description string is part of the prompt — keep it crisp; instruct the model
|
|
23
|
+
* to ONLY produce descriptors from the given schema. Add a refusal pattern.
|
|
24
|
+
*/
|
|
25
|
+
export const renderUIToolDescription = `
|
|
26
|
+
Render a UI to the user. Output ONLY a JSON descriptor matching the provided
|
|
27
|
+
schema. Allowed components: ${allowedComponentList}.
|
|
28
|
+
Refuse to produce any component name not in that list. If the user requests
|
|
29
|
+
something outside this set, explain via a Text component instead.
|
|
30
|
+
`.trim();
|
|
31
|
+
export const renderUIToolSchema = componentDescriptorSchema;
|
|
32
|
+
/**
|
|
33
|
+
* Tool definition shaped for Vercel AI SDK v6's `tool({...})` factory.
|
|
34
|
+
* Consumers wire it into their `streamText`/`generateText` call.
|
|
35
|
+
*/
|
|
36
|
+
export const renderUITool = {
|
|
37
|
+
description: renderUIToolDescription,
|
|
38
|
+
inputSchema: renderUIToolSchema,
|
|
39
|
+
};
|
|
40
|
+
//# sourceMappingURL=tools.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tools.js","sourceRoot":"","sources":["../src/tools.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AACH,OAAO,EACL,kBAAkB,EAClB,yBAAyB,GAC1B,MAAM,oBAAoB,CAAC;AAE5B,MAAM,oBAAoB,GAAG,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAE3D;;;GAGG;AACH,MAAM,CAAC,MAAM,uBAAuB,GAAG;;8BAET,oBAAoB;;;CAGjD,CAAC,IAAI,EAAE,CAAC;AAET,MAAM,CAAC,MAAM,kBAAkB,GAAG,yBAAyB,CAAC;AAE5D;;;GAGG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG;IAC1B,WAAW,EAAE,uBAAuB;IACpC,WAAW,EAAE,kBAAkB;CAChC,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@mihcm/ai-ui",
|
|
3
|
+
"version": "0.14.1",
|
|
4
|
+
"description": "Zod-typed component descriptors + safe renderer for AI-generated UI. Universal across React, Next.js, and React Native.",
|
|
5
|
+
"license": "MIT",
|
|
6
|
+
"private": false,
|
|
7
|
+
"publishConfig": {
|
|
8
|
+
"registry": "https://registry.npmjs.org",
|
|
9
|
+
"access": "public"
|
|
10
|
+
},
|
|
11
|
+
"repository": {
|
|
12
|
+
"type": "git",
|
|
13
|
+
"url": "https://github.com/yashiel/mihcm-design-system.git",
|
|
14
|
+
"directory": "packages/ai-ui"
|
|
15
|
+
},
|
|
16
|
+
"type": "module",
|
|
17
|
+
"main": "./dist/index.js",
|
|
18
|
+
"types": "./dist/index.d.ts",
|
|
19
|
+
"exports": {
|
|
20
|
+
".": {
|
|
21
|
+
"types": "./dist/index.d.ts",
|
|
22
|
+
"import": "./dist/index.js"
|
|
23
|
+
},
|
|
24
|
+
"./schemas": {
|
|
25
|
+
"types": "./dist/schemas/index.d.ts",
|
|
26
|
+
"import": "./dist/schemas/index.js"
|
|
27
|
+
},
|
|
28
|
+
"./tools": {
|
|
29
|
+
"types": "./dist/tools.d.ts",
|
|
30
|
+
"import": "./dist/tools.js"
|
|
31
|
+
},
|
|
32
|
+
"./package.json": "./package.json"
|
|
33
|
+
},
|
|
34
|
+
"files": [
|
|
35
|
+
"dist",
|
|
36
|
+
"README.md"
|
|
37
|
+
],
|
|
38
|
+
"dependencies": {
|
|
39
|
+
"zod": "^4.4.3",
|
|
40
|
+
"@mihcm/ui": "0.14.1"
|
|
41
|
+
},
|
|
42
|
+
"peerDependencies": {
|
|
43
|
+
"react": ">=19.0.0"
|
|
44
|
+
},
|
|
45
|
+
"devDependencies": {
|
|
46
|
+
"@types/react": "^19.2.14",
|
|
47
|
+
"eslint": "10.4.0",
|
|
48
|
+
"react": "19.2.6",
|
|
49
|
+
"typescript": "^6.0.3",
|
|
50
|
+
"@mihcm/eslint-config": "0.1.3"
|
|
51
|
+
},
|
|
52
|
+
"scripts": {
|
|
53
|
+
"build": "tsc -p tsconfig.json",
|
|
54
|
+
"dev": "tsc -p tsconfig.json --watch",
|
|
55
|
+
"typecheck": "tsc --noEmit",
|
|
56
|
+
"lint": "eslint .",
|
|
57
|
+
"test": "node scripts/check-ai-ui-coverage.mjs"
|
|
58
|
+
}
|
|
59
|
+
}
|