NewsBlur/media/js/newsblur/reader/reader_intro.js

373 lines
15 KiB
JavaScript
Raw Normal View History

NEWSBLUR.ReaderIntro = function(options) {
var defaults = {};
_.bindAll(this, 'close');
this.options = $.extend({
'page_number': 2
}, defaults, options);
this.model = NEWSBLUR.AssetModel.reader();
this.page_number = this.options.page_number;
this.slider_value = 0;
this.intervals = {};
this.runner();
};
NEWSBLUR.ReaderIntro.prototype = new NEWSBLUR.Modal;
NEWSBLUR.ReaderIntro.prototype.constructor = NEWSBLUR.ReaderIntro;
_.extend(NEWSBLUR.ReaderIntro.prototype, {
TITLES: [
'Welcome to NewsBlur',
'Welcome to NewsBlur',
'Welcome to NewsBlur',
'Welcome to NewsBlur',
'Welcome to NewsBlur'
],
runner: function() {
this.make_modal();
this.open_modal();
this.page(this.page_number);
this.$modal.bind('click', $.rescope(this.handle_click, this));
this.$modal.bind('change', $.rescope(this.handle_change, this));
},
make_modal: function() {
var self = this;
this.$modal = $.make('div', { className: 'NB-modal-intro NB-modal' }, [
$.make('span', { className: 'NB-modal-loading NB-spinner'}),
$.make('div', { className: 'NB-modal-page' }),
$.make('h2', { className: 'NB-modal-title' }),
$.make('img', { className: 'NB-intro-spinning-logo', src: NEWSBLUR.Globals.MEDIA_URL + 'img/logo_512.png' }),
$.make('div', { className: 'NB-page NB-page-1' }, [
$.make('h4', { className: 'NB-page-1-started' }, "So much time and so little to do. Strike that! Reverse it.")
]),
$.make('div', { className: 'NB-page NB-page-2 carousel' }, [
$.make('div', { className: 'carousel-inner NB-intro-imports' }, [
$.make('div', { className: 'item NB-intro-imports-start' }, [
$.make('h4', { className: 'NB-page-2-started' }, "Let's get some sites to read."),
$.make('div', { className: 'NB-intro-import NB-intro-import-google' }, [
$.make('h3', [
'Import from',
$.make('br'),
$.make('img', { src: NEWSBLUR.Globals.MEDIA_URL + 'img/reader/google-reader-logo.gif' })
]),
$.make('a', { href: NEWSBLUR.URLs['google-reader-authorize'], className: 'NB-google-reader-oauth NB-modal-submit-green NB-modal-submit-button' }, [
'Connect to Google'
]),
$.make('div', { className: 'NB-error' })
]),
$.make('div', { className: 'NB-intro-import NB-intro-import-opml' }, [
$.make('h3', ['Upload an', $.make('br'), 'OPML file']),
$.make('form', { method: 'post', enctype: 'multipart/form-data', className: 'NB-opml-upload-form' }, [
$.make('div', { href: '#', className: 'NB-intro-upload-opml NB-modal-submit-green NB-modal-submit-button' }, [
'Upload OPML File',
$.make('input', { type: 'file', name: 'file', id: 'NB-intro-upload-opml-button', className: 'NB-intro-upload-opml-button' })
])
]),
$.make('div', { className: 'NB-error' })
])
]),
$.make('div', { className: 'item NB-intro-imports-progress' }, [
$.make('h4', { className: 'NB-page-2-started' }, "Importing your sites..."),
$.make('div', { className: 'NB-loading' })
]),
$.make('div', { className: 'item NB-intro-imports-sites' }, [
$.make('h4'),
$.make('div', { className: 'NB-intro-import-restart NB-modal-submit-grey NB-modal-submit-button' }, [
'« Restart and re-import your sites'
])
])
]),
$.make('div', { className: 'NB-intro-bookmarklet' }, [
NEWSBLUR.generate_bookmarklet(),
$.make('div', { className: 'NB-intro-bookmarklet-arrow' }, '←'),
$.make('div', { className: 'NB-intro-bookmarklet-info' }, 'Install the bookmarklet')
])
]),
$.make('div', { className: 'NB-page NB-page-3' }, [
$.make('h4', { className: 'NB-page-3-started' }, "Social")
]),
$.make('div', { className: 'NB-page NB-page-4' }, [
$.make('h4', { className: 'NB-page-4-started' }, "Feed chooser/premium")
]),
$.make('div', { className: 'NB-page NB-page-5' }, [
$.make('h4', { className: 'NB-page-5-started' }, "Feedback")
]),
$.make('div', { className: 'NB-modal-submit' }, [
$.make('div', { className: 'NB-page-next NB-modal-submit-button NB-modal-submit-green NB-modal-submit-save' }, [
$.make('span', { className: 'NB-tutorial-next-page-text' }, "Let's Get Started "),
$.make('span', { className: 'NB-raquo' }, '»')
]),
$.make('div', { className: 'NB-page-previous NB-modal-submit-button NB-modal-submit-close NB-modal-submit-save' }, [
$.make('span', { className: 'NB-tutorial-previous-page-text' }, "Skip this step "),
$.make('span', { className: 'NB-raquo' }, '»')
])
])
]);
$('.carousel', this.$modal).carousel({
interval: 1000
});
},
set_title: function() {
$('.NB-modal-title', this.$modal).text(this.TITLES[this.page_number-1]);
},
// ==========
// = Paging =
// ==========
next_page: function() {
return this.page(this.page_number+1, this.page_number);
},
previous_page: function() {
return this.page(this.page_number-1, this.page_number);
},
page: function(page_number, from_page) {
if (page_number == null) {
return this.page_number;
}
var page_count = $('.NB-page', this.$modal).length;
this.page_number = page_number;
if (page_number == page_count) {
$('.NB-tutorial-next-page-text', this.$modal).text('All Done ');
} else if (page_number > page_count) {
return this.close();
} else if (page_number == 1) {
$('.NB-tutorial-next-page-text', this.$modal).text("Let's Get Started ");
} else {
$('.NB-tutorial-next-page-text', this.$modal).text('Next Page ');
}
$('.NB-page-previous', this.$modal).toggle(page_number != 1);
$('.NB-page', this.$modal).css({'display': 'none'});
$('.NB-page-'+this.page_number, this.$modal).css({'display': 'block'});
$('.NB-modal-page', this.$modal).html($.make('div', [
'Step ',
$.make('b', this.page_number),
' of ',
$.make('b', page_count)
]));
if (page_number > 1) {
$('.NB-intro-spinning-logo', this.$modal).css({'top': 0, 'left': 0, 'width': 48, 'height': 48});
$('.NB-modal-title', this.$modal).css({'paddingLeft': 42});
}
this.set_title();
if (page_number == 2) {
this.advance_import_carousel();
}
},
advance_import_carousel: function(page) {
var $carousel = $('.carousel', this.$modal);
$carousel.carousel('pause');
if (!_.isNumber(page)) {
if (_.size(this.model.feeds) && !this.options.force_import) {
page = 2;
$('.NB-intro-imports-sites', this.$modal).addClass('active');
} else {
page = 0;
$('.NB-intro-imports-start', this.$modal).addClass('active');
}
}
$carousel.carousel(page);
$carousel.carousel('pause');
this.count_feeds();
},
count_feeds: function() {
$(".NB-intro-imports-sites h4", this.$modal).text([
'You are subscribed to ',
Inflector.pluralize(' site', _.size(this.model.feeds), true),
'.'
].join(""));
},
fade_out_logo: function() {
var self = this;
var $logo = $('.NB-intro-spinning-logo', this.$modal);
var $page1 = $('.NB-page-1', this.$modal);
var $page2 = $('.NB-page-2', this.$modal);
var $submit = $('.NB-modal-submit', this.$modal);
var $title = $('.NB-modal-title', this.$modal);
$submit.animate({'opacity': 0}, {'duration': 800, 'easing': 'easeInOutQuad'});
$page1.animate({'opacity': 0}, {
'duration': 800,
'easing': 'easeInOutQuint',
'complete': function() {
$logo.animate({'top': 0, 'left': 0, 'width': 48, 'height': 48}, {
'duration': 1160,
'easing': 'easeInOutCubic',
'complete': function() {
$page2.css({'opacity': 0});
self.page(2);
$page2.animate({'opacity': 1}, {'duration': 1000, 'easing': 'easeInOutQuad'});
$submit.animate({'opacity': 1}, {'duration': 1000, 'easing': 'easeInOutQuad'});
}
});
$title.animate({'paddingLeft': 42}, {'duration': 1100, 'easing': 'easeInOutQuart'});
}
});
},
close_and_load_newsblur_blog: function() {
this.close();
NEWSBLUR.reader.load_feed_in_tryfeed_view(this.newsblur_feed.id, this.newsblur_feed);
},
2012-03-03 09:51:38 -08:00
// ==========
// = Import =
// ==========
google_reader_connect: function() {
var options = "location=0,status=0,width=800,height=500";
var url = "/import/authorize?modal=true";
this.connect_window = window.open(url, '_blank', options);
NEWSBLUR.reader.flags.importing_from_google_reader = true;
},
start_import_from_google_reader: function(data) {
var $error = $('.NB-intro-gitgoogle .NB-error', this.$modal);
var $loading = $('.NB-intro-imports-progress .NB-loading', this.$modal);
if (data.error) {
$error.show().text(data.error);
this.advance_import_carousel(0);
} else {
$error.hide();
NEWSBLUR.reader.flags.importing_from_google_reader = false;
this.advance_import_carousel(1);
$loading.addClass('NB-active');
this.model.start_import_from_google_reader($.rescope(this.finish_import_from_google_reader, this));
}
},
finish_import_from_google_reader: function() {
var $loading = $('.NB-intro-imports-progress .NB-loading', this.$modal);
$loading.removeClass('NB-active');
NEWSBLUR.reader.load_feeds(_.bind(function() {
this.advance_import_carousel(2);
}, this));
},
2012-03-03 09:51:38 -08:00
handle_opml_upload: function() {
var self = this;
var $loading = $('.NB-intro-imports-progress .NB-loading', this.$modal);
2012-03-03 09:51:38 -08:00
var $error = $('.NB-intro-import-opml .NB-error', this.$modal);
var $file = $('.NB-intro-upload-opml-button', this.$modal);
2012-03-03 09:51:38 -08:00
$error.slideUp(300);
$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;
}
this.advance_import_carousel(1);
2012-03-03 09:51:38 -08:00
// NEWSBLUR.log(['Uploading']);
var formData = new FormData($file.closest('form')[0]);
$.ajax({
url: NEWSBLUR.URLs['opml-upload'],
type: 'POST',
2012-03-03 09:51:38 -08:00
success: function (data, status) {
console.log(["upload opml success", status, data]);
2012-03-03 09:51:38 -08:00
$loading.removeClass('NB-active');
NEWSBLUR.reader.load_feeds(function() {
self.advance_import_carousel(2);
});
2012-03-03 09:51:38 -08:00
NEWSBLUR.reader.load_recommended_feed();
},
error: function (data, status, e) {
self.advance_import_carousel(0);
2012-03-03 09:51:38 -08:00
$loading.removeClass('NB-active');
NEWSBLUR.log(['Error', data, status, e]);
$error.text("There was a problem uploading your OPML file. Try e-mailing it to samuel@ofbrooklyn.com.");
$error.slideDown(300);
},
data: formData,
cache: false,
contentType: false,
processData: false
2012-03-03 09:51:38 -08:00
});
$file.replaceWith($file.clone());
2012-03-03 09:51:38 -08:00
return false;
},
// ===========
// = Actions =
// ===========
handle_click: function(elem, e) {
var self = this;
$.targetIs(e, { tagSelector: '.NB-page-next' }, function($t, $p) {
e.preventDefault();
if (self.page_number == 1) {
self.fade_out_logo();
} else {
self.next_page();
}
});
$.targetIs(e, { tagSelector: '.NB-page-previous' }, function($t, $p) {
e.preventDefault();
self.previous_page();
});
$.targetIs(e, { tagSelector: '.NB-tutorial-finish-newsblur-blog' }, function($t, $p) {
e.preventDefault();
self.close_and_load_newsblur_blog();
});
$.targetIs(e, { tagSelector: '.NB-google-reader-oauth' }, function($t, $p) {
e.preventDefault();
self.google_reader_connect();
});
$.targetIs(e, { tagSelector: '.NB-intro-import-restart' }, function($t, $p) {
e.preventDefault();
self.advance_import_carousel(0);
});
2012-03-03 09:51:38 -08:00
$.targetIs(e, { tagSelector: '.NB-intro-upload-opml' }, function($t, $p) {
// e.preventDefault();
// return false;
});
$.targetIs(e, { tagSelector: '.NB-goodies-bookmarklet-button' }, function($t, $p) {
e.preventDefault();
alert('Drag this button to your bookmark toolbar.');
});
},
handle_change: function(elem, e) {
var self = this;
$.targetIs(e, { tagSelector: '.NB-intro-upload-opml-button' }, function($t, $p) {
e.preventDefault();
self.handle_opml_upload();
});
}
});