Agent skill
triage
Strategically route orphaned files and extract scattered tasks
Install this agent skill to your Project
npx add-skill https://github.com/davekilleen/Dex/tree/main/.claude/skills/triage
SKILL.md
Cleanup and routing tool that finds standalone files and scattered tasks, then suggests where they belong using your current strategic context (Week Priorities + Quarterly Goals).
Execution Style
This skill handles quick decisions. Be concise. Don't over-analyze. Make a routing decision and move on. Target: <2 seconds of thinking per item.
What It Does
- Files: Routes standalone files in
00-Inbox/to projects, person pages, or resource folders - Tasks: Finds unchecked
- [ ]tasks scattered across notes and routes them appropriately - Strategic: Uses your Week Priorities and Quarterly Goals to inform routing confidence
Usage
/triage- Process everything (files + tasks)/triage files- Organize standalone files only/triage tasks- Extract and route tasks only
Arguments
$MODE: Optional. "files" | "tasks" | "all". Default: "all"
Demo Mode Check
Before executing, check if demo mode is active:
- Read
System/user-profile.yamland checkdemo_mode - If
demo_mode: true:- Display: "Demo Mode Active — Using sample data"
- Use
System/Demo/paths instead of root paths - Write any output to
System/Demo/subdirectories
- If
demo_mode: false: Use normal vault paths
Step 0: Load Strategic Context & Structure Discovery
Before processing inbox items, load strategic context and build an index of existing entities. This makes triage strategically aware and enables intelligent routing.
0. Load Strategic Context
Read these files to understand current priorities:
-
Week Priorities:
00-Inbox/Week_Priorities.md- Extract this week's Top 3 focus items
- Note any specific projects/people mentioned
- Capture keywords and themes
-
Quarterly Goals:
03-Tasks/Quarterly_Goals.md- Extract current quarter's goals
- Note associated projects and outcomes
- Capture keywords and themes
This context will inform routing decisions - entries matching current priorities get higher confidence scoring and are surfaced first.
1. Scan Projects
List all files in 04-Projects/:
- Extract project name from filename (convert underscores to spaces)
- Read frontmatter if present for description, status, pillar
- Build index:
{ name, path, description, status, pillar }
2. Scan People
List all files in 05-Areas/People/External/ and 05-Areas/People/Internal/:
- Extract name from filename
- Read frontmatter/metadata table for role, company
- Build index:
{ name, path, company, role, type: internal|external }
3. Scan Role-Specific Areas
List any additional folders under 05-Areas/ that aren't People or Career:
- These may be role-specific areas created during setup (e.g., Accounts/, Team/, Content/)
- Extract relevant names from filenames
- Build index:
{ name, path, type: area_type }
4. Read Pillars
Parse System/pillars.yaml:
- Extract pillar names, descriptions, and keywords
- These inform categorization when no entity match is found
Step 0.5: Semantic Matching Enhancement (if QMD available)
This step activates automatically when QMD is installed. It dramatically improves routing accuracy by matching inbox items to goals, projects, and people by meaning, not just keywords.
Check if QMD MCP tools are available by calling qmd_status. If available:
After loading strategic context (Step 0), enhance matching with semantic search:
-
For each inbox item, run:
qmd_search(query="[item title + first 100 words of content]", limit=5)This finds vault content related by meaning. "Email about onboarding flow" matches "Q1 goal: improve activation rate" even though they share no keywords.
-
For task deduplication, use semantic similarity instead of keyword overlap:
qmd_search(query="[task description]", limit=3)Catches semantic duplicates: "Review Q1 metrics" detected as duplicate of "Check quarterly pipeline numbers".
-
For goal alignment scoring, run:
qmd_search(query="[item content]", limit=3)against quarterly goals and weekly priorities. Items semantically related to active goals get a +25 confidence boost.
How this changes matching:
| Aspect | Without QMD (keyword) | With QMD (semantic) |
|---|---|---|
| Goal matching | Exact keyword overlap only | Meaning-based: "churn analysis" matches "retention goal" |
| Duplicate detection | >60% string similarity | Semantic similarity: different words, same intent |
| Person matching | Name must appear in text | Role/title references found: "the sales VP" → Sarah Chen |
| Project matching | Project name in filename | Thematic connection: "pricing update" → "Acme Deal" project |
Merge semantic scores with entity scores from Step 0. The combined confidence determines routing priority.
If QMD is not available: Skip silently. The standard keyword-based matching in the steps below handles routing with existing patterns.
Mode: Files
Organize standalone files in the 00-Inbox/ folder by suggesting where they belong.
Process
-
Scan 00-Inbox/
- List all files (exclude Week Priorities.md, README.md)
- Read each file's content
-
Match Against Strategic Context & Entities
For each inbox file, check in this order:
Check Match Criteria Action Confidence Boost Week Priority match Content relates to this week's Top 3 priorities Route to associated project/person, flag as HIGH priority +30 points Quarterly Goal match Content relates to current quarter's goals Route to associated project, flag as strategic +20 points Project match File mentions project name, or filename contains project reference Route to specific project file +10 points if also matches priority Person match File is about a specific person, contains their name prominently Route to person page OR suggest linking +10 points if person mentioned in priorities Company match File mentions company name, or attendees from known domain Route to company page in 05-Areas/Companies/ Base confidence Pillar keyword match Content matches pillar keywords Tag with pillar, suggest relevant category Base confidence No entity match None of the above Fall back to category routing Low confidence -
Category Fallback Rules
When no specific entity matches, use these rules:
Destination Criteria 04-Projects/Has deadline, specific outcome, time-bound 05-Areas/[specific area]/Belongs to a role-specific area (Accounts/, Team/, Content/) 05-Areas/People/Person-specific information 06-Resources/Reference material, knowledge, learnings 07-Archives/Old/completed, no longer active Delete No value, redundant, or temporary -
Present Suggestions with Strategic & Entity Context
Show what was matched, prioritizing items that align with current priorities:
File: [filename] Strategic Context: [Week Priority/Q Goal if matched] Match: [entity type] → [specific entity name] Destination: [exact path] Confidence: [high/medium/low] ([score]/100) Action: [suggested action]Sort order:
- Items matching Week Priorities (highest confidence first)
- Items matching Quarterly Goals
- Items matching known entities (projects, people, companies)
- Generic category routing
Flag misalignments:
- If multiple entries relate to something NOT in priorities/goals, surface it: "You've captured 5 items about [topic]. Consider adding to priorities?"
-
Execute with Confirmation
- Show full plan
- Wait for user approval
- Move files using
mv(not copy) - For merges, append content to existing file
Mode: Tasks
Extract uncompleted tasks from notes and route them appropriately.
Process
-
Scan Sources
00-Inbox/Meetings/*.md- Meeting action items00-Inbox/*.md- Captured tasks- Any file with unchecked tasks
- [ ]
-
Extract Tasks
- Find all
- [ ]items - Note the source file for each
- Extract any mentioned names, projects, companies
- Find all
-
Match Tasks to Entities
For each task:
- Check if it mentions a known project → suggest adding to that project
- Check if it mentions a known person → suggest linking to person page
- Check if it mentions a known company → suggest linking to company
-
Deduplication Check
For each task, check against:
00-Inbox/Weekly_Plans.md03-Tasks/Tasks.md
Flag items with >60% similarity to existing tasks.
-
Ambiguity Detection
Flag tasks that are:
- Less than 3 words
- Match vague patterns (e.g., "fix bug", "follow up", "research X")
Generate clarification questions for ambiguous items.
-
Present Results
Ready to Route (clear, non-duplicate items):
- Show suggested destination with entity context
- Show pillar if detectable
- Show any linked entities
Potential Duplicates (>60% similarity):
- Show the existing task it matches
- Ask: Skip / Merge / Keep Both
Needs Clarification (ambiguous):
- Show the issue
- Ask clarifying questions
- Wait for user input
-
Route with Confirmation
- To Week Priorities: Add to
00-Inbox/Weekly_Plans.md - To Project: Add to relevant project file
- To Person: Add to person page's action items
- Skip: Don't process
- Defer: Leave for later
- To Week Priorities: Add to
Mode: All (Default)
Process all orphaned items:
- Load strategic context (Week Priorities + Quarterly Goals)
- Run structure discovery (projects, people, companies)
- Organize standalone files in
00-Inbox/ - Extract and route scattered unchecked tasks from all notes
Example Output
📬 Triage Report
=== STRATEGIC CONTEXT ===
Week Priorities:
• Mobile App Launch (beta by Friday)
• Q2 Planning finalization
• Sarah's team onboarding
Quarterly Goals:
• Launch mobile app beta (Q1)
• Expand into EMEA market (Q2)
• Build product marketing team (Q1)
=== STRUCTURE DISCOVERED ===
• 4 projects found in 04-Projects/
• 12 people found in 05-Areas/People/
• 3 companies found in 05-Areas/Companies/
• 3 pillars configured
=== FILES (2) ===
1. "Screenshot 2026-01-28.png"
Found in: 00-Inbox/
Strategic Context: (no automatic match - image file)
Suggested: Review manually or describe context
2. "Q1_Planning_Notes.md"
Strategic Context: ✓ Week Priority "Q2 Planning" (related)
Match: PROJECT → "Q2 Planning"
Destination: 04-Projects/Q2_Planning.md
Confidence: MEDIUM (70/100)
Action: Merge into Q2 Planning project?
=== TASKS (4) ===
🎯 HIGH PRIORITY - MATCHES WEEK PRIORITIES (1):
1. "- [ ] Finalize mobile app pricing model"
Found in: 04-Projects/Mobile_App_Launch.md
Strategic Context: ✓ Week Priority "Mobile App Launch" + Q1 Goal
Match: Already in correct project
Confidence: HIGH (95/100)
Action: Extract to Week Priorities for visibility?
📋 NEEDS ROUTING (2):
2. "- [ ] Follow up with Sarah about timeline concerns"
Found in: random meeting note
Strategic Context: ✓ Week Priority "Sarah's team onboarding"
Match: PERSON → "Sarah Chen"
Destination: Add to Sarah's person page action items
Confidence: HIGH (85/100)
3. "- [ ] Review competitor pricing"
Found in: scattered note
Strategic Context: (no direct priority match)
Match: PILLAR → "Product Strategy"
Destination: Week Priorities or Tasks.md?
Confidence: MEDIUM (60/100)
⚠️ DUPLICATE (1):
4. "- [ ] Reach out to Sarah"
Found in: old meeting note
78% match with existing task in Week Priorities
Action: Skip / Merge / Keep both?
=== TASKS (5 items) ===
✅ READY TO ROUTE (3):
1. "Follow up with Sarah about Q1 budget"
→ Week Priorities
Links: People/External/Sarah_Chen.md
2. "Prep slides for conference"
→ Week Priorities
Pillar: Thought Leadership
3. "Review competitor analysis for Acme deal"
→ 04-Projects/Acme_Deal.md (project match)
Links: 05-Areas/Companies/Acme_Corp.md
⚠️ POTENTIAL DUPLICATE (1):
4. "Contact Tom about implementation"
→ 78% match with "Reach out to Tom" in Week Priorities
[s]kip / [m]erge / [k]eep both?
❓ NEEDS CLARIFICATION (1):
5. "Fix the bug"
- Too vague. Which bug? What system?
---
Proceed with ready items? [y/n]
How Structure Discovery Evolves
Because discovery happens at runtime:
- New projects are automatically recognized in the next triage
- New people pages become available for matching
- New companies get detected
- Custom folders you add are included as destinations
No configuration needed - triage adapts as your structure grows.
Notes
- Never auto-route without confirmation
- Duplicates require explicit decision
- Ambiguous items block until clarified
- Use
mvnotcpwhen moving files - Entity matches show confidence level (high/medium/low)
- Multiple entity matches are shown for user to choose
Track Usage (Silent)
Update System/usage_log.md to mark inbox triage as used.
Analytics (Silent):
Call track_event with event_name triage_completed and properties:
- items_processed
- tasks_extracted
- files_routed
This only fires if the user has opted into analytics. No action needed if it returns "analytics_disabled".
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
getting-started
Interactive post-onboarding tour with adaptive pathways based on available data
industry-truths
Define time-horizoned assumptions about your industry/domain that ground strategic thinking and prevent building on quicksand
process-meetings
Process synced Granola meetings to update person pages, extract tasks, and organize meeting notes
pi-tools
View and manage Pi-built extensions synced to Dex. Shows available tools, commands, and sync status.
pi
Route tasks to Pi for comparison testing. Toggle Pi mode or run specific commands through Pi.
commitment-extractor
Extract and track commitments from meeting notes - who promised what to whom, with deadlines and status tracking.
Didn't find tool you were looking for?