2010-06-08 11:19:41 -04:00
|
|
|
NEWSBLUR.ReaderAddFeed = function(feed_id, score, options) {
|
|
|
|
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.$add.bind('click', $.rescope(this.handle_click, this));
|
|
|
|
},
|
|
|
|
|
|
|
|
make_modal: function() {
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
this.$add = $.make('div', { className: 'NB-add NB-modal' }, [
|
|
|
|
$.make('h2', { className: 'NB-modal-title' }, 'Add feeds and folders'),
|
|
|
|
$.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', [
|
|
|
|
$.make('div', { className: 'NB-add-folders' }, this.make_folders()),
|
|
|
|
'Add a new feed'
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-fieldset-fields' }, [
|
|
|
|
$.make('div', [
|
|
|
|
$.make('div', { className: 'NB-loading' }),
|
|
|
|
$.make('label', { 'for': 'NB-add-url' }, 'RSS or URL: '),
|
|
|
|
$.make('input', { type: 'text', id: 'NB-add-url', className: 'NB-add-url', name: 'url' }),
|
2010-08-30 22:42:44 -04:00
|
|
|
$.make('input', { type: 'submit', value: 'Add it', 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', [
|
|
|
|
$.make('div', { className: 'NB-add-folders' }, this.make_folders()),
|
|
|
|
'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-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' })
|
|
|
|
])
|
|
|
|
])
|
|
|
|
]),
|
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' }, [
|
2010-08-30 22:42:44 -04:00
|
|
|
$.make('a', { href: NEWSBLUR.URLs['google-reader-authorize'], className: 'NB-google-reader-oauth NB-modal-submit-green NB-modal-submit-button' }, [
|
2010-08-01 19:12:42 -04:00
|
|
|
'Import from Google Reader',
|
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' })
|
|
|
|
]),
|
2010-07-05 22:02:08 -04:00
|
|
|
$.make('div', { className: 'NB-add-danger' }, [
|
|
|
|
$.make('img', { src: NEWSBLUR.Globals['MEDIA_URL']+'img/icons/silk/server_go.png' }),
|
|
|
|
'This will erase all existing feeds and folders.'
|
|
|
|
])
|
2010-06-29 20:16:09 -04:00
|
|
|
])
|
|
|
|
]),
|
2010-08-01 19:12:42 -04:00
|
|
|
$.make('div', { className: 'NB-fieldset NB-add-opml NB-modal-submit' }, [
|
2010-06-29 20:16:09 -04:00
|
|
|
$.make('h5', 'Upload 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' }),
|
2010-08-30 22:42:44 -04:00
|
|
|
$.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;
|
|
|
|
})
|
2010-06-30 16:33:41 -04:00
|
|
|
]),
|
2010-07-05 22:02:08 -04:00
|
|
|
$.make('div', { className: 'NB-add-danger' }, [
|
|
|
|
$.make('img', { src: NEWSBLUR.Globals['MEDIA_URL']+'img/icons/silk/server_go.png' }),
|
|
|
|
'This will erase all existing feeds and folders.'
|
2010-07-24 15:54:25 -04:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-error' })
|
2010-06-08 11:19:41 -04:00
|
|
|
])
|
|
|
|
])
|
|
|
|
])
|
|
|
|
]);
|
2010-07-24 15:54:25 -04:00
|
|
|
|
|
|
|
if (NEWSBLUR.Globals.is_anonymous) {
|
|
|
|
this.$add.addClass('NB-signed-out');
|
|
|
|
}
|
2010-06-08 11:19:41 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
make_folders: function() {
|
|
|
|
var folders = this.model.get_folders();
|
|
|
|
var $options = $.make('select', { className: 'NB-folders'});
|
|
|
|
|
|
|
|
var $option = $.make('option', { value: '' }, "Top Level");
|
|
|
|
$options.append($option);
|
|
|
|
|
|
|
|
$options = this.make_folder_options($options, folders, '-');
|
|
|
|
|
|
|
|
return $options;
|
|
|
|
},
|
|
|
|
|
|
|
|
make_folder_options: function($options, items, depth) {
|
|
|
|
for (var i in items) {
|
|
|
|
var item = items[i];
|
|
|
|
if (typeof item == "object") {
|
|
|
|
for (var o in item) {
|
|
|
|
var folder = item[o];
|
|
|
|
var $option = $.make('option', { value: o }, depth + ' ' + o);
|
|
|
|
$options.append($option);
|
|
|
|
$options = this.make_folder_options($options, folder, depth+'-');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $options;
|
|
|
|
},
|
|
|
|
|
|
|
|
open_modal: function() {
|
|
|
|
var self = this;
|
2010-07-25 15:34:50 -04:00
|
|
|
|
2010-06-08 11:19:41 -04:00
|
|
|
this.$add.modal({
|
|
|
|
'minWidth': 600,
|
2010-08-03 23:41:02 -04:00
|
|
|
'maxWidth': 600,
|
2010-06-08 11:19:41 -04:00
|
|
|
'overlayClose': true,
|
2010-08-03 23:41:02 -04:00
|
|
|
'autoResize': true,
|
2010-06-08 11:19:41 -04:00
|
|
|
'onOpen': function (dialog) {
|
2010-07-24 15:54:25 -04:00
|
|
|
dialog.overlay.fadeIn(200, function () {
|
|
|
|
dialog.container.fadeIn(200);
|
2010-08-03 23:41:02 -04:00
|
|
|
dialog.data.fadeIn(200);
|
2010-07-24 15:54:25 -04:00
|
|
|
});
|
2010-06-08 11:19:41 -04:00
|
|
|
},
|
|
|
|
'onShow': function(dialog) {
|
2010-08-03 23:41:02 -04:00
|
|
|
$('#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.$add);
|
|
|
|
|
|
|
|
$cancel.click(function(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
$.modal.close();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
handle_keystrokes: function() {
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
$('.NB-add-url', this.$add).bind('keyup', 'return', function(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
self.save_add_url();
|
|
|
|
});
|
|
|
|
|
|
|
|
$('.NB-add-folder', this.$add).bind('keyup', 'return', function(e) {
|
|
|
|
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');
|
|
|
|
|
2010-07-24 15:54:25 -04:00
|
|
|
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({
|
2010-07-24 15:54:25 -04:00
|
|
|
url: '/import/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');
|
2010-07-24 15:54:25 -04:00
|
|
|
NEWSBLUR.reader.load_feeds();
|
|
|
|
$.modal.close();
|
|
|
|
},
|
|
|
|
error: function (data, status, e)
|
|
|
|
{
|
2010-06-08 11:19:41 -04:00
|
|
|
$loading.removeClass('NB-active');
|
2010-07-24 15:54:25 -04:00
|
|
|
NEWSBLUR.log(['Error', data, status, e]);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return false;
|
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
|
|
|
});
|
|
|
|
|
2010-06-08 11:19:41 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
save_add_url: function() {
|
|
|
|
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');
|
|
|
|
|
|
|
|
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 $loading = $('.NB-loading', '.NB-fieldset.NB-add-add-url');
|
|
|
|
$loading.removeClass('NB-active');
|
|
|
|
|
|
|
|
if (data.code > 0) {
|
|
|
|
NEWSBLUR.reader.load_feeds();
|
|
|
|
$.modal.close();
|
|
|
|
} else {
|
|
|
|
var $error = $('.NB-error', '.NB-fieldset.NB-add-add-url');
|
|
|
|
$error.text(data.message);
|
|
|
|
$error.slideDown(300);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
save_add_folder: function() {
|
|
|
|
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');
|
|
|
|
|
|
|
|
this.model.save_add_folder(folder, parent_folder, $.rescope(this.post_save_add_folder, this));
|
|
|
|
},
|
|
|
|
|
|
|
|
post_save_add_folder: function(e, data) {
|
|
|
|
NEWSBLUR.log(['Data', data]);
|
|
|
|
var $loading = $('.NB-loading', '.NB-fieldset.NB-add-add-folder');
|
|
|
|
$loading.removeClass('NB-active');
|
|
|
|
|
|
|
|
if (data.code > 0) {
|
|
|
|
NEWSBLUR.reader.load_feeds();
|
2010-08-30 19:57:27 -04:00
|
|
|
_.defer(function() {
|
|
|
|
NEWSBLUR.reader.open_add_feed_modal();
|
|
|
|
});
|
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);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|