Skip to content

Commit

Permalink
Fixes #1619, Fixes #1549, Fixes #1103: notification system and docume…
Browse files Browse the repository at this point in the history
…ntation of the js api
  • Loading branch information
mbarto committed Mar 22, 2017
1 parent 8164e45 commit cffff1c
Show file tree
Hide file tree
Showing 10 changed files with 427 additions and 410 deletions.
10 changes: 4 additions & 6 deletions docma-config.json
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,8 @@
{ "label": "Reducers", "href": "api/reducers" },
{ "label": "Epics", "href": "api/epics" },
{ "separator": true },
{ "label": "JavaScript API", "href": "api/jsapi" },
{ "separator": true },
{ "label": "Plugins", "href": "api/plugins" }

]
Expand Down Expand Up @@ -110,6 +112,7 @@
"actions" : ["web/client/actions/search.js"],
"reducers" : ["web/client/reducers/search.js"],
"epics": "web/client/epics/search.js",
"jsapi": "web/client/jsapi/MapStore2.js",
"plugins": [
"web/client/plugins/Search.jsx",
"web/client/plugins/BackgroundSwitcher.jsx",
Expand All @@ -120,12 +123,7 @@
"./docs/**/*md",
{
"readme": "./README.md",
"site": "./docs/index.md",
"developer-guide": "./docs/developer-guide/index.md",
"plugins-architecture": "./docs/developer-guide/plugins-architecture.md",
"building-and-developing": "./docs/developer-guide/plugins-architecture.md",
"plugins-documentation": "./docs/developer-guide/plugins-documentation.md",
"project-creation-script": "./docs/developer-guide/project-creation-script.md"
"site": "./docs/index.md"
}
]
}
8 changes: 2 additions & 6 deletions docs/developer-guide/plugins-documentation.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ Inside the **plugins** section, several modes can be configured (e.g. desktop or
}
```

Each plugin can be simply listed (and the default configuration is used):
Each plugin can be simply listed (and the default configuration is used):

```js
"plugins": {
Expand All @@ -33,15 +33,11 @@ or fully configured:
...
"desktop": [{
"name": "Map",
"cfg": {
...
}
},
...
]
}
```
Look at each plugin documentation page for a list of available configuration properties.

# Plugins List:
* [Map](map-plugin)
Look at the [plugin reference page](./api/plugins) for a list of available configuration properties.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@
},
"//": "replace react-sortable-items with official on npm when 0.0.10 with remove_deprecated PR in included",
"dependencies": {
"@carnesen/redux-add-action-listener-enhancer": "0.0.1",
"ag-grid": "3.3.3",
"ag-grid-react": "3.3.1",
"axios": "0.11.1",
Expand Down
2 changes: 1 addition & 1 deletion web/client/containers/Page.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ const Page = React.createClass({
desktop: [...this.props.pagePluginsConfig.desktop, ...this.props.pluginsConfig.desktop],
mobile: [...this.props.pagePluginsConfig.mobile, ...this.props.pluginsConfig.mobile]
};
return (<PluginsContainer key="{this.props.id}" id={"page-" + this.props.id} className={"page page-" + this.props.id}
return (<PluginsContainer key={this.props.id} id={"page-" + this.props.id} className={"page page-" + this.props.id}
pluginsConfig={pluginsConfig}
plugins={this.props.plugins}
params={this.props.params}
Expand Down
10 changes: 9 additions & 1 deletion web/client/examples/api/init.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,6 @@ function init() {
/*eslint-disable */
pluginsCfg = cfg && MapStore2.buildPluginsCfg(cfg.pluginsCfg.standard, cfg.userCfg) || embeddedPlugins;
MapStore2.create('container', {
/*eslint-enable */
plugins: pluginsCfg,
initialState: cfg && cfg.state && {
defaultState: cfg.state
Expand All @@ -38,4 +37,13 @@ function init() {
path: '../../dist/themes'
}
});
MapStore2.onAction('CHANGE_MAP_VIEW', function(action) {
console.log('ZOOM: ' + action.zoom);
});
MapStore2.onStateChange(function(map) {
console.log('STATE ZOOM: ' + map.zoom);
}, function(state) {
return (state.map && state.map.present) || state.map || {}
});
/*eslint-enable */
}
135 changes: 131 additions & 4 deletions web/client/jsapi/MapStore2.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/**
/*
* Copyright 2016, GeoSolutions Sas.
* All rights reserved.
*
Expand Down Expand Up @@ -196,7 +196,61 @@ function buildPluginsCfg(plugins, cfg) {
};
}

const actionListeners = {};
let stateChangeListeners = [];
let app;

/**
* MapStore2 JavaScript API. Allows embedding MapStore2 functionalities into
* a standard HTML page.
* @class
*/
const MapStore2 = {
/**
* Instantiates an embedded MapStore2 application in the given container.
* @memberof MapStore2
* @static
* @param {string} container id of the DOM element that should contain the embedded MapStore2
* @param {object} options set of options of the embedded app
*
* The options object can contain the following properties, to configure the app UI and state:
* * **plugins**: list of plugins (and the related configuration) to be included in the app
* look at [Plugins documentation](./plugins-documentation) for further details
* * **config**: map configuration object for the application (look at [Map Configuration](./maps-configuration) for details)
* * **initialState**: allows setting the initial application state (look at [State Configuration](./app-state-configuration) for details)
*
* Styling can be configured either using a **theme**, or a complete custom **less stylesheet**, using the
* following options properties:
* * **style**: less style to be applied
* * **theme**: theme configuration options:
* * path: path/url of the themes folder related to the current page
* * theme: theme name to be used
*
* ```javascript
* {
* plugins: ['Map', 'ZoomIn', 'ZoomOut'],
* config: {
* map: {
* ...
* }
* },
* initialState: {
* defaultState: {
* ...
* }
* },
* style: '<custom style>',
* theme: {
* theme: 'mytheme',
* path: 'dist/themes'
* }
* }
* ```
* @example
* MapStore2.create('container', {
* plugins: ['Map']
* });
*/
create(container, options) {
const embedded = require('../containers/Embedded');

Expand All @@ -220,7 +274,7 @@ const MapStore2 = {
const appStore = require('../stores/StandardStore').bind(null, initialState || {}, {});
const initialActions = options.initialState ? [] : [configureMap.bind(null, options.config || defaultConfig)];
const appConfig = {
storeOpts,
storeOpts: assign({}, storeOpts, {notify: true}),
appStore,
pluginsDef,
initialActions,
Expand All @@ -242,11 +296,84 @@ const MapStore2 = {
};

const themeCfg = options.theme && assign({}, defaultThemeCfg, options.theme) || defaultThemeCfg;
ReactDOM.render(<StandardApp themeCfg={themeCfg} className="fill" {...appConfig}/>, document.getElementById(container));
app = ReactDOM.render(<StandardApp themeCfg={themeCfg} className="fill" {...appConfig}/>, document.getElementById(container));
app.store.addActionListener((action) => {
(actionListeners[action.type] || []).concat(actionListeners['*'] || []).forEach((listener) => {
listener.call(null, action);
});
});
app.store.subscribe(() => {
stateChangeListeners.forEach(({listener, selector}) => {
listener.call(null, selector(app.store.getState()));
});
});
},
buildPluginsCfg,
getMapNameFromRequest,
loadConfigFromStorage
loadConfigFromStorage,
/**
* Adds a listener that will be notified of all the MapStore2 events (**actions**), or only some of them.
*
* @memberof MapStore2
* @static
* @param {string} type type of actions to be captured (* for all)
* @param {function} listener function to be called for each launched action; it will receive
* the action as the only argument
* @example
* MapStore2.onAction('CHANGE_MAP_VIEW', function(action) {
* console.log(action.zoom);
* });
*/
onAction: (type, listener) => {
const listeners = actionListeners[type] || [];
listeners.push(listener);
actionListeners[type] = listeners;
},
/**
* Removes an action listener.
*
* @memberof MapStore2
* @static
* @param {string} type type of actions that is captured by the listener (* for all)
* @param {function} listener listener to be removed
* @example
* MapStore2.offAction('CHANGE_MAP_VIEW', listener);
*/
offAction: (type, listener) => {
const listeners = (actionListeners[type] || []).filter((l) => l !== listener);
actionListeners[type] = listeners;
},
/**
* Adds a listener that will be notified of each state update.
*
* @memberof MapStore2
* @static
* @param {function} listener function to be called for each state udpate; it will receive
* the new state as the only argument
* @param {function} [selector] optional function that will produce a partial/derived state
* from the global state before calling the listeners
* @example
* MapStore2.onStateChange(function(map) {
* console.log(map.zoom);
* }, function(state) {
* return (state.map && state.map.present) || state.map || {};
* });
*/
onStateChange: (listener, selector = (state) => state) => {
stateChangeListeners.push({listener, selector});
},
/**
* Removes a state listener.
*
* @memberof MapStore2
* @static
* @param {function} listener listener to be removed
* @example
* MapStore2.offStateChange(listener);
*/
offStateChange: (listener) => {
stateChangeListeners = stateChangeListeners.filter((l) => l !== listener);
}
};

if (!global.Intl ) {
Expand Down
Loading

0 comments on commit cffff1c

Please sign in to comment.