diff --git a/css/emoji-picker.css b/css/emoji-picker.css index 9495154..f71c94d 100644 --- a/css/emoji-picker.css +++ b/css/emoji-picker.css @@ -27,7 +27,7 @@ .emoji-picker-scroll { overflow: scroll; - max-height: 270px; + height: 270px; padding: 0 6px 6px 6px; border: solid #d9d9d9; border-width: 1px 0; diff --git a/package.json b/package.json index 3097cc2..9fdcee6 100644 --- a/package.json +++ b/package.json @@ -18,7 +18,8 @@ "url": "https://github.com/missive/emoji-picker/issues" }, "homepage": "https://github.com/missive/emoji-picker", - "dependencies": {}, + "dependencies": { + }, "peerDependencies": { "react": "^0.14.0 || ^15.0.0-0" }, @@ -29,6 +30,7 @@ "babel-preset-react": "6.5.0", "emoji-data": "git://github.com/missive/emoji-data.git#01aeccb3adf6cdfaab6e13892f7688740047ff32", "inflection": "1.10.0", + "lunr": "0.7.1", "mkdirp": "0.5.1", "react": "0.14.7", "react-dom": "0.14.7", diff --git a/src/components/picker.js b/src/components/picker.js index 7c15870..bdceedd 100644 --- a/src/components/picker.js +++ b/src/components/picker.js @@ -3,9 +3,23 @@ import React from 'react' import data from '../../data' import Preview from './preview' import Category from './category' +import Search from './search' export default class Picker extends React.Component { - componentWillMount() { + constructor(props) { + super(props) + this.testStickyPosition() + + this.state = { + categories: data.categories, + } + } + + componentDidUpdate() { + this.handleScroll() + } + + testStickyPosition() { var stickyTestElement = document.createElement('div') for (let prefix of ['', '-webkit-', '-ms-', '-moz-', '-o-']) { stickyTestElement.style.position = `${prefix}sticky` @@ -14,10 +28,6 @@ export default class Picker extends React.Component { this.hasStickyPosition = !!stickyTestElement.style.position.length } - componentDidUpdate() { - this.handleScroll() - } - handleEmojiOver(emoji) { var { preview } = this.refs preview.setState({ emoji: emoji }) @@ -28,7 +38,7 @@ export default class Picker extends React.Component { scrollTop = target.scrollTop if (!this.hasStickyPosition) { - Array(data.categories.length).fill().forEach((_, i) => { + Array(this.state.categories.length).fill().forEach((_, i) => { var category = this.refs[`category-${i}`] if (category) { category.handleScroll(scrollTop) @@ -37,6 +47,17 @@ export default class Picker extends React.Component { } } + handleSearch(emojis) { + if (emojis == null) { + this.setState({ categories: data.categories }) + } else { + this.setState({ categories: [{ + name: 'Search Results', + emojis: emojis, + }]}) + } + } + render() { var { perLine, emojiSize, sheetURL } = this.props @@ -46,13 +67,11 @@ export default class Picker extends React.Component {
- - {data.categories.map((category, i) => { + {this.state.categories.map((category, i) => { if (category.name == 'Skins') return null return + result.ref + ) + } + + this.props.onSearch(results) + } + + render() { + return + } +} + +Search.propTypes = { + onSearch: React.PropTypes.func, +} + +Search.defaultProps = { + onSearch: (() => {}), +}