Full-stack-skills stitch-vue-bootstrap-components
Convert Stitch designs into modular Vite + Vue 3 + BootstrapVue/BootstrapVueNext components. Use when the user mentions Bootstrap or BootstrapVue conversion from Stitch. Retrieves screen HTML via Stitch MCP get_screen, maps Tailwind to Bootstrap utilities, enforces Vue SFC structure with Bootstrap components (b-container, b-row, b-col, b-button, b-card).
git clone https://github.com/partme-ai/full-stack-skills
T=$(mktemp -d) && git clone --depth=1 https://github.com/partme-ai/full-stack-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/stitch-skills/stitch-vue-bootstrap-components" ~/.claude/skills/partme-ai-full-stack-skills-stitch-vue-bootstrap-components && rm -rf "$T"
skills/stitch-skills/stitch-vue-bootstrap-components/SKILL.mdStitch to Vue 3 + Bootstrap Components
Constraint: Only use this skill when the user explicitly mentions "Stitch" and converting Stitch screens to Vue 3 + Bootstrap (Vite, .vue SFC, BootstrapVue Vue 3 or BootstrapVueNext).
You are a frontend engineer turning Stitch designs into clean, modular Vue 3 + Bootstrap code. Use Stitch MCP (or stitch-mcp-get-screen) to retrieve screen metadata and HTML; use scripts and resources in this skill for reliable fetch and quality checks. Target stack: Vue 3 + BootstrapVue Vue.js 3 Support (@vue/compat) or BootstrapVueNext (Bootstrap 5 + Vue 3).
Prerequisites
- Stitch MCP Server (https://stitch.withgoogle.com/docs/mcp/guide/)
- Node.js and npm (for Vite/Vue 3 project)
- Stitch project and screen IDs — two ways: (1) From a Stitch design URL: parse projectId (path) and screenId (
query). (2) When no URL or when browsing: use stitch-mcp-list-projects and stitch-mcp-list-screens to discover and obtain IDs.node-id
Official Documentation
- Bootstrap Vue: Official · Vue 3 support · Docs · Components · GitHub
- Full links and usage: references/official.md
Retrieval and Networking
- Discover Stitch MCP prefix: Run
to find the prefix (e.g.list_tools
).mcp_stitch__stitch: - Fetch screen metadata: Call
with[prefix]:get_screen
andprojectId
(numeric IDs) to get design JSON,screenId
,htmlCode.downloadUrl
, dimensions, deviceType.screenshot.downloadUrl - High-reliability HTML download: AI fetch tools can fail on Google Cloud Storage URLs. Use Bash to run the skill script:
Ensure the URL is quoted.bash scripts/fetch-stitch.sh "<htmlCode.downloadUrl>" "temp/source.html" - Visual reference: Use
to confirm layout and details.screenshot.downloadUrl
Architectural Rules
- Modular components: Split the design into separate .vue files; avoid one giant SFC.
- Logic isolation: Put event handlers and composables in
or within script setup.src/composables/ - Data decoupling: Move static text, image URLs, and lists into
(or .ts).src/data/mockData.js - Bootstrap components only (use framework components when available): Use b-card for cards, b-alert for tips; do not use div.card or custom .card-header/.tips-text. Use
,<b-container>
,<b-row>
,<b-col>
, etc. per references/contract.md; do not use raw<b-button>
or<button class="btn">
when b-* applies.<div class="card"> - Project-specific: Omit third-party license headers from generated components.
Execution Steps
- Environment: If the project has no
, runnode_modules
.npm install - Data layer: Create
from the design content.src/data/mockData.js - Component drafting: Use
as base; replace placeholder with real component name and Bootstrap Vue tags per contract.resources/component-template.vue - Wiring: Update the app entry (e.g.
or router) to render the new components.App.vue - Quality check: Verify against
; runresources/architecture-checklist.md
to confirm visually.npm run dev
Integration with This Repo
- Get screen: Use stitch-mcp-get-screen with projectId and screenId. Obtain IDs either by parsing a Stitch design URL or by using stitch-mcp-list-projects and stitch-mcp-list-screens when no URL or when the user needs to browse/select.
- Design spec: If Stitch was generated with stitch-ui-design-spec-bootstrap constraints, map to Vue SFC and Bootstrap Vue components. If converting from Stitch HTML (e.g. get_screen htmlCode), use references/tailwind-to-bootstrap.md for Tailwind utility → Bootstrap utilities/components, then references/contract.md for component API.
- Design system: If the project has DESIGN.md (from stitch-design-md), align colors and spacing with that system when mapping to Bootstrap tokens.
Troubleshooting
- Fetch errors: Quote the URL in the bash command; ensure
is executable.scripts/fetch-stitch.sh - Component mapping: Follow references/contract.md for layout (
/b-container
/b-row
), buttons (b-col
), forms (b-button
,b-form-group
), cards (b-form-input
).b-card
Example: Stitch HTML to Bootstrap Vue SFC
Stitch HTML with Tailwind card:
<div class="bg-white rounded-lg shadow p-4"><h2 class="text-lg font-bold">Title</h2><button class="bg-blue-500 text-white px-4 py-2 rounded">Action</button></div>
Converted Bootstrap Vue component:
<template> <b-card title="Title"> <b-button variant="primary">Action</b-button> </b-card> </template>
Key mapping:
div.rounded-lg.shadow becomes <b-card>, raw <button> becomes <b-button variant="primary">, Tailwind colors map to Bootstrap variants.
References
- Examples
- Scripts
- Component index (per-component doc links)
- Tailwind → Bootstrap Vue — Tailwind utility → Bootstrap when converting Stitch HTML.
- Contract (Bootstrap mapping)
- Component API (props/events quick reference)
- Official documentation
- Architecture checklist
- Component template
- Stitch API / MCP