112 lines
3.3 KiB
JavaScript
112 lines
3.3 KiB
JavaScript
import React from 'react'
|
|
import ReactDOM from 'react-dom'
|
|
|
|
import {Picker, Emoji} from '../src'
|
|
|
|
class Example extends React.Component {
|
|
constructor(props) {
|
|
super(props)
|
|
this.state = {
|
|
emojiSize: 24,
|
|
perLine: 9,
|
|
skin: 1,
|
|
set: 'apple',
|
|
hidden: false,
|
|
}
|
|
}
|
|
|
|
handleInput(e) {
|
|
var { currentTarget } = e,
|
|
{ value } = currentTarget,
|
|
key = currentTarget.getAttribute('data-key'),
|
|
state = {}
|
|
|
|
state[key] = parseInt(value)
|
|
this.setState(state)
|
|
}
|
|
|
|
render() {
|
|
return <div>
|
|
<h1>Emoji Mart</h1>
|
|
|
|
<div className="row">
|
|
{['apple', 'google', 'twitter', 'emojione'].map((set) => {
|
|
var props = { disabled: set == this.state.set }
|
|
|
|
return <button
|
|
key={set}
|
|
value={set}
|
|
onClick={() => this.setState({ set: set })}
|
|
{...props}>
|
|
<Emoji
|
|
sheetURL={`https://npmcdn.com/emoji-mart@0.2.1/sheets/sheet_${set}_32.png`}
|
|
size={24}
|
|
emoji='grinning'
|
|
/>
|
|
</button>
|
|
})}
|
|
</div>
|
|
|
|
<div className="row">
|
|
<button
|
|
onClick={() => this.setState({ hidden: !this.state.hidden })}
|
|
>{this.state.hidden ? 'Mount' : 'Unmount'}</button>
|
|
</div>
|
|
|
|
<pre style={{
|
|
fontSize: 18,
|
|
display: 'inline-block',
|
|
verticalAlign: 'top',
|
|
margin: '1em',
|
|
width: '460px',
|
|
}}>
|
|
<Operator>import</Operator> {Picker} <Operator>from</Operator> <String>'emoji-mart'</String>
|
|
<br />
|
|
<br /><Operator><</Operator><Variable>Picker</Variable>
|
|
<br /> emojiSize<Operator>=</Operator>{<Variable>{this.state.emojiSize}</Variable>} <input type='range' data-key='emojiSize' onChange={this.handleInput.bind(this)} min='16' max='64' value={this.state.emojiSize} />
|
|
<br /> perLine<Operator>=</Operator>{<Variable>{this.state.perLine}</Variable>} {this.state.perLine < 10 ? ' ' : ' '} <input type='range' data-key='perLine' onChange={this.handleInput.bind(this)} min='7' max='16' value={this.state.perLine} />
|
|
<br /> skin<Operator>=</Operator>{<Variable>{this.state.skin}</Variable>} <input type='range' data-key='skin' onChange={this.handleInput.bind(this)} min='1' max='6' value={this.state.skin} />
|
|
<br /> sheetURL<Operator>=</Operator><String>'sheets/sheet_{this.state.set}_64.png'</String>
|
|
<br /> onClick<Operator>=</Operator>{(<Variable>emoji</Variable>) => console.log(<Variable>emoji</Variable>)}
|
|
<br /><Operator>/></Operator>
|
|
</pre>
|
|
|
|
{!this.state.hidden &&
|
|
<Picker
|
|
emojiSize={this.state.emojiSize}
|
|
perLine={this.state.perLine}
|
|
skin={this.state.skin}
|
|
sheetURL={`https://npmcdn.com/emoji-mart@0.2.1/sheets/sheet_${this.state.set}_64.png`}
|
|
onClick={(emoji) => console.log(emoji)}
|
|
/>
|
|
}
|
|
</div>
|
|
}
|
|
}
|
|
|
|
class Operator extends React.Component {
|
|
render() {
|
|
return <span style={{color: '#a71d5d'}}>
|
|
{this.props.children}
|
|
</span>
|
|
}
|
|
}
|
|
|
|
class Variable extends React.Component {
|
|
render() {
|
|
return <span style={{color: '#0086b3'}}>
|
|
{this.props.children}
|
|
</span>
|
|
}
|
|
}
|
|
|
|
class String extends React.Component {
|
|
render() {
|
|
return <span style={{color: '#183691'}}>
|
|
{this.props.children}
|
|
</span>
|
|
}
|
|
}
|
|
|
|
ReactDOM.render(<Example />, document.querySelector('div'))
|