clawvault 2.6.1 → 3.0.0

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 (232) hide show
  1. package/bin/command-registration.test.js +1 -3
  2. package/bin/register-core-commands.js +10 -23
  3. package/bin/register-maintenance-commands.js +3 -20
  4. package/bin/register-query-commands.js +23 -0
  5. package/bin/register-task-commands.js +1 -18
  6. package/bin/register-task-commands.test.js +0 -16
  7. package/bin/register-vault-operations-commands.js +1 -29
  8. package/dist/{chunk-QVMXF7FY.js → chunk-3D6BCTP6.js} +39 -1
  9. package/dist/{chunk-R2MIW5G7.js → chunk-3DHXQHYG.js} +1 -1
  10. package/dist/{chunk-Q2J5YTUF.js → chunk-3NSBOUT3.js} +73 -36
  11. package/dist/chunk-3RG5ZIWI.js +10 -0
  12. package/dist/{chunk-AZYOKJYC.js → chunk-62YTUT6J.js} +2 -2
  13. package/dist/chunk-6U6MK36V.js +205 -0
  14. package/dist/{chunk-4QYGFWRM.js → chunk-7R7O6STJ.js} +4 -4
  15. package/dist/{chunk-VXEOHTSL.js → chunk-C7OK5WKP.js} +4 -4
  16. package/dist/chunk-CMB7UL7C.js +327 -0
  17. package/dist/chunk-DEFFDRVP.js +938 -0
  18. package/dist/{chunk-HIHOUSXS.js → chunk-E7MFQB6D.js} +59 -18
  19. package/dist/{chunk-ME37YNW3.js → chunk-F2JEUD4J.js} +6 -4
  20. package/dist/chunk-GAJV4IGR.js +82 -0
  21. package/dist/chunk-GQSLDZTS.js +560 -0
  22. package/dist/{chunk-4OXMU5S2.js → chunk-GUKMRGM7.js} +1 -1
  23. package/dist/{chunk-T76H47ZS.js → chunk-H34S76MB.js} +6 -6
  24. package/dist/{chunk-R6SXNSFD.js → chunk-JY6FYXIT.js} +10 -5
  25. package/dist/chunk-K234IDRJ.js +1073 -0
  26. package/dist/{chunk-IEVLHNLU.js → chunk-LNJA2UGL.js} +86 -9
  27. package/dist/{chunk-MFAWT5O5.js → chunk-LYHGEHXG.js} +1 -0
  28. package/dist/chunk-MFM6K7PU.js +374 -0
  29. package/dist/{chunk-QWQ3TIKS.js → chunk-N2AXRYLC.js} +1 -1
  30. package/dist/chunk-PAH27GSN.js +108 -0
  31. package/dist/{chunk-OIWVQYQF.js → chunk-QBLMXKF2.js} +1 -1
  32. package/dist/{chunk-FHFUXL6G.js → chunk-QK3UCXWL.js} +2 -2
  33. package/dist/{chunk-3BTHWPMB.js → chunk-SJSFRIYS.js} +1 -1
  34. package/dist/{chunk-4VRIMU4O.js → chunk-U55BGUAU.js} +2 -2
  35. package/dist/{chunk-PBEE567J.js → chunk-VGLOTGAS.js} +1 -1
  36. package/dist/{chunk-F55HGNU4.js → chunk-WAZ3NLWL.js} +47 -0
  37. package/dist/{chunk-KL4NAOMO.js → chunk-WGRQ6HDV.js} +1 -1
  38. package/dist/{chunk-UEOUADMO.js → chunk-YKTA5JOJ.js} +13 -10
  39. package/dist/{chunk-XAVB4GB4.js → chunk-ZVVFWOLW.js} +4 -4
  40. package/dist/cli/index.cjs +10033 -0
  41. package/dist/cli/index.d.cts +5 -0
  42. package/dist/cli/index.js +20 -18
  43. package/dist/commands/archive.cjs +287 -0
  44. package/dist/commands/archive.d.cts +11 -0
  45. package/dist/commands/archive.js +1 -0
  46. package/dist/commands/backlog.cjs +721 -0
  47. package/dist/commands/backlog.d.cts +53 -0
  48. package/dist/commands/backlog.js +3 -2
  49. package/dist/commands/blocked.cjs +204 -0
  50. package/dist/commands/blocked.d.cts +26 -0
  51. package/dist/commands/blocked.js +3 -2
  52. package/dist/commands/checkpoint.cjs +244 -0
  53. package/dist/commands/checkpoint.d.cts +41 -0
  54. package/dist/commands/checkpoint.js +2 -1
  55. package/dist/commands/compat.cjs +369 -0
  56. package/dist/commands/compat.d.cts +28 -0
  57. package/dist/commands/compat.js +2 -1
  58. package/dist/commands/context.cjs +2989 -0
  59. package/dist/commands/context.d.cts +2 -0
  60. package/dist/commands/context.js +5 -4
  61. package/dist/commands/doctor.cjs +3062 -0
  62. package/dist/commands/doctor.d.cts +21 -0
  63. package/dist/commands/doctor.d.ts +6 -1
  64. package/dist/commands/doctor.js +13 -11
  65. package/dist/commands/embed.cjs +232 -0
  66. package/dist/commands/embed.d.cts +17 -0
  67. package/dist/commands/embed.js +5 -2
  68. package/dist/commands/entities.cjs +141 -0
  69. package/dist/commands/entities.d.cts +7 -0
  70. package/dist/commands/entities.js +1 -0
  71. package/dist/commands/graph.cjs +501 -0
  72. package/dist/commands/graph.d.cts +21 -0
  73. package/dist/commands/graph.js +1 -0
  74. package/dist/commands/inject.cjs +1636 -0
  75. package/dist/commands/inject.d.cts +2 -0
  76. package/dist/commands/inject.d.ts +1 -1
  77. package/dist/commands/inject.js +4 -2
  78. package/dist/commands/kanban.cjs +884 -0
  79. package/dist/commands/kanban.d.cts +63 -0
  80. package/dist/commands/kanban.js +4 -3
  81. package/dist/commands/link.cjs +965 -0
  82. package/dist/commands/link.d.cts +11 -0
  83. package/dist/commands/link.js +1 -0
  84. package/dist/commands/migrate-observations.cjs +362 -0
  85. package/dist/commands/migrate-observations.d.cts +19 -0
  86. package/dist/commands/migrate-observations.js +3 -2
  87. package/dist/commands/observe.cjs +4099 -0
  88. package/dist/commands/observe.d.cts +23 -0
  89. package/dist/commands/observe.d.ts +1 -0
  90. package/dist/commands/observe.js +11 -9
  91. package/dist/commands/project.cjs +1341 -0
  92. package/dist/commands/project.d.cts +85 -0
  93. package/dist/commands/project.js +5 -4
  94. package/dist/commands/rebuild.cjs +3136 -0
  95. package/dist/commands/rebuild.d.cts +11 -0
  96. package/dist/commands/rebuild.js +10 -8
  97. package/dist/commands/recover.cjs +361 -0
  98. package/dist/commands/recover.d.cts +38 -0
  99. package/dist/commands/recover.js +3 -2
  100. package/dist/commands/reflect.cjs +1008 -0
  101. package/dist/commands/reflect.d.cts +11 -0
  102. package/dist/commands/reflect.js +6 -4
  103. package/dist/commands/repair-session.cjs +457 -0
  104. package/dist/commands/repair-session.d.cts +38 -0
  105. package/dist/commands/repair-session.js +1 -0
  106. package/dist/commands/replay.cjs +4103 -0
  107. package/dist/commands/replay.d.cts +16 -0
  108. package/dist/commands/replay.js +12 -10
  109. package/dist/commands/session-recap.cjs +353 -0
  110. package/dist/commands/session-recap.d.cts +27 -0
  111. package/dist/commands/session-recap.js +1 -0
  112. package/dist/commands/setup.cjs +1345 -0
  113. package/dist/commands/setup.d.cts +100 -0
  114. package/dist/commands/setup.d.ts +90 -2
  115. package/dist/commands/setup.js +21 -2
  116. package/dist/commands/shell-init.cjs +75 -0
  117. package/dist/commands/shell-init.d.cts +7 -0
  118. package/dist/commands/shell-init.js +2 -0
  119. package/dist/commands/sleep.cjs +6028 -0
  120. package/dist/commands/sleep.d.cts +36 -0
  121. package/dist/commands/sleep.d.ts +1 -1
  122. package/dist/commands/sleep.js +17 -15
  123. package/dist/commands/status.cjs +2736 -0
  124. package/dist/commands/status.d.cts +52 -0
  125. package/dist/commands/status.js +12 -10
  126. package/dist/commands/tailscale.cjs +1532 -0
  127. package/dist/commands/tailscale.d.cts +52 -0
  128. package/dist/commands/tailscale.js +1 -0
  129. package/dist/commands/task.cjs +1236 -0
  130. package/dist/commands/task.d.cts +97 -0
  131. package/dist/commands/task.js +4 -3
  132. package/dist/commands/template.cjs +457 -0
  133. package/dist/commands/template.d.cts +36 -0
  134. package/dist/commands/template.js +2 -1
  135. package/dist/commands/wake.cjs +2626 -0
  136. package/dist/commands/wake.d.cts +22 -0
  137. package/dist/commands/wake.d.ts +1 -1
  138. package/dist/commands/wake.js +10 -9
  139. package/dist/context-BUGaWpyL.d.cts +46 -0
  140. package/dist/index.cjs +14526 -0
  141. package/dist/index.d.cts +858 -0
  142. package/dist/index.d.ts +192 -7
  143. package/dist/index.js +101 -75
  144. package/dist/{inject-x65KXWPk.d.ts → inject-Bzi5E-By.d.cts} +1 -1
  145. package/dist/inject-Bzi5E-By.d.ts +137 -0
  146. package/dist/lib/auto-linker.cjs +176 -0
  147. package/dist/lib/auto-linker.d.cts +26 -0
  148. package/dist/lib/auto-linker.js +1 -0
  149. package/dist/lib/canvas-layout.cjs +136 -0
  150. package/dist/lib/canvas-layout.d.cts +31 -0
  151. package/dist/lib/canvas-layout.d.ts +16 -100
  152. package/dist/lib/canvas-layout.js +78 -20
  153. package/dist/lib/config.cjs +78 -0
  154. package/dist/lib/config.d.cts +11 -0
  155. package/dist/lib/config.js +1 -0
  156. package/dist/lib/entity-index.cjs +84 -0
  157. package/dist/lib/entity-index.d.cts +26 -0
  158. package/dist/lib/entity-index.js +1 -0
  159. package/dist/lib/project-utils.cjs +864 -0
  160. package/dist/lib/project-utils.d.cts +97 -0
  161. package/dist/lib/project-utils.js +4 -3
  162. package/dist/lib/session-repair.cjs +239 -0
  163. package/dist/lib/session-repair.d.cts +110 -0
  164. package/dist/lib/session-repair.js +1 -0
  165. package/dist/lib/session-utils.cjs +209 -0
  166. package/dist/lib/session-utils.d.cts +63 -0
  167. package/dist/lib/session-utils.js +1 -0
  168. package/dist/lib/tailscale.cjs +1183 -0
  169. package/dist/lib/tailscale.d.cts +225 -0
  170. package/dist/lib/tailscale.js +1 -0
  171. package/dist/lib/task-utils.cjs +1137 -0
  172. package/dist/lib/task-utils.d.cts +208 -0
  173. package/dist/lib/task-utils.js +3 -2
  174. package/dist/lib/template-engine.cjs +47 -0
  175. package/dist/lib/template-engine.d.cts +11 -0
  176. package/dist/lib/template-engine.js +1 -0
  177. package/dist/lib/webdav.cjs +568 -0
  178. package/dist/lib/webdav.d.cts +109 -0
  179. package/dist/lib/webdav.js +1 -0
  180. package/dist/plugin/index.cjs +1907 -0
  181. package/dist/plugin/index.d.cts +36 -0
  182. package/dist/plugin/index.d.ts +36 -0
  183. package/dist/plugin/index.js +572 -0
  184. package/dist/plugin/inject.cjs +356 -0
  185. package/dist/plugin/inject.d.cts +54 -0
  186. package/dist/plugin/inject.d.ts +54 -0
  187. package/dist/plugin/inject.js +17 -0
  188. package/dist/plugin/observe.cjs +631 -0
  189. package/dist/plugin/observe.d.cts +39 -0
  190. package/dist/plugin/observe.d.ts +39 -0
  191. package/dist/plugin/observe.js +18 -0
  192. package/dist/plugin/templates.cjs +593 -0
  193. package/dist/plugin/templates.d.cts +52 -0
  194. package/dist/plugin/templates.d.ts +52 -0
  195. package/dist/plugin/templates.js +25 -0
  196. package/dist/plugin/types.cjs +18 -0
  197. package/dist/plugin/types.d.cts +209 -0
  198. package/dist/plugin/types.d.ts +209 -0
  199. package/dist/plugin/types.js +0 -0
  200. package/dist/plugin/vault.cjs +927 -0
  201. package/dist/plugin/vault.d.cts +68 -0
  202. package/dist/plugin/vault.d.ts +68 -0
  203. package/dist/plugin/vault.js +22 -0
  204. package/dist/{types-C74wgGL1.d.ts → types-Y2_Um2Ls.d.cts} +44 -1
  205. package/dist/types-Y2_Um2Ls.d.ts +205 -0
  206. package/hooks/clawvault/handler.js +70 -7
  207. package/hooks/clawvault/handler.test.js +91 -0
  208. package/openclaw.plugin.json +56 -0
  209. package/package.json +17 -7
  210. package/templates/memory-event.md +67 -0
  211. package/templates/party.md +63 -0
  212. package/templates/primitive-registry.yaml +551 -0
  213. package/templates/run.md +68 -0
  214. package/templates/trigger.md +68 -0
  215. package/templates/workspace.md +50 -0
  216. package/dashboard/lib/graph-diff.js +0 -104
  217. package/dashboard/lib/graph-diff.test.js +0 -75
  218. package/dashboard/lib/vault-parser.js +0 -556
  219. package/dashboard/lib/vault-parser.test.js +0 -254
  220. package/dashboard/public/app.js +0 -796
  221. package/dashboard/public/index.html +0 -52
  222. package/dashboard/public/styles.css +0 -221
  223. package/dashboard/server.js +0 -374
  224. package/dist/chunk-MAKNAHAW.js +0 -375
  225. package/dist/chunk-MDIH26GC.js +0 -183
  226. package/dist/chunk-MGDEINGP.js +0 -99
  227. package/dist/chunk-RVYA52PY.js +0 -363
  228. package/dist/chunk-TLGBDTYT.js +0 -33
  229. package/dist/commands/canvas.d.ts +0 -15
  230. package/dist/commands/canvas.js +0 -199
  231. package/dist/commands/sync-bd.d.ts +0 -10
  232. package/dist/commands/sync-bd.js +0 -9
@@ -0,0 +1,97 @@
1
+ import { TaskPriority, TaskStatus, Task } from '../lib/task-utils.cjs';
2
+
3
+ /**
4
+ * Task command for ClawVault
5
+ * Manages task add/list/update/done/show operations
6
+ */
7
+
8
+ interface TaskAddOptions {
9
+ owner?: string;
10
+ project?: string;
11
+ priority?: TaskPriority;
12
+ due?: string;
13
+ content?: string;
14
+ tags?: string[];
15
+ description?: string;
16
+ estimate?: string;
17
+ parent?: string;
18
+ dependsOn?: string[];
19
+ }
20
+ interface TaskListOptions {
21
+ status?: TaskStatus;
22
+ owner?: string;
23
+ project?: string;
24
+ priority?: TaskPriority;
25
+ due?: boolean;
26
+ tag?: string;
27
+ overdue?: boolean;
28
+ json?: boolean;
29
+ }
30
+ interface TaskUpdateOptions {
31
+ status?: TaskStatus;
32
+ owner?: string | null;
33
+ project?: string | null;
34
+ priority?: TaskPriority | null;
35
+ blockedBy?: string | null;
36
+ due?: string | null;
37
+ tags?: string[] | null;
38
+ description?: string | null;
39
+ estimate?: string | null;
40
+ parent?: string | null;
41
+ dependsOn?: string[] | null;
42
+ confidence?: number;
43
+ reason?: string | null;
44
+ }
45
+ interface TaskTransitionsOptions {
46
+ agent?: string;
47
+ failed?: boolean;
48
+ json?: boolean;
49
+ }
50
+ interface TaskShowOptions {
51
+ json?: boolean;
52
+ }
53
+ /**
54
+ * Add a new task
55
+ */
56
+ declare function taskAdd(vaultPath: string, title: string, options?: TaskAddOptions): Task;
57
+ /**
58
+ * List tasks with optional filters
59
+ */
60
+ declare function taskList(vaultPath: string, options?: TaskListOptions): Task[];
61
+ /**
62
+ * Update a task
63
+ */
64
+ declare function taskUpdate(vaultPath: string, slug: string, options: TaskUpdateOptions): Task;
65
+ /**
66
+ * Mark a task as done
67
+ */
68
+ declare function taskDone(vaultPath: string, slug: string, options?: {
69
+ confidence?: number;
70
+ reason?: string;
71
+ }): Task;
72
+ /**
73
+ * Query task transitions
74
+ */
75
+ declare function taskTransitions(vaultPath: string, taskId?: string, options?: TaskTransitionsOptions): string;
76
+ /**
77
+ * Show task details
78
+ */
79
+ declare function taskShow(vaultPath: string, slug: string): Task | null;
80
+ /**
81
+ * Format task list as terminal table
82
+ */
83
+ declare function formatTaskList(tasks: Task[]): string;
84
+ /**
85
+ * Format task details for display
86
+ */
87
+ declare function formatTaskDetails(task: Task): string;
88
+ /**
89
+ * Task command handler for CLI
90
+ */
91
+ declare function taskCommand(vaultPath: string, action: 'add' | 'list' | 'update' | 'done' | 'show' | 'transitions', args: {
92
+ title?: string;
93
+ slug?: string;
94
+ options?: TaskAddOptions & TaskListOptions & TaskUpdateOptions & TaskShowOptions & TaskTransitionsOptions;
95
+ }): Promise<void>;
96
+
97
+ export { type TaskAddOptions, type TaskListOptions, type TaskShowOptions, type TaskTransitionsOptions, type TaskUpdateOptions, formatTaskDetails, formatTaskList, taskAdd, taskCommand, taskDone, taskList, taskShow, taskTransitions, taskUpdate };
@@ -8,10 +8,11 @@ import {
8
8
  taskShow,
9
9
  taskTransitions,
10
10
  taskUpdate
11
- } from "../chunk-R2MIW5G7.js";
12
- import "../chunk-QWQ3TIKS.js";
13
- import "../chunk-MFAWT5O5.js";
11
+ } from "../chunk-3DHXQHYG.js";
12
+ import "../chunk-N2AXRYLC.js";
13
+ import "../chunk-LYHGEHXG.js";
14
14
  import "../chunk-7766SIJP.js";
15
+ import "../chunk-3RG5ZIWI.js";
15
16
  export {
16
17
  formatTaskDetails,
17
18
  formatTaskList,
@@ -0,0 +1,457 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/commands/template.ts
31
+ var template_exports = {};
32
+ __export(template_exports, {
33
+ addTemplate: () => addTemplate,
34
+ createFromTemplate: () => createFromTemplate,
35
+ listTemplateDefinitions: () => listTemplateDefinitions2,
36
+ listTemplates: () => listTemplates
37
+ });
38
+ module.exports = __toCommonJS(template_exports);
39
+ var fs2 = __toESM(require("fs"), 1);
40
+ var path2 = __toESM(require("path"), 1);
41
+
42
+ // src/lib/template-engine.ts
43
+ function buildTemplateVariables(input = {}, now = /* @__PURE__ */ new Date()) {
44
+ const datetime = input.datetime ?? now.toISOString();
45
+ const date = input.date ?? datetime.split("T")[0];
46
+ return {
47
+ title: input.title ?? "",
48
+ type: input.type ?? "",
49
+ date,
50
+ datetime
51
+ };
52
+ }
53
+ function renderTemplate(template, variables) {
54
+ return template.replace(/\{\{\s*([a-zA-Z0-9_-]+)\s*\}\}/g, (match, key) => {
55
+ const value = variables[key];
56
+ return value !== void 0 ? String(value) : match;
57
+ });
58
+ }
59
+
60
+ // src/lib/primitive-templates.ts
61
+ var fs = __toESM(require("fs"), 1);
62
+ var path = __toESM(require("path"), 1);
63
+ var import_url = require("url");
64
+ var import_gray_matter = __toESM(require("gray-matter"), 1);
65
+ var import_meta = {};
66
+ var TEMPLATE_EXTENSION = ".md";
67
+ function isRecord(value) {
68
+ return typeof value === "object" && value !== null && !Array.isArray(value);
69
+ }
70
+ function normalizeTemplateName(name) {
71
+ const base = path.basename(name, path.extname(name));
72
+ return base.trim();
73
+ }
74
+ function resolveBuiltinTemplatesDir(override) {
75
+ if (override) {
76
+ const resolved = path.resolve(override);
77
+ return fs.existsSync(resolved) && fs.statSync(resolved).isDirectory() ? resolved : null;
78
+ }
79
+ const moduleDir = path.dirname((0, import_url.fileURLToPath)(import_meta.url));
80
+ const candidates = [
81
+ path.resolve(moduleDir, "../templates"),
82
+ path.resolve(moduleDir, "../../templates")
83
+ ];
84
+ for (const candidate of candidates) {
85
+ if (fs.existsSync(candidate) && fs.statSync(candidate).isDirectory()) {
86
+ return candidate;
87
+ }
88
+ }
89
+ return null;
90
+ }
91
+ function listTemplateFiles(dir, ignore) {
92
+ const entries = /* @__PURE__ */ new Map();
93
+ if (!fs.existsSync(dir)) return entries;
94
+ for (const entry of fs.readdirSync(dir, { withFileTypes: true })) {
95
+ if (!entry.isFile() || !entry.name.endsWith(TEMPLATE_EXTENSION)) continue;
96
+ const name = normalizeTemplateName(entry.name);
97
+ if (!name) continue;
98
+ if (ignore?.has(name)) continue;
99
+ entries.set(name, path.join(dir, entry.name));
100
+ }
101
+ return entries;
102
+ }
103
+ function buildTemplateIndex(options = {}) {
104
+ const index = /* @__PURE__ */ new Map();
105
+ const builtinDir = resolveBuiltinTemplatesDir(options.builtinDir);
106
+ if (builtinDir) {
107
+ for (const [name, filePath] of listTemplateFiles(builtinDir, options.ignoreBuiltinNames)) {
108
+ index.set(name, filePath);
109
+ }
110
+ }
111
+ if (options.vaultPath) {
112
+ const vaultTemplatesDir = path.join(path.resolve(options.vaultPath), "templates");
113
+ for (const [name, filePath] of listTemplateFiles(vaultTemplatesDir)) {
114
+ index.set(name, filePath);
115
+ }
116
+ }
117
+ return index;
118
+ }
119
+ function inferFieldType(defaultValue) {
120
+ if (Array.isArray(defaultValue)) {
121
+ const uniqueItemTypes = [...new Set(defaultValue.map((value) => typeof value))];
122
+ if (uniqueItemTypes.length === 1 && uniqueItemTypes[0] === "string") {
123
+ return "string[]";
124
+ }
125
+ return "array";
126
+ }
127
+ switch (typeof defaultValue) {
128
+ case "string":
129
+ return "string";
130
+ case "number":
131
+ return "number";
132
+ case "boolean":
133
+ return "boolean";
134
+ case "object":
135
+ if (defaultValue === null) return "string";
136
+ return "object";
137
+ default:
138
+ return "string";
139
+ }
140
+ }
141
+ function normalizeFieldDefinition(rawField) {
142
+ if (!isRecord(rawField)) {
143
+ return {
144
+ type: inferFieldType(rawField),
145
+ default: rawField
146
+ };
147
+ }
148
+ const rawType = typeof rawField.type === "string" ? rawField.type.trim() : "";
149
+ const normalized = {
150
+ type: rawType || inferFieldType(rawField.default)
151
+ };
152
+ if (typeof rawField.description === "string" && rawField.description.trim()) {
153
+ normalized.description = rawField.description.trim();
154
+ }
155
+ if (typeof rawField.required === "boolean") {
156
+ normalized.required = rawField.required;
157
+ }
158
+ if (Object.prototype.hasOwnProperty.call(rawField, "default")) {
159
+ normalized.default = rawField.default;
160
+ }
161
+ if (Array.isArray(rawField.enum)) {
162
+ normalized.enum = rawField.enum;
163
+ }
164
+ return normalized;
165
+ }
166
+ function normalizeFieldDefinitions(rawFields) {
167
+ const normalized = {};
168
+ for (const [fieldName, rawField] of Object.entries(rawFields)) {
169
+ const normalizedName = String(fieldName).trim();
170
+ if (!normalizedName) continue;
171
+ normalized[normalizedName] = normalizeFieldDefinition(rawField);
172
+ }
173
+ return normalized;
174
+ }
175
+ function extractSchemaDefinition(frontmatter) {
176
+ const primitive = typeof frontmatter.primitive === "string" ? frontmatter.primitive.trim() : "";
177
+ const description = typeof frontmatter.description === "string" ? frontmatter.description.trim() : void 0;
178
+ if (primitive && isRecord(frontmatter.fields)) {
179
+ return {
180
+ primitive,
181
+ description,
182
+ fields: frontmatter.fields
183
+ };
184
+ }
185
+ const containerCandidates = [frontmatter.schema, frontmatter.template];
186
+ for (const candidate of containerCandidates) {
187
+ if (!isRecord(candidate)) continue;
188
+ const nestedPrimitive = typeof candidate.primitive === "string" ? candidate.primitive.trim() : primitive;
189
+ if (!nestedPrimitive || !isRecord(candidate.fields)) continue;
190
+ const nestedDescription = typeof candidate.description === "string" ? candidate.description.trim() : description;
191
+ return {
192
+ primitive: nestedPrimitive,
193
+ description: nestedDescription,
194
+ fields: candidate.fields
195
+ };
196
+ }
197
+ return null;
198
+ }
199
+ function inferLegacyFieldDefinitions(frontmatter) {
200
+ const normalized = {};
201
+ const ignoredKeys = /* @__PURE__ */ new Set(["primitive", "fields", "schema", "template"]);
202
+ for (const [key, value] of Object.entries(frontmatter)) {
203
+ if (ignoredKeys.has(key)) continue;
204
+ normalized[key] = {
205
+ type: inferFieldType(value),
206
+ default: value
207
+ };
208
+ }
209
+ return normalized;
210
+ }
211
+ function parseTemplateDefinition(rawTemplate, templateName, sourcePath) {
212
+ const normalizedName = normalizeTemplateName(templateName);
213
+ const { data, content } = (0, import_gray_matter.default)(rawTemplate);
214
+ const frontmatter = isRecord(data) ? data : {};
215
+ const extractedSchema = extractSchemaDefinition(frontmatter);
216
+ if (extractedSchema) {
217
+ return {
218
+ name: normalizedName,
219
+ primitive: extractedSchema.primitive,
220
+ description: extractedSchema.description,
221
+ fields: normalizeFieldDefinitions(extractedSchema.fields),
222
+ body: content,
223
+ format: "schema",
224
+ sourcePath
225
+ };
226
+ }
227
+ return {
228
+ name: normalizedName,
229
+ primitive: normalizedName,
230
+ description: typeof frontmatter.description === "string" ? frontmatter.description.trim() : void 0,
231
+ fields: inferLegacyFieldDefinitions(frontmatter),
232
+ body: content,
233
+ format: "legacy",
234
+ sourcePath
235
+ };
236
+ }
237
+ function readTemplateDefinitionFromPath(filePath, templateName) {
238
+ try {
239
+ const raw = fs.readFileSync(filePath, "utf-8");
240
+ return parseTemplateDefinition(raw, templateName, filePath);
241
+ } catch {
242
+ return null;
243
+ }
244
+ }
245
+ function listTemplateDefinitions(options = {}) {
246
+ const index = buildTemplateIndex(options);
247
+ const entries = [];
248
+ for (const [name, filePath] of [...index.entries()].sort(([left], [right]) => left.localeCompare(right))) {
249
+ const definition = readTemplateDefinitionFromPath(filePath, name);
250
+ if (!definition) continue;
251
+ entries.push({
252
+ ...definition,
253
+ path: filePath
254
+ });
255
+ }
256
+ return entries;
257
+ }
258
+ function resolveInterpolatedValue(value, variables) {
259
+ if (typeof value === "string") {
260
+ return renderTemplate(value, variables);
261
+ }
262
+ if (Array.isArray(value)) {
263
+ return value.map((item) => resolveInterpolatedValue(item, variables));
264
+ }
265
+ if (isRecord(value)) {
266
+ const resolved = {};
267
+ for (const [key, nested] of Object.entries(value)) {
268
+ resolved[key] = resolveInterpolatedValue(nested, variables);
269
+ }
270
+ return resolved;
271
+ }
272
+ return value;
273
+ }
274
+ function pruneFrontmatter(frontmatter, options) {
275
+ const dropEmptyStrings = options.dropEmptyStrings ?? true;
276
+ const dropEmptyArrays = options.dropEmptyArrays ?? true;
277
+ const pruned = {};
278
+ for (const [key, value] of Object.entries(frontmatter)) {
279
+ if (value === void 0 || value === null) continue;
280
+ if (dropEmptyStrings && typeof value === "string" && value.trim() === "") continue;
281
+ if (dropEmptyArrays && Array.isArray(value) && value.length === 0) continue;
282
+ pruned[key] = value;
283
+ }
284
+ return pruned;
285
+ }
286
+ function buildFrontmatterFromTemplate(definition, variables, overrides = {}, options = {}) {
287
+ const frontmatter = {};
288
+ for (const [fieldName, schema] of Object.entries(definition.fields)) {
289
+ if (!Object.prototype.hasOwnProperty.call(schema, "default")) continue;
290
+ frontmatter[fieldName] = resolveInterpolatedValue(schema.default, variables);
291
+ }
292
+ for (const [fieldName, value] of Object.entries(overrides)) {
293
+ if (value === void 0) continue;
294
+ if (value === null) {
295
+ delete frontmatter[fieldName];
296
+ continue;
297
+ }
298
+ frontmatter[fieldName] = value;
299
+ }
300
+ if (!options.pruneEmpty) {
301
+ return frontmatter;
302
+ }
303
+ return pruneFrontmatter(frontmatter, options);
304
+ }
305
+ function renderDocumentFromTemplate(definition, options = {}) {
306
+ const now = options.now ?? /* @__PURE__ */ new Date();
307
+ const variables = {
308
+ ...buildTemplateVariables(
309
+ {
310
+ title: options.title ?? "",
311
+ type: options.type ?? definition.primitive
312
+ },
313
+ now
314
+ ),
315
+ ...options.variables ?? {}
316
+ };
317
+ const frontmatter = buildFrontmatterFromTemplate(
318
+ definition,
319
+ variables,
320
+ options.overrides,
321
+ options.frontmatter
322
+ );
323
+ const content = renderTemplate(definition.body, variables);
324
+ const markdown = import_gray_matter.default.stringify(content, frontmatter);
325
+ return {
326
+ frontmatter,
327
+ content,
328
+ markdown,
329
+ variables
330
+ };
331
+ }
332
+
333
+ // src/commands/template.ts
334
+ var VAULT_CONFIG_FILE = ".clawvault.json";
335
+ var TEMPLATE_LIST_IGNORED_BUILTINS = /* @__PURE__ */ new Set(["daily"]);
336
+ function findVaultRoot(start) {
337
+ let current = path2.resolve(start);
338
+ while (true) {
339
+ if (fs2.existsSync(path2.join(current, VAULT_CONFIG_FILE))) {
340
+ return current;
341
+ }
342
+ const parent = path2.dirname(current);
343
+ if (parent === current) return null;
344
+ current = parent;
345
+ }
346
+ }
347
+ function resolveVaultPath(options) {
348
+ if (options.vaultPath) {
349
+ return path2.resolve(options.vaultPath);
350
+ }
351
+ const envPath = process.env.CLAWVAULT_PATH;
352
+ if (envPath) {
353
+ return path2.resolve(envPath);
354
+ }
355
+ const cwd = options.cwd ?? process.cwd();
356
+ return findVaultRoot(cwd);
357
+ }
358
+ function slugify(text) {
359
+ return text.toLowerCase().replace(/[^\w\s-]/g, "").replace(/\s+/g, "-").replace(/-+/g, "-").trim();
360
+ }
361
+ function buildTemplateIndexForContext(options) {
362
+ const vaultPath = resolveVaultPath(options) ?? void 0;
363
+ return buildTemplateIndex({
364
+ vaultPath,
365
+ builtinDir: options.builtinDir,
366
+ ignoreBuiltinNames: TEMPLATE_LIST_IGNORED_BUILTINS
367
+ });
368
+ }
369
+ function listTemplateDefinitions2(options = {}) {
370
+ const vaultPath = resolveVaultPath(options) ?? void 0;
371
+ return listTemplateDefinitions({
372
+ vaultPath,
373
+ builtinDir: options.builtinDir,
374
+ ignoreBuiltinNames: TEMPLATE_LIST_IGNORED_BUILTINS
375
+ }).map((definition) => ({
376
+ name: definition.name,
377
+ primitive: definition.primitive,
378
+ description: definition.description,
379
+ fields: Object.keys(definition.fields),
380
+ path: definition.path,
381
+ format: definition.format
382
+ }));
383
+ }
384
+ function listTemplates(options = {}) {
385
+ return listTemplateDefinitions2(options).map((definition) => definition.name);
386
+ }
387
+ function createFromTemplate(name, options = {}) {
388
+ const templateName = normalizeTemplateName(name);
389
+ if (!templateName) {
390
+ throw new Error("Template name is required.");
391
+ }
392
+ const index = buildTemplateIndexForContext(options);
393
+ const templatePath = index.get(templateName);
394
+ if (!templatePath) {
395
+ const available = [...index.keys()].sort();
396
+ const hint = available.length > 0 ? ` Available: ${available.join(", ")}` : "";
397
+ throw new Error(`Template not found: ${templateName}.${hint}`);
398
+ }
399
+ const raw = fs2.readFileSync(templatePath, "utf-8");
400
+ const now = /* @__PURE__ */ new Date();
401
+ const date = now.toISOString().split("T")[0];
402
+ const type = options.type ?? templateName;
403
+ const title = options.title ?? `${type} ${date}`.trim();
404
+ const variables = buildTemplateVariables({ title, type, date }, now);
405
+ const parsedTemplate = parseTemplateDefinition(raw, templateName, templatePath);
406
+ const rendered = parsedTemplate.format === "schema" ? renderDocumentFromTemplate(parsedTemplate, {
407
+ title,
408
+ type,
409
+ now,
410
+ variables: {
411
+ ...variables,
412
+ content: "",
413
+ links_line: "",
414
+ owner_link: "",
415
+ project_link: "",
416
+ team_links_line: ""
417
+ }
418
+ }).markdown : renderTemplate(raw, variables);
419
+ const cwd = options.cwd ?? process.cwd();
420
+ const slug = slugify(title) || slugify(templateName) || `template-${date}`;
421
+ const outputPath = path2.join(cwd, `${slug}${TEMPLATE_EXTENSION}`);
422
+ if (fs2.existsSync(outputPath)) {
423
+ throw new Error(`File already exists: ${outputPath}`);
424
+ }
425
+ fs2.writeFileSync(outputPath, rendered);
426
+ return { outputPath, templatePath, variables };
427
+ }
428
+ function addTemplate(file, options) {
429
+ const name = normalizeTemplateName(options.name);
430
+ if (!name) {
431
+ throw new Error("Template name is required.");
432
+ }
433
+ const vaultPath = resolveVaultPath(options);
434
+ if (!vaultPath) {
435
+ throw new Error("No vault found. Set CLAWVAULT_PATH or use --vault.");
436
+ }
437
+ const cwd = options.cwd ?? process.cwd();
438
+ const sourcePath = path2.resolve(cwd, file);
439
+ if (!fs2.existsSync(sourcePath) || !fs2.statSync(sourcePath).isFile()) {
440
+ throw new Error(`Template file not found: ${sourcePath}`);
441
+ }
442
+ const templatesDir = path2.join(vaultPath, "templates");
443
+ fs2.mkdirSync(templatesDir, { recursive: true });
444
+ const targetPath = path2.join(templatesDir, `${name}${TEMPLATE_EXTENSION}`);
445
+ if (fs2.existsSync(targetPath) && !options.overwrite) {
446
+ throw new Error(`Template already exists: ${targetPath}`);
447
+ }
448
+ fs2.copyFileSync(sourcePath, targetPath);
449
+ return { templatePath: targetPath, name };
450
+ }
451
+ // Annotate the CommonJS export names for ESM import in node:
452
+ 0 && (module.exports = {
453
+ addTemplate,
454
+ createFromTemplate,
455
+ listTemplateDefinitions,
456
+ listTemplates
457
+ });
@@ -0,0 +1,36 @@
1
+ import { TemplateVariables } from '../lib/template-engine.cjs';
2
+
3
+ interface TemplateCommandContext {
4
+ vaultPath?: string;
5
+ cwd?: string;
6
+ builtinDir?: string;
7
+ }
8
+ interface TemplateCreateOptions extends TemplateCommandContext {
9
+ title?: string;
10
+ type?: string;
11
+ }
12
+ interface TemplateAddOptions extends TemplateCommandContext {
13
+ name: string;
14
+ overwrite?: boolean;
15
+ }
16
+ interface TemplateDefinitionInfo {
17
+ name: string;
18
+ primitive: string;
19
+ description?: string;
20
+ fields: string[];
21
+ path: string;
22
+ format: 'schema' | 'legacy';
23
+ }
24
+ declare function listTemplateDefinitions(options?: TemplateCommandContext): TemplateDefinitionInfo[];
25
+ declare function listTemplates(options?: TemplateCommandContext): string[];
26
+ declare function createFromTemplate(name: string, options?: TemplateCreateOptions): {
27
+ outputPath: string;
28
+ templatePath: string;
29
+ variables: TemplateVariables;
30
+ };
31
+ declare function addTemplate(file: string, options: TemplateAddOptions): {
32
+ templatePath: string;
33
+ name: string;
34
+ };
35
+
36
+ export { type TemplateAddOptions, type TemplateCommandContext, type TemplateCreateOptions, type TemplateDefinitionInfo, addTemplate, createFromTemplate, listTemplateDefinitions, listTemplates };
@@ -5,11 +5,12 @@ import {
5
5
  normalizeTemplateName,
6
6
  parseTemplateDefinition,
7
7
  renderDocumentFromTemplate
8
- } from "../chunk-MFAWT5O5.js";
8
+ } from "../chunk-LYHGEHXG.js";
9
9
  import {
10
10
  buildTemplateVariables,
11
11
  renderTemplate
12
12
  } from "../chunk-7766SIJP.js";
13
+ import "../chunk-3RG5ZIWI.js";
13
14
 
14
15
  // src/commands/template.ts
15
16
  import * as fs from "fs";