-
Notifications
You must be signed in to change notification settings - Fork 4k
/
Onboarding.jsx
47 lines (43 loc) · 1.42 KB
/
Onboarding.jsx
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
import { h, render } from 'preact';
import { getUserDataAndCsrfToken } from '../chat/util';
import { getUnopenedChannels } from '../utilities/connect';
HTMLDocument.prototype.ready = new Promise((resolve) => {
if (document.readyState !== 'loading') {
return resolve();
}
document.addEventListener('DOMContentLoaded', () => resolve());
return null;
});
function renderPage() {
const dataElement = document.getElementById('onboarding-container');
const communityConfig = {
communityName: dataElement.dataset.communityName,
communityLogo: dataElement.dataset.communityLogo,
communityBackground: dataElement.dataset.communityBackground,
communityDescription: dataElement.dataset.communityDescription,
};
import('../onboarding/Onboarding')
.then(({ Onboarding }) => {
render(
<Onboarding communityConfig={communityConfig} />,
document.getElementById('onboarding-container'),
);
})
.catch((error) => {
// eslint-disable-next-line no-console
console.error('Unable to load onboarding', error);
});
}
document.ready.then(
getUserDataAndCsrfToken()
.then(({ currentUser, csrfToken }) => {
window.currentUser = currentUser;
window.csrfToken = csrfToken;
getUnopenedChannels();
renderPage();
})
.catch((error) => {
// eslint-disable-next-line no-console
console.error('Error getting user and CSRF Token', error);
}),
);