npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

vue3-extended-multiselect

v2.3.5

Published

Extended multiselect component for applications based on Vue 3 framework

Downloads

217

Readme

vue3-extended-multiselect v2.3.5


Brief annotation

Vue3 extended multiselect is a component that was created for simplification of custom settings of built-in select element. This component allows developer to escape writing many excess css-rules by using built-in themes and to escape problems with different kinds of provided options. Various decoration of options list by some extra slots will help developer to make it more informative and obvious. More thorough filtering of raw options list given by developer excludes sudden errors if kind of option is not intended for extended multiselect. Switchable useful warnings will help to catch possible errors that may occur while working with options. Tools for working with selected options will allow user to control amount of displayed options and quickly deselect them. Such tools also can be customized by developer. Various slots can help developer to customize to his liking options list, elements with selected options in multiple select or some other interaction elements. You can use this component in your web-applications based on Vue 3 framework.

Page with live examples

https://vue3-extended-multiselect.surge.sh/

Installation with npm

npm install --save vue3-extended-multiselect

Installation with yarn

yarn install --production vue3-extended-multiselect

Importing

import Vue3ExtendedMultiselect from "vue3-extended-multiselect"

Importing types

import { UnionOptionType } from "vue3-extended-multiselect/types"

Table of contents

Props list

Prop name | Prop type | Prop appointment | Prop default value | Prop values ----------|-----------|------------------|--------------------|------------ autoSelectCreatedOption|Boolean|Determines whether to select just now created option automatically.|false|—| autoSelectSearchValue|Boolean|Determines whether to take search value from current selected option if "multiple" prop equals false.|false|—| clearBySelectWhenMultiple|Boolean|Determines whether to clear search field by option selection.|false|—| createOnTheGo|Boolean|Allows user to create new options from search field.|false|—| defaultExpanded|Boolean|Determines whether options list should be expanded by default.|false|—| disabled|Boolean|Disables extended multiselect.|false|—| dropdownDisabled|Boolean|Disables dropdown toggle.|false|—| highlightOptions|Boolean|Switches options highlighting while hovering.|true|—| loading|Boolean|Switches loading state of extended multiselect.|false|—| multiple|Boolean|Allows user to select multiple options.|false|—| noResultsBlockShown|Boolean|Determines whether to show special hint if no options were found.|true|—| resetSearchByValue|Boolean|Determines whether to clear search field by selection/deselection of options.|true|—| searchFilterActive|Boolean|Allows user to use internal search for options.|true|—| simpleEvents|Boolean|Switches full payload of extended multiselect events.|true|—| selectedOptionsShown|Boolean|Determines whether to show selected options in options list.|false|—| showClearIcon|Boolean|Allows user to deselect all options by special icon.|false|—| showDeselectIconLoader|Boolean|Determines whether to show loader icon in multiple options block if "loading" prop equals true|true|—| showInsertWarnings|Boolean|Determines whether to show useful internal warnings in console.|false|—| showMarker|Boolean|Determines whether to show slot with special marker beside option in options list.|false|—| showSearchField|Boolean|Determines whether to show search field which allows user to search for options with internal search.|true|—| toggleMultipleBlocksLimit|Boolean|Allows user to increase limit of shown elements with selected options by special icon.|false|—| toggleOptionsBySelect|Boolean|Determines whether to roll up options list by selection of option.|true|—| togglingSavesSearchValue|Boolean|Determines whether to save current search value if display of options list was toggled.|true|—| wrongCurrentValue|Boolean|Determines whether to define special class for extended multiselect if value is wrong or if irregularity of value is defined by user.|false|—| createOptionPlaceholder|String|Placeholder for the search field to be used if user is allowed to create new options.|"Select or create features"|—| createOptionType|String|Defines kind for all options which will be created by user.|"primitive"| "primitive", "array", "object"| disableByField|String|Determines a field in options of type "object" which value will be used to disable such options.|"disabled"|—| emptyObjectsPlaceholder|String|Placeholder for options of type "object" or Array instances which length/keys length equals 0.|"Empty Object/Array"|—| errorBorderColor|String|Defines "border-color" css-property for extended multiselect with wrong value.|"#FF0000"|—| iconFilter|String|Defines svg-filter with color settings for all icons except loader.|"basic"|"basic", "black", "green"| iconSize|String|Defines sizes for all icons in pixels except loader.|"large"|"large", "medium", "small"| label|String|Defines field in options of type "object" that will be the label of option.|"label"|—| loaderIconFilter|String|Defines svg-filter with color settings for loader icon.|"loader-default"|"loader-default", "basic", "slate-grey", "slate-blue", "teal", "strict"| placeholder|String|Placeholder for search field to be used if user is not allowed to create new options.|"Select features"|—| searchByField|String|Determines field in options of type "object" to use in internal search.|""|—| themeType|String|Defines overall color theme for extended multiselect.|"basic"|"basic", "slate-grey", "slate-blue", "teal", "strict"| toggleAppearanceSide|String|Defines which side options list will be displayed on.|"auto"|"auto", "atop", "under"| toggleIcon|String|Defines kind of toggle icon from icons collection.|"base-arrow"|"base-arrow", "double-arrow", "wide-arrow", "circle-arrow", "inner-arrow", "triangle-arrow", "triangle-circle-arrow"| anyOptionWrapperBlockHeight|Number|Defines "height" css-property for each option in options list.|30|—| increaseDisplayBy|Number|Defines gap which increases limit of displayed elements with selected options.|5|—| maxOptionsCount|Number|Maximal limit of selected options.|null|—| minOptionsCount|Number|Minimal limit of selected options.|null|—| multipleBlocksLimit|Number|Defines limit of displayed elements with selected options.|null|—| optionsCountRestriction|Number|Defines maximal limit of options list length.|null|—| toggleMaxHeight|Number|Defines maximal value in pixels of "max-height" css-property for options list.|400|—| toggleMinHeight|Number|Defines minimal value in pixels of "max-height" css-property for options list.|null|—| createOptionFields|Array|Defines a list of fields for options of type "object" created by user.|["label"]|—| disabledPrimitiveOptions|Array|Defines a list of primitive options which will be disabled for selection.|[]|—| options|Array|Raw options list.|[]|—| optionsPadding|Array|Defines a list with "padding-top", "padding-left", "padding-bottom" and "padding-right" css-properties for options in options list. Property "padding-top" matches index zero. Property "padding-right" matches index three.|[]|—| preselectedOptions|Array|Defines a list of options that will be select by default.|[]|—| specialKeysBlock|Array|Defines a list of keys which in combination with mouse buttons or "enter" key will prevent selection of option.|[]|"alt", "ctrl", "shift"| createCustomOptionLabel|Function|Defines function that creates custom label for each option.|(option) => null|—| multipleBlocksLimitMessage|Function|Defines function that creates notification when maximal limit of selected options has been reached.|(number) => `and ${number} more items`|—| inputId|String, Number|"id" attribute of search field.|null|—| preselectedOption|UnionPropType (from types)|Defines options that will be select by default.|null|—| value|Array|Defines value of extended multiselect that can be used in "v-model".|[]|—|

Slots list

Slot name | Slot appointment | Slot scope ----------|------------------|----------- cancel|Button that deselects all options.|cancel — function that deselects all options| labelBlock|Element with single selected option that is shown if search field display is disabled.|labelBlockValue — option label| lessThanLimit|Message displayed if minimal limit of selected options has not been reached.|—| listHeader|Element at the top of options list for information content.|—| listFooter|Element at the bottom of options list for information content.|—| marker|Marker that indicates state of option selection.|selected — flag to determine markers for selected options| maxElements|Message displayed if maximal limit of elements with selected options has been shown.|—| moreThanLimit|Message displayed if maximal limit of selected options has been reached.|—| multipleBlocks|Block with selected options and other multiple select slots|selectedOptions — list of selected options,deselectBlock — function that deselects option and removes element that contained it| noResults|Message displayed if no options have been found by internal search.|—| noOptions|Message displayed if given options list is empty.|—| option|Option in options list with its label.|option — option from options list,createCustomOptionLabel — function that creates custom label for each option| optionBlock|Element with selected option and its label.|label — option label,deselectBlock — function that deselects option and removes element that contained it,index — option index| showMore|Button that increases limit of displayed elements with selected options.|showMoreOptions — function that increases limit of displayed elements with selected options| toggle|Button that toggles options list display.|toggleOptionsList — function that toggles options list display|

Events list

Event name | Event appointment | Listener method | Simplified event payload | Fields of object with full event payload | -----------|-------------------|-----------------|--------------------------|-----------------------------------------| pattern-changed|Change value of search field.|@pattern-changed|value — pattern of inner search for available options|value — pattern of inner search for available options,inputId — id of search field set by "id" prop| select|Selection of option.|@select|option — just now selected option|option — just now selected option,inputId — id of search field set by "id" prop| clean|Removal of all options or singe option.|@clean|option/options — just now deselected option or array with just now deselected options|option/options — just now deselected option or array with just now deselected options,inputId — id of search field set by "id" prop| option-created|Creation of new option by user.|@option-created|option — option created by user|option/options — option created by user,inputId — id of search field set by "id" prop| active|Dropdown options list expanding.|@active|—|inputId — id of search field set by "id" prop| close|Rolling up dropdown options list.|@close|options — array of selected options|options — array of selected options,inputId — id of search field set by "id" prop| increase|Increasing current limit of displayed elements with selected options.|@increase|limit — current limit of options to be shown next|limit — current limit of options to be shown next,inputId — id of search field set by "id" prop|

Styling with css

Vue3 extended multiselect provides following css-variables:

  --basic-color: #708090;
  --basic-transparent: rgba(112, 128, 144, 0.6);
  --cancel: #B22222;
  --cancel-backgound-color: rgba(179, 33, 33, 0.1);
  --dark-slate-blue: #483D8B;
  --dark-slate-blue-transparent: rgba(72, 61, 139, 0.6);
  --dark-slate-grey: #2F4F4F;
  --dark-slate-grey-transparent: rgba(47, 79, 79, 0.6);
  --disabled: rgba(176, 176, 176, 0.6);
  --hover-color: #FFFFFF;
  --loader-color: #00BFFF;
  --strict: #000000;
  --strict-transparent: rgba(0, 0, 0, 0.6);
  --teal: #008080;
  --teal-transparent: rgba(0, 128, 128, 0.6);
  
  --block-border-radius: 4px;
  --block-cancel-padding: 4px;
  --block-gap: 6px;
  --block-padding: 1px 3px 1px 7px;
  --border-radius: 6px;
  --border-radius-small: 3px;
  --cancel-padding: 3px 8px;
  --grid-columns: 1fr 36px 36px;
  --grid-rows: 1fr 36px;
  --half-size: 50%;
  --icon-size-block: 14px;
  --icon-size-large: 18px;
  --icon-size-medium: 15px;
  --icon-size-small: 12px;
  --increaser-padding: 3px 7px;
  --max-size: 100%;
  --min-block-height: 25px;
  --options-padding: 6px 0;
  --outer-gap: 10px;
  --root-padding: 6px 10px;
  --toggle-icon-gap: 1px;
  --wide-text: 700;
  --wrapper-padding: 5px 10px;
  --z-index-options: 10;

  --border: 1px solid;
  --default-cursor: default;
  --icons-align-self: start;
  --icons-justify-self: center;
  --pointer-cursor: pointer;
  --wrapper-transition: border-top-left-radius 250ms ease 0s, border-top-right-radius 250ms ease 0s,
                        border-bottom-left-radius 250ms ease-out, border-bottom-right-radius 250ms ease-out;

You can override it globally or by particular instance class name.

  <vue3-extended-multiselect class="instance-class" />
.instance-class {
  --basic-color: purple;
  --outer-gap: 2rem;
  --border: 1px dotted;
}

Styling with props

Vue3 extended multiselect provides following props for customizing:

  • errorBorderColor
  • iconFilter
  • iconSize
  • loaderIconFilter
  • themeType
  • toggleIcon
  • anyOptionWrapperBlockHeight
  • toggleMaxHeight
  • toggleMinHeight

Customizing examples

Changing border color when extended multiselect value is invalid.

  <vue3-extended-multiselect error-border-color="#8B0000" />

Changing svg color filter for icons.

  <vue3-extended-multiselect icon-filter="green" />

Resizing icons.

  <vue3-extended-multiselect icon-size="small" />

Changing svg color filter for loader icon.

  <vue3-extended-multiselect icon-size="small" />

Changing general color theme of extended multiselect.

  <vue3-extended-multiselect theme-type="slate-blue" />

Changing toggle icon form.

  <vue3-extended-multiselect toggle-icon="triangle-arrow" />

Resizing option blocks in options list.

  <vue3-extended-multiselect :any-option-wrapper-block-height="60" />

Changing "max-height" css-property of options list.

  <vue3-extended-multiselect :toggle-max-height="500" />

Changing "min-height" css-property of options list.

  <vue3-extended-multiselect :toggle-min-height="500" />

License

MIT