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.
		
		
		
		
		
			
		
			
				
					
					
						
							112 lines
						
					
					
						
							2.9 KiB
						
					
					
				
			
		
		
	
	
							112 lines
						
					
					
						
							2.9 KiB
						
					
					
				"use strict";
 | 
						|
 | 
						|
Object.defineProperty(exports, "__esModule", {
 | 
						|
  value: true
 | 
						|
});
 | 
						|
exports.default = exports.BaseActionComponent = void 0;
 | 
						|
 | 
						|
var _react = _interopRequireDefault(require("react"));
 | 
						|
 | 
						|
var _reactI18next = require("react-i18next");
 | 
						|
 | 
						|
var _designSystem = require("@adminjs/design-system");
 | 
						|
 | 
						|
var _errorBoundary = _interopRequireDefault(require("./error-boundary"));
 | 
						|
 | 
						|
var _actions = require("../actions");
 | 
						|
 | 
						|
var _constants = require("../../../constants");
 | 
						|
 | 
						|
var _hooks = require("../../hooks");
 | 
						|
 | 
						|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | 
						|
 | 
						|
/**
 | 
						|
 * Component which renders all the default and custom actions for both the Resource and the Record.
 | 
						|
 *
 | 
						|
 * It passes all props down to the actual Action component.
 | 
						|
 *
 | 
						|
 * Example of creating your own actions:
 | 
						|
 * ```
 | 
						|
 * // AdminJS options
 | 
						|
 * const AdminJSOptions = {
 | 
						|
 *   resources: [
 | 
						|
 *      resource,
 | 
						|
 *      options: {
 | 
						|
 *        actions: {
 | 
						|
 *           myNewAction: {
 | 
						|
 *             label: 'amazing action',
 | 
						|
 *             icon: 'Add',
 | 
						|
 *             inVisible: (resource, record) => record.param('email') !== '',
 | 
						|
 *             actionType: 'record',
 | 
						|
 *             component: 'MyNewAction',
 | 
						|
 *             handler: (request, response, data) => {
 | 
						|
 *               return {
 | 
						|
 *                  ...
 | 
						|
 *               }
 | 
						|
 *             }
 | 
						|
 *           }
 | 
						|
 *        }
 | 
						|
 *      }
 | 
						|
 *   ]
 | 
						|
 * }
 | 
						|
 * ```
 | 
						|
 *
 | 
						|
 * ```
 | 
						|
 * // ./my-new-action.jsx
 | 
						|
 * import { Box } from 'adminjs'
 | 
						|
 *
 | 
						|
 * const MyNewAction = (props) => {
 | 
						|
 *   const { resource, action, record } = props
 | 
						|
 *   // do something with the props and render action
 | 
						|
 *   return (
 | 
						|
 *     <Box>Some Action Content</Box>
 | 
						|
 *   )
 | 
						|
 * }
 | 
						|
 * ```
 | 
						|
 *
 | 
						|
 * @component
 | 
						|
 * @name BaseActionComponent
 | 
						|
 * @subcategory Application
 | 
						|
 */
 | 
						|
const BaseActionComponent = props => {
 | 
						|
  const {
 | 
						|
    resource,
 | 
						|
    action,
 | 
						|
    record,
 | 
						|
    records,
 | 
						|
    setTag
 | 
						|
  } = props;
 | 
						|
  const documentationLink = [_constants.DOCS, 'BaseAction.html'].join('/');
 | 
						|
  const {
 | 
						|
    translateMessage
 | 
						|
  } = (0, _hooks.useTranslation)();
 | 
						|
  let Action = _actions.actions[action.name];
 | 
						|
 | 
						|
  if (action.component) {
 | 
						|
    Action = AdminJS.UserComponents[action.component];
 | 
						|
  }
 | 
						|
 | 
						|
  if (Action) {
 | 
						|
    return /*#__PURE__*/_react.default.createElement(_errorBoundary.default, null, /*#__PURE__*/_react.default.createElement(Action, {
 | 
						|
      action: action,
 | 
						|
      resource: resource,
 | 
						|
      record: record,
 | 
						|
      records: records,
 | 
						|
      setTag: setTag
 | 
						|
    }));
 | 
						|
  }
 | 
						|
 | 
						|
  return Action || /*#__PURE__*/_react.default.createElement(_designSystem.MessageBox, {
 | 
						|
    variant: "danger"
 | 
						|
  }, translateMessage('noActionComponent'), /*#__PURE__*/_react.default.createElement(_reactI18next.Trans, {
 | 
						|
    key: "messages.buttons.seeTheDocumentation"
 | 
						|
  }, "See:", /*#__PURE__*/_react.default.createElement(_designSystem.Link, {
 | 
						|
    ml: "default",
 | 
						|
    href: documentationLink
 | 
						|
  }, "the documentation")));
 | 
						|
};
 | 
						|
 | 
						|
exports.BaseActionComponent = BaseActionComponent;
 | 
						|
var _default = BaseActionComponent;
 | 
						|
exports.default = _default; |