UNPKG

emoji-mart

Version:

Customizable Slack-like emoji picker for React

158 lines (135 loc) 6.62 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _react = _interopRequireDefault(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _utils = require("../utils"); var _nimbleEmoji = _interopRequireDefault(require("./emoji/nimble-emoji")); var _skinsEmoji = _interopRequireDefault(require("./skins-emoji")); var _skinsDot = _interopRequireDefault(require("./skins-dot")); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } var Preview = /*#__PURE__*/ function (_React$PureComponent) { (0, _inherits2["default"])(Preview, _React$PureComponent); function Preview(props) { var _this; (0, _classCallCheck2["default"])(this, Preview); _this = (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(Preview).call(this, props)); _this.data = props.data; _this.state = { emoji: null }; return _this; } (0, _createClass2["default"])(Preview, [{ key: "render", value: function render() { var emoji = this.state.emoji, _this$props = this.props, emojiProps = _this$props.emojiProps, skinsProps = _this$props.skinsProps, showSkinTones = _this$props.showSkinTones, title = _this$props.title, idleEmoji = _this$props.emoji, i18n = _this$props.i18n, showPreview = _this$props.showPreview; if (emoji && showPreview) { var emojiData = (0, _utils.getData)(emoji, null, null, this.data), _emojiData$emoticons = emojiData.emoticons, emoticons = _emojiData$emoticons === void 0 ? [] : _emojiData$emoticons, knownEmoticons = [], listedEmoticons = []; emoticons.forEach(function (emoticon) { if (knownEmoticons.indexOf(emoticon.toLowerCase()) >= 0) { return; } knownEmoticons.push(emoticon.toLowerCase()); listedEmoticons.push(emoticon); }); return _react["default"].createElement("div", { className: "emoji-mart-preview" }, _react["default"].createElement("div", { className: "emoji-mart-preview-emoji", "aria-hidden": "true" }, (0, _nimbleEmoji["default"])(_objectSpread({ key: emoji.id, emoji: emoji, data: this.data }, emojiProps))), _react["default"].createElement("div", { className: "emoji-mart-preview-data", "aria-hidden": "true" }, _react["default"].createElement("div", { className: "emoji-mart-preview-name" }, emoji.name), _react["default"].createElement("div", { className: "emoji-mart-preview-shortnames" }, emojiData.short_names.map(function (short_name) { return _react["default"].createElement("span", { key: short_name, className: "emoji-mart-preview-shortname" }, ":", short_name, ":"); })), _react["default"].createElement("div", { className: "emoji-mart-preview-emoticons" }, listedEmoticons.map(function (emoticon) { return _react["default"].createElement("span", { key: emoticon, className: "emoji-mart-preview-emoticon" }, emoticon); })))); } else { return _react["default"].createElement("div", { className: "emoji-mart-preview" }, _react["default"].createElement("div", { className: "emoji-mart-preview-emoji", "aria-hidden": "true" }, idleEmoji && idleEmoji.length && (0, _nimbleEmoji["default"])(_objectSpread({ emoji: idleEmoji, data: this.data }, emojiProps))), _react["default"].createElement("div", { className: "emoji-mart-preview-data", "aria-hidden": "true" }, _react["default"].createElement("span", { className: "emoji-mart-title-label" }, title)), showSkinTones && _react["default"].createElement("div", { className: "emoji-mart-preview-skins".concat(skinsProps.skinEmoji ? ' custom' : '') }, skinsProps.skinEmoji ? _react["default"].createElement(_skinsEmoji["default"], { skin: skinsProps.skin, emojiProps: emojiProps, data: this.data, skinEmoji: skinsProps.skinEmoji, i18n: i18n, onChange: skinsProps.onChange }) : _react["default"].createElement(_skinsDot["default"], { skin: skinsProps.skin, i18n: i18n, onChange: skinsProps.onChange }))); } } }]); return Preview; }(_react["default"].PureComponent); exports["default"] = Preview; Preview.propTypes /* remove-proptypes */ = { showSkinTones: _propTypes["default"].bool, title: _propTypes["default"].string.isRequired, emoji: _propTypes["default"].string.isRequired, emojiProps: _propTypes["default"].object.isRequired, skinsProps: _propTypes["default"].object.isRequired }; Preview.defaultProps = { showSkinTones: true, onChange: function onChange() {} };