Release v0.1.2

exclude-unsupported-native-emojis v0.1.2
Etienne Lemay 2016-07-15 12:52:16 -04:00
parent b0893c39be
commit 1615fc1f34
2 changed files with 65 additions and 23 deletions

76
dist/emoji-picker.js vendored
View File

@ -3326,7 +3326,8 @@ return /******/ (function(modules) { // webpackBootstrap
_this.testStickyPosition(); _this.testStickyPosition();
_this.state = { _this.state = {
skin: _utils.store.get('skin') || props.skin skin: _utils.store.get('skin') || props.skin,
firstRender: true
}; };
return _this; return _this;
} }
@ -3338,12 +3339,29 @@ return /******/ (function(modules) { // webpackBootstrap
this.setState({ skin: props.skin }); this.setState({ skin: props.skin });
} }
} }
}, {
key: 'componentDidMount',
value: function componentDidMount() {
var _this2 = this;
if (this.state.firstRender) {
this.firstRenderTimeout = setTimeout(function () {
_this2.setState({ firstRender: false });
}, 60);
}
}
}, { }, {
key: 'componentDidUpdate', key: 'componentDidUpdate',
value: function componentDidUpdate() { value: function componentDidUpdate() {
this.updateCategoriesSize(); this.updateCategoriesSize();
this.handleScroll(); this.handleScroll();
} }
}, {
key: 'componentWillUnmount',
value: function componentWillUnmount() {
clearTimeout(this.leaveTimeout);
clearTimeout(this.firstRenderTimeout);
}
}, { }, {
key: 'testStickyPosition', key: 'testStickyPosition',
value: function testStickyPosition() { value: function testStickyPosition() {
@ -3367,10 +3385,10 @@ return /******/ (function(modules) { // webpackBootstrap
}, { }, {
key: 'handleEmojiLeave', key: 'handleEmojiLeave',
value: function handleEmojiLeave(emoji) { value: function handleEmojiLeave(emoji) {
var _this2 = this; var _this3 = this;
this.leaveTimeout = setTimeout(function () { this.leaveTimeout = setTimeout(function () {
var preview = _this2.refs.preview; var preview = _this3.refs.preview;
preview.setState({ emoji: null }); preview.setState({ emoji: null });
}, 16); }, 16);
@ -3378,7 +3396,7 @@ return /******/ (function(modules) { // webpackBootstrap
}, { }, {
key: 'handleEmojiClick', key: 'handleEmojiClick',
value: function handleEmojiClick(emoji) { value: function handleEmojiClick(emoji) {
var _this3 = this; var _this4 = this;
this.props.onClick(emoji); this.props.onClick(emoji);
_utils.frequently.add(emoji); _utils.frequently.add(emoji);
@ -3393,8 +3411,8 @@ return /******/ (function(modules) { // webpackBootstrap
component.memoizeSize(); component.memoizeSize();
if (maxMargin == component.maxMargin) return; if (maxMargin == component.maxMargin) return;
_this3.updateCategoriesSize(); _this4.updateCategoriesSize();
_this3.handleScrollPaint(); _this4.handleScrollPaint();
}); });
})(); })();
} }
@ -3412,6 +3430,10 @@ return /******/ (function(modules) { // webpackBootstrap
value: function handleScrollPaint() { value: function handleScrollPaint() {
this.waitingForPaint = false; this.waitingForPaint = false;
if (!this.refs.scroll) {
return;
}
var target = this.refs.scroll, var target = this.refs.scroll,
scrollTop = target.scrollTop, scrollTop = target.scrollTop,
scrollingDown = scrollTop > (this.scrollTop || 0), scrollingDown = scrollTop > (this.scrollTop || 0),
@ -3423,14 +3445,15 @@ return /******/ (function(modules) { // webpackBootstrap
category = CATEGORIES[ii], category = CATEGORIES[ii],
component = this.refs['category-' + ii]; component = this.refs['category-' + ii];
if (component) {
var active = component.handleScroll(scrollTop);
if (!minTop || component.top < minTop) { if (!minTop || component.top < minTop) {
if (component.top > 0) { if (component.top > 0) {
minTop = component.top; minTop = component.top;
} }
} }
if (component) {
var active = component.handleScroll(scrollTop);
if (active && !activeCategory) { if (active && !activeCategory) {
if (category.anchor) category = category.anchor; if (category.anchor) category = category.anchor;
activeCategory = category; activeCategory = category;
@ -3520,16 +3543,25 @@ return /******/ (function(modules) { // webpackBootstrap
if (component) component.memoizeSize(); if (component) component.memoizeSize();
} }
} }
}, {
key: 'getCategories',
value: function getCategories() {
var categories = CATEGORIES;
return this.state.firstRender ? categories.slice(0, 3) : categories;
}
}, { }, {
key: 'render', key: 'render',
value: function render() { value: function render() {
var _this4 = this; var _this5 = this;
var _props = this.props; var _props = this.props;
var perLine = _props.perLine; var perLine = _props.perLine;
var emojiSize = _props.emojiSize; var emojiSize = _props.emojiSize;
var sheetURL = _props.sheetURL; var sheetURL = _props.sheetURL;
var style = _props.style; var style = _props.style;
var title = _props.title;
var emoji = _props.emoji;
var skin = this.state.skin; var skin = this.state.skin;
var width = perLine * (emojiSize + 12) + 12 + 2; var width = perLine * (emojiSize + 12) + 12 + 2;
@ -3552,21 +3584,21 @@ return /******/ (function(modules) { // webpackBootstrap
ref: 'search', ref: 'search',
onSearch: this.handleSearch.bind(this) onSearch: this.handleSearch.bind(this)
}), }),
CATEGORIES.map(function (category, i) { this.getCategories().map(function (category, i) {
return _react2.default.createElement(_.Category, { return _react2.default.createElement(_.Category, {
ref: 'category-' + i, ref: 'category-' + i,
key: category.name, key: category.name,
name: category.name, name: category.name,
emojis: category.emojis, emojis: category.emojis,
perLine: perLine, perLine: perLine,
hasStickyPosition: _this4.hasStickyPosition, hasStickyPosition: _this5.hasStickyPosition,
emojiProps: { emojiProps: {
skin: skin, skin: skin,
size: emojiSize, size: emojiSize,
sheetURL: sheetURL, sheetURL: sheetURL,
onOver: _this4.handleEmojiOver.bind(_this4), onOver: _this5.handleEmojiOver.bind(_this5),
onLeave: _this4.handleEmojiLeave.bind(_this4), onLeave: _this5.handleEmojiLeave.bind(_this5),
onClick: _this4.handleEmojiClick.bind(_this4) onClick: _this5.handleEmojiClick.bind(_this5)
} }
}); });
}) })
@ -3576,6 +3608,8 @@ return /******/ (function(modules) { // webpackBootstrap
{ className: 'emoji-picker-bar' }, { className: 'emoji-picker-bar' },
_react2.default.createElement(_.Preview, { _react2.default.createElement(_.Preview, {
ref: 'preview', ref: 'preview',
title: title,
emoji: emoji,
emojiProps: { emojiProps: {
size: 38, size: 38,
sheetURL: sheetURL sheetURL: sheetURL
@ -3602,6 +3636,8 @@ return /******/ (function(modules) { // webpackBootstrap
perLine: _react2.default.PropTypes.number, perLine: _react2.default.PropTypes.number,
emojiSize: _react2.default.PropTypes.number, emojiSize: _react2.default.PropTypes.number,
style: _react2.default.PropTypes.object, style: _react2.default.PropTypes.object,
title: _react2.default.PropTypes.string,
emoji: _react2.default.PropTypes.string,
sheetURL: _react2.default.PropTypes.string.isRequired sheetURL: _react2.default.PropTypes.string.isRequired
}; };
@ -3610,7 +3646,9 @@ return /******/ (function(modules) { // webpackBootstrap
emojiSize: 24, emojiSize: 24,
perLine: 9, perLine: 9,
style: {}, style: {},
skin: 1 skin: 1,
title: 'EmojiPicker',
emoji: 'tophat'
}; };
/***/ }, /***/ },
@ -3696,6 +3734,8 @@ return /******/ (function(modules) { // webpackBootstrap
var _props = this.props; var _props = this.props;
var emojiProps = _props.emojiProps; var emojiProps = _props.emojiProps;
var skinsProps = _props.skinsProps; var skinsProps = _props.skinsProps;
var title = _props.title;
var idleEmoji = _props.emoji;
if (emoji) { if (emoji) {
@ -3784,7 +3824,7 @@ return /******/ (function(modules) { // webpackBootstrap
'div', 'div',
{ className: 'emoji-picker-preview-emoji' }, { className: 'emoji-picker-preview-emoji' },
_react2.default.createElement(_.Emoji, _extends({ _react2.default.createElement(_.Emoji, _extends({
emoji: 'tophat' emoji: idleEmoji
}, emojiProps)) }, emojiProps))
), ),
_react2.default.createElement( _react2.default.createElement(
@ -3793,7 +3833,7 @@ return /******/ (function(modules) { // webpackBootstrap
_react2.default.createElement( _react2.default.createElement(
'span', 'span',
{ className: 'emoji-picker-title-label' }, { className: 'emoji-picker-title-label' },
'EmojiPicker' title
) )
), ),
_react2.default.createElement( _react2.default.createElement(
@ -3813,6 +3853,8 @@ return /******/ (function(modules) { // webpackBootstrap
Preview.propTypes = { Preview.propTypes = {
title: _react2.default.PropTypes.string.isRequired,
emoji: _react2.default.PropTypes.string.isRequired,
emojiProps: _react2.default.PropTypes.object.isRequired, emojiProps: _react2.default.PropTypes.object.isRequired,
skinsProps: _react2.default.PropTypes.object.isRequired skinsProps: _react2.default.PropTypes.object.isRequired
}; };

File diff suppressed because one or more lines are too long