Download the PHP package mttzzz/nova-detached-actions without Composer

On this page you can find all versions of the php package mttzzz/nova-detached-actions. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package nova-detached-actions

Laravel Nova Detached Actions Tool

A Laravel Nova tool to allow for placing actions in the Nova toolbar, detached from the checkbox selection mechanism.

:warning: Keep in mind, since the action is detached from the row selection checkboxes in the resource table, you will not have a collection of models to iterate over. Detached actions are intended to be independent of the selection in the table. :warning: Also, keep in mind, pivot actions are not supported and have not been tested.

screenshot

Installation

You can install the package in to a Laravel app that uses Nova via composer:

The tool will be automatically registered via the ToolServiceProvider

Usage

Create a custom Nova Action file:

Instead of extending the ExportUsers class with the Laravel\Nova\Actions\Action class, swap it with the Brightspot\Nova\Tools\DetachedActions\DetachedAction class.

Since we won't receive a collection of $models, you can remove the variable from the handle method, so that the signature is public function handle(ActionFields $fields).

You can also customize the button label, by overriding the label() method. If you do not override the label, it will 'humanize' the class name, in the example ExportUsers would become Export Users.

By default, the detached action will only appear on the Index Toolbar.

If you want to also show the action on the resource index view (when users select a row with a checkbox), set the $public $showOnIndex = true; If you want to also show the action on the resource detail view (when user selects the action from the dropdown), set the $public $showOnDetail = true;

Here's a full example:

Register the action on your resource:

Chunking and repetitive calls to the handle()

If you initiate an action on the background Nova will chunk up the total amount of records and call the handle() function of your DetachedAction for each chunk. This could have unexpected performance impact as the system will perform your action for each chunk of records. This happens in the handleRequest() function of \Laravel\Nova\Actions\Action.php.

To prevent this the simplest way is to overrule this function in your DetachedAction. this is a bare example dispatching just a job without any checks or other logic:

Display on different screens

showOnIndexToolbar()

Show the detached action buttons on the index page toolbar (i.e. the default location). Do not show on the index grid action dropdown,

onlyOnIndexToolbar()

Only show the detached action buttons on the index toolbar. Do not show them anywhere else.

exceptOnIndexToolbar

Show the detached action buttons everywhere except the index toolbar.

onlyOnIndex

Show the detached action buttons only on the index view. Allows them to be displayed on the standalone dropdown or in the grid action dropdown.

showOnDetailToolbar()

Show the detached action buttons on the detail page toolbar (i.e. the default location).

onlyOnDetailToolbar()

Only show the detached action buttons on the index toolbar. Do not show them anywhere else.

exceptOnDetailToolbar

Show the detached action buttons everywhere except the detail toolbar.

onlyOnDetail

Show the detached action buttons only on the detail view. Allows them to be displayed on the standalone dropdown or in the action dropdown.

Usage with the Laravel Nova Excel DownloadExcel action

You can easily integrate the DetachedAction tool with the Laravel Nova Excel DownloadExcel action by simply passing some additional data along using withMeta().

Customizing Buttons

Visible vs Invisible Buttons

By default, the component will show the first 3 buttons and put the rest into a dropdown menu. If you want to change the number of buttons visible per resource, you can do so by using the additionalInformation method, like so:

You can also change the icon type and whether or not you want to display a dropdown arrow for the invisible action menu:

Customizing Button Classes

The package ships with some common sense default HTML classes that are applied to the action buttons. In the component, we automatically assign the following:

The action buttons are buttons so it makes sense to assign the btn and btn-default classes, we also want consistent spacing between buttons, so we apply ml-3 and to line up the icons and text inside the button, we use flex justify-center items-center. Further, in order to allow theme developers to set a specific class name to hook into, we apply detached-action-button on both the Index and Detail views.

On top of these classes, the DetachedAction class provides btn-primary as a default, that will give the buttons the default button color, i.e. blue in the default Nova theme.

A developer can add classes on the fly, using the extraClassesWithDefault() and extraClasses() methods on the DetachedAction class.

The extraClassesWithDefault() method

If you want to keep the default classes but add extra classes alongside them, then you probably want to use this method. You can pass an array of single class names or multiple class names separated by spaces.

The extraClasses() method

You are free to use any tailwind/nova class.

Adding an icon

You can use any of the 104 Heroicon icons by specifying the icon name in lowercase:

You can also customize the display of that icon using iconClasses:

screenshot

License

The MIT License (MIT). Please see License File for more information.


All versions of nova-detached-actions with dependencies

PHP Build Version
Package Version
Requires php Version >=7.1.0
laravel/nova Version ^4.0
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package mttzzz/nova-detached-actions contains the following files

Loading the files please wait ....