-
Notifications
You must be signed in to change notification settings - Fork 3
/
electron.js
112 lines (93 loc) · 4.15 KB
/
electron.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
/* jshint node: true */
'use strict';
const electron = require('electron');
const path = require('path');
const app = electron.app;
const BrowserWindow = electron.BrowserWindow;
const dirname = __dirname || path.resolve(path.dirname());
const emberAppLocation = `file://${dirname}/dist/index.html`;
const menubar = require('menubar');
let mainWindow = null;
// Uncomment the lines below to enable Electron's crash reporter
// For more information, see http://electron.atom.io/docs/api/crash-reporter/
// electron.crashReporter.start({
// productName: 'YourName',
// companyName: 'YourCompany',
// submitURL: 'https://your-domain.com/url-to-submit',
// autoSubmit: true
// });
const mb = menubar({
index: emberAppLocation,
height: 450,
preloadWindow: true,
transparent: false,
tooltip: 'Epocha',
resizable: false,
});
app.on('window-all-closed', function onWindowAllClosed() {
app.quit();
});
mb.on('ready', function onReady() {
// If you want to open up dev tools programmatically, call
// mb.window.openDevTools()
// By default, we'll open the Ember App by directly going to the
// file system.
//
// Please ensure that you have set the locationType option in the
// config/environment.js file to 'hash'. For more information,
// please consult the ember-electron readme.
});
// app.on('ready', function onReady() {
// mainWindow = new BrowserWindow({
// width: 800,
// height: 600
// });
// delete mainWindow.module;
// // If you want to open up dev tools programmatically, call
// // mainWindow.openDevTools();
// // By default, we'll open the Ember App by directly going to the
// // file system.
// //
// // Please ensure that you have set the locationType option in the
// // config/environment.js file to 'hash'. For more information,
// // please consult the ember-electron readme.
// mainWindow.loadURL(emberAppLocation);
// // If a loading operation goes wrong, we'll send Electron back to
// // Ember App entry point
// mainWindow.webContents.on('did-fail-load', () => {
// mainWindow.loadURL(emberAppLocation);
// });
// mainWindow.webContents.on('crashed', () => {
// console.log('Your Ember app (or other code) in the main window has crashed.');
// console.log('This is a serious issue that needs to be handled and/or debugged.');
// });
// mainWindow.on('unresponsive', () => {
// console.log('Your Ember app (or other code) has made the window unresponsive.');
// });
// mainWindow.on('responsive', () => {
// console.log('The main window has become responsive again.');
// });
// mainWindow.on('closed', () => {
// mainWindow = null;
// });
// // Handle an unhandled error in the main thread
// //
// // Note that 'uncaughtException' is a crude mechanism for exception handling intended to
// // be used only as a last resort. The event should not be used as an equivalent to
// // "On Error Resume Next". Unhandled exceptions inherently mean that an application is in
// // an undefined state. Attempting to resume application code without properly recovering
// // from the exception can cause additional unforeseen and unpredictable issues.
// //
// // Attempting to resume normally after an uncaught exception can be similar to pulling out
// // of the power cord when upgrading a computer -- nine out of ten times nothing happens -
// // but the 10th time, the system becomes corrupted.
// //
// // The correct use of 'uncaughtException' is to perform synchronous cleanup of allocated
// // resources (e.g. file descriptors, handles, etc) before shutting down the process. It is
// // not safe to resume normal operation after 'uncaughtException'.
// process.on('uncaughtException', (err) => {
// console.log('An exception in the main thread was not handled.');
// console.log('This is a serious issue that needs to be handled and/or debugged.');
// console.log(`Exception: ${err}`);
// });
// });