2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# Front-end Development
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-20 09:37:50 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Strapi's admin panel and plugins system aim to be an easy and powerful way to create new features.
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-20 09:37:50 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The admin panel is a [React ](https://facebook.github.io/react/ ) application which can embed other React applications. These other React applications are the `admin`  parts of each Strapi's plugins.
							 
						 
					
						
							
								
									
										
										
										
											2019-05-16 18:12:56 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-20 09:37:50 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Environment setup
  
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-20 09:37:50 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								To enable local plugin development, you need to start your application with the front-end development mode activated:
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-20 09:37:50 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```bash
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ cd my-app
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ yarn develop --watch-admin
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-24 10:47:22 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## API
  
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Strapi global variable
  
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-02-27 01:23:01 +03:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The administration exposes a global variable that is accessible for all the plugins.
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#### `strapi.backendURL`
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Retrieve the back-end URL. (e.g. `http://localhost:1337` ).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### `strapi.currentLanguage`
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Retrieve the administration panel default language (e.g. `en-US` )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### `strapi.languages`
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Array of the administration panel's supported languages. (e.g. `['ar', 'en', 'fr', ...]` ).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### `strapi.lockApp()`
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Display a loader that will prevent the user from interacting with the application.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### `strapi.unlockApp()`
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Remove the loader so the user can interact with the application
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### `strapi.notification`
  
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Display a notification (works with i18n message id). Use this command anywhere in your code.
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								strapi.notification.error('app.notification.error');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								strapi.notification.info('app.notification.info');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								strapi.notification.success('app.notification.success');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								strapi.notification.warning('app.notification.warning');
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### `strapi.remoteURL`
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The administration url (e.g. `http://localhost:4000/admin` ).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Main plugin object
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-02-27 01:23:01 +03:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Each plugin exports all its configurations in an object. This object is located in `my-plugin/admin/src/index.js` 
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Here are its properties:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-04-24 12:46:37 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								| key                       | type    | Description                                                                                                                                                                                                             |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| ------------------------- | ------- | :---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| blockerComponent          | node    | Props can be either `null`  or React node (e.g. `() => <div />` )                                                                                                                                                         |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| blockerComponentProps     | object  | Props to provide to customise the [blockerComponent ](https://github.com/strapi/strapi/blob/58588e10e5d15921b0966e20ce1bc6cde70df5cc/packages/strapi-helper-plugin/lib/src/components/BlockerComponent/index.js#L81-L86 ) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| description               | string  | Plugin's description retrieved from the package.json                                                                                                                                                                    |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| id                        | string  | Id of the plugin from the `package.json`                                                                                                                                                                                 |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| initializer               | node    | Refer to the [Initializer documentation ](#initializer )                                                                                                                                                                  |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| injectedComponents        | array   | Refer to the [Injected Component documentation ](#injected-components )                                                                                                                                                   |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| isReady                   | boolean | The app will load until this proprety is true                                                                                                                                                                           |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| leftMenuLinks             | array   | Array of links to inject in the menu                                                                                                                                                                                    |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| mainComponent             | node    | The plugin's App container, setting it to null will prevent the plugin from being displayed in the menu                                                                                                                 |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| name                      | string  | The plugin's name retrieved from the package.json                                                                                                                                                                       |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| pluginLogo                | file    | The plugin's logo                                                                                                                                                                                                       |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| preventComponentRendering | boolean | Whether or not display the plugin's blockerComponent instead of the main component                                                                                                                                      |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| settings                  | object  | Refer to the [Plugins settings API ](./frontend-settings-api.md )                                                                                                                                                         |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| reducers                  | object  | The plugin's redux reducers                                                                                                                                                                                             |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| trads                     | object  | The plugin's translation files                                                                                                                                                                                          |
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Initializer
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The component is generated by default when you create a new plugin. Use this component to execute some logic when the app is loading. When the logic has been executed this component should emit the `isReady`  event so the user can interact with the application.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								:::note
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 18:34:31 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Below is the Initializer component of the content-type-builder plugin.
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								It checks whether or not the autoreload feature is enabled and depending on this value changes the mainComponent of the plugin.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								:::
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  Initializer
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import React from 'react';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import PropTypes from 'prop-types';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import pluginId from '../../pluginId';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class Initializer extends React.PureComponent {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  // eslint-disable-line react/prefer-stateless-function
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  componentDidMount() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    const {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      admin: { autoReload, currentEnvironment },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } = this.props;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    let preventComponentRendering;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    let blockerComponentProps;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if (currentEnvironment === 'production') {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      preventComponentRendering = true;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      blockerComponentProps = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        blockerComponentTitle: 'components.ProductionBlocker.header',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        blockerComponentDescription: 'components.ProductionBlocker.description',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        blockerComponentIcon: 'fa-ban',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        blockerComponentContent: 'renderButton',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } else {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      // Don't render the plugin if the server autoReload is disabled
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      preventComponentRendering = !autoReload;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      blockerComponentProps = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        blockerComponentTitle: 'components.AutoReloadBlocker.header',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        blockerComponentDescription: 'components.AutoReloadBlocker.description',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        blockerComponentIcon: 'fa-refresh',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        blockerComponentContent: 'renderIde',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // Prevent the plugin from being rendered if currentEnvironment === PRODUCTION
							 
						 
					
						
							
								
									
										
										
										
											2020-04-20 11:04:07 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    this.props.updatePlugin(pluginId, 'preventComponentRendering', preventComponentRendering);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    this.props.updatePlugin(pluginId, 'blockerComponentProps', blockerComponentProps);
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // Emit the event plugin ready
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    this.props.updatePlugin(pluginId, 'isReady', true);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  render() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return null;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Initializer.propTypes = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  admin: PropTypes.object.isRequired,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  updatePlugin: PropTypes.func.isRequired,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default Initializer;
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Injected Components
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								(Coming soon)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Routing
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-20 09:37:50 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The routing is based on the [React Router V5 ](https://reacttraining.com/react-router/web/guides/philosophy ), due to it's implementation each route is declared in the `containers/App/index.js`  file.
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-11-07 12:05:39 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								::: tip
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Each route defined in a plugin must be prefixed by the plugin's id.
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								:::
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								**Route declaration :**
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Let's say that you want to create a route `/user`  with params `/:id`  associated with the container UserPage.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-02-27 01:23:01 +03:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The declaration would be as follows :
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `plugins/my-plugin/admin/src/containers/App/index.js` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import React from 'react';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import pluginId from '../../pluginId';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import UserPage from '../UserPage';
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class App extends React.Component {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  // ...
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  render() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return (
							 
						 
					
						
							
								
									
										
										
										
											2020-01-20 09:37:50 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      < div > 
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        < Switch > 
							 
						 
					
						
							
								
									
										
										
										
											2020-04-20 11:04:07 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          < Route  exact  path = { `/plugins/${pluginId}/user/:id` }  component = {UserPage}  /> 
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        < / Switch > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    );
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// ...
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-20 09:37:50 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Styling
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The administration panel uses [styled-components ](https://styled-components.com/ ) for writing css.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### i18n
  
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[React Intl ](https://github.com/yahoo/react-intl ) provides React components and an API to format dates, numbers, and strings, including pluralization and handling translations.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Usage**
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								We recommend to set all your components text inside the translations folder.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The example below shows how to use i18n inside your plugin.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Define all your ids with the associated message:**
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/translations/en.json` .
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```json
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "notification.error.message": "An error occurred"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/translations/fr.json` 
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```json
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "notification.error.message": "Une erreur est survenue"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Usage inside a component**
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/components/Foo/index.js` .
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { FormattedMessage } from 'react-intl';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import SomeOtherComponent from 'components/SomeOtherComponent';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const Foo = props => (
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  < div  className = {styles.foo} > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < FormattedMessage  id = "my-plugin.notification.error.message"  / > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < SomeOtherComponent  { . . . props }  / > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / div > 
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 17:36:25 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								);
							 
						 
					
						
							
								
									
										
										
										
											2019-05-06 16:17:16 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default Foo;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-10-23 10:11:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								See [the documentation ](https://github.com/yahoo/react-intl/wiki/Components#formattedmessage ) for more extensive usage.
							 
						 
					
						
							
								
									
										
										
										
											2020-01-20 09:37:50 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Global context
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								All plugins are wrapped inside the `GlobalContextProvider` , in this object you will have access to all plugins object as well as other utilities.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Usage:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Inside a functional component:**
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import React from 'react';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { useGlobalContext } from 'strapi-helper-plugin';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const Foo = () => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  const globalContext = useGlobalContext();
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  console.log(globalContext);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  return < div > Foo< / div > ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Inside a class component:**
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import React from 'react';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { GlobalContext } from 'strapi-helper-plugin';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class Foo extends React.Component {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  static contextType = GlobalContext;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  render() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    console.log(this.context);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return < div > Foo< / div > ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```