Skip to content
This repository has been archived by the owner on Dec 11, 2019. It is now read-only.

Commit

Permalink
Clicking on something other than the table will clear any selections
Browse files Browse the repository at this point in the history
Fixes #5458

Auditors: @darkdh

Test Plan:
1. Launch Brave and go to about:history
2. Select a few items (from multiple tables if possible)
3. Click one of the headers to sort; notice selection is not changed.
4. Click the search box (like you want to give it focus) and notice how selection is cleared.
  • Loading branch information
bsclifton committed Nov 10, 2016
1 parent 67099bd commit 4571607
Show file tree
Hide file tree
Showing 3 changed files with 69 additions and 9 deletions.
4 changes: 2 additions & 2 deletions js/about/bookmarks.js
Original file line number Diff line number Diff line change
Expand Up @@ -435,7 +435,7 @@ class AboutBookmarks extends React.Component {
this.refs.bookmarkSearch.focus()
}
render () {
return <div className='siteDetailsPage'>
return <div className='siteDetailsPage' onClick={this.onClick}>
<div className='siteDetailsPageHeader'>
<div data-l10n-id='bookmarkManager' className='sectionTitle' />
<div className='headerActions'>
Expand All @@ -450,7 +450,7 @@ class AboutBookmarks extends React.Component {
</div>
</div>

<div className='siteDetailsPageContent' onClick={this.onClick}>
<div className='siteDetailsPageContent'>
<div className='folderView'>
<div className='columnHeader'>
<span data-l10n-id='folders' />
Expand Down
52 changes: 45 additions & 7 deletions js/about/history.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,14 +31,12 @@ class DeleteHistoryEntryButton extends ImmutableComponent {
super()
this.onClick = this.onClick.bind(this)
}

onClick (e) {
if (e && e.preventDefault) {
e.preventDefault()
}
// TODO(bsclifton): delete the selected entry
}

render () {
return <div className='fa fa-times deleteEntry' onClick={this.onClick} />
}
Expand All @@ -58,6 +56,13 @@ class HistoryTimeCell extends ImmutableComponent {
}

class HistoryDay extends ImmutableComponent {
constructor () {
super()
this.clearSelection = this.clearSelection.bind(this)
}
clearSelection () {
this.refs.historyTable.clearSelection()
}
navigate (entry) {
entry = makeImmutable(entry)
aboutActions.newFrame({
Expand All @@ -69,6 +74,7 @@ class HistoryDay extends ImmutableComponent {
return <div>
<div className='sectionTitle historyDayName'>{this.props.date}</div>
<SortableTable headings={['time', 'title', 'domain']}
ref='historyTable'
defaultHeading='time'
defaultHeadingSortOrder='desc'
rows={this.props.entries.map((entry) => [
Expand Down Expand Up @@ -96,22 +102,35 @@ class HistoryDay extends ImmutableComponent {
}

class GroupedHistoryList extends ImmutableComponent {
constructor () {
super()
this.entriesByDay = []
this.clearSelection = this.clearSelection.bind(this)
}
clearSelection () {
this.entriesByDay.forEach((day) => day.clearSelection())
}
render () {
const defaultLanguage = this.props.languageCodes.find((lang) => lang.includes(navigator.language)) || 'en-US'
const userLanguage = getSetting(settings.LANGUAGE, this.props.settings) || defaultLanguage
const entriesByDay = historyUtil.groupEntriesByDay(this.props.history, userLanguage)
const totalEntries = historyUtil.totalEntries(entriesByDay)
let index = 0
this.entriesByDay = []
return <list className='historyList'>
{
entriesByDay.map((groupedEntry) =>
<HistoryDay
entriesByDay.map((groupedEntry) => {
const day = <HistoryDay
ref={'historyDay' + index}
date={groupedEntry.get('date')}
entries={groupedEntry.get('entries')}
totalEntries={totalEntries}
tableID={index++}
tableID={index}
stateOwner={this.props.stateOwner}
/>)
/>
this.entriesByDay.push(this.refs[('historyDay' + index++)])
return day
})
}
</list>
}
Expand All @@ -123,6 +142,8 @@ class AboutHistory extends React.Component {
this.onChangeSearch = this.onChangeSearch.bind(this)
this.onClearSearchText = this.onClearSearchText.bind(this)
this.clearBrowsingDataNow = this.clearBrowsingDataNow.bind(this)
this.clearSelection = this.clearSelection.bind(this)
this.onClick = this.onClick.bind(this)
this.state = {
history: Immutable.List(),
search: '',
Expand Down Expand Up @@ -150,6 +171,19 @@ class AboutHistory extends React.Component {
search: ''
})
}
onClick (e) {
// Determine if click was on sortableTable
let targetElement = e.target
while (targetElement) {
if (targetElement.tagName === 'TBODY' || targetElement.tagName === 'THEAD') {
return
}
targetElement = targetElement.parentNode
}

// Click was not a child element of sortableTable; clear selection
this.clearSelection()
}
searchedSiteDetails (searchTerm, siteDetails) {
return siteDetails.filter((siteDetail) => {
const title = siteDetail.get('title') + siteDetail.get('location')
Expand All @@ -164,11 +198,14 @@ class AboutHistory extends React.Component {
clearBrowsingDataNow () {
aboutActions.clearBrowsingDataNow({browserHistory: true})
}
clearSelection () {
this.refs.historyList.clearSelection()
}
componentDidMount () {
this.refs.historySearch.focus()
}
render () {
return <div className='siteDetailsPage'>
return <div className='siteDetailsPage' onClick={this.onClick}>
<div className='siteDetailsPageHeader'>
<div data-l10n-id='history' className='sectionTitle' />
<div className='headerActions'>
Expand All @@ -186,6 +223,7 @@ class AboutHistory extends React.Component {

<div className='siteDetailsPageContent'>
<GroupedHistoryList
ref='historyList'
languageCodes={this.state.languageCodes}
settings={this.state.settings}
history={
Expand Down
22 changes: 22 additions & 0 deletions test/about/historyTest.js
Original file line number Diff line number Diff line change
Expand Up @@ -168,5 +168,27 @@ describe('about:history', function () {
.keys(Brave.keys.SHIFT)
.click('table.sortableTable td.title[data-sort="Brave"]')
})
it('deselects everything if something other than the table is clicked', function * () {
yield this.app.client
.tabByUrl(aboutHistoryUrl)
.loadUrl(aboutHistoryUrl)
// Click one bookmark, to select it
.click('table.sortableTable td.title[data-sort="Brave"]')
.waitForVisible('table.sortableTable tr.selected td.title[data-sort="Brave"]')
// Click the search box; this should dismiss and release selection
.click('input#historySearch')
.waitForVisible('table.sortableTable tr.selected td.title[data-sort="Brave"]', 5000, true)
})
it('does not lose selection if table is sorted', function * () {
yield this.app.client
.tabByUrl(aboutHistoryUrl)
.loadUrl(aboutHistoryUrl)
// Click one bookmark, to select it
.click('table.sortableTable td.title[data-sort="Brave"]')
.waitForVisible('table.sortableTable tr.selected td.title[data-sort="Brave"]')
// Click the "title" header; this sort the rows (but keep selection)
.click('table.sortableTable th')
.waitForVisible('table.sortableTable tr.selected td.title[data-sort="Brave"]')
})
})
})

0 comments on commit 4571607

Please sign in to comment.