webdevstudios / wd_s
A starter theme from WebDevStudios.
Installs: 43
Dependents: 0
Suggesters: 0
Security: 0
Stars: 663
Watchers: 52
Forks: 139
Open Issues: 12
Type:wordpress-theme
pkg:composer/webdevstudios/wd_s
Requires
- composer/installers: ^1.5 || ^2.0.0
Requires (Dev)
- dev-main
- v4.0
- v3.5
- 3.0
- 2.1
- v2.0.1
- v2.0.0
- dev-dependabot/npm_and_yarn/tailwindcss-3.4.3
- dev-dependabot/npm_and_yarn/express-4.19.2
- dev-dependabot/npm_and_yarn/webpack-dev-middleware-5.3.4
- dev-dependabot/npm_and_yarn/follow-redirects-1.15.6
- dev-dependabot/npm_and_yarn/stylelint-webpack-plugin-5.0.0
- dev-dependabot/npm_and_yarn/webpack-merge-5.10.0
- dev-fix/block-assets
- dev-dependabot/npm_and_yarn/axios-and-wordpress/scripts-and-browser-sync-1.6.7
- dev-dependabot/npm_and_yarn/ip-1.1.9
- dev-bugfix/WDSUS-48-Site-Editor-Fix
- dev-develop
- dev-feature/theme-json-colormix
- dev-feature/WDSUS-27-Change-block-category-order
- dev-feature/WDSUS-26-Pattern-Support
- dev-feature/WDSUS-25-Update-NPM-to-18
- dev-feature/1000-last-child-style-p-tag
- dev-feature/991-add-tailwind-support-for-patterns
- dev-feature/WDSUS-11-remove-tw-customizations
- dev-feature/dependabot-updates
- dev-feature/WENG-226-add-css-grid
- dev-feature/portable-blocks
- dev-feature/esbuild
- dev-feature/reorganization-release
- dev-hotfix/babel-error
- dev-feature/+762-add-ratio-box-classes
- dev-feature/tailwind-jit-update
- dev-feature/template-modules
- dev-feature/css-custom-properties-typescale
- dev-feature/update-nvm
- dev-feature/css-minimizer-update
- dev-oliver
- dev-feature/tailwind-2-0-dark-mode
- dev-pre-tailwind
This package is auto-updated.
Last update: 2025-09-29 01:59:19 UTC
README
A starter theme from WebDevStudios. https://wdunderscores.com
Table of Contents
Introduction
Hello there! I am a versatile starter theme known as wd_s, or wdunderscores. My foundation is built primarily on PHP templates, but I offer the flexibility to incorporate custom templates through the Site Editor. It's worth noting that I'm designed for customization, so it's best not to use me as a Parent Theme. Instead, harness my potential to transform me into the most amazing WordPress theme you can envision – that's what I'm here for!
I come equipped with a host of robust web technologies, including Tailwind, npm, webpack, Sass, and PostCSS. To ensure your code aligns with WordPress standards and stays clean, I leverage @wordpress/scripts for CSS and JavaScript linting. What's more, I take accessibility seriously and proudly comply with both WCAG 2.1AA and Section 508 standards right from the start.
I also come with the Site Editor activated, providing you with even more versatility and ease in crafting your WordPress theme. Whether you're customizing templates or utilizing the Site Editor, I'm here to support your creative journey. And remember, I do require at least PHP 8.0 to be activated to unlock my full potential.
Getting Started
Prerequisites
Because I compile and bundle assets via NPM scripts, basic knowledge of the command line and the following dependencies are required:
Quick Start
If you want to keep it simple, head over to https://wdunderscores.com and generate your wd_s based theme from there. You just input the name of the theme you want to create, click the "Generate" button, and you get your ready-to-awesomize starter theme. Alternatively, you could download a pre-built ZIP
Advanced
If you want to set me up manually:
- 
Download and extract the zip into your wp-content/themesdirectory and renamewd_sto fit your needs.
- 
Find & Replace 
You'll need to change all instances of the name: wd_s.
- Search for: @package wd_sand replace with:@package project_nameto capture the package name
- Update "WebDevStudios\wd_s,wd_s"to:"CompanyName\project_name,project_name"(with double quotes) in phpcs.xml.dist
- Search for: WebDevStudios\wd_sand replace with:CompanyName\project_nameto capture the namespaces
- Update "webdevstudios/wd_s"to"companyname/project_name"(with double quotes) in composer.json
- Search for: , 'wd_s'and replace with:, 'project_name'(inside backticks) to capture the text domain
- Update Text Domain: wd_sto:Text Domain: project_namein style.css
- Update "wd_s"to:"project_name"(with double quotes) in phpcs.xml.dist and package.json
- Update 'wd_s'to:'project_name'(with single quotes) in inc/setup/setup.php
- Search for: wd_s_and replace with:project_name_to capture all the function names
- Search for: 'wd_s-and replace with:'project_name-to capture prefixed handles
- Search for wd_s.potand replace with:project_name.potto capture translation files
- Search for wdunderscores.testand replace with:project_name.testto match your local development URL
- Edit the theme information in the header of style.scss to meet your needs
Setup
From the command line, change directories to your new theme directory:
cd /wp-content/themes/your-theme
Install theme dependencies and trigger an initial build.
Note: You will need to have Composer 2 and NPM 9 installed first.
npm i && composer i
Development
From the command line, type any of the following to perform an action:
| Command | Action | 
|---|---|
| npm run watch | Builds assets and starts Live Reload and Browsersync servers | 
| npm run start | Builds assets and starts Live Reload server | 
| npm run build | Builds production-ready assets for a deployment | 
| npm run lint | Check all CSS, JS, MD, and PHP files for errors | 
| npm run format | Fix all CSS, JS, MD, and PHP formatting errors automatically | 
| npm run report | Gives detailed information on coding standards violations in PHP code | 
Building a block with wpcli
In order to build a block, run the following wpcli script.
Note: If you're using Local, you can open the shell from within Local to do this. Sitename -> Open site shell.
wp wds create_portable_block myblock --title="This is myblock" --desc="This block is used for wds." --keyword="myblock" --icon="table-row-before" --namespace="wds"
This will scaffold out a block inside of the blocks folder in the theme. Replace myblock with the name of your block and update the other items title, desc, keyword, icon, namespace with the appropriate information.
Note: If you don't see your new block available under the block listing in the editor after following the above steps, try changing the namespacing in your block's block.json to the following format your-namespace/blockname and check again.
Contributing and Support
Your contributions and support tickets are welcome. Please see our contributing guidelines before submitting a pull request.
wd_s is free software, and is released under the terms of the GNU General Public License version 2 or any later version. See LICENSE.md for complete license.