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>
4.0 KiB
4.0 KiB
title, impact, impactDescription, type, tags
| title | impact | impactDescription | type | tags | |||||
|---|---|---|---|---|---|---|---|---|---|
| Mouse Button Modifiers Represent Intent, Not Physical Buttons | LOW | Mouse modifiers .left/.right/.middle may not match physical buttons on left-handed mice or other input devices | gotcha |
|
Mouse Button Modifiers Represent Intent, Not Physical Buttons
Impact: LOW - Vue's mouse button modifiers (.left, .right, .middle) are named based on a typical right-handed mouse layout, but they actually represent "main", "secondary", and "auxiliary" pointing device triggers. This means they may not correspond to physical button positions on left-handed mice, trackpads, or other input devices.
Task Checklist
- Understand that
.leftmeans "primary/main" action, not physical left button - Understand that
.rightmeans "secondary" action (usually context menu) - Consider accessibility when relying on specific mouse buttons
- Don't assume users have a traditional right-handed mouse
Potentially Confusing:
<template>
<!-- Documentation says "left click only" but... -->
<div @click.left="handlePrimaryAction">
<!-- On left-handed mouse: fires on physical RIGHT button -->
<!-- On trackpad: fires on single-finger tap -->
<!-- On touch screen: fires on tap -->
</div>
</template>
Clear Understanding:
<template>
<!-- Think of it as "primary action" -->
<div @click.left="handlePrimaryAction">
Primary action (main button)
</div>
<!-- Think of it as "secondary/context action" -->
<div @click.right="handleSecondaryAction">
Secondary action (context menu button)
</div>
<!-- Think of it as "auxiliary action" -->
<div @click.middle="handleAuxiliaryAction">
Auxiliary action (scroll wheel click)
</div>
</template>
What the Modifiers Actually Mean
// Vue modifier → MouseEvent.button value → Actual meaning
// .left → button === 0 → "Main button" (primary action)
// .right → button === 2 → "Secondary button" (context menu)
// .middle → button === 1 → "Auxiliary button" (middle click)
// The browser handles remapping for:
// - Left-handed mouse settings
// - Trackpad gestures
// - Touch devices
// - Stylus/pen input
Device Behaviors
<!-- How different devices trigger these modifiers -->
<!-- Traditional right-handed mouse -->
<!-- .left = physical left button -->
<!-- .right = physical right button -->
<!-- .middle = scroll wheel press -->
<!-- Left-handed mouse (swapped in OS settings) -->
<!-- .left = physical RIGHT button (remapped by OS) -->
<!-- .right = physical LEFT button (remapped by OS) -->
<!-- .middle = scroll wheel press -->
<!-- Trackpad -->
<!-- .left = single-finger tap/click -->
<!-- .right = two-finger tap/click (or corner click) -->
<!-- .middle = three-finger tap (if configured) -->
<!-- Touch screen -->
<!-- .left = tap -->
<!-- .right = long press (context menu) -->
<!-- .middle = typically not available -->
Best Practice: Semantic Naming in Comments
<template>
<!-- Use comments to clarify intent -->
<!-- Primary action (select item) -->
<div @click.left="selectItem">
<!-- Context menu action -->
<div @click.right.prevent="showContextMenu">
<!-- Open in new tab (auxiliary/middle click convention) -->
<a @click.middle="openInNewTab" href="...">
</template>
Accessibility Considerations
<template>
<!-- Don't require specific mouse buttons for essential actions -->
<!-- BETTER: Provide keyboard alternatives -->
<div
@click.left="select"
@click.right.prevent="showMenu"
@keydown.enter="select"
@keydown.space="select"
@contextmenu.prevent="showMenu"
tabindex="0"
role="button"
>
Accessible interactive element
</div>
</template>