react-item-switcher v1.0.6
react-item-switcher
Simple Item Switcher control. Faxible for change the design for control. More control over switching element.
Usages
Basic Properties to Initilized the ItemSwitcher
<ItemSwitcher
items= {[{text: 'one', value:'one'}, {text: 'two', value:'two'}]}
isMultiple={true}
selectSize={10}
getSelectedValue={this.getSelectedValue}
onChangeValue={this.onChangeValue}
/>items:it will takes the options list array to load in left side list, using for selection.isMultiple:it provide the functinality to select multiple value from list.trueis enable themultipleselection andfalsewill remove the multiple select functionality.selectSize:it will define the size of the list view. it task number value such as:1,2,3....getSelectedValue:it an event forGet Valuebutton to get selected list items value.onChangeValueit will provide the selected items value when change switch one items from left to right, you will get value of selected right size list items array.
Example Code
import React, { Component } from "react";
import ReactDOM from "react-dom";
import ItemSwitcher from "react-item-switcher";
export class App extends Component {
constructor(props) {
super(props);
this.state = {
selectedItems: []
}
}
getSelectedValue = (selectedItems) => {
console.log(selectedItems)
this.setState({selectedItems: selectedItems})
};
getChangeValue = (selectedItems) => {
console.log(selectedItems)
this.setState({selectedItems: selectedItems})
}
render() {
return (
<div>
Test element
<ItemSwitcher
items= {[{text: 'one', value:'one'}, {text: 'two', value:'two'}]}
isMultiple={true}
selectSize={10}
getSelectedValue={this.getSelectedValue}
onChangeValue={this.getChangeValue}
/>
</div>
);
}
}
const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);Design Properties
| Properties | Description |
|---|---|
selectWidth | using for increase or dicrease the width of list.(e.g selectWidth: "10px") |
leftBackgroundColor and rightBackgroundColor | using for add the background color in list box. its support color code and hex and rgba color |
leftSelectBorder and rightSelectBorder | using for add the border style in list box. (e.g leftSelectBorder: "1px solid blue") |
itemTextAlign | using for align the text. it supports center, left, right |
showGetValueButton | hide and show the Get Value button.it takes true or false |
With Design Example
Using selectWidth properties
<ItemSwitcher
...
selectSize={20}
...
/>- Using the numeric size to increase and decrease the size of the listbox
using leftBackgroundColor and rightBackgroundColor properties
<ItemSwitcher
...
leftBackgroundColor={"#898"}
rightBackgroundColor={"blue"}
...
/>leftBackgroundColorwill takes thecolor codeorhexorrgbacolorrightBackgroundColorwill takes thecolor codeorhexorrgbacolorUsing the numeric size to increase and decrease the size of the listbox
using leftSelectBorder and rightSelectBorder andright properties
<ItemSwitcher
...
leftSelectBorder={"1px solid blue"}
rightSelectBorder={"1px solid green"}
...
/>- those two property will change the switcher border colors and border width also
using itemTextAlign to align the text for list box
<ItemSwitcher
...
itemTextAlign={"center"}
...
/>- this properties value supports
centerandrightandleftvalue
using showGetValueButton properties
<ItemSwitcher
...
showGetValueButton={true}
...
/>- This properties takes
blockornonevalue. you can hidenonevalue and show byblockvalue forGet Valuebutton.
Get The value of the Selected Items
- Add the State in
react constructorby
this.state = {
selectedItems: []
}- call the function in
react elementby
getChangeValue = selectedItems => {
console.log(selectedItems);
this.setState({ selectedItems: selectedItems });
};- Add the function to
noChangeValueproperties ofItemSwitcher
/** add the method in react smart component */
<ItemSwitcher
...
onChangeValue={this.getChangeValue}
...
/>Full Code Example of react-item-switcher
import React, { Component } from "react";
import ReactDOM from "react-dom";
import ItemSwitcher from "react-item-switcher";
export class App extends Component {
constructor(props) {
super(props);
this.state = {
selectedItems: []
};
}
getSelectedValue = selectedItems => {
console.log(selectedItems);
this.setState({ selectedItems: selectedItems });
};
getChangeValue = selectedItems => {
console.log(selectedItems);
this.setState({ selectedItems: selectedItems });
};
render() {
return (
<div>
Test element
<ItemSwitcher
items={[{ text: "one", value: "one" }, { text: "two", value: "two" }]}
isMultiple={true}
getSelectedValue={this.getSelectedValue}
onChangeValue={this.getChangeValue}
selectSize={5}
leftBackgroundColor={"#898"}
rightBackgroundColor={"#ddd"}
rightSelectBorder={"2px solid green"}
leftSelectBorder={"2px solid blue"}
itemTextAlign={`right`}
showGetValueButton={'none'}
/>
</div>
);
}
}
const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);