Refactoring
This commit is contained in:
@@ -11,17 +11,17 @@ import Window from './Window'
|
||||
const isDevelopment = process.env.NODE_ENV !== 'production'
|
||||
|
||||
export default class Application {
|
||||
private static _instance: Application;
|
||||
private static _instance: Application
|
||||
|
||||
public static get shared() {
|
||||
// Do you need arguments? Make it a regular static method instead.
|
||||
return this._instance || (this._instance = new this());
|
||||
return this._instance || (this._instance = new this())
|
||||
}
|
||||
|
||||
private constructor() {
|
||||
app.on('window-all-closed', () => this.onWindowAllClosed())
|
||||
app.on('ready', () => this.onReady());
|
||||
app.on('activate', () => this.onActivated());
|
||||
app.on('ready', () => this.onReady())
|
||||
app.on('activate', () => this.onActivated())
|
||||
}
|
||||
|
||||
public setApplicationMenu(menu: Menu) {
|
||||
|
||||
@@ -3,10 +3,10 @@ import {
|
||||
shell,
|
||||
Menu,
|
||||
MenuItemConstructorOptions
|
||||
} from 'electron';
|
||||
import Window from "./Window";
|
||||
import { bugs } from '../../package.json';
|
||||
import { documentURL } from '../../info.json';
|
||||
} from 'electron'
|
||||
import Window from './Window'
|
||||
import { bugs } from '../../package.json'
|
||||
import { documentURL } from '../../info.json'
|
||||
|
||||
const isMac = process.platform === 'darwin'
|
||||
|
||||
@@ -19,7 +19,7 @@ export default class ApplicationMenu {
|
||||
{ role: 'hide' },
|
||||
{ role: 'hideOthers' },
|
||||
{ role: 'unhide' },
|
||||
];
|
||||
]
|
||||
private static macOnlyEditMenu: MenuItemConstructorOptions[] = [
|
||||
{ type: 'separator' },
|
||||
{
|
||||
@@ -29,38 +29,38 @@ export default class ApplicationMenu {
|
||||
{ role: 'stopspeaking' },
|
||||
]
|
||||
}
|
||||
];
|
||||
]
|
||||
private static aboutMenuItem: MenuItemConstructorOptions = {
|
||||
label: process.platform !== 'darwin' ? 'About' : `About ${app.getName()}`,
|
||||
label: !isMac ? 'About' : `About ${app.getName()}`,
|
||||
click: () => Window.About(),
|
||||
}
|
||||
|
||||
public static get menuConstruct(): MenuItemConstructorOptions[] {
|
||||
return [
|
||||
this.AppMenu(isMac),
|
||||
this.EditMenu(isMac),
|
||||
this.AppMenu(),
|
||||
this.EditMenu(),
|
||||
this.ViewMenu(),
|
||||
this.WindowMenu(isMac),
|
||||
this.WindowMenu(),
|
||||
this.HelpMenu(),
|
||||
]
|
||||
}
|
||||
|
||||
public static buildTemplate(): Menu {
|
||||
return Menu.buildFromTemplate(this.menuConstruct);
|
||||
return Menu.buildFromTemplate(this.menuConstruct)
|
||||
}
|
||||
private static AppMenu(isMac: boolean): MenuItemConstructorOptions {
|
||||
private static AppMenu(): MenuItemConstructorOptions {
|
||||
let appMenu: MenuItemConstructorOptions[] = [
|
||||
this.aboutMenuItem,
|
||||
...(isMac ? this.macOnlyAppMenu : []),
|
||||
{ type: 'separator' },
|
||||
{ role: 'quit' },
|
||||
];
|
||||
]
|
||||
return {
|
||||
label: app.getName(),
|
||||
submenu: appMenu,
|
||||
};
|
||||
}
|
||||
}
|
||||
private static EditMenu(isMac: boolean): MenuItemConstructorOptions {
|
||||
private static EditMenu(): MenuItemConstructorOptions {
|
||||
let editMenu: MenuItemConstructorOptions[] = [
|
||||
{ role: 'undo' },
|
||||
{ role: 'redo' },
|
||||
@@ -72,11 +72,11 @@ export default class ApplicationMenu {
|
||||
{ role: 'delete' },
|
||||
{ role: 'selectall' },
|
||||
...(isMac ? this.macOnlyEditMenu : []),
|
||||
];
|
||||
]
|
||||
return {
|
||||
label: 'Edit',
|
||||
submenu: editMenu,
|
||||
};
|
||||
}
|
||||
}
|
||||
private static ViewMenu(): MenuItemConstructorOptions {
|
||||
let viewMenu: MenuItemConstructorOptions[] = [
|
||||
@@ -85,13 +85,13 @@ export default class ApplicationMenu {
|
||||
{ role: 'toggledevtools' },
|
||||
{ type: 'separator' },
|
||||
{ role: 'togglefullscreen' },
|
||||
];
|
||||
]
|
||||
return {
|
||||
label: 'View',
|
||||
submenu: viewMenu
|
||||
};
|
||||
}
|
||||
}
|
||||
private static WindowMenu(isMac: boolean): MenuItemConstructorOptions {
|
||||
private static WindowMenu(): MenuItemConstructorOptions {
|
||||
let windowMenu: MenuItemConstructorOptions[] = isMac ? [
|
||||
{ role: 'close' },
|
||||
{ role: 'minimize' },
|
||||
@@ -101,11 +101,11 @@ export default class ApplicationMenu {
|
||||
] : [
|
||||
{ role: 'minimize' },
|
||||
{ role: 'close' },
|
||||
];
|
||||
]
|
||||
return {
|
||||
label: 'Window',
|
||||
submenu: windowMenu,
|
||||
};
|
||||
}
|
||||
}
|
||||
private static HelpMenu(): MenuItemConstructorOptions {
|
||||
let helpMenu: MenuItemConstructorOptions[] = [
|
||||
@@ -117,10 +117,10 @@ export default class ApplicationMenu {
|
||||
label: 'Learn More',
|
||||
click: () => shell.openExternal(documentURL),
|
||||
}
|
||||
];
|
||||
]
|
||||
return {
|
||||
label: 'Help',
|
||||
submenu: helpMenu,
|
||||
};
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -10,7 +10,7 @@ import {
|
||||
} from 'electron'
|
||||
import { register as shortcutRegister } from 'electron-localshortcut'
|
||||
|
||||
declare const __static: string;
|
||||
declare const __static: string
|
||||
const isDevelopment = process.env.NODE_ENV !== 'production'
|
||||
|
||||
export interface CreateWindowOptions {
|
||||
@@ -23,6 +23,8 @@ export interface CreateWindowOptions {
|
||||
}
|
||||
|
||||
export default class Window {
|
||||
public static ApplicationURL: string = process.env.WEBPACK_DEV_SERVER_URL /* `electron:serve`で起動した時 */ || 'app://./' /* ビルドしたアプリ */
|
||||
|
||||
public static single: Map<string, BrowserWindow> = new Map()
|
||||
public static list: BrowserWindow[]
|
||||
|
||||
@@ -64,7 +66,7 @@ export default class Window {
|
||||
lastAction: (win) => {
|
||||
win.setMenuBarVisibility(false)
|
||||
win.webContents.on('before-input-event', (event: Event, input: Input) => {
|
||||
this.single.get('about')!.webContents.setIgnoreMenuShortcuts((process.platform === 'darwin' ? input.meta : input.control) && input.key === "r")
|
||||
this.single.get('about')!.webContents.setIgnoreMenuShortcuts((process.platform === 'darwin' ? input.meta : input.control) && input.key === 'r')
|
||||
})
|
||||
shortcutRegister(win, 'Esc', () => this.single.get('about')!.destroy())
|
||||
},
|
||||
@@ -89,7 +91,7 @@ export default class Window {
|
||||
})
|
||||
|
||||
let openUrl = (event: Event, url: string) => {
|
||||
if (isDevelopment && url === process.env.WEBPACK_DEV_SERVER_URL + options.loadPath) {
|
||||
if (url === this.ApplicationURL + options.loadPath) {
|
||||
return
|
||||
}
|
||||
event.preventDefault()
|
||||
@@ -102,13 +104,7 @@ export default class Window {
|
||||
win.webContents.on('will-navigate', openUrl)
|
||||
win.webContents.on('new-window', openUrl)
|
||||
|
||||
if (process.env.WEBPACK_DEV_SERVER_URL) {
|
||||
// `electron:serve`で起動した時の読み込み
|
||||
win.loadURL(process.env.WEBPACK_DEV_SERVER_URL + options.loadPath)
|
||||
} else {
|
||||
// ビルドしたアプリでの読み込み
|
||||
win.loadURL(`app://./${options.loadPath}`)
|
||||
}
|
||||
win.loadURL(this.ApplicationURL + options.loadPath)
|
||||
|
||||
if (isDevelopment && options.openDevTools) win.webContents.openDevTools()
|
||||
|
||||
|
||||
Reference in New Issue
Block a user