UNPKG

@openshift-assisted/ui-lib

Version:

React component library for the Assisted Installer UI

58 lines 3.93 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 react_code_editor_1 = require("@patternfly/react-code-editor"); const useFieldErrorMsg_1 = tslib_1.__importDefault(require("../../../hooks/useFieldErrorMsg")); const exclamation_circle_icon_1 = tslib_1.__importDefault(require("@patternfly/react-icons/dist/js/icons/exclamation-circle-icon")); const paste_icon_1 = tslib_1.__importDefault(require("@patternfly/react-icons/dist/js/icons/paste-icon")); const CodeField = ({ label, labelIcon, helperText, isRequired, validate, idPostfix, language, name, description, isDisabled, downloadFileName, dataTestid, isReadOnly, showCustomControls = false, }) => { const [field, , { setValue, setTouched }] = (0, formik_1.useField)({ name, validate }); const fieldId = (0, utils_1.getFieldId)(name, 'input', idPostfix); const errorMessage = (0, useFieldErrorMsg_1.default)({ name, validate }); const isValid = !errorMessage; const pasteFromClipboardFirefox = () => { return new Promise((resolve) => { const handlePaste = (e) => { var _a; const text = (_a = e === null || e === void 0 ? void 0 : e.clipboardData) === null || _a === void 0 ? void 0 : _a.getData('text/plain'); document.removeEventListener('paste', handlePaste); resolve(text); }; document.addEventListener('paste', handlePaste); alert('Use Ctrl+V to paste the content in this browser'); }); }; const pasteFromClipboard = () => tslib_1.__awaiter(void 0, void 0, void 0, function* () { if (navigator.clipboard && navigator.clipboard.readText) { try { return yield navigator.clipboard.readText(); } catch (err) { return ''; } } else { const text = yield pasteFromClipboardFirefox(); return text; } }); const customControl = (React.createElement(react_code_editor_1.CodeEditorControl, { icon: React.createElement(paste_icon_1.default, null), "aria-label": "Paste content", tooltipProps: { content: 'Paste content' }, onClick: () => { void pasteFromClipboard().then((text) => setValue(text, true)); }, isVisible: true })); return (React.createElement(react_core_1.FormGroup, { fieldId: fieldId, label: label, isRequired: isRequired, labelIcon: labelIcon, "data-testid": dataTestid ? dataTestid : `${fieldId}-testid` }, description && (React.createElement(react_core_1.HelperText, null, React.createElement(react_core_1.HelperTextItem, { variant: "indeterminate" }, description))), React.createElement(react_code_editor_1.CodeEditor, { code: field.value, isUploadEnabled: !isDisabled, isDownloadEnabled: isValid, isCopyEnabled: true, isLanguageLabelVisible: true, height: "400px", language: language, downloadFileName: downloadFileName, onCodeChange: (value) => { setTouched(true); setValue(value, true); }, isReadOnly: isReadOnly, customControls: showCustomControls ? customControl : undefined }), (errorMessage || helperText) && (React.createElement(react_core_1.FormHelperText, null, React.createElement(react_core_1.HelperText, null, React.createElement(react_core_1.HelperTextItem, { icon: errorMessage && React.createElement(exclamation_circle_icon_1.default, null), variant: errorMessage ? 'error' : 'default', id: errorMessage ? `${fieldId}-helper-error` : `${fieldId}-helper` }, errorMessage ? errorMessage : helperText)))))); }; exports.default = CodeField; //# sourceMappingURL=CodeField.js.map