2019-01-07 05:53:44 -06:00
|
|
|
import { ipcRenderer } from 'electron';
|
2018-10-29 13:52:58 -05:00
|
|
|
import * as React from 'react';
|
|
|
|
import * as ReactDOM from 'react-dom';
|
2018-11-16 02:38:38 -06:00
|
|
|
|
2019-01-07 05:53:44 -06:00
|
|
|
import { i18n } from '../common/i18n-preload';
|
2018-12-19 00:16:03 -06:00
|
|
|
import AboutBox from './components/about-app';
|
2019-01-07 05:53:44 -06:00
|
|
|
import BasicAuth from './components/basic-auth';
|
2019-03-19 05:52:39 -05:00
|
|
|
import NotificationComp from './components/notification-comp';
|
2019-03-25 03:23:10 -05:00
|
|
|
import NotificationSettings from './components/notification-settings';
|
2018-12-19 00:16:03 -06:00
|
|
|
import ScreenPicker from './components/screen-picker';
|
2019-11-12 03:40:15 -06:00
|
|
|
import ScreenSharingFrame from './components/screen-sharing-frame';
|
2019-01-02 04:19:50 -06:00
|
|
|
import ScreenSharingIndicator from './components/screen-sharing-indicator';
|
2020-11-06 00:43:29 -06:00
|
|
|
import SnippingTool from './components/snipping-tool';
|
2020-04-27 04:35:25 -05:00
|
|
|
import Welcome from './components/welcome';
|
2019-01-02 04:19:50 -06:00
|
|
|
|
|
|
|
const enum components {
|
|
|
|
aboutApp = 'about-app',
|
|
|
|
screenPicker = 'screen-picker',
|
|
|
|
screenSharingIndicator = 'screen-sharing-indicator',
|
2019-11-12 03:40:15 -06:00
|
|
|
screenSharingFrame = 'screen-sharing-frame',
|
2019-01-07 05:53:44 -06:00
|
|
|
basicAuth = 'basic-auth',
|
2019-03-19 05:52:39 -05:00
|
|
|
notification = 'notification-comp',
|
2019-03-25 03:23:10 -05:00
|
|
|
notificationSettings = 'notification-settings',
|
2020-04-27 04:35:25 -05:00
|
|
|
welcome = 'welcome',
|
2020-11-06 00:43:29 -06:00
|
|
|
snippingTool = 'snipping-tool',
|
2019-01-02 04:19:50 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
const loadStyle = (style) => {
|
|
|
|
const styles = document.createElement('link');
|
|
|
|
styles.rel = 'stylesheet';
|
|
|
|
styles.type = 'text/css';
|
|
|
|
styles.href = `./styles/${style}.css`;
|
|
|
|
document.getElementsByTagName('head')[0].appendChild(styles);
|
|
|
|
};
|
2018-10-29 13:52:58 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads the appropriate component
|
|
|
|
*/
|
2018-12-04 00:46:38 -06:00
|
|
|
const load = () => {
|
2018-10-29 13:52:58 -05:00
|
|
|
const query = new URL(window.location.href).searchParams;
|
2018-11-16 02:38:38 -06:00
|
|
|
const componentName = query.get('componentName');
|
2018-10-29 13:52:58 -05:00
|
|
|
|
|
|
|
let component;
|
|
|
|
switch (componentName) {
|
2019-01-02 04:19:50 -06:00
|
|
|
case components.aboutApp:
|
|
|
|
loadStyle(components.aboutApp);
|
2018-10-29 13:52:58 -05:00
|
|
|
component = AboutBox;
|
2019-09-04 07:28:43 -05:00
|
|
|
document.title = i18n.t('About Symphony', 'AboutSymphony')();
|
2018-12-03 11:46:47 -06:00
|
|
|
break;
|
2019-01-02 04:19:50 -06:00
|
|
|
case components.screenPicker:
|
|
|
|
loadStyle(components.screenPicker);
|
2020-11-06 00:43:29 -06:00
|
|
|
document.title = i18n.t('Screen Picker - Symphony')();
|
2018-12-19 00:16:03 -06:00
|
|
|
component = ScreenPicker;
|
|
|
|
break;
|
2019-01-02 04:19:50 -06:00
|
|
|
case components.screenSharingIndicator:
|
|
|
|
loadStyle(components.screenSharingIndicator);
|
2020-11-06 00:43:29 -06:00
|
|
|
document.title = i18n.t('Screen Sharing Indicator - Symphony')();
|
2019-01-02 04:19:50 -06:00
|
|
|
component = ScreenSharingIndicator;
|
|
|
|
break;
|
2019-11-12 03:40:15 -06:00
|
|
|
case components.screenSharingFrame:
|
|
|
|
loadStyle(components.screenSharingFrame);
|
|
|
|
component = ScreenSharingFrame;
|
|
|
|
break;
|
2020-11-06 00:43:29 -06:00
|
|
|
case components.snippingTool:
|
|
|
|
loadStyle(components.snippingTool);
|
|
|
|
document.title = i18n.t('Symphony')();
|
|
|
|
component = SnippingTool;
|
|
|
|
break;
|
2019-01-07 05:53:44 -06:00
|
|
|
case components.basicAuth:
|
|
|
|
loadStyle(components.basicAuth);
|
2020-11-06 00:43:29 -06:00
|
|
|
document.title = i18n.t('Basic Authentication - Symphony')();
|
2019-01-07 05:53:44 -06:00
|
|
|
component = BasicAuth;
|
|
|
|
break;
|
2019-03-19 05:52:39 -05:00
|
|
|
case components.notification:
|
|
|
|
loadStyle(components.notification);
|
2020-11-06 00:43:29 -06:00
|
|
|
document.title = i18n.t('Notification - Symphony')();
|
2019-03-19 05:52:39 -05:00
|
|
|
component = NotificationComp;
|
|
|
|
break;
|
2019-03-25 03:23:10 -05:00
|
|
|
case components.notificationSettings:
|
2019-11-20 04:49:15 -06:00
|
|
|
document.title = i18n.t('Notification Settings - Symphony', 'NotificationSettings')();
|
2019-03-25 03:23:10 -05:00
|
|
|
loadStyle(components.notificationSettings);
|
|
|
|
component = NotificationSettings;
|
|
|
|
break;
|
2020-04-27 04:35:25 -05:00
|
|
|
case components.welcome:
|
|
|
|
document.title = i18n.t('WelcomeText', 'Welcome')();
|
|
|
|
loadStyle(components.welcome);
|
|
|
|
component = Welcome;
|
|
|
|
break;
|
2018-10-29 13:52:58 -05:00
|
|
|
}
|
2018-11-15 03:15:37 -06:00
|
|
|
const element = React.createElement(component);
|
|
|
|
ReactDOM.render(element, document.getElementById('Root'));
|
2018-12-04 00:46:38 -06:00
|
|
|
};
|
|
|
|
|
2019-05-22 02:01:54 -05:00
|
|
|
ipcRenderer.on('page-load', (_event, data) => {
|
2019-01-07 05:53:44 -06:00
|
|
|
const { locale, resource } = data;
|
|
|
|
i18n.setResource(locale, resource);
|
2019-05-22 02:01:54 -05:00
|
|
|
// Renders component as soon as the page is ready
|
|
|
|
load();
|
2019-03-19 05:52:39 -05:00
|
|
|
});
|