1
1
mirror of https://github.com/qvacua/vimr.git synced 2024-12-01 10:02:36 +03:00
vimr/VimR/AppDelegateReducer.swift
Tae Won Ha b1a6f7d5af
GH-325 Store the frame of the last window and cascase manually
- Rough draft: multiple screens are not handled yet.
2017-08-15 17:53:38 +02:00

94 lines
2.7 KiB
Swift

/**
* Tae Won Ha - http://taewon.de - @hataewon
* See LICENSE
*/
import Foundation
class AppDelegateReducer {
typealias Pair = StateActionPair<AppState, AppDelegate.Action>
init(baseServerUrl: URL) {
self.baseServerUrl = baseServerUrl
}
func reduce(_ pair: Pair) -> Pair {
var state = pair.state
switch pair.action {
case let .newMainWindow(urls, cwd, nvimArgs, cliPipePath):
let mainWindow: MainWindow.State
if let args = nvimArgs {
mainWindow = self.newMainWindow(with: state, urls: [], cwd: cwd, nvimArgs: args, cliPipePath: cliPipePath)
} else {
mainWindow = self.newMainWindow(with: state, urls: urls, cwd: cwd, cliPipePath: cliPipePath)
}
state.mainWindows[mainWindow.uuid] = mainWindow
case let .openInKeyWindow(urls, cwd):
guard let uuid = state.currentMainWindowUuid, state.mainWindows[uuid] != nil else {
let mainWindow = self.newMainWindow(with: state, urls: urls, cwd: cwd)
state.mainWindows[mainWindow.uuid] = mainWindow
break
}
state.mainWindows[uuid]?.urlsToOpen = urls.toDict { url in MainWindow.OpenMode.default }
state.mainWindows[uuid]?.cwd = cwd
case .preferences:
state.preferencesOpen = Marked(true)
}
return StateActionPair(state: state, action: pair.action)
}
fileprivate let baseServerUrl: URL
fileprivate func newMainWindow(with state: AppState,
urls: [URL],
cwd: URL,
nvimArgs: [String]? = nil,
cliPipePath: String? = nil) -> MainWindow.State {
var mainWindow = state.mainWindowTemplate
mainWindow.uuid = UUID().uuidString
mainWindow.cwd = cwd
mainWindow.isDirty = false
mainWindow.htmlPreview = HtmlPreviewState(
htmlFile: nil,
server: Marked(self.baseServerUrl.appendingPathComponent(HtmlPreviewToolReducer.selectFirstPath))
)
mainWindow.preview.server = self.baseServerUrl.appendingPathComponent(MarkdownReducer.nonePath)
mainWindow.nvimArgs = nvimArgs
mainWindow.cliPipePath = cliPipePath
mainWindow.urlsToOpen = urls.toDict { _ in MainWindow.OpenMode.default }
if state.mainWindows.isEmpty {
return mainWindow
}
let refFrame = state.mainWindowTemplate.frame
let frame = refFrame.offsetBy(dx: cascadeX, dy: -cascadeY)
mainWindow.frame = frame
return mainWindow
}
fileprivate func screen(containing point: CGPoint) -> NSScreen? {
return NSScreen.screens()?
.reduce(nil) { (result, screen) -> NSScreen? in screen.frame.contains(point) ? screen : result }
}
}
fileprivate let cascadeX: CGFloat = 24.0
fileprivate let cascadeY: CGFloat = 24.0