mirror of
https://github.com/pgadmin-org/pgadmin4.git
synced 2024-11-22 08:46:39 -06:00
Ensure the appropriate entry is focussed when entering the history tab.
This commit is contained in:
parent
eb5bb5fcc0
commit
fe95b7670b
@ -57,13 +57,13 @@ export default class QueryHistory extends React.Component {
|
|||||||
|
|
||||||
refocus() {
|
refocus() {
|
||||||
if (this.state.history.length > 0) {
|
if (this.state.history.length > 0) {
|
||||||
this.retrieveQueryListPane().focus();
|
this.retrieveSelectedQuery().parentElement.focus();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
retrieveQueryListPane() {
|
retrieveSelectedQuery() {
|
||||||
return ReactDOM.findDOMNode(this)
|
return ReactDOM.findDOMNode(this)
|
||||||
.getElementsByClassName('query-history')[0];
|
.getElementsByClassName('selected')[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
getCurrentHistoryDetail() {
|
getCurrentHistoryDetail() {
|
||||||
@ -115,8 +115,8 @@ export default class QueryHistory extends React.Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
navigateUpAndDown(event) {
|
navigateUpAndDown(event) {
|
||||||
let arrowKeys = [ARROWUP, ARROWDOWN];
|
const arrowKeys = [ARROWUP, ARROWDOWN];
|
||||||
let key = event.keyCode || event.which;
|
const key = event.keyCode || event.which;
|
||||||
if (arrowKeys.indexOf(key) > -1) {
|
if (arrowKeys.indexOf(key) > -1) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
this.onKeyDownHandler(event);
|
this.onKeyDownHandler(event);
|
||||||
@ -169,17 +169,18 @@ export default class QueryHistory extends React.Component {
|
|||||||
|
|
||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<SplitPane defaultSize="50%" split="vertical" pane1Style={queryEntryListDivStyle}
|
<SplitPane defaultSize='50%' split='vertical' pane1Style={queryEntryListDivStyle}
|
||||||
pane2Style={queryDetailDivStyle}>
|
pane2Style={queryDetailDivStyle}>
|
||||||
<div id='query_list'
|
<div id='query_list'
|
||||||
className="query-history"
|
className='query-history'
|
||||||
onKeyDown={this.navigateUpAndDown}
|
onKeyDown={this.navigateUpAndDown}
|
||||||
tabIndex='0'>
|
tabIndex={-1}>
|
||||||
<ul>
|
<ul>
|
||||||
{this.retrieveOrderedHistory()
|
{this.retrieveOrderedHistory()
|
||||||
.map((entry, index) =>
|
.map((entry, index) =>
|
||||||
<li key={index} className='list-item'
|
<li key={index} className='list-item'
|
||||||
onClick={this.onClickHandler.bind(this, index)}>
|
onClick={this.onClickHandler.bind(this, index)}
|
||||||
|
tabIndex={-1}>
|
||||||
<QueryHistoryEntry
|
<QueryHistoryEntry
|
||||||
historyEntry={entry}
|
historyEntry={entry}
|
||||||
isSelected={index == this.state.selectedEntry}/>
|
isSelected={index == this.state.selectedEntry}/>
|
||||||
|
@ -36,11 +36,11 @@ describe('QueryHistory', () => {
|
|||||||
describe('when we switch to the query history tab', () => {
|
describe('when we switch to the query history tab', () => {
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
historyWrapper.node.refocus();
|
historyWrapper.node.refocus();
|
||||||
spyOn(historyWrapper.node, 'retrieveQueryListPane');
|
spyOn(historyWrapper.node, 'retrieveSelectedQuery');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('does not try to focus on any element', () => {
|
it('does not try to focus on any element', () => {
|
||||||
expect(historyWrapper.node.retrieveQueryListPane).not.toHaveBeenCalled();
|
expect(historyWrapper.node.retrieveSelectedQuery).not.toHaveBeenCalled();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -55,8 +55,6 @@ describe('QueryHistory', () => {
|
|||||||
expect(foundChildren.length).toBe(1);
|
expect(foundChildren.length).toBe(1);
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('does not error', () => { });
|
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('when there is history', () => {
|
describe('when there is history', () => {
|
||||||
@ -221,12 +219,47 @@ describe('QueryHistory', () => {
|
|||||||
|
|
||||||
it('deselects the first history entry', () => {
|
it('deselects the first history entry', () => {
|
||||||
expect(firstEntry.nodes.length).toBe(1);
|
expect(firstEntry.nodes.length).toBe(1);
|
||||||
expect(firstEntry.hasClass('selected')).toBeFalsy();
|
expect(firstEntry.hasClass('selected')).toBe(false);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('selects the second history entry', () => {
|
it('selects the second history entry', () => {
|
||||||
expect(secondEntry.nodes.length).toBe(1);
|
expect(secondEntry.nodes.length).toBe(1);
|
||||||
expect(secondEntry.hasClass('selected')).toBeTruthy();
|
expect(secondEntry.hasClass('selected')).toBe(true);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('when the user clicks inside the main pane but not in any history entry', () => {
|
||||||
|
let queryList;
|
||||||
|
let firstEntry, secondEntry;
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
firstEntry = foundChildren.at(0);
|
||||||
|
secondEntry = foundChildren.at(1);
|
||||||
|
queryList = historyWrapper.find('#query_list');
|
||||||
|
|
||||||
|
secondEntry.simulate('click');
|
||||||
|
queryList.simulate('click');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should not change the selected entry', () => {
|
||||||
|
expect(firstEntry.hasClass('selected')).toBe(false);
|
||||||
|
expect(secondEntry.hasClass('selected')).toBe(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('when up arrow is keyed', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
pressArrowUpKey(queryList);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('selects the first history entry', () => {
|
||||||
|
expect(firstEntry.nodes.length).toBe(1);
|
||||||
|
expect(firstEntry.hasClass('selected')).toBe(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('deselects the second history entry', () => {
|
||||||
|
expect(secondEntry.nodes.length).toBe(1);
|
||||||
|
expect(secondEntry.hasClass('selected')).toBe(false);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -264,7 +297,7 @@ describe('QueryHistory', () => {
|
|||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
selectedListItem = ReactDOM.findDOMNode(historyWrapper.node)
|
selectedListItem = ReactDOM.findDOMNode(historyWrapper.node)
|
||||||
.getElementsByClassName('query-history')[0];
|
.getElementsByClassName('list-item')[0];
|
||||||
|
|
||||||
spyOn(selectedListItem, 'focus');
|
spyOn(selectedListItem, 'focus');
|
||||||
historyWrapper.node.refocus();
|
historyWrapper.node.refocus();
|
||||||
|
Loading…
Reference in New Issue
Block a user