From 5171c85c20ff7483d7233e65b6395da9e00d8010 Mon Sep 17 00:00:00 2001 From: Nitesh Kumar Date: Thu, 5 Mar 2020 16:22:45 +0530 Subject: [PATCH 1/5] Associate an file tpye to external Application --- src/file/FileUtils.js | 29 +++++++++++++++++++++++++++++ src/nls/root/strings.js | 5 ++++- src/project/FileTreeView.js | 14 ++++++++++++-- src/project/FileViewController.js | 8 ++++++++ src/project/ProjectManager.js | 8 ++++++++ 5 files changed, 61 insertions(+), 3 deletions(-) diff --git a/src/file/FileUtils.js b/src/file/FileUtils.js index 308c389cd62..41c9c0f7998 100644 --- a/src/file/FileUtils.js +++ b/src/file/FileUtils.js @@ -59,6 +59,11 @@ define(function (require, exports, module) { */ var MAX_FILE_SIZE = MAX_FILE_SIZE_MB * 1024 * 1024; + /** + * @const {List} list of File Extensions which will be opened in external Application + */ + var extListToBeOpenedInExtApp = []; + /** * Asynchronously reads a file as UTF-8 encoded text. @@ -526,6 +531,28 @@ define(function (require, exports, module) { return pathArray.join("/"); } + /** + * @param {string} ext extension string a file + * @return {string} returns true If file to be opened in External Application. + * + */ + function shouldOpenInExternalApplication(ext) { + return !extListToBeOpenedInExtApp.includes(ext); + } + + /** + * @param {string} ext File Extensions to be added in External App List + * + */ + function addExtensionToExternalAppList(ext) { + + if(typeof ext !== 'string') { + extListToBeOpenedInExtApp.concat(ext); + } else { + extListToBeOpenedInExtApp.push(ext); + } + } + // Asynchronously load DocumentCommandHandlers // This avoids a temporary circular dependency created // by relocating showFileOpenError() until deprecation is over @@ -568,4 +595,6 @@ define(function (require, exports, module) { exports.comparePaths = comparePaths; exports.MAX_FILE_SIZE = MAX_FILE_SIZE; exports.encodeFilePath = encodeFilePath; + exports.shouldOpenInExternalApplication = shouldOpenInExternalApplication; + exports.addExtensionToExternalAppList = addExtensionToExternalAppList; }); diff --git a/src/nls/root/strings.js b/src/nls/root/strings.js index bb7c0d42698..fbebdc49da1 100644 --- a/src/nls/root/strings.js +++ b/src/nls/root/strings.js @@ -903,5 +903,8 @@ define({ "REMOTE_DEBUGGING_ENABLED" : "Remote debugging enabled on localhost:", // Remote debugging port argument is invalid - "REMOTE_DEBUGGING_PORT_INVALID" : "Cannot enable remote debugging on port {0}. Port numbers should be between {1} and {2}." + "REMOTE_DEBUGGING_PORT_INVALID" : "Cannot enable remote debugging on port {0}. Port numbers should be between {1} and {2}.", + + //Associate File Type to External App + "DESCRIPTION_EXTERNAL_EDITOR" : "Add File type association to external App here" }); diff --git a/src/project/FileTreeView.js b/src/project/FileTreeView.js index 4efeef4a665..258444bd4c2 100644 --- a/src/project/FileTreeView.js +++ b/src/project/FileTreeView.js @@ -39,7 +39,8 @@ define(function (require, exports, module) { LanguageManager = require("language/LanguageManager"), FileTreeViewModel = require("project/FileTreeViewModel"), ViewUtils = require("utils/ViewUtils"), - KeyEvent = require("utils/KeyEvent"); + KeyEvent = require("utils/KeyEvent"), + PreferencesManager = require("preferences/PreferencesManager"); var DOM = Preact.DOM; @@ -554,7 +555,10 @@ define(function (require, exports, module) { }); } } else { - this.props.actions.setSelected(this.myPath()); + this.props.actions.setSelected(this.myPath(), + FileUtils.shouldOpenInExternalApplication( + FileUtils.getFileExtension(this.myPath()).toLowerCase() + )); } e.stopPropagation(); e.preventDefault(); @@ -569,6 +573,12 @@ define(function (require, exports, module) { if (this.state.clickTimer !== null) { this.clearTimer(); } + if (FileUtils.shouldOpenInExternalApplication( + FileUtils.getFileExtension(this.myPath()).toLowerCase() + )) { + this.props.actions.openInExternalEditor(this.myPath()); + return; + } this.props.actions.selectInWorkingSet(this.myPath()); } }, diff --git a/src/project/FileViewController.js b/src/project/FileViewController.js index e8079a0ebd5..fd1cb7886b8 100644 --- a/src/project/FileViewController.js +++ b/src/project/FileViewController.js @@ -226,6 +226,13 @@ define(function (require, exports, module) { return result.promise(); } + /** + * Opens the specified document with its associated external editor, + */ + function openInExternalEditor(fullPath) { + exports.trigger("openInExternalEditor", fullPath); + } + /** * Opens the specified document if it's not already open, adds it to the working set, * and selects it in the WorkingSetView @@ -275,4 +282,5 @@ define(function (require, exports, module) { exports.setFileViewFocus = setFileViewFocus; exports.WORKING_SET_VIEW = WORKING_SET_VIEW; exports.PROJECT_MANAGER = PROJECT_MANAGER; + exports.openInExternalEditor = openInExternalEditor; }); diff --git a/src/project/ProjectManager.js b/src/project/ProjectManager.js index db0cc7375f6..9a84336907f 100644 --- a/src/project/ProjectManager.js +++ b/src/project/ProjectManager.js @@ -280,6 +280,14 @@ define(function (require, exports, module) { this.model.selectInWorkingSet(path); }; + /** + * See `FileViewController.openInExternalEditor` + */ + ActionCreator.prototype.openInExternalEditor = function (path) { + FileViewController.openInExternalEditor(path); + }; + + /** * See `ProjectModel.setContext` */ From 0420ac1da3d7087e0833b7b1e8f27cedf58d65c7 Mon Sep 17 00:00:00 2001 From: Nitesh Kumar Date: Thu, 5 Mar 2020 16:30:39 +0530 Subject: [PATCH 2/5] Adding missed files --- .../default/OpenWithExternalEditor/main.js | 70 +++++++++++++++++++ .../node/OpenWithExternalEditorDomain.js | 68 ++++++++++++++++++ .../OpenWithExternalEditor/node/package.json | 6 ++ 3 files changed, 144 insertions(+) create mode 100644 src/extensions/default/OpenWithExternalEditor/main.js create mode 100644 src/extensions/default/OpenWithExternalEditor/node/OpenWithExternalEditorDomain.js create mode 100644 src/extensions/default/OpenWithExternalEditor/node/package.json diff --git a/src/extensions/default/OpenWithExternalEditor/main.js b/src/extensions/default/OpenWithExternalEditor/main.js new file mode 100644 index 00000000000..62c6766826b --- /dev/null +++ b/src/extensions/default/OpenWithExternalEditor/main.js @@ -0,0 +1,70 @@ +/* + * Copyright (c) 2013 - present Adobe Systems Incorporated. All rights reserved. + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + * + */ + +define(function (require, exports, module) { + "use strict"; + + + var AppInit = brackets.getModule("utils/AppInit"), + PreferencesManager = brackets.getModule("preferences/PreferencesManager"), + Strings = brackets.getModule("strings"), + FileViewController = brackets.getModule("project/FileViewController"), + ExtensionUtils = brackets.getModule("utils/ExtensionUtils"), + NodeDomain = brackets.getModule("utils/NodeDomain"), + FileUtils = brackets.getModule("file/FileUtils"); + + /** + * @private + * @type {string} fullPath of the OpenWithExternalEditor Domain implementation + */ + var _domainPath = ExtensionUtils.getModulePath(module, "node/OpenWithExternalEditorDomain"); + + /** + * @private + * @type {NodeDomain} + */ + var _nodeDomain = new NodeDomain("OpenWithExternalEditor", _domainPath); + + var extensionToExternalEditorMap = {}; + + function _openInExternalEdior(event, path) { + _nodeDomain.exec("open", { + path: path, + app: extensionToExternalEditorMap[FileUtils.getFileExtension(path).toLowerCase()] + }); + } + + PreferencesManager.definePreference("externalEditor", "object", {}, { + description: Strings.DESCRIPTION_EXTERNAL_EDITOR + }); + + PreferencesManager.on("change", "externalEditor", function () { + extensionToExternalEditorMap = PreferencesManager.get("externalEditor"); + }); + + FileViewController.on("openInExternalEditor", _openInExternalEdior); + + AppInit.appReady(function () { + FileUtils.addExtensionToExternalAppList(Object.keys(extensionToExternalEditorMap)); + }); +}); diff --git a/src/extensions/default/OpenWithExternalEditor/node/OpenWithExternalEditorDomain.js b/src/extensions/default/OpenWithExternalEditor/node/OpenWithExternalEditorDomain.js new file mode 100644 index 00000000000..4827cb3f3ed --- /dev/null +++ b/src/extensions/default/OpenWithExternalEditor/node/OpenWithExternalEditorDomain.js @@ -0,0 +1,68 @@ +/* + * Copyright (c) 2012 - present Adobe Systems Incorporated. All rights reserved. + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + * + */ + +/*eslint-env node */ +/*jslint node: true */ +"use strict"; + +var open = require("open"); + +var _domainManager; + +/** + * @private + * + * @param {Object} params Object to use + */ +function _OpenWithExternalEditor(params) { + var application = "default" === params.app ? "": params.app; + open(params.path, application); +} + + +/** + * Initializes the OpenWithExternalEditor domain with its commands. + * @param {DomainManager} domainManager The DomainManager for the server + */ +function init(domainManager) { + _domainManager = domainManager; + + if (!domainManager.hasDomain("OpenWithExternalEditor")) { + domainManager.registerDomain("OpenWithExternalEditor", {major: 0, minor: 1}); + } + _domainManager.registerCommand( + "OpenWithExternalEditor", + "open", + _OpenWithExternalEditor, + true, + "open document with External Editor.", + [{ + name: "params", + type: "object", + description: "Params Object having document and App Path." + }], + [] + ); +} + +exports.init = init; diff --git a/src/extensions/default/OpenWithExternalEditor/node/package.json b/src/extensions/default/OpenWithExternalEditor/node/package.json new file mode 100644 index 00000000000..178069e3c95 --- /dev/null +++ b/src/extensions/default/OpenWithExternalEditor/node/package.json @@ -0,0 +1,6 @@ +{ + "name": "brackets-open-external_editor", + "dependencies": { + "open": "0.0.5" + } +} From 7f5f0647d2df6315e1f5a5bf38e5433312f44959 Mon Sep 17 00:00:00 2001 From: Nitesh Kumar Date: Thu, 5 Mar 2020 18:08:48 +0530 Subject: [PATCH 3/5] few corrections in naming conventions --- .../main.js | 24 ++++++++++--------- .../OpenWithExternalApplicationDomain.js} | 12 +++++----- .../node/package.json | 2 +- src/file/FileUtils.js | 4 ++-- src/nls/root/strings.js | 2 +- src/project/FileTreeView.js | 2 +- src/project/FileViewController.js | 6 ++--- src/project/ProjectManager.js | 6 ++--- 8 files changed, 30 insertions(+), 28 deletions(-) rename src/extensions/default/{OpenWithExternalEditor => OpenWithExternalApplication}/main.js (71%) rename src/extensions/default/{OpenWithExternalEditor/node/OpenWithExternalEditorDomain.js => OpenWithExternalApplication/node/OpenWithExternalApplicationDomain.js} (85%) rename src/extensions/default/{OpenWithExternalEditor => OpenWithExternalApplication}/node/package.json (50%) diff --git a/src/extensions/default/OpenWithExternalEditor/main.js b/src/extensions/default/OpenWithExternalApplication/main.js similarity index 71% rename from src/extensions/default/OpenWithExternalEditor/main.js rename to src/extensions/default/OpenWithExternalApplication/main.js index 62c6766826b..535a6333ee7 100644 --- a/src/extensions/default/OpenWithExternalEditor/main.js +++ b/src/extensions/default/OpenWithExternalApplication/main.js @@ -37,34 +37,36 @@ define(function (require, exports, module) { * @private * @type {string} fullPath of the OpenWithExternalEditor Domain implementation */ - var _domainPath = ExtensionUtils.getModulePath(module, "node/OpenWithExternalEditorDomain"); + var _domainPath = ExtensionUtils.getModulePath(module, "node/OpenWithExternalApplicationDomain"); /** * @private * @type {NodeDomain} */ - var _nodeDomain = new NodeDomain("OpenWithExternalEditor", _domainPath); + var _nodeDomain = new NodeDomain("OpenWithExternalApplication", _domainPath); - var extensionToExternalEditorMap = {}; + var extensionToExtApplicationMap = {}; - function _openInExternalEdior(event, path) { + function _openWithExternalApplication(event, path) { _nodeDomain.exec("open", { path: path, - app: extensionToExternalEditorMap[FileUtils.getFileExtension(path).toLowerCase()] + app: extensionToExtApplicationMap[FileUtils.getFileExtension(path).toLowerCase()] }); } - PreferencesManager.definePreference("externalEditor", "object", {}, { - description: Strings.DESCRIPTION_EXTERNAL_EDITOR + PreferencesManager.definePreference("externalApplications", "object", {}, { + description: Strings.DESCRIPTION_EXTERNAL_APPLICATION_ASSOCIATE }); - PreferencesManager.on("change", "externalEditor", function () { - extensionToExternalEditorMap = PreferencesManager.get("externalEditor"); + PreferencesManager.on("change", "externalApplications", function () { + extensionToExtApplicationMap = PreferencesManager.get("externalApplications"); + FileUtils.addExtensionToExternalAppList(Object.keys(extensionToExtApplicationMap)); }); - FileViewController.on("openInExternalEditor", _openInExternalEdior); + FileViewController.on("openWithExternalApplication", _openWithExternalApplication); AppInit.appReady(function () { - FileUtils.addExtensionToExternalAppList(Object.keys(extensionToExternalEditorMap)); + extensionToExtApplicationMap = PreferencesManager.get("externalApplications"); + FileUtils.addExtensionToExternalAppList(Object.keys(extensionToExtApplicationMap)); }); }); diff --git a/src/extensions/default/OpenWithExternalEditor/node/OpenWithExternalEditorDomain.js b/src/extensions/default/OpenWithExternalApplication/node/OpenWithExternalApplicationDomain.js similarity index 85% rename from src/extensions/default/OpenWithExternalEditor/node/OpenWithExternalEditorDomain.js rename to src/extensions/default/OpenWithExternalApplication/node/OpenWithExternalApplicationDomain.js index 4827cb3f3ed..8a864689ef6 100644 --- a/src/extensions/default/OpenWithExternalEditor/node/OpenWithExternalEditorDomain.js +++ b/src/extensions/default/OpenWithExternalApplication/node/OpenWithExternalApplicationDomain.js @@ -34,7 +34,7 @@ var _domainManager; * * @param {Object} params Object to use */ -function _OpenWithExternalEditor(params) { +function _openWithExternalApplication(params) { var application = "default" === params.app ? "": params.app; open(params.path, application); } @@ -47,15 +47,15 @@ function _OpenWithExternalEditor(params) { function init(domainManager) { _domainManager = domainManager; - if (!domainManager.hasDomain("OpenWithExternalEditor")) { - domainManager.registerDomain("OpenWithExternalEditor", {major: 0, minor: 1}); + if (!domainManager.hasDomain("OpenWithExternalApplication")) { + domainManager.registerDomain("OpenWithExternalApplication", {major: 0, minor: 1}); } _domainManager.registerCommand( - "OpenWithExternalEditor", + "OpenWithExternalApplication", "open", - _OpenWithExternalEditor, + _openWithExternalApplication, true, - "open document with External Editor.", + "open document with External Application.", [{ name: "params", type: "object", diff --git a/src/extensions/default/OpenWithExternalEditor/node/package.json b/src/extensions/default/OpenWithExternalApplication/node/package.json similarity index 50% rename from src/extensions/default/OpenWithExternalEditor/node/package.json rename to src/extensions/default/OpenWithExternalApplication/node/package.json index 178069e3c95..65bb049736e 100644 --- a/src/extensions/default/OpenWithExternalEditor/node/package.json +++ b/src/extensions/default/OpenWithExternalApplication/node/package.json @@ -1,5 +1,5 @@ { - "name": "brackets-open-external_editor", + "name": "brackets-open-external_application", "dependencies": { "open": "0.0.5" } diff --git a/src/file/FileUtils.js b/src/file/FileUtils.js index 41c9c0f7998..819168d12b4 100644 --- a/src/file/FileUtils.js +++ b/src/file/FileUtils.js @@ -537,7 +537,7 @@ define(function (require, exports, module) { * */ function shouldOpenInExternalApplication(ext) { - return !extListToBeOpenedInExtApp.includes(ext); + return extListToBeOpenedInExtApp.includes(ext); } /** @@ -547,7 +547,7 @@ define(function (require, exports, module) { function addExtensionToExternalAppList(ext) { if(typeof ext !== 'string') { - extListToBeOpenedInExtApp.concat(ext); + extListToBeOpenedInExtApp = ext; } else { extListToBeOpenedInExtApp.push(ext); } diff --git a/src/nls/root/strings.js b/src/nls/root/strings.js index fbebdc49da1..e01b2300aeb 100644 --- a/src/nls/root/strings.js +++ b/src/nls/root/strings.js @@ -906,5 +906,5 @@ define({ "REMOTE_DEBUGGING_PORT_INVALID" : "Cannot enable remote debugging on port {0}. Port numbers should be between {1} and {2}.", //Associate File Type to External App - "DESCRIPTION_EXTERNAL_EDITOR" : "Add File type association to external App here" + "DESCRIPTION_EXTERNAL_APPLICATION_ASSOCIATE" : "Add File type association to external App here" }); diff --git a/src/project/FileTreeView.js b/src/project/FileTreeView.js index 258444bd4c2..ec71c797664 100644 --- a/src/project/FileTreeView.js +++ b/src/project/FileTreeView.js @@ -576,7 +576,7 @@ define(function (require, exports, module) { if (FileUtils.shouldOpenInExternalApplication( FileUtils.getFileExtension(this.myPath()).toLowerCase() )) { - this.props.actions.openInExternalEditor(this.myPath()); + this.props.actions.openWithExternalApplication(this.myPath()); return; } this.props.actions.selectInWorkingSet(this.myPath()); diff --git a/src/project/FileViewController.js b/src/project/FileViewController.js index fd1cb7886b8..ac616e943c0 100644 --- a/src/project/FileViewController.js +++ b/src/project/FileViewController.js @@ -229,8 +229,8 @@ define(function (require, exports, module) { /** * Opens the specified document with its associated external editor, */ - function openInExternalEditor(fullPath) { - exports.trigger("openInExternalEditor", fullPath); + function openWithExternalApplication(fullPath) { + exports.trigger("openWithExternalApplication", fullPath); } /** @@ -282,5 +282,5 @@ define(function (require, exports, module) { exports.setFileViewFocus = setFileViewFocus; exports.WORKING_SET_VIEW = WORKING_SET_VIEW; exports.PROJECT_MANAGER = PROJECT_MANAGER; - exports.openInExternalEditor = openInExternalEditor; + exports.openWithExternalApplication = openWithExternalApplication; }); diff --git a/src/project/ProjectManager.js b/src/project/ProjectManager.js index 9a84336907f..f6a799adf12 100644 --- a/src/project/ProjectManager.js +++ b/src/project/ProjectManager.js @@ -281,10 +281,10 @@ define(function (require, exports, module) { }; /** - * See `FileViewController.openInExternalEditor` + * See `FileViewController.openWithExternalApplication` */ - ActionCreator.prototype.openInExternalEditor = function (path) { - FileViewController.openInExternalEditor(path); + ActionCreator.prototype.openWithExternalApplication = function (path) { + FileViewController.openWithExternalApplication(path); }; From b5d9ffdfa434236ffceb7f86a22364d5f62f40ff Mon Sep 17 00:00:00 2001 From: Nitesh Kumar Date: Tue, 10 Mar 2020 11:59:52 +0530 Subject: [PATCH 4/5] Binary file should not be opened if associated with external application --- src/language/languages.json | 2 +- src/project/FileTreeView.js | 14 ++++++++++---- 2 files changed, 11 insertions(+), 5 deletions(-) diff --git a/src/language/languages.json b/src/language/languages.json index 1de22f94d48..5c8e9ef0b93 100644 --- a/src/language/languages.json +++ b/src/language/languages.json @@ -291,7 +291,7 @@ "jsz", "lib", "mpeg", "mpg", "mp4", "msi", "node", "o", "obj", "odc", "odb", "odf", "odg", "odp", "ods", "odt", "otf", "pak", "pdb", "pdf", "pdi", "ppt", "pptx", "psd", "rar", "sdf", "so", "sqlite", "suo", "svgz", - "swf", "tar", "tif", "tiff", "ttf", "woff", "xls", "xlsx", "zip" + "swf", "tar", "tif", "tiff", "ttf", "woff", "xls", "xlsx", "zip", "xd" ], "isBinary": true }, diff --git a/src/project/FileTreeView.js b/src/project/FileTreeView.js index ec71c797664..d7ec88b98c9 100644 --- a/src/project/FileTreeView.js +++ b/src/project/FileTreeView.js @@ -555,10 +555,16 @@ define(function (require, exports, module) { }); } } else { - this.props.actions.setSelected(this.myPath(), - FileUtils.shouldOpenInExternalApplication( - FileUtils.getFileExtension(this.myPath()).toLowerCase() - )); + var language = LanguageManager.getLanguageForPath(this.myPath()), + doNotOpen = false; + if (language && language.isBinary() && "image" !== language.getId() && + FileUtils.shouldOpenInExternalApplication( + FileUtils.getFileExtension(this.myPath()).toLowerCase() + ) + ) { + doNotOpen = true; + } + this.props.actions.setSelected(this.myPath(), doNotOpen); } e.stopPropagation(); e.preventDefault(); From 13bf4d2e8f36f36e7c559cf2edff1e723d3995cd Mon Sep 17 00:00:00 2001 From: Nitesh Kumar Date: Fri, 13 Mar 2020 16:45:43 +0530 Subject: [PATCH 5/5] addressed review comments --- src/file/FileUtils.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/file/FileUtils.js b/src/file/FileUtils.js index 819168d12b4..284c839b44e 100644 --- a/src/file/FileUtils.js +++ b/src/file/FileUtils.js @@ -546,9 +546,9 @@ define(function (require, exports, module) { */ function addExtensionToExternalAppList(ext) { - if(typeof ext !== 'string') { + if(Array.isArray(ext)) { extListToBeOpenedInExtApp = ext; - } else { + } else if (typeof ext === 'string'){ extListToBeOpenedInExtApp.push(ext); } }