$page→addStatusReady()
Called when new status flag about to be added to page but not yet saved
Available since version 3.0.253.
Example
$wire->addHook('Page::addStatusReady', function($e) { $page = $e->object; $name = $e->arguments(0); if($name === 'unpublished' && $page->id === 1) { $page->removeStatus($name); $e->error("We do not allow unpublish of homepage"); } });Usage
$page->addStatusReady(string $name, int $value);Arguments
| Name | Type(s) | Description |
|---|---|---|
$name | string | Name of the status flag to be added, i.e. unpublished, hidden, trash, locked |
$value | int | Value of the status flag to be added, a |
Hooking $page→addStatusReady(…)
You can add your own hook events that are executed either before or after the $page method is executed. Examples of both are included below. A good place for hook code such as this is in your /site/ready.php file.
Hooking before
The 'before' hooks are called immediately before each $page method call is executed. This type of hook is especially useful for modifying arguments before they are sent to the method.
$this->addHookBefore('Page::addStatusReady', function(HookEvent $event) { // Get the object the event occurred on, if needed $page = $event->object; // Get values of arguments sent to hook (and optionally modify them) $name = $event->arguments(0); $value = $event->arguments(1); /* Your code here, perhaps modifying arguments */ // Populate back arguments (if you have modified them) $event->arguments(0, $name); $event->arguments(1, $value); });Hooking after
The 'after' hooks are called immediately after each $page method call is executed. This type of hook is especially useful for modifying the value that was returned by the method call.
$this->addHookAfter('Page::addStatusReady', function(HookEvent $event) { // Get the object the event occurred on, if needed $page = $event->object; // An 'after' hook can retrieve and/or modify the return value $return = $event->return; // Get values of arguments sent to hook (if needed) $name = $event->arguments(0); $value = $event->arguments(1); /* Your code here, perhaps modifying the return value */ // Populate back return value, if you have modified it $event->return = $return; });API reference based on ProcessWire core version 3.0.255