{-# LANGUAGE CPP #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# LANGUAGE OverloadedStrings #-}
module Text.Emoji ( emojis, emojiFromAlias, aliasesFromEmoji ) where
import Prelude
import qualified Data.Map as M
import Data.Text (Text)
emojiMap :: M.Map Text Text
emojiMap = M.fromList emojis
emojiAliasMap :: M.Map Text [Text]
emojiAliasMap =
foldr (\(alias, s) m -> M.alter (go alias) s m) mempty emojis
where
go alias Nothing = Just [alias]
go alias (Just as) = Just (alias:as)
emojiFromAlias :: Text -> Maybe Text
emojiFromAlias name = M.lookup name emojiMap
aliasesFromEmoji :: Text -> Maybe [Text]
aliasesFromEmoji s = M.lookup s emojiAliasMap
emojis :: [(Text, Text)]
#include "emojis.inc"