skills/canvas-component-push/SKILL.md
Push validated Canvas component changes to Drupal Canvas and recover from common push failures. Use only when the user explicitly requests a push/publish/sync action. Handles dependency-related push failures that require retry.
npx skillsauth add drupal-canvas/skills canvas-component-pushInstall 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.
Run this skill only when the user explicitly asks to push, publish, sync, or upload components to Canvas.
Do not run this skill automatically after component edits, validation, or task completion.
Before pushing, confirm the user has Drupal Canvas CLI installed and configured for their target site.
Before running any push command:
.env file in the project root. The CLI also reads
shell environment variables, ~/.canvasrc, and interactive-login tokens
stored in ~/.config/drupal-canvas/oauth.json (written by
npx canvas login).CANVAS_SITE_URL is set.CANVAS_ACCESS_TOKEN — set and non-empty in .env / the shell
(simplest for many setups), orCANVAS_CLIENT_ID and CANVAS_CLIENT_SECRET — both set (typical for
CI and service-style access).CANVAS_SITE_URL is set but
neither an access token nor client credentials appear in .env / the
shell, use npx canvas login (browser-based Canvas sign-in). Tokens are
stored under ~/.config/drupal-canvas/oauth.json (keyed by site URL). See
interactive login with Canvas Login.
Do not treat auth as missing until this fallback has been tried or ruled out.CANVAS_ACCESS_TOKEN is set, treat it as the active auth mode. It skips
the OAuth client credentials flow entirely, and CANVAS_CLIENT_ID,
CANVAS_CLIENT_SECRET, and CANVAS_SCOPE are ignored.When component work is complete and validated, ask the user if they would like
to push the current Canvas changes to Canvas. canvas push --yes will push all
current changes; it does not support selecting specific components. If there are
unrelated or unvalidated Canvas changes in the working tree, stop and ask the
user how they want to proceed. Make sure to use the right package manager. For
example, if using npm, run the following command:
npx canvas push --yes
If pages are included and they contain image props with external URLs, the first push may fail with an error like "Some pages contain media that references external URLs". This is expected until media is reconciled.
Supported authored page image sources:
http:// or https:// URLsdata:image/... URLsSupported image formats for reconciliation: .jpg, .png, .gif, .webp, and
.avif.
Local filesystem image upload through the CLI is not supported.
When working with pages that include image props:
Run the page push, for example:
npx canvas push --yes --include-pages
If Canvas reports external media references, run:
npx canvas reconcile-media
Re-run the page push:
npx canvas push --yes --include-pages
Pull pages back down to sync resolved inputs locally:
npx canvas pull --include-pages
After reconciliation/pull, page JSON may be updated so that:
src,
alt, width, and height_provenance object may be added with values such as target_id and
source_urlPreserve resolved image props and _provenance during later edits unless you
are intentionally replacing the media.
Default behavior: always retry failed pushes unless the error is clearly a connection/setup failure.
Retry pushes when the failure indicates the Canvas app connection is already working (for example, dependency/order-related component errors). Do not retry connection/setup failures.
If push fails with authentication, authorization, or network/connection errors, stop and ask the user to complete or verify setup first. This includes errors like invalid credentials, unauthorized/forbidden responses, DNS issues, connection refused, host unreachable, request timeout before reaching Canvas, or TLS/SSL handshake/certificate failures.
If CANVAS_ACCESS_TOKEN is the active auth mode, treat token-related failures
as setup failures. Do not retry on errors like an invalid or expired token, or
401 responses that indicate the token is not accepted.
Point the user to the official setup docs:
Ask them to verify CANVAS_SITE_URL and the active token or client credential
values from whichever config source the CLI is using first (for example: shell
environment variables, .env, ~/.canvasrc, or interactive-login
config/session); if those are unset or invalid, have them run
npx canvas login as a fallback (or again, to refresh interactive tokens).
Retry the push only after they confirm setup updates are complete.
When pushing multiple new components where one component depends on another
(e.g., hero imports heading), the push may fail with a message indicating
that a component doesn't exist. This happens when a component that includes
another gets pushed before its dependency.
This is expected behavior. Simply retry the push command. On subsequent attempts, the dependencies that were successfully pushed in the previous run will already exist, allowing the dependent components to push successfully.
Example scenario:
hero fails because heading doesn't exist yet, but
heading pushes successfully.hero now succeeds because heading exists.If pushes continue to fail after multiple retries, check that all required dependency components are part of the current local changes or already exist in Canvas.
testing
Use for any task touching site chrome — header, footer, sidebar, or global navigation that repeats across pages — and for any region-spec work (create, modify, review, validate region JSON, or the project-level layout component). Also load when a task creates or edits multiple pages that share chrome, or asks for a "site" or "navigation between pages"; shared chrome belongs in regions, never inlined into page JSON.
content-media
Create and modify content templates that map Drupal content entities to Canvas component layouts. Use when asked to (1) Create a new content template, (2) Modify an existing content template, (3) Add or change entity field mappings in a template, (4) Compose components in a content template via slots. Content templates live in the configured `contentTemplatesDir` (default `content-templates/`) and define how Drupal entity types, bundles, and view modes render as Canvas component trees.
tools
Plans and builds Drupal Canvas navigation UI (main nav, footer links, sidebar nav, mobile drawers, breadcrumbs) using design decomposition for structure and props/slots, then JSON:API menu or page-context patterns from canvas-data-fetching. Use when the user asks for navigation, header or footer links, menus, menu_items, mobile nav, or breadcrumb trails. Run after canvas-design-decomposition for layout and API sketches; follow canvas-data-fetching for SWR, JsonApiClient, sortMenu, and menu fallbacks.
development
Plans structure for a component library with props/slots and right-sized component granularity. Run before building or adding Canvas components (new `src/components/` folders, component.yml, React), or for plan-only / breakdown-only work, whenever UI must map to a coherent tree. Mandatory for every new Figma frame or greenfield screen—repository drafts do not replace phases A–G.