Browse Source

Merge pull request #93 from meriadec/master

Save and restore window dimensions
master
Loëck Vézien 7 years ago
committed by GitHub
parent
commit
2f56a2712d
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 16
      src/helpers/db.js
  2. 16
      src/main/app.js

16
src/helpers/db.js

@ -1,4 +1,6 @@
import Store from 'electron-store' import Store from 'electron-store'
import set from 'lodash/set'
import get from 'lodash/get'
const encryptionKey = {} const encryptionKey = {}
@ -35,4 +37,18 @@ export default {
db.set('data', val) db.set('data', val)
return db.get('data') return db.get('data')
}, },
getIn: (key, path, defaultValue) => {
const db = store(key)
const data = db.get('data')
return get(data, path, defaultValue)
},
setIn: (key, path, val) => {
const db = store(key)
const data = db.get('data')
set(data, path, val)
db.set('data', data)
return db.get('data')
},
} }

16
src/main/app.js

@ -1,8 +1,10 @@
// @flow // @flow
import { app, BrowserWindow, Menu, ipcMain, screen } from 'electron' import { app, BrowserWindow, Menu, ipcMain, screen } from 'electron'
import debounce from 'lodash/debounce'
import menu from 'main/menu' import menu from 'main/menu'
import db from 'helpers/db'
// necessary to prevent win from being garbage collected // necessary to prevent win from being garbage collected
let mainWindow let mainWindow
@ -32,9 +34,10 @@ const defaultWindowOptions = ({ height, width }) => ({
function createMainWindow() { function createMainWindow() {
const MIN_HEIGHT = 768 const MIN_HEIGHT = 768
const MIN_WIDTH = 1024 const MIN_WIDTH = 1024
const savedDimensions = db.getIn('settings', 'window.dimensions', {})
const height = MIN_HEIGHT const width = savedDimensions.width || MIN_WIDTH
const width = MIN_WIDTH const height = savedDimensions.height || MIN_HEIGHT
const windowOptions = { const windowOptions = {
...defaultWindowOptions({ height, width }), ...defaultWindowOptions({ height, width }),
@ -44,11 +47,11 @@ function createMainWindow() {
titleBarStyle: 'hiddenInset', titleBarStyle: 'hiddenInset',
} }
: {}), : {}),
width,
height, height,
minHeight: MIN_HEIGHT,
minWidth: MIN_WIDTH, minWidth: MIN_WIDTH,
minHeight: MIN_HEIGHT,
show: false, show: false,
width,
webPreferences: { webPreferences: {
...defaultWindowOptions.webPreferences, ...defaultWindowOptions.webPreferences,
// Enable, among other things, the ResizeObserver // Enable, among other things, the ResizeObserver
@ -78,6 +81,11 @@ function createMainWindow() {
} }
}) })
window.on('resize', debounce(() => {
const [width, height] = window.getSize()
db.setIn('settings', 'window.dimensions', { width, height })
}, 100))
window.webContents.on('devtools-opened', () => { window.webContents.on('devtools-opened', () => {
window.focus() window.focus()
setImmediate(() => { setImmediate(() => {

Loading…
Cancel
Save