@primer/react
Version:
An implementation of GitHub's Primer Design System using React
58 lines (52 loc) • 1.85 kB
JavaScript
'use strict';
var React = require('react');
var Box = require('../Box/Box.js');
var IconButton = require('../Button/IconButton.js');
require('../Button/ButtonBase.js');
require('../utils/defaultSxProp.js');
var Button = require('../Button/Button.js');
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
var React__default = /*#__PURE__*/_interopDefault(React);
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
const TrailingAction = /*#__PURE__*/React.forwardRef(({
as = 'button',
icon,
label,
href = null,
...props
}, forwardedRef) => {
if (!icon) {
return /*#__PURE__*/React__default.default.createElement(Box, {
"data-component": "ActionList.TrailingAction",
as: "span",
sx: {
flexShrink: 0
}
}, /*#__PURE__*/React__default.default.createElement(Button.ButtonComponent, _extends({
variant: "invisible",
as: as,
href: href,
ref: forwardedRef
}, props), label));
} else {
return /*#__PURE__*/React__default.default.createElement(Box, {
as: "span",
"data-component": "ActionList.TrailingAction",
sx: {
flexShrink: 0
}
}, /*#__PURE__*/React__default.default.createElement(IconButton.IconButton, _extends({
as: as,
"aria-label": label,
icon: icon,
variant: "invisible",
tooltipDirection: "w",
href: href
// @ts-expect-error StyledButton wants both Anchor and Button refs
,
ref: forwardedRef
}, props)));
}
});
TrailingAction.displayName = 'ActionList.TrailingAction';
exports.TrailingAction = TrailingAction;