szepeviktor / sentencepress
OOP toolkit for daily tasks in WordPress development.
Installs: 1 294
Dependents: 0
Suggesters: 0
Security: 0
Stars: 10
Watchers: 3
Forks: 0
Open Issues: 0
Requires
- php: ^7.4 || ^8.0
Requires (Dev)
- dealerdirect/phpcodesniffer-composer-installer: ^1.0
- johnbillion/wp-compat: ^1.1
- szepeviktor/phpcs-psr-12-neutron-hybrid-ruleset: ^1.1.1
- szepeviktor/phpstan-wordpress: ^2.0
- wp-coding-standards/wpcs: 3.1.0 as 2.3.0
README
These tools are recommended for use in agency-type projects where you have full control over the development and installation environment.
Installation
composer require szepeviktor/sentencepress
See WordPress website lifecycle for working with WordPress.
Examples
// Instead of wp_enqueue_script('main-js', get_template_directory_uri() . '/assets/js/main.js', [], '8.44', true) $mainJs = new Script(get_template_directory_uri() . '/assets/js/main.js'); $mainJs ->setHandle('main-js') ->setVer('8.44') ->moveToFooter() ->enqueue();
// Instead of add_action('plugins_loaded', [$this, 'init'], 0, 20); class Plugin { use SzepeViktor\SentencePress\HookAnnotation; public function __construct() { $this->hookMethods(); } /** * @hook plugins_loaded 20 */ public function init(): void { doSomething(); } }
// Instead of require __DIR__ . '/inc/template-functions.php'; // template-functions.php will be loaded and pingbackHeader called when wp_head hook is fired class Template { use SzepeViktor\SentencePress\HookProxy; public function __construct() { $this->lazyHookFunction( 'wp_head', __NAMESPACE__ . '\\TemplateFunction\\pingbackHeader', 10, 0, __DIR__ . '/inc/template-functions.php' ); } }