mirror of
https://github.com/wassname/HackFlowy.git
synced 2026-06-27 16:00:04 +08:00
Add keyboard controls to indent & navigate through tasks
This commit is contained in:
@@ -10,6 +10,12 @@ An open-source [Workflowy](http://workflowy.com) clone.
|
||||
* Create a new database and import `schema/hackflowy.sql`.
|
||||
* `node server.js`
|
||||
|
||||
##Controls
|
||||
|
||||
* <kbd>UP</kbd> & <kbd>DOWN</kbd>: navigate through tasks
|
||||
* <kbd>TAB</kbd>: right-indent
|
||||
* <kbd>SHIFT</kbd> + <kbd>TAB</kbd>: left-indent
|
||||
|
||||
##Technologies used
|
||||
|
||||
* Node + Socket.io
|
||||
|
||||
@@ -10,7 +10,7 @@ var app = app || {};
|
||||
events: {
|
||||
'click .task': 'edit',
|
||||
'blur .edit': 'close',
|
||||
'keyup .edit': 'broadcast',
|
||||
'keyup .edit': 'handleKeyup',
|
||||
'keypress .edit': 'update'
|
||||
},
|
||||
|
||||
@@ -46,8 +46,23 @@ var app = app || {};
|
||||
this.$input.focus();
|
||||
},
|
||||
|
||||
broadcast: function(e) {
|
||||
if (e.keyCode == 9) {
|
||||
handleKeyup: function(e) {
|
||||
if (e.keyCode == 40)
|
||||
this.$el.next('li').find('input').focus();
|
||||
else if (e.keyCode == 38)
|
||||
this.$el.prev('li').find('input').focus();
|
||||
|
||||
if (e.shiftKey && e.keyCode == 9) {
|
||||
var model = this.$el.next('li').find('input').data('id');
|
||||
model = app.Tasks.get(model);
|
||||
var old_parent = model.get('parent_id');
|
||||
old_parent = app.Tasks.get(old_parent);
|
||||
var new_parent = old_parent.get('parent_id');
|
||||
if (new_parent == null) new_parent = 0;
|
||||
model.set('parent_id',new_parent);
|
||||
model.save({content: model.get('content'), parent_id: model.get('parent_id')});
|
||||
}
|
||||
else if (e.keyCode == 9) {
|
||||
var parent = this.$el.prev('li').prev('li').find('input').data('id');
|
||||
var current = this.$el.prev('li').find('input').data('id');
|
||||
var model = app.Tasks.get(current);
|
||||
@@ -75,7 +90,6 @@ var app = app || {};
|
||||
this.model.destroy();
|
||||
}
|
||||
else {
|
||||
console.log(this.model.attributes);
|
||||
this.model.save({content: value, parent_id: this.model.attributes.parent_id});
|
||||
}
|
||||
this.$el.removeClass('editing');
|
||||
|
||||
Reference in New Issue
Block a user