add the beginnings of the plugins preferences page
This commit is contained in:
parent
f10bf6961b
commit
7a09ef5356
|
@ -46,23 +46,36 @@ input {
|
||||||
|
|
||||||
|
|
||||||
/* Torrent Details */
|
/* Torrent Details */
|
||||||
#torrentDetails dl {
|
#torrentDetails dl, dl.singleline {
|
||||||
float: left;
|
float: left;
|
||||||
min-height: 120px;
|
min-height: 120px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#torrentDetails dl dt {
|
#torrentDetails dl dt, dl.singleline dt {
|
||||||
float: left;
|
float: left;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
height: 19px;
|
height: 19px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#torrentDetails dl dd {
|
#torrentDetails dl dd, dl.singleline dd {
|
||||||
margin-left: 100px;
|
margin-left: 100px;
|
||||||
width: 140px;
|
width: 140px;
|
||||||
height: 19px;
|
height: 19px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dl.singleline dt {
|
||||||
|
width: 80px;
|
||||||
|
}
|
||||||
|
|
||||||
|
dl.singleline dd {
|
||||||
|
margin-left: 85px;
|
||||||
|
width: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.x-deluge-plugins {
|
||||||
|
background: White;
|
||||||
|
}
|
||||||
|
|
||||||
/* Torrent Details - Status Tab */
|
/* Torrent Details - Status Tab */
|
||||||
.x-deluge-status-progressbar {
|
.x-deluge-status-progressbar {
|
||||||
margin: 5px;
|
margin: 5px;
|
||||||
|
|
|
@ -806,3 +806,7 @@ body.x-body-masked .x-window-mc, body.x-body-masked .x-window-plain .x-window-mc
|
||||||
.x-slider-vert .x-slider-inner{
|
.x-slider-vert .x-slider-inner{
|
||||||
background:transparent url(/themes/slate/slider/slider-v-bg.png) repeat-y 0 0;
|
background:transparent url(/themes/slate/slider/slider-v-bg.png) repeat-y 0 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.x-deluge-plugins .x-panel-body {
|
||||||
|
background: White;
|
||||||
|
}
|
||||||
|
|
|
@ -1,7 +1,194 @@
|
||||||
/*Deluge.Preferences.addPage(_('Plugins'), {
|
Ext.namespace('Ext.deluge.preferences');
|
||||||
|
Ext.deluge.preferences.Plugins = Ext.extend(Ext.Panel, {
|
||||||
|
constructor: function(config) {
|
||||||
|
config = Ext.apply({
|
||||||
border: false,
|
border: false,
|
||||||
xtype: 'form',
|
title: _('Plugins'),
|
||||||
layout: 'form',
|
layout: 'border',
|
||||||
items: []
|
height: 400,
|
||||||
|
cls: 'x-deluge-plugins'
|
||||||
|
}, config);
|
||||||
|
Ext.deluge.preferences.Plugins.superclass.constructor.call(this, config);
|
||||||
|
},
|
||||||
|
|
||||||
|
pluginTemplate: new Ext.Template(
|
||||||
|
'<dl class="singleline">' +
|
||||||
|
'<dt>Author:</dt><dd>{author}</dd>' +
|
||||||
|
'<dt>Version:</dt><dd>{version}</dd>' +
|
||||||
|
'<dt>Author Email:</dt><dd>{email}</dd>' +
|
||||||
|
'<dt>Homepage:</dt><dd>{homepage}</dd>' +
|
||||||
|
'<dt>Details:</dt><dd>{details}</dd>' +
|
||||||
|
'</dl>'
|
||||||
|
),
|
||||||
|
|
||||||
|
initComponent: function() {
|
||||||
|
Ext.deluge.preferences.Plugins.superclass.initComponent.call(this);
|
||||||
|
this.defaultValues = {
|
||||||
|
'version': '',
|
||||||
|
'email': '',
|
||||||
|
'homepage': '',
|
||||||
|
'details': ''
|
||||||
|
};
|
||||||
|
this.pluginTemplate.compile();
|
||||||
|
|
||||||
|
var checkboxRenderer = function(v, p, record){
|
||||||
|
p.css += ' x-grid3-check-col-td';
|
||||||
|
return '<div class="x-grid3-check-col'+(v?'-on':'')+'"> </div>';
|
||||||
|
}
|
||||||
|
|
||||||
|
this.grid = this.add({
|
||||||
|
xtype: 'grid',
|
||||||
|
region: 'center',
|
||||||
|
store: new Ext.data.SimpleStore({
|
||||||
|
fields: [
|
||||||
|
{name: 'enabled', mapping: 0},
|
||||||
|
{name: 'plugin', mapping: 1}
|
||||||
|
]
|
||||||
|
}),
|
||||||
|
columns: [{
|
||||||
|
id: 'enabled',
|
||||||
|
header: _('Enabled'),
|
||||||
|
width: 50,
|
||||||
|
sortable: true,
|
||||||
|
renderer: checkboxRenderer,
|
||||||
|
dataIndex: 'enabled'
|
||||||
|
}, {
|
||||||
|
id: 'plugin',
|
||||||
|
header: _('Plugin'),
|
||||||
|
sortable: true,
|
||||||
|
dataIndex: 'plugin'
|
||||||
|
}],
|
||||||
|
stripeRows: true,
|
||||||
|
selModel: new Ext.grid.RowSelectionModel({
|
||||||
|
singleSelect: true,
|
||||||
|
listeners: {
|
||||||
|
'rowselect': {
|
||||||
|
fn: this.onPluginSelect,
|
||||||
|
scope: this
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
autoExpandColumn: 'plugin',
|
||||||
|
deferredRender: false,
|
||||||
|
autoScroll: true,
|
||||||
|
margins: '5 5 5 5',
|
||||||
|
bbar: new Ext.Toolbar({
|
||||||
|
items: [{
|
||||||
|
cls: 'x-btn-text-icon',
|
||||||
|
iconCls: 'x-deluge-add',
|
||||||
|
text: _('Install'),
|
||||||
|
handler: this.onInstallPlugin,
|
||||||
|
scope: this
|
||||||
|
}, {
|
||||||
|
cls: 'x-btn-text-icon',
|
||||||
|
text: _('Rescan'),
|
||||||
|
handler: this.onRescanPlugins,
|
||||||
|
scope: this
|
||||||
|
}, '->', {
|
||||||
|
cls: 'x-btn-text-icon',
|
||||||
|
text: _('Find More'),
|
||||||
|
handler: this.onFindMorePlugins,
|
||||||
|
scope: this
|
||||||
|
}]
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
var fieldset = this.add({
|
||||||
|
xtype: 'fieldset',
|
||||||
|
border: false,
|
||||||
|
region: 'south',
|
||||||
|
title: _('Info'),
|
||||||
|
autoHeight: true,
|
||||||
|
labelWidth: 1
|
||||||
|
});
|
||||||
|
this.pluginInfo = fieldset.add({
|
||||||
|
xtype: 'panel',
|
||||||
|
border: false,
|
||||||
|
bodyCfg: {
|
||||||
|
style: 'margin-left: 10px'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
this.on('show', this.onShow, this);
|
||||||
|
this.grid.on('cellclick', this.onCellClick, this);
|
||||||
|
Deluge.Preferences.on('show', this.onPreferencesShow, this);
|
||||||
|
},
|
||||||
|
|
||||||
|
disablePlugin: function(plugin) {
|
||||||
|
Deluge.Client.core.disable_plugin(plugin);
|
||||||
|
},
|
||||||
|
|
||||||
|
enablePlugin: function(plugin) {
|
||||||
|
Deluge.Client.core.enable_plugin(plugin);
|
||||||
|
},
|
||||||
|
|
||||||
|
setInfo: function(plugin) {
|
||||||
|
var values = plugin || this.defaultValues;
|
||||||
|
this.pluginInfo.body.dom.innerHTML = this.pluginTemplate.apply(values);
|
||||||
|
},
|
||||||
|
|
||||||
|
onCellClick: function(grid, rowIndex, colIndex, e) {
|
||||||
|
if (colIndex != 0) return;
|
||||||
|
var r = grid.getStore().getAt(rowIndex);
|
||||||
|
r.set('enabled', !r.get('enabled'));
|
||||||
|
r.commit();
|
||||||
|
if (r.get('enabled')) {
|
||||||
|
this.enablePlugin(r.get('plugin'));
|
||||||
|
} else {
|
||||||
|
this.disablePlugin(r.get('plugin'));
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onGotAvailablePlugins: function(plugins) {
|
||||||
|
this.availablePlugins = plugins;
|
||||||
|
Deluge.Client.core.get_enabled_plugins({
|
||||||
|
success: this.onGotEnabledPlugins,
|
||||||
|
scope: this
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
onGotEnabledPlugins: function(plugins) {
|
||||||
|
this.enabledPlugins = plugins;
|
||||||
|
},
|
||||||
|
|
||||||
|
onGotPluginInfo: function(info) {
|
||||||
|
var values = {
|
||||||
|
author: info['Author'],
|
||||||
|
version: info['Version'],
|
||||||
|
email: info['Author-email'],
|
||||||
|
homepage: info['Home-page'],
|
||||||
|
details: info['Description']
|
||||||
|
}
|
||||||
|
this.setInfo(values);
|
||||||
|
delete info;
|
||||||
|
},
|
||||||
|
|
||||||
|
onPluginSelect: function(selmodel, rowIndex, r) {
|
||||||
|
Deluge.Client.web.get_plugin_info(r.get('plugin'), {
|
||||||
|
success: this.onGotPluginInfo,
|
||||||
|
scope: this
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
onPreferencesShow: function() {
|
||||||
|
Deluge.Client.core.get_available_plugins({
|
||||||
|
success: this.onGotAvailablePlugins,
|
||||||
|
scope: this
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
onShow: function() {
|
||||||
|
Ext.deluge.preferences.Plugins.superclass.onShow.call(this);
|
||||||
|
this.setInfo();
|
||||||
|
var plugins = [];
|
||||||
|
Ext.each(this.availablePlugins, function(plugin) {
|
||||||
|
if (this.enabledPlugins.indexOf(plugin) > -1) {
|
||||||
|
plugins.push([true, plugin]);
|
||||||
|
} else {
|
||||||
|
plugins.push([false, plugin]);
|
||||||
|
}
|
||||||
|
}, this);
|
||||||
|
this.grid.getStore().loadData(plugins);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
*/
|
Deluge.Preferences.addPage(new Ext.deluge.preferences.Plugins());
|
|
@ -710,5 +710,13 @@ class WebApi(JSONComponent):
|
||||||
|
|
||||||
@export
|
@export
|
||||||
def get_plugin_info(self, name):
|
def get_plugin_info(self, name):
|
||||||
return component.get("PluginManager").get_plugin_info(name)
|
return component.get("Web.PluginManager").get_plugin_info(name)
|
||||||
|
|
||||||
|
@export
|
||||||
|
def enable_plugin(self, name):
|
||||||
|
pass
|
||||||
|
|
||||||
|
@export
|
||||||
|
def disable_plugin(self, name):
|
||||||
|
pass
|
||||||
|
|
Loading…
Reference in New Issue