mirror of
https://github.com/pgadmin-org/pgadmin4.git
synced 2025-01-24 15:26:46 -06:00
Adding new control to show SQL query in a control.
It will be used by the nodes like view, which require to show the code inside as one parameter. Also, override the events for the Backform.TextareaControl in order handle some cases, which were not handling the change in textarea properly in all situations. Also, we need to show the error message around the input control with name attribute only. Author: Surinder Kumar (small twicks by me). Reviewed by: Ashesh Vashi
This commit is contained in:
parent
657f14997b
commit
7df9e752bb
@ -182,7 +182,10 @@
|
||||
|
||||
this.clearInvalid();
|
||||
|
||||
this.$el.find(':input').not('button').each(function(ix, el) {
|
||||
/*
|
||||
* Find input which have name attribute.
|
||||
*/
|
||||
this.$el.find(':input[name]').not('button').each(function(ix, el) {
|
||||
var attrArr = $(el).attr('name').split('.'),
|
||||
name = attrArr.shift(),
|
||||
path = attrArr.join('.'),
|
||||
@ -247,6 +250,22 @@
|
||||
"focus input": "clearInvalid"
|
||||
};
|
||||
|
||||
/*
|
||||
* Override the textarea control events in order to resolve the issue related
|
||||
* to not updating the value in model on certain browsers in few situations
|
||||
* like copy/paste, deletion using backspace.
|
||||
*
|
||||
* Reference:
|
||||
* http://stackoverflow.com/questions/11338592/how-can-i-bind-to-the-change-event-of-a-textarea-in-jquery
|
||||
*/
|
||||
Backform.TextareaControl.prototype.events = {
|
||||
"change textarea": "onChange",
|
||||
"keyup textarea": "onChange",
|
||||
"paste textarea": "onChange",
|
||||
"selectionchange textarea": "onChange",
|
||||
"focus textarea": "clearInvalid"
|
||||
};
|
||||
|
||||
/*
|
||||
* Overriding the render function of the select control to allow us to use
|
||||
* options as function, which should return array in the format of
|
||||
@ -1154,9 +1173,9 @@
|
||||
}
|
||||
});
|
||||
|
||||
/*
|
||||
* Integer input Control functionality just like backgrid
|
||||
*/
|
||||
/*
|
||||
* Integer input Control functionality just like backgrid
|
||||
*/
|
||||
var IntegerControl = Backform.IntegerControl = Backform.InputControl.extend({
|
||||
defaults: {
|
||||
type: "number",
|
||||
@ -1409,5 +1428,68 @@
|
||||
collapse: false
|
||||
});
|
||||
|
||||
/*
|
||||
* Control For Code Mirror SQL text area.
|
||||
*/
|
||||
var SqlFieldControl = Backform.SqlFieldControl = Backform.TextareaControl.extend({
|
||||
|
||||
defaults: {
|
||||
label: "",
|
||||
extraClasses: [],
|
||||
helpMessage: null,
|
||||
maxlength: 4096
|
||||
},
|
||||
|
||||
/*
|
||||
* Initialize the SQL Field control properly
|
||||
*/
|
||||
initialize: function(o) {
|
||||
Backform.TextareaControl.prototype.initialize.apply(this, arguments);
|
||||
|
||||
// There is an issue with the Code Mirror SQL.
|
||||
//
|
||||
// It does not initialize the code mirror object completely when the
|
||||
// referenced textarea is hidden (not visible), hence - we need to
|
||||
// refresh the code mirror object on 'pg-property-tab-changed' event to
|
||||
// make it work properly.
|
||||
this.listenTo(this.model, 'pg-property-tab-changed', this.refreshTextArea);
|
||||
},
|
||||
|
||||
getValueFromDOM: function() {
|
||||
return this.sqlField.getValue();
|
||||
},
|
||||
|
||||
render: function() {
|
||||
// Use the Backform TextareaControl's render function
|
||||
Backform.TextareaControl.prototype.render.apply(this, arguments);
|
||||
var self = this,
|
||||
sqlField = CodeMirror.fromTextArea(
|
||||
(self.$el.find("textarea")[0]), {
|
||||
lineNumbers: true,
|
||||
mode: "text/x-sql",
|
||||
readOnly: false
|
||||
});
|
||||
|
||||
self.sqlField = sqlField;
|
||||
|
||||
// Refresh SQL Field to refresh the control lazily after it renders
|
||||
setTimeout(function() {
|
||||
self.refreshTextArea.apply(self);
|
||||
}, 100);
|
||||
|
||||
return self;
|
||||
},
|
||||
|
||||
refreshTextArea: function() {
|
||||
this.sqlField.refresh();
|
||||
},
|
||||
|
||||
remove: function() {
|
||||
this.stopListening(this.model, "pg-property-tab-changed", this.refreshTextArea);
|
||||
|
||||
Backform.TextareaControl.prototype.remove.apply(this, arguments);
|
||||
}
|
||||
});
|
||||
|
||||
return Backform;
|
||||
}));
|
||||
|
Loading…
Reference in New Issue
Block a user