lin3s / wp-routing
Symfony style routing for WordPress
Installs: 6 648
Dependents: 0
Suggesters: 1
Security: 0
Stars: 0
Watchers: 3
Forks: 1
Open Issues: 2
Requires
- php: ^5.5 || ^7.0
- symfony/yaml: ^2.3 || ^3.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^1.11
- lin3s/wp-phpspec-brigde: ^0.1
- phpspec/phpspec: ^2.5
This package is not auto-updated.
Last update: 2025-01-18 20:02:56 UTC
README
Symfony style routing for WordPress.
Why?
WordPress routing system is a magical awesome but dark system. For non developers this routing just "works" but, when you need to customize it, this process is not very intuitive. In LIN3S, we are proud PHP developers that like Symfony ecosystem so, this library is a simple but powerful approach to Symfony Routing component you can easily add to your WordPress project.
If you want to test it, we already have a functional WordPress project that includes this library ready to use, WordPress Standard Edition :).
Installation
The recommended and the most suitable way to install this library is through Composer. Be sure that the tool is installed in your system and execute the following command:
$ composer require lin3s/wp-routing
Usage
Before you start using this library we highly recommend getting familiar with WordPress template hierarchy.
WP-Routing uses YAML to match routes with your methods. For example you can write the following in your
routing.yml
:
- controller: YourTheme\Controller\DefaultController::indexAction type: front - controller: WordpressStandard\Controller\DefaultController::notFoundAction type: 404 - controller: YourTheme\Controller\EventController::searchAction type: search - controller: YourTheme\Controller\YourPostTypeController::singleAction type: single posttype: your-posttype - controller: YourTheme\Controller\PageController::availabilityAction type: page template: your-template
As you can see in the example above you can use the following parameters for each route:
controller
: Defines with method will be called when a match for the given route exists.type
: Which type of route will match the current controller. It uses WordPress standard naming conventions and you can check the available ones in Router class.template
: Can be used in pages to select a custom template. Internally it usesget_page_template_slug()
to get the template the page requires. We use our template-selector plugin to let the user select the template to be used.- other parameters: In case you need to target a specific category, post type (archive or single), taxonomy or page you can use extra parameters like slug, id or posttype (see variable names on WordPress's template hierarchy page).
To resolve the routes added above just include the following code in your theme's index.php
:
(new \LIN3S\WPRouting\Router())->resolve();
Make sure WPRouting library is autoloaded using composer's autoload script
To Do
- Add more specs
- Route registration wih XML
- Route registration wih annotations