make photos page work with backbone

This commit is contained in:
Florian Staudacher 2014-09-08 18:53:58 +02:00
parent 1f724dd123
commit e4ee28885a
2 changed files with 32 additions and 7 deletions

View file

@ -14,13 +14,23 @@ app.pages.Profile = app.views.Base.extend({
tooltipSelector: '.profile_button div, .sharing_message_container', tooltipSelector: '.profile_button div, .sharing_message_container',
initialize: function(opts) { initialize: function(opts) {
if( app.hasPreload('person') ) if( app.hasPreload('person') ) {
this.model = new app.models.Person(app.parsePreload('person')); this.model = new app.models.Person(app.parsePreload('person'));
} else if(opts && opts.person_id) {
this.model = new app.models.Person({guid: opts.person_id});
this.model.fetch();
} else {
throw new Error("unable to load person");
}
if( app.hasPreload('photos') ) if( app.hasPreload('photos') )
this.photos = app.parsePreload('photos'); // we don't interact with it, so no model this.photos = app.parsePreload('photos'); // we don't interact with it, so no model
if( app.hasPreload('contacts') ) if( app.hasPreload('contacts') )
this.contacts = app.parsePreload('contacts'); // we don't interact with it, so no model this.contacts = app.parsePreload('contacts'); // we don't interact with it, so no model
this.streamCollection = _.has(opts, 'streamCollection') ? opts.streamCollection : null;
this.streamViewClass = _.has(opts, 'streamView') ? opts.streamView : null;
this.model.on('change', this.render, this); this.model.on('change', this.render, this);
// bind to global events // bind to global events
@ -31,6 +41,7 @@ app.pages.Profile = app.views.Base.extend({
}, },
sidebarView: function() { sidebarView: function() {
if( !this.model.has('profile') ) return false;
return new app.views.ProfileSidebar({ return new app.views.ProfileSidebar({
model: this.model, model: this.model,
photos: this.photos, photos: this.photos,
@ -39,10 +50,12 @@ app.pages.Profile = app.views.Base.extend({
}, },
headerView: function() { headerView: function() {
if( !this.model.has('profile') ) return false;
return new app.views.ProfileHeader({model: this.model}); return new app.views.ProfileHeader({model: this.model});
}, },
streamView: function() { streamView: function() {
if( !this.model.has('profile') ) return false;
if( this.model.isBlocked() ) { if( this.model.isBlocked() ) {
$('#main_stream').empty().html( $('#main_stream').empty().html(
'<div class="dull">'+ '<div class="dull">'+
@ -51,9 +64,16 @@ app.pages.Profile = app.views.Base.extend({
return false; return false;
} }
app.stream = new app.models.Stream(null, {basePath: Routes.person_stream_path(app.page.model.get('guid'))}); // a collection is set, this means we want to view photos
var route = this.streamCollection ? 'person_photos_path' : 'person_stream_path';
var view = this.streamViewClass ? this.streamViewClass : app.views.Stream;
app.stream = new app.models.Stream(null, {
basePath: Routes[route](app.page.model.get('guid')),
collection: this.streamCollection
});
app.stream.fetch(); app.stream.fetch();
return new app.views.Stream({model: app.stream}); return new view({model: app.stream});
}, },
blockPerson: function(evt) { blockPerson: function(evt) {

View file

@ -77,10 +77,15 @@ app.Router = Backbone.Router.extend({
this._hideInactiveStreamLists(); this._hideInactiveStreamLists();
}, },
photos : function() { photos : function(guid) {
app.photos = new app.models.Stream([], {collection: app.collections.Photos}); this.renderPage(function() {
app.page = new app.views.Photos({model : app.photos}); return new app.pages.Profile({
$("#main_stream").html(app.page.render().el); person_id: guid,
el: $('body > .container'),
streamCollection: app.collections.Photos,
streamView: app.views.Photos
});
});
}, },
followed_tags : function(name) { followed_tags : function(name) {