plugins/canvas-apps/skills/canvas-app/SKILL.md
Creates or edits a Power Apps Canvas App through the Canvas Authoring MCP coauthoring session. Handles new app generation from requirements, simple inline edits, and complex multi-screen changes with parallel screen builders. Triggers on requests to create, build, generate, modify, update, change, or edit a Canvas App or .pa.yaml files.
npx skillsauth add microsoft/power-platform-skills canvas-appInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Create or edit a Power Apps canvas app for the following requirements:
$ARGUMENTS
This skill handles both creating and editing canvas apps through a unified workflow. It syncs the current app state to detect whether the app has existing content, then routes accordingly:
Two specialist agents are used for planned work:
canvas-app-planner — discovers available controls, APIs, and data sources; gathers
control property definitions; and writes the shared plan document (canvas-app-plan.md)
and App.pa.yaml. Receives the approved plan from the skill.canvas-screen-builder — writes or modifies exactly one screen's YAML; multiple
builders run in parallel after the plan is approvedYou (the skill) coordinate the agents, detect mode, design and present the plan for user approval, and own the compilation + error-fixing loop after all screens are written.
Before syncing or editing, create a subfolder to contain the app's YAML files:
$ARGUMENTSexpense-tracker, "my travel planner" →
my-travel-planner)Bash: mkdir -p <folder-name>Pass this absolute path as the working directory in every agent prompt below.
Call the sync_canvas MCP tool targeting the working directory. This pulls the current app
state from the coauthoring session into local .pa.yaml files. Only proceed after
sync_canvas completes successfully.
After sync_canvas completes, read the synced .pa.yaml files and check whether the app
has meaningful content. An app is considered empty if:
.pa.yaml files were written, orGroupContainer) with no
leaf controls inside themIf the app is empty → CREATE mode. Proceed to Phase 3.
If the app has meaningful content → EDIT mode. Skip Phase 3 and proceed to Phase 4.
Use AskUserQuestion to collect design preferences that cannot be reliably inferred from
$ARGUMENTS. Parse $ARGUMENTS first to determine which questions to skip — but a
short request like "visitor check-in app" or "expense tracker" leaves most preferences
unspecified and you MUST ask.
Call AskUserQuestion with the applicable questions from the table below (include only the
ones that need answers):
| Question | Header | When to Ask | Options |
|----------|--------|-------------|---------|
| Who will primarily use this app, and on what device? | Target Users & Device | Only if not clear from $ARGUMENTS | (3–4 dynamically inferred options that combine the user role with their likely device, e.g., for "visitor check-in": Front desk staff on desktop/tablet, Security team on tablet, Self-service kiosk on tablet, Visitors on their phone) |
| Do you have a screenshot or mockup for reference? (paste an image or provide a file path) | Reference | Only if user has NOT already attached/pasted an image with their request | Yes I'll share one now, No just pick a direction for me |
| What aesthetic direction? | Aesthetic | Only if not clear from $ARGUMENTS (skip if user already described a visual direction like "dark themed", "minimal", "corporate style", or provided a reference image) | Clean & Professional (Recommended), Bold & High-Contrast, Soft & Approachable, Dense & Utilitarian |
| Which features do you need? (multi-select) | Features | Only if $ARGUMENTS is vague on features | (3–4 dynamically inferred options based on app purpose + target users) |
Rules:
$ARGUMENTS and any attached images, skip the
wizard entirely and proceed directly to Phase 5.AskUserQuestion call — do not ask them one at a time.Target users & device influence design decisions:
After collecting preferences, proceed to Phase 5 (Plan).
Read all synced .pa.yaml files. Based on $ARGUMENTS and the current app state, determine
whether this is a simple or complex edit:
Simple — all of the following are true:
Examples: change a button color, update label text, fix a formula, adjust a control size.
Complex — any of the following are true:
Examples: add a settings screen, redesign the home screen layout, integrate a new connector, change the navigation flow across the app.
Read ${CLAUDE_PLUGIN_ROOT}/references/TechnicalGuide.md before making changes.
Apply the changes directly:
Edit the relevant .pa.yaml files with the required changes, following conventions
from TechnicalGuide.md.
Validate by calling compile_canvas on the working directory after making changes.
On failure, read the errors, fix with Edit, and re-compile. Iterate until clean.
Present a brief summary:
Edit complete. [1-2 sentence description of what was changed.] Compiled clean after [N] pass(es).
Stop here. The simple edit path is complete — do not continue to Phase 5 or beyond.
You (the skill) own plan design and user approval. After approval, invoke the
canvas-app-planner agent to discover resources, gather control definitions, and write the
plan document.
Read both reference documents before designing the plan:
${CLAUDE_PLUGIN_ROOT}/references/TechnicalGuide.md${CLAUDE_PLUGIN_ROOT}/references/DesignGuide.mdInternalize both. These govern every design decision you will make.
Based on the user preferences from Phase 3 and the user's requirements, reason through:
Read all .pa.yaml files in the working directory (you may have already read them in
Phase 4). Based on the current app state and the user's edit requirements, reason through:
Enter plan mode (EnterPlanMode) and present the plan.
## Canvas App Plan
### Screens ([N] total)
| Screen | File | Purpose | Key Controls |
|--------|------|---------|--------------|
| [Name] | [Name].pa.yaml | [one-line description] | [2-3 controls] |
### Data Strategy
[How data will be loaded — data sources used, or "collections/mock data"]
### Aesthetic Direction
[e.g., "Bold & editorial — high-contrast dark background, accent RGBA(255,90,60,1), card-based layout, strong typographic hierarchy"]
## Canvas Edit Plan
### Screens to Modify ([N] total)
| Screen | File | Summary of Changes |
|--------|------|--------------------|
| [Name] | [Name].pa.yaml | [one-line description of changes] |
### Screens to Add ([N] total, if any)
| Screen | File | Purpose |
|--------|------|---------|
| [Name] | [Name].pa.yaml | [one-line description] |
### Approach
[e.g., "Preserving existing dark theme — updating button palette on Home screen and adding a
new Settings screen with consistent RGBA values extracted from existing files"]
Then call ExitPlanMode to request user approval.
After approval, invoke the canvas-app-planner agent using the Task tool. The agent
will discover available resources, gather control property definitions, write App.pa.yaml
(CREATE only), and write canvas-app-plan.md.
Pass a prompt that includes the approved plan. The agent does NOT redesign the plan or interact with the user — it discovers resources, enriches the plan with control definitions, and writes the output files.
Example prompt:
You are the canvas-app-planner agent. Write the plan document for a Canvas App.
Mode: CREATE
Requirements: [paste $ARGUMENTS here]
Approved plan: [paste the full plan you presented in Step 5.3 — screens, data strategy, aesthetic direction, all RGBA values]
User preferences (from wizard):
- Target users & device: [answer]
- Aesthetic direction: [answer]
- Features: [answer]
- Reference image: [observations, or "none provided"]
Working directory: [absolute path from Phase 0] Plugin root: ${CLAUDE_PLUGIN_ROOT}
Follow the instructions in your agent file. Discover resources, gather control definitions, write App.pa.yaml and canvas-app-plan.md to the working directory. Return the screen list and plan document path when complete.
Example prompt:
You are the canvas-app-planner agent. Write the plan document for edits to a Canvas App.
Mode: EDIT
Edit requirements: [paste $ARGUMENTS here]
Approved plan: [paste the full plan you presented in Step 5.3 — screens to modify/add, approach, all RGBA values]
Current app state:
- Palette: [exact RGBA values extracted from existing files]
- Variables: [variable names found in existing files]
- Layout strategy: [AutoLayout / ManualLayout as found in existing files]
- Screens: [list of existing screens and their key controls]
Working directory: [absolute working directory path] Plugin root: ${CLAUDE_PLUGIN_ROOT} Synced files: [list of .pa.yaml filenames]
Follow the instructions in your agent file. Discover resources for new controls, gather control definitions, write canvas-app-plan.md to the working directory. Return the list of screens and the plan document path when complete.
Wait for the planner to finish. Do not proceed to Phase 6 until the planner task completes successfully.
After the planner completes, read canvas-app-plan.md from the working directory.
Extract the screen list from the ## Screens table — collect each screen name, its target
file name, and its action (Create or Modify).
Invoke one canvas-screen-builder agent per screen. Fire all invocations in a single
message (parallel execution) — do not wait for one screen to finish before starting the
next.
For each screen, pass a prompt that includes:
canvas-app-plan.mdExample prompt per screen:
You are the canvas-screen-builder agent. [Create / Modify] the [Screen Name] screen.
- Action: [Create / Modify]
- Target file: [ScreenName].pa.yaml
- Plan document: [absolute path to canvas-app-plan.md]
- Working directory: [absolute path from Phase 0]
Follow the instructions in your agent file. [Write / Edit] [ScreenName].pa.yaml and return your result when done. Do not call compile_canvas — validation is handled by the skill.
Wait for all screen-builder tasks to complete before proceeding.
After all screen-builders have finished writing their files, call compile_canvas on the
working directory.
On success: Proceed to Phase 8.
On failure: Read every error in the output. Errors will reference specific files and line numbers. For each error:
Read the referenced .pa.yaml fileEditcompile_canvas againRepeat until compile_canvas reports no errors. Do not give up after a single fix attempt —
iterate until the entire directory compiles clean.
Track how many compile_canvas passes were needed.
Delete canvas-app-plan.md from the working directory using Bash:
rm <working-directory>/canvas-app-plan.md
Present a final summary based on the mode:
CREATE mode:
App generation complete.
| Screen | File | Status | |--------|------|--------| | [Screen Name] | [filename].pa.yaml | Created |
Compiled clean after [N] pass(es). | Screens: [N] | Data: [source or collections]
EDIT mode (complex):
Edit complete.
| Action | Screen | File | Status | |--------|--------|------|--------| | [Create / Modify] | [Screen Name] | [filename].pa.yaml | Done |
Compiled clean after [N] pass(es).
If any errors remain after exhausting fixes, report them explicitly so the user knows what needs manual attention.
tools
Configure the Canvas Authoring MCP server for the current coauthoring session. USE WHEN "configure MCP", "set up MCP server", "MCP not working", "connect Canvas Apps MCP", "canvas-authoring not available", "MCP not configured", "set up canvas apps". DO NOT USE WHEN prerequisites are missing — direct the user to install .NET 10 SDK first.
development
Use when the user asks to "set up authentication", "add login", "add logout", "add sign in", "enable auth", "add role-based access", "add authorization", "protect routes", "configure identity provider", "configure Entra ID", "configure Entra External ID", "configure OpenID Connect", "add OIDC", "set up SAML", "set up WS-Federation", "set up local login", "add username password", "add Facebook login", "add Google sign in", "add Microsoft Account", "set up invitation login", or otherwise wants to set up authentication (login/logout) and role-based authorization for their Power Pages code site using any supported identity provider (Microsoft Entra ID, Entra External ID, OpenID Connect, SAML2, WS-Federation, local authentication, Microsoft Account, Facebook, or Google).
development
Creates, updates, and deploys Power Apps generative pages for model-driven apps using React v17, TypeScript, and Fluent UI V9. Orchestrates specialist agents for planning, entity creation, and code generation. Use it when user asks to build, retrieve, or update a page in an existing Microsoft Power Apps model-driven app. Use it when user mentions "generative page", "page in a model-driven", or "genux".
development
Creates a new Power Pages code site (SPA) using React, Angular, Vue, or Astro. Guides through the full process from initial concept to deployed site: requirements discovery, scaffolding, component planning, design, implementation, validation, and deployment. Use when the user wants to create, build, or scaffold a new Power Pages website or portal.