appiq-solution 1.4.8 → 1.4.9
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 +172 -48
- package/bmad-core/agent-teams/team-fullstack.yaml +1 -11
- package/bmad-core/agents/analyst.md +3 -7
- package/bmad-core/agents/architect.md +0 -6
- package/bmad-core/agents/dev.md +5 -24
- package/bmad-core/agents/pm.md +3 -7
- package/bmad-core/agents/qa.md +0 -17
- package/bmad-core/agents/sm.md +3 -8
- package/bmad-core/agents/ux-expert.md +3 -8
- package/bmad-core/data/technical-preferences.md +1 -147
- package/bmad-core/templates/fullstack-architecture-tmpl.yaml +5 -12
- package/bmad-core/workflows/brownfield-fullstack.yaml +1 -15
- package/bmad-core/workflows/greenfield-fullstack.yaml +5 -49
- package/bmad-core/working-in-the-brownfield.md +10 -19
- package/dist/agents/bmad-orchestrator.txt +0 -111
- package/dist/agents/pm.txt +2 -0
- package/dist/expansion-packs/bmad-2d-phaser-game-dev/teams/phaser-2d-nodejs-game-team.txt +0 -111
- package/dist/expansion-packs/bmad-2d-unity-game-dev/teams/unity-2d-game-team.txt +0 -111
- package/dist/teams/team-all.txt +2 -111
- package/dist/teams/team-fullstack.txt +2 -111
- package/dist/teams/team-ide-minimal.txt +0 -111
- package/dist/teams/team-no-ui.txt +2 -111
- package/package.json +60 -18
- package/tools/cli.js +3 -3
- package/tools/installer/package-lock.json +2 -2
- package/#NEW APP PROMPT/ARCHITECTURE.md +0 -279
- package/#NEW APP PROMPT/ARCHITECTURE_UNIFIED.md +0 -414
- package/#NEW APP PROMPT/accesibility_prompt.md +0 -103
- package/#NEW APP PROMPT/clean-code.mdc +0 -55
- package/#NEW APP PROMPT/codequality.mdc +0 -47
- package/#NEW APP PROMPT/flutter-ai-rules/LICENSE +0 -21
- package/#NEW APP PROMPT/flutter-ai-rules/README.md +0 -104
- package/#NEW APP PROMPT/flutter-ai-rules/combined/README.md +0 -25
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_dart.md +0 -192
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_dart__under_6K.md +0 -99
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_dart_bloc_mocktail.md +0 -308
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_dart_bloc_mocktail__under_6K.md +0 -87
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_dart_change_notifier.md +0 -254
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_dart_change_notifier__under_6K.md +0 -98
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_dart_provider.md +0 -261
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_dart_provider__under_6K.md +0 -105
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_dart_riverpod_mockito.md +0 -371
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_dart_riverpod_mockito__under_6K.md +0 -92
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_with_bloc.md +0 -287
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_with_bloc__under_6K.md +0 -68
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_with_riverpod.md +0 -375
- package/#NEW APP PROMPT/flutter-ai-rules/combined/flutter_with_riverpod__under_6K.md +0 -106
- package/#NEW APP PROMPT/flutter-ai-rules/media/flutter_ai_rules.png +0 -0
- package/#NEW APP PROMPT/flutter-ai-rules/media/mocktail_md_01.png +0 -0
- package/#NEW APP PROMPT/flutter-ai-rules/media/mocktail_md_02.png +0 -0
- package/#NEW APP PROMPT/flutter-ai-rules/rules/bloc.md +0 -94
- package/#NEW APP PROMPT/flutter-ai-rules/rules/dart_3_updates.md +0 -93
- package/#NEW APP PROMPT/flutter-ai-rules/rules/effective_dart.md +0 -105
- package/#NEW APP PROMPT/flutter-ai-rules/rules/flutter_app_architecture.md +0 -57
- package/#NEW APP PROMPT/flutter-ai-rules/rules/flutter_change_notifier.md +0 -62
- package/#NEW APP PROMPT/flutter-ai-rules/rules/flutter_errors.md +0 -11
- package/#NEW APP PROMPT/flutter-ai-rules/rules/mockito.md +0 -31
- package/#NEW APP PROMPT/flutter-ai-rules/rules/mocktail.md +0 -24
- package/#NEW APP PROMPT/flutter-ai-rules/rules/provider.md +0 -69
- package/#NEW APP PROMPT/flutter-ai-rules/rules/riverpod.md +0 -188
- package/#NEW APP PROMPT/generate ssh.md +0 -4
- package/#NEW APP PROMPT/project_ai_prompt.md +0 -544
- package/#Tools/APPIQ-METHOD/.bmad-config.json +0 -13
- package/#Tools/APPIQ-METHOD/.cursor/commands/analyze.md +0 -27
- package/#Tools/APPIQ-METHOD/.cursor/commands/appiq.md +0 -27
- package/#Tools/APPIQ-METHOD/.cursor/commands/help.md +0 -27
- package/#Tools/APPIQ-METHOD/.cursor/commands/story.md +0 -27
- package/#Tools/APPIQ-METHOD/DEVELOPMENT_GUIDE.md +0 -855
- package/#Tools/APPIQ-METHOD/NPM-README.md +0 -138
- package/#Tools/APPIQ-METHOD/README.md +0 -107
- package/#Tools/APPIQ-METHOD/SMART_WORKFLOW_GUIDE.md +0 -401
- package/#Tools/APPIQ-METHOD/activate-appiq.js +0 -81
- package/#Tools/APPIQ-METHOD/appiq-solution/README.md +0 -226
- package/#Tools/APPIQ-METHOD/bmad-core/agent-teams/team-all.yaml +0 -14
- package/#Tools/APPIQ-METHOD/bmad-core/agent-teams/team-flutter-mobile.yaml +0 -114
- package/#Tools/APPIQ-METHOD/bmad-core/agent-teams/team-fullstack.yaml +0 -28
- package/#Tools/APPIQ-METHOD/bmad-core/agent-teams/team-ide-minimal.yaml +0 -10
- package/#Tools/APPIQ-METHOD/bmad-core/agent-teams/team-no-ui.yaml +0 -13
- package/#Tools/APPIQ-METHOD/bmad-core/agents/analyst.md +0 -85
- package/#Tools/APPIQ-METHOD/bmad-core/agents/architect.md +0 -90
- package/#Tools/APPIQ-METHOD/bmad-core/agents/bmad-master.md +0 -108
- package/#Tools/APPIQ-METHOD/bmad-core/agents/bmad-orchestrator.md +0 -150
- package/#Tools/APPIQ-METHOD/bmad-core/agents/bmad-smart-launcher.md +0 -170
- package/#Tools/APPIQ-METHOD/bmad-core/agents/dev.md +0 -95
- package/#Tools/APPIQ-METHOD/bmad-core/agents/init-flow-po.md +0 -143
- package/#Tools/APPIQ-METHOD/bmad-core/agents/pm.md +0 -85
- package/#Tools/APPIQ-METHOD/bmad-core/agents/po.md +0 -76
- package/#Tools/APPIQ-METHOD/bmad-core/agents/qa.md +0 -86
- package/#Tools/APPIQ-METHOD/bmad-core/agents/sm.md +0 -67
- package/#Tools/APPIQ-METHOD/bmad-core/agents/ux-expert.md +0 -71
- package/#Tools/APPIQ-METHOD/bmad-core/bmad-core/user-guide.md +0 -0
- package/#Tools/APPIQ-METHOD/bmad-core/checklists/architect-checklist.md +0 -443
- package/#Tools/APPIQ-METHOD/bmad-core/checklists/change-checklist.md +0 -182
- package/#Tools/APPIQ-METHOD/bmad-core/checklists/pm-checklist.md +0 -375
- package/#Tools/APPIQ-METHOD/bmad-core/checklists/po-master-checklist.md +0 -441
- package/#Tools/APPIQ-METHOD/bmad-core/checklists/security-validation-checklist.md +0 -332
- package/#Tools/APPIQ-METHOD/bmad-core/checklists/story-dod-checklist.md +0 -101
- package/#Tools/APPIQ-METHOD/bmad-core/checklists/story-draft-checklist.md +0 -156
- package/#Tools/APPIQ-METHOD/bmad-core/core-config.yaml +0 -20
- package/#Tools/APPIQ-METHOD/bmad-core/core-config.yaml.bak +0 -20
- package/#Tools/APPIQ-METHOD/bmad-core/data/backend-services-integration.md +0 -686
- package/#Tools/APPIQ-METHOD/bmad-core/data/bmad-kb.md +0 -803
- package/#Tools/APPIQ-METHOD/bmad-core/data/brainstorming-techniques.md +0 -36
- package/#Tools/APPIQ-METHOD/bmad-core/data/elicitation-methods.md +0 -134
- package/#Tools/APPIQ-METHOD/bmad-core/data/shadcn-ui-integration.md +0 -388
- package/#Tools/APPIQ-METHOD/bmad-core/data/technical-preferences.md +0 -149
- package/#Tools/APPIQ-METHOD/bmad-core/enhanced-ide-development-workflow.md +0 -43
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/advanced-elicitation.md +0 -117
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/brownfield-create-epic.md +0 -160
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/brownfield-create-story.md +0 -147
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/correct-course.md +0 -70
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/create-brownfield-story.md +0 -304
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/create-deep-research-prompt.md +0 -289
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/create-flutter-story.md +0 -197
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/create-next-story.md +0 -112
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/document-project.md +0 -341
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/facilitate-brainstorming-session.md +0 -136
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/generate-ai-frontend-prompt.md +0 -51
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/index-docs.md +0 -179
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/intelligent-epic-creation.md +0 -234
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/kb-mode-interaction.md +0 -75
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/review-story.md +0 -145
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/shard-doc.md +0 -187
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/smart-project-analysis.md +0 -289
- package/#Tools/APPIQ-METHOD/bmad-core/tasks/validate-next-story.md +0 -134
- package/#Tools/APPIQ-METHOD/bmad-core/templates/architecture-tmpl.yaml +0 -650
- package/#Tools/APPIQ-METHOD/bmad-core/templates/brainstorming-output-tmpl.yaml +0 -156
- package/#Tools/APPIQ-METHOD/bmad-core/templates/brownfield-architecture-tmpl.yaml +0 -476
- package/#Tools/APPIQ-METHOD/bmad-core/templates/brownfield-prd-tmpl.yaml +0 -280
- package/#Tools/APPIQ-METHOD/bmad-core/templates/competitor-analysis-tmpl.yaml +0 -293
- package/#Tools/APPIQ-METHOD/bmad-core/templates/flutter-mobile-prd-tmpl.yaml +0 -330
- package/#Tools/APPIQ-METHOD/bmad-core/templates/flutter-story-tmpl.yaml +0 -376
- package/#Tools/APPIQ-METHOD/bmad-core/templates/flutter-ui-spec-tmpl.yaml +0 -415
- package/#Tools/APPIQ-METHOD/bmad-core/templates/front-end-architecture-tmpl.yaml +0 -206
- package/#Tools/APPIQ-METHOD/bmad-core/templates/front-end-spec-tmpl.yaml +0 -349
- package/#Tools/APPIQ-METHOD/bmad-core/templates/fullstack-architecture-tmpl.yaml +0 -812
- package/#Tools/APPIQ-METHOD/bmad-core/templates/market-research-tmpl.yaml +0 -252
- package/#Tools/APPIQ-METHOD/bmad-core/templates/prd-tmpl.yaml +0 -202
- package/#Tools/APPIQ-METHOD/bmad-core/templates/project-brief-tmpl.yaml +0 -221
- package/#Tools/APPIQ-METHOD/bmad-core/templates/story-tmpl.yaml +0 -137
- package/#Tools/APPIQ-METHOD/bmad-core/user-guide.md +0 -251
- package/#Tools/APPIQ-METHOD/bmad-core/workflows/brownfield-fullstack.yaml +0 -311
- package/#Tools/APPIQ-METHOD/bmad-core/workflows/brownfield-service.yaml +0 -187
- package/#Tools/APPIQ-METHOD/bmad-core/workflows/brownfield-ui.yaml +0 -197
- package/#Tools/APPIQ-METHOD/bmad-core/workflows/greenfield-fullstack.yaml +0 -284
- package/#Tools/APPIQ-METHOD/bmad-core/workflows/greenfield-service.yaml +0 -206
- package/#Tools/APPIQ-METHOD/bmad-core/workflows/greenfield-ui.yaml +0 -235
- package/#Tools/APPIQ-METHOD/bmad-core/working-in-the-brownfield.md +0 -373
- package/#Tools/APPIQ-METHOD/commands/README.md +0 -28
- package/#Tools/APPIQ-METHOD/commands/analyze.md +0 -27
- package/#Tools/APPIQ-METHOD/commands/appiq.md +0 -27
- package/#Tools/APPIQ-METHOD/commands/help.md +0 -27
- package/#Tools/APPIQ-METHOD/commands/story.md +0 -27
- package/#Tools/APPIQ-METHOD/dist/agents/analyst.txt +0 -2882
- package/#Tools/APPIQ-METHOD/dist/agents/architect.txt +0 -3543
- package/#Tools/APPIQ-METHOD/dist/agents/bmad-master.txt +0 -8756
- package/#Tools/APPIQ-METHOD/dist/agents/bmad-orchestrator.txt +0 -1490
- package/#Tools/APPIQ-METHOD/dist/agents/dev.txt +0 -428
- package/#Tools/APPIQ-METHOD/dist/agents/pm.txt +0 -2229
- package/#Tools/APPIQ-METHOD/dist/agents/po.txt +0 -1364
- package/#Tools/APPIQ-METHOD/dist/agents/qa.txt +0 -386
- package/#Tools/APPIQ-METHOD/dist/agents/sm.txt +0 -668
- package/#Tools/APPIQ-METHOD/dist/agents/ux-expert.txt +0 -701
- package/#Tools/APPIQ-METHOD/dist/expansion-packs/bmad-2d-phaser-game-dev/agents/game-designer.txt +0 -2408
- package/#Tools/APPIQ-METHOD/dist/expansion-packs/bmad-2d-phaser-game-dev/agents/game-developer.txt +0 -1631
- package/#Tools/APPIQ-METHOD/dist/expansion-packs/bmad-2d-phaser-game-dev/agents/game-sm.txt +0 -822
- package/#Tools/APPIQ-METHOD/dist/expansion-packs/bmad-2d-phaser-game-dev/teams/phaser-2d-nodejs-game-team.txt +0 -10989
- package/#Tools/APPIQ-METHOD/dist/expansion-packs/bmad-2d-unity-game-dev/agents/game-architect.txt +0 -4047
- package/#Tools/APPIQ-METHOD/dist/expansion-packs/bmad-2d-unity-game-dev/agents/game-designer.txt +0 -3744
- package/#Tools/APPIQ-METHOD/dist/expansion-packs/bmad-2d-unity-game-dev/agents/game-developer.txt +0 -465
- package/#Tools/APPIQ-METHOD/dist/expansion-packs/bmad-2d-unity-game-dev/agents/game-sm.txt +0 -990
- package/#Tools/APPIQ-METHOD/dist/expansion-packs/bmad-2d-unity-game-dev/teams/unity-2d-game-team.txt +0 -15467
- package/#Tools/APPIQ-METHOD/dist/expansion-packs/bmad-infrastructure-devops/agents/infra-devops-platform.txt +0 -2077
- package/#Tools/APPIQ-METHOD/dist/teams/team-all.txt +0 -11062
- package/#Tools/APPIQ-METHOD/dist/teams/team-fullstack.txt +0 -10392
- package/#Tools/APPIQ-METHOD/dist/teams/team-ide-minimal.txt +0 -3507
- package/#Tools/APPIQ-METHOD/dist/teams/team-no-ui.txt +0 -8951
- package/#Tools/APPIQ-METHOD/install-appiq.sh +0 -41
- package/#Tools/APPIQ-METHOD/package-lock.json +0 -631
- package/#Tools/APPIQ-METHOD/package.json +0 -44
- package/#Tools/APPIQ-METHOD/tasks/todo.md +0 -275
- package/#Tools/APPIQ-METHOD/tools/appiq-installer.js +0 -2711
- package/#Tools/APPIQ-METHOD/tools/bmad-npx-wrapper.js +0 -39
- package/#Tools/APPIQ-METHOD/tools/builders/web-builder.js +0 -681
- package/#Tools/APPIQ-METHOD/tools/bump-all-versions.js +0 -106
- package/#Tools/APPIQ-METHOD/tools/bump-expansion-version.js +0 -83
- package/#Tools/APPIQ-METHOD/tools/cli.js +0 -152
- package/#Tools/APPIQ-METHOD/tools/epic-solution-installer.js +0 -536
- package/#Tools/APPIQ-METHOD/tools/flattener/main.js +0 -570
- package/#Tools/APPIQ-METHOD/tools/installer/README.md +0 -8
- package/#Tools/APPIQ-METHOD/tools/installer/bin/bmad.js +0 -483
- package/#Tools/APPIQ-METHOD/tools/installer/config/ide-agent-config.yaml +0 -58
- package/#Tools/APPIQ-METHOD/tools/installer/config/install.config.yaml +0 -92
- package/#Tools/APPIQ-METHOD/tools/installer/lib/config-loader.js +0 -253
- package/#Tools/APPIQ-METHOD/tools/installer/lib/file-manager.js +0 -411
- package/#Tools/APPIQ-METHOD/tools/installer/lib/ide-base-setup.js +0 -227
- package/#Tools/APPIQ-METHOD/tools/installer/lib/ide-setup.js +0 -1096
- package/#Tools/APPIQ-METHOD/tools/installer/lib/installer.js +0 -1772
- package/#Tools/APPIQ-METHOD/tools/installer/lib/memory-profiler.js +0 -224
- package/#Tools/APPIQ-METHOD/tools/installer/lib/module-manager.js +0 -110
- package/#Tools/APPIQ-METHOD/tools/installer/lib/resource-locator.js +0 -310
- package/#Tools/APPIQ-METHOD/tools/installer/package-lock.json +0 -906
- package/#Tools/APPIQ-METHOD/tools/installer/package.json +0 -43
- package/#Tools/APPIQ-METHOD/tools/lib/dependency-resolver.js +0 -179
- package/#Tools/APPIQ-METHOD/tools/lib/yaml-utils.js +0 -29
- package/#Tools/APPIQ-METHOD/tools/md-assets/web-agent-startup-instructions.md +0 -39
- package/#Tools/APPIQ-METHOD/tools/semantic-release-sync-installer.js +0 -30
- package/#Tools/APPIQ-METHOD/tools/setup-ide-commands.js +0 -348
- package/#Tools/APPIQ-METHOD/tools/smart-installer.js +0 -592
- package/#Tools/APPIQ-METHOD/tools/sync-installer-version.js +0 -34
- package/#Tools/APPIQ-METHOD/tools/update-expansion-version.js +0 -54
- package/#Tools/APPIQ-METHOD/tools/upgraders/v3-to-v4-upgrader.js +0 -763
- package/#Tools/APPIQ-METHOD/tools/version-bump.js +0 -79
- package/#Tools/APPIQ-METHOD/tools/yaml-format.js +0 -240
- package/#Tools/SkyReels-V2/.pre-commit-config.yaml +0 -25
- package/#Tools/SkyReels-V2/LICENSE.txt +0 -38
- package/#Tools/SkyReels-V2/README.md +0 -766
- package/#Tools/SkyReels-V2/generate_video.py +0 -161
- package/#Tools/SkyReels-V2/generate_video_df.py +0 -220
- package/#Tools/SkyReels-V2/requirements.txt +0 -16
- package/#Tools/SkyReels-V2/skycaptioner_v1/README.md +0 -278
- package/#Tools/SkyReels-V2/skycaptioner_v1/examples/test.csv +0 -5
- package/#Tools/SkyReels-V2/skycaptioner_v1/examples/test_result.csv +0 -5
- package/#Tools/SkyReels-V2/skycaptioner_v1/infer_fusion_caption.sh +0 -9
- package/#Tools/SkyReels-V2/skycaptioner_v1/infer_struct_caption.sh +0 -8
- package/#Tools/SkyReels-V2/skycaptioner_v1/requirements.txt +0 -3
- package/#Tools/SkyReels-V2/skycaptioner_v1/scripts/gradio_fusion_caption.py +0 -146
- package/#Tools/SkyReels-V2/skycaptioner_v1/scripts/gradio_struct_caption.py +0 -92
- package/#Tools/SkyReels-V2/skycaptioner_v1/scripts/utils.py +0 -19
- package/#Tools/SkyReels-V2/skycaptioner_v1/scripts/vllm_fusion_caption.py +0 -256
- package/#Tools/SkyReels-V2/skycaptioner_v1/scripts/vllm_struct_caption.py +0 -156
- package/#Tools/SkyReels-V2/skyreels_v2_infer/__init__.py +0 -1
- package/#Tools/SkyReels-V2/skyreels_v2_infer/distributed/__init__.py +0 -0
- package/#Tools/SkyReels-V2/skyreels_v2_infer/distributed/xdit_context_parallel.py +0 -286
- package/#Tools/SkyReels-V2/skyreels_v2_infer/modules/__init__.py +0 -69
- package/#Tools/SkyReels-V2/skyreels_v2_infer/modules/attention.py +0 -179
- package/#Tools/SkyReels-V2/skyreels_v2_infer/modules/clip.py +0 -525
- package/#Tools/SkyReels-V2/skyreels_v2_infer/modules/t5.py +0 -454
- package/#Tools/SkyReels-V2/skyreels_v2_infer/modules/tokenizers.py +0 -78
- package/#Tools/SkyReels-V2/skyreels_v2_infer/modules/transformer.py +0 -839
- package/#Tools/SkyReels-V2/skyreels_v2_infer/modules/vae.py +0 -639
- package/#Tools/SkyReels-V2/skyreels_v2_infer/modules/xlm_roberta.py +0 -165
- package/#Tools/SkyReels-V2/skyreels_v2_infer/pipelines/__init__.py +0 -5
- package/#Tools/SkyReels-V2/skyreels_v2_infer/pipelines/diffusion_forcing_pipeline.py +0 -659
- package/#Tools/SkyReels-V2/skyreels_v2_infer/pipelines/image2video_pipeline.py +0 -156
- package/#Tools/SkyReels-V2/skyreels_v2_infer/pipelines/prompt_enhancer.py +0 -65
- package/#Tools/SkyReels-V2/skyreels_v2_infer/pipelines/text2video_pipeline.py +0 -110
- package/#Tools/SkyReels-V2/skyreels_v2_infer/scheduler/__init__.py +0 -0
- package/#Tools/SkyReels-V2/skyreels_v2_infer/scheduler/fm_solvers_unipc.py +0 -759
- package/#Tools/SuperClaude/.claude/commands/analyze.md +0 -36
- package/#Tools/SuperClaude/.claude/commands/build.md +0 -35
- package/#Tools/SuperClaude/.claude/commands/cleanup.md +0 -46
- package/#Tools/SuperClaude/.claude/commands/deploy.md +0 -55
- package/#Tools/SuperClaude/.claude/commands/design.md +0 -91
- package/#Tools/SuperClaude/.claude/commands/dev-setup.md +0 -37
- package/#Tools/SuperClaude/.claude/commands/document.md +0 -99
- package/#Tools/SuperClaude/.claude/commands/estimate.md +0 -69
- package/#Tools/SuperClaude/.claude/commands/explain.md +0 -85
- package/#Tools/SuperClaude/.claude/commands/git.md +0 -47
- package/#Tools/SuperClaude/.claude/commands/improve.md +0 -162
- package/#Tools/SuperClaude/.claude/commands/index.md +0 -159
- package/#Tools/SuperClaude/.claude/commands/load.md +0 -65
- package/#Tools/SuperClaude/.claude/commands/migrate.md +0 -76
- package/#Tools/SuperClaude/.claude/commands/scan.md +0 -163
- package/#Tools/SuperClaude/.claude/commands/shared/ambiguity-check.yml +0 -40
- package/#Tools/SuperClaude/.claude/commands/shared/audit.yml +0 -21
- package/#Tools/SuperClaude/.claude/commands/shared/checkpoint.yml +0 -28
- package/#Tools/SuperClaude/.claude/commands/shared/cleanup-patterns.yml +0 -107
- package/#Tools/SuperClaude/.claude/commands/shared/command-memory.yml +0 -52
- package/#Tools/SuperClaude/.claude/commands/shared/command-templates.yml +0 -167
- package/#Tools/SuperClaude/.claude/commands/shared/config-validator.yml +0 -206
- package/#Tools/SuperClaude/.claude/commands/shared/constants.yml +0 -311
- package/#Tools/SuperClaude/.claude/commands/shared/documentation-dirs.yml +0 -134
- package/#Tools/SuperClaude/.claude/commands/shared/error-handling.yml +0 -341
- package/#Tools/SuperClaude/.claude/commands/shared/evidence.yml +0 -75
- package/#Tools/SuperClaude/.claude/commands/shared/execution-lifecycle.yml +0 -277
- package/#Tools/SuperClaude/.claude/commands/shared/git-operations.yml +0 -217
- package/#Tools/SuperClaude/.claude/commands/shared/git-workflow.yml +0 -37
- package/#Tools/SuperClaude/.claude/commands/shared/implementation.yml +0 -199
- package/#Tools/SuperClaude/.claude/commands/shared/loading-config.yml +0 -73
- package/#Tools/SuperClaude/.claude/commands/shared/mcp-flags.yml +0 -109
- package/#Tools/SuperClaude/.claude/commands/shared/migration-report.md +0 -165
- package/#Tools/SuperClaude/.claude/commands/shared/patterns.yml +0 -155
- package/#Tools/SuperClaude/.claude/commands/shared/performance.yml +0 -317
- package/#Tools/SuperClaude/.claude/commands/shared/planning-mode.yml +0 -51
- package/#Tools/SuperClaude/.claude/commands/shared/research-first.yml +0 -278
- package/#Tools/SuperClaude/.claude/commands/shared/session-recovery.yml +0 -144
- package/#Tools/SuperClaude/.claude/commands/shared/severity-levels.yml +0 -252
- package/#Tools/SuperClaude/.claude/commands/shared/task-system.yml +0 -380
- package/#Tools/SuperClaude/.claude/commands/shared/task-ultracompressed.yml +0 -88
- package/#Tools/SuperClaude/.claude/commands/shared/templates/feature-template.md +0 -59
- package/#Tools/SuperClaude/.claude/commands/shared/templates/task-ultracompressed.md +0 -26
- package/#Tools/SuperClaude/.claude/commands/shared/thinking-modes.yml +0 -61
- package/#Tools/SuperClaude/.claude/commands/shared/ultracompressed.yml +0 -97
- package/#Tools/SuperClaude/.claude/commands/shared/user-experience.yml +0 -208
- package/#Tools/SuperClaude/.claude/commands/shared/validation.yml +0 -54
- package/#Tools/SuperClaude/.claude/commands/shared/workflow-chains.yml +0 -138
- package/#Tools/SuperClaude/.claude/commands/spawn.md +0 -106
- package/#Tools/SuperClaude/.claude/commands/task.md +0 -110
- package/#Tools/SuperClaude/.claude/commands/test.md +0 -67
- package/#Tools/SuperClaude/.claude/commands/troubleshoot.md +0 -93
- package/#Tools/SuperClaude/.github/ISSUE_TEMPLATE/bug_report.yml +0 -114
- package/#Tools/SuperClaude/.github/ISSUE_TEMPLATE/feature_request.yml +0 -119
- package/#Tools/SuperClaude/.github/ISSUE_TEMPLATE/question.yml +0 -87
- package/#Tools/SuperClaude/.github/pull_request_template.md +0 -62
- package/#Tools/SuperClaude/CHANGELOG.md +0 -109
- package/#Tools/SuperClaude/CLAUDE.md +0 -95
- package/#Tools/SuperClaude/CODE_OF_CONDUCT.md +0 -45
- package/#Tools/SuperClaude/CONTRIBUTING.md +0 -225
- package/#Tools/SuperClaude/Commands_Cheat_Sheet.md +0 -160
- package/#Tools/SuperClaude/LICENSE +0 -21
- package/#Tools/SuperClaude/MCP.md +0 -117
- package/#Tools/SuperClaude/PERSONAS.md +0 -115
- package/#Tools/SuperClaude/README.md +0 -249
- package/#Tools/SuperClaude/RULES.md +0 -220
- package/#Tools/SuperClaude/SECURITY.md +0 -91
- package/#Tools/SuperClaude/install.sh +0 -296
- package/#Tools/claude-talk-to-figma-mcp/.github/workflows/test.yml +0 -36
- package/#Tools/claude-talk-to-figma-mcp/CHANGELOG.md +0 -88
- package/#Tools/claude-talk-to-figma-mcp/Dockerfile +0 -16
- package/#Tools/claude-talk-to-figma-mcp/LICENSE +0 -22
- package/#Tools/claude-talk-to-figma-mcp/TESTING.md +0 -216
- package/#Tools/claude-talk-to-figma-mcp/bun.lock +0 -964
- package/#Tools/claude-talk-to-figma-mcp/context/01/00-analisis.md +0 -151
- package/#Tools/claude-talk-to-figma-mcp/context/01/01-tools-refactor.md +0 -370
- package/#Tools/claude-talk-to-figma-mcp/context/01/02-tools-refactor-backlog.md +0 -253
- package/#Tools/claude-talk-to-figma-mcp/context/01/03-tools-refactor-test.md +0 -138
- package/#Tools/claude-talk-to-figma-mcp/context/01/04-tools-refactor-channel-error.md +0 -133
- package/#Tools/claude-talk-to-figma-mcp/context/01/04-tools-refactor-test-backlog.md +0 -0
- package/#Tools/claude-talk-to-figma-mcp/context/01/05-tools-refactor-four-tools-error.md +0 -356
- package/#Tools/claude-talk-to-figma-mcp/context/01/06-tools-refactor-four-tools-error-backlog.md +0 -425
- package/#Tools/claude-talk-to-figma-mcp/context/01/prompt-dev-nodejs-bun.md +0 -105
- package/#Tools/claude-talk-to-figma-mcp/context/01-prompt.md +0 -135
- package/#Tools/claude-talk-to-figma-mcp/context/02/00-analisis.md +0 -131
- package/#Tools/claude-talk-to-figma-mcp/context/02/01-plan.md +0 -162
- package/#Tools/claude-talk-to-figma-mcp/context/02/02-backlog.md +0 -241
- package/#Tools/claude-talk-to-figma-mcp/context/02-analisis.md +0 -202
- package/#Tools/claude-talk-to-figma-mcp/context/99-notas.md +0 -139
- package/#Tools/claude-talk-to-figma-mcp/context/pr-14/pr-14-analisis.md +0 -221
- package/#Tools/claude-talk-to-figma-mcp/context/pr-14/pr-14-claude-tests.md +0 -152
- package/#Tools/claude-talk-to-figma-mcp/context/pr-14/pr-14-npm-publishing.md +0 -272
- package/#Tools/claude-talk-to-figma-mcp/images/claude-talk-to-figma.png +0 -0
- package/#Tools/claude-talk-to-figma-mcp/images/mcp-figma-plugin-configuration.png +0 -0
- package/#Tools/claude-talk-to-figma-mcp/jest.config.cjs +0 -25
- package/#Tools/claude-talk-to-figma-mcp/package.json +0 -67
- package/#Tools/claude-talk-to-figma-mcp/prompts/prompt-ux-ui-especialista-es.md +0 -82
- package/#Tools/claude-talk-to-figma-mcp/prompts/prompt-ux-ui-especialista-gal.md +0 -80
- package/#Tools/claude-talk-to-figma-mcp/prompts/prompt-ux-ui-especialista-pt.md +0 -80
- package/#Tools/claude-talk-to-figma-mcp/prompts/prompt-ux-ui-specialist.md +0 -80
- package/#Tools/claude-talk-to-figma-mcp/readme.md +0 -307
- package/#Tools/claude-talk-to-figma-mcp/scripts/configure-claude.js +0 -90
- package/#Tools/claude-talk-to-figma-mcp/scripts/setup.sh +0 -30
- package/#Tools/claude-talk-to-figma-mcp/scripts/test-integration.js +0 -339
- package/#Tools/claude-talk-to-figma-mcp/smithery.yaml +0 -26
- package/#Tools/claude-talk-to-figma-mcp/src/claude_mcp_plugin/code.js +0 -3295
- package/#Tools/claude-talk-to-figma-mcp/src/claude_mcp_plugin/manifest.json +0 -24
- package/#Tools/claude-talk-to-figma-mcp/src/claude_mcp_plugin/setcharacters.js +0 -215
- package/#Tools/claude-talk-to-figma-mcp/src/claude_mcp_plugin/ui.html +0 -656
- package/#Tools/claude-talk-to-figma-mcp/src/socket.ts +0 -349
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/bun.lock +0 -246
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/config/config.ts +0 -22
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/package.json +0 -31
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/prompts/index.ts +0 -297
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/server.ts +0 -62
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/tools/component-tools.ts +0 -48
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/tools/creation-tools.ts +0 -620
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/tools/document-tools.ts +0 -390
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/tools/index.ts +0 -28
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/tools/modification-tools.ts +0 -408
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/tools/text-tools.ts +0 -531
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/tsconfig.json +0 -18
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/types/color.ts +0 -13
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/types/index.ts +0 -87
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/utils/defaults.ts +0 -23
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/utils/figma-helpers.ts +0 -142
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/utils/logger.ts +0 -8
- package/#Tools/claude-talk-to-figma-mcp/src/talk_to_figma_mcp/utils/websocket.ts +0 -258
- package/#Tools/claude-talk-to-figma-mcp/tests/fixtures/test-data.ts +0 -32
- package/#Tools/claude-talk-to-figma-mcp/tests/integration/set-fill-color.test.ts +0 -309
- package/#Tools/claude-talk-to-figma-mcp/tests/integration/set-stroke-color.test.ts +0 -387
- package/#Tools/claude-talk-to-figma-mcp/tests/setup.ts +0 -7
- package/#Tools/claude-talk-to-figma-mcp/tests/unit/utils/defaults.test.ts +0 -131
- package/#Tools/claude-talk-to-figma-mcp/tsconfig.json +0 -17
- package/#Tools/claude-talk-to-figma-mcp/tsup.config.ts +0 -14
- package/#Tools/jwt creator/AuthKey_MZ7UQGFV2Q.p8 +0 -6
- package/#Tools/jwt creator/generate_apple_jwt.js +0 -18
- package/#Tools/jwt creator/node_modules/.package-lock.json +0 -145
- package/#Tools/jwt creator/node_modules/buffer-equal-constant-time/.travis.yml +0 -4
- package/#Tools/jwt creator/node_modules/buffer-equal-constant-time/LICENSE.txt +0 -12
- package/#Tools/jwt creator/node_modules/buffer-equal-constant-time/README.md +0 -50
- package/#Tools/jwt creator/node_modules/buffer-equal-constant-time/index.js +0 -41
- package/#Tools/jwt creator/node_modules/buffer-equal-constant-time/package.json +0 -21
- package/#Tools/jwt creator/node_modules/buffer-equal-constant-time/test.js +0 -42
- package/#Tools/jwt creator/node_modules/ecdsa-sig-formatter/CODEOWNERS +0 -1
- package/#Tools/jwt creator/node_modules/ecdsa-sig-formatter/LICENSE +0 -201
- package/#Tools/jwt creator/node_modules/ecdsa-sig-formatter/README.md +0 -65
- package/#Tools/jwt creator/node_modules/ecdsa-sig-formatter/package.json +0 -46
- package/#Tools/jwt creator/node_modules/ecdsa-sig-formatter/src/ecdsa-sig-formatter.d.ts +0 -17
- package/#Tools/jwt creator/node_modules/ecdsa-sig-formatter/src/ecdsa-sig-formatter.js +0 -187
- package/#Tools/jwt creator/node_modules/ecdsa-sig-formatter/src/param-bytes-for-alg.js +0 -23
- package/#Tools/jwt creator/node_modules/jsonwebtoken/LICENSE +0 -21
- package/#Tools/jwt creator/node_modules/jsonwebtoken/README.md +0 -396
- package/#Tools/jwt creator/node_modules/jsonwebtoken/decode.js +0 -30
- package/#Tools/jwt creator/node_modules/jsonwebtoken/index.js +0 -8
- package/#Tools/jwt creator/node_modules/jsonwebtoken/lib/JsonWebTokenError.js +0 -14
- package/#Tools/jwt creator/node_modules/jsonwebtoken/lib/NotBeforeError.js +0 -13
- package/#Tools/jwt creator/node_modules/jsonwebtoken/lib/TokenExpiredError.js +0 -13
- package/#Tools/jwt creator/node_modules/jsonwebtoken/lib/asymmetricKeyDetailsSupported.js +0 -3
- package/#Tools/jwt creator/node_modules/jsonwebtoken/lib/psSupported.js +0 -3
- package/#Tools/jwt creator/node_modules/jsonwebtoken/lib/rsaPssKeyDetailsSupported.js +0 -3
- package/#Tools/jwt creator/node_modules/jsonwebtoken/lib/timespan.js +0 -18
- package/#Tools/jwt creator/node_modules/jsonwebtoken/lib/validateAsymmetricKey.js +0 -66
- package/#Tools/jwt creator/node_modules/jsonwebtoken/package.json +0 -71
- package/#Tools/jwt creator/node_modules/jsonwebtoken/sign.js +0 -253
- package/#Tools/jwt creator/node_modules/jsonwebtoken/verify.js +0 -263
- package/#Tools/jwt creator/node_modules/jwa/LICENSE +0 -17
- package/#Tools/jwt creator/node_modules/jwa/README.md +0 -150
- package/#Tools/jwt creator/node_modules/jwa/index.js +0 -266
- package/#Tools/jwt creator/node_modules/jwa/package.json +0 -37
- package/#Tools/jwt creator/node_modules/jws/CHANGELOG.md +0 -34
- package/#Tools/jwt creator/node_modules/jws/LICENSE +0 -17
- package/#Tools/jwt creator/node_modules/jws/index.js +0 -22
- package/#Tools/jwt creator/node_modules/jws/lib/data-stream.js +0 -55
- package/#Tools/jwt creator/node_modules/jws/lib/sign-stream.js +0 -78
- package/#Tools/jwt creator/node_modules/jws/lib/tostring.js +0 -10
- package/#Tools/jwt creator/node_modules/jws/lib/verify-stream.js +0 -120
- package/#Tools/jwt creator/node_modules/jws/package.json +0 -34
- package/#Tools/jwt creator/node_modules/jws/readme.md +0 -255
- package/#Tools/jwt creator/node_modules/lodash.includes/LICENSE +0 -47
- package/#Tools/jwt creator/node_modules/lodash.includes/README.md +0 -18
- package/#Tools/jwt creator/node_modules/lodash.includes/index.js +0 -745
- package/#Tools/jwt creator/node_modules/lodash.includes/package.json +0 -17
- package/#Tools/jwt creator/node_modules/lodash.isboolean/LICENSE +0 -22
- package/#Tools/jwt creator/node_modules/lodash.isboolean/README.md +0 -18
- package/#Tools/jwt creator/node_modules/lodash.isboolean/index.js +0 -70
- package/#Tools/jwt creator/node_modules/lodash.isboolean/package.json +0 -17
- package/#Tools/jwt creator/node_modules/lodash.isinteger/LICENSE +0 -47
- package/#Tools/jwt creator/node_modules/lodash.isinteger/README.md +0 -18
- package/#Tools/jwt creator/node_modules/lodash.isinteger/index.js +0 -265
- package/#Tools/jwt creator/node_modules/lodash.isinteger/package.json +0 -17
- package/#Tools/jwt creator/node_modules/lodash.isnumber/LICENSE +0 -22
- package/#Tools/jwt creator/node_modules/lodash.isnumber/README.md +0 -18
- package/#Tools/jwt creator/node_modules/lodash.isnumber/index.js +0 -79
- package/#Tools/jwt creator/node_modules/lodash.isnumber/package.json +0 -17
- package/#Tools/jwt creator/node_modules/lodash.isplainobject/LICENSE +0 -47
- package/#Tools/jwt creator/node_modules/lodash.isplainobject/README.md +0 -18
- package/#Tools/jwt creator/node_modules/lodash.isplainobject/index.js +0 -139
- package/#Tools/jwt creator/node_modules/lodash.isplainobject/package.json +0 -17
- package/#Tools/jwt creator/node_modules/lodash.isstring/LICENSE +0 -22
- package/#Tools/jwt creator/node_modules/lodash.isstring/README.md +0 -18
- package/#Tools/jwt creator/node_modules/lodash.isstring/index.js +0 -95
- package/#Tools/jwt creator/node_modules/lodash.isstring/package.json +0 -17
- package/#Tools/jwt creator/node_modules/lodash.once/LICENSE +0 -47
- package/#Tools/jwt creator/node_modules/lodash.once/README.md +0 -18
- package/#Tools/jwt creator/node_modules/lodash.once/index.js +0 -294
- package/#Tools/jwt creator/node_modules/lodash.once/package.json +0 -17
- package/#Tools/jwt creator/node_modules/ms/index.js +0 -162
- package/#Tools/jwt creator/node_modules/ms/license.md +0 -21
- package/#Tools/jwt creator/node_modules/ms/package.json +0 -38
- package/#Tools/jwt creator/node_modules/ms/readme.md +0 -59
- package/#Tools/jwt creator/node_modules/safe-buffer/LICENSE +0 -21
- package/#Tools/jwt creator/node_modules/safe-buffer/README.md +0 -584
- package/#Tools/jwt creator/node_modules/safe-buffer/index.d.ts +0 -187
- package/#Tools/jwt creator/node_modules/safe-buffer/index.js +0 -65
- package/#Tools/jwt creator/node_modules/safe-buffer/package.json +0 -51
- package/#Tools/jwt creator/node_modules/semver/LICENSE +0 -15
- package/#Tools/jwt creator/node_modules/semver/README.md +0 -664
- package/#Tools/jwt creator/node_modules/semver/bin/semver.js +0 -191
- package/#Tools/jwt creator/node_modules/semver/classes/comparator.js +0 -143
- package/#Tools/jwt creator/node_modules/semver/classes/index.js +0 -7
- package/#Tools/jwt creator/node_modules/semver/classes/range.js +0 -556
- package/#Tools/jwt creator/node_modules/semver/classes/semver.js +0 -319
- package/#Tools/jwt creator/node_modules/semver/functions/clean.js +0 -8
- package/#Tools/jwt creator/node_modules/semver/functions/cmp.js +0 -54
- package/#Tools/jwt creator/node_modules/semver/functions/coerce.js +0 -62
- package/#Tools/jwt creator/node_modules/semver/functions/compare-build.js +0 -9
- package/#Tools/jwt creator/node_modules/semver/functions/compare-loose.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/compare.js +0 -7
- package/#Tools/jwt creator/node_modules/semver/functions/diff.js +0 -60
- package/#Tools/jwt creator/node_modules/semver/functions/eq.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/gt.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/gte.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/inc.js +0 -21
- package/#Tools/jwt creator/node_modules/semver/functions/lt.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/lte.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/major.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/minor.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/neq.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/parse.js +0 -18
- package/#Tools/jwt creator/node_modules/semver/functions/patch.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/prerelease.js +0 -8
- package/#Tools/jwt creator/node_modules/semver/functions/rcompare.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/rsort.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/satisfies.js +0 -12
- package/#Tools/jwt creator/node_modules/semver/functions/sort.js +0 -5
- package/#Tools/jwt creator/node_modules/semver/functions/valid.js +0 -8
- package/#Tools/jwt creator/node_modules/semver/index.js +0 -91
- package/#Tools/jwt creator/node_modules/semver/internal/constants.js +0 -37
- package/#Tools/jwt creator/node_modules/semver/internal/debug.js +0 -11
- package/#Tools/jwt creator/node_modules/semver/internal/identifiers.js +0 -25
- package/#Tools/jwt creator/node_modules/semver/internal/lrucache.js +0 -42
- package/#Tools/jwt creator/node_modules/semver/internal/parse-options.js +0 -17
- package/#Tools/jwt creator/node_modules/semver/internal/re.js +0 -223
- package/#Tools/jwt creator/node_modules/semver/package.json +0 -78
- package/#Tools/jwt creator/node_modules/semver/preload.js +0 -4
- package/#Tools/jwt creator/node_modules/semver/range.bnf +0 -16
- package/#Tools/jwt creator/node_modules/semver/ranges/gtr.js +0 -6
- package/#Tools/jwt creator/node_modules/semver/ranges/intersects.js +0 -9
- package/#Tools/jwt creator/node_modules/semver/ranges/ltr.js +0 -6
- package/#Tools/jwt creator/node_modules/semver/ranges/max-satisfying.js +0 -27
- package/#Tools/jwt creator/node_modules/semver/ranges/min-satisfying.js +0 -26
- package/#Tools/jwt creator/node_modules/semver/ranges/min-version.js +0 -63
- package/#Tools/jwt creator/node_modules/semver/ranges/outside.js +0 -82
- package/#Tools/jwt creator/node_modules/semver/ranges/simplify.js +0 -49
- package/#Tools/jwt creator/node_modules/semver/ranges/subset.js +0 -249
- package/#Tools/jwt creator/node_modules/semver/ranges/to-comparators.js +0 -10
- package/#Tools/jwt creator/node_modules/semver/ranges/valid.js +0 -13
- package/#Tools/jwt creator/package-lock.json +0 -150
- package/#Tools/jwt creator/package.json +0 -5
- package/#Tools/package.json +0 -94
- package/SuperClaude/.claude/commands/analyze.md +0 -36
- package/SuperClaude/.claude/commands/build.md +0 -35
- package/SuperClaude/.claude/commands/cleanup.md +0 -46
- package/SuperClaude/.claude/commands/deploy.md +0 -55
- package/SuperClaude/.claude/commands/design.md +0 -91
- package/SuperClaude/.claude/commands/dev-setup.md +0 -37
- package/SuperClaude/.claude/commands/document.md +0 -99
- package/SuperClaude/.claude/commands/estimate.md +0 -69
- package/SuperClaude/.claude/commands/explain.md +0 -85
- package/SuperClaude/.claude/commands/git.md +0 -47
- package/SuperClaude/.claude/commands/improve.md +0 -162
- package/SuperClaude/.claude/commands/index.md +0 -159
- package/SuperClaude/.claude/commands/load.md +0 -65
- package/SuperClaude/.claude/commands/migrate.md +0 -76
- package/SuperClaude/.claude/commands/scan.md +0 -163
- package/SuperClaude/.claude/commands/shared/ambiguity-check.yml +0 -40
- package/SuperClaude/.claude/commands/shared/audit.yml +0 -21
- package/SuperClaude/.claude/commands/shared/checkpoint.yml +0 -28
- package/SuperClaude/.claude/commands/shared/cleanup-patterns.yml +0 -107
- package/SuperClaude/.claude/commands/shared/command-memory.yml +0 -52
- package/SuperClaude/.claude/commands/shared/command-templates.yml +0 -167
- package/SuperClaude/.claude/commands/shared/config-validator.yml +0 -206
- package/SuperClaude/.claude/commands/shared/constants.yml +0 -311
- package/SuperClaude/.claude/commands/shared/documentation-dirs.yml +0 -134
- package/SuperClaude/.claude/commands/shared/error-handling.yml +0 -341
- package/SuperClaude/.claude/commands/shared/evidence.yml +0 -75
- package/SuperClaude/.claude/commands/shared/execution-lifecycle.yml +0 -277
- package/SuperClaude/.claude/commands/shared/git-operations.yml +0 -217
- package/SuperClaude/.claude/commands/shared/git-workflow.yml +0 -37
- package/SuperClaude/.claude/commands/shared/implementation.yml +0 -199
- package/SuperClaude/.claude/commands/shared/loading-config.yml +0 -73
- package/SuperClaude/.claude/commands/shared/mcp-flags.yml +0 -109
- package/SuperClaude/.claude/commands/shared/migration-report.md +0 -165
- package/SuperClaude/.claude/commands/shared/patterns.yml +0 -155
- package/SuperClaude/.claude/commands/shared/performance.yml +0 -317
- package/SuperClaude/.claude/commands/shared/planning-mode.yml +0 -51
- package/SuperClaude/.claude/commands/shared/research-first.yml +0 -278
- package/SuperClaude/.claude/commands/shared/session-recovery.yml +0 -144
- package/SuperClaude/.claude/commands/shared/severity-levels.yml +0 -252
- package/SuperClaude/.claude/commands/shared/task-system.yml +0 -380
- package/SuperClaude/.claude/commands/shared/task-ultracompressed.yml +0 -88
- package/SuperClaude/.claude/commands/shared/templates/feature-template.md +0 -59
- package/SuperClaude/.claude/commands/shared/templates/task-ultracompressed.md +0 -26
- package/SuperClaude/.claude/commands/shared/thinking-modes.yml +0 -61
- package/SuperClaude/.claude/commands/shared/ultracompressed.yml +0 -97
- package/SuperClaude/.claude/commands/shared/user-experience.yml +0 -208
- package/SuperClaude/.claude/commands/shared/validation.yml +0 -54
- package/SuperClaude/.claude/commands/shared/workflow-chains.yml +0 -138
- package/SuperClaude/.claude/commands/spawn.md +0 -106
- package/SuperClaude/.claude/commands/task.md +0 -110
- package/SuperClaude/.claude/commands/test.md +0 -67
- package/SuperClaude/.claude/commands/troubleshoot.md +0 -93
- package/SuperClaude/.github/ISSUE_TEMPLATE/bug_report.yml +0 -114
- package/SuperClaude/.github/ISSUE_TEMPLATE/feature_request.yml +0 -119
- package/SuperClaude/.github/ISSUE_TEMPLATE/question.yml +0 -87
- package/SuperClaude/.github/pull_request_template.md +0 -62
- package/SuperClaude/CHANGELOG.md +0 -109
- package/SuperClaude/CLAUDE.md +0 -95
- package/SuperClaude/CODE_OF_CONDUCT.md +0 -45
- package/SuperClaude/CONTRIBUTING.md +0 -225
- package/SuperClaude/Commands_Cheat_Sheet.md +0 -160
- package/SuperClaude/LICENSE +0 -21
- package/SuperClaude/MCP.md +0 -117
- package/SuperClaude/PERSONAS.md +0 -115
- package/SuperClaude/README.md +0 -249
- package/SuperClaude/RULES.md +0 -220
- package/SuperClaude/SECURITY.md +0 -91
- package/SuperClaude/install.sh +0 -296
- package/appiq-mcp installer/How-to.md +0 -250
- package/appiq-mcp installer/LICENSE +0 -21
- package/appiq-mcp installer/README.md +0 -235
- package/appiq-mcp installer/index.js +0 -672
- package/appiq-mcp installer/my_mcps.md +0 -105
- package/appiq-mcp installer/package-lock.json +0 -708
- package/appiq-mcp installer/package.json +0 -46
- package/appiq-mcp installer/test-install.bat +0 -60
- package/appiq-mcp installer/test-install.sh +0 -55
- package/appiq-mcp installer/test-load.js +0 -40
- package/bmad-core/agent-teams/team-flutter-mobile.yaml +0 -114
- package/bmad-core/agents/bmad-smart-launcher.md +0 -170
- package/bmad-core/agents/init-flow-po.md +0 -143
- package/bmad-core/checklists/security-validation-checklist.md +0 -332
- package/bmad-core/core-config.yaml.bak +0 -20
- package/bmad-core/data/backend-services-integration.md +0 -686
- package/bmad-core/data/shadcn-ui-integration.md +0 -388
- package/bmad-core/tasks/create-flutter-story.md +0 -197
- package/bmad-core/tasks/intelligent-epic-creation.md +0 -234
- package/bmad-core/tasks/smart-project-analysis.md +0 -289
- package/bmad-core/templates/flutter-mobile-prd-tmpl.yaml +0 -330
- package/bmad-core/templates/flutter-story-tmpl.yaml +0 -376
- package/bmad-core/templates/flutter-ui-spec-tmpl.yaml +0 -415
- package/dist/expansion-packs/bmad-mobile-app-dev/agents/mobile-analytics.txt +0 -1530
- package/dist/expansion-packs/bmad-mobile-app-dev/agents/mobile-architect.txt +0 -322
- package/dist/expansion-packs/bmad-mobile-app-dev/agents/mobile-developer.txt +0 -692
- package/dist/expansion-packs/bmad-mobile-app-dev/agents/mobile-pm.txt +0 -382
- package/dist/expansion-packs/bmad-mobile-app-dev/agents/mobile-qa.txt +0 -665
- package/dist/expansion-packs/bmad-mobile-app-dev/agents/mobile-security.txt +0 -1070
- package/dist/expansion-packs/bmad-mobile-app-dev/agents/mobile-ux-expert.txt +0 -1494
- package/dist/expansion-packs/bmad-mobile-app-dev/teams/mobile-team-cross-platform.txt +0 -15613
- package/flutter/CLAUDE.md +0 -58
- package/flutter/punkt.claude/New Folder With Items/channel.md +0 -221
- package/flutter/punkt.claude/New Folder With Items/commands/add-translations.md +0 -12
- package/flutter/punkt.claude/New Folder With Items/commands/create-feature.md +0 -168
- package/flutter/punkt.claude/New Folder With Items/commands/explain-codebase.md +0 -1
- package/flutter/punkt.claude/New Folder With Items/commands/feature-business-logic.md +0 -551
- package/flutter/punkt.claude/New Folder With Items/commands/feature-data-layer.md +0 -924
- package/flutter/punkt.claude/New Folder With Items/commands/feature-domain-layer.md +0 -540
- package/flutter/punkt.claude/New Folder With Items/commands/feature-integration.md +0 -493
- package/flutter/punkt.claude/New Folder With Items/commands/feature-localization.md +0 -427
- package/flutter/punkt.claude/New Folder With Items/commands/feature-ui-layer.md +0 -300
- package/flutter/punkt.claude/New Folder With Items/commands/git-commit.md +0 -3
- package/flutter/punkt.claude/New Folder With Items/commands/search-web.md +0 -1
- package/flutter/punkt.claude/punkt.claude/channel.md +0 -225
- package/flutter/punkt.claude/punkt.claude/commands/add-translations.md +0 -60
- package/flutter/punkt.claude/punkt.claude/commands/bug-fix.md +0 -32
- package/flutter/punkt.claude/punkt.claude/commands/checkdev.md +0 -122
- package/flutter/punkt.claude/punkt.claude/commands/create-feature.md +0 -174
- package/flutter/punkt.claude/punkt.claude/commands/dev.md +0 -79
- package/flutter/punkt.claude/punkt.claude/commands/explain-codebase.md +0 -1
- package/flutter/punkt.claude/punkt.claude/commands/feature-business-logic.md +0 -430
- package/flutter/punkt.claude/punkt.claude/commands/feature-data-layer.md +0 -572
- package/flutter/punkt.claude/punkt.claude/commands/feature-domain-layer.md +0 -537
- package/flutter/punkt.claude/punkt.claude/commands/feature-integration.md +0 -493
- package/flutter/punkt.claude/punkt.claude/commands/feature-localization.md +0 -427
- package/flutter/punkt.claude/punkt.claude/commands/feature-ui-layer.md +0 -831
- package/flutter/punkt.claude/punkt.claude/commands/git-commit.md +0 -3
- package/flutter/punkt.claude/punkt.claude/commands/manage-translations.md +0 -433
- package/flutter/punkt.claude/punkt.claude/commands/search-web.md +0 -1
- package/flutter/punkt.claude/punkt.claude/developer_check.md +0 -121
- package/tools/appiq-installer.js +0 -2711
- package/tools/epic-solution-installer.js +0 -536
- package/tools/setup-ide-commands.js +0 -348
- package/tools/smart-installer.js +0 -592
- package/web/CLAUDE.md +0 -58
- /package/{#Tools/APPIQ-METHOD/.github → .github}/FUNDING.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/.github → .github}/ISSUE_TEMPLATE/bug_report.md +0 -0
- /package/{#Tools/APPIQ-METHOD/.github → .github}/ISSUE_TEMPLATE/feature_request.md +0 -0
- /package/{#Tools/APPIQ-METHOD/.github → .github}/workflows/release.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/.releaserc.json → .releaserc.json} +0 -0
- /package/{#Tools/APPIQ-METHOD/.vscode → .vscode}/settings.json +0 -0
- /package/{#Tools/APPIQ-METHOD/CHANGELOG.md → CHANGELOG.md} +0 -0
- /package/{#Tools/APPIQ-METHOD/CONTRIBUTING.md → CONTRIBUTING.md} +0 -0
- /package/{#Tools/APPIQ-METHOD/LICENSE → LICENSE} +0 -0
- /package/{#Tools/APPIQ-METHOD/common → common}/tasks/create-doc.md +0 -0
- /package/{#Tools/APPIQ-METHOD/common → common}/tasks/execute-checklist.md +0 -0
- /package/{#Tools/APPIQ-METHOD/common → common}/utils/bmad-doc-template.md +0 -0
- /package/{#Tools/APPIQ-METHOD/common → common}/utils/workflow-management.md +0 -0
- /package/{#Tools/APPIQ-METHOD/docs → docs}/GUIDING-PRINCIPLES.md +0 -0
- /package/{#Tools/APPIQ-METHOD/docs → docs}/core-architecture.md +0 -0
- /package/{#Tools/APPIQ-METHOD/docs → docs}/expansion-packs.md +0 -0
- /package/{#Tools/APPIQ-METHOD/docs → docs}/how-to-contribute-with-pull-requests.md +0 -0
- /package/{#Tools/APPIQ-METHOD/docs → docs}/versioning-and-releases.md +0 -0
- /package/{#Tools/APPIQ-METHOD/docs → docs}/versions.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/README.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs/bmad-flutter-mobile-dev → expansion-packs/appiq-flutter-mobile-dev}/agent-teams/flutter-mobile-team.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs/bmad-flutter-mobile-dev → expansion-packs/appiq-flutter-mobile-dev}/agents/flutter-cubit-agent.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs/bmad-flutter-mobile-dev → expansion-packs/appiq-flutter-mobile-dev}/agents/flutter-data-agent.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs/bmad-flutter-mobile-dev → expansion-packs/appiq-flutter-mobile-dev}/agents/flutter-domain-agent.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs/bmad-flutter-mobile-dev → expansion-packs/appiq-flutter-mobile-dev}/agents/flutter-ui-agent.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs/bmad-flutter-mobile-dev → expansion-packs/appiq-flutter-mobile-dev}/agents/shared-components-agent.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs/bmad-flutter-mobile-dev → expansion-packs/appiq-flutter-mobile-dev}/checklists/flutter-story-dod-checklist.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs/bmad-flutter-mobile-dev → expansion-packs/appiq-flutter-mobile-dev}/config.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs/bmad-flutter-mobile-dev → expansion-packs/appiq-flutter-mobile-dev}/data/flutter-development-guidelines.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs/bmad-flutter-mobile-dev → expansion-packs/appiq-flutter-mobile-dev}/templates/flutter-mobile-architecture-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs/bmad-flutter-mobile-dev → expansion-packs/appiq-flutter-mobile-dev}/workflows/flutter-ui-first-development.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/agent-teams/phaser-2d-nodejs-game-team.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/agents/game-designer.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/agents/game-developer.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/agents/game-sm.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/checklists/game-design-checklist.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/checklists/game-story-dod-checklist.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/config.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/data/bmad-kb.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/data/development-guidelines.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/tasks/advanced-elicitation.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/tasks/create-game-story.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/tasks/game-design-brainstorming.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/templates/game-architecture-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/templates/game-brief-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/templates/game-design-doc-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/templates/game-story-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/templates/level-design-doc-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/workflows/game-dev-greenfield.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-phaser-game-dev/workflows/game-prototype.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/agent-teams/unity-2d-game-team.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/agents/game-architect.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/agents/game-designer.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/agents/game-developer.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/agents/game-sm.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/checklists/game-architect-checklist.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/checklists/game-change-checklist.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/checklists/game-design-checklist.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/checklists/game-story-dod-checklist.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/config.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/data/bmad-kb.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/data/development-guidelines.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/tasks/advanced-elicitation.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/tasks/correct-course-game.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/tasks/create-game-story.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/tasks/game-design-brainstorming.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/tasks/validate-game-story.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/templates/game-architecture-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/templates/game-brief-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/templates/game-design-doc-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/templates/game-story-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/templates/level-design-doc-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/workflows/game-dev-greenfield.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-2d-unity-game-dev/workflows/game-prototype.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-infrastructure-devops/README.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-infrastructure-devops/agents/infra-devops-platform.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-infrastructure-devops/checklists/infrastructure-checklist.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-infrastructure-devops/config.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-infrastructure-devops/data/bmad-kb.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-infrastructure-devops/tasks/review-infrastructure.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-infrastructure-devops/tasks/validate-infrastructure.md +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-infrastructure-devops/templates/infrastructure-architecture-tmpl.yaml +0 -0
- /package/{#Tools/APPIQ-METHOD/expansion-packs → expansion-packs}/bmad-infrastructure-devops/templates/infrastructure-platform-from-arch-tmpl.yaml +0 -0
@@ -1,309 +0,0 @@
|
|
1
|
-
import { z } from 'zod';
|
2
|
-
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
|
3
|
-
import { registerModificationTools } from '../../src/talk_to_figma_mcp/tools/modification-tools';
|
4
|
-
|
5
|
-
jest.mock('../../src/talk_to_figma_mcp/utils/websocket', () => ({
|
6
|
-
sendCommandToFigma: jest.fn().mockResolvedValue({ name: "MockNode" })
|
7
|
-
}));
|
8
|
-
|
9
|
-
describe("set_fill_color tool integration", () => {
|
10
|
-
let server: McpServer;
|
11
|
-
let mockSendCommand: jest.Mock;
|
12
|
-
let toolHandler: Function;
|
13
|
-
let toolSchema: z.ZodObject<any>;
|
14
|
-
|
15
|
-
beforeEach(() => {
|
16
|
-
server = new McpServer(
|
17
|
-
{ name: 'test-server', version: '1.0.0' },
|
18
|
-
{ capabilities: { tools: {} } }
|
19
|
-
);
|
20
|
-
|
21
|
-
mockSendCommand = require('../../src/talk_to_figma_mcp/utils/websocket').sendCommandToFigma;
|
22
|
-
mockSendCommand.mockClear();
|
23
|
-
|
24
|
-
const originalTool = server.tool.bind(server);
|
25
|
-
jest.spyOn(server, 'tool').mockImplementation((...args: any[]) => {
|
26
|
-
if (args.length === 4) {
|
27
|
-
const [name, description, schema, handler] = args;
|
28
|
-
if (name === 'set_fill_color') {
|
29
|
-
toolHandler = handler;
|
30
|
-
toolSchema = z.object(schema);
|
31
|
-
}
|
32
|
-
}
|
33
|
-
return (originalTool as any)(...args);
|
34
|
-
});
|
35
|
-
|
36
|
-
registerModificationTools(server);
|
37
|
-
});
|
38
|
-
|
39
|
-
async function callToolWithValidation(args: any) {
|
40
|
-
const validatedArgs = toolSchema.parse(args);
|
41
|
-
const result = await toolHandler(validatedArgs, { meta: {} });
|
42
|
-
return result;
|
43
|
-
}
|
44
|
-
|
45
|
-
describe("opacity handling (the critical fix)", () => {
|
46
|
-
it("defaults `a` to 1 when `a` is undefined", async () => {
|
47
|
-
const response = await callToolWithValidation({
|
48
|
-
nodeId: "nodeA",
|
49
|
-
r: 0.2,
|
50
|
-
g: 0.4,
|
51
|
-
b: 0.6,
|
52
|
-
// a is undefined
|
53
|
-
});
|
54
|
-
|
55
|
-
expect(mockSendCommand).toHaveBeenCalledTimes(1);
|
56
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
57
|
-
expect(command).toBe("set_fill_color");
|
58
|
-
expect(payload).toEqual({
|
59
|
-
nodeId: "nodeA",
|
60
|
-
color: { r: 0.2, g: 0.4, b: 0.6, a: 1 },
|
61
|
-
});
|
62
|
-
|
63
|
-
expect(response.content[0].text).toContain("RGBA(0.2, 0.4, 0.6, 1)");
|
64
|
-
});
|
65
|
-
|
66
|
-
it("preserves `a = 0` when explicitly provided (the main bug fix)", async () => {
|
67
|
-
const response = await callToolWithValidation({
|
68
|
-
nodeId: "nodeB",
|
69
|
-
r: 0.1,
|
70
|
-
g: 0.3,
|
71
|
-
b: 0.5,
|
72
|
-
a: 0, // This should be preserved as 0, not converted to 1
|
73
|
-
});
|
74
|
-
|
75
|
-
expect(mockSendCommand).toHaveBeenCalledTimes(1);
|
76
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
77
|
-
expect(payload.color.a).toBe(0); // Critical: should be 0, not 1
|
78
|
-
|
79
|
-
expect(response.content[0].text).toContain("RGBA(0.1, 0.3, 0.5, 0)");
|
80
|
-
});
|
81
|
-
|
82
|
-
it("preserves semi-transparent values", async () => {
|
83
|
-
const response = await callToolWithValidation({
|
84
|
-
nodeId: "nodeC",
|
85
|
-
r: 1,
|
86
|
-
g: 0,
|
87
|
-
b: 0,
|
88
|
-
a: 0.5,
|
89
|
-
});
|
90
|
-
|
91
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
92
|
-
expect(payload.color.a).toBe(0.5);
|
93
|
-
expect(response.content[0].text).toContain("RGBA(1, 0, 0, 0.5)");
|
94
|
-
});
|
95
|
-
});
|
96
|
-
|
97
|
-
describe("RGB component handling", () => {
|
98
|
-
it("preserves pure black (0,0,0)", async () => {
|
99
|
-
await callToolWithValidation({
|
100
|
-
nodeId: "nodeD",
|
101
|
-
r: 0,
|
102
|
-
g: 0,
|
103
|
-
b: 0,
|
104
|
-
a: 1,
|
105
|
-
});
|
106
|
-
|
107
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
108
|
-
expect(payload.color.r).toBe(0);
|
109
|
-
expect(payload.color.g).toBe(0);
|
110
|
-
expect(payload.color.b).toBe(0);
|
111
|
-
});
|
112
|
-
|
113
|
-
it("preserves zero red component", async () => {
|
114
|
-
await callToolWithValidation({
|
115
|
-
nodeId: "nodeE1",
|
116
|
-
r: 0,
|
117
|
-
g: 0.5,
|
118
|
-
b: 0.8,
|
119
|
-
a: 1,
|
120
|
-
});
|
121
|
-
|
122
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
123
|
-
expect(payload.color.r).toBe(0);
|
124
|
-
expect(payload.color.g).toBe(0.5);
|
125
|
-
});
|
126
|
-
|
127
|
-
it("preserves zero green component", async () => {
|
128
|
-
await callToolWithValidation({
|
129
|
-
nodeId: "nodeE2",
|
130
|
-
r: 0.5,
|
131
|
-
g: 0,
|
132
|
-
b: 0.8,
|
133
|
-
a: 1,
|
134
|
-
});
|
135
|
-
|
136
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
137
|
-
expect(payload.color.g).toBe(0);
|
138
|
-
});
|
139
|
-
|
140
|
-
it("preserves zero blue component", async () => {
|
141
|
-
await callToolWithValidation({
|
142
|
-
nodeId: "nodeE3",
|
143
|
-
r: 0.5,
|
144
|
-
g: 0.8,
|
145
|
-
b: 0,
|
146
|
-
a: 1,
|
147
|
-
});
|
148
|
-
|
149
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
150
|
-
expect(payload.color.b).toBe(0);
|
151
|
-
});
|
152
|
-
});
|
153
|
-
|
154
|
-
describe("Zod validation (real validation layer)", () => {
|
155
|
-
it("rejects undefined r component", async () => {
|
156
|
-
await expect(callToolWithValidation({
|
157
|
-
nodeId: "nodeF1",
|
158
|
-
// r is missing
|
159
|
-
g: 0.5,
|
160
|
-
b: 0.8,
|
161
|
-
a: 1,
|
162
|
-
})).rejects.toThrow();
|
163
|
-
|
164
|
-
// WebSocket should not be called if validation fails
|
165
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
166
|
-
});
|
167
|
-
|
168
|
-
it("rejects undefined g component", async () => {
|
169
|
-
await expect(callToolWithValidation({
|
170
|
-
nodeId: "nodeF2",
|
171
|
-
r: 0.5,
|
172
|
-
// g is missing
|
173
|
-
b: 0.8,
|
174
|
-
a: 1,
|
175
|
-
})).rejects.toThrow();
|
176
|
-
|
177
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
178
|
-
});
|
179
|
-
|
180
|
-
it("rejects undefined b component", async () => {
|
181
|
-
await expect(callToolWithValidation({
|
182
|
-
nodeId: "nodeF3",
|
183
|
-
r: 0.5,
|
184
|
-
g: 0.8,
|
185
|
-
// b is missing
|
186
|
-
a: 1,
|
187
|
-
})).rejects.toThrow();
|
188
|
-
|
189
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
190
|
-
});
|
191
|
-
|
192
|
-
it("rejects string r component", async () => {
|
193
|
-
await expect(callToolWithValidation({
|
194
|
-
nodeId: "nodeF4",
|
195
|
-
r: "red", // Invalid type
|
196
|
-
g: 0.5,
|
197
|
-
b: 0.8,
|
198
|
-
a: 1,
|
199
|
-
})).rejects.toThrow();
|
200
|
-
|
201
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
202
|
-
});
|
203
|
-
|
204
|
-
it("rejects null g component", async () => {
|
205
|
-
await expect(callToolWithValidation({
|
206
|
-
nodeId: "nodeF5",
|
207
|
-
r: 0.5,
|
208
|
-
g: null, // Invalid type
|
209
|
-
b: 0.8,
|
210
|
-
a: 1,
|
211
|
-
})).rejects.toThrow();
|
212
|
-
|
213
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
214
|
-
});
|
215
|
-
|
216
|
-
it("rejects boolean b component", async () => {
|
217
|
-
await expect(callToolWithValidation({
|
218
|
-
nodeId: "nodeF6",
|
219
|
-
r: 0.5,
|
220
|
-
g: 0.8,
|
221
|
-
b: true, // Invalid type
|
222
|
-
a: 1,
|
223
|
-
})).rejects.toThrow();
|
224
|
-
|
225
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
226
|
-
});
|
227
|
-
|
228
|
-
it("rejects NaN values", async () => {
|
229
|
-
await expect(callToolWithValidation({
|
230
|
-
nodeId: "nodeF7",
|
231
|
-
r: NaN, // Invalid value
|
232
|
-
g: 0.5,
|
233
|
-
b: 0.8,
|
234
|
-
a: 1,
|
235
|
-
})).rejects.toThrow();
|
236
|
-
|
237
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
238
|
-
});
|
239
|
-
|
240
|
-
it("rejects out-of-range values", async () => {
|
241
|
-
await expect(callToolWithValidation({
|
242
|
-
nodeId: "nodeF8",
|
243
|
-
r: 1.5, // Out of 0-1 range
|
244
|
-
g: 0.5,
|
245
|
-
b: 0.8,
|
246
|
-
a: 1,
|
247
|
-
})).rejects.toThrow();
|
248
|
-
|
249
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
250
|
-
});
|
251
|
-
|
252
|
-
it("rejects negative values", async () => {
|
253
|
-
await expect(callToolWithValidation({
|
254
|
-
nodeId: "nodeF9",
|
255
|
-
r: -0.1, // Negative value
|
256
|
-
g: 0.5,
|
257
|
-
b: 0.8,
|
258
|
-
a: 1,
|
259
|
-
})).rejects.toThrow();
|
260
|
-
|
261
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
262
|
-
});
|
263
|
-
});
|
264
|
-
|
265
|
-
describe("edge cases", () => {
|
266
|
-
it("handles transparent black correctly", async () => {
|
267
|
-
const response = await callToolWithValidation({
|
268
|
-
nodeId: "nodeG",
|
269
|
-
r: 0,
|
270
|
-
g: 0,
|
271
|
-
b: 0,
|
272
|
-
a: 0, // Transparent black
|
273
|
-
});
|
274
|
-
|
275
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
276
|
-
expect(payload.color).toEqual({ r: 0, g: 0, b: 0, a: 0 });
|
277
|
-
expect(response.content[0].text).toContain("RGBA(0, 0, 0, 0)");
|
278
|
-
});
|
279
|
-
|
280
|
-
it("handles boundary values", async () => {
|
281
|
-
const response = await callToolWithValidation({
|
282
|
-
nodeId: "nodeH",
|
283
|
-
r: 1,
|
284
|
-
g: 1,
|
285
|
-
b: 1,
|
286
|
-
a: 1,
|
287
|
-
});
|
288
|
-
|
289
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
290
|
-
expect(payload.color).toEqual({ r: 1, g: 1, b: 1, a: 1 });
|
291
|
-
});
|
292
|
-
|
293
|
-
it("accepts valid decimal values", async () => {
|
294
|
-
await callToolWithValidation({
|
295
|
-
nodeId: "nodeI",
|
296
|
-
r: 0.123,
|
297
|
-
g: 0.456,
|
298
|
-
b: 0.789,
|
299
|
-
a: 0.5,
|
300
|
-
});
|
301
|
-
|
302
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
303
|
-
expect(payload.color.r).toBeCloseTo(0.123);
|
304
|
-
expect(payload.color.g).toBeCloseTo(0.456);
|
305
|
-
expect(payload.color.b).toBeCloseTo(0.789);
|
306
|
-
expect(payload.color.a).toBeCloseTo(0.5);
|
307
|
-
});
|
308
|
-
});
|
309
|
-
});
|
@@ -1,387 +0,0 @@
|
|
1
|
-
import { z } from 'zod';
|
2
|
-
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
|
3
|
-
import { registerModificationTools } from '../../src/talk_to_figma_mcp/tools/modification-tools';
|
4
|
-
|
5
|
-
jest.mock('../../src/talk_to_figma_mcp/utils/websocket', () => ({
|
6
|
-
sendCommandToFigma: jest.fn().mockResolvedValue({ name: "MockNode" })
|
7
|
-
}));
|
8
|
-
|
9
|
-
describe("set_stroke_color tool integration", () => {
|
10
|
-
let server: McpServer;
|
11
|
-
let mockSendCommand: jest.Mock;
|
12
|
-
let toolHandler: Function;
|
13
|
-
let toolSchema: z.ZodObject<any>;
|
14
|
-
|
15
|
-
beforeEach(() => {
|
16
|
-
server = new McpServer(
|
17
|
-
{ name: 'test-server', version: '1.0.0' },
|
18
|
-
{ capabilities: { tools: {} } }
|
19
|
-
);
|
20
|
-
|
21
|
-
mockSendCommand = require('../../src/talk_to_figma_mcp/utils/websocket').sendCommandToFigma;
|
22
|
-
mockSendCommand.mockClear();
|
23
|
-
|
24
|
-
const originalTool = server.tool.bind(server);
|
25
|
-
jest.spyOn(server, 'tool').mockImplementation((...args: any[]) => {
|
26
|
-
if (args.length === 4) {
|
27
|
-
const [name, description, schema, handler] = args;
|
28
|
-
if (name === 'set_stroke_color') {
|
29
|
-
toolHandler = handler;
|
30
|
-
toolSchema = z.object(schema);
|
31
|
-
}
|
32
|
-
}
|
33
|
-
return (originalTool as any)(...args);
|
34
|
-
});
|
35
|
-
|
36
|
-
registerModificationTools(server);
|
37
|
-
});
|
38
|
-
|
39
|
-
async function callToolWithValidation(args: any) {
|
40
|
-
const validatedArgs = toolSchema.parse(args);
|
41
|
-
const result = await toolHandler(validatedArgs, { meta: {} });
|
42
|
-
return result;
|
43
|
-
}
|
44
|
-
|
45
|
-
describe("opacity handling (the critical fix)", () => {
|
46
|
-
it("defaults `a` to 1 when `a` is undefined", async () => {
|
47
|
-
const response = await callToolWithValidation({
|
48
|
-
nodeId: "nodeA",
|
49
|
-
r: 0.2,
|
50
|
-
g: 0.4,
|
51
|
-
b: 0.6,
|
52
|
-
// a is undefined
|
53
|
-
strokeWeight: 2,
|
54
|
-
});
|
55
|
-
|
56
|
-
expect(mockSendCommand).toHaveBeenCalledTimes(1);
|
57
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
58
|
-
expect(command).toBe("set_stroke_color");
|
59
|
-
expect(payload).toEqual({
|
60
|
-
nodeId: "nodeA",
|
61
|
-
color: { r: 0.2, g: 0.4, b: 0.6, a: 1 },
|
62
|
-
strokeWeight: 2,
|
63
|
-
});
|
64
|
-
|
65
|
-
expect(response.content[0].text).toContain("RGBA(0.2, 0.4, 0.6, 1)");
|
66
|
-
expect(response.content[0].text).toContain("weight 2");
|
67
|
-
});
|
68
|
-
|
69
|
-
it("preserves `a = 0` when explicitly provided (the main bug fix)", async () => {
|
70
|
-
const response = await callToolWithValidation({
|
71
|
-
nodeId: "nodeB",
|
72
|
-
r: 0.1,
|
73
|
-
g: 0.3,
|
74
|
-
b: 0.5,
|
75
|
-
a: 0, // This should be preserved as 0, not converted to 1
|
76
|
-
strokeWeight: 1.5,
|
77
|
-
});
|
78
|
-
|
79
|
-
expect(mockSendCommand).toHaveBeenCalledTimes(1);
|
80
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
81
|
-
expect(payload.color.a).toBe(0);
|
82
|
-
expect(payload.strokeWeight).toBe(1.5);
|
83
|
-
|
84
|
-
expect(response.content[0].text).toContain("RGBA(0.1, 0.3, 0.5, 0)");
|
85
|
-
expect(response.content[0].text).toContain("weight 1.5");
|
86
|
-
});
|
87
|
-
|
88
|
-
it("preserves semi-transparent values", async () => {
|
89
|
-
const response = await callToolWithValidation({
|
90
|
-
nodeId: "nodeC",
|
91
|
-
r: 1,
|
92
|
-
g: 0,
|
93
|
-
b: 0,
|
94
|
-
a: 0.5,
|
95
|
-
strokeWeight: 3,
|
96
|
-
});
|
97
|
-
|
98
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
99
|
-
expect(payload.color.a).toBe(0.5);
|
100
|
-
expect(payload.strokeWeight).toBe(3);
|
101
|
-
expect(response.content[0].text).toContain("RGBA(1, 0, 0, 0.5)");
|
102
|
-
expect(response.content[0].text).toContain("weight 3");
|
103
|
-
});
|
104
|
-
});
|
105
|
-
|
106
|
-
describe("stroke weight handling (the other critical fix)", () => {
|
107
|
-
it("defaults strokeWeight to 1 when undefined", async () => {
|
108
|
-
const response = await callToolWithValidation({
|
109
|
-
nodeId: "nodeD",
|
110
|
-
r: 0.5,
|
111
|
-
g: 0.5,
|
112
|
-
b: 0.5,
|
113
|
-
a: 1,
|
114
|
-
// strokeWeight is undefined
|
115
|
-
});
|
116
|
-
|
117
|
-
expect(mockSendCommand).toHaveBeenCalledTimes(1);
|
118
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
119
|
-
expect(payload.strokeWeight).toBe(1); // Should default to 1
|
120
|
-
expect(response.content[0].text).toContain("weight 1");
|
121
|
-
});
|
122
|
-
|
123
|
-
it("preserves provided strokeWeight values", async () => {
|
124
|
-
const response = await callToolWithValidation({
|
125
|
-
nodeId: "nodeE",
|
126
|
-
r: 0.5,
|
127
|
-
g: 0.5,
|
128
|
-
b: 0.5,
|
129
|
-
a: 1,
|
130
|
-
strokeWeight: 5.5,
|
131
|
-
});
|
132
|
-
|
133
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
134
|
-
expect(payload.strokeWeight).toBe(5.5);
|
135
|
-
expect(response.content[0].text).toContain("weight 5.5");
|
136
|
-
});
|
137
|
-
|
138
|
-
it("handles decimal strokeWeight values", async () => {
|
139
|
-
await callToolWithValidation({
|
140
|
-
nodeId: "nodeF",
|
141
|
-
r: 0.2,
|
142
|
-
g: 0.3,
|
143
|
-
b: 0.4,
|
144
|
-
a: 0.8,
|
145
|
-
strokeWeight: 0.5,
|
146
|
-
});
|
147
|
-
|
148
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
149
|
-
expect(payload.strokeWeight).toBe(0.5);
|
150
|
-
});
|
151
|
-
});
|
152
|
-
|
153
|
-
describe("RGB component handling", () => {
|
154
|
-
it("preserves pure black (0,0,0)", async () => {
|
155
|
-
await callToolWithValidation({
|
156
|
-
nodeId: "nodeG",
|
157
|
-
r: 0,
|
158
|
-
g: 0,
|
159
|
-
b: 0,
|
160
|
-
a: 1,
|
161
|
-
strokeWeight: 1,
|
162
|
-
});
|
163
|
-
|
164
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
165
|
-
expect(payload.color.r).toBe(0);
|
166
|
-
expect(payload.color.g).toBe(0);
|
167
|
-
expect(payload.color.b).toBe(0);
|
168
|
-
});
|
169
|
-
|
170
|
-
it("preserves zero red component", async () => {
|
171
|
-
await callToolWithValidation({
|
172
|
-
nodeId: "nodeH1",
|
173
|
-
r: 0,
|
174
|
-
g: 0.5,
|
175
|
-
b: 0.8,
|
176
|
-
a: 1,
|
177
|
-
strokeWeight: 2,
|
178
|
-
});
|
179
|
-
|
180
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
181
|
-
expect(payload.color.r).toBe(0);
|
182
|
-
expect(payload.color.g).toBe(0.5);
|
183
|
-
});
|
184
|
-
|
185
|
-
it("preserves zero green component", async () => {
|
186
|
-
await callToolWithValidation({
|
187
|
-
nodeId: "nodeH2",
|
188
|
-
r: 0.5,
|
189
|
-
g: 0,
|
190
|
-
b: 0.8,
|
191
|
-
a: 1,
|
192
|
-
strokeWeight: 2,
|
193
|
-
});
|
194
|
-
|
195
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
196
|
-
expect(payload.color.g).toBe(0);
|
197
|
-
});
|
198
|
-
|
199
|
-
it("preserves zero blue component", async () => {
|
200
|
-
await callToolWithValidation({
|
201
|
-
nodeId: "nodeH3",
|
202
|
-
r: 0.5,
|
203
|
-
g: 0.8,
|
204
|
-
b: 0,
|
205
|
-
a: 1,
|
206
|
-
strokeWeight: 2,
|
207
|
-
});
|
208
|
-
|
209
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
210
|
-
expect(payload.color.b).toBe(0);
|
211
|
-
});
|
212
|
-
});
|
213
|
-
|
214
|
-
describe("Zod validation (real validation layer)", () => {
|
215
|
-
it("rejects undefined r component", async () => {
|
216
|
-
await expect(callToolWithValidation({
|
217
|
-
nodeId: "nodeI1",
|
218
|
-
// r is missing
|
219
|
-
g: 0.5,
|
220
|
-
b: 0.8,
|
221
|
-
a: 1,
|
222
|
-
strokeWeight: 1,
|
223
|
-
})).rejects.toThrow();
|
224
|
-
|
225
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
226
|
-
});
|
227
|
-
|
228
|
-
it("rejects undefined g component", async () => {
|
229
|
-
await expect(callToolWithValidation({
|
230
|
-
nodeId: "nodeI2",
|
231
|
-
r: 0.5,
|
232
|
-
// g is missing
|
233
|
-
b: 0.8,
|
234
|
-
a: 1,
|
235
|
-
strokeWeight: 1,
|
236
|
-
})).rejects.toThrow();
|
237
|
-
|
238
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
239
|
-
});
|
240
|
-
|
241
|
-
it("rejects undefined b component", async () => {
|
242
|
-
await expect(callToolWithValidation({
|
243
|
-
nodeId: "nodeI3",
|
244
|
-
r: 0.5,
|
245
|
-
g: 0.8,
|
246
|
-
// b is missing
|
247
|
-
a: 1,
|
248
|
-
strokeWeight: 1,
|
249
|
-
})).rejects.toThrow();
|
250
|
-
|
251
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
252
|
-
});
|
253
|
-
|
254
|
-
it("rejects zero strokeWeight (should be positive)", async () => {
|
255
|
-
await expect(callToolWithValidation({
|
256
|
-
nodeId: "nodeI4",
|
257
|
-
r: 0.5,
|
258
|
-
g: 0.5,
|
259
|
-
b: 0.5,
|
260
|
-
a: 1,
|
261
|
-
strokeWeight: 0, // Should be positive
|
262
|
-
})).rejects.toThrow();
|
263
|
-
|
264
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
265
|
-
});
|
266
|
-
|
267
|
-
it("rejects negative strokeWeight", async () => {
|
268
|
-
await expect(callToolWithValidation({
|
269
|
-
nodeId: "nodeI5",
|
270
|
-
r: 0.5,
|
271
|
-
g: 0.5,
|
272
|
-
b: 0.5,
|
273
|
-
a: 1,
|
274
|
-
strokeWeight: -1, // Should be positive
|
275
|
-
})).rejects.toThrow();
|
276
|
-
|
277
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
278
|
-
});
|
279
|
-
|
280
|
-
it("rejects string strokeWeight", async () => {
|
281
|
-
await expect(callToolWithValidation({
|
282
|
-
nodeId: "nodeI6",
|
283
|
-
r: 0.5,
|
284
|
-
g: 0.5,
|
285
|
-
b: 0.5,
|
286
|
-
a: 1,
|
287
|
-
strokeWeight: "thick", // Invalid type
|
288
|
-
})).rejects.toThrow();
|
289
|
-
|
290
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
291
|
-
});
|
292
|
-
|
293
|
-
it("rejects out-of-range color values", async () => {
|
294
|
-
await expect(callToolWithValidation({
|
295
|
-
nodeId: "nodeI7",
|
296
|
-
r: 1.5, // Out of 0-1 range
|
297
|
-
g: 0.5,
|
298
|
-
b: 0.8,
|
299
|
-
a: 1,
|
300
|
-
strokeWeight: 1,
|
301
|
-
})).rejects.toThrow();
|
302
|
-
|
303
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
304
|
-
});
|
305
|
-
|
306
|
-
it("rejects negative color values", async () => {
|
307
|
-
await expect(callToolWithValidation({
|
308
|
-
nodeId: "nodeI8",
|
309
|
-
r: -0.1, // Negative value
|
310
|
-
g: 0.5,
|
311
|
-
b: 0.8,
|
312
|
-
a: 1,
|
313
|
-
strokeWeight: 1,
|
314
|
-
})).rejects.toThrow();
|
315
|
-
|
316
|
-
expect(mockSendCommand).not.toHaveBeenCalled();
|
317
|
-
});
|
318
|
-
});
|
319
|
-
|
320
|
-
describe("edge cases", () => {
|
321
|
-
it("handles transparent stroke correctly", async () => {
|
322
|
-
const response = await callToolWithValidation({
|
323
|
-
nodeId: "nodeJ",
|
324
|
-
r: 1,
|
325
|
-
g: 0,
|
326
|
-
b: 0,
|
327
|
-
a: 0, // Transparent red stroke
|
328
|
-
strokeWeight: 5,
|
329
|
-
});
|
330
|
-
|
331
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
332
|
-
expect(payload.color).toEqual({ r: 1, g: 0, b: 0, a: 0 });
|
333
|
-
expect(payload.strokeWeight).toBe(5);
|
334
|
-
expect(response.content[0].text).toContain("RGBA(1, 0, 0, 0)");
|
335
|
-
expect(response.content[0].text).toContain("weight 5");
|
336
|
-
});
|
337
|
-
|
338
|
-
it("handles boundary values", async () => {
|
339
|
-
const response = await callToolWithValidation({
|
340
|
-
nodeId: "nodeK",
|
341
|
-
r: 1,
|
342
|
-
g: 1,
|
343
|
-
b: 1,
|
344
|
-
a: 1,
|
345
|
-
strokeWeight: 10,
|
346
|
-
});
|
347
|
-
|
348
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
349
|
-
expect(payload.color).toEqual({ r: 1, g: 1, b: 1, a: 1 });
|
350
|
-
expect(payload.strokeWeight).toBe(10);
|
351
|
-
});
|
352
|
-
|
353
|
-
it("accepts valid decimal values", async () => {
|
354
|
-
await callToolWithValidation({
|
355
|
-
nodeId: "nodeL",
|
356
|
-
r: 0.123,
|
357
|
-
g: 0.456,
|
358
|
-
b: 0.789,
|
359
|
-
a: 0.5,
|
360
|
-
strokeWeight: 2.75,
|
361
|
-
});
|
362
|
-
|
363
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
364
|
-
expect(payload.color.r).toBeCloseTo(0.123);
|
365
|
-
expect(payload.color.g).toBeCloseTo(0.456);
|
366
|
-
expect(payload.color.b).toBeCloseTo(0.789);
|
367
|
-
expect(payload.color.a).toBeCloseTo(0.5);
|
368
|
-
expect(payload.strokeWeight).toBeCloseTo(2.75);
|
369
|
-
});
|
370
|
-
|
371
|
-
it("handles both defaults simultaneously", async () => {
|
372
|
-
const response = await callToolWithValidation({
|
373
|
-
nodeId: "nodeM",
|
374
|
-
r: 0.8,
|
375
|
-
g: 0.2,
|
376
|
-
b: 0.4,
|
377
|
-
// Both a and strokeWeight are undefined, should get defaults
|
378
|
-
});
|
379
|
-
|
380
|
-
const [command, payload] = mockSendCommand.mock.calls[0];
|
381
|
-
expect(payload.color.a).toBe(1); // Default opacity
|
382
|
-
expect(payload.strokeWeight).toBe(1); // Default weight
|
383
|
-
expect(response.content[0].text).toContain("RGBA(0.8, 0.2, 0.4, 1)");
|
384
|
-
expect(response.content[0].text).toContain("weight 1");
|
385
|
-
});
|
386
|
-
});
|
387
|
-
});
|