whitelist editing

pull/263/head
Justin Richer 2012-11-14 15:20:32 -05:00
parent bb589fc29a
commit 51cfe1746d
2 changed files with 139 additions and 6 deletions

View File

@ -62,6 +62,7 @@
events:{ events:{
"click button":"addItem", "click button":"addItem",
"keypress input":function (e) { "keypress input":function (e) {
// trap the enter key
if (e.which == 13) { if (e.which == 13) {
this.addItem(); this.addItem();
e.preventDefault(); e.preventDefault();
@ -215,11 +216,18 @@
}, },
model:ClientModel, model:ClientModel,
url:"api/clients" url:"api/clients",
getByClientId: function(clientId) {
var clients = this.where({clientId: clientId});
if (clients.length == 1) {
return clients[0];
} else {
return null;
}
}
}); });
var BreadCrumbView = Backbone.View.extend({ var BreadCrumbView = Backbone.View.extend({
tagName: 'ul', tagName: 'ul',
@ -601,7 +609,7 @@
_.each(this.model.models, function (whitelist) { _.each(this.model.models, function (whitelist) {
// look up client // look up client
var client = app.clientList.where({clientId: whitelist.get('clientId')})[0]; // TODO: bulletproofing var client = app.clientList.getByClientId(whitelist.get('clientId'));
$('#whitelist-table', this.el).append(new WhiteListView({model: whitelist, client: client}).render().el); $('#whitelist-table', this.el).append(new WhiteListView({model: whitelist, client: client}).render().el);
}, this); }, this);
@ -665,6 +673,76 @@
$(this.el).empty(); $(this.el).empty();
} }
}); });
var WhiteListFormView = Backbone.View.extend({
tagName: 'span',
initialize:function () {
if (!this.template) {
this.template = _.template($('#tmpl-whitelist-form').html());
}
this.scopeCollection = new Backbone.Collection();
},
events:{
'click .btn-primary':'saveWhiteList',
'click .btn-cancel':'cancelWhiteList',
},
saveWhiteList:function (event) {
$('.control-group').removeClass('error');
// process allowed scopes
var allowedScopes = this.scopeCollection.pluck("item");
var valid = this.model.set({
clientId:$('#clientId input').val(),
allowedScopes: allowedScopes
});
if (valid) {
var _self = this;
this.model.save(this.model, {
success:function () {
app.whiteListList.add(_self.model);
app.navigate('admin/whitelists', {trigger:true});
},
error:function (model,resp) {
console.error("Oops! The object didn't save correctly.",resp);
}
});
}
return false;
},
render:function (eventName) {
var json = {whitelist: this.model.toJSON(), client: this.options.client.toJSON()};
this.$el.html(this.template(json));
var _self = this;
// build and bind scopes
_.each(this.model.get("scope"), function (scope) {
_self.scopeCollection.add(new Backbone.Model({item:scope}));
});
$("#scope .controls",this.el).html(new ListWidgetView({placeholder: 'new scope here'
, autocomplete: _.uniq(_.flatten(app.clientList.pluck("scope")))
, collection: this.scopeCollection}).render().el);
return this;
}
});
// Router // Router
var AppRouter = Backbone.Router.extend({ var AppRouter = Backbone.Router.extend({
@ -694,7 +772,7 @@
this.breadCrumbView.render(); this.breadCrumbView.render();
this.startAfter([this.clientList]); this.startAfter([this.clientList, this.whiteListList]);
}, },
@ -775,14 +853,32 @@
}, },
whiteList:function () { whiteList:function () {
this.breadCrumbView.collection.reset();
this.breadCrumbView.collection.add([
{text:"Home", href:""},
{text:"Manage Whitelisted Sites", href:"manage/#admin/whitelists"}
]);
$('#content').html(this.whiteListListView.render().el); $('#content').html(this.whiteListListView.render().el);
this.whiteListListView.delegateEvents();
}, },
newWhitelist:function() { newWhitelist:function() {
}, },
editWhitelist:function() { editWhitelist:function(id) {
this.breadCrumbView.collection.reset();
this.breadCrumbView.collection.add([
{text:"Home", href:""},
{text:"Manage Whitelisted Sites", href:"manage/#admin/whitelists"},
{text:"Manage Whitelisted Sites", href:"manage/#admin/whitelist/" + id}
]);
var whiteList = this.whiteListList.get(id);
var client = app.clientList.getByClientId(whitelist.get('clientId'));
this.whiteListFormView = new WhiteListFormView({model: whiteList, client: client});
} }

View File

@ -302,3 +302,40 @@
<button class="btn btn-small btn-primary">New Whitelisted Site</button> <button class="btn btn-small btn-primary">New Whitelisted Site</button>
</div> </div>
</script> </script>
<script type="text/html" id="tmpl-whitelist-form">
<h1><%=(whitelist.id == null ? 'New' : 'Edit')%> Whitelisted Site</h1>
<form class="form-horizontal">
<fieldset>
<legend>Details</legend>
<div class="well">
<button class="btn btn-small btn-primary">Save</button>&nbsp;<button class="btn btn-small btn-cancel">Cancel</button>
</div>
<div class="control-group">
<label class="control-label">Client</label>
<div class="controls">
<input type="hidden" id="clientId" name="clientId" value="<%= client.clientId %> />
<%= client.applicationName != null ? client.applicationName : client.clientId %>
</div>
</div>
<div class="control-group" id="scope">
<label class="control-label">Allowed Scope</label>
<div class="controls">
</div>
</div>
<div class="well">
<button class="btn btn-small btn-primary">Save</button>&nbsp;<button class="btn btn-small btn-cancel">Cancel</button>
</div>
</fieldset>
</form>
</script>