abetter / wordpress
A Better Laravel + Wordpress integration, for exceptionally fast web applications.
Requires
- abetter/toolkit: ^1.6.18
- intervention/image: ^2.5
- vlucas/phpdotenv: ^3.6
- dev-master
- 1.6.26
- 1.6.25
- 1.6.24
- 1.6.23
- 1.6.22
- 1.6.21
- 1.6.20
- 1.6.19
- 1.6.18
- 1.6.17
- 1.6.16
- 1.6.15
- 1.6.14
- 1.6.13
- 1.6.12
- 1.6.11
- 1.6.10
- 1.6.9
- 1.6.8
- 1.6.7
- 1.6.6
- 1.6.5
- 1.6.4
- 1.6.3
- 1.6.2
- 1.6.1
- 1.6.0
- 1.5.27
- 1.5.26
- 1.5.25
- 1.5.24
- 1.5.23
- 1.5.22
- 1.5.21
- 1.5.20
- 1.5.19
- 1.5.18
- 1.5.17
- 1.5.16
- 1.5.15
- 1.5.14
- 1.5.13
- 1.5.12
- 1.5.11
- 1.5.10
- 1.5.9
- 1.5.8
- 1.5.7
- 1.5.6
- 1.5.5
- 1.5.4
- 1.5.3
- 1.5.2
- 1.5.1
- 1.5.0
- 1.4.999
- 1.4.998
- 1.4.997
- 1.4.996
- 1.4.995
- 1.4.994
- 1.4.993
- 1.4.992
- 1.4.991
- 1.4.99
- 1.4.98
- 1.4.97
- 1.4.96
- 1.4.95
- 1.4.94
- 1.4.93
- 1.4.92
- 1.4.91
- 1.4.9
- 1.4.1
- 1.4.0
- 1.3.9
- 1.3.8
- 1.3.7
- 1.3.6
- 1.3.5
- 1.3.4
- 1.3.3
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.71
- 1.2.70
- 1.2.69
- 1.2.68
- 1.2.67
- 1.2.66
- 1.2.65
- 1.2.64
- 1.2.63
- 1.2.62
- 1.2.61
- 1.2.60
- 1.2.59
- 1.2.58
- 1.2.57
- 1.2.56
- 1.2.55
- 1.2.54
- 1.2.53
- 1.2.52
- 1.2.51
- 1.2.50
- 1.2.49
- 1.2.48
- 1.2.47
- 1.2.46
- 1.2.45
- 1.2.44
- 1.2.43
- 1.2.42
- 1.2.41
- 1.2.40
- 1.2.39
- 1.2.38
- 1.2.37
- 1.2.36
- 1.2.35
- 1.2.34
- 1.2.33
- 1.2.32
- 1.2.31
- 1.2.30
- 1.2.29
- 1.2.28
- 1.2.27
- 1.2.26
- 1.2.25
- 1.2.24
- 1.2.23
- 1.2.22
- 1.2.21
- 1.2.20
- 1.2.19
- 1.2.18
- 1.2.17
- 1.2.16
- 1.2.15
- 1.2.14
- 1.2.13
- 1.2.12
- 1.2.11
- 1.2.10
- 1.2.9
- 1.2.8
- 1.2.7
- 1.2.5
- 1.2.4
- 1.2.3
- 1.2.2
- 1.2.1
- 1.2.0
- 1.1.8
- 1.1.7
- 1.1.6
- 1.1.5
- 1.1.4
- 1.1.3
- 1.1.2
- 1.1.1
- 1.1.0
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- dev-dependabot/npm_and_yarn/plugins/wpml-translation-management/libraries/CodeMirror/minimist-1.2.8
- dev-dependabot/npm_and_yarn/plugins/wpml-translation-management/libraries/CodeMirror/qs-6.5.3
This package is auto-updated.
Last update: 2025-01-04 06:58:10 UTC
README
ABetter Wordpress is a turnkey solution for using Wordpress on top of Laravel to build exceptionally fast web applications – while still using the worlds most popular CMS to manage content and translations.
Our methodology to fast web applications is all about Separation of Concerns (SoC) and Scalable Static Caching. We let Wordpress handle the content back-end and Laravel the standalone front-end. Additional API and web services for dynamic content are also routed through Laravel.
With the ABetter Toolkit we give Laravel/Blade some new powerful directives helping us separate as much as possible in standalone and resusable components – much inspired by ReactJS/VueJS.
Requirements
- PHP 7.2+
- Imagick 3+
- MySQL 5.7+
- Composer 1.6+
- Laravel 5.8+
- Deployer 6+
- Node 10.0+
- NPM 6.4+
Installation
Via Composer:
composer create-project --prefer-dist laravel/laravel . "6.*" composer require abetter/wordpress
Laravel modifications
Add post install/update script to composer.json:
"scripts": { "post-install-cmd": [ "ABetter\\Wordpress\\ComposerScripts::postInstall" ], "post-update-cmd": [ "ABetter\\Wordpress\\ComposerScripts::postUpdate" ] }
Note: The script will modify any core files using the global __() method for string translations and add a cross-framework workaround. Sadly wordpress core do not check for function_exists before defining global __(), which breaks Laravel + Wordpress compatibility without modification.
Add middleware to app/Http/Kernel.php:
protected $middleware = [ \ABetter\Toolkit\SandboxMiddleware::class, \ABetter\Wordpress\Middleware::class, ];
Note: The middleware helps Blade clear the view cache when developing many nested components.
Preparations
- Setup a local host domain using .loc, (e.g. www.abetter.loc)
- Point the host to /public
- Create a local mysql database
Setup Laravel
Edit .env settings
APP_NAME=<name> APP_VERSION=<version> APP_KEY=base64:insert/base64/encoded/aes256/encryption/key= APP_ENV=<sandbox|local|dev|stage|production> APP_DEBUG=<true|false> APP_URL=<url> APP_PROXY=<browsersync-proxy-url> DB_DATABASE=<database> DB_USERNAME=<username> DB_PASSWORD=<password> WP_THEME=<optional-views-subfolder> WP_AUTOLOGIN=<optional-autologin-user> WP_REQUIRELOGIN=<optional-require-login-to-view>
Note: Use APP_ENV=sandbox when developing with browsersync.
Add routes to /routes/web.php
// ABetter Toolkit services Route::any('image/{style?}/{path}', '\ABetterToolkitController@handle')->where('path','.*'); Route::any('proxy/{path}', '\ABetterToolkitController@handle')->where('path','.*'); Route::any('browsersync/{event?}/{path}', '\ABetterToolkitController@handle')->where('path','.*'); Route::any('service/{path?}.{type}', '\ABetterToolkitController@handle')->where(['path'=>'.*','type'=>'json']); // ABetter Wordpress main route Route::any('{path}', '\ABetterWordpressController@handle')->where('path','^(?!nova-api|nova-vendor|nova|api).*$');
Note: Remove any other routes for root or wp paths (i.e default Welcome).
Copy the Deployer file to root and run setup once:
cp vendor/abetter/toolkit/deploy/deploy.php deploy.php
dep setuponce local
Run audit fix if needed:
npm audit fix
Note: Only run the setuponce on fresh projects, since it will replace files in /resources and /public.
Test to build the app:
dep build local
Setup Wordpress
Go to host in browser (e.g. http://www.abetter.loc) and follow install instructions.
Go to /Appearance/Themes, and activate ABetter theme.
Go to /Plugins, and activate:
- Advanced Custom Fields.
- Disable Gutenberg (full support is coming soon...).
- ... Any other of the supported plugins you need.
Add default pages:
<name> : <slug> : <template> : <order> Start : start : default : -1 News : news : default : 200 Privacy Policy : privacy-policy : default : 200 Search : search : search : 400 403 Forbidden : 403-forbidden : error : 403 404 Not found : 404-not-found : error : 404
Go to /Settings/Reading:
- Select Start as homepage
- Select News as post page
Finaly, go to host in browser:
Congratulations to your new site!
Usage
Development
Use npm to start webpack and browsersync:
npm run watch
... or if using php artisan serve:
php artisan serve & npm run watch
NOTE: With "php artisan serve" you need to modify APP_PROXY in .env to http://127.0.0.1:8000.
Component file structure
.
├── public # Handled by build script (will be overwritten)
├── routes # Add any development routes to /web.php
├── resources #
│ ├── scripts # Global scripts in "app.js"
│ ├── styles # Global styles in "app.scss"
│ ├── fonts # Fonts here (will copy to /public on build)
│ ├── images # Images here (will copy to /public on build)
│ ├── videos # Videos here (will copy to /public on build)
│ ├── views #
│ │ ├── <theme> # Subfolder defined in .env / WP_THEME
│ │ │ ├── template.blade.php # Template file requested in route
│ │ │ │ ├── components #
│ │ │ │ │ ├── menu # Component subfolder:
│ │ │ │ │ │ ├── menu.blade.php # Template file : @component('components.menu',TRUE)
│ │ │ │ │ │ ├── menu.scss # Sass file : @style('menu.scss')
│ │ │ │ │ │ ├── menu.js # Javascript file : @script('menu.js')
...
/vendor/abetter/wordpress/ # Default components will be used if not overridden!
├── views # (e.g. html head start/end is rendered from here)
│ ├── default #
│ │ ├── robots.blade.php # Default Robots.txt template
│ │ ├── sitemap.blade.php # Default Sitemap.xml template
│ │ ├── components #
│ │ │ │ ├── html # Default HTML head components
│ │ │ │ ├── missing # Default debugging for missing components
│ │ │ │ ├── robots # Default Robots.txt component
│ │ │ │ ├── sitemap # Default Sitemap.xml component
...
Note: Component names will be auto-resolved if the blade file has same basename as folder.
Note: Linked JS/Sass files in components will be external files in development to support browsersync live, but will be embedded in html source on Stage/Production environments for better caching.
Note: You can auto-terminate a @component with TRUE as the second paramater, to avoid writing out @endcomponent, e.g when not using any slots or nested content.
Deployment
(coming soon)
Contributors
Johan Sjöland johan@sjoland.com
Senior Product Developer: ABetter Story Sweden AB.
License
MIT license. Please see the license file for more information.