2010-10-10 23:36:09 -04:00
|
|
|
NEWSBLUR.ReaderKeyboard = function(options) {
|
|
|
|
var defaults = {};
|
|
|
|
|
|
|
|
this.options = $.extend({}, defaults, options);
|
|
|
|
this.runner();
|
|
|
|
};
|
|
|
|
|
|
|
|
NEWSBLUR.ReaderKeyboard.prototype = {
|
|
|
|
|
|
|
|
runner: function() {
|
|
|
|
this.make_modal();
|
|
|
|
this.handle_cancel();
|
|
|
|
this.open_modal();
|
|
|
|
|
|
|
|
this.$modal.bind('click', $.rescope(this.handle_click, this));
|
|
|
|
},
|
|
|
|
|
|
|
|
make_modal: function() {
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
this.$modal = $.make('div', { className: 'NB-modal-keyboard NB-modal' }, [
|
|
|
|
$.make('h2', { className: 'NB-modal-title' }, 'Keyboard shortcuts'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
2010-10-12 20:13:33 -04:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Next story'),
|
2010-10-12 13:17:43 -04:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
2010-10-21 19:36:03 -04:00
|
|
|
'↓'
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
2010-10-12 13:17:43 -04:00
|
|
|
'j'
|
|
|
|
]),
|
2010-10-12 20:13:33 -04:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-image' }, [
|
|
|
|
$.make('img', { src: NEWSBLUR.Globals.MEDIA_URL + '/img/reader/keyboard_down.png', width: 268, height: 65 })
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Previous story'),
|
2010-10-12 13:17:43 -04:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
2010-10-21 19:36:03 -04:00
|
|
|
'↑'
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
2010-10-12 13:17:43 -04:00
|
|
|
'k'
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-image' }, [
|
2010-10-12 20:13:33 -04:00
|
|
|
$.make('img', { src: NEWSBLUR.Globals.MEDIA_URL + '/img/reader/keyboard_up.png', width: 268, height: 65 })
|
2010-10-12 13:17:43 -04:00
|
|
|
])
|
2010-10-12 20:13:33 -04:00
|
|
|
])
|
2010-10-21 19:36:03 -04:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Next site'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'shift',
|
|
|
|
$.make('span', '+'),
|
|
|
|
'↓'
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'shift',
|
|
|
|
$.make('span', '+'),
|
|
|
|
'j'
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Prev. site'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'shift',
|
|
|
|
$.make('span', '+'),
|
|
|
|
'↑'
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'shift',
|
|
|
|
$.make('span', '+'),
|
|
|
|
'k'
|
|
|
|
])
|
|
|
|
])
|
2010-10-12 20:13:33 -04:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
2010-10-12 13:17:43 -04:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Switch views'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
2010-10-12 20:13:33 -04:00
|
|
|
'←'
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'→'
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-image' }, [
|
|
|
|
$.make('img', { src: NEWSBLUR.Globals.MEDIA_URL + '/img/reader/keyboard_leftright.png', width: 268, height: 29 })
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
2011-11-26 02:07:08 -05:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Open in Story view'),
|
2010-10-12 20:13:33 -04:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'enter'
|
2010-10-12 13:17:43 -04:00
|
|
|
]),
|
2010-10-12 20:13:33 -04:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-image' }, [
|
|
|
|
$.make('img', { src: NEWSBLUR.Globals.MEDIA_URL + '/img/reader/keyboard_enter.png', width: 268, height: 29 })
|
|
|
|
])
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Page down'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'space'
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Page up'),
|
2010-10-12 13:17:43 -04:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
2010-10-12 20:13:33 -04:00
|
|
|
'shift',
|
|
|
|
$.make('span', '+'),
|
|
|
|
'space'
|
2010-10-12 13:17:43 -04:00
|
|
|
])
|
2010-10-10 23:36:09 -04:00
|
|
|
])
|
2011-05-20 17:41:36 -04:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Next Unread Story'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'n'
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Hide Sidebar'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'u'
|
|
|
|
])
|
|
|
|
])
|
2011-07-29 09:41:49 -07:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Save/Unsave Story'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
's'
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Change Intelligence'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'+'
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'-'
|
|
|
|
])
|
|
|
|
])
|
2011-10-30 22:21:58 -07:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Open site/feed trainer'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'f'
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Open story trainer'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
't'
|
|
|
|
])
|
|
|
|
])
|
2011-10-31 18:04:25 -07:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Open story in new window'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'o'
|
|
|
|
])
|
2011-10-31 18:40:07 -07:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
2011-11-26 02:07:08 -05:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Mark all as read'),
|
2011-10-31 18:40:07 -07:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'shift',
|
|
|
|
$.make('span', '+'),
|
|
|
|
'a'
|
|
|
|
])
|
2011-10-31 18:04:25 -07:00
|
|
|
])
|
2011-11-26 02:07:08 -05:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Return to dashboard'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'd'
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Open Everything'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'shift',
|
|
|
|
$.make('span', '+'),
|
|
|
|
'e'
|
|
|
|
])
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'View keyboard shortcuts'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'?'
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Find oldest unread story'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'm'
|
|
|
|
])
|
|
|
|
])
|
2012-03-08 23:00:08 +01:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Toggle read/unread'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'shift',
|
|
|
|
$.make('span', '+'),
|
|
|
|
'u'
|
|
|
|
])
|
|
|
|
])
|
2010-10-10 23:36:09 -04:00
|
|
|
])
|
|
|
|
]);
|
|
|
|
},
|
|
|
|
|
|
|
|
open_modal: function() {
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
this.$modal.modal({
|
2011-02-23 18:09:09 -05:00
|
|
|
'minWidth': 620,
|
|
|
|
'maxWidth': 620,
|
2010-10-10 23:36:09 -04:00
|
|
|
'overlayClose': true,
|
|
|
|
'onOpen': function (dialog) {
|
|
|
|
dialog.overlay.fadeIn(200, function () {
|
|
|
|
dialog.container.fadeIn(200);
|
|
|
|
dialog.data.fadeIn(200);
|
2010-10-12 20:13:33 -04:00
|
|
|
$(window).resize();
|
2010-10-10 23:36:09 -04:00
|
|
|
});
|
|
|
|
},
|
|
|
|
'onShow': function(dialog) {
|
|
|
|
$('#simplemodal-container').corner('6px');
|
|
|
|
},
|
|
|
|
'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);
|
|
|
|
|
|
|
|
$cancel.click(function(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
$.modal.close();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
// ===========
|
|
|
|
// = 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();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2012-03-08 23:00:08 +01:00
|
|
|
};
|