Merge pull request #26 from MarcoPolo/master

Allow a custom backgroundImageFn to be passed in
nolan/hinaloe-test
Etienne Lemay 2016-11-30 20:27:53 -05:00 committed by GitHub
commit b7761f6e32
6 changed files with 17 additions and 9 deletions

View File

@ -28,6 +28,7 @@ import { Picker } from 'emoji-mart'
| **i18n** | | [`{…}`](#i18n) | [An object](#i18n) containing localized strings | | **i18n** | | [`{…}`](#i18n) | [An object](#i18n) containing localized strings |
| **set** | | `apple` | The emoji set: `'apple', 'google', 'twitter', 'emojione'` | | **set** | | `apple` | The emoji set: `'apple', 'google', 'twitter', 'emojione'` |
| **sheetSize** | | `64` | The emoji [sheet size](#sheet-sizes): `16, 20, 32, 64` | | **sheetSize** | | `64` | The emoji [sheet size](#sheet-sizes): `16, 20, 32, 64` |
| **backgroundImageFn** | | ```((set, sheetSize) => `https://unpkg.com/emoji-datasource@2.4.4/sheet_${set}_${sheetSize}.png`)``` | A Fn that returns that image sheet to use for emojis. Useful for avoiding a request if you have the sheet locally. |
| **skin** | | `1` | Default skin color: `1, 2, 3, 4, 5, 6` | | **skin** | | `1` | Default skin color: `1, 2, 3, 4, 5, 6` |
| **style** | | | Inline styles applied to the root element. Useful for positioning | | **style** | | | Inline styles applied to the root element. Useful for positioning |
| **title** | | `Emoji Mart™` | The title shown when no emojis are hovered | | **title** | | `Emoji Mart™` | The title shown when no emojis are hovered |
@ -114,6 +115,7 @@ import { Emoji } from 'emoji-mart'
| **onOver** | | | Params: `(emoji, event) => {}` | | **onOver** | | | Params: `(emoji, event) => {}` |
| **set** | | `apple` | The emoji set: `'apple', 'google', 'twitter', 'emojione'` | | **set** | | `apple` | The emoji set: `'apple', 'google', 'twitter', 'emojione'` |
| **sheetSize** | | `64` | The emoji [sheet size](#sheet-sizes): `16, 20, 32, 64` | | **sheetSize** | | `64` | The emoji [sheet size](#sheet-sizes): `16, 20, 32, 64` |
| **backgroundImageFn** | | ```((set, sheetSize) => `https://unpkg.com/emoji-datasource@2.4.4/sheet_${set}_${sheetSize}.png`)``` | A Fn that returns that image sheet to use for emojis. Useful for avoiding a request if you have the sheet locally. |
| **skin** | | `1` | Skin color: `1, 2, 3, 4, 5, 6` | | **skin** | | `1` | Skin color: `1, 2, 3, 4, 5, 6` |
## Headless search ## Headless search

View File

@ -1,6 +1,6 @@
{ {
"name": "emoji-mart", "name": "emoji-mart",
"version": "0.3.3", "version": "0.3.4",
"description": "Customizable Slack-like emoji picker for React", "description": "Customizable Slack-like emoji picker for React",
"main": "dist/emoji-mart.js", "main": "dist/emoji-mart.js",
"repository": { "repository": {
@ -29,7 +29,7 @@
"babel-plugin-transform-object-rest-spread": "6.8.0", "babel-plugin-transform-object-rest-spread": "6.8.0",
"babel-preset-es2015": "6.6.0", "babel-preset-es2015": "6.6.0",
"babel-preset-react": "6.5.0", "babel-preset-react": "6.5.0",
"emoji-data": "git://github.com/iamcal/emoji-data.git#6daffc10d8e8fd06b80ec24c9bdcb65218f71563", "emoji-datasource": "2.4.4",
"emojilib": "2.0.2", "emojilib": "2.0.2",
"inflection": "1.10.0", "inflection": "1.10.0",
"mkdirp": "0.5.1", "mkdirp": "0.5.1",

View File

@ -1,5 +1,5 @@
var fs = require('fs'), var fs = require('fs'),
emojiData = require('emoji-data'), emojiData = require('emoji-datasource'),
emojiLib = require('emojilib'), emojiLib = require('emojilib'),
inflection = require('inflection'), inflection = require('inflection'),
mkdirp = require('mkdirp') mkdirp = require('mkdirp')

View File

@ -17,9 +17,9 @@ export default class Category extends React.Component {
shouldComponentUpdate(nextProps, nextState) { shouldComponentUpdate(nextProps, nextState) {
var { name, perLine, hasStickyPosition, emojis, emojiProps } = this.props, var { name, perLine, hasStickyPosition, emojis, emojiProps } = this.props,
{ skin, size, set } = emojiProps, { skin, size, set, backgroundImageFn } = emojiProps,
{ perLine: nextPerLine, hasStickyPosition: nextHasStickyPosition, emojis: nextEmojis, emojiProps: nextEmojiProps } = nextProps, { perLine: nextPerLine, hasStickyPosition: nextHasStickyPosition, emojis: nextEmojis, emojiProps: nextEmojiProps } = nextProps,
{ skin: nextSkin, size: nextSize, set: nextSet } = nextEmojiProps, { skin: nextSkin, size: nextSize, set: nextSet, backgroundImageFn: nextBackgroundImageFn } = nextEmojiProps,
shouldUpdate = false shouldUpdate = false
if (name == 'Recent' && perLine != nextPerLine) { if (name == 'Recent' && perLine != nextPerLine) {
@ -30,7 +30,7 @@ export default class Category extends React.Component {
shouldUpdate = !(emojis == nextEmojis) shouldUpdate = !(emojis == nextEmojis)
} }
if (skin != nextSkin || size != nextSize || set != nextSet || hasStickyPosition != nextHasStickyPosition) { if (skin != nextSkin || size != nextSize || set != nextSet || hasStickyPosition != nextHasStickyPosition || backgroundImageFn != nextBackgroundImageFn) {
shouldUpdate = true shouldUpdate = true
} }

View File

@ -59,7 +59,7 @@ export default class Emoji extends React.Component {
} }
render() { render() {
var { set, size, sheetSize, native, onOver, onLeave } = this.props, var { set, size, sheetSize, native, onOver, onLeave, backgroundImageFn } = this.props,
{ unified } = this.getData(), { unified } = this.getData(),
style = {}, style = {},
children = null children = null
@ -76,7 +76,7 @@ export default class Emoji extends React.Component {
width: size, width: size,
height: size, height: size,
display: 'inline-block', display: 'inline-block',
backgroundImage: `url(https://unpkg.com/emoji-datasource@2.4.4/sheet_${set}_${sheetSize}.png)`, backgroundImage: `url(${backgroundImageFn(set, sheetSize)})`,
backgroundSize: `${100 * SHEET_COLUMNS}%`, backgroundSize: `${100 * SHEET_COLUMNS}%`,
backgroundPosition: this.getPosition(), backgroundPosition: this.getPosition(),
} }
@ -96,6 +96,7 @@ Emoji.propTypes = {
onOver: React.PropTypes.func, onOver: React.PropTypes.func,
onLeave: React.PropTypes.func, onLeave: React.PropTypes.func,
onClick: React.PropTypes.func, onClick: React.PropTypes.func,
backgroundImageFn: React.PropTypes.func,
native: React.PropTypes.bool, native: React.PropTypes.bool,
skin: React.PropTypes.oneOf([1, 2, 3, 4, 5, 6]), skin: React.PropTypes.oneOf([1, 2, 3, 4, 5, 6]),
sheetSize: React.PropTypes.oneOf([16, 20, 32, 64]), sheetSize: React.PropTypes.oneOf([16, 20, 32, 64]),
@ -113,6 +114,7 @@ Emoji.defaultProps = {
sheetSize: 64, sheetSize: 64,
native: false, native: false,
onOver: (() => {}), onOver: (() => {}),
backgroundImageFn: ((set, sheetSize) => `https://unpkg.com/emoji-datasource@2.4.4/sheet_${set}_${sheetSize}.png`),
onLeave: (() => {}), onLeave: (() => {}),
onClick: (() => {}), onClick: (() => {}),
} }

View File

@ -238,7 +238,7 @@ export default class Picker extends React.Component {
} }
render() { render() {
var { perLine, emojiSize, set, sheetSize, style, title, emoji, color } = this.props, var { perLine, emojiSize, set, sheetSize, style, title, emoji, color, backgroundImageFn } = this.props,
{ skin } = this.state, { skin } = this.state,
width = (perLine * (emojiSize + 12)) + 12 + 2 width = (perLine * (emojiSize + 12)) + 12 + 2
@ -274,6 +274,7 @@ export default class Picker extends React.Component {
size: emojiSize, size: emojiSize,
set: set, set: set,
sheetSize: sheetSize, sheetSize: sheetSize,
backgroundImageFn: backgroundImageFn,
onOver: this.handleEmojiOver.bind(this), onOver: this.handleEmojiOver.bind(this),
onLeave: this.handleEmojiLeave.bind(this), onLeave: this.handleEmojiLeave.bind(this),
onClick: this.handleEmojiClick.bind(this), onClick: this.handleEmojiClick.bind(this),
@ -292,6 +293,7 @@ export default class Picker extends React.Component {
skin: skin, skin: skin,
set: set, set: set,
sheetSize: sheetSize, sheetSize: sheetSize,
backgroundImageFn: backgroundImageFn,
}} }}
skinsProps={{ skinsProps={{
skin: skin, skin: skin,
@ -313,6 +315,7 @@ Picker.propTypes = {
emoji: React.PropTypes.string, emoji: React.PropTypes.string,
color: React.PropTypes.string, color: React.PropTypes.string,
set: Emoji.propTypes.set, set: Emoji.propTypes.set,
backgroundImageFn: Emoji.propTypes.backgroundImageFn,
skin: Emoji.propTypes.skin, skin: Emoji.propTypes.skin,
sheetSize: Emoji.propTypes.sheetSize, sheetSize: Emoji.propTypes.sheetSize,
} }
@ -329,4 +332,5 @@ Picker.defaultProps = {
set: Emoji.defaultProps.set, set: Emoji.defaultProps.set,
skin: Emoji.defaultProps.skin, skin: Emoji.defaultProps.skin,
sheetSize: Emoji.defaultProps.sheetSize, sheetSize: Emoji.defaultProps.sheetSize,
backgroundImageFn: Emoji.defaultProps.backgroundImageFn,
} }