jinzd-ai-cli 0.4.119 → 0.4.120

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.
@@ -1,9 +1,9 @@
1
1
  #!/usr/bin/env node
2
2
  import {
3
3
  ConfigManager
4
- } from "./chunk-UVKO7T4I.js";
4
+ } from "./chunk-R4UGPH5B.js";
5
5
  import "./chunk-2ZD3YTVM.js";
6
- import "./chunk-BS7EUZSO.js";
6
+ import "./chunk-3ATEBRNZ.js";
7
7
  import "./chunk-PDX44BCA.js";
8
8
 
9
9
  // src/cli/batch.ts
@@ -1,7 +1,7 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  // src/core/constants.ts
4
- var VERSION = "0.4.119";
4
+ var VERSION = "0.4.120";
5
5
  var APP_NAME = "ai-cli";
6
6
  var CONFIG_DIR_NAME = ".aicli";
7
7
  var CONFIG_FILE_NAME = "config.json";
@@ -6,7 +6,7 @@ import { platform } from "os";
6
6
  import chalk from "chalk";
7
7
 
8
8
  // src/core/constants.ts
9
- var VERSION = "0.4.119";
9
+ var VERSION = "0.4.120";
10
10
  var APP_NAME = "ai-cli";
11
11
  var CONFIG_DIR_NAME = ".aicli";
12
12
  var CONFIG_FILE_NAME = "config.json";
@@ -1,7 +1,7 @@
1
1
  #!/usr/bin/env node
2
2
  import {
3
3
  schemaToJsonSchema
4
- } from "./chunk-2OMBLQP6.js";
4
+ } from "./chunk-UEXBJEVV.js";
5
5
  import {
6
6
  AuthError,
7
7
  ProviderError,
@@ -2,7 +2,7 @@
2
2
  import {
3
3
  CONFIG_DIR_NAME,
4
4
  VERSION
5
- } from "./chunk-BS7EUZSO.js";
5
+ } from "./chunk-3ATEBRNZ.js";
6
6
 
7
7
  // src/diagnostics/crash-log.ts
8
8
  import {
@@ -8,7 +8,7 @@ import {
8
8
  CONFIG_FILE_NAME,
9
9
  HISTORY_DIR_NAME,
10
10
  PLUGINS_DIR_NAME
11
- } from "./chunk-BS7EUZSO.js";
11
+ } from "./chunk-3ATEBRNZ.js";
12
12
 
13
13
  // src/config/config-manager.ts
14
14
  import { readFileSync, writeFileSync, existsSync, mkdirSync } from "fs";
@@ -5,12 +5,12 @@ import {
5
5
  } from "./chunk-3BICTI5M.js";
6
6
  import {
7
7
  runTestsTool
8
- } from "./chunk-4QMGQO4P.js";
8
+ } from "./chunk-W2WACPMC.js";
9
9
  import {
10
10
  getDangerLevel,
11
11
  isFileWriteTool,
12
12
  runTool
13
- } from "./chunk-2OMBLQP6.js";
13
+ } from "./chunk-UEXBJEVV.js";
14
14
  import {
15
15
  EnvLoader,
16
16
  NetworkError,
@@ -23,7 +23,7 @@ import {
23
23
  SUBAGENT_ALLOWED_TOOLS,
24
24
  SUBAGENT_DEFAULT_MAX_ROUNDS,
25
25
  SUBAGENT_MAX_ROUNDS_LIMIT
26
- } from "./chunk-BS7EUZSO.js";
26
+ } from "./chunk-3ATEBRNZ.js";
27
27
  import {
28
28
  fileCheckpoints
29
29
  } from "./chunk-4BKXL7SM.js";
@@ -1,7 +1,7 @@
1
1
  #!/usr/bin/env node
2
2
  import {
3
3
  CONFIG_DIR_NAME
4
- } from "./chunk-BS7EUZSO.js";
4
+ } from "./chunk-3ATEBRNZ.js";
5
5
 
6
6
  // src/diagnostics/tool-stats.ts
7
7
  import { existsSync, readFileSync, writeFileSync, mkdirSync, renameSync } from "fs";
@@ -1,7 +1,7 @@
1
1
  #!/usr/bin/env node
2
2
  import {
3
3
  truncateForPersist
4
- } from "./chunk-VYTV2VP7.js";
4
+ } from "./chunk-UDR5ZQ6G.js";
5
5
  import {
6
6
  APP_NAME,
7
7
  CONFIG_DIR_NAME,
@@ -11,7 +11,7 @@ import {
11
11
  MCP_PROTOCOL_VERSION,
12
12
  MCP_TOOL_PREFIX,
13
13
  VERSION
14
- } from "./chunk-BS7EUZSO.js";
14
+ } from "./chunk-3ATEBRNZ.js";
15
15
  import {
16
16
  redactJson
17
17
  } from "./chunk-7ZJN4KLV.js";
@@ -1,7 +1,7 @@
1
1
  #!/usr/bin/env node
2
2
  import {
3
3
  TEST_TIMEOUT
4
- } from "./chunk-BS7EUZSO.js";
4
+ } from "./chunk-3ATEBRNZ.js";
5
5
 
6
6
  // src/tools/builtin/run-tests.ts
7
7
  import { execSync, spawnSync } from "child_process";
@@ -36,7 +36,7 @@ import {
36
36
  TEST_TIMEOUT,
37
37
  VERSION,
38
38
  buildUserIdentityPrompt
39
- } from "./chunk-BS7EUZSO.js";
39
+ } from "./chunk-3ATEBRNZ.js";
40
40
  import "./chunk-PDX44BCA.js";
41
41
  export {
42
42
  AGENTIC_BEHAVIOR_GUIDELINE,
@@ -2,25 +2,25 @@
2
2
  import {
3
3
  getConfigDirUsage,
4
4
  listRecentCrashes
5
- } from "./chunk-SYF3BPZK.js";
5
+ } from "./chunk-HVB3HT7S.js";
6
6
  import {
7
7
  ProviderRegistry
8
- } from "./chunk-M36KRNHE.js";
8
+ } from "./chunk-DQOJ65TM.js";
9
9
  import {
10
10
  ConfigManager
11
- } from "./chunk-UVKO7T4I.js";
11
+ } from "./chunk-R4UGPH5B.js";
12
12
  import {
13
13
  getStatsSnapshot,
14
14
  getTopFailingTools,
15
15
  getTopUsedTools,
16
16
  resetStats
17
- } from "./chunk-2OMBLQP6.js";
17
+ } from "./chunk-UEXBJEVV.js";
18
18
  import "./chunk-2ZD3YTVM.js";
19
19
  import {
20
20
  DEV_STATE_FILE_NAME,
21
21
  MEMORY_FILE_NAME,
22
22
  VERSION
23
- } from "./chunk-BS7EUZSO.js";
23
+ } from "./chunk-3ATEBRNZ.js";
24
24
  import "./chunk-PDX44BCA.js";
25
25
 
26
26
  // src/diagnostics/doctor-cli.ts
@@ -36,7 +36,7 @@ import {
36
36
  VERSION,
37
37
  buildUserIdentityPrompt,
38
38
  runTestsTool
39
- } from "./chunk-SWOK6GDC.js";
39
+ } from "./chunk-BAINGLSZ.js";
40
40
  import {
41
41
  hasSemanticIndex,
42
42
  semanticSearch
@@ -9795,11 +9795,9 @@ var ToolExecutorWeb = class _ToolExecutorWeb {
9795
9795
  const confirmed = await this.confirm(call, dangerLevel);
9796
9796
  if (!confirmed) {
9797
9797
  const label = dangerLevel === "destructive" ? "destructive " : "";
9798
- return {
9799
- callId: call.id,
9800
- content: `[User cancelled] The user declined the ${label}${call.name} operation. Do not retry without asking.`,
9801
- isError: true
9802
- };
9798
+ const rejectionMsg = `[User cancelled] The user declined the ${label}${call.name} operation. Do not retry without asking.`;
9799
+ this.sendToolCallResult(call, rejectionMsg, true);
9800
+ return { callId: call.id, content: rejectionMsg, isError: true };
9803
9801
  }
9804
9802
  }
9805
9803
  try {
@@ -9842,11 +9840,9 @@ var ToolExecutorWeb = class _ToolExecutorWeb {
9842
9840
  if (decision === "all" || decision instanceof Set && decision.has(i + 1)) {
9843
9841
  approvedIndices.push(i);
9844
9842
  } else {
9845
- results[i] = {
9846
- callId: calls[i].id,
9847
- content: `[User rejected] File write rejected by user. Do not retry without asking.`,
9848
- isError: true
9849
- };
9843
+ const rejectionMsg = `[User rejected] File write rejected by user. Do not retry without asking.`;
9844
+ this.sendToolCallResult(calls[i], rejectionMsg, true);
9845
+ results[i] = { callId: calls[i].id, content: rejectionMsg, isError: true };
9850
9846
  }
9851
9847
  }
9852
9848
  if (approvedIndices.length >= 2) {
@@ -12202,7 +12198,7 @@ ${undoResults.map((r) => ` \u2022 ${r}`).join("\n")}` });
12202
12198
  case "test": {
12203
12199
  this.send({ type: "info", message: "\u{1F9EA} Running tests..." });
12204
12200
  try {
12205
- const { executeTests } = await import("./run-tests-3ZLFXP7F.js");
12201
+ const { executeTests } = await import("./run-tests-UXIWK4RR.js");
12206
12202
  const argStr = args.join(" ").trim();
12207
12203
  let testArgs = {};
12208
12204
  if (argStr) {
@@ -386,7 +386,7 @@ ${content}`);
386
386
  }
387
387
  }
388
388
  async function runTaskMode(config, providers, configManager, topic) {
389
- const { TaskOrchestrator } = await import("./task-orchestrator-SDFF4CQ7.js");
389
+ const { TaskOrchestrator } = await import("./task-orchestrator-T5B3ATNQ.js");
390
390
  const orchestrator = new TaskOrchestrator(config, providers, configManager);
391
391
  let interrupted = false;
392
392
  const onSigint = () => {
package/dist/index.js CHANGED
@@ -16,12 +16,12 @@ import {
16
16
  saveDevState,
17
17
  sessionHasMeaningfulContent,
18
18
  setupProxy
19
- } from "./chunk-DIOSW6R4.js";
19
+ } from "./chunk-V4X56UVE.js";
20
20
  import {
21
21
  getConfigDirUsage,
22
22
  listRecentCrashes,
23
23
  writeCrashLog
24
- } from "./chunk-SYF3BPZK.js";
24
+ } from "./chunk-HVB3HT7S.js";
25
25
  import {
26
26
  CONTENT_ONLY_STREAM_REMINDER,
27
27
  HALLUCINATION_CORRECTION_MESSAGE,
@@ -39,10 +39,10 @@ import {
39
39
  looksLikeDocumentBody,
40
40
  stripPseudoToolCalls,
41
41
  stripToolCallReminder
42
- } from "./chunk-M36KRNHE.js";
42
+ } from "./chunk-DQOJ65TM.js";
43
43
  import {
44
44
  ConfigManager
45
- } from "./chunk-UVKO7T4I.js";
45
+ } from "./chunk-R4UGPH5B.js";
46
46
  import {
47
47
  ToolExecutor,
48
48
  ToolRegistry,
@@ -61,16 +61,16 @@ import {
61
61
  spawnAgentContext,
62
62
  theme,
63
63
  undoStack
64
- } from "./chunk-VYTV2VP7.js";
64
+ } from "./chunk-UDR5ZQ6G.js";
65
65
  import "./chunk-3BICTI5M.js";
66
66
  import "./chunk-2DXY7UGF.js";
67
- import "./chunk-4QMGQO4P.js";
67
+ import "./chunk-W2WACPMC.js";
68
68
  import {
69
69
  getStatsSnapshot,
70
70
  getTopFailingTools,
71
71
  getTopUsedTools,
72
72
  installFlushOnExit
73
- } from "./chunk-2OMBLQP6.js";
73
+ } from "./chunk-UEXBJEVV.js";
74
74
  import "./chunk-2ZD3YTVM.js";
75
75
  import {
76
76
  AGENTIC_BEHAVIOR_GUIDELINE,
@@ -93,7 +93,7 @@ import {
93
93
  SKILLS_DIR_NAME,
94
94
  VERSION,
95
95
  buildUserIdentityPrompt
96
- } from "./chunk-BS7EUZSO.js";
96
+ } from "./chunk-3ATEBRNZ.js";
97
97
  import {
98
98
  formatGitContextForPrompt,
99
99
  getGitContext,
@@ -1661,7 +1661,7 @@ ${text}
1661
1661
  const { join: join6 } = await import("path");
1662
1662
  const { existsSync: existsSync6 } = await import("fs");
1663
1663
  const { getGitRoot: getGitRoot2 } = await import("./git-context-7KIP4X2V.js");
1664
- const { MCP_PROJECT_CONFIG_NAME: MCP_PROJECT_CONFIG_NAME2 } = await import("./constants-QVAT2SUA.js");
1664
+ const { MCP_PROJECT_CONFIG_NAME: MCP_PROJECT_CONFIG_NAME2 } = await import("./constants-3A3ID7AF.js");
1665
1665
  const { approveProject, hashMcpFile } = await import("./project-trust-IFM7FXEV.js");
1666
1666
  const cwd = process.cwd();
1667
1667
  const projectRoot = getGitRoot2(cwd) ?? cwd;
@@ -2722,7 +2722,7 @@ ${hint}` : "")
2722
2722
  usage: "/test [command|filter]",
2723
2723
  async execute(args, ctx) {
2724
2724
  try {
2725
- const { executeTests } = await import("./run-tests-CDY775VC.js");
2725
+ const { executeTests } = await import("./run-tests-X54V5LQW.js");
2726
2726
  const argStr = args.join(" ").trim();
2727
2727
  let testArgs = {};
2728
2728
  if (argStr) {
@@ -7071,7 +7071,7 @@ program.command("web").description("Start Web UI server with browser-based chat
7071
7071
  console.error("Error: Invalid port number. Must be between 1 and 65535.");
7072
7072
  process.exit(1);
7073
7073
  }
7074
- const { startWebServer } = await import("./server-C6Z6TVTZ.js");
7074
+ const { startWebServer } = await import("./server-U6CBEAK4.js");
7075
7075
  await startWebServer({ port, host: options.host });
7076
7076
  });
7077
7077
  program.command("user [action] [username]").description("Manage Web UI users (list | create <name> | delete <name> | reset-password <name> | logout-all <name> | migrate <name>)").action(async (action, username) => {
@@ -7206,12 +7206,12 @@ program.command("sessions").description("List recent conversation sessions").act
7206
7206
  console.log();
7207
7207
  });
7208
7208
  program.command("doctor").description("Health check: API keys, config, MCP, recent crashes, tool usage, disk usage").option("--json", "Output as JSON (for scripting)").option("--reset-stats", "Reset accumulated tool usage statistics").action(async (options) => {
7209
- const { runDoctorCli } = await import("./doctor-cli-RZC5PSDE.js");
7209
+ const { runDoctorCli } = await import("./doctor-cli-RDOZODEH.js");
7210
7210
  await runDoctorCli({ json: !!options.json, resetStats: !!options.resetStats });
7211
7211
  });
7212
7212
  program.command("batch <action> [arg] [arg2]").description("Anthropic Message Batches: submit | list | status <id> | results <id> [out] | cancel <id>").option("--dry-run", "Parse and validate input without submitting (submit only)").action(async (action, arg, arg2, options) => {
7213
7213
  try {
7214
- const batch = await import("./batch-7QSGU2F3.js");
7214
+ const batch = await import("./batch-OJJJAKYZ.js");
7215
7215
  switch (action) {
7216
7216
  case "submit":
7217
7217
  if (!arg) {
@@ -7254,7 +7254,7 @@ program.command("batch <action> [arg] [arg2]").description("Anthropic Message Ba
7254
7254
  }
7255
7255
  });
7256
7256
  program.command("mcp-serve").description("Start an MCP server over STDIO, exposing aicli's built-in tools to Claude Desktop / Cursor / other MCP clients").option("--allow-destructive", "Allow bash / run_interactive / task_create (always destructive in MCP mode)").option("--allow-outside-cwd", "Allow tool path arguments to escape the sandbox root \u2014 disabled by default").option("--tools <list>", "Comma-separated whitelist of tools to expose (default: all eligible tools)").option("--cwd <path>", "Working directory AND sandbox root (default: current directory)").action(async (options) => {
7257
- const { startMcpServer } = await import("./server-HMJTQCKI.js");
7257
+ const { startMcpServer } = await import("./server-NYXCGP2W.js");
7258
7258
  await startMcpServer({
7259
7259
  allowDestructive: !!options.allowDestructive,
7260
7260
  allowOutsideCwd: !!options.allowOutsideCwd,
@@ -7381,7 +7381,7 @@ program.command("hub [topic]").description("Start multi-agent hub (discuss / bra
7381
7381
  }),
7382
7382
  config.get("customProviders")
7383
7383
  );
7384
- const { startHub } = await import("./hub-SODOTZRX.js");
7384
+ const { startHub } = await import("./hub-2AJBBGEW.js");
7385
7385
  await startHub(
7386
7386
  {
7387
7387
  topic: topic ?? "",
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  executeTests,
3
3
  runTestsTool
4
- } from "./chunk-SWOK6GDC.js";
4
+ } from "./chunk-BAINGLSZ.js";
5
5
  import "./chunk-3RG5ZIWI.js";
6
6
  export {
7
7
  executeTests,
@@ -2,8 +2,8 @@
2
2
  import {
3
3
  executeTests,
4
4
  runTestsTool
5
- } from "./chunk-4QMGQO4P.js";
6
- import "./chunk-BS7EUZSO.js";
5
+ } from "./chunk-W2WACPMC.js";
6
+ import "./chunk-3ATEBRNZ.js";
7
7
  import "./chunk-PDX44BCA.js";
8
8
  export {
9
9
  executeTests,
@@ -1,19 +1,19 @@
1
1
  #!/usr/bin/env node
2
2
  import {
3
3
  ToolRegistry
4
- } from "./chunk-VYTV2VP7.js";
4
+ } from "./chunk-UDR5ZQ6G.js";
5
5
  import "./chunk-3BICTI5M.js";
6
6
  import "./chunk-2DXY7UGF.js";
7
- import "./chunk-4QMGQO4P.js";
7
+ import "./chunk-W2WACPMC.js";
8
8
  import {
9
9
  getDangerLevel,
10
10
  runTool,
11
11
  schemaToJsonSchema
12
- } from "./chunk-2OMBLQP6.js";
12
+ } from "./chunk-UEXBJEVV.js";
13
13
  import "./chunk-2ZD3YTVM.js";
14
14
  import {
15
15
  VERSION
16
- } from "./chunk-BS7EUZSO.js";
16
+ } from "./chunk-3ATEBRNZ.js";
17
17
  import "./chunk-4BKXL7SM.js";
18
18
  import "./chunk-7ZJN4KLV.js";
19
19
  import "./chunk-KHYD3WXE.js";
@@ -14,7 +14,7 @@ import {
14
14
  loadDevState,
15
15
  persistToolRound,
16
16
  setupProxy
17
- } from "./chunk-DIOSW6R4.js";
17
+ } from "./chunk-V4X56UVE.js";
18
18
  import {
19
19
  CONTENT_ONLY_STREAM_REMINDER,
20
20
  HALLUCINATION_CORRECTION_MESSAGE,
@@ -28,10 +28,10 @@ import {
28
28
  looksLikeDocumentBody,
29
29
  stripPseudoToolCalls,
30
30
  stripToolCallReminder
31
- } from "./chunk-M36KRNHE.js";
31
+ } from "./chunk-DQOJ65TM.js";
32
32
  import {
33
33
  ConfigManager
34
- } from "./chunk-UVKO7T4I.js";
34
+ } from "./chunk-R4UGPH5B.js";
35
35
  import {
36
36
  ToolExecutor,
37
37
  ToolRegistry,
@@ -49,14 +49,14 @@ import {
49
49
  spawnAgentContext,
50
50
  truncateOutput,
51
51
  undoStack
52
- } from "./chunk-VYTV2VP7.js";
52
+ } from "./chunk-UDR5ZQ6G.js";
53
53
  import "./chunk-3BICTI5M.js";
54
54
  import "./chunk-2DXY7UGF.js";
55
- import "./chunk-4QMGQO4P.js";
55
+ import "./chunk-W2WACPMC.js";
56
56
  import {
57
57
  getDangerLevel,
58
58
  runTool
59
- } from "./chunk-2OMBLQP6.js";
59
+ } from "./chunk-UEXBJEVV.js";
60
60
  import "./chunk-2ZD3YTVM.js";
61
61
  import {
62
62
  AGENTIC_BEHAVIOR_GUIDELINE,
@@ -76,7 +76,7 @@ import {
76
76
  SKILLS_DIR_NAME,
77
77
  VERSION,
78
78
  buildUserIdentityPrompt
79
- } from "./chunk-BS7EUZSO.js";
79
+ } from "./chunk-3ATEBRNZ.js";
80
80
  import {
81
81
  formatGitContextForPrompt,
82
82
  getGitContext,
@@ -345,11 +345,9 @@ var ToolExecutorWeb = class _ToolExecutorWeb {
345
345
  const confirmed = await this.confirm(call, dangerLevel);
346
346
  if (!confirmed) {
347
347
  const label = dangerLevel === "destructive" ? "destructive " : "";
348
- return {
349
- callId: call.id,
350
- content: `[User cancelled] The user declined the ${label}${call.name} operation. Do not retry without asking.`,
351
- isError: true
352
- };
348
+ const rejectionMsg = `[User cancelled] The user declined the ${label}${call.name} operation. Do not retry without asking.`;
349
+ this.sendToolCallResult(call, rejectionMsg, true);
350
+ return { callId: call.id, content: rejectionMsg, isError: true };
353
351
  }
354
352
  }
355
353
  try {
@@ -392,11 +390,9 @@ var ToolExecutorWeb = class _ToolExecutorWeb {
392
390
  if (decision === "all" || decision instanceof Set && decision.has(i + 1)) {
393
391
  approvedIndices.push(i);
394
392
  } else {
395
- results[i] = {
396
- callId: calls[i].id,
397
- content: `[User rejected] File write rejected by user. Do not retry without asking.`,
398
- isError: true
399
- };
393
+ const rejectionMsg = `[User rejected] File write rejected by user. Do not retry without asking.`;
394
+ this.sendToolCallResult(calls[i], rejectionMsg, true);
395
+ results[i] = { callId: calls[i].id, content: rejectionMsg, isError: true };
400
396
  }
401
397
  }
402
398
  if (approvedIndices.length >= 2) {
@@ -2464,7 +2460,7 @@ ${undoResults.map((r) => ` \u2022 ${r}`).join("\n")}` });
2464
2460
  case "test": {
2465
2461
  this.send({ type: "info", message: "\u{1F9EA} Running tests..." });
2466
2462
  try {
2467
- const { executeTests } = await import("./run-tests-CDY775VC.js");
2463
+ const { executeTests } = await import("./run-tests-X54V5LQW.js");
2468
2464
  const argStr = args.join(" ").trim();
2469
2465
  let testArgs = {};
2470
2466
  if (argStr) {
@@ -3,18 +3,18 @@ import {
3
3
  ToolRegistry,
4
4
  googleSearchContext,
5
5
  truncateOutput
6
- } from "./chunk-VYTV2VP7.js";
6
+ } from "./chunk-UDR5ZQ6G.js";
7
7
  import "./chunk-3BICTI5M.js";
8
8
  import "./chunk-2DXY7UGF.js";
9
- import "./chunk-4QMGQO4P.js";
9
+ import "./chunk-W2WACPMC.js";
10
10
  import {
11
11
  getDangerLevel,
12
12
  runTool
13
- } from "./chunk-2OMBLQP6.js";
13
+ } from "./chunk-UEXBJEVV.js";
14
14
  import "./chunk-2ZD3YTVM.js";
15
15
  import {
16
16
  SUBAGENT_ALLOWED_TOOLS
17
- } from "./chunk-BS7EUZSO.js";
17
+ } from "./chunk-3ATEBRNZ.js";
18
18
  import "./chunk-4BKXL7SM.js";
19
19
  import "./chunk-7ZJN4KLV.js";
20
20
  import "./chunk-KHYD3WXE.js";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "jinzd-ai-cli",
3
- "version": "0.4.119",
3
+ "version": "0.4.120",
4
4
  "description": "Cross-platform REPL-style AI CLI with multi-provider support",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",