-
Notifications
You must be signed in to change notification settings - Fork 1
/
main.ts
executable file
·107 lines (89 loc) · 2.75 KB
/
main.ts
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
import {app, BrowserWindow, screen} from 'electron';
import {dbCalls} from './datastore/nedb_service';
import * as fs from 'fs';
import {test1} from './pdf-generator';
const ipc = require('electron').ipcMain;
let win, serve;
const args = process.argv.slice(1);
serve = args.some(val => val === '--serve');
if (serve) {
require('electron-reload')(__dirname, {});
}
function createWindow() {
const electronScreen = screen;
const size = electronScreen.getPrimaryDisplay().workAreaSize;
// Create the browser window.
win = new BrowserWindow({
x: 0,
y: 0,
width: size.width,
height: size.height
});
// and load the index.html of the app.
win.loadURL('file:https://' + __dirname + '/index.html');
// Open the DevTools.
if (serve) {
win.webContents.openDevTools();
}
// Emitted when the window is closed.
win.on('closed', () => {
// Dereference the window object, usually you would store window
// in an array if your app supports multi windows, this is the time
// when you should delete the corresponding element.
win = null;
});
}
try {
// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
// Some APIs can only be used after this event occurs.
app.on('ready', createWindow);
// Quit when all windows are closed.
app.on('window-all-closed', () => {
// On OS X it is common for applications and their menu bar
// to stay active until the user quits explicitly with Cmd + Q
if (process.platform !== 'darwin') {
app.quit();
}
});
app.on('activate', () => {
// On OS X it's common to re-create a window in the app when the
// dock icon is clicked and there are no other windows open.
if (win === null) {
createWindow();
}
});
} catch (e) {
// Catch Error
// throw e;
}
const log = (msg: string) => {
const logName = 'log/log.log';
const logSize = 634880;
const x = new Date();
fs.appendFile(logName, x.toLocaleDateString() + ':' + x.toTimeString().substring(0, 9) + ' - ' + msg + '\n', err => {
if (!err) {
fs.stat(logName, (err2, stat) => {
if (stat.size > logSize) {
fs.rename(logName, 'log/' + new Date() + ' - old.log');
}
});
}
});
};
ipc.on('db_calls', (event, arg) => {
log('[main] db_calls ' + JSON.stringify(arg));
dbCalls(arg, function (err, data) {
event.sender.send('db_returns', {err: err, doc: data, unq: arg['unq']});
if (err) {
log('[main] db_calls - returns ' + JSON.stringify({err: err}));
}
log('[main] db_calls - returns ' + JSON.stringify({data: data}).substring(0, 100));
});
});
ipc.on('log_calls', (event, arg) => {
log('[renderer] ' + arg['msg']);
});
ipc.on('pdf_calls', (event, arg) => {
test1(arg);
});