terriajs
Version:
Geospatial data visualization platform.
431 lines (388 loc) • 36.6 kB
HTML
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>JSDoc: Source: ReactViews/Custom/registerCustomComponentTypes.js</title>
<script src="scripts/prettify/prettify.js"> </script>
<script src="scripts/prettify/lang-css.js"> </script>
<!--[if lt IE 9]>
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
<link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css">
</head>
<body>
<div id="main">
<h1 class="page-title">Source: ReactViews/Custom/registerCustomComponentTypes.js</h1>
<section>
<article>
<pre class="prettyprint source linenums"><code>'use strict';
/* global require */
const defined = require('terriajs-cesium/Source/Core/defined');
const DeveloperError = require('terriajs-cesium/Source/Core/DeveloperError');
const Chart = require('./Chart/Chart');
const ChartExpandAndDownloadButtons = require('./Chart/ChartExpandAndDownloadButtons');
const Collapsible = require('./Collapsible/Collapsible');
const CustomComponents = require('./CustomComponents');
const CustomComponentType = require('./CustomComponentType');
const TableStructure = require('../../Map/TableStructure');
const VarType = require('../../Map/VarType');
const React = require('react');
import ChartPreviewStyles from './Chart/chart-preview.scss';
const chartAttributes = [
'src',
'src-preview',
'sources',
'source-names',
'downloads',
'download-names',
'preview-x-label',
'data',
'id',
'x-column',
'y-column',
'y-columns',
'colors',
'column-names',
'column-units',
'styling',
'highlight-x',
'poll-seconds',
'poll-sources',
'poll-id-columns',
'poll-replace',
'title',
'can-download',
'hide-buttons'
];
/**
* @private
*/
function splitStringIfDefined(string) {
return defined(string) ? string.split(',') : undefined;
}
/**
* Registers custom component types.
*
* Here we define the following:
* - <chart>
* - <collapsible>
* You can define your own by replacing this file with your own version.
*
*
* <collapsible> displays a collapsible section (see Collapsible.jsx) around its children components.
* It has two allowed attributes:
* - title: The title of the section.
* - [open]: true or false (the default).
*
*
* <chart> displays an interactive chart (see Chart.jsx), along with "expand" and "download" buttons (ChartExpandAndDownloadButtons.jsx).
* This button enables a catalog item based on the data, for display in the Chart Panel (ChartPanel.jsx).
* It also detects if it appears in the second column of a <table> and, if so, rearranges itself to span two columns.
*
* It can have the following attributes. Currently URLs must point to csv (not json) data; but inline json data is supported.
* Note if you change any of these, also update the chartAttributes array above, or they won't make it here.
*
* - [title]: The title of the chart. If not supplied, defaults to the name of the context-supplied feature, if available, or else simply "Chart".
* - [x-column]: The x column name or number to show in the preview, if not the first appropriate column. NOT FULLY IMPLEMENTED YET.
* - [y-column]: The y column name or number to show in the preview, if not the first scalar column.
* - [y-columns]: Comma-separated list of y column names or numbers to show in the preview. Overrides "y-column" if provided.
* - [colors]: Comma-separated list of css colors to apply to data columns.
* - [column-names]: Comma-separated list of column names to override those in the source data; empty strings retain the original column name.
* Eg. column-names="Time,Height,Speed"
* - [column-units]: Comma-separated list of the units for each column. Empty strings are ok.
* Eg. column-units=",m,km/h"
* - [preview-x-label]: The preview chart x-axis label. Defaults to empty string. Eg. long-names="Last 24 hours,Last 5 days,Time".
* - [id]: An id for the chart; give different charts from the same feature different ids. The actual catalogItem.id used for the expanded chart will
* also incorporate the chart title and the catalog item name it came from.
* - [styling]: Defaults to 'feature-info'. Can also be 'histogram'. TODO: improve.
* - [highlight-x]: An x-coordinate to highlight.
* - [poll-seconds]: If present, the chart is updated from [poll-sources] every [poll-seconds] seconds.
* TODO: Returned data is merged into existing data and shown.
* - [poll-sources]: Comma-separated list of URLs to poll every [poll-seconds] seconds. Defaults to sources.
* - [poll-replace]: Either 'true' or 'false' (case sensitive). Pass 'true' to completely replace the data, 'false' to update
* the existing data. Defaults to false (updating).
* - [can-download]: 'false' to hide the Download button on the chart. By default true and for any other value, the download button is shown.
* - [hide-buttons]: 'true' to hide the Expand and Download buttons on the chart. By default and for any other value, the buttons are shown when applicable.
* Overrides can-download.
*
* Provide the data in one of these four ways:
* - [sources]: Comma-separated URLs for data at each available time range. The first in the list is shown in the feature info panel preview.
* Eg. sources="http://example.com/series?offset=1d,http://example.com/series?offset=5d,http://example.com/series?all"
* - [source-names]: Comma-separated display names for each available time range, used in the expand-chart dropdown button.
* Eg. source-names="1d,5d,30d".
* - [downloads]: Same as sources, but for download only. Defaults to the same as sources.
* Eg. sources="http://example.com/series?offset=1d,http://example.com/series?offset=5d,http://example.com/series?all"
* - [download-names]: Same as source-names, but for download only. Defaults to the same as source-names.
* Eg. source-names="1d,5d,30d,max".
* Or:
* - [src]: The URL of the data to show in the chart panel, once "expand" is clicked. Eg. src="http://example.com/full_time_series.csv".
* - [src-preview]: The URL of the data to show in the feature info panel. Defaults to src. Eg. src-preview="http://example.com/preview_time_series.csv".
* Or:
* - [data]: csv-formatted data, with \n for newlines. Eg. data="time,a,b\n2016-01-01,2,3\n2016-01-02,5,6".
* or json-formatted string data, with \quot; for quotes, eg. data="[[\quot;a\quot;,\quot;b\quot;],[2,3],[5,6]]".
* Or:
* - None of the above, but supply csv or json-formatted data as the content of the chart data, with \n for newlines.
* Eg. <chart>time,a,b\n2016-01-01,2,3\n2016-01-02,5,6</chart>.
* or <chart>[["x","y","z"],[1,10,3],[2,15,9],[3,8,12],[5,25,4]]</chart>.
*
*
* See CustomComponentType for more details.
*/
const registerCustomComponentTypes = function(terria) {
/**
* @private
*/
function processChartNode(context, node, children) {
checkAllPropertyKeys(node.attribs, chartAttributes);
const columnNames = splitStringIfDefined(node.attribs['column-names']);
const columnUnits = splitStringIfDefined(node.attribs['column-units']);
const styling = node.attribs['styling'] || 'feature-info';
// Present src and src-preview as if they came from sources.
let sources = splitStringIfDefined(node.attribs.sources);
const sourceNames = splitStringIfDefined(node.attribs['source-names']);
if (!defined(sources) && defined(node.attribs.src)) {
// [src-preview, src], or [src] if src-preview is not defined.
sources = [node.attribs.src];
if (defined(node.attribs['src-preview'])) {
sources.unshift(node.attribs['src-preview']);
}
}
const downloads = splitStringIfDefined(node.attribs.downloads) || sources;
const downloadNames = splitStringIfDefined(node.attribs['download-names']) || sourceNames;
const pollSources = splitStringIfDefined(node.attribs['poll-sources']);
const id = node.attribs.id;
const xColumn = node.attribs['x-column'];
let yColumns = splitStringIfDefined(node.attribs['y-columns']);
if (!defined(yColumns) && defined(node.attribs['y-column'])) {
yColumns = [node.attribs['y-column']];
}
const url = defined(sources) ? sources[0] : undefined;
const tableStructure = tableStructureFromStringData(getSourceData(node, children));
const colors = splitStringIfDefined(node.attribs['colors']);
const title = node.attribs['title'];
const updateCounterKeyProps = {
url: url,
xColumn: xColumn,
yColumns: yColumns
};
const updateCounter = CustomComponents.getUpdateCounter(context.updateCounters, Chart, updateCounterKeyProps);
// If any of these attributes change, change the key so that React knows to re-render the chart.
const reactKeys = [
title || '',
id || '',
(sources && sources.join('|')) || '',
xColumn || '',
(defined(yColumns) ? yColumns.join('|') : ''),
colors || ''
];
const chartElements = [];
if (node.attribs['hide-buttons'] !== 'true') {
chartElements.push(React.createElement(ChartExpandAndDownloadButtons, {
key: 'button',
terria: terria,
catalogItem: context.catalogItem,
title: title,
colors: colors, // The colors are used when the chart is expanded.
feature: context.feature,
sources: sources,
sourceNames: sourceNames,
downloads: downloads,
downloadNames: downloadNames,
tableStructure: tableStructure,
columnNames: columnNames,
columnUnits: columnUnits,
xColumn: node.attribs['x-column'],
yColumns: yColumns,
id: id,
canDownload: !(node.attribs['can-download'] === 'false'),
raiseToTitle: !!getInsertedTitle(node),
pollSources: pollSources,
pollSeconds: node.attribs['poll-seconds'],
pollReplace: node.attribs['poll-replace'] === 'true',
updateCounter: updateCounter // Change this to trigger an update.
}));
}
chartElements.push(React.createElement(Chart, {
key: 'chart',
axisLabel: {
x: node.attribs['preview-x-label'],
y: undefined
},
catalogItem: context.catalogItem,
url: url,
tableStructure: tableStructure,
xColumn: node.attribs['x-column'],
yColumns: yColumns,
styling: styling,
highlightX: node.attribs['highlight-x'],
// colors: colors, // Note that the preview chart doesn't show the colors.
pollUrl: defined(pollSources) ? pollSources[0] : undefined,
pollSeconds: node.attribs['poll-seconds'], // This is unorthodox: this prop is picked up not by Chart.jsx, but in selfUpdateSeconds below.
// pollIdColumns: node.attribs['poll-id-columns'], // TODO: implement.
// pollReplace: (node.attribs['poll-replace'] === 'true'),
updateCounter: updateCounter,
transitionDuration: 300
}));
return React.createElement('div', {
key: (reactKeys.join('-')) || 'chart-wrapper',
className: ChartPreviewStyles.previewChartWrapper
}, chartElements);
}
/**
* Returns the 'data' attribute if available, otherwise the child of this node.
* @private
*/
function getSourceData(node, children) {
const sourceData = node.attribs['data'];
if (sourceData) {
return sourceData;
}
if (Array.isArray(children) && children.length > 0) {
return children[0];
}
return children;
}
/**
* This function does not activate any columns in itself.
* That should be done by TableCatalogItem when it is created around this.
* @private
*/
function tableStructureFromStringData(stringData) {
// sourceData can be either json (starts with a '[') or csv format (contains a true line feed or '\n'; \n is replaced with a real linefeed).
if (!defined(stringData) || stringData.length < 2) {
return;
}
// We prevent ALT, LON and LAT from being chosen, since we know this is a non-geo csv already.
const result = new TableStructure('chart', {unallowedTypes: [VarType.ALT, VarType.LAT, VarType.LON]});
if (stringData[0] === '[') {
// Treat as json.
const json = JSON.parse(stringData.replace(/&quot;/g, '"'));
return TableStructure.fromJson(json, result);
}
if (stringData.indexOf('\\n') >=0 || stringData.indexOf('\n') >= 0) {
// Treat as csv.
return TableStructure.fromCsv(stringData.replace(/\\n/g, '\n'), result);
}
}
/**
* @private
*/
function getInsertedTitle(node) {
// Check if there is a title in the position 'Title' relative to node <chart>:
// <tr><td>Title</td><td><chart></chart></tr>
if (defined(node.parent) && (node.parent.name === 'td')
&& defined(node.parent.parent) && (node.parent.parent.name === 'tr')
&& defined(node.parent.parent.children[0])
&& defined(node.parent.parent.children[0].children[0])) {
return node.parent.parent.children[0].children[0].data;
}
}
const chartComponentType = new CustomComponentType({
name: 'chart',
attributes: chartAttributes,
processNode: processChartNode,
furtherProcessing: [
//
// These replacements reformat <chart>s defined directly in a csv, so they take the full width of the 2-column table,
// and present the column name as the title.
// It replaces:
// <tr><td>Title</td><td><chart></chart></tr>
// with:
// <tr><td colSpan:2><div class="chart-title">Title</div><chart></chart></tr>
//
{
shouldProcessNode: node => (
// If this node is a <chart> in the second column of a 2-column table,
// then add a title taken from the first column, and give it colSpan 2.
node.name === 'td'
&& node.children.length === 1
&& node.children[0].name === 'chart'
&& node.parent.name === 'tr'
&& node.parent.children.length === 2
),
processNode: (context, node, children) => { // eslint-disable-line react/display-name
const title = node.parent.children[0].children[0].data;
const revisedChildren = [
React.createElement('div', {key: 'title', className: ChartPreviewStyles.chartTitleFromTable}, title)
].concat(children);
return React.createElement(node.name, {key: 'chart', colSpan: 2, className: ChartPreviewStyles.chartTd}, node.data, revisedChildren);
}
},
{
shouldProcessNode: node => (
// If this node is in the first column of a 2-column table, and the second column is a <chart>,
// then remove it.
node.name === 'td'
&& node.children.length === 1
&& node.parent.name === 'tr'
&& node.parent.children.length === 2
&& node.parent.children[1].name === 'td'
&& node.parent.children[1].children.length === 1
&& node.parent.children[1].children[0].name === 'chart'
),
processNode: function() {
return; // Do not return a node.
}
}
],
/*
* isCorresponding is a function which checks a ReactComponent and returns a Boolean,
* indicating if that react component corresponds to this type.
* "Correspondence" is whatever the component wants it to be, but must be consistent with selfUpdateSeconds.
*/
isCorresponding: function(reactComponent) {
return reactComponent.type === Chart;
},
selfUpdateSeconds: function(reactComponent) {
return reactComponent.props.pollSeconds; // Note this is unorthodox.
}
});
if (!defined(terria)) {
// The chart expand button needs a reference to the Terria instance to add the chart to the catalog.
throw new DeveloperError('Terria is a required argument of registerCustomComponentTypes.');
}
CustomComponents.register(chartComponentType);
const collapsibleComponentType = new CustomComponentType({
name: 'collapsible',
attributes: ['title', 'open'],
processNode: function(context, node, children) {
return React.createElement(Collapsible, {
key: node.attribs.title,
displayName: node.attribs.title,
title: node.attribs.title,
startsOpen: typeof node.attribs.open === 'string' ? JSON.parse(node.attribs.open) : undefined
}, children);
}
});
CustomComponents.register(collapsibleComponentType);
};
/**
* @private
*/
function checkAllPropertyKeys(object, allowedKeys) {
for (const key in object) {
if (object.hasOwnProperty(key)) {
if (allowedKeys.indexOf(key) === -1) {
console.log('Unknown attribute ' + key);
throw new DeveloperError('Unknown attribute ' + key);
}
}
}
}
module.exports = registerCustomComponentTypes;
</code></pre>
</article>
</section>
</div>
<nav>
<h2><a href="index.html">Home</a></h2><h3>Classes</h3><ul><li><a href="AbsCode.html">AbsCode</a></li><li><a href="AbsConcept.html">AbsConcept</a></li><li><a href="AbsDataset.html">AbsDataset</a></li><li><a href="AbsIttCatalogGroup.html">AbsIttCatalogGroup</a></li><li><a href="AbsIttCatalogItem.html">AbsIttCatalogItem</a></li><li><a href="AddressGeocoder.html">AddressGeocoder</a></li><li><a href="ArcGisCatalogGroup.html">ArcGisCatalogGroup</a></li><li><a href="ArcGisFeatureServerCatalogGroup.html">ArcGisFeatureServerCatalogGroup</a></li><li><a href="ArcGisFeatureServerCatalogItem.html">ArcGisFeatureServerCatalogItem</a></li><li><a href="ArcGisMapServerCatalogGroup.html">ArcGisMapServerCatalogGroup</a></li><li><a href="ArcGisMapServerCatalogItem.html">ArcGisMapServerCatalogItem</a></li><li><a href="AugmentedVirtuality.html">AugmentedVirtuality</a></li><li><a href="BingMapsCatalogItem.html">BingMapsCatalogItem</a></li><li><a href="BooleanParameter.html">BooleanParameter</a></li><li><a href="BulkAddressGeocoderResult.html">BulkAddressGeocoderResult</a></li><li><a href="CameraView.html">CameraView</a></li><li><a href="Catalog.html">Catalog</a></li><li><a href="CatalogFunction.html">CatalogFunction</a></li><li><a href="CatalogGroup.html">CatalogGroup</a></li><li><a href="CatalogItem.html">CatalogItem</a></li><li><a href="CatalogMember.html">CatalogMember</a></li><li><a href="Cesium.html">Cesium</a></li><li><a href="Cesium3DTilesCatalogItem.html">Cesium3DTilesCatalogItem</a></li><li><a href="CesiumDragPoints.html">CesiumDragPoints</a></li><li><a href="CesiumTerrainCatalogItem.html">CesiumTerrainCatalogItem</a></li><li><a href="CkanCatalogGroup.html">CkanCatalogGroup</a></li><li><a href="CkanCatalogItem.html">CkanCatalogItem</a></li><li><a href="Clock.html">Clock</a></li><li><a href="CompositeCatalogItem.html">CompositeCatalogItem</a></li><li><a href="Concept.html">Concept</a></li><li><a href="CorsProxy.html">CorsProxy</a></li><li><a href="CsvCatalogItem.html">CsvCatalogItem</a></li><li><a href="CswCatalogGroup.html">CswCatalogGroup</a></li><li><a href="CustomComponentType.html">CustomComponentType</a></li><li><a href="CzmlCatalogItem.html">CzmlCatalogItem</a></li><li><a href="DataSourceCatalogItem.html">DataSourceCatalogItem</a></li><li><a href="DateTimeParameter.html">DateTimeParameter</a></li><li><a href="DisplayVariablesConcept.html">DisplayVariablesConcept</a></li><li><a href="EnumerationParameter.html">EnumerationParameter</a></li><li><a href="Feature.html">Feature</a></li><li><a href="FunctionParameter.html">FunctionParameter</a></li><li><a href="GeoJsonCatalogItem.html">GeoJsonCatalogItem</a></li><li><a href="GlobeOrMap.html">GlobeOrMap</a></li><li><a href="GnafAddressGeocoder.html">GnafAddressGeocoder</a></li><li><a href="GnafApi.html">GnafApi</a></li><li><a href="GnafSearchProviderViewModel.html">GnafSearchProviderViewModel</a></li><li><a href="GpxCatalogItem.html">GpxCatalogItem</a></li><li><a href="HelpScreen.html">HelpScreen</a></li><li><a href="HelpSequence.html">HelpSequence</a></li><li><a href="HelpSequences.html">HelpSequences</a></li><li><a href="HelpViewState.html">HelpViewState</a></li><li><a href="ImageryLayerCatalogItem____.html">ImageryLayerCatalogItem</a></li><li><a href="IonImageryCatalogItem.html">IonImageryCatalogItem</a></li><li><a href="KmlCatalogItem.html">KmlCatalogItem</a></li><li><a href="Leaflet.html">Leaflet</a></li><li><a href="LeafletDataSourceDisplay.html">LeafletDataSourceDisplay</a></li><li><a href="LeafletDragPoints.html">LeafletDragPoints</a></li><li><a href="LeafletGeomVisualizer.html">LeafletGeomVisualizer</a></li><li><a href="LegendHelper.html">LegendHelper</a></li><li><a href="LegendUrl.html">LegendUrl</a></li><li><a href="LineParameter.html">LineParameter</a></li><li><a href="MagdaCatalogItem.html">MagdaCatalogItem</a></li><li><a href="MapboxMapCatalogItem.html">MapboxMapCatalogItem</a></li><li><a href="MapInteractionMode.html">MapInteractionMode</a></li><li><a href="Metadata.html">Metadata</a></li><li><a href="MetadataItem.html">MetadataItem</a></li><li><a href="module.html#.exports">exports</a></li><li><a href="OgrCatalogItem.html">OgrCatalogItem</a></li><li><a href="OpenStreetMapCatalogItem.html">OpenStreetMapCatalogItem</a></li><li><a href="PlacesLikeMeCatalogfunction.html">PlacesLikeMeCatalogfunction</a></li><li><a href="PointParameter.html">PointParameter</a></li><li><a href="Polling.html">Polling</a></li><li><a href="PolygonParameter.html">PolygonParameter</a></li><li><a href="RectangleParameter.html">RectangleParameter</a></li><li><a href="RegionDataParameter.html">RegionDataParameter</a></li><li><a href="RegionMapping.html">RegionMapping</a></li><li><a href="RegionParameter.html">RegionParameter</a></li><li><a href="RegionProvider.html">RegionProvider</a></li><li><a href="RegionProviderList.html">RegionProviderList</a></li><li><a href="RegionTypeParameter.html">RegionTypeParameter</a></li><li><a href="ResultPendingCatalogItem.html">ResultPendingCatalogItem</a></li><li><a href="SdmxJsonCatalogItem.html">SdmxJsonCatalogItem</a></li><li><a href="SensorObservationServiceCatalogItem.html">SensorObservationServiceCatalogItem</a></li><li><a href="SocrataCatalogGroup.html">SocrataCatalogGroup</a></li><li><a href="SpatialDetailingCatalogFunction.html">SpatialDetailingCatalogFunction</a></li><li><a href="StringParameter.html">StringParameter</a></li><li><a href="SummaryConcept.html">SummaryConcept</a></li><li><a href="TableCatalogItem.html">TableCatalogItem</a></li><li><a href="TableColumn.html">TableColumn</a></li><li><a href="TableColumnStyle.html">TableColumnStyle</a></li><li><a href="TableDataSource.html">TableDataSource</a></li><li><a href="TableStructure.html">TableStructure</a></li><li><a href="TableStyle.html">TableStyle</a></li><li><a href="TerrainCatalogItem.html">TerrainCatalogItem</a></li><li><a href="Terria.html">Terria</a></li><li><a href="TerriaError.html">TerriaError</a></li><li><a href="TerriaJsonCatalogFunction.html">TerriaJsonCatalogFunction</a></li><li><a href="TimeSeriesStack.html">TimeSeriesStack</a></li><li><a href="UrlTemplateCatalogItem.html">UrlTemplateCatalogItem</a></li><li><a href="UrthecastCatalogGroup.html">UrthecastCatalogGroup</a></li><li><a href="UrthecastServerCatalogItem.html">UrthecastServerCatalogItem</a></li><li><a href="UserDrawing.html">UserDrawing</a></li><li><a href="VariableConcept.html">VariableConcept</a></li><li><a href="ViewerModes..html">ViewerModes.</a></li><li><a href="WebFeatureServiceCatalogGroup.html">WebFeatureServiceCatalogGroup</a></li><li><a href="WebFeatureServiceCatalogItem.html">WebFeatureServiceCatalogItem</a></li><li><a href="WebMapServiceCatalogGroup.html">WebMapServiceCatalogGroup</a></li><li><a href="WebMapServiceCatalogItem.html">WebMapServiceCatalogItem</a></li><li><a href="WebMapTileServiceCatalogGroup.html">WebMapTileServiceCatalogGroup</a></li><li><a href="WebMapTileServiceCatalogItem.html">WebMapTileServiceCatalogItem</a></li><li><a href="WebProcessingServiceCatalogFunction.html">WebProcessingServiceCatalogFunction</a></li><li><a href="WebProcessingServiceCatalogGroup.html">WebProcessingServiceCatalogGroup</a></li><li><a href="WebProcessingServiceCatalogItem.html">WebProcessingServiceCatalogItem</a></li><li><a href="WfsFeaturesCatalogGroup.html">WfsFeaturesCatalogGroup</a></li><li><a href="WhyAmISpecialCatalogFunction.html">WhyAmISpecialCatalogFunction</a></li></ul><h3>Global</h3><ul><li><a href="global.html#_bumpyTerrainProvider">_bumpyTerrainProvider</a></li><li><a href="global.html#_terrain">_terrain</a></li><li><a href="global.html#activeTimeColumnNameIdOrIndex">activeTimeColumnNameIdOrIndex</a></li><li><a href="global.html#addBoundingBox">addBoundingBox</a></li><li><a href="global.html#addMarker">addMarker</a></li><li><a href="global.html#addUserCatalogMember">addUserCatalogMember</a></li><li><a href="global.html#allFeaturesAvailablePromise">allFeaturesAvailablePromise</a></li><li><a href="global.html#allShareKeys">allShareKeys</a></li><li><a href="global.html#arrayProduct">arrayProduct</a></li><li><a href="global.html#barHeightMax">barHeightMax</a></li><li><a href="global.html#barHeightMin">barHeightMin</a></li><li><a href="global.html#barLeft">barLeft</a></li><li><a href="global.html#barTop">barTop</a></li><li><a href="global.html#buildEmptyAccumulator">buildEmptyAccumulator</a></li><li><a href="global.html#buildRequestData">buildRequestData</a></li><li><a href="global.html#buildShareLink">buildShareLink</a></li><li><a href="global.html#buildShortShareLink">buildShortShareLink</a></li><li><a href="global.html#calculateFinishDatesFromStartDates">calculateFinishDatesFromStartDates</a></li><li><a href="global.html#canShorten">canShorten</a></li><li><a href="global.html#categoryName">categoryName</a></li><li><a href="global.html#ChartData">ChartData</a></li><li><a href="global.html#color">color</a></li><li><a href="global.html#ColorMap">ColorMap</a></li><li><a href="global.html#combineData">combineData</a></li><li><a href="global.html#combineFilters">combineFilters</a></li><li><a href="global.html#combineRepeated">combineRepeated</a></li><li><a href="global.html#combineValueArrays">combineValueArrays</a></li><li><a href="global.html#computeRingWindingOrder">computeRingWindingOrder</a></li><li><a href="global.html#computeScreenSpacePosition">computeScreenSpacePosition</a></li><li><a href="global.html#config">config</a></li><li><a href="global.html#containsAny">containsAny</a></li><li><a href="global.html#convertLuceneHit">convertLuceneHit</a></li><li><a href="global.html#convertToDates">convertToDates</a></li><li><a href="global.html#correctEntityHeight">correctEntityHeight</a></li><li><a href="global.html#createCatalogItemFromFileOrUrl">createCatalogItemFromFileOrUrl</a></li><li><a href="global.html#createCatalogItemFromUrl">createCatalogItemFromUrl</a></li><li><a href="global.html#createCatalogMemberFromType">createCatalogMemberFromType</a></li><li><a href="global.html#createLeafletCredit">createLeafletCredit</a></li><li><a href="global.html#createParameterFromType">createParameterFromType</a></li><li><a href="global.html#createRegexDeserializer">createRegexDeserializer</a></li><li><a href="global.html#createRegexSerializer">createRegexSerializer</a></li><li><a href="global.html#cssClass">cssClass</a></li><li><a href="global.html#CustomComponents">CustomComponents</a></li><li><a href="global.html#deIndexWithDescendants">deIndexWithDescendants</a></li><li><a href="global.html#Description">Description</a></li><li><a href="global.html#direction">direction</a></li><li><a href="global.html#disposeSubscription">disposeSubscription</a></li><li><a href="global.html#EarthGravityModel1996">EarthGravityModel1996</a></li><li><a href="global.html#error">error</a></li><li><a href="global.html#extendLoad">extendLoad</a></li><li><a href="global.html#extent">extent</a></li><li><a href="global.html#featureClicked">featureClicked</a></li><li><a href="global.html#featureDataToGeoJson">featureDataToGeoJson</a></li><li><a href="global.html#featureMousedown">featureMousedown</a></li><li><a href="global.html#features">features</a></li><li><a href="global.html#findKeyForGroupElement">findKeyForGroupElement</a></li><li><a href="global.html#flattenCatalog">flattenCatalog</a></li><li><a href="global.html#formatDate">formatDate</a></li><li><a href="global.html#formatDateTime">formatDateTime</a></li><li><a href="global.html#formatNumberForLocale">formatNumberForLocale</a></li><li><a href="global.html#formatPropertyValue">formatPropertyValue</a></li><li><a href="global.html#formatTime">formatTime</a></li><li><a href="global.html#getAncestors">getAncestors</a></li><li><a href="global.html#getColumnOptions">getColumnOptions</a></li><li><a href="global.html#getColumnWithNameIdOrIndex">getColumnWithNameIdOrIndex</a></li><li><a href="global.html#getDataUriFormat">getDataUriFormat</a></li><li><a href="global.html#getGroupChildren">getGroupChildren</a></li><li><a href="global.html#getShareData">getShareData</a></li><li><a href="global.html#getTemporalFiltersContext">getTemporalFiltersContext</a></li><li><a href="global.html#getUniqueValues">getUniqueValues</a></li><li><a href="global.html#gmlToGeoJson">gmlToGeoJson</a></li><li><a href="global.html#gradientColorMap">gradientColorMap</a></li><li><a href="global.html#hasAddress">hasAddress</a></li><li><a href="global.html#hasChildren">hasChildren</a></li><li><a href="global.html#hasLatitudeAndLongitude">hasLatitudeAndLongitude</a></li><li><a href="global.html#hostInDomains">hostInDomains</a></li><li><a href="global.html#id">id</a></li><li><a href="global.html#infoWithoutSources">infoWithoutSources</a></li><li><a href="global.html#isBrowserCompatible">isBrowserCompatible</a></li><li><a href="global.html#isCommonMobilePlatform">isCommonMobilePlatform</a></li><li><a href="global.html#isLoading">isLoading</a></li><li><a href="global.html#isVisible">isVisible</a></li><li><a href="global.html#itemHeight">itemHeight</a></li><li><a href="global.html#itemHeightMin">itemHeightMin</a></li><li><a href="global.html#items">items</a></li><li><a href="global.html#itemSpacing">itemSpacing</a></li><li><a href="global.html#itemWidth">itemWidth</a></li><li><a href="global.html#Legend">Legend</a></li><li><a href="global.html#legendUrl">legendUrl</a></li><li><a href="global.html#map">map</a></li><li><a href="global.html#markdownToHtml">markdownToHtml</a></li><li><a href="global.html#markerVisible">markerVisible</a></li><li><a href="global.html#name">name</a></li><li><a href="global.html#NowViewing">NowViewing</a></li><li><a href="global.html#overrideProperty">overrideProperty</a></li><li><a href="global.html#pad">pad</a></li><li><a href="global.html#parseCustomHtmlToReact">parseCustomHtmlToReact</a></li><li><a href="global.html#parseCustomMarkdownToReact">parseCustomMarkdownToReact</a></li><li><a href="global.html#PickedFeatures">PickedFeatures</a></li><li><a href="global.html#pickPosition">pickPosition</a></li><li><a href="global.html#point">point</a></li><li><a href="global.html#points">points</a></li><li><a href="global.html#position">position</a></li><li><a href="global.html#prettifyCoordinates">prettifyCoordinates</a></li><li><a href="global.html#prettifyProjection">prettifyProjection</a></li><li><a href="global.html#printWindow">printWindow</a></li><li><a href="global.html#processAddress">processAddress</a></li><li><a href="global.html#Proj4Definitions">Proj4Definitions</a></li><li><a href="global.html#propertyGetTimeValues">propertyGetTimeValues</a></li><li><a href="global.html#readJson">readJson</a></li><li><a href="global.html#rectangle">rectangle</a></li><li><a href="global.html#rectangleToLatLngBounds">rectangleToLatLngBounds</a></li><li><a href="global.html#RegionDataValue">RegionDataValue</a></li><li><a href="global.html#regionDetails">regionDetails</a></li><li><a href="global.html#registerCustomComponentTypes">registerCustomComponentTypes</a></li><li><a href="global.html#rememberRejections">rememberRejections</a></li><li><a href="global.html#removeMarker">removeMarker</a></li><li><a href="global.html#replaceUnderscores">replaceUnderscores</a></li><li><a href="global.html#sanitiseAddressNumber">sanitiseAddressNumber</a></li><li><a href="global.html#selectBaseMap">selectBaseMap</a></li><li><a href="global.html#serializeToJson">serializeToJson</a></li><li><a href="global.html#ServerConfig">ServerConfig</a></li><li><a href="global.html#setClockCurrentTime">setClockCurrentTime</a></li><li><a href="global.html#shareKeyIndex">shareKeyIndex</a></li><li><a href="global.html#shouldBeUpdated">shouldBeUpdated</a></li><li><a href="global.html#showSelection">showSelection</a></li><li><a href="global.html#sortByFirst">sortByFirst</a></li><li><a href="global.html#sortedIndices">sortedIndices</a></li><li><a href="global.html#splitIntoBatches">splitIntoBatches</a></li><li><a href="global.html#supportsIntervals">supportsIntervals</a></li><li><a href="global.html#supportsWebGL">supportsWebGL</a></li><li><a href="global.html#TerriaViewer">TerriaViewer</a></li><li><a href="global.html#Title">Title</a></li><li><a href="global.html#toArrayOfRows">toArrayOfRows</a></li><li><a href="global.html#Tooltip">Tooltip</a></li><li><a href="global.html#triggerResize">triggerResize</a></li><li><a href="global.html#unionRectangleArray">unionRectangleArray</a></li><li><a href="global.html#unionRectangles">unionRectangles</a></li><li><a href="global.html#units">units</a></li><li><a href="global.html#up">up</a></li><li><a href="global.html#updateApplicationOnHashChange">updateApplicationOnHashChange</a></li><li><a href="global.html#updateFromJson">updateFromJson</a></li><li><a href="global.html#updateRectangleFromRegion">updateRectangleFromRegion</a></li><li><a href="global.html#variableNameLeft">variableNameLeft</a></li><li><a href="global.html#variableNameTop">variableNameTop</a></li><li><a href="global.html#ViewerMode">ViewerMode</a></li><li><a href="global.html#width">width</a></li><li><a href="global.html#yAxisMax">yAxisMax</a></li><li><a href="global.html#yAxisMin">yAxisMin</a></li></ul>
</nav>
<br class="clear">
<footer>
Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 3.5.5</a> on Fri Sep 21 2018 12:26:19 GMT+1000 (AUS Eastern Standard Time)
</footer>
<script> prettyPrint(); </script>
<script src="scripts/linenumber.js"> </script>
</body>
</html>