UNPKG

1.48 kBTypeScriptView Raw
1/*
2 * Copyright 2020 Ladifire. All rights reserved.
3 * This file is licensed to you under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License. You may obtain a copy
5 * of the License at http://www.apache.org/licenses/LICENSE-2.0
6 *
7 * Unless required by applicable law or agreed to in writing, software distributed under
8 * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
9 * OF ANY KIND, either express or implied. See the License for the specific language
10 * governing permissions and limitations under the License.
11 */
12
13import {ReactNode} from 'react';
14
15export type LabelPosition = 'top' | 'side';
16export type Alignment = 'start' | 'end';
17export type NecessityIndicator = 'icon' | 'label';
18
19export interface LabelableProps {
20 /** The content to display as the label. */
21 label?: ReactNode,
22 /** Whether the label is labeling a required field or group. */
23 isRequired?: boolean
24}
25
26export interface SpectrumLabelableProps extends LabelableProps {
27 /**
28 * The label's overall position relative to the element it is labeling.
29 * @default 'top'
30 */
31 labelPosition?: LabelPosition,
32 /**
33 * The label's horizontal alignment relative to the element it is labeling.
34 * @default 'start'
35 */
36 labelAlign?: Alignment,
37 /**
38 * Whether the required state should be shown as an icon or text.
39 * @default 'icon'
40 */
41 necessityIndicator?: NecessityIndicator
42}