UNPKG

@appbuckets/react-ui

Version:
93 lines (86 loc) 2.32 kB
'use strict'; var tslib = require('tslib'); var React = require('react'); var clsx = require('clsx'); var reactUiCore = require('@appbuckets/react-ui-core'); var customHook = require('../utils/customHook.js'); require('../BucketTheme/BucketTheme.js'); var BucketContext = require('../BucketTheme/BucketContext.js'); var TableCell = require('./TableCell.js'); function _interopDefaultLegacy(e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; } function _interopNamespace(e) { if (e && e.__esModule) return e; var n = Object.create(null); if (e) { Object.keys(e).forEach(function (k) { if (k !== 'default') { var d = Object.getOwnPropertyDescriptor(e, k); Object.defineProperty( n, k, d.get ? d : { enumerable: true, get: function () { return e[k]; }, } ); } }); } n['default'] = e; return Object.freeze(n); } var React__namespace = /*#__PURE__*/ _interopNamespace(React); var clsx__default = /*#__PURE__*/ _interopDefaultLegacy(clsx); /* -------- * Component Render * -------- */ var TableHeaderCell = function (receivedProps) { var props = BucketContext.useWithDefaultProps( 'tableHeaderCell', receivedProps ); var _a = customHook.useSharedClassName(props), className = _a.className, _b = _a.rest, sortable = _b.sortable, sorted = _b.sorted, rest = tslib.__rest(_b, ['sortable', 'sorted']); var classes = clsx__default['default']( className, sorted && 'sorted', sorted, sortable && 'sortable' ); return React__namespace.createElement( TableCell, tslib.__assign({}, rest, { as: props.as, className: classes, icon: sortable ? { name: sorted === 'desc' ? 'sort-up' : sorted === 'asc' ? 'sort-down' : 'sort', className: 'clickable', } : undefined, }) ); }; TableHeaderCell.displayName = 'TableHeaderCell'; TableHeaderCell.create = reactUiCore.createShorthandFactory( TableHeaderCell, function (content) { return { header: content }; } ); module.exports = TableHeaderCell;