Resolved few undo action on UI tabs - tabs were not getting activated

during undo-redo action. Also, resolved the focus losing issue, which
closing the subnode editor using undo action.

Also, resolved an issue related to 'beforeopen' failed on server node,
due to api changes on tree events.
pull/3/head
Ashesh Vashi 2015-10-30 13:07:09 +05:30
parent 30c560f33b
commit 45596dffa0
5 changed files with 77 additions and 34 deletions

View File

@ -112,16 +112,14 @@ function($, _, S, pgAdmin, pgBrowser, alertify) {
return false;
},
/* Connect the server (if not connected), before opening this node */
beforeopen: function(o) {
var data = o.data;
beforeopen: function(item, data, browser) {
if(!data || data._type != 'server') {
return false;
}
o.browser.tree.addIcon(o.item, {icon: data.icon});
browser.tree.addIcon(item, {icon: data.icon});
if (!data.connected) {
connect_to_server(this, data, o.browser.tree, o.item);
connect_to_server(this, data, browser.tree, item);
return false;
}
return true;

View File

@ -52,7 +52,7 @@ OWNER TO helpdesk;\n';
if (d && obj.Nodes[d._type].callbacks['selected'] &&
_.isFunction(obj.Nodes[d._type].callbacks['selected'])) {
return obj.Nodes[d._type].callbacks['selected'].apply(
obj.Nodes[d._type], [i]);
obj.Nodes[d._type], [i, d, obj]);
}
}
};
@ -441,7 +441,7 @@ OWNER TO helpdesk;\n';
typeof obj.Nodes[d._type].callbacks[eventName] ==
'function') {
return obj.Nodes[d._type].callbacks[eventName].apply(
obj.Nodes[d._type], [item, eventName, options]
obj.Nodes[d._type], [item, d, obj, options, eventName]
);
}
}
@ -475,6 +475,7 @@ OWNER TO helpdesk;\n';
}
break;
}
return true;
});
// There are some scripts which needed to be loaded immediately,

View File

@ -400,7 +400,7 @@ function($, _, S, pgAdmin, Menu, Backbone, Alertify, Backform) {
null).show()
},
// Callback called - when a node is selected in browser tree.
selected: function(item) {
selected: function(item, data, browser) {
// Show the information about the selected node in the below panels,
// which are visible at this time:
// + Properties
@ -408,9 +408,9 @@ function($, _, S, pgAdmin, Menu, Backbone, Alertify, Backform) {
// + Dependents
// + Dependencies
// + Statistics
var b = pgBrowser,
var b = browser || pgBrowser,
t = b.tree,
d = t.itemData(item);
d = data || t.itemData(item);
// Update the menu items
pgAdmin.Browser.enable_disable_menus.apply(b, [item]);
@ -847,6 +847,7 @@ function($, _, S, pgAdmin, Menu, Backbone, Alertify, Backform) {
if (self.handler && self.handler.undoMgr) {
self.handler.undoMgr.merge(self.undoMgr);
self.handler.ignoreTabChange = 0;
}
self.undoMgr.addUndoType("pg-sub-node:opened", {
@ -871,21 +872,28 @@ function($, _, S, pgAdmin, Menu, Backbone, Alertify, Backform) {
}
});
self.undoMgr.addUndoType("pg-sub-node:closed", {
"handler": (self.handler || self),
"on": function (cell, index) {
return {
"object": cell,
"object": {'cell': cell, 'index': index},
"before": null,
"after": null,
"options": index
"options": this.handler
}
},
"undo": function (cell, before, after, opts) {
if (cell && cell.enterEditMode &&
_.isFunction(cell.enterEditMode)) {
cell.enterEditMode();
cell.currentEditor.objectView.$el
.find('.nav-tabs').first()
.find('a[data-tab-index="' + opts + '"]').tab('show');
"undo": function (obj, before, after, opts) {
if (obj.cell && obj.cell.enterEditMode &&
_.isFunction(obj.cell.enterEditMode)) {
obj.cell.enterEditMode();
var tabs = obj.cell.currentEditor.objectView.$el
.find('.nav-tabs').first();
var tab = tabs.find('a[data-tab-index="' + obj.index + '"]');
if (tab.length) {
opts.ignoreTabChange++;
tab.tab('show');
tabs.find('li').removeClass('active');
tab.parent().addClass('active');
}
}
},
"redo": function (cell, before, after, opts) {
@ -895,30 +903,58 @@ function($, _, S, pgAdmin, Menu, Backbone, Alertify, Backform) {
}
}
});
(self.handler || self).ignoreTabChange = 0;
self.undoMgr.addUndoType("pg-property-tab-changed", {
"ignore": false,
'mgr': self.undoMgr,
"on": function (tabs) {
if (!this.ignore && !this.mgr.stack.isCurrentlyUndoRedoing) {
'handler': (self.handler || self),
"on": function (obj) {
if (!this.handler.ignoreTabChange &&
!this.mgr.stack.isCurrentlyUndoRedoing) {
return {
"object": tabs,
"object": obj,
"before": null,
"after": null,
"options": this
"options": this.handler
}
}
this.igonre = false;
this.handler.ignoreTabChange--;
},
"undo": function (obj, before, after, opts) {
if (obj.hidden) {
opts.ignore = true;
$(obj.hidden).tab('show');
var m = obj.model;
if (obj.collection) {
m = obj.collection.models[obj.index];
}
var panelEl = m && m.panelEl;
if (panelEl) {
var tabs = panelEl.find('.nav-tabs').first(),
tab = tabs.find('a[data-tab-index="' + obj.hidden + '"]');
if (tab.length) {
opts.ignoreTabChange++;
tab.tab('show');
tabs.find('li').removeClass('active');
tab.parent().addClass('active');
}
}
}
},
"redo": function (obj, before, after, opts) {
if (obj.shown) {
opts.ignore = true;
$(obj.shown).tab('show');
var m = obj.model;
if (obj.collection) {
m = obj.collection.models[obj.index];
}
var panelEl = m && m.panelEl;
if (panelEl) {
var tabs = panelEl.find('.nav-tabs').first(),
tab = tabs.find('a[data-tab-index="' + obj.shown + '"]');
if (tab.length) {
opts.ignoreTabChange++;
tab.tab('show');
tabs.find('li').removeClass('active');
tab.parent().addClass('active');
}
}
}
}
});

View File

@ -181,12 +181,13 @@
controls = this.controls,
tmpls = this.template,
self = this,
idx=0;
idx=1;
this.$el
.empty()
.attr('role', 'tabpanel')
.attr('class', this.tabPanelClassName());
m.panelEl = this.$el;
var tabHead = $('<ul class="nav nav-tabs" role="tablist"></ul>')
.appendTo(this.$el);
@ -208,12 +209,15 @@
controls.push(cntr);
});
tabHead.find('a[data-toggle="tab"]').on('hidden.bs.tab', function() {
self.hidden_tab = this;
self.hidden_tab = $(this).data('tabIndex');
});
tabHead.find('a[data-toggle="tab"]').on('shown.bs.tab', function() {
self.shown_tab = this;
self.curr_tab_index = $(this).data('tabIndex');
m.trigger('pg-property-tab-changed', {'shown': self.shown_tab, 'hidden': self.hidden_tab});
self.shown_tab = $(this).data('tabIndex');
m.trigger('pg-property-tab-changed', {
'collection': m.collection, 'model': m,
'index': _.indexOf(m.collection.models, m),
'shown': self.shown_tab, 'hidden': self.hidden_tab
});
});
});

View File

@ -139,6 +139,7 @@
editorOptions['el'] = $(this.el);
editorOptions['columns_length'] = this.column.collection.length;
editorOptions['el'].attr('tabindex' , 1);
this.listenTo(this.model, "backgrid:edit", function (model, column, cell, editor) {
if (column.get("name") == this.column.get("name"))
@ -163,6 +164,8 @@
this.$el.empty();
this.$el.html("<i class='fa fa-pencil-square-o'></i>");
this.delegateEvents();
if (this.grabFocus)
this.$el.focus();
return this;
},
exitEditMode: function() {
@ -173,6 +176,7 @@
this.model.trigger(
"pg-sub-node:closed", this, index
);
this.grabFocus = true;
},
events: {
'click': function(e) {