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
			| 
											3 years ago
										 | "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; |