UNPKG

@eccenca/gui-elements

Version:

GUI elements based on other libraries, usable in React application, written in Typescript.

109 lines 7.84 kB
var __assign = (this && this.__assign) || function () { __assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; var __rest = (this && this.__rest) || function (s, e) { var t = {}; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; } return t; }; import React from "react"; import { Classes as BlueprintClassNames, TextArea as BlueprintTextArea, } from "@blueprintjs/core"; import { Definitions as IntentDefinitions } from "../../common/Intent/index.js"; import { CLASSPREFIX as eccgui } from "../../configuration/constants.js"; import { Icon } from "../Icon/index.js"; import { useTextValidation } from "./useTextValidation.js"; export var TextArea = function (_a) { var _b = _a.className, className = _b === void 0 ? "" : _b, _c = _a.rows, rows = _c === void 0 ? 5 : _c, invisibleCharacterWarning = _a.invisibleCharacterWarning, leftIcon = _a.leftIcon, rightElement = _a.rightElement, wrapperDivProps = _a.wrapperDivProps, intent = _a.intent, otherBlueprintTextAreaProps = __rest(_a, ["className", "rows", "invisibleCharacterWarning", "leftIcon", "rightElement", "wrapperDivProps", "intent"]); var textAreaCallback = React.useCallback(function (textAreaElement) { var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r; if (textAreaElement && typeof textAreaElement === "object") { var textAreaStyle = void 0; if (!textAreaElement.dataset.processed) { textAreaStyle = getComputedStyle(textAreaElement); textAreaElement.dataset.processed = "yes"; textAreaElement.dataset.paddingtop = (_a = textAreaStyle.paddingTop) !== null && _a !== void 0 ? _a : "0px"; textAreaElement.dataset.paddingleft = (_b = textAreaStyle.paddingLeft) !== null && _b !== void 0 ? _b : "0px"; textAreaElement.dataset.paddingright = (_c = textAreaStyle.paddingRight) !== null && _c !== void 0 ? _c : "0px"; } else { textAreaStyle = { paddingTop: (_d = textAreaElement.dataset.paddingtop) !== null && _d !== void 0 ? _d : "0px", paddingLeft: (_e = textAreaElement.dataset.paddingleft) !== null && _e !== void 0 ? _e : "0px", paddingRight: (_f = textAreaElement.dataset.paddingright) !== null && _f !== void 0 ? _f : "0px", }; } var textAreaElementRect = textAreaElement.getBoundingClientRect(); var wrapperElement = textAreaElement.parentElement; if (leftIcon && wrapperElement) { var leftIconElement = wrapperElement.querySelector(".".concat(eccgui, "-textarea__icon")); var leftIconElementRect = leftIconElement.getBoundingClientRect(); if (parseInt(textAreaStyle.paddingTop, 10) * 2 + ((_g = leftIconElementRect.height) !== null && _g !== void 0 ? _g : 0) <= ((_h = textAreaElementRect.height) !== null && _h !== void 0 ? _h : 0)) { leftIconElement.style.setProperty("top", textAreaStyle.paddingTop); } else { leftIconElement.style.setProperty("top", "".concat((((_j = textAreaElementRect.height) !== null && _j !== void 0 ? _j : 0) - ((_k = leftIconElementRect.height) !== null && _k !== void 0 ? _k : 0)) * 0.5, "px")); } leftIconElement.style.setProperty("left", textAreaStyle.paddingLeft); textAreaElement.style.setProperty("padding-left", "calc(".concat(leftIconElementRect.width ? 2 : 1, " * ").concat(textAreaStyle.paddingLeft, " + ").concat((_l = leftIconElementRect.width) !== null && _l !== void 0 ? _l : 0, "px)")); leftIconElement.addEventListener("click", function () { textAreaElement.focus(); }); } if (rightElement && wrapperElement) { var rightElementElement = wrapperElement.querySelector(".".concat(eccgui, "-textarea__options")); var rightElementElementRect = rightElementElement.getBoundingClientRect(); if (parseInt(textAreaStyle.paddingTop, 10) * 2 + ((_m = rightElementElementRect.height) !== null && _m !== void 0 ? _m : 0) <= ((_o = textAreaElementRect.height) !== null && _o !== void 0 ? _o : 0)) { rightElementElement.style.setProperty("top", textAreaStyle.paddingTop); } else { rightElementElement.style.setProperty("top", "".concat((((_p = textAreaElementRect.height) !== null && _p !== void 0 ? _p : 0) - ((_q = rightElementElementRect.height) !== null && _q !== void 0 ? _q : 0)) * 0.5, "px")); } rightElementElement.style.setProperty("right", textAreaStyle.paddingRight); textAreaElement.style.setProperty("padding-right", "calc(".concat(rightElementElementRect.width ? 2 : 1, " * ").concat(textAreaStyle.paddingRight, " + ").concat((_r = rightElementElementRect.width) !== null && _r !== void 0 ? _r : 0, "px)")); } } }, [leftIcon, rightElement]); var iconIntent; switch (intent) { case "edited": iconIntent = IntentDefinitions.INFO; break; case "removed": iconIntent = IntentDefinitions.DANGER; break; default: iconIntent = intent; break; } var maybeWrappedOnChange = useTextValidation(__assign(__assign({}, otherBlueprintTextAreaProps), { invisibleCharacterWarning: invisibleCharacterWarning })); var textarea = (React.createElement(BlueprintTextArea, __assign({ inputRef: textAreaCallback, className: "".concat(eccgui, "-textarea") + (intent ? " ".concat(eccgui, "-intent--").concat(intent) : "") + (className ? " ".concat(className) : ""), intent: intent && !["info", "edited", "removed", "neutral"].includes(intent) ? intent : undefined, spellCheck: intent === "removed" ? false : undefined, rows: rows && !otherBlueprintTextAreaProps.autoResize && !otherBlueprintTextAreaProps.growVertically ? rows : 2 }, otherBlueprintTextAreaProps, { dir: "auto", onChange: maybeWrappedOnChange }))); var _d = wrapperDivProps !== null && wrapperDivProps !== void 0 ? wrapperDivProps : {}, wrapperClassName = _d.className, otherWrapperDivProps = __rest(_d, ["className"]); return wrapperDivProps || leftIcon || rightElement ? (React.createElement("div", __assign({ className: "".concat(eccgui, "-textarea__wrapper") + (wrapperClassName ? " ".concat(wrapperClassName) : "") }, otherWrapperDivProps), textarea, leftIcon && (React.createElement("div", { className: "".concat(eccgui, "-textarea__icon") }, typeof leftIcon === "string" ? (React.createElement(Icon, { name: leftIcon, className: BlueprintClassNames.ICON, intent: iconIntent })) : (React.createElement("span", { className: BlueprintClassNames.ICON }, leftIcon)))), rightElement && React.createElement("div", { className: "".concat(eccgui, "-textarea__options") }, rightElement))) : (textarea); }; export default TextArea; //# sourceMappingURL=TextArea.js.map