Work Effort Implementation Guidelines
Overview
A work effort (WE) is our way of tracking significant pieces of work in the Nova system. Think of it like a project folder that contains all discussions, decisions, and documentation about a specific task or feature.
When to Create a Work Effort
Create a work effort when you have:
- A feature that will take more than a day to complete
- Work that requires discussion or collaboration
- A task that needs to be tracked and documented
- Something that others might need to reference later
When NOT to Create a Work Effort
Don’t create a work effort for:
- Quick fixes (under 1 hour)
- Simple documentation updates
- Questions that can be answered in a single chat
- Personal tasks or notes
Example Scenarios
✅ Good Use Cases:
- “Implement user authentication system”
- “Design new database schema”
- “Create API documentation”
- “Investigate performance issues”
❌ Not Needed:
- “Fix typo in README”
- “Update package version”
- “Quick CSS adjustment”
- “Ask about meeting time”
Getting Started
Work Effort Lifecycle
graph TD
A[Need Identified] -->|Is it worth tracking?| B{Create Work Effort?}
B -->|Yes| C[Create WE]
B -->|No| D[Regular Task]
C --> E[Setup Initial Files]
E --> F[Create First Chat]
F --> G{Work Progress}
G -->|Discussion Needed| H[Create New Chat]
G -->|Update Status| I[Update Main File]
G -->|Complex Task| J[Create Child WE]
H --> G
I --> G
J --> G
G -->|Complete| K[Archive WE]
style A fill:#f9f,stroke:#333,stroke-width:2px
style B fill:#ff9,stroke:#333,stroke-width:2px
style C fill:#9f9,stroke:#333,stroke-width:2px
style K fill:#f99,stroke:#333,stroke-width:2px
Quick Reference Guide
What You Need | When You Need It | Example |
---|---|---|
Work Effort ID | Starting new project | 2432 or WE2432-1117-2024 |
Chat ID | Having discussions | CH2432-1117-2024-001 |
Status Update | Changed progress | status: in-progress |
Child Work Effort | Breaking down big tasks | WE2432-1117-2024-a |
Common Commands
Command | What It Does | When to Use |
---|---|---|
python create_work_effort.py 2432 | Creates new work effort | Starting new work |
python create_chat.py 2432 001 | Creates new chat | Need discussion |
python update_status.py 2432 completed | Updates status | Work is done |
python archive_we.py 2432 | Archives work effort | Project completed |
Creating a Work Effort
- Basic Creation:
- Supported ID Formats:
2432 -> WE2432-1117-2024 (today's date) 2432-1117 -> WE2432-1117-2024 (current year) WE2432-1117-2024 (full format)
Directory Structure
Your work effort will create this structure:
WE2432-1117-2024/
├── WE2432-1117-2024.md # Main work effort file
├── _router-WE2432-1117-2024.md # Chat router
└── chats/ # Chat directory
├── CH2432-1117-2024-001.md # Initial planning
├── CH2432-1117-2024-002.md # Technical discussion
└── CH2432-1117-2024-003.md # Implementation details
Initial Setup Steps
-
Main File Setup:
-
Router File Example:
Work Effort Management
Status Tracking
Use these status values in the frontmatter:
Chat Management
-
Creating New Chats:
-
Chat Content Template:
Child Work Efforts
When to Create Children:
-
Complex Features:
WE2432-1117-2024/ # Parent: API System ├── WE2432-1117-2024-a/ # Child: Authentication ├── WE2432-1117-2024-b/ # Child: Database Schema └── WE2432-1117-2024-c/ # Child: API Endpoints
-
Team Distribution:
WE2433-1117-2024/ # Parent: Web App ├── WE2433-1117-2024-a/ # Child: Frontend Team ├── WE2433-1117-2024-b/ # Child: Backend Team └── WE2433-1117-2024-c/ # Child: DevOps Team
graph TD
A[Parent Work Effort] --> B[Child: Frontend]
A --> C[Child: Backend]
A --> D[Child: DevOps]
B --> E[Chats]
B --> F[Documentation]
C --> G[Chats]
C --> H[Documentation]
D --> I[Chats]
D --> J[Documentation]
style A fill:#f9f,stroke:#333,stroke-width:2px
style B fill:#9f9,stroke:#333,stroke-width:2px
style C fill:#9f9,stroke:#333,stroke-width:2px
style D fill:#9f9,stroke:#333,stroke-width:2px
Common Workflows
Scenario | Action | Example Command |
---|---|---|
Starting new discussion | Create chat | python create_chat.py 2432 001 |
Task completed | Update status | python update_status.py 2432 completed |
Adding subtask | Create child | python create_work_effort.py 2432-a |
Project finished | Archive WE | python archive_we.py 2432 |
Tips for Success
- Create chats for important discussions
- Keep status updated (at least weekly)
- Link related work efforts
- Document decisions promptly
- Use child efforts for complex features
- Archive completed work efforts
Common Issues & Solutions
ID Generation Issues
Solutions:
- Use exactly 4 digits (e.g., 2432)
- Valid date format (MMDD)
- No special characters
- Use script validation
File Structure Problems
Solutions:
- Check existing WEs
- Use unique ID
- Archive old WEs
- Verify naming
Best Practices
Documentation
-
Clear Descriptions:
-
Linking Strategy:
Progress Tracking
-
Regular Updates:
-
Milestone Tracking:
Common Mistakes to Avoid
Mistake | Impact | How to Fix |
---|---|---|
Wrong ID format | Creation fails | Use script’s default format |
Missing links | Hard to find related work | Always add parent/child links |
Outdated status | Team confusion | Update at least weekly |
No chat records | Lost decisions | Create chat for each discussion |
Incomplete docs | Knowledge gaps | Fill all required sections |
Getting Help
-
First Steps:
- Check this documentation
- Look at similar work efforts
- Review error messages
-
Who to Ask:
- Your team lead for process questions
- Technical lead for system issues
- Project manager for scope questions
- DevOps for script problems
-
Where to Look:
Related Resources
Tags
guidelineswork-effortprocessdocumentation
Real-World Examples & Scenarios
Example 1: Feature Implementation
graph TD
A[WE2432: New User Dashboard] --> B[WE2432-a: Frontend]
A --> C[WE2432-b: Backend API]
A --> D[WE2432-c: Database]
B --> E[CH001: Design Review]
B --> F[CH002: Component Structure]
C --> G[CH001: API Endpoints]
C --> H[CH002: Auth Flow]
D --> I[CH001: Schema Design]
style A fill:#f9f,stroke:#333,stroke-width:2px
style B fill:#9f9,stroke:#333,stroke-width:2px
style C fill:#9f9,stroke:#333,stroke-width:2px
style D fill:#9f9,stroke:#333,stroke-width:2px
Example 2: Bug Investigation
Example 3: Documentation Project
Common Workflows
1. Starting a New Feature
2. Daily Development
3. Project Completion
Template Library
1. Feature Implementation Template
2. Bug Investigation Template
3. Documentation Project Template
Troubleshooting Guide
Common Error Messages
Error Message | Likely Cause | Solution |
---|---|---|
Invalid WE ID format | Incorrect ID pattern | Use format: 2432 or 2432-1117 or 2432-a |
Parent work effort doesn't exist | Creating child without parent | Create parent WE first |
Permission denied | File system permissions | Check folder permissions |
Work Effort already exists | Duplicate WE creation | Use a different ID or archive old WE |
A child effort with suffix 'a' already exists | Duplicate child suffix | Use next available letter (b, c, etc.) |
Quick Fixes
-
Script Won’t Run:
-
Parent-Child Issues:
-
File Structure Problems:
Recovery Steps
-
Corrupted Work Effort:
-
Missing Parent Links:
-
Broken Chat Router:
Best Practices for Prevention
-
Before Creating Work Efforts:
- Check existing WE IDs
- Verify parent exists for child efforts
- Use
--dry-run
flag to preview
-
During Development:
- Keep status updated
- Link related work efforts
- Use chat system for discussions
-
Regular Maintenance:
- Archive completed work efforts
- Update parent-child relationships
- Clean up unused chats
Getting Additional Help
-
Internal Resources:
- Check
#work-efforts
Slack channel - Review system documentation
- Contact your team lead
- Check
-
External Support:
- Submit issue in GitLab
- Check knowledge base
- Contact system administrator
Version History
Version | Date | Changes |
---|---|---|
1.0.0 | 2024-11-17 | Initial release |
1.0.1 | 2024-11-18 | Added troubleshooting guide |
1.1.0 | 2024-11-19 | Added support for child efforts |
Need Help?
If you’re stuck, remember to check the troubleshooting guide above or reach out to the support team in the
#work-efforts
Slack channel.