Browse Source

Merge pull request #92 from loeck/master

Improved build, fix center window with multiscreen
master
Meriadec Pillet 7 years ago
committed by GitHub
parent
commit
3c55ec239c
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 4
      .babelrc
  2. 36
      electron-builder.yml
  3. 16
      src/components/base/Defer.js
  4. 36
      src/main/app.js

4
.babelrc

@ -3,9 +3,11 @@
[ [
"env", "env",
{ {
"loose": true,
"modules": false, "modules": false,
"targets": { "targets": {
"node": "8" "electron": "1.8",
"node": "current"
} }
} }
], ],

36
electron-builder.yml

@ -1,4 +1,4 @@
appId: com.electron.ledger appId: com.ledger.desktop
protocols: protocols:
name: Ledger Wallet Desktop name: Ledger Wallet Desktop
@ -6,9 +6,39 @@ protocols:
- ledgerhq - ledgerhq
mac: mac:
category: public.app-category.utilities artifactName: ${name}-${version}-${os}.${ext}
category: public.app-category.wallet
target:
- dmg
- zip
linux: linux:
target: appImage artifactName: ${name}-${version}-${os}-${arch}.${ext}
target:
- target: AppImage
arch:
- x64
- target: tar.gz
arch:
- x64
win:
artifactName: ${name}-${version}-${os}-${arch}.${ext}
target:
- target: nsis
arch:
- x64
- ia32
- target: zip
arch:
- x64
- ia32
nsis:
oneClick: false
perMachine: true
allowToChangeInstallationDirectory: true
files: files:
- dist/internals - dist/internals

16
src/components/base/Defer.js

@ -7,31 +7,25 @@ type Props = {
} }
type State = { type State = {
show: boolean, shouldRender: boolean,
} }
class Defer extends PureComponent<Props, State> { class Defer extends PureComponent<Props, State> {
state = { state = {
show: false, shouldRender: false,
} }
componentDidMount() { componentDidMount() {
window.requestAnimationFrame(() => window.requestAnimationFrame(() =>
this.setState({ window.requestAnimationFrame(() => this.setState({ shouldRender: true })),
show: true,
}),
) )
} }
render() { render() {
const { children } = this.props const { children } = this.props
const { show } = this.state const { shouldRender } = this.state
if (show) { return shouldRender ? children : null
return children
}
return null
} }
} }

36
src/main/app.js

@ -1,6 +1,6 @@
// @flow // @flow
import { app, BrowserWindow, Menu, ipcMain } from 'electron' import { app, BrowserWindow, Menu, ipcMain, screen } from 'electron'
import menu from 'main/menu' import menu from 'main/menu'
@ -12,31 +12,43 @@ let forceClose = false
const devTools = __DEV__ const devTools = __DEV__
const defaultWindowOptions = { const getWindowPosition = (height, width) => {
const { bounds } = screen.getPrimaryDisplay()
return {
x: Math.ceil(bounds.x + (bounds.width - width) / 2),
y: Math.ceil(bounds.y + (bounds.height - height) / 2),
}
}
const defaultWindowOptions = ({ height, width }) => ({
...getWindowPosition(height, width),
backgroundColor: '#fff', backgroundColor: '#fff',
center: true,
webPreferences: { webPreferences: {
devTools, devTools,
}, },
} })
function createMainWindow() { function createMainWindow() {
const MIN_HEIGHT = 768 const MIN_HEIGHT = 768
const MIN_WIDTH = 1024 const MIN_WIDTH = 1024
const height = MIN_HEIGHT
const width = MIN_WIDTH
const windowOptions = { const windowOptions = {
...defaultWindowOptions, ...defaultWindowOptions({ height, width }),
...(process.platform === 'darwin' ...(process.platform === 'darwin'
? { ? {
frame: false, frame: false,
titleBarStyle: 'hiddenInset', titleBarStyle: 'hiddenInset',
} }
: {}), : {}),
height: MIN_HEIGHT, height,
minHeight: MIN_HEIGHT, minHeight: MIN_HEIGHT,
minWidth: MIN_WIDTH, minWidth: MIN_WIDTH,
show: false, show: false,
width: MIN_WIDTH, width,
webPreferences: { webPreferences: {
...defaultWindowOptions.webPreferences, ...defaultWindowOptions.webPreferences,
// Enable, among other things, the ResizeObserver // Enable, among other things, the ResizeObserver
@ -80,19 +92,19 @@ function createPreloadWindow() {
// Preload renderer of main windows // Preload renderer of main windows
mainWindow = createMainWindow() mainWindow = createMainWindow()
const HEIGHT = 144 const height = 144
const WIDTH = 256 const width = 256
const windowOptions = { const windowOptions = {
...defaultWindowOptions, ...defaultWindowOptions({ height, width }),
closable: false, closable: false,
frame: false, frame: false,
fullscreenable: false, fullscreenable: false,
height: HEIGHT, height,
resizable: false, resizable: false,
show: false, show: false,
skipTaskbar: true, skipTaskbar: true,
width: WIDTH, width,
} }
const window = new BrowserWindow(windowOptions) const window = new BrowserWindow(windowOptions)

Loading…
Cancel
Save