1
0
mirror of https://github.com/BoostIo/Boostnote synced 2025-12-13 01:36:22 +00:00

feature tag search

This commit is contained in:
Sosuke Suzuki
2017-09-30 16:59:03 +09:00
parent ad0ac19d3d
commit faede48217
3 changed files with 17 additions and 9 deletions

View File

@@ -12,8 +12,8 @@ import CSSModules from 'browser/lib/CSSModules'
const TagListItem = (({name, handleClickTagButton}) => {
return (
<button onClick={handleClickTagButton}>
{name}
<button onClick={(e) => handleClickTagButton(e, name)}>
{`# ${name}`}
</button>
)
})

View File

@@ -229,7 +229,7 @@ class NoteList extends React.Component {
let { data, params, location } = this.props
let { router } = this.context
if (location.pathname.match(/\/home/)) {
if (location.pathname.match(/\/home/) || location.pathname.match(/\alltags/)) {
const allNotes = data.noteMap.map((note) => note)
this.contextNotes = allNotes
return allNotes
@@ -255,6 +255,14 @@ class NoteList extends React.Component {
return trashedNotes
}
if (location.pathname.match(/\/tags/)) {
return data.noteMap.map(note => {
return note
}).filter(note => {
return note.tags.includes(params.tagname)
})
}
return this.getContextNotes()
}
@@ -454,7 +462,6 @@ class NoteList extends React.Component {
}
render () {
console.log(this.props)
let { location, notes, config, dispatch } = this.props
let sortFunc = config.sortBy === 'CREATED_AT'
? sortByCreatedAt

View File

@@ -53,7 +53,6 @@ class SideNav extends React.Component {
SideNavComponent (isFolded, isHomeActive, isStarredActive, isTrashedActive, storageList) {
let { location, data } = this.props
console.log(data)
let component
if (!location.pathname.match('/tags') && !location.pathname.match('/alltags')) {
component = (
@@ -85,12 +84,12 @@ class SideNav extends React.Component {
)
} else {
let tagList = data.tagNoteMap.map((tag, key) => {
return `# ${key}`
return key
})
component = (
tagList.map(tag => {
return (
<TagListItem name={tag} handleClickTagButton={(e) => this.handleClickTagButton(e)} />
<TagListItem name={tag} handleClickTagButton={this.handleClickTagButton.bind(this)} />
)
})
)
@@ -99,8 +98,10 @@ class SideNav extends React.Component {
return component
}
handleClickTagButton (e) {
console.log('TAGBUTTON!!!')
handleClickTagButton (e, name) {
console.log(name)
let { router } = this.context
router.push(`/tags/${name}`)
}
render () {