Learning > ui > components > Color Edit this page Color The Color category in the @bentley/ui-components package includes classes and components for working with and picking a Color. Component Description AlphaSlider used to set the alpha value for a color ColorPickerButton used to pick a color from an array of available colors HueSlider used to set the hue value for a color SaturationPicker used to set the saturation value for a color ColorSwatch displays a color swatch in a button Samples Multiple Color Components Used Together The following sample shows the components above used together to form a color picker. Imports import { HSVColor, ColorDef, ColorByName } from "@bentley/imodeljs-common"; import { SaturationPicker, HueSlider, ColorSwatch } from "@bentley/ui-components"; State interface State { . . . shadowColor: ColorDef; } Preset Colors private readonly _presetColors = [ new ColorDef(ColorByName.grey), new ColorDef(ColorByName.lightGrey), new ColorDef(ColorByName.darkGrey), new ColorDef(ColorByName.lightBlue), new ColorDef(ColorByName.lightGreen), new ColorDef(ColorByName.darkGreen), new ColorDef(ColorByName.tan), new ColorDef(ColorByName.darkBrown), ]; render() method const colorSwatchStyle: React.CSSProperties = { width: `100%`, height: `100%`, }; . . . <div > <div className="shadow-settings-color"> <div className="shadow-settings-color-top"> <SaturationPicker hsv={this.state.shadowColor.toHSV()} onSaturationChange={this._handleHueOrSaturationChange} /> </div> <div className="shadow-settings-color-bottom"> <div className="shadow-settings-color-bottom-left"> <HueSlider hsv={this.state.shadowColor.toHSV()} onHueChange={this._handleHueOrSaturationChange} isHorizontal={true} /> </div> <div className="shadow-settings-color-bottom-right"> <ColorSwatch style={colorSwatchStyle} colorDef={this.state.shadowColor} round={false} /> </div> </div> </div> <div className="shadow-settings-color-presets"> <ColorSwatch colorDef={this._presetColors[0]} round={false} onColorPick={this._onPresetColorPick} /> <ColorSwatch colorDef={this._presetColors[1]} round={false} onColorPick={this._onPresetColorPick} /> <ColorSwatch colorDef={this._presetColors[2]} round={false} onColorPick={this._onPresetColorPick} /> <ColorSwatch colorDef={this._presetColors[3]} round={false} onColorPick={this._onPresetColorPick} /> <ColorSwatch colorDef={this._presetColors[4]} round={false} onColorPick={this._onPresetColorPick} /> <ColorSwatch colorDef={this._presetColors[5]} round={false} onColorPick={this._onPresetColorPick} /> <ColorSwatch colorDef={this._presetColors[6]} round={false} onColorPick={this._onPresetColorPick} /> <ColorSwatch colorDef={this._presetColors[7]} round={false} onColorPick={this._onPresetColorPick} /> </div> </div> Handler Functions private _onPresetColorPick = (shadowColor: ColorDef) => { this.setState({ shadowColor }, () => this.props.dataProvider.shadowColor = shadowColor); } private _handleHueOrSaturationChange = (hueOrSaturation: HSVColor) => { if (hueOrSaturation.s === 0) // for a ColorDef to be created from hsv s can't be 0 hueOrSaturation.s = 0.5; const shadowColor = hueOrSaturation.toColorDef(); this.setState({ shadowColor }, () => this.props.dataProvider.shadowColor = shadowColor); } ColorPickerButton Sample The following sample shows the ColorPickerButton component used to pick a color. Imports import { ColorDef } from "@bentley/imodeljs-common"; import { ColorPickerButton } from "@bentley/ui-components"; State interface State { . . . color: ColorDef; } render() method <ColorPickerButton initialColor={this.state.color} onColorPick={this._handleColorChange} /> Handler Function private _handleColorChange = (value: ColorDef) => { this.setState({color: value}); } Note: The properties for the ColorPickerButton are defined in the ColorPickerProps interface. The optional colorDefs prop may be used to provide the available colors. API Reference Color Last Updated: 11 June, 2024