elliot-stack 1.0.30 → 1.0.36

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 (127) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +4 -0
  3. package/bin/install.cjs +981 -950
  4. package/hooks/repo-search-nudge.js +32 -32
  5. package/package.json +1 -1
  6. package/skills/estack-active-learning-tutor/SKILL.md +339 -339
  7. package/skills/estack-better-title/SKILL.md +64 -64
  8. package/skills/estack-better-title/scripts/rename.sh +55 -55
  9. package/skills/estack-chris-voss/SKILL.md +80 -80
  10. package/skills/estack-chris-voss/references/elliot-notes.md +120 -120
  11. package/skills/estack-chris-voss/references/voss-principles.md +210 -210
  12. package/skills/estack-customer-discovery/SKILL.md +60 -60
  13. package/skills/estack-flight-planner/SKILL.md +332 -332
  14. package/skills/estack-flight-planner/references/config_schema.md +156 -156
  15. package/skills/estack-flight-planner/references/flight_history_schema.md +97 -97
  16. package/skills/estack-flight-planner/references/shuttle_schedules.md +98 -98
  17. package/skills/estack-flight-planner/scripts/check_setup.sh +89 -89
  18. package/skills/estack-flight-planner/scripts/fetch_flights.py +99 -99
  19. package/skills/estack-flight-planner/scripts/filter_flights.py +265 -265
  20. package/skills/estack-flight-planner/scripts/pair_shuttles.py +173 -173
  21. package/skills/estack-github-issue-tracker/SKILL.md +322 -322
  22. package/skills/estack-github-issue-tracker/bin/tracker-tools.cjs +1358 -1358
  23. package/skills/estack-github-issue-tracker/references/gh-cli-patterns.md +124 -124
  24. package/skills/estack-github-issue-tracker/references/result-file-schema.md +156 -156
  25. package/skills/estack-github-issue-tracker/references/tracker-schema.md +96 -96
  26. package/skills/estack-github-issue-tracker/tracker-template.md +58 -58
  27. package/skills/estack-leadership-coach/SKILL.md +235 -0
  28. package/skills/estack-leadership-coach/adding-references.md +280 -0
  29. package/skills/estack-leadership-coach/frameworks/delegation/flows/post-mortem.md +120 -0
  30. package/skills/estack-leadership-coach/frameworks/delegation/flows/pre-delegation.md +138 -0
  31. package/skills/estack-leadership-coach/frameworks/delegation/phases/1-intake.md +145 -0
  32. package/skills/estack-leadership-coach/frameworks/delegation/phases/2-trm-assessment.md +119 -0
  33. package/skills/estack-leadership-coach/frameworks/delegation/phases/3-enrollment.md +132 -0
  34. package/skills/estack-leadership-coach/frameworks/delegation/phases/4-build-brief.md +171 -0
  35. package/skills/estack-leadership-coach/frameworks/delegation/phases/5-monitoring.md +134 -0
  36. package/skills/estack-leadership-coach/frameworks/delegation/phases/6-reverse-delegation.md +118 -0
  37. package/skills/estack-leadership-coach/frameworks/delegation/phases/7-diagnose.md +200 -0
  38. package/skills/estack-leadership-coach/references/.source-files/deci-ryan_self-determination-theory__deci-olafsen-ryan-2017-self-determination-theory-in-work-organizations.md +1881 -0
  39. package/skills/estack-leadership-coach/references/.source-files/deci-ryan_self-determination-theory__gagne-deci-2005-self-determination-theory-and-work-motivation.md +2058 -0
  40. package/skills/estack-leadership-coach/references/.source-files/deci-ryan_self-determination-theory__selfdeterminationtheory-org-theory-overview-page.md +61 -0
  41. package/skills/estack-leadership-coach/references/.source-files/gallup_engagement-research__gallup-3-key-insights-into-the-global-workplace-2024.md +57 -0
  42. package/skills/estack-leadership-coach/references/.source-files/gallup_engagement-research__gallup-managers-account-for-70-percent-of-variance-in-employee-engagement-2015.md +40 -0
  43. package/skills/estack-leadership-coach/references/.source-files/gallup_engagement-research__gallup-state-of-the-global-workplace-2026-global-data-summary.md +73 -0
  44. package/skills/estack-leadership-coach/references/.source-files/gallup_engagement-research__gallup-state-of-the-global-workplace-2026-report-landing.md +42 -0
  45. package/skills/estack-leadership-coach/references/.source-files/hormozi-leila_4-stages__leila-hormozi-the-art-of-delegation-blog-post.md +91 -0
  46. package/skills/estack-leadership-coach/references/.source-files/oncken-wass_monkeys-hbr-1974__oncken-wass-management-time-whos-got-the-monkey-hbr-classic-1974.md +969 -0
  47. package/skills/estack-leadership-coach/references/.source-files/sanchez_main-street-millionaire__codie-sanchez-afford-anything-podcast-ep-565-show-notes.md +89 -0
  48. package/skills/estack-leadership-coach/references/.source-files/sullivan_who-not-how__dan-sullivan-impact-filter-tool-and-guide-booklet.md +565 -0
  49. package/skills/estack-leadership-coach/references/.source-files/van-edwards_cues__vanessa-van-edwards-lewis-howes-school-of-greatness-ep-1231-show-notes.md +122 -0
  50. package/skills/estack-leadership-coach/references/.source-files/van-edwards_cues__vanessa-van-edwards-roger-dooley-cues-interview.md +194 -0
  51. package/skills/estack-leadership-coach/references/deci-ryan_self-determination-theory.md +166 -0
  52. package/skills/estack-leadership-coach/references/doerr_measure-what-matters.md +154 -0
  53. package/skills/estack-leadership-coach/references/ferriss_4hww.md +189 -0
  54. package/skills/estack-leadership-coach/references/gallup_engagement-research.md +105 -0
  55. package/skills/estack-leadership-coach/references/gerber_e-myth-revisited.md +118 -0
  56. package/skills/estack-leadership-coach/references/grove_high-output-management.md +95 -0
  57. package/skills/estack-leadership-coach/references/hormozi-alex_followthrough.md +152 -0
  58. package/skills/estack-leadership-coach/references/hormozi-leila_4-stages.md +146 -0
  59. package/skills/estack-leadership-coach/references/oncken-wass_monkeys-hbr-1974.md +128 -0
  60. package/skills/estack-leadership-coach/references/sanchez_main-street-millionaire.md +196 -0
  61. package/skills/estack-leadership-coach/references/sullivan_who-not-how.md +137 -0
  62. package/skills/estack-leadership-coach/references/van-edwards_cues.md +189 -0
  63. package/skills/estack-migrate-claude-session-history/SKILL.md +226 -0
  64. package/skills/estack-migrate-claude-session-history/references/path-encoding.md +55 -0
  65. package/skills/estack-migrate-claude-session-history/references/troubleshooting.md +96 -0
  66. package/skills/estack-migrate-claude-session-history/scripts/migrate-claude-history.js +1123 -0
  67. package/skills/estack-migrate-claude-session-history/scripts/test-append-note.js +48 -0
  68. package/skills/estack-migrate-claude-session-history/scripts/test-validate-migration.py +326 -0
  69. package/skills/estack-migrate-claude-session-history/scripts/validate-migration.py +493 -0
  70. package/skills/estack-pdf-to-md/SKILL.md +180 -0
  71. package/skills/estack-pdf-to-md/scripts/pdf_to_md.py +596 -0
  72. package/skills/estack-productivity-prioritization-coach/SKILL.md +124 -0
  73. package/skills/estack-productivity-prioritization-coach/sources/01-tony-robbins-rpm.md +39 -0
  74. package/skills/estack-productivity-prioritization-coach/sources/02-justin-sung-task-prioritization.md +34 -0
  75. package/skills/estack-prompt-builder-coach/SKILL.md +81 -81
  76. package/skills/estack-prompt-builder-coach/definition-of-done-generator.md +42 -42
  77. package/skills/estack-prompt-builder-coach/prompt-builder.md +37 -37
  78. package/skills/estack-prompt-builder-coach/task-shaper.md +36 -36
  79. package/skills/estack-prompt-builder-coach/vague-ask-auditor.md +37 -37
  80. package/skills/estack-read-claude-session-history/SKILL.md +204 -204
  81. package/skills/estack-read-claude-session-history/references/jsonl-schema.md +126 -126
  82. package/skills/estack-read-claude-session-history/references/modes.md +423 -423
  83. package/skills/estack-read-claude-session-history/references/recipes.md +271 -271
  84. package/skills/estack-read-claude-session-history/scripts/lib/__init__.py +1 -1
  85. package/skills/estack-read-claude-session-history/scripts/lib/parser.py +460 -460
  86. package/skills/estack-read-claude-session-history/scripts/lib/paths.py +234 -234
  87. package/skills/estack-read-claude-session-history/scripts/lib/search.py +179 -179
  88. package/skills/estack-read-claude-session-history/scripts/lib/subagents.py +88 -88
  89. package/skills/estack-read-claude-session-history/scripts/lib/tools.py +144 -144
  90. package/skills/estack-read-claude-session-history/scripts/read_transcript.py +1776 -1776
  91. package/skills/estack-read-claude-session-history/scripts/tests/conftest.py +40 -40
  92. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/README.md +20 -20
  93. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/all-noise.jsonl +4 -4
  94. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/basic-session.jsonl +2 -2
  95. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/engagement-gaps.jsonl +9 -9
  96. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/engagement-noise.jsonl +7 -7
  97. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/engagement-parallel-a.jsonl +3 -3
  98. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/engagement-parallel-b.jsonl +3 -3
  99. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/engagement-waiting.jsonl +5 -5
  100. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/interrupted.jsonl +2 -2
  101. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/multi-compact.jsonl +8 -8
  102. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/pending-user.jsonl +2 -2
  103. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/subagent-no-meta/subagents/agent-aaa.jsonl +2 -2
  104. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/subagent-no-meta.jsonl +2 -2
  105. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/subagent-parent/subagents/agent-xyz123.jsonl +2 -2
  106. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/subagent-parent/subagents/agent-xyz123.meta.json +1 -1
  107. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/subagent-parent.jsonl +4 -4
  108. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/time-spread.jsonl +6 -6
  109. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/timeline-day-test.jsonl +5 -5
  110. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/tool-zoo.jsonl +10 -10
  111. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/truncated.jsonl +2 -2
  112. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/unicode.jsonl +2 -2
  113. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/with-advisor.jsonl +3 -3
  114. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/with-compact.jsonl +5 -5
  115. package/skills/estack-read-claude-session-history/scripts/tests/fixtures/with-thinking.jsonl +2 -2
  116. package/skills/estack-read-claude-session-history/scripts/tests/test_backup_roots.py +56 -56
  117. package/skills/estack-read-claude-session-history/scripts/tests/test_engagement.py +239 -239
  118. package/skills/estack-read-claude-session-history/scripts/tests/test_json_format.py +201 -201
  119. package/skills/estack-read-claude-session-history/scripts/tests/test_modes.py +199 -199
  120. package/skills/estack-read-claude-session-history/scripts/tests/test_parser.py +195 -195
  121. package/skills/estack-read-claude-session-history/scripts/tests/test_paths.py +133 -133
  122. package/skills/estack-read-claude-session-history/scripts/tests/test_search.py +78 -78
  123. package/skills/estack-read-claude-session-history/scripts/tests/test_subagents.py +43 -43
  124. package/skills/estack-read-claude-session-history/scripts/tests/test_timeline.py +179 -179
  125. package/skills/estack-read-claude-session-history/scripts/tests/test_timezone_and_project.py +212 -212
  126. package/skills/estack-read-claude-session-history/scripts/tests/test_tools.py +80 -80
  127. package/skills/estack-repo-search/SKILL.md +3 -1
@@ -1,144 +1,144 @@
1
- """Tool-call extraction, per-tool formatting, and tool-result lookup."""
2
-
3
- from __future__ import annotations
4
-
5
- import json
6
- from pathlib import Path
7
- from typing import Optional
8
-
9
-
10
- def extract_tool_calls(
11
- lines: list[dict], tool_filter: Optional[set[str]] = None
12
- ) -> list[dict]:
13
- """Every tool_use block with timestamp and parent line index.
14
-
15
- Returns list of dicts: {name, input, id, timestamp, line_index}.
16
- """
17
- out = []
18
- for i, obj in enumerate(lines):
19
- msg = obj.get("message", {})
20
- if not isinstance(msg, dict):
21
- continue
22
- content = msg.get("content")
23
- if not isinstance(content, list):
24
- continue
25
- ts = obj.get("timestamp")
26
- for block in content:
27
- if not isinstance(block, dict):
28
- continue
29
- if block.get("type") != "tool_use":
30
- continue
31
- name = block.get("name", "")
32
- if tool_filter and name not in tool_filter:
33
- continue
34
- out.append({
35
- "name": name,
36
- "input": block.get("input", {}) or {},
37
- "id": block.get("id", ""),
38
- "timestamp": ts,
39
- "line_index": i,
40
- })
41
- return out
42
-
43
-
44
- def _first_line(s: str, n: int = 200) -> str:
45
- if not s:
46
- return ""
47
- line = s.splitlines()[0] if s.splitlines() else s
48
- return line if len(line) <= n else line[: n - 1] + "…"
49
-
50
-
51
- def format_tool_call(call: dict) -> str:
52
- """Per-tool human-readable one-liner."""
53
- name = call.get("name", "?")
54
- inp = call.get("input", {}) or {}
55
-
56
- if name in ("Bash", "PowerShell"):
57
- cmd = inp.get("command", "")
58
- return f"{name}: {_first_line(cmd, 200)}"
59
- if name == "Read":
60
- fp = inp.get("file_path", "")
61
- offset = inp.get("offset")
62
- limit = inp.get("limit")
63
- if offset is not None or limit is not None:
64
- o = offset or 1
65
- l = limit or 0
66
- return f"Read {fp} (lines {o}-{o + l if l else '?'})"
67
- return f"Read {fp}"
68
- if name == "Edit":
69
- fp = inp.get("file_path", "")
70
- edits = inp.get("edits")
71
- if isinstance(edits, list):
72
- return f"Edit {fp} ({len(edits)} edits)"
73
- return f"Edit {fp}"
74
- if name == "Write":
75
- fp = inp.get("file_path", "")
76
- content = inp.get("content", "")
77
- return f"Write {fp} ({len(content)} chars)"
78
- if name in ("Agent", "Task"):
79
- sub = inp.get("subagent_type") or inp.get("agentType") or "?"
80
- desc = inp.get("description", "")
81
- return f"{name}[{sub}]: {_first_line(desc, 200)}"
82
- if name == "Skill":
83
- sk = inp.get("skill", "")
84
- args = inp.get("args", "")
85
- if args:
86
- return f"Skill: {sk} {_first_line(str(args), 100)}"
87
- return f"Skill: {sk}"
88
- if name == "Glob":
89
- pat = inp.get("pattern", "")
90
- return f"Glob: {pat}"
91
- if name == "Grep":
92
- pat = inp.get("pattern", "")
93
- return f"Grep: {pat}"
94
- try:
95
- preview = json.dumps(inp)[:200]
96
- except (TypeError, ValueError):
97
- preview = str(inp)[:200]
98
- return f"{name}: {preview}"
99
-
100
-
101
- def extract_tool_results(
102
- lines: list[dict], tool_use_id: str
103
- ) -> Optional[str]:
104
- """Find the tool_result block whose tool_use_id matches the given id."""
105
- if not tool_use_id:
106
- return None
107
- for obj in lines:
108
- msg = obj.get("message", {})
109
- if not isinstance(msg, dict):
110
- continue
111
- content = msg.get("content")
112
- if not isinstance(content, list):
113
- continue
114
- for block in content:
115
- if not isinstance(block, dict):
116
- continue
117
- if block.get("type") != "tool_result":
118
- continue
119
- if block.get("tool_use_id") != tool_use_id:
120
- continue
121
- inner = block.get("content", "")
122
- if isinstance(inner, str):
123
- return inner
124
- if isinstance(inner, list):
125
- parts = []
126
- for sub in inner:
127
- if isinstance(sub, dict) and sub.get("type") == "text":
128
- parts.append(sub.get("text", ""))
129
- return "\n".join(parts)
130
- return None
131
-
132
-
133
- def files_touched(lines: list[dict]) -> dict[Path, list[str]]:
134
- """Map of file paths to the list of operations performed on them."""
135
- out: dict[str, list[str]] = {}
136
- for call in extract_tool_calls(lines):
137
- name = call["name"]
138
- inp = call.get("input", {}) or {}
139
- if name in ("Edit", "Write", "Read", "NotebookEdit"):
140
- fp = inp.get("file_path") or inp.get("notebook_path", "")
141
- if fp:
142
- out.setdefault(fp, []).append(name)
143
- # Convert to Path keys
144
- return {Path(k): v for k, v in out.items()}
1
+ """Tool-call extraction, per-tool formatting, and tool-result lookup."""
2
+
3
+ from __future__ import annotations
4
+
5
+ import json
6
+ from pathlib import Path
7
+ from typing import Optional
8
+
9
+
10
+ def extract_tool_calls(
11
+ lines: list[dict], tool_filter: Optional[set[str]] = None
12
+ ) -> list[dict]:
13
+ """Every tool_use block with timestamp and parent line index.
14
+
15
+ Returns list of dicts: {name, input, id, timestamp, line_index}.
16
+ """
17
+ out = []
18
+ for i, obj in enumerate(lines):
19
+ msg = obj.get("message", {})
20
+ if not isinstance(msg, dict):
21
+ continue
22
+ content = msg.get("content")
23
+ if not isinstance(content, list):
24
+ continue
25
+ ts = obj.get("timestamp")
26
+ for block in content:
27
+ if not isinstance(block, dict):
28
+ continue
29
+ if block.get("type") != "tool_use":
30
+ continue
31
+ name = block.get("name", "")
32
+ if tool_filter and name not in tool_filter:
33
+ continue
34
+ out.append({
35
+ "name": name,
36
+ "input": block.get("input", {}) or {},
37
+ "id": block.get("id", ""),
38
+ "timestamp": ts,
39
+ "line_index": i,
40
+ })
41
+ return out
42
+
43
+
44
+ def _first_line(s: str, n: int = 200) -> str:
45
+ if not s:
46
+ return ""
47
+ line = s.splitlines()[0] if s.splitlines() else s
48
+ return line if len(line) <= n else line[: n - 1] + "…"
49
+
50
+
51
+ def format_tool_call(call: dict) -> str:
52
+ """Per-tool human-readable one-liner."""
53
+ name = call.get("name", "?")
54
+ inp = call.get("input", {}) or {}
55
+
56
+ if name in ("Bash", "PowerShell"):
57
+ cmd = inp.get("command", "")
58
+ return f"{name}: {_first_line(cmd, 200)}"
59
+ if name == "Read":
60
+ fp = inp.get("file_path", "")
61
+ offset = inp.get("offset")
62
+ limit = inp.get("limit")
63
+ if offset is not None or limit is not None:
64
+ o = offset or 1
65
+ l = limit or 0
66
+ return f"Read {fp} (lines {o}-{o + l if l else '?'})"
67
+ return f"Read {fp}"
68
+ if name == "Edit":
69
+ fp = inp.get("file_path", "")
70
+ edits = inp.get("edits")
71
+ if isinstance(edits, list):
72
+ return f"Edit {fp} ({len(edits)} edits)"
73
+ return f"Edit {fp}"
74
+ if name == "Write":
75
+ fp = inp.get("file_path", "")
76
+ content = inp.get("content", "")
77
+ return f"Write {fp} ({len(content)} chars)"
78
+ if name in ("Agent", "Task"):
79
+ sub = inp.get("subagent_type") or inp.get("agentType") or "?"
80
+ desc = inp.get("description", "")
81
+ return f"{name}[{sub}]: {_first_line(desc, 200)}"
82
+ if name == "Skill":
83
+ sk = inp.get("skill", "")
84
+ args = inp.get("args", "")
85
+ if args:
86
+ return f"Skill: {sk} {_first_line(str(args), 100)}"
87
+ return f"Skill: {sk}"
88
+ if name == "Glob":
89
+ pat = inp.get("pattern", "")
90
+ return f"Glob: {pat}"
91
+ if name == "Grep":
92
+ pat = inp.get("pattern", "")
93
+ return f"Grep: {pat}"
94
+ try:
95
+ preview = json.dumps(inp)[:200]
96
+ except (TypeError, ValueError):
97
+ preview = str(inp)[:200]
98
+ return f"{name}: {preview}"
99
+
100
+
101
+ def extract_tool_results(
102
+ lines: list[dict], tool_use_id: str
103
+ ) -> Optional[str]:
104
+ """Find the tool_result block whose tool_use_id matches the given id."""
105
+ if not tool_use_id:
106
+ return None
107
+ for obj in lines:
108
+ msg = obj.get("message", {})
109
+ if not isinstance(msg, dict):
110
+ continue
111
+ content = msg.get("content")
112
+ if not isinstance(content, list):
113
+ continue
114
+ for block in content:
115
+ if not isinstance(block, dict):
116
+ continue
117
+ if block.get("type") != "tool_result":
118
+ continue
119
+ if block.get("tool_use_id") != tool_use_id:
120
+ continue
121
+ inner = block.get("content", "")
122
+ if isinstance(inner, str):
123
+ return inner
124
+ if isinstance(inner, list):
125
+ parts = []
126
+ for sub in inner:
127
+ if isinstance(sub, dict) and sub.get("type") == "text":
128
+ parts.append(sub.get("text", ""))
129
+ return "\n".join(parts)
130
+ return None
131
+
132
+
133
+ def files_touched(lines: list[dict]) -> dict[Path, list[str]]:
134
+ """Map of file paths to the list of operations performed on them."""
135
+ out: dict[str, list[str]] = {}
136
+ for call in extract_tool_calls(lines):
137
+ name = call["name"]
138
+ inp = call.get("input", {}) or {}
139
+ if name in ("Edit", "Write", "Read", "NotebookEdit"):
140
+ fp = inp.get("file_path") or inp.get("notebook_path", "")
141
+ if fp:
142
+ out.setdefault(fp, []).append(name)
143
+ # Convert to Path keys
144
+ return {Path(k): v for k, v in out.items()}