-
Notifications
You must be signed in to change notification settings - Fork 263
/
index.js
157 lines (140 loc) · 6.33 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
"use strict";
var terriaOptions = {
baseUrl: "build/TerriaJS"
};
import { runInAction } from "mobx";
import ConsoleAnalytics from "terriajs/lib/Core/ConsoleAnalytics";
import GoogleAnalytics from "terriajs/lib/Core/GoogleAnalytics";
import ShareDataService from "terriajs/lib/Models/ShareDataService";
// import registerAnalytics from 'terriajs/lib/Models/registerAnalytics';
import registerCustomComponentTypes from "terriajs/lib/ReactViews/Custom/registerCustomComponentTypes";
import Terria from "terriajs/lib/Models/Terria";
import updateApplicationOnHashChange from "terriajs/lib/ViewModels/updateApplicationOnHashChange";
import updateApplicationOnMessageFromParentWindow from "terriajs/lib/ViewModels/updateApplicationOnMessageFromParentWindow";
import ViewState from "terriajs/lib/ReactViewModels/ViewState";
import render from "./lib/Views/render";
import registerCatalogMembers from "terriajs/lib/Models/Catalog/registerCatalogMembers";
import registerSearchProviders from "terriajs/lib/Models/SearchProviders/registerSearchProviders";
import defined from "terriajs-cesium/Source/Core/defined";
import loadPlugins from "./lib/Core/loadPlugins";
import plugins from "./plugins";
// Register all types of catalog members in the core TerriaJS. If you only want to register a subset of them
// (i.e. to reduce the size of your application if you don't actually use them all), feel free to copy a subset of
// the code in the registerCatalogMembers function here instead.
// registerCatalogMembers();
// registerAnalytics();
// we check exact match for development to reduce chances that production flag isn't set on builds(?)
if (process.env.NODE_ENV === "development") {
terriaOptions.analytics = new ConsoleAnalytics();
} else {
terriaOptions.analytics = new GoogleAnalytics();
}
// Construct the TerriaJS application, arrange to show errors to the user, and start it up.
var terria = new Terria(terriaOptions);
// Register custom components in the core TerriaJS. If you only want to register a subset of them, or to add your own,
// insert your custom version of the code in the registerCustomComponentTypes function here instead.
registerCustomComponentTypes(terria);
// Create the ViewState before terria.start so that errors have somewhere to go.
const viewState = new ViewState({
terria: terria
});
registerCatalogMembers();
// Register custom search providers in the core TerriaJS. If you only want to register a subset of them, or to add your own,
// insert your custom version of the code in the registerSearchProviders function here instead.
registerSearchProviders();
if (process.env.NODE_ENV === "development") {
window.viewState = viewState;
}
// If we're running in dev mode, disable the built style sheet as we'll be using the webpack style loader.
// Note that if the first stylesheet stops being nationalmap.css then this will have to change.
if (process.env.NODE_ENV !== "production" && module.hot) {
document.styleSheets[0].disabled = true;
}
module.exports = terria
.start({
applicationUrl: window.location,
configUrl: "config.json",
shareDataService: new ShareDataService({
terria: terria
}),
beforeRestoreAppState: () => {
// Load plugins before restoring app state because app state may
// reference plugin components and catalog items.
return loadPlugins(viewState, plugins).catch((error) => {
console.error(`Error loading plugins`);
console.error(error);
});
}
})
.catch(function (e) {
terria.raiseErrorToUser(e);
})
.finally(function () {
// Override the default document title with appName. Check first for default
// title, because user might have already customized the title in
// index.ejs
if (document.title === "Terria Map") {
document.title = terria.appName;
}
terria.loadInitSources().then((result) => result.raiseError(terria));
try {
// Automatically update Terria (load new catalogs, etc.) when the hash part of the URL changes.
updateApplicationOnHashChange(terria, window);
updateApplicationOnMessageFromParentWindow(terria, window);
// Show a modal disclaimer before user can do anything else.
if (defined(terria.configParameters.globalDisclaimer)) {
var globalDisclaimer = terria.configParameters.globalDisclaimer;
var hostname = window.location.hostname;
if (
globalDisclaimer.enableOnLocalhost ||
hostname.indexOf("localhost") === -1
) {
var message = "";
// Sometimes we want to show a preamble if the user is viewing a site other than the official production instance.
// This can be expressed as a devHostRegex ("any site starting with staging.") or a negative prodHostRegex ("any site not ending in .gov.au")
if (
(defined(globalDisclaimer.devHostRegex) &&
hostname.match(globalDisclaimer.devHostRegex)) ||
(defined(globalDisclaimer.prodHostRegex) &&
!hostname.match(globalDisclaimer.prodHostRegex))
) {
message += require("./lib/Views/DevelopmentDisclaimerPreamble.html");
}
message += require("./lib/Views/GlobalDisclaimer.html");
var options = {
title:
globalDisclaimer.title !== undefined
? globalDisclaimer.title
: "Warning",
confirmText: globalDisclaimer.buttonTitle || "Ok",
denyText: globalDisclaimer.denyText || "Cancel",
denyAction: globalDisclaimer.afterDenyLocation
? function () {
window.location = globalDisclaimer.afterDenyLocation;
}
: undefined,
width: 600,
height: 550,
message: message,
horizontalPadding: 100
};
runInAction(() => {
viewState.disclaimerSettings = options;
viewState.disclaimerVisible = true;
});
}
}
// Add font-imports
const fontImports = terria.configParameters.theme?.fontImports;
if (fontImports) {
const styleSheet = document.createElement("style");
styleSheet.type = "text/css";
styleSheet.innerText = fontImports;
document.head.appendChild(styleSheet);
}
render(terria, [], viewState);
} catch (e) {
console.error(e);
console.error(e.stack);
}
});