Use cross-platform callbacks in the dialog API.
This commit is contained in:
parent
d377cbfa74
commit
f725927c44
2 changed files with 47 additions and 50 deletions
|
@ -5,18 +5,32 @@ ipc = require 'ipc'
|
||||||
FileDialog = binding.FileDialog
|
FileDialog = binding.FileDialog
|
||||||
FileDialog.prototype.__proto__ = EventEmitter.prototype
|
FileDialog.prototype.__proto__ = EventEmitter.prototype
|
||||||
|
|
||||||
callbacksInfo = {}
|
class CallbacksRegistry
|
||||||
|
@nextId = 0
|
||||||
|
@callbacks = {}
|
||||||
|
|
||||||
|
@add: (callback) ->
|
||||||
|
@callbacks[++@nextId] = callback
|
||||||
|
@nextId
|
||||||
|
|
||||||
|
@get: (id) ->
|
||||||
|
@callbacks[id]
|
||||||
|
|
||||||
|
@call: (id, args...) ->
|
||||||
|
@callbacks[id].call global, args...
|
||||||
|
|
||||||
|
@remove: (id) ->
|
||||||
|
delete @callbacks[id]
|
||||||
|
|
||||||
fileDialog = new FileDialog
|
fileDialog = new FileDialog
|
||||||
|
|
||||||
onSelected = (event, id, paths...) ->
|
fileDialog.on 'selected', (event, callbackId, paths...) ->
|
||||||
{processId, routingId} = callbacksInfo[id]
|
CallbacksRegistry.call callbackId, 'selected', paths...
|
||||||
delete callbacksInfo[id]
|
CallbacksRegistry.remove callbackId
|
||||||
|
|
||||||
ipc.sendChannel processId, routingId, 'ATOM_RENDERER_DIALOG', id, paths...
|
fileDialog.on 'cancelled', (event, callbackId) ->
|
||||||
|
CallbacksRegistry.call callbackId, 'cancelled'
|
||||||
fileDialog.on 'selected', onSelected
|
CallbacksRegistry.remove callbackId
|
||||||
fileDialog.on 'cancelled', onSelected
|
|
||||||
|
|
||||||
validateOptions = (options) ->
|
validateOptions = (options) ->
|
||||||
return false unless typeof options is 'object'
|
return false unless typeof options is 'object'
|
||||||
|
@ -30,19 +44,20 @@ validateOptions = (options) ->
|
||||||
options.defaultPath = '' unless options.defaultPath?
|
options.defaultPath = '' unless options.defaultPath?
|
||||||
options.fileTypeIndex = 0 unless options.fileTypeIndex?
|
options.fileTypeIndex = 0 unless options.fileTypeIndex?
|
||||||
options.defaultExtension = '' unless options.defaultExtension?
|
options.defaultExtension = '' unless options.defaultExtension?
|
||||||
|
|
||||||
true
|
true
|
||||||
|
|
||||||
ipc.on 'ATOM_BROWSER_FILE_DIALOG', (processId, routingId, callbackId, type, title, options) ->
|
selectFileWrap = (window, options, callback, type, title) ->
|
||||||
|
throw new TypeError('Need Window object') unless window.constructor?.name is 'Window'
|
||||||
|
|
||||||
options = {} unless options?
|
options = {} unless options?
|
||||||
options.type = type
|
options.type = type
|
||||||
options.title = title unless options.title?
|
options.title = title unless options.title?
|
||||||
|
|
||||||
throw new TypeError('Bad arguments') unless validateOptions options
|
throw new TypeError('Bad arguments') unless validateOptions options
|
||||||
|
|
||||||
callbacksInfo[callbackId] = processId: processId, routingId: routingId
|
callbackId = CallbacksRegistry.add callback
|
||||||
|
|
||||||
fileDialog.selectFile processId, routingId,
|
fileDialog.selectFile window.getProcessId(), window.getRoutingId(),
|
||||||
options.type,
|
options.type,
|
||||||
options.title,
|
options.title,
|
||||||
options.defaultPath,
|
options.defaultPath,
|
||||||
|
@ -50,3 +65,16 @@ ipc.on 'ATOM_BROWSER_FILE_DIALOG', (processId, routingId, callbackId, type, titl
|
||||||
options.fileTypeIndex,
|
options.fileTypeIndex,
|
||||||
options.defaultExtension,
|
options.defaultExtension,
|
||||||
callbackId
|
callbackId
|
||||||
|
|
||||||
|
module.exports =
|
||||||
|
openFolder: (args...) ->
|
||||||
|
selectFileWrap args..., 1, 'Open Folder'
|
||||||
|
|
||||||
|
saveAs: (args...) ->
|
||||||
|
selectFileWrap args..., 2, 'Save As'
|
||||||
|
|
||||||
|
openFile: (args...) ->
|
||||||
|
selectFileWrap args..., 3, 'Open File'
|
||||||
|
|
||||||
|
openMultiFiles: (args...) ->
|
||||||
|
selectFileWrap args..., 4, 'Open Files'
|
||||||
|
|
|
@ -1,41 +1,10 @@
|
||||||
ipc = require 'ipc'
|
remote = require 'remote'
|
||||||
|
dialog = remote.require 'dialog'
|
||||||
|
|
||||||
callbackId = 0
|
win = remote.getCurrentWindow()
|
||||||
callbacks = {}
|
|
||||||
|
|
||||||
storeCallback = (callback) ->
|
|
||||||
throw new TypeError('Bad argument') unless typeof callback is 'function'
|
|
||||||
|
|
||||||
++callbackId
|
|
||||||
callbacks[callbackId] = callback
|
|
||||||
callbackId
|
|
||||||
|
|
||||||
makeCallback = (id, args...) ->
|
|
||||||
callbacks[id].call global, args...
|
|
||||||
delete callbacks[id]
|
|
||||||
|
|
||||||
# Force loading dialog code in browser.
|
|
||||||
remote.require 'dialog'
|
|
||||||
|
|
||||||
ipc.on 'ATOM_RENDERER_DIALOG', (id, args...) ->
|
|
||||||
makeCallback(id, args...)
|
|
||||||
|
|
||||||
callFileDialogs = (options, callback, args...) ->
|
|
||||||
if typeof options is 'function'
|
|
||||||
callback = options
|
|
||||||
options = {}
|
|
||||||
|
|
||||||
ipc.sendChannel 'ATOM_BROWSER_FILE_DIALOG', storeCallback(callback), args..., options
|
|
||||||
|
|
||||||
module.exports =
|
module.exports =
|
||||||
openFolder: (options, callback) ->
|
openFolder: (args...) -> dialog.openFolder win, args...
|
||||||
callFileDialogs options, callback, 1, 'Open Folder'
|
saveAs: (args...) -> dialog.saveAs win, args...
|
||||||
|
openFile: (args...) -> dialog.openFile win, args...
|
||||||
saveAs: (options, callback) ->
|
openMultiFiles: (args...) -> dialog.openMultiFiles win, args...
|
||||||
callFileDialogs options, callback, 2, 'Save As'
|
|
||||||
|
|
||||||
openFile: (options, callback) ->
|
|
||||||
callFileDialogs options, callback, 3, 'Open File'
|
|
||||||
|
|
||||||
openMultiFiles: (options, callback) ->
|
|
||||||
callFileDialogs options, callback, 4, 'Open Files'
|
|
||||||
|
|
Loading…
Reference in a new issue