Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devloco/create-react-wptheme
Create modern, React-enabled WordPress themes with a single command.
https://github.com/devloco/create-react-wptheme
create-react-app php react react-theme react-tutorial react-wordpress-themes reactjs wordpress wordpress-api wordpress-development wordpress-server wordpress-starter-theme wordpress-theme
Last synced: 1 day ago
JSON representation
Create modern, React-enabled WordPress themes with a single command.
- Host: GitHub
- URL: https://github.com/devloco/create-react-wptheme
- Owner: devloco
- License: mit
- Created: 2018-06-17T12:33:19.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-11-20T13:13:30.000Z (2 months ago)
- Last Synced: 2025-01-17T22:04:55.067Z (8 days ago)
- Topics: create-react-app, php, react, react-theme, react-tutorial, react-wordpress-themes, reactjs, wordpress, wordpress-api, wordpress-development, wordpress-server, wordpress-starter-theme, wordpress-theme
- Language: JavaScript
- Homepage:
- Size: 611 KB
- Stars: 361
- Watchers: 18
- Forks: 61
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Create React WP Theme
## Still Up To Date!
May 6, 2020
Just wanted to note that version [v3.4.1](https://github.com/facebook/create-react-app/releases/tag/v3.4.1) of [Create-React-App](https://create-react-app.dev/) is still the latest.If you have a theme made with an earlier version of `create-react-wptheme` and want to update it to the latest code, [just follow these instructions](#updating-existing-themes).
---
## Getting Started
[Michael Soriano](https://github.com/michaelsoriano) is writing a tutorial for creating a theme using React. He uses `create-react-wptheme` for the initial setup. He provides a lot more detail than this `readme` and the screen shots are really helpful.
Check it out:
[Let's build a WordPress theme with React: Part 1 (Setup)](http://michaelsoriano.com/wordpress-theme-react-part-1-setup/)## Readme Contents
For more details check out the rest of this document.
- [Creating a New Theme](#creating-a-new-theme)
- [Updating Existing Themes](#updating-existing-themes)
- [Updating TypeScript Types](#updating-typescript-types)
- [Developing Your Theme](#developing-your-theme)
- [React Tutorials](#react-tutorials)
- [The Public Folder](#the-public-folder)
- [Dev Configuration](#dev-configuration)
- [HTTPS/SSL Support](#httpsssl-support)
- [Deploying Your Theme](#deploying-your-theme)
- [Dealing With Differing Paths Between DEV and PROD](#dealing-with-differing-paths-between-dev-and-prod)
- [Goals](#goals)
- [Acknowledgements](#acknowledgements)
- [License](#license)## Creating a New Theme
To create a WordPress theme using `create-react-wptheme`, follow these steps.
- Make sure your WordPress server is up and running.
- Change dir into your WordPress themes folder (**this is just an example, use your real themes folder**).
- Windows: `cd C:\xampp\htdocs\wordpress\wp-content\themes`
- Mac or \*nix: `cd /xampp/htdocs/wordpress/wp-content/themes`
- Use `npx create-react-wptheme` to make a new theme
- For example: (**replace "my_react_theme" with whatever you want your theme to be named**):
- `npx create-react-wptheme my_react_theme`
- If you want to use TypeScript, then the command would be:
- `npx create-react-wptheme my_react_theme --typescript`
- When it finishes it'll tell you to change into your new theme's folder and run the Nodejs watcher (replace "my_react_theme" with the same name you used in the previous step):
- `cd my_react_theme/react-src`
- `npm run start`
- That sets up the theme so that it can be seen in the WordPress admin area.
- **Go there now and set your WordPress site to use this theme.**
- View the site in your browser with the new theme.
- **You must do this as it does some extra setup via PHP.**
- **If you get PHP errors, most likely your web server doesn't have write access to your theme.**
- Write access for your web server is only needed during this setup step.
- **You can revoke write access after the setup has completed.**
- Interested (paranoid?) about what it's doing? Check out the file: `/index.php`
- When that's done you'll see: `Now, back in your command prompt, rerun the "start" script again...`
- To do that, go back to your command prompt where you first ran `npm run start` and rerun that same command again.
- In a few seconds you should see your browser load with the standard create-react-app page, but it's running as a WordPress theme!## Updating Existing Themes
When new versions of `Create-React-WPTheme` are released, you can easily upgrade an existing theme using a single command.
- At a command prompt, navigate to your theme's `react-src` folder.
- e.g. `/react-src`
- If you use `npm` then run this command:
- `npm install @devloco/react-scripts-wptheme@latest`
- If you use `yarn` then run this command:
- `yarn add @devloco/react-scripts-wptheme@latest`### Updating TypeScript Types
If your theme uses TypeScript, you'll need to modify the theme's `react-app-env.d.ts` file:
- Navigate to the `/react-src/src` folder.
- Open the `react-app-env.d.ts` file in your editor of choice.
- Change the line in there to read (be sure to include the leading three slashes):
- `/// `
- Save the change and you should be all set.## Developing Your Theme
### React Tutorials
If you're looking at a React tutorial on the web, you can use `create-react-wptheme` in place of `create-react-app`.
But you do have to remember that the React app code is one extra folder down inside your theme folder.
Notice that the final folder in this path is `react-src`:`/xampp/htdocs/wordpress/wp-content/themes//react-src`
So for example, if the tutorial instructs you to edit the `src/App.js` file, then for you, that file would actually be located at:
`/react-src/src/App.js`
### The Public Folder
The authors of the original `create-react-app` say that using the "Public" folder (found at `react-src/public` in your new theme's folder) is a last ditch "escape hatch" for adding otherwise-hard-to-deal-with files.
But for this project, I've decided to use it for all things that you'd put into a normal WordPress theme (e.g. functions.php, etc.). So any PHP, hard-coded CSS, and/or hard-coded JS (like other JS libraries that you'd like to reference globally (I don't judge)), can go into the public folder.
**In addition, any changes made to CSS, JS, and PHP files in the Public folder will cause a rebuild to happen.** Which is unlike `create-react-app` which ignores most of the files in the Public folder.
### Dev Configuration
After you've created a new theme, and all the setup is done, you'll find a file named `react-src/user.dev.json` that has some configuration options that you can mess with if you need to.
### HTTPS/SSL Support
If you develop using SSL (i.e. HTTPS), then you might want to run the `Browser Refresh Server` under SSL as well. Especially if you use Firefox, see here: [Firefox Websocket security issue](https://stackoverflow.com/questions/11768221/firefox-websocket-security-issue).
To configure the `Browser Refresh Server` to use SSL, follow these steps:
- Assuming you've already created a theme using `create-react-wptheme`, change directory into the `react-src` folder in your theme's folder
- Be sure to follow **all the instructions** under the **Usage** section at the top of this document. You need to complete the PHP portion of the setup before you can configure SSL.
- Windows example: `cd C:\xampp\htdocs\wordpress\wp-content\themes\\react-src`
- Mac or \*nix example: `cd /xampp/htdocs/wordpress/wp-content/themes//react-src`
- Create a new folder to hold you're development SSL certificate and key.
- All OSes: `mkdir ssl`
- Change directory into the `ssl` folder
- All OSes `cd ssl`
- Then create the SSL certificate and key.
- Windows: Install the [Linux Subsystem for Windows 10](https://docs.microsoft.com/en-us/windows/wsl/install-win10), then use the \*nix instructions below.
- Mac, see here: https://ksearch.wordpress.com/2017/08/22/generate-and-import-a-self-signed-ssl-certificate-on-mac-osx-sierra/
- \*nix, see here (**also works with Linux Subsystem for Windows 10**): https://stackoverflow.com/questions/10175812/how-to-create-a-self-signed-certificate-with-openssl
- Depending on which process you use to create the certificate and key, the files you created might have different extensions than those mentioned below.
- That's OK.
- Sometimes both files have a `.pem` extension, or each file has a different extension like `.crt` and `.key`.
- **Just be sure you know which file is the certificate and which is the key.**
- There is a file named `user.dev.json` in the folder named `react-src` in your theme.
- Open that file in your favorite text editor.
- Change the "wpThemeServer" section to look like this (make sure it is proper JSON):
- `"wpThemeServer": { "enable": true, "host": "127.0.0.1", "port": 8090, "sslCert": "ssl/localhost.crt", "sslKey": "ssl/localhost.key", "watchFile": "../index.php" },`
- **NOTE** the `sslCert` and `sslKey` items. **Make sure the values point to your SSL certificate and key files.**
- The paths to those files can be **full paths** or **relative paths** from the `react-src` folder (as shown above).
- I like to set the `host` to `127.0.0.1` instead of "localhost". Supposedly the numeric address gets special treatment at the OS level as being mostly safe.
- Back in your command prompt, change dir back to the `react-src` folder.
- All OSes: `cd ..`
- Start Node/Webpack JS watcher as you normally would:
- All OSes: `npm run start`
- Your theme should open in a new browser tab
- If you need to add an SSL exception to your browser for your new certificate, there is a page running over HTTPS at the "host" and "port" you set in `user.dev.json` above.
- For example, if you're using host `127.0.0.1` and port `8090` as shown above, then open your browser to:
- https://127.0.0.1:8090/
- From there you'll get the standard browser warning about self-signed certificates and get the option to add an exception.
- Once you've finished adding an exception to your browser, you'll need to refresh the tab with your development theme to force a reconnect to the `Browser Refresh Server`.## Deploying Your Theme
While you're actively developing your theme, the files are not optimized for production. Before you put your theme into production, you need to run the `build` command.
Open a command prompt and change into the `react-src` folder of you theme and run this command:
`npm run build`When that command finishes, your optimized files are located in a folder that can be deployed to your production server.
Here's an example showing which folder to deploy to your server:
- ...wp-content
- themes
- my-theme
- my-theme `<- deploy this folder to your production server's themes folder`
- react-src
- !READY_TO_DEPLOY!.txtIf you need to continue developing your theme, simply:
- `cd react-src`
- `npm run start`And all your theme files will reappear.
### Dealing With Differing Paths Between DEV and PROD
The `react-src/user.prod.json` configuration file is read when you run `npm run build`. The only option in there is setting the "homepage"
which controls the relative linking to files in your theme. The "homepage" setting in your main `package.json` file is used during development (and build by default).During development, this is probably what you want. But **if you know your production server has a different root**, then you can set the homepage to be different during a production build.
For example:
- Your WordPress dev server is running at http://localhost/wordpress
- the homepage setting in your main package.json file will probably work just fine.
- The homepage line in your main package.json will be something like: `"homepage": "/wordpress/wp-content/themes/"`
- But you know that your production server runs WordPress from the root: http://mycoolblog.com/
- In this case you want to remove the `/wordpress` part, so set the "homepage" line in your `user.prod.json` file to:
`"homepage": "/wp-content/themes/"`
- Then run `npm run build`
- **Note** at this point, **your theme will appear broken on your dev server**. But it should look as expected on your production server.## Goals
- Remove WebPackDevServer and use your WordPress dev server instead.
- Also, do not proxy the WordPress server.
- Thus removing CORS as a concern.
- Maintain feature parity(ish) with `create-react-app`
- Touch the original `react-scripts` as little as possible.
- Add new files where possible.
- This will make merges easier.## Acknowledgements
I'm grateful to the authors of existing related projects for their ideas and collaboration:
- [create-react-app](https://github.com/facebook/create-react-app)
The original.
- [filewatcher-webpack-plugin](https://www.npmjs.com/package/filewatcher-webpack-plugin)
I used this as an example for writing my own plugin for watching changes to the create-react-app "public" folder.
## License
Create React WP Theme is open source software [licensed as MIT](https://github.com/devloco/create-react-wptheme/blob/master/LICENSE).