Getting started | Staying up to date with Dawn changes | Developer tools | Contributing | Code of conduct | Theme Store submission | License
Dawn represents a HTML-first, JavaScript-only-as-needed approach to theme development. It's Shopify's first source available theme with performance, flexibility, and Online Store 2.0 features built-in and acts as a reference for building Shopify themes.
Templates | Theme Architecture | Theme Development | Theme Check | Lighthouse | Shopify CLI
Dawn includes CLI commands to generate new sections and snippets with the correct file structure and boilerplate code:
# Create a new section
npm run create:section mySectionName
# Create a new snippet
npm run create:snippet mySnippetNameThis will:
- Create the Liquid template with proper stylesheet inclusion
- Generate the SCSS file with BEM structure
- Set up responsive breakpoints
- Add standard padding/margin variables
Generated files follow this structure:
sections/
└── custom-my-section-name.liquid
src/
└── sections/
└── _custom-my-section-name.scss
The build process will:
- Compile section SCSS files to
assets/section-*.css - Compile snippet SCSS files to
assets/component-*.css - Watch for changes during development (
npm run start:testing) - Auto-reload the theme preview
Each generated section includes:
- Standard padding settings
- Mobile-first responsive design
- BEM class structure
- Proper asset loading
Each generated snippet includes:
- Component-based styling
- BEM methodology
- Responsive breakpoints
- Asset optimization
Following coding-standards/liquid/README.md standards:
- Use standardized naming conventions for settings:
titlefor Titlescontentfor Content areas (userichtextorinline_richtext)cta_textandcta_linkfor CTAsimage_desktop,image_tablet,image_mobilefor responsive images
Based on coding-standards/css/README.md (lines 479-486):
- Follow OOCSS and BEM methodology
- Create reusable, composable components
- Maintain low specificity
- Use CSS custom properties for theme settings
- Mobile-first responsive approach
Following coding-standards/blubolt-quality/README.md (lines 26-31):
- Use provided helper utilities:
data-smooth-scrolldata-click-toggle
- Add new functionality in
src/scripts/ - Use data attributes for JavaScript targeting
Based on coding-standards/documentation/README.md (lines 13-14):
Each new feature/component should include:
- Inline documentation for complex functionality
- Usage examples
- Available customization options
- Performance considerations
Following .github/PULL_REQUEST_TEMPLATE.md (lines 36-43):
- Test on multiple browsers
- Ensure mobile responsiveness
- Validate accessibility
- Run Theme Check linting
- Check performance metrics
- Create feature branch:
[initials]-[ticket-id] - Follow coding standards
- Document changes
- Create PR with comprehensive description
- Include mobile/desktop screenshots
- Install recommended VS Code extensions
- Use provided snippets for common patterns
- Follow the folder structure
- Use existing theme settings where possible
- Add new features progressively
Based on .github/CONTRIBUTING.md (lines 53-58):
- Maintain zero Cumulative Layout Shift
- Avoid render-blocking resources
- Optimize for core web vitals
- Use lazy loading where appropriate
- Implement proper image sizing
- Review existing components before creating new ones
- Follow the naming conventions
- Update documentation
- Create meaningful PRs
- Update changelog
- Web-native in its purest form: Themes run on the evergreen web. We leverage the latest web browsers to their fullest, while maintaining support for the older ones through progressive enhancement—not polyfills.
- Lean, fast, and reliable: Functionality and design defaults to "no" until it meets this requirement. Code ships on quality. Themes must be built with purpose. They shouldn't support each and every feature in Shopify.
- Server-rendered: HTML must be rendered by Shopify servers using Liquid. Business logic and platform primitives such as translations and money formatting don't belong on the client. Async and on-demand rendering of parts of the page is OK, but we do it sparingly as a progressive enhancement.
- Functional, not pixel-perfect: The Web doesn't require each page to be rendered pixel-perfect by each browser engine. Using semantic markup, progressive enhancement, and clever design, we ensure that themes remain functional regardless of the browser.
You can find a more detailed version of our theme code principles in the contribution guide.
We recommend using Dawn as a starting point for theme development. Learn more on Shopify.dev.
If you're building a theme for the Shopify Theme Store, then you can use Dawn as a starting point. However, the theme that you submit needs to be substantially different from Dawn so that it provides added value for merchants. Learn about the ways that you can use Dawn.
Please note that the main branch may include code for features not yet released. The "stable" version of Dawn is available in the theme store.
Say you're building a new theme off Dawn but you still want to be able to pull in the latest changes, you can add a remote upstream pointing to this Dawn repository.
- Navigate to your local theme folder.
- Verify the list of remotes and validate that you have both an
originandupstream:
git remote -v- If you don't see an
upstream, you can add one that points to Shopify's Dawn repository:
git remote add upstream https://github.com/Shopify/dawn.git- Pull in the latest Dawn changes into your repository:
git fetch upstream
git pull upstream mainAlternatively, you can create a separate branch for upstream changes and merge them carefully:
# Create a branch for upstream changes
git checkout -b dawn-upstream
git fetch upstream
git reset --hard upstream/main
# Go back to your main branch
git checkout main
# Merge upstream changes while ignoring your custom files
git merge dawn-upstream -X ignore-space-change -X ignore-all-space --no-commitThere are a number of really useful tools that the Shopify Themes team uses during development. Dawn is already set up to work with these tools.
Shopify CLI helps you build Shopify themes faster and is used to automate and enhance your local development workflow. It comes bundled with a suite of commands for developing Shopify themes—everything from working with themes on a Shopify store (e.g. creating, publishing, deleting themes) or launching a development server for local theme development.
You can follow this quick start guide for theme developers to get started.
We recommend using Theme Check as a way to validate and lint your Shopify themes.
We've added Theme Check to Dawn's list of VS Code extensions so if you're using Visual Studio Code as your code editor of choice, you'll be prompted to install the Theme Check VS Code extension upon opening VS Code after you've forked and cloned Dawn.
You can also run it from a terminal with the following Shopify CLI command:
shopify theme checkDawn uses GitHub Actions to maintain the quality of the theme. This is a starting point and what we suggest to use in order to ensure you're building better themes. Feel free to build off of it!
We love fast websites! Which is why we created Shopify/lighthouse-ci-action. This runs a series of Google Lighthouse audits for the home, product and collections pages on a store to ensure code that gets added doesn't degrade storefront performance over time.
Dawn runs Theme Check on every commit via Shopify/theme-check-action.
Want to make commerce better for everyone by contributing to Dawn? We'd love your help! Please read our contributing guide to learn about our development process, how to propose bug fixes and improvements, and how to build for Dawn.
All developers who wish to contribute through code or issues, please first read our Code of Conduct.
The Shopify Theme Store is the place where Shopify merchants find the themes that they'll use to showcase and support their business. As a theme partner, you can create themes for the Shopify Theme Store and reach an international audience of an ever-growing number of entrepreneurs.
Ensure that you follow the list of theme store requirements if you're interested in becoming a Shopify Theme Partner and building themes for the Shopify platform.
Copyright (c) 2021-present Shopify Inc. See LICENSE for further details.