Pulled ALL skills from 15 source repositories: - anthropics/skills: 16 (docs, design, MCP, testing) - obra/superpowers: 14 (TDD, debugging, agents, planning) - coreyhaines31/marketingskills: 25 (marketing, CRO, SEO, growth) - better-auth/skills: 5 (auth patterns) - vercel-labs/agent-skills: 5 (React, design, Vercel) - antfu/skills: 16 (Vue, Vite, Vitest, pnpm, Turborepo) - Plus 13 individual skills from various repos Mosaic Stack is not limited to coding — the Orchestrator and subagents serve coding, business, design, marketing, writing, logistics, analysis, and more. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
3.1 KiB
3.1 KiB
title, impact, impactDescription, type, tags
| title | impact | impactDescription | type | tags | |||||
|---|---|---|---|---|---|---|---|---|---|
| Use PascalCase for Component Names | LOW | Improves code clarity and IDE support, but both cases work | best-practice |
|
Use PascalCase for Component Names
Impact: LOW - Vue supports both PascalCase (<MyComponent>) and kebab-case (<my-component>) in templates, but PascalCase is recommended. It provides better IDE support, clearly distinguishes Vue components from native HTML elements, and avoids confusion with web components (custom elements).
Task Checklist
- Name component files in PascalCase (e.g.,
UserProfile.vue) - Use PascalCase when referencing components in templates
- Use kebab-case only when required (in-DOM templates)
- Be consistent across the entire codebase
Less Ideal:
<script setup>
import userProfile from './user-profile.vue'
</script>
<template>
<!-- Works but harder to distinguish from HTML elements -->
<user-profile :user="currentUser" />
<header>Native HTML</header>
<footer>Native HTML</footer>
</template>
Recommended:
<script setup>
import UserProfile from './UserProfile.vue'
</script>
<template>
<!-- Clear visual distinction: components vs HTML elements -->
<UserProfile :user="currentUser" />
<header>Native HTML</header>
<footer>Native HTML</footer>
</template>
Why PascalCase?
1. Visual Distinction
<template>
<!-- Immediately clear what's a component vs native HTML -->
<PageHeader /> <!-- Component -->
<header>...</header> <!-- Native HTML -->
<NavigationMenu /> <!-- Component -->
<nav>...</nav> <!-- Native HTML -->
<UserAvatar /> <!-- Component -->
<img src="..." /> <!-- Native HTML -->
</template>
2. IDE Auto-completion
PascalCase names are valid JavaScript identifiers, enabling better IDE support:
- Auto-import suggestions
- Go-to-definition
- Refactoring tools
3. Avoids Web Component Confusion
Web Components (custom elements) require kebab-case with a hyphen. Using PascalCase for Vue components avoids any confusion:
<template>
<!-- Vue component -->
<MyButton @click="handle" />
<!-- Web component (custom element) -->
<my-custom-element></my-custom-element>
</template>
Exception: In-DOM Templates
When using in-DOM templates (HTML files without build step), you MUST use kebab-case because HTML is case-insensitive:
<!-- index.html - in-DOM template -->
<div id="app">
<!-- PascalCase won't work in HTML files -->
<!-- <UserProfile></UserProfile> --> <!-- WRONG -->
<!-- Must use kebab-case -->
<user-profile :user="currentUser"></user-profile>
</div>
Vue's Automatic Resolution
Vue automatically resolves PascalCase components to both casings:
<script setup>
import MyComponent from './MyComponent.vue'
</script>
<template>
<!-- Both work, but PascalCase is preferred -->
<MyComponent />
<my-component />
</template>