2010-10-10 23:36:09 -04:00
|
|
|
NEWSBLUR.ReaderKeyboard = function(options) {
|
2013-04-03 22:33:01 -07:00
|
|
|
var defaults = {
|
2013-04-11 16:50:18 -07:00
|
|
|
width: 620
|
2013-04-03 22:33:01 -07:00
|
|
|
};
|
2010-10-10 23:36:09 -04:00
|
|
|
|
|
|
|
this.options = $.extend({}, defaults, options);
|
|
|
|
this.runner();
|
|
|
|
};
|
|
|
|
|
2013-04-03 22:33:01 -07:00
|
|
|
NEWSBLUR.ReaderKeyboard.prototype = new NEWSBLUR.Modal;
|
|
|
|
NEWSBLUR.ReaderKeyboard.prototype.constructor = NEWSBLUR.ReaderKeyboard;
|
|
|
|
|
|
|
|
_.extend(NEWSBLUR.ReaderKeyboard.prototype, {
|
2010-10-10 23:36:09 -04:00
|
|
|
|
|
|
|
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' }, [
|
2013-04-05 11:26:25 -07:00
|
|
|
$.make('h2', { className: 'NB-modal-title' }, [
|
|
|
|
$.make('div', { className: 'NB-icon' }),
|
|
|
|
'Keyboard shorcuts'
|
|
|
|
]),
|
2010-10-10 23:36:09 -04:00
|
|
|
$.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' }, [
|
2013-01-09 11:57:47 -08:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Quick search for a site'),
|
2010-10-12 20:13:33 -04:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
2013-01-09 11:57:47 -08:00
|
|
|
'g'
|
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 })
|
|
|
|
])
|
|
|
|
])
|
|
|
|
]),
|
2013-01-09 11:57:47 -08:00
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Open in Story view'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'enter'
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Open in Text view'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'shift+enter'
|
|
|
|
])
|
|
|
|
])
|
|
|
|
]),
|
2010-10-12 20:13:33 -04:00
|
|
|
$.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'
|
|
|
|
])
|
|
|
|
]),
|
2012-05-07 15:25:20 -07:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Toggle read/unread'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'u'
|
|
|
|
])
|
2011-05-20 17:41:36 -04:00
|
|
|
])
|
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' }, [
|
2012-08-31 15:38:26 -07:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Reload feed/folder'),
|
2011-07-29 09:41:49 -07:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
2012-08-31 15:38:26 -07:00
|
|
|
'r'
|
2011-07-29 09:41:49 -07:00
|
|
|
])
|
|
|
|
])
|
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'),
|
2012-11-19 11:28:52 -08:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'esc'
|
|
|
|
]),
|
2011-11-26 02:07:08 -05:00
|
|
|
$.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' }, [
|
2012-07-01 14:20:21 -07:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Email story'),
|
2011-11-26 02:07:08 -05:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
2012-07-01 14:20:21 -07:00
|
|
|
'e'
|
2011-11-26 02:07:08 -05:00
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.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'
|
|
|
|
])
|
2013-02-05 18:10:16 -08:00
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Expand story'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'x'
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Scroll to comments'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'c'
|
|
|
|
])
|
2012-04-27 17:44:00 -07:00
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
2012-08-30 18:31:44 -07:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Share this story'),
|
2012-04-27 17:44:00 -07:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'shift',
|
|
|
|
$.make('span', '+'),
|
|
|
|
's'
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Save comments'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'ctrl',
|
|
|
|
$.make('span', '+'),
|
|
|
|
'enter'
|
|
|
|
])
|
2011-11-26 02:07:08 -05:00
|
|
|
])
|
2012-03-08 23:00:08 +01:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
2012-09-01 14:05:24 -07:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Hide Sites'),
|
2012-03-08 23:00:08 +01:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'shift',
|
|
|
|
$.make('span', '+'),
|
|
|
|
'u'
|
|
|
|
])
|
2012-07-01 14:20:21 -07:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
2012-09-01 14:05:24 -07:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Hide Story titles'),
|
2012-07-01 14:20:21 -07:00
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
2012-09-01 14:05:24 -07:00
|
|
|
'shift',
|
|
|
|
$.make('span', '+'),
|
|
|
|
't'
|
2012-07-01 14:20:21 -07:00
|
|
|
])
|
2012-03-08 23:00:08 +01:00
|
|
|
])
|
2012-08-31 15:38:26 -07:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Change Intelligence'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'+'
|
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'-'
|
|
|
|
])
|
2012-09-01 14:05:24 -07:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'View keyboard shortcuts'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'?'
|
|
|
|
])
|
2012-08-31 15:38:26 -07:00
|
|
|
])
|
2013-02-11 17:02:30 -05:00
|
|
|
]),
|
|
|
|
$.make('div', { className: 'NB-keyboard-group' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut NB-last' }, [
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-explanation' }, 'Add Site/Folder'),
|
|
|
|
$.make('div', { className: 'NB-keyboard-shortcut-key' }, [
|
|
|
|
'a'
|
|
|
|
])
|
|
|
|
])
|
2010-10-10 23:36:09 -04:00
|
|
|
])
|
|
|
|
]);
|
|
|
|
},
|
|
|
|
|
|
|
|
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();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2013-04-03 22:33:01 -07:00
|
|
|
});
|