Keyboard shortcut legend
New: Show keybaord shortcuts with '?' New: ctrl+s will save settings
This commit is contained in:
parent
7fc3b971f6
commit
e71de9cc29
|
@ -7,6 +7,7 @@ define(
|
||||||
Events: {
|
Events: {
|
||||||
ConfigUpdatedEvent: 'ConfigUpdatedEvent'
|
ConfigUpdatedEvent: 'ConfigUpdatedEvent'
|
||||||
},
|
},
|
||||||
|
|
||||||
Keys : {
|
Keys : {
|
||||||
DefaultProfileId : 'DefaultProfileId',
|
DefaultProfileId : 'DefaultProfileId',
|
||||||
DefaultRootFolderId : 'DefaultRootFolderId',
|
DefaultRootFolderId : 'DefaultRootFolderId',
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
@import "../Rename/rename";
|
@import "../Rename/rename";
|
||||||
@import "typeahead";
|
@import "typeahead";
|
||||||
@import "utilities";
|
@import "utilities";
|
||||||
|
@import "../Hotkeys/hotkeys";
|
||||||
|
|
||||||
.main-region {
|
.main-region {
|
||||||
@media (min-width: @screen-lg-min) {
|
@media (min-width: @screen-lg-min) {
|
||||||
|
@ -239,3 +240,10 @@ body {
|
||||||
padding-top: 10px;
|
padding-top: 10px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.modal-header {
|
||||||
|
h3 {
|
||||||
|
margin-top : 0px;
|
||||||
|
margin-bottom : 0px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,37 @@
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
define(
|
||||||
|
[
|
||||||
|
'jquery',
|
||||||
|
'vent',
|
||||||
|
'Hotkeys/HotkeysView'
|
||||||
|
], function ($, vent, HotkeysView) {
|
||||||
|
$(document).on('keydown', function (e) {
|
||||||
|
if (e.ctrlKey && e.keyCode === 83) {
|
||||||
|
vent.trigger(vent.Hotkeys.SaveSettings);
|
||||||
|
e.preventDefault();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.shiftKey && e.keyCode === 191) {
|
||||||
|
vent.trigger(vent.Commands.OpenModalCommand, new HotkeysView());
|
||||||
|
// vent.trigger(vent.Hotkeys.ShowHotkeys);
|
||||||
|
e.preventDefault();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($(e.target).is('input') || $(e.target).is('textarea')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.ctrlKey || e.metaKey || e.altKey) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.keyCode === 84) {
|
||||||
|
vent.trigger(vent.Hotkeys.NavbarSearch);
|
||||||
|
e.preventDefault();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
|
@ -0,0 +1,11 @@
|
||||||
|
'use strict';
|
||||||
|
define(
|
||||||
|
[
|
||||||
|
'vent',
|
||||||
|
'marionette'
|
||||||
|
], function (vent, Marionette) {
|
||||||
|
|
||||||
|
return Marionette.ItemView.extend({
|
||||||
|
template: 'Hotkeys/HotkeysViewTemplate'
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,47 @@
|
||||||
|
<div class="modal-dialog">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-header">
|
||||||
|
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
|
||||||
|
<h3>Keyboard Shortcuts</h3>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body hotkeys-modal">
|
||||||
|
<div class="row hotkey-group">
|
||||||
|
<div class="col-md-12">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-5 col-md-offset-1">
|
||||||
|
<h3>Focus Search Box</h3>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-3">
|
||||||
|
<kbd class="hotkey">t</kbd>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-11 col-md-offset-1">
|
||||||
|
Pressing 't' puts the cursor in the search box below the navigation links
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="row hotkey-group">
|
||||||
|
<div class="col-md-12">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-5 col-md-offset-1">
|
||||||
|
<h3>Save Settings</h3>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-3">
|
||||||
|
<kbd class="hotkey">ctrl + s</kbd>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-11 col-md-offset-1">
|
||||||
|
Pressing ctrl + 's' saves your settings (only in settings)
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button class="btn" data-dismiss="modal">close</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
|
@ -0,0 +1,23 @@
|
||||||
|
.hotkeys-modal {
|
||||||
|
h3 {
|
||||||
|
margin-top : 0px;
|
||||||
|
margin-botton : 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hotkey-group {
|
||||||
|
&:first-of-type {
|
||||||
|
margin-top : 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:last-of-type {
|
||||||
|
margin-bottom : 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
margin-top : 25px;
|
||||||
|
margin-bottom : 25px;
|
||||||
|
|
||||||
|
.hotkey {
|
||||||
|
font-size : 22px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -3,23 +3,14 @@ define(
|
||||||
[
|
[
|
||||||
'underscore',
|
'underscore',
|
||||||
'jquery',
|
'jquery',
|
||||||
|
'vent',
|
||||||
'backbone',
|
'backbone',
|
||||||
'Series/SeriesCollection',
|
'Series/SeriesCollection',
|
||||||
'typeahead'
|
'typeahead'
|
||||||
], function (_, $, Backbone, SeriesCollection) {
|
], function (_, $, vent, Backbone, SeriesCollection) {
|
||||||
$(document).on('keydown', function (e) {
|
|
||||||
if ($(e.target).is('input') || $(e.target).is('textarea')) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (e.ctrlKey || e.metaKey || e.altKey) {
|
vent.on(vent.Hotkeys.NavbarSearch, function () {
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (e.keyCode === 84) {
|
|
||||||
$('.x-series-search').focus();
|
$('.x-series-search').focus();
|
||||||
e.preventDefault();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
$.fn.bindSearch = function () {
|
$.fn.bindSearch = function () {
|
||||||
|
|
|
@ -89,6 +89,8 @@ define(
|
||||||
if (options.action) {
|
if (options.action) {
|
||||||
this.action = options.action.toLowerCase();
|
this.action = options.action.toLowerCase();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.listenTo(vent, vent.Hotkeys.SaveSettings, this._save);
|
||||||
},
|
},
|
||||||
|
|
||||||
onRender: function () {
|
onRender: function () {
|
||||||
|
|
|
@ -245,7 +245,8 @@ define(
|
||||||
'System/StatusModel',
|
'System/StatusModel',
|
||||||
'Shared/Tooltip',
|
'Shared/Tooltip',
|
||||||
'Instrumentation/StringFormat',
|
'Instrumentation/StringFormat',
|
||||||
'LifeCycle'
|
'LifeCycle',
|
||||||
|
'Hotkeys/Hotkeys'
|
||||||
], function ($, Backbone, Marionette, RouteBinder, SignalRBroadcaster, NavbarView, AppLayout, SeriesController, Router, ModalController, ControlPanelController, serverStatusModel, Tooltip) {
|
], function ($, Backbone, Marionette, RouteBinder, SignalRBroadcaster, NavbarView, AppLayout, SeriesController, Router, ModalController, ControlPanelController, serverStatusModel, Tooltip) {
|
||||||
|
|
||||||
new SeriesController();
|
new SeriesController();
|
||||||
|
|
|
@ -30,5 +30,11 @@ define(
|
||||||
CloseControlPanelCommand : 'CloseControlPanelCommand'
|
CloseControlPanelCommand : 'CloseControlPanelCommand'
|
||||||
};
|
};
|
||||||
|
|
||||||
|
vent.Hotkeys = {
|
||||||
|
NavbarSearch : 'navbar:search',
|
||||||
|
SaveSettings : 'settings:save',
|
||||||
|
ShowHotkeys : 'hotkeys:show'
|
||||||
|
};
|
||||||
|
|
||||||
return vent;
|
return vent;
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue