From f725927c4480ace172ba898a57039ec3478597bb Mon Sep 17 00:00:00 2001 From: Cheng Zhao Date: Sun, 5 May 2013 20:24:20 +0800 Subject: [PATCH] Use cross-platform callbacks in the dialog API. --- browser/api/lib/dialog.coffee | 52 ++++++++++++++++++++++++++-------- renderer/api/lib/dialog.coffee | 45 +++++------------------------ 2 files changed, 47 insertions(+), 50 deletions(-) diff --git a/browser/api/lib/dialog.coffee b/browser/api/lib/dialog.coffee index c278bc32b9e7..20f83d053c2a 100644 --- a/browser/api/lib/dialog.coffee +++ b/browser/api/lib/dialog.coffee @@ -5,18 +5,32 @@ ipc = require 'ipc' FileDialog = binding.FileDialog 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 -onSelected = (event, id, paths...) -> - {processId, routingId} = callbacksInfo[id] - delete callbacksInfo[id] +fileDialog.on 'selected', (event, callbackId, paths...) -> + CallbacksRegistry.call callbackId, 'selected', paths... + CallbacksRegistry.remove callbackId - ipc.sendChannel processId, routingId, 'ATOM_RENDERER_DIALOG', id, paths... - -fileDialog.on 'selected', onSelected -fileDialog.on 'cancelled', onSelected +fileDialog.on 'cancelled', (event, callbackId) -> + CallbacksRegistry.call callbackId, 'cancelled' + CallbacksRegistry.remove callbackId validateOptions = (options) -> return false unless typeof options is 'object' @@ -30,19 +44,20 @@ validateOptions = (options) -> options.defaultPath = '' unless options.defaultPath? options.fileTypeIndex = 0 unless options.fileTypeIndex? options.defaultExtension = '' unless options.defaultExtension? - 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.type = type options.title = title unless options.title? 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.title, options.defaultPath, @@ -50,3 +65,16 @@ ipc.on 'ATOM_BROWSER_FILE_DIALOG', (processId, routingId, callbackId, type, titl options.fileTypeIndex, options.defaultExtension, 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' diff --git a/renderer/api/lib/dialog.coffee b/renderer/api/lib/dialog.coffee index 6ac381f9b6e3..8fd20a70032f 100644 --- a/renderer/api/lib/dialog.coffee +++ b/renderer/api/lib/dialog.coffee @@ -1,41 +1,10 @@ -ipc = require 'ipc' +remote = require 'remote' +dialog = remote.require 'dialog' -callbackId = 0 -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 +win = remote.getCurrentWindow() module.exports = - openFolder: (options, callback) -> - callFileDialogs options, callback, 1, 'Open Folder' - - saveAs: (options, callback) -> - callFileDialogs options, callback, 2, 'Save As' - - openFile: (options, callback) -> - callFileDialogs options, callback, 3, 'Open File' - - openMultiFiles: (options, callback) -> - callFileDialogs options, callback, 4, 'Open Files' + openFolder: (args...) -> dialog.openFolder win, args... + saveAs: (args...) -> dialog.saveAs win, args... + openFile: (args...) -> dialog.openFile win, args... + openMultiFiles: (args...) -> dialog.openMultiFiles win, args...