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
						
					
					
				
			
		
		
	
	
							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; |