{"version":3,"file":"emoji-picker.cjs","sources":["../../../components/emoji_picker/modules/emoji_tabset.vue","../../../components/emoji_picker/modules/emoji_search.vue","../../../components/emoji_picker/modules/emoji_selector.vue","../../../components/emoji_picker/modules/emoji_description.vue","../../../components/emoji_picker/modules/emoji_skin_selector.vue","../../../components/emoji_picker/emoji_picker.vue"],"sourcesContent":["<template>\n  <div class=\"d-emoji-picker__tabset\">\n    <dt-tab-group\n      :selected=\"selectedTab\"\n      size=\"sm\"\n      tab-list-class=\"d-emoji-picker__tabset-list\"\n    >\n      <template #tabs>\n        <dt-tab\n          v-for=\"(tab, index) in tabs\"\n          :id=\"tab.id\"\n          :key=\"tab.id\"\n          :ref=\"`tabsetRef-${index}`\"\n          :label=\"tab.label\"\n          :panel-id=\"tab.panelId\"\n          :tabindex=\"index + 1\"\n          aria-controls=\"d-emoji-picker-list\"\n          @keydown=\"handleKeyDown($event, tab.id)\"\n          @click.capture.stop=\"selectTabset(tab.id)\"\n        >\n          <component\n            :is=\"tab.icon\"\n            size=\"400\"\n          />\n        </dt-tab>\n      </template>\n    </dt-tab-group>\n  </div>\n</template>\n\n<script>\nimport { DtTab, DtTabGroup } from '@/components/tab';\nimport {\n  DtIconClock,\n  DtIconSatisfied,\n  DtIconLivingThing,\n  DtIconFood,\n  DtIconObject,\n  DtIconTransportation,\n  DtIconLightbulb,\n  DtIconHeart,\n  DtIconFlag,\n  DtIconTiktok,\n} from '@dialpad/dialtone-icons/vue2';\n\nexport default {\n  name: 'EmojiTabset',\n\n  components: {\n    DtTabGroup,\n    DtTab,\n  },\n\n  props: {\n    /**\n     * Whether to show the recently used tab or not\n     * @type {Boolean}\n     * @default false\n     */\n    showRecentlyUsedTab: {\n      type: Boolean,\n      default: false,\n    },\n\n    showCustomEmojisTab: {\n      type: Boolean,\n      default: false,\n    },\n\n    scrollIntoTab: {\n      type: Number,\n      required: true,\n    },\n\n    emojiFilter: {\n      type: String,\n      default: '',\n    },\n\n    /**\n     * The labels for the aria-label\n     * @type {Array}\n     * @required\n     */\n    tabSetLabels: {\n      type: Array,\n      required: true,\n    },\n  },\n\n  data () {\n    return {\n      selectedTab: '1',\n      tabsetRef: [],\n      TABS_DATA: [\n        { label: this.tabSetLabels[0], icon: DtIconClock },\n        { label: this.tabSetLabels[1], icon: DtIconSatisfied },\n        { label: this.tabSetLabels[2], icon: DtIconLivingThing },\n        { label: this.tabSetLabels[3], icon: DtIconFood },\n        { label: this.tabSetLabels[4], icon: DtIconObject },\n        { label: this.tabSetLabels[5], icon: DtIconTransportation },\n        { label: this.tabSetLabels[6], icon: DtIconLightbulb },\n        { label: this.tabSetLabels[7], icon: DtIconHeart },\n        { label: this.tabSetLabels[8], icon: DtIconFlag },\n        { label: this.tabSetLabels[9], icon: DtIconTiktok },\n      ],\n    };\n  },\n\n  computed: {\n    tabs () {\n      // if showRecentlyUsedTab is false remove first index of TABS_DATA\n      const tabsData = this.showRecentlyUsedTab ? this.TABS_DATA : this.TABS_DATA.slice(1);\n      // if showCustomEmojisTab is false remove last index of TABS_DATA\n      if (!this.showCustomEmojisTab) {\n        tabsData.pop();\n      }\n\n      return tabsData.map((tab, index) => ({\n        ...tab,\n        // IDs on dt-tab component need to be on string\n        id: (index + 1).toString(),\n        panelId: (index + 1).toString(),\n      }));\n    },\n\n    isSearching () {\n      return this.emojiFilter.length > 0;\n    },\n  },\n\n  watch: {\n    scrollIntoTab: function (newVal) {\n      if (!this.isSearching) {\n        this.selectedTab = (newVal + 1).toString();\n      }\n    },\n\n    isSearching: function (newVal) {\n      if (newVal) {\n        this.selectedTab = null;\n      }\n    },\n  },\n\n  mounted () {\n    this.$nextTick(() => {\n      this.setTabsetRef();\n    });\n  },\n\n  methods: {\n    selectTabset (id) {\n      // IDs on scrollToTab need to be on number\n      const parseId = parseInt(id);\n      // IDs on dt-tab component need to be on string\n      this.selectedTab = id;\n      this.$emit('selected-tabset', parseId);\n    },\n\n    setTabsetRef () {\n      this.tabs.forEach((skin, index) => {\n        const refKey = `tabsetRef-${index}`;\n        if (this.$refs[refKey]) {\n          this.$set(this.tabsetRef, index, this.$refs[refKey][0].$el);\n        }\n      });\n    },\n\n    focusTabset () {\n      if (this.tabsetRef[0]) {\n        this.tabsetRef[0].focus();\n      }\n    },\n\n    // eslint-disable-next-line complexity\n    handleKeyDown (event, tabId) {\n      if (event.key === 'Enter') {\n        this.selectTabset(tabId);\n        if (this.tabsetRef[tabId - 1]) {\n          this.tabsetRef[tabId - 1].blur();\n        }\n      }\n\n      if (event.key === 'Tab') {\n        event.preventDefault();\n        if (event.shiftKey) {\n          this.$emit('focus-skin-selector');\n        } else {\n          this.$emit('focus-search-input');\n        }\n      }\n\n      if (event.key === 'ArrowDown') {\n        this.$emit('focus-search-input');\n      }\n    },\n  },\n};\n</script>\n","<template>\n  <div class=\"d-emoji-picker__search d-emoji-picker__alignment\">\n    <dt-input\n      id=\"searchInput\"\n      ref=\"searchInputRef\"\n      :placeholder=\"searchPlaceholderLabel\"\n      :value=\"modelValue\"\n      @input=\"updateModelValue\"\n      @keydown.up=\"focusTabset\"\n      @keydown.down.prevent=\"focusEmojiSelector\"\n      @keydown.enter=\"selectFirstEmoji\"\n    >\n      <template #leftIcon>\n        <dt-icon-search\n          size=\"200\"\n        />\n      </template>\n      <template\n        v-if=\"modelValue.length > 0\"\n        #rightIcon\n      >\n        <dt-button\n          importance=\"clear\"\n          size=\"xs\"\n          class=\"d-emoji-picker__search-x-button\"\n          circle\n          kind=\"muted\"\n          @click=\"clearSearch\"\n        >\n          <template #icon>\n            <dt-icon-close\n              size=\"200\"\n            />\n          </template>\n        </dt-button>\n      </template>\n    </dt-input>\n  </div>\n</template>\n\n<script>\nimport { DtIconSearch, DtIconClose } from '@dialpad/dialtone-icons/vue2';\nimport { DtInput } from '@/components/input';\nimport { DtButton } from '@/components/button';\n\nexport default {\n  name: 'EmojiSearch',\n\n  components: {\n    DtInput,\n    DtIconSearch,\n    DtIconClose,\n    DtButton,\n  },\n\n  props: {\n    searchPlaceholderLabel: {\n      type: String,\n      required: true,\n    },\n\n    modelValue: {\n      type: String,\n      default: '',\n    },\n  },\n\n  mounted () {\n    this.focusSearchInput();\n  },\n\n  methods: {\n    updateModelValue (value) {\n      this.$emit('update:model-value', value);\n    },\n\n    focusEmojiSelector () {\n      this.$emit('focus-emoji-selector');\n    },\n\n    focusTabset () {\n      this.$emit('focus-tabset');\n    },\n\n    selectFirstEmoji () {\n      this.$emit('select-first-emoji');\n    },\n\n    clearSearch () {\n      this.$emit('update:model-value', '');\n      this.focusSearchInput();\n    },\n\n    focusSearchInput () {\n      this.$refs.searchInputRef.focus();\n    },\n  },\n};\n</script>\n","<template>\n  <div\n    class=\"d-emoji-picker__selector\"\n  >\n    <div\n      id=\"d-emoji-picker-list\"\n      ref=\"listRef\"\n      class=\"d-emoji-picker__list\"\n    >\n      <p\n        v-if=\"emojiFilter\"\n        class=\"d-emoji-picker__search-label d-emoji-picker__alignment\"\n      >\n        {{ filteredEmojis.length > 0 ? searchResultsLabel : searchNoResultsLabel }}\n      </p>\n      <div\n        v-else\n        ref=\"tabCategoryRef\"\n        class=\"d-emoji-picker__category d-emoji-picker__alignment\"\n      >\n        <p>\n          {{ fixedLabel }}\n        </p>\n      </div>\n      <div\n        v-for=\"(tabLabel, indexTab) in tabLabels\"\n        v-show=\"!emojiFilter\"\n        :key=\"indexTab\"\n        :ref=\"`tabLabelRef-${indexTab}`\"\n        class=\"d-emoji-picker__alignment\"\n      >\n        <p\n          v-if=\"indexTab\"\n        >\n          {{ tabLabel.label }}\n        </p>\n        <div\n          class=\"d-emoji-picker__tab\"\n        >\n          <button\n            v-for=\"(emoji, indexEmoji) in\n            (emojis[tabs[indexTab] + skinTone] ? emojis[tabs[indexTab] + skinTone] : emojis[tabs[indexTab]])\"\n            :key=\"emoji.shortname\"\n            :ref=\"`emojiRef-${indexTab}`\"\n            type=\"button\"\n            :aria-label=\"emoji.name\"\n            @click=\"event => handleEmojiSelection(emoji, event)\"\n            @focusin=\"$emit('highlighted-emoji', emoji)\"\n            @focusout=\"$emit('highlighted-emoji', null)\"\n            @mouseover=\"$emit('highlighted-emoji', emoji)\"\n            @mouseleave=\"$emit('highlighted-emoji', null)\"\n            @keydown=\"event => handleKeyDown(event, indexTab, indexEmoji, emoji)\"\n          >\n            <img\n              class=\"d-icon d-icon--size-500\"\n              :alt=\"emoji.name\"\n              :aria-label=\"emoji.name\"\n              :title=\"emoji.name\"\n              :src=\"getImgSrc(emoji)\"\n              @error=\"handleImageError\"\n            >\n          </button>\n        </div>\n      </div>\n      <div\n        v-if=\"emojiFilter\"\n        class=\"d-emoji-picker__alignment\"\n      >\n        <div\n          class=\"d-emoji-picker__tab \"\n          data-qa=\"filtered-emojis\"\n        >\n          <button\n            v-for=\"(emoji, index) in filteredEmojis\"\n            :key=\"emoji.shortname\"\n            :ref=\"`filteredEmoji-${index}`\"\n            type=\"button\"\n            :aria-label=\"emoji.name\"\n            :class=\"{\n              'hover-emoji': (index === 0 && hoverFirstEmoji),\n            }\"\n            @click=\"event => handleEmojiSelection(emoji, event)\"\n            @focusin=\"$emit('highlighted-emoji', emoji)\"\n            @focusout=\"$emit('highlighted-emoji', null)\"\n            @mouseover=\"hoverEmoji(emoji)\"\n            @mouseleave=\"hoverEmoji(null)\"\n            @keydown=\"event => handleKeyDownFilteredEmojis(event, index, emoji)\"\n          >\n            <img\n              class=\"d-icon d-icon--size-500\"\n              :alt=\"emoji.name\"\n              :aria-label=\"emoji.name\"\n              :title=\"emoji.name\"\n              :src=\"`${CDN_URL + emoji.unicode_character}.png`\"\n            >\n          </button>\n        </div>\n      </div>\n    </div>\n  </div>\n</template>\n\n<script>\n/* eslint-disable max-len */\n/* eslint-disable max-lines */\nimport { emojisGrouped as emojisImported } from '@dialpad/dialtone-emojis';\nimport { CDN_URL, EMOJIS_PER_ROW } from '@/components/emoji_picker/emoji_picker_constants';\n\nexport default {\n  name: 'EmojiSelector',\n\n  props: {\n    emojiFilter: {\n      type: String,\n      default: '',\n    },\n\n    skinTone: {\n      type: String,\n      required: true,\n    },\n\n    tabSetLabels: {\n      type: Array,\n      required: true,\n    },\n\n    selectedTabset: {\n      type: Object,\n      required: true,\n    },\n\n    searchResultsLabel: {\n      type: String,\n      required: true,\n    },\n\n    searchNoResultsLabel: {\n      type: String,\n      required: true,\n    },\n\n    recentlyUsedEmojis: {\n      type: Array,\n      default: () => [],\n    },\n\n    customEmojis: {\n      type: Array,\n      default: () => [],\n    },\n  },\n\n  data () {\n    return {\n      tabLabelsRefs: [],\n      emojiRefs: [],\n      emojiFilteredRefs: [],\n      isFiltering: false,\n      hoverFirstEmoji: true,\n      fixedLabel: '',\n      filteredEmojis: [],\n      TABS_DATA: ['Recently used', 'People', 'Nature', 'Food', 'Activity', 'Travel', 'Objects', 'Symbols', 'Flags', 'Custom'],\n      tabLabelObserver: null,\n    };\n  },\n\n  computed: {\n    /* eslint-disable-next-line complexity */\n    currentEmojis () {\n      return [\n        ...this.emojis[`People${this.skinTone}`] || [],\n        ...this.emojis.Nature || [],\n        ...this.emojis.Food || [],\n        ...this.emojis[`Activity${this.skinTone}`] || [],\n        ...this.emojis.Travel || [],\n        ...this.emojis[`Objects${this.skinTone}`] || [],\n        ...this.emojis.Symbols || [],\n        ...this.emojis.Flags || [],\n      ];\n    },\n\n    emojis () {\n      return emojisImported;\n    },\n\n    CDN_URL () {\n      return CDN_URL;\n    },\n\n    tabLabels () {\n      let updateTabLabels = this.tabSetLabels.map((label) => ({ label }));\n\n      if (!this.recentlyUsedEmojis.length) {\n        updateTabLabels = this.tabSetLabels.slice(1).map((label) => ({ label }));\n      }\n\n      if (!this.customEmojis.length) {\n        updateTabLabels.pop();\n      }\n\n      return updateTabLabels;\n    },\n\n    tabs () {\n      const updateTabsOrder = this.recentlyUsedEmojis.length ? this.TABS_DATA.slice() : this.TABS_DATA.slice(1);\n\n      if (!this.customEmojis.length) {\n        updateTabsOrder.pop();\n      }\n\n      return updateTabsOrder;\n    },\n  },\n\n  watch: {\n    currentEmojis: {\n      handler () {\n        this.searchByNameAndKeywords();\n      },\n\n      immediate: true,\n    },\n\n    recentlyUsedEmojis: {\n      handler (newValue) {\n        this.emojis['Recently used'] = newValue;\n      },\n\n      immediate: true,\n    },\n\n    customEmojis: {\n      handler (newValue) {\n        this.emojis.Custom = newValue;\n      },\n\n      immediate: true,\n    },\n\n    emojiFilter: {\n      handler (newFilter) {\n        this.resetScroll();\n        if (newFilter) {\n          this.isFiltering = true;\n        } else {\n          this.isFiltering = false;\n          this.$emit('highlighted-emoji', null);\n        }\n\n        this.debouncedSearch();\n      },\n    },\n\n    selectedTabset: {\n      handler (newValue) {\n        this.scrollToTab(newValue.tabId);\n      },\n\n      deep: true,\n    },\n  },\n\n  created () {\n    this.debouncedSearch = this.debounce(this.searchByNameAndKeywords, 300);\n  },\n\n  mounted () {\n    this.$nextTick(() => {\n      this.setupEmojiRefs();\n      this.setupFilteredRefs();\n      this.setupTabLabelRefs();\n      this.setTabLabelObserver();\n      this.setBottomScrollListener();\n    });\n  },\n\n  beforeDestroy () {\n    if (this.tabLabelObserver) {\n      this.tabLabelObserver.disconnect();\n    }\n\n    if (this.$refs.listRef && this.handleScroll) {\n      this.$refs.listRef.removeEventListener('scroll', this.handleScroll);\n    }\n  },\n\n  methods: {\n    setupTabLabelRefs () {\n      this.tabSetLabels?.forEach((_, index) => {\n        const refKey = `tabLabelRef-${index}`;\n        if (this.$refs[refKey]) {\n          this.$set(this.tabLabelsRefs, index, { ref: this.$refs[refKey] });\n        }\n      });\n    },\n\n    setupFilteredRefs () {\n      // it is necessary to clean the array before setting the new refs\n      this.emojiFilteredRefs = [];\n\n      this.filteredEmojis.forEach((emoji, index) => {\n        const refKey = `filteredEmoji-${index}`;\n        if (this.$refs[refKey]) {\n          this.setFilteredRef(this.$refs[refKey], index);\n        }\n      });\n    },\n\n    setupEmojiRefs () {\n      for (let i = 0; i < this.tabs.length; i++) {\n        const refKey = `emojiRef-${i}`;\n        if (this.$refs[refKey]) {\n          this.$refs[refKey].forEach((el, indexEmoji) => {\n            if (el) {\n              this.setEmojiRef(el, i, indexEmoji);\n            }\n          });\n        }\n      }\n    },\n\n    searchByNameAndKeywords () {\n      const searchStr = this.emojiFilter.toLowerCase();\n      this.filteredEmojis = this.currentEmojis.filter(function (obj) {\n        const nameIncludesSearchStr = obj.name.toLowerCase().includes(searchStr);\n        const keywordsIncludeSearchStr = obj.keywords.some(function (keyword) {\n          return keyword.toLowerCase().includes(searchStr);\n        });\n        return nameIncludesSearchStr || keywordsIncludeSearchStr;\n      });\n      this.$nextTick(function () {\n        if (searchStr) {\n          this.hoverEmoji(this.filteredEmojis[0], true);\n          this.setupFilteredRefs();\n        }\n      });\n    },\n\n    debounce: function (fn, delay) {\n      if (delay === undefined) { delay = 300; }\n      let timeout;\n      return function () {\n        const args = []; let len = arguments.length;\n        while (len--) args[len] = arguments[len];\n\n        clearTimeout(timeout);\n        timeout = setTimeout(function () {\n          fn.apply(undefined, args);\n        }, delay);\n      };\n    },\n\n    getImgSrc: function (emoji) {\n      // TODO Update json structure to have a property for custom emojis and avoid using date_added\n      if (emoji.date_added) { // if custom emoji\n        return emoji.image;\n      } else { // if regular emoji\n        return this.CDN_URL + emoji.unicode_character + '.png';\n      }\n    },\n\n    handleImageError: function (event) {\n      event.target.parentNode.style.display = 'none';\n    },\n\n    scrollToTab: function (tabIndex, focusFirstEmoji) {\n      const vm = this;\n      if (focusFirstEmoji === undefined) { focusFirstEmoji = true; }\n      const tabElement = vm.tabLabelsRefs[tabIndex - 1].ref[0];\n\n      vm.$nextTick(function () {\n        const container = vm.$refs.listRef;\n        const offsetTop = tabIndex === 1 ? 0 : tabElement.offsetTop - 15;\n\n        container.scrollTop = offsetTop;\n\n        if (focusFirstEmoji) {\n          vm.focusEmoji(tabIndex - 1, 0);\n        }\n      });\n    },\n\n    resetScroll: function () {\n      const container = this.$refs.listRef;\n      container.scrollTop = 0;\n    },\n\n    focusEmojiSelector: function () {\n      this.focusEmoji(0, 0);\n    },\n\n    hoverEmoji (emoji, isFirst) {\n      if (isFirst === undefined) { isFirst = false; }\n      this.hoverFirstEmoji = isFirst;\n      this.$emit('highlighted-emoji', emoji);\n    },\n\n    setEmojiRef: function (el, indexTab, indexEmoji) {\n      if (!this.emojiRefs[indexTab]) {\n        this.$set(this.emojiRefs, indexTab, []);\n      }\n      this.$set(this.emojiRefs[indexTab], indexEmoji, el);\n    },\n\n    setFilteredRef: function (el, index) {\n      this.$set(this.emojiFilteredRefs, index, el);\n    },\n\n    focusEmoji: function (indexTab, indexEmoji) {\n      // eslint-disable-next-line max-len\n      const emojiRef = this.isFiltering ? this.emojiFilteredRefs[indexEmoji]?.[0] : this.emojiRefs[indexTab] && this.emojiRefs[indexTab][indexEmoji];\n      if (emojiRef) {\n        emojiRef.focus();\n        return true;\n      }\n\n      return false;\n    },\n\n    // eslint-disable-next-line complexity\n    handleKeyDown: function (event, indexTab, indexEmoji, emoji) {\n      event.preventDefault();\n\n      if (event.key === 'ArrowUp') {\n        const position = indexEmoji % EMOJIS_PER_ROW;\n\n        if (indexTab === 0) {\n          // we are on the first emoji tab, then we should jump to the last row of the last emoji tab\n          const numberOfMissingEmojis =\n        EMOJIS_PER_ROW - (this.emojiRefs[this.emojiRefs.length - 1].length % EMOJIS_PER_ROW);\n\n          const emojiToJump =\n        this.emojiRefs[this.emojiRefs.length - 1].length + numberOfMissingEmojis - (EMOJIS_PER_ROW - position);\n\n          if (!this.focusEmoji(this.emojiRefs.length - 1, emojiToJump)) {\n            // if there is no emoji in this position, jump to the last emoji of the row\n            this.focusEmoji(this.emojiRefs.length - 1, this.emojiRefs[this.emojiRefs.length - 1].length - 1);\n          }\n          return;\n        }\n\n        // if we are not on the first tab, we should jump to the previous row of the current tab\n        if (!this.focusEmoji(indexTab, indexEmoji - EMOJIS_PER_ROW)) {\n          // if there is no previous row, we should jump to emoji in the sampe position of the previous tab\n          const previousTab = indexTab - 1 < 0 ? 0 : indexTab - 1;\n          const emojisInPreviousTab = this.emojiRefs[previousTab].length;\n          const lastEmojiPosition = emojisInPreviousTab - (emojisInPreviousTab % EMOJIS_PER_ROW) + position;\n\n          if (!this.focusEmoji(previousTab, lastEmojiPosition)) {\n            // if there is no emoji in this position, jump to the last emoji of the row\n            this.focusEmoji(indexTab - 1, this.emojiRefs[indexTab - 1].length - 1);\n          }\n        }\n      }\n\n      if (event.key === 'ArrowDown') {\n        if (!this.focusEmoji(indexTab, indexEmoji + EMOJIS_PER_ROW)) {\n          // if cannot go down\n\n          // Calculate position from cell 0 to cell 8\n          const position = indexEmoji % EMOJIS_PER_ROW;\n\n          // check if it exists a next row in the current tab\n          if (this.emojiRefs?.[indexTab]?.[indexEmoji + (EMOJIS_PER_ROW - position)]) {\n            // if it exists, we should focus the last emoji of the next row in the current tab\n            this.focusEmoji(indexTab, this.emojiRefs[indexTab].length - 1);\n            // if we are at the end of the list it will do nothing\n          } else {\n            // We don't have next row, we are in the last of the tab, then jump\n            // to the next tab but in the equal emoji position in row 0.\n\n            if (!this.focusEmoji(indexTab + 1, position)) {\n              // We are on the bottom!, should jump to the same position emoji in the first row of the first tabset\n              // if it doesn't has, jump to the last\n              if (!this.focusEmoji(0, position)) {\n                this.focusEmoji(0, this.emojiRefs[0].length - 1);\n              }\n            }\n          }\n        }\n      }\n\n      if (event.key === 'ArrowLeft') {\n        this.handleHorizontalNavigation('left', indexTab, indexEmoji);\n      }\n\n      if (event.key === 'ArrowRight') {\n        this.handleHorizontalNavigation('right', indexTab, indexEmoji);\n      }\n\n      if (event.key === 'Tab' && !event.shiftKey) {\n        if (this.focusEmoji(indexTab + 1, 0)) {\n          this.scrollToTab((indexTab + 1) + 1, false);\n        } else {\n          // We are on the last emoji tabset, jump to the skin selector\n          this.$emit('focus-skin-selector');\n        }\n      }\n\n      if (event.key === 'Tab' && event.shiftKey) {\n        if (this.focusEmoji(indexTab, 0) && indexTab > 0) {\n          this.scrollToTab(indexTab, true);\n        } else {\n          this.scrollToTab(1, false);\n          this.$emit('focus-search-input');\n        }\n      }\n\n      if (event.key === 'Enter') {\n        this.handleEmojiSelection(emoji, event);\n      }\n    },\n\n    /* eslint-disable-next-line complexity */\n    handleHorizontalNavigation: function (direction, indexTab, indexEmoji) {\n      if (this.isFiltering) {\n        if (direction === 'left') {\n          this.handleArrowLeftFiltered(indexTab, indexEmoji);\n        } else if (direction === 'right') {\n          this.handleArrowRightFiltered(indexTab, indexEmoji);\n        }\n      } else {\n        if (direction === 'left') {\n          this.handleArrowLeft(indexTab, indexEmoji);\n        } else if (direction === 'right') {\n          this.handleArrowRight(indexTab, indexEmoji);\n        }\n      }\n    },\n\n    handleArrowLeftFiltered: function (indexTab, indexEmoji) {\n      if (!this.focusEmoji(0, indexEmoji - 1)) {\n        this.focusEmoji(0, this.emojiFilteredRefs.length - 1);\n      }\n    },\n\n    handleArrowRightFiltered: function (indexTab, indexEmoji) {\n      if (!this.focusEmoji(0, indexEmoji + 1)) {\n        this.focusEmoji(0, 0);\n      }\n    },\n\n    handleArrowLeft: function (indexTab, indexEmoji) {\n      if (!this.focusEmoji(indexTab, indexEmoji - 1)) {\n        if (this.emojiRefs[indexTab - 1]) {\n          this.focusEmoji(indexTab - 1, this.emojiRefs[indexTab - 1].length - 1);\n        } else {\n          this.focusEmoji(this.emojiRefs.length - 1, this.emojiRefs[this.emojiRefs.length - 1].length - 1);\n        }\n      }\n    },\n\n    handleArrowRight: function (indexTab, indexEmoji) {\n      if (!this.focusEmoji(indexTab, indexEmoji + 1)) {\n        if (!this.focusEmoji(indexTab + 1, 0)) {\n          this.focusEmoji(0, 0);\n        }\n      }\n    },\n\n    handleEmojiSelection (emoji, event) {\n      this.$emit('selected-emoji', { ...emoji, shift_key: event.shiftKey });\n    },\n\n    // @TODO(improvement): Sync with simplified Vue 3 version\n    /* eslint-disable-next-line complexity */\n    handleKeyDownFilteredEmojis (event, indexEmoji, emoji) {\n      event.preventDefault();\n      this.hoverFirstEmoji = false;\n\n      if (event.key === 'ArrowUp') {\n        const position = indexEmoji % EMOJIS_PER_ROW;\n        if (!this.focusEmoji(0, indexEmoji - EMOJIS_PER_ROW)) {\n          const lastEmojiPosition =\n          this.emojiFilteredRefs.length - (this.emojiFilteredRefs.length % EMOJIS_PER_ROW) + position;\n\n          this.focusEmoji(0, lastEmojiPosition);\n\n          if (!this.focusEmoji(0, lastEmojiPosition)) {\n            this.focusEmoji(0, this.emojiFilteredRefs.length - 1);\n          }\n        }\n      }\n\n      if (event.key === 'ArrowDown') {\n        if (!this.focusEmoji(0, indexEmoji + EMOJIS_PER_ROW)) {\n          const position = indexEmoji % EMOJIS_PER_ROW;\n\n          if (this.emojiFilteredRefs?.[indexEmoji + (EMOJIS_PER_ROW - position)]) {\n            this.focusEmoji(0, this.emojiFilteredRefs.length - 1);\n          } else {\n            this.focusEmoji(0, position);\n          }\n        }\n      }\n\n      if (event.key === 'ArrowLeft') {\n        this.handleHorizontalNavigation('left', 0, indexEmoji);\n      }\n\n      if (event.key === 'ArrowRight') {\n        this.handleHorizontalNavigation('right', 0, indexEmoji);\n      }\n\n      if (event.key === 'Tab') {\n        this.$emit('focus-skin-selector');\n      }\n\n      if (event.key === 'Enter') {\n        this.handleEmojiSelection(emoji, event);\n      }\n    },\n\n    setBottomScrollListener () {\n      this.handleScroll = () => {\n        const container = this.$refs.listRef;\n        if (container.scrollTop + container.clientHeight >= container.scrollHeight) {\n          this.$emit('scroll-bottom-reached');\n        }\n      };\n\n      this.$refs.listRef.addEventListener('scroll', this.handleScroll);\n    },\n\n    setTabLabelObserver () {\n      this.tabLabelObserver = new IntersectionObserver(entries => {\n        /* eslint-disable-next-line complexity */\n        entries.forEach(entry => {\n          const { target } = entry;\n          const index = parseInt(target.dataset.index);\n\n          if (entry.isIntersecting && target.offsetTop <= this.$refs.tabCategoryRef?.offsetTop + 50) {\n            this.fixedLabel = this.tabLabels[index - 1]?.label ?? this.tabLabels[0]?.label;\n            this.$emit('scroll-into-tab', index - 1);\n          } else if (entry.boundingClientRect.bottom <= this.$refs.tabCategoryRef?.getBoundingClientRect().bottom) {\n            this.$emit('scroll-into-tab', index);\n            this.fixedLabel = this.tabLabels[index]?.label;\n          } else if (index === 1) {\n            this.$emit('scroll-into-tab', index);\n            this.fixedLabel = this.tabLabels[0]?.label;\n          }\n        });\n      });\n\n      this.tabLabelObserver.observe(this.$refs.tabCategoryRef);\n\n      Array.from(this.$refs.listRef.children).forEach((child, index) => {\n        this.tabLabelObserver.observe(child);\n        child.dataset.index = index;\n      });\n    },\n\n    focusLastEmoji () {\n      this.scrollToTab(this.tabs.length, true);\n    },\n\n  },\n\n};\n</script>\n","<template>\n  <div class=\"d-emoji-picker__data\">\n    <img\n      v-if=\"emoji\"\n      class=\"d-icon d-icon--size-500\"\n      :alt=\"emoji.name\"\n      :aria-label=\"emoji.name\"\n      :title=\"emoji.name\"\n      :src=\"getImgSrc(emoji)\"\n    >\n    <div>{{ emoji?.name }}</div>\n  </div>\n</template>\n\n<script>\nimport { CDN_URL } from '@/components/emoji_picker/emoji_picker_constants';\n\nexport default {\n  name: 'EmojiDescription',\n\n  props: {\n    /**\n     * Emoji data\n     * @type {Object}\n     * @default null\n     */\n    emoji: {\n      type: Object,\n      default: () => null,\n    },\n  },\n\n  data () {\n    return {\n      CDN_URL,\n    };\n  },\n\n  methods: {\n    getImgSrc (emoji) {\n      if (emoji.date_added) { // if custom emoji\n        return emoji.image;\n      } else { // if regular emoji\n        return `${CDN_URL + emoji.unicode_character}.png`;\n      }\n    },\n  },\n};\n</script>\n","<template>\n  <div data-qa=\"skin-selector\">\n    <div\n      v-show=\"isOpen\"\n      class=\"d-emoji-picker__skin-list\"\n    >\n      <button\n        v-for=\"(skin, index) in skinList\"\n        :key=\"skin.name\"\n        :ref=\"`skinRef-${index}`\"\n        :class=\"{\n          'selected': skinSelected?.skinCode === skin.skinCode,\n        }\"\n        @click=\"selectSkin(skin)\"\n        @keydown=\"event => handleKeyDown(event, skin, index)\"\n      >\n        <img\n          class=\"d-icon d-icon--size-500\"\n          :alt=\"skin.name\"\n          :aria-label=\"skin.name\"\n          :title=\"skin.name\"\n          :src=\"`${cdnUrl + skin.unicode_output}.png`\"\n        >\n      </button>\n    </div>\n    <div\n      v-show=\"!isOpen\"\n      class=\"d-emoji-picker__skin-selected\"\n    >\n      <dt-tooltip placement=\"top-end\">\n        {{ skinSelectorButtonTooltipLabel }}\n        <template #anchor>\n          <button\n            ref=\"skinSelectorRef\"\n            :aria-label=\"skinSelectorButtonTooltipLabel\"\n            tabindex=\"-1\"\n            @click=\"toggleSkinList\"\n            @keydown=\"event => handleKeyDown(event)\"\n          >\n            <img\n              class=\"d-icon d-icon--size-500\"\n              :alt=\"skinSelected?.name\"\n              :aria-label=\"skinSelected?.name\"\n              :title=\"skinSelected?.name\"\n              :src=\"`${cdnUrl + skinSelected?.unicode_output}.png`\"\n            >\n          </button>\n        </template>\n      </dt-tooltip>\n    </div>\n  </div>\n</template>\n\n<script>\nimport DtTooltip from '@/components/tooltip/tooltip.vue';\nimport { CDN_URL, EMOJI_PICKER_SKIN_TONE_MODIFIERS } from '@/components/emoji_picker/emoji_picker_constants';\n\nexport default {\n  name: 'EmojiSkinSelector',\n\n  components: {\n    DtTooltip,\n  },\n\n  props: {\n    skinTone: {\n      type: String,\n      required: true,\n    },\n\n    isHovering: {\n      type: Boolean,\n      default: false,\n    },\n\n    skinSelectorButtonTooltipLabel: {\n      type: String,\n      required: true,\n    },\n  },\n\n  data () {\n    return {\n      isOpen: false,\n      skinSelected: null,\n      skinsRef: [],\n      cdnUrl: CDN_URL,\n    };\n  },\n\n  computed: {\n    skinPassedIn () {\n      return this.skinList.find(skin => skin.skinTone === this.skinTone);\n    },\n\n    skinList () {\n      return [\n        {\n          name: ':wave_tone1:',\n          unicode_output: '1f44b-1f3fb',\n          skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.LIGHT,\n          skinCode: '_tone1',\n        },\n        {\n          name: ':wave_tone2:',\n          unicode_output: '1f44b-1f3fc',\n          skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM_LIGHT,\n          skinCode: '_tone2',\n        },\n        {\n          name: ':wave_tone3:',\n          unicode_output: '1f44b-1f3fd',\n          skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM,\n          skinCode: '_tone3',\n        },\n        {\n          name: ':wave_tone4:',\n          unicode_output: '1f44b-1f3fe',\n          skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM_DARK,\n          skinCode: '_tone4',\n        },\n        {\n          name: ':wave_tone5:',\n          unicode_output: '1f44b-1f3ff',\n          skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.DARK,\n          skinCode: '_tone5',\n        },\n        {\n          name: ':wave:',\n          unicode_output: '1f44b',\n          skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.DEFAULT,\n          skinCode: '',\n        },\n      ];\n    },\n  },\n\n  watch: {\n    isHovering (newVal) {\n      if (newVal) {\n        this.isOpen = false;\n      }\n    },\n\n    skinTone (newVal, oldVal) {\n      if (newVal !== oldVal) {\n        this.skinSelected = this.skinPassedIn;\n      }\n    },\n  },\n\n  mounted () {\n    this.skinSelected = this.skinPassedIn;\n    this.$nextTick(() => {\n      this.setupSkinRefs();\n    });\n  },\n\n  methods: {\n    setupSkinRefs () {\n      this.skinList.forEach((skin, index) => {\n        const refKey = `skinRef-${index}`;\n        if (this.$refs[refKey]) {\n          this.$set(this.skinsRef, index, this.$refs[refKey][0]);\n        }\n      });\n    },\n\n    focusSkinSelector () {\n      if (this.$refs.skinSelectorRef) {\n        this.$refs.skinSelectorRef.focus();\n      }\n    },\n\n    selectSkin (skin) {\n      this.skinSelected = skin;\n      this.isOpen = false;\n      this.$emit('skin-tone', skin.skinTone);\n      this.$nextTick(() => {\n        this.focusSkinSelector();\n      });\n    },\n\n    handleKeyDown (event, skin, index) {\n      event.preventDefault();\n\n      if (event.key === 'ArrowLeft') {\n        if (index === 0) this.skinsRef[this.skinsRef.length - 1]?.focus();\n        this.skinsRef[index - 1]?.focus();\n      }\n\n      if (event.key === 'ArrowRight') {\n        if (this.skinsRef.length) this.skinsRef[0]?.focus();\n        this.skinsRef[index + 1]?.focus();\n      }\n\n      if (event.key === 'Enter') {\n        if (skin) { this.selectSkin(skin); } else {\n          this.toggleSkinList();\n        }\n      }\n\n      if (event.key === 'Tab') {\n        if (event.shiftKey) {\n          this.$emit('focus-last-emoji');\n        } else {\n          this.$emit('focus-tabset');\n        }\n      }\n    },\n\n    toggleSkinList () {\n      this.isOpen = !this.isOpen;\n      this.$nextTick(() => {\n        if (this.skinsRef[0]) {\n          this.skinsRef[0].focus();\n        }\n      });\n    },\n  },\n};\n</script>\n","<template>\n  <div\n    class=\"d-emoji-picker\"\n  >\n    <div class=\"d-emoji-picker--header\">\n      <emoji-tabset\n        ref=\"tabsetRef\"\n        :emoji-filter=\"internalSearchQuery\"\n        :show-custom-emojis-tab=\"showCustomEmojisTab\"\n        :show-recently-used-tab=\"showRecentlyUsedTab\"\n        :scroll-into-tab=\"scrollIntoTab\"\n        :tab-set-labels=\"tabSetLabels\"\n        @focus-skin-selector=\"$refs.skinSelectorRef.focusSkinSelector()\"\n        @focus-search-input=\"showSearch\n          ? $refs.searchInputRef.focusSearchInput()\n          : $refs.emojiSelectorRef.focusEmojiSelector()\"\n        @selected-tabset=\"scrollToSelectedTabset\"\n        @keydown.esc.native=\"$emit('close')\"\n      />\n    </div>\n    <div class=\"d-emoji-picker--body\">\n      <emoji-search\n        v-if=\"showSearch\"\n        ref=\"searchInputRef\"\n        :model-value=\"internalSearchQuery\"\n        :search-placeholder-label=\"searchPlaceholderLabel\"\n        @update:model-value=\"newValue => internalSearchQuery = newValue\"\n        @select-first-emoji=\"$emit('selected-emoji', highlightedEmoji)\"\n        @focus-tabset=\"$refs.tabsetRef.focusTabset()\"\n        @focus-emoji-selector=\"$refs.emojiSelectorRef.focusEmojiSelector()\"\n        @keydown.esc.native=\"$emit('close')\"\n      />\n      <emoji-selector\n        ref=\"emojiSelectorRef\"\n        :emoji-filter=\"internalSearchQuery\"\n        :skin-tone=\"skinTone\"\n        :tab-set-labels=\"tabSetLabels\"\n        :search-results-label=\"searchResultsLabel\"\n        :search-no-results-label=\"searchNoResultsLabel\"\n        :recently-used-emojis=\"recentlyUsedEmojis\"\n        :custom-emojis=\"customEmojis\"\n        :selected-tabset=\"selectedTabset\"\n        @scroll-into-tab=\"updateScrollIntoTab\"\n        @highlighted-emoji=\"updateHighlightedEmoji\"\n        @selected-emoji=\"$emit('selected-emoji', $event)\"\n        @focus-skin-selector=\"$refs.skinSelectorRef.focusSkinSelector()\"\n        @focus-search-input=\"showSearch ? $refs.searchInputRef.focusSearchInput() : $refs.tabsetRef.focusTabset()\"\n        @keydown.esc.native=\"$emit('close')\"\n        @scroll-bottom-reached=\"$emit('scroll-bottom-reached')\"\n      />\n    </div>\n    <div class=\"d-emoji-picker--footer\">\n      <dt-button\n        v-if=\"showCustomEmojisTab && !highlightedEmoji\"\n        importance=\"outlined\"\n        :aria-label=\"addEmojiLabel\"\n        class=\"d-emoji-picker__add-emoji\"\n        @click=\"$emit('add-emoji')\"\n      >\n        {{ addEmojiLabel }}\n      </dt-button>\n      <emoji-description :emoji=\"highlightedEmoji\" />\n      <emoji-skin-selector\n        ref=\"skinSelectorRef\"\n        :is-hovering=\"!!highlightedEmoji\"\n        :skin-selector-button-tooltip-label=\"skinSelectorButtonTooltipLabel\"\n        :skin-tone=\"skinTone\"\n        @skin-tone=\"$emit('skin-tone', $event)\"\n        @focus-tabset=\"$refs.tabsetRef.focusTabset()\"\n        @focus-last-emoji=\"$refs.emojiSelectorRef.focusLastEmoji()\"\n        @keydown.esc.native=\"$emit('close')\"\n      />\n    </div>\n  </div>\n</template>\n\n<script>\nimport EmojiTabset from './modules/emoji_tabset.vue';\nimport EmojiSearch from './modules/emoji_search.vue';\nimport EmojiSelector from './modules/emoji_selector.vue';\nimport EmojiDescription from './modules/emoji_description.vue';\nimport EmojiSkinSelector from './modules/emoji_skin_selector.vue';\nimport { DtButton } from '../button';\nimport { DialtoneLocalization } from '@/localization';\n\nexport default {\n  name: 'DtEmojiPicker',\n\n  components: {\n    EmojiTabset,\n    EmojiSearch,\n    EmojiSelector,\n    EmojiDescription,\n    EmojiSkinSelector,\n    DtButton,\n  },\n\n  props: {\n    /**\n     * The array with recently used  emoji object\n     * This list is necessary to fill the recently used tab\n     * @type {Array}\n     * @default []\n     * @example\n     * <dt-emoji-picker :recentlyUsedEmojis=\"[emojiObject, emojiObject]\" />\n     */\n    // TODO try to simplify this to achieve an array of unicode characters and not an entire emoji data object\n    recentlyUsedEmojis: {\n      type: Array,\n      default: () => [],\n    },\n\n    /**\n     * The array with custom emojis object\n     * This list is necessary to fill the custom tab\n     * @type {Array}\n     * @default []\n     * @example\n     * <dt-emoji-picker :customEmojis=\"[emojiObject, emojiObject]\" />\n     */\n    customEmojis: {\n      type: Array,\n    },\n\n    /**\n     * The skin tone to show the emojis\n     * This prop gives the possibility to use the skin tone selected by the user previously\n     * @type {String}\n     * @default 'Default'\n     * @values 'Default', 'Light', 'MediumLight', 'Medium', 'MediumDark', 'Dark'\n     * @example\n     * <dt-emoji-picker :skinTone=\"'Default'\" />\n     */\n    skinTone: {\n      type: String,\n      default: 'Default',\n    },\n\n    /**\n     * Sets the search query that filters emojis.\n     * @type {String}\n     * @example\n     * <dt-emoji-picker search-query=\"smile\" />\n     */\n    searchQuery: {\n      type: String,\n      default: '',\n    },\n\n    /**\n     * Shows the search input\n     * @type {Boolean}\n     * @example\n     * <dt-emoji-picker :show-search=\"false\" />\n     */\n    showSearch: {\n      type: Boolean,\n      default: true,\n    },\n  },\n\n  data () {\n    return {\n      internalSearchQuery: this.searchQuery,\n      highlightedEmoji: null,\n      selectedTabset: {},\n      scrollIntoTab: 0,\n      i18n: new DialtoneLocalization(),\n    };\n  },\n\n  computed: {\n    showCustomEmojisTab () {\n      return this.customEmojis?.length > 0;\n    },\n\n    showRecentlyUsedTab () {\n      return this.recentlyUsedEmojis?.length > 0;\n    },\n\n    tabSetLabels () {\n      return [\n        this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_RECENTLY_USED_LABEL'),\n        this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_SMILEYS_AND_PEOPLE_LABEL'),\n        this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_NATURE_LABEL'),\n        this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_FOOD_LABEL'),\n        this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_ACTIVITY_LABEL'),\n        this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_TRAVEL_LABEL'),\n        this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_OBJECTS_LABEL'),\n        this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_SYMBOLS_LABEL'),\n        this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_FLAGS_LABEL'),\n        this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_CUSTOM_LABEL'),\n      ];\n    },\n\n    searchPlaceholderLabel () {\n      return this.i18n.$t('DIALTONE_EMOJI_PICKER_SEARCH_PLACEHOLDER_LABEL');\n    },\n\n    searchResultsLabel () {\n      return this.i18n.$t('DIALTONE_EMOJI_PICKER_SEARCH_RESULTS_LABEL');\n    },\n\n    searchNoResultsLabel () {\n      return this.i18n.$t('DIALTONE_EMOJI_PICKER_SEARCH_NO_RESULTS_LABEL');\n    },\n\n    skinSelectorButtonTooltipLabel () {\n      return this.i18n.$t('DIALTONE_EMOJI_PICKER_SKIN_SELECTOR_BUTTON_TOOLTIP_LABEL');\n    },\n\n    addEmojiLabel () {\n      return this.i18n.$t('DIALTONE_EMOJI_PICKER_ADD_EMOJI_LABEL');\n    },\n  },\n\n  watch: {\n    searchQuery (value) {\n      this.internalSearchQuery = value;\n    },\n  },\n\n  methods: {\n    scrollToSelectedTabset (tabId) {\n      this.internalSearchQuery = '';\n      this.selectedTabset = { ...this.selectedTabset, tabId };\n    },\n\n    updateScrollIntoTab (value) {\n      this.scrollIntoTab = value;\n    },\n\n    updateHighlightedEmoji (emoji) {\n      this.highlightedEmoji = emoji;\n    },\n  },\n};\n</script>\n"],"names":["_sfc_main","DtTabGroup","DtTab","DtIconClock","DtIconSatisfied","DtIconLivingThing","DtIconFood","DtIconObject","DtIconTransportation","DtIconLightbulb","DtIconHeart","DtIconFlag","DtIconTiktok","tabsData","tab","index","newVal","id","parseId","skin","refKey","event","tabId","DtInput","DtIconSearch","DtIconClose","DtButton","value","emojisImported","CDN_URL","updateTabLabels","label","updateTabsOrder","newValue","newFilter","_a","_","emoji","i","el","indexEmoji","searchStr","obj","nameIncludesSearchStr","keywordsIncludeSearchStr","keyword","fn","delay","timeout","args","len","tabIndex","focusFirstEmoji","vm","tabElement","container","offsetTop","isFirst","indexTab","emojiRef","position","EMOJIS_PER_ROW","numberOfMissingEmojis","emojiToJump","previousTab","emojisInPreviousTab","lastEmojiPosition","_b","direction","entries","entry","target","_c","_d","_e","_f","child","DtTooltip","EMOJI_PICKER_SKIN_TONE_MODIFIERS","oldVal","EmojiTabset","EmojiSearch","EmojiSelector","EmojiDescription","EmojiSkinSelector","DialtoneLocalization"],"mappings":"kfA6CAA,EAAA,CACA,KAAA,cAEA,WAAA,CACA,WAAAC,EAAAA,QACA,MAAAC,EAAAA,OACA,EAEA,MAAA,CAMA,oBAAA,CACA,KAAA,QACA,QAAA,EACA,EAEA,oBAAA,CACA,KAAA,QACA,QAAA,EACA,EAEA,cAAA,CACA,KAAA,OACA,SAAA,EACA,EAEA,YAAA,CACA,KAAA,OACA,QAAA,EACA,EAOA,aAAA,CACA,KAAA,MACA,SAAA,EACA,CACA,EAEA,MAAA,CACA,MAAA,CACA,YAAA,IACA,UAAA,CAAA,EACA,UAAA,CACA,CAAA,MAAA,KAAA,aAAA,CAAA,EAAA,KAAAC,aAAA,EACA,CAAA,MAAA,KAAA,aAAA,CAAA,EAAA,KAAAC,iBAAA,EACA,CAAA,MAAA,KAAA,aAAA,CAAA,EAAA,KAAAC,mBAAA,EACA,CAAA,MAAA,KAAA,aAAA,CAAA,EAAA,KAAAC,YAAA,EACA,CAAA,MAAA,KAAA,aAAA,CAAA,EAAA,KAAAC,cAAA,EACA,CAAA,MAAA,KAAA,aAAA,CAAA,EAAA,KAAAC,sBAAA,EACA,CAAA,MAAA,KAAA,aAAA,CAAA,EAAA,KAAAC,iBAAA,EACA,CAAA,MAAA,KAAA,aAAA,CAAA,EAAA,KAAAC,aAAA,EACA,CAAA,MAAA,KAAA,aAAA,CAAA,EAAA,KAAAC,YAAA,EACA,CAAA,MAAA,KAAA,aAAA,CAAA,EAAA,KAAAC,cAAA,CACA,CACA,CACA,EAEA,SAAA,CACA,MAAA,CAEA,MAAAC,EAAA,KAAA,oBAAA,KAAA,UAAA,KAAA,UAAA,MAAA,CAAA,EAEA,OAAA,KAAA,qBACAA,EAAA,IAAA,EAGAA,EAAA,IAAA,CAAAC,EAAAC,KAAA,CACA,GAAAD,EAEA,IAAAC,EAAA,GAAA,SAAA,EACA,SAAAA,EAAA,GAAA,SAAA,CACA,EAAA,CACA,EAEA,aAAA,CACA,OAAA,KAAA,YAAA,OAAA,CACA,CACA,EAEA,MAAA,CACA,cAAA,SAAAC,EAAA,CACA,KAAA,cACA,KAAA,aAAAA,EAAA,GAAA,SAAA,EAEA,EAEA,YAAA,SAAAA,EAAA,CACAA,IACA,KAAA,YAAA,KAEA,CACA,EAEA,SAAA,CACA,KAAA,UAAA,IAAA,CACA,KAAA,aAAA,CACA,CAAA,CACA,EAEA,QAAA,CACA,aAAAC,EAAA,CAEA,MAAAC,EAAA,SAAAD,CAAA,EAEA,KAAA,YAAAA,EACA,KAAA,MAAA,kBAAAC,CAAA,CACA,EAEA,cAAA,CACA,KAAA,KAAA,QAAA,CAAAC,EAAAJ,IAAA,CACA,MAAAK,EAAA,aAAAL,CAAA,GACA,KAAA,MAAAK,CAAA,GACA,KAAA,KAAA,KAAA,UAAAL,EAAA,KAAA,MAAAK,CAAA,EAAA,CAAA,EAAA,GAAA,CAEA,CAAA,CACA,EAEA,aAAA,CACA,KAAA,UAAA,CAAA,GACA,KAAA,UAAA,CAAA,EAAA,MAAA,CAEA,EAGA,cAAAC,EAAAC,EAAA,CACAD,EAAA,MAAA,UACA,KAAA,aAAAC,CAAA,EACA,KAAA,UAAAA,EAAA,CAAA,GACA,KAAA,UAAAA,EAAA,CAAA,EAAA,KAAA,GAIAD,EAAA,MAAA,QACAA,EAAA,eAAA,EACAA,EAAA,SACA,KAAA,MAAA,qBAAA,EAEA,KAAA,MAAA,oBAAA,GAIAA,EAAA,MAAA,aACA,KAAA,MAAA,oBAAA,CAEA,CACA,CACA,0qBCzJArB,EAAA,CACA,KAAA,cAEA,WAAA,CACA,QAAAuB,EAAAA,QACA,aAAAC,EAAAA,aACA,YAAAC,EAAAA,YACA,SAAAC,EAAAA,OACA,EAEA,MAAA,CACA,uBAAA,CACA,KAAA,OACA,SAAA,EACA,EAEA,WAAA,CACA,KAAA,OACA,QAAA,EACA,CACA,EAEA,SAAA,CACA,KAAA,iBAAA,CACA,EAEA,QAAA,CACA,iBAAAC,EAAA,CACA,KAAA,MAAA,qBAAAA,CAAA,CACA,EAEA,oBAAA,CACA,KAAA,MAAA,sBAAA,CACA,EAEA,aAAA,CACA,KAAA,MAAA,cAAA,CACA,EAEA,kBAAA,CACA,KAAA,MAAA,oBAAA,CACA,EAEA,aAAA,CACA,KAAA,MAAA,qBAAA,EAAA,EACA,KAAA,iBAAA,CACA,EAEA,kBAAA,CACA,KAAA,MAAA,eAAA,MAAA,CACA,CACA,CACA,gsCCWA3B,EAAA,CACA,KAAA,gBAEA,MAAA,CACA,YAAA,CACA,KAAA,OACA,QAAA,EACA,EAEA,SAAA,CACA,KAAA,OACA,SAAA,EACA,EAEA,aAAA,CACA,KAAA,MACA,SAAA,EACA,EAEA,eAAA,CACA,KAAA,OACA,SAAA,EACA,EAEA,mBAAA,CACA,KAAA,OACA,SAAA,EACA,EAEA,qBAAA,CACA,KAAA,OACA,SAAA,EACA,EAEA,mBAAA,CACA,KAAA,MACA,QAAA,IAAA,CAAA,CACA,EAEA,aAAA,CACA,KAAA,MACA,QAAA,IAAA,CAAA,CACA,CACA,EAEA,MAAA,CACA,MAAA,CACA,cAAA,CAAA,EACA,UAAA,CAAA,EACA,kBAAA,CAAA,EACA,YAAA,GACA,gBAAA,GACA,WAAA,GACA,eAAA,CAAA,EACA,UAAA,CAAA,gBAAA,SAAA,SAAA,OAAA,WAAA,SAAA,UAAA,UAAA,QAAA,QAAA,EACA,iBAAA,IACA,CACA,EAEA,SAAA,CAEA,eAAA,CACA,MAAA,CACA,GAAA,KAAA,OAAA,SAAA,KAAA,QAAA,EAAA,GAAA,CAAA,EACA,GAAA,KAAA,OAAA,QAAA,CAAA,EACA,GAAA,KAAA,OAAA,MAAA,CAAA,EACA,GAAA,KAAA,OAAA,WAAA,KAAA,QAAA,EAAA,GAAA,CAAA,EACA,GAAA,KAAA,OAAA,QAAA,CAAA,EACA,GAAA,KAAA,OAAA,UAAA,KAAA,QAAA,EAAA,GAAA,CAAA,EACA,GAAA,KAAA,OAAA,SAAA,CAAA,EACA,GAAA,KAAA,OAAA,OAAA,CAAA,CACA,CACA,EAEA,QAAA,CACA,OAAA4B,EAAAA,aACA,EAEA,SAAA,CACA,OAAAC,EAAAA,OACA,EAEA,WAAA,CACA,IAAAC,EAAA,KAAA,aAAA,IAAAC,IAAA,CAAA,MAAAA,CAAA,EAAA,EAEA,OAAA,KAAA,mBAAA,SACAD,EAAA,KAAA,aAAA,MAAA,CAAA,EAAA,IAAAC,IAAA,CAAA,MAAAA,CAAA,EAAA,GAGA,KAAA,aAAA,QACAD,EAAA,IAAA,EAGAA,CACA,EAEA,MAAA,CACA,MAAAE,EAAA,KAAA,mBAAA,OAAA,KAAA,UAAA,MAAA,EAAA,KAAA,UAAA,MAAA,CAAA,EAEA,OAAA,KAAA,aAAA,QACAA,EAAA,IAAA,EAGAA,CACA,CACA,EAEA,MAAA,CACA,cAAA,CACA,SAAA,CACA,KAAA,wBAAA,CACA,EAEA,UAAA,EACA,EAEA,mBAAA,CACA,QAAAC,EAAA,CACA,KAAA,OAAA,eAAA,EAAAA,CACA,EAEA,UAAA,EACA,EAEA,aAAA,CACA,QAAAA,EAAA,CACA,KAAA,OAAA,OAAAA,CACA,EAEA,UAAA,EACA,EAEA,YAAA,CACA,QAAAC,EAAA,CACA,KAAA,YAAA,EACAA,EACA,KAAA,YAAA,IAEA,KAAA,YAAA,GACA,KAAA,MAAA,oBAAA,IAAA,GAGA,KAAA,gBAAA,CACA,CACA,EAEA,eAAA,CACA,QAAAD,EAAA,CACA,KAAA,YAAAA,EAAA,KAAA,CACA,EAEA,KAAA,EACA,CACA,EAEA,SAAA,CACA,KAAA,gBAAA,KAAA,SAAA,KAAA,wBAAA,GAAA,CACA,EAEA,SAAA,CACA,KAAA,UAAA,IAAA,CACA,KAAA,eAAA,EACA,KAAA,kBAAA,EACA,KAAA,kBAAA,EACA,KAAA,oBAAA,EACA,KAAA,wBAAA,CACA,CAAA,CACA,EAEA,eAAA,CACA,KAAA,kBACA,KAAA,iBAAA,WAAA,EAGA,KAAA,MAAA,SAAA,KAAA,cACA,KAAA,MAAA,QAAA,oBAAA,SAAA,KAAA,YAAA,CAEA,EAEA,QAAA,CACA,mBAAA,QACAE,EAAA,KAAA,eAAA,MAAAA,EAAA,QAAA,CAAAC,EAAArB,IAAA,CACA,MAAAK,EAAA,eAAAL,CAAA,GACA,KAAA,MAAAK,CAAA,GACA,KAAA,KAAA,KAAA,cAAAL,EAAA,CAAA,IAAA,KAAA,MAAAK,CAAA,EAAA,CAEA,EACA,EAEA,mBAAA,CAEA,KAAA,kBAAA,CAAA,EAEA,KAAA,eAAA,QAAA,CAAAiB,EAAAtB,IAAA,CACA,MAAAK,EAAA,iBAAAL,CAAA,GACA,KAAA,MAAAK,CAAA,GACA,KAAA,eAAA,KAAA,MAAAA,CAAA,EAAAL,CAAA,CAEA,CAAA,CACA,EAEA,gBAAA,CACA,QAAAuB,EAAA,EAAAA,EAAA,KAAA,KAAA,OAAAA,IAAA,CACA,MAAAlB,EAAA,YAAAkB,CAAA,GACA,KAAA,MAAAlB,CAAA,GACA,KAAA,MAAAA,CAAA,EAAA,QAAA,CAAAmB,EAAAC,IAAA,CACAD,GACA,KAAA,YAAAA,EAAAD,EAAAE,CAAA,CAEA,CAAA,CAEA,CACA,EAEA,yBAAA,CACA,MAAAC,EAAA,KAAA,YAAA,YAAA,EACA,KAAA,eAAA,KAAA,cAAA,OAAA,SAAAC,EAAA,CACA,MAAAC,EAAAD,EAAA,KAAA,YAAA,EAAA,SAAAD,CAAA,EACAG,EAAAF,EAAA,SAAA,KAAA,SAAAG,EAAA,CACA,OAAAA,EAAA,cAAA,SAAAJ,CAAA,CACA,CAAA,EACA,OAAAE,GAAAC,CACA,CAAA,EACA,KAAA,UAAA,UAAA,CACAH,IACA,KAAA,WAAA,KAAA,eAAA,CAAA,EAAA,EAAA,EACA,KAAA,kBAAA,EAEA,CAAA,CACA,EAEA,SAAA,SAAAK,EAAAC,EAAA,CACAA,IAAA,SAAAA,EAAA,KACA,IAAAC,EACA,OAAA,UAAA,CACA,MAAAC,EAAA,CAAA,EAAA,IAAAC,EAAA,UAAA,OACA,KAAAA,KAAAD,EAAAC,CAAA,EAAA,UAAAA,CAAA,EAEA,aAAAF,CAAA,EACAA,EAAA,WAAA,UAAA,CACAF,EAAA,MAAA,OAAAG,CAAA,CACA,EAAAF,CAAA,CACA,CACA,EAEA,UAAA,SAAAV,EAAA,CAEA,OAAAA,EAAA,WACAA,EAAA,MAEA,KAAA,QAAAA,EAAA,kBAAA,MAEA,EAEA,iBAAA,SAAAhB,EAAA,CACAA,EAAA,OAAA,WAAA,MAAA,QAAA,MACA,EAEA,YAAA,SAAA8B,EAAAC,EAAA,CACA,MAAAC,EAAA,KACAD,IAAA,SAAAA,EAAA,IACA,MAAAE,EAAAD,EAAA,cAAAF,EAAA,CAAA,EAAA,IAAA,CAAA,EAEAE,EAAA,UAAA,UAAA,CACA,MAAAE,EAAAF,EAAA,MAAA,QACAG,EAAAL,IAAA,EAAA,EAAAG,EAAA,UAAA,GAEAC,EAAA,UAAAC,EAEAJ,GACAC,EAAA,WAAAF,EAAA,EAAA,CAAA,CAEA,CAAA,CACA,EAEA,YAAA,UAAA,CACA,MAAAI,EAAA,KAAA,MAAA,QACAA,EAAA,UAAA,CACA,EAEA,mBAAA,UAAA,CACA,KAAA,WAAA,EAAA,CAAA,CACA,EAEA,WAAAlB,EAAAoB,EAAA,CACAA,IAAA,SAAAA,EAAA,IACA,KAAA,gBAAAA,EACA,KAAA,MAAA,oBAAApB,CAAA,CACA,EAEA,YAAA,SAAAE,EAAAmB,EAAAlB,EAAA,CACA,KAAA,UAAAkB,CAAA,GACA,KAAA,KAAA,KAAA,UAAAA,EAAA,CAAA,CAAA,EAEA,KAAA,KAAA,KAAA,UAAAA,CAAA,EAAAlB,EAAAD,CAAA,CACA,EAEA,eAAA,SAAAA,EAAAxB,EAAA,CACA,KAAA,KAAA,KAAA,kBAAAA,EAAAwB,CAAA,CACA,EAEA,WAAA,SAAAmB,EAAAlB,EAAA,OAEA,MAAAmB,EAAA,KAAA,aAAAxB,EAAA,KAAA,kBAAAK,CAAA,IAAA,YAAAL,EAAA,GAAA,KAAA,UAAAuB,CAAA,GAAA,KAAA,UAAAA,CAAA,EAAAlB,CAAA,EACA,OAAAmB,GACAA,EAAA,MAAA,EACA,IAGA,EACA,EAGA,cAAA,SAAAtC,EAAAqC,EAAAlB,EAAAH,EAAA,SAGA,GAFAhB,EAAA,eAAA,EAEAA,EAAA,MAAA,UAAA,CACA,MAAAuC,EAAApB,EAAAqB,EAAAA,eAEA,GAAAH,IAAA,EAAA,CAEA,MAAAI,EACAD,iBAAA,KAAA,UAAA,KAAA,UAAA,OAAA,CAAA,EAAA,OAAAA,iBAEAE,EACA,KAAA,UAAA,KAAA,UAAA,OAAA,CAAA,EAAA,OAAAD,GAAAD,EAAAA,eAAAD,GAEA,KAAA,WAAA,KAAA,UAAA,OAAA,EAAAG,CAAA,GAEA,KAAA,WAAA,KAAA,UAAA,OAAA,EAAA,KAAA,UAAA,KAAA,UAAA,OAAA,CAAA,EAAA,OAAA,CAAA,EAEA,MACA,CAGA,GAAA,CAAA,KAAA,WAAAL,EAAAlB,EAAAqB,EAAAA,cAAA,EAAA,CAEA,MAAAG,EAAAN,EAAA,EAAA,EAAA,EAAAA,EAAA,EACAO,EAAA,KAAA,UAAAD,CAAA,EAAA,OACAE,EAAAD,EAAAA,EAAAJ,EAAAA,eAAAD,EAEA,KAAA,WAAAI,EAAAE,CAAA,GAEA,KAAA,WAAAR,EAAA,EAAA,KAAA,UAAAA,EAAA,CAAA,EAAA,OAAA,CAAA,CAEA,CACA,CAEA,GAAArC,EAAA,MAAA,aACA,CAAA,KAAA,WAAAqC,EAAAlB,EAAAqB,EAAAA,cAAA,EAAA,CAIA,MAAAD,EAAApB,EAAAqB,EAAAA,gBAGAM,GAAAhC,EAAA,KAAA,YAAA,YAAAA,EAAAuB,KAAA,MAAAS,EAAA3B,GAAAqB,EAAAA,eAAAD,IAEA,KAAA,WAAAF,EAAA,KAAA,UAAAA,CAAA,EAAA,OAAA,CAAA,EAMA,KAAA,WAAAA,EAAA,EAAAE,CAAA,GAGA,KAAA,WAAA,EAAAA,CAAA,GACA,KAAA,WAAA,EAAA,KAAA,UAAA,CAAA,EAAA,OAAA,CAAA,CAIA,CAGAvC,EAAA,MAAA,aACA,KAAA,2BAAA,OAAAqC,EAAAlB,CAAA,EAGAnB,EAAA,MAAA,cACA,KAAA,2BAAA,QAAAqC,EAAAlB,CAAA,EAGAnB,EAAA,MAAA,OAAA,CAAAA,EAAA,WACA,KAAA,WAAAqC,EAAA,EAAA,CAAA,EACA,KAAA,YAAAA,EAAA,EAAA,EAAA,EAAA,EAGA,KAAA,MAAA,qBAAA,GAIArC,EAAA,MAAA,OAAAA,EAAA,WACA,KAAA,WAAAqC,EAAA,CAAA,GAAAA,EAAA,EACA,KAAA,YAAAA,EAAA,EAAA,GAEA,KAAA,YAAA,EAAA,EAAA,EACA,KAAA,MAAA,oBAAA,IAIArC,EAAA,MAAA,SACA,KAAA,qBAAAgB,EAAAhB,CAAA,CAEA,EAGA,2BAAA,SAAA+C,EAAAV,EAAAlB,EAAA,CACA,KAAA,YACA4B,IAAA,OACA,KAAA,wBAAAV,EAAAlB,CAAA,EACA4B,IAAA,SACA,KAAA,yBAAAV,EAAAlB,CAAA,EAGA4B,IAAA,OACA,KAAA,gBAAAV,EAAAlB,CAAA,EACA4B,IAAA,SACA,KAAA,iBAAAV,EAAAlB,CAAA,CAGA,EAEA,wBAAA,SAAAkB,EAAAlB,EAAA,CACA,KAAA,WAAA,EAAAA,EAAA,CAAA,GACA,KAAA,WAAA,EAAA,KAAA,kBAAA,OAAA,CAAA,CAEA,EAEA,yBAAA,SAAAkB,EAAAlB,EAAA,CACA,KAAA,WAAA,EAAAA,EAAA,CAAA,GACA,KAAA,WAAA,EAAA,CAAA,CAEA,EAEA,gBAAA,SAAAkB,EAAAlB,EAAA,CACA,KAAA,WAAAkB,EAAAlB,EAAA,CAAA,IACA,KAAA,UAAAkB,EAAA,CAAA,EACA,KAAA,WAAAA,EAAA,EAAA,KAAA,UAAAA,EAAA,CAAA,EAAA,OAAA,CAAA,EAEA,KAAA,WAAA,KAAA,UAAA,OAAA,EAAA,KAAA,UAAA,KAAA,UAAA,OAAA,CAAA,EAAA,OAAA,CAAA,EAGA,EAEA,iBAAA,SAAAA,EAAAlB,EAAA,CACA,KAAA,WAAAkB,EAAAlB,EAAA,CAAA,GACA,KAAA,WAAAkB,EAAA,EAAA,CAAA,GACA,KAAA,WAAA,EAAA,CAAA,CAGA,EAEA,qBAAArB,EAAAhB,EAAA,CACA,KAAA,MAAA,iBAAA,CAAA,GAAAgB,EAAA,UAAAhB,EAAA,SAAA,CACA,EAIA,4BAAAA,EAAAmB,EAAAH,EAAA,OAIA,GAHAhB,EAAA,eAAA,EACA,KAAA,gBAAA,GAEAA,EAAA,MAAA,UAAA,CACA,MAAAuC,EAAApB,EAAAqB,EAAAA,eACA,GAAA,CAAA,KAAA,WAAA,EAAArB,EAAAqB,EAAAA,cAAA,EAAA,CACA,MAAAK,EACA,KAAA,kBAAA,OAAA,KAAA,kBAAA,OAAAL,EAAAA,eAAAD,EAEA,KAAA,WAAA,EAAAM,CAAA,EAEA,KAAA,WAAA,EAAAA,CAAA,GACA,KAAA,WAAA,EAAA,KAAA,kBAAA,OAAA,CAAA,CAEA,CACA,CAEA,GAAA7C,EAAA,MAAA,aACA,CAAA,KAAA,WAAA,EAAAmB,EAAAqB,EAAAA,cAAA,EAAA,CACA,MAAAD,EAAApB,EAAAqB,EAAAA,gBAEA1B,EAAA,KAAA,oBAAA,MAAAA,EAAAK,GAAAqB,EAAAA,eAAAD,IACA,KAAA,WAAA,EAAA,KAAA,kBAAA,OAAA,CAAA,EAEA,KAAA,WAAA,EAAAA,CAAA,CAEA,CAGAvC,EAAA,MAAA,aACA,KAAA,2BAAA,OAAA,EAAAmB,CAAA,EAGAnB,EAAA,MAAA,cACA,KAAA,2BAAA,QAAA,EAAAmB,CAAA,EAGAnB,EAAA,MAAA,OACA,KAAA,MAAA,qBAAA,EAGAA,EAAA,MAAA,SACA,KAAA,qBAAAgB,EAAAhB,CAAA,CAEA,EAEA,yBAAA,CACA,KAAA,aAAA,IAAA,CACA,MAAAkC,EAAA,KAAA,MAAA,QACAA,EAAA,UAAAA,EAAA,cAAAA,EAAA,cACA,KAAA,MAAA,uBAAA,CAEA,EAEA,KAAA,MAAA,QAAA,iBAAA,SAAA,KAAA,YAAA,CACA,EAEA,qBAAA,CACA,KAAA,iBAAA,IAAA,qBAAAc,GAAA,CAEAA,EAAA,QAAAC,GAAA,iBACA,KAAA,CAAA,OAAAC,CAAA,EAAAD,EACAvD,EAAA,SAAAwD,EAAA,QAAA,KAAA,EAEAD,EAAA,gBAAAC,EAAA,aAAApC,EAAA,KAAA,MAAA,iBAAA,YAAAA,EAAA,WAAA,IACA,KAAA,aAAAgC,EAAA,KAAA,UAAApD,EAAA,CAAA,IAAA,YAAAoD,EAAA,UAAAK,EAAA,KAAA,UAAA,CAAA,IAAA,YAAAA,EAAA,OACA,KAAA,MAAA,kBAAAzD,EAAA,CAAA,GACAuD,EAAA,mBAAA,UAAAG,EAAA,KAAA,MAAA,iBAAA,YAAAA,EAAA,wBAAA,SACA,KAAA,MAAA,kBAAA1D,CAAA,EACA,KAAA,YAAA2D,EAAA,KAAA,UAAA3D,CAAA,IAAA,YAAA2D,EAAA,OACA3D,IAAA,IACA,KAAA,MAAA,kBAAAA,CAAA,EACA,KAAA,YAAA4D,EAAA,KAAA,UAAA,CAAA,IAAA,YAAAA,EAAA,MAEA,CAAA,CACA,CAAA,EAEA,KAAA,iBAAA,QAAA,KAAA,MAAA,cAAA,EAEA,MAAA,KAAA,KAAA,MAAA,QAAA,QAAA,EAAA,QAAA,CAAAC,EAAA7D,IAAA,CACA,KAAA,iBAAA,QAAA6D,CAAA,EACAA,EAAA,QAAA,MAAA7D,CACA,CAAA,CACA,EAEA,gBAAA,CACA,KAAA,YAAA,KAAA,KAAA,OAAA,EAAA,CACA,CAEA,CAEA,+0ECloBAf,EAAA,CACA,KAAA,mBAEA,MAAA,CAMA,MAAA,CACA,KAAA,OACA,QAAA,IAAA,IACA,CACA,EAEA,MAAA,CACA,MAAA,CACA,QAAA6B,EAAAA,OACA,CACA,EAEA,QAAA,CACA,UAAAQ,EAAA,CACA,OAAAA,EAAA,WACAA,EAAA,MAEA,GAAAR,EAAAA,QAAAQ,EAAA,iBAAA,MAEA,CACA,CACA,mWCUArC,EAAA,CACA,KAAA,oBAEA,WAAA,CACA,UAAA6E,EAAAA,OACA,EAEA,MAAA,CACA,SAAA,CACA,KAAA,OACA,SAAA,EACA,EAEA,WAAA,CACA,KAAA,QACA,QAAA,EACA,EAEA,+BAAA,CACA,KAAA,OACA,SAAA,EACA,CACA,EAEA,MAAA,CACA,MAAA,CACA,OAAA,GACA,aAAA,KACA,SAAA,CAAA,EACA,OAAAhD,EAAAA,OACA,CACA,EAEA,SAAA,CACA,cAAA,CACA,OAAA,KAAA,SAAA,KAAAV,GAAAA,EAAA,WAAA,KAAA,QAAA,CACA,EAEA,UAAA,CACA,MAAA,CACA,CACA,KAAA,eACA,eAAA,cACA,SAAA2D,EAAAA,iCAAA,MACA,SAAA,QACA,EACA,CACA,KAAA,eACA,eAAA,cACA,SAAAA,EAAAA,iCAAA,aACA,SAAA,QACA,EACA,CACA,KAAA,eACA,eAAA,cACA,SAAAA,EAAAA,iCAAA,OACA,SAAA,QACA,EACA,CACA,KAAA,eACA,eAAA,cACA,SAAAA,EAAAA,iCAAA,YACA,SAAA,QACA,EACA,CACA,KAAA,eACA,eAAA,cACA,SAAAA,EAAAA,iCAAA,KACA,SAAA,QACA,EACA,CACA,KAAA,SACA,eAAA,QACA,SAAAA,EAAAA,iCAAA,QACA,SAAA,EACA,CACA,CACA,CACA,EAEA,MAAA,CACA,WAAA9D,EAAA,CACAA,IACA,KAAA,OAAA,GAEA,EAEA,SAAAA,EAAA+D,EAAA,CACA/D,IAAA+D,IACA,KAAA,aAAA,KAAA,aAEA,CACA,EAEA,SAAA,CACA,KAAA,aAAA,KAAA,aACA,KAAA,UAAA,IAAA,CACA,KAAA,cAAA,CACA,CAAA,CACA,EAEA,QAAA,CACA,eAAA,CACA,KAAA,SAAA,QAAA,CAAA5D,EAAAJ,IAAA,CACA,MAAAK,EAAA,WAAAL,CAAA,GACA,KAAA,MAAAK,CAAA,GACA,KAAA,KAAA,KAAA,SAAAL,EAAA,KAAA,MAAAK,CAAA,EAAA,CAAA,CAAA,CAEA,CAAA,CACA,EAEA,mBAAA,CACA,KAAA,MAAA,iBACA,KAAA,MAAA,gBAAA,MAAA,CAEA,EAEA,WAAAD,EAAA,CACA,KAAA,aAAAA,EACA,KAAA,OAAA,GACA,KAAA,MAAA,YAAAA,EAAA,QAAA,EACA,KAAA,UAAA,IAAA,CACA,KAAA,kBAAA,CACA,CAAA,CACA,EAEA,cAAAE,EAAAF,EAAAJ,EAAA,aACAM,EAAA,eAAA,EAEAA,EAAA,MAAA,cACAN,IAAA,KAAAoB,EAAA,KAAA,SAAA,KAAA,SAAA,OAAA,CAAA,IAAA,MAAAA,EAAA,UACAgC,EAAA,KAAA,SAAApD,EAAA,CAAA,IAAA,MAAAoD,EAAA,SAGA9C,EAAA,MAAA,eACA,KAAA,SAAA,UAAAmD,EAAA,KAAA,SAAA,CAAA,IAAA,MAAAA,EAAA,UACAC,EAAA,KAAA,SAAA1D,EAAA,CAAA,IAAA,MAAA0D,EAAA,SAGApD,EAAA,MAAA,UACAF,EAAA,KAAA,WAAAA,CAAA,EACA,KAAA,eAAA,GAIAE,EAAA,MAAA,QACAA,EAAA,SACA,KAAA,MAAA,kBAAA,EAEA,KAAA,MAAA,cAAA,EAGA,EAEA,gBAAA,CACA,KAAA,OAAA,CAAA,KAAA,OACA,KAAA,UAAA,IAAA,CACA,KAAA,SAAA,CAAA,GACA,KAAA,SAAA,CAAA,EAAA,MAAA,CAEA,CAAA,CACA,CACA,CACA,24CCvIArB,EAAA,CACA,KAAA,gBAEA,WAAA,CACA,YAAAgF,EACA,YAAAC,EACA,cAAAC,EACA,iBAAAC,EACA,kBAAAC,EACA,SAAA1D,EAAAA,OACA,EAEA,MAAA,CAUA,mBAAA,CACA,KAAA,MACA,QAAA,IAAA,CAAA,CACA,EAUA,aAAA,CACA,KAAA,KACA,EAWA,SAAA,CACA,KAAA,OACA,QAAA,SACA,EAQA,YAAA,CACA,KAAA,OACA,QAAA,EACA,EAQA,WAAA,CACA,KAAA,QACA,QAAA,EACA,CACA,EAEA,MAAA,CACA,MAAA,CACA,oBAAA,KAAA,YACA,iBAAA,KACA,eAAA,CAAA,EACA,cAAA,EACA,KAAA,IAAA2D,EAAAA,oBACA,CACA,EAEA,SAAA,CACA,qBAAA,OACA,QAAAlD,EAAA,KAAA,eAAA,YAAAA,EAAA,QAAA,CACA,EAEA,qBAAA,OACA,QAAAA,EAAA,KAAA,qBAAA,YAAAA,EAAA,QAAA,CACA,EAEA,cAAA,CACA,MAAA,CACA,KAAA,KAAA,GAAA,kDAAA,EACA,KAAA,KAAA,GAAA,uDAAA,EACA,KAAA,KAAA,GAAA,2CAAA,EACA,KAAA,KAAA,GAAA,yCAAA,EACA,KAAA,KAAA,GAAA,6CAAA,EACA,KAAA,KAAA,GAAA,2CAAA,EACA,KAAA,KAAA,GAAA,4CAAA,EACA,KAAA,KAAA,GAAA,4CAAA,EACA,KAAA,KAAA,GAAA,0CAAA,EACA,KAAA,KAAA,GAAA,2CAAA,CACA,CACA,EAEA,wBAAA,CACA,OAAA,KAAA,KAAA,GAAA,gDAAA,CACA,EAEA,oBAAA,CACA,OAAA,KAAA,KAAA,GAAA,4CAAA,CACA,EAEA,sBAAA,CACA,OAAA,KAAA,KAAA,GAAA,+CAAA,CACA,EAEA,gCAAA,CACA,OAAA,KAAA,KAAA,GAAA,0DAAA,CACA,EAEA,eAAA,CACA,OAAA,KAAA,KAAA,GAAA,uCAAA,CACA,CACA,EAEA,MAAA,CACA,YAAAR,EAAA,CACA,KAAA,oBAAAA,CACA,CACA,EAEA,QAAA,CACA,uBAAAL,EAAA,CACA,KAAA,oBAAA,GACA,KAAA,eAAA,CAAA,GAAA,KAAA,eAAA,MAAAA,CAAA,CACA,EAEA,oBAAAK,EAAA,CACA,KAAA,cAAAA,CACA,EAEA,uBAAAU,EAAA,CACA,KAAA,iBAAAA,CACA,CACA,CACA"}