@dialpad/dialtone 9.123.1 → 9.123.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (331) hide show
  1. package/dist/css/dialtone-default-theme.css +50 -28
  2. package/dist/css/dialtone-default-theme.min.css +1 -1
  3. package/dist/css/dialtone-docs.json +1 -1
  4. package/dist/css/dialtone.css +50 -28
  5. package/dist/css/dialtone.min.css +1 -1
  6. package/dist/tokens/doc.json +17362 -17362
  7. package/dist/vue2/_plugin-vue2_normalizer-DSLOjnn3.js +11 -0
  8. package/dist/vue2/_plugin-vue2_normalizer-DSLOjnn3.js.map +1 -0
  9. package/dist/vue2/_plugin-vue2_normalizer-e_CkxkSV.cjs +2 -0
  10. package/dist/vue2/_plugin-vue2_normalizer-e_CkxkSV.cjs.map +1 -0
  11. package/dist/vue2/lib/attachment-carousel/attachment-carousel.cjs +1 -1
  12. package/dist/vue2/lib/attachment-carousel/attachment-carousel.cjs.map +1 -1
  13. package/dist/vue2/lib/attachment-carousel/attachment-carousel.js +8 -17
  14. package/dist/vue2/lib/attachment-carousel/attachment-carousel.js.map +1 -1
  15. package/dist/vue2/lib/avatar/avatar.cjs +1 -1
  16. package/dist/vue2/lib/avatar/avatar.js +2 -5
  17. package/dist/vue2/lib/avatar/avatar.js.map +1 -1
  18. package/dist/vue2/lib/badge/badge.cjs +1 -1
  19. package/dist/vue2/lib/badge/badge.js +4 -7
  20. package/dist/vue2/lib/badge/badge.js.map +1 -1
  21. package/dist/vue2/lib/banner/banner.cjs +2 -2
  22. package/dist/vue2/lib/banner/banner.js +6 -9
  23. package/dist/vue2/lib/banner/banner.js.map +1 -1
  24. package/dist/vue2/lib/breadcrumbs/breadcrumb-item.cjs +1 -1
  25. package/dist/vue2/lib/breadcrumbs/breadcrumb-item.js +4 -7
  26. package/dist/vue2/lib/breadcrumbs/breadcrumb-item.js.map +1 -1
  27. package/dist/vue2/lib/breadcrumbs/breadcrumbs.cjs +1 -1
  28. package/dist/vue2/lib/breadcrumbs/breadcrumbs.js +2 -5
  29. package/dist/vue2/lib/breadcrumbs/breadcrumbs.js.map +1 -1
  30. package/dist/vue2/lib/button/button.cjs +1 -1
  31. package/dist/vue2/lib/button/button.js +2 -5
  32. package/dist/vue2/lib/button/button.js.map +1 -1
  33. package/dist/vue2/lib/button-group/button-group.cjs +1 -1
  34. package/dist/vue2/lib/button-group/button-group.js +8 -11
  35. package/dist/vue2/lib/button-group/button-group.js.map +1 -1
  36. package/dist/vue2/lib/button-group/buttons-decorator.cjs +1 -1
  37. package/dist/vue2/lib/button-group/buttons-decorator.js +4 -7
  38. package/dist/vue2/lib/button-group/buttons-decorator.js.map +1 -1
  39. package/dist/vue2/lib/callbar-button/callbar-button.cjs +1 -1
  40. package/dist/vue2/lib/callbar-button/callbar-button.js +7 -10
  41. package/dist/vue2/lib/callbar-button/callbar-button.js.map +1 -1
  42. package/dist/vue2/lib/callbar-button-with-dropdown/callbar-button-with-dropdown.cjs +1 -1
  43. package/dist/vue2/lib/callbar-button-with-dropdown/callbar-button-with-dropdown.js +2 -5
  44. package/dist/vue2/lib/callbar-button-with-dropdown/callbar-button-with-dropdown.js.map +1 -1
  45. package/dist/vue2/lib/callbar-button-with-popover/callbar-button-with-popover.cjs +1 -1
  46. package/dist/vue2/lib/callbar-button-with-popover/callbar-button-with-popover.js +9 -12
  47. package/dist/vue2/lib/callbar-button-with-popover/callbar-button-with-popover.js.map +1 -1
  48. package/dist/vue2/lib/callbox/callbox.cjs +1 -1
  49. package/dist/vue2/lib/callbox/callbox.js +2 -5
  50. package/dist/vue2/lib/callbox/callbox.js.map +1 -1
  51. package/dist/vue2/lib/card/card.cjs +1 -1
  52. package/dist/vue2/lib/card/card.js +4 -7
  53. package/dist/vue2/lib/card/card.js.map +1 -1
  54. package/dist/vue2/lib/checkbox/checkbox.cjs +1 -1
  55. package/dist/vue2/lib/checkbox/checkbox.js +2 -5
  56. package/dist/vue2/lib/checkbox/checkbox.js.map +1 -1
  57. package/dist/vue2/lib/checkbox-group/checkbox-group.cjs +1 -1
  58. package/dist/vue2/lib/checkbox-group/checkbox-group.js +5 -8
  59. package/dist/vue2/lib/checkbox-group/checkbox-group.js.map +1 -1
  60. package/dist/vue2/lib/checkbox-group/checkboxes-decorator.cjs +1 -1
  61. package/dist/vue2/lib/checkbox-group/checkboxes-decorator.js +9 -12
  62. package/dist/vue2/lib/checkbox-group/checkboxes-decorator.js.map +1 -1
  63. package/dist/vue2/lib/chip/chip.cjs +1 -1
  64. package/dist/vue2/lib/chip/chip.js +8 -11
  65. package/dist/vue2/lib/chip/chip.js.map +1 -1
  66. package/dist/vue2/lib/codeblock/codeblock.cjs +2 -2
  67. package/dist/vue2/lib/codeblock/codeblock.js +8 -11
  68. package/dist/vue2/lib/codeblock/codeblock.js.map +1 -1
  69. package/dist/vue2/lib/collapsible/collapsible-lazy-show.cjs +1 -1
  70. package/dist/vue2/lib/collapsible/collapsible-lazy-show.js +2 -5
  71. package/dist/vue2/lib/collapsible/collapsible-lazy-show.js.map +1 -1
  72. package/dist/vue2/lib/collapsible/collapsible.cjs +1 -1
  73. package/dist/vue2/lib/collapsible/collapsible.js +4 -7
  74. package/dist/vue2/lib/collapsible/collapsible.js.map +1 -1
  75. package/dist/vue2/lib/combobox/combobox-empty-list.cjs +1 -1
  76. package/dist/vue2/lib/combobox/combobox-empty-list.js +7 -10
  77. package/dist/vue2/lib/combobox/combobox-empty-list.js.map +1 -1
  78. package/dist/vue2/lib/combobox/combobox-loading-list.cjs +1 -1
  79. package/dist/vue2/lib/combobox/combobox-loading-list.js +7 -10
  80. package/dist/vue2/lib/combobox/combobox-loading-list.js.map +1 -1
  81. package/dist/vue2/lib/combobox/combobox.cjs +2 -2
  82. package/dist/vue2/lib/combobox/combobox.js +2 -5
  83. package/dist/vue2/lib/combobox/combobox.js.map +1 -1
  84. package/dist/vue2/lib/combobox-multi-select/combobox-multi-select.cjs +1 -1
  85. package/dist/vue2/lib/combobox-multi-select/combobox-multi-select.js +6 -9
  86. package/dist/vue2/lib/combobox-multi-select/combobox-multi-select.js.map +1 -1
  87. package/dist/vue2/lib/combobox-with-popover/combobox-with-popover.cjs +1 -1
  88. package/dist/vue2/lib/combobox-with-popover/combobox-with-popover.js +2 -5
  89. package/dist/vue2/lib/combobox-with-popover/combobox-with-popover.js.map +1 -1
  90. package/dist/vue2/lib/contact-centers-row/contact-centers-row.cjs +1 -1
  91. package/dist/vue2/lib/contact-centers-row/contact-centers-row.js +6 -9
  92. package/dist/vue2/lib/contact-centers-row/contact-centers-row.js.map +1 -1
  93. package/dist/vue2/lib/contact-info/contact-info.cjs +1 -1
  94. package/dist/vue2/lib/contact-info/contact-info.js +5 -8
  95. package/dist/vue2/lib/contact-info/contact-info.js.map +1 -1
  96. package/dist/vue2/lib/contact-row/contact-row.cjs +1 -1
  97. package/dist/vue2/lib/contact-row/contact-row.js +2 -5
  98. package/dist/vue2/lib/contact-row/contact-row.js.map +1 -1
  99. package/dist/vue2/lib/datepicker/datepicker.cjs +1 -1
  100. package/dist/vue2/lib/datepicker/datepicker.cjs.map +1 -1
  101. package/dist/vue2/lib/datepicker/datepicker.js +4 -13
  102. package/dist/vue2/lib/datepicker/datepicker.js.map +1 -1
  103. package/dist/vue2/lib/description-list/description-list.cjs +1 -1
  104. package/dist/vue2/lib/description-list/description-list.js +10 -13
  105. package/dist/vue2/lib/description-list/description-list.js.map +1 -1
  106. package/dist/vue2/lib/dropdown/dropdown-list.cjs +1 -1
  107. package/dist/vue2/lib/dropdown/dropdown-list.js +5 -8
  108. package/dist/vue2/lib/dropdown/dropdown-list.js.map +1 -1
  109. package/dist/vue2/lib/dropdown/dropdown-separator.cjs +1 -1
  110. package/dist/vue2/lib/dropdown/dropdown-separator.js +4 -7
  111. package/dist/vue2/lib/dropdown/dropdown-separator.js.map +1 -1
  112. package/dist/vue2/lib/dropdown/dropdown.cjs +1 -1
  113. package/dist/vue2/lib/dropdown/dropdown.js +2 -5
  114. package/dist/vue2/lib/dropdown/dropdown.js.map +1 -1
  115. package/dist/vue2/lib/editor/editor.cjs +1 -1
  116. package/dist/vue2/lib/editor/editor.js +46 -49
  117. package/dist/vue2/lib/editor/editor.js.map +1 -1
  118. package/dist/vue2/lib/emoji/emoji.cjs +1 -1
  119. package/dist/vue2/lib/emoji/emoji.js +7 -10
  120. package/dist/vue2/lib/emoji/emoji.js.map +1 -1
  121. package/dist/vue2/lib/emoji-picker/emoji-picker.cjs +1 -1
  122. package/dist/vue2/lib/emoji-picker/emoji-picker.cjs.map +1 -1
  123. package/dist/vue2/lib/emoji-picker/emoji-picker.js +7 -25
  124. package/dist/vue2/lib/emoji-picker/emoji-picker.js.map +1 -1
  125. package/dist/vue2/lib/emoji-row/emoji-row.cjs +1 -1
  126. package/dist/vue2/lib/emoji-row/emoji-row.js +3 -6
  127. package/dist/vue2/lib/emoji-row/emoji-row.js.map +1 -1
  128. package/dist/vue2/lib/emoji-text-wrapper/emoji-text-wrapper.cjs +1 -1
  129. package/dist/vue2/lib/emoji-text-wrapper/emoji-text-wrapper.js +6 -9
  130. package/dist/vue2/lib/emoji-text-wrapper/emoji-text-wrapper.js.map +1 -1
  131. package/dist/vue2/lib/empty-state/empty-state.cjs +1 -1
  132. package/dist/vue2/lib/empty-state/empty-state.js +6 -9
  133. package/dist/vue2/lib/empty-state/empty-state.js.map +1 -1
  134. package/dist/vue2/lib/feed-item-pill/feed-item-pill.cjs +1 -1
  135. package/dist/vue2/lib/feed-item-pill/feed-item-pill.js +11 -14
  136. package/dist/vue2/lib/feed-item-pill/feed-item-pill.js.map +1 -1
  137. package/dist/vue2/lib/feed-item-row/feed-item-row.cjs +1 -1
  138. package/dist/vue2/lib/feed-item-row/feed-item-row.js +6 -9
  139. package/dist/vue2/lib/feed-item-row/feed-item-row.js.map +1 -1
  140. package/dist/vue2/lib/general-row/general-row.cjs +1 -1
  141. package/dist/vue2/lib/general-row/general-row.js +2 -5
  142. package/dist/vue2/lib/general-row/general-row.js.map +1 -1
  143. package/dist/vue2/lib/general-row/leftbar-general-row-icon.cjs +1 -1
  144. package/dist/vue2/lib/general-row/leftbar-general-row-icon.js +7 -10
  145. package/dist/vue2/lib/general-row/leftbar-general-row-icon.js.map +1 -1
  146. package/dist/vue2/lib/group-row/group-row.cjs +1 -1
  147. package/dist/vue2/lib/group-row/group-row.js +4 -7
  148. package/dist/vue2/lib/group-row/group-row.js.map +1 -1
  149. package/dist/vue2/lib/grouped-chip/grouped-chip.cjs +1 -1
  150. package/dist/vue2/lib/grouped-chip/grouped-chip.js +4 -7
  151. package/dist/vue2/lib/grouped-chip/grouped-chip.js.map +1 -1
  152. package/dist/vue2/lib/hovercard/hovercard.cjs +1 -1
  153. package/dist/vue2/lib/hovercard/hovercard.js +6 -9
  154. package/dist/vue2/lib/hovercard/hovercard.js.map +1 -1
  155. package/dist/vue2/lib/icon/icon.cjs +1 -1
  156. package/dist/vue2/lib/icon/icon.js +9 -12
  157. package/dist/vue2/lib/icon/icon.js.map +1 -1
  158. package/dist/vue2/lib/illustration/illustration.cjs +1 -1
  159. package/dist/vue2/lib/illustration/illustration.js +10 -13
  160. package/dist/vue2/lib/illustration/illustration.js.map +1 -1
  161. package/dist/vue2/lib/image-viewer/image-viewer.cjs +1 -1
  162. package/dist/vue2/lib/image-viewer/image-viewer.js +6 -9
  163. package/dist/vue2/lib/image-viewer/image-viewer.js.map +1 -1
  164. package/dist/vue2/lib/input/input.cjs +1 -1
  165. package/dist/vue2/lib/input/input.js +2 -5
  166. package/dist/vue2/lib/input/input.js.map +1 -1
  167. package/dist/vue2/lib/input-group/input-group.cjs +1 -1
  168. package/dist/vue2/lib/input-group/input-group.js +6 -9
  169. package/dist/vue2/lib/input-group/input-group.js.map +1 -1
  170. package/dist/vue2/lib/item-layout/item-layout.cjs +2 -2
  171. package/dist/vue2/lib/item-layout/item-layout.js +4 -7
  172. package/dist/vue2/lib/item-layout/item-layout.js.map +1 -1
  173. package/dist/vue2/lib/ivr-node/ivr-node.cjs +1 -1
  174. package/dist/vue2/lib/ivr-node/ivr-node.js +11 -14
  175. package/dist/vue2/lib/ivr-node/ivr-node.js.map +1 -1
  176. package/dist/vue2/lib/keyboard-shortcut/keyboard-shortcut.cjs +1 -1
  177. package/dist/vue2/lib/keyboard-shortcut/keyboard-shortcut.js +10 -13
  178. package/dist/vue2/lib/keyboard-shortcut/keyboard-shortcut.js.map +1 -1
  179. package/dist/vue2/lib/lazy-show/lazy-show.cjs +1 -1
  180. package/dist/vue2/lib/lazy-show/lazy-show.js +2 -5
  181. package/dist/vue2/lib/lazy-show/lazy-show.js.map +1 -1
  182. package/dist/vue2/lib/link/link.cjs +1 -1
  183. package/dist/vue2/lib/link/link.js +6 -9
  184. package/dist/vue2/lib/link/link.js.map +1 -1
  185. package/dist/vue2/lib/list-item/list-item.cjs +1 -1
  186. package/dist/vue2/lib/list-item/list-item.js +22 -25
  187. package/dist/vue2/lib/list-item/list-item.js.map +1 -1
  188. package/dist/vue2/lib/list-item-group/list-item-group.cjs +1 -1
  189. package/dist/vue2/lib/list-item-group/list-item-group.js +8 -11
  190. package/dist/vue2/lib/list-item-group/list-item-group.js.map +1 -1
  191. package/dist/vue2/lib/message-input/message-input-button.cjs +1 -1
  192. package/dist/vue2/lib/message-input/message-input-button.js +4 -7
  193. package/dist/vue2/lib/message-input/message-input-button.js.map +1 -1
  194. package/dist/vue2/lib/message-input/message-input-link.cjs +1 -1
  195. package/dist/vue2/lib/message-input/message-input-link.js +2 -5
  196. package/dist/vue2/lib/message-input/message-input-link.js.map +1 -1
  197. package/dist/vue2/lib/message-input/message-input-topbar.cjs +1 -1
  198. package/dist/vue2/lib/message-input/message-input-topbar.js +2 -5
  199. package/dist/vue2/lib/message-input/message-input-topbar.js.map +1 -1
  200. package/dist/vue2/lib/message-input/message-input.cjs +1 -1
  201. package/dist/vue2/lib/message-input/message-input.cjs.map +1 -1
  202. package/dist/vue2/lib/message-input/message-input.js +3 -9
  203. package/dist/vue2/lib/message-input/message-input.js.map +1 -1
  204. package/dist/vue2/lib/modal/modal.cjs +2 -2
  205. package/dist/vue2/lib/modal/modal.js +2 -5
  206. package/dist/vue2/lib/modal/modal.js.map +1 -1
  207. package/dist/vue2/lib/notice/notice-action.cjs +1 -1
  208. package/dist/vue2/lib/notice/notice-action.js +4 -7
  209. package/dist/vue2/lib/notice/notice-action.js.map +1 -1
  210. package/dist/vue2/lib/notice/notice-content.cjs +1 -1
  211. package/dist/vue2/lib/notice/notice-content.js +2 -5
  212. package/dist/vue2/lib/notice/notice-content.js.map +1 -1
  213. package/dist/vue2/lib/notice/notice-icon.cjs +1 -1
  214. package/dist/vue2/lib/notice/notice-icon.js +13 -16
  215. package/dist/vue2/lib/notice/notice-icon.js.map +1 -1
  216. package/dist/vue2/lib/notice/notice.cjs +1 -1
  217. package/dist/vue2/lib/notice/notice.js +7 -10
  218. package/dist/vue2/lib/notice/notice.js.map +1 -1
  219. package/dist/vue2/lib/pagination/pagination.cjs +1 -1
  220. package/dist/vue2/lib/pagination/pagination.js +6 -9
  221. package/dist/vue2/lib/pagination/pagination.js.map +1 -1
  222. package/dist/vue2/lib/popover/popover-header-footer.cjs +1 -1
  223. package/dist/vue2/lib/popover/popover-header-footer.js +5 -8
  224. package/dist/vue2/lib/popover/popover-header-footer.js.map +1 -1
  225. package/dist/vue2/lib/popover/popover.cjs +1 -1
  226. package/dist/vue2/lib/popover/popover.cjs.map +1 -1
  227. package/dist/vue2/lib/popover/popover.js +3 -6
  228. package/dist/vue2/lib/popover/popover.js.map +1 -1
  229. package/dist/vue2/lib/presence/presence.cjs +1 -1
  230. package/dist/vue2/lib/presence/presence.js +4 -7
  231. package/dist/vue2/lib/presence/presence.js.map +1 -1
  232. package/dist/vue2/lib/radio/radio.cjs +1 -1
  233. package/dist/vue2/lib/radio/radio.js +5 -8
  234. package/dist/vue2/lib/radio/radio.js.map +1 -1
  235. package/dist/vue2/lib/radio-group/radio-group.cjs +1 -1
  236. package/dist/vue2/lib/radio-group/radio-group.js +2 -5
  237. package/dist/vue2/lib/radio-group/radio-group.js.map +1 -1
  238. package/dist/vue2/lib/radio-group/radios-decorator.cjs +1 -1
  239. package/dist/vue2/lib/radio-group/radios-decorator.js +6 -9
  240. package/dist/vue2/lib/radio-group/radios-decorator.js.map +1 -1
  241. package/dist/vue2/lib/rich-text-editor/rich-text-editor.cjs +3 -3
  242. package/dist/vue2/lib/rich-text-editor/rich-text-editor.cjs.map +1 -1
  243. package/dist/vue2/lib/rich-text-editor/rich-text-editor.js +11 -41
  244. package/dist/vue2/lib/rich-text-editor/rich-text-editor.js.map +1 -1
  245. package/dist/vue2/lib/root-layout/root-layout.cjs +1 -1
  246. package/dist/vue2/lib/root-layout/root-layout.js +5 -8
  247. package/dist/vue2/lib/root-layout/root-layout.js.map +1 -1
  248. package/dist/vue2/lib/select-menu/select-menu.cjs +1 -1
  249. package/dist/vue2/lib/select-menu/select-menu.js +2 -5
  250. package/dist/vue2/lib/select-menu/select-menu.js.map +1 -1
  251. package/dist/vue2/lib/settings-menu-button/settings-menu-button.cjs +1 -1
  252. package/dist/vue2/lib/settings-menu-button/settings-menu-button.js +4 -7
  253. package/dist/vue2/lib/settings-menu-button/settings-menu-button.js.map +1 -1
  254. package/dist/vue2/lib/skeleton/skeleton-list-item.cjs +1 -1
  255. package/dist/vue2/lib/skeleton/skeleton-list-item.js +2 -5
  256. package/dist/vue2/lib/skeleton/skeleton-list-item.js.map +1 -1
  257. package/dist/vue2/lib/skeleton/skeleton-paragraph.cjs +1 -1
  258. package/dist/vue2/lib/skeleton/skeleton-paragraph.js +5 -8
  259. package/dist/vue2/lib/skeleton/skeleton-paragraph.js.map +1 -1
  260. package/dist/vue2/lib/skeleton/skeleton-shape.cjs +1 -1
  261. package/dist/vue2/lib/skeleton/skeleton-shape.js +4 -7
  262. package/dist/vue2/lib/skeleton/skeleton-shape.js.map +1 -1
  263. package/dist/vue2/lib/skeleton/skeleton-text.cjs +1 -1
  264. package/dist/vue2/lib/skeleton/skeleton-text.js +11 -14
  265. package/dist/vue2/lib/skeleton/skeleton-text.js.map +1 -1
  266. package/dist/vue2/lib/skeleton/skeleton.cjs +1 -1
  267. package/dist/vue2/lib/skeleton/skeleton.js +6 -9
  268. package/dist/vue2/lib/skeleton/skeleton.js.map +1 -1
  269. package/dist/vue2/lib/split-button/split-button-alpha.cjs +1 -1
  270. package/dist/vue2/lib/split-button/split-button-alpha.js +9 -12
  271. package/dist/vue2/lib/split-button/split-button-alpha.js.map +1 -1
  272. package/dist/vue2/lib/split-button/split-button-omega.cjs +1 -1
  273. package/dist/vue2/lib/split-button/split-button-omega.js +6 -9
  274. package/dist/vue2/lib/split-button/split-button-omega.js.map +1 -1
  275. package/dist/vue2/lib/split-button/split-button.cjs +1 -1
  276. package/dist/vue2/lib/split-button/split-button.js +6 -9
  277. package/dist/vue2/lib/split-button/split-button.js.map +1 -1
  278. package/dist/vue2/lib/stack/stack.cjs +1 -1
  279. package/dist/vue2/lib/stack/stack.js +12 -15
  280. package/dist/vue2/lib/stack/stack.js.map +1 -1
  281. package/dist/vue2/lib/tab/tab-group.cjs +1 -1
  282. package/dist/vue2/lib/tab/tab-group.js +2 -5
  283. package/dist/vue2/lib/tab/tab-group.js.map +1 -1
  284. package/dist/vue2/lib/tab/tab-panel.cjs +1 -1
  285. package/dist/vue2/lib/tab/tab-panel.js +8 -11
  286. package/dist/vue2/lib/tab/tab-panel.js.map +1 -1
  287. package/dist/vue2/lib/tab/tab.cjs +1 -1
  288. package/dist/vue2/lib/tab/tab.js +7 -10
  289. package/dist/vue2/lib/tab/tab.js.map +1 -1
  290. package/dist/vue2/lib/time-pill/time-pill.cjs +1 -1
  291. package/dist/vue2/lib/time-pill/time-pill.js +5 -8
  292. package/dist/vue2/lib/time-pill/time-pill.js.map +1 -1
  293. package/dist/vue2/lib/toast/toast.cjs +1 -1
  294. package/dist/vue2/lib/toast/toast.cjs.map +1 -1
  295. package/dist/vue2/lib/toast/toast.js +5 -17
  296. package/dist/vue2/lib/toast/toast.js.map +1 -1
  297. package/dist/vue2/lib/toggle/toggle.cjs +1 -1
  298. package/dist/vue2/lib/toggle/toggle.js +2 -5
  299. package/dist/vue2/lib/toggle/toggle.js.map +1 -1
  300. package/dist/vue2/lib/tooltip/tooltip.cjs +1 -1
  301. package/dist/vue2/lib/tooltip/tooltip.js +6 -9
  302. package/dist/vue2/lib/tooltip/tooltip.js.map +1 -1
  303. package/dist/vue2/lib/top-banner-info/top-banner-info.cjs +1 -1
  304. package/dist/vue2/lib/top-banner-info/top-banner-info.js +2 -5
  305. package/dist/vue2/lib/top-banner-info/top-banner-info.js.map +1 -1
  306. package/dist/vue2/lib/unread-pill/unread-pill.cjs +1 -1
  307. package/dist/vue2/lib/unread-pill/unread-pill.js +5 -8
  308. package/dist/vue2/lib/unread-pill/unread-pill.js.map +1 -1
  309. package/dist/vue2/lib/validation-messages/validation-messages.cjs +1 -1
  310. package/dist/vue2/lib/validation-messages/validation-messages.js +7 -10
  311. package/dist/vue2/lib/validation-messages/validation-messages.js.map +1 -1
  312. package/dist/vue2/shared/sr_only_close_button.cjs +1 -1
  313. package/dist/vue2/shared/sr_only_close_button.js +9 -12
  314. package/dist/vue2/shared/sr_only_close_button.js.map +1 -1
  315. package/dist/vue2/types/components/popover/popover.vue.d.ts.map +1 -1
  316. package/dist/vue3/lib/popover/popover.cjs +1 -1
  317. package/dist/vue3/lib/popover/popover.cjs.map +1 -1
  318. package/dist/vue3/lib/popover/popover.js +37 -38
  319. package/dist/vue3/lib/popover/popover.js.map +1 -1
  320. package/dist/vue3/lib/rich-text-editor/rich-text-editor.cjs +1 -1
  321. package/dist/vue3/lib/rich-text-editor/rich-text-editor.cjs.map +1 -1
  322. package/dist/vue3/lib/rich-text-editor/rich-text-editor.js +1 -1
  323. package/dist/vue3/lib/rich-text-editor/rich-text-editor.js.map +1 -1
  324. package/dist/vue3/types/components/popover/popover.vue.d.ts.map +1 -1
  325. package/package.json +3 -3
  326. package/dist/vue2/_plugin-vue2_normalizer-CeySl7Fu.js +0 -11
  327. package/dist/vue2/_plugin-vue2_normalizer-CeySl7Fu.js.map +0 -1
  328. package/dist/vue2/_plugin-vue2_normalizer-yXi3ZRRD.cjs +0 -2
  329. package/dist/vue2/_plugin-vue2_normalizer-yXi3ZRRD.cjs.map +0 -1
  330. package/dist/vue2/style.css +0 -1
  331. package/dist/vue3/style.css +0 -1
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const i=require("../../common/emoji/index.cjs"),n=require("../../_plugin-vue2_normalizer-yXi3ZRRD.cjs"),s=require("../skeleton/skeleton.cjs"),o=require("../icon/icon-constants.cjs"),r={name:"DtEmoji",components:{DtSkeleton:s.default},props:{code:{type:String,required:!0},size:{type:String,default:"500",validator:t=>Object.keys(o.ICON_SIZE_MODIFIERS).includes(t)},imgClass:{type:[String,Object,Array],default:""},ariaLabel:{type:String,default:null},showSkeleton:{type:Boolean,default:!0}},data(){return{emojiData:null,imgLoading:!1}},computed:{emojiDataValid(){return!!this.emojiData},emojiSrc(){var t;return this.emojiDataValid?(t=this.emojiData)!=null&&t.custom?i.customEmojiAssetUrl+this.emojiData.key+this.emojiData.extension:["100","200"].includes(this.size)?i.emojiImageUrlSmall+this.emojiData.key+i.emojiFileExtensionSmall:i.emojiImageUrlLarge+this.emojiData.key+i.emojiFileExtensionLarge:"invalid"},emojiAlt(){if(this.emojiDataValid)return this.emojiData.unicode_output?i.stringToUnicode(this.emojiData.unicode_output):this.emojiData.name},emojiLabel(){return this.emojiDataValid?this.ariaLabel?this.ariaLabel:this.emojiData.name:"Invalid Emoji"},emojiSize(){return o.ICON_SIZE_MODIFIERS[this.size]}},watch:{code:{handler:function(){this.getEmojiData()},immediate:!0},emojiSrc:{handler:async function(){this.imgLoading=!0},immediate:!0}},methods:{getEmojiData(){this.emojiData=i.codeToEmojiData(this.code)},imageLoaded(){this.imgLoading=!1},imageErrored(){this.imgLoading=!1}}};var m=function(){var e=this,a=e._self._c;return a("span",{class:["d-emoji d-icon",e.emojiSize]},[a("dt-skeleton",{directives:[{name:"show",rawName:"v-show",value:e.imgLoading&&e.showSkeleton,expression:"imgLoading && showSkeleton"}],class:["d-icon",e.emojiSize],attrs:{offset:0,"shape-option":{shape:"circle",size:"100%"}}}),a("img",{directives:[{name:"show",rawName:"v-show",value:!e.imgLoading,expression:"!imgLoading"}],ref:"emojiImg",class:["d-icon",e.emojiSize,e.imgClass],attrs:{"aria-label":e.emojiLabel,alt:e.emojiAlt,title:e.emojiLabel,src:e.emojiSrc},on:{load:e.imageLoaded,error:e.imageErrored}})],1)},l=[],d=n.n(r,m,l,!1,null,null);const u=d.exports;exports.default=u;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const i=require("../../common/emoji/index.cjs"),r=require("../../_plugin-vue2_normalizer-e_CkxkSV.cjs"),s=require("../skeleton/skeleton.cjs"),o=require("../icon/icon-constants.cjs"),n={name:"DtEmoji",components:{DtSkeleton:s.default},props:{code:{type:String,required:!0},size:{type:String,default:"500",validator:t=>Object.keys(o.ICON_SIZE_MODIFIERS).includes(t)},imgClass:{type:[String,Object,Array],default:""},ariaLabel:{type:String,default:null},showSkeleton:{type:Boolean,default:!0}},data(){return{emojiData:null,imgLoading:!1}},computed:{emojiDataValid(){return!!this.emojiData},emojiSrc(){var t;return this.emojiDataValid?(t=this.emojiData)!=null&&t.custom?i.customEmojiAssetUrl+this.emojiData.key+this.emojiData.extension:["100","200"].includes(this.size)?i.emojiImageUrlSmall+this.emojiData.key+i.emojiFileExtensionSmall:i.emojiImageUrlLarge+this.emojiData.key+i.emojiFileExtensionLarge:"invalid"},emojiAlt(){if(this.emojiDataValid)return this.emojiData.unicode_output?i.stringToUnicode(this.emojiData.unicode_output):this.emojiData.name},emojiLabel(){return this.emojiDataValid?this.ariaLabel?this.ariaLabel:this.emojiData.name:"Invalid Emoji"},emojiSize(){return o.ICON_SIZE_MODIFIERS[this.size]}},watch:{code:{handler:function(){this.getEmojiData()},immediate:!0},emojiSrc:{handler:async function(){this.imgLoading=!0},immediate:!0}},methods:{getEmojiData(){this.emojiData=i.codeToEmojiData(this.code)},imageLoaded(){this.imgLoading=!1},imageErrored(){this.imgLoading=!1}}};var m=function(){var e=this,a=e._self._c;return a("span",{class:["d-emoji d-icon",e.emojiSize]},[a("dt-skeleton",{directives:[{name:"show",rawName:"v-show",value:e.imgLoading&&e.showSkeleton,expression:"imgLoading && showSkeleton"}],class:["d-icon",e.emojiSize],attrs:{offset:0,"shape-option":{shape:"circle",size:"100%"}}}),a("img",{directives:[{name:"show",rawName:"v-show",value:!e.imgLoading,expression:"!imgLoading"}],ref:"emojiImg",class:["d-icon",e.emojiSize,e.imgClass],attrs:{"aria-label":e.emojiLabel,alt:e.emojiAlt,title:e.emojiLabel,src:e.emojiSrc},on:{load:e.imageLoaded,error:e.imageErrored}})],1)},l=[],d=r.n(n,m,l);const u=d.exports;exports.default=u;
2
2
  //# sourceMappingURL=emoji.cjs.map
@@ -1,11 +1,11 @@
1
1
  import { customEmojiAssetUrl as o, emojiImageUrlSmall as r, emojiFileExtensionSmall as m, emojiImageUrlLarge as s, emojiFileExtensionLarge as n, stringToUnicode as l, codeToEmojiData as d } from "../../common/emoji/index.js";
2
- import { n as u } from "../../_plugin-vue2_normalizer-CeySl7Fu.js";
3
- import c from "../skeleton/skeleton.js";
2
+ import { n as c } from "../../_plugin-vue2_normalizer-DSLOjnn3.js";
3
+ import j from "../skeleton/skeleton.js";
4
4
  import { ICON_SIZE_MODIFIERS as a } from "../icon/icon-constants.js";
5
- const j = {
5
+ const u = {
6
6
  name: "DtEmoji",
7
7
  components: {
8
- DtSkeleton: c
8
+ DtSkeleton: j
9
9
  },
10
10
  props: {
11
11
  /**
@@ -109,13 +109,10 @@ const j = {
109
109
  var h = function() {
110
110
  var e = this, t = e._self._c;
111
111
  return t("span", { class: ["d-emoji d-icon", e.emojiSize] }, [t("dt-skeleton", { directives: [{ name: "show", rawName: "v-show", value: e.imgLoading && e.showSkeleton, expression: "imgLoading && showSkeleton" }], class: ["d-icon", e.emojiSize], attrs: { offset: 0, "shape-option": { shape: "circle", size: "100%" } } }), t("img", { directives: [{ name: "show", rawName: "v-show", value: !e.imgLoading, expression: "!imgLoading" }], ref: "emojiImg", class: ["d-icon", e.emojiSize, e.imgClass], attrs: { "aria-label": e.emojiLabel, alt: e.emojiAlt, title: e.emojiLabel, src: e.emojiSrc }, on: { load: e.imageLoaded, error: e.imageErrored } })], 1);
112
- }, g = [], f = /* @__PURE__ */ u(
113
- j,
112
+ }, g = [], f = /* @__PURE__ */ c(
113
+ u,
114
114
  h,
115
- g,
116
- !1,
117
- null,
118
- null
115
+ g
119
116
  );
120
117
  const _ = f.exports;
121
118
  export {
@@ -1 +1 @@
1
- {"version":3,"file":"emoji.js","sources":["../../../components/emoji/emoji.vue"],"sourcesContent":["<template>\n <span :class=\"['d-emoji d-icon', emojiSize]\">\n <dt-skeleton\n v-show=\"imgLoading && showSkeleton\"\n :offset=\"0\"\n :class=\"['d-icon', emojiSize]\"\n :shape-option=\"{ shape: 'circle', size: '100%' }\"\n />\n <img\n v-show=\"!imgLoading\"\n ref=\"emojiImg\"\n :class=\"['d-icon', emojiSize, imgClass]\"\n :aria-label=\"emojiLabel\"\n :alt=\"emojiAlt\"\n :title=\"emojiLabel\"\n :src=\"emojiSrc\"\n @load=\"imageLoaded\"\n @error=\"imageErrored\"\n >\n </span>\n</template>\n\n<script>\nimport { ICON_SIZE_MODIFIERS } from '@/components/icon';\nimport {\n codeToEmojiData,\n stringToUnicode,\n emojiImageUrlSmall,\n emojiFileExtensionSmall,\n emojiImageUrlLarge,\n emojiFileExtensionLarge,\n customEmojiAssetUrl,\n} from '@/common/emoji';\nimport { DtSkeleton } from '@/components/skeleton';\n\n/**\n * Renders an emoji from a shortcode such as :smile: or unicode character such as 😄\n * @see https://dialtone.dialpad.com/components/emoji.html\n */\nexport default {\n name: 'DtEmoji',\n\n components: {\n DtSkeleton,\n },\n\n props: {\n /**\n * Supports shortcode ex: :smile: or unicode ex: 😄. Will display the resulting emoji.\n * <a class=\"d-link\" href=\"https://emojipedia.org/joypixels/\" target=\"_blank\">JoyPixels</a>\n * for all supported shortcode/unicode or the docs for setting up custom emojis.\n */\n code: {\n type: String,\n required: true,\n },\n\n /**\n * The size of the emoji. Can be any of the icon size utility classes from\n * <a class=\"d-link\" href=\"https://dialtone.dialpad.com/components/icon.html\" target=\"_blank\"> Dialpad Icon Size</a>\n * @values 100, 200, 300, 400, 500, 600, 700, 800\n */\n size: {\n type: String,\n default: '500',\n validator: (t) => Object.keys(ICON_SIZE_MODIFIERS).includes(t),\n },\n\n /**\n * Additional class name for the emoji img element.\n * Can accept String, Object, and Array, i.e. has the\n * same API as Vue's built-in handling of the class attribute.\n */\n imgClass: {\n type: [String, Object, Array],\n default: '',\n },\n\n /**\n * Will be read out on a screen reader for this emoji. You must use this prop if you want your emoji to be i18n\n * Compatible as Dialtone Vue will not translate it by itself. If you do not set this prop the aria-label will\n * be set to the english description of the emoji. You can retrieve the description for an emoji yourself via the\n * getEmojiData() function\n */\n ariaLabel: {\n type: String,\n default: null,\n },\n\n /**\n * Shows a skeleton loader while the emoji asset is loading.\n * @values true, false\n */\n showSkeleton: {\n type: Boolean,\n default: true,\n },\n },\n\n data () {\n return {\n emojiData: null,\n imgLoading: false,\n };\n },\n\n computed: {\n emojiDataValid () {\n return !!this.emojiData;\n },\n\n emojiSrc () {\n if (!this.emojiDataValid) { return 'invalid'; }\n\n // custom emoji\n if (this.emojiData?.custom) {\n return customEmojiAssetUrl + this.emojiData.key + this.emojiData.extension;\n }\n\n if (['100', '200'].includes(this.size)) {\n return emojiImageUrlSmall + this.emojiData.key + emojiFileExtensionSmall;\n } else {\n return emojiImageUrlLarge + this.emojiData.key + emojiFileExtensionLarge;\n }\n },\n\n emojiAlt () {\n if (!this.emojiDataValid) { return undefined; }\n return this.emojiData.unicode_output ? stringToUnicode(this.emojiData.unicode_output) : this.emojiData.name;\n },\n\n emojiLabel () {\n if (!this.emojiDataValid) { return 'Invalid Emoji'; }\n return this.ariaLabel ? this.ariaLabel : this.emojiData.name;\n },\n\n emojiSize () {\n return ICON_SIZE_MODIFIERS[this.size];\n },\n },\n\n watch: {\n code: {\n handler: function () {\n this.getEmojiData();\n },\n\n immediate: true,\n },\n\n emojiSrc: {\n handler: async function () {\n this.imgLoading = true;\n },\n\n immediate: true,\n },\n },\n\n methods: {\n getEmojiData () {\n this.emojiData = codeToEmojiData(this.code);\n },\n\n imageLoaded () {\n this.imgLoading = false;\n },\n\n imageErrored () {\n this.imgLoading = false;\n },\n },\n};\n</script>\n"],"names":["_sfc_main","DtSkeleton","t","ICON_SIZE_MODIFIERS","_a","customEmojiAssetUrl","emojiImageUrlSmall","emojiFileExtensionSmall","emojiImageUrlLarge","emojiFileExtensionLarge","stringToUnicode","codeToEmojiData"],"mappings":";;;;AAuCA,MAAAA,IAAA;AAAA,EACA,MAAA;AAAA,EAEA,YAAA;AAAA,IACA,YAAAC;AAAA,EACA;AAAA,EAEA,OAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,MACA,WAAA,CAAAC,MAAA,OAAA,KAAAC,CAAA,EAAA,SAAAD,CAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,UAAA;AAAA,MACA,MAAA,CAAA,QAAA,QAAA,KAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,WAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,cAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AACA,WAAA;AAAA,MACA,WAAA;AAAA,MACA,YAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,UAAA;AAAA,IACA,iBAAA;AACA,aAAA,CAAA,CAAA,KAAA;AAAA,IACA;AAAA,IAEA,WAAA;;AACA,aAAA,KAAA,kBAGAE,IAAA,KAAA,cAAA,QAAAA,EAAA,SACAC,IAAA,KAAA,UAAA,MAAA,KAAA,UAAA,YAGA,CAAA,OAAA,KAAA,EAAA,SAAA,KAAA,IAAA,IACAC,IAAA,KAAA,UAAA,MAAAC,IAEAC,IAAA,KAAA,UAAA,MAAAC,IAVA;AAAA,IAYA;AAAA,IAEA,WAAA;AACA,UAAA,KAAA;AACA,eAAA,KAAA,UAAA,iBAAAC,EAAA,KAAA,UAAA,cAAA,IAAA,KAAA,UAAA;AAAA,IACA;AAAA,IAEA,aAAA;AACA,aAAA,KAAA,iBACA,KAAA,YAAA,KAAA,YAAA,KAAA,UAAA,OADA;AAAA,IAEA;AAAA,IAEA,YAAA;AACA,aAAAP,EAAA,KAAA,IAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA,IACA,MAAA;AAAA,MACA,SAAA,WAAA;AACA,aAAA,aAAA;AAAA,MACA;AAAA,MAEA,WAAA;AAAA,IACA;AAAA,IAEA,UAAA;AAAA,MACA,SAAA,iBAAA;AACA,aAAA,aAAA;AAAA,MACA;AAAA,MAEA,WAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA,IACA,eAAA;AACA,WAAA,YAAAQ,EAAA,KAAA,IAAA;AAAA,IACA;AAAA,IAEA,cAAA;AACA,WAAA,aAAA;AAAA,IACA;AAAA,IAEA,eAAA;AACA,WAAA,aAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"emoji.js","sources":["../../../components/emoji/emoji.vue"],"sourcesContent":["<template>\n <span :class=\"['d-emoji d-icon', emojiSize]\">\n <dt-skeleton\n v-show=\"imgLoading && showSkeleton\"\n :offset=\"0\"\n :class=\"['d-icon', emojiSize]\"\n :shape-option=\"{ shape: 'circle', size: '100%' }\"\n />\n <img\n v-show=\"!imgLoading\"\n ref=\"emojiImg\"\n :class=\"['d-icon', emojiSize, imgClass]\"\n :aria-label=\"emojiLabel\"\n :alt=\"emojiAlt\"\n :title=\"emojiLabel\"\n :src=\"emojiSrc\"\n @load=\"imageLoaded\"\n @error=\"imageErrored\"\n >\n </span>\n</template>\n\n<script>\nimport { ICON_SIZE_MODIFIERS } from '@/components/icon';\nimport {\n codeToEmojiData,\n stringToUnicode,\n emojiImageUrlSmall,\n emojiFileExtensionSmall,\n emojiImageUrlLarge,\n emojiFileExtensionLarge,\n customEmojiAssetUrl,\n} from '@/common/emoji';\nimport { DtSkeleton } from '@/components/skeleton';\n\n/**\n * Renders an emoji from a shortcode such as :smile: or unicode character such as 😄\n * @see https://dialtone.dialpad.com/components/emoji.html\n */\nexport default {\n name: 'DtEmoji',\n\n components: {\n DtSkeleton,\n },\n\n props: {\n /**\n * Supports shortcode ex: :smile: or unicode ex: 😄. Will display the resulting emoji.\n * <a class=\"d-link\" href=\"https://emojipedia.org/joypixels/\" target=\"_blank\">JoyPixels</a>\n * for all supported shortcode/unicode or the docs for setting up custom emojis.\n */\n code: {\n type: String,\n required: true,\n },\n\n /**\n * The size of the emoji. Can be any of the icon size utility classes from\n * <a class=\"d-link\" href=\"https://dialtone.dialpad.com/components/icon.html\" target=\"_blank\"> Dialpad Icon Size</a>\n * @values 100, 200, 300, 400, 500, 600, 700, 800\n */\n size: {\n type: String,\n default: '500',\n validator: (t) => Object.keys(ICON_SIZE_MODIFIERS).includes(t),\n },\n\n /**\n * Additional class name for the emoji img element.\n * Can accept String, Object, and Array, i.e. has the\n * same API as Vue's built-in handling of the class attribute.\n */\n imgClass: {\n type: [String, Object, Array],\n default: '',\n },\n\n /**\n * Will be read out on a screen reader for this emoji. You must use this prop if you want your emoji to be i18n\n * Compatible as Dialtone Vue will not translate it by itself. If you do not set this prop the aria-label will\n * be set to the english description of the emoji. You can retrieve the description for an emoji yourself via the\n * getEmojiData() function\n */\n ariaLabel: {\n type: String,\n default: null,\n },\n\n /**\n * Shows a skeleton loader while the emoji asset is loading.\n * @values true, false\n */\n showSkeleton: {\n type: Boolean,\n default: true,\n },\n },\n\n data () {\n return {\n emojiData: null,\n imgLoading: false,\n };\n },\n\n computed: {\n emojiDataValid () {\n return !!this.emojiData;\n },\n\n emojiSrc () {\n if (!this.emojiDataValid) { return 'invalid'; }\n\n // custom emoji\n if (this.emojiData?.custom) {\n return customEmojiAssetUrl + this.emojiData.key + this.emojiData.extension;\n }\n\n if (['100', '200'].includes(this.size)) {\n return emojiImageUrlSmall + this.emojiData.key + emojiFileExtensionSmall;\n } else {\n return emojiImageUrlLarge + this.emojiData.key + emojiFileExtensionLarge;\n }\n },\n\n emojiAlt () {\n if (!this.emojiDataValid) { return undefined; }\n return this.emojiData.unicode_output ? stringToUnicode(this.emojiData.unicode_output) : this.emojiData.name;\n },\n\n emojiLabel () {\n if (!this.emojiDataValid) { return 'Invalid Emoji'; }\n return this.ariaLabel ? this.ariaLabel : this.emojiData.name;\n },\n\n emojiSize () {\n return ICON_SIZE_MODIFIERS[this.size];\n },\n },\n\n watch: {\n code: {\n handler: function () {\n this.getEmojiData();\n },\n\n immediate: true,\n },\n\n emojiSrc: {\n handler: async function () {\n this.imgLoading = true;\n },\n\n immediate: true,\n },\n },\n\n methods: {\n getEmojiData () {\n this.emojiData = codeToEmojiData(this.code);\n },\n\n imageLoaded () {\n this.imgLoading = false;\n },\n\n imageErrored () {\n this.imgLoading = false;\n },\n },\n};\n</script>\n"],"names":["_sfc_main","DtSkeleton","t","ICON_SIZE_MODIFIERS","_a","customEmojiAssetUrl","emojiImageUrlSmall","emojiFileExtensionSmall","emojiImageUrlLarge","emojiFileExtensionLarge","stringToUnicode","codeToEmojiData"],"mappings":";;;;AAuCA,MAAAA,IAAA;AAAA,EACA,MAAA;AAAA,EAEA,YAAA;AAAA,IACA,YAAAC;AAAA,EACA;AAAA,EAEA,OAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,MACA,WAAA,CAAAC,MAAA,OAAA,KAAAC,CAAA,EAAA,SAAAD,CAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,UAAA;AAAA,MACA,MAAA,CAAA,QAAA,QAAA,KAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,WAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,cAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AACA,WAAA;AAAA,MACA,WAAA;AAAA,MACA,YAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,UAAA;AAAA,IACA,iBAAA;AACA,aAAA,CAAA,CAAA,KAAA;AAAA,IACA;AAAA,IAEA,WAAA;;AACA,aAAA,KAAA,kBAGAE,IAAA,KAAA,cAAA,QAAAA,EAAA,SACAC,IAAA,KAAA,UAAA,MAAA,KAAA,UAAA,YAGA,CAAA,OAAA,KAAA,EAAA,SAAA,KAAA,IAAA,IACAC,IAAA,KAAA,UAAA,MAAAC,IAEAC,IAAA,KAAA,UAAA,MAAAC,IAVA;AAAA,IAYA;AAAA,IAEA,WAAA;AACA,UAAA,KAAA;AACA,eAAA,KAAA,UAAA,iBAAAC,EAAA,KAAA,UAAA,cAAA,IAAA,KAAA,UAAA;AAAA,IACA;AAAA,IAEA,aAAA;AACA,aAAA,KAAA,iBACA,KAAA,YAAA,KAAA,YAAA,KAAA,UAAA,OADA;AAAA,IAEA;AAAA,IAEA,YAAA;AACA,aAAAP,EAAA,KAAA,IAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA,IACA,MAAA;AAAA,MACA,SAAA,WAAA;AACA,aAAA,aAAA;AAAA,MACA;AAAA,MAEA,WAAA;AAAA,IACA;AAAA,IAEA,UAAA;AAAA,MACA,SAAA,iBAAA;AACA,aAAA,aAAA;AAAA,MACA;AAAA,MAEA,WAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA,IACA,eAAA;AACA,WAAA,YAAAQ,EAAA,KAAA,IAAA;AAAA,IACA;AAAA,IAEA,cAAA;AACA,WAAA,aAAA;AAAA,IACA;AAAA,IAEA,eAAA;AACA,WAAA,aAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const n=require("./emoji-picker-constants.cjs"),c=require("@dialpad/dialtone-icons/vue2"),u=require("../../_plugin-vue2_normalizer-yXi3ZRRD.cjs"),d=require("../tab/tab-group.cjs"),_=require("../tab/tab.cjs"),p=require("../input/input.cjs"),m=require("../button/button.cjs"),b=require("@dialpad/dialtone-emojis"),E=require("../tooltip/tooltip.cjs"),j={name:"EmojiTabset",components:{DtTabGroup:d.default,DtTab:_.default},props:{showRecentlyUsedTab:{type:Boolean,default:!1},showCustomEmojisTab:{type:Boolean,default:!1},scrollIntoTab:{type:Number,required:!0},emojiFilter:{type:String,default:""},tabSetLabels:{type:Array,required:!0}},data(){return{selectedTab:"1",tabsetRef:[],TABS_DATA:[{label:n.EMOJI_PICKER_CATEGORIES.MOST_RECENTLY_USED,icon:c.DtIconClock},{label:n.EMOJI_PICKER_CATEGORIES.SMILEYS_AND_PEOPLE,icon:c.DtIconSatisfied},{label:n.EMOJI_PICKER_CATEGORIES.NATURE,icon:c.DtIconLivingThing},{label:n.EMOJI_PICKER_CATEGORIES.FOOD,icon:c.DtIconFood},{label:n.EMOJI_PICKER_CATEGORIES.ACTIVITY,icon:c.DtIconObject},{label:n.EMOJI_PICKER_CATEGORIES.TRAVEL,icon:c.DtIconTransportation},{label:n.EMOJI_PICKER_CATEGORIES.OBJECTS,icon:c.DtIconLightbulb},{label:n.EMOJI_PICKER_CATEGORIES.SYMBOLS,icon:c.DtIconHeart},{label:n.EMOJI_PICKER_CATEGORIES.FLAGS,icon:c.DtIconFlag},{label:n.EMOJI_PICKER_CATEGORIES.CUSTOM,icon:c.DtIconTiktok}]}},computed:{tabs(){const t=this.showRecentlyUsedTab?this.TABS_DATA:this.TABS_DATA.slice(1);return this.showCustomEmojisTab||t.pop(),t.map((e,i)=>({...e,label:this.tabSetLabels[i],id:(i+1).toString(),panelId:(i+1).toString()}))},isSearching(){return this.emojiFilter.length>0}},watch:{scrollIntoTab:function(t){this.isSearching||(this.selectedTab=(t+1).toString())},isSearching:function(t){t&&(this.selectedTab=null)}},mounted(){this.$nextTick(()=>{this.setTabsetRef()})},methods:{selectTabset(t){const e=parseInt(t);this.selectedTab=t,this.$emit("selected-tabset",e)},setTabsetRef(){this.tabs.forEach((t,e)=>{const i=`tabsetRef-${e}`;this.$refs[i]&&this.$set(this.tabsetRef,e,this.$refs[i][0].$el)})},focusTabset(){this.tabsetRef[0]&&this.tabsetRef[0].focus()},handleKeyDown(t,e){t.key==="Enter"&&(this.selectTabset(e),this.tabsetRef[e-1]&&this.tabsetRef[e-1].blur()),t.key==="Tab"&&(t.preventDefault(),t.shiftKey?this.$emit("focus-skin-selector"):this.$emit("focus-search-input")),t.key==="ArrowDown"&&this.$emit("focus-search-input")}}};var R=function(){var e=this,i=e._self._c;return i("div",{staticClass:"d-emoji-picker__tabset"},[i("dt-tab-group",{attrs:{size:"sm","tab-list-class":"d-emoji-picker__tabset-list",selected:e.selectedTab},scopedSlots:e._u([{key:"tabs",fn:function(){return e._l(e.tabs,function(s,o){return i("dt-tab",{key:s.id,ref:`tabsetRef-${o}`,refInFor:!0,attrs:{id:s.id,"panel-id":s.panelId,label:s.label,"aria-controls":"d-emoji-picker-list",tabindex:o+1},on:{"!click":function(r){return r.stopPropagation(),e.selectTabset(s.id)},keydown:function(r){return e.handleKeyDown(r,s.id)}}},[i(s.icon,{tag:"component",attrs:{size:"400"}})],1)})},proxy:!0}])})],1)},k=[],S=u.n(j,R,k,!1,null,null);const g=S.exports,y={name:"EmojiSearch",components:{DtInput:p.default,DtIconSearch:c.DtIconSearch,DtIconClose:c.DtIconClose,DtButton:m.default},props:{searchPlaceholderLabel:{type:String,required:!0},modelValue:{type:String,default:""}},mounted(){this.focusSearchInput()},methods:{updateModelValue(t){this.$emit("update:model-value",t)},focusEmojiSelector(){this.$emit("focus-emoji-selector")},focusTabset(){this.$emit("focus-tabset")},selectFirstEmoji(){this.$emit("select-first-emoji")},clearSearch(){this.$emit("update:model-value",""),this.focusSearchInput()},focusSearchInput(){this.$refs.searchInputRef.focus()}}};var I=function(){var e=this,i=e._self._c;return i("div",{staticClass:"d-emoji-picker__search d-emoji-picker__alignment"},[i("dt-input",{ref:"searchInputRef",attrs:{id:"searchInput",placeholder:e.searchPlaceholderLabel,value:e.modelValue},on:{input:e.updateModelValue,keydown:[function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"up",38,s.key,["Up","ArrowUp"])?null:e.focusTabset.apply(null,arguments)},function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"down",40,s.key,["Down","ArrowDown"])?null:(s.preventDefault(),e.focusEmojiSelector.apply(null,arguments))},function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"enter",13,s.key,"Enter")?null:e.selectFirstEmoji.apply(null,arguments)}]},scopedSlots:e._u([{key:"leftIcon",fn:function(){return[i("dt-icon-search",{attrs:{size:"200"}})]},proxy:!0},e.modelValue.length>0?{key:"rightIcon",fn:function(){return[i("dt-button",{staticClass:"d-emoji-picker__search-x-button",attrs:{importance:"clear",size:"xs",circle:"",kind:"muted"},on:{click:e.clearSearch},scopedSlots:e._u([{key:"icon",fn:function(){return[i("dt-icon-close",{attrs:{size:"200"}})]},proxy:!0}],null,!1,4156074325)})]},proxy:!0}:null],null,!0)})],1)},T=[],$=u.n(y,I,T,!1,null,null);const O=$.exports,v={name:"EmojiSelector",props:{emojiFilter:{type:String,default:""},skinTone:{type:String,required:!0},tabSetLabels:{type:Array,required:!0},selectedTabset:{type:Object,required:!0},searchResultsLabel:{type:String,required:!0},searchNoResultsLabel:{type:String,required:!0},recentlyUsedEmojis:{type:Array,default:()=>[]},customEmojis:{type:Array,default:()=>[]}},data(){return{tabLabelsRefs:[],emojiRefs:[],emojiFilteredRefs:[],isFiltering:!1,hoverFirstEmoji:!0,fixedLabel:"",filteredEmojis:[],TABS_DATA:["Recently used","People","Nature","Food","Activity","Travel","Objects","Symbols","Flags","Custom"],tabLabelObserver:null}},computed:{currentEmojis(){return[...this.emojis[`People${this.skinTone}`]||[],...this.emojis.Nature||[],...this.emojis.Food||[],...this.emojis[`Activity${this.skinTone}`]||[],...this.emojis.Travel||[],...this.emojis[`Objects${this.skinTone}`]||[],...this.emojis.Symbols||[],...this.emojis.Flags||[]]},emojis(){return b.emojisGrouped},CDN_URL(){return n.CDN_URL},tabLabels(){let t=this.tabSetLabels.map(e=>({label:e}));return this.recentlyUsedEmojis.length||(t=this.tabSetLabels.slice(1).map(e=>({label:e}))),this.customEmojis.length||t.pop(),t},tabs(){const t=this.recentlyUsedEmojis.length?this.TABS_DATA.slice():this.TABS_DATA.slice(1);return this.customEmojis.length||t.pop(),t}},watch:{currentEmojis:{handler(){this.searchByNameAndKeywords()},immediate:!0},recentlyUsedEmojis:{handler(t){this.emojis["Recently used"]=t},immediate:!0},customEmojis:{handler(t){this.emojis.Custom=t},immediate:!0},emojiFilter:{handler(t){this.resetScroll(),t?this.isFiltering=!0:(this.isFiltering=!1,this.$emit("highlighted-emoji",null)),this.debouncedSearch()}},selectedTabset:{handler(t){this.scrollToTab(t.tabId)},deep:!0}},created(){this.debouncedSearch=this.debounce(this.searchByNameAndKeywords,300)},mounted(){this.$nextTick(()=>{this.setupEmojiRefs(),this.setupFilteredRefs(),this.setupTabLabelRefs(),this.setTabLabelObserver(),this.setBottomScrollListener()})},beforeDestroy(){this.tabLabelObserver&&this.tabLabelObserver.disconnect(),this.$refs.listRef&&this.handleScroll&&this.$refs.listRef.removeEventListener("scroll",this.handleScroll)},methods:{setupTabLabelRefs(){var t;(t=this.tabSetLabels)==null||t.forEach((e,i)=>{const s=`tabLabelRef-${i}`;this.$refs[s]&&this.$set(this.tabLabelsRefs,i,{ref:this.$refs[s]})})},setupFilteredRefs(){this.emojiFilteredRefs=[],this.filteredEmojis.forEach((t,e)=>{const i=`filteredEmoji-${e}`;this.$refs[i]&&this.setFilteredRef(this.$refs[i],e)})},setupEmojiRefs(){for(let t=0;t<this.tabs.length;t++){const e=`emojiRef-${t}`;this.$refs[e]&&this.$refs[e].forEach((i,s)=>{i&&this.setEmojiRef(i,t,s)})}},searchByNameAndKeywords(){const t=this.emojiFilter.toLowerCase();this.filteredEmojis=this.currentEmojis.filter(function(e){const i=e.name.toLowerCase().includes(t),s=e.keywords.some(function(o){return o.toLowerCase().includes(t)});return i||s}),this.$nextTick(function(){t&&(this.hoverEmoji(this.filteredEmojis[0],!0),this.setupFilteredRefs())})},debounce:function(t,e){e===void 0&&(e=300);let i;return function(){const s=[];let o=arguments.length;for(;o--;)s[o]=arguments[o];clearTimeout(i),i=setTimeout(function(){t.apply(void 0,s)},e)}},getImgSrc:function(t){return t.date_added?t.image:this.CDN_URL+t.unicode_character+".png"},handleImageError:function(t){t.target.parentNode.style.display="none"},scrollToTab:function(t,e){const i=this;e===void 0&&(e=!0);const s=i.tabLabelsRefs[t-1].ref[0];i.$nextTick(function(){const o=i.$refs.listRef,r=t===1?0:s.offsetTop-15;o.scrollTop=r,e&&i.focusEmoji(t-1,0)})},resetScroll:function(){const t=this.$refs.listRef;t.scrollTop=0},focusEmojiSelector:function(){this.focusEmoji(0,0)},hoverEmoji(t,e){e===void 0&&(e=!1),this.hoverFirstEmoji=e,this.$emit("highlighted-emoji",t)},setEmojiRef:function(t,e,i){this.emojiRefs[e]||this.$set(this.emojiRefs,e,[]),this.$set(this.emojiRefs[e],i,t)},setFilteredRef:function(t,e){this.$set(this.emojiFilteredRefs,e,t)},focusEmoji:function(t,e){var s;const i=this.isFiltering?(s=this.emojiFilteredRefs[e])==null?void 0:s[0]:this.emojiRefs[t]&&this.emojiRefs[t][e];return i?(i.focus(),!0):!1},handleKeyDown:function(t,e,i,s){var o,r;if(t.preventDefault(),t.key==="ArrowUp"){const l=i%n.EMOJIS_PER_ROW;if(e===0){const a=n.EMOJIS_PER_ROW-this.emojiRefs[this.emojiRefs.length-1].length%n.EMOJIS_PER_ROW,f=this.emojiRefs[this.emojiRefs.length-1].length+a-(n.EMOJIS_PER_ROW-l);this.focusEmoji(this.emojiRefs.length-1,f)||this.focusEmoji(this.emojiRefs.length-1,this.emojiRefs[this.emojiRefs.length-1].length-1);return}if(!this.focusEmoji(e,i-n.EMOJIS_PER_ROW)){const a=e-1<0?0:e-1,f=this.emojiRefs[a].length,h=f-f%n.EMOJIS_PER_ROW+l;this.focusEmoji(a,h)||this.focusEmoji(e-1,this.emojiRefs[e-1].length-1)}}if(t.key==="ArrowDown"&&!this.focusEmoji(e,i+n.EMOJIS_PER_ROW)){const l=i%n.EMOJIS_PER_ROW;(r=(o=this.emojiRefs)==null?void 0:o[e])!=null&&r[i+(n.EMOJIS_PER_ROW-l)]?this.focusEmoji(e,this.emojiRefs[e].length-1):this.focusEmoji(e+1,l)||this.focusEmoji(0,l)||this.focusEmoji(0,this.emojiRefs[0].length-1)}t.key==="ArrowLeft"&&this.handleHorizontalNavigation("left",e,i),t.key==="ArrowRight"&&this.handleHorizontalNavigation("right",e,i),t.key==="Tab"&&!t.shiftKey&&(this.focusEmoji(e+1,0)?this.scrollToTab(e+1+1,!1):this.$emit("focus-skin-selector")),t.key==="Tab"&&t.shiftKey&&(this.focusEmoji(e,0)&&e>0?this.scrollToTab(e,!0):(this.scrollToTab(1,!1),this.$emit("focus-search-input"))),t.key==="Enter"&&this.handleEmojiSelection(s,t)},handleHorizontalNavigation:function(t,e,i){this.isFiltering?t==="left"?this.handleArrowLeftFiltered(e,i):t==="right"&&this.handleArrowRightFiltered(e,i):t==="left"?this.handleArrowLeft(e,i):t==="right"&&this.handleArrowRight(e,i)},handleArrowLeftFiltered:function(t,e){this.focusEmoji(0,e-1)||this.focusEmoji(0,this.emojiFilteredRefs.length-1)},handleArrowRightFiltered:function(t,e){this.focusEmoji(0,e+1)||this.focusEmoji(0,0)},handleArrowLeft:function(t,e){this.focusEmoji(t,e-1)||(this.emojiRefs[t-1]?this.focusEmoji(t-1,this.emojiRefs[t-1].length-1):this.focusEmoji(this.emojiRefs.length-1,this.emojiRefs[this.emojiRefs.length-1].length-1))},handleArrowRight:function(t,e){this.focusEmoji(t,e+1)||this.focusEmoji(t+1,0)||this.focusEmoji(0,0)},handleEmojiSelection(t,e){this.$emit("selected-emoji",{...t,shift_key:e.shiftKey})},handleKeyDownFilteredEmojis(t,e,i){var s;if(t.preventDefault(),this.hoverFirstEmoji=!1,t.key==="ArrowUp"){const o=e%n.EMOJIS_PER_ROW;if(!this.focusEmoji(0,e-n.EMOJIS_PER_ROW)){const r=this.emojiFilteredRefs.length-this.emojiFilteredRefs.length%n.EMOJIS_PER_ROW+o;this.focusEmoji(0,r),this.focusEmoji(0,r)||this.focusEmoji(0,this.emojiFilteredRefs.length-1)}}if(t.key==="ArrowDown"&&!this.focusEmoji(0,e+n.EMOJIS_PER_ROW)){const o=e%n.EMOJIS_PER_ROW;(s=this.emojiFilteredRefs)!=null&&s[e+(n.EMOJIS_PER_ROW-o)]?this.focusEmoji(0,this.emojiFilteredRefs.length-1):this.focusEmoji(0,o)}t.key==="ArrowLeft"&&this.handleHorizontalNavigation("left",0,e),t.key==="ArrowRight"&&this.handleHorizontalNavigation("right",0,e),t.key==="Tab"&&this.$emit("focus-skin-selector"),t.key==="Enter"&&this.handleEmojiSelection(i,t)},setBottomScrollListener(){this.handleScroll=()=>{const t=this.$refs.listRef;t.scrollTop+t.clientHeight>=t.scrollHeight&&this.$emit("scroll-bottom-reached")},this.$refs.listRef.addEventListener("scroll",this.handleScroll)},setTabLabelObserver(){this.tabLabelObserver=new IntersectionObserver(t=>{t.forEach(e=>{var o,r,l,a,f,h;const{target:i}=e,s=parseInt(i.dataset.index);e.isIntersecting&&i.offsetTop<=((o=this.$refs.tabCategoryRef)==null?void 0:o.offsetTop)+50?(this.fixedLabel=((r=this.tabLabels[s-1])==null?void 0:r.label)??((l=this.tabLabels[0])==null?void 0:l.label),this.$emit("scroll-into-tab",s-1)):e.boundingClientRect.bottom<=((a=this.$refs.tabCategoryRef)==null?void 0:a.getBoundingClientRect().bottom)?(this.$emit("scroll-into-tab",s),this.fixedLabel=(f=this.tabLabels[s])==null?void 0:f.label):s===1&&(this.$emit("scroll-into-tab",s),this.fixedLabel=(h=this.tabLabels[0])==null?void 0:h.label)})}),this.tabLabelObserver.observe(this.$refs.tabCategoryRef),Array.from(this.$refs.listRef.children).forEach((t,e)=>{this.tabLabelObserver.observe(t),t.dataset.index=e})},focusLastEmoji(){this.scrollToTab(this.tabs.length,!0)}}};var L=function(){var e=this,i=e._self._c;return i("div",{staticClass:"d-emoji-picker__selector"},[i("div",{ref:"listRef",staticClass:"d-emoji-picker__list",attrs:{id:"d-emoji-picker-list"}},[e.emojiFilter?i("p",{staticClass:"d-emoji-picker__search-label d-emoji-picker__alignment"},[e._v(" "+e._s(e.filteredEmojis.length>0?e.searchResultsLabel:e.searchNoResultsLabel)+" ")]):i("div",{ref:"tabCategoryRef",staticClass:"d-emoji-picker__category d-emoji-picker__alignment"},[i("p",[e._v(" "+e._s(e.fixedLabel)+" ")])]),e._l(e.tabLabels,function(s,o){return i("div",{directives:[{name:"show",rawName:"v-show",value:!e.emojiFilter,expression:"!emojiFilter"}],key:o,ref:`tabLabelRef-${o}`,refInFor:!0,staticClass:"d-emoji-picker__alignment"},[o?i("p",[e._v(" "+e._s(s.label)+" ")]):e._e(),i("div",{staticClass:"d-emoji-picker__tab"},e._l(e.emojis[e.tabs[o]+e.skinTone]?e.emojis[e.tabs[o]+e.skinTone]:e.emojis[e.tabs[o]],function(r,l){return i("button",{key:r.shortname,ref:`emojiRef-${o}`,refInFor:!0,attrs:{type:"button","aria-label":r.name},on:{click:a=>e.handleEmojiSelection(r,a),focusin:function(a){return e.$emit("highlighted-emoji",r)},focusout:function(a){return e.$emit("highlighted-emoji",null)},mouseover:function(a){return e.$emit("highlighted-emoji",r)},mouseleave:function(a){return e.$emit("highlighted-emoji",null)},keydown:a=>e.handleKeyDown(a,o,l,r)}},[i("img",{staticClass:"d-icon d-icon--size-500",attrs:{alt:r.name,"aria-label":r.name,title:r.name,src:e.getImgSrc(r)},on:{error:e.handleImageError}})])}),0)])}),e.emojiFilter?i("div",{staticClass:"d-emoji-picker__alignment"},[i("div",{staticClass:"d-emoji-picker__tab",attrs:{"data-qa":"filtered-emojis"}},e._l(e.filteredEmojis,function(s,o){return i("button",{key:s.shortname,ref:`filteredEmoji-${o}`,refInFor:!0,class:{"hover-emoji":o===0&&e.hoverFirstEmoji},attrs:{type:"button","aria-label":s.name},on:{click:r=>e.handleEmojiSelection(s,r),focusin:function(r){return e.$emit("highlighted-emoji",s)},focusout:function(r){return e.$emit("highlighted-emoji",null)},mouseover:function(r){return e.hoverEmoji(s)},mouseleave:function(r){return e.hoverEmoji(null)},keydown:r=>e.handleKeyDownFilteredEmojis(r,o,s)}},[i("img",{staticClass:"d-icon d-icon--size-500",attrs:{alt:s.name,"aria-label":s.name,title:s.name,src:`${e.CDN_URL+s.unicode_character}.png`}})])}),0)]):e._e()],2)])},C=[],w=u.n(v,L,C,!1,null,null);const D=w.exports,A={name:"EmojiDescription",props:{emoji:{type:Object,default:()=>null}},data(){return{CDN_URL:n.CDN_URL}},methods:{getImgSrc(t){return t.date_added?t.image:`${n.CDN_URL+t.unicode_character}.png`}}};var F=function(){var s;var e=this,i=e._self._c;return i("div",{staticClass:"d-emoji-picker__data"},[e.emoji?i("img",{staticClass:"d-icon d-icon--size-500",attrs:{alt:e.emoji.name,"aria-label":e.emoji.name,title:e.emoji.name,src:e.getImgSrc(e.emoji)}}):e._e(),i("div",[e._v(e._s((s=e.emoji)==null?void 0:s.name))])])},M=[],P=u.n(A,F,M,!1,null,null);const K=P.exports,N={name:"EmojiSkinSelector",components:{DtTooltip:E.default},props:{skinTone:{type:String,required:!0},isHovering:{type:Boolean,default:!1},skinSelectorButtonTooltipLabel:{type:String,required:!0}},data(){return{isOpen:!1,skinSelected:null,skinsRef:[],cdnUrl:n.CDN_URL}},computed:{skinPassedIn(){return this.skinList.find(t=>t.skinTone===this.skinTone)},skinList(){return[{name:":wave_tone1:",unicode_output:"1f44b-1f3fb",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.LIGHT,skinCode:"_tone1"},{name:":wave_tone2:",unicode_output:"1f44b-1f3fc",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM_LIGHT,skinCode:"_tone2"},{name:":wave_tone3:",unicode_output:"1f44b-1f3fd",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM,skinCode:"_tone3"},{name:":wave_tone4:",unicode_output:"1f44b-1f3fe",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM_DARK,skinCode:"_tone4"},{name:":wave_tone5:",unicode_output:"1f44b-1f3ff",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.DARK,skinCode:"_tone5"},{name:":wave:",unicode_output:"1f44b",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.DEFAULT,skinCode:""}]}},watch:{isHovering(t){t&&(this.isOpen=!1)},skinTone(t,e){t!==e&&(this.skinSelected=this.skinPassedIn)}},mounted(){this.skinSelected=this.skinPassedIn,this.$nextTick(()=>{this.setupSkinRefs()})},methods:{setupSkinRefs(){this.skinList.forEach((t,e)=>{const i=`skinRef-${e}`;this.$refs[i]&&this.$set(this.skinsRef,e,this.$refs[i][0])})},focusSkinSelector(){this.$refs.skinSelectorRef&&this.$refs.skinSelectorRef.focus()},selectSkin(t){this.skinSelected=t,this.isOpen=!1,this.$emit("skin-tone",t.skinTone),this.$nextTick(()=>{this.focusSkinSelector()})},handleKeyDown(t,e,i){var s,o,r,l;t.preventDefault(),t.key==="ArrowLeft"&&(i===0&&((s=this.skinsRef[this.skinsRef.length-1])==null||s.focus()),(o=this.skinsRef[i-1])==null||o.focus()),t.key==="ArrowRight"&&(this.skinsRef.length&&((r=this.skinsRef[0])==null||r.focus()),(l=this.skinsRef[i+1])==null||l.focus()),t.key==="Enter"&&(e?this.selectSkin(e):this.toggleSkinList()),t.key==="Tab"&&(t.shiftKey?this.$emit("focus-last-emoji"):this.$emit("focus-tabset"))},toggleSkinList(){this.isOpen=!this.isOpen,this.$nextTick(()=>{this.skinsRef[0]&&this.skinsRef[0].focus()})}}};var J=function(){var e=this,i=e._self._c;return i("div",{attrs:{"data-qa":"skin-selector"}},[i("div",{directives:[{name:"show",rawName:"v-show",value:e.isOpen,expression:"isOpen"}],staticClass:"d-emoji-picker__skin-list"},e._l(e.skinList,function(s,o){var r;return i("button",{key:s.name,ref:`skinRef-${o}`,refInFor:!0,class:{selected:((r=e.skinSelected)==null?void 0:r.skinCode)===s.skinCode},on:{click:function(l){return e.selectSkin(s)},keydown:l=>e.handleKeyDown(l,s,o)}},[i("img",{staticClass:"d-icon d-icon--size-500",attrs:{alt:s.name,"aria-label":s.name,title:s.name,src:`${e.cdnUrl+s.unicode_output}.png`}})])}),0),i("div",{directives:[{name:"show",rawName:"v-show",value:!e.isOpen,expression:"!isOpen"}],staticClass:"d-emoji-picker__skin-selected"},[i("dt-tooltip",{attrs:{placement:"top-end"},scopedSlots:e._u([{key:"anchor",fn:function(){var s,o,r,l;return[i("button",{ref:"skinSelectorRef",attrs:{"aria-label":e.skinSelectorButtonTooltipLabel,tabindex:"-1"},on:{click:e.toggleSkinList,keydown:a=>e.handleKeyDown(a)}},[i("img",{staticClass:"d-icon d-icon--size-500",attrs:{alt:(s=e.skinSelected)==null?void 0:s.name,"aria-label":(o=e.skinSelected)==null?void 0:o.name,title:(r=e.skinSelected)==null?void 0:r.name,src:`${e.cdnUrl+((l=e.skinSelected)==null?void 0:l.unicode_output)}.png`}})])]},proxy:!0}])},[e._v(" "+e._s(e.skinSelectorButtonTooltipLabel)+" ")])],1)])},U=[],q=u.n(N,J,U,!1,null,null);const B=q.exports,z={name:"DtEmojiPicker",components:{EmojiTabset:g,EmojiSearch:O,EmojiSelector:D,EmojiDescription:K,EmojiSkinSelector:B,DtButton:m.default},props:{recentlyUsedEmojis:{type:Array},customEmojis:{type:Array},addEmojiLabel:{type:String,required:!1,default:"Add emoji"},searchPlaceholderLabel:{type:String,required:!0},searchResultsLabel:{type:String,required:!0},searchNoResultsLabel:{type:String,required:!0},tabSetLabels:{type:Array,required:!0},skinTone:{type:String,default:"Default"},skinSelectorButtonTooltipLabel:{type:String,required:!0},searchQuery:{type:String,default:""},showSearch:{type:Boolean,default:!0}},data(){return{internalSearchQuery:this.searchQuery,highlightedEmoji:null,selectedTabset:{},scrollIntoTab:0}},computed:{showCustomEmojisTab(){var t;return((t=this.customEmojis)==null?void 0:t.length)>0},showRecentlyUsedTab(){var t;return((t=this.recentlyUsedEmojis)==null?void 0:t.length)>0}},watch:{searchQuery(t){this.internalSearchQuery=t}},methods:{scrollToSelectedTabset(t){this.internalSearchQuery="",this.selectedTabset={...this.selectedTabset,tabId:t}},updateScrollIntoTab(t){this.scrollIntoTab=t},updateHighlightedEmoji(t){this.highlightedEmoji=t}}};var G=function(){var e=this,i=e._self._c;return i("div",{staticClass:"d-emoji-picker"},[i("div",{staticClass:"d-emoji-picker--header"},[i("emoji-tabset",{ref:"tabsetRef",attrs:{"emoji-filter":e.internalSearchQuery,"show-custom-emojis-tab":e.showCustomEmojisTab,"show-recently-used-tab":e.showRecentlyUsedTab,"scroll-into-tab":e.scrollIntoTab,"tab-set-labels":e.tabSetLabels},on:{"focus-skin-selector":function(s){return e.$refs.skinSelectorRef.focusSkinSelector()},"focus-search-input":function(s){e.showSearch?e.$refs.searchInputRef.focusSearchInput():e.$refs.emojiSelectorRef.focusEmojiSelector()},"selected-tabset":e.scrollToSelectedTabset},nativeOn:{keydown:function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"esc",27,s.key,["Esc","Escape"])?null:e.$emit("close")}}})],1),i("div",{staticClass:"d-emoji-picker--body"},[e.showSearch?i("emoji-search",{ref:"searchInputRef",attrs:{"model-value":e.internalSearchQuery,"search-placeholder-label":e.searchPlaceholderLabel},on:{"update:model-value":s=>e.internalSearchQuery=s,"select-first-emoji":function(s){return e.$emit("selected-emoji",e.highlightedEmoji)},"focus-tabset":function(s){return e.$refs.tabsetRef.focusTabset()},"focus-emoji-selector":function(s){return e.$refs.emojiSelectorRef.focusEmojiSelector()}},nativeOn:{keydown:function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"esc",27,s.key,["Esc","Escape"])?null:e.$emit("close")}}}):e._e(),i("emoji-selector",{ref:"emojiSelectorRef",attrs:{"emoji-filter":e.internalSearchQuery,"skin-tone":e.skinTone,"tab-set-labels":e.tabSetLabels,"search-results-label":e.searchResultsLabel,"search-no-results-label":e.searchNoResultsLabel,"recently-used-emojis":e.recentlyUsedEmojis,"custom-emojis":e.customEmojis,"selected-tabset":e.selectedTabset},on:{"scroll-into-tab":e.updateScrollIntoTab,"highlighted-emoji":e.updateHighlightedEmoji,"selected-emoji":function(s){return e.$emit("selected-emoji",s)},"focus-skin-selector":function(s){return e.$refs.skinSelectorRef.focusSkinSelector()},"focus-search-input":function(s){e.showSearch?e.$refs.searchInputRef.focusSearchInput():e.$refs.tabsetRef.focusTabset()},"scroll-bottom-reached":function(s){return e.$emit("scroll-bottom-reached")}},nativeOn:{keydown:function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"esc",27,s.key,["Esc","Escape"])?null:e.$emit("close")}}})],1),i("div",{staticClass:"d-emoji-picker--footer"},[e.showCustomEmojisTab&&!e.highlightedEmoji?i("dt-button",{staticClass:"d-emoji-picker__add-emoji",attrs:{importance:"outlined","aria-label":e.addEmojiLabel},on:{click:function(s){return e.$emit("add-emoji")}}},[e._v(" "+e._s(e.addEmojiLabel)+" ")]):e._e(),i("emoji-description",{attrs:{emoji:e.highlightedEmoji}}),i("emoji-skin-selector",{ref:"skinSelectorRef",attrs:{"is-hovering":!!e.highlightedEmoji,"skin-selector-button-tooltip-label":e.skinSelectorButtonTooltipLabel,"skin-tone":e.skinTone},on:{"skin-tone":function(s){return e.$emit("skin-tone",s)},"focus-tabset":function(s){return e.$refs.tabsetRef.focusTabset()},"focus-last-emoji":function(s){return e.$refs.emojiSelectorRef.focusLastEmoji()}},nativeOn:{keydown:function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"esc",27,s.key,["Esc","Escape"])?null:e.$emit("close")}}})],1)])},W=[],H=u.n(z,G,W,!1,null,null);const Q=H.exports;exports.default=Q;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const n=require("./emoji-picker-constants.cjs"),c=require("@dialpad/dialtone-icons/vue2"),u=require("../../_plugin-vue2_normalizer-e_CkxkSV.cjs"),d=require("../tab/tab-group.cjs"),_=require("../tab/tab.cjs"),p=require("../input/input.cjs"),m=require("../button/button.cjs"),b=require("@dialpad/dialtone-emojis"),E=require("../tooltip/tooltip.cjs"),j={name:"EmojiTabset",components:{DtTabGroup:d.default,DtTab:_.default},props:{showRecentlyUsedTab:{type:Boolean,default:!1},showCustomEmojisTab:{type:Boolean,default:!1},scrollIntoTab:{type:Number,required:!0},emojiFilter:{type:String,default:""},tabSetLabels:{type:Array,required:!0}},data(){return{selectedTab:"1",tabsetRef:[],TABS_DATA:[{label:n.EMOJI_PICKER_CATEGORIES.MOST_RECENTLY_USED,icon:c.DtIconClock},{label:n.EMOJI_PICKER_CATEGORIES.SMILEYS_AND_PEOPLE,icon:c.DtIconSatisfied},{label:n.EMOJI_PICKER_CATEGORIES.NATURE,icon:c.DtIconLivingThing},{label:n.EMOJI_PICKER_CATEGORIES.FOOD,icon:c.DtIconFood},{label:n.EMOJI_PICKER_CATEGORIES.ACTIVITY,icon:c.DtIconObject},{label:n.EMOJI_PICKER_CATEGORIES.TRAVEL,icon:c.DtIconTransportation},{label:n.EMOJI_PICKER_CATEGORIES.OBJECTS,icon:c.DtIconLightbulb},{label:n.EMOJI_PICKER_CATEGORIES.SYMBOLS,icon:c.DtIconHeart},{label:n.EMOJI_PICKER_CATEGORIES.FLAGS,icon:c.DtIconFlag},{label:n.EMOJI_PICKER_CATEGORIES.CUSTOM,icon:c.DtIconTiktok}]}},computed:{tabs(){const t=this.showRecentlyUsedTab?this.TABS_DATA:this.TABS_DATA.slice(1);return this.showCustomEmojisTab||t.pop(),t.map((e,i)=>({...e,label:this.tabSetLabels[i],id:(i+1).toString(),panelId:(i+1).toString()}))},isSearching(){return this.emojiFilter.length>0}},watch:{scrollIntoTab:function(t){this.isSearching||(this.selectedTab=(t+1).toString())},isSearching:function(t){t&&(this.selectedTab=null)}},mounted(){this.$nextTick(()=>{this.setTabsetRef()})},methods:{selectTabset(t){const e=parseInt(t);this.selectedTab=t,this.$emit("selected-tabset",e)},setTabsetRef(){this.tabs.forEach((t,e)=>{const i=`tabsetRef-${e}`;this.$refs[i]&&this.$set(this.tabsetRef,e,this.$refs[i][0].$el)})},focusTabset(){this.tabsetRef[0]&&this.tabsetRef[0].focus()},handleKeyDown(t,e){t.key==="Enter"&&(this.selectTabset(e),this.tabsetRef[e-1]&&this.tabsetRef[e-1].blur()),t.key==="Tab"&&(t.preventDefault(),t.shiftKey?this.$emit("focus-skin-selector"):this.$emit("focus-search-input")),t.key==="ArrowDown"&&this.$emit("focus-search-input")}}};var R=function(){var e=this,i=e._self._c;return i("div",{staticClass:"d-emoji-picker__tabset"},[i("dt-tab-group",{attrs:{size:"sm","tab-list-class":"d-emoji-picker__tabset-list",selected:e.selectedTab},scopedSlots:e._u([{key:"tabs",fn:function(){return e._l(e.tabs,function(s,o){return i("dt-tab",{key:s.id,ref:`tabsetRef-${o}`,refInFor:!0,attrs:{id:s.id,"panel-id":s.panelId,label:s.label,"aria-controls":"d-emoji-picker-list",tabindex:o+1},on:{"!click":function(r){return r.stopPropagation(),e.selectTabset(s.id)},keydown:function(r){return e.handleKeyDown(r,s.id)}}},[i(s.icon,{tag:"component",attrs:{size:"400"}})],1)})},proxy:!0}])})],1)},k=[],S=u.n(j,R,k);const g=S.exports,y={name:"EmojiSearch",components:{DtInput:p.default,DtIconSearch:c.DtIconSearch,DtIconClose:c.DtIconClose,DtButton:m.default},props:{searchPlaceholderLabel:{type:String,required:!0},modelValue:{type:String,default:""}},mounted(){this.focusSearchInput()},methods:{updateModelValue(t){this.$emit("update:model-value",t)},focusEmojiSelector(){this.$emit("focus-emoji-selector")},focusTabset(){this.$emit("focus-tabset")},selectFirstEmoji(){this.$emit("select-first-emoji")},clearSearch(){this.$emit("update:model-value",""),this.focusSearchInput()},focusSearchInput(){this.$refs.searchInputRef.focus()}}};var I=function(){var e=this,i=e._self._c;return i("div",{staticClass:"d-emoji-picker__search d-emoji-picker__alignment"},[i("dt-input",{ref:"searchInputRef",attrs:{id:"searchInput",placeholder:e.searchPlaceholderLabel,value:e.modelValue},on:{input:e.updateModelValue,keydown:[function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"up",38,s.key,["Up","ArrowUp"])?null:e.focusTabset.apply(null,arguments)},function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"down",40,s.key,["Down","ArrowDown"])?null:(s.preventDefault(),e.focusEmojiSelector.apply(null,arguments))},function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"enter",13,s.key,"Enter")?null:e.selectFirstEmoji.apply(null,arguments)}]},scopedSlots:e._u([{key:"leftIcon",fn:function(){return[i("dt-icon-search",{attrs:{size:"200"}})]},proxy:!0},e.modelValue.length>0?{key:"rightIcon",fn:function(){return[i("dt-button",{staticClass:"d-emoji-picker__search-x-button",attrs:{importance:"clear",size:"xs",circle:"",kind:"muted"},on:{click:e.clearSearch},scopedSlots:e._u([{key:"icon",fn:function(){return[i("dt-icon-close",{attrs:{size:"200"}})]},proxy:!0}],null,!1,4156074325)})]},proxy:!0}:null],null,!0)})],1)},T=[],$=u.n(y,I,T);const O=$.exports,v={name:"EmojiSelector",props:{emojiFilter:{type:String,default:""},skinTone:{type:String,required:!0},tabSetLabels:{type:Array,required:!0},selectedTabset:{type:Object,required:!0},searchResultsLabel:{type:String,required:!0},searchNoResultsLabel:{type:String,required:!0},recentlyUsedEmojis:{type:Array,default:()=>[]},customEmojis:{type:Array,default:()=>[]}},data(){return{tabLabelsRefs:[],emojiRefs:[],emojiFilteredRefs:[],isFiltering:!1,hoverFirstEmoji:!0,fixedLabel:"",filteredEmojis:[],TABS_DATA:["Recently used","People","Nature","Food","Activity","Travel","Objects","Symbols","Flags","Custom"],tabLabelObserver:null}},computed:{currentEmojis(){return[...this.emojis[`People${this.skinTone}`]||[],...this.emojis.Nature||[],...this.emojis.Food||[],...this.emojis[`Activity${this.skinTone}`]||[],...this.emojis.Travel||[],...this.emojis[`Objects${this.skinTone}`]||[],...this.emojis.Symbols||[],...this.emojis.Flags||[]]},emojis(){return b.emojisGrouped},CDN_URL(){return n.CDN_URL},tabLabels(){let t=this.tabSetLabels.map(e=>({label:e}));return this.recentlyUsedEmojis.length||(t=this.tabSetLabels.slice(1).map(e=>({label:e}))),this.customEmojis.length||t.pop(),t},tabs(){const t=this.recentlyUsedEmojis.length?this.TABS_DATA.slice():this.TABS_DATA.slice(1);return this.customEmojis.length||t.pop(),t}},watch:{currentEmojis:{handler(){this.searchByNameAndKeywords()},immediate:!0},recentlyUsedEmojis:{handler(t){this.emojis["Recently used"]=t},immediate:!0},customEmojis:{handler(t){this.emojis.Custom=t},immediate:!0},emojiFilter:{handler(t){this.resetScroll(),t?this.isFiltering=!0:(this.isFiltering=!1,this.$emit("highlighted-emoji",null)),this.debouncedSearch()}},selectedTabset:{handler(t){this.scrollToTab(t.tabId)},deep:!0}},created(){this.debouncedSearch=this.debounce(this.searchByNameAndKeywords,300)},mounted(){this.$nextTick(()=>{this.setupEmojiRefs(),this.setupFilteredRefs(),this.setupTabLabelRefs(),this.setTabLabelObserver(),this.setBottomScrollListener()})},beforeDestroy(){this.tabLabelObserver&&this.tabLabelObserver.disconnect(),this.$refs.listRef&&this.handleScroll&&this.$refs.listRef.removeEventListener("scroll",this.handleScroll)},methods:{setupTabLabelRefs(){var t;(t=this.tabSetLabels)==null||t.forEach((e,i)=>{const s=`tabLabelRef-${i}`;this.$refs[s]&&this.$set(this.tabLabelsRefs,i,{ref:this.$refs[s]})})},setupFilteredRefs(){this.emojiFilteredRefs=[],this.filteredEmojis.forEach((t,e)=>{const i=`filteredEmoji-${e}`;this.$refs[i]&&this.setFilteredRef(this.$refs[i],e)})},setupEmojiRefs(){for(let t=0;t<this.tabs.length;t++){const e=`emojiRef-${t}`;this.$refs[e]&&this.$refs[e].forEach((i,s)=>{i&&this.setEmojiRef(i,t,s)})}},searchByNameAndKeywords(){const t=this.emojiFilter.toLowerCase();this.filteredEmojis=this.currentEmojis.filter(function(e){const i=e.name.toLowerCase().includes(t),s=e.keywords.some(function(o){return o.toLowerCase().includes(t)});return i||s}),this.$nextTick(function(){t&&(this.hoverEmoji(this.filteredEmojis[0],!0),this.setupFilteredRefs())})},debounce:function(t,e){e===void 0&&(e=300);let i;return function(){const s=[];let o=arguments.length;for(;o--;)s[o]=arguments[o];clearTimeout(i),i=setTimeout(function(){t.apply(void 0,s)},e)}},getImgSrc:function(t){return t.date_added?t.image:this.CDN_URL+t.unicode_character+".png"},handleImageError:function(t){t.target.parentNode.style.display="none"},scrollToTab:function(t,e){const i=this;e===void 0&&(e=!0);const s=i.tabLabelsRefs[t-1].ref[0];i.$nextTick(function(){const o=i.$refs.listRef,r=t===1?0:s.offsetTop-15;o.scrollTop=r,e&&i.focusEmoji(t-1,0)})},resetScroll:function(){const t=this.$refs.listRef;t.scrollTop=0},focusEmojiSelector:function(){this.focusEmoji(0,0)},hoverEmoji(t,e){e===void 0&&(e=!1),this.hoverFirstEmoji=e,this.$emit("highlighted-emoji",t)},setEmojiRef:function(t,e,i){this.emojiRefs[e]||this.$set(this.emojiRefs,e,[]),this.$set(this.emojiRefs[e],i,t)},setFilteredRef:function(t,e){this.$set(this.emojiFilteredRefs,e,t)},focusEmoji:function(t,e){var s;const i=this.isFiltering?(s=this.emojiFilteredRefs[e])==null?void 0:s[0]:this.emojiRefs[t]&&this.emojiRefs[t][e];return i?(i.focus(),!0):!1},handleKeyDown:function(t,e,i,s){var o,r;if(t.preventDefault(),t.key==="ArrowUp"){const l=i%n.EMOJIS_PER_ROW;if(e===0){const a=n.EMOJIS_PER_ROW-this.emojiRefs[this.emojiRefs.length-1].length%n.EMOJIS_PER_ROW,f=this.emojiRefs[this.emojiRefs.length-1].length+a-(n.EMOJIS_PER_ROW-l);this.focusEmoji(this.emojiRefs.length-1,f)||this.focusEmoji(this.emojiRefs.length-1,this.emojiRefs[this.emojiRefs.length-1].length-1);return}if(!this.focusEmoji(e,i-n.EMOJIS_PER_ROW)){const a=e-1<0?0:e-1,f=this.emojiRefs[a].length,h=f-f%n.EMOJIS_PER_ROW+l;this.focusEmoji(a,h)||this.focusEmoji(e-1,this.emojiRefs[e-1].length-1)}}if(t.key==="ArrowDown"&&!this.focusEmoji(e,i+n.EMOJIS_PER_ROW)){const l=i%n.EMOJIS_PER_ROW;(r=(o=this.emojiRefs)==null?void 0:o[e])!=null&&r[i+(n.EMOJIS_PER_ROW-l)]?this.focusEmoji(e,this.emojiRefs[e].length-1):this.focusEmoji(e+1,l)||this.focusEmoji(0,l)||this.focusEmoji(0,this.emojiRefs[0].length-1)}t.key==="ArrowLeft"&&this.handleHorizontalNavigation("left",e,i),t.key==="ArrowRight"&&this.handleHorizontalNavigation("right",e,i),t.key==="Tab"&&!t.shiftKey&&(this.focusEmoji(e+1,0)?this.scrollToTab(e+1+1,!1):this.$emit("focus-skin-selector")),t.key==="Tab"&&t.shiftKey&&(this.focusEmoji(e,0)&&e>0?this.scrollToTab(e,!0):(this.scrollToTab(1,!1),this.$emit("focus-search-input"))),t.key==="Enter"&&this.handleEmojiSelection(s,t)},handleHorizontalNavigation:function(t,e,i){this.isFiltering?t==="left"?this.handleArrowLeftFiltered(e,i):t==="right"&&this.handleArrowRightFiltered(e,i):t==="left"?this.handleArrowLeft(e,i):t==="right"&&this.handleArrowRight(e,i)},handleArrowLeftFiltered:function(t,e){this.focusEmoji(0,e-1)||this.focusEmoji(0,this.emojiFilteredRefs.length-1)},handleArrowRightFiltered:function(t,e){this.focusEmoji(0,e+1)||this.focusEmoji(0,0)},handleArrowLeft:function(t,e){this.focusEmoji(t,e-1)||(this.emojiRefs[t-1]?this.focusEmoji(t-1,this.emojiRefs[t-1].length-1):this.focusEmoji(this.emojiRefs.length-1,this.emojiRefs[this.emojiRefs.length-1].length-1))},handleArrowRight:function(t,e){this.focusEmoji(t,e+1)||this.focusEmoji(t+1,0)||this.focusEmoji(0,0)},handleEmojiSelection(t,e){this.$emit("selected-emoji",{...t,shift_key:e.shiftKey})},handleKeyDownFilteredEmojis(t,e,i){var s;if(t.preventDefault(),this.hoverFirstEmoji=!1,t.key==="ArrowUp"){const o=e%n.EMOJIS_PER_ROW;if(!this.focusEmoji(0,e-n.EMOJIS_PER_ROW)){const r=this.emojiFilteredRefs.length-this.emojiFilteredRefs.length%n.EMOJIS_PER_ROW+o;this.focusEmoji(0,r),this.focusEmoji(0,r)||this.focusEmoji(0,this.emojiFilteredRefs.length-1)}}if(t.key==="ArrowDown"&&!this.focusEmoji(0,e+n.EMOJIS_PER_ROW)){const o=e%n.EMOJIS_PER_ROW;(s=this.emojiFilteredRefs)!=null&&s[e+(n.EMOJIS_PER_ROW-o)]?this.focusEmoji(0,this.emojiFilteredRefs.length-1):this.focusEmoji(0,o)}t.key==="ArrowLeft"&&this.handleHorizontalNavigation("left",0,e),t.key==="ArrowRight"&&this.handleHorizontalNavigation("right",0,e),t.key==="Tab"&&this.$emit("focus-skin-selector"),t.key==="Enter"&&this.handleEmojiSelection(i,t)},setBottomScrollListener(){this.handleScroll=()=>{const t=this.$refs.listRef;t.scrollTop+t.clientHeight>=t.scrollHeight&&this.$emit("scroll-bottom-reached")},this.$refs.listRef.addEventListener("scroll",this.handleScroll)},setTabLabelObserver(){this.tabLabelObserver=new IntersectionObserver(t=>{t.forEach(e=>{var o,r,l,a,f,h;const{target:i}=e,s=parseInt(i.dataset.index);e.isIntersecting&&i.offsetTop<=((o=this.$refs.tabCategoryRef)==null?void 0:o.offsetTop)+50?(this.fixedLabel=((r=this.tabLabels[s-1])==null?void 0:r.label)??((l=this.tabLabels[0])==null?void 0:l.label),this.$emit("scroll-into-tab",s-1)):e.boundingClientRect.bottom<=((a=this.$refs.tabCategoryRef)==null?void 0:a.getBoundingClientRect().bottom)?(this.$emit("scroll-into-tab",s),this.fixedLabel=(f=this.tabLabels[s])==null?void 0:f.label):s===1&&(this.$emit("scroll-into-tab",s),this.fixedLabel=(h=this.tabLabels[0])==null?void 0:h.label)})}),this.tabLabelObserver.observe(this.$refs.tabCategoryRef),Array.from(this.$refs.listRef.children).forEach((t,e)=>{this.tabLabelObserver.observe(t),t.dataset.index=e})},focusLastEmoji(){this.scrollToTab(this.tabs.length,!0)}}};var L=function(){var e=this,i=e._self._c;return i("div",{staticClass:"d-emoji-picker__selector"},[i("div",{ref:"listRef",staticClass:"d-emoji-picker__list",attrs:{id:"d-emoji-picker-list"}},[e.emojiFilter?i("p",{staticClass:"d-emoji-picker__search-label d-emoji-picker__alignment"},[e._v(" "+e._s(e.filteredEmojis.length>0?e.searchResultsLabel:e.searchNoResultsLabel)+" ")]):i("div",{ref:"tabCategoryRef",staticClass:"d-emoji-picker__category d-emoji-picker__alignment"},[i("p",[e._v(" "+e._s(e.fixedLabel)+" ")])]),e._l(e.tabLabels,function(s,o){return i("div",{directives:[{name:"show",rawName:"v-show",value:!e.emojiFilter,expression:"!emojiFilter"}],key:o,ref:`tabLabelRef-${o}`,refInFor:!0,staticClass:"d-emoji-picker__alignment"},[o?i("p",[e._v(" "+e._s(s.label)+" ")]):e._e(),i("div",{staticClass:"d-emoji-picker__tab"},e._l(e.emojis[e.tabs[o]+e.skinTone]?e.emojis[e.tabs[o]+e.skinTone]:e.emojis[e.tabs[o]],function(r,l){return i("button",{key:r.shortname,ref:`emojiRef-${o}`,refInFor:!0,attrs:{type:"button","aria-label":r.name},on:{click:a=>e.handleEmojiSelection(r,a),focusin:function(a){return e.$emit("highlighted-emoji",r)},focusout:function(a){return e.$emit("highlighted-emoji",null)},mouseover:function(a){return e.$emit("highlighted-emoji",r)},mouseleave:function(a){return e.$emit("highlighted-emoji",null)},keydown:a=>e.handleKeyDown(a,o,l,r)}},[i("img",{staticClass:"d-icon d-icon--size-500",attrs:{alt:r.name,"aria-label":r.name,title:r.name,src:e.getImgSrc(r)},on:{error:e.handleImageError}})])}),0)])}),e.emojiFilter?i("div",{staticClass:"d-emoji-picker__alignment"},[i("div",{staticClass:"d-emoji-picker__tab",attrs:{"data-qa":"filtered-emojis"}},e._l(e.filteredEmojis,function(s,o){return i("button",{key:s.shortname,ref:`filteredEmoji-${o}`,refInFor:!0,class:{"hover-emoji":o===0&&e.hoverFirstEmoji},attrs:{type:"button","aria-label":s.name},on:{click:r=>e.handleEmojiSelection(s,r),focusin:function(r){return e.$emit("highlighted-emoji",s)},focusout:function(r){return e.$emit("highlighted-emoji",null)},mouseover:function(r){return e.hoverEmoji(s)},mouseleave:function(r){return e.hoverEmoji(null)},keydown:r=>e.handleKeyDownFilteredEmojis(r,o,s)}},[i("img",{staticClass:"d-icon d-icon--size-500",attrs:{alt:s.name,"aria-label":s.name,title:s.name,src:`${e.CDN_URL+s.unicode_character}.png`}})])}),0)]):e._e()],2)])},C=[],w=u.n(v,L,C);const D=w.exports,A={name:"EmojiDescription",props:{emoji:{type:Object,default:()=>null}},data(){return{CDN_URL:n.CDN_URL}},methods:{getImgSrc(t){return t.date_added?t.image:`${n.CDN_URL+t.unicode_character}.png`}}};var F=function(){var s;var e=this,i=e._self._c;return i("div",{staticClass:"d-emoji-picker__data"},[e.emoji?i("img",{staticClass:"d-icon d-icon--size-500",attrs:{alt:e.emoji.name,"aria-label":e.emoji.name,title:e.emoji.name,src:e.getImgSrc(e.emoji)}}):e._e(),i("div",[e._v(e._s((s=e.emoji)==null?void 0:s.name))])])},M=[],P=u.n(A,F,M);const K=P.exports,N={name:"EmojiSkinSelector",components:{DtTooltip:E.default},props:{skinTone:{type:String,required:!0},isHovering:{type:Boolean,default:!1},skinSelectorButtonTooltipLabel:{type:String,required:!0}},data(){return{isOpen:!1,skinSelected:null,skinsRef:[],cdnUrl:n.CDN_URL}},computed:{skinPassedIn(){return this.skinList.find(t=>t.skinTone===this.skinTone)},skinList(){return[{name:":wave_tone1:",unicode_output:"1f44b-1f3fb",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.LIGHT,skinCode:"_tone1"},{name:":wave_tone2:",unicode_output:"1f44b-1f3fc",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM_LIGHT,skinCode:"_tone2"},{name:":wave_tone3:",unicode_output:"1f44b-1f3fd",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM,skinCode:"_tone3"},{name:":wave_tone4:",unicode_output:"1f44b-1f3fe",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM_DARK,skinCode:"_tone4"},{name:":wave_tone5:",unicode_output:"1f44b-1f3ff",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.DARK,skinCode:"_tone5"},{name:":wave:",unicode_output:"1f44b",skinTone:n.EMOJI_PICKER_SKIN_TONE_MODIFIERS.DEFAULT,skinCode:""}]}},watch:{isHovering(t){t&&(this.isOpen=!1)},skinTone(t,e){t!==e&&(this.skinSelected=this.skinPassedIn)}},mounted(){this.skinSelected=this.skinPassedIn,this.$nextTick(()=>{this.setupSkinRefs()})},methods:{setupSkinRefs(){this.skinList.forEach((t,e)=>{const i=`skinRef-${e}`;this.$refs[i]&&this.$set(this.skinsRef,e,this.$refs[i][0])})},focusSkinSelector(){this.$refs.skinSelectorRef&&this.$refs.skinSelectorRef.focus()},selectSkin(t){this.skinSelected=t,this.isOpen=!1,this.$emit("skin-tone",t.skinTone),this.$nextTick(()=>{this.focusSkinSelector()})},handleKeyDown(t,e,i){var s,o,r,l;t.preventDefault(),t.key==="ArrowLeft"&&(i===0&&((s=this.skinsRef[this.skinsRef.length-1])==null||s.focus()),(o=this.skinsRef[i-1])==null||o.focus()),t.key==="ArrowRight"&&(this.skinsRef.length&&((r=this.skinsRef[0])==null||r.focus()),(l=this.skinsRef[i+1])==null||l.focus()),t.key==="Enter"&&(e?this.selectSkin(e):this.toggleSkinList()),t.key==="Tab"&&(t.shiftKey?this.$emit("focus-last-emoji"):this.$emit("focus-tabset"))},toggleSkinList(){this.isOpen=!this.isOpen,this.$nextTick(()=>{this.skinsRef[0]&&this.skinsRef[0].focus()})}}};var J=function(){var e=this,i=e._self._c;return i("div",{attrs:{"data-qa":"skin-selector"}},[i("div",{directives:[{name:"show",rawName:"v-show",value:e.isOpen,expression:"isOpen"}],staticClass:"d-emoji-picker__skin-list"},e._l(e.skinList,function(s,o){var r;return i("button",{key:s.name,ref:`skinRef-${o}`,refInFor:!0,class:{selected:((r=e.skinSelected)==null?void 0:r.skinCode)===s.skinCode},on:{click:function(l){return e.selectSkin(s)},keydown:l=>e.handleKeyDown(l,s,o)}},[i("img",{staticClass:"d-icon d-icon--size-500",attrs:{alt:s.name,"aria-label":s.name,title:s.name,src:`${e.cdnUrl+s.unicode_output}.png`}})])}),0),i("div",{directives:[{name:"show",rawName:"v-show",value:!e.isOpen,expression:"!isOpen"}],staticClass:"d-emoji-picker__skin-selected"},[i("dt-tooltip",{attrs:{placement:"top-end"},scopedSlots:e._u([{key:"anchor",fn:function(){var s,o,r,l;return[i("button",{ref:"skinSelectorRef",attrs:{"aria-label":e.skinSelectorButtonTooltipLabel,tabindex:"-1"},on:{click:e.toggleSkinList,keydown:a=>e.handleKeyDown(a)}},[i("img",{staticClass:"d-icon d-icon--size-500",attrs:{alt:(s=e.skinSelected)==null?void 0:s.name,"aria-label":(o=e.skinSelected)==null?void 0:o.name,title:(r=e.skinSelected)==null?void 0:r.name,src:`${e.cdnUrl+((l=e.skinSelected)==null?void 0:l.unicode_output)}.png`}})])]},proxy:!0}])},[e._v(" "+e._s(e.skinSelectorButtonTooltipLabel)+" ")])],1)])},U=[],q=u.n(N,J,U);const B=q.exports,z={name:"DtEmojiPicker",components:{EmojiTabset:g,EmojiSearch:O,EmojiSelector:D,EmojiDescription:K,EmojiSkinSelector:B,DtButton:m.default},props:{recentlyUsedEmojis:{type:Array},customEmojis:{type:Array},addEmojiLabel:{type:String,required:!1,default:"Add emoji"},searchPlaceholderLabel:{type:String,required:!0},searchResultsLabel:{type:String,required:!0},searchNoResultsLabel:{type:String,required:!0},tabSetLabels:{type:Array,required:!0},skinTone:{type:String,default:"Default"},skinSelectorButtonTooltipLabel:{type:String,required:!0},searchQuery:{type:String,default:""},showSearch:{type:Boolean,default:!0}},data(){return{internalSearchQuery:this.searchQuery,highlightedEmoji:null,selectedTabset:{},scrollIntoTab:0}},computed:{showCustomEmojisTab(){var t;return((t=this.customEmojis)==null?void 0:t.length)>0},showRecentlyUsedTab(){var t;return((t=this.recentlyUsedEmojis)==null?void 0:t.length)>0}},watch:{searchQuery(t){this.internalSearchQuery=t}},methods:{scrollToSelectedTabset(t){this.internalSearchQuery="",this.selectedTabset={...this.selectedTabset,tabId:t}},updateScrollIntoTab(t){this.scrollIntoTab=t},updateHighlightedEmoji(t){this.highlightedEmoji=t}}};var G=function(){var e=this,i=e._self._c;return i("div",{staticClass:"d-emoji-picker"},[i("div",{staticClass:"d-emoji-picker--header"},[i("emoji-tabset",{ref:"tabsetRef",attrs:{"emoji-filter":e.internalSearchQuery,"show-custom-emojis-tab":e.showCustomEmojisTab,"show-recently-used-tab":e.showRecentlyUsedTab,"scroll-into-tab":e.scrollIntoTab,"tab-set-labels":e.tabSetLabels},on:{"focus-skin-selector":function(s){return e.$refs.skinSelectorRef.focusSkinSelector()},"focus-search-input":function(s){e.showSearch?e.$refs.searchInputRef.focusSearchInput():e.$refs.emojiSelectorRef.focusEmojiSelector()},"selected-tabset":e.scrollToSelectedTabset},nativeOn:{keydown:function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"esc",27,s.key,["Esc","Escape"])?null:e.$emit("close")}}})],1),i("div",{staticClass:"d-emoji-picker--body"},[e.showSearch?i("emoji-search",{ref:"searchInputRef",attrs:{"model-value":e.internalSearchQuery,"search-placeholder-label":e.searchPlaceholderLabel},on:{"update:model-value":s=>e.internalSearchQuery=s,"select-first-emoji":function(s){return e.$emit("selected-emoji",e.highlightedEmoji)},"focus-tabset":function(s){return e.$refs.tabsetRef.focusTabset()},"focus-emoji-selector":function(s){return e.$refs.emojiSelectorRef.focusEmojiSelector()}},nativeOn:{keydown:function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"esc",27,s.key,["Esc","Escape"])?null:e.$emit("close")}}}):e._e(),i("emoji-selector",{ref:"emojiSelectorRef",attrs:{"emoji-filter":e.internalSearchQuery,"skin-tone":e.skinTone,"tab-set-labels":e.tabSetLabels,"search-results-label":e.searchResultsLabel,"search-no-results-label":e.searchNoResultsLabel,"recently-used-emojis":e.recentlyUsedEmojis,"custom-emojis":e.customEmojis,"selected-tabset":e.selectedTabset},on:{"scroll-into-tab":e.updateScrollIntoTab,"highlighted-emoji":e.updateHighlightedEmoji,"selected-emoji":function(s){return e.$emit("selected-emoji",s)},"focus-skin-selector":function(s){return e.$refs.skinSelectorRef.focusSkinSelector()},"focus-search-input":function(s){e.showSearch?e.$refs.searchInputRef.focusSearchInput():e.$refs.tabsetRef.focusTabset()},"scroll-bottom-reached":function(s){return e.$emit("scroll-bottom-reached")}},nativeOn:{keydown:function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"esc",27,s.key,["Esc","Escape"])?null:e.$emit("close")}}})],1),i("div",{staticClass:"d-emoji-picker--footer"},[e.showCustomEmojisTab&&!e.highlightedEmoji?i("dt-button",{staticClass:"d-emoji-picker__add-emoji",attrs:{importance:"outlined","aria-label":e.addEmojiLabel},on:{click:function(s){return e.$emit("add-emoji")}}},[e._v(" "+e._s(e.addEmojiLabel)+" ")]):e._e(),i("emoji-description",{attrs:{emoji:e.highlightedEmoji}}),i("emoji-skin-selector",{ref:"skinSelectorRef",attrs:{"is-hovering":!!e.highlightedEmoji,"skin-selector-button-tooltip-label":e.skinSelectorButtonTooltipLabel,"skin-tone":e.skinTone},on:{"skin-tone":function(s){return e.$emit("skin-tone",s)},"focus-tabset":function(s){return e.$refs.tabsetRef.focusTabset()},"focus-last-emoji":function(s){return e.$refs.emojiSelectorRef.focusLastEmoji()}},nativeOn:{keydown:function(s){return!s.type.indexOf("key")&&e._k(s.keyCode,"esc",27,s.key,["Esc","Escape"])?null:e.$emit("close")}}})],1)])},W=[],H=u.n(z,G,W);const Q=H.exports;exports.default=Q;
2
2
  //# sourceMappingURL=emoji-picker.cjs.map
@@ -1 +1 @@
1
- {"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 size=\"sm\"\n tab-list-class=\"d-emoji-picker__tabset-list\"\n :selected=\"selectedTab\"\n >\n <template #tabs>\n <dt-tab\n v-for=\"(tab, index) in tabs\"\n :id=\"tab.id\"\n :ref=\"`tabsetRef-${index}`\"\n :key=\"tab.id\"\n :panel-id=\"tab.panelId\"\n :label=\"tab.label\"\n aria-controls=\"d-emoji-picker-list\"\n :tabindex=\"index + 1\"\n @click.capture.stop=\"selectTabset(tab.id)\"\n @keydown=\"handleKeyDown($event, 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 { EMOJI_PICKER_CATEGORIES } from '@/components/emoji_picker/emoji_picker_constants';\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: EMOJI_PICKER_CATEGORIES.MOST_RECENTLY_USED, icon: DtIconClock },\n { label: EMOJI_PICKER_CATEGORIES.SMILEYS_AND_PEOPLE, icon: DtIconSatisfied },\n { label: EMOJI_PICKER_CATEGORIES.NATURE, icon: DtIconLivingThing },\n { label: EMOJI_PICKER_CATEGORIES.FOOD, icon: DtIconFood },\n { label: EMOJI_PICKER_CATEGORIES.ACTIVITY, icon: DtIconObject },\n { label: EMOJI_PICKER_CATEGORIES.TRAVEL, icon: DtIconTransportation },\n { label: EMOJI_PICKER_CATEGORIES.OBJECTS, icon: DtIconLightbulb },\n { label: EMOJI_PICKER_CATEGORIES.SYMBOLS, icon: DtIconHeart },\n { label: EMOJI_PICKER_CATEGORIES.FLAGS, icon: DtIconFlag },\n { label: EMOJI_PICKER_CATEGORIES.CUSTOM, 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 label: this.tabSetLabels[index],\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 /* 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';\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 },\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 label for the add emoji button\n * required false because it is still experimental\n * @type {String}\n * @example\n * <dt-emoji-picker :addEmojiLabel=\"'Add emoji'\" />\n */\n addEmojiLabel: {\n type: String,\n required: false,\n default: 'Add emoji',\n },\n\n /**\n * The placeholder text for the search input\n * @type {String}\n * @required\n * @example\n * <dt-emoji-picker :searchPlaceholderLabel=\"'Search...'\" />\n */\n searchPlaceholderLabel: {\n type: String,\n required: true,\n },\n\n /**\n * The label for the search results tab\n * @type {String}\n * @required\n * @example\n * <dt-emoji-picker :searchResultsLabel=\"'Search results'\" />\n */\n searchResultsLabel: {\n type: String,\n required: true,\n },\n\n /**\n * The label for the search no results\n * @type {String}\n * @required\n * @example\n * <dt-emoji-picker :searchNoResultsLabel=\"'No results'\" />\n */\n searchNoResultsLabel: {\n type: String,\n required: true,\n },\n\n /**\n * The list of tabsets to show, it is necessary to be updated with the correct language\n * It must respect the provided order.\n * @type {Array}\n * @required\n * @example\n * <dt-emoji-picker\n * :tabSetLabels=\"['Most recently used', 'Smileys and people', 'Nature',\n * 'Food', 'Activity', 'Travel', 'Objects', 'Symbols', 'Flags', 'Custom']\" />\n */\n tabSetLabels: {\n type: Array,\n required: true,\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 * Tooltip shown when skin selector button is hovered.\n * @type {String}\n * @required\n * @example\n * <dt-emoji-picker :skin-selector-button-tooltip-label=\"'Change default skin tone'\" />\n */\n skinSelectorButtonTooltipLabel: {\n type: String,\n required: true,\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 };\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\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","EMOJI_PICKER_CATEGORIES","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"],"mappings":"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"}
1
+ {"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 size=\"sm\"\n tab-list-class=\"d-emoji-picker__tabset-list\"\n :selected=\"selectedTab\"\n >\n <template #tabs>\n <dt-tab\n v-for=\"(tab, index) in tabs\"\n :id=\"tab.id\"\n :ref=\"`tabsetRef-${index}`\"\n :key=\"tab.id\"\n :panel-id=\"tab.panelId\"\n :label=\"tab.label\"\n aria-controls=\"d-emoji-picker-list\"\n :tabindex=\"index + 1\"\n @click.capture.stop=\"selectTabset(tab.id)\"\n @keydown=\"handleKeyDown($event, 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 { EMOJI_PICKER_CATEGORIES } from '@/components/emoji_picker/emoji_picker_constants';\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: EMOJI_PICKER_CATEGORIES.MOST_RECENTLY_USED, icon: DtIconClock },\n { label: EMOJI_PICKER_CATEGORIES.SMILEYS_AND_PEOPLE, icon: DtIconSatisfied },\n { label: EMOJI_PICKER_CATEGORIES.NATURE, icon: DtIconLivingThing },\n { label: EMOJI_PICKER_CATEGORIES.FOOD, icon: DtIconFood },\n { label: EMOJI_PICKER_CATEGORIES.ACTIVITY, icon: DtIconObject },\n { label: EMOJI_PICKER_CATEGORIES.TRAVEL, icon: DtIconTransportation },\n { label: EMOJI_PICKER_CATEGORIES.OBJECTS, icon: DtIconLightbulb },\n { label: EMOJI_PICKER_CATEGORIES.SYMBOLS, icon: DtIconHeart },\n { label: EMOJI_PICKER_CATEGORIES.FLAGS, icon: DtIconFlag },\n { label: EMOJI_PICKER_CATEGORIES.CUSTOM, 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 label: this.tabSetLabels[index],\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 /* 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';\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 },\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 label for the add emoji button\n * required false because it is still experimental\n * @type {String}\n * @example\n * <dt-emoji-picker :addEmojiLabel=\"'Add emoji'\" />\n */\n addEmojiLabel: {\n type: String,\n required: false,\n default: 'Add emoji',\n },\n\n /**\n * The placeholder text for the search input\n * @type {String}\n * @required\n * @example\n * <dt-emoji-picker :searchPlaceholderLabel=\"'Search...'\" />\n */\n searchPlaceholderLabel: {\n type: String,\n required: true,\n },\n\n /**\n * The label for the search results tab\n * @type {String}\n * @required\n * @example\n * <dt-emoji-picker :searchResultsLabel=\"'Search results'\" />\n */\n searchResultsLabel: {\n type: String,\n required: true,\n },\n\n /**\n * The label for the search no results\n * @type {String}\n * @required\n * @example\n * <dt-emoji-picker :searchNoResultsLabel=\"'No results'\" />\n */\n searchNoResultsLabel: {\n type: String,\n required: true,\n },\n\n /**\n * The list of tabsets to show, it is necessary to be updated with the correct language\n * It must respect the provided order.\n * @type {Array}\n * @required\n * @example\n * <dt-emoji-picker\n * :tabSetLabels=\"['Most recently used', 'Smileys and people', 'Nature',\n * 'Food', 'Activity', 'Travel', 'Objects', 'Symbols', 'Flags', 'Custom']\" />\n */\n tabSetLabels: {\n type: Array,\n required: true,\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 * Tooltip shown when skin selector button is hovered.\n * @type {String}\n * @required\n * @example\n * <dt-emoji-picker :skin-selector-button-tooltip-label=\"'Change default skin tone'\" />\n */\n skinSelectorButtonTooltipLabel: {\n type: String,\n required: true,\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 };\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\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","EMOJI_PICKER_CATEGORIES","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"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { EMOJI_PICKER_CATEGORIES as c, CDN_URL as d, EMOJIS_PER_ROW as a, EMOJI_PICKER_SKIN_TONE_MODIFIERS as h } from "./emoji-picker-constants.js";
2
2
  import { DtIconClock as b, DtIconSatisfied as j, DtIconLivingThing as k, DtIconFood as _, DtIconObject as y, DtIconTransportation as g, DtIconLightbulb as S, DtIconHeart as R, DtIconFlag as E, DtIconTiktok as $, DtIconSearch as T, DtIconClose as v } from "@dialpad/dialtone-icons/vue2";
3
- import { n as u } from "../../_plugin-vue2_normalizer-CeySl7Fu.js";
3
+ import { n as u } from "../../_plugin-vue2_normalizer-DSLOjnn3.js";
4
4
  import L from "../tab/tab-group.js";
5
5
  import w from "../tab/tab.js";
6
6
  import I from "../input/input.js";
@@ -125,10 +125,7 @@ var F = function() {
125
125
  }, O = [], U = /* @__PURE__ */ u(
126
126
  A,
127
127
  F,
128
- O,
129
- !1,
130
- null,
131
- null
128
+ O
132
129
  );
133
130
  const N = U.exports, K = {
134
131
  name: "EmojiSearch",
@@ -190,10 +187,7 @@ var B = function() {
190
187
  }, P = [], q = /* @__PURE__ */ u(
191
188
  K,
192
189
  B,
193
- P,
194
- !1,
195
- null,
196
- null
190
+ P
197
191
  );
198
192
  const M = q.exports, z = {
199
193
  name: "EmojiSelector",
@@ -504,10 +498,7 @@ var H = function() {
504
498
  }, Q = [], V = /* @__PURE__ */ u(
505
499
  z,
506
500
  H,
507
- Q,
508
- !1,
509
- null,
510
- null
501
+ Q
511
502
  );
512
503
  const G = V.exports, J = {
513
504
  name: "EmojiDescription",
@@ -540,10 +531,7 @@ var Y = function() {
540
531
  }, W = [], X = /* @__PURE__ */ u(
541
532
  J,
542
533
  Y,
543
- W,
544
- !1,
545
- null,
546
- null
534
+ W
547
535
  );
548
536
  const Z = X.exports, x = {
549
537
  name: "EmojiSkinSelector",
@@ -672,10 +660,7 @@ var ee = function() {
672
660
  }, te = [], se = /* @__PURE__ */ u(
673
661
  x,
674
662
  ee,
675
- te,
676
- !1,
677
- null,
678
- null
663
+ te
679
664
  );
680
665
  const ie = se.exports, oe = {
681
666
  name: "DtEmojiPicker",
@@ -890,10 +875,7 @@ var re = function() {
890
875
  }, ne = [], le = /* @__PURE__ */ u(
891
876
  oe,
892
877
  re,
893
- ne,
894
- !1,
895
- null,
896
- null
878
+ ne
897
879
  );
898
880
  const je = le.exports;
899
881
  export {