admin-bro
Version:
Admin panel for apps written in node.js
74 lines (58 loc) • 1.58 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.ActionButton = void 0;
var _react = _interopRequireDefault(require("react"));
var _interfaces = require("../../../interfaces");
var _hooks = require("../../../hooks");
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* eslint-disable no-undef */
/* eslint-disable no-alert */
/* eslint-disable no-restricted-globals */
/**
* Renders Button which redirects to given action
*
* ### Usage
*
* ```
* import { ActionButton } from 'admin-bro'
* ```
*
* @component
* @subcategory Application
*/
const ActionButton = props => {
const {
children,
action,
actionPerformed,
resourceId,
recordId,
recordIds
} = props;
const {
href,
handleClick
} = (0, _hooks.useAction)(action, {
resourceId,
recordId,
recordIds
}, actionPerformed);
if (!action) {
return null;
}
const firstChild = _react.default.Children.toArray(children)[0];
if (!firstChild || typeof firstChild === 'string' || typeof firstChild === 'number' || typeof firstChild === 'boolean') {
throw new Error('ActionButton has to have one child');
}
const WrappedElement = /*#__PURE__*/_react.default.cloneElement(firstChild, {
onClick: handleClick,
'data-testid': (0, _interfaces.buildActionTestId)(action),
href
});
return WrappedElement;
}; // TODO - remove this hack
exports.ActionButton = ActionButton;
var _default = ActionButton;
exports.default = _default;
;