| 
									
										
										
										
											2012-06-11 18:56:19 -07:00
										 |  |  | NEWSBLUR.Views.StoryDetailView = Backbone.View.extend({ | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-29 11:48:40 -07:00
										 |  |  |     tagName: 'li', | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |     className: 'NB-feed-story', | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     FUDGE_CONTENT_HEIGHT_OVERAGE: 260, | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2013-02-08 15:08:25 -08:00
										 |  |  |     STORY_CONTENT_MAX_HEIGHT: 460, // ALSO CHANGE IN reader.css: .NB-story-content-wrapper-height-truncated
 | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     events: { | 
					
						
							| 
									
										
										
										
											2013-06-07 12:08:14 -04:00
										 |  |  |         "click"                                 : "mark_read", | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |         "click .NB-feed-story-content a"        : "click_link_in_story", | 
					
						
							| 
									
										
										
										
											2012-07-27 13:08:58 -07:00
										 |  |  |         "click .NB-feed-story-share-container a": "click_link_in_story", | 
					
						
							|  |  |  |         "click .NB-feed-story-comments a"       : "click_link_in_story", | 
					
						
							| 
									
										
										
										
											2012-05-25 18:54:04 -07:00
										 |  |  |         "click .NB-feed-story-title"            : "click_link_in_story", | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |         "mouseenter .NB-feed-story-manage-icon" : "mouseenter_manage_icon", | 
					
						
							| 
									
										
										
										
											2012-05-25 18:54:04 -07:00
										 |  |  |         "mouseleave .NB-feed-story-manage-icon" : "mouseleave_manage_icon", | 
					
						
							| 
									
										
										
										
											2013-07-12 15:21:11 -07:00
										 |  |  |         "contextmenu .NB-feed-story-header"     : "show_manage_menu_rightclick", | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |         "click .NB-feed-story-manage-icon"      : "show_manage_menu", | 
					
						
							|  |  |  |         "click .NB-feed-story-hide-changes"     : "hide_story_changes", | 
					
						
							|  |  |  |         "click .NB-feed-story-header-title"     : "open_feed", | 
					
						
							|  |  |  |         "click .NB-feed-story-tag"              : "save_classifier", | 
					
						
							|  |  |  |         "click .NB-feed-story-author"           : "save_classifier", | 
					
						
							|  |  |  |         "click .NB-feed-story-train"            : "open_story_trainer", | 
					
						
							| 
									
										
										
										
											2013-08-13 13:15:36 -07:00
										 |  |  |         "click .NB-feed-story-save"             : "toggle_starred", | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |         "click .NB-story-comments-label"        : "scroll_to_comments", | 
					
						
							| 
									
										
										
										
											2013-04-25 13:01:36 -07:00
										 |  |  |         "click .NB-story-content-expander"      : "expand_story" | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |     initialize: function() { | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |         _.bindAll(this, 'mouseleave', 'mouseenter'); | 
					
						
							|  |  |  |         this.model.bind('change', this.toggle_classes, this); | 
					
						
							|  |  |  |         this.model.bind('change:read_status', this.toggle_read_status, this); | 
					
						
							|  |  |  |         this.model.bind('change:selected', this.toggle_selected, this); | 
					
						
							| 
									
										
										
										
											2013-08-13 13:15:36 -07:00
										 |  |  |         this.model.bind('change:starred', this.render_starred, this); | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |         this.model.bind('change:intelligence', this.render_header, this); | 
					
						
							| 
									
										
										
										
											2013-04-25 13:01:36 -07:00
										 |  |  |         this.model.bind('change:intelligence', this.toggle_intelligence, this); | 
					
						
							| 
									
										
										
										
											2013-01-09 15:36:35 -08:00
										 |  |  |         this.model.bind('change:shared', this.render_comments, this); | 
					
						
							|  |  |  |         this.model.bind('change:comments', this.render_comments, this); | 
					
						
							| 
									
										
										
										
											2013-05-06 16:16:45 -07:00
										 |  |  |         if (this.collection) { | 
					
						
							|  |  |  |             this.collection.bind('render:intelligence', this.render_intelligence, this); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |          | 
					
						
							|  |  |  |         // Binding directly instead of using event delegation. Need for speed.
 | 
					
						
							| 
									
										
										
										
											2012-06-18 23:51:03 -07:00
										 |  |  |         // this.$el.bind('mouseenter', this.mouseenter);
 | 
					
						
							|  |  |  |         // this.$el.bind('mouseleave', this.mouseleave);
 | 
					
						
							| 
									
										
										
										
											2012-06-14 17:21:51 -07:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2013-02-11 13:42:32 -08:00
										 |  |  |         if (!this.options.feed_floater &&  | 
					
						
							|  |  |  |             !this.options.text_view && | 
					
						
							|  |  |  |             !this.options.inline_story_title) { | 
					
						
							| 
									
										
										
										
											2012-06-14 17:21:51 -07:00
										 |  |  |             this.model.story_view = this; | 
					
						
							| 
									
										
										
										
											2013-02-11 17:09:38 -08:00
										 |  |  |         } else if (this.options.inline_story_title) { | 
					
						
							| 
									
										
										
										
											2013-02-12 16:07:01 -08:00
										 |  |  |             this.model.story_view = this; | 
					
						
							| 
									
										
										
										
											2013-02-11 17:09:38 -08:00
										 |  |  |             this.model.inline_story_detail_view = this; | 
					
						
							| 
									
										
										
										
											2012-06-14 17:21:51 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-04-03 11:57:40 -07:00
										 |  |  |         if (!this.options.feed_floater) { | 
					
						
							|  |  |  |             this.model.latest_story_detail_view = this; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     // =============
 | 
					
						
							|  |  |  |     // = Rendering =
 | 
					
						
							|  |  |  |     // =============
 | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |     render: function() { | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |         var params = this.get_render_params(); | 
					
						
							|  |  |  |         params['story_header'] = this.story_header_template(params); | 
					
						
							| 
									
										
										
										
											2013-08-08 17:35:26 -07:00
										 |  |  |         this.sideoptions_view = new NEWSBLUR.Views.StorySideoptionsView({ | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |             model: this.model,  | 
					
						
							|  |  |  |             el: this.el | 
					
						
							| 
									
										
										
										
											2013-02-25 14:45:59 -08:00
										 |  |  |         }); | 
					
						
							| 
									
										
										
										
											2013-08-08 17:35:26 -07:00
										 |  |  |         this.save_view = this.sideoptions_view.save_view; | 
					
						
							|  |  |  |         this.share_view = this.sideoptions_view.share_view; | 
					
						
							| 
									
										
										
										
											2013-03-02 13:37:43 -08:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2013-08-08 17:35:26 -07:00
										 |  |  |         params['story_save_view'] = this.sideoptions_view.save_view.render(); | 
					
						
							|  |  |  |         params['story_share_view'] = this.sideoptions_view.share_view.template({ | 
					
						
							| 
									
										
										
										
											2012-06-27 23:57:57 -07:00
										 |  |  |             story: this.model, | 
					
						
							| 
									
										
										
										
											2012-10-24 16:09:47 -07:00
										 |  |  |             social_services: NEWSBLUR.assets.social_services, | 
					
						
							|  |  |  |             profile: NEWSBLUR.assets.user_profile | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |         }); | 
					
						
							|  |  |  |         this.$el.html(this.template(params)); | 
					
						
							| 
									
										
										
										
											2013-01-08 18:33:30 -08:00
										 |  |  |         if (this.feed) { | 
					
						
							|  |  |  |             this.$el.toggleClass('NB-inverse', this.feed.is_light()); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-06-20 14:45:05 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-11 12:35:42 -08:00
										 |  |  |         this.setup_classes(); | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |         this.toggle_classes(); | 
					
						
							|  |  |  |         this.toggle_read_status(); | 
					
						
							| 
									
										
										
										
											2013-04-25 13:01:36 -07:00
										 |  |  |         this.toggle_intelligence(); | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |         this.generate_gradients(); | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |         this.render_comments(); | 
					
						
							| 
									
										
										
										
											2014-01-05 14:55:24 -08:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |         return this; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2013-08-13 18:26:57 -07:00
										 |  |  |     render_starred_tags: function() { | 
					
						
							|  |  |  |         if (this.model.get('starred')) { | 
					
						
							|  |  |  |             this.save_view.toggle_feed_story_save_dialog(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2013-12-06 13:56:28 -08:00
										 |  |  |     resize_starred_tags: function() { | 
					
						
							|  |  |  |         if (this.model.get('starred')) { | 
					
						
							| 
									
										
										
										
											2013-12-19 11:08:22 -08:00
										 |  |  |             this.save_view.reset_height({immediate: true}); | 
					
						
							| 
									
										
										
										
											2013-12-06 13:56:28 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2014-01-13 17:37:00 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-05 14:55:24 -08:00
										 |  |  |     attach_handlers: function() { | 
					
						
							|  |  |  |         this.watch_images_for_story_height(); | 
					
						
							| 
									
										
										
										
											2014-01-03 17:13:21 -08:00
										 |  |  |         this.attach_audio_handler(); | 
					
						
							|  |  |  |         this.attach_syntax_highlighter_handler(); | 
					
						
							|  |  |  |         this.attach_fitvid_handler(); | 
					
						
							| 
									
										
										
										
											2014-01-13 17:37:00 -08:00
										 |  |  |         this.render_starred_tags(); | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2013-12-06 13:56:28 -08:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2012-07-01 12:00:30 -07:00
										 |  |  |     render_header: function(model, value, options) { | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |         var params = this.get_render_params(); | 
					
						
							|  |  |  |         this.$('.NB-feed-story-header').replaceWith($(this.story_header_template(params))); | 
					
						
							|  |  |  |         this.generate_gradients(); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     get_render_params: function() { | 
					
						
							|  |  |  |         this.feed = NEWSBLUR.assets.get_feed(this.model.get('story_feed_id')); | 
					
						
							|  |  |  |         this.classifiers = NEWSBLUR.assets.classifiers[this.model.get('story_feed_id')]; | 
					
						
							| 
									
										
										
										
											2013-02-05 17:46:53 -08:00
										 |  |  |         var show_feed_title = NEWSBLUR.reader.flags.river_view ||  | 
					
						
							|  |  |  |                               NEWSBLUR.reader.flags.social_view ||  | 
					
						
							|  |  |  |                               this.options.show_feed_title; | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |         return { | 
					
						
							| 
									
										
										
										
											2013-07-06 13:34:36 -07:00
										 |  |  |             story             : this.model, | 
					
						
							|  |  |  |             feed              : show_feed_title && this.feed, | 
					
						
							|  |  |  |             tag               : _.first(this.model.get("story_tags")), | 
					
						
							|  |  |  |             title             : this.make_story_title(), | 
					
						
							|  |  |  |             authors_score     : this.classifiers &&  | 
					
						
							|  |  |  |                                 this.classifiers.authors[this.model.get('story_authors')], | 
					
						
							|  |  |  |             tags_score        : this.classifiers && this.classifiers.tags, | 
					
						
							|  |  |  |             options           : this.options, | 
					
						
							|  |  |  |             truncatable       : this.is_truncatable(), | 
					
						
							|  |  |  |             inline_story_title: this.options.inline_story_title | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |         }; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     story_header_template: _.template('\ | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |         <div class="NB-feed-story-header">\ | 
					
						
							|  |  |  |             <div class="NB-feed-story-header-feed">\ | 
					
						
							|  |  |  |                 <% if (feed) { %>\ | 
					
						
							|  |  |  |                     <div class="NB-feed-story-feed">\ | 
					
						
							|  |  |  |                         <img class="feed_favicon" src="<%= $.favicon(feed) %>">\ | 
					
						
							|  |  |  |                         <span class="NB-feed-story-header-title"><%= feed.get("feed_title") %></span>\ | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |                     </div>\ | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |                 <% } %>\ | 
					
						
							|  |  |  |             </div>\ | 
					
						
							|  |  |  |             <div class="NB-feed-story-header-info">\ | 
					
						
							|  |  |  |                 <div class="NB-feed-story-title-container">\ | 
					
						
							|  |  |  |                     <div class="NB-feed-story-sentiment"></div>\ | 
					
						
							|  |  |  |                     <div class="NB-feed-story-manage-icon"></div>\ | 
					
						
							|  |  |  |                     <a class="NB-feed-story-title" href="<%= story.get("story_permalink") %>"><%= title %></a>\ | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |                 </div>\ | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |                 <% if (story.get("long_parsed_date")) { %>\ | 
					
						
							| 
									
										
										
										
											2013-01-31 14:54:21 -08:00
										 |  |  |                     <div class="NB-feed-story-date">\ | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |                         <% if (story.has_modifications()) { %>\ | 
					
						
							|  |  |  |                             <div class="NB-feed-story-hide-changes" \ | 
					
						
							| 
									
										
										
										
											2013-02-26 10:00:35 -08:00
										 |  |  |                                  title="<%= NEWSBLUR.assets.preference("hide_story_changes") ? "Show" : "Hide" %> story modifications">\ | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |                             </div>\ | 
					
						
							|  |  |  |                         <% } %>\ | 
					
						
							|  |  |  |                         <%= story.get("long_parsed_date") %>\ | 
					
						
							| 
									
										
										
										
											2013-01-31 14:54:21 -08:00
										 |  |  |                     </div>\ | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |                 <% } %>\ | 
					
						
							| 
									
										
										
										
											2013-01-31 14:54:21 -08:00
										 |  |  |                 <% if (story.get("story_authors")) { %>\ | 
					
						
							| 
									
										
										
										
											2013-01-31 18:44:15 -08:00
										 |  |  |                     <div class="NB-feed-story-author-wrapper">\ | 
					
						
							| 
									
										
										
										
											2013-01-31 14:54:21 -08:00
										 |  |  |                         <span class="NB-middot">·</span>\ | 
					
						
							| 
									
										
										
										
											2013-01-31 18:44:15 -08:00
										 |  |  |                         <span class="NB-feed-story-author <% if (authors_score) { %>NB-score-<%= authors_score %><% } %>">\ | 
					
						
							|  |  |  |                             <%= story.get("story_authors") %>\ | 
					
						
							|  |  |  |                         </span>\ | 
					
						
							| 
									
										
										
										
											2013-01-31 14:54:21 -08:00
										 |  |  |                     </div>\ | 
					
						
							|  |  |  |                 <% } %>\ | 
					
						
							|  |  |  |                 <% if (story.get("story_tags", []).length) { %>\ | 
					
						
							|  |  |  |                     <div class="NB-feed-story-tags">\ | 
					
						
							|  |  |  |                         <span class="NB-middot">·</span>\ | 
					
						
							|  |  |  |                         <% _.each(story.get("story_tags"), function(tag) { %>\ | 
					
						
							|  |  |  |                             <div class="NB-feed-story-tag <% if (tags_score && tags_score[tag]) { %>NB-score-<%= tags_score[tag] %><% } %>">\ | 
					
						
							|  |  |  |                                 <%= tag %>\ | 
					
						
							|  |  |  |                             </div>\ | 
					
						
							|  |  |  |                         <% }) %>\ | 
					
						
							|  |  |  |                     </div>\ | 
					
						
							|  |  |  |                 <% } %>\ | 
					
						
							| 
									
										
										
										
											2013-02-25 14:45:59 -08:00
										 |  |  |                 <% if (story.get("starred_date")) { %>\ | 
					
						
							|  |  |  |                     <span class="NB-feed-story-starred-date"><%= story.get("starred_date") %></span>\ | 
					
						
							|  |  |  |                 <% } %>\ | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |             </div>\ | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |         </div>\ | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |     '), | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     template: _.template('\ | 
					
						
							|  |  |  |         <%= story_header %>\ | 
					
						
							| 
									
										
										
										
											2012-08-08 19:13:26 -07:00
										 |  |  |         <div class="NB-feed-story-shares-container"></div>\ | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |         <div class="NB-story-content-container">\ | 
					
						
							|  |  |  |             <div class="NB-story-content-wrapper <% if (truncatable) { %>NB-story-content-truncatable<% } %>">\ | 
					
						
							|  |  |  |                 <div class="NB-feed-story-content">\ | 
					
						
							|  |  |  |                     <% if (!options.skip_content) { %>\ | 
					
						
							|  |  |  |                         <%= story.get("story_content") %>\ | 
					
						
							|  |  |  |                     <% } %>\ | 
					
						
							|  |  |  |                 </div>\ | 
					
						
							|  |  |  |                 <div class="NB-story-content-expander">\ | 
					
						
							|  |  |  |                     <div class="NB-story-content-expander-inner">\ | 
					
						
							|  |  |  |                         <div class="NB-story-cutoff"></div>\ | 
					
						
							|  |  |  |                         <div class="NB-story-content-expander-text">Read the whole story</div>\ | 
					
						
							|  |  |  |                         <div class="NB-story-content-expander-pages"></div>\ | 
					
						
							|  |  |  |                     </div>\ | 
					
						
							|  |  |  |                 </div>\ | 
					
						
							|  |  |  |             </div>\ | 
					
						
							| 
									
										
										
										
											2013-02-11 12:35:42 -08:00
										 |  |  |             <div class="NB-feed-story-comments-container"></div>\ | 
					
						
							|  |  |  |             <div class="NB-feed-story-sideoptions-container">\ | 
					
						
							|  |  |  |                 <div class="NB-sideoption NB-feed-story-train">\ | 
					
						
							|  |  |  |                     <div class="NB-sideoption-icon"> </div>\ | 
					
						
							|  |  |  |                     <div class="NB-sideoption-title">Train this story</div>\ | 
					
						
							|  |  |  |                 </div>\ | 
					
						
							|  |  |  |                 <div class="NB-sideoption NB-feed-story-save">\ | 
					
						
							|  |  |  |                     <div class="NB-sideoption-icon"> </div>\ | 
					
						
							|  |  |  |                     <div class="NB-sideoption-title"><%= story.get("starred") ? "Saved" : "Save this story" %></div>\ | 
					
						
							|  |  |  |                 </div>\ | 
					
						
							| 
									
										
										
										
											2013-08-07 12:29:32 -07:00
										 |  |  |                 <%= story_save_view %>\ | 
					
						
							| 
									
										
										
										
											2013-02-11 12:35:42 -08:00
										 |  |  |                 <div class="NB-sideoption NB-feed-story-share">\ | 
					
						
							|  |  |  |                     <div class="NB-sideoption-icon"> </div>\ | 
					
						
							|  |  |  |                     <div class="NB-sideoption-title"><%= story.get("shared") ? "Shared" : "Share this story" %></div>\ | 
					
						
							|  |  |  |                 </div>\ | 
					
						
							|  |  |  |                 <%= story_share_view %>\ | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |             </div>\ | 
					
						
							|  |  |  |         </div>\ | 
					
						
							| 
									
										
										
										
											2013-07-06 13:34:36 -07:00
										 |  |  |         <% if (inline_story_title) { %>\ | 
					
						
							|  |  |  |             <div class="NB-feed-story-header-feed">\ | 
					
						
							|  |  |  |             </div>\ | 
					
						
							|  |  |  |         <% } %>\ | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |     '), | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     generate_gradients: function() { | 
					
						
							|  |  |  |         var $header = this.$('.NB-feed-story-header-feed'); | 
					
						
							| 
									
										
										
										
											2012-07-12 22:26:49 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-29 11:48:40 -07:00
										 |  |  |         if (!this.feed) return; | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2012-07-12 22:26:49 -07:00
										 |  |  |         var favicon_color = this.feed.get('favicon_color'); | 
					
						
							|  |  |  |         if (favicon_color) { | 
					
						
							|  |  |  |             $header.css('backgroundColor',  '#' + favicon_color); | 
					
						
							|  |  |  |             $header.css('background-image', 'none'); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |         $header.css('background-image', NEWSBLUR.utils.generate_gradient(this.feed, 'webkit')); | 
					
						
							|  |  |  |         $header.css('background-image', NEWSBLUR.utils.generate_gradient(this.feed, 'moz')); | 
					
						
							|  |  |  |         $header.css('borderTop',        NEWSBLUR.utils.generate_gradient(this.feed, 'border')); | 
					
						
							|  |  |  |         $header.css('borderBottom',     NEWSBLUR.utils.generate_gradient(this.feed, 'border')); | 
					
						
							| 
									
										
										
										
											2012-06-25 11:55:38 -07:00
										 |  |  |         $header.css('textShadow',       NEWSBLUR.utils.generate_shadow(this.feed)); | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2013-02-06 14:40:15 -08:00
										 |  |  |     is_truncatable: function() { | 
					
						
							|  |  |  |         return NEWSBLUR.assets.preference("truncate_story") == 'all' ||  | 
					
						
							|  |  |  |                (NEWSBLUR.assets.preference("truncate_story") == 'social' && | 
					
						
							|  |  |  |                 NEWSBLUR.reader.flags['social_view']); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2013-01-08 18:33:30 -08:00
										 |  |  |     make_story_title: function(story) { | 
					
						
							|  |  |  |         story = story || this.model; | 
					
						
							|  |  |  |         var title = story.get('story_title'); | 
					
						
							|  |  |  |         var classifiers = NEWSBLUR.assets.classifiers[story.get('story_feed_id')]; | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |         var feed_titles = classifiers && classifiers.titles || []; | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         _.each(feed_titles, function(score, title_classifier) { | 
					
						
							|  |  |  |             if (title.indexOf(title_classifier) != -1) { | 
					
						
							|  |  |  |                 title = title.replace(title_classifier, '<span class="NB-score-'+score+'">'+title_classifier+'</span>'); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         return title; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |     render_comments: function() { | 
					
						
							| 
									
										
										
										
											2012-08-08 19:13:26 -07:00
										 |  |  |         var $original_comments = this.$('.NB-feed-story-comments-container,.NB-feed-story-comments'); | 
					
						
							|  |  |  |         var $original_shares = this.$('.NB-feed-story-shares-container,.NB-feed-story-shares'); | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |         if (this.model.get("comment_count") || this.model.get("share_count")) { | 
					
						
							| 
									
										
										
										
											2013-12-16 12:20:56 -08:00
										 |  |  |             this.comments_view = new NEWSBLUR.Views.StoryCommentsView({model: this.model}).render(); | 
					
						
							| 
									
										
										
										
											2013-12-16 12:11:16 -08:00
										 |  |  |             var $comments = this.comments_view.el; | 
					
						
							| 
									
										
										
										
											2012-06-20 20:53:32 -07:00
										 |  |  |             $original_comments.replaceWith($comments); | 
					
						
							| 
									
										
										
										
											2012-08-08 19:13:26 -07:00
										 |  |  |             var $shares = $('.NB-story-comments-shares-teaser-wrapper', $comments); | 
					
						
							|  |  |  |             $original_shares.replaceWith($shares); | 
					
						
							| 
									
										
										
										
											2012-06-20 20:53:32 -07:00
										 |  |  |         } else if ($original_comments.length) { | 
					
						
							| 
									
										
										
										
											2012-08-08 19:13:26 -07:00
										 |  |  |             $original_comments.replaceWith($.make('div', { className: 'NB-feed-story-comments-container' })); | 
					
						
							|  |  |  |             $original_shares.replaceWith($.make('div', { className: 'NB-feed-story-shares-container' })); | 
					
						
							| 
									
										
										
										
											2012-06-02 16:33:44 -07:00
										 |  |  |         } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-06-14 17:21:51 -07:00
										 |  |  |     destroy: function() { | 
					
						
							| 
									
										
										
										
											2013-12-16 12:11:16 -08:00
										 |  |  |         // console.log(["destroy story detail", this.model.get('story_title')]);
 | 
					
						
							| 
									
										
										
										
											2013-02-12 16:02:41 -08:00
										 |  |  |         clearTimeout(this.truncate_delay_function); | 
					
						
							|  |  |  |         this.images_to_load = null; | 
					
						
							| 
									
										
										
										
											2012-06-14 17:21:51 -07:00
										 |  |  |         this.model.unbind(null, null, this); | 
					
						
							| 
									
										
										
										
											2013-12-16 12:11:16 -08:00
										 |  |  |         if (this.collection) this.collection.unbind(null, null, this); | 
					
						
							|  |  |  |         // this.sideoptions_view.destroy();
 | 
					
						
							|  |  |  |         if (this.comments_view) this.comments_view.destroy(); | 
					
						
							| 
									
										
										
										
											2013-02-11 17:09:38 -08:00
										 |  |  |         delete this.model.inline_story_detail_view; | 
					
						
							| 
									
										
										
										
											2012-06-14 17:21:51 -07:00
										 |  |  |         this.remove(); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2013-04-25 13:01:36 -07:00
										 |  |  |     render_intelligence: function(options) { | 
					
						
							|  |  |  |         options = options || {}; | 
					
						
							|  |  |  |         var score = this.model.score(); | 
					
						
							|  |  |  |         var unread_view = NEWSBLUR.reader.get_unread_view_score(); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         if (score >= unread_view || this.model.get('visible')) { | 
					
						
							|  |  |  |             this.$el.removeClass('NB-hidden'); | 
					
						
							|  |  |  |             this.model.set('visible', true); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             this.$el.addClass('NB-hidden'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     // ============
 | 
					
						
							|  |  |  |     // = Bindings =
 | 
					
						
							|  |  |  |     // ============
 | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |     toggle_classes: function() { | 
					
						
							| 
									
										
										
										
											2012-05-29 11:48:40 -07:00
										 |  |  |         var changes = this.model.changedAttributes(); | 
					
						
							|  |  |  |         var onlySelected = changes && _.all(_.keys(changes), function(change) { | 
					
						
							| 
									
										
										
										
											2012-07-01 12:49:08 -07:00
										 |  |  |             return _.contains(['selected', 'read', 'intelligence', 'visible'], change); | 
					
						
							| 
									
										
										
										
											2012-05-29 11:48:40 -07:00
										 |  |  |         }); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         if (onlySelected) return; | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2012-10-23 15:38:44 -07:00
										 |  |  |         if (this.model.changedAttributes()) { | 
					
						
							| 
									
										
										
										
											2013-01-23 10:02:14 -08:00
										 |  |  |             // NEWSBLUR.log(["Story changed", this.model.changedAttributes(), this.model.previousAttributes()]);
 | 
					
						
							| 
									
										
										
										
											2012-10-23 15:38:44 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-05-29 11:48:40 -07:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2013-02-11 12:35:42 -08:00
										 |  |  |         this.setup_classes(); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     setup_classes: function() { | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |         var story = this.model; | 
					
						
							| 
									
										
										
										
											2012-10-23 15:38:44 -07:00
										 |  |  |         var unread_view = NEWSBLUR.reader.get_unread_view_score(); | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2013-02-05 17:46:53 -08:00
										 |  |  |         this.$el.toggleClass('NB-river-story', NEWSBLUR.reader.flags.river_view || | 
					
						
							|  |  |  |                                                NEWSBLUR.reader.flags.social_view); | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |         this.$el.toggleClass('NB-story-starred', !!story.get('starred')); | 
					
						
							|  |  |  |         this.$el.toggleClass('NB-story-shared', !!story.get('shared')); | 
					
						
							| 
									
										
										
										
											2013-04-25 13:01:36 -07:00
										 |  |  |         this.toggle_intelligence(); | 
					
						
							|  |  |  |         this.render_intelligence(); | 
					
						
							| 
									
										
										
										
											2013-06-20 14:45:05 -07:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |         if (NEWSBLUR.assets.preference('show_tooltips')) { | 
					
						
							|  |  |  |             this.$('.NB-story-sentiment').tipsy({ | 
					
						
							|  |  |  |                 delayIn: 375, | 
					
						
							|  |  |  |                 gravity: 's' | 
					
						
							|  |  |  |             }); | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |             this.$('.NB-feed-story-hide-changes').tipsy({ | 
					
						
							|  |  |  |                 delayIn: 375 | 
					
						
							|  |  |  |             }); | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |         } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     toggle_read_status: function() { | 
					
						
							|  |  |  |         this.$el.toggleClass('read', !!this.model.get('read_status')); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2013-04-25 13:01:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     toggle_intelligence: function() { | 
					
						
							|  |  |  |         var score = this.model.score(); | 
					
						
							| 
									
										
										
										
											2012-07-01 12:49:08 -07:00
										 |  |  |         this.$el.removeClass('NB-story-negative NB-story-neutral NB-story-postiive') | 
					
						
							| 
									
										
										
										
											2013-04-25 13:01:36 -07:00
										 |  |  |                 .addClass('NB-story-'+this.model.score_name(score)); | 
					
						
							| 
									
										
										
										
											2012-07-01 12:49:08 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     toggle_selected: function(model, selected, options) { | 
					
						
							| 
									
										
										
										
											2013-01-14 12:50:00 -08:00
										 |  |  |         options = options || {}; | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |         this.$el.toggleClass('NB-selected', !!this.model.get('selected')); | 
					
						
							| 
									
										
										
										
											2013-04-08 11:47:21 -07:00
										 |  |  |         NEWSBLUR.app.taskbar_info.hide_stories_error(); | 
					
						
							| 
									
										
										
										
											2012-06-13 15:09:19 -07:00
										 |  |  |          | 
					
						
							|  |  |  |         if (selected && options.scroll_to_comments) { | 
					
						
							|  |  |  |             NEWSBLUR.app.story_list.scroll_to_selected_story(model, { | 
					
						
							|  |  |  |                 scroll_offset: -50, | 
					
						
							|  |  |  |                 scroll_to_comments: true | 
					
						
							|  |  |  |             }); | 
					
						
							| 
									
										
										
										
											2013-04-26 15:09:51 -07:00
										 |  |  |         } else if (NEWSBLUR.assets.preference('feed_view_single_story')) { | 
					
						
							|  |  |  |             NEWSBLUR.app.story_list.scroll_to_selected_story(model, { | 
					
						
							|  |  |  |                 'scroll_to_top': true | 
					
						
							|  |  |  |             }); | 
					
						
							| 
									
										
										
										
											2012-06-13 15:09:19 -07:00
										 |  |  |         } else if (selected &&  | 
					
						
							| 
									
										
										
										
											2012-06-11 17:51:12 -07:00
										 |  |  |             !options.selected_by_scrolling && | 
					
						
							|  |  |  |             (NEWSBLUR.reader.story_view == 'feed' || | 
					
						
							|  |  |  |              (NEWSBLUR.reader.story_view == 'page' && | 
					
						
							|  |  |  |               NEWSBLUR.reader.flags['page_view_showing_feed_view']))) { | 
					
						
							| 
									
										
										
										
											2013-04-25 13:01:36 -07:00
										 |  |  |             // NEWSBLUR.app.story_list.show_stories_preference_in_feed_view();
 | 
					
						
							| 
									
										
										
										
											2012-06-11 17:51:12 -07:00
										 |  |  |             NEWSBLUR.app.story_list.scroll_to_selected_story(model, options); | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-07-01 14:28:11 -07:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2013-01-09 15:36:35 -08:00
										 |  |  |         if (NEWSBLUR.reader.flags['feed_view_showing_story_view'] || | 
					
						
							|  |  |  |             NEWSBLUR.reader.flags['temporary_story_view']) { | 
					
						
							| 
									
										
										
										
											2012-07-01 14:28:11 -07:00
										 |  |  |             NEWSBLUR.reader.switch_to_correct_view(); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |     // ============
 | 
					
						
							|  |  |  |     // = Expander =
 | 
					
						
							|  |  |  |     // ============
 | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     truncate_story_height: function() { | 
					
						
							|  |  |  |         if (this._truncated) return; | 
					
						
							| 
									
										
										
										
											2013-06-20 19:46:41 -07:00
										 |  |  |         // if (NEWSBLUR.assets.preference('feed_view_single_story')) return;
 | 
					
						
							| 
									
										
										
										
											2013-06-20 14:45:05 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-12 16:02:41 -08:00
										 |  |  |         // console.log(["Checking truncate", this.$el, this.images_to_load, this.truncate_delay / 1000 + " sec delay"]);
 | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |         var $expander = this.$(".NB-story-content-expander"); | 
					
						
							|  |  |  |         var $expander_cutoff = this.$(".NB-story-cutoff"); | 
					
						
							|  |  |  |         var $wrapper = this.$(".NB-story-content-wrapper"); | 
					
						
							|  |  |  |         var $content = this.$(".NB-feed-story-content"); | 
					
						
							|  |  |  |         var max_height = parseInt($wrapper.css('maxHeight'), 10) || this.STORY_CONTENT_MAX_HEIGHT; | 
					
						
							|  |  |  |         var content_height = $content.outerHeight(true); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         if (content_height > max_height &&  | 
					
						
							|  |  |  |             content_height < max_height + this.FUDGE_CONTENT_HEIGHT_OVERAGE) { | 
					
						
							| 
									
										
										
										
											2013-02-05 16:03:55 -08:00
										 |  |  |             // console.log(["Height over but within fudge", this.model.get('story_title').substr(0, 30), content_height, max_height]);
 | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |             $wrapper.addClass('NB-story-content-wrapper-height-fudged'); | 
					
						
							|  |  |  |         } else if (content_height > max_height) { | 
					
						
							|  |  |  |             $expander.css('display', 'block'); | 
					
						
							|  |  |  |             $expander_cutoff.css('display', 'block'); | 
					
						
							|  |  |  |             $wrapper.removeClass('NB-story-content-wrapper-height-fudged'); | 
					
						
							|  |  |  |             $wrapper.addClass('NB-story-content-wrapper-height-truncated'); | 
					
						
							|  |  |  |             var pages = Math.round(content_height / max_height, true); | 
					
						
							|  |  |  |             var dots = _.map(_.range(pages), function() { return '·'; }).join(' '); | 
					
						
							|  |  |  |              | 
					
						
							| 
									
										
										
										
											2013-02-05 16:03:55 -08:00
										 |  |  |             // console.log(["Height over, truncating...", this.model.get('story_title').substr(0, 30), content_height, max_height, pages]);
 | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |             this.$(".NB-story-content-expander-pages").html(dots); | 
					
						
							|  |  |  |             this._truncated = true; | 
					
						
							|  |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2013-02-05 16:03:55 -08:00
										 |  |  |             // console.log(["Height under.", this.model.get('story_title').substr(0, 30), content_height, max_height]);
 | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-02-12 16:02:41 -08:00
										 |  |  |          | 
					
						
							|  |  |  |         if (this.images_to_load > 0) { | 
					
						
							|  |  |  |             this.truncate_delay *= 1 + Math.random(); | 
					
						
							|  |  |  |             clearTimeout(this.truncate_delay_function); | 
					
						
							|  |  |  |             this.truncate_delay_function = _.delay(_.bind(this.truncate_story_height, this), this.truncate_delay); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     watch_images_for_story_height: function() { | 
					
						
							| 
									
										
										
										
											2013-12-06 13:56:28 -08:00
										 |  |  |         this.model.on('change:images_loaded', _.bind(function() { | 
					
						
							|  |  |  |             this.resize_starred_tags(); | 
					
						
							|  |  |  |         }, this)); | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2013-02-06 14:40:15 -08:00
										 |  |  |         if (!this.is_truncatable()) return; | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2013-02-12 16:02:41 -08:00
										 |  |  |         this.truncate_delay = 100; | 
					
						
							|  |  |  |         this.images_to_load = this.$('img').length; | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |         this.truncate_story_height(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.$('img').load(_.bind(function() { | 
					
						
							| 
									
										
										
										
											2013-02-12 16:02:41 -08:00
										 |  |  |             this.images_to_load -= 1; | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |             this.truncate_story_height(); | 
					
						
							|  |  |  |         }, this)); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     expand_story: function(options) { | 
					
						
							|  |  |  |         options = options || {}; | 
					
						
							|  |  |  |         var $expander = this.$(".NB-story-content-expander"); | 
					
						
							|  |  |  |         var $expander_cutoff = this.$(".NB-story-cutoff"); | 
					
						
							|  |  |  |         var $wrapper = this.$(".NB-story-content-wrapper"); | 
					
						
							|  |  |  |         var $content = this.$(".NB-feed-story-content"); | 
					
						
							|  |  |  |         var max_height = parseInt($wrapper.css('maxHeight'), 10) || this.STORY_CONTENT_MAX_HEIGHT; | 
					
						
							|  |  |  |         var content_height = $content.outerHeight(true); | 
					
						
							|  |  |  |         var height_ratio = content_height / max_height; | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         if (content_height < max_height) return; | 
					
						
							|  |  |  |         // console.log(["max height", max_height, content_height, content_height / max_height]);
 | 
					
						
							|  |  |  |         this._fetch_interval = setInterval(function() { | 
					
						
							|  |  |  |             NEWSBLUR.app.story_list.fetch_story_locations_in_feed_view(); | 
					
						
							|  |  |  |         }, 250); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         $wrapper.animate({ | 
					
						
							|  |  |  |             maxHeight: content_height | 
					
						
							|  |  |  |         }, { | 
					
						
							|  |  |  |             duration: options.instant ? 0 : Math.min(2 * 1000, parseInt(200 * height_ratio, 10)), | 
					
						
							|  |  |  |             easing: 'easeInOutQuart', | 
					
						
							|  |  |  |             complete: _.bind(function() { | 
					
						
							|  |  |  |                 clearInterval(this._fetch_interval); | 
					
						
							|  |  |  |                 NEWSBLUR.app.story_list.fetch_story_locations_in_feed_view(); | 
					
						
							| 
									
										
										
										
											2013-02-12 12:18:32 -08:00
										 |  |  |                 $wrapper.removeClass('NB-story-content-wrapper-height-truncated'); | 
					
						
							| 
									
										
										
										
											2013-02-05 12:52:32 -08:00
										 |  |  |             }, this) | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         $expander.add($expander_cutoff).animate({ | 
					
						
							|  |  |  |             bottom: -1 * $expander.outerHeight() - 48 | 
					
						
							|  |  |  |         }, { | 
					
						
							|  |  |  |             duration: options.instant ? 0 : Math.min(2 * 1000, parseInt(200 * height_ratio, 10)), | 
					
						
							|  |  |  |             easing: 'easeInOutQuart' | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     // ===========
 | 
					
						
							|  |  |  |     // = Actions =
 | 
					
						
							|  |  |  |     // ===========
 | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2013-06-07 12:08:14 -04:00
										 |  |  |     mark_read: function() { | 
					
						
							| 
									
										
										
										
											2013-07-13 11:06:26 -07:00
										 |  |  |         this.model.mark_read({force: true}); | 
					
						
							| 
									
										
										
										
											2013-06-07 12:08:14 -04:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |     preserve_classifier_color: function(classifier_type, value, score) { | 
					
						
							|  |  |  |         var $tag; | 
					
						
							|  |  |  |         this.$('.NB-feed-story-'+classifier_type).each(function() { | 
					
						
							| 
									
										
										
										
											2012-05-25 22:13:50 -07:00
										 |  |  |             if (_.string.trim($(this).text()) == value) { | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |                 $tag = $(this); | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |         $tag.removeClass('NB-score-now-1') | 
					
						
							|  |  |  |             .removeClass('NB-score-now--1') | 
					
						
							|  |  |  |             .removeClass('NB-score-now-0') | 
					
						
							|  |  |  |             .addClass('NB-score-now-'+score) | 
					
						
							|  |  |  |             .one('mouseleave', function() { | 
					
						
							| 
									
										
										
										
											2013-07-06 13:34:36 -07:00
										 |  |  |                 // console.log(["leave", score]);
 | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |                 $tag.removeClass('NB-score-now-'+score); | 
					
						
							| 
									
										
										
										
											2013-04-25 13:01:36 -07:00
										 |  |  |                 _.delay(function() { | 
					
						
							|  |  |  |                     $tag.one('mouseenter', function() { | 
					
						
							| 
									
										
										
										
											2013-07-06 13:34:36 -07:00
										 |  |  |                         // console.log(["enter", score]);
 | 
					
						
							| 
									
										
										
										
											2013-04-25 13:01:36 -07:00
										 |  |  |                         $tag.removeClass('NB-score-now-'+score); | 
					
						
							|  |  |  |                     }); | 
					
						
							|  |  |  |                 }, 100); | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |             }); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-13 13:15:36 -07:00
										 |  |  |     render_starred: function() { | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |         var story = this.model; | 
					
						
							|  |  |  |         var $sideoption_title = this.$('.NB-feed-story-save .NB-sideoption-title'); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         if (story.get('starred')) { | 
					
						
							|  |  |  |             $sideoption_title.text('Saved'); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             $sideoption_title.text('Removed'); | 
					
						
							|  |  |  |             $sideoption_title.one('mouseleave', function() { | 
					
						
							|  |  |  |                 _.delay(function() { | 
					
						
							|  |  |  |                     if (!story.get('starred')) { | 
					
						
							|  |  |  |                         $sideoption_title.text('Save this story'); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 }, 200); | 
					
						
							|  |  |  |             });         | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2014-01-03 17:13:21 -08:00
										 |  |  |     attach_audio_handler: function() { | 
					
						
							| 
									
										
										
										
											2012-08-30 15:56:15 -07:00
										 |  |  |         _.delay(_.bind(function() { | 
					
						
							|  |  |  |             var $audio = this.$('audio').filter(function() { | 
					
						
							|  |  |  |                 return !$(this).closest('.audiojs').length; | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             var audio_opts = window.a = { | 
					
						
							|  |  |  |                 imageLocation: NEWSBLUR.Globals.MEDIA_URL + 'img/reader/player-graphics.gif', | 
					
						
							|  |  |  |                 swfLocation: NEWSBLUR.Globals.MEDIA_URL + 'flash/audiojs.swf', | 
					
						
							|  |  |  |                 preload: false | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             audiojs.events.ready(function() { | 
					
						
							|  |  |  |                 audiojs.createAll(audio_opts, $audio); | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |         }, this), 500); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2014-01-03 17:13:21 -08:00
										 |  |  |     attach_syntax_highlighter_handler: function() { | 
					
						
							|  |  |  |         _.delay(_.bind(function() { | 
					
						
							|  |  |  |             this.$('pre').each(function(i, e) { | 
					
						
							|  |  |  |                 hljs.highlightBlock(e); | 
					
						
							|  |  |  |             }); | 
					
						
							| 
									
										
										
										
											2014-01-05 14:55:24 -08:00
										 |  |  |         }, this), 100); | 
					
						
							| 
									
										
										
										
											2014-01-03 17:13:21 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     attach_fitvid_handler: function() { | 
					
						
							|  |  |  |         // Thanks to feedbin for the custom selector
 | 
					
						
							|  |  |  |         _.delay(_.bind(function() { | 
					
						
							|  |  |  |             this.$el.fitVids({ | 
					
						
							|  |  |  |                 customSelector: "iframe[src*='youtu.be'],iframe[src*='www.flickr.com'],iframe[src*='view.vzaar.com']" | 
					
						
							|  |  |  |             }); | 
					
						
							| 
									
										
										
										
											2014-01-05 14:55:24 -08:00
										 |  |  |         }, this), 50); | 
					
						
							| 
									
										
										
										
											2014-01-03 17:13:21 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     // ==========
 | 
					
						
							|  |  |  |     // = Events =
 | 
					
						
							|  |  |  |     // ==========
 | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     click_link_in_story: function(e) { | 
					
						
							| 
									
										
										
										
											2013-06-03 14:42:22 -07:00
										 |  |  |         if (NEWSBLUR.hotkeys.shift) return; | 
					
						
							| 
									
										
										
										
											2014-01-05 14:55:24 -08:00
										 |  |  |         var $target = $(e.currentTarget); | 
					
						
							| 
									
										
										
										
											2013-06-03 14:42:22 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |         e.preventDefault(); | 
					
						
							| 
									
										
										
										
											2012-08-30 15:08:24 -07:00
										 |  |  |         e.stopPropagation(); | 
					
						
							|  |  |  |         if (e.which >= 2) return; | 
					
						
							|  |  |  |         if (e.which == 1 && $('.NB-menu-manage-container:visible').length) return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-05 14:55:24 -08:00
										 |  |  |         var href = $target.attr('href'); | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2014-01-06 12:10:25 -08:00
										 |  |  |         // Fix footnotes
 | 
					
						
							|  |  |  |         if (_.string.contains(href, "#")) { | 
					
						
							| 
									
										
										
										
											2014-01-08 11:25:32 -08:00
										 |  |  |             try { | 
					
						
							|  |  |  |                 footnote_href = href.replace(/^.*?\#(.*?)$/, "\#$1") | 
					
						
							|  |  |  |                                     .replace(':', "\\\:"); | 
					
						
							|  |  |  |                 var $footnote = $(footnote_href); | 
					
						
							|  |  |  |             } catch (err) { | 
					
						
							|  |  |  |                 $footnote = []; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2014-01-06 12:10:25 -08:00
										 |  |  |             if ($footnote.length) { | 
					
						
							| 
									
										
										
										
											2014-01-08 11:04:28 -08:00
										 |  |  |                 href = footnote_href; | 
					
						
							| 
									
										
										
										
											2014-01-06 12:10:25 -08:00
										 |  |  |                 var offset = $(href).offset().top; | 
					
						
							| 
									
										
										
										
											2014-01-06 12:21:46 -08:00
										 |  |  |                 var $scroll; | 
					
						
							|  |  |  |                 if (NEWSBLUR.assets.preference('story_layout') == "list") { | 
					
						
							|  |  |  |                     $scroll = NEWSBLUR.reader.$s.$story_titles; | 
					
						
							|  |  |  |                 } else if (NEWSBLUR.reader.flags['temporary_story_view'] ||  | 
					
						
							|  |  |  |                     NEWSBLUR.reader.story_view == 'text') { | 
					
						
							|  |  |  |                     $scroll = NEWSBLUR.reader.$s.$text_view; | 
					
						
							|  |  |  |                 } else { | 
					
						
							|  |  |  |                     $scroll = NEWSBLUR.reader.$s.$feed_scroll; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 offset += $scroll.scrollTop(); | 
					
						
							|  |  |  |                 $scroll.stop().scrollTo(offset-60, { | 
					
						
							| 
									
										
										
										
											2014-01-06 12:10:25 -08:00
										 |  |  |                     duration: 340, | 
					
						
							|  |  |  |                     axis: 'y',  | 
					
						
							|  |  |  |                     easing: 'easeInOutQuint' | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |         if (NEWSBLUR.assets.preference('new_window') == 1) { | 
					
						
							|  |  |  |             window.open(href, '_blank'); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             window.open(href); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-05-07 16:39:05 -07:00
										 |  |  |          | 
					
						
							|  |  |  |         this.model.set('selected', true, {selected_by_scrolling: true}); | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     mouseenter_manage_icon: function() { | 
					
						
							|  |  |  |         var menu_height = 270; | 
					
						
							|  |  |  |         if (this.$el.offset().top > $(window).height() - menu_height) { | 
					
						
							|  |  |  |             this.$el.addClass('NB-hover-inverse'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     mouseleave_manage_icon: function() { | 
					
						
							|  |  |  |         this.$el.removeClass('NB-hover-inverse'); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     mouseenter: function() { | 
					
						
							|  |  |  |         if (this.model.get('selected')) return; | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2012-06-11 18:23:59 -07:00
										 |  |  |         if (NEWSBLUR.reader.flags['scrolling_by_selecting_story_title'] || | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |             NEWSBLUR.assets.preference('feed_view_single_story')) { | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |         this.model.set('selected', true, {selected_by_scrolling: true}); | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2012-05-24 17:32:01 -07:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     mouseleave: function() { | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2012-05-25 18:54:04 -07:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2013-07-12 15:21:11 -07:00
										 |  |  |      | 
					
						
							|  |  |  |     show_manage_menu_rightclick: function(e) { | 
					
						
							|  |  |  |         if (!NEWSBLUR.assets.preference('show_contextmenus')) return; | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         return this.show_manage_menu(e); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2012-05-25 18:54:04 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     show_manage_menu: function(e) { | 
					
						
							|  |  |  |         e.preventDefault(); | 
					
						
							|  |  |  |         e.stopPropagation(); | 
					
						
							|  |  |  |         NEWSBLUR.reader.show_manage_menu('story', this.$el, { | 
					
						
							|  |  |  |             story_id: this.model.id, | 
					
						
							| 
									
										
										
										
											2012-08-30 18:31:44 -07:00
										 |  |  |             feed_id: this.model.get('story_feed_id'), | 
					
						
							|  |  |  |             rightclick: e.which >= 2 | 
					
						
							| 
									
										
										
										
											2012-05-25 18:54:04 -07:00
										 |  |  |         }); | 
					
						
							|  |  |  |         return false; | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     hide_story_changes: function() { | 
					
						
							|  |  |  |         var $button = this.$('.NB-feed-story-hide-changes'); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         if (NEWSBLUR.assets.preference('hide_story_changes')) { | 
					
						
							| 
									
										
										
										
											2012-09-26 13:49:17 -07:00
										 |  |  |             this.$el.addClass('NB-story-show-changes'); | 
					
						
							|  |  |  |             // this.$('ins').css({'text-decoration': 'underline'});
 | 
					
						
							|  |  |  |             // this.$('del').css({'display': 'inline'});
 | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2012-09-26 13:49:17 -07:00
										 |  |  |             this.$el.addClass('NB-story-hide-changes'); | 
					
						
							|  |  |  |             // this.$('ins').css({'text-decoration': 'none'});
 | 
					
						
							|  |  |  |             // this.$('del').css({'display': 'none'});
 | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-02-15 17:51:31 -08:00
										 |  |  |         $button.css('opacity', 1).animate({ | 
					
						
							|  |  |  |             'width': 0, | 
					
						
							|  |  |  |             'opacity': 0 | 
					
						
							|  |  |  |         }, { | 
					
						
							|  |  |  |             'queue': false, | 
					
						
							|  |  |  |             'duration': 500 | 
					
						
							|  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |         $button.tipsy('hide').tipsy('disable'); | 
					
						
							| 
									
										
										
										
											2012-06-19 14:21:43 -07:00
										 |  |  |         NEWSBLUR.app.story_list.fetch_story_locations_in_feed_view(); | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     open_feed: function() { | 
					
						
							|  |  |  |         NEWSBLUR.reader.open_feed(this.model.get('story_feed_id')); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     save_classifier: function(e) { | 
					
						
							|  |  |  |         var $tag = $(e.currentTarget); | 
					
						
							| 
									
										
										
										
											2013-01-31 18:44:15 -08:00
										 |  |  |         var classifier_type = $tag.hasClass('NB-feed-story-tag') ? 'tag' : 'author'; | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |         var value = _.string.trim($tag.text()); | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |         var score = $tag.hasClass('NB-score-1') ? -1 : $tag.hasClass('NB-score--1') ? 0 : 1; | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |         var feed_id = this.model.get('story_feed_id'); | 
					
						
							|  |  |  |         var data = { | 
					
						
							|  |  |  |             'feed_id': feed_id | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         if (score == 0) { | 
					
						
							|  |  |  |             data['remove_like_'+classifier_type] = value; | 
					
						
							|  |  |  |         } else if (score == 1) { | 
					
						
							|  |  |  |             data['like_'+classifier_type] = value; | 
					
						
							|  |  |  |         } else if (score == -1) { | 
					
						
							|  |  |  |             data['dislike_'+classifier_type] = value; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-07-01 12:49:08 -07:00
										 |  |  |         this.model.set('visible', true, {silent: true}); | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |         NEWSBLUR.assets.classifiers[feed_id][classifier_type+'s'][value] = score; | 
					
						
							| 
									
										
										
										
											2012-07-01 12:00:30 -07:00
										 |  |  |         NEWSBLUR.assets.recalculate_story_scores(feed_id, {story_view: this}); | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |         NEWSBLUR.assets.save_classifier(data, function(resp) { | 
					
						
							| 
									
										
										
										
											2012-12-10 20:22:21 -08:00
										 |  |  |             NEWSBLUR.reader.feed_unread_count(feed_id); | 
					
						
							| 
									
										
										
										
											2012-06-12 16:13:34 -07:00
										 |  |  |         }); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         this.preserve_classifier_color(classifier_type, value, score); | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     open_story_trainer: function() { | 
					
						
							| 
									
										
										
										
											2012-09-07 19:14:01 -07:00
										 |  |  |         var feed_id = this.model.get('story_feed_id'); | 
					
						
							|  |  |  |         var options = {}; | 
					
						
							|  |  |  |         if (NEWSBLUR.reader.flags['social_view']) { | 
					
						
							|  |  |  |             options['social_feed'] = true; | 
					
						
							| 
									
										
										
										
											2012-12-28 11:34:06 -08:00
										 |  |  |             options['feed_loaded'] = true; | 
					
						
							| 
									
										
										
										
											2012-09-07 19:14:01 -07:00
										 |  |  |         } | 
					
						
							|  |  |  |         NEWSBLUR.reader.open_story_trainer(this.model.id, feed_id, options); | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2013-08-13 13:15:36 -07:00
										 |  |  |     toggle_starred: function() { | 
					
						
							|  |  |  |         this.model.toggle_starred(); | 
					
						
							| 
									
										
										
										
											2012-05-25 20:52:30 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2012-11-26 12:50:05 -08:00
										 |  |  |     scroll_to_comments: function() { | 
					
						
							|  |  |  |         NEWSBLUR.app.story_list.scroll_to_selected_story(this.model, { | 
					
						
							|  |  |  |             scroll_to_comments: true, | 
					
						
							|  |  |  |             scroll_offset: -50 | 
					
						
							|  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-06-06 20:37:20 -07:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2012-05-25 18:54:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-25 16:42:41 -07:00
										 |  |  | }); |