5.2.1 • Published 4 years ago

selectorizer v5.2.1

Weekly downloads
2
License
ISC
Repository
github
Last release
4 years ago

Do you wanna beautify your selects using pure javascript or typescript? Ok. This package was created for you. I have written the most used methods in my opinion.

npm.io

Demo page: https://denoro55.github.io/selectorizer/ (native on mobiles)

Works in IE 10+

Simple example

const selects = document.querySelectorAll("select");
// const selects = document.querySelector("select"); will be the same result

selectorize(selects); // got the Controller anyway
selectorize(selects).getSelectorizers()[0]; // got the first selectorizer

implemented methods of Controller (group of Selectorizers):

  • getSelectorizers
  • getValues
  • open
  • close
  • change
  • addOptions
  • setOptions
  • refresh
  • destroy

implemented methods of Selectorizer:

all methods from Controller except "getValues"

  • getState
  • getCurrentValue
  • getElements
  • getWrapper
  • getSelect
  • getConfig

options:

PropertyDescriptionTypeDefault value
withIconSet icon renderingbooleantrue
iconHtmlSet icon htmlstring
isNativeOnMobileShow native dropdown on mobiles.booleanfalse
isMobileSet function for detecting mobile screen. Fires on init and window resizefunctionfunction
maxHeightMax height of dropdownnumber
classesAdditional classes on selectorizer wrapperstring[][]
placeholderLabel value when no selected optionsstring"Select value"
renderOptionSet html of optionfunction
renderLabelSet label html of selectorizerfunction
closeOnClickOutsideClose selectorizer when click outsidebooleantrue
calculateDropdownDirDefine dropdown position before openfunctionfunction
multipleSet delimiter of multiple select{ delimiter: string }{ delimiter: ',' }
callbacksDefine callback functions that trigger after different eventsobject

callbacks:

  • beforeInit?: (select: Selectorizer) => void;
  • init?: (select: Selectorizer) => void;
  • beforeOpen?: (select: Selectorizer) => void;
  • open?: (select: Selectorizer) => void;
  • beforeClose?: (select: Selectorizer) => void;
  • close?: (select: Selectorizer) => void;
  • beforeChange?: (select: Selectorizer) => void;
  • change?: (select: Selectorizer) => void;
  • beforeRefresh?: (select: Selectorizer) => void;
  • refresh?: (select: Selectorizer) => void;
  • click?: (select: Selectorizer) => void;
  • beforeDestroy?: (select: Selectorizer) => void;
  • destroy?: (select: Selectorizer) => void;

How to use:

import "selectorizer/lib/styles/index.scss";
import { selectorize } from "selectorizer";

// node list
const selects = document.querySelectorAll("select");
selectorize(selects);

// single select
const singleSelect = document.querySelector("select");
if (singleSelect) {
  selectorize(singleSelect);
}

// Warning! If you want to reinit your selectorizer just specify second argument
const selects = document.querySelectorAll("select");

// first init
selectorize(selects);

// reinit
selectorize(selects, {
  withIcon: false,
});

// init with some options
const selects = document.querySelectorAll("select");
selectorize(selects, {
  withIcon: false,
  classes: ["my-class"],
  callbacks: {
    init: (selectorizer) => {
      const state = selectorizer.getState();
      const $elements = selectorizer.getElements();
      const $wrapper = selectorizer.getWrapper();
      const $select = selectorizer.getSelect();
      const config = selectorizer.getConfig();

      console.log(
        "init",
        selectorizer,
        state,
        $elements,
        $wrapper,
        $select,
        config
      );
    },
  },
  renderOption: (selectorizer, option) =>
    `<div class="my-awesome-option">${option.text}</div>`,
  renderLabel: (selectorizer) =>
    `<div class="my-awesome-label">${selectorizer.getCurrentValue()}</div>`,
  renderPlaceholder: (selectorizer) =>
    `<div class="my-awesome-placeholder">${selectorizer.getConfig().placeholder}</div>`,
});

// ok. let's start to do something with our selects

// *** get values of selects ***
selectorize(selects).getValues();
// [ { name: 'select-1', value: 'option 1' }, { name: 'select-2', value: 'option 1' } ]

// *** open selects ***
selectorize(selects).open();

// *** close selects ***
selectorize(selects).close();

// *** change value of selects ***
selectorize(selects).change("option 3");

// *** add new options ***
selectorize(selects).addOptions([
  { value: "new option 1", text: "new option 1" },
  { value: "new option 2", text: "new option 2" },
]);

// Warning! You can also update your native select without implemented methods, but then you must call refresh method
const $select = document.createElement("select");
const selectorizer = selectorize($select);

// append new option
const $option = document.createElement("option");
$option.value = "new value";
$option.text = "new value";
$select.appendChild(option);

// refresh selectorizer
selectorizer.refresh();

// *** set only specified options ***
selectorize(selects).setOptions([
  { value: "new option 1", text: "new option 1" },
  { value: "new option 2", text: "new option 2" },
]);

// *** destroy :( ***
selectorize(selects).destroy();
5.2.1

4 years ago

5.2.0

4 years ago

5.1.1

5 years ago

5.0.2

5 years ago

5.1.0

5 years ago

5.0.1

5 years ago

5.0.0

5 years ago

3.0.4

6 years ago

4.0.1

6 years ago

4.0.0

6 years ago

4.0.3

6 years ago

4.0.2

6 years ago

3.0.3

6 years ago

3.0.2

6 years ago

3.0.1

6 years ago

3.0.0

6 years ago

2.0.0

6 years ago

1.0.7

6 years ago

1.0.6

6 years ago

1.0.5

6 years ago

1.0.4

6 years ago

1.0.3

6 years ago

1.0.2

6 years ago

1.0.1

6 years ago

1.0.0

6 years ago