UNPKG

@openshift-assisted/ui-lib

Version:

React component library for the Assisted Installer UI

30 lines 2.69 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const tslib_1 = require("tslib"); const React = tslib_1.__importStar(require("react")); const formik_1 = require("formik"); const react_core_1 = require("@patternfly/react-core"); const utils_1 = require("./utils"); const exclamation_circle_icon_1 = tslib_1.__importDefault(require("@patternfly/react-icons/dist/js/icons/exclamation-circle-icon")); // Reimplement this component to use custom Select in case of using it along the MultiSelectField component due to visual differences. // Idea: use Formik's field.multiple to switch among single and multi-selection. // See: https://www.patternfly.org/v4/components/form-select/design-guidelines#usage const SelectField = (_a) => { var { label, options, helperText, isRequired, onChange, getHelperText, idPostfix, labelIcon, callFormikOnChange = true } = _a, props = tslib_1.__rest(_a, ["label", "options", "helperText", "isRequired", "onChange", "getHelperText", "idPostfix", "labelIcon", "callFormikOnChange"]); const [field, { touched, error }] = (0, formik_1.useField)(props.name); const fieldId = (0, utils_1.getFieldId)(props.name, 'input', idPostfix); const isValid = !(touched && error); const errorMessage = !isValid ? error : ''; const hText = getHelperText ? getHelperText(field.value) : helperText; return (React.createElement(react_core_1.FormGroup, { fieldId: fieldId, label: label, isRequired: isRequired, labelIcon: labelIcon, id: `form-control__${fieldId}` }, React.createElement(react_core_1.FormSelect, Object.assign({}, field, props, { id: fieldId, validated: isValid ? 'default' : 'error', isRequired: isRequired, "aria-describedby": `${fieldId}-helper`, onChange: (event, value) => { //customHandleChange enables calling formik change handler explicitly, useful for example to have the previous value callFormikOnChange && field.onChange(event); onChange && onChange(event, value); } }), options.map((option, index) => (React.createElement(react_core_1.FormSelectOption, Object.assign({ key: option.id || index }, option))))), (errorMessage || hText) && (React.createElement(react_core_1.FormHelperText, null, React.createElement(react_core_1.HelperText, null, React.createElement(react_core_1.HelperTextItem, { icon: React.createElement(exclamation_circle_icon_1.default, null), variant: errorMessage ? 'error' : 'default', id: errorMessage ? `${fieldId}-helper-error` : `${fieldId}-helper` }, errorMessage ? errorMessage : hText)))))); }; exports.default = SelectField; //# sourceMappingURL=SelectField.js.map