diff options
author | Samy Pessé <samypesse@gmail.com> | 2016-12-22 10:18:38 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-12-22 10:18:38 +0100 |
commit | 194ebc3da9641ff96f083f9d8ab43c2d27944f9a (patch) | |
tree | c50988f32ccf18df93ae7ab40be78e9459642818 /packages/gitbook-plugin-search/src/components/Results.js | |
parent | 64ccb6b00b4b63fa0e516d4e35351275b34f8c07 (diff) | |
parent | 16af264360e48e8a833e9efa9ab8d194574dbc70 (diff) | |
download | gitbook-194ebc3da9641ff96f083f9d8ab43c2d27944f9a.zip gitbook-194ebc3da9641ff96f083f9d8ab43c2d27944f9a.tar.gz gitbook-194ebc3da9641ff96f083f9d8ab43c2d27944f9a.tar.bz2 |
Merge pull request #1543 from GitbookIO/dream
React for rendering website with plugins
Diffstat (limited to 'packages/gitbook-plugin-search/src/components/Results.js')
-rw-r--r-- | packages/gitbook-plugin-search/src/components/Results.js | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/packages/gitbook-plugin-search/src/components/Results.js b/packages/gitbook-plugin-search/src/components/Results.js new file mode 100644 index 0000000..16a8cbd --- /dev/null +++ b/packages/gitbook-plugin-search/src/components/Results.js @@ -0,0 +1,80 @@ +const GitBook = require('gitbook-core'); +const { React } = GitBook; +const Highlight = require('react-highlighter'); + +const MAX_DESCRIPTION_SIZE = 500; + +const Result = React.createClass({ + propTypes: { + result: React.PropTypes.object, + query: React.PropTypes.string + }, + + render() { + const { result, query } = this.props; + + let summary = result.body.trim(); + if (summary.length > MAX_DESCRIPTION_SIZE) { + summary = summary.slice(0, MAX_DESCRIPTION_SIZE).trim() + '...'; + } + + return ( + <div className="Search-ResultContainer"> + <GitBook.InjectedComponent matching={{ role: 'search:result' }} props={{ result, query }}> + <div className="Search-Result"> + <h3> + <GitBook.Link to={result.url}>{result.title}</GitBook.Link> + </h3> + <p> + <Highlight + matchElement="span" + matchClass="Search-MatchSpan" + search={query}> + {summary} + </Highlight> + </p> + </div> + </GitBook.InjectedComponent> + </div> + ); + } +}); + +const SearchResults = React.createClass({ + propTypes: { + i18n: GitBook.PropTypes.I18n, + results: GitBook.PropTypes.list, + query: React.PropTypes.string, + children: React.PropTypes.node + }, + + render() { + const { i18n, query, results, children } = this.props; + + if (!query) { + return React.Children.only(children); + } + + return ( + <div className="Search-ResultsContainer"> + <GitBook.InjectedComponent matching={{ role: 'search:results' }} props={{ results, query }}> + <div className="Search-Results"> + <h1>{i18n.t('SEARCH_RESULTS_TITLE', { query, count: results.size })}</h1> + <div className="Search-Results"> + {results.map((result, i) => { + return <Result key={i} result={result} query={query} />; + })} + </div> + </div> + </GitBook.InjectedComponent> + </div> + ); + } +}); + +const mapStateToProps = (state) => { + const { results, query } = state.search; + return { results, query }; +}; + +module.exports = GitBook.connect(SearchResults, mapStateToProps); |