1 | import { __rest } from "tslib";
|
2 | import * as React from 'react';
|
3 | import styles from '@patternfly/react-styles/css/components/Form/form';
|
4 | import { css } from '@patternfly/react-styles';
|
5 | import { FormFieldGroupToggle } from './FormFieldGroupToggle';
|
6 | import { GenerateId } from '../../helpers';
|
7 | export const InternalFormFieldGroup = (_a) => {
|
8 | var { children, className, header, isExpandable, isExpanded, onToggle, toggleAriaLabel } = _a, props = __rest(_a, ["children", "className", "header", "isExpandable", "isExpanded", "onToggle", "toggleAriaLabel"]);
|
9 | const headerTitleText = header ? header.props.titleText : null;
|
10 | if (isExpandable && !toggleAriaLabel && !headerTitleText) {
|
11 |
|
12 | console.error('FormFieldGroupExpandable:', 'toggleAriaLabel or the titleText prop of FormFieldGroupHeader is required to make the toggle button accessible');
|
13 | }
|
14 | return (React.createElement("div", Object.assign({ className: css(styles.formFieldGroup, isExpanded && isExpandable && styles.modifiers.expanded, className) }, props),
|
15 | isExpandable && (React.createElement(GenerateId, { prefix: "form-field-group-toggle" }, id => (React.createElement(FormFieldGroupToggle, Object.assign({ onToggle: onToggle, isExpanded: isExpanded, "aria-label": toggleAriaLabel, toggleId: id }, (headerTitleText && { 'aria-labelledby': `${header.props.titleText.id} ${id}` })))))),
|
16 | header && header,
|
17 | (!isExpandable || (isExpandable && isExpanded)) && (React.createElement("div", { className: css(styles.formFieldGroupBody) }, children))));
|
18 | };
|
19 | InternalFormFieldGroup.displayName = 'InternalFormFieldGroup';
|
20 |
|
\ | No newline at end of file |