
planning-guidelines
by aiskillstore
Security-audited skills for Claude, Codex & Claude Code. One-click install, quality verified.
SKILL.md
name: planning-guidelines description: "Core planning principles for Portfolio Buddy 2 development. Use when: planning any feature implementation, modification, or refactoring. Ensures code preservation, mobile/desktop optimization, and thorough requirement gathering."
Planning Guidelines for Portfolio Buddy 2
Core Principles
When planning and implementing features for Portfolio Buddy 2, always follow these fundamental principles:
- Preserve Existing Code - Default to extending rather than replacing
- Optimize for Mobile & Desktop - Every feature must work well on both
- Ask Clarifying Questions - Gather complete context before execution
- Integrate Seamlessly - New code should feel native to the existing codebase
Code Preservation Strategy
Default Behavior: Always Preserve
Rule: Preserve existing code unless explicitly instructed to refactor or rewrite.
When implementing new features or fixes:
- ✅ Extend existing components
- ✅ Add new functions alongside existing ones
- ✅ Preserve existing patterns and conventions
- ✅ Maintain backward compatibility
- ❌ Don't refactor working code "just because"
- ❌ Don't introduce new patterns without justification
Exception: Massively Better Options
You MAY propose improvements to existing code ONLY when ALL conditions are met:
- Very Low Risk - Change is isolated, well-understood, easily reversible
- Massive Upside - Significant benefit (correctness, performance, maintainability)
- No Unnecessary Complexity - Solution is simpler or equal complexity
- Clear Justification - Can explain why exception applies
When exception applies, you MUST:
- Explain the problem with current implementation
- Show the proposed improvement
- Demonstrate why it meets all three criteria
- Get user approval before implementing
Real Example: Annual Growth Rate Fix
Situation: During implementation of Trading Days update, discovered Annual Growth Rate calculation was mathematically incorrect.
Current (incorrect) code:
const tradingPeriodDays = uniqueTradingDates.size || 1; // 150 days
const annualGrowthRate = (totalPnl / startingCapital / tradingPeriodDays) * 365 * 100;
// Result: Inflated by mixing trading days (denominator) with calendar day annualization (365)
Why exception applied:
-
Very Low Risk ✅
- Isolated calculation (one line)
- Easy to understand (calendar days vs trading days)
- Easily reversible if wrong
-
Massive Upside ✅
- Fixes incorrect financial metric (accuracy critical)
- Returns were inflated by ~2.4x
- Aligns with financial industry standards
-
No Unnecessary Complexity ✅
- Added 9 lines (calendar day calculation)
- Clearer, more correct logic
- No new dependencies
Result: User approved fix immediately because exception criteria were clearly met.
Mobile & Desktop Optimization
Every feature must be optimized for both mobile and desktop experiences.
Quick Reference Checklist
✅ Use Responsive Tailwind Classes
- Base styles for mobile (no prefix)
sm:for small screens (640px+)md:for medium screens (768px+)lg:for large screens (1024px+)
✅ Touch Targets
- Minimum 44x44 pixels for all interactive elements
- Use
touch-manipulationCSS class for better touch response
✅ Test Both Viewports
- Verify layout works on mobile and desktop before completion
- Check that text is readable on small screens
- Ensure buttons/inputs are appropriately sized
Existing Patterns to Follow
Portfolio Buddy 2 already has excellent responsive patterns. Reference these:
Example 1: Responsive Text Sizing
className="text-xs sm:text-sm" // Smaller on mobile
className="text-base sm:text-lg" // Larger on desktop
Example 2: Responsive Spacing
className="gap-1 sm:gap-2" // Tighter gaps on mobile
className="px-2 sm:px-4 py-2 sm:py-3" // Smaller padding on mobile
Example 3: Responsive Layout
className="flex flex-col sm:flex-row" // Stack on mobile, row on desktop
Example 4: Responsive Visibility
<span className="hidden sm:inline">Total Margin</span> // Hide text on mobile, show on desktop
See: src/components/PortfolioSection.tsx for comprehensive examples of responsive patterns throughout the application.
Clarifying Questions Framework
When to Ask Questions
Ask clarifying questions BEFORE executing when:
- Requirements are ambiguous
- Multiple valid approaches exist
- Decision affects architecture or user experience
- User's request could be interpreted multiple ways
- You need context about business logic or domain knowledge
Question Format Template
Use this structure for ALL clarifying questions:
## Clarifying Question: [Topic]
[Brief context about why you need to ask]
**Option A: [Approach Name]** ✅ (Recommended)
- [Detail about approach]
- [Key characteristics]
- **Pros:** [Benefits]
- **Cons:** [Trade-offs]
- **Why experts prefer this:** [Technical reasoning from domain expert perspective]
**Option B: [Alternative Approach]**
- [Detail about approach]
- [Key characteristics]
- **Pros:** [Benefits]
- **Cons:** [Trade-offs]
- **Trade-offs:** [Why this isn't the top choice]
**Option C: [Another Alternative]** (if applicable)
- [Detail about approach]
- [Key characteristics]
- **Pros:** [Benefits]
- **Cons:** [Trade-offs]
- **Trade-offs:** [Why this isn't the top choice]
Key Requirements
- Mark Best Option - Use ✅ to indicate expert-recommended choice
- Explain Reasoning - "Why experts prefer this" section required
- Unbiased Options - Present all options fairly, let marking indicate preference
- Complete Context - User should understand trade-offs without additional research
Real Example: Trading Days Calculation
From today's conversation about how to calculate Trading Days:
## Clarifying Question 2: Trading Days Calculation with Date Filters
When the user sets a custom date range (Start Date/End Date), should Trading Days represent:
**Option A: The number of calendar days in the selected date range** ✅ (Recommended)
- Example: Jan 1 to Jan 31 = 31 days
- **Pros:** Simple, matches user's mental model of "days in range"
- **Cons:** Doesn't account for non-trading days
- **Why experts prefer this:** For portfolio analysis, calendar days provide accurate time-based performance metrics and match financial industry standards for annualized returns.
**Option B: The number of actual trading days (days with trades) within the date range**
- Example: Jan 1 to Jan 31 = only count days where trades occurred (e.g., 18 days)
- **Pros:** Reflects actual market activity
- **Cons:** Can be misleading - a strategy might not trade every day by design
- **Trade-offs:** Better for measuring trading frequency, not time-based performance
Outcome: User chose Option B, demonstrating how clear options enable informed decisions.
Decision Criteria
When to Preserve vs Improve
Use this decision tree:
Is the code broken or incorrect?
├─ YES → Fix it (with explanation)
└─ NO → Is there a massively better option?
├─ YES → Does it meet ALL exception criteria?
│ ├─ YES → Propose improvement (get approval)
│ └─ NO → Preserve existing code
└─ NO → Preserve existing code
Risk Assessment Checklist
Before proposing any change to existing code, verify:
- Change is isolated to specific files/functions
- No ripple effects on other features
- TypeScript compilation succeeds
- No breaking changes to interfaces
- Existing tests still pass (if tests exist)
- Can be reverted with single git revert
Complexity Evaluation
Avoid unnecessary complexity:
- ❌ Adding new libraries when existing ones suffice
- ❌ Introducing new patterns when existing patterns work
- ❌ Over-engineering simple features
- ❌ Premature optimization
- ✅ Using existing utilities and components
- ✅ Following established patterns
- ✅ Simple, readable solutions
Integration with Other Skills
This skill works alongside other Portfolio Buddy 2 skills:
- Use with
planning-framework- Apply Musk's 5-step algorithm and ICE scoring for feature planning - Reference
coding-standards- Follow React 19 and TypeScript standards during implementation - Check
architecture-reference- Understand component hierarchy and existing patterns before adding code - Consult
migration-tracker- Verify feature parity and check for known issues before starting - Load
portfolio-context- Get tech stack and architectural constraints context
Workflow:
- Load
planning-guidelines(this skill) → Understand principles - Load
planning-framework→ Plan the feature approach - Check
architecture-reference→ Find where code goes - Apply
coding-standards→ Write the code correctly - Update
migration-tracker→ Document what was added
Real Portfolio Buddy 2 Examples
Example 1: Risk-Free Rate Default (Code Preservation)
Task: Set Risk-Free Rate default to 4%
Approach: Pure preservation
- Found existing code:
useState<number>(0) - Changed ONLY the default value:
useState<number>(4) - Preserved everything else: input field, validation, usage in Sortino Ratio
- Result: One line changed, zero risk
Example 2: Trading Days Update (Code Preservation)
Task: Make Trading Days recalculate when date range changes
Approach: Extend existing calculation
- Kept existing
tradingPeriodDaysvariable and display - Added new logic to count unique dates from filtered trades
- Preserved all downstream usage (Annual Growth Rate, etc.)
- Result: Extended, didn't replace
Example 3: Total Margin Button (Seamless Integration)
Task: Add "Set to Total Margin" button for Starting Capital
Approach: Mobile/desktop optimized integration
- Added button next to existing Starting Capital input
- Used existing Portfolio Buddy 2 responsive patterns:
className="flex items-center gap-1 sm:gap-2"(responsive spacing)<span className="hidden sm:inline">Total Margin</span>(hide text on mobile)className="h-3 w-3 sm:h-3.5 sm:w-3.5"(smaller icon on mobile)touch-manipulationclass for better mobile interaction
- Matched existing blue theme and styling
- Only appears when
portfolioDataexists (conditional rendering) - Result: Feels native, works on both viewports
Example 4: Annual Growth Rate Fix (Exception Case)
Task: Originally just fixing Trading Days calculation
Discovery: Found Annual Growth Rate calculation was mathematically incorrect
Exception Applied:
- Very Low Risk: Isolated calculation, 9 lines added, clear logic
- Massive Upside: Fixed inflated returns (was ~2.4x too high), critical for financial accuracy
- No Complexity: Simpler logic (calendar days vs trading days), more maintainable
Approach:
- Explained the problem clearly
- Showed incorrect vs correct formula with examples
- Demonstrated exception criteria were met
- Got user approval
- Implemented fix
Result: User approved immediately because criteria were objective and clearly met.
Summary
Always:
- Preserve existing code by default
- Optimize for mobile AND desktop
- Ask clarifying questions with ✅ marked recommendations
- Integrate seamlessly with existing patterns
Only when ALL criteria met:
- Propose improvements (low risk + massive upside + no added complexity)
- Get user approval before implementing
Never:
- Refactor working code without justification
- Add complexity unnecessarily
- Guess at requirements when you could ask
- Ignore mobile or desktop experience
This skill ensures Portfolio Buddy 2 remains maintainable, consistent, and user-friendly across all devices while preserving the stability of working code.
Score
Total Score
Based on repository quality metrics
SKILL.mdファイルが含まれている
ライセンスが設定されている
100文字以上の説明がある
GitHub Stars 100以上
1ヶ月以内に更新
10回以上フォークされている
オープンIssueが50未満
プログラミング言語が設定されている
1つ以上のタグが設定されている
Reviews
Reviews coming soon
