zachgilbert / vue-multiselectable
PHP support for vue-multiselect
Installs: 2
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:project
pkg:composer/zachgilbert/vue-multiselectable
Requires
- illuminate/database: ^6.0|^7.0|^8.0
- illuminate/support: ^6.0|^7.0|^8.0
Requires (Dev)
- mockery/mockery: ^1.4.4
- phpunit/phpunit: ^9.5.10
This package is auto-updated.
Last update: 2025-10-29 03:18:19 UTC
README
This package provides methods to conveniently convert PHP classes to array data prepared for use on the frontend Vue component, Vue Multiselect (2.4.1).
Please note this utility package is independent of and not endorsed by https://vue-multiselect.js.org/.
Table of Contents:
- Installation
- 1.1. Laravel
- The
MultiselectableTrait - Eloquent Collection Methods
- 3.1.
multiselect() - 3.2.
disbaleOptionsBy()
- 3.1.
- Eloquent Query Builder Methods
- 4.1.
multiselect()
- 4.1.
# 1. Installation
Install using Composer:
$ composer require zachgilbert/vue-multiselect
Apply the trait Multiselectable to any PHP object (such as an Eloquent model, in Laravel) that you wish to convert to an option for use on the <vue-multiselect /> Vue component:
<?php use ZachGilbert\VueMultiselectable\Traits\Multiselectable; class User { use Multiselectable; // ... }
# 1.1. Laravel
To extend Eloquent collections in laravel, be sure to register the following provider in config/app.php:
<?php return [ // ... 'providers' => [ // ... \ZachGilbert\VueMultiselectable\Laravel\Providers\MultiselectProvider::class, ], ];
# 2. The Multiselectable Trait
# 2.1. toMultiselectOption()
The toMultiselectOption() method converts any given class instance to an option formatted for use on the <vue-multiselect /> Vue component.
toMultiselectOption() accepts five arguments: $trackByAttribute, $labelAttribute, $trackByKey, $labelKey, and $isDisabled.
$trackByAttributeand$labelAttributeare the attributes on the class that should be used for the value and the label on the multiselect option:<?php $user->toMultiselectOption('id', 'name'); // ['value' => 1, 'name' => 'John McEnroe']
Note that$trackByAttributeis the only required argument. Provided on its own,->toMultiselectOption()will just return the attribute value:<?php $user->toMultiselectOption('name'); // 'John McEnroe'
$trackByKeyand$labelKeyset how the attributes should be keyed:<?php $user->toMultiselectOption('id', 'name', 'user_id', 'user_name'); // ['user_id' => 1, 'user_name' => 'John McEnroe']
$isDisabled, if provided, will set a key with a boolean value for whether the option should be disabled:<?php $user->toMultiselectOption('id', 'name', 'value', 'label', true); // ['value' => 1, 'name' => 'John McEnroe', '$isDisabled' => true]
# 3. Eloquent Collection Methods
In Larvel, collections of PHP objects that use the Multiselectable trait can be easily converted to a JSON-serializable array of options.
Make sure to register the provider
MultiselectProviderinconfig/app.php).
# 3.1. multiselect()
The multiselect() method converts each item in the collection to an array of options.
multiselect() accepts four arguments: $trackByAttribute, $labelAttribute, $trackByKey, and $labelKey:
$trackByAttributeand$labelAttributeare the attributes on each item in the collection that should be used for the value and the label on the multiselect option:<?php $collection->multiselect('id', 'name')->toJson(); // '[{"value": 1, "name": "John McEnroe"}, {"value": 2, "name": "Dr Eggman"}]''
Note that if only the first argument is provided, the resultant collection will be an array of that attribute's values:<?php $collection->multiselect('name')->toJson(); // '["John McEnroe", "Dr Eggman"]'
- By default, the Vue multiselect component assumes the value and label on each option will be keyed by
'value'and'label'. Using$trackByKeyand$labelKeycan set how the attributes should be keyed:<?php $collection->multiselect('id', 'name', 'user_id', 'user_name')->toJson(); // '[{"user_id": 1, "user_name": "John McEnroe"}, {"user_id": 2, "user_name": "Dr Eggman"}]'
# 3.2. disbaleOptionsBy()
The disableOptionsBy() method disables options for the multiselect based on a callback (the return value of which is evaluated as true or false). Any items that pass the truth test will have $isDisabled = true set; any items that fail will have $isDisabled = false set.
<?php $options = $collection->disableOptionsBy(function ($item, $key) { return strpos($item->name, 'John') === 0; }); $options->multiselect('id', 'name')->toJson(); // '[{"value": 1, "label": "John McEnroe", "$isDisabled": true}, {"value": 2, "label": "Dr Eggman"}]'
Note that disabling multiselect options is only applicable to options which can be converted to objects in JSON (i.e. arrays).
# 4. Eloquent Query Builder Methods
Using Laravel's Eloquent query builder, we can obtain database records in a multiselect-ready format. Note this does not require any classes using the Multiselectable trait.
# 4.1. multiselect()
The multiselect() method selects two columns, with aliases, ready for use on the multiselect component. It accepts four arguments: $trackBySelect, $labelSelect, $trackByAlias, and $labelAlias:
$trackBySelectand$labelSelectare the raw SQL columns/statements to select, that should be used for the value and the label on the multiselect:<?php $users = User::query() ->multiselect('users.id', 'CONCAT(users.name, " - ", companies.name)') ->join('companies', 'users.company_id', '=', 'companies.id'); // SELECT `users`.`id` AS `value`, CONCAT(`users`.name`, " - ", `companies`.`name`) AS `label` // ... $users->get()->toJson(); // '[{"value": "1", "label": "John McEnroe - Tennis Co."}]'
$trackByAliasand$labelAliasset the column names for the selects:<?php $users = User::query() ->multiselect( 'users.id', 'CONCAT(users.name, " - ", companies.name)', 'employee_id', 'employee_name' ) ->join('companies', 'users.company_id', '=', 'companies.id'); // SELECT `users`.`id` AS `employee_id`, CONCAT(`users`.name`, " - ", `companies`.`name`) AS `employee_name` // ... $users->get()->toJson(); // '[{"employee_id": 1, "employee_name": "John McEnroe - Tennis Co."}]'