1 | "use strict";
|
2 |
|
3 | function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
|
4 |
|
5 | Object.defineProperty(exports, "__esModule", {
|
6 | value: true
|
7 | });
|
8 | exports.default = void 0;
|
9 |
|
10 | var React = _interopRequireWildcard(require("react"));
|
11 |
|
12 | var _index = require("../checkbox/index.js");
|
13 |
|
14 | var _index2 = require("../styles/index.js");
|
15 |
|
16 | var _chevronDown = _interopRequireDefault(require("../icon/chevron-down.js"));
|
17 |
|
18 | var _chevronUp = _interopRequireDefault(require("../icon/chevron-up.js"));
|
19 |
|
20 | var _constants = require("./constants.js");
|
21 |
|
22 | var _focusVisible = require("../utils/focusVisible.js");
|
23 |
|
24 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
25 |
|
26 | function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
|
27 |
|
28 | function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
29 |
|
30 | function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
|
31 |
|
32 | function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
33 |
|
34 | function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
35 |
|
36 | function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }
|
37 |
|
38 | function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance"); }
|
39 |
|
40 | function _iterableToArrayLimit(arr, i) { if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === "[object Arguments]")) { return; } var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
41 |
|
42 | function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
43 |
|
44 | var HeaderCell = React.forwardRef(function (props, ref) {
|
45 | var _useStyletron = (0, _index2.useStyletron)(),
|
46 | _useStyletron2 = _slicedToArray(_useStyletron, 2),
|
47 | css = _useStyletron2[0],
|
48 | theme = _useStyletron2[1];
|
49 |
|
50 | var _React$useState = React.useState(false),
|
51 | _React$useState2 = _slicedToArray(_React$useState, 2),
|
52 | focusVisible = _React$useState2[0],
|
53 | setFocusVisible = _React$useState2[1];
|
54 |
|
55 | var checkboxRef = React.useRef(null);
|
56 |
|
57 | var handleFocus = function handleFocus(event) {
|
58 | if ((0, _focusVisible.isFocusVisible)(event)) {
|
59 | setFocusVisible(true);
|
60 | }
|
61 | };
|
62 |
|
63 | var handleBlur = function handleBlur(event) {
|
64 | if (focusVisible !== false) {
|
65 | setFocusVisible(false);
|
66 | }
|
67 | };
|
68 |
|
69 | var backgroundColor = props.isHovered ? theme.colors.backgroundSecondary : theme.colors.backgroundPrimary;
|
70 | return React.createElement("div", {
|
71 | ref: ref,
|
72 | role: "button",
|
73 | tabIndex: "0",
|
74 | className: css(_objectSpread({}, theme.typography.font150, {
|
75 | alignItems: 'center',
|
76 | backgroundColor: backgroundColor,
|
77 | boxSizing: 'border-box',
|
78 | color: theme.colors.contentPrimary,
|
79 | cursor: props.sortable ? 'pointer' : null,
|
80 | display: props.isMeasured ? 'inline-flex' : 'flex',
|
81 | flexGrow: 1,
|
82 | height: '100%',
|
83 | paddingLeft: theme.sizing.scale500,
|
84 | paddingRight: theme.sizing.scale500,
|
85 | flexWrap: 'nowrap',
|
86 | whiteSpace: 'nowrap',
|
87 | outline: focusVisible ? "3px solid ".concat(theme.colors.accent) : 'none',
|
88 | outlineOffset: '-3px'
|
89 | })),
|
90 | onMouseEnter: props.onMouseEnter,
|
91 | onMouseLeave: props.onMouseLeave,
|
92 | onKeyUp: function onKeyUp(event) {
|
93 | if (event.key === 'Enter') {
|
94 | props.onSort(props.index);
|
95 | }
|
96 | },
|
97 | onClick: function onClick(event) {
|
98 |
|
99 | if (checkboxRef.current && checkboxRef.current.contains(event.target)) {
|
100 | return;
|
101 | }
|
102 |
|
103 | if (props.sortable) {
|
104 | props.onSort(props.index);
|
105 | }
|
106 | },
|
107 | onFocus: handleFocus,
|
108 | onBlur: handleBlur
|
109 | }, props.isSelectable && React.createElement("span", {
|
110 | ref: checkboxRef
|
111 | }, React.createElement(_index.Checkbox, {
|
112 | onChange: function onChange(e) {
|
113 | if (props.isSelectedAll || props.isSelectedIndeterminate) {
|
114 | props.onSelectNone();
|
115 | } else {
|
116 | props.onSelectAll();
|
117 | }
|
118 | },
|
119 | checked: props.isSelectedAll || props.isSelectedIndeterminate,
|
120 | isIndeterminate: props.isSelectedIndeterminate
|
121 | })), props.title, React.createElement("div", {
|
122 | className: css({
|
123 | position: 'relative',
|
124 | width: '100%',
|
125 | display: 'flex',
|
126 | alignItems: 'center'
|
127 | })
|
128 | }, (props.isHovered || props.sortDirection) && props.sortable && React.createElement("div", {
|
129 | style: {
|
130 | backgroundColor: backgroundColor,
|
131 | display: 'flex',
|
132 | alignItems: 'center',
|
133 | position: 'absolute',
|
134 | right: -4
|
135 | }
|
136 | }, (props.sortDirection === _constants.SORT_DIRECTIONS.DESC || !props.sortDirection) && React.createElement(_chevronDown.default, {
|
137 | color: props.sortDirection ? theme.colors.contentPrimary : theme.colors.contentSecondary
|
138 | }), props.sortDirection === _constants.SORT_DIRECTIONS.ASC && React.createElement(_chevronUp.default, {
|
139 | color: props.sortDirection ? theme.colors.contentPrimary : theme.colors.contentSecondary
|
140 | }))));
|
141 | });
|
142 | HeaderCell.displayName = 'HeaderCell';
|
143 | var _default = HeaderCell;
|
144 | exports.default = _default; |
\ | No newline at end of file |