Skillquality 0.47

craft-site

Craft CMS 5 front-end Twig development — atomic design, template architecture, component patterns, Vite buildchain. Covers the full site template surface: atoms, molecules, organisms, props/extends/block pattern, layout chains, view routing, content builders, image presets, Tailw

Price
free
Protocol
skill
Verified
no

What it does

Craft CMS 5 — Front-End Twig (Atomic Design)

Atomic design system patterns for Craft CMS 5 site templates. Vanilla Twig — no module dependency. Works with any Craft 5 project.

This skill is scoped to front-end template architecture — component design, routing, composition, theming, and buildchain. For extending Craft (plugins, modules, PHP), see the craftcms skill.

Companion Skills — Always Load Together

When this skill triggers, also load:

  • craft-twig-guidelines — Twig coding standards: variable naming, null handling, whitespace control, include isolation, Craft helpers. Required for any Twig code.
  • craft-content-modeling — Sections, entry types, fields, Matrix, relations. Required when deciding what content to query or how templates access data.
  • ddev — All commands run through DDEV. Required for running Vite, npm, and Craft CLI commands.

Documentation

Use WebFetch on specific doc pages when a reference file doesn't cover enough detail.

Common Pitfalls (Cross-Cutting)

  • Missing only on {% include %} — ambient variables leak in silently.
  • Variant logic via conditionals ({% if variant == 'x' %}) instead of extends/block.
  • Naming atoms by parent context (hero-button) instead of visual treatment (button--primary).
  • utilities prop used as override — it's additive. Override via named-slot merge.
  • Queries inside views — views receive data, they don't fetch it.
  • Missing .eagerly() on relation fields in views — causes N+1 queries.
  • Missing devMode fallback in builders for unknown block types.
  • Hardcoded Tailwind colors (bg-yellow-600) instead of brand tokens (bg-brand-accent).
  • Mixing buttons and links — buttons are actions (resolve to <a>, <button>, or <span> from props), links are navigation (always <a>). Separate atom categories.
  • Tracking/analytics inside components — decouple to data attributes at view/page level.
  • Forgetting project-config/touch after editing YAML outside the CP — Git pulls, manual edits, and merge conflict resolution don't update dateModified. Run ddev craft project-config/touch then ddev craft up, or craft up on other environments won't detect the change.

Reference Files

Read the relevant reference file(s) for your task. Multiple files often apply together.

Task examples:

  • "Build a new card component" → read atomic-patterns.md + composition-patterns.md + component-inventory.md + tailwind-conventions.md
  • "Set up a new project's template structure" → read boilerplate-routing.md + component-inventory.md
  • "Add a content builder for a Matrix field" → read boilerplate-routing.md + composition-patterns.md
  • "Handle responsive images" → read image-presets.md + plugins/image-optimize.md
  • "Add multi-brand theming" → read tailwind-conventions.md
  • "Decide between Alpine and Vue for a feature" → read javascript-boundaries.md
  • "Compose Tailwind classes without conflicts" → read tailwind-conventions.md + twig-collections.md
  • "Understand atomic design methodology" → read atomic-design.md
  • "Set up Vite + Tailwind in a new Craft project" → read vite-buildchain.md
  • "Debug why assets aren't loading in production" → read vite-buildchain.md
  • "Install GTM/analytics/CMP in a Craft project" → read third-party-integration.md
  • "Configure SEOMatic for a section" → read plugins/seomatic.md
  • "Set up Blitz caching with Cloudflare" → read plugins/blitz.md
  • "Add a form to a page" → read plugins/formie.md
  • "Configure CKEditor with nested entries" → read plugins/ckeditor.md
  • "Build a navigation menu" → read plugins/navigation.md
  • "Add a link field to a component" → read plugins/hyper.md
  • "Set up redirects for a site" → read plugins/retour.md
  • "Add recurring/repeating dates to entries" → read plugins/timeloop.md
  • "Create a JSON API endpoint" → read plugins/element-api.md
  • "Debug N+1 queries in templates" → read plugins/elements-panel.md
  • "Run a security audit" → read plugins/sherlock.md
  • "Embed a YouTube/Vimeo video as an asset" → read plugins/embedded-assets.md
  • "Configure email delivery via SES" → read plugins/amazon-ses.md + third-party-integration.md
  • "Build a language switcher" → read multi-site-patterns.md
  • "Add login/registration to the front end" → read auth-flows.md
  • "Build a user profile edit page" → read auth-account.md
  • "Set up password reset flow" → read auth-flows.md
  • "Set up hreflang tags" → read multi-site-patterns.md
  • "Plan a multi-language site architecture" → read multi-site-patterns.md
  • "Add live search without JavaScript" → read plugins/sprig.md
  • "Build reactive filtering or load-more" → read plugins/sprig.md
  • "Import data from an external feed" → read plugins/feed-me.md
  • "Set up responsive images with Imager-X" → read plugins/imager-x.md
  • "Build a search page" → read search.md
  • "Configure search settings" → read search.md (Search Configuration)
  • "Rebuild the search index" → read search.md (Rebuilding)
  • "Create an RSS feed" → read feeds.md
  • "Build an XML sitemap" → read feeds.md (XML Sitemap)
  • "Create a JSON Feed" → read feeds.md (JSON Feed)
  • "Set up a headless Craft CMS with Next.js" → read headless.md
  • "Fix GraphQL preview tokens" → read headless.md
  • "Consume Craft GraphQL API from a front-end framework" → read headless.md
  • "Use entry.render() for reusable card components" → read element-partials.md
  • "Set up _partials/ templates for entries" → read element-partials.md
  • "Render Matrix blocks with partials" → read element-partials.md
ReferenceScope
references/atomic-design.mdMethodology: Brad Frost's atomic design principles, 5-to-3 tier compression, composability, context-agnostic naming, classification problem, decompose-downward workflow. Technology-independent.
references/atomic-patterns.mdIndividual component construction: props/extends/block pattern, variant file mechanics, button/link/text/icon atom implementations
references/composition-patterns.mdComponent composition: molecule pattern, organism pattern, structural embed pattern, include/extends/embed decision table, calling conventions, creating new components
references/component-inventory.mdClassification methodology: decision tree, naming conventions, file naming, props design, scaffold guidelines, tier promotion, audit checklist
references/boilerplate-routing.mdTemplate chain: layout hierarchy, Craft section template paths, global variables, routers, views, content builders, directory structure
references/tailwind-conventions.mdClass composition: named-key collections, standard key names, utilities prop, variant-based dark mode, spacing preference. Assumes Tailwind CSS — adapt patterns to your CSS framework.
references/vite-buildchain.mdCraft CMS Vite setup: nystudio107 plugin bridge, config/vite.php, vite.config.ts, craft.vite.script(), conditional per-page loading, Tailwind v4 integration, DDEV configuration
references/image-presets.mdImage handling: single atom with presets, srcset/sizes, ImageOptimize vs Craft Cloud, hosting strategies
references/javascript-boundaries.mdJS decision tree: Twig → Alpine/DataStar → Vue, mount points, data handoff, coexistence rules
references/twig-collections.mdcollect() method reference: creating, accessing, transforming, filtering, sorting, slicing, arrow functions
references/third-party-integration.mdScript loading order, CMP (UserCentrics/CookieBot), GTM/sGTM data layer, analytics (Fathom/Plausible), AWS SES transport, n8n webhooks, Blitz compatibility, full head template example
references/multi-site-patterns.mdLanguage switchers, hreflang tags, site architectures (subfolder/domain/subdomain/multi-brand), cross-site queries, static translations, site-specific templates, multi-site forms, site detection
references/auth-flows.mdFront-end authentication forms: login, registration, password reset, set new password
references/auth-account.mdAccount management: edit profile, email verification, navigation partial, access control tags, user session helpers, GeneralConfig auth settings
references/search.mdSearch: syntax, Twig queries, configuration, indexing, rebuilding, score and ranking
references/feeds.mdFeeds: RSS 2.0, Atom, JSON Feed, XML sitemap, custom routes, date filters
references/headless.mdHeadless & hybrid: headlessMode, GraphQL API, CORS, preview tokens, Next.js/Nuxt/Astro integration
references/element-partials.mdElement partials: entry.render(), _partials/ directory, template lookup, custom variables, eager loading in partials

Plugin References

Detailed configuration, Twig API, and pitfalls for Craft plugins. Located in references/plugins/.

ReferencePluginKey Surface
references/plugins/seomatic.mdSEOMatic (nystudio107)Meta cascade, Twig get/set API, JSON-LD, custom element SEO bundles, sitemaps, GraphQL
references/plugins/blitz.mdBlitz (putyourlightson)Refresh modes, Twig dynamic content, driver architecture (storage/purger/deployer), Nginx rewrite, Cloudflare integration
references/plugins/formie.mdFormie (verbb)Form rendering (one-line/granular), theme config for Tailwind, submission querying, hooks, integrations
references/plugins/image-optimize.mdImageOptimize (nystudio107)OptimizedImages field, imgTag()/pictureTag() builders, loading strategies, transform methods, console commands
references/plugins/ckeditor.mdCKEditor (craftcms)Toolbar config, nested entries with chunk rendering, HTML Purifier, custom styles, Redactor migration
references/plugins/sprig.mdSprig (putyourlightson)Reactive Twig components (htmx), live search, load more, pagination, filtering, form submissions without JS
references/plugins/colour-swatches.mdColour Swatches (craftpulse)Palette config, multi-colour swatches, Tailwind class mapping, Twig model API
references/plugins/password-policy.mdPassword Policy (craftpulse)Validation rules, HIBP check, retention/expiry, console commands, recommended settings
references/plugins/hyper.mdHyper (verbb)Link types, getLinkAttributes(), getText(), single/multi-link, element access, button atom integration
references/plugins/retour.mdRetour (nystudio107)Redirect types (exact/regex), 404 tracking, CSV import, auto slug-change redirects, config
references/plugins/navigation.mdNavigation (verbb)Node querying, custom rendering, active states, custom fields on nodes, GraphQL
references/plugins/typogrify.mdTypogrify (nystudio107)|typogrify, |widont, |truncateOnWord, smart quotes, widow prevention
references/plugins/cache-igniter.mdCache Igniter (putyourlightson)GlobalPing warmer, geographic locations, refresh delay, Blitz companion
references/plugins/knock-knock.mdKnock Knock (verbb)Staging password protection, environment-aware config, URL exclusions
references/plugins/timeloop.mdTimeloop (craftpulse)Repeating date field, craft.timeloop variable API, recurringDates() function, GraphQL, period frequencies
references/plugins/element-api.mdElement API (craftcms)JSON API via config file, Fractal transformers, endpoint routing, pagination, caching
references/plugins/elements-panel.mdElements Panel (putyourlightson)Debug toolbar panels for element population counts, duplicate detection, eager-loading opportunities
references/plugins/sherlock.mdSherlock (putyourlightson)Security scanning, HTTP headers, CMS config checks, scheduled scans, IP restriction, monitoring
references/plugins/embedded-assets.mdEmbedded Assets (spicyweb)oEmbed as first-class assets, craft.embeddedAssets.get(), iframe customization, GraphQL
references/plugins/amazon-ses.mdAmazon SES (putyourlightson)SES mail transport adapter, AWS credential config, SNS bounce tracking
references/plugins/feed-me.mdFeed Me (craftcms)Data import from XML/JSON/CSV, field mapping, duplicate handling, CLI automation
references/plugins/imager-x.mdImager-X (spacecrafttechnologies)Advanced image transforms, batch generation, named presets, effects, optimizers, external storage

Component System Conventions

One canonical component system across all projects. Atoms are context-agnostic — always named by visual treatment, never by parent. HTML element type is resolved from props (url<a>, type<button>, fallback → <span>).

External link detection is derived from the URL, never passed as a prop. Components auto-apply target="_blank", rel="noopener noreferrer", external icon, and sr-only text when a URL is external.

FontAwesome is the universal icon system. Icons are passed as FA class strings.

Visual variants use extends/block — base template defines structure, variant overrides classes. Never use conditional logic to switch between variant styles. For structural skeletons with content slots, use {% embed %} — see composition-patterns.md.

Image handling uses a single atom with config-driven presets, not separate variant files per context.

CSS & Theming Conventions

This skill assumes Tailwind CSS for class composition examples. Adapt patterns to your CSS framework — the architectural principles (named keys, additive utilities, semantic tokens) are framework-agnostic.

Class collections use named keys per style concern — this is the primary mechanism for preventing conflicts. The utilities prop is additive (extending), not overriding. Override specific concerns via named-slot merge.

Multi-brand theming uses CSS custom properties activated by data-brand="{{ currentSite.handle }}" on <html>. Components reference semantic Tailwind classes (bg-brand-accent) resolved via CSS variables. Template-level brand overrides only exist when the HTML structure itself differs between brands — not for color/font/spacing differences.

Token naming follows three layers: primitives (--brand-{color}-{shade}), semantics (--brand-{purpose}), and framework mapping (--color-brand-{purpose}).

Tailwind v4 cascade layers don't fix class conflicts within the same utilities layer. Named-key collections remain necessary.

Routing Conventions

PHP handles data, Twig handles presentation. Views receive data through includes — they never query it themselves.

collect() is used for both props and class building. The full Collection API is available in Twig via Craft.

The JS boundary follows a decision tree: Twig is the default → Alpine/DataStar for UI state → Vue for application state.

Capabilities

skillsource-michtioskill-craft-sitetopic-agent-skillstopic-claude-codetopic-claude-code-plugintopic-claude-code-skillstopic-claude-skillstopic-content-modelingtopic-craft-cmstopic-craft-cms-5topic-craftcmstopic-ddevtopic-phptopic-twig

Install

Installnpx skills add michtio/craftcms-claude-skills
Transportskills-sh
Protocolskill

Quality

0.47/ 1.00

deterministic score 0.47 from registry signals: · indexed on github topic:agent-skills · 39 github stars · SKILL.md body (15,112 chars)

Provenance

Indexed fromgithub
Enriched2026-05-01 18:56:48Z · deterministic:skill-github:v1 · v1
First seen2026-04-18
Last seen2026-05-01

Agent access