@mytechtoday/augment-extensions 0.4.0 → 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -6
- package/augment-extensions/domain-rules/design/color/themes/catppuccin-latte/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/catppuccin-latte/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/catppuccin-mocha/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/catppuccin-mocha/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/dracula/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/dracula/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/gruvbox-dark/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/gruvbox-dark/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/gruvbox-light/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/gruvbox-light/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/high-contrast/README.md +27 -0
- package/augment-extensions/domain-rules/design/color/themes/high-contrast/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/monokai/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/monokai/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/nord/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/nord/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/one-dark/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/one-dark/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/one-light/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/one-light/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/solarized-dark/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/solarized-dark/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/solarized-light/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/solarized-light/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/tokyo-night/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/tokyo-night/module.json +26 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/README.md +136 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/SCHEMA-VALIDATION-REPORT.md +216 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/brand-kit-example.yaml +292 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/campaign-brief-example.yaml +389 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/content-calendar-example.yaml +643 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/email-newsletter-example.md +376 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/landing-page-example.md +934 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/ppc-ad-copy-example.md +301 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/seo-blog-post-example.md +347 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/social-media-campaign-example.md +606 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/module.json +50 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/affiliate-influencer-marketing.md +593 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/asset-management.md +418 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/brand-consistency.md +210 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/content-marketing.md +337 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/conversion-optimization.md +455 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/direct-sales.md +499 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/email-marketing.md +439 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/legal-compliance.md +227 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/ppc-advertising.md +569 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/seo-optimization.md +470 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/social-media-marketing.md +414 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/universal-marketing.md +177 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/schemas/asset-inventory.schema.json +247 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/schemas/brand-kit.schema.json +326 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/schemas/campaign-brief.schema.json +342 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/schemas/color-palette.schema.json +223 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/schemas/content-template.schema.json +383 -0
- package/augment-extensions/workflows/beads-integration/IMPLEMENTATION-STATUS.md +145 -0
- package/augment-extensions/workflows/beads-integration/README.md +143 -0
- package/augment-extensions/workflows/beads-integration/config/defaults.json +32 -0
- package/augment-extensions/workflows/beads-integration/config/schema.json +140 -0
- package/augment-extensions/workflows/beads-integration/examples/basic-task-generation.md +293 -0
- package/augment-extensions/workflows/beads-integration/module.json +75 -0
- package/augment-extensions/workflows/beads-integration/rules/core-rules.md +219 -0
- package/augment-extensions/workflows/beads-integration/rules/effectiveness-standards.md +256 -0
- package/augment-extensions/workflows/beads-integration/rules/task-generation.md +607 -0
- package/augment-extensions/writing-standards/screenplay/README.md +135 -6
- package/augment-extensions/writing-standards/screenplay/_templates/README.md +121 -0
- package/augment-extensions/writing-standards/screenplay/_templates/genre-template.md +153 -0
- package/augment-extensions/writing-standards/screenplay/_templates/style-template.md +243 -0
- package/augment-extensions/writing-standards/screenplay/_templates/theme-template.md +213 -0
- package/augment-extensions/writing-standards/screenplay/examples/beat-sheet-example.yaml +95 -0
- package/augment-extensions/writing-standards/screenplay/examples/character-profile-example.yaml +116 -0
- package/augment-extensions/writing-standards/screenplay/examples/commercial-30sec.fountain +151 -0
- package/augment-extensions/writing-standards/screenplay/examples/independent-monologue.fountain +67 -0
- package/augment-extensions/writing-standards/screenplay/examples/news-segment.fountain +142 -0
- package/augment-extensions/writing-standards/screenplay/examples/plot-outline-example.yaml +184 -0
- package/augment-extensions/writing-standards/screenplay/examples/tv-episode-teaser.fountain +204 -0
- package/augment-extensions/writing-standards/screenplay/genres/README.md +181 -0
- package/augment-extensions/writing-standards/screenplay/genres/examples/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/genres/module.json +70 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/action.md +399 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/adventure.md +407 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/animation.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/biographical.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/comedy.md +401 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/documentary.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/drama.md +409 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/fantasy.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/historical.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/horror.md +268 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/musical.md +294 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/mystery.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/noir.md +294 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/romance.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/sci-fi.md +289 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/superhero.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/thriller.md +294 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/western.md +293 -0
- package/augment-extensions/writing-standards/screenplay/module.json +1 -1
- package/augment-extensions/writing-standards/screenplay/rules/aaa-hollywood-films.md +339 -0
- package/augment-extensions/writing-standards/screenplay/rules/ai-integration-testing.md +329 -0
- package/augment-extensions/writing-standards/screenplay/rules/character-development.md +169 -0
- package/augment-extensions/writing-standards/screenplay/rules/commercials.md +437 -0
- package/augment-extensions/writing-standards/screenplay/rules/dialogue-writing.md +263 -0
- package/augment-extensions/writing-standards/screenplay/rules/diversity-inclusion.md +261 -0
- package/augment-extensions/writing-standards/screenplay/rules/examples-guide.md +315 -0
- package/augment-extensions/writing-standards/screenplay/rules/formatting-validation.md +413 -0
- package/augment-extensions/writing-standards/screenplay/rules/fountain-format.md +372 -0
- package/augment-extensions/writing-standards/screenplay/rules/independent-films.md +374 -0
- package/augment-extensions/writing-standards/screenplay/rules/live-tv-productions.md +443 -0
- package/augment-extensions/writing-standards/screenplay/rules/narrative-structures.md +207 -0
- package/augment-extensions/writing-standards/screenplay/rules/news-broadcasts.md +444 -0
- package/augment-extensions/writing-standards/screenplay/rules/pacing-timing.md +331 -0
- package/augment-extensions/writing-standards/screenplay/rules/quality-review-checklist.md +334 -0
- package/augment-extensions/writing-standards/screenplay/rules/quick-reference.md +299 -0
- package/augment-extensions/writing-standards/screenplay/rules/screen-continuity.md +263 -0
- package/augment-extensions/writing-standards/screenplay/rules/streaming-content.md +412 -0
- package/augment-extensions/writing-standards/screenplay/rules/trope-management.md +370 -0
- package/augment-extensions/writing-standards/screenplay/rules/tv-series.md +374 -0
- package/augment-extensions/writing-standards/screenplay/rules/vscode-integration.md +277 -0
- package/augment-extensions/writing-standards/screenplay/rules/web-content.md +393 -0
- package/augment-extensions/writing-standards/screenplay/schemas/beat-sheet.json +332 -0
- package/augment-extensions/writing-standards/screenplay/schemas/character-profile.json +247 -0
- package/augment-extensions/writing-standards/screenplay/schemas/feature-selection.json +200 -0
- package/augment-extensions/writing-standards/screenplay/schemas/plot-outline.json +233 -0
- package/augment-extensions/writing-standards/screenplay/schemas/screenplay-config.json +245 -0
- package/augment-extensions/writing-standards/screenplay/schemas/trope-inventory.json +221 -0
- package/augment-extensions/writing-standards/screenplay/styles/README.md +159 -0
- package/augment-extensions/writing-standards/screenplay/styles/examples/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/styles/examples/style-applications.md +1449 -0
- package/augment-extensions/writing-standards/screenplay/styles/module.json +64 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/dialogue-centric.md +520 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/ensemble.md +499 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/epic.md +497 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/experimental.md +492 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/flashback.md +509 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/linear.md +490 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/minimalist.md +499 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/non-linear.md +501 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/poetic.md +499 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/realistic.md +498 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/satirical.md +499 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/surreal.md +508 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/voice-over.md +500 -0
- package/augment-extensions/writing-standards/screenplay/themes/README.md +158 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/common-mistakes-and-fixes.md +643 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/complete-scene-example.md +311 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/individual-theme-examples.md +562 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/multi-theme-weaving.md +538 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/theme-application-guide.md +432 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/theme-integration-across-acts.md +637 -0
- package/augment-extensions/writing-standards/screenplay/themes/module.json +66 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/ambition.md +458 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/betrayal.md +490 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/environment.md +458 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/fate.md +459 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/friendship.md +491 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/growth.md +491 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/identity.md +490 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/isolation.md +464 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/justice.md +461 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/love.md +489 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/power.md +494 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/redemption.md +483 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/revenge.md +489 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/survival.md +496 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/technology.md +463 -0
- package/cli/dist/cli.js +30 -1
- package/cli/dist/cli.js.map +1 -1
- package/cli/dist/commands/show.d.ts +23 -0
- package/cli/dist/commands/show.d.ts.map +1 -1
- package/cli/dist/commands/show.js +928 -10
- package/cli/dist/commands/show.js.map +1 -1
- package/cli/dist/types/gui.d.ts +62 -0
- package/cli/dist/types/gui.d.ts.map +1 -0
- package/cli/dist/types/gui.js +30 -0
- package/cli/dist/types/gui.js.map +1 -0
- package/cli/dist/utils/config-system.d.ts +111 -0
- package/cli/dist/utils/config-system.d.ts.map +1 -0
- package/cli/dist/utils/config-system.js +239 -0
- package/cli/dist/utils/config-system.js.map +1 -0
- package/cli/dist/utils/gui-helpers.d.ts +23 -0
- package/cli/dist/utils/gui-helpers.d.ts.map +1 -0
- package/cli/dist/utils/gui-helpers.js +159 -0
- package/cli/dist/utils/gui-helpers.js.map +1 -0
- package/cli/dist/utils/hook-system.d.ts +84 -0
- package/cli/dist/utils/hook-system.d.ts.map +1 -0
- package/cli/dist/utils/hook-system.js +151 -0
- package/cli/dist/utils/hook-system.js.map +1 -0
- package/cli/dist/utils/inspection-cache.d.ts +56 -0
- package/cli/dist/utils/inspection-cache.d.ts.map +1 -0
- package/cli/dist/utils/inspection-cache.js +166 -0
- package/cli/dist/utils/inspection-cache.js.map +1 -0
- package/cli/dist/utils/inspection-handlers.d.ts +75 -0
- package/cli/dist/utils/inspection-handlers.d.ts.map +1 -0
- package/cli/dist/utils/inspection-handlers.js +171 -0
- package/cli/dist/utils/inspection-handlers.js.map +1 -0
- package/cli/dist/utils/module-system.d.ts +81 -1
- package/cli/dist/utils/module-system.d.ts.map +1 -1
- package/cli/dist/utils/module-system.js +393 -16
- package/cli/dist/utils/module-system.js.map +1 -1
- package/cli/dist/utils/plugin-system.d.ts +133 -0
- package/cli/dist/utils/plugin-system.d.ts.map +1 -0
- package/cli/dist/utils/plugin-system.js +210 -0
- package/cli/dist/utils/plugin-system.js.map +1 -0
- package/cli/dist/utils/progress.d.ts +67 -0
- package/cli/dist/utils/progress.d.ts.map +1 -0
- package/cli/dist/utils/progress.js +146 -0
- package/cli/dist/utils/progress.js.map +1 -0
- package/cli/dist/utils/stream-reader.d.ts +34 -0
- package/cli/dist/utils/stream-reader.d.ts.map +1 -0
- package/cli/dist/utils/stream-reader.js +147 -0
- package/cli/dist/utils/stream-reader.js.map +1 -0
- package/cli/dist/utils/vscode-editor.d.ts +45 -0
- package/cli/dist/utils/vscode-editor.d.ts.map +1 -0
- package/cli/dist/utils/vscode-editor.js +171 -0
- package/cli/dist/utils/vscode-editor.js.map +1 -0
- package/cli/dist/utils/vscode-links.d.ts +49 -0
- package/cli/dist/utils/vscode-links.d.ts.map +1 -0
- package/cli/dist/utils/vscode-links.js +167 -0
- package/cli/dist/utils/vscode-links.js.map +1 -0
- package/modules.md +44 -2
- package/package.json +6 -4
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
{
|
|
2
|
+
"mode": "advanced",
|
|
3
|
+
"features": {
|
|
4
|
+
"task_generation": true,
|
|
5
|
+
"openspec_integration": true,
|
|
6
|
+
"typescript_commands": true,
|
|
7
|
+
"effectiveness_rules": true
|
|
8
|
+
},
|
|
9
|
+
"rules": {
|
|
10
|
+
"task_detail_level": "comprehensive",
|
|
11
|
+
"require_dependencies": true,
|
|
12
|
+
"require_verification": true,
|
|
13
|
+
"require_prerequisites": true,
|
|
14
|
+
"require_success_metrics": true
|
|
15
|
+
},
|
|
16
|
+
"openspec": {
|
|
17
|
+
"auto_decompose": false,
|
|
18
|
+
"dependency_detection": "hybrid",
|
|
19
|
+
"parallelization": true
|
|
20
|
+
},
|
|
21
|
+
"typescript": {
|
|
22
|
+
"validation_level": "standard",
|
|
23
|
+
"auto_fix": false
|
|
24
|
+
},
|
|
25
|
+
"effectiveness": {
|
|
26
|
+
"atomicity_check": true,
|
|
27
|
+
"completeness_check": true,
|
|
28
|
+
"clarity_check": true,
|
|
29
|
+
"testability_check": true
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"title": "Beads Integration Configuration Schema",
|
|
4
|
+
"description": "Configuration schema for the Beads Integration Workflow module",
|
|
5
|
+
"type": "object",
|
|
6
|
+
"properties": {
|
|
7
|
+
"mode": {
|
|
8
|
+
"type": "string",
|
|
9
|
+
"enum": ["basic", "advanced", "custom"],
|
|
10
|
+
"default": "advanced",
|
|
11
|
+
"description": "Configuration mode: basic (simplified), advanced (full features), custom (configurable)"
|
|
12
|
+
},
|
|
13
|
+
"features": {
|
|
14
|
+
"type": "object",
|
|
15
|
+
"description": "Feature flags for enabling/disabling functionality",
|
|
16
|
+
"properties": {
|
|
17
|
+
"task_generation": {
|
|
18
|
+
"type": "boolean",
|
|
19
|
+
"default": true,
|
|
20
|
+
"description": "Enable AI-driven comprehensive task generation"
|
|
21
|
+
},
|
|
22
|
+
"openspec_integration": {
|
|
23
|
+
"type": "boolean",
|
|
24
|
+
"default": true,
|
|
25
|
+
"description": "Enable automated OpenSpec-to-Beads decomposition"
|
|
26
|
+
},
|
|
27
|
+
"typescript_commands": {
|
|
28
|
+
"type": "boolean",
|
|
29
|
+
"default": true,
|
|
30
|
+
"description": "Enable TypeScript automation commands"
|
|
31
|
+
},
|
|
32
|
+
"effectiveness_rules": {
|
|
33
|
+
"type": "boolean",
|
|
34
|
+
"default": true,
|
|
35
|
+
"description": "Enable effectiveness standards for task quality"
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
},
|
|
39
|
+
"rules": {
|
|
40
|
+
"type": "object",
|
|
41
|
+
"description": "Rule settings for task generation and validation",
|
|
42
|
+
"properties": {
|
|
43
|
+
"task_detail_level": {
|
|
44
|
+
"type": "string",
|
|
45
|
+
"enum": ["minimal", "standard", "comprehensive"],
|
|
46
|
+
"default": "comprehensive",
|
|
47
|
+
"description": "Level of detail required in task descriptions"
|
|
48
|
+
},
|
|
49
|
+
"require_dependencies": {
|
|
50
|
+
"type": "boolean",
|
|
51
|
+
"default": true,
|
|
52
|
+
"description": "Require explicit dependency declarations"
|
|
53
|
+
},
|
|
54
|
+
"require_verification": {
|
|
55
|
+
"type": "boolean",
|
|
56
|
+
"default": true,
|
|
57
|
+
"description": "Require verification/acceptance criteria in tasks"
|
|
58
|
+
},
|
|
59
|
+
"require_prerequisites": {
|
|
60
|
+
"type": "boolean",
|
|
61
|
+
"default": true,
|
|
62
|
+
"description": "Require prerequisite documentation in tasks"
|
|
63
|
+
},
|
|
64
|
+
"require_success_metrics": {
|
|
65
|
+
"type": "boolean",
|
|
66
|
+
"default": true,
|
|
67
|
+
"description": "Require success metrics in task descriptions"
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
},
|
|
71
|
+
"openspec": {
|
|
72
|
+
"type": "object",
|
|
73
|
+
"description": "OpenSpec integration settings",
|
|
74
|
+
"properties": {
|
|
75
|
+
"auto_decompose": {
|
|
76
|
+
"type": "boolean",
|
|
77
|
+
"default": false,
|
|
78
|
+
"description": "Automatically decompose OpenSpec specs into tasks"
|
|
79
|
+
},
|
|
80
|
+
"dependency_detection": {
|
|
81
|
+
"type": "string",
|
|
82
|
+
"enum": ["automatic", "manual", "hybrid"],
|
|
83
|
+
"default": "hybrid",
|
|
84
|
+
"description": "Method for detecting task dependencies"
|
|
85
|
+
},
|
|
86
|
+
"parallelization": {
|
|
87
|
+
"type": "boolean",
|
|
88
|
+
"default": true,
|
|
89
|
+
"description": "Identify and mark parallelizable tasks"
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
},
|
|
93
|
+
"typescript": {
|
|
94
|
+
"type": "object",
|
|
95
|
+
"description": "TypeScript command settings",
|
|
96
|
+
"properties": {
|
|
97
|
+
"validation_level": {
|
|
98
|
+
"type": "string",
|
|
99
|
+
"enum": ["strict", "standard", "lenient"],
|
|
100
|
+
"default": "standard",
|
|
101
|
+
"description": "Validation strictness level"
|
|
102
|
+
},
|
|
103
|
+
"auto_fix": {
|
|
104
|
+
"type": "boolean",
|
|
105
|
+
"default": false,
|
|
106
|
+
"description": "Automatically fix validation errors when possible"
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
},
|
|
110
|
+
"effectiveness": {
|
|
111
|
+
"type": "object",
|
|
112
|
+
"description": "Effectiveness standards settings",
|
|
113
|
+
"properties": {
|
|
114
|
+
"atomicity_check": {
|
|
115
|
+
"type": "boolean",
|
|
116
|
+
"default": true,
|
|
117
|
+
"description": "Verify tasks are atomic (single-purpose)"
|
|
118
|
+
},
|
|
119
|
+
"completeness_check": {
|
|
120
|
+
"type": "boolean",
|
|
121
|
+
"default": true,
|
|
122
|
+
"description": "Verify tasks contain all necessary information"
|
|
123
|
+
},
|
|
124
|
+
"clarity_check": {
|
|
125
|
+
"type": "boolean",
|
|
126
|
+
"default": true,
|
|
127
|
+
"description": "Verify tasks have clear, unambiguous instructions"
|
|
128
|
+
},
|
|
129
|
+
"testability_check": {
|
|
130
|
+
"type": "boolean",
|
|
131
|
+
"default": true,
|
|
132
|
+
"description": "Verify tasks have clear success criteria"
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
},
|
|
137
|
+
"required": ["mode"],
|
|
138
|
+
"additionalProperties": false
|
|
139
|
+
}
|
|
140
|
+
|
|
@@ -0,0 +1,293 @@
|
|
|
1
|
+
# Basic Task Generation Examples
|
|
2
|
+
|
|
3
|
+
## Overview
|
|
4
|
+
|
|
5
|
+
This document demonstrates basic task generation with examples showing the transformation from a simple specification to a comprehensive Beads task. It includes before/after comparisons and configuration examples.
|
|
6
|
+
|
|
7
|
+
## Example 1: Simple Feature Specification
|
|
8
|
+
|
|
9
|
+
### Input Specification
|
|
10
|
+
|
|
11
|
+
```markdown
|
|
12
|
+
# Feature: User Profile Picture Upload
|
|
13
|
+
|
|
14
|
+
Users should be able to upload a profile picture. The picture should be displayed on their profile page.
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
### Step-by-Step Decomposition
|
|
18
|
+
|
|
19
|
+
#### Step 1: Identify Core Requirements
|
|
20
|
+
- File upload functionality
|
|
21
|
+
- Image storage
|
|
22
|
+
- Profile page display
|
|
23
|
+
- Validation (file type, size)
|
|
24
|
+
|
|
25
|
+
#### Step 2: Break Down into Tasks
|
|
26
|
+
1. Backend: File upload endpoint
|
|
27
|
+
2. Backend: Image storage and retrieval
|
|
28
|
+
3. Frontend: Upload UI component
|
|
29
|
+
4. Frontend: Display profile picture
|
|
30
|
+
|
|
31
|
+
#### Step 3: Apply Core Rules
|
|
32
|
+
|
|
33
|
+
For Task 1 (Backend: File upload endpoint):
|
|
34
|
+
|
|
35
|
+
**Title**: Create profile picture upload endpoint
|
|
36
|
+
|
|
37
|
+
**Description**: Implement POST /api/users/:id/profile-picture endpoint that accepts image uploads, validates file type and size, and stores the image.
|
|
38
|
+
|
|
39
|
+
**Prerequisites**:
|
|
40
|
+
- [ ] File storage service configured (S3 or local storage)
|
|
41
|
+
- [ ] Image processing library installed (sharp or jimp)
|
|
42
|
+
- [ ] User authentication middleware implemented
|
|
43
|
+
|
|
44
|
+
**Steps**:
|
|
45
|
+
1. Create POST /api/users/:id/profile-picture route
|
|
46
|
+
2. Add multer middleware for file upload handling
|
|
47
|
+
3. Validate file type (JPEG, PNG, GIF only)
|
|
48
|
+
4. Validate file size (max 5MB)
|
|
49
|
+
5. Resize image to 400x400px
|
|
50
|
+
6. Generate unique filename
|
|
51
|
+
7. Store image in file storage
|
|
52
|
+
8. Update user record with image URL
|
|
53
|
+
9. Return image URL in response
|
|
54
|
+
|
|
55
|
+
**Verification**:
|
|
56
|
+
- [ ] Endpoint accepts valid image files
|
|
57
|
+
- [ ] Endpoint rejects invalid file types
|
|
58
|
+
- [ ] Endpoint rejects files > 5MB
|
|
59
|
+
- [ ] Image is resized to 400x400px
|
|
60
|
+
- [ ] Image URL is stored in user record
|
|
61
|
+
- [ ] Endpoint returns 400 for invalid requests
|
|
62
|
+
- [ ] Endpoint returns 200 with image URL for valid requests
|
|
63
|
+
|
|
64
|
+
**Success Metrics**:
|
|
65
|
+
- Upload success rate > 99%
|
|
66
|
+
- Upload time < 2 seconds
|
|
67
|
+
- Image quality maintained after resize
|
|
68
|
+
- No security vulnerabilities (file type validation)
|
|
69
|
+
|
|
70
|
+
### Before/After Comparison
|
|
71
|
+
|
|
72
|
+
#### ❌ BEFORE: Minimal Task (Unacceptable)
|
|
73
|
+
|
|
74
|
+
```markdown
|
|
75
|
+
# Task: Add profile picture upload
|
|
76
|
+
|
|
77
|
+
## Description
|
|
78
|
+
Users can upload profile pictures
|
|
79
|
+
|
|
80
|
+
## Steps
|
|
81
|
+
1. Create upload endpoint
|
|
82
|
+
2. Store image
|
|
83
|
+
3. Display on profile
|
|
84
|
+
|
|
85
|
+
## Verification
|
|
86
|
+
- Upload works
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
**Problems**:
|
|
90
|
+
- No specific endpoint details
|
|
91
|
+
- No validation requirements
|
|
92
|
+
- No error handling
|
|
93
|
+
- No measurable success criteria
|
|
94
|
+
- Missing prerequisites
|
|
95
|
+
- Vague steps
|
|
96
|
+
|
|
97
|
+
#### ✅ AFTER: Comprehensive Task (Acceptable)
|
|
98
|
+
|
|
99
|
+
```markdown
|
|
100
|
+
# Task: Create profile picture upload endpoint
|
|
101
|
+
|
|
102
|
+
## Description
|
|
103
|
+
Implement POST /api/users/:id/profile-picture endpoint that accepts image uploads, validates file type and size, resizes images, and stores them securely.
|
|
104
|
+
|
|
105
|
+
## Context
|
|
106
|
+
Users need to personalize their profiles with pictures. This endpoint will handle the upload, validation, and storage of profile pictures.
|
|
107
|
+
|
|
108
|
+
## Prerequisites
|
|
109
|
+
- [ ] File storage service configured (AWS S3 or local storage)
|
|
110
|
+
- [ ] Image processing library installed (sharp npm package)
|
|
111
|
+
- [ ] User authentication middleware implemented
|
|
112
|
+
- [ ] User model includes profilePictureUrl field
|
|
113
|
+
|
|
114
|
+
## Inputs
|
|
115
|
+
- **User ID**: From URL parameter (:id)
|
|
116
|
+
- **Image File**: Multipart form data (field name: "profilePicture")
|
|
117
|
+
- **Auth Token**: JWT token in Authorization header
|
|
118
|
+
|
|
119
|
+
## Outputs
|
|
120
|
+
- **Success Response**: { "imageUrl": "https://..." }
|
|
121
|
+
- **Error Response**: { "error": "Invalid file type" }
|
|
122
|
+
|
|
123
|
+
## Steps
|
|
124
|
+
1. **Create route handler**
|
|
125
|
+
- Add POST /api/users/:id/profile-picture route
|
|
126
|
+
- Apply authentication middleware
|
|
127
|
+
- Apply authorization check (user can only upload own picture)
|
|
128
|
+
|
|
129
|
+
2. **Configure multer middleware**
|
|
130
|
+
- Set up multer with memory storage
|
|
131
|
+
- Configure file size limit (5MB)
|
|
132
|
+
- Set field name to "profilePicture"
|
|
133
|
+
|
|
134
|
+
3. **Implement validation**
|
|
135
|
+
- Check file exists in request
|
|
136
|
+
- Validate MIME type (image/jpeg, image/png, image/gif)
|
|
137
|
+
- Validate file size <= 5MB
|
|
138
|
+
- Return 400 error if validation fails
|
|
139
|
+
|
|
140
|
+
4. **Process image**
|
|
141
|
+
- Use sharp to resize image to 400x400px
|
|
142
|
+
- Maintain aspect ratio with cover fit
|
|
143
|
+
- Convert to JPEG format
|
|
144
|
+
- Compress to 80% quality
|
|
145
|
+
|
|
146
|
+
5. **Store image**
|
|
147
|
+
- Generate unique filename (userId-timestamp.jpg)
|
|
148
|
+
- Upload to S3 or save to local storage
|
|
149
|
+
- Get public URL for image
|
|
150
|
+
|
|
151
|
+
6. **Update user record**
|
|
152
|
+
- Update user.profilePictureUrl with image URL
|
|
153
|
+
- Save user record to database
|
|
154
|
+
|
|
155
|
+
7. **Return response**
|
|
156
|
+
- Return 200 with { "imageUrl": "..." }
|
|
157
|
+
- Include appropriate headers
|
|
158
|
+
|
|
159
|
+
## Dependencies
|
|
160
|
+
### Blocks
|
|
161
|
+
- `bd-auth`: User authentication middleware must be implemented
|
|
162
|
+
- `bd-storage`: File storage service must be configured
|
|
163
|
+
|
|
164
|
+
### Related
|
|
165
|
+
- `bd-profile-display`: Profile page will display this image
|
|
166
|
+
|
|
167
|
+
## Edge Cases
|
|
168
|
+
### Case 1: User uploads non-image file
|
|
169
|
+
- **Condition**: File MIME type is not image/*
|
|
170
|
+
- **Handling**: Return 400 error with message "Invalid file type"
|
|
171
|
+
- **Expected Outcome**: Upload rejected, user notified
|
|
172
|
+
|
|
173
|
+
### Case 2: File size exceeds limit
|
|
174
|
+
- **Condition**: File size > 5MB
|
|
175
|
+
- **Handling**: Multer rejects upload, return 400 error
|
|
176
|
+
- **Expected Outcome**: Upload rejected before processing
|
|
177
|
+
|
|
178
|
+
### Case 3: Storage service unavailable
|
|
179
|
+
- **Condition**: S3 or storage service returns error
|
|
180
|
+
- **Handling**: Return 500 error, log error, retry once
|
|
181
|
+
- **Expected Outcome**: User notified, error logged for investigation
|
|
182
|
+
|
|
183
|
+
## Error Handling
|
|
184
|
+
### Error 1: Invalid file type
|
|
185
|
+
- **Cause**: User uploads non-image file
|
|
186
|
+
- **Detection**: MIME type check fails
|
|
187
|
+
- **Resolution**: Return 400 with clear error message
|
|
188
|
+
- **Prevention**: Client-side validation (accept="image/*")
|
|
189
|
+
|
|
190
|
+
### Error 2: Storage failure
|
|
191
|
+
- **Cause**: S3 unavailable or disk full
|
|
192
|
+
- **Detection**: Storage operation throws error
|
|
193
|
+
- **Resolution**: Return 500, log error, alert ops team
|
|
194
|
+
- **Prevention**: Monitor storage health and capacity
|
|
195
|
+
|
|
196
|
+
## Verification
|
|
197
|
+
- [ ] Endpoint accepts JPEG, PNG, GIF files
|
|
198
|
+
- [ ] Endpoint rejects non-image files (400 error)
|
|
199
|
+
- [ ] Endpoint rejects files > 5MB (400 error)
|
|
200
|
+
- [ ] Image is resized to 400x400px
|
|
201
|
+
- [ ] Image quality is acceptable after processing
|
|
202
|
+
- [ ] Image URL is stored in user.profilePictureUrl
|
|
203
|
+
- [ ] Endpoint requires authentication
|
|
204
|
+
- [ ] User can only upload own profile picture
|
|
205
|
+
- [ ] Storage errors handled gracefully
|
|
206
|
+
- [ ] Response includes correct image URL
|
|
207
|
+
|
|
208
|
+
## Success Metrics
|
|
209
|
+
- **Upload Success Rate**: > 99% for valid files
|
|
210
|
+
- **Upload Time**: < 2 seconds (p95)
|
|
211
|
+
- **Image Quality**: SSIM > 0.95 after resize
|
|
212
|
+
- **Error Rate**: < 1% for valid requests
|
|
213
|
+
|
|
214
|
+
## Testing
|
|
215
|
+
### Unit Tests
|
|
216
|
+
- Validate file type validation logic
|
|
217
|
+
- Validate file size validation logic
|
|
218
|
+
- Test image resize function
|
|
219
|
+
- Test filename generation
|
|
220
|
+
|
|
221
|
+
### Integration Tests
|
|
222
|
+
- Upload valid JPEG file - success
|
|
223
|
+
- Upload valid PNG file - success
|
|
224
|
+
- Upload PDF file - 400 error
|
|
225
|
+
- Upload 10MB file - 400 error
|
|
226
|
+
- Upload without authentication - 401 error
|
|
227
|
+
- Upload to another user's profile - 403 error
|
|
228
|
+
|
|
229
|
+
## Documentation
|
|
230
|
+
- [ ] API endpoint documented in API docs
|
|
231
|
+
- [ ] Error codes documented
|
|
232
|
+
- [ ] File size and type limits documented
|
|
233
|
+
- [ ] Example request/response added
|
|
234
|
+
|
|
235
|
+
## Rollback Plan
|
|
236
|
+
1. Remove route from API
|
|
237
|
+
2. Revert user model changes
|
|
238
|
+
3. Clean up uploaded images (if any)
|
|
239
|
+
4. Verify API works without endpoint
|
|
240
|
+
|
|
241
|
+
## Estimated Effort
|
|
242
|
+
- **Time**: 4-6 hours
|
|
243
|
+
- **Complexity**: Medium
|
|
244
|
+
- **Risk**: Low
|
|
245
|
+
|
|
246
|
+
## Resources
|
|
247
|
+
- [Multer documentation](https://github.com/expressjs/multer)
|
|
248
|
+
- [Sharp documentation](https://sharp.pixelplumbing.com/)
|
|
249
|
+
- [AWS S3 SDK](https://docs.aws.amazon.com/sdk-for-javascript/)
|
|
250
|
+
```
|
|
251
|
+
|
|
252
|
+
**Improvements**:
|
|
253
|
+
- ✅ Specific endpoint and method
|
|
254
|
+
- ✅ Detailed validation requirements
|
|
255
|
+
- ✅ Comprehensive error handling
|
|
256
|
+
- ✅ Measurable success criteria
|
|
257
|
+
- ✅ Clear prerequisites
|
|
258
|
+
- ✅ Step-by-step instructions
|
|
259
|
+
- ✅ Edge cases documented
|
|
260
|
+
- ✅ Testing requirements specified
|
|
261
|
+
|
|
262
|
+
## Configuration Example for Basic Mode
|
|
263
|
+
|
|
264
|
+
```json
|
|
265
|
+
{
|
|
266
|
+
"mode": "basic",
|
|
267
|
+
"features": {
|
|
268
|
+
"task_generation": true,
|
|
269
|
+
"openspec_integration": false,
|
|
270
|
+
"typescript_commands": false,
|
|
271
|
+
"effectiveness_rules": true
|
|
272
|
+
},
|
|
273
|
+
"rules": {
|
|
274
|
+
"task_detail_level": "standard",
|
|
275
|
+
"require_dependencies": true,
|
|
276
|
+
"require_verification": true,
|
|
277
|
+
"require_prerequisites": true,
|
|
278
|
+
"require_success_metrics": false
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
## Summary
|
|
284
|
+
|
|
285
|
+
Basic task generation transforms simple specifications into comprehensive, actionable tasks by:
|
|
286
|
+
1. **Identifying** core requirements
|
|
287
|
+
2. **Breaking down** into atomic tasks
|
|
288
|
+
3. **Applying** core rules and effectiveness standards
|
|
289
|
+
4. **Adding** all necessary context and details
|
|
290
|
+
5. **Ensuring** tasks are complete, clear, and testable
|
|
291
|
+
|
|
292
|
+
**Key Takeaway**: Never create bare-minimum task skeletons. Always provide comprehensive, actionable task descriptions.
|
|
293
|
+
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "beads-integration",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"displayName": "Beads Integration Workflow",
|
|
5
|
+
"description": "Comprehensive guidelines and automation for AI-driven Beads task generation, OpenSpec decomposition, and workflow integration",
|
|
6
|
+
"type": "workflow",
|
|
7
|
+
"tags": [
|
|
8
|
+
"beads",
|
|
9
|
+
"task-management",
|
|
10
|
+
"openspec",
|
|
11
|
+
"workflow",
|
|
12
|
+
"automation",
|
|
13
|
+
"ai-integration",
|
|
14
|
+
"task-generation"
|
|
15
|
+
],
|
|
16
|
+
"dependencies": {
|
|
17
|
+
"workflows/openspec": ">=1.0.0",
|
|
18
|
+
"workflows/beads": ">=1.0.0"
|
|
19
|
+
},
|
|
20
|
+
"augment": {
|
|
21
|
+
"characterCount": 0,
|
|
22
|
+
"priority": "high",
|
|
23
|
+
"category": "workflow",
|
|
24
|
+
"appliesTo": {
|
|
25
|
+
"filePatterns": [
|
|
26
|
+
".beads/**/*",
|
|
27
|
+
"openspec/**/*",
|
|
28
|
+
"**/*.md"
|
|
29
|
+
],
|
|
30
|
+
"languages": ["markdown", "json", "typescript"]
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
"installation": {
|
|
34
|
+
"required": false,
|
|
35
|
+
"steps": [
|
|
36
|
+
"Link module: augx link workflows/beads-integration",
|
|
37
|
+
"Configure mode in config/defaults.json (basic, advanced, or custom)",
|
|
38
|
+
"Enable desired features in configuration"
|
|
39
|
+
]
|
|
40
|
+
},
|
|
41
|
+
"features": {
|
|
42
|
+
"task_generation": {
|
|
43
|
+
"enabled": true,
|
|
44
|
+
"description": "AI-driven comprehensive task generation with quality standards"
|
|
45
|
+
},
|
|
46
|
+
"openspec_integration": {
|
|
47
|
+
"enabled": true,
|
|
48
|
+
"description": "Automated OpenSpec-to-Beads decomposition"
|
|
49
|
+
},
|
|
50
|
+
"typescript_commands": {
|
|
51
|
+
"enabled": true,
|
|
52
|
+
"description": "TypeScript automation commands for validation and generation"
|
|
53
|
+
},
|
|
54
|
+
"effectiveness_rules": {
|
|
55
|
+
"enabled": true,
|
|
56
|
+
"description": "Effectiveness standards ensuring high-quality task content"
|
|
57
|
+
}
|
|
58
|
+
},
|
|
59
|
+
"contents": [
|
|
60
|
+
"rules/core-rules.md - Universal guidelines for all beads task generation",
|
|
61
|
+
"rules/task-generation.md - Comprehensive task generation guidelines",
|
|
62
|
+
"rules/effectiveness-standards.md - Quality and effectiveness criteria",
|
|
63
|
+
"rules/openspec-integration.md - OpenSpec decomposition automation",
|
|
64
|
+
"rules/typescript-commands.md - TypeScript command framework",
|
|
65
|
+
"config/schema.json - Configuration schema",
|
|
66
|
+
"config/defaults.json - Default configuration",
|
|
67
|
+
"examples/basic-task-generation.md - Basic task generation examples",
|
|
68
|
+
"examples/advanced-decomposition.md - Advanced decomposition examples",
|
|
69
|
+
"examples/typescript-automation.md - TypeScript automation examples",
|
|
70
|
+
"scripts/validators/ - Validation commands",
|
|
71
|
+
"scripts/generators/ - Generation commands",
|
|
72
|
+
"scripts/integrations/ - Integration commands"
|
|
73
|
+
]
|
|
74
|
+
}
|
|
75
|
+
|