pencil-mcp-find-empty-space-on-canvas
$
npx mdskill add partme-ai/full-stack-skills/pencil-mcp-find-empty-space-on-canvasFinds empty space on a Pencil canvas to place artboards without overlap, triggered by explicit Pencil-related requests.
- Helps organize the canvas by planning artboard placement to avoid overlapping existing elements.
- Integrates with the Pencil MCP tool, specifically the find_empty_space_on_canvas function.
- Uses intent recognition to activate only when users mention Pencil in design tasks.
- Delivers results by recommending optimal positions based on input width, height, and optional direction.
SKILL.md
.github/skills/pencil-mcp-find-empty-space-on-canvasView on GitHub ↗
---
name: pencil-mcp-find-empty-space-on-canvas
description: Smartly find empty canvas space. Use to automatically plan artboard placement to avoid overlap and keep the canvas organized.
license: Complete terms in LICENSE.txt
---
## Tools
This skill is designed to call the Pencil MCP tool:
* `find_empty_space_on_canvas`
If your client namespaces MCP tools, it may appear as `mcp__pencil__find_empty_space_on_canvas`.
## When to use this skill
### Intent Recognition (CRITICAL)
Even if a trigger phrase matches, you must **verify the user's intent**:
1. Is the user explicitly asking to use "Pencil"?
2. Is the current conversation context clearly about "Pencil" design tasks?
**If the answer is NO, do NOT use this skill.**
**CRITICAL PREREQUISITE:**
**You must ONLY use this skill when the user EXPLICITLY mentions "Pencil".**
**ALWAYS use this skill when:**
- You are about to insert a new Frame or Artboard **in Pencil**.
- You want to ensure the new element doesn't overlap with existing work **on the Pencil canvas**.
- You need to organize the canvas.
**Trigger phrases include:**
- "Find space for new screen in Pencil" (为 Pencil 新页面找位置)
- "Where can I draw in Pencil?" (我在 Pencil 哪里画?)
- "Pencil avoid overlap" (Pencil 避免重叠)
## Input Parameters
* **`width`** (number, required): The width of the required space.
* **`height`** (number, required): The height of the required space.
* **`direction`** (string, optional): Search direction relative to node (e.g., "RIGHT", "BOTTOM").
* **`nodeId`** (string, optional): Starting reference node. If omitted, searches around entire canvas content.
* **`padding`** (number, optional): Minimum padding distance (default: 100).
## How to use this skill
1. **Estimate Size**: Determine the size of the element you plan to create.
2. **Call Tool**: `find_empty_space_on_canvas(width=..., height=...)`.
3. **Use Result**: The tool returns `{x, y}` coordinates. Use these coordinates in your subsequent `batch_design` call to insert the Frame.
## Examples
### 1. Simple: Find Any Space
Find a spot for a small element (e.g., 100x100).
See [1-find-any.json](examples/1-find-any.json).
### 2. Medium: Place Next to Node
Find space to the right of an existing frame.
See [2-place-next-to.json](examples/2-place-next-to.json).
### 3. Complex: Organized Layout
Find space for a large dashboard with ample padding below the header section.
See [3-organized-layout.json](examples/3-organized-layout.json).
## Keywords
**English keywords:**
find space, empty canvas, layout planning, avoid overlap, next to node, smart placement
**Chinese keywords (中文关键词):**
查找空白, 空画布, 布局规划, 避免重叠, 节点旁, 智能放置