Show More
@@ -35,7 +35,7 b' define(["components/underscore/underscore-min",' | |||
|
35 | 35 | this.pending_msgs = 0; |
|
36 | 36 | this.msg_throttle = 3; |
|
37 | 37 | this.msg_buffer = null; |
|
38 |
this.views = |
|
|
38 | this.views = []; | |
|
39 | 39 | this._custom_msg_callbacks = []; |
|
40 | 40 | |
|
41 | 41 | // Remember comm associated with the model. |
@@ -54,15 +54,12 b' define(["components/underscore/underscore-min",' | |||
|
54 | 54 | this.last_modified_view = caller; |
|
55 | 55 | this.save(this.changedAttributes(), {patch: true}); |
|
56 | 56 | |
|
57 |
for (var |
|
|
58 |
var view |
|
|
59 | for (var view_index in views) { | |
|
60 | var view = views[view_index]; | |
|
57 | for (var view_index in this.views) { | |
|
58 | var view = this.views[view_index]; | |
|
61 | 59 |
|
|
62 | 60 |
|
|
63 | 61 |
|
|
64 | 62 |
|
|
65 | } | |
|
66 | 63 | }, |
|
67 | 64 | |
|
68 | 65 | |
@@ -290,10 +287,8 b' define(["components/underscore/underscore-min",' | |||
|
290 | 287 | args = [].splice.call(arguments,1); |
|
291 | 288 | } |
|
292 | 289 | |
|
293 |
for (var |
|
|
294 |
var view |
|
|
295 | for (var view_index in views) { | |
|
296 | var view = views[view_index]; | |
|
290 | for (var view_index in this.views) { | |
|
291 | var view = this.views[view_index]; | |
|
297 | 292 |
|
|
298 | 293 |
|
|
299 | 294 |
|
@@ -301,7 +296,6 b' define(["components/underscore/underscore-min",' | |||
|
301 | 296 |
|
|
302 | 297 |
|
|
303 | 298 |
|
|
304 | } | |
|
305 | 299 | }, |
|
306 | 300 | |
|
307 | 301 | |
@@ -314,9 +308,10 b' define(["components/underscore/underscore-min",' | |||
|
314 | 308 | if (parent_comm_id != undefined) { |
|
315 | 309 | var parent_comm = this.comm_manager.comms[parent_comm_id]; |
|
316 | 310 | var parent_model = parent_comm.model; |
|
317 |
var parent_views = parent_model.views |
|
|
311 | var parent_views = parent_model.views; | |
|
318 | 312 | for (var parent_view_index in parent_views) { |
|
319 | 313 | var parent_view = parent_views[parent_view_index]; |
|
314 | if (parent_view.cell === cell) { | |
|
320 | 315 | if (parent_view.display_child != undefined) { |
|
321 | 316 | var view = this._create_view(view_name, cell); |
|
322 | 317 | if (view != null) { |
@@ -328,6 +323,7 b' define(["components/underscore/underscore-min",' | |||
|
328 | 323 | } |
|
329 | 324 | } |
|
330 | 325 | } |
|
326 | } | |
|
331 | 327 | |
|
332 | 328 | // If no parent view is defined or exists. Add the view's |
|
333 | 329 | // element to cell's widget div. |
@@ -358,23 +354,17 b' define(["components/underscore/underscore-min",' | |||
|
358 | 354 | if (view_type != undefined && view_type != null) { |
|
359 | 355 | var view = new view_type({model: this}); |
|
360 | 356 | view.render(); |
|
361 |
|
|
|
362 | this.views[cell] = [] | |
|
363 | } | |
|
364 | this.views[cell].push(view); | |
|
357 | this.views.push(view); | |
|
365 | 358 | view.cell = cell; |
|
366 | 359 | |
|
367 | 360 | // Handle when the view element is remove from the page. |
|
368 | 361 | var that = this; |
|
369 | 362 | view.$el.on("remove", function(){ |
|
370 |
var index = that.views |
|
|
363 | var index = that.views.indexOf(view); | |
|
371 | 364 | if (index > -1) { |
|
372 |
that.views |
|
|
365 | that.views.splice(index, 1); | |
|
373 | 366 | } |
|
374 | 367 | view.remove(); // Clean-up view |
|
375 | if (that.views[cell].length()==0) { | |
|
376 | delete that.views[cell]; | |
|
377 | } | |
|
378 | 368 | |
|
379 | 369 | // Close the comm if there are no views left. |
|
380 | 370 | if (that.views.length()==0) { |
General Comments 0
You need to be logged in to leave comments.
Login now