Download the PHP package ziffmedia/nova-select-plus without Composer
On this page you can find all versions of the php package ziffmedia/nova-select-plus. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package nova-select-plus
Nova Select Plus
Installation
Versions & Compatibility
- Version
^1.0
supports Nova 2-3 - Version
^2.0
supports Nova 4 (with Vue 3, dark mode support, etc)
Description & Use Cases
This Nova component was built to satisfy the use cases just beyond Nova's built-in <select>
component. Here are
some scenarios where you might want SelectPlus
(which uses vue-select
) over the simple Select
:
Select For BelongsToMany and MorphsToMany On the Form Screen
The default Nova experience for BelongsToMany
and MorphsToMany
is to have a separate UI screen for
attaching/detaching and syncing relationships through a "Pivot" model. For simple relationships (relationships that do
not have addition pivot values or the only value in the pivot table is there for ordering), it is benefitial to move
this Selection to the Form workflow instead of a separate workflow.
Ajax For Options
For Select's that have between a handful to several 1000 options, it is more peformant to load the full list of options only on the screen that needs it: the Form screen.
There are 2 options for Ajax Options, the default is to load them all on the Form load. The second is to allow for full option searching (in this case you can write you own ajax search resolver).
Reordering Simple Pivot/BelongsToMany Relations
Through ->reorderable()
, you can enable a SelectPlus
field to be reorderable. This allows, at BelongsToMany->sync()
time, to populate a pivot value useful for ordering relations.
Usage
Options & Examples
->label(string|closure $attribute)
Pick a different attribute to use as the label
Default: 'name'
If a closure is provided, it will be called and the value can be utilized. Additionally, the output may be HTML as the component will v-html
the output on the frontend:
->usingIndexLabel()
& ->usingDetailLabel()
Default is to produce a count of the number of items on the index and detail screen
If a string name is provided, the name attribute is plucked and comma joined:
If a closure is provided, it will be called, and the value will be utilized. If the value is a string, it will be placed:
If an array is returned, the Index and Detail screens will produce a <ol>
or <ul>
list:
->reorderable(string $pivotOrderAttribute)
- Ability to reorder multiple selects
->optionsQuery(closure)
- Ability to apply changes to options query object
- Note: this will apply before any
ajaxSearchable()
functionality, it will not replace it but be applied along withajaxSearchable()
if it exists
->ajaxSearchable(string|closure|true)
Ajax search for values
Given a string, models will be search the resources via the provided attribute using WHERE LIKE. Given a callback, returning a Collection will populate the dropdown: