moai-adk 0.25.4__py3-none-any.whl → 0.32.8__py3-none-any.whl
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.
Potentially problematic release.
This version of moai-adk might be problematic. Click here for more details.
- moai_adk/__init__.py +2 -5
- moai_adk/__main__.py +114 -82
- moai_adk/cli/__init__.py +6 -1
- moai_adk/cli/commands/__init__.py +1 -3
- moai_adk/cli/commands/analyze.py +5 -16
- moai_adk/cli/commands/doctor.py +6 -18
- moai_adk/cli/commands/init.py +56 -125
- moai_adk/cli/commands/language.py +14 -35
- moai_adk/cli/commands/status.py +9 -15
- moai_adk/cli/commands/update.py +1555 -190
- moai_adk/cli/prompts/init_prompts.py +112 -56
- moai_adk/cli/spec_status.py +263 -0
- moai_adk/cli/ui/__init__.py +44 -0
- moai_adk/cli/ui/progress.py +422 -0
- moai_adk/cli/ui/prompts.py +389 -0
- moai_adk/cli/ui/theme.py +129 -0
- moai_adk/cli/worktree/__init__.py +27 -0
- moai_adk/cli/worktree/__main__.py +31 -0
- moai_adk/cli/worktree/cli.py +672 -0
- moai_adk/cli/worktree/exceptions.py +89 -0
- moai_adk/cli/worktree/manager.py +490 -0
- moai_adk/cli/worktree/models.py +65 -0
- moai_adk/cli/worktree/registry.py +128 -0
- moai_adk/core/PHASE2_OPTIMIZATIONS.md +467 -0
- moai_adk/core/analysis/session_analyzer.py +17 -56
- moai_adk/core/claude_integration.py +26 -54
- moai_adk/core/command_helpers.py +10 -10
- moai_adk/core/comprehensive_monitoring_system.py +1183 -0
- moai_adk/core/config/auto_spec_config.py +5 -11
- moai_adk/core/config/migration.py +19 -9
- moai_adk/core/config/unified.py +436 -0
- moai_adk/core/context_manager.py +6 -12
- moai_adk/core/enterprise_features.py +1404 -0
- moai_adk/core/error_recovery_system.py +725 -112
- moai_adk/core/event_driven_hook_system.py +1371 -0
- moai_adk/core/git/__init__.py +8 -0
- moai_adk/core/git/branch_manager.py +3 -11
- moai_adk/core/git/checkpoint.py +1 -3
- moai_adk/core/git/conflict_detector.py +413 -0
- moai_adk/core/git/manager.py +91 -1
- moai_adk/core/hooks/post_tool_auto_spec_completion.py +56 -80
- moai_adk/core/input_validation_middleware.py +1006 -0
- moai_adk/core/integration/engine.py +6 -18
- moai_adk/core/integration/integration_tester.py +10 -9
- moai_adk/core/integration/utils.py +1 -1
- moai_adk/core/issue_creator.py +10 -28
- moai_adk/core/jit_context_loader.py +956 -0
- moai_adk/core/jit_enhanced_hook_manager.py +1987 -0
- moai_adk/core/language_config_resolver.py +485 -0
- moai_adk/core/language_validator.py +28 -41
- moai_adk/core/mcp/setup.py +15 -12
- moai_adk/core/merge/__init__.py +9 -0
- moai_adk/core/merge/analyzer.py +481 -0
- moai_adk/core/migration/alfred_to_moai_migrator.py +383 -0
- moai_adk/core/migration/backup_manager.py +78 -9
- moai_adk/core/migration/custom_element_scanner.py +358 -0
- moai_adk/core/migration/file_migrator.py +8 -17
- moai_adk/core/migration/interactive_checkbox_ui.py +488 -0
- moai_adk/core/migration/selective_restorer.py +470 -0
- moai_adk/core/migration/template_utils.py +74 -0
- moai_adk/core/migration/user_selection_ui.py +338 -0
- moai_adk/core/migration/version_detector.py +6 -10
- moai_adk/core/migration/version_migrator.py +3 -3
- moai_adk/core/performance/cache_system.py +8 -10
- moai_adk/core/phase_optimized_hook_scheduler.py +879 -0
- moai_adk/core/project/checker.py +2 -4
- moai_adk/core/project/detector.py +1 -3
- moai_adk/core/project/initializer.py +135 -23
- moai_adk/core/project/phase_executor.py +54 -81
- moai_adk/core/project/validator.py +6 -12
- moai_adk/core/quality/trust_checker.py +9 -27
- moai_adk/core/realtime_monitoring_dashboard.py +1724 -0
- moai_adk/core/robust_json_parser.py +611 -0
- moai_adk/core/rollback_manager.py +73 -148
- moai_adk/core/session_manager.py +10 -26
- moai_adk/core/skill_loading_system.py +579 -0
- moai_adk/core/spec/confidence_scoring.py +31 -100
- moai_adk/core/spec/ears_template_engine.py +351 -286
- moai_adk/core/spec/quality_validator.py +35 -69
- moai_adk/core/spec_status_manager.py +64 -74
- moai_adk/core/template/backup.py +45 -20
- moai_adk/core/template/config.py +112 -39
- moai_adk/core/template/merger.py +11 -19
- moai_adk/core/template/processor.py +253 -149
- moai_adk/core/template_engine.py +73 -40
- moai_adk/core/template_variable_synchronizer.py +417 -0
- moai_adk/core/unified_permission_manager.py +745 -0
- moai_adk/core/user_behavior_analytics.py +851 -0
- moai_adk/core/version_sync.py +429 -0
- moai_adk/foundation/__init__.py +56 -0
- moai_adk/foundation/backend.py +1027 -0
- moai_adk/foundation/database.py +1115 -0
- moai_adk/foundation/devops.py +1585 -0
- moai_adk/foundation/ears.py +431 -0
- moai_adk/foundation/frontend.py +870 -0
- moai_adk/foundation/git/commit_templates.py +4 -12
- moai_adk/foundation/git.py +376 -0
- moai_adk/foundation/langs.py +484 -0
- moai_adk/foundation/ml_ops.py +1162 -0
- moai_adk/foundation/testing.py +1524 -0
- moai_adk/foundation/trust/trust_principles.py +23 -72
- moai_adk/foundation/trust/validation_checklist.py +57 -162
- moai_adk/project/__init__.py +0 -0
- moai_adk/project/configuration.py +1084 -0
- moai_adk/project/documentation.py +566 -0
- moai_adk/project/schema.py +447 -0
- moai_adk/statusline/alfred_detector.py +1 -3
- moai_adk/statusline/config.py +13 -4
- moai_adk/statusline/enhanced_output_style_detector.py +23 -15
- moai_adk/statusline/main.py +51 -15
- moai_adk/statusline/renderer.py +104 -48
- moai_adk/statusline/update_checker.py +3 -9
- moai_adk/statusline/version_reader.py +140 -46
- moai_adk/templates/.claude/agents/moai/ai-nano-banana.md +549 -0
- moai_adk/templates/.claude/agents/moai/builder-agent.md +445 -0
- moai_adk/templates/.claude/agents/moai/builder-command.md +1132 -0
- moai_adk/templates/.claude/agents/moai/builder-skill.md +601 -0
- moai_adk/templates/.claude/agents/moai/expert-backend.md +831 -0
- moai_adk/templates/.claude/agents/moai/expert-database.md +774 -0
- moai_adk/templates/.claude/agents/moai/expert-debug.md +396 -0
- moai_adk/templates/.claude/agents/moai/expert-devops.md +711 -0
- moai_adk/templates/.claude/agents/moai/expert-frontend.md +666 -0
- moai_adk/templates/.claude/agents/moai/expert-security.md +474 -0
- moai_adk/templates/.claude/agents/moai/expert-uiux.md +1038 -0
- moai_adk/templates/.claude/agents/moai/manager-claude-code.md +429 -0
- moai_adk/templates/.claude/agents/moai/manager-docs.md +570 -0
- moai_adk/templates/.claude/agents/moai/manager-git.md +937 -0
- moai_adk/templates/.claude/agents/moai/manager-project.md +891 -0
- moai_adk/templates/.claude/agents/moai/manager-quality.md +598 -0
- moai_adk/templates/.claude/agents/moai/manager-spec.md +713 -0
- moai_adk/templates/.claude/agents/moai/manager-strategy.md +600 -0
- moai_adk/templates/.claude/agents/moai/manager-tdd.md +603 -0
- moai_adk/templates/.claude/agents/moai/mcp-context7.md +369 -0
- moai_adk/templates/.claude/agents/moai/mcp-figma.md +1567 -0
- moai_adk/templates/.claude/agents/moai/mcp-notion.md +749 -0
- moai_adk/templates/.claude/agents/moai/mcp-playwright.md +427 -0
- moai_adk/templates/.claude/agents/moai/mcp-sequential-thinking.md +994 -0
- moai_adk/templates/.claude/commands/moai/0-project.md +1143 -0
- moai_adk/templates/.claude/commands/moai/1-plan.md +1435 -0
- moai_adk/templates/.claude/commands/moai/2-run.md +883 -0
- moai_adk/templates/.claude/commands/moai/3-sync.md +993 -0
- moai_adk/templates/.claude/commands/moai/9-feedback.md +314 -0
- moai_adk/templates/.claude/hooks/__init__.py +8 -0
- moai_adk/templates/.claude/hooks/moai/__init__.py +8 -0
- moai_adk/templates/.claude/hooks/moai/lib/__init__.py +85 -0
- moai_adk/templates/.claude/hooks/moai/lib/checkpoint.py +244 -0
- moai_adk/templates/.claude/hooks/moai/lib/common.py +131 -0
- moai_adk/templates/.claude/hooks/moai/lib/config_manager.py +446 -0
- moai_adk/templates/.claude/hooks/moai/lib/config_validator.py +639 -0
- moai_adk/templates/.claude/hooks/moai/lib/example_config.json +104 -0
- moai_adk/templates/.claude/hooks/moai/lib/git_operations_manager.py +590 -0
- moai_adk/templates/.claude/hooks/moai/lib/language_validator.py +317 -0
- moai_adk/templates/.claude/hooks/moai/lib/models.py +102 -0
- moai_adk/templates/.claude/hooks/moai/lib/path_utils.py +28 -0
- moai_adk/templates/.claude/hooks/moai/lib/project.py +768 -0
- moai_adk/templates/.claude/hooks/moai/lib/test_hooks_improvements.py +443 -0
- moai_adk/templates/.claude/hooks/moai/lib/timeout.py +160 -0
- moai_adk/templates/.claude/hooks/moai/lib/unified_timeout_manager.py +530 -0
- moai_adk/templates/.claude/hooks/moai/session_end__auto_cleanup.py +862 -0
- moai_adk/templates/.claude/hooks/moai/session_start__show_project_info.py +921 -0
- moai_adk/templates/.claude/output-styles/moai/r2d2.md +380 -0
- moai_adk/templates/.claude/output-styles/moai/yoda.md +338 -0
- moai_adk/templates/.claude/settings.json +172 -0
- moai_adk/templates/.claude/skills/moai-docs-generation/SKILL.md +247 -0
- moai_adk/templates/.claude/skills/moai-docs-generation/modules/README.md +44 -0
- moai_adk/templates/.claude/skills/moai-docs-generation/modules/api-documentation.md +130 -0
- moai_adk/templates/.claude/skills/moai-docs-generation/modules/code-documentation.md +152 -0
- moai_adk/templates/.claude/skills/moai-docs-generation/modules/multi-format-output.md +178 -0
- moai_adk/templates/.claude/skills/moai-docs-generation/modules/user-guides.md +147 -0
- moai_adk/templates/.claude/skills/moai-domain-backend/SKILL.md +319 -0
- moai_adk/templates/.claude/skills/moai-domain-database/SKILL.md +320 -0
- moai_adk/templates/.claude/skills/moai-domain-database/modules/README.md +53 -0
- moai_adk/templates/.claude/skills/moai-domain-database/modules/mongodb.md +231 -0
- moai_adk/templates/.claude/skills/moai-domain-database/modules/postgresql.md +169 -0
- moai_adk/templates/.claude/skills/moai-domain-database/modules/redis.md +262 -0
- moai_adk/templates/.claude/skills/moai-domain-frontend/SKILL.md +496 -0
- moai_adk/templates/.claude/skills/moai-domain-uiux/SKILL.md +453 -0
- moai_adk/templates/.claude/skills/moai-domain-uiux/examples.md +560 -0
- moai_adk/templates/.claude/skills/moai-domain-uiux/modules/accessibility-wcag.md +260 -0
- moai_adk/templates/.claude/skills/moai-domain-uiux/modules/component-architecture.md +228 -0
- moai_adk/templates/.claude/skills/moai-domain-uiux/modules/design-system-tokens.md +405 -0
- moai_adk/templates/.claude/skills/moai-domain-uiux/modules/icon-libraries.md +401 -0
- moai_adk/templates/.claude/skills/moai-domain-uiux/modules/theming-system.md +373 -0
- moai_adk/templates/.claude/skills/moai-domain-uiux/reference.md +243 -0
- moai_adk/templates/.claude/skills/moai-formats-data/SKILL.md +491 -0
- moai_adk/templates/.claude/skills/moai-formats-data/modules/README.md +98 -0
- moai_adk/templates/.claude/skills/moai-formats-data/modules/SKILL-MODULARIZATION-TEMPLATE.md +278 -0
- moai_adk/templates/.claude/skills/moai-formats-data/modules/caching-performance.md +459 -0
- moai_adk/templates/.claude/skills/moai-formats-data/modules/data-validation.md +485 -0
- moai_adk/templates/.claude/skills/moai-formats-data/modules/json-optimization.md +374 -0
- moai_adk/templates/.claude/skills/moai-formats-data/modules/toon-encoding.md +308 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/SKILL.md +201 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/best-practices-checklist.md +616 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-custom-slash-commands-official.md +729 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-hooks-official.md +560 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-iam-official.md +635 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-memory-official.md +543 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-settings-official.md +663 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-skills-official.md +113 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-sub-agents-official.md +238 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/complete-configuration-guide.md +175 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/skill-examples.md +1674 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/skill-formatting-guide.md +729 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/sub-agents/sub-agent-examples.md +1513 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/sub-agents/sub-agent-formatting-guide.md +1086 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/sub-agents/sub-agent-integration-patterns.md +1100 -0
- moai_adk/templates/.claude/skills/moai-foundation-context/SKILL.md +438 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/SKILL.md +515 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/README.md +296 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/agents-reference.md +346 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/commands-reference.md +432 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/delegation-patterns.md +757 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/execution-rules.md +687 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/modular-system.md +665 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/progressive-disclosure.md +649 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/spec-first-tdd.md +864 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/token-optimization.md +708 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/trust-5-framework.md +981 -0
- moai_adk/templates/.claude/skills/moai-foundation-quality/SKILL.md +362 -0
- moai_adk/templates/.claude/skills/moai-foundation-quality/examples.md +1232 -0
- moai_adk/templates/.claude/skills/moai-foundation-quality/modules/best-practices.md +261 -0
- moai_adk/templates/.claude/skills/moai-foundation-quality/modules/integration-patterns.md +194 -0
- moai_adk/templates/.claude/skills/moai-foundation-quality/modules/proactive-analysis.md +229 -0
- moai_adk/templates/.claude/skills/moai-foundation-quality/modules/trust5-validation.md +169 -0
- moai_adk/templates/.claude/skills/moai-foundation-quality/reference.md +1266 -0
- moai_adk/templates/.claude/skills/moai-foundation-quality/scripts/quality-gate.sh +668 -0
- moai_adk/templates/.claude/skills/moai-foundation-quality/templates/github-actions-quality.yml +481 -0
- moai_adk/templates/.claude/skills/moai-foundation-quality/templates/quality-config.yaml +519 -0
- moai_adk/templates/.claude/skills/moai-integration-mcp/SKILL.md +352 -0
- moai_adk/templates/.claude/skills/moai-integration-mcp/modules/README.md +52 -0
- moai_adk/templates/.claude/skills/moai-integration-mcp/modules/error-handling.md +334 -0
- moai_adk/templates/.claude/skills/moai-integration-mcp/modules/integration-patterns.md +310 -0
- moai_adk/templates/.claude/skills/moai-integration-mcp/modules/security-authentication.md +256 -0
- moai_adk/templates/.claude/skills/moai-integration-mcp/modules/server-architecture.md +253 -0
- moai_adk/templates/.claude/skills/moai-lang-unified/README.md +133 -0
- moai_adk/templates/.claude/skills/moai-lang-unified/SKILL.md +296 -0
- moai_adk/templates/.claude/skills/moai-lang-unified/examples.md +1269 -0
- moai_adk/templates/.claude/skills/moai-lang-unified/reference.md +331 -0
- moai_adk/templates/.claude/skills/moai-library-mermaid/SKILL.md +298 -0
- moai_adk/templates/.claude/skills/moai-library-mermaid/advanced-patterns.md +465 -0
- moai_adk/templates/.claude/skills/moai-library-mermaid/examples.md +270 -0
- moai_adk/templates/.claude/skills/moai-library-mermaid/optimization.md +440 -0
- moai_adk/templates/.claude/skills/moai-library-mermaid/reference.md +228 -0
- moai_adk/templates/.claude/skills/moai-library-nextra/SKILL.md +316 -0
- moai_adk/templates/.claude/skills/moai-library-nextra/advanced-patterns.md +336 -0
- moai_adk/templates/.claude/skills/moai-library-nextra/modules/advanced-deployment-patterns.md +182 -0
- moai_adk/templates/.claude/skills/moai-library-nextra/modules/advanced-patterns.md +17 -0
- moai_adk/templates/.claude/skills/moai-library-nextra/modules/configuration.md +57 -0
- moai_adk/templates/.claude/skills/moai-library-nextra/modules/content-architecture-optimization.md +162 -0
- moai_adk/templates/.claude/skills/moai-library-nextra/modules/deployment.md +52 -0
- moai_adk/templates/.claude/skills/moai-library-nextra/modules/framework-core-configuration.md +186 -0
- moai_adk/templates/.claude/skills/moai-library-nextra/modules/i18n-setup.md +55 -0
- moai_adk/templates/.claude/skills/moai-library-nextra/modules/mdx-components.md +52 -0
- moai_adk/templates/.claude/skills/moai-library-nextra/optimization.md +303 -0
- moai_adk/templates/.claude/skills/moai-library-shadcn/SKILL.md +370 -0
- moai_adk/templates/.claude/skills/moai-library-shadcn/examples.md +575 -0
- moai_adk/templates/.claude/skills/moai-library-shadcn/modules/advanced-patterns.md +394 -0
- moai_adk/templates/.claude/skills/moai-library-shadcn/modules/optimization.md +278 -0
- moai_adk/templates/.claude/skills/moai-library-shadcn/modules/shadcn-components.md +457 -0
- moai_adk/templates/.claude/skills/moai-library-shadcn/modules/shadcn-theming.md +373 -0
- moai_adk/templates/.claude/skills/moai-library-shadcn/reference.md +74 -0
- moai_adk/templates/.claude/skills/moai-platform-baas/README.md +186 -0
- moai_adk/templates/.claude/skills/moai-platform-baas/SKILL.md +290 -0
- moai_adk/templates/.claude/skills/moai-platform-baas/examples.md +1225 -0
- moai_adk/templates/.claude/skills/moai-platform-baas/reference.md +567 -0
- moai_adk/templates/.claude/skills/moai-platform-baas/scripts/provider-selector.py +323 -0
- moai_adk/templates/.claude/skills/moai-platform-baas/templates/stack-config.yaml +204 -0
- moai_adk/templates/.claude/skills/moai-workflow-jit-docs/SKILL.md +446 -0
- moai_adk/templates/.claude/skills/moai-workflow-jit-docs/advanced-patterns.md +379 -0
- moai_adk/templates/.claude/skills/moai-workflow-jit-docs/optimization.md +286 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/README.md +190 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/SKILL.md +387 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/__init__.py +520 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/complete_workflow_demo_fixed.py +574 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/examples/complete_project_setup.py +317 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/examples/complete_workflow_demo.py +663 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/examples/config-migration-example.json +190 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/examples/question-examples.json +135 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/examples/quick_start.py +196 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/__init__.py +17 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/advanced-patterns.md +158 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/ask_user_integration.py +340 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/batch_questions.py +713 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/config_manager.py +538 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/documentation_manager.py +1336 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/language_initializer.py +730 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/migration_manager.py +608 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/template_optimizer.py +1005 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/schemas/config-schema.json +316 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/schemas/tab_schema.json +1362 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/templates/config-template.json +71 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/templates/doc-templates/product-template.md +44 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/templates/doc-templates/structure-template.md +48 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/templates/doc-templates/tech-template.md +71 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/templates/question-templates/config-manager-setup.json +109 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/templates/question-templates/language-initializer.json +228 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/templates/question-templates/menu-project-config.json +130 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/templates/question-templates/project-batch-questions.json +97 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/templates/question-templates/spec-workflow-setup.json +150 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/test_integration_simple.py +436 -0
- moai_adk/templates/.claude/skills/moai-workflow-templates/SKILL.md +374 -0
- moai_adk/templates/.claude/skills/moai-workflow-templates/modules/code-templates.md +124 -0
- moai_adk/templates/.claude/skills/moai-workflow-templates/modules/feedback-templates.md +100 -0
- moai_adk/templates/.claude/skills/moai-workflow-templates/modules/template-optimizer.md +138 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/LICENSE.txt +202 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/SKILL.md +453 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/advanced-patterns.md +576 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/examples/ai-powered-testing.py +294 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/examples/console_logging.py +35 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/examples/element_discovery.py +40 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/examples/static_html_automation.py +34 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/README.md +220 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/ai-debugging.md +845 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/automated-code-review.md +1416 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/performance-optimization.md +1234 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/smart-refactoring.md +1243 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/tdd-context7.md +1260 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/optimization.md +505 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/reference/playwright-best-practices.md +57 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/scripts/with_server.py +218 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/templates/alfred-integration.md +376 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/workflows/enterprise-testing-workflow.py +571 -0
- moai_adk/templates/.claude/skills/moai-worktree/SKILL.md +410 -0
- moai_adk/templates/.claude/skills/moai-worktree/examples.md +606 -0
- moai_adk/templates/.claude/skills/moai-worktree/modules/integration-patterns.md +982 -0
- moai_adk/templates/.claude/skills/moai-worktree/modules/parallel-development.md +778 -0
- moai_adk/templates/.claude/skills/moai-worktree/modules/worktree-commands.md +646 -0
- moai_adk/templates/.claude/skills/moai-worktree/modules/worktree-management.md +782 -0
- moai_adk/templates/.claude/skills/moai-worktree/reference.md +357 -0
- moai_adk/templates/.git-hooks/pre-commit +103 -41
- moai_adk/templates/.git-hooks/pre-push +116 -21
- moai_adk/templates/.github/workflows/ci-universal.yml +513 -0
- moai_adk/templates/.github/workflows/security-secrets-check.yml +179 -0
- moai_adk/templates/.gitignore +184 -44
- moai_adk/templates/.mcp.json +7 -9
- moai_adk/templates/.moai/cache/personalization.json +10 -0
- moai_adk/templates/.moai/config/config.yaml +344 -0
- moai_adk/templates/.moai/config/presets/manual.yaml +28 -0
- moai_adk/templates/.moai/config/presets/personal.yaml +30 -0
- moai_adk/templates/.moai/config/presets/team.yaml +33 -0
- moai_adk/templates/.moai/config/questions/_schema.yaml +79 -0
- moai_adk/templates/.moai/config/questions/tab1-user.yaml +108 -0
- moai_adk/templates/.moai/config/questions/tab2-project.yaml +122 -0
- moai_adk/templates/.moai/config/questions/tab3-git.yaml +542 -0
- moai_adk/templates/.moai/config/questions/tab4-quality.yaml +167 -0
- moai_adk/templates/.moai/config/questions/tab5-system.yaml +152 -0
- moai_adk/templates/.moai/config/sections/git-strategy.yaml +40 -0
- moai_adk/templates/.moai/config/sections/language.yaml +11 -0
- moai_adk/templates/.moai/config/sections/project.yaml +13 -0
- moai_adk/templates/.moai/config/sections/quality.yaml +15 -0
- moai_adk/templates/.moai/config/sections/system.yaml +14 -0
- moai_adk/templates/.moai/config/sections/user.yaml +5 -0
- moai_adk/templates/.moai/config/statusline-config.yaml +86 -0
- moai_adk/templates/.moai/scripts/setup-glm.py +136 -0
- moai_adk/templates/CLAUDE.md +382 -501
- moai_adk/utils/__init__.py +24 -1
- moai_adk/utils/banner.py +7 -10
- moai_adk/utils/common.py +16 -30
- moai_adk/utils/link_validator.py +4 -12
- moai_adk/utils/safe_file_reader.py +2 -6
- moai_adk/utils/timeout.py +160 -0
- moai_adk/utils/toon_utils.py +256 -0
- moai_adk/version.py +22 -0
- moai_adk-0.32.8.dist-info/METADATA +2478 -0
- moai_adk-0.32.8.dist-info/RECORD +396 -0
- {moai_adk-0.25.4.dist-info → moai_adk-0.32.8.dist-info}/WHEEL +1 -1
- {moai_adk-0.25.4.dist-info → moai_adk-0.32.8.dist-info}/entry_points.txt +1 -0
- moai_adk/cli/commands/backup.py +0 -82
- moai_adk/cli/commands/improve_user_experience.py +0 -348
- moai_adk/cli/commands/migrate.py +0 -158
- moai_adk/cli/commands/validate_links.py +0 -118
- moai_adk/templates/.github/workflows/moai-gitflow.yml +0 -413
- moai_adk/templates/.github/workflows/moai-release-create.yml +0 -100
- moai_adk/templates/.github/workflows/moai-release-pipeline.yml +0 -188
- moai_adk/utils/user_experience.py +0 -531
- moai_adk-0.25.4.dist-info/METADATA +0 -2279
- moai_adk-0.25.4.dist-info/RECORD +0 -112
- {moai_adk-0.25.4.dist-info → moai_adk-0.32.8.dist-info}/licenses/LICENSE +0 -0
|
@@ -0,0 +1,401 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: moai-foundation-uiux
|
|
3
|
+
description: Vector icon libraries ecosystem guide covering 10+ major libraries with 200K+ icons, including React Icons (35K+), Lucide (1000+), Tabler Icons (5900+), Iconify (200K+), Heroicons, Phosphor, and Radix Icons with implementation patterns, decision trees, and best practices.
|
|
4
|
+
version: 1.0.0
|
|
5
|
+
modularized: false
|
|
6
|
+
tags:
|
|
7
|
+
- enterprise
|
|
8
|
+
- development
|
|
9
|
+
- vector
|
|
10
|
+
updated: 2025-11-24
|
|
11
|
+
status: active
|
|
12
|
+
---
|
|
13
|
+
|
|
14
|
+
## Quick Reference (30 seconds)
|
|
15
|
+
|
|
16
|
+
# Icon Libraries
|
|
17
|
+
|
|
18
|
+
Vector Icon Libraries: Enterprise Guide (10+ Libraries, 200K+ Icons)
|
|
19
|
+
|
|
20
|
+
> Primary Agent: frontend-expert
|
|
21
|
+
> Secondary Agent: ui-ux-expert
|
|
22
|
+
> Version: 4.0.0 (Lucide v0.4+, React Icons 35K+, Tabler v2.0+, Phosphor v1.4+)
|
|
23
|
+
> Keywords: icons, vector icons, lucide, react icons, iconify, svg icons, accessibility
|
|
24
|
+
|
|
25
|
+
## Level 1: Quick Reference
|
|
26
|
+
|
|
27
|
+
### Library Selection Guide
|
|
28
|
+
|
|
29
|
+
Ecosystem Leaders (1000+ icons):
|
|
30
|
+
- Lucide (1000+): General UI, modern design, ~30KB
|
|
31
|
+
- React Icons (35K+): Multi-library support, modular bundles
|
|
32
|
+
- Tabler Icons (5900+): Dashboard optimized, ~22KB
|
|
33
|
+
- Ionicons (1300+): Mobile + web compatibility
|
|
34
|
+
|
|
35
|
+
Specialist Libraries (300-800 icons):
|
|
36
|
+
- Heroicons (300+): Official Tailwind CSS icons
|
|
37
|
+
- Phosphor (800+): 6 weights + duotone variations
|
|
38
|
+
- Material Design (900+): Google design system
|
|
39
|
+
- Bootstrap Icons (2000+): Bootstrap ecosystem
|
|
40
|
+
|
|
41
|
+
Compact & Specialized:
|
|
42
|
+
- Radix Icons (150+): Precise 15x15px, ~5KB
|
|
43
|
+
- Simple Icons (3300+): Brand logos only
|
|
44
|
+
- Iconify (200K+): Universal framework, CDN-based
|
|
45
|
+
|
|
46
|
+
### Quick Decision Matrix
|
|
47
|
+
|
|
48
|
+
| Scenario | Best Choice | Why |
|
|
49
|
+
|----------|-------------|-----|
|
|
50
|
+
| Want maximum icons | Iconify | 200K+ icons from 150+ sets |
|
|
51
|
+
| Dashboard application | Tabler Icons | 5900 optimized icons, 24px |
|
|
52
|
+
| Tailwind CSS project | Heroicons | Official integration |
|
|
53
|
+
| Flexible styling needed | Phosphor | 6 weights + duotone |
|
|
54
|
+
| Minimal bundle size | Radix Icons | 5KB, precise 15x15px |
|
|
55
|
+
| Brand logos | Simple Icons | 3300+ company logos |
|
|
56
|
+
| General purpose UI | Lucide | 1000+ modern, well-designed |
|
|
57
|
+
|
|
58
|
+
### Bundle Size Comparison
|
|
59
|
+
|
|
60
|
+
```
|
|
61
|
+
Radix Icons: ~5KB (150 icons)
|
|
62
|
+
Heroicons: ~10KB (300 icons)
|
|
63
|
+
Tabler Icons: ~22KB (5900 icons)
|
|
64
|
+
Ionicons: ~25KB (1300 icons)
|
|
65
|
+
Phosphor: ~25KB (800 icons with weights)
|
|
66
|
+
Lucide: ~30KB (1000 icons)
|
|
67
|
+
Simple Icons: ~50KB (3300+ brand icons)
|
|
68
|
+
React Icons: Modular (varies by library)
|
|
69
|
+
```
|
|
70
|
+
|
|
71
|
+
## Quick Installation Commands
|
|
72
|
+
|
|
73
|
+
```bash
|
|
74
|
+
# Core libraries
|
|
75
|
+
npm install lucide-react
|
|
76
|
+
npm install @heroicons/react
|
|
77
|
+
npm install @phosphor-icons/react
|
|
78
|
+
npm install @tabler/icons-react
|
|
79
|
+
npm install @radix-ui/react-icons
|
|
80
|
+
|
|
81
|
+
# Multi-library support
|
|
82
|
+
npm install react-icons
|
|
83
|
+
npm install @iconify/react
|
|
84
|
+
|
|
85
|
+
# Brand icons
|
|
86
|
+
npm install simple-icons
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
Version: 4.0.0 Enterprise
|
|
90
|
+
Last Updated: 2025-11-13
|
|
91
|
+
Status: Production Ready
|
|
92
|
+
Enterprise Grade: Full Enterprise Support
|
|
93
|
+
|
|
94
|
+
## Implementation Guide
|
|
95
|
+
|
|
96
|
+
## Level 2: Practical Implementation
|
|
97
|
+
|
|
98
|
+
### Core Library Patterns
|
|
99
|
+
|
|
100
|
+
#### Lucide React - General Purpose (1000+ icons)
|
|
101
|
+
|
|
102
|
+
```tsx
|
|
103
|
+
import { Heart, Search, Settings, ChevronRight } from 'lucide-react'
|
|
104
|
+
|
|
105
|
+
export function LucideExample() {
|
|
106
|
+
return (
|
|
107
|
+
<div className="space-y-4">
|
|
108
|
+
{/* Basic usage (24px default) */}
|
|
109
|
+
<div className="flex items-center gap-2">
|
|
110
|
+
<Search />
|
|
111
|
+
<span>Search</span>
|
|
112
|
+
</div>
|
|
113
|
+
|
|
114
|
+
{/* Custom styling */}
|
|
115
|
+
<Heart size={32} color="#ff0000" fill="#ff0000" />
|
|
116
|
+
|
|
117
|
+
{/* Tailwind integration */}
|
|
118
|
+
<Settings className="w-6 h-6 text-gray-500 hover:text-gray-900" />
|
|
119
|
+
|
|
120
|
+
{/* Icon button */}
|
|
121
|
+
<button className="p-2 rounded-lg hover:bg-gray-100">
|
|
122
|
+
<ChevronRight size={20} />
|
|
123
|
+
</button>
|
|
124
|
+
</div>
|
|
125
|
+
)
|
|
126
|
+
}
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
#### React Icons - Multi-Library (35K+ icons)
|
|
130
|
+
|
|
131
|
+
```tsx
|
|
132
|
+
import { FaHome } from "react-icons/fa" // Font Awesome
|
|
133
|
+
import { MdHome } from "react-icons/md" // Material Design
|
|
134
|
+
import { BsHouse } from "react-icons/bs" // Bootstrap
|
|
135
|
+
import { FiHome } from "react-icons/fi" // Feather
|
|
136
|
+
import { SiReact } from "react-icons/si" // Brand logos
|
|
137
|
+
|
|
138
|
+
export function MultiLibraryExample() {
|
|
139
|
+
return (
|
|
140
|
+
<div className="flex gap-4">
|
|
141
|
+
<FaHome size={32} className="text-blue-600" />
|
|
142
|
+
<MdHome size={32} className="text-green-600" />
|
|
143
|
+
<BsHouse size={32} className="text-purple-600" />
|
|
144
|
+
<FiHome size={32} className="text-orange-600" />
|
|
145
|
+
<SiReact size={32} className="text-cyan-500" />
|
|
146
|
+
</div>
|
|
147
|
+
)
|
|
148
|
+
}
|
|
149
|
+
```
|
|
150
|
+
|
|
151
|
+
#### Phosphor Icons - Weight Variations (800+ icons)
|
|
152
|
+
|
|
153
|
+
```tsx
|
|
154
|
+
import { Heart, Star } from "@phosphor-icons/react"
|
|
155
|
+
|
|
156
|
+
export function PhosphorExample() {
|
|
157
|
+
const [rating, setRating] = React.useState(3)
|
|
158
|
+
|
|
159
|
+
return (
|
|
160
|
+
<div className="space-y-4">
|
|
161
|
+
{/* Weight variations */}
|
|
162
|
+
<div className="flex gap-2">
|
|
163
|
+
<Heart weight="thin" />
|
|
164
|
+
<Heart weight="light" />
|
|
165
|
+
<Heart weight="regular" />
|
|
166
|
+
<Heart weight="bold" />
|
|
167
|
+
<Heart weight="fill" />
|
|
168
|
+
</div>
|
|
169
|
+
|
|
170
|
+
{/* Interactive rating */}
|
|
171
|
+
<div className="flex gap-1">
|
|
172
|
+
{[1, 2, 3, 4, 5].map((star) => (
|
|
173
|
+
<button key={star}>
|
|
174
|
+
<Star
|
|
175
|
+
weight={star <= rating ? "fill" : "regular"}
|
|
176
|
+
size={24}
|
|
177
|
+
color={star <= rating ? "#fbbf24" : "#d1d5db"}
|
|
178
|
+
/>
|
|
179
|
+
</button>
|
|
180
|
+
))}
|
|
181
|
+
</div>
|
|
182
|
+
</div>
|
|
183
|
+
)
|
|
184
|
+
}
|
|
185
|
+
```
|
|
186
|
+
|
|
187
|
+
#### Iconify - Universal Framework (200K+ icons)
|
|
188
|
+
|
|
189
|
+
```tsx
|
|
190
|
+
import { Icon } from "@iconify/react"
|
|
191
|
+
|
|
192
|
+
export function IconifyExample() {
|
|
193
|
+
return (
|
|
194
|
+
<div className="space-y-4">
|
|
195
|
+
{/* String-based (CDN loaded) */}
|
|
196
|
+
<Icon icon="fa:home" width="32" height="32" />
|
|
197
|
+
<Icon icon="mdi:account" width="32" height="32" />
|
|
198
|
+
<Icon icon="bi:house" width="32" height="32" />
|
|
199
|
+
|
|
200
|
+
{/* Custom styling */}
|
|
201
|
+
<Icon
|
|
202
|
+
icon="heroicons:heart"
|
|
203
|
+
width="48"
|
|
204
|
+
height="48"
|
|
205
|
+
style={{ color: "#ef4444" }}
|
|
206
|
+
/>
|
|
207
|
+
</div>
|
|
208
|
+
)
|
|
209
|
+
}
|
|
210
|
+
```
|
|
211
|
+
|
|
212
|
+
### Type-Safe Icon Button
|
|
213
|
+
|
|
214
|
+
```tsx
|
|
215
|
+
import { FC, SVGProps } from 'react'
|
|
216
|
+
|
|
217
|
+
type IconType = FC<SVGProps<SVGSVGElement>>
|
|
218
|
+
|
|
219
|
+
interface IconButtonProps {
|
|
220
|
+
icon: IconType
|
|
221
|
+
label: string
|
|
222
|
+
variant?: 'primary' | 'secondary' | 'ghost'
|
|
223
|
+
size?: 'sm' | 'md' | 'lg'
|
|
224
|
+
onClick?: () => void
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
const sizeMap = {
|
|
228
|
+
sm: 'w-4 h-4',
|
|
229
|
+
md: 'w-5 h-5',
|
|
230
|
+
lg: 'w-6 h-6',
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
const variantMap = {
|
|
234
|
+
primary: 'bg-blue-500 text-white hover:bg-blue-600',
|
|
235
|
+
secondary: 'bg-gray-200 text-gray-900 hover:bg-gray-300',
|
|
236
|
+
ghost: 'text-gray-600 hover:text-gray-900 hover:bg-gray-100',
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
export function IconButton({
|
|
240
|
+
icon: Icon,
|
|
241
|
+
label,
|
|
242
|
+
variant = 'ghost',
|
|
243
|
+
size = 'md',
|
|
244
|
+
onClick,
|
|
245
|
+
}: IconButtonProps) {
|
|
246
|
+
return (
|
|
247
|
+
<button
|
|
248
|
+
onClick={onClick}
|
|
249
|
+
aria-label={label}
|
|
250
|
+
title={label}
|
|
251
|
+
className={`
|
|
252
|
+
p-2 rounded-lg transition-all
|
|
253
|
+
${variantMap[variant]}
|
|
254
|
+
`}
|
|
255
|
+
>
|
|
256
|
+
<Icon className={sizeMap[size]} />
|
|
257
|
+
</button>
|
|
258
|
+
)
|
|
259
|
+
}
|
|
260
|
+
```
|
|
261
|
+
|
|
262
|
+
## Performance & Best Practices
|
|
263
|
+
|
|
264
|
+
### Performance Optimization
|
|
265
|
+
|
|
266
|
+
```tsx
|
|
267
|
+
// Good: Tree-shake specific icons
|
|
268
|
+
import { Heart, Star } from 'lucide-react'
|
|
269
|
+
|
|
270
|
+
// Bad: Import entire library
|
|
271
|
+
import * as Icons from 'lucide-react'
|
|
272
|
+
const Icon = Icons[iconName]
|
|
273
|
+
|
|
274
|
+
// Good: Dynamic imports for large sets
|
|
275
|
+
const LazyIcon = React.lazy(() => import('lucide-react').then(module => ({
|
|
276
|
+
default: module[iconName]
|
|
277
|
+
})))
|
|
278
|
+
|
|
279
|
+
// Good: Memoize components
|
|
280
|
+
const MemoHeart = React.memo(Heart)
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
### Bundle Optimization Strategies
|
|
284
|
+
|
|
285
|
+
1. Choose right library size: Use Radix Icons for minimal bundles
|
|
286
|
+
2. Import specific icons: Avoid `import *` patterns
|
|
287
|
+
3. Dynamic loading: Load icons on-demand for large sets
|
|
288
|
+
4. Icon subsets: Create custom bundles per feature
|
|
289
|
+
5. Tree-shaking: Use ES modules and bundler optimization
|
|
290
|
+
|
|
291
|
+
### Accessibility Essentials
|
|
292
|
+
|
|
293
|
+
- Use `aria-label` for icon-only buttons
|
|
294
|
+
- Ensure 4.5:1 color contrast ratio
|
|
295
|
+
- Support high contrast mode with `currentColor`
|
|
296
|
+
- Don't rely on color alone for meaning
|
|
297
|
+
- Use semantic HTML structure
|
|
298
|
+
- Test with screen readers
|
|
299
|
+
|
|
300
|
+
## Library Comparison Summary
|
|
301
|
+
|
|
302
|
+
| Library | Icons | Bundle Size | Best For |
|
|
303
|
+
|---------|-------|-------------|----------|
|
|
304
|
+
| Lucide | 1000+ | ~30KB | General purpose UI |
|
|
305
|
+
| Heroicons | 300+ | ~10KB | Tailwind CSS projects |
|
|
306
|
+
| Phosphor | 800+ | ~25KB | Weight flexibility needed |
|
|
307
|
+
| Tabler | 5900+ | ~22KB | Dashboard applications |
|
|
308
|
+
| Radix | 150+ | ~5KB | Minimal bundle size |
|
|
309
|
+
| React Icons | 35K+ | Modular | Multi-library support |
|
|
310
|
+
| Iconify | 200K+ | CDN | Maximum icon variety |
|
|
311
|
+
|
|
312
|
+
## Advanced Patterns
|
|
313
|
+
|
|
314
|
+
## Level 3: Advanced Integration
|
|
315
|
+
|
|
316
|
+
### Custom Icon Component
|
|
317
|
+
|
|
318
|
+
```tsx
|
|
319
|
+
import { forwardRef, SVGProps } from 'react'
|
|
320
|
+
|
|
321
|
+
interface CustomIconProps extends SVGProps<SVGSVGElement> {
|
|
322
|
+
isActive?: boolean
|
|
323
|
+
tooltip?: string
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
export const CustomIcon = forwardRef<SVGSVGElement, CustomIconProps>(
|
|
327
|
+
({ isActive, tooltip, className = '', ...props }, ref) => (
|
|
328
|
+
<svg
|
|
329
|
+
ref={ref}
|
|
330
|
+
viewBox="0 0 24 24"
|
|
331
|
+
width="24"
|
|
332
|
+
height="24"
|
|
333
|
+
className={`
|
|
334
|
+
${isActive ? 'text-blue-500' : 'text-gray-400'}
|
|
335
|
+
${tooltip ? 'cursor-help' : ''}
|
|
336
|
+
${className}
|
|
337
|
+
transition-colors duration-200
|
|
338
|
+
`}
|
|
339
|
+
title={tooltip}
|
|
340
|
+
{...props}
|
|
341
|
+
>
|
|
342
|
+
<path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2z" />
|
|
343
|
+
</svg>
|
|
344
|
+
)
|
|
345
|
+
)
|
|
346
|
+
```
|
|
347
|
+
|
|
348
|
+
### Icon Theme System
|
|
349
|
+
|
|
350
|
+
```tsx
|
|
351
|
+
import { Heart, Settings } from 'lucide-react'
|
|
352
|
+
|
|
353
|
+
type IconTheme = 'light' | 'dark' | 'accent'
|
|
354
|
+
|
|
355
|
+
interface IconThemeConfig {
|
|
356
|
+
color: string
|
|
357
|
+
strokeWidth: number
|
|
358
|
+
opacity: number
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
const themeConfig: Record<IconTheme, IconThemeConfig> = {
|
|
362
|
+
light: { color: '#e5e7eb', strokeWidth: 2, opacity: 1 },
|
|
363
|
+
dark: { color: '#1f2937', strokeWidth: 2, opacity: 1 },
|
|
364
|
+
accent: { color: '#0ea5e9', strokeWidth: 2.5, opacity: 1 },
|
|
365
|
+
}
|
|
366
|
+
|
|
367
|
+
export function ThemedIcon({ theme, size = 24 }: { theme: IconTheme; size?: number }) {
|
|
368
|
+
const config = themeConfig[theme]
|
|
369
|
+
|
|
370
|
+
return (
|
|
371
|
+
<div className="flex gap-4">
|
|
372
|
+
<Heart size={size} color={config.color} strokeWidth={config.strokeWidth} />
|
|
373
|
+
<Settings size={size} color={config.color} strokeWidth={config.strokeWidth} />
|
|
374
|
+
</div>
|
|
375
|
+
)
|
|
376
|
+
}
|
|
377
|
+
```
|
|
378
|
+
|
|
379
|
+
### Icon Animation
|
|
380
|
+
|
|
381
|
+
```tsx
|
|
382
|
+
import { Heart } from 'lucide-react'
|
|
383
|
+
import { useState } from 'react'
|
|
384
|
+
|
|
385
|
+
export function AnimatedIcon() {
|
|
386
|
+
const [isActive, setIsActive] = useState(false)
|
|
387
|
+
|
|
388
|
+
return (
|
|
389
|
+
<button onClick={() => setIsActive(!isActive)} className="p-4">
|
|
390
|
+
<Heart
|
|
391
|
+
size={32}
|
|
392
|
+
className={`
|
|
393
|
+
text-red-500 transition-all duration-300
|
|
394
|
+
${isActive ? 'scale-125 animate-pulse' : 'scale-100'}
|
|
395
|
+
`}
|
|
396
|
+
fill={isActive ? '#ff0000' : 'none'}
|
|
397
|
+
/>
|
|
398
|
+
</button>
|
|
399
|
+
)
|
|
400
|
+
}
|
|
401
|
+
```
|