@dxc-technology/halstack-react 12.0.2 → 12.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/HalstackContext.d.ts +23 -0
- package/HalstackContext.js +31 -21
- package/breadcrumbs/Breadcrumbs.stories.tsx +1 -1
- package/breadcrumbs/Breadcrumbs.test.js +1 -2
- package/breadcrumbs/types.d.ts +24 -0
- package/card/Card.stories.tsx +1 -1
- package/chip/Chip.stories.tsx +2 -6
- package/common/coreTokens.d.ts +0 -1
- package/common/coreTokens.js +0 -1
- package/common/variables.d.ts +29 -0
- package/common/variables.js +25 -2
- package/container/types.d.ts +113 -11
- package/contextual-menu/ContextualMenu.js +56 -8
- package/contextual-menu/ContextualMenu.stories.tsx +50 -51
- package/contextual-menu/ContextualMenu.test.js +108 -66
- package/contextual-menu/GroupItem.js +9 -9
- package/contextual-menu/ItemAction.d.ts +1 -1
- package/contextual-menu/ItemAction.js +52 -15
- package/contextual-menu/SingleItem.d.ts +1 -1
- package/contextual-menu/SingleItem.js +14 -14
- package/contextual-menu/types.d.ts +13 -6
- package/date-input/Calendar.js +46 -30
- package/date-input/DateInput.accessibility.test.js +12 -13
- package/date-input/DateInput.js +9 -3
- package/date-input/DateInput.stories.tsx +5 -6
- package/date-input/DateInput.test.js +30 -31
- package/date-input/YearPicker.js +9 -4
- package/dialog/Dialog.stories.tsx +2 -3
- package/dialog/Dialog.test.js +1 -2
- package/divider/Divider.stories.tsx +2 -1
- package/dropdown/Dropdown.accessibility.test.js +1 -2
- package/dropdown/Dropdown.stories.tsx +1 -1
- package/dropdown/Dropdown.test.js +1 -2
- package/file-input/FileInput.js +1 -3
- package/file-input/FileItem.js +1 -1
- package/file-input/types.d.ts +0 -4
- package/grid/Grid.stories.tsx +3 -1
- package/header/Header.stories.tsx +1 -1
- package/icon/Icon.stories.tsx +1 -1
- package/number-input/NumberInput.accessibility.test.js +1 -2
- package/number-input/NumberInput.js +5 -2
- package/number-input/NumberInput.stories.tsx +11 -16
- package/number-input/NumberInput.test.js +1 -2
- package/package.json +19 -16
- package/paginator/Paginator.accessibility.test.js +1 -2
- package/paginator/Paginator.test.js +1 -2
- package/password-input/PasswordInput.accessibility.test.js +1 -2
- package/password-input/PasswordInput.js +6 -3
- package/password-input/PasswordInput.stories.tsx +10 -1
- package/password-input/PasswordInput.test.js +1 -2
- package/resultset-table/ResultsetTable.accessibility.test.js +1 -2
- package/resultset-table/ResultsetTable.js +33 -9
- package/resultset-table/ResultsetTable.stories.tsx +2 -2
- package/resultset-table/ResultsetTable.test.js +102 -32
- package/resultset-table/types.d.ts +3 -2
- package/select/Select.accessibility.test.js +1 -2
- package/select/Select.js +3 -1
- package/select/Select.stories.tsx +11 -2
- package/select/Select.test.js +1 -2
- package/sidenav/Sidenav.stories.tsx +1 -1
- package/slider/Slider.accessibility.test.js +1 -2
- package/slider/Slider.test.js +1 -2
- package/table/Table.accessibility.test.js +1 -2
- package/table/Table.stories.tsx +1 -1
- package/table/Table.test.js +1 -2
- package/tabs/Tabs.stories.tsx +2 -2
- package/tag/Tag.stories.tsx +1 -1
- package/text-input/TextInput.accessibility.test.js +1 -2
- package/text-input/TextInput.js +3 -1
- package/text-input/TextInput.stories.tsx +11 -8
- package/text-input/TextInput.test.js +1 -2
- package/toggle-group/ToggleGroup.stories.tsx +1 -1
- package/tooltip/Tooltip.accessibility.test.d.ts +1 -0
- package/tooltip/Tooltip.accessibility.test.js +144 -0
- package/tooltip/Tooltip.d.ts +4 -0
- package/tooltip/Tooltip.js +50 -0
- package/tooltip/Tooltip.stories.tsx +111 -0
- package/tooltip/Tooltip.test.d.ts +1 -0
- package/tooltip/Tooltip.test.js +112 -0
- package/tooltip/types.d.ts +16 -0
- package/tooltip/types.js +5 -0
- package/typography/Typography.stories.tsx +1 -3
- package/typography/Typography.test.js +23 -0
- package/useTheme.d.ts +23 -0
- package/utils/BaseTypography.js +44 -40
- package/utils/FocusLock.js +2 -1
- package/wizard/Wizard.stories.tsx +1 -1
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
5
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
6
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
7
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var _react2 = require("@testing-library/react");
|
|
10
|
+
var _axeHelper = require("../../test/accessibility/axe-helper.js");
|
|
11
|
+
var _Tooltip = _interopRequireDefault(require("./Tooltip"));
|
|
12
|
+
var _Button = _interopRequireDefault(require("../button/Button"));
|
|
13
|
+
global.globalThis = global;
|
|
14
|
+
global.DOMRect = {
|
|
15
|
+
fromRect: function fromRect() {
|
|
16
|
+
return {
|
|
17
|
+
top: 0,
|
|
18
|
+
left: 0,
|
|
19
|
+
bottom: 0,
|
|
20
|
+
right: 0,
|
|
21
|
+
width: 0,
|
|
22
|
+
height: 0,
|
|
23
|
+
x: 0,
|
|
24
|
+
y: 0
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
global.ResizeObserver = /*#__PURE__*/function () {
|
|
29
|
+
function ResizeObserver() {
|
|
30
|
+
(0, _classCallCheck2["default"])(this, ResizeObserver);
|
|
31
|
+
}
|
|
32
|
+
return (0, _createClass2["default"])(ResizeObserver, [{
|
|
33
|
+
key: "observe",
|
|
34
|
+
value: function observe() {}
|
|
35
|
+
}, {
|
|
36
|
+
key: "unobserve",
|
|
37
|
+
value: function unobserve() {}
|
|
38
|
+
}, {
|
|
39
|
+
key: "disconnect",
|
|
40
|
+
value: function disconnect() {}
|
|
41
|
+
}]);
|
|
42
|
+
}();
|
|
43
|
+
describe("Tooltip component accessibility tests", function () {
|
|
44
|
+
it("Should not have basic accessibility issues for bottom position", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
45
|
+
var _render, baseElement, getByText, triggerElement, results;
|
|
46
|
+
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
47
|
+
while (1) switch (_context.prev = _context.next) {
|
|
48
|
+
case 0:
|
|
49
|
+
// baseElement is needed when using React Portals
|
|
50
|
+
_render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tooltip["default"], {
|
|
51
|
+
label: "Tooltip Test",
|
|
52
|
+
position: "bottom"
|
|
53
|
+
}, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
|
|
54
|
+
label: "Hoverable button"
|
|
55
|
+
}))), baseElement = _render.baseElement, getByText = _render.getByText;
|
|
56
|
+
triggerElement = getByText("Hoverable button");
|
|
57
|
+
_react2.fireEvent.mouseEnter(triggerElement);
|
|
58
|
+
_context.next = 5;
|
|
59
|
+
return (0, _axeHelper.axe)(baseElement);
|
|
60
|
+
case 5:
|
|
61
|
+
results = _context.sent;
|
|
62
|
+
expect(results).toHaveNoViolations();
|
|
63
|
+
case 7:
|
|
64
|
+
case "end":
|
|
65
|
+
return _context.stop();
|
|
66
|
+
}
|
|
67
|
+
}, _callee);
|
|
68
|
+
})));
|
|
69
|
+
it("Should not have basic accessibility issues for top position", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
70
|
+
var _render2, baseElement, getByText, triggerElement, results;
|
|
71
|
+
return _regenerator["default"].wrap(function _callee2$(_context2) {
|
|
72
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
73
|
+
case 0:
|
|
74
|
+
// baseElement is needed when using React Portals
|
|
75
|
+
_render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tooltip["default"], {
|
|
76
|
+
label: "Tooltip Test",
|
|
77
|
+
position: "top"
|
|
78
|
+
}, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
|
|
79
|
+
label: "Hoverable button"
|
|
80
|
+
}))), baseElement = _render2.baseElement, getByText = _render2.getByText;
|
|
81
|
+
triggerElement = getByText("Hoverable button");
|
|
82
|
+
_react2.fireEvent.mouseEnter(triggerElement);
|
|
83
|
+
_context2.next = 5;
|
|
84
|
+
return (0, _axeHelper.axe)(baseElement);
|
|
85
|
+
case 5:
|
|
86
|
+
results = _context2.sent;
|
|
87
|
+
expect(results).toHaveNoViolations();
|
|
88
|
+
case 7:
|
|
89
|
+
case "end":
|
|
90
|
+
return _context2.stop();
|
|
91
|
+
}
|
|
92
|
+
}, _callee2);
|
|
93
|
+
})));
|
|
94
|
+
it("Should not have basic accessibility issues for left position", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
95
|
+
var _render3, baseElement, getByText, triggerElement, results;
|
|
96
|
+
return _regenerator["default"].wrap(function _callee3$(_context3) {
|
|
97
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
98
|
+
case 0:
|
|
99
|
+
// baseElement is needed when using React Portals
|
|
100
|
+
_render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tooltip["default"], {
|
|
101
|
+
label: "Tooltip Test",
|
|
102
|
+
position: "left"
|
|
103
|
+
}, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
|
|
104
|
+
label: "Hoverable button"
|
|
105
|
+
}))), baseElement = _render3.baseElement, getByText = _render3.getByText;
|
|
106
|
+
triggerElement = getByText("Hoverable button");
|
|
107
|
+
_react2.fireEvent.mouseEnter(triggerElement);
|
|
108
|
+
_context3.next = 5;
|
|
109
|
+
return (0, _axeHelper.axe)(baseElement);
|
|
110
|
+
case 5:
|
|
111
|
+
results = _context3.sent;
|
|
112
|
+
expect(results).toHaveNoViolations();
|
|
113
|
+
case 7:
|
|
114
|
+
case "end":
|
|
115
|
+
return _context3.stop();
|
|
116
|
+
}
|
|
117
|
+
}, _callee3);
|
|
118
|
+
})));
|
|
119
|
+
it("Should not have basic accessibility issues for right position", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
|
|
120
|
+
var _render4, baseElement, getByText, triggerElement, results;
|
|
121
|
+
return _regenerator["default"].wrap(function _callee4$(_context4) {
|
|
122
|
+
while (1) switch (_context4.prev = _context4.next) {
|
|
123
|
+
case 0:
|
|
124
|
+
// baseElement is needed when using React Portals
|
|
125
|
+
_render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tooltip["default"], {
|
|
126
|
+
label: "Tooltip Test",
|
|
127
|
+
position: "right"
|
|
128
|
+
}, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
|
|
129
|
+
label: "Hoverable button"
|
|
130
|
+
}))), baseElement = _render4.baseElement, getByText = _render4.getByText;
|
|
131
|
+
triggerElement = getByText("Hoverable button");
|
|
132
|
+
_react2.fireEvent.mouseEnter(triggerElement);
|
|
133
|
+
_context4.next = 5;
|
|
134
|
+
return (0, _axeHelper.axe)(baseElement);
|
|
135
|
+
case 5:
|
|
136
|
+
results = _context4.sent;
|
|
137
|
+
expect(results).toHaveNoViolations();
|
|
138
|
+
case 7:
|
|
139
|
+
case "end":
|
|
140
|
+
return _context4.stop();
|
|
141
|
+
}
|
|
142
|
+
}, _callee4);
|
|
143
|
+
})));
|
|
144
|
+
});
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
10
|
+
var _react = _interopRequireDefault(require("react"));
|
|
11
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
12
|
+
var Tooltip = _interopRequireWildcard(require("@radix-ui/react-tooltip"));
|
|
13
|
+
var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
|
|
14
|
+
var _templateObject, _templateObject2, _templateObject3;
|
|
15
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
16
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
17
|
+
var Triangle = function Triangle() {
|
|
18
|
+
return /*#__PURE__*/_react["default"].createElement("svg", {
|
|
19
|
+
width: "12",
|
|
20
|
+
height: "6",
|
|
21
|
+
viewBox: "0 0 12 6",
|
|
22
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
23
|
+
preserveAspectRatio: "none",
|
|
24
|
+
display: "block"
|
|
25
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
26
|
+
d: "M0.351562 0L5.30131 4.94975C5.69184 5.34027 6.325 5.34027 6.71552 4.94975L11.6653 0H6.00842H0.351562Z",
|
|
27
|
+
fill: _coreTokens["default"].color_grey_800
|
|
28
|
+
}));
|
|
29
|
+
};
|
|
30
|
+
var DxcTooltip = function DxcTooltip(_ref) {
|
|
31
|
+
var _ref$position = _ref.position,
|
|
32
|
+
position = _ref$position === void 0 ? "bottom" : _ref$position,
|
|
33
|
+
label = _ref.label,
|
|
34
|
+
children = _ref.children;
|
|
35
|
+
return label ? /*#__PURE__*/_react["default"].createElement(Tooltip.Provider, {
|
|
36
|
+
delayDuration: 300
|
|
37
|
+
}, /*#__PURE__*/_react["default"].createElement(Tooltip.Root, null, /*#__PURE__*/_react["default"].createElement(Tooltip.Trigger, {
|
|
38
|
+
asChild: true
|
|
39
|
+
}, /*#__PURE__*/_react["default"].createElement(TooltipTriggerContainer, null, children)), /*#__PURE__*/_react["default"].createElement(Tooltip.Portal, null, /*#__PURE__*/_react["default"].createElement(StyledTooltipContent, {
|
|
40
|
+
side: position,
|
|
41
|
+
sideOffset: 8
|
|
42
|
+
}, /*#__PURE__*/_react["default"].createElement(TooltipContainer, null, label), /*#__PURE__*/_react["default"].createElement(Tooltip.Arrow, {
|
|
43
|
+
asChild: true,
|
|
44
|
+
"aria-hidden": true
|
|
45
|
+
}, /*#__PURE__*/_react["default"].createElement(Triangle, null)))))) : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, children);
|
|
46
|
+
};
|
|
47
|
+
var TooltipTriggerContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n position: relative;\n"])));
|
|
48
|
+
var StyledTooltipContent = (0, _styledComponents["default"])(Tooltip.Content)(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n z-index: 2147483647;\n\n animation-duration: 0.2s;\n animation-timing-function: ease-out;\n\n /* Additional optimization to prevent blurry text in certain browsers */\n -webkit-font-smoothing: antialiased;\n transform: translateZ(0) scale(1, 1);\n\n &[data-side=\"top\"] {\n animation-name: slideUp;\n }\n &[data-side=\"bottom\"] {\n animation-name: slideDown;\n }\n &[data-side=\"left\"] {\n animation-name: slideLeft;\n }\n &[data-side=\"right\"] {\n animation-name: slideRight;\n }\n @keyframes slideDown {\n from {\n opacity: 0;\n transform: translateY(-10px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n }\n @keyframes slideUp {\n from {\n opacity: 0;\n transform: translateY(10px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n }\n @keyframes slideLeft {\n from {\n opacity: 0;\n transform: translateX(10px);\n }\n to {\n opacity: 1;\n transform: translateX(0);\n }\n }\n @keyframes slideRight {\n from {\n opacity: 0;\n transform: translateX(-10px);\n }\n to {\n opacity: 1;\n transform: translateX(0);\n }\n }\n"])));
|
|
49
|
+
var TooltipContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n padding: 8px 12px;\n border-radius: 4px;\n font-size: ", ";\n font-family: ", ";\n max-width: 242px;\n color: ", ";\n background-color: ", ";\n border-color: ", ";\n"])), _coreTokens["default"].type_scale_01, _coreTokens["default"].type_sans, _coreTokens["default"].color_white, _coreTokens["default"].color_grey_800, _coreTokens["default"].color_grey_800);
|
|
50
|
+
var _default = exports["default"] = DxcTooltip;
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import DxcTooltip from "./Tooltip";
|
|
3
|
+
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
4
|
+
import DxcButton from "../button/Button";
|
|
5
|
+
import { userEvent, within } from "@storybook/test";
|
|
6
|
+
import DxcInset from "../inset/Inset";
|
|
7
|
+
import Title from "../../.storybook/components/Title";
|
|
8
|
+
import DxcFlex from "../flex/Flex";
|
|
9
|
+
|
|
10
|
+
export default {
|
|
11
|
+
title: "Tooltip",
|
|
12
|
+
component: DxcTooltip,
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
const Tooltip = () => (
|
|
16
|
+
<>
|
|
17
|
+
<Title title="Default tooltip" theme="light" level={4} />
|
|
18
|
+
<ExampleContainer>
|
|
19
|
+
<DxcInset bottom="3rem">
|
|
20
|
+
<DxcTooltip label="Tooltip Test">
|
|
21
|
+
<DxcButton label="Hoverable button" />
|
|
22
|
+
</DxcTooltip>
|
|
23
|
+
</DxcInset>
|
|
24
|
+
</ExampleContainer>
|
|
25
|
+
</>
|
|
26
|
+
);
|
|
27
|
+
|
|
28
|
+
const LargeTextWithinTooltip = () => (
|
|
29
|
+
<>
|
|
30
|
+
<Title title="Multiple line tooltip" theme="light" level={4} />
|
|
31
|
+
<ExampleContainer>
|
|
32
|
+
<DxcInset bottom="5rem" left="1rem">
|
|
33
|
+
<DxcTooltip label="Tooltip Test with a large text to display in the container while hovering the component">
|
|
34
|
+
<DxcButton label="Hoverable button" />
|
|
35
|
+
</DxcTooltip>
|
|
36
|
+
</DxcInset>
|
|
37
|
+
</ExampleContainer>
|
|
38
|
+
</>
|
|
39
|
+
);
|
|
40
|
+
|
|
41
|
+
const TopTooltip = () => (
|
|
42
|
+
<>
|
|
43
|
+
<Title title="Top tooltip" theme="light" level={4} />
|
|
44
|
+
<ExampleContainer>
|
|
45
|
+
<DxcInset top="3rem">
|
|
46
|
+
<DxcTooltip label="Tooltip Test" position="top">
|
|
47
|
+
<DxcButton label="Hoverable button" />
|
|
48
|
+
</DxcTooltip>
|
|
49
|
+
</DxcInset>
|
|
50
|
+
</ExampleContainer>
|
|
51
|
+
</>
|
|
52
|
+
);
|
|
53
|
+
|
|
54
|
+
const LeftTooltip = () => (
|
|
55
|
+
<>
|
|
56
|
+
<Title title="Left tooltip" theme="light" level={4} />
|
|
57
|
+
<ExampleContainer>
|
|
58
|
+
<DxcFlex justifyContent="center">
|
|
59
|
+
<DxcTooltip label="Tooltip Test" position="left">
|
|
60
|
+
<DxcButton label="Hoverable button" />
|
|
61
|
+
</DxcTooltip>
|
|
62
|
+
</DxcFlex>
|
|
63
|
+
</ExampleContainer>
|
|
64
|
+
</>
|
|
65
|
+
);
|
|
66
|
+
|
|
67
|
+
const RightTooltip = () => (
|
|
68
|
+
<>
|
|
69
|
+
<Title title="Right tooltip" theme="light" level={4} />
|
|
70
|
+
<ExampleContainer>
|
|
71
|
+
<DxcTooltip label="Tooltip Test" position="right">
|
|
72
|
+
<DxcButton label="Hoverable button" />
|
|
73
|
+
</DxcTooltip>
|
|
74
|
+
</ExampleContainer>
|
|
75
|
+
</>
|
|
76
|
+
);
|
|
77
|
+
|
|
78
|
+
export const Chromatic = Tooltip.bind({});
|
|
79
|
+
Chromatic.play = async ({ canvasElement }) => {
|
|
80
|
+
const canvas = within(canvasElement);
|
|
81
|
+
const buttonList = canvas.getByRole("button");
|
|
82
|
+
await userEvent.hover(buttonList);
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
export const LargeTextTooltip = LargeTextWithinTooltip.bind({});
|
|
86
|
+
LargeTextTooltip.play = async ({ canvasElement }) => {
|
|
87
|
+
const canvas = within(canvasElement);
|
|
88
|
+
const buttonList = canvas.getByRole("button");
|
|
89
|
+
await userEvent.hover(buttonList);
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
export const TooltipPositionTop = TopTooltip.bind({});
|
|
93
|
+
TooltipPositionTop.play = async ({ canvasElement }) => {
|
|
94
|
+
const canvas = within(canvasElement);
|
|
95
|
+
const buttonList = canvas.getByRole("button");
|
|
96
|
+
await userEvent.hover(buttonList);
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
export const TooltipPositionLeft = LeftTooltip.bind({});
|
|
100
|
+
TooltipPositionLeft.play = async ({ canvasElement }) => {
|
|
101
|
+
const canvas = within(canvasElement);
|
|
102
|
+
const buttonList = canvas.getByRole("button");
|
|
103
|
+
await userEvent.hover(buttonList);
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
export const TooltipPositionRight = RightTooltip.bind({});
|
|
107
|
+
TooltipPositionRight.play = async ({ canvasElement }) => {
|
|
108
|
+
const canvas = within(canvasElement);
|
|
109
|
+
const buttonList = canvas.getByRole("button");
|
|
110
|
+
await userEvent.hover(buttonList);
|
|
111
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import "@testing-library/jest-dom";
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
5
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
6
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
7
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var _react2 = require("@testing-library/react");
|
|
10
|
+
var _Tooltip = _interopRequireDefault(require("./Tooltip"));
|
|
11
|
+
var _Button = _interopRequireDefault(require("../button/Button"));
|
|
12
|
+
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
13
|
+
require("@testing-library/jest-dom");
|
|
14
|
+
global.globalThis = global;
|
|
15
|
+
global.DOMRect = {
|
|
16
|
+
fromRect: function fromRect() {
|
|
17
|
+
return {
|
|
18
|
+
top: 0,
|
|
19
|
+
left: 0,
|
|
20
|
+
bottom: 0,
|
|
21
|
+
right: 0,
|
|
22
|
+
width: 0,
|
|
23
|
+
height: 0,
|
|
24
|
+
x: 0,
|
|
25
|
+
y: 0
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
global.ResizeObserver = /*#__PURE__*/function () {
|
|
30
|
+
function ResizeObserver() {
|
|
31
|
+
(0, _classCallCheck2["default"])(this, ResizeObserver);
|
|
32
|
+
}
|
|
33
|
+
return (0, _createClass2["default"])(ResizeObserver, [{
|
|
34
|
+
key: "observe",
|
|
35
|
+
value: function observe() {}
|
|
36
|
+
}, {
|
|
37
|
+
key: "unobserve",
|
|
38
|
+
value: function unobserve() {}
|
|
39
|
+
}, {
|
|
40
|
+
key: "disconnect",
|
|
41
|
+
value: function disconnect() {}
|
|
42
|
+
}]);
|
|
43
|
+
}();
|
|
44
|
+
describe("Tooltip component tests", function () {
|
|
45
|
+
test("Tooltip does not render by default", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
46
|
+
var _render, queryByRole;
|
|
47
|
+
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
48
|
+
while (1) switch (_context.prev = _context.next) {
|
|
49
|
+
case 0:
|
|
50
|
+
_render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tooltip["default"], {
|
|
51
|
+
label: "Tooltip Test"
|
|
52
|
+
}, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
|
|
53
|
+
label: "Hoverable button"
|
|
54
|
+
}))), queryByRole = _render.queryByRole;
|
|
55
|
+
_context.next = 3;
|
|
56
|
+
return (0, _react2.waitFor)(function () {
|
|
57
|
+
var tooltipElement = queryByRole("tooltip");
|
|
58
|
+
expect(tooltipElement).toBeFalsy();
|
|
59
|
+
});
|
|
60
|
+
case 3:
|
|
61
|
+
case "end":
|
|
62
|
+
return _context.stop();
|
|
63
|
+
}
|
|
64
|
+
}, _callee);
|
|
65
|
+
})));
|
|
66
|
+
test("Tooltip renders with correct label on hover", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
67
|
+
var _render2, getByText, triggerElement;
|
|
68
|
+
return _regenerator["default"].wrap(function _callee2$(_context2) {
|
|
69
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
70
|
+
case 0:
|
|
71
|
+
_render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tooltip["default"], {
|
|
72
|
+
label: "Tooltip Test"
|
|
73
|
+
}, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
|
|
74
|
+
label: "Hoverable button"
|
|
75
|
+
}))), getByText = _render2.getByText;
|
|
76
|
+
triggerElement = getByText("Hoverable button");
|
|
77
|
+
_userEvent["default"].hover(triggerElement);
|
|
78
|
+
_context2.next = 5;
|
|
79
|
+
return _react2.screen.findByRole("tooltip", {
|
|
80
|
+
name: "Tooltip Test"
|
|
81
|
+
});
|
|
82
|
+
case 5:
|
|
83
|
+
case "end":
|
|
84
|
+
return _context2.stop();
|
|
85
|
+
}
|
|
86
|
+
}, _callee2);
|
|
87
|
+
})));
|
|
88
|
+
test("Tooltip stops being rendered when hover is stopped", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
89
|
+
var _render3, getByText, queryByRole, triggerElement;
|
|
90
|
+
return _regenerator["default"].wrap(function _callee3$(_context3) {
|
|
91
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
92
|
+
case 0:
|
|
93
|
+
_render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tooltip["default"], {
|
|
94
|
+
label: "Tooltip Test"
|
|
95
|
+
}, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
|
|
96
|
+
label: "Hoverable button"
|
|
97
|
+
}))), getByText = _render3.getByText, queryByRole = _render3.queryByRole;
|
|
98
|
+
triggerElement = getByText("Hoverable button");
|
|
99
|
+
_userEvent["default"].hover(triggerElement);
|
|
100
|
+
_userEvent["default"].unhover(triggerElement);
|
|
101
|
+
_context3.next = 6;
|
|
102
|
+
return (0, _react2.waitFor)(function () {
|
|
103
|
+
var tooltipElement = queryByRole("tooltip");
|
|
104
|
+
expect(tooltipElement).toBeFalsy();
|
|
105
|
+
});
|
|
106
|
+
case 6:
|
|
107
|
+
case "end":
|
|
108
|
+
return _context3.stop();
|
|
109
|
+
}
|
|
110
|
+
}, _callee3);
|
|
111
|
+
})));
|
|
112
|
+
});
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
type Props = {
|
|
3
|
+
/**
|
|
4
|
+
* Preferred position for displaying the tooltip. It may adjust automatically based on available space.
|
|
5
|
+
*/
|
|
6
|
+
position?: "bottom" | "top" | "left" | "right";
|
|
7
|
+
/**
|
|
8
|
+
* Text to be displayed inside the tooltip.
|
|
9
|
+
*/
|
|
10
|
+
label: string;
|
|
11
|
+
/**
|
|
12
|
+
* Content in which the Tooltip will be displayed.
|
|
13
|
+
*/
|
|
14
|
+
children: React.ReactNode;
|
|
15
|
+
};
|
|
16
|
+
export default Props;
|
package/tooltip/types.js
ADDED
|
@@ -140,9 +140,7 @@ export const Chromatic = () => (
|
|
|
140
140
|
<ExampleContainer>
|
|
141
141
|
<Title title="Typography whitespace" theme="light" level={4} />
|
|
142
142
|
<div style={{ margin: "50px", border: "1px solid red", width: "125px" }}>
|
|
143
|
-
<DxcTypography fontSize="2rem">
|
|
144
|
-
{" "} Normal: A bunch of words you see.
|
|
145
|
-
</DxcTypography>
|
|
143
|
+
<DxcTypography fontSize="2rem">{" "} Normal: A bunch of words you see.</DxcTypography>
|
|
146
144
|
</div>
|
|
147
145
|
<div style={{ margin: "50px", border: "1px solid red", width: "125px" }}>
|
|
148
146
|
<DxcTypography whiteSpace="nowrap" fontSize="2rem">
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
var _Typography = _interopRequireDefault(require("./Typography"));
|
|
7
|
+
describe("Typography component tests", function () {
|
|
8
|
+
test("Renders as the selected component", function () {
|
|
9
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
|
|
10
|
+
as: "h1"
|
|
11
|
+
}, "Test H1 Text")),
|
|
12
|
+
container = _render.container;
|
|
13
|
+
expect(container.querySelector('h1')).not.toBeNull();
|
|
14
|
+
});
|
|
15
|
+
test("Renders as span if it receives invalid tag", function () {
|
|
16
|
+
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
|
|
17
|
+
as: "br"
|
|
18
|
+
}, "Test BR Text")),
|
|
19
|
+
container = _render2.container;
|
|
20
|
+
expect(container.querySelector('br')).toBeNull();
|
|
21
|
+
expect(container.querySelector('span')).not.toBeNull();
|
|
22
|
+
});
|
|
23
|
+
});
|
package/useTheme.d.ts
CHANGED
|
@@ -217,6 +217,29 @@ declare const useTheme: () => {
|
|
|
217
217
|
focusBorderThickness: string;
|
|
218
218
|
focusBorderRadius: string;
|
|
219
219
|
}>;
|
|
220
|
+
contextualMenu?: Partial<{
|
|
221
|
+
fontFamily: string;
|
|
222
|
+
backgroundColor: string;
|
|
223
|
+
borderColor: string;
|
|
224
|
+
menuItemFontColor: string;
|
|
225
|
+
menuItemFontSize: string;
|
|
226
|
+
menuItemFontStyle: string;
|
|
227
|
+
menuItemFontWeight: string;
|
|
228
|
+
menuItemLineHeight: string;
|
|
229
|
+
hoverMenuItemBackgroundColor: string;
|
|
230
|
+
activeMenuItemBackgroundColor: string;
|
|
231
|
+
selectedMenuItemBackgroundColor: string;
|
|
232
|
+
hoverSelectedMenuItemBackgroundColor: string;
|
|
233
|
+
activeSelectedMenuItemBackgroundColor: string;
|
|
234
|
+
selectedMenuItemFontWeight: string;
|
|
235
|
+
sectionTitleFontColor: string;
|
|
236
|
+
sectionTitleFontSize: string;
|
|
237
|
+
sectionTitleFontStyle: string;
|
|
238
|
+
sectionTitleFontWeight: string;
|
|
239
|
+
sectionTitleLineHeight: string;
|
|
240
|
+
iconColor: string;
|
|
241
|
+
iconSize: string;
|
|
242
|
+
}>;
|
|
220
243
|
dateInput?: Partial<{
|
|
221
244
|
pickerBackgroundColor: string;
|
|
222
245
|
pickerFontColor: string;
|
package/utils/BaseTypography.js
CHANGED
|
@@ -13,6 +13,10 @@ var _templateObject;
|
|
|
13
13
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
14
14
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
15
15
|
var TypographyContext = /*#__PURE__*/_react["default"].createContext(null);
|
|
16
|
+
var ValidTypographyTags = ["a", "blockquote", "cite", "code", "div", "em", "figcaption", "h1", "h2", "h3", "h4", "h5", "h6", "p", "pre", "small", "span", "strong"];
|
|
17
|
+
var isValidTypography = function isValidTypography(tag) {
|
|
18
|
+
return ValidTypographyTags.includes(tag);
|
|
19
|
+
};
|
|
16
20
|
var BaseTypography = function BaseTypography(_ref) {
|
|
17
21
|
var as = _ref.as,
|
|
18
22
|
display = _ref.display,
|
|
@@ -30,65 +34,65 @@ var BaseTypography = function BaseTypography(_ref) {
|
|
|
30
34
|
children = _ref.children;
|
|
31
35
|
var componentContext = (0, _react.useContext)(TypographyContext);
|
|
32
36
|
var contextValue = (0, _react.useMemo)(function () {
|
|
33
|
-
var _ref2, _ref3, _ref4, _ref5, _ref6, _ref7, _ref8, _ref9, _ref10, _ref11, _ref12, _ref13
|
|
37
|
+
var _ref2, _ref3, _ref4, _ref5, _ref6, _ref7, _ref8, _ref9, _ref10, _ref11, _ref12, _ref13;
|
|
34
38
|
return {
|
|
35
|
-
as: (
|
|
36
|
-
display: (
|
|
37
|
-
fontFamily: (
|
|
38
|
-
fontSize: (
|
|
39
|
-
fontStyle: (
|
|
40
|
-
fontWeight: (
|
|
41
|
-
letterSpacing: (
|
|
42
|
-
lineHeight: (
|
|
43
|
-
textAlign: (
|
|
44
|
-
color: (
|
|
45
|
-
textDecoration: (
|
|
46
|
-
textOverflow: (
|
|
47
|
-
whiteSpace: (
|
|
39
|
+
as: isValidTypography(as) ? as : isValidTypography(componentContext === null || componentContext === void 0 ? void 0 : componentContext.as) ? componentContext === null || componentContext === void 0 ? void 0 : componentContext.as : "span",
|
|
40
|
+
display: (_ref2 = display !== null && display !== void 0 ? display : componentContext === null || componentContext === void 0 ? void 0 : componentContext.display) !== null && _ref2 !== void 0 ? _ref2 : "inline",
|
|
41
|
+
fontFamily: (_ref3 = fontFamily !== null && fontFamily !== void 0 ? fontFamily : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontFamily) !== null && _ref3 !== void 0 ? _ref3 : "Open Sans, sans-serif",
|
|
42
|
+
fontSize: (_ref4 = fontSize !== null && fontSize !== void 0 ? fontSize : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontSize) !== null && _ref4 !== void 0 ? _ref4 : "1rem",
|
|
43
|
+
fontStyle: (_ref5 = fontStyle !== null && fontStyle !== void 0 ? fontStyle : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontStyle) !== null && _ref5 !== void 0 ? _ref5 : "normal",
|
|
44
|
+
fontWeight: (_ref6 = fontWeight !== null && fontWeight !== void 0 ? fontWeight : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontWeight) !== null && _ref6 !== void 0 ? _ref6 : "400",
|
|
45
|
+
letterSpacing: (_ref7 = letterSpacing !== null && letterSpacing !== void 0 ? letterSpacing : componentContext === null || componentContext === void 0 ? void 0 : componentContext.letterSpacing) !== null && _ref7 !== void 0 ? _ref7 : "0em",
|
|
46
|
+
lineHeight: (_ref8 = lineHeight !== null && lineHeight !== void 0 ? lineHeight : componentContext === null || componentContext === void 0 ? void 0 : componentContext.lineHeight) !== null && _ref8 !== void 0 ? _ref8 : "1.5em",
|
|
47
|
+
textAlign: (_ref9 = textAlign !== null && textAlign !== void 0 ? textAlign : componentContext === null || componentContext === void 0 ? void 0 : componentContext.textAlign) !== null && _ref9 !== void 0 ? _ref9 : "left",
|
|
48
|
+
color: (_ref10 = color !== null && color !== void 0 ? color : componentContext === null || componentContext === void 0 ? void 0 : componentContext.color) !== null && _ref10 !== void 0 ? _ref10 : "#000000",
|
|
49
|
+
textDecoration: (_ref11 = textDecoration !== null && textDecoration !== void 0 ? textDecoration : componentContext === null || componentContext === void 0 ? void 0 : componentContext.textDecoration) !== null && _ref11 !== void 0 ? _ref11 : "none",
|
|
50
|
+
textOverflow: (_ref12 = textOverflow !== null && textOverflow !== void 0 ? textOverflow : componentContext === null || componentContext === void 0 ? void 0 : componentContext.textOverflow) !== null && _ref12 !== void 0 ? _ref12 : "unset",
|
|
51
|
+
whiteSpace: (_ref13 = whiteSpace !== null && whiteSpace !== void 0 ? whiteSpace : componentContext === null || componentContext === void 0 ? void 0 : componentContext.whiteSpace) !== null && _ref13 !== void 0 ? _ref13 : "normal"
|
|
48
52
|
};
|
|
49
53
|
}, [as, display, fontFamily, fontSize, fontStyle, fontWeight, letterSpacing, lineHeight, textAlign, color, textDecoration, textOverflow, whiteSpace]);
|
|
50
54
|
return /*#__PURE__*/_react["default"].createElement(TypographyContext.Provider, {
|
|
51
55
|
value: contextValue
|
|
52
56
|
}, /*#__PURE__*/_react["default"].createElement(StyledTypography, contextValue, children));
|
|
53
57
|
};
|
|
54
|
-
var StyledTypography = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: ", ";\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n text-align: ", ";\n text-decoration: ", ";\n text-overflow: ", ";\n white-space: ", ";\n overflow: ", ";\n margin: 0;\n"])), function (
|
|
55
|
-
var display =
|
|
58
|
+
var StyledTypography = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: ", ";\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n text-align: ", ";\n text-decoration: ", ";\n text-overflow: ", ";\n white-space: ", ";\n overflow: ", ";\n margin: 0;\n"])), function (_ref14) {
|
|
59
|
+
var display = _ref14.display;
|
|
56
60
|
return display;
|
|
57
|
-
}, function (
|
|
58
|
-
var color =
|
|
61
|
+
}, function (_ref15) {
|
|
62
|
+
var color = _ref15.color;
|
|
59
63
|
return color;
|
|
60
|
-
}, function (
|
|
61
|
-
var fontFamily =
|
|
64
|
+
}, function (_ref16) {
|
|
65
|
+
var fontFamily = _ref16.fontFamily;
|
|
62
66
|
return fontFamily;
|
|
63
|
-
}, function (
|
|
64
|
-
var fontSize =
|
|
67
|
+
}, function (_ref17) {
|
|
68
|
+
var fontSize = _ref17.fontSize;
|
|
65
69
|
return fontSize;
|
|
66
|
-
}, function (
|
|
67
|
-
var fontStyle =
|
|
70
|
+
}, function (_ref18) {
|
|
71
|
+
var fontStyle = _ref18.fontStyle;
|
|
68
72
|
return fontStyle;
|
|
69
|
-
}, function (
|
|
70
|
-
var fontWeight =
|
|
73
|
+
}, function (_ref19) {
|
|
74
|
+
var fontWeight = _ref19.fontWeight;
|
|
71
75
|
return fontWeight;
|
|
72
|
-
}, function (
|
|
73
|
-
var letterSpacing =
|
|
76
|
+
}, function (_ref20) {
|
|
77
|
+
var letterSpacing = _ref20.letterSpacing;
|
|
74
78
|
return letterSpacing;
|
|
75
|
-
}, function (
|
|
76
|
-
var lineHeight =
|
|
79
|
+
}, function (_ref21) {
|
|
80
|
+
var lineHeight = _ref21.lineHeight;
|
|
77
81
|
return lineHeight;
|
|
78
|
-
}, function (
|
|
79
|
-
var textAlign =
|
|
82
|
+
}, function (_ref22) {
|
|
83
|
+
var textAlign = _ref22.textAlign;
|
|
80
84
|
return textAlign;
|
|
81
|
-
}, function (
|
|
82
|
-
var textDecoration =
|
|
85
|
+
}, function (_ref23) {
|
|
86
|
+
var textDecoration = _ref23.textDecoration;
|
|
83
87
|
return textDecoration;
|
|
84
|
-
}, function (
|
|
85
|
-
var textOverflow =
|
|
88
|
+
}, function (_ref24) {
|
|
89
|
+
var textOverflow = _ref24.textOverflow;
|
|
86
90
|
return textOverflow;
|
|
87
|
-
}, function (
|
|
88
|
-
var whiteSpace =
|
|
91
|
+
}, function (_ref25) {
|
|
92
|
+
var whiteSpace = _ref25.whiteSpace;
|
|
89
93
|
return whiteSpace;
|
|
90
|
-
}, function (
|
|
91
|
-
var textOverflow =
|
|
94
|
+
}, function (_ref26) {
|
|
95
|
+
var textOverflow = _ref26.textOverflow;
|
|
92
96
|
return textOverflow !== "unset" ? "hidden" : "visible";
|
|
93
97
|
});
|
|
94
98
|
var _default = exports["default"] = BaseTypography;
|