MultiSelect
MultiSelect consente agli utenti di selezionare più opzioni da una lista a discesa. Supporta stati di apertura e chiusura, rendering personalizzato dei valori e navigazione da tastiera tra le altre funzionalità.
Utilizzo
Sezione intitolata “Utilizzo”Per usare il MultiSelect, importalo insieme al suo componente item. Puoi passare prop come value, onMultiValueChange, size, label, disabled e molte altre per personalizzarne il comportamento e l’aspetto.
MultiSelect di base
Sezione intitolata “MultiSelect di base”Un esempio semplice che dimostra l’utilizzo base del componente MultiSelect.
import * as React from "react";import { MultiSelect, MultiSelectItem } from "@firecms/ui";
export default function MultiSelectBasicDemo() { const [selectedValues, setSelectedValues] = React.useState<string[]>([]);
return ( <MultiSelect value={selectedValues} onValueChange={setSelectedValues} label="Basic MultiSelect"> <MultiSelectItem value="option1">Option 1</MultiSelectItem> <MultiSelectItem value="option2">Option 2</MultiSelectItem> <MultiSelectItem value="option3">Option 3</MultiSelectItem> </MultiSelect> );}Rendering valore personalizzato
Sezione intitolata “Rendering valore personalizzato”Questo esempio mostra come personalizzare il rendering dei valori selezionati.
import * as React from "react";import { MultiSelect, MultiSelectItem } from "@firecms/ui";
export default function MultiSelectCustomRenderDemo() { const [selectedValues, setSelectedValues] = React.useState<string[]>([]);
return ( <MultiSelect value={selectedValues} onValueChange={setSelectedValues} label="Custom Render MultiSelect" renderValues={(values) => (values.map((value, index) => <span key={index} style={{ marginRight: 8, background: "#eee", padding: 4 }}> {value} </span>) )}> <MultiSelectItem value="red">Red</MultiSelectItem> <MultiSelectItem value="green">Green</MultiSelectItem> <MultiSelectItem value="blue">Blue</MultiSelectItem> </MultiSelect> );}Gestione dello stato disabilitato
Sezione intitolata “Gestione dello stato disabilitato”Un esempio per dimostrare un componente MultiSelect in stato disabilitato.
import * as React from "react";import { MultiSelect, MultiSelectItem } from "@firecms/ui";
export default function MultiSelectDisabledDemo() { return ( <MultiSelect disabled label="Disabled MultiSelect" value={["option1"]} renderValues={(values) => (values.map((value) => <span key={value} style={{ marginRight: 8, background: "#eee", padding: 4 }}> {value} </span>) )}> <MultiSelectItem value="option1">Option 1</MultiSelectItem> <MultiSelectItem value="option2">Option 2 is disabled</MultiSelectItem> <MultiSelectItem value="option3">Option 3 is disabled</MultiSelectItem> </MultiSelect> );}