fixed load/fetch order, fixed edit form display, robustified whitelist views against missing client IDs

pull/263/head
Justin Richer 2012-11-14 16:30:10 -05:00
parent f39c254353
commit 321172c40c
2 changed files with 44 additions and 23 deletions

View File

@ -144,7 +144,7 @@
var WhiteListCollection = Backbone.Collection.extend({ var WhiteListCollection = Backbone.Collection.extend({
initialize: function() { initialize: function() {
this.fetch(); //this.fetch();
}, },
model: WhiteListModel, model: WhiteListModel,
@ -212,7 +212,7 @@
var ClientCollection = Backbone.Collection.extend({ var ClientCollection = Backbone.Collection.extend({
initialize: function() { initialize: function() {
this.fetch(); //this.fetch();
}, },
model:ClientModel, model:ClientModel,
@ -325,7 +325,7 @@
tagName: 'span', tagName: 'span',
initialize:function () { initialize:function () {
this.model.bind("reset", this.render, this); //this.model.bind("reset", this.render, this);
}, },
events:{ events:{
@ -591,7 +591,7 @@
tagName: 'span', tagName: 'span',
initialize:function () { initialize:function () {
this.model.bind("reset", this.render, this); //this.model.bind("reset", this.render, this);
}, },
events:{ events:{
@ -611,7 +611,11 @@
// look up client // look up client
var client = app.clientList.getByClientId(whiteList.get('clientId')); var client = app.clientList.getByClientId(whiteList.get('clientId'));
// if there's no client ID, this is an error!
if (client != null) {
$('#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);
return this; return this;
@ -697,8 +701,11 @@
// process allowed scopes // process allowed scopes
var allowedScopes = this.scopeCollection.pluck("item"); var allowedScopes = this.scopeCollection.pluck("item");
if (this.model.get('id') == null) {
this.model.set({clientId:$('#clientId input').val()});
}
var valid = this.model.set({ var valid = this.model.set({
clientId:$('#clientId input').val(),
allowedScopes: allowedScopes allowedScopes: allowedScopes
}); });
@ -732,14 +739,14 @@
var _self = this; var _self = this;
// build and bind scopes // build and bind scopes
_.each(this.model.get("scope"), function (scope) { _.each(this.model.get("allowedScopes"), function (scope) {
_self.scopeCollection.add(new Backbone.Model({item:scope})); _self.scopeCollection.add(new Backbone.Model({item:scope}));
}); });
$("#scope .controls",this.el).html(new ListWidgetView({placeholder: 'new scope here' $("#scope .controls",this.el).html(new ListWidgetView({
, autocomplete: _.uniq(_.flatten(app.clientList.pluck("scope"))) placeholder: 'new scope here',
, collection: this.scopeCollection}).render().el); autocomplete: this.options.client.scope,
collection: this.scopeCollection}).render().el);
return this; return this;
@ -763,11 +770,8 @@
initialize:function () { initialize:function () {
// TODO: lazy load these instead? bootstrap them?
jQuery.ajaxSetup({async:false});
this.clientList = new ClientCollection(); this.clientList = new ClientCollection();
this.whiteListList = new WhiteListCollection(); this.whiteListList = new WhiteListCollection();
jQuery.ajaxSetup({async:true});
this.clientListView = new ClientListView({model:this.clientList}); this.clientListView = new ClientListView({model:this.clientList});
this.whiteListListView = new WhiteListListView({model:this.whiteListList}); this.whiteListListView = new WhiteListListView({model:this.whiteListList});
@ -778,22 +782,36 @@
this.breadCrumbView.render(); this.breadCrumbView.render();
this.startAfter([this.clientList, this.whiteListList]); //this.startAfter([this.clientList, this.whiteListList]);
// load things in the right order:
this.clientList.on('reset', function(collection, response) {
app.whiteListList.fetch();
});
this.whiteListList.on('reset', function(collection, response) {
var baseUrl = $.url($('base').attr('href'));
Backbone.history.start({pushState: true, root: baseUrl.attr('relative') + 'manage/'});
});
// start the loading process
this.clientList.fetch();
}, },
/*
startAfter:function (collections) { startAfter:function (collections) {
// Start history when required collections are loaded // Start history when required collections are loaded
var start = _.after(collections.length, _.once(function () { var start = _.after(collections.length, _.once(function () {
var baseUrl = $.url($('base').attr('href'));
Backbone.history.start({pushState: true, root: baseUrl.attr('relative') + 'manage/'});
})); }));
_.each(collections, function (collection) { _.each(collections, function (collection) {
collection.bind('reset', start, Backbone.history); collection.bind('reset', start, Backbone.history);
}); });
}, },
*/
listClients:function () { listClients:function () {
@ -884,8 +902,11 @@
var whiteList = this.whiteListList.get(id); var whiteList = this.whiteListList.get(id);
var client = app.clientList.getByClientId(whiteList.get('clientId')); var client = app.clientList.getByClientId(whiteList.get('clientId'));
// if there's no client, this is an error
if (client != null) {
this.whiteListFormView = new WhiteListFormView({model: whiteList, client: client}); this.whiteListFormView = new WhiteListFormView({model: whiteList, client: client});
$('#content').html(this.whiteListFormView.render().el); $('#content').html(this.whiteListFormView.render().el);
}
} }

View File

@ -316,16 +316,16 @@
<button class="btn btn-small btn-primary">Save</button>&nbsp;<button class="btn btn-small btn-cancel">Cancel</button> <button class="btn btn-small btn-primary">Save</button>&nbsp;<button class="btn btn-small btn-cancel">Cancel</button>
</div> </div>
<div class="control-group"> <div class="control-group" id="clientId">
<label class="control-label">Client</label> <label class="control-label">Client</label>
<div class="controls"> <div class="controls">
<input type="hidden" id="clientId" name="clientId" value="<%= client.clientId %> /> <input type="hidden" name="clientId" value="<%= client.clientId %>" />
<%= client.applicationName != null ? client.applicationName : client.clientId %> <%= client.applicationName != null ? client.applicationName : client.clientId %>
</div> </div>
</div> </div>
<div class="control-group" id="scope"> <div class="control-group" id="scope">
<label class="control-label">Allowed Scope</label> <label class="control-label">Allowed Scopes</label>
<div class="controls"> <div class="controls">
</div> </div>
</div> </div>