Skip to content

Commit

Permalink
[sql lab] ctrl-r hotkey should run latest SQL (apache#4719)
Browse files Browse the repository at this point in the history
Turns out the SQL would only be committed to the redux store `onBlur`
event to avoid the laggy typing. The delay come from the localStorage
binding that add enough millisecs of delay to feel odd while typing.

I now store the most recent SQL in the local and use that instead.
  • Loading branch information
mistercrunch authored and hughhhh committed Apr 4, 2018
1 parent 783ab29 commit f4b6ec3
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -37,10 +37,12 @@ const propTypes = {
descr: PropTypes.string.isRequired,
func: PropTypes.func.isRequired,
})),
onChange: PropTypes.func,
};

const defaultProps = {
onBlur: () => {},
onChange: () => {},
tables: [],
};

Expand All @@ -51,6 +53,7 @@ class AceEditorWrapper extends React.PureComponent {
sql: props.sql,
selectedText: '',
};
this.onChange = this.onChange.bind(this);
}
componentDidMount() {
// Making sure no text is selected from previous mount
Expand Down Expand Up @@ -97,6 +100,10 @@ class AceEditorWrapper extends React.PureComponent {
}
});
}
onChange(text) {
this.setState({ sql: text });
this.props.onChange(text);
}
getCompletions(aceEditor, session, pos, prefix, callback) {
callback(null, this.state.words);
}
Expand Down Expand Up @@ -125,9 +132,6 @@ class AceEditorWrapper extends React.PureComponent {
}
});
}
textChange(text) {
this.setState({ sql: text });
}
render() {
return (
<AceEditor
Expand All @@ -136,7 +140,7 @@ class AceEditorWrapper extends React.PureComponent {
onLoad={this.onEditorLoad.bind(this)}
onBlur={this.onBlur.bind(this)}
height={this.props.height}
onChange={this.textChange.bind(this)}
onChange={this.onChange}
width="100%"
editorProps={{ $blockScrolling: true }}
enableLiveAutocompletion
Expand Down
11 changes: 9 additions & 2 deletions superset/assets/javascripts/SqlLab/components/SqlEditor.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -53,12 +53,15 @@ class SqlEditor extends React.PureComponent {
this.state = {
autorun: props.queryEditor.autorun,
ctas: '',
sql: props.queryEditor.sql,
};

this.onResize = this.onResize.bind(this);
this.throttledResize = throttle(this.onResize, 250);
this.runQuery = this.runQuery.bind(this);
this.stopQuery = this.stopQuery.bind(this);
this.onSqlChanged = this.onSqlChanged.bind(this);
this.setQueryEditorSql = this.setQueryEditorSql.bind(this);
}
componentWillMount() {
if (this.state.autorun) {
Expand Down Expand Up @@ -88,6 +91,9 @@ class SqlEditor extends React.PureComponent {
this.props.actions.persistEditorHeight(this.props.queryEditor, this.refs.ace.clientHeight);
}
}
onSqlChanged(sql) {
this.setState({ sql });
}
getHotkeyConfig() {
return [
{
Expand Down Expand Up @@ -126,7 +132,7 @@ class SqlEditor extends React.PureComponent {
const qe = this.props.queryEditor;
const query = {
dbId: qe.dbId,
sql: qe.selectedText ? qe.selectedText : qe.sql,
sql: qe.selectedText ? qe.selectedText : this.state.sql,
sqlEditorId: qe.id,
tab: qe.title,
schema: qe.schema,
Expand Down Expand Up @@ -301,7 +307,8 @@ class SqlEditor extends React.PureComponent {
<div>
<AceEditorWrapper
actions={this.props.actions}
onBlur={this.setQueryEditorSql.bind(this)}
onBlur={this.setQueryEditorSql}
onChange={this.onSqlChanged}
queryEditor={this.props.queryEditor}
sql={this.props.queryEditor.sql}
tables={this.props.tables}
Expand Down

0 comments on commit f4b6ec3

Please sign in to comment.