mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-02-24 23:48:13 -05:00
Merge pull request #3002 from novaugust/shortcuts
Implement Shortcuts in Ember
This commit is contained in:
commit
700e9644e2
9 changed files with 120 additions and 7 deletions
|
@ -22,6 +22,7 @@ var popoverInitializer = {
|
||||||
application.inject('component:gh-popover', 'popover', 'popover:service');
|
application.inject('component:gh-popover', 'popover', 'popover:service');
|
||||||
application.inject('component:gh-popover-button', 'popover', 'popover:service');
|
application.inject('component:gh-popover-button', 'popover', 'popover:service');
|
||||||
application.inject('controller:modals.delete-post', 'popover', 'popover:service');
|
application.inject('controller:modals.delete-post', 'popover', 'popover:service');
|
||||||
|
application.inject('route:application', 'popover', 'popover:service');
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
25
ghost/admin/mixins/editor-route-base.js
Normal file
25
ghost/admin/mixins/editor-route-base.js
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
import ShortcutsRoute from 'ghost/mixins/shortcuts-route';
|
||||||
|
import styleBody from 'ghost/mixins/style-body';
|
||||||
|
|
||||||
|
var EditorRouteBase = Ember.Mixin.create(styleBody, ShortcutsRoute, {
|
||||||
|
shortcuts: {
|
||||||
|
'ctrl+s, command+s': 'save',
|
||||||
|
'ctrl+alt+p': 'publish',
|
||||||
|
'ctrl+alt+z': 'toggleZenMode'
|
||||||
|
},
|
||||||
|
actions: {
|
||||||
|
save: function () {
|
||||||
|
this.get('controller').send('save');
|
||||||
|
},
|
||||||
|
publish: function () {
|
||||||
|
var controller = this.get('controller');
|
||||||
|
controller.send('setSaveType', 'publish');
|
||||||
|
controller.send('save');
|
||||||
|
},
|
||||||
|
toggleZenMode: function () {
|
||||||
|
Ember.$('body').toggleClass('zen');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
export default EditorRouteBase;
|
61
ghost/admin/mixins/shortcuts-route.js
Normal file
61
ghost/admin/mixins/shortcuts-route.js
Normal file
|
@ -0,0 +1,61 @@
|
||||||
|
/* global key, console */
|
||||||
|
|
||||||
|
//Configure KeyMaster to respond to all shortcuts,
|
||||||
|
//even inside of
|
||||||
|
//input, textarea, and select.
|
||||||
|
key.filter = function () {
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only routes can implement shortcuts.
|
||||||
|
* If you need to trigger actions on the controller,
|
||||||
|
* simply call them with `this.get('controller').send('action')`.
|
||||||
|
*
|
||||||
|
* To implement shortcuts, add this mixin to your `extend()`,
|
||||||
|
* and implement a `shortcuts` hash.
|
||||||
|
* In this hash, keys are shortcut combinations
|
||||||
|
* (see [keymaster docs](https://github.com/madrobby/keymaster/blob/master/README.markdown)), and values are controller action names.
|
||||||
|
* ```javascript
|
||||||
|
* shortcuts: {
|
||||||
|
* 'ctrl+s, command+s': 'save',
|
||||||
|
* 'ctrl+alt+p': 'toggleZenMode'
|
||||||
|
* }
|
||||||
|
* ```
|
||||||
|
*/
|
||||||
|
var ShortcutsRoute = Ember.Mixin.create({
|
||||||
|
registerShortcuts: function () {
|
||||||
|
var self = this,
|
||||||
|
shortcuts = this.get('shortcuts');
|
||||||
|
|
||||||
|
Ember.keys(shortcuts).forEach(function (shortcut) {
|
||||||
|
key(shortcut, function (event) {
|
||||||
|
//stop things like ctrl+s from actually opening a save dialogue
|
||||||
|
event.preventDefault();
|
||||||
|
//map the shortcut to its action
|
||||||
|
self.send(shortcuts[shortcut], event);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
removeShortcuts: function () {
|
||||||
|
var shortcuts = this.get('shortcuts');
|
||||||
|
|
||||||
|
Ember.keys(shortcuts).forEach(function (shortcut) {
|
||||||
|
key.unbind(shortcut);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
activate: function () {
|
||||||
|
this._super();
|
||||||
|
if (!this.shortcuts) {
|
||||||
|
console.error('Shortcuts not found on route');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.registerShortcuts();
|
||||||
|
},
|
||||||
|
deactivate: function () {
|
||||||
|
this._super();
|
||||||
|
this.removeShortcuts();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
export default ShortcutsRoute;
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
var styleBody = Ember.Mixin.create({
|
var styleBody = Ember.Mixin.create({
|
||||||
activate: function () {
|
activate: function () {
|
||||||
|
this._super();
|
||||||
var cssClasses = this.get('classNames');
|
var cssClasses = this.get('classNames');
|
||||||
|
|
||||||
if (cssClasses) {
|
if (cssClasses) {
|
||||||
|
@ -14,6 +15,7 @@ var styleBody = Ember.Mixin.create({
|
||||||
},
|
},
|
||||||
|
|
||||||
deactivate: function () {
|
deactivate: function () {
|
||||||
|
this._super();
|
||||||
var cssClasses = this.get('classNames');
|
var cssClasses = this.get('classNames');
|
||||||
|
|
||||||
Ember.run.schedule('afterRender', null, function () {
|
Ember.run.schedule('afterRender', null, function () {
|
||||||
|
|
|
@ -1,5 +1,15 @@
|
||||||
var ApplicationRoute = Ember.Route.extend({
|
import ShortcutsRoute from 'ghost/mixins/shortcuts-route';
|
||||||
|
|
||||||
|
var ApplicationRoute = Ember.Route.extend(ShortcutsRoute, {
|
||||||
|
shortcuts: {
|
||||||
|
'esc': 'closePopups'
|
||||||
|
},
|
||||||
actions: {
|
actions: {
|
||||||
|
closePopups: function () {
|
||||||
|
this.get('popover').closePopovers();
|
||||||
|
this.get('notifications').closeAll();
|
||||||
|
// @todo close modals
|
||||||
|
},
|
||||||
signedIn: function (user) {
|
signedIn: function (user) {
|
||||||
// Update the user on all routes and controllers
|
// Update the user on all routes and controllers
|
||||||
this.container.unregister('user:current');
|
this.container.unregister('user:current');
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import styleBody from 'ghost/mixins/style-body';
|
|
||||||
import AuthenticatedRoute from 'ghost/routes/authenticated';
|
import AuthenticatedRoute from 'ghost/routes/authenticated';
|
||||||
|
import base from 'ghost/mixins/editor-route-base';
|
||||||
|
|
||||||
var EditorEditRoute = AuthenticatedRoute.extend(styleBody, {
|
var EditorEditRoute = AuthenticatedRoute.extend(base, {
|
||||||
classNames: ['editor'],
|
classNames: ['editor'],
|
||||||
|
|
||||||
model: function (params) {
|
model: function (params) {
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import AuthenticatedRoute from 'ghost/routes/authenticated';
|
import AuthenticatedRoute from 'ghost/routes/authenticated';
|
||||||
import styleBody from 'ghost/mixins/style-body';
|
import base from 'ghost/mixins/editor-route-base';
|
||||||
|
|
||||||
var EditorNewRoute = AuthenticatedRoute.extend(styleBody, {
|
var EditorNewRoute = AuthenticatedRoute.extend(base, {
|
||||||
classNames: ['editor'],
|
classNames: ['editor'],
|
||||||
|
|
||||||
model: function () {
|
model: function () {
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import styleBody from 'ghost/mixins/style-body';
|
|
||||||
import AuthenticatedRoute from 'ghost/routes/authenticated';
|
import AuthenticatedRoute from 'ghost/routes/authenticated';
|
||||||
|
import styleBody from 'ghost/mixins/style-body';
|
||||||
|
import ShortcutsRoute from 'ghost/mixins/shortcuts-route';
|
||||||
|
|
||||||
var paginationSettings = {
|
var paginationSettings = {
|
||||||
status: 'all',
|
status: 'all',
|
||||||
|
@ -7,7 +8,7 @@ var paginationSettings = {
|
||||||
page: 1
|
page: 1
|
||||||
};
|
};
|
||||||
|
|
||||||
var PostsRoute = AuthenticatedRoute.extend(styleBody, {
|
var PostsRoute = AuthenticatedRoute.extend(ShortcutsRoute, styleBody, {
|
||||||
classNames: ['manage'],
|
classNames: ['manage'],
|
||||||
|
|
||||||
model: function () {
|
model: function () {
|
||||||
|
@ -23,9 +24,19 @@ var PostsRoute = AuthenticatedRoute.extend(styleBody, {
|
||||||
controller.set('paginationSettings', paginationSettings);
|
controller.set('paginationSettings', paginationSettings);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
shortcuts: {
|
||||||
|
'up': 'moveUp',
|
||||||
|
'down': 'moveDown'
|
||||||
|
},
|
||||||
actions: {
|
actions: {
|
||||||
openEditor: function (post) {
|
openEditor: function (post) {
|
||||||
this.transitionTo('editor', post);
|
this.transitionTo('editor', post);
|
||||||
|
},
|
||||||
|
moveUp: function () {
|
||||||
|
window.alert('@todo keyboard post navigation: up');
|
||||||
|
},
|
||||||
|
moveDown: function () {
|
||||||
|
window.alert('@todo keyboard post navigation: down');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -46,6 +46,9 @@ var Notifications = Ember.ArrayProxy.extend({
|
||||||
type: 'warn',
|
type: 'warn',
|
||||||
message: message
|
message: message
|
||||||
});
|
});
|
||||||
|
},
|
||||||
|
closeAll: function () {
|
||||||
|
window.alert('@TODO implement closeALl notifications');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue