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

jvx-multiselect

v2.0.44

Published

a multiselect

Downloads

344

Readme

<jvx-multiselect>

A web component that offers a multipurpose material multiselect which handles both synchronous and asynchronous selections.

Install jvx-multiselect

npm install jvx-multiselect

API

Slots

| Name | Description | -------------- | ----------- | option-item | Use this slot to pass a custom template for the options. Use [[option.propertyname]] to access the property of the item. The template should be styled inline. | options | It's one of the way to pass the options to the select: the elements inside the slot shall be divs with a value attribute and a text attribute that are used to define the option.

Properties/Attributes

| Name | Type | Default | Description | ----------------------- | ------------------------------- | ----------| --------------------------------------------------------------------------- | advancedSearch | Boolean | false | True to enable the advanced search (searchInput must be true). | clearable | Boolean | false | True to enable the empty selection. | closeOnClick | Boolean | false | True if the options list must be closed on each click outside the component. | disabled | Boolean | false | True to disable the select. | filter | Object | null | The custom filter for the post call. | flatRound | Boolean | false | When true gives the jvx-multiselect a nice flat-rounded appearance. | hasErros | Boolean | false | True to display the component in the "error" mode. | httpParameters | Object | null | The custom search value and pagination for the asynchronous selection. | itemText | String | 'text' | The name of the property of the option object that will be displayed as description of the options. | itemValue | String | 'value' | The name of the property of the option object that will be treated as value of the options. | placeholder | String | '' | The placeholder. | label | String | '' | The label. | labels | Object | null | The dictionary to map the response. | multi | Boolean | false | True if it's a multiselect. | options | Array | [] | Array of the options in the form of Objects. | requestHeaders | Object | {...} | The headers of the HTTP request. | requestType | 'GET'|'POST' | 'GET' | The type of the HTTP request. | searchInput | Boolean | false | True to enable the search input for the options list. | searchLabel | String | 'search'| The label of the search input. | useOnlyHttpParameters | Boolean | false | True to ignore the default pagination. | paginated | Boolean | false | True if the the response is never paginated. | listProp | String | false | Name of the property in response.data where the list is stored. | totalRowsProp | String | false | Name of the property in response.data where the number of total rows is stored. | url | String | '' | The url to get the options. | value | Array | [] | The current value of the selection.

Methods

None

Events

| Event Name | Target | Detail | Description | --------------------- | ------------- | ------- | ----------- | input | | Array | Fired when the user changes the value of the input. The detail contains the value of the selection. | showAdvancedSearch | | None | Fired when the user clicks on the advanced search icon. | response | | Object| Fired when the backend call returns successfully. The detail contains the response. | invalid-jwt | | Object| Fired when the backend call returns with an invalit jwt error. The detail contains the response. | error | | String| Fired when the backend call throws an exception. The detail contains the exception. | scrollEnd | | None | Fired when the scrollbar in the options menu reaches the bottom. | jvx-menu-openeed | | None | Fired when the the menu is opened. | jvx-menu-closed | | None | Fired when the the menu is closed.

CSS Custom Properties

None

Global Custom Properties

| Name | Default | Description | ------------------------------------------------- | --------------------------------- |------------ | --jvx-multiselect-primary | blue | Color of the select bottom line when idle. | --jvx-multiselect-accent | green | Color of the underline ripple, the outline, and the caret when active. | --jvx-multiselect-error | red | Color of the underline ripple, the outline, and the caret when has errors. | --jvx-multiselect-color | #000 | Color of the text. | --jvx-multiselect-background-color | #fff | Color of the background of the menu. | --jvx-material-input-height | `` | Height of the select. | --jvx-multiselect-selection-color | currentColor | Color of the selected value. | --jvx-multiselect-selection-font-size | 14px | Font size of the selected value. | --jvx-multiselect-selection-font-weight | 400 | Font weight of the selected value. | --jvx-multiselect-label-color | currentColor | Color of the label. | --jvx-multiselect-label-font-size | 14px | Font size of the label. | --jvx-multiselect-label-font-weight | 400 | Font weight of the label. | --jvx-multiselect-placeholder-color | var(--jvx-multiselect-color) | Color of the placeholder. | --jvx-multiselect-placeholder-font-size | 14px | Font size of the placeholder. | --jvx-multiselect-placeholder-font-weight | 400 | Font weight of the placeholder.

HTTP Request

Request

The HTTP request can be either a GET or a POST request. The user can set the type using the property requestType which is set to 'GET' by default.

The HTTP request will be executed via axios.

httpParameters

The parameters for the HTTP request are stored in the property httpParameters. If the property useOnlyHttpParamters is false, a new object will be created which will integrate a copy of httpParameters will be completed as follows:

  Object.assign(httpParametersCopy, {
        search: this.searchValue,
        page: this.pagination.page,
        pageSize: this.pagination.pageSize,
        filter: !!this.filter && (typeof this.filter === 'object' || this.filter.length > 0) ? JSON.stringify(this.filter) : null
      });

This object will be passed in the property data or in the property params of the axios request depending on the HTTP request type.

Headers

The headers can be set in the property requestHeaders. By default the jvx-multiselect uses the property trusted stored in the sessionStorage. The default headers are:

var requestHeaders = {
  'Accept': 'application/json',
  'Access-Control-Allow-Origin': '*',
  'Access-Control-Allow-Methods': 'GET, PUT, POST, DELETE, OPTIONS',
  'Content-Type': 'application/json',
  'Authorization': window.sessionStorage.getItem('trusted')
}

Response

By now the response must contain an array of objects, stored in the property message in the response.data object.

The object template should be

var obj: {
  value: Number|String,
  text: String
}

If the object comes in different form, via the property labels it is possible to set an object that maps the properties in order to make it readable for the jvx-multiselect. For example if the response object template is

var response = {
  id: 1,
  title: 'This is the title',
  description: 'This is the description',
  start: 2020/01/01,
  end: 2020/03/01
}

and the property labels is

var labels = {
  id: 'value',
  title: 'text'
}

the response object will be mapped like this

var response = {
  value: 1,
  text: 'This is the title',
  id: 1,
  title: 'This is the title',
  description: 'This is the description',
  start: 2020/01/01,
  end: 2020/03/01,
  selected: Boolean
}

The user can use the properties itemText and itemValue to prevent the need for the mapping (being in the example above itemText = 'title' and itemValue = 'id').

Search

When the user searches for a term, the property searchInput is updated with the searched value. Its value is then copied in the property search of the object of the search parameters.

Pagination

The property pagination is structured by default as follows:

var pagination = {
  page: 1,
  pageSize: 15
}

Whenever the scrollbar in the menu reaches the bottom, the property page is incremented by one and a further http request is called. When the user searches or closes the menu the property page is set again at 1. The jvx-multiselect copies these values individually in the object of the search parameters.

Slots

option-item

The slot option-item allows to define a template for the options that will be shown in the dropdown menu. It is possible to access the context wrapping it between square brackets. i.e.: Let's say we have the following structure:

var options = [{
  value: 1, 
  text: 'Lorem ipsum',
  color: 'blue',
  preview: 'path/to/first-image.jpg'
},
  {
    value: 2,
    text: 'dolor sit amet',
    color: 'red',
    preview: 'path/to/second-image.jpg'
  }];

and we want our options to have in the text field both the property color and the property text. We can write the template like so:

<div slot="option-item">[[option.text]] [[option.color]]</div>

It's possible to use the context inside attributes too. In that case it's suggested to preppend the string data-jvx- to all the attributes' names that will access the context. i.e.

<div slot="option-item">
    <span>[[option.text]]</span>
    <span>
        <img data-jvx-src="[[option.preview]]"/>
    </span>
</div>

selected-item

This slot works exactly as option-item, but it is used to style the selected value when multi is false.

options

The slot options is there to provide an easy way to describe all the available options of the select. This is necessary because some frameworks may have problems in passing the array to the options prop. Each option will be a div and all the properties of the corresponding object can be written inside an attribute preceded by data-jvx-, like so:

<div slot="options">
    <div value="1" text="Lorem ipsum" data-jvx-color="blue" data-jvx-preview="path/to/first-image.jpg"></div>
    <div value="2" text="dolor sit amet" data-jvx-color="red" data-jvx-preview="path/to/second-image.jpg"></div>
</div>