2011-02-01 03:35:11 +01:00
|
|
|
NEWSBLUR.ReaderAddFeed = function(options) {
|
2012-03-05 19:18:40 -08:00
|
|
|
var defaults = {
|
|
|
|
'onOpen': _.bind(function() {
|
|
|
|
this.focus_add_feed();
|
|
|
|
}, this)
|
|
|
|
};
|
2010-06-08 11:19:41 -04:00
|
|
|
|
|
|
|
this.options = $.extend({}, defaults, options);
|
2012-05-17 18:40:46 -07:00
|
|
|
this.model = NEWSBLUR.assets;
|
2010-06-08 11:19:41 -04:00
|
|
|
this.runner();
|
|
|
|
};
|
|
|
|
|
2012-03-05 19:18:40 -08:00
|
|
|
NEWSBLUR.ReaderAddFeed.prototype = new NEWSBLUR.Modal;
|
|
|
|
NEWSBLUR.ReaderAddFeed.prototype.constructor = NEWSBLUR.ReaderAddFeed;
|
|
|
|
|
|
|
|
_.extend(NEWSBLUR.ReaderAddFeed.prototype, {
|
|
|
|
|
2010-06-08 11:19:41 -04:00
|
|
|
runner: function() {
|
|
|
|
this.make_modal();
|
|
|
|
this.handle_cancel();
|
|
|
|
this.open_modal();
|
|
|
|
this.handle_keystrokes();
|
2010-12-23 16:02:17 -05:00
|
|
|
this.setup_autocomplete();
|
2012-01-24 18:37:22 -08:00
|
|
|
this.setup_chosen();
|
2011-03-12 17:43:53 -05:00
|
|
|
this.focus_add_feed();
|
2010-06-08 11:19:41 -04:00
|
|
|
|
2010-12-23 16:02:17 -05:00
|
|
|
this.$modal.bind('click', $.rescope(this.handle_click, this));
|
2010-06-08 11:19:41 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
make_modal: function() {
|
|
|
|
var self = this;
|
|
|
|
|
2010-12-23 16:02:17 -05:00
|
|
|
this.$modal = $.make('div', { className: 'NB-add NB-modal' }, [
|
2011-05-07 21:12:13 -04:00
|
|
|
$.make('h2', { className: 'NB-modal-title' }, 'Add sites and folders'),
|
2010-06-08 11:19:41 -04:00
|
|
|
$.make('div', { className: 'NB-add-form' }, [
|
2010-08-01 19:12:42 -04:00
|
|
|
$.make('div', { className: 'NB-fieldset NB-add-add-url NB-modal-submit' }, [
|
2010-06-08 11:19:41 -04:00
|
|
|
$.make('h5', [
|
2011-09-04 15:42:13 -07:00
|
|
|
$.make('div', { className: 'NB-add-folders' }, NEWSBLUR.utils.make_folders(this.model)),
|
2011-05-07 21:12:13 -04:00
|
|
|
'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' }),
|
2011-05-07 21:12:13 -04:00
|
|
|
$.make('label', { 'for': 'NB-add-url' }, 'Website or RSS: '),
|
2011-04-07 10:30:05 -04:00
|
|
|
$.make('input', { type: 'text', id: 'NB-add-url', className: 'NB-input NB-add-url', name: 'url', value: self.options.url }),
|
2011-05-07 21:12:13 -04:00
|
|
|
$.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' })
|
|
|
|
])
|
|
|
|
])
|
|
|
|
]),
|
2010-08-01 19:12:42 -04:00
|
|
|
$.make('div', { className: 'NB-fieldset NB-add-add-folder NB-modal-submit' }, [
|
2010-06-08 11:19:41 -04:00
|
|
|
$.make('h5', [
|
2011-09-04 15:42:13 -07:00
|
|
|
$.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' })
|
|
|
|
]),
|
2011-04-07 10:30:05 -04:00
|
|
|
$.make('input', { type: 'text', id: 'NB-add-folder', className: 'NB-input NB-add-folder', name: 'url' }),
|
2010-08-30 22:42:44 -04:00
|
|
|
$.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' })
|
|
|
|
])
|
|
|
|
])
|
|
|
|
]),
|
2011-03-11 11:22:28 -05:00
|
|
|
// $.make('div', { className: 'NB-fieldset-divider' }, [
|
|
|
|
// 'Google Reader and OPML'
|
|
|
|
// ]),
|
2010-08-01 19:12:42 -04:00
|
|
|
$.make('div', { className: 'NB-fieldset NB-anonymous-ok NB-modal-submit' }, [
|
2010-06-29 20:16:09 -04:00
|
|
|
$.make('h5', [
|
2010-08-01 19:12:42 -04:00
|
|
|
'Import feeds'
|
2010-06-29 20:16:09 -04:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-fieldset-fields' }, [
|
2012-03-05 19:18:40 -08:00
|
|
|
$.make('div', { className: 'NB-add-import-button NB-modal-submit-green NB-modal-submit-button' }, [
|
|
|
|
'Import from Google Reader or upload OPML',
|
2010-06-30 16:33:41 -04:00
|
|
|
$.make('img', { className: 'NB-add-google-reader-arrow', src: NEWSBLUR.Globals['MEDIA_URL']+'img/icons/silk/arrow_right.png' })
|
|
|
|
]),
|
2012-02-10 11:57:37 -08:00
|
|
|
$.make('div', { className: 'NB-add-danger' }, (NEWSBLUR.Globals.is_authenticated && _.size(this.model.feeds) > 0 && [
|
2010-07-05 22:02:08 -04:00
|
|
|
$.make('img', { src: NEWSBLUR.Globals['MEDIA_URL']+'img/icons/silk/server_go.png' }),
|
|
|
|
'This will erase all existing feeds and folders.'
|
2010-12-07 09:52:14 -05:00
|
|
|
]))
|
2010-06-29 20:16:09 -04:00
|
|
|
])
|
2010-06-08 11:19:41 -04:00
|
|
|
])
|
|
|
|
])
|
|
|
|
]);
|
2010-07-24 15:54:25 -04:00
|
|
|
|
|
|
|
if (NEWSBLUR.Globals.is_anonymous) {
|
2010-12-23 16:02:17 -05:00
|
|
|
this.$modal.addClass('NB-signed-out');
|
2010-07-24 15:54:25 -04:00
|
|
|
}
|
2010-06-08 11:19:41 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
handle_cancel: function() {
|
2010-12-23 16:02:17 -05:00
|
|
|
var $cancel = $('.NB-modal-cancel', this.$modal);
|
2010-06-08 11:19:41 -04:00
|
|
|
|
|
|
|
$cancel.click(function(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
$.modal.close();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
2011-03-12 17:43:53 -05:00
|
|
|
focus_add_feed: function() {
|
|
|
|
var $add = $('.NB-add-url', this.$modal);
|
|
|
|
if (!NEWSBLUR.Globals.is_anonymous) {
|
|
|
|
_.delay(function() {
|
|
|
|
$add.focus();
|
|
|
|
}, 200);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2010-12-23 16:02:17 -05:00
|
|
|
setup_autocomplete: function() {
|
|
|
|
var self = this;
|
|
|
|
var $add = $('.NB-add-url', this.$modal);
|
|
|
|
|
|
|
|
$add.autocomplete({
|
2011-03-12 17:43:53 -05:00
|
|
|
minLength: 1,
|
2010-12-23 16:02:17 -05:00
|
|
|
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);
|
|
|
|
};
|
|
|
|
},
|
|
|
|
|
2012-01-24 18:37:22 -08:00
|
|
|
setup_chosen: function() {
|
|
|
|
var $select = $('select', this.$modal);
|
|
|
|
$select.chosen();
|
|
|
|
},
|
|
|
|
|
2010-06-08 11:19:41 -04:00
|
|
|
handle_keystrokes: function() {
|
|
|
|
var self = this;
|
|
|
|
|
2010-12-23 16:02:17 -05:00
|
|
|
$('.NB-add-url', this.$modal).bind('keyup', 'return', function(e) {
|
2010-06-08 11:19:41 -04:00
|
|
|
e.preventDefault();
|
|
|
|
self.save_add_url();
|
|
|
|
});
|
|
|
|
|
2010-12-23 16:02:17 -05:00
|
|
|
$('.NB-add-folder', this.$modal).bind('keyup', 'return', function(e) {
|
2010-06-08 11:19:41 -04:00
|
|
|
e.preventDefault();
|
|
|
|
self.save_add_folder();
|
|
|
|
});
|
|
|
|
},
|
2010-07-24 15:54:25 -04:00
|
|
|
|
2012-03-05 19:18:40 -08:00
|
|
|
close_and_open_import: function() {
|
|
|
|
this.close(function() {
|
|
|
|
NEWSBLUR.reader.open_intro_modal({
|
|
|
|
'page_number': 2,
|
|
|
|
'force_import': true
|
|
|
|
});
|
2010-07-24 15:54:25 -04:00
|
|
|
});
|
2010-06-08 11:19:41 -04:00
|
|
|
},
|
2010-06-29 20:16:09 -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-29 20:16:09 -04:00
|
|
|
});
|
|
|
|
|
2012-03-05 19:18:40 -08:00
|
|
|
$.targetIs(e, { tagSelector: '.NB-add-import-button' }, function($t, $p) {
|
|
|
|
e.preventDefault();
|
|
|
|
|
|
|
|
self.close_and_open_import();
|
|
|
|
});
|
|
|
|
|
2010-06-08 11:19:41 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
save_add_url: function() {
|
2011-05-07 21:12:13 -04:00
|
|
|
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');
|
2011-05-07 21:12:13 -04:00
|
|
|
$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]);
|
2011-05-07 21:12:13 -04:00
|
|
|
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');
|
2011-05-07 21:12:13 -04:00
|
|
|
$submit.removeClass('NB-disabled');
|
2010-06-08 11:19:41 -04:00
|
|
|
|
|
|
|
if (data.code > 0) {
|
2012-05-23 10:02:30 -07:00
|
|
|
NEWSBLUR.assets.load_feeds();
|
2011-03-13 16:24:49 -04:00
|
|
|
NEWSBLUR.reader.load_recommended_feed();
|
2010-12-24 10:41:32 -05:00
|
|
|
NEWSBLUR.reader.handle_mouse_indicator_hover();
|
2010-06-08 11:19:41 -04:00
|
|
|
$.modal.close();
|
2011-05-07 21:12:13 -04:00
|
|
|
$submit.val('Added!');
|
2012-03-19 16:35:56 -07:00
|
|
|
this.model.preference('has_setup_feeds', true);
|
|
|
|
NEWSBLUR.reader.check_hide_getting_started();
|
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);
|
2011-05-07 21:12:13 -04:00
|
|
|
$submit.val('Add Site');
|
2010-06-08 11:19:41 -04:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
save_add_folder: function() {
|
2011-05-07 21:12:13 -04:00
|
|
|
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');
|
2011-05-07 21:12:13 -04:00
|
|
|
$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) {
|
2011-05-07 21:12:13 -04:00
|
|
|
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');
|
2011-05-07 21:12:13 -04:00
|
|
|
$submit.removeClass('NB-disabled');
|
2010-06-08 11:19:41 -04:00
|
|
|
|
|
|
|
if (data.code > 0) {
|
2012-05-17 18:40:46 -07:00
|
|
|
NEWSBLUR.app.feed_list.fetch();
|
2010-08-30 19:57:27 -04:00
|
|
|
_.defer(function() {
|
|
|
|
NEWSBLUR.reader.open_add_feed_modal();
|
|
|
|
});
|
2011-05-07 21:12:13 -04:00
|
|
|
$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);
|
2011-05-07 21:12:13 -04:00
|
|
|
$submit.val('Add Folder');
|
2010-06-08 11:19:41 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-03-05 19:18:40 -08:00
|
|
|
});
|