Agent skill
followup-todos
Extract action items as plain markdown bullets (with confirmation). Args: <path>. No args = run [/note-status pending --step=todos](../note-status/SKILL.md#pending-mode).
Install this agent skill to your Project
npx add-skill https://github.com/benoror/obsidianos_work/tree/main/.agents/skills/followup-todos
SKILL.md
Follow-up Todos
Usage
/followup-todos <path>β Extract and propose follow-ups from a specific meeting note./followup-todos(no args) β Run /note-status pending --step=todos to show meetings missing follow-up extraction. The user picks one (or more) to process.
Output format (mandatory)
- Never insert Obsidian Tasks / checkbox lines: no
- [ ],- [x],- [-], or any- [?]pattern. - Never append Tasks-plugin inline metadata on inserted lines: no
π,π«,β³, or other parsed task tokens. (Optional priority emoji at the very end as plain text β e.g.πΌβ is fine if it reads naturally in prose.) - Always insert plain list items:
- Descriptionβ¦Wikilinks ([[@Name]],[[+Team]]) and bold are allowed.
Prerequisites
The meeting file should ideally have cached AI transcripts (from /cache-notes). If not cached, suggest running /cache-notes <path> first. However, the skill also works on notes with only manual content.
Optional context
For classification (owner, urgency, dates in the proposal step), you may still use people-resolver and obsidian-tasks as reference β but do not copy Tasks checkbox or date-token syntax into the note.
Workflow
Step 1: Read the meeting note and gather context
See vault-context for vault discovery conventions.
Read the entire file. Also read Tracker.md to cross-reference Jira tickets and current task status β this helps:
- Set priority: A ticket already marked
πΊin the Tracker should keep that priority (as trailing emoji in the bullet text if you include one). - Avoid duplicates: If a follow-up already exists in the Tracker for the same Jira ticket, flag it in the proposal table (Step 3) rather than creating a duplicate line in the note.
- Add context: If the meeting references a Jira ticket ID (e.g.
PAMENG-1456), pull its current status and assignee from the Tracker.
Extract action items from all content sources, skipping lines that are already captured as follow-ups (compare meaning, not only exact text):
- Manual notes (between frontmatter
---and## π€ AI Notes/## AI Transcripts): Free-text action items (e.g. "- Talk to Chris about X"). Skip lines that are checkbox tasks (- [*]β any single character between brackets) when deduplicating, but note the vault may still contain legacy- [ ]lines from older runs. [!gemini_todos]callout: Gemini's "Suggested Next Steps" β explicit action items.[!gemini_notes]callout: Summary & Details β scan for implicit commitments ("will do X", "agreed to Y", "plans to Z").- Other provider callouts (
[!otter_todos], etc.): Same treatment as Gemini.
Also extract:
- Existing plain bullets and checkbox lines in the follow-up section to avoid duplicates
Participants:from frontmatter (to resolve assignees)- Meeting date (from filename or
created:frontmatter)
Step 2: Classify each action item
For each candidate action item (from manual notes, transcript todos, or implicit commitments in details), determine:
-
Owner: Who is responsible? See people-resolver for name matching and assignee rules.
-
Relevance: Score as
high,medium, orskip:- High: Action is for the user, has a clear deliverable, or is time-sensitive.
- Medium: Action is for someone else but the user should track it, or it's vague but potentially important.
- Skip: Purely informational, already completed (based on date vs today), or not actionable.
-
Priority (for the proposal table only): Based on urgency and impact (see priorities in obsidian-tasks). When inserting bullets, you may end the line with a single priority emoji (
πΊβ«πΌπ½) as plain text β never as Tasks metadata. -
Dates: Note due/start in the proposal table when helpful; do not put
π/π«/β³on inserted lines. If a date matters, write it in words in the bullet (e.g. "by 2026-03-26").
Step 3: Present proposals to the user β MANDATORY CONFIRMATION
β οΈ STOP HERE AND WAIT FOR USER CONFIRMATION. Never skip this step, even during /meeting wrap sequences. Do NOT write follow-ups to the file until the user explicitly approves.
Display a numbered table:
| # | Add? | Follow-up | Owner | Priority |
|---|------|-----------|-------|----------|
| 1 | β
| Talk with Chris about temp environments | Me | πΌ |
| 2 | β
| Offload data lake work to Rob | Me | β« |
| 3 | β¬ | Confirm travel plans for Friday | @Zak | β |
| 4 | β¬ | Verify Vitor's prod hash deployed | Me | πΌ |
- Default
βfor high-relevance items owned by the user. - Default
β¬for others' items or skippable ones. - Let the user toggle by saying numbers (e.g. "1,3,4" or "all" or "none except 2").
Step 4: Insert confirmed follow-ups
Only proceed after the user has explicitly confirmed which items to include (Step 3).
Insert each confirmed item as one line:
- Clear, self-contained description (optional **bold**, `[[@Name]]`, optional trailing πΌ)
Do not use - [ ]. Placement depends on the note's template:
Daily Standup notes (Meetings/*/Scrum/YYYY-MM-DD.md)
These follow the Daily Standup template:
Yesterday
- ...
Today
- ... β INSERT FOLLOW-UPS HERE (append after existing Today items)
Blockers
- ...
---
Pending/Carry-over Backlog
- ...
Insert at the end of the "Today" section, just before the Blockers line. Use StrReplace targeting Blockers as the anchor.
Other meeting notes
Prefer a dedicated section heading if missing, e.g. ## Follow-ups, placed after the title / any manual notes and before ## π€ AI Notes (or ## AI Transcripts). If a ## Follow-ups (or equivalent) section already exists, append there. If neither heading exists, append after the frontmatter closing --- and add ## Follow-ups first.
General rules
- Group by owner if multiple people are involved (optional sub-bullets under a short
**[[@Name]]**line). - Preserve existing content β always append, never overwrite.
Step 5: Mark as processed
After inserting, add a TodosExtracted: YYYY-MM-DDTHH:MM:SS-06:00 frontmatter property to prevent re-processing. This is required β /meeting wrap pending relies on it to detect unprocessed meetings.
Step 6: Offer to commit
See /commit. Skip when called as part of a sequence (e.g. /meeting wrap).
Important Notes
- Always read the file before editing β frontmatter may have changed since your last read.
- Do NOT duplicate follow-ups that already exist in the note body (compare by description similarity).
- When in doubt about relevance, include it as
β¬in Step 3 and let the user decide. - If the meeting is old (>2 weeks), flag items that may already be completed and suggest skipping them.
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
commit
Stage and commit with flexible intent parsing. Accepts file/folder scope, free-text description, amend, or any combination.
obsidian-cli
Interact with Obsidian vaults using the Obsidian CLI to read, create, search, and manage notes, tasks, properties, and more. Also supports plugin and theme development with commands to reload plugins, run JavaScript, capture errors, take screenshots, and inspect the DOM. Use when the user asks to interact with their Obsidian vault, manage notes, search vault content, perform vault operations from the command line, or develop and debug Obsidian plugins and themes.
defuddle
Extract clean markdown content from web pages using Defuddle CLI, removing clutter and navigation to save tokens. Use instead of WebFetch when the user provides a URL to read or analyze, for online documentation, articles, blog posts, or any standard web page.
obsidian-markdown
Create and edit Obsidian Flavored Markdown with wikilinks, embeds, callouts, properties, and other Obsidian-specific syntax. Use when working with .md files in Obsidian, or when the user mentions wikilinks, callouts, frontmatter, tags, embeds, or Obsidian notes.
obsidian-bases
Create and edit Obsidian Bases (.base files) with views, filters, formulas, and summaries. Use when working with .base files, creating database-like views of notes, or when the user mentions Bases, table views, card views, filters, or formulas in Obsidian.
cache-notes
Fetch & embed AI transcripts as Obsidian callouts. Args: <path>, all, refresh <path>. Prompts for URLs if empty.
Didn't find tool you were looking for?