1059 lines
40 KiB
HTML
Executable File
1059 lines
40 KiB
HTML
Executable File
<!doctype>
|
|
<html>
|
|
|
|
<!-- {{{ head -->
|
|
<head>
|
|
<link rel="icon" href="favicon.ico" />
|
|
|
|
<meta charset="utf-8">
|
|
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
|
|
<title ng-controller="NavCtrl">{{ name }}</title>
|
|
|
|
<link rel="stylesheet" href="css/bootstrap.css">
|
|
<link rel="stylesheet" href="css/font-awesome.min.css">
|
|
|
|
<link rel="stylesheet" href="css/style.css">
|
|
<link rel="stylesheet" href="css/download.css">
|
|
<link rel="stylesheet" href="css/modals.css">
|
|
|
|
|
|
<!-- external javascript dependencies -->
|
|
<script src="js/libs/jquery-2.1.3.js"></script>
|
|
<script src="js/libs/lodash.js"></script>
|
|
|
|
<script src="js/libs/angular.js"></script>
|
|
|
|
<script src="js/libs/angularui-bootstrap.js"></script>
|
|
|
|
|
|
<script src="js/libs/jquery.flot.js"></script>
|
|
<script src="js/libs/jquery.flot.time.js"></script>
|
|
|
|
<!-- We do manual resize currently
|
|
<script src="js/libs/jquery.flot.resize.js"></script>
|
|
-->
|
|
|
|
<!-- webui core -->
|
|
<script src="js/init.js"></script>
|
|
<script src="configuration.js"></script>
|
|
|
|
<script src="js/directives/chunkbar.js"></script>
|
|
<script src="js/directives/dgraph.js"></script>
|
|
<script src="js/directives/fselect.js"></script>
|
|
|
|
<script src="js/filters/bytes.js"></script>
|
|
|
|
<script src="js/services/deps.js"></script>
|
|
<script src="js/services/base64.js"></script>
|
|
<script src="js/services/utils.js"></script>
|
|
|
|
<script src="js/services/modals.js"></script>
|
|
<script src="js/services/alerts.js"></script>
|
|
|
|
<script src="js/services/settings/settings.js"></script>
|
|
<script src="js/services/settings/filters.js"></script>
|
|
|
|
<script src="js/services/rpc/jsoncall.js"></script>
|
|
<script src="js/services/rpc/sockcall.js"></script>
|
|
<script src="js/services/rpc/syscall.js"></script>
|
|
<script src="js/services/rpc/rpc.js"></script>
|
|
<script src="js/services/rpc/helpers.js"></script>
|
|
|
|
|
|
<script src="js/ctrls/main.js"></script>
|
|
<script src="js/ctrls/modal.js"></script>
|
|
<script src="js/ctrls/nav.js"></script>
|
|
<script src="js/ctrls/alert.js"></script>
|
|
<script src="js/ctrls/props.js"></script>
|
|
</head>
|
|
<!-- }}} -->
|
|
|
|
<body ng-controller="MainCtrl">
|
|
|
|
<!-- {{{ header -->
|
|
<div class="navbar navbar-inverse navbar-static-top" ng-controller="NavCtrl">
|
|
<div class="container">
|
|
<div class="navbar-header">
|
|
<button type="button" class="navbar-toggle collapsed" ng-click="collapsed = !collapsed">
|
|
<span class="sr-only">Toggle navigation</span>
|
|
<span class="icon-bar"></span>
|
|
<span class="icon-bar"></span>
|
|
<span class="icon-bar"></span>
|
|
</button>
|
|
<a class="navbar-brand"><span class="fa fa-fw fa-arrow-circle-down"></span> {{ name }}</a>
|
|
</div>
|
|
|
|
<form class="navbar-form navbar-right" role="search">
|
|
<div class="form-group">
|
|
<input class="form-control" type="text" placeholder="Search" ng-model="downloadFilter" autocomplete="off" ng-change="onDownloadFilter()" />
|
|
</div>
|
|
</form>
|
|
|
|
<!-- {{{ Nav menu -->
|
|
<div class="collapse navbar-collapse" collapse="collapsed">
|
|
<ul class="nav navbar-nav">
|
|
<li class="dropdown" dropdown>
|
|
<a class="dropdown-toggle" href="#" dropdown-toggle>
|
|
Add <span class="caret"></span>
|
|
</a>
|
|
<ul class="dropdown-menu">
|
|
<li>
|
|
<a href="#" ng-click="addUris()">
|
|
<span class="fa fa-fw fa-arrow-circle-o-down"> </span> By URIs
|
|
</a>
|
|
</li>
|
|
<li ng-show="isFeatureEnabled('BitTorrent') && enable.torrent">
|
|
<a href="#" ng-click="addTorrents()">
|
|
<span class="fa fa-fw fa-cloud-download"> </span> By Torrents
|
|
</a>
|
|
</li>
|
|
<li ng-show="isFeatureEnabled('Metalink') && enable.metalink">
|
|
<a href="#" ng-click="addMetalinks()">
|
|
<span class="fa fa-fw fa-file-text-o"> </span> By Metalinks
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li class="dropdown" dropdown>
|
|
<a class="dropdown-toggle" href="#" dropdown-toggle> Manage <span class="caret"></span></a>
|
|
<ul class="dropdown-menu">
|
|
<li>
|
|
<a
|
|
href="#"
|
|
ng-click="forcePauseAll()"><span class="fa fa-fw fa-pause"> </span> Pause All</a>
|
|
</li>
|
|
<li>
|
|
<a
|
|
href="#"
|
|
ng-click="unpauseAll()"><span class="fa fa-fw fa-play"> </span> Resume Paused</a>
|
|
</li>
|
|
<li>
|
|
<a
|
|
href="#"
|
|
ng-click="purgeDownloadResult()"><span class="fa fa-fw fa-times-circle"> </span> Purge Completed</a>
|
|
</li>
|
|
|
|
<!-- not adding remove all as requires many rpc syscalls to finish
|
|
<li>
|
|
<a
|
|
href="#"
|
|
ng-click="removeAll()"><span class="fa fa-fw fa-fire"> </span> Remove All</a>
|
|
</li>
|
|
-->
|
|
</ul>
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
<ul class="nav navbar-nav">
|
|
<li class="dropdown" dropdown>
|
|
<a
|
|
href="#"
|
|
class="dropdown-toggle" dropdown-toggle>Settings <span class="caret"></span></a>
|
|
|
|
<ul class="dropdown-menu">
|
|
<li>
|
|
<a
|
|
ng-click="changeCSettings()"
|
|
href="#"><span class="fa fa-fw fa-wrench"> </span> Connection Settings</a>
|
|
</li>
|
|
|
|
<li>
|
|
<a
|
|
ng-click="changeGSettings()"
|
|
href="#"><span class="fa fa-fw fa-wrench"> </span> Global Settings</a>
|
|
</li>
|
|
|
|
<li>
|
|
<a
|
|
ng-click="showServerInfo()"
|
|
href="#"><span class="fa fa-fw fa-info-circle"> </span> Server info</a>
|
|
</li>
|
|
|
|
<li>
|
|
<a
|
|
ng-click="showAbout()"
|
|
href="#"><span class="fa fa-fw fa-question-circle"> </span> About and contribute</a>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
|
|
<ul class="nav navbar-nav pull-right" ng-show="false">
|
|
<li class="dropdown" dropdown>
|
|
<a
|
|
class="dropdown-toggle" dropdown-toggle
|
|
href="#">Miscellaneous <span class="caret"></span></a>
|
|
<ul class="dropdown-menu">
|
|
<li>
|
|
<a href="#"><span class="fa fa-fw fa-list-alt"> </span> Global Statistics</a>
|
|
</li>
|
|
<li>
|
|
<a href="#"><span class="fa fa-fw fa-info-circle"> </span> About</a>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
<!-- }}} -->
|
|
|
|
</div><!--/.nav-collapse -->
|
|
</div>
|
|
</div>
|
|
<!-- }}} -->
|
|
|
|
<!-- {{{ body -->
|
|
<div role="main" class="container-fluid">
|
|
|
|
<!-- {{{ alerts -->
|
|
<div ng-controller="AlertCtrl" class="row-fluid alerts">
|
|
<div class="alert alert-{{alert.type}}" ng-repeat="alert in pendingAlerts">
|
|
<button type="button" class="close" ng-click="removeAlert($index)">x</button>
|
|
<span ng-bind-html="alert.msg"></span>
|
|
</div>
|
|
</div>
|
|
<!-- }}} -->
|
|
|
|
<div class="row-fluid">
|
|
<div ng-class="{'col-md-3': enable.sidebar.show}" ng-show="enable.sidebar.show">
|
|
<!-- {{{ nav side bar -->
|
|
<div class="well sidebar-nav">
|
|
|
|
<!-- {{{ global statistics -->
|
|
<ul class="nav nav-list" ng-if="enable.sidebar.stats">
|
|
<li class="nav-header" ng-show="totalAria2Downloads()">Global Statistics</li>
|
|
<li>
|
|
<div
|
|
yticks="3"
|
|
xticks="1"
|
|
dspeed="gstats.downloadSpeed"
|
|
uspeed="gstats.uploadSpeed"
|
|
dgraph ng-show="totalAria2Downloads()"
|
|
nolabel="true"
|
|
draw="true">
|
|
</div>
|
|
</li>
|
|
</ul>
|
|
<!-- }}} -->
|
|
|
|
<br>
|
|
|
|
|
|
<!-- {{{ download filters -->
|
|
<ul id="filters" class="clearfix nav nav-list" ng-show="enable.sidebar.filters">
|
|
<li class="nav-header">Download Filters</li>
|
|
<li class="checkbox">
|
|
<label for="filter-speed">
|
|
<input type="checkbox" ng-model="filterSpeed" ng-change="persistFilters()" id="filter-speed">
|
|
Running
|
|
</label>
|
|
</li>
|
|
<li class="active checkbox">
|
|
<label for="filter-active">
|
|
<input type="checkbox" ng-model="filterActive" ng-change="persistFilters()" id="filter-active">
|
|
Active
|
|
</label>
|
|
</li>
|
|
<li class="checkbox">
|
|
<label for="filter-waiting">
|
|
<input type="checkbox" ng-model="filterWaiting" ng-change="persistFilters()" id="filter-waiting">
|
|
Waiting
|
|
</label>
|
|
</li>
|
|
<li class="checkbox">
|
|
<label for="filter-complete">
|
|
<input type="checkbox" ng-model="filterComplete" ng-change="persistFilters()" id="filter-complete">
|
|
Complete
|
|
</label>
|
|
</li>
|
|
<li class="checkbox">
|
|
<label for="filter-error">
|
|
<input type="checkbox" ng-model="filterError" ng-change="persistFilters()" id="filter-error">
|
|
Error
|
|
</label>
|
|
</li>
|
|
<li class="checkbox">
|
|
<label for="filter-paused">
|
|
<input type="checkbox" ng-model="filterPaused" ng-change="persistFilters()" id="filter-paused">
|
|
Paused
|
|
</label>
|
|
</li>
|
|
<li class="checkbox">
|
|
<label for="filter-removed">
|
|
<input type="checkbox" ng-model="filterRemoved" ng-change="persistFilters()" id="filter-removed">
|
|
Removed
|
|
</label>
|
|
</li>
|
|
<li class="checkbox">
|
|
<label>
|
|
<input type="checkbox" ng-model="hideLinkedMetadata" id="hide-linked-metadata">
|
|
Hide linked meta-data
|
|
</label>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
Displaying <strong>{{totalDownloads}}</strong> of <em>{{totalAria2Downloads()}}</em> downloads
|
|
</p>
|
|
<p>
|
|
<button ng-click="toggleStateFilters()" class="btn btn-default btn-xs">Toggle</button>
|
|
<button ng-click="resetFilters()" class="btn btn-default btn-xs">Reset filters</button>
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
<!-- }}} -->
|
|
|
|
<br>
|
|
|
|
|
|
<!-- {{{ starred properties -->
|
|
<ul class="clearfix nav nav-list" ng-controller="StarredPropsCtrl" ng-show="properties.length && enable.sidebar.starredProps">
|
|
<li class="nav-header">Quick Access Settings</li>
|
|
<li ng-repeat="prop in properties" class="form-group">
|
|
<label title="{{prop.desc}}" style="width: 100%;">{{prop.name}}</label>
|
|
<div class="form-group">
|
|
<select style="width: 100%;" ng-show="prop.options.length" class="form-control" ng-options="opt for opt in prop.options" ng-model="prop.val"></select>
|
|
<input style="width: 100%;" ng-show="!prop.options.length" type="text" class="form-control input-large" ng-model="prop.val"/>
|
|
</div>
|
|
</li>
|
|
<li>
|
|
<button ng-disabled="!enabled()" ng-click="save()" class="btn btn-default btn-sm">Save settings</button>
|
|
</li>
|
|
</ul>
|
|
<!-- }}} -->
|
|
|
|
|
|
</div>
|
|
<!-- }}} -->
|
|
</div>
|
|
|
|
<div ng-class="{'col-md-9': enable.sidebar.show, 'col-md-12': !enable.sidebar.show }">
|
|
<!-- {{{ downloads -->
|
|
<!-- Bug?? <div ng-show="!totalAria2Downloads() && totalAria2Downloads() > getDownloads()" class="hero-unit">-->
|
|
<div ng-show="!totalAria2Downloads()" class="jumbotron">
|
|
Currently no download in line to display, use the '<strong>Add</strong>' download button to start downloading files!
|
|
</div>
|
|
|
|
|
|
<!-- {{{ download template -->
|
|
|
|
<div
|
|
ng-repeat="download in getDownloads()"
|
|
class="row-fluid download well" data-gid="{{download.gid}}"
|
|
ng-click="toggleCollapsed(download)">
|
|
<div class="download-name download-item download-controls">
|
|
<!-- {{{ download control buttons -->
|
|
<div class="btn-group" role="group" ng-click="$event.stopPropagation()">
|
|
<button
|
|
ng-if="hasStatus(download, ['active', 'waiting'])"
|
|
class="btn btn-default"
|
|
ng-click="pause(download)">
|
|
<span class="fa fa-fw fa-pause"></span>
|
|
</button>
|
|
|
|
<button
|
|
ng-if="hasStatus(download, 'paused')"
|
|
class="btn btn-default"
|
|
ng-click="resume(download)">
|
|
<span class="fa fa-fw fa-play"></span>
|
|
</button>
|
|
|
|
<button
|
|
ng-if="canRestart(download)"
|
|
class="btn btn-default"
|
|
ng-click="restart(download)">
|
|
<span class="fa fa-fw fa-repeat"></span>
|
|
</button>
|
|
|
|
<button
|
|
class="btn btn-default hidden-phone"
|
|
ng-click="remove(download)">
|
|
<span class="fa fa-fw fa-stop"></span>
|
|
</button>
|
|
|
|
<button
|
|
ng-if="hasStatus(download, 'paused')"
|
|
class="btn btn-default"
|
|
ng-click="selectFiles(download)">
|
|
<span class="fa fa-fw fa-list"></span>
|
|
</button>
|
|
|
|
<button
|
|
class="btn btn-default hidden-phone"
|
|
ng-if="['waiting', 'active'].indexOf( getType(download) )!= -1"
|
|
ng-click="showSettings(download)">
|
|
<span class="fa fa-fw fa-cog"></span>
|
|
</button>
|
|
|
|
<div class="btn-group" dropdown>
|
|
<button class="btn btn-default dropdown-toggle" dropdown-toggle>
|
|
<span class="caret"></span>
|
|
</button>
|
|
<ul class="dropdown-menu pull-right">
|
|
|
|
<li class="visible-phone">
|
|
<a
|
|
ng-click="showSettings(download)"
|
|
ng-show="['waiting', 'active'].indexOf( getType(download) )!= -1"
|
|
href="#"><span class="fa fa-fw fa-cog"> </span> Settings</a>
|
|
</li>
|
|
|
|
<li ng-show="download.bittorrent && false">
|
|
<a href="#"><span class="fa fa-fw fa-list-alt"> </span> Peers</a>
|
|
</li>
|
|
|
|
<li>
|
|
<a ng-click="toggleCollapsed(download)"
|
|
href="#"><span class="fa fa-fw fa-info-circle"> </span> More Info</a>
|
|
</li>
|
|
|
|
<li class="visible-phone">
|
|
<a ng-click="remove(download)"
|
|
href="#"><span class="fa fa-fw fa-times"> </span> Remove</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
<!-- }}} -->
|
|
|
|
<div class="title">
|
|
<span class="fa fa-fw fa-magnet" style="color: red;" ng-show="download.metadata"></span>
|
|
{{download.name}}
|
|
</div>
|
|
</div>
|
|
<div class="download-overview download-item" ng-switch="download.status">
|
|
<!-- {{{ statistics -->
|
|
<ul class="stats pull-left" ng-switch-when="active">
|
|
<!-- {{{ active download statistics -->
|
|
<li class="label label-active hidden-phone hidden-tablet">
|
|
<span title="Download status"><span class="fa fa-fw fa-play"> </span> {{download.status}}</span>
|
|
</li>
|
|
|
|
<li class="label label-default" ng-class="{'label-active': download.downloadSpeed > 2048, 'label-warning': download.downloadSpeed <= 2048}">
|
|
<span title="Download Speed"><span class="fa fa-fw fa-arrow-circle-o-down"> </span> {{download.downloadSpeed | bspeed}}</span>
|
|
</li>
|
|
|
|
<li ng-show="download.bittorrent" class="label label-default hidden-phone" ng-class="{'label-info': download.uploadSpeed > 2048}">
|
|
<span title="Upload Speed"><span class="fa fa-fw fa-arrow-circle-o-up"> </span> {{download.uploadSpeed | bspeed}}</span>
|
|
</li>
|
|
|
|
<li class="label label-active">
|
|
<span title="Estimated time"><span class="fa fa-fw fa-clock-o"> </span> {{getEta(download) | time}}</span>
|
|
</li>
|
|
|
|
<li class="label label-active hidden-phone">
|
|
<span title="Download Size"><span class="fa fa-fw fa-cloud-download"> </span> {{download.fmtTotalLength}}</span>
|
|
</li>
|
|
|
|
<li class="label label-active hidden-phone">
|
|
<span title="Downloaded"><span class="fa fa-fw fa-arrow-circle-o-down"> </span> {{download.fmtCompletedLength}}</span>
|
|
</li>
|
|
|
|
<li class="label label-active hidden-phone hidden-tablet">
|
|
<span title="Progress"><span class="fa fa-fw fa-chevron-right"> </span> {{getProgress(download)}}%</span>
|
|
</li>
|
|
|
|
<!-- }}} -->
|
|
</ul>
|
|
|
|
<ul class="stats pull-left" ng-switch-when="paused">
|
|
<!-- {{{ paused download statistics -->
|
|
<li class="label label-info">
|
|
<span title="Download Status"><span class="fa fa-fw fa-pause"> </span> {{download.status}}</span>
|
|
</li>
|
|
|
|
<li class="label label-info">
|
|
<span title="Download Size"><span class="fa fa-fw fa-cloud-download"> </span> {{download.fmtTotalLength}}</span>
|
|
</li>
|
|
|
|
<li class="label label-info hidden-phone">
|
|
<span title="Downloaded"><span class="fa fa-fw fa-download"> </span> {{download.fmtCompletedLength}}</span>
|
|
</li>
|
|
|
|
<li class="label label-info hidden-phone">
|
|
<span title="Download Path"><span class="fa fa-fw fa-folder-open"> </span> {{download.dir}}</span>
|
|
</li>
|
|
|
|
<!-- }}} -->
|
|
</ul>
|
|
|
|
<ul class="stats pull-left" ng-switch-when="waiting">
|
|
<!-- {{{ paused download statistics -->
|
|
<li class="label label-default">
|
|
<span title="Download Status"><span class="fa fa-fw fa-caret-right"> </span> {{download.status}}</span>
|
|
</li>
|
|
|
|
<li class="label label-default">
|
|
<span title="Download Size"><span class="fa fa-fw fa-cloud-download"> </span> {{download.fmtTotalLength}}</span>
|
|
</li>
|
|
|
|
<li class="label label-default hidden-phone">
|
|
<span title="Downloaded"><span class="fa fa-fw fa-download"> </span> {{download.fmtCompletedLength}}</span>
|
|
</li>
|
|
|
|
<li class="label label-default hidden-phone">
|
|
<span title="Download Path"><span class="fa fa-fw fa-folder-open"> </span> {{download.dir}}</span>
|
|
</li>
|
|
|
|
<!-- }}} -->
|
|
</ul>
|
|
|
|
<ul class="stats pull-left" ng-switch-when="complete">
|
|
<!-- {{{ complete download statistics -->
|
|
|
|
<li class="label label-success">
|
|
<span title="Download Status"><span class="fa fa-fw fa-check-square-o"> </span> {{download.status}}</span>
|
|
</li>
|
|
|
|
<li class="label label-success">
|
|
<span title="Download Size"><span class="fa fa-fw fa-cloud-download"> </span> {{download.fmtTotalLength}}</span>
|
|
</li>
|
|
|
|
<li class="label label-success hidden-phone">
|
|
<span title="Download Path"><span class="fa fa-fw fa-folder-open"> </span> {{download.dir}}</span>
|
|
</li>
|
|
|
|
<!-- }}} -->
|
|
</ul>
|
|
|
|
<ul class="stats pull-left" ng-switch-when="removed">
|
|
<!-- {{{ removed download statistics -->
|
|
<li class="label label-warning">
|
|
<span title="Download Status"><span class="fa fa-fw fa-times"> </span> {{download.status}}</span>
|
|
</li>
|
|
|
|
<li class="label label-warning">
|
|
<span title="Download Size"><span class="fa fa-fw fa-cloud-download"> </span> {{download.fmtTotalLength}}</span>
|
|
</li>
|
|
|
|
<li class="label label-warning hidden-phone">
|
|
<span title="Download Path"><span class="fa fa-fw fa-folder-open"> </span> {{download.dir}}</span>
|
|
</li>
|
|
|
|
<!-- }}} -->
|
|
</ul>
|
|
|
|
<ul class="stats pull-left" ng-switch-when="error">
|
|
<!-- {{{ error download statistics -->
|
|
<li class="label label-important">
|
|
<span title="Download Status"><span class="fa fa-fw fa-times-circle"> </span> {{download.status}}</span>
|
|
</li>
|
|
|
|
<li class="label label-important">
|
|
<span title="Download Size"><span class="fa fa-fw fa-cloud-download"> </span> {{download.fmtTotalLength}}</span>
|
|
</li>
|
|
|
|
<li class="label label-important hidden-phone">
|
|
<span title="Download Path"><span class="fa fa-fw fa-folder-open"> </span> {{download.dir}}</span>
|
|
</li>
|
|
|
|
<!-- }}} -->
|
|
</ul>
|
|
|
|
<!-- }}} -->
|
|
</div>
|
|
<div class="download-progress download-item">
|
|
<div class="progress">
|
|
<div ng-class="'progress-bar progress-bar-striped ' + getProgressClass(download)" style="width: {{getProgress(download)}}%;"></div>
|
|
</div>
|
|
</div>
|
|
<div ng-switch="download.collapsed">
|
|
<div ng-switch-when="false" collapse="download.animCollapsed">
|
|
<div class="download-item" ng-show="download.numPieces > 1">
|
|
<canvas bitfield="download.bitfield" draw="!download.collapsed" pieces="download.numPieces" class="progress chunk-canvas" width="1400" chunkbar></canvas>
|
|
</div>
|
|
<ul class="stats download-item">
|
|
<li class="label label-default" title="Estimated Time"><i class="fa fa-fw fa-clock-o"> </i> <span class="download-eta">{{getEta(download) | time}}</span></li>
|
|
<li class="label label-default" title="Download Size"><i class="fa fa-fw fa-cloud-download"> </i> <span class="download-totalLength">{{download.fmtTotalLength}}</span></li>
|
|
<li class="label label-default" title="Downloaded"><i class="fa fa-fw fa-download"> </i> <span class="download-completedLength">{{download.fmtCompletedLength}}</span></li>
|
|
<li class="label label-default" title="Download Speed"><i class="fa fa-fw fa-arrow-circle-o-down"> </i> <span class="download-downloadSpeed">{{download.fmtDownloadSpeed}}</span></li>
|
|
|
|
<li class="label label-default" title="Upload Speed" ng-show="download.bittorrent"><i class="fa fa-fw fa-arrow-circle-o-up"> </i> <span class="download-uploadSpeed">{{download.fmtUploadSpeed}}</span></li>
|
|
<li class="label label-default" title="Uploaded" ng-show="download.bittorrent"><i class="fa fa-fw fa-upload"> </i> <span class="download-uploadLength">{{download.fmtUploadLength}}</span></li>
|
|
|
|
<li class="label label-default" title="Connections"><i class="fa fa-fw fa-link"> </i> <span class="download-connections">{{download.connections}}</span></li>
|
|
|
|
<li class="label label-default" title="Download GID"><i class="fa fa-fw fa-bars"> </i> <span class="download-gid">{{download.gid}}</span></li>
|
|
<li class="label label-default" title="Number of Pieces"># of <i class="fa fa-fw fa-puzzle-piece"> </i> <span class="download-numPieces">{{download.numPieces}}</span></li>
|
|
<li class="label label-default" title="Piece Length"><i class="fa fa-fw fa-puzzle-piece"></i> Length <span class="download-pieceLength">{{download.fmtPieceLength}}</span></li>
|
|
<li class="label label-default" title="Download Path"><i class="fa fa-fw fa-folder-open"> </i> <span class="download-dir">{{download.dir}}</span></li>
|
|
</ul>
|
|
<ul class="download-files hidden-phone download-item">
|
|
<li class="label label-default" ng-repeat="file in download.files" ng-class="{'label-success': file.selected}">{{file.relpath}} ({{file.fmtLength}})</li>
|
|
</ul>
|
|
<div ng-show="hasStatus(download, 'active')" class="download-item hidden-phone">
|
|
<div class="download-graph" dspeed="download.downloadSpeed" uspeed="download.uploadSpeed" xticks="7" yticks="7" dgraph draw="!download.collapsed"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- }}} -->
|
|
|
|
<!-- }}} -->
|
|
</div>
|
|
|
|
<!-- {{{ download pagination -->
|
|
<div class="col-md-offset-3 col-md-9" ng-show="totalDownloads > pageSize">
|
|
<div class="pagination pull-right">
|
|
<pagination
|
|
total-items="totalDownloads"
|
|
items-per-page="pageSize"
|
|
max-size="11"
|
|
ng-model="currentPage"
|
|
boundary-links="true"
|
|
previous-text="‹"
|
|
next-text="›"
|
|
first-text="«"
|
|
last-text="»"
|
|
>
|
|
</pagination>
|
|
</div>
|
|
</div>
|
|
<!-- }}} -->
|
|
|
|
</div>
|
|
</div>
|
|
|
|
<!-- }}} -->
|
|
|
|
<!-- {{{ modals -->
|
|
<div ng-controller="ModalCtrl">
|
|
|
|
<!--{{{ add uri modal -->
|
|
<script type="text/ng-template" id="getUris.html">
|
|
<div class="modal-header">
|
|
<button class="close" ng-click="$dismiss()">×</button>
|
|
<h4>Add Downloads By URIs</h4>
|
|
</div>
|
|
<form class="modal-body">
|
|
<fieldset>
|
|
<legend>Download URIs</legend>
|
|
<p class="help-block">
|
|
- You can add multiple downloads (files)
|
|
at the same time by putting uris for each
|
|
file on a separate line. <br>
|
|
- You can also add multiple uris (mirrors) for the
|
|
*same* file. To do this separate the uris
|
|
by a space. <br>
|
|
- Additional options can be specified for individual
|
|
files, in "--option[=value]" format. <br>
|
|
- A URI can be HTTP(S)/FTP/BitTorrent Magnet URI. </br>
|
|
- Aria2 will use multiple uris (or mirrors) to boost
|
|
the download speed for that file (download). <br>
|
|
E.g. To add 2 files (downloads) f1.jpg
|
|
and f2.mp4 with 2 uris (mirrors) each,
|
|
add uris as following:
|
|
<br>
|
|
<!-- pre tags print tabs, so do not indent them! -->
|
|
<pre>
|
|
http://ex1.com/f1.jpg http://ex2.com/f1.jpg
|
|
http://ex1.com/f2.mp4 http://ex2.com/f2.mp4 --out=file2.mp4
|
|
</pre>
|
|
</p>
|
|
<textarea rows="4" style="width: 100%" ng-model="getUris.uris"></textarea>
|
|
|
|
<br /><br />
|
|
|
|
<div>
|
|
<div class="modal-advanced-title">
|
|
Download settings
|
|
</div>
|
|
<div class="form-horizontal modal-advanced-options">
|
|
<div class="form-group" ng-repeat="(name, set) in getUris.settings">
|
|
<label class="col-sm-3 control-label">{{name}}</label>
|
|
|
|
<div class="col-sm-9 controls">
|
|
<select class="form-control" ng-show="set.options.length" ng-options="opt for opt in set.options" ng-model="set.val">
|
|
</select>
|
|
<input ng-show="!set.options.length" type="text" class="form-control input-xxlarge modal-form-input-verylarge" ng-model="set.val"/>
|
|
</div>
|
|
<br>
|
|
</div>
|
|
</div>
|
|
|
|
<br />
|
|
<div ng-click="getUris.collapsed = !getUris.collapsed" class="modal-advanced-title">
|
|
Advanced settings
|
|
<i ng-hide="!getUris.collapsed" class="fa fa-fw fa-caret-right"></i>
|
|
<i ng-hide="getUris.collapsed" class="fa fa-fw fa-caret-down"></i>
|
|
</div>
|
|
<div collapse="getUris.collapsed" class="form-horizontal modal-advanced-options">
|
|
<div class="form-group" ng-repeat="(name, set) in getUris.fsettings">
|
|
<p class="col-sm-offset-3 col-sm-9 help-block controls">{{set.desc}}</p>
|
|
|
|
<label class="col-sm-3 control-label">{{name}}</label>
|
|
<div class="col-sm-9 controls">
|
|
<select class="form-control" ng-show="set.options.length" ng-options="opt for opt in set.options" ng-model="set.val">
|
|
</select>
|
|
<input ng-show="!set.options.length" type="text" class="form-control input-xxlarge modal-form-input-verylarge" ng-model="set.val"/>
|
|
</div>
|
|
<br />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</fieldset>
|
|
</form>
|
|
<div class="modal-footer">
|
|
<button class="btn btn-default" ng-click="$dismiss()">Cancel</button>
|
|
<button class="btn btn-default btn-primary" ng-click="$close()">Start</button>
|
|
</div>
|
|
</script>
|
|
<!-- }}} -->
|
|
|
|
<!-- {{{ add torrent modal -->
|
|
<script type="text/ng-template" id="getTorrents.html">
|
|
<div class="modal-header">
|
|
<button class="close" ng-click="$dismiss()">x</button>
|
|
<h4>Add Downloads By Torrents</h4>
|
|
</div>
|
|
<form class="modal-body">
|
|
<fieldset>
|
|
<legend>Select Torrents</legend>
|
|
<p class="help-block">
|
|
- Select the torrent from the local filesystem to start the download. <br>
|
|
- You can select multiple torrents to start multiple downloads <br>
|
|
- To add a magnet torrent url, use the add url option and add it there.
|
|
</p>
|
|
<div class="form-horizontal form-group">
|
|
<label class="control-label" style="text-align: left;"><b>Select a Torrent:</b></label>
|
|
<div class="controls">
|
|
<input type="file" class="input-xlarge" fselect="getTorrents.files" multiple/>
|
|
</div>
|
|
</div>
|
|
<br />
|
|
|
|
<div>
|
|
<div class="modal-advanced-title">
|
|
Download settings
|
|
</div>
|
|
<div class="form-horizontal modal-advanced-options">
|
|
<div class="form-group" ng-repeat="(name, set) in getTorrents.settings">
|
|
<label class="col-sm-3 control-label">{{name}}</label>
|
|
|
|
<div class="col-sm-9 controls">
|
|
<select class="form-control" ng-show="set.options.length" ng-options="opt for opt in set.options" ng-model="set.val">
|
|
</select>
|
|
<input ng-show="!set.options.length" type="text" class="form-control input-xxlarge modal-form-input-verylarge" ng-model="set.val"/>
|
|
</div>
|
|
<br>
|
|
</div>
|
|
</div>
|
|
|
|
<br />
|
|
<div ng-click="getTorrents.collapsed = !getTorrents.collapsed" class="modal-advanced-title">
|
|
Advanced settings
|
|
<i ng-hide="!getTorrents.collapsed" class="fa fa-fw fa-caret-right"></i>
|
|
<i ng-hide="getTorrents.collapsed" class="fa fa-fw fa-caret-down"></i>
|
|
</div>
|
|
<div collapse="getTorrents.collapsed" class="form-horizontal modal-advanced-options">
|
|
<div class="form-group" ng-repeat="(name, set) in getTorrents.fsettings">
|
|
<p class="col-sm-offset-3 col-sm-9 help-block controls">{{set.desc}}</p>
|
|
|
|
<label class="col-sm-3 control-label">{{name}}</label>
|
|
<div class="col-sm-9 controls">
|
|
<select class="form-control" ng-show="set.options.length" ng-options="opt for opt in set.options" ng-model="set.val">
|
|
</select>
|
|
<input ng-show="!set.options.length" type="text" class="form-control input-xxlarge modal-form-input-verylarge" ng-model="set.val"/>
|
|
</div>
|
|
<br />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</fieldset>
|
|
</form>
|
|
<div class="modal-footer">
|
|
<button class="btn btn-default" ng-click="$dismiss()">Cancel</button>
|
|
<button class="btn btn-default btn-primary" ng-click="$close()">Start</button>
|
|
</div>
|
|
</script>
|
|
<!-- }}} -->
|
|
|
|
<!-- {{{ add metalink modal -->
|
|
<script type="text/ng-template" id="getMetalinks.html">
|
|
<div class="modal-header">
|
|
<button class="close" ng-click="$dismiss()">x</button>
|
|
<h4>Add Downloads By Metalinks</h4>
|
|
</div>
|
|
<form class="modal-body">
|
|
<fieldset>
|
|
<legend>Select Metalinks</legend>
|
|
<p class="help-block">
|
|
- Select the metalink from the local filesystem to start the download. <br>
|
|
- You can select multiple metalinks to start multiple downloads
|
|
</p>
|
|
<div class="form-horizontal form-group">
|
|
<label class="control-label" style="text-align: left;"><b>Select a Metalinks:</b></label>
|
|
<div class="controls">
|
|
<input type="file" class="input-xlarge" fselect="getMetalinks.files" multiple/>
|
|
</div>
|
|
</div>
|
|
<br />
|
|
|
|
<div>
|
|
<div class="modal-advanced-title">
|
|
Download settings
|
|
</div>
|
|
<div class="form-horizontal modal-advanced-options">
|
|
<div class="form-group" ng-repeat="(name, set) in getMetalinks.settings">
|
|
<label class="col-sm-3 control-label">{{name}}</label>
|
|
|
|
<div class="col-sm-9 controls">
|
|
<select class="form-control" ng-show="set.options.length" ng-options="opt for opt in set.options" ng-model="set.val">
|
|
</select>
|
|
<input ng-show="!set.options.length" type="text" class="form-control input-xxlarge modal-form-input-verylarge" ng-model="set.val"/>
|
|
</div>
|
|
<br>
|
|
</div>
|
|
</div>
|
|
|
|
<br />
|
|
<div ng-click="getMetalinks.collapsed = !getMetalinks.collapsed" class="modal-advanced-title">
|
|
Advanced settings
|
|
<i ng-hide="!getMetalinks.collapsed" class="fa fa-fw fa-caret-right"></i>
|
|
<i ng-hide="getMetalinks.collapsed" class="fa fa-fw fa-caret-down"></i>
|
|
</div>
|
|
<div collapse="getMetalinks.collapsed" class="form-horizontal modal-advanced-options">
|
|
<div class="form-group" ng-repeat="(name, set) in getMetalinks.fsettings">
|
|
<p class="col-sm-offset-3 col-sm-9 help-block controls">{{set.desc}}</p>
|
|
|
|
<label class="col-sm-3 control-label">{{name}}</label>
|
|
<div class="col-sm-9 controls">
|
|
<select class="form-control" ng-show="set.options.length" ng-options="opt for opt in set.options" ng-model="set.val">
|
|
</select>
|
|
<input ng-show="!set.options.length" type="text" class="form-control input-xxlarge modal-form-input-verylarge" ng-model="set.val"/>
|
|
</div>
|
|
<br />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</fieldset>
|
|
</form>
|
|
<div class="modal-footer">
|
|
<button class="btn btn-default" ng-click="$dismiss()">Cancel</button>
|
|
<button class="btn btn-default btn-primary" ng-click="$close()">Start</button>
|
|
</div>
|
|
</script>
|
|
<!-- }}} -->
|
|
|
|
<!-- {{{ select file modal -->
|
|
<script type="text/ng-template" id="selectFiles.html">
|
|
<div class="modal-header">
|
|
<button class="close" ng-click="$dismiss()">x</button>
|
|
<h4>Choose files to start download for</h4>
|
|
</div>
|
|
|
|
<form class="form-horizontal modal-body">
|
|
<fieldset>
|
|
<div class="form-group">
|
|
<div ng-repeat="file in selectFiles.files">
|
|
<label class="control-label">Select to download </label>
|
|
|
|
<div class="controls">
|
|
<label class="checkbox">
|
|
<input type="checkbox" ng-model="file.selected"/>{{file.relpath}}
|
|
</label>
|
|
</div>
|
|
<br><br>
|
|
</div>
|
|
</div>
|
|
</fieldset>
|
|
</form>
|
|
|
|
<div class="modal-footer">
|
|
<button class="btn btn-default" ng-click="$dismiss()">Cancel</button>
|
|
<button class="btn btn-default btn-primary" ng-click="$close()">Choose</button>
|
|
</div>
|
|
</script>
|
|
<!-- }}} -->
|
|
|
|
<!-- {{{ settings modal -->
|
|
<script type="text/ng-template" id="settings.html">
|
|
<div class="modal-header">
|
|
<button class="close" ng-click="$dismiss()">x</button>
|
|
<h4>{{settings.title}}</h4>
|
|
</div>
|
|
|
|
<div class="modal-body">
|
|
<form class="form-horizontal">
|
|
<fieldset>
|
|
<div class="form-group" ng-repeat="(name, set) in settings.settings">
|
|
<label class="col-sm-3 control-label">{{name}}</label>
|
|
|
|
<div class="col-sm-9 controls">
|
|
<select class="form-control" ng-show="set.options.length" ng-options="opt for opt in set.options" ng-model="set.val">
|
|
</select>
|
|
<input ng-show="!set.options.length" type="text" class="form-control input-xlarge" ng-model="set.val"/>
|
|
<div class="checkbox" ng-show="set.starred != undefined">
|
|
<label>
|
|
<input type="checkbox" ng-model="set.starred"/>
|
|
Quick Access (shown on the main page)
|
|
</label>
|
|
</div>
|
|
<p class="help-block">{{set.desc}}</p>
|
|
</div>
|
|
</div>
|
|
</fieldset>
|
|
</form>
|
|
</div>
|
|
|
|
<div class="modal-footer">
|
|
<button class="btn btn-default" ng-click="$dismiss()">Cancel</button>
|
|
<button class="btn btn-default btn-primary" ng-click="$close()">{{settings.actionText}}</button>
|
|
</div>
|
|
</script>
|
|
<!-- }}} -->
|
|
|
|
<!--{{{ connection modal -->
|
|
<script type="text/ng-template" id="connection.html">
|
|
<div class="modal-header">
|
|
<button class="close" ng-click="$dismiss()">x</button>
|
|
<h4>Connection Settings</h4>
|
|
</div>
|
|
<div class="modal-body">
|
|
<form class="form-horizontal">
|
|
<fieldset>
|
|
<legend>Aria2 RPC host and port</legend>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label">Enter the host:</label>
|
|
<div class="col-sm-9 controls">
|
|
<div class="input-group">
|
|
<span class="input-group-addon">http(s)://</span>
|
|
<input type="text" class="form-control input-xlarge"
|
|
ng-model="connection.conf.host"/>
|
|
</div>
|
|
<p class="help-block">
|
|
Enter the ip or dns name of the server on which the
|
|
rpc for aria2 is running (default = localhost)
|
|
</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label">Enter the port:</label>
|
|
<div class="col-sm-9 controls">
|
|
<input type="text" class="form-control input-xlarge modal-form-input-number"
|
|
ng-model="connection.conf.port"/>
|
|
<p class="help-block">
|
|
Enter the port of the server on which the rpc for
|
|
aria2 is running (default = 6800)
|
|
</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label">SSL/TLS encryption:</label>
|
|
<div class="col-sm-9 controls">
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" ng-model="connection.conf.encrypt"/>
|
|
Enable SSL/TLS encryption.
|
|
</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label">Enter the secret token (optional):</label>
|
|
<div class="col-sm-9 controls">
|
|
<label>
|
|
<input type="text" class="form-control input-xlarge" ng-model="connection.conf.auth.token"/>
|
|
<p class="help-block">
|
|
Enter the aria2 RPC secret token (leave empty if authentication is not enabled)
|
|
</p>
|
|
</label>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label">Enter the username (optional):</label>
|
|
<div class="col-sm-9 controls">
|
|
<input type="text" class="form-control input-xlarge"
|
|
ng-model="connection.conf.auth.user"/>
|
|
<p class="help-block">
|
|
Enter the aria2 RPC username
|
|
(empty if authentication not enabled)
|
|
</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label">Enter the password (optional):</label>
|
|
<div class="col-sm-9 controls">
|
|
<input type="password" class="form-control input-xlarge"
|
|
ng-model="connection.conf.auth.pass"/>
|
|
<p class="help-block">
|
|
Enter the aria2 RPC password
|
|
(empty if authentication not enabled)
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</fieldset>
|
|
</form>
|
|
</div>
|
|
<div class="modal-footer">
|
|
<button href="#" class="btn btn-default" ng-click="$dismiss()">Cancel</button>
|
|
<button href="#" class="btn btn-default btn-primary" ng-click="$close()">
|
|
Save Connection configuration
|
|
</button>
|
|
</div>
|
|
</script>
|
|
<!-- }}} -->
|
|
|
|
|
|
<!-- {{{ server info modal -->
|
|
<script type="text/ng-template" id="server_info.html">
|
|
<div class="modal-header">
|
|
<button class="close" ng-click="$dismiss()">x</button>
|
|
<h4>Aria2 server info</h4>
|
|
</div>
|
|
<div class="modal-body">
|
|
<b>Aria2 Version {{miscellaneous.version}}</b>
|
|
<br><br>
|
|
<b>Features Enabled</b>
|
|
<ul>
|
|
<li
|
|
ng-repeat="feature in miscellaneous.enabledFeatures">
|
|
<span>{{feature}}</span>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
<div class="modal-footer">
|
|
<button class="btn btn-default" ng-click="$dismiss()">Close</button>
|
|
</div>
|
|
</script>
|
|
<!-- }}} -->
|
|
|
|
<!-- {{{ about modal -->
|
|
<script type="text/ng-template" id="about.html">
|
|
<div class="modal-header">
|
|
<button class="close" ng-click="$dismiss()">x</button>
|
|
<h4>About and contribute</h4>
|
|
</div>
|
|
<div class="modal-body">
|
|
<p>
|
|
To download the latest version of the project,<br />
|
|
add issues or to contribute back head on to:<br />
|
|
<a href="https://github.com/ziahamza/webui-aria2">http://github.com/ziahamza/webui-aria2</a>
|
|
<br /><br />
|
|
Or you can open the latest version in browser through:<br />
|
|
<a href="http://ziahamza.github.io/webui-aria2">http://ziahamza.github.io/webui-aria2</a>
|
|
</p>
|
|
</div>
|
|
<div class="modal-footer">
|
|
<button class="btn btn-default" ng-click="$dismiss()">Close</button>
|
|
</div>
|
|
</script>
|
|
<!-- }}} -->
|
|
|
|
|
|
</div>
|
|
<!-- }}} -->
|
|
|
|
<!-- Bottom Padding -->
|
|
<br /><br /><br /><br /><br />
|
|
|
|
</body>
|
|
</html>
|