@gravity-ui/uikit
Version:
Gravity UI base styling and components
22 lines (21 loc) • 1.48 kB
JavaScript
'use client';
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.ActionTooltip = ActionTooltip;
const tslib_1 = require("tslib");
const jsx_runtime_1 = require("react/jsx-runtime");
const React = tslib_1.__importStar(require("react"));
const Hotkey_1 = require("../Hotkey/index.js");
const Tooltip_1 = require("../Tooltip/index.js");
const cn_1 = require("../utils/cn.js");
require("./ActionTooltip.css");
const b = (0, cn_1.block)('action-tooltip');
const DEFAULT_OPEN_DELAY = 500;
const DEFAULT_CLOSE_DELAY = 0;
function ActionTooltip({ title, description, hotkey, openDelay = DEFAULT_OPEN_DELAY, closeDelay = DEFAULT_CLOSE_DELAY, className, ...restProps }) {
const content = React.useMemo(() => ((0, jsx_runtime_1.jsxs)(React.Fragment, { children: [(0, jsx_runtime_1.jsxs)("div", { className: b('heading'), children: [(0, jsx_runtime_1.jsx)("div", { className: b('title'), children: title }), hotkey && (0, jsx_runtime_1.jsx)(Hotkey_1.Hotkey, { view: "dark", value: hotkey, className: b('hotkey') })] }), description && (0, jsx_runtime_1.jsx)("div", { className: b('description'), children: description })] })), [title, description, hotkey]);
return ((0, jsx_runtime_1.jsx)(Tooltip_1.Tooltip, { ...restProps,
// eslint-disable-next-line jsx-a11y/aria-role
role: "label", content: content, openDelay: openDelay, closeDelay: closeDelay, className: b(null, className) }));
}
//# sourceMappingURL=ActionTooltip.js.map