@hasna/prompts 0.3.2 → 0.3.4

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 (2) hide show
  1. package/dist/mcp/index.js +77 -1
  2. package/package.json +1 -1
package/dist/mcp/index.js CHANGED
@@ -5413,7 +5413,31 @@ server.registerTool("prompts_render", {
5413
5413
  }, async ({ id, vars, agent }) => {
5414
5414
  try {
5415
5415
  const prompt = usePrompt(id);
5416
- const result = renderTemplate(prompt.body, vars);
5416
+ const autoFilled = {};
5417
+ if (agent) {
5418
+ const CONTEXT_VARS = {
5419
+ agent_name: () => agent,
5420
+ agent_id: () => agent,
5421
+ project_id: () => process.env.TODOS_PROJECT_ID || process.env.PROJECT_ID,
5422
+ org_id: () => process.env.ORG_ID,
5423
+ session_id: () => process.env.SESSION_ID,
5424
+ cwd: () => process.cwd(),
5425
+ date: () => new Date().toISOString().split("T")[0],
5426
+ datetime: () => new Date().toISOString()
5427
+ };
5428
+ for (const [key, getter] of Object.entries(CONTEXT_VARS)) {
5429
+ if (!(key in vars)) {
5430
+ const val = getter();
5431
+ if (val)
5432
+ autoFilled[key] = val;
5433
+ }
5434
+ }
5435
+ }
5436
+ const mergedVars = { ...autoFilled, ...vars };
5437
+ const result = renderTemplate(prompt.body, mergedVars);
5438
+ if (Object.keys(autoFilled).length > 0) {
5439
+ result.auto_filled = autoFilled;
5440
+ }
5417
5441
  await maybeSaveMemento({ slug: prompt.slug, body: prompt.body, rendered: result.rendered, agentId: agent });
5418
5442
  return ok(result);
5419
5443
  } catch (e) {
@@ -5547,6 +5571,58 @@ server.registerTool("prompts_import", {
5547
5571
  const results = importFromJson(prompts, changed_by);
5548
5572
  return ok(results);
5549
5573
  });
5574
+ server.registerTool("prompts_export_as_skills", {
5575
+ description: "Export prompts as Claude Code SKILL.md files in ~/.claude/skills/ so they become /slug slash commands. Each prompt slug becomes an invocable skill.",
5576
+ inputSchema: {
5577
+ collection: exports_external.string().optional().describe("Only export prompts from this collection"),
5578
+ slugs: exports_external.array(exports_external.string()).optional().describe("Specific prompt slugs to export"),
5579
+ target_dir: exports_external.string().optional().describe("Target skills directory (default: ~/.claude/skills)"),
5580
+ overwrite: exports_external.boolean().optional().describe("Overwrite existing skill files (default: false)")
5581
+ }
5582
+ }, async ({ collection, slugs, target_dir, overwrite }) => {
5583
+ try {
5584
+ const { mkdirSync: mkdirSync2, writeFileSync, existsSync: existsSync2 } = await import("fs");
5585
+ const { join: join2 } = await import("path");
5586
+ const { homedir } = await import("os");
5587
+ const skillsDir = target_dir ?? join2(homedir(), ".claude", "skills");
5588
+ mkdirSync2(skillsDir, { recursive: true });
5589
+ const filter = collection ? { collection } : {};
5590
+ const allPrompts = listPrompts(filter);
5591
+ const toExport = slugs ? allPrompts.filter((p) => slugs.includes(p.slug)) : allPrompts;
5592
+ const exported = [];
5593
+ const skipped = [];
5594
+ for (const prompt of toExport) {
5595
+ const skillDir = join2(skillsDir, `skill-${prompt.slug}`);
5596
+ const skillFile = join2(skillDir, "SKILL.md");
5597
+ if (!overwrite && existsSync2(skillFile)) {
5598
+ skipped.push(prompt.slug);
5599
+ continue;
5600
+ }
5601
+ mkdirSync2(skillDir, { recursive: true });
5602
+ const skillContent = [
5603
+ "---",
5604
+ `name: skill-${prompt.slug}`,
5605
+ `description: ${prompt.description || prompt.title}`,
5606
+ "user_invocable: true",
5607
+ "---",
5608
+ "",
5609
+ prompt.body
5610
+ ].join(`
5611
+ `);
5612
+ writeFileSync(skillFile, skillContent, "utf-8");
5613
+ exported.push(prompt.slug);
5614
+ }
5615
+ return ok({
5616
+ exported: exported.length,
5617
+ skipped: skipped.length,
5618
+ skills_dir: skillsDir,
5619
+ exported_slugs: exported,
5620
+ message: `Exported ${exported.length} prompt(s) as skills. Use /skill-{slug} to invoke them.`
5621
+ });
5622
+ } catch (e) {
5623
+ return err(e instanceof Error ? e.message : String(e));
5624
+ }
5625
+ });
5550
5626
  server.registerTool("prompts_import_slash_commands", {
5551
5627
  description: "Auto-scan .claude/commands, .codex/skills, .gemini/extensions (both project and home dir) and import all .md files as prompts.",
5552
5628
  inputSchema: {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hasna/prompts",
3
- "version": "0.3.2",
3
+ "version": "0.3.4",
4
4
  "description": "Reusable prompt library for AI agents — CLI + MCP server + REST API + web dashboard",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",