You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

79 lines
1.8 KiB

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.ActionButton = void 0;
var _react = _interopRequireDefault(require("react"));
var _allowOverride = _interopRequireDefault(require("../../../hoc/allow-override"));
var _hooks = require("../../../hooks");
var _interfaces = require("../../../interfaces");
var _utils = require("../../../utils");
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 'adminjs'
* ```
*
* @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 contentTag = (0, _utils.getActionElementCss)(resourceId, action.name, 'button');
const WrappedElement = /*#__PURE__*/_react.default.cloneElement(firstChild, {
onClick: handleClick,
'data-testid': (0, _interfaces.buildActionTestId)(action),
'data-css': contentTag,
href
});
return WrappedElement;
};
const OverridableActionButton = (0, _allowOverride.default)(ActionButton, 'ActionButton');
exports.ActionButton = exports.default = OverridableActionButton;