-
Notifications
You must be signed in to change notification settings - Fork 11
/
ports.js
149 lines (124 loc) · 4.83 KB
/
ports.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
"use strict";
// get a reference to the div where we will show our UI
let container = document.getElementById("container");
var storedState = localStorage.getItem("exosphere-save");
var startingState = storedState ? JSON.parse(storedState) : null;
// Determine if running in Electron, per https://github.com/electron/electron/issues/2288#issuecomment-337858978
var userAgent = navigator.userAgent.toLowerCase();
var isElectron = userAgent.indexOf(" electron/") > -1;
// Get a high-quality random seed to make a client UUID. We use 4 32-bit integers
// https://package.elm-lang.org/packages/TSFoster/elm-uuid/latest/UUID#generator
var typedArray = new Int32Array(4);
var randomSeeds = crypto.getRandomValues(typedArray);
// Used on logout to ensure we don't save preferences
// during the logout sequence. On logout this gets set
// to disable updates, but then logout reloads the page
// which "re-enables" persistence by means of
// re-initializing the page.
let disablePersistence = false;
// We need this to get the UTC offset?
var d = new Date();
var electronDeprecationNotice = `
<html>
<body>
<p>This Electron-based desktop application has been deprecated.</p>
<p>Please start using Exosphere in your browser at https://try.exosphere.app. If you are a Jetstream2 user, please use https://jetstream2.exosphere.app.</p>
<p>Both of these sites support installation to your desktop or home screen; see https://gitlab.com/exosphere/exosphere/-/blob/master/docs/pwa-install.md for more information.</p>
</body>
</html>
`;
if (isElectron) {
document.write(electronDeprecationNotice);
} else {
var moduleToInit = Elm.Exosphere.init;
}
const themeDetector =
"undefined" !== typeof window.matchMedia
? window.matchMedia("(prefers-color-scheme: dark)")
: null;
const themePreference = (detector) => {
if (!detector) {
return null;
}
return detector.matches ? "dark" : "light";
};
var flags = {
// Flags that Exosphere sets dynamically, not intended to be modified by deployer
localeGuessingString: new Intl.NumberFormat(navigator.language).format(
Math.PI * -1000000
),
width: window.innerWidth,
height: window.innerHeight,
storedState: startingState,
randomSeed0: randomSeeds[0],
randomSeed1: randomSeeds[1],
randomSeed2: randomSeeds[2],
randomSeed3: randomSeeds[3],
epoch: Date.now(),
themePreference: themePreference(themeDetector),
timeZone: d.getTimezoneOffset(),
};
const merged_config = Object.assign({}, cloud_configs, config);
// start the elm app in the container
// and keep a reference for communicating with the app
var app = moduleToInit({
node: container,
flags: JSON.stringify(Object.assign(flags, merged_config)),
});
app.ports.logout.subscribe(() => {
disablePersistence = true;
localStorage.clear();
window.location.reload();
});
app.ports.openNewWindow.subscribe(function (url) {
window.open(url);
});
app.ports.setStorage.subscribe(function (state) {
if (disablePersistence) {
return;
}
localStorage.setItem("exosphere-save", JSON.stringify(state));
});
app.ports.instantiateClipboardJs.subscribe(function () {
var clipboard = new ClipboardJS(".copy-button");
});
app.ports.setFavicon.subscribe(function (url) {
// From https://stackoverflow.com/questions/260857/changing-website-favicon-dynamically
var link = document.querySelector("link[rel~='icon']");
if (!link) {
link = document.createElement("link");
link.rel = "icon";
document.getElementsByTagName("head")[0].appendChild(link);
}
link.href = url;
});
// Note that this only does anything if an Exosphere environment is deployed with Matomo analytics. By default, it has no effect.
app.ports.pushUrlAndTitleToMatomo.subscribe(function (args) {
if (typeof _paq !== "undefined") {
// From https://developer.matomo.org/guides/spa-tracking
var currentUrl = args.newUrl;
_paq.push(["setReferrerUrl", currentUrl]);
_paq.push(["setCustomUrl", currentUrl]);
_paq.push(["setDocumentTitle", args.pageTitle]);
// remove all previously assigned custom variables, requires Matomo (formerly Piwik) 3.0.2
_paq.push(["deleteCustomVariables", "page"]);
_paq.push(["trackPageView"]);
// make Matomo aware of newly added content
var content = document.getElementById("content");
_paq.push(["MediaAnalytics::scanForMedia", content]);
_paq.push(["FormAnalytics::scanForForms", content]);
_paq.push(["trackContentImpressionsWithinNode", content]);
}
});
// Notify app of OS color scheme changes, if we can
themeDetector &&
themeDetector.addEventListener("change", (detector) =>
app.ports.changeThemePreference.send(themePreference(detector))
);
// Fired when the browser has lost access to the network.
window.addEventListener("offline", (event) => {
app.ports.updateNetworkConnectivity.send(false);
});
window.addEventListener("online", (event) => {
app.ports.updateNetworkConnectivity.send(true);
});