file service supports read text file and save file
This commit is contained in:
parent
3004b7be8c
commit
e6d7e7fd1a
|
@ -128,7 +128,10 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
$scope.openTorrent = function () {
|
$scope.openTorrent = function () {
|
||||||
ariaNgFileService.openFileContent('.torrent', function (result) {
|
ariaNgFileService.openFileContent({
|
||||||
|
fileFilter: '.torrent',
|
||||||
|
fileType: 'binary'
|
||||||
|
}, function (result) {
|
||||||
$scope.context.uploadFile = result;
|
$scope.context.uploadFile = result;
|
||||||
$scope.context.taskType = 'torrent';
|
$scope.context.taskType = 'torrent';
|
||||||
$scope.changeTab('options');
|
$scope.changeTab('options');
|
||||||
|
@ -138,7 +141,10 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
$scope.openMetalink = function () {
|
$scope.openMetalink = function () {
|
||||||
ariaNgFileService.openFileContent('.meta4,.metalink', function (result) {
|
ariaNgFileService.openFileContent({
|
||||||
|
fileFilter: '.meta4,.metalink',
|
||||||
|
fileType: 'binary'
|
||||||
|
}, function (result) {
|
||||||
$scope.context.uploadFile = result;
|
$scope.context.uploadFile = result;
|
||||||
$scope.context.taskType = 'metalink';
|
$scope.context.taskType = 'metalink';
|
||||||
$scope.changeTab('options');
|
$scope.changeTab('options');
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
|
|
||||||
angular.module('ariaNg').factory('ariaNgFileService', ['$window', function ($window) {
|
angular.module('ariaNg').factory('ariaNgFileService', ['$window', function ($window) {
|
||||||
var isSupportFileReader = !!$window.FileReader;
|
var isSupportFileReader = !!$window.FileReader;
|
||||||
|
var isSupportBlob = !!$window.Blob;
|
||||||
|
|
||||||
var getAllowedExtensions = function (fileFilter) {
|
var getAllowedExtensions = function (fileFilter) {
|
||||||
var extensions = [];
|
var extensions = [];
|
||||||
|
@ -46,7 +47,13 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
return {
|
return {
|
||||||
openFileContent: function (fileFilter, successCallback, errorCallback, element) {
|
isSupportFileReader: function () {
|
||||||
|
return isSupportFileReader;
|
||||||
|
},
|
||||||
|
isSupportBlob: function () {
|
||||||
|
return isSupportBlob;
|
||||||
|
},
|
||||||
|
openFileContent: function (options, successCallback, errorCallback, element) {
|
||||||
if (!isSupportFileReader) {
|
if (!isSupportFileReader) {
|
||||||
if (errorCallback) {
|
if (errorCallback) {
|
||||||
errorCallback('Your browser does not support loading file!');
|
errorCallback('Your browser does not support loading file!');
|
||||||
|
@ -55,12 +62,19 @@
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var allowedExtensions = getAllowedExtensions(fileFilter);
|
options = angular.extend({
|
||||||
|
fileFilter: null,
|
||||||
|
fileType: 'binary' // or 'text'
|
||||||
|
}, options);
|
||||||
|
|
||||||
|
var allowedExtensions = getAllowedExtensions(options.fileFilter);
|
||||||
|
|
||||||
if (!element || !element.change) {
|
if (!element || !element.change) {
|
||||||
element = angular.element('<input type="file" style="display: none"/>');
|
element = angular.element('<input type="file" style="display: none"/>');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
element.val('');
|
||||||
|
|
||||||
if (element.attr('data-ariang-file-initialized') !== 'true') {
|
if (element.attr('data-ariang-file-initialized') !== 'true') {
|
||||||
element.change(function () {
|
element.change(function () {
|
||||||
if (!this.files || this.files.length < 1) {
|
if (!this.files || this.files.length < 1) {
|
||||||
|
@ -82,10 +96,19 @@
|
||||||
|
|
||||||
reader.onload = function () {
|
reader.onload = function () {
|
||||||
var result = {
|
var result = {
|
||||||
fileName: fileName,
|
fileName: fileName
|
||||||
base64Content: this.result.replace(/.*?base64,/, '')
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
switch (options.fileType) {
|
||||||
|
case 'text':
|
||||||
|
result.content = this.result;
|
||||||
|
break;
|
||||||
|
case 'binary':
|
||||||
|
default:
|
||||||
|
result.base64Content = this.result.replace(/.*?base64,/, '');
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if (successCallback) {
|
if (successCallback) {
|
||||||
successCallback(result);
|
successCallback(result);
|
||||||
}
|
}
|
||||||
|
@ -97,11 +120,52 @@
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
reader.readAsDataURL(file);
|
switch (options.fileType) {
|
||||||
|
case 'text':
|
||||||
|
reader.readAsText(file);
|
||||||
|
break;
|
||||||
|
case 'binary':
|
||||||
|
default:
|
||||||
|
reader.readAsDataURL(file);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}).attr('data-ariang-file-initialized', 'true');
|
}).attr('data-ariang-file-initialized', 'true');
|
||||||
}
|
}
|
||||||
|
|
||||||
element.trigger('click');
|
element.trigger('click');
|
||||||
|
},
|
||||||
|
saveFileContent: function (content, element, options) {
|
||||||
|
if (!isSupportBlob) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
options = angular.extend({
|
||||||
|
fileName: null,
|
||||||
|
contentType: 'application/octet-stream',
|
||||||
|
autoTrigger: false,
|
||||||
|
autoRevoke: false
|
||||||
|
}, options);
|
||||||
|
|
||||||
|
var blob = new Blob([content], { type: options.contentType });
|
||||||
|
var objectUrl = URL.createObjectURL(blob);
|
||||||
|
|
||||||
|
if (!element) {
|
||||||
|
element = angular.element('<a style="display: none"/>');
|
||||||
|
}
|
||||||
|
|
||||||
|
element.attr('href', objectUrl);
|
||||||
|
|
||||||
|
if (options.fileName) {
|
||||||
|
element.attr('download', options.fileName);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (options.autoTrigger) {
|
||||||
|
element.trigger('click');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (options.autoRevoke) {
|
||||||
|
URL.revokeObjectURL(objectUrl);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}]);
|
}]);
|
||||||
|
|
Reference in a new issue