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
|
@@ -1,531 +0,0 @@
|
|
|
1
|
-
"""
|
|
2
|
-
User Experience Enhancement Utilities
|
|
3
|
-
|
|
4
|
-
This module provides utilities for analyzing and improving user experience
|
|
5
|
-
across multiple dimensions including performance, navigation, content quality,
|
|
6
|
-
and accessibility.
|
|
7
|
-
"""
|
|
8
|
-
|
|
9
|
-
import asyncio
|
|
10
|
-
import logging
|
|
11
|
-
import time
|
|
12
|
-
from dataclasses import dataclass, field
|
|
13
|
-
from datetime import datetime
|
|
14
|
-
from typing import Any, Dict, List, Tuple
|
|
15
|
-
from urllib.parse import urljoin
|
|
16
|
-
|
|
17
|
-
import aiohttp
|
|
18
|
-
|
|
19
|
-
from moai_adk.utils.common import HTTPClient
|
|
20
|
-
|
|
21
|
-
logger = logging.getLogger(__name__)
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
@dataclass
|
|
25
|
-
class PerformanceMetrics:
|
|
26
|
-
"""Performance metrics for user experience analysis"""
|
|
27
|
-
|
|
28
|
-
load_time: float
|
|
29
|
-
response_time: float
|
|
30
|
-
success_rate: float
|
|
31
|
-
throughput: float
|
|
32
|
-
error_rate: float
|
|
33
|
-
timestamp: datetime = field(default_factory=datetime.now)
|
|
34
|
-
|
|
35
|
-
@property
|
|
36
|
-
def is_good(self) -> bool:
|
|
37
|
-
"""Check if performance meets quality thresholds"""
|
|
38
|
-
return (
|
|
39
|
-
self.load_time <= 2.0
|
|
40
|
-
and self.response_time <= 1.0
|
|
41
|
-
and self.success_rate >= 0.9
|
|
42
|
-
and self.throughput >= 10
|
|
43
|
-
and self.error_rate <= 0.1
|
|
44
|
-
)
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
@dataclass
|
|
48
|
-
class NavigationMetrics:
|
|
49
|
-
"""Navigation structure metrics for UX analysis"""
|
|
50
|
-
|
|
51
|
-
structure_score: float
|
|
52
|
-
link_count: int
|
|
53
|
-
depth: int
|
|
54
|
-
completeness: float
|
|
55
|
-
timestamp: datetime = field(default_factory=datetime.now)
|
|
56
|
-
|
|
57
|
-
@property
|
|
58
|
-
def is_good(self) -> bool:
|
|
59
|
-
"""Check if navigation structure meets quality thresholds"""
|
|
60
|
-
return (
|
|
61
|
-
self.structure_score >= 0.8
|
|
62
|
-
and self.link_count >= 5
|
|
63
|
-
and self.depth <= 3
|
|
64
|
-
and self.completeness >= 0.9
|
|
65
|
-
)
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
@dataclass
|
|
69
|
-
class ContentMetrics:
|
|
70
|
-
"""Content quality metrics for UX analysis"""
|
|
71
|
-
|
|
72
|
-
accuracy_score: float
|
|
73
|
-
completeness_score: float
|
|
74
|
-
organization_score: float
|
|
75
|
-
readability_score: float
|
|
76
|
-
timestamp: datetime = field(default_factory=datetime.now)
|
|
77
|
-
|
|
78
|
-
@property
|
|
79
|
-
def is_good(self) -> bool:
|
|
80
|
-
"""Check if content quality meets quality thresholds"""
|
|
81
|
-
return (
|
|
82
|
-
self.accuracy_score >= 0.9
|
|
83
|
-
and self.completeness_score >= 0.9
|
|
84
|
-
and self.organization_score >= 0.8
|
|
85
|
-
and self.readability_score >= 0.8
|
|
86
|
-
)
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
@dataclass
|
|
90
|
-
class AccessibilityMetrics:
|
|
91
|
-
"""Accessibility metrics for UX analysis"""
|
|
92
|
-
|
|
93
|
-
keyboard_navigation: bool
|
|
94
|
-
screen_reader_support: bool
|
|
95
|
-
color_contrast: bool
|
|
96
|
-
responsive_design: bool
|
|
97
|
-
aria_labels: bool
|
|
98
|
-
timestamp: datetime = field(default_factory=datetime.now)
|
|
99
|
-
|
|
100
|
-
@property
|
|
101
|
-
def is_good(self) -> bool:
|
|
102
|
-
"""Check if accessibility meets quality thresholds"""
|
|
103
|
-
return all(
|
|
104
|
-
[
|
|
105
|
-
self.keyboard_navigation,
|
|
106
|
-
self.screen_reader_support,
|
|
107
|
-
self.color_contrast,
|
|
108
|
-
self.responsive_design,
|
|
109
|
-
self.aria_labels,
|
|
110
|
-
]
|
|
111
|
-
)
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
class UserExperienceAnalyzer(HTTPClient):
|
|
115
|
-
"""
|
|
116
|
-
User experience analyzer for comprehensive UX assessment
|
|
117
|
-
|
|
118
|
-
Analyzes multiple dimensions of user experience including performance,
|
|
119
|
-
navigation, content quality, and accessibility. Provides actionable
|
|
120
|
-
recommendations for improvement.
|
|
121
|
-
"""
|
|
122
|
-
|
|
123
|
-
def __init__(self, base_url: str, max_workers: int = 5):
|
|
124
|
-
super().__init__(max_concurrent=max_workers, timeout=10)
|
|
125
|
-
self.base_url = base_url
|
|
126
|
-
|
|
127
|
-
async def __aenter__(self):
|
|
128
|
-
"""Enter async context manager"""
|
|
129
|
-
connector = aiohttp.TCPConnector(limit=self.max_concurrent)
|
|
130
|
-
timeout = aiohttp.ClientTimeout(total=self.timeout)
|
|
131
|
-
self.session = aiohttp.ClientSession(
|
|
132
|
-
connector=connector,
|
|
133
|
-
timeout=timeout,
|
|
134
|
-
headers={
|
|
135
|
-
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36"
|
|
136
|
-
},
|
|
137
|
-
)
|
|
138
|
-
return self
|
|
139
|
-
|
|
140
|
-
async def __aexit__(self, exc_type, exc_val, exc_tb):
|
|
141
|
-
"""Exit async context manager"""
|
|
142
|
-
if self.session:
|
|
143
|
-
await self.session.close()
|
|
144
|
-
|
|
145
|
-
async def analyze_performance(self) -> PerformanceMetrics:
|
|
146
|
-
"""
|
|
147
|
-
Analyze website performance metrics
|
|
148
|
-
|
|
149
|
-
Tests multiple pages concurrently to measure load times, success rates,
|
|
150
|
-
throughput, and error rates.
|
|
151
|
-
"""
|
|
152
|
-
# Test multiple pages with concurrent loading
|
|
153
|
-
pages = [
|
|
154
|
-
self.base_url,
|
|
155
|
-
urljoin(self.base_url, "/getting-started"),
|
|
156
|
-
urljoin(self.base_url, "/api"),
|
|
157
|
-
urljoin(self.base_url, "/guides"),
|
|
158
|
-
urljoin(self.base_url, "/search"),
|
|
159
|
-
]
|
|
160
|
-
|
|
161
|
-
load_times = []
|
|
162
|
-
success_count = 0
|
|
163
|
-
total_requests = len(pages)
|
|
164
|
-
|
|
165
|
-
async def load_page(url: str) -> Tuple[float, bool]:
|
|
166
|
-
page_start = time.time()
|
|
167
|
-
try:
|
|
168
|
-
response = await self.fetch_url(url)
|
|
169
|
-
load_time = time.time() - page_start
|
|
170
|
-
success = response.success
|
|
171
|
-
return load_time, success
|
|
172
|
-
except Exception:
|
|
173
|
-
load_time = time.time() - page_start
|
|
174
|
-
return load_time, False
|
|
175
|
-
|
|
176
|
-
# Load all pages concurrently
|
|
177
|
-
tasks = [load_page(url) for url in pages]
|
|
178
|
-
results = await asyncio.gather(*tasks)
|
|
179
|
-
|
|
180
|
-
# Analyze results
|
|
181
|
-
total_load_time = 0.0
|
|
182
|
-
success_count = 0
|
|
183
|
-
|
|
184
|
-
for load_time, success in results:
|
|
185
|
-
load_times.append(load_time)
|
|
186
|
-
total_load_time += load_time
|
|
187
|
-
if success:
|
|
188
|
-
success_count += 1
|
|
189
|
-
|
|
190
|
-
avg_load_time = total_load_time / total_requests if total_requests > 0 else 0
|
|
191
|
-
success_rate = success_count / total_requests if total_requests > 0 else 0
|
|
192
|
-
|
|
193
|
-
# Mock measurements (actual implementation would use real metrics)
|
|
194
|
-
response_time = 0.5 # Mock response time
|
|
195
|
-
throughput = 15.0 # Mock throughput
|
|
196
|
-
error_rate = 1.0 - success_rate
|
|
197
|
-
|
|
198
|
-
return PerformanceMetrics(
|
|
199
|
-
load_time=avg_load_time,
|
|
200
|
-
response_time=response_time,
|
|
201
|
-
success_rate=success_rate,
|
|
202
|
-
throughput=throughput,
|
|
203
|
-
error_rate=error_rate,
|
|
204
|
-
)
|
|
205
|
-
|
|
206
|
-
async def analyze_navigation(self) -> NavigationMetrics:
|
|
207
|
-
"""
|
|
208
|
-
Analyze navigation structure
|
|
209
|
-
|
|
210
|
-
Evaluates navigation hierarchy, link distribution, and completeness
|
|
211
|
-
to assess ease of navigation.
|
|
212
|
-
"""
|
|
213
|
-
# Mock navigation data (actual implementation would perform real crawling)
|
|
214
|
-
navigation_data: Dict[str, Any] = {
|
|
215
|
-
"main_links": ["Getting Started", "API Documentation", "Guides", "Search"],
|
|
216
|
-
"sub_links": {
|
|
217
|
-
"Getting Started": ["Installation", "Configuration", "First Steps"],
|
|
218
|
-
"API Documentation": ["Core API", "Authentication", "Webhooks"],
|
|
219
|
-
"Guides": ["Best Practices", "Examples", "Troubleshooting"],
|
|
220
|
-
"Search": ["Advanced Search", "Filters", "Results"],
|
|
221
|
-
},
|
|
222
|
-
"depth": 2,
|
|
223
|
-
"total_links": 15,
|
|
224
|
-
}
|
|
225
|
-
|
|
226
|
-
# Calculate structure score
|
|
227
|
-
structure_score = self._calculate_structure_score(navigation_data)
|
|
228
|
-
|
|
229
|
-
return NavigationMetrics(
|
|
230
|
-
structure_score=structure_score,
|
|
231
|
-
link_count=int(navigation_data["total_links"]),
|
|
232
|
-
depth=int(navigation_data["depth"]),
|
|
233
|
-
completeness=0.95,
|
|
234
|
-
)
|
|
235
|
-
|
|
236
|
-
def _calculate_structure_score(self, navigation_data: Dict) -> float:
|
|
237
|
-
"""
|
|
238
|
-
Calculate navigation structure score
|
|
239
|
-
|
|
240
|
-
Considers link balance and hierarchical structure to determine
|
|
241
|
-
overall navigation quality.
|
|
242
|
-
"""
|
|
243
|
-
main_links = len(navigation_data["main_links"])
|
|
244
|
-
sub_links_count = sum(
|
|
245
|
-
len(links) for links in navigation_data["sub_links"].values()
|
|
246
|
-
)
|
|
247
|
-
|
|
248
|
-
# Calculate structure score (considering link balance and hierarchy)
|
|
249
|
-
balance_score = min(1.0, main_links / 4.0) # Main link balance
|
|
250
|
-
hierarchy_score = max(
|
|
251
|
-
0.5, 1.0 - navigation_data["depth"] / 5.0
|
|
252
|
-
) # Hierarchy depth
|
|
253
|
-
coverage_score = min(1.0, sub_links_count / 20.0) # Sub-link coverage
|
|
254
|
-
|
|
255
|
-
return (balance_score + hierarchy_score + coverage_score) / 3.0
|
|
256
|
-
|
|
257
|
-
async def analyze_content(self) -> ContentMetrics:
|
|
258
|
-
"""
|
|
259
|
-
Analyze content quality
|
|
260
|
-
|
|
261
|
-
Evaluates content accuracy, completeness, organization, and readability
|
|
262
|
-
to assess overall content quality.
|
|
263
|
-
"""
|
|
264
|
-
# Mock content data (actual implementation would perform real content analysis)
|
|
265
|
-
content_data = {
|
|
266
|
-
"word_count": 5000,
|
|
267
|
-
"code_examples": 25,
|
|
268
|
-
"images": 15,
|
|
269
|
-
"links": 30,
|
|
270
|
-
"readability_score": 8.5,
|
|
271
|
-
"completeness_score": 0.95,
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
# Calculate accuracy score
|
|
275
|
-
accuracy_score = self._calculate_accuracy_score(content_data)
|
|
276
|
-
organization_score = self._calculate_organization_score(content_data)
|
|
277
|
-
readability_score = content_data["readability_score"] / 10.0
|
|
278
|
-
|
|
279
|
-
return ContentMetrics(
|
|
280
|
-
accuracy_score=accuracy_score,
|
|
281
|
-
completeness_score=content_data["completeness_score"],
|
|
282
|
-
organization_score=organization_score,
|
|
283
|
-
readability_score=readability_score,
|
|
284
|
-
)
|
|
285
|
-
|
|
286
|
-
def _calculate_accuracy_score(self, content_data: Dict) -> float:
|
|
287
|
-
"""
|
|
288
|
-
Calculate content accuracy score
|
|
289
|
-
|
|
290
|
-
Evaluates the presence and quality of code examples, images, and links
|
|
291
|
-
to determine content accuracy.
|
|
292
|
-
"""
|
|
293
|
-
code_examples_ratio = min(1.0, content_data["code_examples"] / 20.0)
|
|
294
|
-
images_ratio = min(1.0, content_data["images"] / 10.0)
|
|
295
|
-
links_ratio = min(1.0, content_data["links"] / 25.0)
|
|
296
|
-
|
|
297
|
-
return (code_examples_ratio + images_ratio + links_ratio) / 3.0
|
|
298
|
-
|
|
299
|
-
def _calculate_organization_score(self, content_data: Dict) -> float:
|
|
300
|
-
"""
|
|
301
|
-
Calculate content organization score
|
|
302
|
-
|
|
303
|
-
Evaluates content structure and word count to determine organization quality.
|
|
304
|
-
"""
|
|
305
|
-
word_count_ratio = min(1.0, content_data["word_count"] / 5000.0)
|
|
306
|
-
structure_score = min(1.0, content_data["code_examples"] / 15.0)
|
|
307
|
-
|
|
308
|
-
return (word_count_ratio + structure_score) / 2.0
|
|
309
|
-
|
|
310
|
-
async def analyze_accessibility(self) -> AccessibilityMetrics:
|
|
311
|
-
"""
|
|
312
|
-
Analyze accessibility compliance
|
|
313
|
-
|
|
314
|
-
Evaluates keyboard navigation, screen reader support, color contrast,
|
|
315
|
-
responsive design, and ARIA labels to assess accessibility.
|
|
316
|
-
"""
|
|
317
|
-
# Mock accessibility data (actual implementation would perform real accessibility checks)
|
|
318
|
-
accessibility_data = {
|
|
319
|
-
"keyboard_navigation": True,
|
|
320
|
-
"screen_reader_support": True,
|
|
321
|
-
"color_contrast": True,
|
|
322
|
-
"responsive_design": True,
|
|
323
|
-
"aria_labels": True,
|
|
324
|
-
}
|
|
325
|
-
|
|
326
|
-
return AccessibilityMetrics(
|
|
327
|
-
keyboard_navigation=accessibility_data["keyboard_navigation"],
|
|
328
|
-
screen_reader_support=accessibility_data["screen_reader_support"],
|
|
329
|
-
color_contrast=accessibility_data["color_contrast"],
|
|
330
|
-
responsive_design=accessibility_data["responsive_design"],
|
|
331
|
-
aria_labels=accessibility_data["aria_labels"],
|
|
332
|
-
)
|
|
333
|
-
|
|
334
|
-
async def generate_report(self) -> Dict[str, Any]:
|
|
335
|
-
"""
|
|
336
|
-
Generate comprehensive user experience report
|
|
337
|
-
|
|
338
|
-
Analyzes all UX dimensions concurrently and provides an overall score
|
|
339
|
-
with actionable recommendations for improvement.
|
|
340
|
-
"""
|
|
341
|
-
async with self:
|
|
342
|
-
# Analyze all metrics concurrently
|
|
343
|
-
performance_task = self.analyze_performance()
|
|
344
|
-
navigation_task = self.analyze_navigation()
|
|
345
|
-
content_task = self.analyze_content()
|
|
346
|
-
accessibility_task = self.analyze_accessibility()
|
|
347
|
-
|
|
348
|
-
# Execute all analyses in parallel
|
|
349
|
-
performance, navigation, content, accessibility = await asyncio.gather(
|
|
350
|
-
performance_task, navigation_task, content_task, accessibility_task
|
|
351
|
-
)
|
|
352
|
-
|
|
353
|
-
# Calculate overall score
|
|
354
|
-
overall_score = (
|
|
355
|
-
performance.success_rate * 0.3
|
|
356
|
-
+ navigation.structure_score * 0.2
|
|
357
|
-
+ content.accuracy_score * 0.3
|
|
358
|
-
+ (1 if accessibility.is_good else 0) * 0.2
|
|
359
|
-
)
|
|
360
|
-
|
|
361
|
-
# Generate improvement recommendations
|
|
362
|
-
recommendations = self._generate_recommendations(
|
|
363
|
-
performance, navigation, content, accessibility
|
|
364
|
-
)
|
|
365
|
-
|
|
366
|
-
return {
|
|
367
|
-
"overall_score": overall_score,
|
|
368
|
-
"performance": performance,
|
|
369
|
-
"navigation": navigation,
|
|
370
|
-
"content": content,
|
|
371
|
-
"accessibility": accessibility,
|
|
372
|
-
"recommendations": recommendations,
|
|
373
|
-
"generated_at": datetime.now().isoformat(),
|
|
374
|
-
}
|
|
375
|
-
|
|
376
|
-
def _generate_recommendations(
|
|
377
|
-
self,
|
|
378
|
-
performance: PerformanceMetrics,
|
|
379
|
-
navigation: NavigationMetrics,
|
|
380
|
-
content: ContentMetrics,
|
|
381
|
-
accessibility: AccessibilityMetrics,
|
|
382
|
-
) -> List[str]:
|
|
383
|
-
"""
|
|
384
|
-
Generate improvement recommendations
|
|
385
|
-
|
|
386
|
-
Analyzes all metrics to provide specific, actionable recommendations
|
|
387
|
-
for improving user experience.
|
|
388
|
-
"""
|
|
389
|
-
recommendations = []
|
|
390
|
-
|
|
391
|
-
# Performance improvement recommendations
|
|
392
|
-
if not performance.is_good:
|
|
393
|
-
if performance.load_time > 2.0:
|
|
394
|
-
recommendations.append(
|
|
395
|
-
"Improve page load time: Optimize images, use CDN, consider code splitting"
|
|
396
|
-
)
|
|
397
|
-
if performance.error_rate > 0.1:
|
|
398
|
-
recommendations.append(
|
|
399
|
-
"Improve error handling: Enhance 404 pages, improve error messages"
|
|
400
|
-
)
|
|
401
|
-
|
|
402
|
-
# Navigation improvement recommendations
|
|
403
|
-
if not navigation.is_good:
|
|
404
|
-
if navigation.structure_score < 0.8:
|
|
405
|
-
recommendations.append(
|
|
406
|
-
"Redesign navigation structure: Simplify hierarchy, reorganize categories"
|
|
407
|
-
)
|
|
408
|
-
if navigation.completeness < 0.9:
|
|
409
|
-
recommendations.append(
|
|
410
|
-
"Improve link completeness: Connect missing pages, add breadcrumb links"
|
|
411
|
-
)
|
|
412
|
-
|
|
413
|
-
# Content improvement recommendations
|
|
414
|
-
if not content.is_good:
|
|
415
|
-
if content.accuracy_score < 0.9:
|
|
416
|
-
recommendations.append(
|
|
417
|
-
"Improve content accuracy: Update information, validate code examples"
|
|
418
|
-
)
|
|
419
|
-
if content.organization_score < 0.8:
|
|
420
|
-
recommendations.append(
|
|
421
|
-
"Improve content structure: Add section divisions, table of contents, related links"
|
|
422
|
-
)
|
|
423
|
-
|
|
424
|
-
# Accessibility improvement recommendations
|
|
425
|
-
if not accessibility.is_good:
|
|
426
|
-
if not accessibility.keyboard_navigation:
|
|
427
|
-
recommendations.append(
|
|
428
|
-
"Improve keyboard navigation: Optimize tab order, add keyboard shortcuts"
|
|
429
|
-
)
|
|
430
|
-
if not accessibility.screen_reader_support:
|
|
431
|
-
recommendations.append(
|
|
432
|
-
"Improve screen reader support: Add ARIA labels, use semantic HTML"
|
|
433
|
-
)
|
|
434
|
-
|
|
435
|
-
return recommendations
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
def generate_improvement_plan(analysis_report: Dict[str, Any]) -> Dict[str, Any]:
|
|
439
|
-
"""
|
|
440
|
-
Generate improvement plan from analysis report
|
|
441
|
-
|
|
442
|
-
Creates a prioritized action plan based on UX analysis results, categorizing
|
|
443
|
-
improvements by priority and timeline.
|
|
444
|
-
"""
|
|
445
|
-
overall_score = analysis_report["overall_score"]
|
|
446
|
-
|
|
447
|
-
# Set priorities
|
|
448
|
-
priorities: Dict[str, List[str]] = {"high": [], "medium": [], "low": []}
|
|
449
|
-
|
|
450
|
-
# Performance priorities
|
|
451
|
-
performance = analysis_report["performance"]
|
|
452
|
-
if not performance.is_good:
|
|
453
|
-
if performance.error_rate > 0.2:
|
|
454
|
-
priorities["high"].append("Improve error handling system")
|
|
455
|
-
elif performance.load_time > 3.0:
|
|
456
|
-
priorities["high"].append("Improve load time")
|
|
457
|
-
else:
|
|
458
|
-
priorities["medium"].append("Optimize performance")
|
|
459
|
-
|
|
460
|
-
# Content priorities
|
|
461
|
-
content = analysis_report["content"]
|
|
462
|
-
if not content.is_good:
|
|
463
|
-
if content.accuracy_score < 0.8:
|
|
464
|
-
priorities["high"].append("Validate content accuracy")
|
|
465
|
-
elif content.completeness_score < 0.8:
|
|
466
|
-
priorities["medium"].append("Improve content completeness")
|
|
467
|
-
else:
|
|
468
|
-
priorities["low"].append("Fine-tune content")
|
|
469
|
-
|
|
470
|
-
# Accessibility priorities
|
|
471
|
-
accessibility = analysis_report["accessibility"]
|
|
472
|
-
if not accessibility.is_good:
|
|
473
|
-
if not accessibility.keyboard_navigation:
|
|
474
|
-
priorities["high"].append("Improve keyboard accessibility")
|
|
475
|
-
elif not accessibility.screen_reader_support:
|
|
476
|
-
priorities["high"].append("Improve screen reader support")
|
|
477
|
-
else:
|
|
478
|
-
priorities["medium"].append("Ensure accessibility standards compliance")
|
|
479
|
-
|
|
480
|
-
# Generate execution plan
|
|
481
|
-
timeline = {
|
|
482
|
-
"immediate": priorities["high"],
|
|
483
|
-
"short_term": priorities["medium"],
|
|
484
|
-
"long_term": priorities["low"],
|
|
485
|
-
}
|
|
486
|
-
|
|
487
|
-
return {
|
|
488
|
-
"overall_score": overall_score,
|
|
489
|
-
"priorities": priorities,
|
|
490
|
-
"timeline": timeline,
|
|
491
|
-
"estimated_duration": (
|
|
492
|
-
f"{len(priorities['high']) + len(priorities['medium']) * 2 + len(priorities['low']) * 3} weeks"
|
|
493
|
-
),
|
|
494
|
-
"success_criteria": {
|
|
495
|
-
"performance_score": 0.9,
|
|
496
|
-
"content_score": 0.9,
|
|
497
|
-
"accessibility_score": 1.0,
|
|
498
|
-
"overall_score": 0.85,
|
|
499
|
-
},
|
|
500
|
-
}
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
if __name__ == "__main__":
|
|
504
|
-
# User experience analysis execution example
|
|
505
|
-
analyzer = UserExperienceAnalyzer("https://adk.mo.ai.kr")
|
|
506
|
-
|
|
507
|
-
async def main():
|
|
508
|
-
analysis_report = await analyzer.generate_report()
|
|
509
|
-
|
|
510
|
-
print("=== User Experience Analysis Report ===")
|
|
511
|
-
print(f"Overall Score: {analysis_report['overall_score']:.2f}")
|
|
512
|
-
print(f"Performance Score: {analysis_report['performance'].success_rate:.2f}")
|
|
513
|
-
print(f"Navigation Score: {analysis_report['navigation'].structure_score:.2f}")
|
|
514
|
-
print(f"Content Score: {analysis_report['content'].accuracy_score:.2f}")
|
|
515
|
-
print(
|
|
516
|
-
f"Accessibility Score: {1.0 if analysis_report['accessibility'].is_good else 0.0:.2f}"
|
|
517
|
-
)
|
|
518
|
-
|
|
519
|
-
print("\nImprovement Recommendations:")
|
|
520
|
-
for recommendation in analysis_report["recommendations"]:
|
|
521
|
-
print(f"- {recommendation}")
|
|
522
|
-
|
|
523
|
-
# Generate improvement plan
|
|
524
|
-
improvement_plan = generate_improvement_plan(analysis_report)
|
|
525
|
-
print("\nImprovement Plan:")
|
|
526
|
-
print(f"Estimated Duration: {improvement_plan['estimated_duration']}")
|
|
527
|
-
print(f"Immediate Actions: {improvement_plan['timeline']['immediate']}")
|
|
528
|
-
print(f"Short-term Actions: {improvement_plan['timeline']['short_term']}")
|
|
529
|
-
print(f"Long-term Actions: {improvement_plan['timeline']['long_term']}")
|
|
530
|
-
|
|
531
|
-
asyncio.run(main())
|