{"version":3,"file":"static/js/6262.d8f2014f.chunk.js","mappings":"gyCAAO,IAAMA,EAAQ,CACnBC,OAAQ,CACN,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,mDACA,mDACA,eACA,qEACA,qEACA,eACA,mDACA,qEACA,qEACA,qEACA,mDACA,mDACA,qEACA,qEACA,qEACA,mDACA,mDACA,qEACA,qEACA,qEACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,gBAEFC,OAAQ,CACN,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,gBAEF,iBAAkB,CAChB,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,gBAEFC,SAAU,CACR,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,gBAEF,oBAAqB,CACnB,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,UAEFC,QAAS,CACP,eACA,eACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,SACA,SACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,SACA,eACA,SACA,eACA,SACA,SACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,SACA,SACA,SACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,gBAEFC,QAAS,CACP,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,SACA,eACA,SACA,eACA,eACA,eACA,eACA,SACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,SACA,SACA,eACA,eACA,eACA,qBACA,eACA,eACA,qBACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,qBACA,qBACA,eACA,eACA,qBACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,SACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,eACA,eACA,eACA,qBACA,eACA,eACA,eACA,SACA,SACA,eACA,eACA,SACA,eACA,eACA,eACA,qBACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,qBACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,gBACA,gBACA,gBACA,gBACA,gBACA,gBACA,gBACA,gBACA,gBACA,gBACA,eACA,eACA,eACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,SACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,gBACA,gBACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,SACA,eACA,eACA,SACA,SACA,SACA,eACA,eACA,eACA,aACA,aACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,qBACA,eACA,eACA,eACA,eACA,eACA,iCACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,gBAEFC,MAAO,CACL,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,2BACA,6BCjxCSC,EAAU,SACrBC,EACAC,GAEA,YAHA,IAAAD,IAAAA,EAAU,IAGHA,EAAGE,QAAO,SAACC,EAASC,GAEzB,OADCD,EAAGC,EAAEH,IAAQE,EAAGC,EAAEH,KAAS,IAAII,KAAKD,GAC9BD,C,GACN,CAAC,EACL,ECRYG,EAAeC,IAAAA,eAAoB,GAEnCC,EAAW,kBAAMD,IAAAA,WAAiBD,EAAvB,E,oCCKXG,EAAQF,IAAAA,YACnB,SAAAG,EAAgDC,G,QAA7CC,WAAAA,OAAA,IAAAC,EAAa,CAAC,EAADA,EAAIC,EAAAJ,EAAAI,SAAUC,EAAAL,EAAAK,MAAUC,EAAAC,EAAAP,EAAAQ,GACtCC,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","sources":["../node_modules/@charkour/react-reactions/src/helpers/emoji.ts","../node_modules/@charkour/react-reactions/src/helpers/groupBy.ts","../node_modules/@charkour/react-reactions/src/helpers/useHover.ts","../node_modules/@charkour/react-reactions/src/helpers/Hover.tsx","../node_modules/@charkour/react-reactions/src/helpers/HoverStyle.tsx","../node_modules/@charkour/react-reactions/src/helpers/icons.ts","../node_modules/@charkour/react-reactions/src/helpers/slack.ts","../node_modules/@charkour/react-reactions/src/helpers/strings.ts","../node_modules/@charkour/react-reactions/src/helpers/withActive.tsx","../node_modules/@charkour/react-reactions/src/components/custom/ReactionBarSelectorEmoji.tsx","../node_modules/@charkour/react-reactions/src/components/custom/ReactionBarSelector.tsx","../node_modules/@charkour/react-reactions/src/components/custom/ReactionCounterEmoji.tsx","../node_modules/@charkour/react-reactions/src/components/custom/ReactionCounter.tsx","../node_modules/@charkour/react-reactions/src/components/facebook/FacebookCounterReaction.tsx","../node_modules/@charkour/react-reactions/src/components/facebook/FacebookCounter.tsx","../node_modules/@charkour/react-reactions/src/components/facebook/FacebookSelectorEmoji.tsx","../node_modules/@charkour/react-reactions/src/components/facebook/FacebookSelector.tsx","../node_modules/@charkour/react-reactions/src/components/github/GithubCounterGroup.tsx","../node_modules/@charkour/react-reactions/src/components/github/GithubCounter.tsx","../node_modules/@charkour/react-reactions/src/components/github/GithubSelectorEmoji.tsx","../node_modules/@charkour/react-reactions/src/components/github/GithubSelector.tsx","../node_modules/@charkour/react-reactions/src/components/pokemon/PokemonCounter.tsx","../node_modules/@charkour/react-reactions/src/components/pokemon/PokemonSelector.tsx","../node_modules/@charkour/react-reactions/src/components/slack/SlackCounterGroup.tsx","../node_modules/@charkour/react-reactions/src/components/slack/SlackCSS.tsx","../node_modules/@charkour/react-reactions/src/components/slack/SlackCounter.tsx","../node_modules/@charkour/react-reactions/src/components/slack/SlackSelectorSectionEmoji.tsx","../node_modules/@charkour/react-reactions/src/components/slack/SlackSelectorSection.tsx","../node_modules/@charkour/react-reactions/src/components/slack/SlackSelectorFooter.tsx","../node_modules/@charkour/react-reactions/src/components/slack/SlackSelectorHeaderTab.tsx","../node_modules/@charkour/react-reactions/src/components/slack/SlackSelectorHeader.tsx","../node_modules/@charkour/react-reactions/src/components/slack/SlackSelectorItems.tsx","../node_modules/@charkour/react-reactions/src/components/slack/SlackSelector.tsx","../node_modules/@charkour/react-reactions/src/components/youtube/YoutubeCounterButton.tsx","../node_modules/@charkour/react-reactions/src/components/youtube/YoutubeCounter.tsx","../node_modules/@charkour/react-reactions/src/index.ts"],"sourcesContent":["export const emoji = {\n people: [\n '😀',\n '😬',\n 'ðŸ˜',\n '😂',\n '😃',\n '😄',\n '😅',\n '😆',\n '😇',\n '😉',\n '😊',\n '🙂',\n '🙃',\n '☺ï¸',\n '😋',\n '😌',\n 'ðŸ˜',\n '😘',\n '😗',\n '😙',\n '😚',\n '😜',\n 'ðŸ˜',\n '😛',\n '🤑',\n '🤓',\n '😎',\n '🤗',\n 'ðŸ˜',\n '😶',\n 'ðŸ˜',\n '😑',\n '😒',\n '🙄',\n '🤔',\n '😳',\n '😞',\n '😟',\n '😠',\n '😡',\n '😔',\n '😕',\n 'ðŸ™',\n '☹ï¸',\n '😣',\n '😖',\n '😫',\n '😩',\n '😤',\n '😮',\n '😱',\n '😨',\n '😰',\n '😯',\n '😦',\n '😧',\n '😢',\n '😥',\n '😪',\n '😓',\n 'ðŸ˜',\n '😵',\n '😲',\n 'ðŸ¤',\n '😷',\n '🤒',\n '🤕',\n '😴',\n '💤',\n '💩',\n '😈',\n '👿',\n '👹',\n '👺',\n '💀',\n '👻',\n '👽',\n '🤖',\n '😺',\n '😸',\n '😹',\n '😻',\n '😼',\n '😽',\n '🙀',\n '😿',\n '😾',\n '🙌',\n 'ðŸ‘',\n '👋',\n 'ðŸ‘',\n '👊',\n '✊',\n '✌ï¸',\n '👌',\n '✋',\n '💪',\n 'ðŸ™',\n 'â˜ï¸',\n '👆',\n '👇',\n '👈',\n '👉',\n '🖕',\n '🤘',\n '🖖',\n 'âœï¸',\n '💅',\n '👄',\n '👅',\n '👂',\n '👃',\n 'ðŸ‘',\n '👀',\n '👤',\n '🗣',\n '👶',\n '👦',\n '👧',\n '👨',\n '👩',\n '👱',\n '👴',\n '👵',\n '👲',\n '👳',\n '👮',\n '👷',\n '💂',\n '🕵',\n '🎅',\n '👼',\n '👸',\n '👰',\n '🚶',\n 'ðŸƒ',\n '💃',\n '👯',\n '👫',\n '👬',\n 'ðŸ‘',\n '🙇',\n 'ðŸ’',\n '🙅',\n '🙆',\n '🙋',\n '🙎',\n 'ðŸ™',\n '💇',\n '💆',\n '💑',\n '👩â€â¤ï¸â€ðŸ‘©',\n '👨â€â¤ï¸â€ðŸ‘¨',\n 'ðŸ’',\n '👩â€â¤ï¸â€ðŸ’‹â€ðŸ‘©',\n '👨â€â¤ï¸â€ðŸ’‹â€ðŸ‘¨',\n '👪',\n '👨â€ðŸ‘©â€ðŸ‘§',\n '👨â€ðŸ‘©â€ðŸ‘§â€ðŸ‘¦',\n '👨â€ðŸ‘©â€ðŸ‘¦â€ðŸ‘¦',\n '👨â€ðŸ‘©â€ðŸ‘§â€ðŸ‘§',\n '👩â€ðŸ‘©â€ðŸ‘¦',\n '👩â€ðŸ‘©â€ðŸ‘§',\n '👩â€ðŸ‘©â€ðŸ‘§â€ðŸ‘¦',\n '👩â€ðŸ‘©â€ðŸ‘¦â€ðŸ‘¦',\n '👩â€ðŸ‘©â€ðŸ‘§â€ðŸ‘§',\n '👨â€ðŸ‘¨â€ðŸ‘¦',\n '👨â€ðŸ‘¨â€ðŸ‘§',\n '👨â€ðŸ‘¨â€ðŸ‘§â€ðŸ‘¦',\n '👨â€ðŸ‘¨â€ðŸ‘¦â€ðŸ‘¦',\n '👨â€ðŸ‘¨â€ðŸ‘§â€ðŸ‘§',\n '👚',\n '👕',\n '👖',\n '👔',\n '👗',\n '👙',\n '👘',\n '💄',\n '💋',\n '👣',\n '👠',\n '👡',\n '👢',\n '👞',\n '👟',\n '👒',\n '🎩',\n '⛑',\n '🎓',\n '👑',\n '🎒',\n 'ðŸ‘',\n '👛',\n '👜',\n '💼',\n '👓',\n '🕶',\n 'ðŸ’',\n '🌂',\n ],\n nature: [\n 'ðŸ¶',\n 'ðŸ±',\n 'ðŸ',\n 'ðŸ¹',\n 'ðŸ°',\n 'ðŸ»',\n 'ðŸ¼',\n 'ðŸ¨',\n 'ðŸ¯',\n 'ðŸ¦',\n 'ðŸ®',\n 'ðŸ·',\n 'ðŸ½',\n 'ðŸ¸',\n 'ðŸ™',\n 'ðŸµ',\n '🙈',\n '🙉',\n '🙊',\n 'ðŸ’',\n 'ðŸ”',\n 'ðŸ§',\n 'ðŸ¦',\n 'ðŸ¤',\n 'ðŸ£',\n 'ðŸ¥',\n 'ðŸº',\n 'ðŸ—',\n 'ðŸ´',\n '🦄',\n 'ðŸ',\n 'ðŸ›',\n 'ðŸŒ',\n 'ðŸž',\n 'ðŸœ',\n '🕷',\n '🦂',\n '🦀',\n 'ðŸ',\n 'ðŸ¢',\n 'ðŸ ',\n 'ðŸŸ',\n 'ðŸ¡',\n 'ðŸ¬',\n 'ðŸ³',\n 'ðŸ‹',\n 'ðŸŠ',\n 'ðŸ†',\n 'ðŸ…',\n 'ðŸƒ',\n 'ðŸ‚',\n 'ðŸ„',\n 'ðŸª',\n 'ðŸ«',\n 'ðŸ˜',\n 'ðŸ',\n 'ðŸ',\n 'ðŸ‘',\n 'ðŸŽ',\n 'ðŸ–',\n 'ðŸ€',\n 'ðŸ',\n 'ðŸ“',\n '🦃',\n '🕊',\n 'ðŸ•',\n 'ðŸ©',\n 'ðŸˆ',\n 'ðŸ‡',\n 'ðŸ¿',\n 'ðŸ¾',\n 'ðŸ‰',\n 'ðŸ²',\n '🌵',\n '🎄',\n '🌲',\n '🌳',\n '🌴',\n '🌱',\n '🌿',\n '☘',\n 'ðŸ€',\n 'ðŸŽ',\n '🎋',\n 'ðŸƒ',\n 'ðŸ‚',\n 'ðŸ',\n '🌾',\n '🌺',\n '🌻',\n '🌹',\n '🌷',\n '🌼',\n '🌸',\n 'ðŸ’',\n 'ðŸ„',\n '🌰',\n '🎃',\n 'ðŸš',\n '🕸',\n '🌎',\n 'ðŸŒ',\n 'ðŸŒ',\n '🌕',\n '🌖',\n '🌗',\n '🌘',\n '🌑',\n '🌒',\n '🌓',\n '🌔',\n '🌚',\n 'ðŸŒ',\n '🌛',\n '🌜',\n '🌞',\n '🌙',\n 'âï¸',\n '🌟',\n '💫',\n '✨',\n '☄',\n '☀ï¸',\n '🌤',\n 'â›…ï¸',\n '🌥',\n '🌦',\n 'â˜ï¸',\n '🌧',\n '⛈',\n '🌩',\n 'âš¡ï¸',\n '🔥',\n '💥',\n 'â„ï¸',\n '🌨',\n '🔥',\n '💥',\n 'â„ï¸',\n '🌨',\n '☃ï¸',\n '⛄ï¸',\n '🌬',\n '💨',\n '🌪',\n '🌫',\n '☂ï¸',\n '☔ï¸',\n '💧',\n '💦',\n '🌊',\n ],\n 'food-and-drink': [\n 'ðŸ',\n 'ðŸŽ',\n 'ðŸ',\n 'ðŸŠ',\n 'ðŸ‹',\n 'ðŸŒ',\n 'ðŸ‰',\n 'ðŸ‡',\n 'ðŸ“',\n 'ðŸˆ',\n 'ðŸ’',\n 'ðŸ‘',\n 'ðŸ',\n 'ðŸ…',\n 'ðŸ†',\n '🌶',\n '🌽',\n 'ðŸ ',\n 'ðŸ¯',\n 'ðŸž',\n '🧀',\n 'ðŸ—',\n 'ðŸ–',\n 'ðŸ¤',\n 'ðŸ³',\n 'ðŸ”',\n 'ðŸŸ',\n 'ðŸŒ',\n 'ðŸ•',\n 'ðŸ',\n '🌮',\n '🌯',\n 'ðŸœ',\n 'ðŸ²',\n 'ðŸ¥',\n 'ðŸ£',\n 'ðŸ±',\n 'ðŸ›',\n 'ðŸ™',\n 'ðŸš',\n 'ðŸ˜',\n 'ðŸ¢',\n 'ðŸ¡',\n 'ðŸ§',\n 'ðŸ¨',\n 'ðŸ¦',\n 'ðŸ°',\n '🎂',\n 'ðŸ®',\n 'ðŸ¬',\n 'ðŸ',\n 'ðŸ«',\n 'ðŸ¿',\n 'ðŸ©',\n 'ðŸª',\n 'ðŸº',\n 'ðŸ»',\n 'ðŸ·',\n 'ðŸ¸',\n 'ðŸ¹',\n 'ðŸ¾',\n 'ðŸ¶',\n 'ðŸµ',\n '☕ï¸',\n 'ðŸ¼',\n 'ðŸ´',\n 'ðŸ½',\n ],\n activity: [\n 'âš½ï¸',\n 'ðŸ€',\n 'ðŸˆ',\n 'âš¾ï¸',\n '🎾',\n 'ðŸ',\n 'ðŸ‰',\n '🎱',\n '⛳ï¸',\n 'ðŸŒ',\n 'ðŸ“',\n 'ðŸ¸',\n 'ðŸ’',\n 'ðŸ‘',\n 'ðŸ',\n '🎿',\n 'â›·',\n 'ðŸ‚',\n '⛸',\n 'ðŸ¹',\n '🎣',\n '🚣',\n 'ðŸŠ',\n 'ðŸ„',\n '🛀',\n '⛹',\n 'ðŸ‹',\n '🚴',\n '🚵',\n 'ðŸ‡',\n '🕴',\n 'ðŸ†',\n '🎽',\n 'ðŸ…',\n '🎖',\n '🎗',\n 'ðŸµ',\n '🎫',\n '🎟',\n 'ðŸŽ',\n '🎨',\n '🎪',\n '🎤',\n '🎧',\n '🎼',\n '🎹',\n '🎷',\n '🎺',\n '🎸',\n '🎻',\n '🎬',\n '🎮',\n '👾',\n '🎯',\n '🎲',\n '🎰',\n '🎳',\n ],\n 'travel-and-places': [\n '🚗',\n '🚕',\n '🚙',\n '🚌',\n '🚎',\n 'ðŸŽ',\n '🚓',\n '🚑',\n '🚒',\n 'ðŸš',\n '🚚',\n '🚛',\n '🚜',\n 'ðŸ',\n '🚲',\n '🚨',\n '🚔',\n 'ðŸš',\n '🚘',\n '🚖',\n '🚡',\n '🚠',\n '🚟',\n '🚃',\n '🚋',\n 'ðŸš',\n '🚄',\n '🚅',\n '🚈',\n '🚞',\n '🚂',\n '🚆',\n '🚇',\n '🚊',\n '🚉',\n 'ðŸš',\n '🛩',\n '✈ï¸',\n '🛫',\n '🛬',\n '⛵ï¸',\n '🛥',\n '🚤',\n 'â›´',\n '🛳',\n '🚀',\n '🛰',\n '💺',\n 'âš“ï¸',\n '🚧',\n '⛽ï¸',\n 'ðŸš',\n '🚦',\n '🚥',\n 'ðŸ',\n '🚢',\n '🎡',\n '🎢',\n '🎠',\n 'ðŸ—',\n 'ðŸŒ',\n '🗼',\n 'ðŸ',\n '⛲ï¸',\n '🎑',\n 'â›°',\n 'ðŸ”',\n '🗻',\n '🌋',\n '🗾',\n 'ðŸ•',\n '⛺ï¸',\n 'ðŸž',\n '🛣',\n '🛤',\n '🌅',\n '🌄',\n 'ðŸœ',\n 'ðŸ–',\n 'ðŸ',\n '🌇',\n '🌆',\n 'ðŸ™',\n '🌃',\n '🌉',\n '🌌',\n '🌠',\n '🎇',\n '🎆',\n '🌈',\n 'ðŸ˜',\n 'ðŸ°',\n 'ðŸ¯',\n 'ðŸŸ',\n '🗽',\n 'ðŸ ',\n 'ðŸ¡',\n 'ðŸš',\n 'ðŸ¢',\n 'ðŸ¬',\n 'ðŸ£',\n 'ðŸ¤',\n 'ðŸ¥',\n 'ðŸ¦',\n 'ðŸ¨',\n 'ðŸª',\n 'ðŸ«',\n 'ðŸ©',\n '💒',\n 'ðŸ›',\n '⛪ï¸',\n '🕌',\n 'ðŸ•',\n '🕋',\n '⛩',\n ],\n objects: [\n '⌚ï¸',\n '📱',\n '📲',\n '💻',\n '⌨',\n '🖥',\n '🖨',\n '🖱',\n '🖲',\n '🕹',\n '🗜',\n '💽',\n '💾',\n '💿',\n '📀',\n '📼',\n '📷',\n '📸',\n '📹',\n '🎥',\n '📽',\n '🎞',\n '📞',\n '☎ï¸',\n '📟',\n '📠',\n '📺',\n '📻',\n '🎙',\n '🎚',\n '🎛',\n 'â±',\n 'â²',\n 'â°',\n '🕰',\n 'â³',\n '⌛ï¸',\n '📡',\n '🔋',\n '🔌',\n '💡',\n '🔦',\n '🕯',\n '🗑',\n '🛢',\n '💸',\n '💵',\n '💴',\n '💶',\n '💷',\n '💰',\n '💳',\n '💎',\n 'âš–',\n '🔧',\n '🔨',\n 'âš’',\n '🛠',\n 'â›',\n '🔩',\n 'âš™',\n '⛓',\n '🔫',\n '💣',\n '🔪',\n '🗡',\n 'âš”',\n '🛡',\n '🚬',\n '☠',\n 'âš°',\n 'âš±',\n 'ðŸº',\n '🔮',\n '📿',\n '💈',\n 'âš—',\n 'ðŸ”',\n '🔬',\n '🕳',\n '💊',\n '💉',\n '🌡',\n 'ðŸ·',\n '🔖',\n '🚽',\n '🚿',\n 'ðŸ›',\n '🔑',\n 'ðŸ—',\n '🛋',\n '🛌',\n 'ðŸ›',\n '🚪',\n '🛎',\n '🖼',\n '🗺',\n 'â›±',\n '🗿',\n 'ðŸ›',\n '🎈',\n 'ðŸŽ',\n '🎀',\n 'ðŸŽ',\n '🎊',\n '🎉',\n '🎎',\n 'ðŸŽ',\n '🎌',\n 'ðŸ®',\n '✉ï¸',\n '📩',\n '📨',\n '📧',\n '💌',\n '📮',\n '📪',\n '📫',\n '📬',\n 'ðŸ“',\n '📦',\n '📯',\n '📥',\n '📤',\n '📜',\n '📃',\n '📑',\n '📊',\n '📈',\n '📉',\n '📄',\n '📅',\n '📆',\n '🗓',\n '📇',\n '🗃',\n '🗳',\n '🗄',\n '📋',\n '🗒',\n 'ðŸ“',\n '📂',\n '🗂',\n '🗞',\n '📰',\n '📓',\n '📕',\n '📗',\n '📘',\n '📙',\n '📔',\n '📒',\n '📚',\n '📖',\n '🔗',\n '📎',\n '🖇',\n '✂ï¸',\n 'ðŸ“',\n 'ðŸ“',\n '📌',\n 'ðŸ“',\n '🚩',\n 'ðŸ³',\n 'ðŸ´',\n 'ðŸ”',\n '🔒',\n '🔓',\n 'ðŸ”',\n '🖊',\n '🖊',\n '🖋',\n '✒ï¸',\n 'ðŸ“',\n 'âœï¸',\n 'ðŸ–',\n '🖌',\n 'ðŸ”',\n '🔎',\n ],\n symbols: [\n 'â¤ï¸',\n '💛',\n '💙',\n '💜',\n '💔',\n 'â£ï¸',\n '💕',\n '💞',\n '💓',\n '💗',\n '💖',\n '💘',\n 'ðŸ’',\n '💟',\n '☮',\n 'âœï¸',\n '☪',\n '🕉',\n '☸',\n '✡ï¸',\n '🔯',\n '🕎',\n '☯ï¸',\n '☦',\n 'ðŸ›',\n '⛎',\n '♈ï¸',\n '♉ï¸',\n '♊ï¸',\n '♋ï¸',\n '♌ï¸',\n 'â™ï¸',\n '♎ï¸',\n 'â™ï¸',\n 'â™ï¸',\n '♑ï¸',\n 'â™’ï¸',\n '♓ï¸',\n '🆔',\n 'âš›',\n '🈳',\n '🈹',\n '☢',\n '☣',\n '📴',\n '📳',\n '🈶',\n '🈚ï¸',\n '🈸',\n '🈺',\n '🈷ï¸',\n '✴ï¸',\n '🆚',\n '🉑',\n '💮',\n 'ðŸ‰',\n '㊙ï¸',\n '㊗ï¸',\n '🈴',\n '🈵',\n '🈲',\n '🅰ï¸',\n '🅱ï¸',\n '🆎',\n '🆑',\n '🅾ï¸',\n '🆘',\n 'â›”ï¸',\n '📛',\n '🚫',\n 'âŒ',\n 'â•ï¸',\n '💢',\n '♨ï¸',\n '🚷',\n '🚯',\n '🚳',\n '🚱',\n '🔞',\n '📵',\n 'â—ï¸',\n 'â•',\n 'â“',\n 'â”',\n '‼ï¸',\n 'â‰ï¸',\n '💯',\n '🔅',\n '🔆',\n '🔱',\n 'âšœ',\n '〽ï¸',\n 'âš ï¸',\n '🚸',\n '🔰',\n 'â™»ï¸',\n '🈯ï¸',\n '💹',\n 'â‡ï¸',\n '✳ï¸',\n 'âŽ',\n '✅',\n '💠',\n '🌀',\n 'âž¿',\n 'ðŸŒ',\n 'â“‚ï¸',\n 'ðŸ§',\n '🈂ï¸',\n '🛂',\n '🛃',\n '🛄',\n '🛅',\n '♿ï¸',\n 'ðŸš',\n '🚾',\n '🅿ï¸',\n '🚰',\n '🚹',\n '🚺',\n '🚼',\n '🚻',\n '🚮',\n '🎦',\n '📶',\n 'ðŸˆ',\n '🆖',\n '🆗',\n '🆙',\n '🆒',\n '🆕',\n '🆓',\n '0ï¸âƒ£',\n '1ï¸âƒ£',\n '2ï¸âƒ£',\n '3ï¸âƒ£',\n '4ï¸âƒ£',\n '5ï¸âƒ£',\n '6ï¸âƒ£',\n '7ï¸âƒ£',\n '8ï¸âƒ£',\n '9ï¸âƒ£',\n '🔟',\n '🔢',\n 'â–¶ï¸',\n 'â¸',\n 'â¯',\n 'â¹',\n 'âº',\n 'â',\n 'â®',\n 'â©',\n 'âª',\n '🔀',\n 'ðŸ”',\n '🔂',\n 'â—€ï¸',\n '🔼',\n '🔽',\n 'â«',\n 'â¬',\n 'âž¡ï¸',\n '⬅ï¸',\n '⬆ï¸',\n '⬇ï¸',\n '↗ï¸',\n '↘ï¸',\n '↙ï¸',\n '↖ï¸',\n '↕ï¸',\n '↔ï¸',\n '🔄',\n '↪ï¸',\n '↩ï¸',\n '⤴ï¸',\n '⤵ï¸',\n '#ï¸âƒ£',\n '*ï¸âƒ£',\n 'ℹï¸',\n '🔤',\n '🔡',\n '🔠',\n '🔣',\n '🎵',\n '🎶',\n '〰ï¸',\n 'âž°',\n '✔ï¸',\n '🔃',\n 'âž•',\n 'âž–',\n 'âž—',\n '✖ï¸',\n '💲',\n '💱',\n '©ï¸',\n '®ï¸',\n 'â„¢ï¸',\n '🔚',\n '🔙',\n '🔛',\n 'ðŸ”',\n '🔜',\n '☑ï¸',\n '🔘',\n '⚪ï¸',\n 'âš«ï¸',\n '🔴',\n '🔵',\n '🔸',\n '🔹',\n '🔶',\n '🔷',\n '🔺',\n 'â–ªï¸',\n 'â–«ï¸',\n '⬛ï¸',\n '⬜ï¸',\n '🔻',\n 'â—¼ï¸',\n 'â—»ï¸',\n 'â—¾ï¸',\n 'â—½ï¸',\n '🔲',\n '🔳',\n '🔈',\n '🔉',\n '🔊',\n '🔇',\n '📣',\n '📢',\n '🔔',\n '🔕',\n 'ðŸƒ',\n '🀄ï¸',\n 'â™ ï¸',\n '♣ï¸',\n '♥ï¸',\n '♦ï¸',\n '🎴',\n 'ðŸ‘â€ðŸ—¨',\n 'ðŸ’',\n '🗯',\n '💬',\n 'ðŸ•',\n '🕑',\n '🕒',\n '🕓',\n '🕔',\n '🕕',\n '🕖',\n '🕗',\n '🕘',\n '🕙',\n '🕚',\n '🕛',\n '🕜',\n 'ðŸ•',\n '🕞',\n '🕟',\n '🕠',\n '🕡',\n '🕢',\n '🕣',\n '🕤',\n '🕥',\n '🕦',\n '🕧',\n ],\n flags: [\n '🇦🇫',\n '🇦🇽',\n '🇦🇱',\n '🇩🇿',\n '🇦🇸',\n '🇦🇩',\n '🇦🇴',\n '🇦🇮',\n '🇦🇶',\n '🇦🇬',\n '🇦🇷',\n '🇦🇲',\n '🇦🇼',\n '🇦🇺',\n '🇦🇹',\n '🇦🇿',\n '🇧🇸',\n '🇧ðŸ‡',\n '🇧🇩',\n '🇧🇧',\n '🇧🇾',\n '🇧🇪',\n '🇧🇿',\n '🇧🇯',\n '🇧🇲',\n '🇧🇹',\n '🇧🇴',\n '🇧🇶',\n '🇧🇦',\n '🇧🇼',\n '🇧🇷',\n '🇮🇴',\n '🇻🇬',\n '🇧🇳',\n '🇧🇬',\n '🇧🇫',\n '🇧🇮',\n '🇨🇻',\n '🇰ðŸ‡',\n '🇨🇲',\n '🇨🇦',\n '🇮🇨',\n '🇰🇾',\n '🇨🇫',\n '🇹🇩',\n '🇨🇱',\n '🇨🇳',\n '🇨🇽',\n '🇨🇨',\n '🇨🇴',\n '🇰🇲',\n '🇨🇬',\n '🇨🇩',\n '🇨🇰',\n '🇨🇷',\n 'ðŸ‡ðŸ‡·',\n '🇨🇺',\n '🇨🇼',\n '🇨🇾',\n '🇨🇿',\n '🇩🇰',\n '🇩🇯',\n '🇩🇲',\n '🇩🇴',\n '🇪🇨',\n '🇪🇬',\n '🇸🇻',\n '🇬🇶',\n '🇪🇷',\n '🇪🇪',\n '🇪🇹',\n '🇪🇺',\n '🇫🇰',\n '🇫🇴',\n '🇫🇯',\n '🇫🇮',\n '🇫🇷',\n '🇬🇫',\n '🇵🇫',\n '🇹🇫',\n '🇬🇦',\n '🇬🇲',\n '🇬🇪',\n '🇩🇪',\n '🇬ðŸ‡',\n '🇬🇮',\n '🇬🇷',\n '🇬🇱',\n '🇬🇩',\n '🇬🇵',\n '🇬🇺',\n '🇬🇹',\n '🇬🇬',\n '🇬🇳',\n '🇬🇼',\n '🇬🇾',\n 'ðŸ‡ðŸ‡¹',\n 'ðŸ‡ðŸ‡³',\n 'ðŸ‡ðŸ‡°',\n 'ðŸ‡ðŸ‡º',\n '🇮🇸',\n '🇮🇳',\n '🇮🇩',\n '🇮🇷',\n '🇮🇶',\n '🇮🇪',\n '🇮🇲',\n '🇮🇱',\n '🇮🇹',\n '🇨🇮',\n '🇯🇲',\n '🇯🇵',\n '🇯🇪',\n '🇯🇴',\n '🇰🇿',\n '🇰🇪',\n '🇰🇮',\n '🇽🇰',\n '🇰🇼',\n '🇰🇬',\n '🇱🇦',\n '🇱🇻',\n '🇱🇧',\n '🇱🇸',\n '🇱🇷',\n '🇱🇾',\n '🇱🇮',\n '🇱🇹',\n '🇱🇺',\n '🇲🇴',\n '🇲🇰',\n '🇲🇬',\n '🇲🇼',\n '🇲🇾',\n '🇲🇻',\n '🇲🇱',\n '🇲🇹',\n '🇲ðŸ‡',\n '🇲🇶',\n '🇲🇷',\n '🇲🇺',\n '🇾🇹',\n '🇲🇽',\n '🇫🇲',\n '🇲🇩',\n '🇲🇨',\n '🇲🇳',\n '🇲🇪',\n '🇲🇸',\n '🇲🇦',\n '🇲🇿',\n '🇲🇲',\n '🇳🇦',\n '🇳🇷',\n '🇳🇵',\n '🇳🇱',\n '🇳🇨',\n '🇳🇿',\n '🇳🇮',\n '🇳🇪',\n '🇳🇬',\n '🇳🇺',\n '🇳🇫',\n '🇲🇵',\n '🇰🇵',\n '🇳🇴',\n '🇴🇲',\n '🇵🇰',\n '🇵🇼',\n '🇵🇸',\n '🇵🇦',\n '🇵🇬',\n '🇵🇾',\n '🇵🇪',\n '🇵ðŸ‡',\n '🇵🇳',\n '🇵🇱',\n '🇵🇹',\n '🇵🇷',\n '🇶🇦',\n '🇷🇪',\n '🇷🇴',\n '🇷🇺',\n '🇷🇼',\n '🇧🇱',\n '🇸ðŸ‡',\n '🇰🇳',\n '🇱🇨',\n '🇵🇲',\n '🇻🇨',\n '🇼🇸',\n '🇸🇲',\n '🇸🇹',\n '🇸🇦',\n '🇸🇳',\n '🇷🇸',\n '🇸🇨',\n '🇸🇱',\n '🇸🇬',\n '🇸🇽',\n '🇸🇰',\n '🇸🇮',\n '🇸🇧',\n '🇸🇴',\n '🇿🇦',\n '🇬🇸',\n '🇰🇷',\n '🇸🇸',\n '🇪🇸',\n '🇱🇰',\n '🇸🇩',\n '🇸🇷',\n '🇸🇿',\n '🇸🇪',\n '🇨ðŸ‡',\n '🇸🇾',\n '🇹🇼',\n '🇹🇯',\n '🇹🇿',\n '🇹ðŸ‡',\n '🇹🇱',\n '🇹🇬',\n '🇹🇰',\n '🇹🇴',\n '🇹🇹',\n '🇹🇳',\n '🇹🇷',\n '🇹🇲',\n '🇹🇨',\n '🇹🇻',\n '🇺🇬',\n '🇺🇦',\n '🇦🇪',\n '🇬🇧',\n '🇺🇸',\n '🇻🇮',\n '🇺🇾',\n '🇺🇿',\n '🇻🇺',\n '🇻🇦',\n '🇻🇪',\n '🇻🇳',\n '🇼🇫',\n '🇪ðŸ‡',\n '🇾🇪',\n '🇿🇲',\n '🇿🇼',\n ],\n};\n\nexport default emoji;\n","// https://stackoverflow.com/a/34890276/9931154\n// https://stackoverflow.com/a/61400956/9931154\nexport const groupBy = <T extends object, U extends keyof T>(\n xs: T[] = [],\n key: U\n): { [key: string]: T[] } => {\n return xs.reduce((rv: any, x: T) => {\n (rv[x[key]] = rv[x[key]] || []).push(x);\n return rv;\n }, {});\n};\n","import React from 'react';\n\nexport const HoverContext = React.createContext(false);\n\nexport const useHover = () => React.useContext(HoverContext);\n","import React from 'react';\nimport { HoverContext } from './useHover';\n\ninterface HoverProps extends React.HTMLAttributes<HTMLDivElement> {\n hoverStyle?: React.CSSProperties;\n}\n\n// TODO: turn this into a HOC?\n// Wrapper that keeps track of weather or not the component is being hovered\nexport const Hover = React.forwardRef<HTMLDivElement, HoverProps>(\n ({ hoverStyle = {}, children, style, ...rest }, ref) => {\n const [isHovered, setHovered] = React.useState(false);\n\n return (\n <HoverContext.Provider value={isHovered}>\n <div\n ref={ref}\n onMouseEnter={() => setHovered(true)}\n onMouseLeave={() => setHovered(false)}\n {...rest}\n style={{ ...style, ...(isHovered ? hoverStyle : {}) }}\n >\n {children}\n </div>\n </HoverContext.Provider>\n );\n }\n);\n\nexport default Hover;\n","import React from 'react';\nimport { useHover } from './useHover';\n\ninterface HoverStyleProps extends React.HTMLAttributes<HTMLDivElement> {\n hoverStyle: React.CSSProperties;\n}\n\n// https://stackoverflow.com/a/65886428/9931154\nexport const HoverStyle: React.FC<HoverStyleProps> = ({\n style = {},\n hoverStyle,\n children,\n ...rest\n}) => {\n const isHovered = useHover();\n const calculatedStyle = { ...style, ...(isHovered ? hoverStyle : {}) };\n\n return (\n <div {...rest} style={calculatedStyle}>\n {children}\n </div>\n );\n};\n","type thing = { facebook: type2; pokemon: type2 };\n\ntype type2 = {\n like: string;\n love: string;\n haha: string;\n wow: string;\n sad: string;\n angry: string;\n};\n\nconst icons: thing = {\n facebook: {\n like:\n '',\n love:\n '',\n haha:\n '',\n wow:\n '',\n sad:\n '',\n angry:\n '',\n },\n pokemon: {\n like:\n '',\n love:\n '',\n haha:\n '',\n wow:\n '',\n sad:\n '',\n angry:\n '',\n },\n};\n\nexport default {\n find: (scope: string, name: string) => {\n return (\n (icons[scope as keyof thing] &&\n icons[scope as keyof thing][name as keyof type2]) ||\n 'n/a'\n );\n },\n};\n","export const emojiColors = [\n '#b7e887',\n '#b5e0fe',\n '#f9ef67',\n '#f3c1fd',\n '#ffe1ae',\n '#e0dfff',\n];\n\nexport const sectionSlugToName = (name: string): string => {\n const thing: { [key: string]: string } = {\n mine: 'Frequently Used',\n people: 'People',\n nature: 'Nature',\n 'food-and-drink': 'Food & Drink',\n activity: 'Activity',\n 'travel-and-places': 'Travel & Places',\n objects: 'Objects',\n symbols: 'Symbols',\n flags: 'Flags',\n };\n return thing[name];\n};\n","export function listOfNames(names: string[]) {\n return [names.slice(0, -1).join(', '), names.slice(-1)[0]].join(\n names.length < 2 ? '' : ' and '\n );\n}\n","import React from 'react';\n\n// HOC that keeps track of weather or not the component is being clicked.\n// https://stackoverflow.com/a/53453431/9931154\nexport const withActive = <T extends Record<string, any>>(\n Component: React.ElementType\n) => {\n return React.forwardRef<HTMLDivElement, T>((props, ref) => {\n const [active, setActive] = React.useState(false);\n\n const handleMouseDown = React.useCallback(() => {\n setActive(true);\n }, []);\n const handleMouseUp = React.useCallback(() => {\n setActive(false);\n }, []);\n\n return (\n <div ref={ref} onMouseDown={handleMouseDown} onMouseUp={handleMouseUp}>\n <Component {...props} active={active} />\n </div>\n );\n });\n};\n\nexport default withActive;\n","import React from 'react';\nimport { Hover, HoverStyle, Reaction } from '../../helpers';\n\nexport interface ReactionBarSelectorEmojiProps {\n reaction: Reaction;\n onSelect: (label: string) => void;\n}\n\nexport const ReactionBarSelectorEmoji = React.forwardRef<\n HTMLDivElement,\n ReactionBarSelectorEmojiProps\n>(({ reaction, onSelect }, ref) => {\n const { node, label, key } = reaction;\n\n const handleClick = () => {\n onSelect && onSelect(key ?? label);\n };\n\n return (\n <Hover ref={ref} style={wrapStyle}>\n <HoverStyle hoverStyle={labelStyleHover} style={labelStyle}>\n {label}\n </HoverStyle>\n <HoverStyle\n hoverStyle={iconStyleHover}\n style={iconStyle}\n onClick={handleClick}\n >\n {node}\n </HoverStyle>\n </Hover>\n );\n});\n\nconst wrapStyle: React.CSSProperties = {\n padding: '5px',\n position: 'relative',\n};\nconst labelStyleHover = {\n transform: 'translateX(-50%) translateY(-10px)',\n opacity: '1',\n};\nconst labelStyle: React.CSSProperties = {\n position: 'absolute',\n top: '-22px',\n background: 'rgba(0,0,0,.8)',\n borderRadius: '14px',\n color: '#fff',\n fontSize: '11px',\n padding: '4px 7px 3px',\n fontWeight: 'bold',\n textTransform: 'capitalize',\n left: '50%',\n transform: 'translateX(-50%)',\n transition: '200ms transform cubic-bezier(0.23, 1, 0.32, 1)',\n opacity: '0',\n fontFamily: 'sans-serif',\n};\nconst iconStyle = {\n transformOrigin: 'bottom',\n cursor: 'pointer',\n transition: '200ms transform cubic-bezier(0.23, 1, 0.32, 1)',\n};\nconst iconStyleHover = { transform: 'scale(1.3)' };\n\nexport default ReactionBarSelectorEmoji;\n","import React from 'react';\nimport { Reaction } from '../../helpers';\nimport ReactionBarSelectorEmoji from './ReactionBarSelectorEmoji';\n\nexport interface ReactionBarSelectorProps {\n iconSize?: number;\n reactions?: Reaction[];\n onSelect?: (key: string) => void;\n style?: React.CSSProperties;\n}\n\nexport const ReactionBarSelector = React.forwardRef<\n HTMLDivElement,\n ReactionBarSelectorProps\n>(\n (\n {\n iconSize = defaultProps.iconSize,\n reactions = defaultProps.reactions,\n onSelect = defaultProps.onSelect,\n style = defaultProps.style,\n },\n ref\n ) => {\n const emojiStyle = React.useMemo(() => {\n return {\n width: `${iconSize + 10}px`,\n height: `${iconSize + 10}px`,\n display: 'flex',\n alignItems: 'center',\n fontSize: iconSize,\n };\n }, [iconSize]);\n\n return (\n <div ref={ref} style={{ ...wrapStyle, ...style }}>\n {reactions.map((reaction: Reaction) => {\n return (\n <div style={emojiStyle} key={reaction.key ?? reaction.label}>\n <ReactionBarSelectorEmoji\n reaction={reaction}\n onSelect={onSelect}\n />\n </div>\n );\n })}\n </div>\n );\n }\n);\n\nexport const defaultProps: Required<ReactionBarSelectorProps> = {\n style: {},\n reactions: [\n { node: <div>ðŸ‘</div>, label: 'like', key: 'satisfaction' },\n { node: <div>â¤ï¸</div>, label: 'love', key: 'love' },\n { node: <div>😆</div>, label: 'haha', key: 'happy' },\n { node: <div>😮</div>, label: 'wow', key: 'surprise' },\n { node: <div>😢</div>, label: 'sad', key: 'sad' },\n { node: <div>😡</div>, label: 'angry', key: 'angry' },\n ],\n iconSize: 38,\n onSelect: (key: string) => {\n console.log(key);\n },\n};\n\nconst wrapStyle = {\n backgroundColor: '#fff',\n borderRadius: '50px',\n padding: '2px',\n boxShadow: '0 0 0 1px rgba(0, 0, 0, .05), 0 1px 2px rgba(0, 0, 0, .15)',\n display: 'flex',\n width: 'fit-content',\n};\n\nexport default ReactionBarSelector;\n","import React from 'react';\n\nexport interface ReactionCounterEmojiProps {\n node: JSX.Element;\n bg: string;\n iconSize: number;\n index: number;\n}\n\nexport const ReactionCounterEmoji = React.forwardRef<\n HTMLDivElement,\n ReactionCounterEmojiProps\n>(({ node, bg, iconSize, index }, ref) => {\n const emojiContainerStyle: React.CSSProperties = React.useMemo(() => {\n return {\n zIndex: index,\n position: 'relative',\n boxShadow: `0 0 0 2px ${bg}`,\n width: `${iconSize}px`,\n height: `${iconSize}px`,\n };\n }, [iconSize, index, bg]);\n\n const emojiStyle: React.CSSProperties = React.useMemo(() => {\n return {\n width: `${iconSize}px`,\n height: `${iconSize}px`,\n objectFit: 'contain',\n objectPosition: 'center center',\n };\n }, [iconSize]);\n\n return (\n <div ref={ref} style={emojiContainerStyle}>\n {React.cloneElement(node, {\n style: { ...emojiStyle, ...node.props.style },\n })}\n </div>\n );\n});\n\nexport default ReactionCounterEmoji;\n","import React from 'react';\nimport { groupBy, listOfNames, ReactionCounterObject } from '../../helpers';\nimport {\n ReactionCounterEmoji,\n ReactionCounterEmojiProps,\n} from './ReactionCounterEmoji';\n\nexport interface ReactionCounterProps\n extends Partial<Pick<ReactionCounterEmojiProps, 'iconSize' | 'bg'>> {\n reactions: ReactionCounterObject[];\n user?: string;\n important?: string[];\n showReactsOnly?: boolean;\n showTotalOnly?: boolean;\n showOthersAlways?: boolean;\n className?: string;\n onClick?: () => void;\n style?: React.CSSProperties;\n}\n\nexport const ReactionCounter = React.forwardRef<\n HTMLDivElement,\n ReactionCounterProps\n>(\n (\n {\n reactions,\n user,\n important,\n className,\n onClick,\n iconSize = 24,\n bg = '#FFF',\n showReactsOnly = false,\n showTotalOnly = false,\n showOthersAlways = true,\n style,\n },\n ref\n ) => {\n const groups = groupBy(reactions, 'label');\n const names = reactions.map(({ by }: ReactionCounterObject) => {\n return by;\n });\n\n const nameString = [];\n if (user && names.includes(user)) {\n nameString.push('You');\n }\n if (important?.length) {\n if (names.includes(important[0])) {\n nameString.push(important[0]);\n }\n if (names.includes(important[1])) {\n nameString.push(important[1]);\n }\n }\n const othersCount = names.length - nameString.length;\n if (showOthersAlways || othersCount > 0) {\n nameString.push(`${othersCount} other${othersCount === 1 ? '' : 's'}`);\n }\n\n const nameStyle: React.CSSProperties = React.useMemo(() => {\n return {\n fontSize: `${iconSize - 8}px`,\n marginLeft: '8px',\n };\n }, [iconSize]);\n\n return (\n <div\n ref={ref}\n style={{ ...counterStyle, ...style }}\n className={className}\n onClick={onClick}\n >\n {Object.keys(groups).map((reaction, i, reactions) => (\n <ReactionCounterEmoji\n key={i}\n bg={bg}\n iconSize={iconSize}\n index={reactions.length - i}\n node={groups[reaction][0].node}\n />\n ))}\n {!showReactsOnly ? (\n <div style={nameStyle}>\n {showTotalOnly ? names.length : listOfNames(nameString)}\n </div>\n ) : null}\n </div>\n );\n }\n);\n\nconst counterStyle = {\n display: 'flex',\n cursor: 'pointer',\n alignItems: 'center',\n};\n\nexport default ReactionCounter;\n","import React from 'react';\nimport icons from '../../helpers/icons';\n\nexport interface FacebookCounterReactionProps {\n reaction: string;\n bg: string;\n index: number;\n variant: 'facebook' | 'pokemon';\n}\n\nexport const FacebookCounterReaction = React.forwardRef<\n HTMLDivElement,\n FacebookCounterReactionProps\n>(({ reaction, bg, index, variant }, ref) => {\n const reactionStyle: React.CSSProperties = React.useMemo(() => {\n return {\n width: '16px',\n height: '16px',\n backgroundSize: '100% 100%',\n borderRadius: '8px',\n backgroundImage: `url(${icons.find(variant, reaction)})`,\n boxShadow: `0 0 0 2px ${bg}`,\n position: 'relative',\n zIndex: index,\n };\n }, [reaction, bg, index, variant]);\n\n return <div ref={ref} style={reactionStyle} />;\n});\n\nexport default FacebookCounterReaction;\n","import React from 'react';\nimport { CounterObject, groupBy, listOfNames } from '../../helpers';\nimport FacebookCounterReaction from './FacebookCounterReaction';\n\nexport interface FacebookCounterProps {\n counters?: CounterObject[];\n user?: string;\n important?: string[];\n onClick?: () => void;\n bg?: string;\n variant?: 'facebook' | 'pokemon';\n alwaysShowOthers?: boolean;\n}\n\nexport const FacebookCounter = React.forwardRef<\n HTMLDivElement,\n FacebookCounterProps\n>(\n (\n {\n counters = defaultProps.counters,\n user = defaultProps.user,\n important = defaultProps.important,\n onClick = defaultProps.onClick,\n bg = defaultProps.bg,\n variant = defaultProps.variant,\n alwaysShowOthers = defaultProps.alwaysShowOthers,\n },\n ref\n ) => {\n const groups = groupBy(counters, 'emoji');\n const names = counters.map(({ by }: CounterObject) => {\n return by;\n });\n\n const nameString = [];\n if (names.includes(user)) {\n nameString.push('You');\n }\n if (important?.length) {\n if (names.includes(important[0])) {\n nameString.push(important[0]);\n }\n if (names.includes(important[1])) {\n nameString.push(important[1]);\n }\n }\n const othersCount = names.length - nameString.length;\n if (alwaysShowOthers || othersCount > 0) {\n nameString.push(`${othersCount} other${othersCount === 1 ? '' : 's'}`);\n }\n\n return (\n <div ref={ref} style={counterStyle} onClick={onClick}>\n {Object.keys(groups).map((reaction, i, reactions) => {\n return (\n <FacebookCounterReaction\n key={i}\n reaction={reaction}\n index={reactions.length - i}\n bg={bg}\n variant={variant}\n />\n );\n })}\n <div style={nameStyle}>{listOfNames(nameString)}</div>\n </div>\n );\n }\n);\n\nexport const defaultProps: Required<FacebookCounterProps> = {\n important: [],\n bg: '#fff',\n variant: 'facebook',\n counters: [\n {\n emoji: 'like',\n by: 'Case Sandberg',\n },\n {\n emoji: 'like',\n by: 'Jon',\n },\n {\n emoji: 'haha',\n by: 'Charlie',\n },\n ],\n user: 'Charlie',\n onClick: () => {\n console.log('click');\n },\n alwaysShowOthers: false,\n};\n\nconst counterStyle = {\n display: 'flex',\n cursor: 'pointer',\n color: '#365899',\n fontFamily: `\"San Francisco\", -apple-system, BlinkMacSystemFont,\n \".SFNSText-Regular\", sans-serif`,\n fontSize: '12px',\n fontWeight: 500,\n};\nconst nameStyle = {\n paddingLeft: '4px',\n marginTop: '2px',\n};\n\nexport default FacebookCounter;\n","import React from 'react';\nimport { Hover, HoverStyle, withActive } from '../../helpers';\n\nexport interface FacebookSelectorEmojiProps {\n icon: string;\n label: string;\n onSelect: (label: string) => void;\n}\n\nexport const FacebookSelectorEmoji = withActive<FacebookSelectorEmojiProps>(\n ({ icon, label, onSelect }) => {\n const iconStyle = React.useMemo(() => {\n return {\n paddingBottom: '100%',\n backgroundImage: `url(${icon})`,\n backgroundSize: '100% 100%',\n transformOrigin: 'bottom',\n cursor: 'pointer',\n transition: '200ms transform cubic-bezier(0.23, 1, 0.32, 1)',\n };\n }, [icon]);\n\n const handleClick = () => {\n onSelect && onSelect(label);\n };\n\n return (\n <Hover style={wrapStyle}>\n <HoverStyle hoverStyle={labelStyleHover} style={labelStyle}>\n {label}\n </HoverStyle>\n <HoverStyle\n hoverStyle={iconStyleHover}\n style={iconStyle}\n onClick={handleClick}\n />\n </Hover>\n );\n }\n);\n\nconst wrapStyle: React.CSSProperties = {\n padding: '5px',\n position: 'relative',\n};\nconst labelStyleHover = {\n transform: 'translateX(-50%) translateY(-10px)',\n opacity: '1',\n};\nconst labelStyle: React.CSSProperties = {\n position: 'absolute',\n top: '-22px',\n background: 'rgba(0,0,0,.8)',\n borderRadius: '14px',\n color: '#fff',\n fontSize: '11px',\n padding: '4px 7px 3px',\n fontWeight: 'bold',\n textTransform: 'capitalize',\n left: '50%',\n transform: 'translateX(-50%)',\n transition: '200ms transform cubic-bezier(0.23, 1, 0.32, 1)',\n opacity: '0',\n};\nconst iconStyleHover = { transform: 'scale(1.3)' };\n\nexport default FacebookSelectorEmoji;\n","import React from 'react';\nimport { icons } from '../../helpers';\nimport FacebookSelectorEmoji from './FacebookSelectorEmoji';\n\n// TODO: use the custom reaction bar\nexport interface FacebookSelectorProps {\n iconSize?: number;\n reactions?: string[];\n variant?: 'facebook' | 'pokemon';\n onSelect?: (label: string) => void;\n}\n\nexport const FacebookSelector = React.forwardRef<\n HTMLDivElement,\n FacebookSelectorProps\n>(\n (\n {\n iconSize = defaultProps.iconSize,\n reactions = defaultProps.reactions,\n variant = defaultProps.variant,\n onSelect = defaultProps.onSelect,\n },\n ref\n ) => {\n const emojiStyle = React.useMemo(() => {\n return { width: `${iconSize + 10}px` };\n }, [iconSize]);\n\n return (\n <div ref={ref} style={wrapStyle}>\n {reactions.map((reaction: string) => {\n return (\n <div style={emojiStyle} key={reaction}>\n <FacebookSelectorEmoji\n icon={icons.find(variant, reaction)}\n label={reaction}\n onSelect={onSelect}\n />\n </div>\n );\n })}\n </div>\n );\n }\n);\n\nexport const defaultProps: Required<FacebookSelectorProps> = {\n reactions: ['like', 'love', 'haha', 'wow', 'sad', 'angry'],\n iconSize: 38,\n variant: 'facebook',\n onSelect: (label: string) => {\n console.log(label);\n },\n};\n\nconst wrapStyle = {\n backgroundColor: '#fff',\n borderRadius: '50px',\n padding: '2px',\n boxShadow: '0 0 0 1px rgba(0, 0, 0, .05), 0 1px 2px rgba(0, 0, 0, .15)',\n display: 'flex',\n};\n\nexport default FacebookSelector;\n","/* eslint-disable no-shadow */\n\nimport React from 'react';\nimport { Hover, HoverStyle } from '../../helpers';\nimport { listOfNames } from '../../helpers/strings';\n\nexport interface GithubCounterGroupProps {\n emoji: string;\n count: number;\n onSelect: (emoji: string) => void;\n names: string[];\n active: boolean;\n}\n\nexport const GithubCounterGroup = React.forwardRef<\n HTMLDivElement,\n GithubCounterGroupProps\n>(({ emoji, count, onSelect, names, active }, ref) => {\n const handleClick = () => {\n onSelect(emoji);\n };\n\n return (\n <Hover\n ref={ref}\n style={{ ...groupStyle, ...(active ? groupStyleActive : {}) }}\n onClick={handleClick}\n >\n <span style={emojiStyle}>{emoji}</span> {count}\n <HoverStyle hoverStyle={tooltipStyleHover} style={tooltipStyle}>\n {listOfNames(names)}\n </HoverStyle>\n </Hover>\n );\n});\n\nconst groupStyle: React.CSSProperties = {\n width: '35px',\n height: '20px',\n padding: '8px 15px',\n borderRight: '1px solid #ddd',\n fontFamily:\n '-apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica',\n fontSize: '14px',\n color: '#3D76C2',\n fontWeight: 500,\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n position: 'relative',\n cursor: 'pointer',\n borderRadius: '3px 0 0 3px',\n};\nconst groupStyleActive = {\n background: '#f2f8fa',\n};\nconst emojiStyle = {\n fontSize: '21px',\n marginTop: '1px',\n};\nconst tooltipStyle: React.CSSProperties = {\n maxWidth: '250px',\n wordBreak: 'break-word',\n wordWrap: 'normal',\n whiteSpace: 'nowrap',\n font: `normal normal 11px/1.5 -apple-system, BlinkMacSystemFont, \"Segoe UI\",\n Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\"`,\n color: '#fff',\n background: 'rgba(0,0,0,0.8)',\n borderRadius: '3px',\n padding: '5px 8px',\n position: 'absolute',\n top: '100%',\n left: '15px',\n marginTop: '4px',\n opacity: '0',\n transition: 'opacity 0.1s ease-in-out',\n};\nconst tooltipStyleHover = { opacity: '1' };\n\nexport default GithubCounterGroup;\n","import React from 'react';\nimport { CounterObject, groupBy, Hover, HoverStyle } from '../../helpers';\nimport GithubCounterGroup from './GithubCounterGroup';\n\nexport interface GithubCounterProps {\n counters?: CounterObject[];\n user?: string;\n onSelect?: (emoji: string) => void;\n onAdd?: () => void;\n}\n\nexport const GithubCounter = React.forwardRef<\n HTMLDivElement,\n GithubCounterProps\n>(\n (\n {\n counters = defaultProps.counters,\n user = defaultProps.user,\n onSelect = defaultProps.onSelect,\n onAdd = defaultProps.onAdd,\n },\n ref\n ) => {\n const groups = groupBy(counters, 'emoji');\n\n return (\n <Hover ref={ref} style={counterStyle}>\n {Object.keys(groups).map((emoji: string) => {\n const names = groups[emoji].map(({ by }: CounterObject) => {\n return by;\n });\n return (\n <GithubCounterGroup\n key={emoji}\n emoji={emoji}\n count={names.length}\n names={names}\n active={names.includes(user)}\n onSelect={onSelect}\n />\n );\n })}\n <HoverStyle hoverStyle={addStyleHover} style={addStyle} onClick={onAdd}>\n <svg height=\"16\" width=\"7\" viewBox=\"0 0 7 16\">\n <path d=\"M4 7V4H3v3H0v1h3v3h1V8h3V7H4z\"></path>\n </svg>\n <svg height=\"16\" width=\"16\" viewBox=\"0 0 16 16\">\n <path d=\"M8 0C3.58 0 0 3.58 0 8s3.58 8 8 8 8-3.58 8-8-3.58-8-8-8zm4.81 12.81a6.72 6.72 0 0 1-2.17 1.45c-.83.36-1.72.53-2.64.53-.92 0-1.81-.17-2.64-.53-.81-.34-1.55-.83-2.17-1.45a6.773 6.773 0 0 1-1.45-2.17A6.59 6.59 0 0 1 1.21 8c0-.92.17-1.81.53-2.64.34-.81.83-1.55 1.45-2.17.62-.62 1.36-1.11 2.17-1.45A6.59 6.59 0 0 1 8 1.21c.92 0 1.81.17 2.64.53.81.34 1.55.83 2.17 1.45.62.62 1.11 1.36 1.45 2.17.36.83.53 1.72.53 2.64 0 .92-.17 1.81-.53 2.64-.34.81-.83 1.55-1.45 2.17zM4 6.8v-.59c0-.66.53-1.19 1.2-1.19h.59c.66 0 1.19.53 1.19 1.19v.59c0 .67-.53 1.2-1.19 1.2H5.2C4.53 8 4 7.47 4 6.8zm5 0v-.59c0-.66.53-1.19 1.2-1.19h.59c.66 0 1.19.53 1.19 1.19v.59c0 .67-.53 1.2-1.19 1.2h-.59C9.53 8 9 7.47 9 6.8zm4 3.2c-.72 1.88-2.91 3-5 3s-4.28-1.13-5-3c-.14-.39.23-1 .66-1h8.59c.41 0 .89.61.75 1z\"></path>\n </svg>\n </HoverStyle>\n </Hover>\n );\n }\n);\n\nexport const defaultProps: Required<GithubCounterProps> = {\n counters: [\n {\n emoji: 'ðŸ‘',\n by: 'Case Sandberg',\n },\n {\n emoji: '👎',\n by: 'Charlie',\n },\n ],\n user: 'Charlie',\n onAdd: () => {\n console.log('add');\n },\n onSelect: (emoji: string) => {\n console.log(emoji);\n },\n};\n\nconst counterStyle = {\n height: '36px',\n border: '1px solid #ddd',\n borderRadius: '4px',\n display: 'flex',\n background: '#fff',\n};\nconst addStyle = {\n fill: '#4078c0',\n width: '25px',\n height: '20px',\n padding: '8px 15px',\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n cursor: 'pointer',\n opacity: '0',\n transition: 'opacity 0.1s ease-in-out',\n};\nconst addStyleHover = { opacity: '1' };\n\nexport default GithubCounter;\n","import React from 'react';\nimport { Hover, HoverStyle, withActive } from '../../helpers';\n\nexport interface GithubSelectorEmojiProps {\n onSelect: (shortCode: string) => void;\n shortCode: string;\n active?: boolean;\n}\n\nexport const GithubSelectorEmoji = withActive<GithubSelectorEmojiProps>(\n ({ onSelect, shortCode, active = false }) => {\n const handleClick = () => {\n onSelect(shortCode);\n };\n\n return (\n <Hover\n style={{ ...wrapStyle, ...(active ? wrapStyleActive : {}) }}\n onClick={handleClick}\n >\n <HoverStyle hoverStyle={emojiStyleHover} style={emojiStyle}>\n {shortCode}\n </HoverStyle>\n </Hover>\n );\n }\n);\n\nconst wrapStyle = {\n padding: '8px 0',\n};\nconst emojiStyle: React.CSSProperties = {\n width: '34px',\n textAlign: 'center',\n lineHeight: '29px',\n fontSize: '21px',\n fontFamily:\n '\"Apple Color Emoji\", \"Segoe UI\", \"Segoe UI Emoji\", \"Segoe UI Symbol\"',\n cursor: 'pointer',\n\n transform: 'scale(1)',\n transition: 'transform 0.15s cubic-bezier(0.2, 0, 0.13, 2)',\n};\nconst emojiStyleHover = {\n transform: 'scale(1.2)',\n};\nconst wrapStyleActive = {\n backgroundColor: '#f2f8fa',\n};\n\nexport default GithubSelectorEmoji;\n","import React from 'react';\nimport GithubSelectorEmoji from './GithubSelectorEmoji';\n\nexport interface GithubSelectorProps {\n reactions?: string[];\n onSelect?: (shortCode: string) => void;\n}\n\nexport const GithubSelector = React.forwardRef<\n HTMLDivElement,\n GithubSelectorProps\n>(\n (\n { reactions = defaultProps.reactions, onSelect = defaultProps.onSelect },\n ref\n ) => {\n return (\n <div ref={ref} style={selectorStyle}>\n <p style={labelStyle}>Pick your reaction</p>\n <div style={dividerStyle} />\n <div style={emojiStyle}>\n {reactions.map((reaction: string) => {\n return (\n <GithubSelectorEmoji\n key={reaction}\n shortCode={reaction}\n onSelect={onSelect}\n />\n );\n })}\n </div>\n </div>\n );\n }\n);\n\nexport const defaultProps: Required<GithubSelectorProps> = {\n reactions: ['ðŸ‘', '👎', '😄', '🎉', '😕', 'â¤ï¸'],\n onSelect: (shortCode: string) => {\n console.log(shortCode);\n },\n};\n\nconst selectorStyle = {\n paddingTop: '5px',\n backgroundColor: '#fff',\n border: '1px solid rgba(0,0,0,0.15)',\n borderRadius: '4px',\n boxShadow: '0 3px 12px rgba(0,0,0,0.15)',\n display: 'inline-block',\n};\nconst labelStyle = {\n fontSize: '14px',\n lineHeight: '1.5',\n color: '#767676',\n margin: '6px 12px',\n fontFamily:\n '-apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica',\n};\nconst dividerStyle = {\n height: '1px',\n margin: '8px 1px 0px',\n backgroundColor: '#e5e5e5',\n};\nconst emojiStyle = {\n display: 'flex',\n margin: '0 6px',\n};\n\nexport default GithubSelector;\n","import React from 'react';\nimport FacebookCounter, {\n FacebookCounterProps,\n} from '../facebook/FacebookCounter';\n\nexport type PokemonCounterProps = Omit<FacebookCounterProps, 'variant'>;\n\nexport const PokemonCounter = React.forwardRef<\n HTMLDivElement,\n PokemonCounterProps\n>((props, ref) => {\n return <FacebookCounter ref={ref} {...props} variant=\"pokemon\" />;\n});\n\nexport default PokemonCounter;\n","import React from 'react';\nimport FacebookSelector, {\n defaultProps,\n FacebookSelectorProps,\n} from '../facebook/FacebookSelector';\n\nexport type PokemonSelectorProps = Omit<FacebookSelectorProps, 'variant'>;\n\nexport const PokemonSelector = React.forwardRef<\n HTMLDivElement,\n PokemonSelectorProps\n>(\n (\n {\n reactions = defaultProps.reactions,\n iconSize = defaultProps.iconSize,\n onSelect = defaultProps.onSelect,\n },\n ref\n ) => {\n return (\n <FacebookSelector\n ref={ref}\n reactions={reactions}\n variant=\"pokemon\"\n iconSize={iconSize}\n onSelect={onSelect}\n />\n );\n }\n);\n\nexport default PokemonSelector;\n","import React from 'react';\nimport { Hover, HoverStyle, listOfNames } from '../../helpers';\n\nexport interface SlackCounterGroupProps {\n hover?: boolean;\n onSelect?: (emoji: string) => void;\n emoji: string;\n count?: number;\n active?: boolean;\n names?: string[];\n}\nexport const SlackCounterGroup = React.forwardRef<\n HTMLDivElement,\n SlackCounterGroupProps\n>(({ onSelect, emoji, count, names, active }, ref) => {\n const handleClick = () => {\n onSelect && onSelect(emoji);\n };\n\n return (\n <Hover\n ref={ref}\n hoverStyle={groupStyleActive}\n style={{ ...groupStyle, ...(active ? groupStyleActive : {}) }}\n onClick={handleClick}\n >\n <span style={{ ...emojiStyle, ...(!names ? emojiStyleNoNames : {}) }}>\n {emoji}\n </span>{' '}\n {count}\n {names ? (\n <HoverStyle hoverStyle={tooltipStyleHover} style={tooltipStyle}>\n {listOfNames(names)}\n </HoverStyle>\n ) : null}\n </Hover>\n );\n});\n\nconst groupStyle: React.CSSProperties = {\n height: '19px',\n paddingTop: '1px',\n paddingLeft: '3px',\n paddingRight: '4px',\n border: '1px solid #E8E8E8',\n background: '#fff',\n fontSize: '11px',\n color: '#999',\n fontWeight: 500,\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n position: 'relative',\n cursor: 'pointer',\n borderRadius: '5px',\n};\nconst emojiStyle = {\n fontSize: '16px',\n marginTop: '1px',\n paddingRight: '3px',\n};\nconst tooltipStyle: React.CSSProperties = {\n maxWidth: '250px',\n wordBreak: 'break-word',\n wordWrap: 'normal',\n whiteSpace: 'nowrap',\n font: `normal normal 11px/1.5 -apple-system, BlinkMacSystemFont, \"Segoe UI\",\n Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\"`,\n color: '#fff',\n background: 'rgba(0,0,0,0.8)',\n borderRadius: '3px',\n padding: '5px 8px',\n position: 'absolute',\n bottom: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginBottom: '4px',\n opacity: '0',\n transition: 'opacity 0.1s ease-in-out',\n};\nconst tooltipStyleHover = {\n opacity: '1',\n};\nconst groupStyleActive = {\n background: '#F4FAFF',\n border: '1px solid #BBE1FF',\n};\nconst emojiStyleNoNames = {\n paddingRight: '0',\n};\n\nexport default SlackCounterGroup;\n","import React from 'react';\n\nexport const SlackCSS = () => {\n return (\n <style\n dangerouslySetInnerHTML={{\n __html: `\n @font-face {\n font-family: Slack;\n src: url(fonts/slack-icons-Regular.eot);\n src: url(fonts/slack-icons-Regular.eot?#iefix) format('embedded-opentype'),\n url(fonts/slack-icons-Regular.woff) format('woff'),\n url(fonts/slack-icons-Regular.ttf) format('truetype')\n }\n .frame::-webkit-scrollbar {\n -webkit-appearance: none;\n }\n .frame::-webkit-scrollbar:vertical {\n width: 8px;\n }\n .frame::-webkit-scrollbar-thumb {\n border-radius: 4px;\n background-color: #D9D9DE;\n box-shadow: 0 0 0 3px #fff;\n height: 30px;\n }\n .frame::-webkit-scrollbar-track {\n background-color: #F3F3F3;\n border-radius: 4px;\n }\n `,\n }}\n />\n );\n};\n\nexport default SlackCSS;\n","import React from 'react';\nimport { CounterObject, groupBy, Hover, HoverStyle } from '../../helpers';\nimport SlackCounterGroup from './SlackCounterGroup';\nimport SlackCSS from './SlackCSS';\n\nexport interface SlackCounterProps {\n counters?: CounterObject[];\n user?: string;\n onSelect?: (emoji: string) => void;\n onAdd?: () => void;\n}\n\nexport const SlackCounter = React.forwardRef<HTMLDivElement, SlackCounterProps>(\n (\n {\n counters = defaultProps.counters,\n user = defaultProps.user,\n onSelect = defaultProps.onSelect,\n onAdd = defaultProps.onAdd,\n },\n ref\n ) => {\n const groups = groupBy(counters, 'emoji');\n\n return (\n <>\n <SlackCSS />\n <Hover ref={ref} style={counterStyle}>\n {Object.keys(groups).map((emoji: string) => {\n const names = groups[emoji].map(({ by }: CounterObject) => {\n return by;\n });\n return (\n <div style={groupStyle} key={emoji}>\n <SlackCounterGroup\n emoji={emoji}\n count={names.length}\n names={names}\n active={names.includes(user)}\n onSelect={onSelect}\n />\n </div>\n );\n })}\n <HoverStyle\n hoverStyle={addStyleHover}\n style={addStyle}\n onClick={onAdd}\n >\n <SlackCounterGroup emoji={''} />\n </HoverStyle>\n </Hover>\n </>\n );\n }\n);\n\nexport const defaultProps: Required<SlackCounterProps> = {\n counters: [\n {\n emoji: 'ðŸ‘',\n by: 'Case Sandberg',\n },\n {\n emoji: '👎',\n by: 'Charlie!!!!!',\n },\n ],\n user: 'Charlie',\n onSelect: (emoji: string) => {\n console.log(emoji);\n },\n onAdd: () => {\n console.log('add');\n },\n};\n\nconst counterStyle = {\n display: 'flex',\n};\nconst addStyle = {\n cursor: 'pointer',\n fontFamily: 'Slack',\n paddingLeft: '8px',\n opacity: '0',\n transition: 'opacity 0.1s ease-in-out',\n};\nconst groupStyle = {\n marginRight: '4px',\n};\nconst addStyleHover = {\n opacity: '1',\n};\n\nexport default SlackCounter;\n","import React from 'react';\nimport { Hover } from '../../helpers';\n\nexport interface SlackSelectorSectionEmojiProps {\n hoverColor: string;\n onSelect: (emoji: string) => void;\n emoji: string;\n}\n\nexport const SlackSelectorSectionEmoji = React.forwardRef<\n HTMLDivElement,\n SlackSelectorSectionEmojiProps\n>(({ hoverColor, onSelect, emoji }, ref) => {\n const wrapStyleHover = React.useMemo(() => {\n return { background: hoverColor };\n }, [hoverColor]);\n\n const handleClick = () => {\n onSelect(emoji);\n };\n\n return (\n <Hover\n ref={ref}\n hoverStyle={wrapStyleHover}\n style={wrapStyle}\n onClick={handleClick}\n >\n <div style={emojiStyle}>{emoji}</div>\n </Hover>\n );\n});\n\nconst wrapStyle = {\n width: '36px',\n height: '32px',\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n margin: '0 1px 1px 0',\n borderRadius: '6px',\n cursor: 'pointer',\n transition: 'background .15s ease-out 50ms',\n};\nconst emojiStyle = {\n fontSize: '22px',\n width: '22px',\n height: '22px',\n lineHeight: '26px',\n};\n\nexport default SlackSelectorSectionEmoji;\n","import React from 'react';\nimport { emojiColors, sectionSlugToName } from '../../helpers/slack';\nimport SlackSelectorSectionEmoji from './SlackSelectorSectionEmoji';\n\nexport interface SlackSelectorSectionProps {\n slug?: string;\n emojis: string[];\n onSelect: (emoji: string) => void;\n}\n\nexport const SlackSelectorSection = React.forwardRef<\n HTMLDivElement,\n SlackSelectorSectionProps\n>(({ slug = '', emojis, onSelect }, ref) => {\n return (\n <div ref={ref} id={slug}>\n <div style={titleStyle}>{sectionSlugToName(slug)}</div>\n <div style={emojisStyle}>\n {emojis.map((emoji, i) => {\n return (\n <SlackSelectorSectionEmoji\n key={i}\n hoverColor={emojiColors[i % emojiColors.length]}\n emoji={emoji}\n onSelect={onSelect}\n />\n );\n })}\n </div>\n </div>\n );\n});\n\nconst emojisStyle: React.CSSProperties = {\n display: 'flex',\n flexWrap: 'wrap',\n};\nconst titleStyle: React.CSSProperties = {\n fontWeight: 600,\n WebkitFontSmoothing: 'antialiased',\n fontSize: '16px',\n lineHeight: '1.5rem',\n margin: '0 6px',\n};\n\nexport default SlackSelectorSection;\n","import React from 'react';\nimport SlackSelectorSection from './SlackSelectorSection';\n\nexport interface SlackSelectorFooterProps {\n onSelect: (id: string) => void;\n}\n\nexport const SlackSelectorFooter = React.forwardRef<\n HTMLDivElement,\n SlackSelectorFooterProps\n>(({ onSelect }, ref) => {\n return (\n <div ref={ref} style={footerStyle}>\n <div style={leftStyle}>Handy Reactions</div>\n <div style={rightStyle}>\n <SlackSelectorSection\n onSelect={onSelect}\n emojis={['😀', 'ðŸ‘', '✅', 'â¤ï¸', '👀']}\n />\n </div>\n </div>\n );\n});\n\nconst footerStyle = {\n padding: '5px 11px',\n borderTop: '1px solid rgba(0,0,0,.15)',\n display: 'flex',\n justifyContent: 'space-between',\n};\nconst leftStyle: React.CSSProperties = {\n fontSize: '16px',\n lineHeight: '1.5',\n margin: '4px 2px',\n fontWeight: 600,\n WebkitFontSmoothing: 'antialiased',\n};\nconst rightStyle = {\n paddingRight: '6px',\n};\n\nexport default SlackSelectorFooter;\n","import React from 'react';\nimport { Hover } from '../../helpers';\n\nexport interface SlackSelectorHeaderTabProps {\n onClick: (id: string) => void;\n id: string;\n icon: string;\n active?: boolean;\n}\n\nexport const SlackSelectorHeaderTab = React.forwardRef<\n HTMLDivElement,\n SlackSelectorHeaderTabProps\n>(({ onClick, id, icon, active = false }, ref) => {\n const handleClick = () => {\n onClick && onClick(id);\n };\n\n return (\n <Hover\n ref={ref}\n hoverStyle={{ ...tabStyleHover }}\n style={{ ...tabStyle, ...(active ? tabStyleActive : {}) }}\n onClick={handleClick}\n >\n <div style={iconStyle}>{icon}</div>\n </Hover>\n );\n});\n\nconst tabStyle = {\n color: '#9e9ea6',\n padding: '5px 8px 7px',\n borderRadius: '6px 6px 0 0',\n marginRight: '1px',\n borderBottom: '3px solid transparent',\n cursor: 'pointer',\n};\nconst iconStyle = {\n width: '20px',\n height: '18px',\n fontFamily: 'Slack',\n fontSize: '20px',\n WebkitFontSmoothing: 'antialiased',\n};\nconst tabStyleHover = {\n color: '#555459',\n borderBottom: '3px solid #2ab27b',\n};\nconst tabStyleActive = {\n color: '#9e9ea6',\n borderBottom: '3px solid #2ab27b',\n};\n\nexport default SlackSelectorHeaderTab;\n","import React from 'react';\nimport SlackSelectorHeaderTab from './SlackSelectorHeaderTab';\n\ninterface Tab {\n icon: string;\n id: string;\n}\n\nexport interface SlackSelectorHeaderProps {\n tabs?: Tab[];\n}\n\nexport const SlackSelectorHeader = React.forwardRef<\n HTMLDivElement,\n SlackSelectorHeaderProps\n>(({ tabs = [] }, ref) => {\n const [activeString, setActiveString] = React.useState('');\n\n const handleClick = (id: string) => {\n document?.getElementById(id)!.scrollIntoView(false);\n setActiveString(id);\n };\n\n return (\n <div ref={ref} style={headerStyle}>\n {tabs.map((tab: Tab) => {\n return (\n <SlackSelectorHeaderTab\n icon={tab.icon}\n id={tab.id}\n key={tab.id}\n active={tab.id === activeString}\n onClick={handleClick}\n />\n );\n })}\n </div>\n );\n});\n\nconst headerStyle = {\n padding: '4px 0 0 7px',\n borderBottom: '1px solid rgba(0,0,0,.15)',\n display: 'flex',\n};\n\nSlackSelectorHeader.defaultProps = {\n tabs: [\n {\n icon: 'î¹',\n id: 'mine',\n },\n {\n icon: 'î„™',\n id: 'people',\n },\n {\n icon: '',\n id: 'nature',\n },\n {\n icon: '',\n id: 'food-and-drink',\n },\n {\n icon: 'î„©',\n id: 'activity',\n },\n {\n icon: 'î„°',\n id: 'travel-and-places',\n },\n {\n icon: '',\n id: 'objects',\n },\n {\n icon: 'î–',\n id: 'symbols',\n },\n {\n icon: 'î…',\n id: 'flags',\n },\n ],\n};\n\nexport default SlackSelectorHeader;\n","import React from 'react';\nimport emoji from '../../helpers/emoji';\nimport SlackSelectorSection from './SlackSelectorSection';\n\nexport interface SlackSelectorItemsProps {\n scrollHeight: string;\n frequent: string[];\n onSelect: (emoji: string) => void;\n removeEmojis: string[];\n}\n\nexport const SlackSelectorItems = React.forwardRef<\n HTMLDivElement,\n SlackSelectorItemsProps\n>(({ scrollHeight, frequent, onSelect, removeEmojis }, ref) => {\n const wrapStyle: React.CSSProperties = React.useMemo(() => {\n return {\n maxHeight: scrollHeight,\n overflowY: 'auto',\n overflowX: 'hidden',\n padding: '4px 4px 8px',\n };\n }, [scrollHeight]);\n\n return (\n <div ref={ref} style={sectionsStyle}>\n <div style={wrapStyle} className=\"frame\">\n {frequent ? (\n <SlackSelectorSection\n key=\"mine\"\n slug=\"mine\"\n emojis={frequent}\n onSelect={onSelect}\n />\n ) : null}\n {Object.keys(emoji).map((slug: string) => {\n const group = emoji[slug as keyof typeof emoji];\n return (\n <SlackSelectorSection\n key={slug}\n slug={slug}\n emojis={group.filter(function(this: any, e: string) {\n // https://stackoverflow.com/a/41945742/9931154\n // https://stackoverflow.com/a/34902391/9931154\n return this.indexOf(e) < 0;\n }, removeEmojis)}\n onSelect={onSelect}\n />\n );\n })}\n </div>\n </div>\n );\n});\n\nconst sectionsStyle = {\n padding: '4px 4px 0',\n background: '#fff',\n};\n\nexport default SlackSelectorItems;\n","import React from 'react';\nimport SlackCSS from './SlackCSS';\nimport SlackSelectorFooter from './SlackSelectorFooter';\nimport SlackSelectorHeader from './SlackSelectorHeader';\nimport SlackSelectorItems from './SlackSelectorItems';\n\nexport interface SlackSelectorProps {\n scrollHeight?: string;\n frequent?: string[];\n removeEmojis?: string[];\n onSelect?: (id: string) => void;\n}\n\nexport const SlackSelector = React.forwardRef<\n HTMLDivElement,\n SlackSelectorProps\n>(\n (\n {\n scrollHeight = defaultProps.scrollHeight,\n frequent = defaultProps.frequent,\n removeEmojis = defaultProps.removeEmojis,\n onSelect = defaultProps.onSelect,\n },\n ref\n ) => {\n return (\n <div ref={ref} style={menuStyle}>\n <SlackCSS />\n <SlackSelectorHeader />\n <SlackSelectorItems\n scrollHeight={scrollHeight}\n removeEmojis={removeEmojis}\n frequent={frequent}\n onSelect={onSelect}\n />\n <SlackSelectorFooter onSelect={onSelect} />\n </div>\n );\n }\n);\n\nconst menuStyle = {\n fontFamily: '\"Helvetica Neue\",Helvetica,\"Segoe UI\",Tahoma,Arial,sans-serif',\n width: '358px',\n color: '#555459',\n fontSize: '.95rem',\n background: '#f7f7f7',\n lineHeight: '1rem',\n boxShadow: '0 5px 10px rgba(0,0,0,.12)',\n borderRadius: '6px',\n border: '1px solid rgba(0,0,0,.15)',\n};\n\nexport const defaultProps: Required<SlackSelectorProps> = {\n scrollHeight: '270px',\n removeEmojis: [\n '🙂',\n '🙃',\n '☺ï¸',\n '🤑',\n '🤓',\n '🤗',\n '🙄',\n '🤔',\n 'ðŸ™',\n '☹ï¸',\n 'ðŸ¤',\n '🤒',\n '🤕',\n '🤖',\n ],\n frequent: [\n 'ðŸ‘',\n 'ðŸ‰',\n '🙌',\n '🗿',\n '😊',\n 'ðŸ¬',\n '😹',\n '👻',\n '🚀',\n 'ðŸš',\n 'ðŸ‡',\n '🇨🇦',\n ],\n onSelect: (id: string) => {\n console.log(id);\n },\n};\n\nexport default SlackSelector;\n","import React from 'react';\nimport { Hover, HoverStyle } from '../../helpers';\n\nexport interface YoutubeCounterButtonProps {\n position: string;\n number: string;\n tooltip: string;\n onClick: () => void;\n active: boolean;\n // TODO: not used, but would be cool\n // activeColor: string;\n}\n\nexport const YoutubeCounterButton = React.forwardRef<\n HTMLDivElement,\n YoutubeCounterButtonProps\n>(\n (\n {\n position,\n number,\n tooltip,\n onClick,\n active,\n // activeColor,\n },\n ref\n ) => {\n const iconStyle = React.useMemo(() => {\n return {\n background: `no-repeat url(//s.ytimg.com/yts/imgbin/www-hitchhiker-2x-vflaXbyPz.webp) ${position}`,\n backgroundSize: '573px 310px',\n width: '20px',\n height: '20px',\n marginRight: '6px',\n };\n }, [position]);\n\n return (\n <Hover\n ref={ref}\n hoverStyle={buttonStyleHover}\n style={{ ...buttonStyle, ...(active ? buttonStyleActive : {}) }}\n onClick={onClick}\n >\n <div style={iconStyle} />\n {parseInt(number, 10).toLocaleString()}\n <HoverStyle hoverStyle={tooltipStyleHover} style={tooltipStyle}>\n {tooltip}\n </HoverStyle>\n </Hover>\n );\n }\n);\n\nconst buttonStyle: React.CSSProperties = {\n display: 'flex',\n alignItems: 'center',\n fontFamily: 'Roboto,arial,sans-serif',\n fontSize: '11px',\n opacity: '0.5',\n cursor: 'pointer',\n position: 'relative',\n};\nconst tooltipStyle: React.CSSProperties = {\n color: '#fff',\n background: 'rgba(0,0,0,0.8)',\n borderRadius: '3px',\n padding: '5px 8px',\n position: 'absolute',\n bottom: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginBottom: '4px',\n whiteSpace: 'nowrap',\n opacity: '0',\n transition: 'opacity 0.1s ease-in-out',\n};\nconst buttonStyleHover = {\n opacity: '0.7',\n};\nconst tooltipStyleHover = {\n opacity: '1',\n};\nconst buttonStyleActive = {\n opacity: '1',\n};\n\nexport default YoutubeCounterButton;\n","import React from 'react';\nimport YoutubeCounterButton from './YoutubeCounterButton';\n\nexport interface YoutubeCounterProps {\n like?: string;\n dislike?: string;\n onLikeClick?: () => void;\n onDislikeClick?: () => void;\n didLike?: boolean;\n didDislike?: boolean;\n}\n\nexport const YoutubeCounter = React.forwardRef<\n HTMLDivElement,\n YoutubeCounterProps\n>(\n (\n {\n like = defaultProps.like,\n dislike = defaultProps.dislike,\n onLikeClick = defaultProps.onLikeClick,\n onDislikeClick = defaultProps.onDislikeClick,\n didLike = defaultProps.didLike,\n didDislike = defaultProps.didDislike,\n },\n ref\n ) => {\n const handleLikeClick = () => onLikeClick();\n const handleDislikeClick = () => onDislikeClick();\n\n return (\n <div ref={ref} style={counterStyle}>\n <YoutubeCounterButton\n number={like}\n position=\"-66px -69px\"\n tooltip=\"I like this\"\n onClick={handleLikeClick}\n active={didLike}\n />\n <div style={spaceStyle} />\n <YoutubeCounterButton\n number={dislike}\n position=\"-390px -148px\"\n tooltip=\"I dislike this\"\n onClick={handleDislikeClick}\n active={didDislike}\n />\n </div>\n );\n }\n);\n\nconst defaultProps: Required<YoutubeCounterProps> = {\n like: '3',\n dislike: '2',\n onLikeClick: () => {\n console.log('like');\n },\n onDislikeClick: () => {\n console.log('dislike');\n },\n didLike: false,\n didDislike: false,\n};\n\nconst counterStyle = {\n display: 'flex',\n};\nconst spaceStyle = {\n width: '12px',\n};\n\nexport default YoutubeCounter;\n","export default 'Reactions';\n\nexport * from './components';\nexport * from './helpers';\n"],"names":["emoji","people","nature","activity","objects","symbols","flags","groupBy","xs","key","reduce","rv","x","push","HoverContext","React","useHover","Hover","_ref","ref","hoverStyle","_ref$hoverStyle","children","style","rest","_objectWithoutPropertiesLoose","_excluded","_React$useState","isHovered","setHovered","Provider","value","Object","assign","onMouseEnter","onMouseLeave","_extends","HoverStyle","_ref$style","_excluded$1","calculatedStyle","icons","facebook","like","love","haha","wow","sad","angry","pokemon","icons$1","find","scope","name","emojiColors","sectionSlugToName","mine","listOfNames","names","slice","join","length","withActive","Component","props","active","setActive","handleMouseDown","handleMouseUp","onMouseDown","onMouseUp","ReactionBarSelectorEmoji","reaction","onSelect","node","label","wrapStyle","labelStyleHover","labelStyle","iconStyleHover","iconStyle","onClick","padding","position","transform","opacity","top","background","borderRadius","color","fontSize","fontWeight","textTransform","left","transition","fontFamily","transformOrigin","cursor","ReactionBarSelector","iconSize","_ref$iconSize","defaultProps","reactions","_ref$reactions","_ref$onSelect","emojiStyle","width","height","display","alignItems","wrapStyle$1","map","_reaction$key","console","log","backgroundColor","boxShadow","ReactionCounterEmoji","bg","index","emojiContainerStyle","zIndex","objectFit","objectPosition","ReactionCounter","user","important","className","_ref$bg","showReactsOnly","_ref$showReactsOnly","showTotalOnly","_ref$showTotalOnly","showOthersAlways","_ref$showOthersAlways","groups","_ref2","by","nameString","includes","othersCount","nameStyle","marginLeft","counterStyle","keys","i","FacebookCounterReaction","variant","reactionStyle","backgroundSize","backgroundImage","FacebookCounter","counters","_ref$counters","defaultProps$1","_ref$user","_ref$important","_ref$onClick","_ref$variant","alwaysShowOthers","_ref$alwaysShowOthers","counterStyle$1","paddingLeft","marginTop","FacebookSelectorEmoji","icon","paddingBottom","wrapStyle$2","labelStyleHover$1","labelStyle$1","iconStyleHover$1","FacebookSelector","defaultProps$2","wrapStyle$3","GithubCounterGroup","count","groupStyle","groupStyleActive","tooltipStyleHover","tooltipStyle","borderRight","justifyContent","maxWidth","wordBreak","wordWrap","whiteSpace","font","GithubCounter","defaultProps$3","onAdd","_ref$onAdd","counterStyle$2","addStyleHover","addStyle","viewBox","d","border","fill","GithubSelectorEmoji","shortCode","_ref$active","wrapStyle$4","wrapStyleActive","emojiStyleHover","emojiStyle$1","textAlign","lineHeight","GithubSelector","defaultProps$4","selectorStyle","labelStyle$2","dividerStyle","emojiStyle$2","paddingTop","margin","PokemonCounter","PokemonSelector","SlackCounterGroup","groupStyleActive$1","groupStyle$1","emojiStyle$3","emojiStyleNoNames","tooltipStyleHover$1","tooltipStyle$1","paddingRight","bottom","marginBottom","SlackCSS","dangerouslySetInnerHTML","__html","SlackCounter","defaultProps$5","counterStyle$3","groupStyle$2","addStyleHover$1","addStyle$1","marginRight","SlackSelectorSectionEmoji","hoverColor","wrapStyleHover","wrapStyle$5","emojiStyle$4","SlackSelectorSection","slug","_ref$slug","emojis","id","titleStyle","emojisStyle","flexWrap","WebkitFontSmoothing","SlackSelectorFooter","footerStyle","leftStyle","rightStyle","borderTop","SlackSelectorHeaderTab","tabStyleHover","tabStyle","tabStyleActive","iconStyle$1","borderBottom","SlackSelectorHeader","tabs","_ref$tabs","activeString","setActiveString","handleClick","_document","document","getElementById","scrollIntoView","headerStyle","tab","SlackSelectorItems","scrollHeight","frequent","removeEmojis","maxHeight","overflowY","overflowX","sectionsStyle","group","filter","e","this","indexOf","SlackSelector","_ref$scrollHeight","defaultProps$6","_ref$frequent","_ref$removeEmojis","menuStyle","YoutubeCounterButton","number","tooltip","buttonStyleHover","buttonStyle","buttonStyleActive","parseInt","toLocaleString","tooltipStyleHover$2","tooltipStyle$2","YoutubeCounter","_ref$like","defaultProps$7","dislike","_ref$dislike","onLikeClick","_ref$onLikeClick","onDislikeClick","_ref$onDislikeClick","didLike","_ref$didLike","didDislike","_ref$didDislike","counterStyle$4","spaceStyle"],"sourceRoot":""}