summaryrefslogtreecommitdiffstats
path: root/module/web/static/js/views/settingsView.js
diff options
context:
space:
mode:
authorGravatar RaNaN <Mast3rRaNaN@hotmail.de> 2013-03-25 19:12:39 +0100
committerGravatar RaNaN <Mast3rRaNaN@hotmail.de> 2013-03-25 19:12:39 +0100
commitb5f66789e70bd105e162470927942c40496cdc92 (patch)
tree3a762f29008dd7d7c92221eb363f90580f8acb6f /module/web/static/js/views/settingsView.js
parentadded view type for input fields (diff)
downloadpyload-b5f66789e70bd105e162470927942c40496cdc92.tar.xz
simple rendering for settings page
Diffstat (limited to 'module/web/static/js/views/settingsView.js')
-rw-r--r--module/web/static/js/views/settingsView.js89
1 files changed, 75 insertions, 14 deletions
diff --git a/module/web/static/js/views/settingsView.js b/module/web/static/js/views/settingsView.js
index a322cdae7..00c4b3739 100644
--- a/module/web/static/js/views/settingsView.js
+++ b/module/web/static/js/views/settingsView.js
@@ -1,23 +1,31 @@
-define(['jquery', 'underscore', 'backbone'],
- function($, _, Backbone) {
+define(['jquery', 'underscore', 'backbone', 'app', './input/inputLoader', 'models/ConfigHolder'],
+ function($, _, Backbone, App, load_input, ConfigHolder) {
// Renders settings over view page
return Backbone.View.extend({
el: "#content",
- template_menu: _.compile($("#template-menu").html()),
+ templateMenu: _.compile($("#template-menu").html()),
+ templateConfig: _.compile($("#template-config").html()),
+ templateConfigItem: _.compile($("#template-config-item").html()),
events: {
'click .settings-menu li > a': 'change_section'
},
menu: null,
+ content: null,
core_config: null, // It seems models are not needed
plugin_config: null,
+ // currently open configHolder
+ config: null,
+ isLoading: false,
+
initialize: function() {
- this.menu = $('.settings-menu');
+ this.menu = this.$('.settings-menu');
+ this.content = this.$('#settings-form');
this.refresh();
console.log("Settings initialized");
@@ -25,27 +33,80 @@ define(['jquery', 'underscore', 'backbone'],
refresh: function() {
var self = this;
- $.ajax("/api/getCoreConfig", {success: function(data) {
+ $.ajax(App.apiRequest("getCoreConfig", null, {success: function(data) {
self.core_config = data;
- self.render()
- }});
- $.ajax("/api/getPluginConfig", {success: function(data) {
+ self.render();
+ }}));
+ $.ajax(App.apiRequest("getPluginConfig", null, {success: function(data) {
self.plugin_config = data;
self.render();
- }});
+ }}));
},
render: function() {
- this.menu.html(this.template_menu({
- core: this.core_config,
- plugin: this.plugin_config
- }));
+ this.menu.html(this.templateMenu({
+ core: this.core_config,
+ plugin: this.plugin_config
+ }));
+ },
+
+ openConfig: function(name) {
+ // Do nothing when this config is already open
+ if (this.config && this.config.get('name') === name)
+ return;
+
+ this.config = new ConfigHolder({name: name});
+ this.loading();
+
+ var self = this;
+ this.config.fetch({success: function() {
+ if (!self.isLoading)
+ self.show();
+
+ }, failure: _.bind(this.failure, this)});
+
+ },
+
+ loading: function() {
+ this.isLoading = true;
+ var self = this;
+ this.content.fadeOut({complete: function() {
+ if (self.config.isLoaded())
+ self.show();
+
+ self.isLoading = false;
+ }});
+
+ },
+
+ show: function() {
+ // TODO: better refactor in separate views
+ this.content.html(this.templateConfig(this.config.toJSON()));
+ var container = this.content.find('.control-content');
+ var items = this.config.get('items');
+ var self = this;
+ _.each(items, function(item) {
+ var el = $('<div>').html(self.templateConfigItem(item.toJSON()));
+ var inputView = load_input("todo");
+ el.find('.controls').append(
+ new inputView(item.get('input'), item.get('value'),
+ item.get('default_value'), item.get('description')).render().el);
+ container.append(el);
+ });
+
+ this.content.fadeIn();
+ },
+
+ failure: function() {
+
},
change_section: function(e) {
+ // TODO check for changes
+
var el = $(e.target).parent();
var name = el.data("name");
- console.log("Section changed to " + name);
+ this.openConfig(name);
this.menu.find("li.active").removeClass("active");
el.addClass("active");