Actions allow you perform tasks on one or more items. You can trigger actions by selecting multiple items in a listing, or using each item's contextual menu.

Defining an action

You may create an action using the following command, which will generate a class in the App\Actions namespace.

php please make:action


The most basic action should have a run method.

use Statamic\Actions\Action;
class Delete extends Action
public function run($items, $values)
return trans_choice('Item deleted.|:count items deleted.', $items);

The run method is for executing the task. You will be provided with a collection of $items, and any submitted $values (more about those later).

If you return a string, it will be shown in the toast notification. Otherwise, you’ll get a generic success message.


If you want to redirect after your action completes, override the redirect method and return a route or URL:

public function redirect($items, $values)
return route('some.where.over.the', $rainbow);


To produce a download, override the download method and return a file path or download response:

public function download($items, $values)
return storage_path('some/file.pdf');

Registering an Action

Any action classes in the App\Actions namespace will be automatically registered.

If you would like to store them elsewhere, you can manually register an action in a service provider by calling the static register method on your action class.

public function boot()

Filtering Actions

You may limit which items an action can be applied to using the visibleTo method. For example, if you want your action to only be used by entries, you can return a boolean like this:

use Statamic\Contracts\Entries\Entry;
public function visibleTo($item)
return $item instanceof Entry;
Best Practice

Don’t include authorization in your visibleTo method. Instead, use the authorize method below.

Authorizing Actions

Before any actions are run, Statamic will make sure the user is allowed to run them. You can return a boolean like this:

public function authorize($user, $item)
return $user->can('edit', $item);

By default, there is no authorization.

Dangerous Actions

You can mark an action as dangerous, which will give it red text and more sinister looking confirmation dialog.

protected $dangerous = true;


Each action may have additional contextual data passed to it depending on which listing its being used within. For example, you may find the collection handle when used inside an entry listing, or the asset container handle when used in an asset listing

$this->context; // ['collection' => 'blog']

You may find this useful when building confirmation dialog fields:

Adding Fields

By default, an action will prompt you with an “Are you sure?” dialog.

You’re free to add additional fields to the action by adding a $fields property with a fieldset-style definition. Each will be added to the confirmation dialog.

protected $fields = [
'message' => [
'type' => 'text',
'validate' => 'required|min:40',

If you need more control over the fields, you can use the fieldItems method instead. Within this method, you can use $this->context. Then return the same array as described above.

protected function fieldItems()
return [
'message' => ['type' => 'text'],

The values entered into these fields when a user runs the action will be passed into the run method.

Docs feedback

Submit improvements, related content, or suggestions through Github.

Betterify this page →