assistant-ui 0.0.3 → 0.0.5
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 +4 -34
- package/dist/index.js +65 -4
- package/dist/index.js.map +1 -1
- package/package.json +15 -24
package/README.md
CHANGED
|
@@ -1,39 +1,9 @@
|
|
|
1
|
-
# `assistant-ui`
|
|
1
|
+
# `assistant-ui` CLI
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
This package contains the command line interface for `assistant-ui`.
|
|
4
4
|
|
|
5
|
-
|
|
6
|
-
- [Website](https://assistant-ui.com/)
|
|
7
|
-
- [Demo](https://assistant-ui-rsc-example.vercel.app/)
|
|
8
|
-
|
|
9
|
-
## Documentation
|
|
10
|
-
|
|
11
|
-
- [Documentation](https://www.assistant-ui.com/docs/getting-started)
|
|
12
|
-
|
|
13
|
-
## Minimal Example with Vercel AI SDK
|
|
5
|
+
## Usage
|
|
14
6
|
|
|
15
7
|
```sh
|
|
16
|
-
npx assistant-ui@latest add
|
|
8
|
+
npx assistant-ui@latest add
|
|
17
9
|
```
|
|
18
|
-
|
|
19
|
-
```tsx
|
|
20
|
-
"use client";
|
|
21
|
-
|
|
22
|
-
import { useChat } from "@ai-sdk/react";
|
|
23
|
-
import { AssistantRuntimeProvider } from "@assistant-ui/react";
|
|
24
|
-
import { useVercelUseChatRuntime } from "@assistant-ui/react-ai-sdk";
|
|
25
|
-
import { AssistantModal } from "@/components/ui/assistant-ui/assistant-modal";
|
|
26
|
-
|
|
27
|
-
export default const MyApp = () => {
|
|
28
|
-
const chat = useChat({
|
|
29
|
-
api: "/api/chat" // your backend route
|
|
30
|
-
});
|
|
31
|
-
const runtime = useVercelUseChatRuntime(chat);
|
|
32
|
-
|
|
33
|
-
return (
|
|
34
|
-
<AssistantRuntimeProvider runtime={runtime}>
|
|
35
|
-
<AssistantModal />
|
|
36
|
-
</AssistantRuntimeProvider>
|
|
37
|
-
);
|
|
38
|
-
}
|
|
39
|
-
```
|
package/dist/index.js
CHANGED
|
@@ -170,27 +170,88 @@ var add = new Command().name("add").description("add a component to your project
|
|
|
170
170
|
});
|
|
171
171
|
|
|
172
172
|
// src/index.ts
|
|
173
|
-
import { Command as
|
|
173
|
+
import { Command as Command3 } from "commander";
|
|
174
174
|
|
|
175
175
|
// src/utils/get-package-info.ts
|
|
176
176
|
import path4 from "node:path";
|
|
177
177
|
import fs from "node:fs";
|
|
178
|
+
import { fileURLToPath } from "node:url";
|
|
178
179
|
function getPackageInfo() {
|
|
179
|
-
const
|
|
180
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
181
|
+
const __dirname = path4.dirname(__filename);
|
|
182
|
+
const packageJsonPath = path4.join(__dirname, "..", "package.json");
|
|
180
183
|
return JSON.parse(fs.readFileSync(packageJsonPath).toString("utf-8"));
|
|
181
184
|
}
|
|
182
185
|
|
|
186
|
+
// src/commands/create.ts
|
|
187
|
+
import { Command as Command2 } from "commander";
|
|
188
|
+
import chalk2 from "chalk";
|
|
189
|
+
import { spawn as spawn2 } from "child_process";
|
|
190
|
+
var create = new Command2().name("create").description("create a new project").arguments("<project-directory>").usage(`${chalk2.green("<project-directory>")} [options]`).option(
|
|
191
|
+
"--use-npm",
|
|
192
|
+
`
|
|
193
|
+
|
|
194
|
+
Explicitly tell the CLI to bootstrap the application using npm
|
|
195
|
+
`
|
|
196
|
+
).option(
|
|
197
|
+
"--use-pnpm",
|
|
198
|
+
`
|
|
199
|
+
|
|
200
|
+
Explicitly tell the CLI to bootstrap the application using pnpm
|
|
201
|
+
`
|
|
202
|
+
).option(
|
|
203
|
+
"--use-yarn",
|
|
204
|
+
`
|
|
205
|
+
|
|
206
|
+
Explicitly tell the CLI to bootstrap the application using Yarn
|
|
207
|
+
`
|
|
208
|
+
).option(
|
|
209
|
+
"--use-bun",
|
|
210
|
+
`
|
|
211
|
+
|
|
212
|
+
Explicitly tell the CLI to bootstrap the application using Bun
|
|
213
|
+
`
|
|
214
|
+
).option(
|
|
215
|
+
"--skip-install",
|
|
216
|
+
`
|
|
217
|
+
|
|
218
|
+
Explicitly tell the CLI to skip installing packages
|
|
219
|
+
`
|
|
220
|
+
).action(() => {
|
|
221
|
+
const child = spawn2(
|
|
222
|
+
"npx",
|
|
223
|
+
[
|
|
224
|
+
`create-next-app@latest`,
|
|
225
|
+
...process.argv.slice(3),
|
|
226
|
+
"-e",
|
|
227
|
+
"https://github.com/Yonom/assistant-ui-starter"
|
|
228
|
+
],
|
|
229
|
+
{
|
|
230
|
+
stdio: "inherit"
|
|
231
|
+
}
|
|
232
|
+
);
|
|
233
|
+
child.on("error", (error) => {
|
|
234
|
+
console.error(`Error: ${error.message}`);
|
|
235
|
+
});
|
|
236
|
+
child.on("close", (code) => {
|
|
237
|
+
if (code !== 0) {
|
|
238
|
+
console.log(`other-package-script process exited with code ${code}`);
|
|
239
|
+
}
|
|
240
|
+
});
|
|
241
|
+
});
|
|
242
|
+
|
|
183
243
|
// src/index.ts
|
|
184
244
|
process.on("SIGINT", () => process.exit(0));
|
|
185
245
|
process.on("SIGTERM", () => process.exit(0));
|
|
186
246
|
async function main() {
|
|
187
|
-
const packageInfo =
|
|
188
|
-
const program = new
|
|
247
|
+
const packageInfo = getPackageInfo();
|
|
248
|
+
const program = new Command3().name("assistant-ui").description("add components and dependencies to your project").version(
|
|
189
249
|
packageInfo.version || "1.0.0",
|
|
190
250
|
"-v, --version",
|
|
191
251
|
"display the version number"
|
|
192
252
|
);
|
|
193
253
|
program.addCommand(add);
|
|
254
|
+
program.addCommand(create);
|
|
194
255
|
program.parse();
|
|
195
256
|
}
|
|
196
257
|
main();
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/commands/add.ts","../src/utils/get-component-target-path.ts","../src/utils/get-config.ts","../src/utils/resolve-import.ts","../src/index.ts","../src/utils/get-package-info.ts"],"sourcesContent":["import { existsSync, mkdirSync } from \"node:fs\";\nimport path from \"node:path\";\nimport chalk from \"chalk\";\nimport { Command } from \"commander\";\nimport { spawn } from \"cross-spawn\";\nimport { getComponentTargetPath } from \"../utils/get-component-target-path\";\nimport { type Config, getConfig } from \"../utils/get-config\";\n\nconst SHADCN_CLI_VERSION = \"0.8.0\";\n\nconst getTargetPath = (config: Config, pathOverride: string) => {\n const baseConfig = pathOverride ?? getComponentTargetPath(config);\n if (!baseConfig) {\n console.warn(\n `Unable to determine the base path. Please run ${chalk.green(\n \"npx shadcn-ui init\",\n )} to create a components.json file.`,\n );\n process.exit(1);\n }\n\n return [baseConfig, path.join(baseConfig, \"assistant-ui\")] as const;\n};\n\nexport const add = new Command()\n .name(\"add\")\n .description(\"add a component to your project\")\n .argument(\"[components...]\", \"the components to add\")\n .option(\"-y, --yes\", \"skip confirmation prompt.\", true)\n .option(\"-o, --overwrite\", \"overwrite existing files.\", false)\n .option(\n \"-c, --cwd <cwd>\",\n \"the working directory. defaults to the current directory.\",\n process.cwd(),\n )\n .option(\"-a, --all\", \"add all available components\", false)\n .option(\"-p, --path <path>\", \"the path to add the component to.\")\n .action(async (_, opts) => {\n const cwd = path.resolve(opts.cwd);\n const config = await getConfig(cwd);\n\n if (!config) {\n console.warn(\n `Configuration is missing. Please run ${chalk.green(\n \"npx shadcn-ui init\",\n )} to create a components.json file.`,\n );\n process.exit(1);\n }\n\n const [basePath, targetPath] = getTargetPath(config, opts.path);\n\n // create target path directory if it doesnt exist\n if (targetPath && !existsSync(targetPath)) {\n mkdirSync(targetPath, { recursive: true });\n }\n\n const child = spawn(\n \"npx\",\n [\n `shadcn-ui@${SHADCN_CLI_VERSION}`,\n ...process.argv.slice(2),\n \"--path\",\n basePath,\n ],\n {\n stdio: \"inherit\",\n env: {\n COMPONENTS_REGISTRY_URL: \"https://www.assistant-ui.com\",\n ...process.env,\n },\n },\n );\n\n child.on(\"error\", (error) => {\n console.error(`Error: ${error.message}`);\n });\n\n child.on(\"close\", (code) => {\n if (code !== 0) {\n console.log(`other-package-script process exited with code ${code}`);\n }\n });\n });\n","import path from \"node:path\";\nimport type { Config } from \"./get-config\";\n\nexport function getComponentTargetPath(config: Config) {\n if (config.aliases.ui) {\n return config.resolvedPaths.ui;\n }\n\n const [parent, type] = [\"components\", \"ui\"];\n if (!(parent in config.resolvedPaths)) {\n return null;\n }\n\n return path.join(\n config.resolvedPaths[parent as keyof typeof config.resolvedPaths],\n type,\n );\n}\n","import path from \"node:path\";\nimport { cosmiconfig } from \"cosmiconfig\";\nimport { loadConfig } from \"tsconfig-paths\";\nimport { z } from \"zod\";\nimport { resolveImport } from \"./resolve-import\";\n\nconst explorer = cosmiconfig(\"components\", {\n searchPlaces: [\"components.json\"],\n});\n\nexport const rawConfigSchema = z.object({\n $schema: z.string().optional(),\n style: z.string(),\n rsc: z.coerce.boolean().default(false),\n tsx: z.coerce.boolean().default(true),\n tailwind: z.object({\n config: z.string(),\n css: z.string(),\n baseColor: z.string(),\n cssVariables: z.boolean().default(true),\n prefix: z.string().default(\"\").optional(),\n }),\n aliases: z.object({\n components: z.string(),\n utils: z.string(),\n ui: z.string().optional(),\n }),\n});\n\nexport type RawConfig = z.infer<typeof rawConfigSchema>;\n\nexport const configSchema = rawConfigSchema.extend({\n resolvedPaths: z.object({\n tailwindConfig: z.string(),\n tailwindCss: z.string(),\n utils: z.string(),\n components: z.string(),\n ui: z.string(),\n }),\n});\n\nexport type Config = z.infer<typeof configSchema>;\n\nexport async function getConfig(cwd: string) {\n const config = await getRawConfig(cwd);\n\n if (!config) {\n return null;\n }\n\n return resolveConfigPaths(cwd, config);\n}\n\nexport function resolveConfigPaths(cwd: string, config: RawConfig) {\n // Read tsconfig.json.\n const tsConfig = loadConfig(cwd);\n\n if (tsConfig.resultType === \"failed\") {\n throw new Error(\n `Failed to load ${config.tsx ? \"tsconfig\" : \"jsconfig\"}.json. ${\n tsConfig.message ?? \"\"\n }`.trim(),\n );\n }\n\n return configSchema.parse({\n ...config,\n resolvedPaths: {\n tailwindConfig: path.resolve(cwd, config.tailwind.config),\n tailwindCss: path.resolve(cwd, config.tailwind.css),\n utils: resolveImport(config.aliases[\"utils\"], tsConfig),\n components: resolveImport(config.aliases[\"components\"], tsConfig),\n ui: config.aliases[\"ui\"]\n ? resolveImport(config.aliases[\"ui\"], tsConfig)\n : resolveImport(config.aliases[\"components\"], tsConfig),\n },\n });\n}\n\nexport async function getRawConfig(cwd: string): Promise<RawConfig | null> {\n try {\n const configResult = await explorer.search(cwd);\n\n if (!configResult) {\n return null;\n }\n\n return rawConfigSchema.parse(configResult.config);\n } catch (error) {\n throw new Error(`Invalid configuration found in ${cwd}/components.json.`);\n }\n}\n","import {\n type ConfigLoaderSuccessResult,\n createMatchPath,\n} from \"tsconfig-paths\";\n\nexport function resolveImport(\n importPath: string,\n config: Pick<ConfigLoaderSuccessResult, \"absoluteBaseUrl\" | \"paths\">,\n) {\n return createMatchPath(config.absoluteBaseUrl, config.paths)(\n importPath,\n undefined,\n () => true,\n [\".ts\", \".tsx\"],\n );\n}\n","#!/usr/bin/env node\n\nimport { add } from \"@/src/commands/add\";\nimport { Command } from \"commander\";\n\nimport { getPackageInfo } from \"./utils/get-package-info\";\n\nprocess.on(\"SIGINT\", () => process.exit(0));\nprocess.on(\"SIGTERM\", () => process.exit(0));\n\nasync function main() {\n const packageInfo = await getPackageInfo();\n\n const program = new Command()\n .name(\"assistant-ui\")\n .description(\"add components and dependencies to your project\")\n .version(\n packageInfo.version || \"1.0.0\",\n \"-v, --version\",\n \"display the version number\",\n );\n\n program.addCommand(add);\n\n program.parse();\n}\n\nmain();\n","import path from \"node:path\";\nimport fs from \"node:fs\";\n\nexport function getPackageInfo() {\n const packageJsonPath = path.join(\"package.json\");\n\n return JSON.parse(fs.readFileSync(packageJsonPath).toString(\"utf-8\")) as {\n version: string;\n };\n}\n"],"mappings":"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","names":["path","path","path","path","Command","path","Command"]}
|
|
1
|
+
{"version":3,"sources":["../src/commands/add.ts","../src/utils/get-component-target-path.ts","../src/utils/get-config.ts","../src/utils/resolve-import.ts","../src/index.ts","../src/utils/get-package-info.ts","../src/commands/create.ts"],"sourcesContent":["import { existsSync, mkdirSync } from \"node:fs\";\nimport path from \"node:path\";\nimport chalk from \"chalk\";\nimport { Command } from \"commander\";\nimport { spawn } from \"cross-spawn\";\nimport { getComponentTargetPath } from \"../utils/get-component-target-path\";\nimport { type Config, getConfig } from \"../utils/get-config\";\n\nconst SHADCN_CLI_VERSION = \"0.8.0\";\n\nconst getTargetPath = (config: Config, pathOverride: string) => {\n const baseConfig = pathOverride ?? getComponentTargetPath(config);\n if (!baseConfig) {\n console.warn(\n `Unable to determine the base path. Please run ${chalk.green(\n \"npx shadcn-ui init\",\n )} to create a components.json file.`,\n );\n process.exit(1);\n }\n\n return [baseConfig, path.join(baseConfig, \"assistant-ui\")] as const;\n};\n\nexport const add = new Command()\n .name(\"add\")\n .description(\"add a component to your project\")\n .argument(\"[components...]\", \"the components to add\")\n .option(\"-y, --yes\", \"skip confirmation prompt.\", true)\n .option(\"-o, --overwrite\", \"overwrite existing files.\", false)\n .option(\n \"-c, --cwd <cwd>\",\n \"the working directory. defaults to the current directory.\",\n process.cwd(),\n )\n .option(\"-a, --all\", \"add all available components\", false)\n .option(\"-p, --path <path>\", \"the path to add the component to.\")\n .action(async (_, opts) => {\n const cwd = path.resolve(opts.cwd);\n const config = await getConfig(cwd);\n\n if (!config) {\n console.warn(\n `Configuration is missing. Please run ${chalk.green(\n \"npx shadcn-ui init\",\n )} to create a components.json file.`,\n );\n process.exit(1);\n }\n\n const [basePath, targetPath] = getTargetPath(config, opts.path);\n\n // create target path directory if it doesnt exist\n if (targetPath && !existsSync(targetPath)) {\n mkdirSync(targetPath, { recursive: true });\n }\n\n const child = spawn(\n \"npx\",\n [\n `shadcn-ui@${SHADCN_CLI_VERSION}`,\n ...process.argv.slice(2),\n \"--path\",\n basePath,\n ],\n {\n stdio: \"inherit\",\n env: {\n COMPONENTS_REGISTRY_URL: \"https://www.assistant-ui.com\",\n ...process.env,\n },\n },\n );\n\n child.on(\"error\", (error) => {\n console.error(`Error: ${error.message}`);\n });\n\n child.on(\"close\", (code) => {\n if (code !== 0) {\n console.log(`other-package-script process exited with code ${code}`);\n }\n });\n });\n","import path from \"node:path\";\nimport type { Config } from \"./get-config\";\n\nexport function getComponentTargetPath(config: Config) {\n if (config.aliases.ui) {\n return config.resolvedPaths.ui;\n }\n\n const [parent, type] = [\"components\", \"ui\"];\n if (!(parent in config.resolvedPaths)) {\n return null;\n }\n\n return path.join(\n config.resolvedPaths[parent as keyof typeof config.resolvedPaths],\n type,\n );\n}\n","import path from \"node:path\";\nimport { cosmiconfig } from \"cosmiconfig\";\nimport { loadConfig } from \"tsconfig-paths\";\nimport { z } from \"zod\";\nimport { resolveImport } from \"./resolve-import\";\n\nconst explorer = cosmiconfig(\"components\", {\n searchPlaces: [\"components.json\"],\n});\n\nexport const rawConfigSchema = z.object({\n $schema: z.string().optional(),\n style: z.string(),\n rsc: z.coerce.boolean().default(false),\n tsx: z.coerce.boolean().default(true),\n tailwind: z.object({\n config: z.string(),\n css: z.string(),\n baseColor: z.string(),\n cssVariables: z.boolean().default(true),\n prefix: z.string().default(\"\").optional(),\n }),\n aliases: z.object({\n components: z.string(),\n utils: z.string(),\n ui: z.string().optional(),\n }),\n});\n\nexport type RawConfig = z.infer<typeof rawConfigSchema>;\n\nexport const configSchema = rawConfigSchema.extend({\n resolvedPaths: z.object({\n tailwindConfig: z.string(),\n tailwindCss: z.string(),\n utils: z.string(),\n components: z.string(),\n ui: z.string(),\n }),\n});\n\nexport type Config = z.infer<typeof configSchema>;\n\nexport async function getConfig(cwd: string) {\n const config = await getRawConfig(cwd);\n\n if (!config) {\n return null;\n }\n\n return resolveConfigPaths(cwd, config);\n}\n\nexport function resolveConfigPaths(cwd: string, config: RawConfig) {\n // Read tsconfig.json.\n const tsConfig = loadConfig(cwd);\n\n if (tsConfig.resultType === \"failed\") {\n throw new Error(\n `Failed to load ${config.tsx ? \"tsconfig\" : \"jsconfig\"}.json. ${\n tsConfig.message ?? \"\"\n }`.trim(),\n );\n }\n\n return configSchema.parse({\n ...config,\n resolvedPaths: {\n tailwindConfig: path.resolve(cwd, config.tailwind.config),\n tailwindCss: path.resolve(cwd, config.tailwind.css),\n utils: resolveImport(config.aliases[\"utils\"], tsConfig),\n components: resolveImport(config.aliases[\"components\"], tsConfig),\n ui: config.aliases[\"ui\"]\n ? resolveImport(config.aliases[\"ui\"], tsConfig)\n : resolveImport(config.aliases[\"components\"], tsConfig),\n },\n });\n}\n\nexport async function getRawConfig(cwd: string): Promise<RawConfig | null> {\n try {\n const configResult = await explorer.search(cwd);\n\n if (!configResult) {\n return null;\n }\n\n return rawConfigSchema.parse(configResult.config);\n } catch (error) {\n throw new Error(`Invalid configuration found in ${cwd}/components.json.`);\n }\n}\n","import {\n type ConfigLoaderSuccessResult,\n createMatchPath,\n} from \"tsconfig-paths\";\n\nexport function resolveImport(\n importPath: string,\n config: Pick<ConfigLoaderSuccessResult, \"absoluteBaseUrl\" | \"paths\">,\n) {\n return createMatchPath(config.absoluteBaseUrl, config.paths)(\n importPath,\n undefined,\n () => true,\n [\".ts\", \".tsx\"],\n );\n}\n","#!/usr/bin/env node\n\nimport { add } from \"@/src/commands/add\";\nimport { Command } from \"commander\";\n\nimport { getPackageInfo } from \"./utils/get-package-info\";\nimport { create } from \"./commands/create\";\n\nprocess.on(\"SIGINT\", () => process.exit(0));\nprocess.on(\"SIGTERM\", () => process.exit(0));\n\nasync function main() {\n const packageInfo = getPackageInfo();\n\n const program = new Command()\n .name(\"assistant-ui\")\n .description(\"add components and dependencies to your project\")\n .version(\n packageInfo.version || \"1.0.0\",\n \"-v, --version\",\n \"display the version number\",\n );\n\n program.addCommand(add);\n program.addCommand(create);\n\n program.parse();\n}\n\nmain();\n","import path from \"node:path\";\nimport fs from \"node:fs\";\nimport { fileURLToPath } from \"node:url\";\n\nexport function getPackageInfo() {\n // Convert the current module URL to a file path\n const __filename = fileURLToPath(import.meta.url);\n const __dirname = path.dirname(__filename);\n const packageJsonPath = path.join(__dirname, \"..\", \"package.json\");\n\n return JSON.parse(fs.readFileSync(packageJsonPath).toString(\"utf-8\")) as {\n version: string;\n };\n}\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { spawn } from \"child_process\";\n\nexport const create = new Command()\n .name(\"create\")\n .description(\"create a new project\")\n .arguments(\"<project-directory>\")\n .usage(`${chalk.green(\"<project-directory>\")} [options]`)\n .option(\n \"--use-npm\",\n `\n\n Explicitly tell the CLI to bootstrap the application using npm\n`,\n )\n .option(\n \"--use-pnpm\",\n `\n\n Explicitly tell the CLI to bootstrap the application using pnpm\n`,\n )\n .option(\n \"--use-yarn\",\n `\n\n Explicitly tell the CLI to bootstrap the application using Yarn\n`,\n )\n .option(\n \"--use-bun\",\n `\n\n Explicitly tell the CLI to bootstrap the application using Bun\n`,\n )\n .option(\n \"--skip-install\",\n `\n\n Explicitly tell the CLI to skip installing packages\n`,\n )\n .action(() => {\n const child = spawn(\n \"npx\",\n [\n `create-next-app@latest`,\n ...process.argv.slice(3),\n \"-e\",\n \"https://github.com/Yonom/assistant-ui-starter\",\n ],\n {\n stdio: \"inherit\",\n },\n );\n\n child.on(\"error\", (error) => {\n console.error(`Error: ${error.message}`);\n });\n\n child.on(\"close\", (code) => {\n if (code !== 0) {\n console.log(`other-package-script process exited with code ${code}`);\n }\n });\n });\n"],"mappings":"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","names":["path","path","path","path","Command","path","Command","chalk","spawn","Command"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "assistant-ui",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.5",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"dependencies": {
|
|
@@ -8,31 +8,15 @@
|
|
|
8
8
|
"commander": "^12.1.0",
|
|
9
9
|
"cosmiconfig": "^9.0.0",
|
|
10
10
|
"cross-spawn": "^7.0.3",
|
|
11
|
+
"shadcn-ui": "0.8.0",
|
|
11
12
|
"tsconfig-paths": "^4.2.0",
|
|
12
13
|
"zod": "^3.23.8"
|
|
13
14
|
},
|
|
14
15
|
"devDependencies": {
|
|
15
|
-
"@radix-ui/react-avatar": "^1.0.4",
|
|
16
|
-
"@radix-ui/react-popover": "^1.0.7",
|
|
17
|
-
"@radix-ui/react-slot": "^1.0.2",
|
|
18
|
-
"@radix-ui/react-tooltip": "^1.0.7",
|
|
19
16
|
"@types/cross-spawn": "^6.0.6",
|
|
20
|
-
"@types/node": "^20.14.
|
|
21
|
-
"@types/react": "^18",
|
|
22
|
-
"class-variance-authority": "^0.7.0",
|
|
23
|
-
"clsx": "^2.1.1",
|
|
24
|
-
"lucide-react": "^0.394.0",
|
|
25
|
-
"react": "^18.3.1",
|
|
26
|
-
"react-resizable-panels": "^2.0.19",
|
|
27
|
-
"rimraf": "^5.0.7",
|
|
28
|
-
"shadcn-ui": "0.8.0",
|
|
29
|
-
"tailwind-merge": "^2.3.0",
|
|
30
|
-
"tailwindcss": "^3.4.4",
|
|
31
|
-
"tailwindcss-animate": "^1.0.7",
|
|
17
|
+
"@types/node": "^20.14.7",
|
|
32
18
|
"tsup": "^8.1.0",
|
|
33
|
-
"
|
|
34
|
-
"@assistant-ui/tsconfig": "0.0.0",
|
|
35
|
-
"@assistant-ui/react": "0.0.28"
|
|
19
|
+
"@assistant-ui/tsconfig": "0.0.0"
|
|
36
20
|
},
|
|
37
21
|
"files": [
|
|
38
22
|
"dist",
|
|
@@ -40,11 +24,18 @@
|
|
|
40
24
|
],
|
|
41
25
|
"bin": "./dist/index.js",
|
|
42
26
|
"publishConfig": {
|
|
43
|
-
"access": "public"
|
|
27
|
+
"access": "public",
|
|
28
|
+
"provenance": true
|
|
29
|
+
},
|
|
30
|
+
"homepage": "https://assistant-ui.com/",
|
|
31
|
+
"repository": {
|
|
32
|
+
"type": "git",
|
|
33
|
+
"url": "git+https://github.com/Yonom/assistant-ui.git"
|
|
34
|
+
},
|
|
35
|
+
"bugs": {
|
|
36
|
+
"url": "https://github.com/Yonom/assistant-ui/issues"
|
|
44
37
|
},
|
|
45
38
|
"scripts": {
|
|
46
|
-
"build": "tsup src/index.ts --format esm --sourcemap"
|
|
47
|
-
"build:registry": "tsx ./scripts/build-registry.ts",
|
|
48
|
-
"prepublish": "cp ../../README.md ./README.md"
|
|
39
|
+
"build": "tsup src/index.ts --format esm --sourcemap"
|
|
49
40
|
}
|
|
50
41
|
}
|