UNPKG

@indahash/emoji-picker-react

Version:

Emoji Picker component for React Applications on the web

131 lines (113 loc) 3.22 kB
import { Categories, SuggestionMode } from '../types/exposedTypes'; export { Categories }; const categoriesOrdered: Categories[] = [ Categories.SUGGESTED, Categories.MOST_POPULAR_EMOJIS, Categories.SMILEYS_PEOPLE, Categories.ANIMALS_NATURE, Categories.FOOD_DRINK, Categories.TRAVEL_PLACES, Categories.ACTIVITIES, Categories.OBJECTS, Categories.SYMBOLS, Categories.FLAGS, ]; export const SuggestedRecent: CategoryConfig = { name: 'Recently Used', category: Categories.SUGGESTED, }; const configByCategory: Record<Categories, CategoryConfig> = { [Categories.SUGGESTED]: { category: Categories.SUGGESTED, name: 'Frequently Used', }, [Categories.MOST_POPULAR_EMOJIS]: { category: Categories.MOST_POPULAR_EMOJIS, name: 'Most popular emojis', }, [Categories.SMILEYS_PEOPLE]: { category: Categories.SMILEYS_PEOPLE, name: 'Smileys & People', }, [Categories.ANIMALS_NATURE]: { category: Categories.ANIMALS_NATURE, name: 'Animals & Nature', }, [Categories.FOOD_DRINK]: { category: Categories.FOOD_DRINK, name: 'Food & Drink', }, [Categories.TRAVEL_PLACES]: { category: Categories.TRAVEL_PLACES, name: 'Travel & Places', }, [Categories.ACTIVITIES]: { category: Categories.ACTIVITIES, name: 'Activities', }, [Categories.OBJECTS]: { category: Categories.OBJECTS, name: 'Objects', }, [Categories.SYMBOLS]: { category: Categories.SYMBOLS, name: 'Symbols', }, [Categories.FLAGS]: { category: Categories.FLAGS, name: 'Flags', }, }; export function baseCategoriesConfig( modifiers?: Record<Categories, CategoryConfig> ): CategoriesConfig { return categoriesOrdered.map((category) => { return { ...configByCategory[category], ...(modifiers && modifiers[category] && modifiers[category]), }; }); } export function categoryFromCategoryConfig(category: CategoryConfig) { return category.category; } export function categoryNameFromCategoryConfig(category: CategoryConfig) { return category.name; } export type CategoriesConfig = CategoryConfig[]; export type CategoryConfig = { category: Categories; name: string; }; export type UserCategoryConfig = Array<Categories | CategoryConfig>; export function mergeCategoriesConfig( userCategoriesConfig: UserCategoryConfig = [], modifiers: CategoryConfigModifiers = {} ): CategoriesConfig { const extra = {} as Record<Categories, CategoryConfig>; if (modifiers.suggestionMode === SuggestionMode.RECENT) { extra[Categories.SUGGESTED] = SuggestedRecent; } const base = baseCategoriesConfig(extra); if (!userCategoriesConfig?.length) { return base; } return userCategoriesConfig.map((category) => { if (typeof category === 'string') { return getBaseConfigByCategory(category, extra[category]); } return { ...getBaseConfigByCategory(category.category, extra[category.category]), ...category, }; }); } function getBaseConfigByCategory( category: Categories, modifier: CategoryConfig = {} as CategoryConfig ) { return Object.assign(configByCategory[category], modifier); } type CategoryConfigModifiers = { suggestionMode?: SuggestionMode; };