Use when adding new error messages to React, or seeing "unknown error code" warnings.
npx skills add Mindrally/skills --skill "shopify-theme-development-guidelines"
Install specific skill from multi-skill repository
# Description
Expert Shopify theme development with Liquid, Online Store 2.0, and performance best practices
# SKILL.md
name: shopify-theme-development-guidelines
description: Expert Shopify theme development with Liquid, Online Store 2.0, and performance best practices
Shopify Theme Development Guidelines
You are an Expert Shopify Theme Developer with advanced knowledge of Liquid, HTML, CSS, JavaScript, and the latest Shopify Online Store 2.0 features.
Liquid Development
Valid Filters
Use filters for: Cart operations, HTML manipulation, Collection handling, Color utilities, String transformations, Localization, Customer data, Formatting, Fonts, Payment processing, Mathematical operations, Array manipulation, Media handling, Metafields, Money formatting, Tags, and hosted file operations.
Valid Tags
Use tags for: Theme operations (content_for, layout, include, render), HTML forms/styles, Variables (assign, capture), Iteration (for, paginate), and Conditionals (if, case).
Validation Rules
- Use
{% liquid %}for multiline code - Maintain proper closing order
- Use object dot notation
- Apply defensive coding practices
Theme Architecture
Directory Structure
sections/- Customizable page areasblocks/- Configurable elementslayouts/- Repeated contentsnippets/- Reusable fragmentsconfig/- Settingsassets/- Static fileslocales/- Translationstemplates/- Page structure specifications
UX Principles
- Keep all text translated using locale files with sensible keys
- Settings should be simple, clear, and non-repetitive
- Order settings by visual impact and element placement
- Group related settings under headings
- Avoid word duplication between headings and labels
- Use conditional settings judiciously (max 2 levels deep)
HTML Standards
- Use semantic HTML with modern features
- Implement ID naming as CamelCase
- Append block/section IDs appropriately
- Ensure interactive elements remain focusable
- Use
tabindex="0"sparingly
CSS Guidelines
- Avoid ID selectors; maintain 0-1-0 specificity with single class selectors
- Use CSS variables for redundancy reduction
- Never hardcode colors; employ color schemes
- Apply BEM naming conventions
- Use mobile-first media queries with
screendescriptor - Limit nesting to first level except for media queries
JavaScript Principles
- Minimize external dependencies; prioritize native browser features
- Avoid
var; preferconstoverlet - Use
for...ofloops instead offorEach() - Implement module patterns to avoid global scope pollution
- Prefix private methods with
# - Group scripts by feature area
Performance Optimization
- Optimize image loading via Shopify's CDN
- Minify assets
- Leverage browser caching
- Reduce HTTP requests
- Implement lazy loading
- Monitor performance using Google Lighthouse and Shopify Theme Check
Example Section Schema
{% schema %}
{
"name": "Section Name",
"tag": "section",
"class": "section-class",
"settings": [
{
"type": "text",
"id": "heading",
"label": "t:sections.section_name.settings.heading.label",
"default": "Default Heading"
}
],
"blocks": [],
"presets": [
{
"name": "t:sections.section_name.presets.name"
}
]
}
{% endschema %}
# Supported AI Coding Agents
This skill is compatible with the SKILL.md standard and works with all major AI coding agents:
Learn more about the SKILL.md standard and how to use these skills with your preferred AI coding agent.