n5s/wp-hook-kit

A lightweight WordPress hook helper library. Register hooks before WordPress loads, run callbacks only once, and more.

Installs: 12

Dependents: 1

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

pkg:composer/n5s/wp-hook-kit

1.0.0 2025-12-23 15:20 UTC

This package is auto-updated.

Last update: 2025-12-23 15:36:40 UTC


README

Tests Coverage PHPStan

A lightweight WordPress hook helper library. Register hooks before WordPress loads, run callbacks only once, and more.

Installation

composer require n5s/wp-hook-kit

Usage

use n5s\WpHookKit\Hook;

// Basic usage - works even before WordPress is loaded
Hook::addFilter('the_content', fn($content) => $content . '<p>Footer</p>');
Hook::addAction('init', fn() => register_post_type('book', []));

// Run a callback only once (removes itself after first execution)
Hook::addFilterOnce('the_title', fn($title) => $title . ' - Launch Sale!');
Hook::addActionOnce('wp_footer', fn() => echo '<!-- First visit -->');

// Side effects - run code without modifying the filtered value
Hook::addFilterSideEffect('the_content', function($content) {
    error_log('Content rendered: ' . strlen($content) . ' chars');
});

// Combine both: side effect that runs once
Hook::addFilterSideEffectOnce('template_include', function($template) {
    log_first_template_load($template);
});

// Register same callback on multiple hooks
Hook::addFilters(['the_title', 'the_content'], 'esc_html');
Hook::addActions(['wp_head', 'wp_footer'], fn() => do_something());

All methods accept the standard WordPress parameters: $hook, $callback, $priority = 10, $accepted_args = 1.

Why?

Early registration: Register hooks before WordPress fully loads. The library writes directly to $wp_filter when add_filter() isn't available yet. Unlocks the power of bringing features without the "plugin" way hassle when it's not needed (library, composer autoloaded files, etc.).

Once variants: Because sometimes, you might not want your callback to be executed every time a hook is called.

Side effects: Runs your callback and returns the original value unchanged. Useful to trigger actions when an actual action isn't available, observe filter behavior, etc.

Acknowledgments

This package is gathering multiple package implementations inside a single library, credits goes to:

License

MIT