NewsBlur/media/js/newsblur/reader_add_feed.js

330 lines
13 KiB
JavaScript
Raw Normal View History

NEWSBLUR.ReaderAddFeed = function(options) {
2010-06-08 11:19:41 -04:00
var defaults = {};
this.options = $.extend({}, defaults, options);
this.model = NEWSBLUR.AssetModel.reader();
this.runner();
};
NEWSBLUR.ReaderAddFeed.prototype = {
runner: function() {
this.make_modal();
this.handle_cancel();
this.open_modal();
this.handle_keystrokes();
this.setup_autocomplete();
this.focus_add_feed();
2010-06-08 11:19:41 -04:00
this.$modal.bind('click', $.rescope(this.handle_click, this));
2010-06-08 11:19:41 -04:00
},
make_modal: function() {
var self = this;
this.$modal = $.make('div', { className: 'NB-add NB-modal' }, [
$.make('h2', { className: 'NB-modal-title' }, 'Add sites and folders'),
2010-06-08 11:19:41 -04:00
$.make('div', { className: 'NB-add-form' }, [
$.make('div', { className: 'NB-fieldset NB-add-add-url NB-modal-submit' }, [
2010-06-08 11:19:41 -04:00
$.make('h5', [
$.make('div', { className: 'NB-add-folders' }, NEWSBLUR.utils.make_folders(this.model)),
'Add a new site'
2010-06-08 11:19:41 -04:00
]),
$.make('div', { className: 'NB-fieldset-fields' }, [
$.make('div', [
$.make('div', { className: 'NB-loading' }),
$.make('label', { 'for': 'NB-add-url' }, 'Website or RSS: '),
$.make('input', { type: 'text', id: 'NB-add-url', className: 'NB-input NB-add-url', name: 'url', value: self.options.url }),
$.make('input', { type: 'submit', value: 'Add site', className: 'NB-modal-submit-green NB-add-url-submit' }),
2010-06-08 11:19:41 -04:00
$.make('div', { className: 'NB-error' })
])
])
]),
$.make('div', { className: 'NB-fieldset NB-add-add-folder NB-modal-submit' }, [
2010-06-08 11:19:41 -04:00
$.make('h5', [
$.make('div', { className: 'NB-add-folders' }, NEWSBLUR.utils.make_folders(this.model)),
2010-06-08 11:19:41 -04:00
'Add a new folder'
]),
$.make('div', { className: 'NB-fieldset-fields' }, [
$.make('div', [
$.make('div', { className: 'NB-loading' }),
$.make('label', { 'for': 'NB-add-folder' }, [
$.make('div', { className: 'NB-folder-icon' })
]),
$.make('input', { type: 'text', id: 'NB-add-folder', className: 'NB-input NB-add-folder', name: 'url' }),
$.make('input', { type: 'submit', value: 'Add folder', className: 'NB-add-folder-submit NB-modal-submit-green' }),
2010-06-08 11:19:41 -04:00
$.make('div', { className: 'NB-error' })
])
])
]),
// $.make('div', { className: 'NB-fieldset-divider' }, [
// 'Google Reader and OPML'
// ]),
$.make('div', { className: 'NB-fieldset NB-anonymous-ok NB-modal-submit' }, [
$.make('h5', [
'Import feeds'
]),
$.make('div', { className: 'NB-fieldset-fields' }, [
$.make('a', { href: NEWSBLUR.URLs['google-reader-authorize'], className: 'NB-google-reader-oauth NB-modal-submit-green NB-modal-submit-button' }, [
'Import from Google Reader',
$.make('img', { className: 'NB-add-google-reader-arrow', src: NEWSBLUR.Globals['MEDIA_URL']+'img/icons/silk/arrow_right.png' })
]),
$.make('div', { className: 'NB-add-danger' }, (NEWSBLUR.Globals.is_authenticated && _.size(this.model.feeds) && [
$.make('img', { src: NEWSBLUR.Globals['MEDIA_URL']+'img/icons/silk/server_go.png' }),
'This will erase all existing feeds and folders.'
]))
])
]),
$.make('div', { className: 'NB-fieldset NB-add-opml NB-modal-submit' }, [
$.make('h5', [
'Upload OPML',
$.make('a', { className: 'NB-right NB-splash-link', href: NEWSBLUR.URLs['opml-export'] }, 'Export OPML')
]),
2010-06-08 11:19:41 -04:00
$.make('div', { className: 'NB-fieldset-fields' }, [
$.make('form', { method: 'post', enctype: 'multipart/form-data', className: 'NB-add-form' }, [
$.make('div', { className: 'NB-loading' }),
$.make('input', { type: 'file', name: 'file', id: 'opml_file_input' }),
$.make('input', { type: 'submit', className: 'NB-add-opml-button NB-modal-submit-green', value: 'Upload OPML File' }).click(function(e) {
2010-06-08 11:19:41 -04:00
e.preventDefault();
self.handle_opml_upload();
return false;
})
]),
$.make('div', { className: 'NB-add-danger' }, (NEWSBLUR.Globals.is_authenticated && _.size(this.model.feeds) && [
$.make('img', { src: NEWSBLUR.Globals['MEDIA_URL']+'img/icons/silk/server_go.png' }),
'This will erase all existing feeds and folders.'
])),
$.make('div', { className: 'NB-error' })
2010-06-08 11:19:41 -04:00
])
])
])
]);
if (NEWSBLUR.Globals.is_anonymous) {
this.$modal.addClass('NB-signed-out');
}
2010-06-08 11:19:41 -04:00
},
open_modal: function() {
var self = this;
this.$modal.modal({
2010-06-08 11:19:41 -04:00
'minWidth': 600,
'maxWidth': 600,
2010-06-08 11:19:41 -04:00
'overlayClose': true,
'autoResize': true,
2010-06-08 11:19:41 -04:00
'onOpen': function (dialog) {
dialog.overlay.fadeIn(200, function () {
dialog.container.fadeIn(200);
dialog.data.fadeIn(200, function() {
self.focus_add_feed();
});
});
2010-06-08 11:19:41 -04:00
},
'onShow': function(dialog) {
$('#simplemodal-container').corner('6px');
2010-06-08 11:19:41 -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.$modal);
2010-06-08 11:19:41 -04:00
$cancel.click(function(e) {
e.preventDefault();
$.modal.close();
});
},
focus_add_feed: function() {
var $add = $('.NB-add-url', this.$modal);
if (!NEWSBLUR.Globals.is_anonymous) {
_.delay(function() {
$add.focus();
}, 200);
}
},
setup_autocomplete: function() {
var self = this;
var $add = $('.NB-add-url', this.$modal);
$add.autocomplete({
minLength: 1,
source: '/rss_feeds/feed_autocomplete',
focus: function(e, ui) {
$add.val(ui.item.value);
return false;
},
select: function(e, ui) {
$add.val(ui.item.value);
self.save_add_url();
return false;
}
}).data("autocomplete")._renderItem = function(ul, item) {
return $.make('li', [
$.make('a', [
$.make('div', { className: 'NB-add-autocomplete-subscribers'}, item.num_subscribers + Inflector.pluralize(' subscriber', item.num_subscribers)),
$.make('div', { className: 'NB-add-autocomplete-title'}, item.label),
$.make('div', { className: 'NB-add-autocomplete-address'}, item.value)
])
]).data("item.autocomplete", item).appendTo(ul);
};
},
2010-06-08 11:19:41 -04:00
handle_keystrokes: function() {
var self = this;
$('.NB-add-url', this.$modal).bind('keyup', 'return', function(e) {
2010-06-08 11:19:41 -04:00
e.preventDefault();
self.save_add_url();
});
$('.NB-add-folder', this.$modal).bind('keyup', 'return', function(e) {
2010-06-08 11:19:41 -04:00
e.preventDefault();
self.save_add_folder();
});
},
// ========
// = OPML =
// ========
handle_opml_upload: function() {
var self = this;
var $loading = $('.NB-fieldset.NB-add-opml .NB-loading');
$loading.addClass('NB-active');
if (NEWSBLUR.Globals.is_anonymous) {
var $error = $('.NB-error', '.NB-fieldset.NB-add-opml');
$error.text("Please create an account. Not much to do without an account.");
$error.slideDown(300);
$loading.removeClass('NB-active');
return false;
}
2010-06-08 11:19:41 -04:00
// NEWSBLUR.log(['Uploading']);
$.ajaxFileUpload({
url: NEWSBLUR.URLs['opml-upload'],
secureuri: false,
fileElementId: 'opml_file_input',
dataType: 'text',
success: function (data, status)
{
2010-06-08 11:19:41 -04:00
$loading.removeClass('NB-active');
NEWSBLUR.reader.load_feeds();
NEWSBLUR.reader.load_recommended_feed();
$.modal.close();
},
error: function (data, status, e)
{
2010-06-08 11:19:41 -04:00
$loading.removeClass('NB-active');
NEWSBLUR.log(['Error', data, status, e]);
}
});
return false;
2010-06-08 11:19:41 -04:00
},
2010-06-08 11:19:41 -04:00
// ===========
// = Actions =
// ===========
handle_click: function(elem, e) {
var self = this;
$.targetIs(e, { tagSelector: '.NB-add-url-submit' }, function($t, $p) {
e.preventDefault();
self.save_add_url();
});
$.targetIs(e, { tagSelector: '.NB-add-folder-submit' }, function($t, $p) {
e.preventDefault();
self.save_add_folder();
});
2010-06-08 11:19:41 -04:00
},
save_add_url: function() {
var $submit = $('.NB-add-add-url input[type=submit]', this.$modal);
2010-06-08 11:19:41 -04:00
var $error = $('.NB-error', '.NB-fieldset.NB-add-add-url');
var $loading = $('.NB-loading', '.NB-fieldset.NB-add-add-url');
var url = $('.NB-add-url').val();
var folder = $('.NB-add-url').parents('.NB-fieldset').find('.NB-folders').val();
$error.slideUp(300);
$loading.addClass('NB-active');
$submit.addClass('NB-disabled').val('Adding...');
2010-06-08 11:19:41 -04:00
this.model.save_add_url(url, folder, $.rescope(this.post_save_add_url, this));
},
post_save_add_url: function(e, data) {
NEWSBLUR.log(['Data', data]);
var $submit = $('.NB-add-add-url input[type=submit]', this.$modal);
2010-06-08 11:19:41 -04:00
var $loading = $('.NB-loading', '.NB-fieldset.NB-add-add-url');
$loading.removeClass('NB-active');
$submit.removeClass('NB-disabled');
2010-06-08 11:19:41 -04:00
if (data.code > 0) {
NEWSBLUR.reader.load_feeds();
NEWSBLUR.reader.load_recommended_feed();
NEWSBLUR.reader.handle_mouse_indicator_hover();
2010-06-08 11:19:41 -04:00
$.modal.close();
$submit.val('Added!');
2010-06-08 11:19:41 -04:00
} else {
var $error = $('.NB-error', '.NB-fieldset.NB-add-add-url');
$error.text(data.message);
$error.slideDown(300);
$submit.val('Add Site');
2010-06-08 11:19:41 -04:00
}
},
save_add_folder: function() {
var $submit = $('.NB-add-add-folder input[type=submit]', this.$modal);
2010-06-08 11:19:41 -04:00
var $error = $('.NB-error', '.NB-fieldset.NB-add-add-folder');
var $loading = $('.NB-loading', '.NB-fieldset.NB-add-add-folder');
var folder = $('.NB-add-folder').val();
var parent_folder = $('.NB-add-folder').parents('.NB-fieldset').find('.NB-folders').val();
$error.slideUp(300);
$loading.addClass('NB-active');
$submit.addClass('NB-disabled').val('Adding...');
2010-06-08 11:19:41 -04:00
this.model.save_add_folder(folder, parent_folder, $.rescope(this.post_save_add_folder, this));
},
post_save_add_folder: function(e, data) {
var $submit = $('.NB-add-add-folder input[type=submit]', this.$modal);
2010-06-08 11:19:41 -04:00
var $loading = $('.NB-loading', '.NB-fieldset.NB-add-add-folder');
$loading.removeClass('NB-active');
$submit.removeClass('NB-disabled');
2010-06-08 11:19:41 -04:00
if (data.code > 0) {
NEWSBLUR.reader.load_feeds();
_.defer(function() {
NEWSBLUR.reader.open_add_feed_modal();
});
$submit.val('Added!');
2010-06-08 11:19:41 -04:00
} else {
var $error = $('.NB-error', '.NB-fieldset.NB-add-add-folder');
$error.text(data.message);
$error.slideDown(300);
$submit.val('Add Folder');
2010-06-08 11:19:41 -04:00
}
}
};