# Color Area Allows users to adjust two channels of an RGB, HSL, or HSB color value against a two-dimensional gradient background. ## Import ``` Copyts import { ColorArea } from "@kobalte/core/color-area"; // or import { Root, Background, ... } from "@kobalte/core/color-area"; ``` ``` Copyts import { ColorArea } from "@kobalte/core/color-area"; // or import { Root, Background, ... } from "@kobalte/core/color-area"; ``` ## Features - Can be controlled or uncontrolled. - Support for adjusting two-channel values of an RGB, HSL or HSB color value. - Pressing on the color area background moves the thumb to that position. - Supports using the arrow keys, for changing value by step, as well as shift + arrow key, page up/down, home, and end keys, for changing the value by page step. - Support for disabling the color area. - Prevents text selection while dragging. - Exposed to assistive technology as a 2D slider element via ARIA. - Uses two hidden native input elements within a group to support touch screen readers. - Automatic ARIA labeling using the localized channel names by default. - Support for mirroring in RTL locales. ## Anatomy The color area consists of: - **ColorArea:** The root container for the color area. - **ColorArea.Background:** The component that visually represents the range of colors from which a user can select. - **ColorArea.Thumb:** The thumb that is used to visually indicate a value in the color area background. - **ColorArea.HiddenInputX:** The horizontal native html input that is visually hidden in the color area thumb. - **ColorArea.HiddenInputY:** The vertical native html input that is visually hidden in the color area thumb. - **ColorArea.Label:** The label that gives the user information on the color area. ``` Copytsx ``` ``` Copytsx ``` ## Example Label index.tsxstyle.css ``` Copytsx import { ColorArea } from "@kobalte/core/color-area"; import { parseColor } from "@kobalte/utils"; import "./style.css"; function App() { return ( Label ); } ``` ``` Copytsx import { ColorArea } from "@kobalte/core/color-area"; import { parseColor } from "@kobalte/utils"; import "./style.css"; function App() { return ( Label ); } ``` ## Usage The value provided to `defaultValue` or `value` should be `Color` object. You can obtain a Color object by using the `parseColor` function to parse a color from a string. The `xChannel` and `yChannel` must be one of the channels included in the color value, for example, for RGB colors, the "red", "green", and "blue" channels are available. If no `xChannel` or `yChannel` is provided, for the RGB color space, the red color channel maps to the horizontal axis or xChannel, and the green color channel maps to the vertical axis or yChannel. Similarly, for the HSL and HSB color spaces, the hue color channel maps to the horizontal axis or xChannel, and the saturation color channel maps to the vertical axis or yChannel. ### Default value Label ``` Copytsx Label ``` ``` Copytsx Label ``` ### Controlled value Label Current color value: hsl(0 100% 50%) ``` Copytsx import { createSignal } from "solid-js"; const [value, setValue] = createSignal(parseColor("hsl(0, 100%, 50%)")); <> Label

Current color value: {value().toString("hsl")}

; ``` ``` Copytsx import { createSignal } from "solid-js"; const [value, setValue] = createSignal(parseColor("hsl(0, 100%, 50%)")); <> Label

Current color value: {value().toString("hsl")}

; ``` ### xChannel and yChannel The color channel for each axis of a color area can be specified using the `xChannel` and `yChannel` props. An array of channel names for a color can be returned using the color.getColorChannels method. Label ``` Copytsx const [value, setValue] = createSignal(parseColor("rgb(100, 149, 237)")); const [rChannel, gChannel, bChannel] = value().getColorChannels(); Label ; ``` ``` Copytsx const [value, setValue] = createSignal(parseColor("rgb(100, 149, 237)")); const [rChannel, gChannel, bChannel] = value().getColorChannels(); Label ; ``` ### HTML forms ColorArea supports the `xName` and `yName` props for integration with HTML forms. Label ResetSubmit ``` Copytsx Label ``` ``` Copytsx Label ``` ## API Reference ### ColorArea `ColorArea` is equivalent to the `Root` import from `@kobalte/core/color-area`. | Prop | Description | | --- | --- | | value | `Color`
The controlled value of the color area.. | | defaultValue | `Color`
The value of the color area when initially rendered. | | colorSpace | `ColorSpace`
The color space that the color area operates in. The `xChannel` and `yChannel` must be in this color space. | | onChange | `(value: Color) => void`
Event handler called when the value changes. | | onChangeEnd | `(value: Color) => void`
Event handler called when the value changes at the end of an interaction. | | xChannel | `ColorChannel`
Color channel for the horizontal axis. | | yChannel | `ColorChannel`
Color channel for the vertical axis. | | xName | `string`
The name of the x channel input element, used when submitting an HTML form. See [MDN](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#htmlattrdefname). | | yName | `string`
The name of the y channel input element, used when submitting an HTML form. See [MDN](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#htmlattrdefname). | | name | `string`
The name of the color area, used when submitting an HTML form. | | validationState | `'valid' | 'invalid'`
Whether the color area should display its "valid" or "invalid" visual styling. | | required | `boolean`
Whether the user must check a radio group item before the owning form can be submitted. | | disabled | `boolean`
Whether the radio group is disabled. | | readOnly | `boolean`
Whether the radio group items can be selected but not changed by the user. | | translations | `ColorAreaIntlTranslations`
Localization strings. | | Data attribute | Description | | --- | --- | | data-valid | Present when the slider is valid according to the validation rules. | | data-invalid | Present when the slider is invalid according to the validation rules. | | data-required | Present when the user must slider an item before the owning form can be submitted. | | data-disabled | Present when the slider is disabled. | | data-readonly | Present when the slider is read only. | `ColorArea.Background`, `ColorArea.Thumb`, `ColorArea.HiddenInputX`, `ColorArea.HiddenInputY` and `ColorArea.Label` share the same data-attributes. ### ColorArea.Thumb The current color is available on the thumb using the custom css property `--kb-color-current`. ### ColorArea.HiddenInputX | Data attribute | Description | | --- | --- | | data-orientation='horizontal' | Always presesnt | ### ColorArea.HiddenInputY | Data attribute | Description | | --- | --- | | data-orientation='vertical' | Always presesnt | ## Rendered elements | Component | Default rendered element | | --- | --- | | `ColorArea` | `div` | | `ColorArea.Background` | `div` | | `ColorArea.Thumb` | `span` | | `ColorArea.HiddenInputX` | `input` | | `ColorArea.HiddenInputY` | `input` | | `ColorArea.Label` | `label` | | `ColorArea.Description` | `div` | | `ColorArea.ErrorMessage` | `div` | ## Accessibility ### Keyboard Interactions | Key | Description | | --- | --- | | `PageUp` | Increments the value of the thumb in the vertical axis by a larger step. | | `PageDown` | Decrements the value of the thumb in the vertical axis by a larger step. | | `ArrowDown` | Decrements the value of the thumb in the vertical axis by the step amount. | | `ArrowUp` | Increments the value of the thumb in the vertical axis by the step amount. | | `ArrowRight` | Increments the value of the thumb in the horizontal axis by the step amount. | | `ArrowLeft` | Decrements the value of the thumb in the vertical axis by the step amount. | | `Home` | Decrements the value of the thumb in the horizontal axis by a larger step. | | `End` | Increments the value of the thumb in the horizontal axis by a larger step. | Previous[←Collapsible](https://kobalte.dev/docs/core/components/collapsible)Next[Color Channel Field→](https://kobalte.dev/docs/core/components/color-channel-field)