Catalog
affaan-m/ui-to-vue

affaan-m

ui-to-vue

Use when the user has UI screenshots or design exports that need batch conversion into Vue 3 components, especially with Vant, Element Plus, or Ant Design Vue.

global
0installs0uses~1.2k
v1.0Saved May 15, 2026

UI To Vue

Batch-convert UI design screenshots into Vue 3 Composition API component code.

When to Use

  • The user provides a directory of design screenshots or design-export images.
  • The target application is Vue 3.
  • The user wants a first pass of page components, shared components, and router wiring.
  • The user specifies Vant, Element Plus, or Ant Design Vue as the component library.

When Not to Use

  • The user has only one screenshot and wants a bespoke component.
  • The target project is not Vue.
  • The design requires detailed interaction logic, data flow, or accessibility review.
  • The screenshots contain private customer data that cannot be sent to an external model API.

Inputs

Use an input directory that groups screenshots by module and page state:

screenshots/
|-- HomePage/
|   |-- List/
|   |   |-- HomePage-List-Default@3x.png
|   |   `-- cut-images/
|   |-- cut-images/
|   `-- HomePage-Default@3x.png
`-- cut-images/

Supported cut-image directory names include assets, icons, sprites, cut, images, and cut-images.

Conversion Model

  • Page grouping: combine related screenshots into one page component when they represent list, detail, form, loading, or empty states.
  • UI library mapping: map native visual elements to Vant, Element Plus, or Ant Design Vue components where practical.
  • Cut-image priority: prefer page-level assets, then module-level assets, then global shared assets.
  • Component extraction: extract repeated UI regions into shared components when they appear more than once.

CLI Usage

Run the converter with npx so the documented command works without relying on a global binary:

export DASHSCOPE_API_KEY=your_key
npx ui-to-vue-converter@1.0.2 --input ./screenshots --ui vant --output ./src

For desktop UI libraries:

npx ui-to-vue-converter@1.0.2 --input ./designs --ui element-plus --output ./src
npx ui-to-vue-converter@1.0.2 --input ./designs --ui antd-vue --output ./src

If the package is installed globally, the ui-to-vue binary can be used directly:

npm install -g ui-to-vue-converter@1.0.2
ui-to-vue --input ./screenshots --ui vant --output ./src

Options

Option Description Default
--input Design image directory ./screenshots
--ui UI library: vant, element-plus, or antd-vue vant
--output Output directory ./src
--config Config file path ./.ui-to-vue.config.json

API Key Handling

The converter can read DashScope credentials from a config file or from the environment. Prefer an environment variable in repositories:

export DASHSCOPE_API_KEY=your_key

If a local config file is required, keep it out of version control:

{
  "apiKey": "your_dashscope_key",
  "input": "./designs",
  "ui": "vant",
  "output": "./src"
}
.ui-to-vue.config.json

Security and Privacy

  • Treat design screenshots as source material that may be sent to an external model API.
  • Do not run this flow on private customer designs without permission.
  • Pin the converter version in repeatable workflows instead of using @latest.
  • Review generated Vue code before committing it.
  • Do not commit .ui-to-vue.config.json, API keys, generated secrets, or customer screenshots.

Output Review Checklist

  • Page components were generated under views/ or the chosen output directory.
  • Repeated UI regions were extracted into components/ only when reuse is clear.
  • Router output is compatible with the target project's router style.
  • Generated components use the requested UI library consistently.
  • Generated CSS units match the design baseline.
  • The code passes the project's formatter, linter, type checker, and build.
  • Placeholder copy, mock data, and generated assets were reviewed before commit.

Troubleshooting

Issue Check
401 or authentication error Confirm DASHSCOPE_API_KEY is set in the shell running the command.
command not found: ui-to-vue Use the npx ui-to-vue-converter@1.0.2 form or install the package globally.
Cut images are ignored Confirm the asset directory name is supported and nested under the matching page or module.
Components ignore the requested UI library Re-run with an explicit --ui value and inspect the generated imports.
Generated layout dimensions look wrong Confirm the screenshot export width matches the target library baseline.

References

  • npm package: ui-to-vue-converter
Files1
1 files · 1.0 KB

Select a file to preview

Overall Score

82/100

Grade

B

Good

Safety

82

Quality

78

Clarity

88

Completeness

78

Summary

This skill guides agents to batch-convert UI design screenshots into Vue 3 components using an external CLI tool (ui-to-vue-converter). The agent orchestrates CLI execution, manages API key configuration, organizes screenshot inputs, and validates generated component output against a checklist. The skill handles external model API integration (DashScope) and includes clear privacy/security boundaries.

Detected Capabilities

file readcli executionexternal api integrationenvironment variable readjson config parsingcode generation

Trigger Keywords

Phrases that MCP clients use to match this skill to user intent.

convert ui to vuebatch design screenshotsvant component generationelement plus scaffoldingui library conversion

Risk Signals

INFO

Environment variable read for DASHSCOPE_API_KEY

API Key Handling section
INFO

External API call to DashScope model service

When to Use, Security and Privacy sections
WARNING

Design screenshot content sent to external model

Security and Privacy section
INFO

CLI tool installation and execution via npx

CLI Usage section

Use Cases

  • Convert batch UI screenshots to Vue 3 components with Vant library
  • Map design exports to Element Plus component scaffolding
  • Generate Ant Design Vue components from wireframes in bulk
  • Extract shared components from repeated UI regions across design screenshots
  • Set up router wiring and page structure from multi-state design exports

Quality Notes

  • Excellent scope definition: 'When to Use' and 'When Not to Use' sections clearly distinguish appropriate vs. inappropriate use cases
  • Strong privacy guidance: explicitly warns against processing private customer data and recommends permission verification
  • Comprehensive troubleshooting table covers common failure modes with actionable checks
  • Input structure documented with directory hierarchy examples for asset organization
  • Output checklist provides concrete validation steps for generated code (linting, type checking, library consistency)
  • Security best practice documented: version pinning, config file exclusion in .gitignore, code review before commit
  • CLI usage shows both npx and global installation paths, reducing friction for users
  • Missing: no error handling guidance for agent when conversion fails or partial completion occurs
  • Missing: no documented limits on batch size, image dimensions, or API rate limits
  • Missing: no example of expected output structure (where components land, naming conventions for generated files)
Model: claude-haiku-4-5-20251001Analyzed: May 15, 2026

Reviews

Add this skill to your library to leave a review.

No reviews yet

Be the first to share your experience.

Add affaan-m/ui-to-vue to your library

Command Palette

Search for a command to run...