mirror of
https://gitee.com/shuto/cordova-plugin-file-opener2.git
synced 2025-01-31 12:02:49 +08:00
Merge pull request #83 from J3r0M3D3V/master
Update fileOpener2Proxy.js, Windows fixes.
This commit is contained in:
commit
588f722f7f
@ -4,18 +4,46 @@
|
|||||||
|
|
||||||
var schemes = [
|
var schemes = [
|
||||||
{ protocol: 'ms-app', getFile: getFileFromApplicationUri },
|
{ protocol: 'ms-app', getFile: getFileFromApplicationUri },
|
||||||
{ protocol: 'file:///', getFile: getFileFromFileUri }
|
{ protocol: 'cdvfile', getFile: getFileFromFileUri } //protocol cdvfile
|
||||||
]
|
]
|
||||||
|
|
||||||
|
function nthIndex(str, pat, n) {
|
||||||
|
var L = str.length, i = -1;
|
||||||
|
while (n-- && i++ < L) {
|
||||||
|
i = str.indexOf(pat, i);
|
||||||
|
if (i < 0) break;
|
||||||
|
}
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
function getFileFromApplicationUri(uri) {
|
function getFileFromApplicationUri(uri) {
|
||||||
var applicationUri = new Windows.Foundation.Uri(uri);
|
/* bad path from a file entry due to the last '//'
|
||||||
|
example: ms-appdata:///local//path/to/file
|
||||||
|
*/
|
||||||
|
var index = nthIndex(uri, "//", 3);
|
||||||
|
var newUri = uri.substr(0, index) + uri.substr(index + 1);
|
||||||
|
|
||||||
|
var applicationUri = new Windows.Foundation.Uri(newUri);
|
||||||
|
|
||||||
return Windows.Storage.StorageFile.getFileFromApplicationUriAsync(applicationUri);
|
return Windows.Storage.StorageFile.getFileFromApplicationUriAsync(applicationUri);
|
||||||
}
|
}
|
||||||
|
|
||||||
function getFileFromFileUri(uri) {
|
function getFileFromFileUri(uri) {
|
||||||
var path = Windows.Storage.ApplicationData.current.localFolder.path +
|
/* uri example:
|
||||||
uri.substr(8);
|
cdvfile://localhost/persistent|temporary|another-fs-root/path/to/file
|
||||||
|
*/
|
||||||
|
var indexFrom = nthIndex(uri, "/", 3) + 1;
|
||||||
|
var indexTo = nthIndex(uri, "/", 4);
|
||||||
|
var whichFolder = uri.substring(indexFrom, indexTo);
|
||||||
|
var filePath = uri.substr(indexTo + 1);
|
||||||
|
var path = "\\" + filePath;
|
||||||
|
|
||||||
|
if (whichFolder == "persistent") {
|
||||||
|
path = Windows.Storage.ApplicationData.current.localFolder.path + path;
|
||||||
|
}
|
||||||
|
else { //temporary, note: no roaming management
|
||||||
|
path = Windows.Storage.ApplicationData.current.temporaryFolder.path + path;
|
||||||
|
}
|
||||||
|
|
||||||
return getFileFromNativePath(path);
|
return getFileFromNativePath(path);
|
||||||
}
|
}
|
||||||
@ -39,23 +67,23 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
|
|
||||||
open: function (successCallback, errorCallback, args) {
|
open: function (successCallback, errorCallback, args) {
|
||||||
|
|
||||||
var path = args[0];
|
var path = args[0];
|
||||||
|
|
||||||
var getFile = getFileLoaderForScheme(path);
|
var getFile = getFileLoaderForScheme(path);
|
||||||
|
|
||||||
getFile(path).then(function (file) {
|
getFile(path).then(function (file) {
|
||||||
var options = new Windows.System.LauncherOptions();
|
var options = new Windows.System.LauncherOptions();
|
||||||
|
|
||||||
Windows.System.Launcher.launchFileAsync(file, options).then(function (success) {
|
Windows.System.Launcher.launchFileAsync(file, options).then(function (success) {
|
||||||
if (success) {
|
successCallback();
|
||||||
successCallback();
|
}, function (error) {
|
||||||
} else {
|
errorCallback(error);
|
||||||
errorCallback();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
}, function (errror) {
|
}, function (error) {
|
||||||
console.log("Error abriendo el archivo");
|
console.log("Error while opening the file: "+error);
|
||||||
|
errorCallback(error);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user