Architecture design and phased implementation planning for Bitwarden Android. Use when planning implementation, designing architecture, creating file inventories, or breaking features into phases. Triggered by "plan implementation", "architecture design", "implementation plan", "break this into phases", "what files do I need", "design the architecture".
This skill takes a refined specification (ideally from the refining-android-requirements skill) and produces a phased implementation plan with architecture design, file inventory, and risk assessment.
Prerequisite: A clear set of requirements. If requirements are vague or incomplete, invoke the refining-android-requirements skill first.
Determine the change type to guide scope and planning depth:
| Type | Description | Typical Scope |
|---|---|---|
| New Feature | Entirely new functionality, screens, or flows | New files + modifications, multi-phase |
| Enhancement | Extending existing feature with new capabilities | Mostly modifications, 1-2 phases |
| Bug Fix | Correcting incorrect behavior | Targeted modifications, single phase |
| Refactoring | Restructuring without behavior change | Modifications only, migration-aware |
| Infrastructure | Build, CI, tooling, or dependency changes | Config files, minimal code changes |
State the classification and rationale before proceeding.
Search the codebase to find reference implementations and integration points. Use the discovery commands from the build-test-verify skill as needed.
Identify 2-3 existing files that serve as templates for the planned work:
**Pattern Anchors:**
1. [file path] — [why this is a good reference]
2. [file path] — [why this is a good reference]
3. [file path] — [why this is a good reference]
Identify files that must be modified to integrate the new work:
@Provides / @Binds functionsdocs/ARCHITECTURE.md Managers section)src/testFixtures/ directoriessrc/standard/ vs src/main/ for Play Services dependenciesNote the specific patterns used by the pattern anchors:
Produce an ASCII diagram showing component relationships for the planned work:
┌─────────────────┐
│ Screen │ ← Compose UI
│ (Composable) │
└────────┬────────┘
│ State / Action / Event
┌────────▼────────┐
│ ViewModel │ ← Business logic orchestration
└────────┬────────┘
│ Repository calls
┌────────▼────────┐
│ Repository │ ← Data coordination (sealed class results)
└───┬────┬────┬───┘
│ │ │
┌───▼───┐ │ ┌─▼──────┐
│Manager│ │ │Manager │ ← Single-responsibility (optional)
└───┬───┘ │ └─┬──────┘
│ │ │
┌───▼─────▼───▼────┐
│ Data Sources │ ← Raw data (Result<T>, never throw)
└─┬────┬────┬──────┘
│ │ │
Room Retrofit SDK
Adapt the diagram to show the actual components planned. Consult docs/ARCHITECTURE.md for full data layer patterns and conventions.
Document key architectural decisions in a table:
| Decision | Resolution | Rationale |
|---|---|---|
| [What needed deciding] | [What was chosen] | [Why] |
| File Path | Type | Pattern Reference |
|---|---|---|
| [full path] | [ViewModel / Screen / Repository / etc.] | [pattern anchor file] |
Include in file inventory:
...Navigation.kt files for new screens...Module.kt Hilt module files for new DI bindings...Test.kt) for each new class| File Path | Change Description | Risk Level |
|---|---|---|
| [full path] | [what changes] | Low / Medium / High |
Risk levels:
Break the work into sequential phases. Each phase should be independently testable and committable.
Phase ordering principle: Foundation → SDK/Data → Network → UI (tests accompany each phase)
For each phase:
### Phase N: [Name]
**Goal**: [What this phase accomplishes]
**Files**:
- Create: [list]
- Modify: [list]
**Tasks**:
1. [Specific implementation task]
2. [Specific implementation task]
3. ...
**Verification**:
- [Test command or manual verification step]
**Skills**: [Which workflow skills apply — e.g., `implementing-android-code`, `testing-android-code`]
| Risk | Likelihood | Impact | Mitigation |
|---|---|---|---|
| [What could go wrong] | Low/Med/High | Low/Med/High | [How to prevent or handle] |
Automated Verification:
build-test-verify skill)Manual Verification:
SavedStateHandle persistence and Don't keep activities developer option)