support select file by file type in task detail page

This commit is contained in:
MaysWind 2016-06-26 18:10:58 +08:00
parent 1d5b8a6ee1
commit e581a16724
6 changed files with 253 additions and 13 deletions

View file

@ -3,12 +3,15 @@
"Operation Succeeded": "操作成功",
"Error": "错误",
"OK": "确定",
"Confirm": "确认",
"Cancel": "取消",
"New": "新建",
"Start": "开始下载任务",
"Pause": "暂停下载任务",
"Delete": "删除下载任务",
"Select All": "全选",
"Select None": "不选",
"Select Invert": "反选",
"Display Order": "显示顺序",
"Search": "搜索",
"Default": "默认",
@ -64,6 +67,13 @@
"Connections": "连接数",
"Seed Creation Time": "种子创建时间",
"Download Dir": "下载路径",
"(Choose Files)": "(选择文件)",
"Videos": "视频",
"Audios": "音频",
"Pictures": "图片",
"Documents": "文档",
"Applications": "应用程序",
"Archives": "存档文件",
"Address": "地址",
"Status": "状态",
"Percent": "完成度",

View file

@ -9,6 +9,103 @@
taskStatStorageCapacity: 300,
lazySaveTimeout: 500,
errorTooltipDelay: 200
}).constant('ariaNgFileTypes', {
video: [
'.3gp',
'.3gpp',
'.asf',
'.asx',
'.avi',
'.dat',
'.flv',
'.m4v',
'.mkv',
'.mov',
'.mp4',
'.mpe',
'.mpeg',
'.mpg',
'.rm',
'.rmvb',
'.vob',
'.wmv'
],
audio: [
'.aac',
'.amr',
'.ape',
'.flac',
'.m4a',
'.mid',
'.mp3',
'.ogg',
'.ra',
'.vqf',
'.wav',
'.wma'
],
picture: [
'.bmp',
'.emf',
'.gif',
'.jp2',
'.jpeg',
'.jpg',
'.png',
'.psd',
'.raw',
'.tga',
'.tif',
'.tiff',
'.wmf'
],
document: [
'.doc',
'.docx',
'.key',
'.numbers',
'.odp',
'.ods',
'.odt',
'.pages',
'.pdf',
'.ppt',
'.pptx',
'.rtf',
'.txt',
'.vsd',
'.vsdx',
'.wps',
'.xls',
'.xlsx'
],
application: [
'.apk',
'.bat',
'.com',
'.deb',
'.dll',
'.dmg',
'.exe',
'.ipa',
'.jar',
'.rpm',
'.sh'
],
archive: [
'.7z',
'.arj',
'.bz2',
'.cab',
'.gz',
'.iso',
'.r',
'.rar',
'.tar',
'.tar',
'.z',
'.zip'
]
}).constant('ariaNgDefaultOptions', {
language: 'en',
rpcHost: '',

View file

@ -7,12 +7,15 @@
'Operation Succeeded': 'Operation Succeeded',
'Error': 'Error',
'OK': 'OK',
'Confirm': 'Confirm',
'Cancel': 'Cancel',
'New': 'New',
'Start': 'Start',
'Pause': 'Pause',
'Delete': 'Delete',
'Select All': 'Select All',
'Select None': 'Select None',
'Select Invert': 'Select Invert',
'Display Order': 'Display Order',
'Search': 'Search',
'Default': 'Default',
@ -68,6 +71,13 @@
'Connections': 'Connections',
'Seed Creation Time': 'Seed Creation Time',
'Download Dir': 'Download Dir',
'(Choose Files)': '(Choose Files)',
'Videos': 'Videos',
'Audios': 'Audios',
'Pictures': 'Pictures',
'Documents': 'Documents',
'Applications': 'Applications',
'Archives': 'Archives',
'Address': 'Address',
'Status': 'Status',
'Percent': 'Percent',

View file

@ -1,7 +1,7 @@
(function () {
'use strict';
angular.module('ariaNg').controller('TaskDetailController', ['$rootScope', '$scope', '$routeParams', '$interval', 'aria2RpcErrors', 'ariaNgCommonService', 'ariaNgSettingService', 'ariaNgMonitorService', 'aria2TaskService', 'aria2SettingService', function ($rootScope, $scope, $routeParams, $interval, aria2RpcErrors, ariaNgCommonService, ariaNgSettingService, ariaNgMonitorService, aria2TaskService, aria2SettingService) {
angular.module('ariaNg').controller('TaskDetailController', ['$rootScope', '$scope', '$routeParams', '$interval', 'aria2RpcErrors', 'ariaNgFileTypes', 'ariaNgCommonService', 'ariaNgSettingService', 'ariaNgMonitorService', 'aria2TaskService', 'aria2SettingService', function ($rootScope, $scope, $routeParams, $interval, aria2RpcErrors, ariaNgFileTypes, ariaNgCommonService, ariaNgSettingService, ariaNgMonitorService, aria2TaskService, aria2SettingService) {
var tabOrders = ['overview', 'blocks', 'filelist', 'btpeers'];
var downloadTaskRefreshPromise = null;
var pauseDownloadTaskRefresh = false;
@ -74,8 +74,36 @@
}, silent);
};
var setSelectFiles = function (silent) {
if (!$scope.task || !$scope.task.files) {
return;
}
var gid = $scope.task.gid;
var selectedFileIndex = [];
for (var i = 0; i < $scope.task.files.length; i++) {
var file = $scope.task.files[i];
if (file && file.selected) {
selectedFileIndex.push(file.index);
}
}
pauseDownloadTaskRefresh = true;
return aria2TaskService.selectTaskFile(gid, selectedFileIndex, function (response) {
pauseDownloadTaskRefresh = false;
if (response.success) {
refreshDownloadTask(false);
}
}, silent);
};
$scope.context = {
currentTab: 'overview',
showChooseFilesToolbar: false,
btPeers: [],
healthPercent: 0,
statusData: ariaNgMonitorService.getEmptyStatsData($routeParams.gid),
@ -135,31 +163,83 @@
return ariaNgSettingService.getFileListDisplayOrder();
};
$scope.setSelectedFile = function () {
$scope.showChooseFilesToolbar = function () {
pauseDownloadTaskRefresh = true;
$scope.context.showChooseFilesToolbar = true;
};
$scope.getSelectedFileCount = function () {
var count = 0;
for (var i = 0; i < $scope.task.files.length; i++) {
count += $scope.task.files[i].selected ? 1 : 0;
}
return count;
};
$scope.selectFiles = function (type) {
if (!$scope.task || !$scope.task.files) {
return;
}
var gid = $scope.task.gid;
var selectedFileIndex = [];
for (var i = 0; i < $scope.task.files.length; i++) {
if (type == 'all') {
$scope.task.files[i].selected = true;
} else if (type == 'none') {
$scope.task.files[i].selected = false;
} else if (type == 'reverse') {
$scope.task.files[i].selected = !$scope.task.files[i].selected;
}
}
};
$scope.chooseSpecifiedFiles = function (type) {
if (!$scope.task || !$scope.task.files || !ariaNgFileTypes[type]) {
return;
}
var extensions = ariaNgFileTypes[type];
var fileIndexes = [];
var isAllSelected = true;
for (var i = 0; i < $scope.task.files.length; i++) {
var file = $scope.task.files[i];
var extension = ariaNgCommonService.getFileExtension($scope.task.files[i].fileName);
if (file && file.selected) {
selectedFileIndex.push(file.index);
if (extensions.indexOf(extension) >= 0) {
fileIndexes.push(i);
if (!$scope.task.files[i].selected) {
isAllSelected = false;
}
}
}
pauseDownloadTaskRefresh = true;
for (var i = 0; i < fileIndexes.length; i++) {
var index = fileIndexes[i];
$scope.task.files[index].selected = !isAllSelected;
}
};
return aria2TaskService.selectTaskFile(gid, selectedFileIndex, function (response) {
$scope.saveChoosedFiles = function () {
if ($scope.context.showChooseFilesToolbar) {
$rootScope.loadPromise = setSelectFiles(false);
$scope.context.showChooseFilesToolbar = false;
}
};
$scope.cancelChooseFiles = function () {
if ($scope.context.showChooseFilesToolbar) {
pauseDownloadTaskRefresh = false;
refreshDownloadTask(true);
$scope.context.showChooseFilesToolbar = false;
}
};
if (response.success) {
refreshDownloadTask(false);
}
}, true);
$scope.setSelectedFile = function () {
if (!$scope.context.showChooseFilesToolbar) {
setSelectFiles(true);
}
};
$scope.changePeerListDisplayOrder = function (type, autoSetReverse) {

View file

@ -51,6 +51,13 @@
}
});
},
getFileExtension: function (filePath) {
if (!filePath || filePath.lastIndexOf('.') < 0) {
return filePath;
}
return filePath.substring(filePath.lastIndexOf('.'));
},
extendArray: function (sourceArray, targetArray, keyProperty) {
if (!targetArray || !sourceArray || sourceArray.length != targetArray.length) {
return false;

View file

@ -157,6 +157,7 @@
<div class="col-sm-8">
<a ng-click="changeFileListDisplayOrder('name:asc', true)" translate>File Name</a>
<i class="fa" ng-class="{'fa-sort-asc fa-order-asc': isSetFileListDisplayOrder('name:asc'), 'fa-sort-desc fa-order-desc': isSetFileListDisplayOrder('name:desc')}"></i>
<a ng-click="showChooseFilesToolbar()" ng-if="task && (task.status == 'waiting' || task.status == 'paused')" translate>(Choose Files)</a>
</div>
<div class="col-sm-2">
<a ng-click="changeFileListDisplayOrder('percent:desc', true)" translate>Completed Percent</a>
@ -168,6 +169,41 @@
</div>
</div>
</div>
<div class="task-table-title" ng-if="context.showChooseFilesToolbar">
<div class="row">
<div class="col-sm-12">
<button class="btn btn-xs btn-primary" ng-click="selectFiles('all')" translate>Select All</button>
<button class="btn btn-xs btn-primary" ng-click="selectFiles('none')" translate>Select None</button>
<button class="btn btn-xs btn-primary" ng-click="selectFiles('reverse')" translate>Select Invert</button>
<button class="btn btn-xs btn-default" ng-click="chooseSpecifiedFiles('video')">
<i class="fa fa-file-video-o"></i>
<span translate>Videos</span>
</button>
<button class="btn btn-xs btn-default" ng-click="chooseSpecifiedFiles('audio')">
<i class="fa fa-file-audio-o"></i>
<span translate>Audios</span>
</button>
<button class="btn btn-xs btn-default" ng-click="chooseSpecifiedFiles('picture')">
<i class="fa fa-file-picture-o"></i>
<span translate>Pictures</span>
</button>
<button class="btn btn-xs btn-default" ng-click="chooseSpecifiedFiles('document')">
<i class="fa fa-file-text-o"></i>
<span translate>Documents</span>
</button>
<button class="btn btn-xs btn-default" ng-click="chooseSpecifiedFiles('application')">
<i class="fa fa-file-o"></i>
<span translate>Applications</span>
</button>
<button class="btn btn-xs btn-default" ng-click="chooseSpecifiedFiles('archive')">
<i class="fa fa-file-archive-o"></i>
<span translate>Archives</span>
</button>
<button class="btn btn-xs btn-success" ng-click="saveChoosedFiles()" ng-disabled="getSelectedFileCount() < 1" translate>Confirm</button>
<button class="btn btn-xs btn-default" ng-click="cancelChooseFiles()" translate>Cancel</button>
</div>
</div>
</div>
<div class="task-table-body">
<div class="row" ng-repeat="file in task.files | fileOrderBy: getFileListOrderType()" data-file-index="{{file.index}}">
<div class="col-sm-8">