mirror of
https://github.com/codex-storage/deluge.git
synced 2025-01-11 20:14:13 +00:00
Update Changelog, translation files and compress js
This commit is contained in:
parent
19bbf5ac8f
commit
bd979da949
45
ChangeLog
45
ChangeLog
@ -44,6 +44,51 @@
|
||||
=== Deluge 1.3.6 (In Development) ===
|
||||
==== Core ====
|
||||
* Catch & log KeyError when removing a torrent from the queued torrents set
|
||||
* Fix moving/renaming torrents with non-ascii characters in libtorrent 0.16
|
||||
* Make sure queue order is preserved when restarting
|
||||
* #2160: Disable use of python bindings for libtorrent extensions and replace with session flag
|
||||
* #2163: Fix unable add torrent file with empty (0:) encoding tag
|
||||
* #2201: Fix error in authmanager if auth file has extra newlines
|
||||
|
||||
==== GtkUI ====
|
||||
* Add move completed option to add torrent dialog
|
||||
* Prevent jitter in torrent view
|
||||
* Fix torrent creation with non-ascii characters
|
||||
* Fix #2100 : Add option not to bring main window to front when adding torrents through ipcinterface
|
||||
* Add Quit Dialog when toggling classic mode in preferences and only show connection manager when not in classic mode.
|
||||
* #2169: Fix 'Download Location' in the Add Torrent Dialog not set correctly when folder typed into Other->Location field
|
||||
* #2171: Fix the Add Peer dialog not responding if empty or invalid values entered
|
||||
* #2104: Fix no title set for the appindicator
|
||||
* #2086: Fix submenus and icons for appindicator
|
||||
|
||||
==== Console ====
|
||||
* LP#1004793: Enable use of connect command in non-interactive mode
|
||||
* Ensure console commands are executed in order
|
||||
* #2065: Fix crash with missing closing quote
|
||||
* #1397: Add support for -s STATE in info command
|
||||
|
||||
==== WebUI ====
|
||||
* #2112: Fix world readable tmp directory in json_api
|
||||
* #2069: Fix login window layout problem when using larger than default font size
|
||||
* #1890: Fix columns in files and peers view could use some spacing
|
||||
* #2103: Fix sorting by name is case-sensitive [sedulous]
|
||||
* #2120: Fix manually entered values not being saved in spinners
|
||||
* #2212: Fix unable to scroll in proxy preferences page
|
||||
* Fix autoconnecting to the default host
|
||||
|
||||
==== Windows OS ====
|
||||
* Hide the cmd windows when running deluged.exe or deluge-web.exe
|
||||
* Add deluged-debug.exe and deluge-web-debug.exe that still show the cmd window
|
||||
* Add gtk locale files to fix untranslated text
|
||||
* Fix the Open Folder option not working with non-ascii paths
|
||||
* Fix the daemon starting with config dir containing spaces
|
||||
* Fix Windows tray submenu items requiring right-click instead of left-click
|
||||
|
||||
==== OS X ====
|
||||
* Fix Open File/Folder option
|
||||
|
||||
==== Execute ====
|
||||
* Fix execute plugin not working with unicode torrent names
|
||||
|
||||
=== Deluge 1.3.5 (09 April 2012) ===
|
||||
==== GtkUI ====
|
||||
|
@ -212,7 +212,7 @@ GetText.add('Create', '${escape(_("Create"))}')
|
||||
// Menus.js:103
|
||||
GetText.add('D/L Speed Limit', '${escape(_("D/L Speed Limit"))}')
|
||||
|
||||
// NetworkPage.js:225, ProxyPage.js:69
|
||||
// NetworkPage.js:225, ProxyPage.js:70
|
||||
GetText.add('DHT', '${escape(_("DHT"))}')
|
||||
|
||||
// Statusbar.js:210
|
||||
@ -308,7 +308,7 @@ GetText.add('File Browser', '${escape(_("File Browser"))}')
|
||||
// OptionsPanel.js:143
|
||||
GetText.add('File prioritization is unavailable when using Compact allocation. Would you like to switch to Full allocation?', '${escape(_("File prioritization is unavailable when using Compact allocation. Would you like to switch to Full allocation?"))}')
|
||||
|
||||
// FilesTab.js:41, FilesTab.js:50
|
||||
// FilesTab.js:40, FilesTab.js:50
|
||||
GetText.add('Filename', '${escape(_("Filename"))}')
|
||||
|
||||
// FilesTab.js:35, FilesTab.js:41
|
||||
@ -428,7 +428,7 @@ GetText.add('Location', '${escape(_("Location"))}')
|
||||
// LoginWindow.js:45, LoginWindow.js:54
|
||||
GetText.add('Login', '${escape(_("Login"))}')
|
||||
|
||||
// LoginWindow.js:127
|
||||
// LoginWindow.js:130
|
||||
GetText.add('Login Failed', '${escape(_("Login Failed"))}')
|
||||
|
||||
// Toolbar.js:114
|
||||
@ -545,7 +545,7 @@ GetText.add('Path', '${escape(_("Path"))}')
|
||||
// Menus.js:88, Toolbar.js:70
|
||||
GetText.add('Pause', '${escape(_("Pause"))}')
|
||||
|
||||
// ProxyPage.js:51
|
||||
// ProxyPage.js:52
|
||||
GetText.add('Peer', '${escape(_("Peer"))}')
|
||||
|
||||
// NetworkPage.js:212
|
||||
@ -590,7 +590,7 @@ GetText.add('Prioritize First/Last Pieces', '${escape(_("Prioritize First/Last P
|
||||
// DownloadsPage.js:140
|
||||
GetText.add('Prioritize first and last pieces of torrent', '${escape(_("Prioritize first and last pieces of torrent"))}')
|
||||
|
||||
// FilesTab.js:61
|
||||
// FilesTab.js:60
|
||||
GetText.add('Priority', '${escape(_("Priority"))}')
|
||||
|
||||
// OptionsTab.js:300
|
||||
@ -599,7 +599,7 @@ GetText.add('Private', '${escape(_("Private"))}')
|
||||
// InterfacePage.js:166
|
||||
GetText.add('Private Key', '${escape(_("Private Key"))}')
|
||||
|
||||
// TorrentGrid.js:128, FilesTab.js:53
|
||||
// TorrentGrid.js:128, FilesTab.js:52
|
||||
GetText.add('Progress', '${escape(_("Progress"))}')
|
||||
|
||||
// Statusbar.js:200
|
||||
@ -695,7 +695,7 @@ GetText.add('Show filters with zero torrents', '${escape(_("Show filters with ze
|
||||
// InterfacePage.js:64
|
||||
GetText.add('Show session speed in titlebar', '${escape(_("Show session speed in titlebar"))}')
|
||||
|
||||
// TorrentGrid.js:122, FilesTab.js:45, FilesTab.js:54
|
||||
// TorrentGrid.js:122, FilesTab.js:44, FilesTab.js:54
|
||||
GetText.add('Size', '${escape(_("Size"))}')
|
||||
|
||||
// ProxyField.js:56
|
||||
@ -749,7 +749,7 @@ GetText.add('Total Active Seeding', '${escape(_("Total Active Seeding"))}')
|
||||
// DetailsTab.js:49
|
||||
GetText.add('Total Size', '${escape(_("Total Size"))}')
|
||||
|
||||
// EditTrackersWindow.js:80, TorrentGrid.js:193, EditTrackerWindow.js:66, DetailsTab.js:53, ProxyPage.js:63
|
||||
// EditTrackersWindow.js:80, TorrentGrid.js:193, EditTrackerWindow.js:66, DetailsTab.js:53, ProxyPage.js:64
|
||||
GetText.add('Tracker', '${escape(_("Tracker"))}')
|
||||
|
||||
// Sidebar.js:35
|
||||
@ -824,13 +824,13 @@ GetText.add('Username', '${escape(_("Username"))}')
|
||||
// ConnectionManager.js:80
|
||||
GetText.add('Version', '${escape(_("Version"))}')
|
||||
|
||||
// ProxyPage.js:57
|
||||
// ProxyPage.js:58
|
||||
GetText.add('Web Seed', '${escape(_("Web Seed"))}')
|
||||
|
||||
// OtherPage.js:90
|
||||
GetText.add('Yes, please send anonymous statistics', '${escape(_("Yes, please send anonymous statistics"))}')
|
||||
|
||||
// LoginWindow.js:128
|
||||
// LoginWindow.js:131
|
||||
GetText.add('You entered an incorrect password', '${escape(_("You entered an incorrect password"))}')
|
||||
|
||||
// InterfacePage.js:215
|
||||
|
@ -48,6 +48,10 @@ Deluge.data.SortTypes = {
|
||||
|
||||
asQueuePosition: function(value) {
|
||||
return (value > -1) ? value : Number.MAX_VALUE;
|
||||
},
|
||||
|
||||
asName: function(value) {
|
||||
return String(value).toLowerCase();
|
||||
}
|
||||
}
|
||||
/*!
|
||||
@ -168,7 +172,8 @@ Deluge.data.Torrent = Ext.data.Record.create([{
|
||||
type: 'int'
|
||||
}, {
|
||||
name: 'name',
|
||||
type: 'string'
|
||||
type: 'string',
|
||||
sortType: Deluge.data.SortTypes.asName
|
||||
}, {
|
||||
name: 'total_size',
|
||||
type: 'int'
|
||||
@ -349,7 +354,7 @@ Deluge.details.DetailsTab = Ext.extend(Ext.Panel, {
|
||||
title: _('Details'),
|
||||
|
||||
fields: {},
|
||||
|
||||
autoScroll: true,
|
||||
queuedItems: {},
|
||||
|
||||
oldData: {},
|
||||
@ -462,7 +467,6 @@ Deluge.details.FilesTab = Ext.extend(Ext.ux.tree.TreeGrid, {
|
||||
|
||||
title: _('Files'),
|
||||
|
||||
autoScroll: true,
|
||||
rootVisible: false,
|
||||
|
||||
columns: [{
|
||||
@ -1544,6 +1548,7 @@ Deluge.add.AddWindow = Ext.extend(Deluge.add.Window, {
|
||||
}, {
|
||||
text: _('Infohash'),
|
||||
iconCls: 'icon-add-magnet',
|
||||
hidden: true,
|
||||
disabled: true
|
||||
}, '->', {
|
||||
text: _('Remove'),
|
||||
@ -4432,7 +4437,8 @@ Deluge.preferences.Proxy = Ext.extend(Ext.form.FormPanel, {
|
||||
config = Ext.apply({
|
||||
border: false,
|
||||
title: _('Proxy'),
|
||||
layout: 'form'
|
||||
layout: 'form',
|
||||
autoScroll: true
|
||||
}, config);
|
||||
Deluge.preferences.Proxy.superclass.constructor.call(this, config);
|
||||
},
|
||||
@ -7098,15 +7104,18 @@ Deluge.LoginWindow = Ext.extend(Ext.Window, {
|
||||
this.form = this.add({
|
||||
xtype: 'form',
|
||||
baseCls: 'x-plain',
|
||||
labelWidth: 55,
|
||||
width: 300,
|
||||
defaults: {width: 200},
|
||||
labelWidth: 120,
|
||||
labelAlign: 'right',
|
||||
defaults: {width: 110},
|
||||
defaultType: 'textfield'
|
||||
});
|
||||
|
||||
this.passwordField = this.form.add({
|
||||
xtype: 'textfield',
|
||||
fieldLabel: _('Password'),
|
||||
grow: true,
|
||||
growMin: '110',
|
||||
growMax: '145',
|
||||
id: '_password',
|
||||
name: 'password',
|
||||
inputType: 'password'
|
||||
@ -7187,7 +7196,7 @@ Deluge.LoginWindow = Ext.extend(Ext.Window, {
|
||||
},
|
||||
|
||||
onShow: function() {
|
||||
this.passwordField.focus(true, 100);
|
||||
this.passwordField.focus(true, 300);
|
||||
}
|
||||
});
|
||||
/*!
|
||||
@ -9046,7 +9055,7 @@ Deluge.Toolbar = Ext.extend(Ext.Toolbar, {
|
||||
idProperty: 'id',
|
||||
fields: [
|
||||
{name: 'queue', sortType: Deluge.data.SortTypes.asQueuePosition},
|
||||
{name: 'name'},
|
||||
{name: 'name', sortType: Deluge.data.SortTypes.asName},
|
||||
{name: 'total_size', type: 'int'},
|
||||
{name: 'state'},
|
||||
{name: 'progress', type: 'float'},
|
||||
@ -9055,7 +9064,7 @@ Deluge.Toolbar = Ext.extend(Ext.Toolbar, {
|
||||
{name: 'num_peers', type: 'int'},
|
||||
{name: 'total_peers', type: 'int'},
|
||||
{name: 'download_payload_rate', type: 'int'},
|
||||
{name: 'upload_payload_speed', type: 'int'},
|
||||
{name: 'upload_payload_rate', type: 'int'},
|
||||
{name: 'eta', type: 'int', sortType: etaSorter},
|
||||
{name: 'ratio', type: 'float'},
|
||||
{name: 'distributed_copies', type: 'float'},
|
||||
|
File diff suppressed because one or more lines are too long
@ -1581,6 +1581,7 @@ Ext.ux.form.SpinnerGroup = Ext.extend(Ext.form.CheckboxGroup, {
|
||||
|
||||
// private
|
||||
defaultType: 'spinnerfield',
|
||||
anchor: '98%',
|
||||
|
||||
// private
|
||||
groupCls: 'x-form-spinner-group',
|
||||
@ -1697,6 +1698,7 @@ Ext.ux.form.SpinnerGroup = Ext.extend(Ext.form.CheckboxGroup, {
|
||||
|
||||
this.items.each(function(field) {
|
||||
field.on('spin', this.onFieldChange, this);
|
||||
field.on('change', this.onFieldChange, this);
|
||||
}, this);
|
||||
|
||||
if (this.lazyValueSet) {
|
||||
|
@ -220,7 +220,7 @@ Ext.override(Ext.ux.form.SpinnerField,{onBlur:Ext.form.Field.prototype.onBlur});
|
||||
* this exception statement from your version. If you delete this exception
|
||||
* statement from all source files in the program, then also delete it here.
|
||||
*/
|
||||
Ext.ns("Ext.ux.form");Ext.ux.form.SpinnerGroup=Ext.extend(Ext.form.CheckboxGroup,{defaultType:"spinnerfield",groupCls:"x-form-spinner-group",colCfg:{},onRender:function(h,f){if(!this.el){var o={cls:this.groupCls,layout:"column",border:false,renderTo:h};var a=Ext.apply({defaultType:this.defaultType,layout:"form",border:false,labelWidth:60,defaults:{hideLabel:true,anchor:"60%"}},this.colCfg);if(this.items[0].items){Ext.apply(o,{layoutConfig:{columns:this.items.length},defaults:this.defaults,items:this.items});for(var e=0,k=this.items.length;e<k;e++){Ext.applyIf(this.items[e],a)}}else{var d,m=[];if(typeof this.columns=="string"){this.columns=this.items.length}if(!Ext.isArray(this.columns)){var j=[];for(var e=0;e<this.columns;e++){j.push((100/this.columns)*0.01)}this.columns=j}d=this.columns.length;for(var e=0;e<d;e++){var b=Ext.apply({items:[]},a);b[this.columns[e]<=1?"columnWidth":"width"]=this.columns[e];if(this.defaults){b.defaults=Ext.apply(b.defaults||{},this.defaults)}m.push(b)}if(this.vertical){var q=Math.ceil(this.items.length/d),n=0;for(var e=0,k=this.items.length;e<k;e++){if(e>0&&e%q==0){n++}if(this.items[e].fieldLabel){this.items[e].hideLabel=false}m[n].items.push(this.items[e])}}else{for(var e=0,k=this.items.length;e<k;e++){var p=e%d;if(this.items[e].fieldLabel){this.items[e].hideLabel=false}m[p].items.push(this.items[e])}}Ext.apply(o,{layoutConfig:{columns:d},items:m})}this.panel=new Ext.Panel(o);this.el=this.panel.getEl();if(this.forId&&this.itemCls){var c=this.el.up(this.itemCls).child("label",true);if(c){c.setAttribute("htmlFor",this.forId)}}var g=this.panel.findBy(function(l){return l.isFormField},this);this.items=new Ext.util.MixedCollection();this.items.addAll(g);this.items.each(function(l){l.on("spin",this.onFieldChange,this)},this);if(this.lazyValueSet){this.setValue(this.value);delete this.value;delete this.lazyValueSet}if(this.lazyRawValueSet){this.setRawValue(this.rawValue);delete this.rawValue;delete this.lazyRawValueSet}}Ext.ux.form.SpinnerGroup.superclass.onRender.call(this,h,f)},onFieldChange:function(a){this.fireEvent("change",this,this.getValue())},initValue:Ext.emptyFn,getValue:function(){var a=[this.items.getCount()];this.items.each(function(c,b){a[b]=Number(c.getValue())});return a},getRawValue:function(){var a=[this.items.getCount()];this.items.each(function(c,b){a[b]=Number(c.getRawValue())});return a},setValue:function(a){if(!this.rendered){this.value=a;this.lazyValueSet=true}else{this.items.each(function(c,b){c.setValue(a[b])})}},setRawValue:function(a){if(!this.rendered){this.rawValue=a;this.lazyRawValueSet=true}else{this.items.each(function(c,b){c.setRawValue(a[b])})}}});Ext.reg("spinnergroup",Ext.ux.form.SpinnerGroup);
|
||||
Ext.ns("Ext.ux.form");Ext.ux.form.SpinnerGroup=Ext.extend(Ext.form.CheckboxGroup,{defaultType:"spinnerfield",anchor:"98%",groupCls:"x-form-spinner-group",colCfg:{},onRender:function(h,f){if(!this.el){var o={cls:this.groupCls,layout:"column",border:false,renderTo:h};var a=Ext.apply({defaultType:this.defaultType,layout:"form",border:false,labelWidth:60,defaults:{hideLabel:true,anchor:"60%"}},this.colCfg);if(this.items[0].items){Ext.apply(o,{layoutConfig:{columns:this.items.length},defaults:this.defaults,items:this.items});for(var e=0,k=this.items.length;e<k;e++){Ext.applyIf(this.items[e],a)}}else{var d,m=[];if(typeof this.columns=="string"){this.columns=this.items.length}if(!Ext.isArray(this.columns)){var j=[];for(var e=0;e<this.columns;e++){j.push((100/this.columns)*0.01)}this.columns=j}d=this.columns.length;for(var e=0;e<d;e++){var b=Ext.apply({items:[]},a);b[this.columns[e]<=1?"columnWidth":"width"]=this.columns[e];if(this.defaults){b.defaults=Ext.apply(b.defaults||{},this.defaults)}m.push(b)}if(this.vertical){var q=Math.ceil(this.items.length/d),n=0;for(var e=0,k=this.items.length;e<k;e++){if(e>0&&e%q==0){n++}if(this.items[e].fieldLabel){this.items[e].hideLabel=false}m[n].items.push(this.items[e])}}else{for(var e=0,k=this.items.length;e<k;e++){var p=e%d;if(this.items[e].fieldLabel){this.items[e].hideLabel=false}m[p].items.push(this.items[e])}}Ext.apply(o,{layoutConfig:{columns:d},items:m})}this.panel=new Ext.Panel(o);this.el=this.panel.getEl();if(this.forId&&this.itemCls){var c=this.el.up(this.itemCls).child("label",true);if(c){c.setAttribute("htmlFor",this.forId)}}var g=this.panel.findBy(function(l){return l.isFormField},this);this.items=new Ext.util.MixedCollection();this.items.addAll(g);this.items.each(function(l){l.on("spin",this.onFieldChange,this);l.on("change",this.onFieldChange,this)},this);if(this.lazyValueSet){this.setValue(this.value);delete this.value;delete this.lazyValueSet}if(this.lazyRawValueSet){this.setRawValue(this.rawValue);delete this.rawValue;delete this.lazyRawValueSet}}Ext.ux.form.SpinnerGroup.superclass.onRender.call(this,h,f)},onFieldChange:function(a){this.fireEvent("change",this,this.getValue())},initValue:Ext.emptyFn,getValue:function(){var a=[this.items.getCount()];this.items.each(function(c,b){a[b]=Number(c.getValue())});return a},getRawValue:function(){var a=[this.items.getCount()];this.items.each(function(c,b){a[b]=Number(c.getRawValue())});return a},setValue:function(a){if(!this.rendered){this.value=a;this.lazyValueSet=true}else{this.items.each(function(c,b){c.setValue(a[b])})}},setRawValue:function(a){if(!this.rendered){this.rawValue=a;this.lazyRawValueSet=true}else{this.items.each(function(c,b){c.setRawValue(a[b])})}}});Ext.reg("spinnergroup",Ext.ux.form.SpinnerGroup);
|
||||
/*
|
||||
* Ext.ux.form.ToggleField.js
|
||||
*
|
||||
|
Loading…
x
Reference in New Issue
Block a user