Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/itsamoreh/byob-headless-wordpress
WIP - Headless WordPress setup for Gutenberg blocks from scratch.
https://github.com/itsamoreh/byob-headless-wordpress
nextjs wordpress
Last synced: 2 months ago
JSON representation
WIP - Headless WordPress setup for Gutenberg blocks from scratch.
- Host: GitHub
- URL: https://github.com/itsamoreh/byob-headless-wordpress
- Owner: itsamoreh
- License: gpl-3.0
- Created: 2021-11-16T08:15:19.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-09-15T23:43:54.000Z (over 2 years ago)
- Last Synced: 2024-08-01T19:39:43.633Z (5 months ago)
- Topics: nextjs, wordpress
- Language: JavaScript
- Homepage: byob-demo.vercel.app
- Size: 1.42 MB
- Stars: 7
- Watchers: 1
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Next.js Headless WordPress Starter
## Setup
First, clone or fork the repo and `cd` into it.
```bash
git clone https://github.com/itsamoreh/nextjs-headless-wordpress.git
cd nextjs-headless-wordpress
```Next install Docker from [docs.docker.com/get-docker](https://docs.docker.com/get-docker/) and make sure Docker is running before you continue.
Set up the project with: `./wp-byob configure`. You'll be asked a few questions.
**Would you like to use this project's WordPress backend setup?**
Answer:
`y`: If you would like to use this project's WordPress backend setup using Docker.
`n`: If you want to use your own WordPress setup.
**What is your WordPress URL?**
This URL will be used to access WordPress. The default is http://localhost:8080 if you just press enter.
**What is your Next.js frontend URL?**
This URL will be used to access the Next.js frontend. The default is http://localhost:3000 if you just press enter.
**This is going to:**
- Create the `.env` file in the frontend directory.
- Setup the WordPress backend with all plugins via composer (if you chose to use this project's WordPress backend setup).
- Install npm packages for Next.js frontend and start the development server.The **WordPress backend** will be available at [http://localhost:8080](http://localhost:8080) by default.
The **Next.js frontend** will be available on at [http://localhost:3000](http://localhost:3000) by default.### After Setup
- Make sure to activate all plugins that were installed via composer by going to "WordPress Admin Panel > Plugins".
- Update the block registry by going to "WordPress Admin Panel > GraphQL Gutenberg".
- Update the permalink by going to "WordPress Admin Panel > Settings > Permalinks". Choose "Post name" under "Common Settings" and hit "Save".
- Set a Homepage and Posts page by going to "WordPress Admin Panel > Settings > Reading".
- See "Debugging" if you're having problems.### During development
Useful commands (run these from the project root):
```bash
./wp-byob configure # Run the configuration wizard to set up the backend, frontend and create an .env file.
./wp-byob start-all # Create and start the WordPress docker environment and run the Next.js development server.
./wp-byob start-backend # Start the WordPress docker environment.
./wp-byob start-frontend # Run Next.js development server.
./wp-byob stop # Stop the WordPress docker environment.
```## Debugging
**If you get a server error on the frontend, check to see that the `.htaccess` file in `backend/wordpress` has the following rules. They may have been overwritten during setup.**
```shell script
# BEGIN WordPress
# The directives (lines) between "BEGIN WordPress" and "END WordPress" are
# dynamically generated, and should only be modified via WordPress filters.
# Any changes to the directives between these markers will be overwritten.RewriteEngine On
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
RewriteBase /
RewriteRule ^index\.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.php [L]# END WordPress
```**If you're getting another error on the frontend.**
- Check if all the required WordPress plugins form `backend/wordpress/composer.json` are Activated by going to "WordPress Admin Panel > Plugins".
- Ensure you have updated the block registry by going to "WordPress Admin Panel > GraphQL Gutenberg".
- Ensure that `.env` file has the correct env variables and values in `frontend/.env`.**If you need to change `php.ini`'s `upload_max_filesize` directive, add the following to the `.htaccess` file in `backend/wordpress`, customizing limits for your needs.**
```shell script
# END WordPress
php_value upload_max_filesize 12M
php_value post_max_size 13M
php_value memory_limit 15M
```## Credits
[Imran Sayed's Next.js Headless WordPress](https://github.com/imranhsayed/nextjs-headless-wordpress)
[Colby Fayock's Next.js WordPress Starter](https://github.com/colbyfayock/next-wordpress-starter)
[WebDevStudios' Next.js WordPress Starter](https://github.com/WebDevStudios/nextjs-wordpress-starter)