NewsBlur/media/js/newsblur/reader_statistics.js

117 lines
5.1 KiB
JavaScript
Raw Normal View History

NEWSBLUR.ReaderStatistics = function(feed_id, options) {
var defaults = {};
this.options = $.extend({}, defaults, options);
this.model = NEWSBLUR.AssetModel.reader();
this.google_favicon_url = 'http://www.google.com/s2/favicons?domain_url=';
this.feed_id = feed_id;
this.feed = this.model.get_feed(feed_id);
this.runner();
};
NEWSBLUR.ReaderStatistics.prototype = {
runner: function() {
this.make_modal();
this.open_modal();
this.get_stats();
},
make_modal: function() {
var self = this;
this.$modal = $.make('div', { className: 'NB-modal-statistics NB-modal' }, [
$.make('h2', { className: 'NB-modal-title' }, 'Statistics & History'),
$.make('h2', { className: 'NB-modal-subtitle' }, [
$.make('img', { className: 'NB-modal-statistics-feed-image feed_favicon', src: this.google_favicon_url + this.feed.feed_link }),
$.make('span', { className: 'NB-modal-statistics-feed-title' }, this.feed.feed_title)
]),
$.make('div', { className: 'NB-modal-statistics-info' })
]);
},
open_modal: function() {
var self = this;
var $holder = $.make('div', { className: 'NB-modal-holder' }).append(this.$modal).appendTo('body').css({'visibility': 'hidden', 'display': 'block', 'width': 600});
var height = $('.NB-add', $holder).outerHeight(true);
$holder.css({'visibility': 'visible', 'display': 'none'});
this.$modal.modal({
'minWidth': 600,
'maxHeight': height,
'minHeight': 340,
'overlayClose': true,
'onOpen': function (dialog) {
dialog.overlay.fadeIn(200, function () {
dialog.container.fadeIn(200);
dialog.data.fadeIn(200);
});
},
'onShow': function(dialog) {
$('#simplemodal-container').corner('6px');
$.modal.impl.setPosition();
},
'onClose': function(dialog) {
dialog.data.hide().empty().remove();
dialog.container.hide().empty().remove();
dialog.overlay.fadeOut(200, function() {
dialog.overlay.empty().remove();
$.modal.close();
});
$('.NB-modal-holder').empty().remove();
}
});
},
get_stats: function() {
this.model.get_feed_statistics(this.feed_id, $.rescope(this.populate_stats, this));
},
populate_stats: function(s, data) {
NEWSBLUR.log(['Stats', data]);
var interval_start = data['update_interval_minutes'];
var interval_end = data['update_interval_minutes'] * 1.25;
var interval = '';
if (interval_start < 60) {
interval = interval_start + ' to ' + interval_end + ' minutes';
} else {
var interval_start_hours = parseInt(interval_start / 60, 10);
var interval_end_hours = parseInt(interval_end / 60, 10);
var dec_start = interval_start % 60;
var dec_end = interval_end % 60;
interval = interval_start_hours + (dec_start >= 30 ? '.5' : '') + ' to ' + interval_end_hours + (dec_end >= 30 || interval_start_hours == interval_end_hours ? '.5' : '') + ' hours';
}
var $stats = $.make('div', { className: 'NB-modal-statistics-info' }, [
$.make('div', { className: 'NB-statistics-stat NB-statistics-updates'}, [
$.make('div', { className: 'NB-statistics-update'}, [
$.make('div', { className: 'NB-statistics-update-label' }, 'Last Update'),
2010-07-28 18:18:01 -04:00
$.make('div', { className: 'NB-statistics-update-count' }, data['last_update'] + ' ago')
]),
$.make('div', { className: 'NB-statistics-update'}, [
2010-07-28 18:18:01 -04:00
$.make('div', { className: 'NB-statistics-update-label' }, 'Every'),
$.make('div', { className: 'NB-statistics-update-count' }, interval)
]),
$.make('div', { className: 'NB-statistics-update'}, [
$.make('div', { className: 'NB-statistics-update-label' }, 'Next Update'),
2010-07-28 18:18:01 -04:00
$.make('div', { className: 'NB-statistics-update-count' }, 'in ' + data['next_update'])
])
]),
$.make('div', { className: 'NB-statistics-stat'}, [
$.make('div', { className: 'NB-statistics-count' }, ''+data['subscriber_count']),
$.make('div', { className: 'NB-statistics-label' }, 'subscribers')
]),
$.make('div', { className: 'NB-statistics-stat'}, [
$.make('div', { className: 'NB-statistics-count' }, ''+data['average_stories_per_month']),
$.make('div', { className: 'NB-statistics-label' }, ' stories per month')
])
]);
$('.NB-modal-statistics-info', this.$modal).replaceWith($stats);
setTimeout(function() {
$.modal.impl.setPosition();
}, 10);
}
};