2018-01-10 13:36:24 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Front-end Use Cases
  
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This section gives use cases examples on front-end plugin development.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# Plugin advanced usage
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This section contains advanced resources to develop plugins.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Inject design
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The `ExtendComponent`  allows you to inject design from one plugin into another.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Example
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Let's say that you want to enable another plugin to inject a component into the top area of your plugin's container called `FooPage` ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/containers/FooPage/actions.js` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import { ON_TOGGLE_SHOW_LOREM } from './constants';
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export function onToggleShowLorem() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  return {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    type: ON_TOGGLE_SHOW_LOREM,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/containers/FooPage/index.js` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import React from 'react';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { connect } from 'react-redux';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { bindActionCreators, compose } from 'redux';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { createStructuredSelector } from 'reselect';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import PropTypes from 'prop-types';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Import the ExtendComponent
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import ExtendComponent from 'components/ExtendComponent';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Utils
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import injectReducer from 'utils/injectReducer';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Actions
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import { onToggleShowLorem } from './action';
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import reducer from './reducer';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Selectors
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { makeSelectShowLorem } from './selectors';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class FooPage extends React.Component {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  render() {
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    const lorem = this.props.showLorem ? (
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < p > Lorem ipsum dolor sit amet, consectetur adipiscing< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ) : (
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    );
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    return (
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < h1 > This is FooPage container< / h1 > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < ExtendComponent 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          area="top"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          container="FooPage"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          plugin="my-plugin"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          {...props}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        />
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        {lorem}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    );
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								FooPage.propTypes = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  onToggleShowLorem: PropTypes.func.isRequired,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  showLorem: PropTypes.bool.isRequired,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								function mapDispatchToProps(dispatch) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  return bindActionCreators(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      onToggleShowLorem,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    },
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    dispatch
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  );
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const mapStateToProps = createStructuredSelector({
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  showLorem: makeSelectShowLorem(),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const withConnect = connect(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  mapDispatchToProps,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  mapDispatchToProps
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								);
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								const withReducer = injectReducer({ key: 'fooPage', reducer });
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default compose(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  withReducer,
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  withConnect
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								)(FooPage);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/containers/FooPage/reducer.js` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { fromJS } from 'immutable';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { ON_TOGGLE_SHOW_LOREM } from './constants';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const initialState = fromJS({
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  showLorem: false,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								function fooPageReducer(state = initialState, action) {
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  switch (action.type) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case ON_TOGGLE_SHOW_LOREM:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      return state.set('showLorem', !state.get('showLorem'));
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    default:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      return state;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default fooPageReducer;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/containers/FooPage/selectors.js` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import { createSelector } from 'reselect';
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  Direct selector to the fooPage state domain
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const selectFooPageDomain = () => state => state.get('fooPage');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  Other specific selectors
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const makeSelectShowLorem = () =>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  createSelector(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    selectFooPageDomain(),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    substate => substate.get('showLorem')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  );
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export { makeSelectShowLorem };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								That's all now your plugin's container is injectable!
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-26 10:59:22 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Let's see how to inject a React Component from a plugin into another.
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Create your injectedComponent
  
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								**Path -** `./plugins/another-plugin/admin/src/extendables/BarContainer/index.js` ;
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import React from 'react';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import PropTypes from 'prop-types';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Import our Button component
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import Button from 'components/Button';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Other imports such as actions, selectors, sagas, reducer...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class BarContainer extends React.Component {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  render() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return (
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < Button  primary  onClick = {this.props.onToggleShowLorem} > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          Click me to show lorem paragraph
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < / Button > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    );
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								BarContainer.propTypes = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  onToggleShowLorem: PropTypes.func,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								BarContainer.defaultProps = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  onToggleShowLorem: () => {},
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default BarContainer;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-26 10:59:22 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Tell the admin that you want to inject a React Component from a plugin into another
  
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								You have to create a file called `injectedComponents.js`  at the root of your `another-plugin`  src folder.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/another-plugin/admin/src/injectedComponents.js` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import BarContainer from 'extendables/BarContainer';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// export an array containing all the injected components
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default [
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    area: 'top',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    container: 'FooPage',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    injectedComponent: BarContainer,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    plugin: 'my-plugin',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								];
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								Just by doing so, the `another-plugin`  will add a `Button`  which toggles the `lorem`  paragraph in the `FooPage`  view.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Routeless container store injection
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you have a container which can be a child of several other containers (i.e. it doesn't have a route); you'll have to inject it directly in the `./plugins/my-plugin/admin/src/containers/App/index.js`  file as follows :
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/containers/App/index.js` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import fooReducer from 'containers/Foo/reducer';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import fooSaga from 'container/Foo/sagas';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import saga from './sagas';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { makeSelectFoo } from './selectors';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export class App extends React.Component {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  render() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return (
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < div  className = {styles.app} > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < Switch > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          {*/ List of all your routes here */}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < / Switch > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    );
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								function mapDispatchToProps(dispatch) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  return bindActionCreators(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    dispatch
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  );
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const mapStateToProps = createStructuredSelector({
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  // ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const withConnect = connect(mapStateToProps, mapDispatchToProps);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Foo reducer
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const withFooReducer = injectReducer({ key: 'foo', reducer: fooReducer });
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Global reducer
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const withReducer = injectReducer({ key: 'global', reducer });
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Foo saga
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const withFooSaga = injectSaga({ key: 'foo', saga: fooSaga });
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Global saga
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const withSaga = injectSaga({ key: 'global', saga });
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default compose(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  withFooReducer,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  withReducer,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  withFooSaga,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  withSaga,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  withConnect,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								)(App);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:45:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Execute logic before mounting the plugin
  
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								You can execute a business logic before your plugin is being mounted.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Usage
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								To do this, you need to create `bootstrap.js`  file at the root of your `src`  plugin's folder.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This file must contains a default functions that returns a `Promise` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Example
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In this example, we want to populate the left menu with links that will refer to our Content Types.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./app/plugins/content-manager/admin/src/bootstrap.js` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { generateMenu } from 'containers/App/sagas';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// This method is executed before the load of the plugin
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const bootstrap = plugin =>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  new Promise((resolve, reject) => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    generateMenu()
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      .then(menu => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        plugin.leftMenuSections = menu;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        resolve(plugin);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      })
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      .catch(e => reject(e));
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  });
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default bootstrap;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:45:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Prevent plugin rendering
  
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								You can prevent your plugin from being rendered if some conditions aren't met.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Usage
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								To disable your plugin's rendering, you can simply create `requirements.js`  file at the root of your `src`  plugin's folder.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This file must contain a default function that returns a `Promise` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Example
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Let's say that you want to disable your plugin if the server autoReload config is disabled in development mode.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./app/config/environments/development/server.json` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "host": "localhost",
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "port": 1337,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "autoReload": {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    "enabled": true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "cron": {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    "enabled": false
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								You'll first create a request to check if the `autoReload`  config is enabled.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./app/plugins/my-plugin/config/routes.json` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```json
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "routes": [
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      "method": "GET",
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      "path": "/autoReload",
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      "handler": "MyPlugin.autoReload",
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      "config": {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        "policies": []
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  ]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								Then the associated handler:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./app/plugins/my-plugin/controllers/MyPlugin.js` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const _ = require('lodash');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const send = require('koa-send');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								module.exports = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  autoReload: async ctx => {
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    ctx.send({
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      autoReload: _.get(strapi.config.currentEnvironment, 'server.autoReload', {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        enabled: false,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      }),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    });
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Finally, you'll create a file called `requirements.js` at the root of your plugin's src folder.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The default function exported must return a `Promise` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you wan't to prevent the plugin from being rendered you'll have to set `plugin.preventComponentRendering = true;` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In this case, you'll have to set:
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								plugin.blockerComponentProps = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  blockerComponentTitle: 'my-plugin.blocker.title',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  blockerComponentDescription: 'my-plugin.blocker.description',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  blockerComponentIcon: 'fa-refresh',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								To follow the example above:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./app/plugins/my-plugin/admin/src/requirements.js` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Use our request helper
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import request from 'utils/request';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const shouldRenderCompo = plugin =>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  new Promise((resolve, request) => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    request('/my-plugin/autoReload')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      .then(response => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // If autoReload is enabled the response is `{ autoReload: { enabled: true } }` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        plugin.preventComponentRendering = !response.autoReload.enabled;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // Set the BlockerComponent props
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        plugin.blockerComponentProps = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          blockerComponentTitle: 'my-plugin.blocker.title',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          blockerComponentDescription: 'my-plugin.blocker.description',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          blockerComponentIcon: 'fa-refresh',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          blockerComponentContent: 'renderIde', // renderIde will add an ide section that shows the development environment server.json config
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return resolve(plugin);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      })
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      .catch(err => reject(err));
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  });
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default shouldRenderCompo;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Customization
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								You can render your own custom blocker by doing as follows:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./app/plugins/my-plugin/admin/src/requirements.js` .
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Use our request helper
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import request from 'utils/request';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Your custom blockerComponentProps
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import MyCustomBlockerComponent from 'components/MyCustomBlockerComponent';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const shouldRenderCompo = plugin =>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  new Promise((resolve, request) => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    request('/my-plugin/autoReload')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      .then(response => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // If autoReload is enabled the response is `{ autoReload: { enabled: true } }` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        plugin.preventComponentRendering = !response.autoReload.enabled;
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // Tell which component to be rendered instead
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        plugin.blockerComponent = MyCustomBlockerComponent;
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return resolve(plugin);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      })
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      .catch(err => reject(err));
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  });
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default shouldRenderCompo;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Using React/Redux and sagas
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If your application is going to interact with some back-end application for data, we recommend using redux saga for side effect management.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This short tutorial will show how to fetch data using actions/reducer/sagas.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Constants declaration
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/containers/FooPage/constants.js` 
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export const DATA_FETCH = 'MyPlugin/FooPage/DATA_FETCH';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export const DATA_FETCH_ERROR = 'MyPlugin/FooPage/DATA_FETCH_ERROR';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export const DATA_FETCH_SUCCEEDED = 'MyPlugin/FooPage/DATA_FETCH_SUCCEEDED';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Actions declaration
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/containers/FooPage/actions.js` 
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  DATA_FETCH,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  DATA_FETCH_ERROR,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  DATA_FETCH_SUCCEEDED,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								} from './constants';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export function dataFetch(params) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  return {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    type: DATA_FETCH,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    params,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export function dataFetchError(errorMessage) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  return {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    type: DATA_FETCH_ERROR,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    errorMessage,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export function dataFetchSucceeded(data) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  return {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    type: DATA_FETCH_SUCCEEDED,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    data,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Reducer
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								We strongly recommend to use [Immutable.js ](https://facebook.github.io/immutable-js/ ) to structure your data.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/containers/FooPage/reducer.js` 
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { fromJS, Map } from 'immutable';
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import { DATA_FETCH_ERROR, DATA_FETCH_SUCCEEDED } from './constants';
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const initialState = fromJS({
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  data: Map({}),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  error: false,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  errorMessage: '',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  loading: true,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								function fooPageReducer(state = initialState, action) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  switch (action.type) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case DATA_FETCH_ERROR:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      return state
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        .set('error', true)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        .set('errorMessage', action.errorMessage)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        .set('loading', false);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case DATA_FETCH_SUCCEEDED:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      return state
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        .set('data', Map(action.data))
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        .set('error', false)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        .set('errorMessage', '')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        .set('loading', false);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    default:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      return state;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default fooPageReducer;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Sagas
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/containers/FooPage/sagas.js` 
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { LOCATION_CHANGE } from 'react-router-redux';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { takeLatest, put, fork, call, take, cancel } from 'redux-saga/effects';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Use our request helper
							 
						 
					
						
							
								
									
										
										
										
											2018-07-02 18:37:00 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import request from 'utils/request';
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Actions
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { dataFetchError, dataFetchSucceeded } from './actions';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { DATA_FETCH } from './constants';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export function* fetchData(action) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  try {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    const requestUrl = `/baseUrl/${action.params}` ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    const opts = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      method: 'GET',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // Fetch data
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    const response = yield call(request, requestUrl, opts);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // Pass the response to the reducer
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    yield put(dataFetchSucceeded(response));
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  } catch (error) {
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    yield put(dataFetchError(error));
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Individual export for testing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								function* defaultSaga() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  // Listen to DATA_FETCH event
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  const fetchDataWatcher = yield fork(takeLatest, DATA_FETCH, fetchData);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  // Cancel watcher
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  yield take(LOCATION_CHANGE);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  yield cancel(fetchDataWatcher);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default defaultSaga;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								N.B. You can use a selector in your sagas :
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { put, select, fork, call, take, cancel } from 'redux-saga/effects';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { makeSelectUserName } from './selectors';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export function* foo() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  try {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    const userName = yield select(makeSelectUserName());
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // ...
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  } catch (error) {
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    // ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								function defaultSaga() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  // ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default defaultSaga;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Selectors
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[Reselect ](https://github.com/reactjs/reselect ) is a library used for slicing your redux state and providing only the relevant sub-tree to a react component. It has three key features:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								1.  Computational power 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  Memoization 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								3.  Composability 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Creating a selector:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/containers/FooPage/selectors.js` 
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { createSelector } from 'reselect';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  Direct selector to the fooPage state domain
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								const selectFooPageDomain = () => state => state.get('fooPage');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  Other specific selectors
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const makeSelectLoading = () =>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  createSelector(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    selectFooPageDomain(),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    substate => substate.get('loading')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  );
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  Default selector used by FooPage
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const selectFooPage = () =>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  createSelector(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    selectFooDomain(),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    substate => substate.toJS()
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  );
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default selectFooPage;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export { makeSelectLoading };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Example
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Path —** `./plugins/my-plugin/admin/src/containers/FooPage/index.js` 
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import React from 'react';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { bindActionCreators } from 'redux';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { connect, compose } from 'react-redux';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import PropTypes from 'prop-types';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Main router
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { router } from 'app';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Utils
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import injectSaga from 'utils/injectSaga';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import injectReducer from 'utils/injectReducer';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Actions
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import { dataFetch } from './actions';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// sagas
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import saga from './sagas';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Selectors
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import selectFooPage from './selectors';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Reducer
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import reducer from './reducer';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export class FooPage extends React.Component {
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 11:31:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  UNSAFE_componentWillReceiveProps(nextProps) {
							 
						 
					
						
							
								
									
										
										
										
											2018-01-10 11:32:24 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    if (this.props.error !== nextProps.error & &  nextProps.error) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      strapi.notification.error(nextProps.errorMessage);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  componentDidUpdate(prevProps) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if (prevProps.match.pathname !== this.props.pathname) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      this.props.dataFetch(this.props.match.params.bar);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  render() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if (this.props.error) return < div > An error occurred< / div > ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return (
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < h4 > Data display< / h4 > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < span > {this.props.data.foo}< / span > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < span > {this.props.data.bar}< / span > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    );
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  FooPage.propTypes = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    data: PropTypes.object.isRequired,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    dataFetch: PropTypes.func.isRequired,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    error: PropTypes.bool.isRequired,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    errorMessage: PropTypes.string.isRequired,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    match: PropTypes.object.isRequired,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  const mapStateToProps = selectFoo();
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  function mapDispatchToProps(dispatch) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return bindActionCreators(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        dataFetch,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      dispatch
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    );
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  const withConnect = connect(mapStateToProps, mapDispatchToProps);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  const withReducer = injectReducer({ key: 'fooPage', reducer });
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  const withSagas = injectSaga({ key: 'fooPage', saga });
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  export default compose(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    withReducer,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    withSagas,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    withConnect,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  )(FooPage);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```