2010-06-13 18:57:20 -04:00
|
|
|
NEWSBLUR.ReaderMarkRead = function(options) {
|
2010-06-14 01:01:21 -04:00
|
|
|
var defaults = {
|
|
|
|
'days': 1
|
|
|
|
};
|
2010-06-13 18:57:20 -04:00
|
|
|
|
|
|
|
this.options = $.extend({}, defaults, options);
|
|
|
|
this.model = NEWSBLUR.AssetModel.reader();
|
|
|
|
this.runner();
|
|
|
|
};
|
|
|
|
|
|
|
|
NEWSBLUR.ReaderMarkRead.prototype = {
|
|
|
|
|
|
|
|
runner: function() {
|
|
|
|
this.make_modal();
|
2010-06-14 01:01:21 -04:00
|
|
|
this.load_slider();
|
|
|
|
this.generate_explanation(this.options['days']);
|
2010-06-13 18:57:20 -04:00
|
|
|
this.handle_cancel();
|
|
|
|
this.open_modal();
|
|
|
|
|
|
|
|
this.$modal.bind('click', $.rescope(this.handle_click, this));
|
|
|
|
},
|
|
|
|
|
|
|
|
make_modal: function() {
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
this.$modal = $.make('div', { className: 'NB-modal-markread NB-modal' }, [
|
|
|
|
$.make('h2', { className: 'NB-modal-title' }, 'Mark old stories as read'),
|
|
|
|
$.make('form', { className: 'NB-markread-form' }, [
|
2010-06-14 01:01:21 -04:00
|
|
|
$.make('div', { className: 'NB-markread-slider'}),
|
|
|
|
$.make('div', { className: 'NB-markread-explanation'}),
|
2010-06-13 18:57:20 -04:00
|
|
|
$.make('div', { className: 'NB-modal-submit' }, [
|
2010-08-30 22:42:44 -04:00
|
|
|
$.make('input', { type: 'submit', className: 'NB-modal-submit-save NB-modal-submit-green', value: 'Do it' }),
|
2010-06-13 18:57:20 -04:00
|
|
|
' or ',
|
|
|
|
$.make('a', { href: '#', className: 'NB-modal-cancel' }, 'cancel')
|
|
|
|
])
|
|
|
|
]).bind('submit', function(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
self.save_mark_read();
|
|
|
|
return false;
|
|
|
|
})
|
|
|
|
]);
|
|
|
|
},
|
|
|
|
|
|
|
|
open_modal: function() {
|
|
|
|
var self = this;
|
2010-06-30 12:17:22 -04:00
|
|
|
|
2010-06-13 18:57:20 -04:00
|
|
|
this.$modal.modal({
|
|
|
|
'minWidth': 600,
|
2010-08-03 23:41:02 -04:00
|
|
|
'maxWidth': 600,
|
2010-06-13 18:57:20 -04:00
|
|
|
'overlayClose': true,
|
|
|
|
'onOpen': function (dialog) {
|
|
|
|
dialog.overlay.fadeIn(200, function () {
|
|
|
|
dialog.container.fadeIn(200);
|
|
|
|
dialog.data.fadeIn(200);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
'onShow': function(dialog) {
|
2010-08-03 23:41:02 -04:00
|
|
|
$('#simplemodal-container').corner('6px');
|
2010-06-13 18:57:20 -04:00
|
|
|
// $('.NB-classifier-tag', self.$modal).corner('4px');
|
|
|
|
},
|
|
|
|
'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();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
2010-06-14 01:01:21 -04:00
|
|
|
load_slider: function() {
|
|
|
|
var self = this;
|
|
|
|
var $slider = $('.NB-markread-slider', this.$modal);
|
2010-06-13 18:57:20 -04:00
|
|
|
|
2010-06-14 01:01:21 -04:00
|
|
|
$slider.slider({
|
|
|
|
range: 'min',
|
|
|
|
min: 0,
|
|
|
|
max: 7,
|
|
|
|
step: 1,
|
|
|
|
value: this.options['days'],
|
|
|
|
slide: function(e, ui) {
|
|
|
|
var value = ui.value;
|
|
|
|
self.update_dayofweek(value);
|
|
|
|
self.generate_explanation(value);
|
|
|
|
},
|
|
|
|
stop: function(e, ui) {
|
|
|
|
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
update_dayofweek: function(value) {
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
generate_explanation: function(value) {
|
|
|
|
var $explanation = $('.NB-markread-explanation', this.$modal);
|
|
|
|
var explanation;
|
|
|
|
|
|
|
|
if (value == 0) {
|
|
|
|
explanation = "Mark <b>every story</b> as read.";
|
|
|
|
} else if (value >= 1) {
|
|
|
|
explanation = "Mark all stories older than <b>" + value + " day" + (value==1?'':'s') + " old</b> as read.";
|
|
|
|
}
|
|
|
|
|
|
|
|
$explanation.html(explanation);
|
|
|
|
},
|
|
|
|
|
|
|
|
save_mark_read: function() {
|
|
|
|
var $save = $('.NB-modal input[type=submit]');
|
|
|
|
var $slider = $('.NB-markread-slider', this.$modal);
|
|
|
|
var days = $slider.slider('option', 'value');
|
|
|
|
|
|
|
|
$save.attr('value', 'Marking as read...').addClass('NB-disabled').attr('disabled', true);
|
2010-08-01 19:12:42 -04:00
|
|
|
if (NEWSBLUR.Globals.is_authenticated) {
|
|
|
|
this.model.save_mark_read(days, function() {
|
2010-08-18 08:05:59 -04:00
|
|
|
NEWSBLUR.reader.start_count_unreads_after_import();
|
|
|
|
$.modal.close();
|
2010-10-10 23:33:56 -04:00
|
|
|
NEWSBLUR.reader.force_feeds_refresh(function() {
|
2010-08-18 08:05:59 -04:00
|
|
|
NEWSBLUR.reader.finish_count_unreads_after_import();
|
2011-03-10 09:38:24 -05:00
|
|
|
}, true);
|
2010-06-14 01:01:21 -04:00
|
|
|
});
|
2010-08-01 19:12:42 -04:00
|
|
|
} else {
|
|
|
|
$.modal.close();
|
|
|
|
}
|
2010-06-13 18:57:20 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
// ===========
|
|
|
|
// = Actions =
|
|
|
|
// ===========
|
|
|
|
|
|
|
|
handle_click: function(elem, e) {
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
$.targetIs(e, { tagSelector: '.NB-add-url-submit' }, function($t, $p) {
|
|
|
|
e.preventDefault();
|
2010-06-14 01:01:21 -04:00
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
handle_cancel: function() {
|
|
|
|
var $cancel = $('.NB-modal-cancel', this.$modal);
|
|
|
|
|
|
|
|
$cancel.click(function(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
$.modal.close();
|
2010-06-13 18:57:20 -04:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|