2010-03-15 00:52:06 -04:00
|
|
|
NEWSBLUR.ReaderManageFeed = function(feed_id, options) {
|
|
|
|
var defaults = {};
|
|
|
|
|
|
|
|
this.options = $.extend({}, defaults, options);
|
|
|
|
this.model = NEWSBLUR.AssetModel.reader();
|
|
|
|
this.feed_id = feed_id;
|
|
|
|
this.feed = this.model.get_feed(feed_id);
|
|
|
|
this.feeds = this.model.get_feeds();
|
|
|
|
this.google_favicon_url = 'http://www.google.com/s2/favicons?domain_url=';
|
2010-03-16 23:18:54 -04:00
|
|
|
this.runner(feed_id);
|
2010-03-15 00:52:06 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
NEWSBLUR.ReaderManageFeed.prototype = {
|
|
|
|
|
|
|
|
runner: function() {
|
|
|
|
this.make_modal();
|
2010-03-16 23:18:54 -04:00
|
|
|
this.initialize_feed(this.feed_id);
|
2010-03-15 00:52:06 -04:00
|
|
|
this.handle_cancel();
|
|
|
|
this.open_modal();
|
2010-03-16 23:18:54 -04:00
|
|
|
this.load_feed_classifier();
|
|
|
|
|
|
|
|
this.$manage.bind('change', $.rescope(this.handle_change, this));
|
|
|
|
},
|
|
|
|
|
|
|
|
initialize_feed: function(feed_id) {
|
|
|
|
this.feed_id = feed_id;
|
|
|
|
this.feed = this.model.get_feed(feed_id);
|
|
|
|
$('.NB-modal-title', this.$manage).html(this.feed['feed_title']);
|
|
|
|
$('input[name=feed_id]', this.$manage).val(this.feed_id);
|
|
|
|
$('input[name=rename_title]', this.$manage).val(this.feed['feed_title']);
|
2010-03-15 00:52:06 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
make_modal: function() {
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
this.$manage = $.make('div', { className: 'NB-manage NB-modal' }, [
|
|
|
|
$.make('form', { method: 'post', className: 'NB-manage-form' }, [
|
2010-03-16 23:18:54 -04:00
|
|
|
$.make('div', { className: 'NB-manage-container'}, [
|
|
|
|
$.make('div', { className: 'NB-modal-loading' }),
|
|
|
|
$.make('h2', { className: 'NB-modal-title' }),
|
|
|
|
$.make('div', { className: 'NB-manage-field' }, [
|
|
|
|
$.make('h5', [
|
|
|
|
'What you ',
|
|
|
|
$.make('span', { className: 'NB-classifier-like' }, 'like')
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-manage-classifier-likes' }),
|
|
|
|
$.make('h5', [
|
|
|
|
'What you ',
|
|
|
|
$.make('span', { className: 'NB-classifier-like' }, 'dislike')
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-manage-classifier-dislikes' }),
|
|
|
|
$.make('h5', 'Management'),
|
|
|
|
$.make('div', { className: 'NB-manage-management' }, [
|
|
|
|
$.make('label', { className: 'NB-manage-rename-label', 'for': 'id_rename' }, "Title: "),
|
|
|
|
$.make('input', { name: 'rename_title', id: 'id_rename' }),
|
|
|
|
$.make('a', { className: 'NB-manage-delete'}, "Rename feed"),
|
|
|
|
$.make('a', { className: 'NB-manage-delete'}, "Delete this feed")
|
|
|
|
])
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-manage-feed-chooser-container'}, [
|
|
|
|
this.make_feed_chooser()
|
2010-03-15 00:52:06 -04:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-modal-submit' }, [
|
2010-03-16 23:18:54 -04:00
|
|
|
$.make('input', { name: 'feed_id', type: 'hidden' }),
|
2010-03-15 00:52:06 -04:00
|
|
|
$.make('input', { type: 'submit', disabled: 'true', className: 'NB-disabled', value: 'Check what you like above...' }),
|
|
|
|
' or ',
|
|
|
|
$.make('a', { href: '#', className: 'NB-modal-cancel' }, 'cancel')
|
|
|
|
])
|
|
|
|
]).bind('submit', function(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
self.save();
|
|
|
|
return false;
|
|
|
|
})
|
|
|
|
]);
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
make_feed_chooser: function() {
|
|
|
|
var $chooser = $.make('select', { name: 'feed', className: 'NB-manage-feed-chooser' });
|
|
|
|
|
|
|
|
for (var f in this.feeds) {
|
|
|
|
var feed = this.feeds[f];
|
|
|
|
var $option = $.make('option', { value: feed.id }, feed.feed_title);
|
|
|
|
$option.appendTo($chooser);
|
|
|
|
|
|
|
|
if (feed.id == this.feed_id) {
|
|
|
|
$option.attr('selected', true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$('option', $chooser).tsort();
|
|
|
|
return $chooser;
|
|
|
|
},
|
2010-03-16 23:18:54 -04:00
|
|
|
|
|
|
|
load_feed_classifier: function() {
|
|
|
|
var $loading = $('.NB-modal-loading', this.$manage);
|
|
|
|
$loading.addClass('NB-active');
|
2010-03-15 00:52:06 -04:00
|
|
|
|
2010-03-16 23:18:54 -04:00
|
|
|
this.model.get_feed_classifier(this.feed_id, this.post_load_feed_classifier);
|
|
|
|
},
|
|
|
|
|
|
|
|
post_load_feed_classifier: function(classifiers) {
|
|
|
|
var $loading = $('.NB-modal-loading', this.$manage);
|
|
|
|
$loading.removeClass('NB-active');
|
|
|
|
},
|
|
|
|
|
2010-03-15 00:52:06 -04:00
|
|
|
open_modal: function() {
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
var $holder = $.make('div', { className: 'NB-modal-holder' }).append(this.$manage).appendTo('body').css({'visibility': 'hidden', 'display': 'block', 'width': 600});
|
|
|
|
var height = $('.NB-manage', $holder).outerHeight(true);
|
|
|
|
$holder.css({'visibility': 'visible', 'display': 'none'});
|
|
|
|
|
|
|
|
this.$manage.modal({
|
|
|
|
'minWidth': 600,
|
|
|
|
'minHeight': height,
|
|
|
|
'overlayClose': true,
|
|
|
|
'onOpen': function (dialog) {
|
|
|
|
dialog.overlay.fadeIn(200, function () {
|
|
|
|
dialog.container.fadeIn(200);
|
|
|
|
dialog.data.fadeIn(200);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
'onShow': function(dialog) {
|
2010-03-23 20:03:40 -04:00
|
|
|
$('#simplemodal-container').corner('6px').css({'width': 600, 'height': height});
|
|
|
|
// $('.NB-classifier-tag', self.$manage).corner('4px');
|
2010-03-15 00:52:06 -04:00
|
|
|
},
|
|
|
|
'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();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
handle_cancel: function() {
|
|
|
|
var $cancel = $('.NB-modal-cancel', this.$manage);
|
|
|
|
|
|
|
|
$cancel.click(function(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
$.modal.close();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
serialize_classifier: function() {
|
|
|
|
var data = $('.NB-manage form input').serialize();
|
|
|
|
|
|
|
|
return data;
|
|
|
|
},
|
|
|
|
|
|
|
|
save: function() {
|
|
|
|
var $save = $('.NB-modal input[type=submit]');
|
|
|
|
var data = this.serialize_classifier();
|
|
|
|
|
|
|
|
$save.text('Saving...').addClass('NB-disabled').attr('disabled', true);
|
|
|
|
this.model.save_classifier_publisher(data, function() {
|
|
|
|
$.modal.close();
|
|
|
|
});
|
2010-03-16 23:18:54 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
handle_change: function(elem, e) {
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
$.targetIs(e, { tagSelector: '.NB-manage-feed-chooser' }, function($t, $p){
|
|
|
|
var feed_id = $t.val();
|
|
|
|
self.initialize_feed(feed_id);
|
|
|
|
self.load_feed_classifier();
|
|
|
|
});
|
|
|
|
|
2010-03-15 00:52:06 -04:00
|
|
|
}
|
|
|
|
};
|