NewsBlur/media/js/newsblur/views/story_detail_view.js

750 lines
30 KiB
JavaScript
Raw Normal View History

NEWSBLUR.Views.StoryDetailView = Backbone.View.extend({
tagName: 'li',
className: 'NB-feed-story',
FUDGE_CONTENT_HEIGHT_OVERAGE: 260,
STORY_CONTENT_MAX_HEIGHT: 460, // ALSO CHANGE IN reader.css: .NB-story-content-wrapper-height-truncated
2012-05-25 16:42:41 -07:00
events: {
"click" : "mark_read",
2012-05-25 16:42:41 -07:00
"click .NB-feed-story-content a" : "click_link_in_story",
"click .NB-feed-story-share-container a": "click_link_in_story",
"click .NB-feed-story-comments a" : "click_link_in_story",
"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",
"mouseleave .NB-feed-story-manage-icon" : "mouseleave_manage_icon",
"contextmenu .NB-feed-story-header" : "show_manage_menu_rightclick",
"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",
"click .NB-feed-story-save" : "toggle_starred",
"click .NB-story-comments-label" : "scroll_to_comments",
"click .NB-story-content-expander" : "expand_story"
2012-05-25 16:42:41 -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);
this.model.bind('change:starred', this.render_starred, this);
this.model.bind('change:intelligence', this.render_header, this);
this.model.bind('change:intelligence', this.toggle_intelligence, this);
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.
// this.$el.bind('mouseenter', this.mouseenter);
// this.$el.bind('mouseleave', this.mouseleave);
2012-06-14 17:21:51 -07: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;
} else if (this.options.inline_story_title) {
2013-02-12 16:07:01 -08:00
this.model.story_view = this;
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-25 16:42:41 -07:00
// =============
// = Rendering =
// =============
render: function() {
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({
model: this.model,
el: this.el
});
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({
story: this.model,
social_services: NEWSBLUR.assets.social_services,
profile: NEWSBLUR.assets.user_profile
});
this.$el.html(this.template(params));
if (this.feed) {
this.$el.toggleClass('NB-inverse', this.feed.is_light());
}
2013-06-20 14:45:05 -07:00
this.setup_classes();
this.toggle_classes();
this.toggle_read_status();
this.toggle_intelligence();
this.generate_gradients();
2012-06-02 16:33:44 -07:00
this.render_comments();
return this;
},
render_starred_tags: function() {
if (this.model.get('starred')) {
this.save_view.toggle_feed_story_save_dialog();
}
},
resize_starred_tags: function() {
if (this.model.get('starred')) {
this.save_view.reset_height({immediate: true});
}
},
attach_handlers: function() {
this.watch_images_for_story_height();
this.attach_audio_handler();
this.attach_syntax_highlighter_handler();
this.attach_fitvid_handler();
this.render_starred_tags();
},
render_header: function(model, value, options) {
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')];
var show_feed_title = NEWSBLUR.reader.flags.river_view ||
NEWSBLUR.reader.flags.social_view ||
this.options.show_feed_title;
return {
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
};
},
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>\
</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>\
</div>\
2012-06-02 16:33:44 -07:00
<% if (story.get("long_parsed_date")) { %>\
<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") %>\
</div>\
2012-06-02 16:33:44 -07:00
<% } %>\
<% if (story.get("story_authors")) { %>\
2013-01-31 18:44:15 -08:00
<div class="NB-feed-story-author-wrapper">\
<span class="NB-middot">&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>\
</div>\
<% } %>\
<% if (story.get("story_tags", []).length) { %>\
<div class="NB-feed-story-tags">\
<span class="NB-middot">&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>\
<% } %>\
<% if (story.get("starred_date")) { %>\
<span class="NB-feed-story-starred-date"><%= story.get("starred_date") %></span>\
<% } %>\
</div>\
2012-06-02 16:33:44 -07:00
</div>\
'),
template: _.template('\
<%= story_header %>\
<div class="NB-feed-story-shares-container"></div>\
<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>\
<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">&nbsp;</div>\
<div class="NB-sideoption-title">Train this story</div>\
</div>\
<div class="NB-sideoption NB-feed-story-save">\
<div class="NB-sideoption-icon">&nbsp;</div>\
<div class="NB-sideoption-title"><%= story.get("starred") ? "Saved" : "Save this story" %></div>\
</div>\
<%= story_save_view %>\
<div class="NB-sideoption NB-feed-story-share">\
<div class="NB-sideoption-icon">&nbsp;</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>\
<% if (inline_story_title) { %>\
<div class="NB-feed-story-header-feed">\
</div>\
<% } %>\
2012-06-02 16:33:44 -07:00
'),
2012-05-25 16:42:41 -07:00
generate_gradients: function() {
var $header = this.$('.NB-feed-story-header-feed');
if (!this.feed) return;
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'));
$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']);
},
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() {
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);
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) {
$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();
delete this.model.inline_story_detail_view;
2012-06-14 17:21:51 -07:00
this.remove();
},
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 =
// ============
toggle_classes: function() {
var changes = this.model.changedAttributes();
var onlySelected = changes && _.all(_.keys(changes), function(change) {
return _.contains(['selected', 'read', 'intelligence', 'visible'], change);
});
if (onlySelected) return;
if (this.model.changedAttributes()) {
// NEWSBLUR.log(["Story changed", this.model.changedAttributes(), this.model.previousAttributes()]);
}
this.setup_classes();
},
setup_classes: function() {
var story = this.model;
var unread_view = NEWSBLUR.reader.get_unread_view_score();
this.$el.toggleClass('NB-river-story', NEWSBLUR.reader.flags.river_view ||
NEWSBLUR.reader.flags.social_view);
this.$el.toggleClass('NB-story-starred', !!story.get('starred'));
this.$el.toggleClass('NB-story-shared', !!story.get('shared'));
this.toggle_intelligence();
this.render_intelligence();
2013-06-20 14:45:05 -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
});
}
},
toggle_read_status: function() {
this.$el.toggleClass('read', !!this.model.get('read_status'));
},
toggle_intelligence: function() {
var score = this.model.score();
this.$el.removeClass('NB-story-negative NB-story-neutral NB-story-postiive')
.addClass('NB-story-'+this.model.score_name(score));
},
2012-05-25 16:42:41 -07:00
toggle_selected: function(model, selected, options) {
options = options || {};
2012-05-25 16:42:41 -07:00
this.$el.toggleClass('NB-selected', !!this.model.get('selected'));
NEWSBLUR.app.taskbar_info.hide_stories_error();
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
});
} 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']))) {
// 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
}
if (NEWSBLUR.reader.flags['feed_view_showing_story_view'] ||
NEWSBLUR.reader.flags['temporary_story_view']) {
NEWSBLUR.reader.switch_to_correct_view();
}
2012-05-25 16:42:41 -07:00
},
// ============
// = Expander =
// ============
truncate_story_height: function() {
if (this._truncated) return;
// 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"]);
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) {
// console.log(["Height over but within fudge", this.model.get('story_title').substr(0, 30), content_height, max_height]);
$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 '&middot;'; }).join(' ');
// console.log(["Height over, truncating...", this.model.get('story_title').substr(0, 30), content_height, max_height, pages]);
this.$(".NB-story-content-expander-pages").html(dots);
this._truncated = true;
} else {
// console.log(["Height under.", this.model.get('story_title').substr(0, 30), content_height, max_height]);
}
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);
}
},
watch_images_for_story_height: function() {
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;
this.truncate_story_height();
this.$('img').load(_.bind(function() {
2013-02-12 16:02:41 -08:00
this.images_to_load -= 1;
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');
}, 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 =
// ===========
mark_read: function() {
this.model.mark_read({force: true});
},
preserve_classifier_color: function(classifier_type, value, score) {
var $tag;
this.$('.NB-feed-story-'+classifier_type).each(function() {
if (_.string.trim($(this).text()) == value) {
$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() {
// console.log(["leave", score]);
$tag.removeClass('NB-score-now-'+score);
_.delay(function() {
$tag.one('mouseenter', function() {
// console.log(["enter", score]);
$tag.removeClass('NB-score-now-'+score);
});
}, 100);
});
},
render_starred: function() {
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);
});
}
},
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);
},
attach_syntax_highlighter_handler: function() {
_.delay(_.bind(function() {
this.$('pre').each(function(i, e) {
hljs.highlightBlock(e);
});
}, this), 100);
},
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']"
});
}, this), 50);
},
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;
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;
var href = $target.attr('href');
2014-01-06 12:10:25 -08:00
// Fix footnotes
if (_.string.contains(href, "#")) {
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-25 16:42:41 -07:00
if (NEWSBLUR.assets.preference('new_window') == 1) {
window.open(href, '_blank');
} else {
window.open(href);
}
this.model.set('selected', true, {selected_by_scrolling: true});
},
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;
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;
}
this.model.set('selected', true, {selected_by_scrolling: true});
2012-05-25 16:42:41 -07:00
},
2012-05-25 16:42:41 -07:00
mouseleave: function() {
},
show_manage_menu_rightclick: function(e) {
if (!NEWSBLUR.assets.preference('show_contextmenus')) return;
return this.show_manage_menu(e);
},
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
});
return false;
},
hide_story_changes: function() {
var $button = this.$('.NB-feed-story-hide-changes');
if (NEWSBLUR.assets.preference('hide_story_changes')) {
this.$el.addClass('NB-story-show-changes');
// this.$('ins').css({'text-decoration': 'underline'});
// this.$('del').css({'display': 'inline'});
} else {
this.$el.addClass('NB-story-hide-changes');
// this.$('ins').css({'text-decoration': 'none'});
// this.$('del').css({'display': 'none'});
}
2013-02-15 17:51:31 -08:00
$button.css('opacity', 1).animate({
'width': 0,
'opacity': 0
}, {
'queue': false,
'duration': 500
});
$button.tipsy('hide').tipsy('disable');
NEWSBLUR.app.story_list.fetch_story_locations_in_feed_view();
},
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';
var value = _.string.trim($tag.text());
var score = $tag.hasClass('NB-score-1') ? -1 : $tag.hasClass('NB-score--1') ? 0 : 1;
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;
}
this.model.set('visible', true, {silent: true});
NEWSBLUR.assets.classifiers[feed_id][classifier_type+'s'][value] = score;
NEWSBLUR.assets.recalculate_story_scores(feed_id, {story_view: this});
NEWSBLUR.assets.save_classifier(data, function(resp) {
NEWSBLUR.reader.feed_unread_count(feed_id);
});
this.preserve_classifier_color(classifier_type, value, score);
},
open_story_trainer: function() {
var feed_id = this.model.get('story_feed_id');
var options = {};
if (NEWSBLUR.reader.flags['social_view']) {
options['social_feed'] = true;
options['feed_loaded'] = true;
}
NEWSBLUR.reader.open_story_trainer(this.model.id, feed_id, options);
},
toggle_starred: function() {
this.model.toggle_starred();
},
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-05-25 16:42:41 -07:00
});