@dialpad/dialtone 9.130.0 → 9.131.1

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 (1131) hide show
  1. package/dist/css/dialtone-default-theme.css +8 -2
  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 +8 -2
  5. package/dist/css/dialtone.min.css +1 -1
  6. package/dist/css/tokens-docs.json +1 -1
  7. package/dist/tokens/css/tokens-dp-dark.css +104 -265
  8. package/dist/tokens/css/tokens-expressive-dark.css +104 -265
  9. package/dist/tokens/css/tokens-expressive-sm-dark.css +104 -265
  10. package/dist/tokens/css/tokens-tmo-dark.css +104 -265
  11. package/dist/tokens/doc.json +43289 -45313
  12. package/dist/tokens/themes/dp-dark.cjs +1 -1
  13. package/dist/tokens/themes/dp-dark.js +1 -1
  14. package/dist/tokens/themes/expressive-dark.cjs +1 -1
  15. package/dist/tokens/themes/expressive-dark.js +1 -1
  16. package/dist/tokens/themes/expressive-sm-dark.cjs +1 -1
  17. package/dist/tokens/themes/expressive-sm-dark.js +1 -1
  18. package/dist/tokens/themes/tmo-dark.cjs +1 -1
  19. package/dist/tokens/themes/tmo-dark.js +1 -1
  20. package/dist/tokens/tokens-dp-dark.json +11 -34
  21. package/dist/tokens/tokens-expressive-dark.json +11 -34
  22. package/dist/tokens/tokens-expressive-sm-dark.json +11 -34
  23. package/dist/tokens/tokens-tmo-dark.json +11 -34
  24. package/dist/vue2/common/constants/index.cjs.map +1 -1
  25. package/dist/vue2/common/constants/index.js.map +1 -1
  26. package/dist/vue2/common/dates/index.cjs.map +1 -1
  27. package/dist/vue2/common/dates/index.js +3 -3
  28. package/dist/vue2/common/dates/index.js.map +1 -1
  29. package/dist/vue2/common/emoji/index.cjs.map +1 -1
  30. package/dist/vue2/common/emoji/index.js.map +1 -1
  31. package/dist/vue2/common/mixins/dom.cjs.map +1 -1
  32. package/dist/vue2/common/mixins/dom.js.map +1 -1
  33. package/dist/vue2/common/mixins/input-group.cjs.map +1 -1
  34. package/dist/vue2/common/mixins/input-group.js +5 -5
  35. package/dist/vue2/common/mixins/input-group.js.map +1 -1
  36. package/dist/vue2/common/mixins/input.cjs.map +1 -1
  37. package/dist/vue2/common/mixins/input.js.map +1 -1
  38. package/dist/vue2/common/mixins/keyboard-list-navigation.cjs.map +1 -1
  39. package/dist/vue2/common/mixins/keyboard-list-navigation.js.map +1 -1
  40. package/dist/vue2/common/mixins/modal.cjs.map +1 -1
  41. package/dist/vue2/common/mixins/modal.js.map +1 -1
  42. package/dist/vue2/common/mixins/skeleton.cjs.map +1 -1
  43. package/dist/vue2/common/mixins/skeleton.js.map +1 -1
  44. package/dist/vue2/common/utils/index.cjs.map +1 -1
  45. package/dist/vue2/common/utils/index.js +0 -1
  46. package/dist/vue2/common/utils/index.js.map +1 -1
  47. package/dist/vue2/common/validators/index.cjs.map +1 -1
  48. package/dist/vue2/common/validators/index.js.map +1 -1
  49. package/dist/vue2/lib/attachment-carousel/attachment-carousel.cjs +1 -1
  50. package/dist/vue2/lib/attachment-carousel/attachment-carousel.cjs.map +1 -1
  51. package/dist/vue2/lib/attachment-carousel/attachment-carousel.js +4 -4
  52. package/dist/vue2/lib/avatar/avatar-constants.cjs.map +1 -1
  53. package/dist/vue2/lib/avatar/avatar-constants.js.map +1 -1
  54. package/dist/vue2/lib/avatar/avatar.cjs.map +1 -1
  55. package/dist/vue2/lib/avatar/avatar.js +11 -11
  56. package/dist/vue2/lib/avatar/avatar.js.map +1 -1
  57. package/dist/vue2/lib/avatar/utils.cjs.map +1 -1
  58. package/dist/vue2/lib/avatar/utils.js.map +1 -1
  59. package/dist/vue2/lib/badge/badge.cjs.map +1 -1
  60. package/dist/vue2/lib/badge/badge.js +7 -7
  61. package/dist/vue2/lib/badge/badge.js.map +1 -1
  62. package/dist/vue2/lib/banner/banner.cjs +1 -1
  63. package/dist/vue2/lib/banner/banner.cjs.map +1 -1
  64. package/dist/vue2/lib/banner/banner.js +4 -4
  65. package/dist/vue2/lib/breadcrumbs/breadcrumb-item.cjs.map +1 -1
  66. package/dist/vue2/lib/breadcrumbs/breadcrumbs.cjs.map +1 -1
  67. package/dist/vue2/lib/button/button-constants.cjs.map +1 -1
  68. package/dist/vue2/lib/button/button-constants.js.map +1 -1
  69. package/dist/vue2/lib/button/button.cjs +1 -1
  70. package/dist/vue2/lib/button/button.cjs.map +1 -1
  71. package/dist/vue2/lib/button/button.js +14 -14
  72. package/dist/vue2/lib/button/button.js.map +1 -1
  73. package/dist/vue2/lib/button-group/button-group.cjs.map +1 -1
  74. package/dist/vue2/lib/button-group/buttons-decorator.cjs.map +1 -1
  75. package/dist/vue2/lib/callbar-button/callbar-button-constants.cjs.map +1 -1
  76. package/dist/vue2/lib/callbar-button/callbar-button-constants.js.map +1 -1
  77. package/dist/vue2/lib/callbar-button/callbar-button.cjs +1 -1
  78. package/dist/vue2/lib/callbar-button/callbar-button.cjs.map +1 -1
  79. package/dist/vue2/lib/callbar-button/callbar-button.js +3 -3
  80. package/dist/vue2/lib/callbar-button/callbar-button.js.map +1 -1
  81. package/dist/vue2/lib/callbar-button-with-dropdown/callbar-button-with-dropdown.cjs +1 -1
  82. package/dist/vue2/lib/callbar-button-with-dropdown/callbar-button-with-dropdown.cjs.map +1 -1
  83. package/dist/vue2/lib/callbar-button-with-dropdown/callbar-button-with-dropdown.js +6 -6
  84. package/dist/vue2/lib/callbar-button-with-dropdown/callbar-button-with-dropdown.js.map +1 -1
  85. package/dist/vue2/lib/callbar-button-with-popover/callbar-button-with-popover.cjs +1 -1
  86. package/dist/vue2/lib/callbar-button-with-popover/callbar-button-with-popover.cjs.map +1 -1
  87. package/dist/vue2/lib/callbar-button-with-popover/callbar-button-with-popover.js +6 -6
  88. package/dist/vue2/lib/callbar-button-with-popover/callbar-button-with-popover.js.map +1 -1
  89. package/dist/vue2/lib/callbox/callbox-constants.cjs.map +1 -1
  90. package/dist/vue2/lib/callbox/callbox-constants.js.map +1 -1
  91. package/dist/vue2/lib/callbox/callbox.cjs.map +1 -1
  92. package/dist/vue2/lib/callbox/callbox.js +5 -5
  93. package/dist/vue2/lib/checkbox/checkbox-constants.cjs.map +1 -1
  94. package/dist/vue2/lib/checkbox/checkbox-constants.js.map +1 -1
  95. package/dist/vue2/lib/checkbox/checkbox.cjs.map +1 -1
  96. package/dist/vue2/lib/checkbox-group/checkbox-group.cjs.map +1 -1
  97. package/dist/vue2/lib/checkbox-group/checkbox-group.js.map +1 -1
  98. package/dist/vue2/lib/checkbox-group/checkboxes-decorator.cjs.map +1 -1
  99. package/dist/vue2/lib/chip/chip-constants.cjs.map +1 -1
  100. package/dist/vue2/lib/chip/chip-constants.js.map +1 -1
  101. package/dist/vue2/lib/chip/chip.cjs.map +1 -1
  102. package/dist/vue2/lib/chip/chip.js +3 -3
  103. package/dist/vue2/lib/collapsible/collapsible.cjs +1 -1
  104. package/dist/vue2/lib/collapsible/collapsible.cjs.map +1 -1
  105. package/dist/vue2/lib/collapsible/collapsible.js +7 -7
  106. package/dist/vue2/lib/combobox/combobox-constants.cjs.map +1 -1
  107. package/dist/vue2/lib/combobox/combobox-constants.js.map +1 -1
  108. package/dist/vue2/lib/combobox/combobox-empty-list.cjs.map +1 -1
  109. package/dist/vue2/lib/combobox/combobox-loading-list.cjs +1 -1
  110. package/dist/vue2/lib/combobox/combobox-loading-list.cjs.map +1 -1
  111. package/dist/vue2/lib/combobox/combobox-loading-list.js +3 -3
  112. package/dist/vue2/lib/combobox/combobox.cjs +1 -1
  113. package/dist/vue2/lib/combobox/combobox.cjs.map +1 -1
  114. package/dist/vue2/lib/combobox/combobox.js +1 -1
  115. package/dist/vue2/lib/combobox/combobox.js.map +1 -1
  116. package/dist/vue2/lib/combobox-multi-select/combobox-multi-select-constants.cjs.map +1 -1
  117. package/dist/vue2/lib/combobox-multi-select/combobox-multi-select-constants.js.map +1 -1
  118. package/dist/vue2/lib/combobox-multi-select/combobox-multi-select-story-constants.cjs.map +1 -1
  119. package/dist/vue2/lib/combobox-multi-select/combobox-multi-select-story-constants.js.map +1 -1
  120. package/dist/vue2/lib/combobox-multi-select/combobox-multi-select.cjs +1 -1
  121. package/dist/vue2/lib/combobox-multi-select/combobox-multi-select.cjs.map +1 -1
  122. package/dist/vue2/lib/combobox-multi-select/combobox-multi-select.js +4 -4
  123. package/dist/vue2/lib/combobox-multi-select/combobox-multi-select.js.map +1 -1
  124. package/dist/vue2/lib/combobox-with-popover/combobox-with-popover.cjs +1 -1
  125. package/dist/vue2/lib/combobox-with-popover/combobox-with-popover.cjs.map +1 -1
  126. package/dist/vue2/lib/combobox-with-popover/combobox-with-popover.js +9 -9
  127. package/dist/vue2/lib/contact-centers-row/contact-centers-row.cjs +1 -1
  128. package/dist/vue2/lib/contact-centers-row/contact-centers-row.cjs.map +1 -1
  129. package/dist/vue2/lib/contact-centers-row/contact-centers-row.js +7 -7
  130. package/dist/vue2/lib/contact-centers-row/contact-centers-row.js.map +1 -1
  131. package/dist/vue2/lib/contact-info/contact-info.cjs.map +1 -1
  132. package/dist/vue2/lib/contact-row/contact-row.cjs +1 -1
  133. package/dist/vue2/lib/contact-row/contact-row.cjs.map +1 -1
  134. package/dist/vue2/lib/contact-row/contact-row.js +4 -4
  135. package/dist/vue2/lib/datepicker/datepicker.cjs +1 -1
  136. package/dist/vue2/lib/datepicker/datepicker.cjs.map +1 -1
  137. package/dist/vue2/lib/datepicker/datepicker.js +83 -83
  138. package/dist/vue2/lib/datepicker/datepicker.js.map +1 -1
  139. package/dist/vue2/lib/datepicker/formatUtils.cjs.map +1 -1
  140. package/dist/vue2/lib/datepicker/formatUtils.js.map +1 -1
  141. package/dist/vue2/lib/datepicker/utils.cjs.map +1 -1
  142. package/dist/vue2/lib/datepicker/utils.js.map +1 -1
  143. package/dist/vue2/lib/description-list/description-list.cjs.map +1 -1
  144. package/dist/vue2/lib/dropdown/dropdown-constants.cjs.map +1 -1
  145. package/dist/vue2/lib/dropdown/dropdown-constants.js.map +1 -1
  146. package/dist/vue2/lib/dropdown/dropdown-story-constants.cjs.map +1 -1
  147. package/dist/vue2/lib/dropdown/dropdown-story-constants.js.map +1 -1
  148. package/dist/vue2/lib/dropdown/dropdown.cjs +1 -1
  149. package/dist/vue2/lib/dropdown/dropdown.cjs.map +1 -1
  150. package/dist/vue2/lib/dropdown/dropdown.js +1 -1
  151. package/dist/vue2/lib/dropdown/dropdown.js.map +1 -1
  152. package/dist/vue2/lib/editor/editor-constants.cjs.map +1 -1
  153. package/dist/vue2/lib/editor/editor-constants.js.map +1 -1
  154. package/dist/vue2/lib/editor/editor.cjs +1 -1
  155. package/dist/vue2/lib/editor/editor.cjs.map +1 -1
  156. package/dist/vue2/lib/editor/editor.js +44 -44
  157. package/dist/vue2/lib/editor/editor.js.map +1 -1
  158. package/dist/vue2/lib/emoji/emoji.cjs.map +1 -1
  159. package/dist/vue2/lib/emoji/emoji.js +4 -4
  160. package/dist/vue2/lib/emoji-picker/emoji-picker-constants.cjs.map +1 -1
  161. package/dist/vue2/lib/emoji-picker/emoji-picker-constants.js.map +1 -1
  162. package/dist/vue2/lib/emoji-picker/emoji-picker.cjs +1 -1
  163. package/dist/vue2/lib/emoji-picker/emoji-picker.cjs.map +1 -1
  164. package/dist/vue2/lib/emoji-picker/emoji-picker.js +9 -9
  165. package/dist/vue2/lib/emoji-picker/emoji-picker.js.map +1 -1
  166. package/dist/vue2/lib/emoji-row/emoji-row-constants.cjs.map +1 -1
  167. package/dist/vue2/lib/emoji-row/emoji-row-constants.js.map +1 -1
  168. package/dist/vue2/lib/emoji-row/emoji-row.cjs +1 -1
  169. package/dist/vue2/lib/emoji-row/emoji-row.cjs.map +1 -1
  170. package/dist/vue2/lib/emoji-row/emoji-row.js +5 -5
  171. package/dist/vue2/lib/emoji-row/emoji-row.js.map +1 -1
  172. package/dist/vue2/lib/emoji-text-wrapper/emoji-text-wrapper.cjs +1 -1
  173. package/dist/vue2/lib/emoji-text-wrapper/emoji-text-wrapper.cjs.map +1 -1
  174. package/dist/vue2/lib/emoji-text-wrapper/emoji-text-wrapper.js +1 -1
  175. package/dist/vue2/lib/emoji-text-wrapper/emoji-text-wrapper.js.map +1 -1
  176. package/dist/vue2/lib/empty-state/empty-state-constants.cjs.map +1 -1
  177. package/dist/vue2/lib/empty-state/empty-state-constants.js.map +1 -1
  178. package/dist/vue2/lib/empty-state/empty-state.cjs.map +1 -1
  179. package/dist/vue2/lib/empty-state/empty-state.js +3 -3
  180. package/dist/vue2/lib/empty-state/empty-state.js.map +1 -1
  181. package/dist/vue2/lib/feed-item-pill/feed-item-pill-constants.cjs.map +1 -1
  182. package/dist/vue2/lib/feed-item-pill/feed-item-pill-constants.js.map +1 -1
  183. package/dist/vue2/lib/feed-item-pill/feed-item-pill.cjs +1 -1
  184. package/dist/vue2/lib/feed-item-pill/feed-item-pill.cjs.map +1 -1
  185. package/dist/vue2/lib/feed-item-pill/feed-item-pill.js +3 -3
  186. package/dist/vue2/lib/feed-item-row/feed-item-row-constants.cjs.map +1 -1
  187. package/dist/vue2/lib/feed-item-row/feed-item-row-constants.js.map +1 -1
  188. package/dist/vue2/lib/feed-item-row/feed-item-row.cjs +1 -1
  189. package/dist/vue2/lib/feed-item-row/feed-item-row.cjs.map +1 -1
  190. package/dist/vue2/lib/feed-item-row/feed-item-row.js +9 -9
  191. package/dist/vue2/lib/feed-item-row/feed-item-row.js.map +1 -1
  192. package/dist/vue2/lib/general-row/general-row-constants.cjs.map +1 -1
  193. package/dist/vue2/lib/general-row/general-row-constants.js.map +1 -1
  194. package/dist/vue2/lib/general-row/general-row.cjs +1 -1
  195. package/dist/vue2/lib/general-row/general-row.cjs.map +1 -1
  196. package/dist/vue2/lib/general-row/general-row.js +14 -14
  197. package/dist/vue2/lib/general-row/general-row.js.map +1 -1
  198. package/dist/vue2/lib/general-row/leftbar-general-row-icon.cjs.map +1 -1
  199. package/dist/vue2/lib/general-row/leftbar-general-row-icon.js +30 -30
  200. package/dist/vue2/lib/group-row/group-row.cjs.map +1 -1
  201. package/dist/vue2/lib/grouped-chip/grouped-chip.cjs.map +1 -1
  202. package/dist/vue2/lib/hovercard/hovercard.cjs +1 -1
  203. package/dist/vue2/lib/hovercard/hovercard.cjs.map +1 -1
  204. package/dist/vue2/lib/hovercard/hovercard.js +7 -7
  205. package/dist/vue2/lib/hovercard/hovercard.js.map +1 -1
  206. package/dist/vue2/lib/icon/icon-constants.cjs.map +1 -1
  207. package/dist/vue2/lib/icon/icon-constants.js.map +1 -1
  208. package/dist/vue2/lib/icon/icon.js +3 -3
  209. package/dist/vue2/lib/illustration/illustration-constants.cjs.map +1 -1
  210. package/dist/vue2/lib/illustration/illustration-constants.js.map +1 -1
  211. package/dist/vue2/lib/image-viewer/image-viewer.cjs.map +1 -1
  212. package/dist/vue2/lib/image-viewer/image-viewer.js.map +1 -1
  213. package/dist/vue2/lib/input/input-constants.cjs.map +1 -1
  214. package/dist/vue2/lib/input/input-constants.js.map +1 -1
  215. package/dist/vue2/lib/input/input.cjs.map +1 -1
  216. package/dist/vue2/lib/input/input.js +8 -8
  217. package/dist/vue2/lib/input/input.js.map +1 -1
  218. package/dist/vue2/lib/input-group/input-group.cjs.map +1 -1
  219. package/dist/vue2/lib/ivr-node/ivr-node-constants.cjs.map +1 -1
  220. package/dist/vue2/lib/ivr-node/ivr-node-constants.js.map +1 -1
  221. package/dist/vue2/lib/ivr-node/ivr-node.cjs +1 -1
  222. package/dist/vue2/lib/ivr-node/ivr-node.cjs.map +1 -1
  223. package/dist/vue2/lib/ivr-node/ivr-node.js +27 -27
  224. package/dist/vue2/lib/keyboard-shortcut/keyboard-shortcut.cjs.map +1 -1
  225. package/dist/vue2/lib/keyboard-shortcut/keyboard-shortcut.js +13 -13
  226. package/dist/vue2/lib/link/link-constants.cjs.map +1 -1
  227. package/dist/vue2/lib/link/link-constants.js.map +1 -1
  228. package/dist/vue2/lib/link/link.cjs.map +1 -1
  229. package/dist/vue2/lib/link/link.js +3 -3
  230. package/dist/vue2/lib/list-item/list-item-constants.cjs.map +1 -1
  231. package/dist/vue2/lib/list-item/list-item-constants.js.map +1 -1
  232. package/dist/vue2/lib/list-item/list-item.cjs.map +1 -1
  233. package/dist/vue2/lib/list-item/list-item.js +1 -1
  234. package/dist/vue2/lib/list-item/list-item.js.map +1 -1
  235. package/dist/vue2/lib/list-item-group/list-item-group-constants.cjs.map +1 -1
  236. package/dist/vue2/lib/list-item-group/list-item-group-constants.js.map +1 -1
  237. package/dist/vue2/lib/list-item-group/list-item-group.cjs.map +1 -1
  238. package/dist/vue2/lib/loader/loader.cjs.map +1 -1
  239. package/dist/vue2/lib/message-input/last-active-nodes.cjs +1 -1
  240. package/dist/vue2/lib/message-input/last-active-nodes.cjs.map +1 -1
  241. package/dist/vue2/lib/message-input/last-active-nodes.js +22 -22
  242. package/dist/vue2/lib/message-input/last-active-nodes.js.map +1 -1
  243. package/dist/vue2/lib/message-input/message-input-button.cjs +1 -1
  244. package/dist/vue2/lib/message-input/message-input-button.cjs.map +1 -1
  245. package/dist/vue2/lib/message-input/message-input-button.js +8 -8
  246. package/dist/vue2/lib/message-input/message-input-constants.cjs.map +1 -1
  247. package/dist/vue2/lib/message-input/message-input-constants.js.map +1 -1
  248. package/dist/vue2/lib/message-input/message-input-link.cjs +1 -1
  249. package/dist/vue2/lib/message-input/message-input-link.cjs.map +1 -1
  250. package/dist/vue2/lib/message-input/message-input-link.js +8 -8
  251. package/dist/vue2/lib/message-input/message-input-topbar.cjs.map +1 -1
  252. package/dist/vue2/lib/message-input/message-input-topbar.js +9 -9
  253. package/dist/vue2/lib/message-input/message-input.cjs +1 -1
  254. package/dist/vue2/lib/message-input/message-input.cjs.map +1 -1
  255. package/dist/vue2/lib/message-input/message-input.js +28 -28
  256. package/dist/vue2/lib/message-input/message-input.js.map +1 -1
  257. package/dist/vue2/lib/modal/modal.cjs +1 -1
  258. package/dist/vue2/lib/modal/modal.cjs.map +1 -1
  259. package/dist/vue2/lib/modal/modal.js +12 -12
  260. package/dist/vue2/lib/modal/modal.js.map +1 -1
  261. package/dist/vue2/lib/notice/notice-action.cjs.map +1 -1
  262. package/dist/vue2/lib/notice/notice-constants.cjs.map +1 -1
  263. package/dist/vue2/lib/notice/notice-constants.js.map +1 -1
  264. package/dist/vue2/lib/notice/notice-icon.cjs.map +1 -1
  265. package/dist/vue2/lib/notice/notice-icon.js +9 -9
  266. package/dist/vue2/lib/notice/notice.cjs.map +1 -1
  267. package/dist/vue2/lib/notice/notice.js +3 -3
  268. package/dist/vue2/lib/pagination/pagination.cjs.map +1 -1
  269. package/dist/vue2/lib/pagination/pagination.js +3 -3
  270. package/dist/vue2/lib/pagination/pagination.js.map +1 -1
  271. package/dist/vue2/lib/popover/popover-constants.cjs.map +1 -1
  272. package/dist/vue2/lib/popover/popover-constants.js.map +1 -1
  273. package/dist/vue2/lib/popover/popover-header-footer.cjs.map +1 -1
  274. package/dist/vue2/lib/popover/popover.cjs +1 -1
  275. package/dist/vue2/lib/popover/popover.cjs.map +1 -1
  276. package/dist/vue2/lib/popover/popover.js +16 -16
  277. package/dist/vue2/lib/popover/popover.js.map +1 -1
  278. package/dist/vue2/lib/popover/tippy-utils.cjs +1 -1
  279. package/dist/vue2/lib/popover/tippy-utils.cjs.map +1 -1
  280. package/dist/vue2/lib/popover/tippy-utils.js +16 -18
  281. package/dist/vue2/lib/popover/tippy-utils.js.map +1 -1
  282. package/dist/vue2/lib/presence/presence.cjs.map +1 -1
  283. package/dist/vue2/lib/radio/radio-constants.cjs.map +1 -1
  284. package/dist/vue2/lib/radio/radio-constants.js.map +1 -1
  285. package/dist/vue2/lib/radio/radio.cjs.map +1 -1
  286. package/dist/vue2/lib/radio-group/radio-group.cjs.map +1 -1
  287. package/dist/vue2/lib/radio-group/radios-decorator.cjs.map +1 -1
  288. package/dist/vue2/lib/recipes/eslint.config.cjs +2 -0
  289. package/dist/vue2/lib/recipes/eslint.config.cjs.map +1 -0
  290. package/dist/vue2/lib/recipes/eslint.config.js +12 -0
  291. package/dist/vue2/lib/recipes/eslint.config.js.map +1 -0
  292. package/dist/vue2/lib/rich-text-editor/channel-suggestion.cjs.map +1 -1
  293. package/dist/vue2/lib/rich-text-editor/channel-suggestion.js.map +1 -1
  294. package/dist/vue2/lib/rich-text-editor/mention-suggestion.cjs.map +1 -1
  295. package/dist/vue2/lib/rich-text-editor/mention-suggestion.js.map +1 -1
  296. package/dist/vue2/lib/rich-text-editor/rich-text-editor-constants.cjs.map +1 -1
  297. package/dist/vue2/lib/rich-text-editor/rich-text-editor-constants.js.map +1 -1
  298. package/dist/vue2/lib/rich-text-editor/rich-text-editor.cjs +2 -2
  299. package/dist/vue2/lib/rich-text-editor/rich-text-editor.cjs.map +1 -1
  300. package/dist/vue2/lib/rich-text-editor/rich-text-editor.js +72 -65
  301. package/dist/vue2/lib/rich-text-editor/rich-text-editor.js.map +1 -1
  302. package/dist/vue2/lib/rich-text-editor/slash-command-suggestion.cjs.map +1 -1
  303. package/dist/vue2/lib/rich-text-editor/slash-command-suggestion.js.map +1 -1
  304. package/dist/vue2/lib/root-layout/root-layout-constants.cjs.map +1 -1
  305. package/dist/vue2/lib/root-layout/root-layout-constants.js.map +1 -1
  306. package/dist/vue2/lib/root-layout/root-layout.cjs.map +1 -1
  307. package/dist/vue2/lib/root-layout/root-layout.js +1 -1
  308. package/dist/vue2/lib/scrollbar-directive/scrollbar.cjs.map +1 -1
  309. package/dist/vue2/lib/scrollbar-directive/scrollbar.js.map +1 -1
  310. package/dist/vue2/lib/select-menu/select-menu-constants.cjs.map +1 -1
  311. package/dist/vue2/lib/select-menu/select-menu-constants.js.map +1 -1
  312. package/dist/vue2/lib/select-menu/select-menu.cjs.map +1 -1
  313. package/dist/vue2/lib/select-menu/select-menu.js +7 -7
  314. package/dist/vue2/lib/settings-menu-button/settings-menu-button.cjs.map +1 -1
  315. package/dist/vue2/lib/skeleton/skeleton-constants.cjs.map +1 -1
  316. package/dist/vue2/lib/skeleton/skeleton-constants.js.map +1 -1
  317. package/dist/vue2/lib/skeleton/skeleton-list-item.cjs.map +1 -1
  318. package/dist/vue2/lib/skeleton/skeleton-paragraph.cjs.map +1 -1
  319. package/dist/vue2/lib/skeleton/skeleton-paragraph.js.map +1 -1
  320. package/dist/vue2/lib/skeleton/skeleton-shape.cjs.map +1 -1
  321. package/dist/vue2/lib/skeleton/skeleton-shape.js +1 -1
  322. package/dist/vue2/lib/skeleton/skeleton-text.cjs.map +1 -1
  323. package/dist/vue2/lib/skeleton/skeleton.cjs +1 -1
  324. package/dist/vue2/lib/skeleton/skeleton.cjs.map +1 -1
  325. package/dist/vue2/lib/skeleton/skeleton.js +1 -1
  326. package/dist/vue2/lib/skeleton/skeleton.js.map +1 -1
  327. package/dist/vue2/lib/split-button/split-button-alpha.cjs.map +1 -1
  328. package/dist/vue2/lib/split-button/split-button-constants.cjs.map +1 -1
  329. package/dist/vue2/lib/split-button/split-button-constants.js.map +1 -1
  330. package/dist/vue2/lib/split-button/split-button-omega.cjs.map +1 -1
  331. package/dist/vue2/lib/split-button/split-button.cjs.map +1 -1
  332. package/dist/vue2/lib/split-button/split-button.js +5 -5
  333. package/dist/vue2/lib/split-button/split-button.js.map +1 -1
  334. package/dist/vue2/lib/stack/stack-constants.cjs.map +1 -1
  335. package/dist/vue2/lib/stack/stack-constants.js.map +1 -1
  336. package/dist/vue2/lib/stack/stack.cjs.map +1 -1
  337. package/dist/vue2/lib/stack/stack.js +9 -9
  338. package/dist/vue2/lib/stack/utils.cjs.map +1 -1
  339. package/dist/vue2/lib/stack/utils.js.map +1 -1
  340. package/dist/vue2/lib/stack/validators.cjs.map +1 -1
  341. package/dist/vue2/lib/stack/validators.js.map +1 -1
  342. package/dist/vue2/lib/tab/tab-group.cjs.map +1 -1
  343. package/dist/vue2/lib/tab/tab-group.js +5 -5
  344. package/dist/vue2/lib/tab/tab-group.js.map +1 -1
  345. package/dist/vue2/lib/tab/tab.cjs.map +1 -1
  346. package/dist/vue2/lib/toast/toast-constants.cjs.map +1 -1
  347. package/dist/vue2/lib/toast/toast-constants.js.map +1 -1
  348. package/dist/vue2/lib/toast/toast.cjs +1 -1
  349. package/dist/vue2/lib/toast/toast.cjs.map +1 -1
  350. package/dist/vue2/lib/toast/toast.js +11 -11
  351. package/dist/vue2/lib/toggle/toggle-constants.cjs.map +1 -1
  352. package/dist/vue2/lib/toggle/toggle-constants.js.map +1 -1
  353. package/dist/vue2/lib/toggle/toggle.cjs +1 -1
  354. package/dist/vue2/lib/toggle/toggle.cjs.map +1 -1
  355. package/dist/vue2/lib/toggle/toggle.js +1 -1
  356. package/dist/vue2/lib/toggle/toggle.js.map +1 -1
  357. package/dist/vue2/lib/tooltip/tooltip-constants.cjs.map +1 -1
  358. package/dist/vue2/lib/tooltip/tooltip-constants.js.map +1 -1
  359. package/dist/vue2/lib/tooltip/tooltip.cjs +1 -1
  360. package/dist/vue2/lib/tooltip/tooltip.cjs.map +1 -1
  361. package/dist/vue2/lib/tooltip/tooltip.js +63 -64
  362. package/dist/vue2/lib/tooltip/tooltip.js.map +1 -1
  363. package/dist/vue2/lib/tooltip-directive/tooltip.cjs.map +1 -1
  364. package/dist/vue2/lib/tooltip-directive/tooltip.js.map +1 -1
  365. package/dist/vue2/lib/top-banner-info/top-banner-info-constants.cjs.map +1 -1
  366. package/dist/vue2/lib/top-banner-info/top-banner-info-constants.js.map +1 -1
  367. package/dist/vue2/lib/top-banner-info/top-banner-info.cjs.map +1 -1
  368. package/dist/vue2/lib/unread-pill/unread-pill-constants.cjs.map +1 -1
  369. package/dist/vue2/lib/unread-pill/unread-pill-constants.js.map +1 -1
  370. package/dist/vue2/lib/unread-pill/unread-pill.cjs.map +1 -1
  371. package/dist/vue2/lib/unread-pill/unread-pill.js +6 -6
  372. package/dist/vue2/lib/validation-messages/validation-messages.cjs.map +1 -1
  373. package/dist/vue2/lib/validation-messages/validation-messages.js +3 -3
  374. package/dist/vue2/localization/de-DE.cjs.map +1 -1
  375. package/dist/vue2/localization/de-DE.js.map +1 -1
  376. package/dist/vue2/localization/en-US.cjs.map +1 -1
  377. package/dist/vue2/localization/en-US.js.map +1 -1
  378. package/dist/vue2/localization/es-LA.cjs.map +1 -1
  379. package/dist/vue2/localization/es-LA.js.map +1 -1
  380. package/dist/vue2/localization/fr-FR.cjs.map +1 -1
  381. package/dist/vue2/localization/fr-FR.js.map +1 -1
  382. package/dist/vue2/localization/index.cjs.map +1 -1
  383. package/dist/vue2/localization/index.js.map +1 -1
  384. package/dist/vue2/localization/it-IT.cjs.map +1 -1
  385. package/dist/vue2/localization/it-IT.js.map +1 -1
  386. package/dist/vue2/localization/ja-JP.cjs.map +1 -1
  387. package/dist/vue2/localization/ja-JP.js.map +1 -1
  388. package/dist/vue2/localization/nl-NL.cjs.map +1 -1
  389. package/dist/vue2/localization/nl-NL.js.map +1 -1
  390. package/dist/vue2/localization/pt-BR.cjs.map +1 -1
  391. package/dist/vue2/localization/pt-BR.js.map +1 -1
  392. package/dist/vue2/localization/ru-RU.cjs.map +1 -1
  393. package/dist/vue2/localization/ru-RU.js.map +1 -1
  394. package/dist/vue2/localization/zh-CN.cjs.map +1 -1
  395. package/dist/vue2/localization/zh-CN.js.map +1 -1
  396. package/dist/vue2/node_modules/@linusborg/vue-simple-portal.cjs.map +1 -1
  397. package/dist/vue2/node_modules/@linusborg/vue-simple-portal.js.map +1 -1
  398. package/dist/vue2/node_modules/@tiptap/vue-2.cjs.map +1 -1
  399. package/dist/vue2/node_modules/@tiptap/vue-2.js.map +1 -1
  400. package/dist/vue2/shared/sr_only_close_button.cjs.map +1 -1
  401. package/dist/vue2/types/common/constants/index.d.ts.map +1 -1
  402. package/dist/vue2/types/common/dates/index.d.ts.map +1 -1
  403. package/dist/vue2/types/common/emoji/index.d.ts.map +1 -1
  404. package/dist/vue2/types/common/mixins/dom.d.ts.map +1 -1
  405. package/dist/vue2/types/common/mixins/input.d.ts +7 -7
  406. package/dist/vue2/types/common/mixins/input.d.ts.map +1 -1
  407. package/dist/vue2/types/common/mixins/input_group.d.ts +3 -3
  408. package/dist/vue2/types/common/mixins/modal.d.ts.map +1 -1
  409. package/dist/vue2/types/common/utils/index.d.ts.map +1 -1
  410. package/dist/vue2/types/components/avatar/avatar.vue.d.ts +8 -8
  411. package/dist/vue2/types/components/badge/badge.vue.d.ts +3 -3
  412. package/dist/vue2/types/components/banner/banner.vue.d.ts +2 -2
  413. package/dist/vue2/types/components/banner/banner.vue.d.ts.map +1 -1
  414. package/dist/vue2/types/components/breadcrumbs/breadcrumbs.vue.d.ts +1 -1
  415. package/dist/vue2/types/components/breadcrumbs/breadcrumbs_constants.d.ts.map +1 -1
  416. package/dist/vue2/types/components/button/button.vue.d.ts +2 -2
  417. package/dist/vue2/types/components/button/button_constants.d.ts.map +1 -1
  418. package/dist/vue2/types/components/card/card.vue.d.ts +8 -8
  419. package/dist/vue2/types/components/checkbox/checkbox.vue.d.ts +7 -7
  420. package/dist/vue2/types/components/checkbox_group/checkbox_group.vue.d.ts +3 -3
  421. package/dist/vue2/types/components/chip/chip.vue.d.ts +5 -5
  422. package/dist/vue2/types/components/collapsible/collapsible.vue.d.ts +4 -4
  423. package/dist/vue2/types/components/combobox/combobox.vue.d.ts +3 -3
  424. package/dist/vue2/types/components/combobox/combobox_empty-list.vue.d.ts +2 -2
  425. package/dist/vue2/types/components/datepicker/datepicker_constants.d.ts.map +1 -1
  426. package/dist/vue2/types/components/datepicker/formatUtils.d.ts +5 -5
  427. package/dist/vue2/types/components/datepicker/formatUtils.d.ts.map +1 -1
  428. package/dist/vue2/types/components/datepicker/modules/calendar.vue.d.ts +1 -1
  429. package/dist/vue2/types/components/description_list/description_list.vue.d.ts +4 -4
  430. package/dist/vue2/types/components/dropdown/dropdown.vue.d.ts +8 -8
  431. package/dist/vue2/types/components/emoji/emoji.vue.d.ts +2 -2
  432. package/dist/vue2/types/components/emoji_picker/emoji_picker_constants.d.ts.map +1 -1
  433. package/dist/vue2/types/components/emoji_text_wrapper/emoji_text_wrapper.vue.d.ts +1 -1
  434. package/dist/vue2/types/components/emoji_text_wrapper/emoji_text_wrapper.vue.d.ts.map +1 -1
  435. package/dist/vue2/types/components/eslint.config.d.ts +8 -0
  436. package/dist/vue2/types/components/eslint.config.d.ts.map +1 -0
  437. package/dist/vue2/types/components/image_viewer/image_viewer.vue.d.ts.map +1 -1
  438. package/dist/vue2/types/components/input/input.vue.d.ts +7 -7
  439. package/dist/vue2/types/components/input_group/input_group.vue.d.ts +3 -3
  440. package/dist/vue2/types/components/item_layout/item_layout.vue.d.ts +1 -1
  441. package/dist/vue2/types/components/link/link_constants.d.ts.map +1 -1
  442. package/dist/vue2/types/components/list_item/list_item.vue.d.ts +2 -2
  443. package/dist/vue2/types/components/list_item_group/list_item_group.vue.d.ts +4 -4
  444. package/dist/vue2/types/components/modal/modal.vue.d.ts +13 -13
  445. package/dist/vue2/types/components/modal/modal.vue.d.ts.map +1 -1
  446. package/dist/vue2/types/components/notice/notice.vue.d.ts +2 -2
  447. package/dist/vue2/types/components/popover/popover.vue.d.ts +22 -22
  448. package/dist/vue2/types/components/popover/popover.vue.d.ts.map +1 -1
  449. package/dist/vue2/types/components/popover/popover_header_footer.vue.d.ts +2 -2
  450. package/dist/vue2/types/components/popover/tippy_utils.d.ts +2 -3
  451. package/dist/vue2/types/components/popover/tippy_utils.d.ts.map +1 -1
  452. package/dist/vue2/types/components/radio/radio.vue.d.ts +7 -7
  453. package/dist/vue2/types/components/radio_group/radio_group.vue.d.ts +3 -3
  454. package/dist/vue2/types/components/rich_text_editor/extensions/slash_command/slash_command.d.ts +1 -1
  455. package/dist/vue2/types/components/rich_text_editor/extensions/slash_command/slash_command.d.ts.map +1 -1
  456. package/dist/vue2/types/components/rich_text_editor/rich_text_editor.vue.d.ts +12 -17
  457. package/dist/vue2/types/components/rich_text_editor/rich_text_editor.vue.d.ts.map +1 -1
  458. package/dist/vue2/types/components/root_layout/root_layout.vue.d.ts +8 -8
  459. package/dist/vue2/types/components/select_menu/select_menu.vue.d.ts +10 -10
  460. package/dist/vue2/types/components/skeleton/skeleton-list-item.vue.d.ts +1 -1
  461. package/dist/vue2/types/components/skeleton/skeleton-paragraph.vue.d.ts +1 -1
  462. package/dist/vue2/types/components/skeleton/skeleton-shape.vue.d.ts +3 -3
  463. package/dist/vue2/types/components/skeleton/skeleton-text.vue.d.ts +1 -1
  464. package/dist/vue2/types/components/skeleton/skeleton.vue.d.ts +7 -7
  465. package/dist/vue2/types/components/skeleton/skeleton_constants.d.ts.map +1 -1
  466. package/dist/vue2/types/components/split_button/split_button-alpha.vue.d.ts +3 -3
  467. package/dist/vue2/types/components/split_button/split_button-omega.vue.d.ts +1 -1
  468. package/dist/vue2/types/components/split_button/split_button.vue.d.ts +2 -2
  469. package/dist/vue2/types/components/tab/tab.vue.d.ts +2 -2
  470. package/dist/vue2/types/components/tab/tab_group.vue.d.ts +2 -2
  471. package/dist/vue2/types/components/tab/tab_panel.vue.d.ts +2 -2
  472. package/dist/vue2/types/components/tab/tab_panel.vue.d.ts.map +1 -1
  473. package/dist/vue2/types/components/toast/layouts/toast_layout_alternate.vue.d.ts +2 -2
  474. package/dist/vue2/types/components/toast/layouts/toast_layout_default.vue.d.ts +2 -2
  475. package/dist/vue2/types/components/toast/toast.vue.d.ts +7 -7
  476. package/dist/vue2/types/components/toast/toast_constants.d.ts.map +1 -1
  477. package/dist/vue2/types/components/toggle/toggle.vue.d.ts +5 -5
  478. package/dist/vue2/types/components/tooltip/tooltip.vue.d.ts +8 -8
  479. package/dist/vue2/types/components/tooltip/tooltip.vue.d.ts.map +1 -1
  480. package/dist/vue2/types/components/tooltip/tooltip_constants.d.ts.map +1 -1
  481. package/dist/vue2/types/components/validation_messages/validation_messages.vue.d.ts +0 -1
  482. package/dist/vue2/types/components/validation_messages/validation_messages.vue.d.ts.map +1 -1
  483. package/dist/vue2/types/recipes/buttons/callbar_button/callbar_button.vue.d.ts +6 -6
  484. package/dist/vue2/types/recipes/buttons/callbar_button_with_dropdown/callbar_button_with_dropdown.vue.d.ts +5 -5
  485. package/dist/vue2/types/recipes/buttons/callbar_button_with_popover/callbar_button_with_popover.vue.d.ts +6 -6
  486. package/dist/vue2/types/recipes/cards/ivr_node/ivr_node_constants.d.ts.map +1 -1
  487. package/dist/vue2/types/recipes/comboboxes/combobox_multi_select/combobox_multi_select.vue.d.ts +1 -1
  488. package/dist/vue2/types/recipes/comboboxes/combobox_with_popover/combobox_with_popover.vue.d.ts +7 -7
  489. package/dist/vue2/types/recipes/conversation_view/editor/editor.vue.d.ts +3 -3
  490. package/dist/vue2/types/recipes/conversation_view/editor/editor_constants.d.ts.map +1 -1
  491. package/dist/vue2/types/recipes/conversation_view/feed_item_pill/feed_item_pill.vue.d.ts +4 -4
  492. package/dist/vue2/types/recipes/conversation_view/feed_item_row/feed_item_row.vue.d.ts +1 -1
  493. package/dist/vue2/types/recipes/conversation_view/feed_item_row/feed_item_row.vue.d.ts.map +1 -1
  494. package/dist/vue2/types/recipes/conversation_view/feed_item_row/feed_item_row_constants.d.ts.map +1 -1
  495. package/dist/vue2/types/recipes/conversation_view/message_input/last_active_nodes.d.ts.map +1 -1
  496. package/dist/vue2/types/recipes/conversation_view/message_input/message_input.vue.d.ts +15 -15
  497. package/dist/vue2/types/recipes/eslint.config.d.ts +8 -0
  498. package/dist/vue2/types/recipes/eslint.config.d.ts.map +1 -0
  499. package/dist/vue2/types/recipes/item_layout/contact_info/contact_info.vue.d.ts +1 -1
  500. package/dist/vue2/types/recipes/leftbar/callbox/callbox.vue.d.ts +1 -1
  501. package/dist/vue2/types/recipes/leftbar/contact_centers_row/contact_centers_row.vue.d.ts +1 -1
  502. package/dist/vue2/types/recipes/leftbar/general_row/general_row.vue.d.ts +1 -1
  503. package/dist/vue3/common/constants/index.cjs.map +1 -1
  504. package/dist/vue3/common/constants/index.js.map +1 -1
  505. package/dist/vue3/common/dates/index.cjs.map +1 -1
  506. package/dist/vue3/common/dates/index.js +3 -3
  507. package/dist/vue3/common/dates/index.js.map +1 -1
  508. package/dist/vue3/common/emoji/index.cjs.map +1 -1
  509. package/dist/vue3/common/emoji/index.js.map +1 -1
  510. package/dist/vue3/common/mixins/dom.cjs.map +1 -1
  511. package/dist/vue3/common/mixins/dom.js.map +1 -1
  512. package/dist/vue3/common/mixins/input-group.cjs.map +1 -1
  513. package/dist/vue3/common/mixins/input-group.js +5 -5
  514. package/dist/vue3/common/mixins/input-group.js.map +1 -1
  515. package/dist/vue3/common/mixins/input.cjs.map +1 -1
  516. package/dist/vue3/common/mixins/input.js.map +1 -1
  517. package/dist/vue3/common/mixins/keyboard-list-navigation.cjs.map +1 -1
  518. package/dist/vue3/common/mixins/keyboard-list-navigation.js.map +1 -1
  519. package/dist/vue3/common/mixins/modal.cjs.map +1 -1
  520. package/dist/vue3/common/mixins/modal.js.map +1 -1
  521. package/dist/vue3/common/mixins/skeleton.cjs.map +1 -1
  522. package/dist/vue3/common/mixins/skeleton.js.map +1 -1
  523. package/dist/vue3/common/utils/index.cjs.map +1 -1
  524. package/dist/vue3/common/utils/index.js +3 -3
  525. package/dist/vue3/common/utils/index.js.map +1 -1
  526. package/dist/vue3/common/validators/index.cjs.map +1 -1
  527. package/dist/vue3/common/validators/index.js.map +1 -1
  528. package/dist/vue3/lib/attachment-carousel/attachment-carousel.cjs +1 -1
  529. package/dist/vue3/lib/attachment-carousel/attachment-carousel.cjs.map +1 -1
  530. package/dist/vue3/lib/attachment-carousel/attachment-carousel.js +5 -5
  531. package/dist/vue3/lib/attachment-carousel/attachment-carousel.js.map +1 -1
  532. package/dist/vue3/lib/avatar/avatar-constants.cjs.map +1 -1
  533. package/dist/vue3/lib/avatar/avatar-constants.js.map +1 -1
  534. package/dist/vue3/lib/avatar/avatar.cjs.map +1 -1
  535. package/dist/vue3/lib/avatar/avatar.js +11 -11
  536. package/dist/vue3/lib/avatar/avatar.js.map +1 -1
  537. package/dist/vue3/lib/avatar/utils.cjs.map +1 -1
  538. package/dist/vue3/lib/avatar/utils.js.map +1 -1
  539. package/dist/vue3/lib/badge/badge.cjs.map +1 -1
  540. package/dist/vue3/lib/badge/badge.js +12 -12
  541. package/dist/vue3/lib/badge/badge.js.map +1 -1
  542. package/dist/vue3/lib/banner/banner.cjs +1 -1
  543. package/dist/vue3/lib/banner/banner.cjs.map +1 -1
  544. package/dist/vue3/lib/banner/banner.js +7 -7
  545. package/dist/vue3/lib/banner/banner.js.map +1 -1
  546. package/dist/vue3/lib/breadcrumbs/breadcrumb-item.cjs.map +1 -1
  547. package/dist/vue3/lib/breadcrumbs/breadcrumb-item.js +5 -5
  548. package/dist/vue3/lib/breadcrumbs/breadcrumb-item.js.map +1 -1
  549. package/dist/vue3/lib/breadcrumbs/breadcrumbs.cjs.map +1 -1
  550. package/dist/vue3/lib/breadcrumbs/breadcrumbs.js +1 -1
  551. package/dist/vue3/lib/breadcrumbs/breadcrumbs.js.map +1 -1
  552. package/dist/vue3/lib/button/button-constants.cjs.map +1 -1
  553. package/dist/vue3/lib/button/button-constants.js.map +1 -1
  554. package/dist/vue3/lib/button/button.cjs.map +1 -1
  555. package/dist/vue3/lib/button/button.js +22 -22
  556. package/dist/vue3/lib/button/button.js.map +1 -1
  557. package/dist/vue3/lib/button-group/button-group.cjs.map +1 -1
  558. package/dist/vue3/lib/button-group/button-group.js +2 -2
  559. package/dist/vue3/lib/button-group/button-group.js.map +1 -1
  560. package/dist/vue3/lib/button-group/buttons-decorator.cjs.map +1 -1
  561. package/dist/vue3/lib/button-group/buttons-decorator.js +2 -2
  562. package/dist/vue3/lib/button-group/buttons-decorator.js.map +1 -1
  563. package/dist/vue3/lib/callbar-button/callbar-button-constants.cjs.map +1 -1
  564. package/dist/vue3/lib/callbar-button/callbar-button-constants.js.map +1 -1
  565. package/dist/vue3/lib/callbar-button/callbar-button.cjs +1 -1
  566. package/dist/vue3/lib/callbar-button/callbar-button.cjs.map +1 -1
  567. package/dist/vue3/lib/callbar-button/callbar-button.js +13 -13
  568. package/dist/vue3/lib/callbar-button/callbar-button.js.map +1 -1
  569. package/dist/vue3/lib/callbar-button-with-dropdown/callbar-button-with-dropdown.cjs +1 -1
  570. package/dist/vue3/lib/callbar-button-with-dropdown/callbar-button-with-dropdown.cjs.map +1 -1
  571. package/dist/vue3/lib/callbar-button-with-dropdown/callbar-button-with-dropdown.js +13 -13
  572. package/dist/vue3/lib/callbar-button-with-dropdown/callbar-button-with-dropdown.js.map +1 -1
  573. package/dist/vue3/lib/callbar-button-with-popover/callbar-button-with-popover.cjs +1 -1
  574. package/dist/vue3/lib/callbar-button-with-popover/callbar-button-with-popover.cjs.map +1 -1
  575. package/dist/vue3/lib/callbar-button-with-popover/callbar-button-with-popover.js +13 -13
  576. package/dist/vue3/lib/callbar-button-with-popover/callbar-button-with-popover.js.map +1 -1
  577. package/dist/vue3/lib/callbox/callbox-constants.cjs.map +1 -1
  578. package/dist/vue3/lib/callbox/callbox-constants.js.map +1 -1
  579. package/dist/vue3/lib/callbox/callbox.cjs.map +1 -1
  580. package/dist/vue3/lib/callbox/callbox.js +6 -6
  581. package/dist/vue3/lib/callbox/callbox.js.map +1 -1
  582. package/dist/vue3/lib/card/card.cjs.map +1 -1
  583. package/dist/vue3/lib/card/card.js +4 -4
  584. package/dist/vue3/lib/card/card.js.map +1 -1
  585. package/dist/vue3/lib/checkbox/checkbox-constants.cjs.map +1 -1
  586. package/dist/vue3/lib/checkbox/checkbox-constants.js.map +1 -1
  587. package/dist/vue3/lib/checkbox/checkbox.cjs.map +1 -1
  588. package/dist/vue3/lib/checkbox/checkbox.js +8 -8
  589. package/dist/vue3/lib/checkbox/checkbox.js.map +1 -1
  590. package/dist/vue3/lib/checkbox-group/checkbox-group.cjs.map +1 -1
  591. package/dist/vue3/lib/checkbox-group/checkbox-group.js.map +1 -1
  592. package/dist/vue3/lib/checkbox-group/checkboxes-decorator.cjs.map +1 -1
  593. package/dist/vue3/lib/checkbox-group/checkboxes-decorator.js +1 -1
  594. package/dist/vue3/lib/checkbox-group/checkboxes-decorator.js.map +1 -1
  595. package/dist/vue3/lib/chip/chip-constants.cjs.map +1 -1
  596. package/dist/vue3/lib/chip/chip-constants.js.map +1 -1
  597. package/dist/vue3/lib/chip/chip.cjs.map +1 -1
  598. package/dist/vue3/lib/chip/chip.js +13 -13
  599. package/dist/vue3/lib/chip/chip.js.map +1 -1
  600. package/dist/vue3/lib/codeblock/codeblock.cjs.map +1 -1
  601. package/dist/vue3/lib/codeblock/codeblock.js +2 -2
  602. package/dist/vue3/lib/codeblock/codeblock.js.map +1 -1
  603. package/dist/vue3/lib/collapsible/collapsible-lazy-show.cjs.map +1 -1
  604. package/dist/vue3/lib/collapsible/collapsible-lazy-show.js +3 -3
  605. package/dist/vue3/lib/collapsible/collapsible-lazy-show.js.map +1 -1
  606. package/dist/vue3/lib/collapsible/collapsible.cjs +1 -1
  607. package/dist/vue3/lib/collapsible/collapsible.cjs.map +1 -1
  608. package/dist/vue3/lib/collapsible/collapsible.js +18 -18
  609. package/dist/vue3/lib/collapsible/collapsible.js.map +1 -1
  610. package/dist/vue3/lib/combobox/combobox-constants.cjs.map +1 -1
  611. package/dist/vue3/lib/combobox/combobox-constants.js.map +1 -1
  612. package/dist/vue3/lib/combobox/combobox-empty-list.cjs.map +1 -1
  613. package/dist/vue3/lib/combobox/combobox-empty-list.js +2 -2
  614. package/dist/vue3/lib/combobox/combobox-empty-list.js.map +1 -1
  615. package/dist/vue3/lib/combobox/combobox-loading-list.cjs +1 -1
  616. package/dist/vue3/lib/combobox/combobox-loading-list.cjs.map +1 -1
  617. package/dist/vue3/lib/combobox/combobox-loading-list.js +6 -6
  618. package/dist/vue3/lib/combobox/combobox-loading-list.js.map +1 -1
  619. package/dist/vue3/lib/combobox/combobox.cjs +1 -1
  620. package/dist/vue3/lib/combobox/combobox.cjs.map +1 -1
  621. package/dist/vue3/lib/combobox/combobox.js +8 -8
  622. package/dist/vue3/lib/combobox/combobox.js.map +1 -1
  623. package/dist/vue3/lib/combobox-multi-select/combobox-multi-select-constants.cjs.map +1 -1
  624. package/dist/vue3/lib/combobox-multi-select/combobox-multi-select-constants.js.map +1 -1
  625. package/dist/vue3/lib/combobox-multi-select/combobox-multi-select-story-constants.cjs.map +1 -1
  626. package/dist/vue3/lib/combobox-multi-select/combobox-multi-select-story-constants.js.map +1 -1
  627. package/dist/vue3/lib/combobox-multi-select/combobox-multi-select.cjs +1 -1
  628. package/dist/vue3/lib/combobox-multi-select/combobox-multi-select.cjs.map +1 -1
  629. package/dist/vue3/lib/combobox-multi-select/combobox-multi-select.js +16 -16
  630. package/dist/vue3/lib/combobox-multi-select/combobox-multi-select.js.map +1 -1
  631. package/dist/vue3/lib/combobox-with-popover/combobox-with-popover.cjs +1 -1
  632. package/dist/vue3/lib/combobox-with-popover/combobox-with-popover.cjs.map +1 -1
  633. package/dist/vue3/lib/combobox-with-popover/combobox-with-popover.js +13 -13
  634. package/dist/vue3/lib/combobox-with-popover/combobox-with-popover.js.map +1 -1
  635. package/dist/vue3/lib/contact-centers-row/contact-centers-row.cjs +1 -1
  636. package/dist/vue3/lib/contact-centers-row/contact-centers-row.cjs.map +1 -1
  637. package/dist/vue3/lib/contact-centers-row/contact-centers-row.js +19 -19
  638. package/dist/vue3/lib/contact-centers-row/contact-centers-row.js.map +1 -1
  639. package/dist/vue3/lib/contact-info/contact-info.cjs.map +1 -1
  640. package/dist/vue3/lib/contact-info/contact-info.js +1 -1
  641. package/dist/vue3/lib/contact-info/contact-info.js.map +1 -1
  642. package/dist/vue3/lib/contact-row/contact-row.cjs +1 -1
  643. package/dist/vue3/lib/contact-row/contact-row.cjs.map +1 -1
  644. package/dist/vue3/lib/contact-row/contact-row.js +12 -12
  645. package/dist/vue3/lib/contact-row/contact-row.js.map +1 -1
  646. package/dist/vue3/lib/datepicker/datepicker.cjs +1 -1
  647. package/dist/vue3/lib/datepicker/datepicker.cjs.map +1 -1
  648. package/dist/vue3/lib/datepicker/datepicker.js +139 -139
  649. package/dist/vue3/lib/datepicker/datepicker.js.map +1 -1
  650. package/dist/vue3/lib/datepicker/formatUtils.cjs.map +1 -1
  651. package/dist/vue3/lib/datepicker/formatUtils.js.map +1 -1
  652. package/dist/vue3/lib/datepicker/utils.cjs.map +1 -1
  653. package/dist/vue3/lib/datepicker/utils.js.map +1 -1
  654. package/dist/vue3/lib/description-list/description-list.cjs.map +1 -1
  655. package/dist/vue3/lib/description-list/description-list.js +3 -3
  656. package/dist/vue3/lib/description-list/description-list.js.map +1 -1
  657. package/dist/vue3/lib/dropdown/dropdown-constants.cjs.map +1 -1
  658. package/dist/vue3/lib/dropdown/dropdown-constants.js.map +1 -1
  659. package/dist/vue3/lib/dropdown/dropdown-list.cjs.map +1 -1
  660. package/dist/vue3/lib/dropdown/dropdown-list.js +5 -5
  661. package/dist/vue3/lib/dropdown/dropdown-list.js.map +1 -1
  662. package/dist/vue3/lib/dropdown/dropdown-separator.cjs.map +1 -1
  663. package/dist/vue3/lib/dropdown/dropdown-separator.js +2 -2
  664. package/dist/vue3/lib/dropdown/dropdown-separator.js.map +1 -1
  665. package/dist/vue3/lib/dropdown/dropdown-story-constants.cjs.map +1 -1
  666. package/dist/vue3/lib/dropdown/dropdown-story-constants.js.map +1 -1
  667. package/dist/vue3/lib/dropdown/dropdown.cjs +1 -1
  668. package/dist/vue3/lib/dropdown/dropdown.cjs.map +1 -1
  669. package/dist/vue3/lib/dropdown/dropdown.js +3 -3
  670. package/dist/vue3/lib/dropdown/dropdown.js.map +1 -1
  671. package/dist/vue3/lib/editor/editor-constants.cjs.map +1 -1
  672. package/dist/vue3/lib/editor/editor-constants.js.map +1 -1
  673. package/dist/vue3/lib/editor/editor.cjs +1 -1
  674. package/dist/vue3/lib/editor/editor.cjs.map +1 -1
  675. package/dist/vue3/lib/editor/editor.js +48 -48
  676. package/dist/vue3/lib/editor/editor.js.map +1 -1
  677. package/dist/vue3/lib/emoji/emoji.cjs.map +1 -1
  678. package/dist/vue3/lib/emoji/emoji.js +6 -6
  679. package/dist/vue3/lib/emoji/emoji.js.map +1 -1
  680. package/dist/vue3/lib/emoji-picker/emoji-picker-constants.cjs.map +1 -1
  681. package/dist/vue3/lib/emoji-picker/emoji-picker-constants.js.map +1 -1
  682. package/dist/vue3/lib/emoji-picker/emoji-picker.cjs.map +1 -1
  683. package/dist/vue3/lib/emoji-picker/emoji-picker.js +2 -2
  684. package/dist/vue3/lib/emoji-picker/emoji-picker.js.map +1 -1
  685. package/dist/vue3/lib/emoji-row/emoji-row-constants.cjs.map +1 -1
  686. package/dist/vue3/lib/emoji-row/emoji-row-constants.js.map +1 -1
  687. package/dist/vue3/lib/emoji-row/emoji-row.cjs +1 -1
  688. package/dist/vue3/lib/emoji-row/emoji-row.cjs.map +1 -1
  689. package/dist/vue3/lib/emoji-row/emoji-row.js +10 -10
  690. package/dist/vue3/lib/emoji-row/emoji-row.js.map +1 -1
  691. package/dist/vue3/lib/emoji-text-wrapper/emoji-text-wrapper.cjs +1 -1
  692. package/dist/vue3/lib/emoji-text-wrapper/emoji-text-wrapper.cjs.map +1 -1
  693. package/dist/vue3/lib/emoji-text-wrapper/emoji-text-wrapper.js +1 -1
  694. package/dist/vue3/lib/emoji-text-wrapper/emoji-text-wrapper.js.map +1 -1
  695. package/dist/vue3/lib/empty-state/empty-state-constants.cjs.map +1 -1
  696. package/dist/vue3/lib/empty-state/empty-state-constants.js.map +1 -1
  697. package/dist/vue3/lib/empty-state/empty-state.cjs.map +1 -1
  698. package/dist/vue3/lib/empty-state/empty-state.js +7 -7
  699. package/dist/vue3/lib/feed-item-pill/feed-item-pill-constants.cjs.map +1 -1
  700. package/dist/vue3/lib/feed-item-pill/feed-item-pill-constants.js.map +1 -1
  701. package/dist/vue3/lib/feed-item-pill/feed-item-pill.cjs +1 -1
  702. package/dist/vue3/lib/feed-item-pill/feed-item-pill.cjs.map +1 -1
  703. package/dist/vue3/lib/feed-item-pill/feed-item-pill.js +6 -6
  704. package/dist/vue3/lib/feed-item-pill/feed-item-pill.js.map +1 -1
  705. package/dist/vue3/lib/feed-item-row/feed-item-row-constants.cjs.map +1 -1
  706. package/dist/vue3/lib/feed-item-row/feed-item-row-constants.js.map +1 -1
  707. package/dist/vue3/lib/feed-item-row/feed-item-row.cjs +1 -1
  708. package/dist/vue3/lib/feed-item-row/feed-item-row.cjs.map +1 -1
  709. package/dist/vue3/lib/feed-item-row/feed-item-row.js +56 -56
  710. package/dist/vue3/lib/feed-item-row/feed-item-row.js.map +1 -1
  711. package/dist/vue3/lib/general-row/general-row-constants.cjs.map +1 -1
  712. package/dist/vue3/lib/general-row/general-row-constants.js.map +1 -1
  713. package/dist/vue3/lib/general-row/general-row.cjs +1 -1
  714. package/dist/vue3/lib/general-row/general-row.cjs.map +1 -1
  715. package/dist/vue3/lib/general-row/general-row.js +30 -30
  716. package/dist/vue3/lib/general-row/general-row.js.map +1 -1
  717. package/dist/vue3/lib/general-row/leftbar-general-row-icon.cjs.map +1 -1
  718. package/dist/vue3/lib/general-row/leftbar-general-row-icon.js +35 -35
  719. package/dist/vue3/lib/general-row/leftbar-general-row-icon.js.map +1 -1
  720. package/dist/vue3/lib/group-row/group-row.cjs.map +1 -1
  721. package/dist/vue3/lib/group-row/group-row.js +3 -3
  722. package/dist/vue3/lib/group-row/group-row.js.map +1 -1
  723. package/dist/vue3/lib/grouped-chip/grouped-chip.cjs.map +1 -1
  724. package/dist/vue3/lib/grouped-chip/grouped-chip.js +14 -14
  725. package/dist/vue3/lib/grouped-chip/grouped-chip.js.map +1 -1
  726. package/dist/vue3/lib/hovercard/hovercard.cjs +1 -1
  727. package/dist/vue3/lib/hovercard/hovercard.cjs.map +1 -1
  728. package/dist/vue3/lib/hovercard/hovercard.js +6 -6
  729. package/dist/vue3/lib/hovercard/hovercard.js.map +1 -1
  730. package/dist/vue3/lib/icon/icon-constants.cjs.map +1 -1
  731. package/dist/vue3/lib/icon/icon-constants.js.map +1 -1
  732. package/dist/vue3/lib/icon/icon.cjs.map +1 -1
  733. package/dist/vue3/lib/icon/icon.js +6 -6
  734. package/dist/vue3/lib/icon/icon.js.map +1 -1
  735. package/dist/vue3/lib/illustration/illustration-constants.cjs.map +1 -1
  736. package/dist/vue3/lib/illustration/illustration-constants.js.map +1 -1
  737. package/dist/vue3/lib/illustration/illustration.cjs.map +1 -1
  738. package/dist/vue3/lib/illustration/illustration.js +3 -3
  739. package/dist/vue3/lib/image-viewer/image-viewer.cjs.map +1 -1
  740. package/dist/vue3/lib/image-viewer/image-viewer.js +12 -12
  741. package/dist/vue3/lib/image-viewer/image-viewer.js.map +1 -1
  742. package/dist/vue3/lib/input/input-constants.cjs.map +1 -1
  743. package/dist/vue3/lib/input/input-constants.js.map +1 -1
  744. package/dist/vue3/lib/input/input.cjs.map +1 -1
  745. package/dist/vue3/lib/input/input.js +20 -20
  746. package/dist/vue3/lib/input/input.js.map +1 -1
  747. package/dist/vue3/lib/input-group/input-group.cjs.map +1 -1
  748. package/dist/vue3/lib/input-group/input-group.js +8 -8
  749. package/dist/vue3/lib/input-group/input-group.js.map +1 -1
  750. package/dist/vue3/lib/item-layout/item-layout.cjs.map +1 -1
  751. package/dist/vue3/lib/item-layout/item-layout.js +13 -13
  752. package/dist/vue3/lib/item-layout/item-layout.js.map +1 -1
  753. package/dist/vue3/lib/ivr-node/ivr-node-constants.cjs.map +1 -1
  754. package/dist/vue3/lib/ivr-node/ivr-node-constants.js.map +1 -1
  755. package/dist/vue3/lib/ivr-node/ivr-node.cjs +1 -1
  756. package/dist/vue3/lib/ivr-node/ivr-node.cjs.map +1 -1
  757. package/dist/vue3/lib/ivr-node/ivr-node.js +36 -36
  758. package/dist/vue3/lib/ivr-node/ivr-node.js.map +1 -1
  759. package/dist/vue3/lib/keyboard-shortcut/keyboard-shortcut.cjs.map +1 -1
  760. package/dist/vue3/lib/keyboard-shortcut/keyboard-shortcut.js +15 -15
  761. package/dist/vue3/lib/keyboard-shortcut/keyboard-shortcut.js.map +1 -1
  762. package/dist/vue3/lib/lazy-show/lazy-show.cjs.map +1 -1
  763. package/dist/vue3/lib/lazy-show/lazy-show.js +2 -2
  764. package/dist/vue3/lib/lazy-show/lazy-show.js.map +1 -1
  765. package/dist/vue3/lib/link/link-constants.cjs.map +1 -1
  766. package/dist/vue3/lib/link/link-constants.js.map +1 -1
  767. package/dist/vue3/lib/link/link.cjs.map +1 -1
  768. package/dist/vue3/lib/link/link.js +5 -5
  769. package/dist/vue3/lib/link/link.js.map +1 -1
  770. package/dist/vue3/lib/list-item/list-item-constants.cjs.map +1 -1
  771. package/dist/vue3/lib/list-item/list-item-constants.js.map +1 -1
  772. package/dist/vue3/lib/list-item/list-item.cjs.map +1 -1
  773. package/dist/vue3/lib/list-item/list-item.js +4 -4
  774. package/dist/vue3/lib/list-item/list-item.js.map +1 -1
  775. package/dist/vue3/lib/list-item-group/list-item-group-constants.cjs.map +1 -1
  776. package/dist/vue3/lib/list-item-group/list-item-group-constants.js.map +1 -1
  777. package/dist/vue3/lib/list-item-group/list-item-group.cjs.map +1 -1
  778. package/dist/vue3/lib/list-item-group/list-item-group.js +5 -5
  779. package/dist/vue3/lib/list-item-group/list-item-group.js.map +1 -1
  780. package/dist/vue3/lib/loader/loader.cjs.map +1 -1
  781. package/dist/vue3/lib/loader/loader.js +2 -2
  782. package/dist/vue3/lib/loader/loader.js.map +1 -1
  783. package/dist/vue3/lib/message-input/last-active-nodes.cjs +1 -1
  784. package/dist/vue3/lib/message-input/last-active-nodes.cjs.map +1 -1
  785. package/dist/vue3/lib/message-input/last-active-nodes.js +22 -22
  786. package/dist/vue3/lib/message-input/last-active-nodes.js.map +1 -1
  787. package/dist/vue3/lib/message-input/message-input-button.cjs +1 -1
  788. package/dist/vue3/lib/message-input/message-input-button.cjs.map +1 -1
  789. package/dist/vue3/lib/message-input/message-input-button.js +14 -14
  790. package/dist/vue3/lib/message-input/message-input-button.js.map +1 -1
  791. package/dist/vue3/lib/message-input/message-input-constants.cjs.map +1 -1
  792. package/dist/vue3/lib/message-input/message-input-constants.js.map +1 -1
  793. package/dist/vue3/lib/message-input/message-input-link.cjs +1 -1
  794. package/dist/vue3/lib/message-input/message-input-link.cjs.map +1 -1
  795. package/dist/vue3/lib/message-input/message-input-link.js +10 -10
  796. package/dist/vue3/lib/message-input/message-input-link.js.map +1 -1
  797. package/dist/vue3/lib/message-input/message-input-topbar.cjs.map +1 -1
  798. package/dist/vue3/lib/message-input/message-input-topbar.js +11 -11
  799. package/dist/vue3/lib/message-input/message-input-topbar.js.map +1 -1
  800. package/dist/vue3/lib/message-input/message-input.cjs +1 -1
  801. package/dist/vue3/lib/message-input/message-input.cjs.map +1 -1
  802. package/dist/vue3/lib/message-input/message-input.js +32 -32
  803. package/dist/vue3/lib/message-input/message-input.js.map +1 -1
  804. package/dist/vue3/lib/modal/modal.cjs +1 -1
  805. package/dist/vue3/lib/modal/modal.cjs.map +1 -1
  806. package/dist/vue3/lib/modal/modal.js +14 -14
  807. package/dist/vue3/lib/modal/modal.js.map +1 -1
  808. package/dist/vue3/lib/notice/notice-action.cjs.map +1 -1
  809. package/dist/vue3/lib/notice/notice-action.js +1 -1
  810. package/dist/vue3/lib/notice/notice-action.js.map +1 -1
  811. package/dist/vue3/lib/notice/notice-constants.cjs.map +1 -1
  812. package/dist/vue3/lib/notice/notice-constants.js.map +1 -1
  813. package/dist/vue3/lib/notice/notice-content.cjs.map +1 -1
  814. package/dist/vue3/lib/notice/notice-content.js +6 -6
  815. package/dist/vue3/lib/notice/notice-content.js.map +1 -1
  816. package/dist/vue3/lib/notice/notice-icon.cjs.map +1 -1
  817. package/dist/vue3/lib/notice/notice-icon.js +13 -13
  818. package/dist/vue3/lib/notice/notice-icon.js.map +1 -1
  819. package/dist/vue3/lib/notice/notice.cjs.map +1 -1
  820. package/dist/vue3/lib/notice/notice.js +4 -4
  821. package/dist/vue3/lib/notice/notice.js.map +1 -1
  822. package/dist/vue3/lib/pagination/pagination.cjs.map +1 -1
  823. package/dist/vue3/lib/pagination/pagination.js +4 -4
  824. package/dist/vue3/lib/pagination/pagination.js.map +1 -1
  825. package/dist/vue3/lib/popover/popover-constants.cjs.map +1 -1
  826. package/dist/vue3/lib/popover/popover-constants.js.map +1 -1
  827. package/dist/vue3/lib/popover/popover-header-footer.cjs.map +1 -1
  828. package/dist/vue3/lib/popover/popover-header-footer.js +6 -6
  829. package/dist/vue3/lib/popover/popover-header-footer.js.map +1 -1
  830. package/dist/vue3/lib/popover/popover.cjs +1 -1
  831. package/dist/vue3/lib/popover/popover.cjs.map +1 -1
  832. package/dist/vue3/lib/popover/popover.js +17 -17
  833. package/dist/vue3/lib/popover/popover.js.map +1 -1
  834. package/dist/vue3/lib/popover/tippy-utils.cjs +1 -1
  835. package/dist/vue3/lib/popover/tippy-utils.cjs.map +1 -1
  836. package/dist/vue3/lib/popover/tippy-utils.js +16 -18
  837. package/dist/vue3/lib/popover/tippy-utils.js.map +1 -1
  838. package/dist/vue3/lib/presence/presence.cjs.map +1 -1
  839. package/dist/vue3/lib/presence/presence.js +4 -4
  840. package/dist/vue3/lib/presence/presence.js.map +1 -1
  841. package/dist/vue3/lib/radio/radio-constants.cjs.map +1 -1
  842. package/dist/vue3/lib/radio/radio-constants.js.map +1 -1
  843. package/dist/vue3/lib/radio/radio.cjs.map +1 -1
  844. package/dist/vue3/lib/radio/radio.js +13 -13
  845. package/dist/vue3/lib/radio/radio.js.map +1 -1
  846. package/dist/vue3/lib/radio-group/radio-group.cjs.map +1 -1
  847. package/dist/vue3/lib/radio-group/radio-group.js.map +1 -1
  848. package/dist/vue3/lib/radio-group/radios-decorator.cjs.map +1 -1
  849. package/dist/vue3/lib/radio-group/radios-decorator.js +1 -1
  850. package/dist/vue3/lib/radio-group/radios-decorator.js.map +1 -1
  851. package/dist/vue3/lib/recipes/eslint.config.cjs +2 -0
  852. package/dist/vue3/lib/recipes/eslint.config.cjs.map +1 -0
  853. package/dist/vue3/lib/recipes/eslint.config.js +12 -0
  854. package/dist/vue3/lib/recipes/eslint.config.js.map +1 -0
  855. package/dist/vue3/lib/rich-text-editor/channel-suggestion.cjs.map +1 -1
  856. package/dist/vue3/lib/rich-text-editor/channel-suggestion.js.map +1 -1
  857. package/dist/vue3/lib/rich-text-editor/mention-suggestion.cjs.map +1 -1
  858. package/dist/vue3/lib/rich-text-editor/mention-suggestion.js.map +1 -1
  859. package/dist/vue3/lib/rich-text-editor/rich-text-editor-constants.cjs.map +1 -1
  860. package/dist/vue3/lib/rich-text-editor/rich-text-editor-constants.js.map +1 -1
  861. package/dist/vue3/lib/rich-text-editor/rich-text-editor.cjs +3 -3
  862. package/dist/vue3/lib/rich-text-editor/rich-text-editor.cjs.map +1 -1
  863. package/dist/vue3/lib/rich-text-editor/rich-text-editor.js +61 -54
  864. package/dist/vue3/lib/rich-text-editor/rich-text-editor.js.map +1 -1
  865. package/dist/vue3/lib/rich-text-editor/slash-command-suggestion.cjs.map +1 -1
  866. package/dist/vue3/lib/rich-text-editor/slash-command-suggestion.js.map +1 -1
  867. package/dist/vue3/lib/root-layout/root-layout-constants.cjs.map +1 -1
  868. package/dist/vue3/lib/root-layout/root-layout-constants.js.map +1 -1
  869. package/dist/vue3/lib/root-layout/root-layout.cjs.map +1 -1
  870. package/dist/vue3/lib/root-layout/root-layout.js +3 -3
  871. package/dist/vue3/lib/root-layout/root-layout.js.map +1 -1
  872. package/dist/vue3/lib/scrollbar-directive/scrollbar.cjs.map +1 -1
  873. package/dist/vue3/lib/scrollbar-directive/scrollbar.js.map +1 -1
  874. package/dist/vue3/lib/scroller/scroller.cjs +1 -1
  875. package/dist/vue3/lib/scroller/scroller.cjs.map +1 -1
  876. package/dist/vue3/lib/scroller/scroller.js +2 -2
  877. package/dist/vue3/lib/scroller/scroller.js.map +1 -1
  878. package/dist/vue3/lib/select-menu/select-menu-constants.cjs.map +1 -1
  879. package/dist/vue3/lib/select-menu/select-menu-constants.js.map +1 -1
  880. package/dist/vue3/lib/select-menu/select-menu.cjs.map +1 -1
  881. package/dist/vue3/lib/select-menu/select-menu.js +21 -21
  882. package/dist/vue3/lib/select-menu/select-menu.js.map +1 -1
  883. package/dist/vue3/lib/settings-menu-button/settings-menu-button.cjs.map +1 -1
  884. package/dist/vue3/lib/settings-menu-button/settings-menu-button.js +3 -3
  885. package/dist/vue3/lib/settings-menu-button/settings-menu-button.js.map +1 -1
  886. package/dist/vue3/lib/skeleton/skeleton-constants.cjs.map +1 -1
  887. package/dist/vue3/lib/skeleton/skeleton-constants.js.map +1 -1
  888. package/dist/vue3/lib/skeleton/skeleton-list-item.cjs.map +1 -1
  889. package/dist/vue3/lib/skeleton/skeleton-list-item.js +2 -2
  890. package/dist/vue3/lib/skeleton/skeleton-list-item.js.map +1 -1
  891. package/dist/vue3/lib/skeleton/skeleton-paragraph.cjs.map +1 -1
  892. package/dist/vue3/lib/skeleton/skeleton-paragraph.js +1 -1
  893. package/dist/vue3/lib/skeleton/skeleton-paragraph.js.map +1 -1
  894. package/dist/vue3/lib/skeleton/skeleton-shape.cjs.map +1 -1
  895. package/dist/vue3/lib/skeleton/skeleton-shape.js +5 -5
  896. package/dist/vue3/lib/skeleton/skeleton-shape.js.map +1 -1
  897. package/dist/vue3/lib/skeleton/skeleton-text.cjs.map +1 -1
  898. package/dist/vue3/lib/skeleton/skeleton-text.js +7 -7
  899. package/dist/vue3/lib/skeleton/skeleton-text.js.map +1 -1
  900. package/dist/vue3/lib/skeleton/skeleton.cjs +1 -1
  901. package/dist/vue3/lib/skeleton/skeleton.cjs.map +1 -1
  902. package/dist/vue3/lib/skeleton/skeleton.js +11 -11
  903. package/dist/vue3/lib/skeleton/skeleton.js.map +1 -1
  904. package/dist/vue3/lib/split-button/split-button-alpha.cjs.map +1 -1
  905. package/dist/vue3/lib/split-button/split-button-alpha.js +2 -2
  906. package/dist/vue3/lib/split-button/split-button-alpha.js.map +1 -1
  907. package/dist/vue3/lib/split-button/split-button-constants.cjs.map +1 -1
  908. package/dist/vue3/lib/split-button/split-button-constants.js.map +1 -1
  909. package/dist/vue3/lib/split-button/split-button-omega.cjs.map +1 -1
  910. package/dist/vue3/lib/split-button/split-button-omega.js +2 -2
  911. package/dist/vue3/lib/split-button/split-button-omega.js.map +1 -1
  912. package/dist/vue3/lib/split-button/split-button.cjs.map +1 -1
  913. package/dist/vue3/lib/split-button/split-button.js +19 -19
  914. package/dist/vue3/lib/split-button/split-button.js.map +1 -1
  915. package/dist/vue3/lib/stack/stack-constants.cjs.map +1 -1
  916. package/dist/vue3/lib/stack/stack-constants.js.map +1 -1
  917. package/dist/vue3/lib/stack/stack.cjs.map +1 -1
  918. package/dist/vue3/lib/stack/stack.js +11 -11
  919. package/dist/vue3/lib/stack/stack.js.map +1 -1
  920. package/dist/vue3/lib/stack/utils.cjs.map +1 -1
  921. package/dist/vue3/lib/stack/utils.js.map +1 -1
  922. package/dist/vue3/lib/stack/validators.cjs.map +1 -1
  923. package/dist/vue3/lib/stack/validators.js +5 -5
  924. package/dist/vue3/lib/stack/validators.js.map +1 -1
  925. package/dist/vue3/lib/tab/tab-group.cjs.map +1 -1
  926. package/dist/vue3/lib/tab/tab-group.js +7 -7
  927. package/dist/vue3/lib/tab/tab-group.js.map +1 -1
  928. package/dist/vue3/lib/tab/tab-panel.cjs.map +1 -1
  929. package/dist/vue3/lib/tab/tab-panel.js +2 -2
  930. package/dist/vue3/lib/tab/tab-panel.js.map +1 -1
  931. package/dist/vue3/lib/tab/tab.cjs.map +1 -1
  932. package/dist/vue3/lib/tab/tab.js +2 -2
  933. package/dist/vue3/lib/tab/tab.js.map +1 -1
  934. package/dist/vue3/lib/time-pill/time-pill.cjs.map +1 -1
  935. package/dist/vue3/lib/time-pill/time-pill.js +2 -2
  936. package/dist/vue3/lib/time-pill/time-pill.js.map +1 -1
  937. package/dist/vue3/lib/toast/toast-constants.cjs.map +1 -1
  938. package/dist/vue3/lib/toast/toast-constants.js.map +1 -1
  939. package/dist/vue3/lib/toast/toast.cjs +1 -1
  940. package/dist/vue3/lib/toast/toast.cjs.map +1 -1
  941. package/dist/vue3/lib/toast/toast.js +12 -12
  942. package/dist/vue3/lib/toast/toast.js.map +1 -1
  943. package/dist/vue3/lib/toggle/toggle-constants.cjs.map +1 -1
  944. package/dist/vue3/lib/toggle/toggle-constants.js.map +1 -1
  945. package/dist/vue3/lib/toggle/toggle.cjs +1 -1
  946. package/dist/vue3/lib/toggle/toggle.cjs.map +1 -1
  947. package/dist/vue3/lib/toggle/toggle.js +14 -14
  948. package/dist/vue3/lib/toggle/toggle.js.map +1 -1
  949. package/dist/vue3/lib/tooltip/tooltip-constants.cjs.map +1 -1
  950. package/dist/vue3/lib/tooltip/tooltip-constants.js.map +1 -1
  951. package/dist/vue3/lib/tooltip/tooltip.cjs +1 -1
  952. package/dist/vue3/lib/tooltip/tooltip.cjs.map +1 -1
  953. package/dist/vue3/lib/tooltip/tooltip.js +20 -22
  954. package/dist/vue3/lib/tooltip/tooltip.js.map +1 -1
  955. package/dist/vue3/lib/tooltip-directive/tooltip.cjs.map +1 -1
  956. package/dist/vue3/lib/tooltip-directive/tooltip.js +1 -1
  957. package/dist/vue3/lib/tooltip-directive/tooltip.js.map +1 -1
  958. package/dist/vue3/lib/top-banner-info/top-banner-info-constants.cjs.map +1 -1
  959. package/dist/vue3/lib/top-banner-info/top-banner-info-constants.js.map +1 -1
  960. package/dist/vue3/lib/top-banner-info/top-banner-info.cjs.map +1 -1
  961. package/dist/vue3/lib/top-banner-info/top-banner-info.js +2 -2
  962. package/dist/vue3/lib/top-banner-info/top-banner-info.js.map +1 -1
  963. package/dist/vue3/lib/unread-pill/unread-pill-constants.cjs.map +1 -1
  964. package/dist/vue3/lib/unread-pill/unread-pill-constants.js.map +1 -1
  965. package/dist/vue3/lib/unread-pill/unread-pill.cjs.map +1 -1
  966. package/dist/vue3/lib/unread-pill/unread-pill.js +7 -7
  967. package/dist/vue3/lib/unread-pill/unread-pill.js.map +1 -1
  968. package/dist/vue3/lib/validation-messages/validation-messages.cjs.map +1 -1
  969. package/dist/vue3/lib/validation-messages/validation-messages.js +9 -9
  970. package/dist/vue3/lib/validation-messages/validation-messages.js.map +1 -1
  971. package/dist/vue3/localization/de-DE.cjs.map +1 -1
  972. package/dist/vue3/localization/de-DE.js.map +1 -1
  973. package/dist/vue3/localization/en-US.cjs.map +1 -1
  974. package/dist/vue3/localization/en-US.js.map +1 -1
  975. package/dist/vue3/localization/es-LA.cjs.map +1 -1
  976. package/dist/vue3/localization/es-LA.js.map +1 -1
  977. package/dist/vue3/localization/fr-FR.cjs.map +1 -1
  978. package/dist/vue3/localization/fr-FR.js.map +1 -1
  979. package/dist/vue3/localization/index.cjs.map +1 -1
  980. package/dist/vue3/localization/index.js.map +1 -1
  981. package/dist/vue3/localization/it-IT.cjs.map +1 -1
  982. package/dist/vue3/localization/it-IT.js.map +1 -1
  983. package/dist/vue3/localization/ja-JP.cjs.map +1 -1
  984. package/dist/vue3/localization/ja-JP.js.map +1 -1
  985. package/dist/vue3/localization/nl-NL.cjs.map +1 -1
  986. package/dist/vue3/localization/nl-NL.js.map +1 -1
  987. package/dist/vue3/localization/pt-BR.cjs.map +1 -1
  988. package/dist/vue3/localization/pt-BR.js.map +1 -1
  989. package/dist/vue3/localization/ru-RU.cjs.map +1 -1
  990. package/dist/vue3/localization/ru-RU.js.map +1 -1
  991. package/dist/vue3/localization/zh-CN.cjs.map +1 -1
  992. package/dist/vue3/localization/zh-CN.js.map +1 -1
  993. package/dist/vue3/node_modules/@tiptap/vue-3.cjs.map +1 -1
  994. package/dist/vue3/node_modules/@tiptap/vue-3.js +3 -3
  995. package/dist/vue3/node_modules/@tiptap/vue-3.js.map +1 -1
  996. package/dist/vue3/shared/sr_only_close_button.cjs.map +1 -1
  997. package/dist/vue3/shared/sr_only_close_button.js +2 -2
  998. package/dist/vue3/shared/sr_only_close_button.js.map +1 -1
  999. package/dist/vue3/types/common/constants/index.d.ts.map +1 -1
  1000. package/dist/vue3/types/common/dates/index.d.ts.map +1 -1
  1001. package/dist/vue3/types/common/emoji/index.d.ts.map +1 -1
  1002. package/dist/vue3/types/common/mixins/dom.d.ts.map +1 -1
  1003. package/dist/vue3/types/common/mixins/input.d.ts +6 -6
  1004. package/dist/vue3/types/common/mixins/input.d.ts.map +1 -1
  1005. package/dist/vue3/types/common/mixins/input_group.d.ts +2 -2
  1006. package/dist/vue3/types/common/mixins/modal.d.ts.map +1 -1
  1007. package/dist/vue3/types/common/utils/index.d.ts.map +1 -1
  1008. package/dist/vue3/types/components/avatar/avatar.vue.d.ts +12 -12
  1009. package/dist/vue3/types/components/badge/badge.vue.d.ts +4 -4
  1010. package/dist/vue3/types/components/banner/banner.vue.d.ts +1 -1
  1011. package/dist/vue3/types/components/banner/banner.vue.d.ts.map +1 -1
  1012. package/dist/vue3/types/components/breadcrumbs/breadcrumbs_constants.d.ts.map +1 -1
  1013. package/dist/vue3/types/components/button/button.vue.d.ts +3 -3
  1014. package/dist/vue3/types/components/button/button_constants.d.ts.map +1 -1
  1015. package/dist/vue3/types/components/card/card.vue.d.ts +12 -12
  1016. package/dist/vue3/types/components/checkbox/checkbox.vue.d.ts +6 -6
  1017. package/dist/vue3/types/components/checkbox_group/checkbox_group.vue.d.ts +2 -2
  1018. package/dist/vue3/types/components/chip/chip.vue.d.ts +6 -6
  1019. package/dist/vue3/types/components/collapsible/collapsible.vue.d.ts +6 -6
  1020. package/dist/vue3/types/components/combobox/combobox.vue.d.ts +4 -4
  1021. package/dist/vue3/types/components/combobox/combobox_empty-list.vue.d.ts +3 -3
  1022. package/dist/vue3/types/components/datepicker/datepicker_constants.d.ts.map +1 -1
  1023. package/dist/vue3/types/components/datepicker/formatUtils.d.ts +5 -5
  1024. package/dist/vue3/types/components/datepicker/formatUtils.d.ts.map +1 -1
  1025. package/dist/vue3/types/components/datepicker/modules/calendar.vue.d.ts +1 -1
  1026. package/dist/vue3/types/components/datepicker/modules/month-year-picker.vue.d.ts +1 -1
  1027. package/dist/vue3/types/components/description_list/description_list.vue.d.ts +6 -6
  1028. package/dist/vue3/types/components/dropdown/dropdown.vue.d.ts +10 -10
  1029. package/dist/vue3/types/components/emoji/emoji.vue.d.ts +3 -3
  1030. package/dist/vue3/types/components/emoji_picker/emoji_picker_constants.d.ts.map +1 -1
  1031. package/dist/vue3/types/components/emoji_picker/modules/emoji_search.vue.d.ts.map +1 -1
  1032. package/dist/vue3/types/components/emoji_picker/modules/emoji_selector.vue.d.ts.map +1 -1
  1033. package/dist/vue3/types/components/emoji_picker/modules/emoji_skin_selector.vue.d.ts.map +1 -1
  1034. package/dist/vue3/types/components/emoji_picker/modules/emoji_tabset.vue.d.ts.map +1 -1
  1035. package/dist/vue3/types/components/emoji_text_wrapper/emoji_text_wrapper.vue.d.ts +1 -1
  1036. package/dist/vue3/types/components/emoji_text_wrapper/emoji_text_wrapper.vue.d.ts.map +1 -1
  1037. package/dist/vue3/types/components/empty_state/empty_state.vue.d.ts +7 -11
  1038. package/dist/vue3/types/components/empty_state/empty_state.vue.d.ts.map +1 -1
  1039. package/dist/vue3/types/components/eslint.config.d.ts +8 -0
  1040. package/dist/vue3/types/components/eslint.config.d.ts.map +1 -0
  1041. package/dist/vue3/types/components/hovercard/hovercard.vue.d.ts +686 -11
  1042. package/dist/vue3/types/components/hovercard/hovercard.vue.d.ts.map +1 -1
  1043. package/dist/vue3/types/components/image_viewer/image_viewer.vue.d.ts.map +1 -1
  1044. package/dist/vue3/types/components/input/input.vue.d.ts +8 -8
  1045. package/dist/vue3/types/components/input_group/input_group.vue.d.ts +2 -2
  1046. package/dist/vue3/types/components/item_layout/item_layout.vue.d.ts +1 -1
  1047. package/dist/vue3/types/components/keyboard_shortcut/keyboard_shortcut.vue.d.ts +7 -210
  1048. package/dist/vue3/types/components/lazy_show/lazy_show.vue.d.ts +1 -1
  1049. package/dist/vue3/types/components/link/link_constants.d.ts.map +1 -1
  1050. package/dist/vue3/types/components/list_item/list_item.vue.d.ts +3 -3
  1051. package/dist/vue3/types/components/list_item_group/list_item_group.vue.d.ts +6 -6
  1052. package/dist/vue3/types/components/modal/modal.vue.d.ts +16 -16
  1053. package/dist/vue3/types/components/modal/modal.vue.d.ts.map +1 -1
  1054. package/dist/vue3/types/components/notice/notice.vue.d.ts +1 -1
  1055. package/dist/vue3/types/components/notice/notice_icon.vue.d.ts +1 -30
  1056. package/dist/vue3/types/components/notice/notice_icon.vue.d.ts.map +1 -1
  1057. package/dist/vue3/types/components/popover/popover.vue.d.ts +26 -26
  1058. package/dist/vue3/types/components/popover/popover.vue.d.ts.map +1 -1
  1059. package/dist/vue3/types/components/popover/popover_header_footer.vue.d.ts +3 -3
  1060. package/dist/vue3/types/components/popover/tippy_utils.d.ts +2 -3
  1061. package/dist/vue3/types/components/popover/tippy_utils.d.ts.map +1 -1
  1062. package/dist/vue3/types/components/radio/radio.vue.d.ts +6 -6
  1063. package/dist/vue3/types/components/radio_group/radio_group.vue.d.ts +2 -2
  1064. package/dist/vue3/types/components/rich_text_editor/extensions/channels/ChannelComponent.vue.d.ts +22 -22
  1065. package/dist/vue3/types/components/rich_text_editor/extensions/emoji/EmojiComponent.vue.d.ts +22 -22
  1066. package/dist/vue3/types/components/rich_text_editor/extensions/mentions/MentionComponent.vue.d.ts +22 -22
  1067. package/dist/vue3/types/components/rich_text_editor/extensions/slash_command/SlashCommandComponent.vue.d.ts +22 -22
  1068. package/dist/vue3/types/components/rich_text_editor/extensions/slash_command/slash_command.d.ts +1 -1
  1069. package/dist/vue3/types/components/rich_text_editor/extensions/slash_command/slash_command.d.ts.map +1 -1
  1070. package/dist/vue3/types/components/rich_text_editor/rich_text_editor.vue.d.ts +7 -12
  1071. package/dist/vue3/types/components/rich_text_editor/rich_text_editor.vue.d.ts.map +1 -1
  1072. package/dist/vue3/types/components/root_layout/root_layout.vue.d.ts +15 -15
  1073. package/dist/vue3/types/components/scroller/modules/core_scroller.vue.d.ts +26 -16
  1074. package/dist/vue3/types/components/scroller/modules/core_scroller.vue.d.ts.map +1 -1
  1075. package/dist/vue3/types/components/scroller/modules/scroller_item.vue.d.ts +1 -1
  1076. package/dist/vue3/types/components/scroller/scroller.vue.d.ts +245 -12
  1077. package/dist/vue3/types/components/scroller/scroller.vue.d.ts.map +1 -1
  1078. package/dist/vue3/types/components/select_menu/select_menu.vue.d.ts +13 -13
  1079. package/dist/vue3/types/components/skeleton/skeleton-list-item.vue.d.ts +1 -1
  1080. package/dist/vue3/types/components/skeleton/skeleton-paragraph.vue.d.ts +3 -3
  1081. package/dist/vue3/types/components/skeleton/skeleton-shape.vue.d.ts +4 -4
  1082. package/dist/vue3/types/components/skeleton/skeleton-text.vue.d.ts +1 -1
  1083. package/dist/vue3/types/components/skeleton/skeleton.vue.d.ts +1 -1
  1084. package/dist/vue3/types/components/skeleton/skeleton_constants.d.ts.map +1 -1
  1085. package/dist/vue3/types/components/split_button/split_button-alpha.vue.d.ts +3 -3
  1086. package/dist/vue3/types/components/split_button/split_button.vue.d.ts +3 -3
  1087. package/dist/vue3/types/components/tab/tab.vue.d.ts +3 -3
  1088. package/dist/vue3/types/components/tab/tab_group.vue.d.ts +3 -3
  1089. package/dist/vue3/types/components/tab/tab_panel.vue.d.ts +3 -3
  1090. package/dist/vue3/types/components/tab/tab_panel.vue.d.ts.map +1 -1
  1091. package/dist/vue3/types/components/toast/layouts/toast_layout_alternate.vue.d.ts +1 -1
  1092. package/dist/vue3/types/components/toast/layouts/toast_layout_alternate_icon.vue.d.ts +1 -30
  1093. package/dist/vue3/types/components/toast/layouts/toast_layout_default.vue.d.ts +1 -1
  1094. package/dist/vue3/types/components/toast/toast.vue.d.ts +4 -4
  1095. package/dist/vue3/types/components/toast/toast_constants.d.ts.map +1 -1
  1096. package/dist/vue3/types/components/toggle/toggle.vue.d.ts +7 -7
  1097. package/dist/vue3/types/components/tooltip/tooltip.vue.d.ts +10 -10
  1098. package/dist/vue3/types/components/tooltip/tooltip_constants.d.ts.map +1 -1
  1099. package/dist/vue3/types/components/validation_messages/validation_messages.vue.d.ts +0 -1
  1100. package/dist/vue3/types/components/validation_messages/validation_messages.vue.d.ts.map +1 -1
  1101. package/dist/vue3/types/recipes/buttons/callbar_button/callbar_button.vue.d.ts +7 -7
  1102. package/dist/vue3/types/recipes/buttons/callbar_button_with_dropdown/callbar_button_with_dropdown.vue.d.ts +7 -7
  1103. package/dist/vue3/types/recipes/buttons/callbar_button_with_popover/callbar_button_with_popover.vue.d.ts +9 -9
  1104. package/dist/vue3/types/recipes/cards/ivr_node/ivr_node.vue.d.ts +1 -30
  1105. package/dist/vue3/types/recipes/cards/ivr_node/ivr_node.vue.d.ts.map +1 -1
  1106. package/dist/vue3/types/recipes/cards/ivr_node/ivr_node_constants.d.ts.map +1 -1
  1107. package/dist/vue3/types/recipes/comboboxes/combobox_with_popover/combobox_with_popover.vue.d.ts +9 -9
  1108. package/dist/vue3/types/recipes/conversation_view/editor/editor.vue.d.ts +9 -241
  1109. package/dist/vue3/types/recipes/conversation_view/editor/editor.vue.d.ts.map +1 -1
  1110. package/dist/vue3/types/recipes/conversation_view/editor/editor_constants.d.ts.map +1 -1
  1111. package/dist/vue3/types/recipes/conversation_view/feed_item_pill/feed_item_pill.vue.d.ts +7 -36
  1112. package/dist/vue3/types/recipes/conversation_view/feed_item_pill/feed_item_pill.vue.d.ts.map +1 -1
  1113. package/dist/vue3/types/recipes/conversation_view/feed_item_row/feed_item_row.vue.d.ts +1 -1
  1114. package/dist/vue3/types/recipes/conversation_view/feed_item_row/feed_item_row.vue.d.ts.map +1 -1
  1115. package/dist/vue3/types/recipes/conversation_view/feed_item_row/feed_item_row_constants.d.ts.map +1 -1
  1116. package/dist/vue3/types/recipes/conversation_view/message_input/extensions/meeting_pill/MeetingPill.vue.d.ts +22 -22
  1117. package/dist/vue3/types/recipes/conversation_view/message_input/last_active_nodes.d.ts.map +1 -1
  1118. package/dist/vue3/types/recipes/conversation_view/message_input/message_input.vue.d.ts +7 -7
  1119. package/dist/vue3/types/recipes/eslint.config.d.ts +8 -0
  1120. package/dist/vue3/types/recipes/eslint.config.d.ts.map +1 -0
  1121. package/dist/vue3/types/recipes/item_layout/contact_info/contact_info.vue.d.ts +1 -1
  1122. package/dist/vue3/types/recipes/leftbar/general_row/leftbar_general_row_icon.vue.d.ts +1 -30
  1123. package/package.json +7 -6
  1124. package/dist/vue2/types/components/rich_text_editor/extensions/channels/ChannelComponent.vue.d.ts +0 -47
  1125. package/dist/vue2/types/components/rich_text_editor/extensions/channels/ChannelComponent.vue.d.ts.map +0 -1
  1126. package/dist/vue2/types/components/rich_text_editor/extensions/mentions/MentionComponent.vue.d.ts +0 -47
  1127. package/dist/vue2/types/components/rich_text_editor/extensions/mentions/MentionComponent.vue.d.ts.map +0 -1
  1128. package/dist/vue2/types/components/rich_text_editor/extensions/slash_command/SlashCommandComponent.vue.d.ts +0 -47
  1129. package/dist/vue2/types/components/rich_text_editor/extensions/slash_command/SlashCommandComponent.vue.d.ts.map +0 -1
  1130. package/dist/vue2/types/recipes/conversation_view/message_input/extensions/meeting_pill/MeetingPill.vue.d.ts +0 -52
  1131. package/dist/vue2/types/recipes/conversation_view/message_input/extensions/meeting_pill/MeetingPill.vue.d.ts.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"emoji-picker.js","sources":["../../../components/emoji_picker/modules/emoji_tabset.vue","../../../components/emoji_picker/modules/emoji_search.vue","../../../components/emoji_picker/modules/emoji_selector.vue","../../../components/emoji_picker/modules/emoji_description.vue","../../../components/emoji_picker/modules/emoji_skin_selector.vue","../../../components/emoji_picker/emoji_picker.vue"],"sourcesContent":["<template>\n <div class=\"d-emoji-picker__tabset\">\n <dt-tab-group\n :selected=\"selectedTab\"\n size=\"sm\"\n tab-list-class=\"d-emoji-picker__tabset-list\"\n >\n <template #tabs>\n <dt-tab\n v-for=\"(tab, index) in tabs\"\n :id=\"tab.id\"\n :key=\"tab.id\"\n :ref=\"`tabsetRef-${index}`\"\n :label=\"tab.label\"\n :panel-id=\"tab.panelId\"\n :tabindex=\"index + 1\"\n aria-controls=\"d-emoji-picker-list\"\n @keydown=\"handleKeyDown($event, tab.id)\"\n @click.capture.stop=\"selectTabset(tab.id)\"\n >\n <component\n :is=\"tab.icon\"\n size=\"400\"\n />\n </dt-tab>\n </template>\n </dt-tab-group>\n </div>\n</template>\n\n<script>\nimport { DtTab, DtTabGroup } from '@/components/tab';\nimport {\n DtIconClock,\n DtIconSatisfied,\n DtIconLivingThing,\n DtIconFood,\n DtIconObject,\n DtIconTransportation,\n DtIconLightbulb,\n DtIconHeart,\n DtIconFlag,\n DtIconTiktok,\n} from '@dialpad/dialtone-icons/vue2';\n\nexport default {\n name: 'EmojiTabset',\n\n components: {\n DtTabGroup,\n DtTab,\n },\n\n props: {\n /**\n * Whether to show the recently used tab or not\n * @type {Boolean}\n * @default false\n */\n showRecentlyUsedTab: {\n type: Boolean,\n default: false,\n },\n\n showCustomEmojisTab: {\n type: Boolean,\n default: false,\n },\n\n scrollIntoTab: {\n type: Number,\n required: true,\n },\n\n emojiFilter: {\n type: String,\n default: '',\n },\n\n /**\n * The labels for the aria-label\n * @type {Array}\n * @required\n */\n tabSetLabels: {\n type: Array,\n required: true,\n },\n },\n\n data () {\n return {\n selectedTab: '1',\n tabsetRef: [],\n TABS_DATA: [\n { label: this.tabSetLabels[0], icon: DtIconClock },\n { label: this.tabSetLabels[1], icon: DtIconSatisfied },\n { label: this.tabSetLabels[2], icon: DtIconLivingThing },\n { label: this.tabSetLabels[3], icon: DtIconFood },\n { label: this.tabSetLabels[4], icon: DtIconObject },\n { label: this.tabSetLabels[5], icon: DtIconTransportation },\n { label: this.tabSetLabels[6], icon: DtIconLightbulb },\n { label: this.tabSetLabels[7], icon: DtIconHeart },\n { label: this.tabSetLabels[8], icon: DtIconFlag },\n { label: this.tabSetLabels[9], icon: DtIconTiktok },\n ],\n };\n },\n\n computed: {\n tabs () {\n // if showRecentlyUsedTab is false remove first index of TABS_DATA\n const tabsData = this.showRecentlyUsedTab ? this.TABS_DATA : this.TABS_DATA.slice(1);\n // if showCustomEmojisTab is false remove last index of TABS_DATA\n if (!this.showCustomEmojisTab) {\n tabsData.pop();\n }\n\n return tabsData.map((tab, index) => ({\n ...tab,\n // IDs on dt-tab component need to be on string\n id: (index + 1).toString(),\n panelId: (index + 1).toString(),\n }));\n },\n\n isSearching () {\n return this.emojiFilter.length > 0;\n },\n },\n\n watch: {\n scrollIntoTab: function (newVal) {\n if (!this.isSearching) {\n this.selectedTab = (newVal + 1).toString();\n }\n },\n\n isSearching: function (newVal) {\n if (newVal) {\n this.selectedTab = null;\n }\n },\n },\n\n mounted () {\n this.$nextTick(() => {\n this.setTabsetRef();\n });\n },\n\n methods: {\n selectTabset (id) {\n // IDs on scrollToTab need to be on number\n const parseId = parseInt(id);\n // IDs on dt-tab component need to be on string\n this.selectedTab = id;\n this.$emit('selected-tabset', parseId);\n },\n\n setTabsetRef () {\n this.tabs.forEach((skin, index) => {\n const refKey = `tabsetRef-${index}`;\n if (this.$refs[refKey]) {\n this.$set(this.tabsetRef, index, this.$refs[refKey][0].$el);\n }\n });\n },\n\n focusTabset () {\n if (this.tabsetRef[0]) {\n this.tabsetRef[0].focus();\n }\n },\n\n // eslint-disable-next-line complexity\n handleKeyDown (event, tabId) {\n if (event.key === 'Enter') {\n this.selectTabset(tabId);\n if (this.tabsetRef[tabId - 1]) {\n this.tabsetRef[tabId - 1].blur();\n }\n }\n\n if (event.key === 'Tab') {\n event.preventDefault();\n if (event.shiftKey) {\n this.$emit('focus-skin-selector');\n } else {\n this.$emit('focus-search-input');\n }\n }\n\n if (event.key === 'ArrowDown') {\n this.$emit('focus-search-input');\n }\n },\n },\n};\n</script>\n","<template>\n <div class=\"d-emoji-picker__search d-emoji-picker__alignment\">\n <dt-input\n id=\"searchInput\"\n ref=\"searchInputRef\"\n :placeholder=\"searchPlaceholderLabel\"\n :value=\"modelValue\"\n @input=\"updateModelValue\"\n @keydown.up=\"focusTabset\"\n @keydown.down.prevent=\"focusEmojiSelector\"\n @keydown.enter=\"selectFirstEmoji\"\n >\n <template #leftIcon>\n <dt-icon-search\n size=\"200\"\n />\n </template>\n <template\n v-if=\"modelValue.length > 0\"\n #rightIcon\n >\n <dt-button\n importance=\"clear\"\n size=\"xs\"\n class=\"d-emoji-picker__search-x-button\"\n circle\n kind=\"muted\"\n @click=\"clearSearch\"\n >\n <template #icon>\n <dt-icon-close\n size=\"200\"\n />\n </template>\n </dt-button>\n </template>\n </dt-input>\n </div>\n</template>\n\n<script>\nimport { DtIconSearch, DtIconClose } from '@dialpad/dialtone-icons/vue2';\nimport { DtInput } from '@/components/input';\nimport { DtButton } from '@/components/button';\n\nexport default {\n name: 'EmojiSearch',\n\n components: {\n DtInput,\n DtIconSearch,\n DtIconClose,\n DtButton,\n },\n\n props: {\n searchPlaceholderLabel: {\n type: String,\n required: true,\n },\n\n modelValue: {\n type: String,\n default: '',\n },\n },\n\n mounted () {\n this.focusSearchInput();\n },\n\n methods: {\n updateModelValue (value) {\n this.$emit('update:model-value', value);\n },\n\n focusEmojiSelector () {\n this.$emit('focus-emoji-selector');\n },\n\n focusTabset () {\n this.$emit('focus-tabset');\n },\n\n selectFirstEmoji () {\n this.$emit('select-first-emoji');\n },\n\n clearSearch () {\n this.$emit('update:model-value', '');\n this.focusSearchInput();\n },\n\n focusSearchInput () {\n this.$refs.searchInputRef.focus();\n },\n },\n};\n</script>\n","<template>\n <div\n class=\"d-emoji-picker__selector\"\n >\n <div\n id=\"d-emoji-picker-list\"\n ref=\"listRef\"\n class=\"d-emoji-picker__list\"\n >\n <p\n v-if=\"emojiFilter\"\n class=\"d-emoji-picker__search-label d-emoji-picker__alignment\"\n >\n {{ filteredEmojis.length > 0 ? searchResultsLabel : searchNoResultsLabel }}\n </p>\n <div\n v-else\n ref=\"tabCategoryRef\"\n class=\"d-emoji-picker__category d-emoji-picker__alignment\"\n >\n <p>\n {{ fixedLabel }}\n </p>\n </div>\n <div\n v-for=\"(tabLabel, indexTab) in tabLabels\"\n v-show=\"!emojiFilter\"\n :key=\"indexTab\"\n :ref=\"`tabLabelRef-${indexTab}`\"\n class=\"d-emoji-picker__alignment\"\n >\n <p\n v-if=\"indexTab\"\n >\n {{ tabLabel.label }}\n </p>\n <div\n class=\"d-emoji-picker__tab\"\n >\n <button\n v-for=\"(emoji, indexEmoji) in\n (emojis[tabs[indexTab] + skinTone] ? emojis[tabs[indexTab] + skinTone] : emojis[tabs[indexTab]])\"\n :key=\"emoji.shortname\"\n :ref=\"`emojiRef-${indexTab}`\"\n type=\"button\"\n :aria-label=\"emoji.name\"\n @click=\"event => handleEmojiSelection(emoji, event)\"\n @focusin=\"$emit('highlighted-emoji', emoji)\"\n @focusout=\"$emit('highlighted-emoji', null)\"\n @mouseover=\"$emit('highlighted-emoji', emoji)\"\n @mouseleave=\"$emit('highlighted-emoji', null)\"\n @keydown=\"event => handleKeyDown(event, indexTab, indexEmoji, emoji)\"\n >\n <img\n class=\"d-icon d-icon--size-500\"\n :alt=\"emoji.name\"\n :aria-label=\"emoji.name\"\n :title=\"emoji.name\"\n :src=\"getImgSrc(emoji)\"\n @error=\"handleImageError\"\n >\n </button>\n </div>\n </div>\n <div\n v-if=\"emojiFilter\"\n class=\"d-emoji-picker__alignment\"\n >\n <div\n class=\"d-emoji-picker__tab \"\n data-qa=\"filtered-emojis\"\n >\n <button\n v-for=\"(emoji, index) in filteredEmojis\"\n :key=\"emoji.shortname\"\n :ref=\"`filteredEmoji-${index}`\"\n type=\"button\"\n :aria-label=\"emoji.name\"\n :class=\"{\n 'hover-emoji': (index === 0 && hoverFirstEmoji),\n }\"\n @click=\"event => handleEmojiSelection(emoji, event)\"\n @focusin=\"$emit('highlighted-emoji', emoji)\"\n @focusout=\"$emit('highlighted-emoji', null)\"\n @mouseover=\"hoverEmoji(emoji)\"\n @mouseleave=\"hoverEmoji(null)\"\n @keydown=\"event => handleKeyDownFilteredEmojis(event, index, emoji)\"\n >\n <img\n class=\"d-icon d-icon--size-500\"\n :alt=\"emoji.name\"\n :aria-label=\"emoji.name\"\n :title=\"emoji.name\"\n :src=\"`${CDN_URL + emoji.unicode_character}.png`\"\n >\n </button>\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script>\n/* eslint-disable max-len */\n/* eslint-disable max-lines */\nimport { emojisGrouped as emojisImported } from '@dialpad/dialtone-emojis';\nimport { CDN_URL, EMOJIS_PER_ROW } from '@/components/emoji_picker/emoji_picker_constants';\n\nexport default {\n name: 'EmojiSelector',\n\n props: {\n emojiFilter: {\n type: String,\n default: '',\n },\n\n skinTone: {\n type: String,\n required: true,\n },\n\n tabSetLabels: {\n type: Array,\n required: true,\n },\n\n selectedTabset: {\n type: Object,\n required: true,\n },\n\n searchResultsLabel: {\n type: String,\n required: true,\n },\n\n searchNoResultsLabel: {\n type: String,\n required: true,\n },\n\n recentlyUsedEmojis: {\n type: Array,\n default: () => [],\n },\n\n customEmojis: {\n type: Array,\n default: () => [],\n },\n },\n\n data () {\n return {\n tabLabelsRefs: [],\n emojiRefs: [],\n emojiFilteredRefs: [],\n isFiltering: false,\n hoverFirstEmoji: true,\n fixedLabel: '',\n filteredEmojis: [],\n TABS_DATA: ['Recently used', 'People', 'Nature', 'Food', 'Activity', 'Travel', 'Objects', 'Symbols', 'Flags', 'Custom'],\n tabLabelObserver: null,\n };\n },\n\n computed: {\n /* eslint-disable-next-line complexity */\n currentEmojis () {\n return [\n ...this.emojis[`People${this.skinTone}`] || [],\n ...this.emojis.Nature || [],\n ...this.emojis.Food || [],\n ...this.emojis[`Activity${this.skinTone}`] || [],\n ...this.emojis.Travel || [],\n ...this.emojis[`Objects${this.skinTone}`] || [],\n ...this.emojis.Symbols || [],\n ...this.emojis.Flags || [],\n ];\n },\n\n emojis () {\n return emojisImported;\n },\n\n CDN_URL () {\n return CDN_URL;\n },\n\n tabLabels () {\n let updateTabLabels = this.tabSetLabels.map((label) => ({ label }));\n\n if (!this.recentlyUsedEmojis.length) {\n updateTabLabels = this.tabSetLabels.slice(1).map((label) => ({ label }));\n }\n\n if (!this.customEmojis.length) {\n updateTabLabels.pop();\n }\n\n return updateTabLabels;\n },\n\n tabs () {\n const updateTabsOrder = this.recentlyUsedEmojis.length ? this.TABS_DATA.slice() : this.TABS_DATA.slice(1);\n\n if (!this.customEmojis.length) {\n updateTabsOrder.pop();\n }\n\n return updateTabsOrder;\n },\n },\n\n watch: {\n currentEmojis: {\n handler () {\n this.searchByNameAndKeywords();\n },\n\n immediate: true,\n },\n\n recentlyUsedEmojis: {\n handler (newValue) {\n this.emojis['Recently used'] = newValue;\n },\n\n immediate: true,\n },\n\n customEmojis: {\n handler (newValue) {\n this.emojis.Custom = newValue;\n },\n\n immediate: true,\n },\n\n emojiFilter: {\n handler (newFilter) {\n this.resetScroll();\n if (newFilter) {\n this.isFiltering = true;\n } else {\n this.isFiltering = false;\n this.$emit('highlighted-emoji', null);\n }\n\n this.debouncedSearch();\n },\n },\n\n selectedTabset: {\n handler (newValue) {\n this.scrollToTab(newValue.tabId);\n },\n\n deep: true,\n },\n },\n\n created () {\n this.debouncedSearch = this.debounce(this.searchByNameAndKeywords, 300);\n },\n\n mounted () {\n this.$nextTick(() => {\n this.setupEmojiRefs();\n this.setupFilteredRefs();\n this.setupTabLabelRefs();\n this.setTabLabelObserver();\n this.setBottomScrollListener();\n });\n },\n\n beforeDestroy () {\n if (this.tabLabelObserver) {\n this.tabLabelObserver.disconnect();\n }\n\n if (this.$refs.listRef && this.handleScroll) {\n this.$refs.listRef.removeEventListener('scroll', this.handleScroll);\n }\n },\n\n methods: {\n setupTabLabelRefs () {\n this.tabSetLabels?.forEach((_, index) => {\n const refKey = `tabLabelRef-${index}`;\n if (this.$refs[refKey]) {\n this.$set(this.tabLabelsRefs, index, { ref: this.$refs[refKey] });\n }\n });\n },\n\n setupFilteredRefs () {\n // it is necessary to clean the array before setting the new refs\n this.emojiFilteredRefs = [];\n\n this.filteredEmojis.forEach((emoji, index) => {\n const refKey = `filteredEmoji-${index}`;\n if (this.$refs[refKey]) {\n this.setFilteredRef(this.$refs[refKey], index);\n }\n });\n },\n\n setupEmojiRefs () {\n for (let i = 0; i < this.tabs.length; i++) {\n const refKey = `emojiRef-${i}`;\n if (this.$refs[refKey]) {\n this.$refs[refKey].forEach((el, indexEmoji) => {\n if (el) {\n this.setEmojiRef(el, i, indexEmoji);\n }\n });\n }\n }\n },\n\n searchByNameAndKeywords () {\n const searchStr = this.emojiFilter.toLowerCase();\n this.filteredEmojis = this.currentEmojis.filter(function (obj) {\n const nameIncludesSearchStr = obj.name.toLowerCase().includes(searchStr);\n const keywordsIncludeSearchStr = obj.keywords.some(function (keyword) {\n return keyword.toLowerCase().includes(searchStr);\n });\n return nameIncludesSearchStr || keywordsIncludeSearchStr;\n });\n this.$nextTick(function () {\n if (searchStr) {\n this.hoverEmoji(this.filteredEmojis[0], true);\n this.setupFilteredRefs();\n }\n });\n },\n\n debounce: function (fn, delay) {\n if (delay === undefined) { delay = 300; }\n let timeout;\n return function () {\n const args = []; let len = arguments.length;\n while (len--) args[len] = arguments[len];\n\n clearTimeout(timeout);\n timeout = setTimeout(function () {\n fn.apply(undefined, args);\n }, delay);\n };\n },\n\n getImgSrc: function (emoji) {\n // TODO Update json structure to have a property for custom emojis and avoid using date_added\n if (emoji.date_added) { // if custom emoji\n return emoji.image;\n } else { // if regular emoji\n return this.CDN_URL + emoji.unicode_character + '.png';\n }\n },\n\n handleImageError: function (event) {\n event.target.parentNode.style.display = 'none';\n },\n\n scrollToTab: function (tabIndex, focusFirstEmoji) {\n const vm = this;\n if (focusFirstEmoji === undefined) { focusFirstEmoji = true; }\n const tabElement = vm.tabLabelsRefs[tabIndex - 1].ref[0];\n\n vm.$nextTick(function () {\n const container = vm.$refs.listRef;\n const offsetTop = tabIndex === 1 ? 0 : tabElement.offsetTop - 15;\n\n container.scrollTop = offsetTop;\n\n if (focusFirstEmoji) {\n vm.focusEmoji(tabIndex - 1, 0);\n }\n });\n },\n\n resetScroll: function () {\n const container = this.$refs.listRef;\n container.scrollTop = 0;\n },\n\n focusEmojiSelector: function () {\n this.focusEmoji(0, 0);\n },\n\n hoverEmoji (emoji, isFirst) {\n if (isFirst === undefined) { isFirst = false; }\n this.hoverFirstEmoji = isFirst;\n this.$emit('highlighted-emoji', emoji);\n },\n\n setEmojiRef: function (el, indexTab, indexEmoji) {\n if (!this.emojiRefs[indexTab]) {\n this.$set(this.emojiRefs, indexTab, []);\n }\n this.$set(this.emojiRefs[indexTab], indexEmoji, el);\n },\n\n setFilteredRef: function (el, index) {\n this.$set(this.emojiFilteredRefs, index, el);\n },\n\n focusEmoji: function (indexTab, indexEmoji) {\n // eslint-disable-next-line max-len\n const emojiRef = this.isFiltering ? this.emojiFilteredRefs[indexEmoji]?.[0] : this.emojiRefs[indexTab] && this.emojiRefs[indexTab][indexEmoji];\n if (emojiRef) {\n emojiRef.focus();\n return true;\n }\n\n return false;\n },\n\n // eslint-disable-next-line complexity\n handleKeyDown: function (event, indexTab, indexEmoji, emoji) {\n event.preventDefault();\n\n if (event.key === 'ArrowUp') {\n const position = indexEmoji % EMOJIS_PER_ROW;\n\n if (indexTab === 0) {\n // we are on the first emoji tab, then we should jump to the last row of the last emoji tab\n const numberOfMissingEmojis =\n EMOJIS_PER_ROW - (this.emojiRefs[this.emojiRefs.length - 1].length % EMOJIS_PER_ROW);\n\n const emojiToJump =\n this.emojiRefs[this.emojiRefs.length - 1].length + numberOfMissingEmojis - (EMOJIS_PER_ROW - position);\n\n if (!this.focusEmoji(this.emojiRefs.length - 1, emojiToJump)) {\n // if there is no emoji in this position, jump to the last emoji of the row\n this.focusEmoji(this.emojiRefs.length - 1, this.emojiRefs[this.emojiRefs.length - 1].length - 1);\n }\n return;\n }\n\n // if we are not on the first tab, we should jump to the previous row of the current tab\n if (!this.focusEmoji(indexTab, indexEmoji - EMOJIS_PER_ROW)) {\n // if there is no previous row, we should jump to emoji in the sampe position of the previous tab\n const previousTab = indexTab - 1 < 0 ? 0 : indexTab - 1;\n const emojisInPreviousTab = this.emojiRefs[previousTab].length;\n const lastEmojiPosition = emojisInPreviousTab - (emojisInPreviousTab % EMOJIS_PER_ROW) + position;\n\n if (!this.focusEmoji(previousTab, lastEmojiPosition)) {\n // if there is no emoji in this position, jump to the last emoji of the row\n this.focusEmoji(indexTab - 1, this.emojiRefs[indexTab - 1].length - 1);\n }\n }\n }\n\n if (event.key === 'ArrowDown') {\n if (!this.focusEmoji(indexTab, indexEmoji + EMOJIS_PER_ROW)) {\n // if cannot go down\n\n // Calculate position from cell 0 to cell 8\n const position = indexEmoji % EMOJIS_PER_ROW;\n\n // check if it exists a next row in the current tab\n if (this.emojiRefs?.[indexTab]?.[indexEmoji + (EMOJIS_PER_ROW - position)]) {\n // if it exists, we should focus the last emoji of the next row in the current tab\n this.focusEmoji(indexTab, this.emojiRefs[indexTab].length - 1);\n // if we are at the end of the list it will do nothing\n } else {\n // We don't have next row, we are in the last of the tab, then jump\n // to the next tab but in the equal emoji position in row 0.\n\n if (!this.focusEmoji(indexTab + 1, position)) {\n // We are on the bottom!, should jump to the same position emoji in the first row of the first tabset\n // if it doesn't has, jump to the last\n if (!this.focusEmoji(0, position)) {\n this.focusEmoji(0, this.emojiRefs[0].length - 1);\n }\n }\n }\n }\n }\n\n if (event.key === 'ArrowLeft') {\n this.handleHorizontalNavigation('left', indexTab, indexEmoji);\n }\n\n if (event.key === 'ArrowRight') {\n this.handleHorizontalNavigation('right', indexTab, indexEmoji);\n }\n\n if (event.key === 'Tab' && !event.shiftKey) {\n if (this.focusEmoji(indexTab + 1, 0)) {\n this.scrollToTab((indexTab + 1) + 1, false);\n } else {\n // We are on the last emoji tabset, jump to the skin selector\n this.$emit('focus-skin-selector');\n }\n }\n\n if (event.key === 'Tab' && event.shiftKey) {\n if (this.focusEmoji(indexTab, 0) && indexTab > 0) {\n this.scrollToTab(indexTab, true);\n } else {\n this.scrollToTab(1, false);\n this.$emit('focus-search-input');\n }\n }\n\n if (event.key === 'Enter') {\n this.handleEmojiSelection(emoji, event);\n }\n },\n\n /* eslint-disable-next-line complexity */\n handleHorizontalNavigation: function (direction, indexTab, indexEmoji) {\n if (this.isFiltering) {\n if (direction === 'left') {\n this.handleArrowLeftFiltered(indexTab, indexEmoji);\n } else if (direction === 'right') {\n this.handleArrowRightFiltered(indexTab, indexEmoji);\n }\n } else {\n if (direction === 'left') {\n this.handleArrowLeft(indexTab, indexEmoji);\n } else if (direction === 'right') {\n this.handleArrowRight(indexTab, indexEmoji);\n }\n }\n },\n\n handleArrowLeftFiltered: function (indexTab, indexEmoji) {\n if (!this.focusEmoji(0, indexEmoji - 1)) {\n this.focusEmoji(0, this.emojiFilteredRefs.length - 1);\n }\n },\n\n handleArrowRightFiltered: function (indexTab, indexEmoji) {\n if (!this.focusEmoji(0, indexEmoji + 1)) {\n this.focusEmoji(0, 0);\n }\n },\n\n handleArrowLeft: function (indexTab, indexEmoji) {\n if (!this.focusEmoji(indexTab, indexEmoji - 1)) {\n if (this.emojiRefs[indexTab - 1]) {\n this.focusEmoji(indexTab - 1, this.emojiRefs[indexTab - 1].length - 1);\n } else {\n this.focusEmoji(this.emojiRefs.length - 1, this.emojiRefs[this.emojiRefs.length - 1].length - 1);\n }\n }\n },\n\n handleArrowRight: function (indexTab, indexEmoji) {\n if (!this.focusEmoji(indexTab, indexEmoji + 1)) {\n if (!this.focusEmoji(indexTab + 1, 0)) {\n this.focusEmoji(0, 0);\n }\n }\n },\n\n handleEmojiSelection (emoji, event) {\n this.$emit('selected-emoji', { ...emoji, shift_key: event.shiftKey });\n },\n\n // @TODO(improvement): Sync with simplified Vue 3 version\n /* eslint-disable-next-line complexity */\n handleKeyDownFilteredEmojis (event, indexEmoji, emoji) {\n event.preventDefault();\n this.hoverFirstEmoji = false;\n\n if (event.key === 'ArrowUp') {\n const position = indexEmoji % EMOJIS_PER_ROW;\n if (!this.focusEmoji(0, indexEmoji - EMOJIS_PER_ROW)) {\n const lastEmojiPosition =\n this.emojiFilteredRefs.length - (this.emojiFilteredRefs.length % EMOJIS_PER_ROW) + position;\n\n this.focusEmoji(0, lastEmojiPosition);\n\n if (!this.focusEmoji(0, lastEmojiPosition)) {\n this.focusEmoji(0, this.emojiFilteredRefs.length - 1);\n }\n }\n }\n\n if (event.key === 'ArrowDown') {\n if (!this.focusEmoji(0, indexEmoji + EMOJIS_PER_ROW)) {\n const position = indexEmoji % EMOJIS_PER_ROW;\n\n if (this.emojiFilteredRefs?.[indexEmoji + (EMOJIS_PER_ROW - position)]) {\n this.focusEmoji(0, this.emojiFilteredRefs.length - 1);\n } else {\n this.focusEmoji(0, position);\n }\n }\n }\n\n if (event.key === 'ArrowLeft') {\n this.handleHorizontalNavigation('left', 0, indexEmoji);\n }\n\n if (event.key === 'ArrowRight') {\n this.handleHorizontalNavigation('right', 0, indexEmoji);\n }\n\n if (event.key === 'Tab') {\n this.$emit('focus-skin-selector');\n }\n\n if (event.key === 'Enter') {\n this.handleEmojiSelection(emoji, event);\n }\n },\n\n setBottomScrollListener () {\n this.handleScroll = () => {\n const container = this.$refs.listRef;\n if (container.scrollTop + container.clientHeight >= container.scrollHeight) {\n this.$emit('scroll-bottom-reached');\n }\n };\n\n this.$refs.listRef.addEventListener('scroll', this.handleScroll);\n },\n\n setTabLabelObserver () {\n this.tabLabelObserver = new IntersectionObserver(entries => {\n /* eslint-disable-next-line complexity */\n entries.forEach(entry => {\n const { target } = entry;\n const index = parseInt(target.dataset.index);\n\n if (entry.isIntersecting && target.offsetTop <= this.$refs.tabCategoryRef?.offsetTop + 50) {\n this.fixedLabel = this.tabLabels[index - 1]?.label ?? this.tabLabels[0]?.label;\n this.$emit('scroll-into-tab', index - 1);\n } else if (entry.boundingClientRect.bottom <= this.$refs.tabCategoryRef?.getBoundingClientRect().bottom) {\n this.$emit('scroll-into-tab', index);\n this.fixedLabel = this.tabLabels[index]?.label;\n } else if (index === 1) {\n this.$emit('scroll-into-tab', index);\n this.fixedLabel = this.tabLabels[0]?.label;\n }\n });\n });\n\n this.tabLabelObserver.observe(this.$refs.tabCategoryRef);\n\n Array.from(this.$refs.listRef.children).forEach((child, index) => {\n this.tabLabelObserver.observe(child);\n child.dataset.index = index;\n });\n },\n\n focusLastEmoji () {\n this.scrollToTab(this.tabs.length, true);\n },\n\n },\n\n};\n</script>\n","<template>\n <div class=\"d-emoji-picker__data\">\n <img\n v-if=\"emoji\"\n class=\"d-icon d-icon--size-500\"\n :alt=\"emoji.name\"\n :aria-label=\"emoji.name\"\n :title=\"emoji.name\"\n :src=\"getImgSrc(emoji)\"\n >\n <div>{{ emoji?.name }}</div>\n </div>\n</template>\n\n<script>\nimport { CDN_URL } from '@/components/emoji_picker/emoji_picker_constants';\n\nexport default {\n name: 'EmojiDescription',\n\n props: {\n /**\n * Emoji data\n * @type {Object}\n * @default null\n */\n emoji: {\n type: Object,\n default: () => null,\n },\n },\n\n data () {\n return {\n CDN_URL,\n };\n },\n\n methods: {\n getImgSrc (emoji) {\n if (emoji.date_added) { // if custom emoji\n return emoji.image;\n } else { // if regular emoji\n return `${CDN_URL + emoji.unicode_character}.png`;\n }\n },\n },\n};\n</script>\n","<template>\n <div data-qa=\"skin-selector\">\n <div\n v-show=\"isOpen\"\n class=\"d-emoji-picker__skin-list\"\n >\n <button\n v-for=\"(skin, index) in skinList\"\n :key=\"skin.name\"\n :ref=\"`skinRef-${index}`\"\n :class=\"{\n 'selected': skinSelected?.skinCode === skin.skinCode,\n }\"\n @click=\"selectSkin(skin)\"\n @keydown=\"event => handleKeyDown(event, skin, index)\"\n >\n <img\n class=\"d-icon d-icon--size-500\"\n :alt=\"skin.name\"\n :aria-label=\"skin.name\"\n :title=\"skin.name\"\n :src=\"`${cdnUrl + skin.unicode_output}.png`\"\n >\n </button>\n </div>\n <div\n v-show=\"!isOpen\"\n class=\"d-emoji-picker__skin-selected\"\n >\n <dt-tooltip placement=\"top-end\">\n {{ skinSelectorButtonTooltipLabel }}\n <template #anchor>\n <button\n ref=\"skinSelectorRef\"\n :aria-label=\"skinSelectorButtonTooltipLabel\"\n tabindex=\"-1\"\n @click=\"toggleSkinList\"\n @keydown=\"event => handleKeyDown(event)\"\n >\n <img\n class=\"d-icon d-icon--size-500\"\n :alt=\"skinSelected?.name\"\n :aria-label=\"skinSelected?.name\"\n :title=\"skinSelected?.name\"\n :src=\"`${cdnUrl + skinSelected?.unicode_output}.png`\"\n >\n </button>\n </template>\n </dt-tooltip>\n </div>\n </div>\n</template>\n\n<script>\nimport DtTooltip from '@/components/tooltip/tooltip.vue';\nimport { CDN_URL, EMOJI_PICKER_SKIN_TONE_MODIFIERS } from '@/components/emoji_picker/emoji_picker_constants';\n\nexport default {\n name: 'EmojiSkinSelector',\n\n components: {\n DtTooltip,\n },\n\n props: {\n skinTone: {\n type: String,\n required: true,\n },\n\n isHovering: {\n type: Boolean,\n default: false,\n },\n\n skinSelectorButtonTooltipLabel: {\n type: String,\n required: true,\n },\n },\n\n data () {\n return {\n isOpen: false,\n skinSelected: null,\n skinsRef: [],\n cdnUrl: CDN_URL,\n };\n },\n\n computed: {\n skinPassedIn () {\n return this.skinList.find(skin => skin.skinTone === this.skinTone);\n },\n\n skinList () {\n return [\n {\n name: ':wave_tone1:',\n unicode_output: '1f44b-1f3fb',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.LIGHT,\n skinCode: '_tone1',\n },\n {\n name: ':wave_tone2:',\n unicode_output: '1f44b-1f3fc',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM_LIGHT,\n skinCode: '_tone2',\n },\n {\n name: ':wave_tone3:',\n unicode_output: '1f44b-1f3fd',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM,\n skinCode: '_tone3',\n },\n {\n name: ':wave_tone4:',\n unicode_output: '1f44b-1f3fe',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM_DARK,\n skinCode: '_tone4',\n },\n {\n name: ':wave_tone5:',\n unicode_output: '1f44b-1f3ff',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.DARK,\n skinCode: '_tone5',\n },\n {\n name: ':wave:',\n unicode_output: '1f44b',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.DEFAULT,\n skinCode: '',\n },\n ];\n },\n },\n\n watch: {\n isHovering (newVal) {\n if (newVal) {\n this.isOpen = false;\n }\n },\n\n skinTone (newVal, oldVal) {\n if (newVal !== oldVal) {\n this.skinSelected = this.skinPassedIn;\n }\n },\n },\n\n mounted () {\n this.skinSelected = this.skinPassedIn;\n this.$nextTick(() => {\n this.setupSkinRefs();\n });\n },\n\n methods: {\n setupSkinRefs () {\n this.skinList.forEach((skin, index) => {\n const refKey = `skinRef-${index}`;\n if (this.$refs[refKey]) {\n this.$set(this.skinsRef, index, this.$refs[refKey][0]);\n }\n });\n },\n\n focusSkinSelector () {\n if (this.$refs.skinSelectorRef) {\n this.$refs.skinSelectorRef.focus();\n }\n },\n\n selectSkin (skin) {\n this.skinSelected = skin;\n this.isOpen = false;\n this.$emit('skin-tone', skin.skinTone);\n this.$nextTick(() => {\n this.focusSkinSelector();\n });\n },\n\n handleKeyDown (event, skin, index) {\n event.preventDefault();\n\n if (event.key === 'ArrowLeft') {\n if (index === 0) this.skinsRef[this.skinsRef.length - 1]?.focus();\n this.skinsRef[index - 1]?.focus();\n }\n\n if (event.key === 'ArrowRight') {\n if (this.skinsRef.length) this.skinsRef[0]?.focus();\n this.skinsRef[index + 1]?.focus();\n }\n\n if (event.key === 'Enter') {\n if (skin) { this.selectSkin(skin); } else {\n this.toggleSkinList();\n }\n }\n\n if (event.key === 'Tab') {\n if (event.shiftKey) {\n this.$emit('focus-last-emoji');\n } else {\n this.$emit('focus-tabset');\n }\n }\n },\n\n toggleSkinList () {\n this.isOpen = !this.isOpen;\n this.$nextTick(() => {\n if (this.skinsRef[0]) {\n this.skinsRef[0].focus();\n }\n });\n },\n },\n};\n</script>\n","<template>\n <div\n class=\"d-emoji-picker\"\n >\n <div class=\"d-emoji-picker--header\">\n <emoji-tabset\n ref=\"tabsetRef\"\n :emoji-filter=\"internalSearchQuery\"\n :show-custom-emojis-tab=\"showCustomEmojisTab\"\n :show-recently-used-tab=\"showRecentlyUsedTab\"\n :scroll-into-tab=\"scrollIntoTab\"\n :tab-set-labels=\"tabSetLabels\"\n @focus-skin-selector=\"$refs.skinSelectorRef.focusSkinSelector()\"\n @focus-search-input=\"showSearch\n ? $refs.searchInputRef.focusSearchInput()\n : $refs.emojiSelectorRef.focusEmojiSelector()\"\n @selected-tabset=\"scrollToSelectedTabset\"\n @keydown.esc.native=\"$emit('close')\"\n />\n </div>\n <div class=\"d-emoji-picker--body\">\n <emoji-search\n v-if=\"showSearch\"\n ref=\"searchInputRef\"\n :model-value=\"internalSearchQuery\"\n :search-placeholder-label=\"searchPlaceholderLabel\"\n @update:model-value=\"newValue => internalSearchQuery = newValue\"\n @select-first-emoji=\"$emit('selected-emoji', highlightedEmoji)\"\n @focus-tabset=\"$refs.tabsetRef.focusTabset()\"\n @focus-emoji-selector=\"$refs.emojiSelectorRef.focusEmojiSelector()\"\n @keydown.esc.native=\"$emit('close')\"\n />\n <emoji-selector\n ref=\"emojiSelectorRef\"\n :emoji-filter=\"internalSearchQuery\"\n :skin-tone=\"skinTone\"\n :tab-set-labels=\"tabSetLabels\"\n :search-results-label=\"searchResultsLabel\"\n :search-no-results-label=\"searchNoResultsLabel\"\n :recently-used-emojis=\"recentlyUsedEmojis\"\n :custom-emojis=\"customEmojis\"\n :selected-tabset=\"selectedTabset\"\n @scroll-into-tab=\"updateScrollIntoTab\"\n @highlighted-emoji=\"updateHighlightedEmoji\"\n @selected-emoji=\"$emit('selected-emoji', $event)\"\n @focus-skin-selector=\"$refs.skinSelectorRef.focusSkinSelector()\"\n @focus-search-input=\"showSearch ? $refs.searchInputRef.focusSearchInput() : $refs.tabsetRef.focusTabset()\"\n @keydown.esc.native=\"$emit('close')\"\n @scroll-bottom-reached=\"$emit('scroll-bottom-reached')\"\n />\n </div>\n <div class=\"d-emoji-picker--footer\">\n <dt-button\n v-if=\"showCustomEmojisTab && !highlightedEmoji\"\n importance=\"outlined\"\n :aria-label=\"addEmojiLabel\"\n class=\"d-emoji-picker__add-emoji\"\n @click=\"$emit('add-emoji')\"\n >\n {{ addEmojiLabel }}\n </dt-button>\n <emoji-description :emoji=\"highlightedEmoji\" />\n <emoji-skin-selector\n ref=\"skinSelectorRef\"\n :is-hovering=\"!!highlightedEmoji\"\n :skin-selector-button-tooltip-label=\"skinSelectorButtonTooltipLabel\"\n :skin-tone=\"skinTone\"\n @skin-tone=\"$emit('skin-tone', $event)\"\n @focus-tabset=\"$refs.tabsetRef.focusTabset()\"\n @focus-last-emoji=\"$refs.emojiSelectorRef.focusLastEmoji()\"\n @keydown.esc.native=\"$emit('close')\"\n />\n </div>\n </div>\n</template>\n\n<script>\nimport EmojiTabset from './modules/emoji_tabset.vue';\nimport EmojiSearch from './modules/emoji_search.vue';\nimport EmojiSelector from './modules/emoji_selector.vue';\nimport EmojiDescription from './modules/emoji_description.vue';\nimport EmojiSkinSelector from './modules/emoji_skin_selector.vue';\nimport { DtButton } from '../button';\nimport { DialtoneLocalization } from '@/localization';\n\nexport default {\n name: 'DtEmojiPicker',\n\n components: {\n EmojiTabset,\n EmojiSearch,\n EmojiSelector,\n EmojiDescription,\n EmojiSkinSelector,\n DtButton,\n },\n\n props: {\n /**\n * The array with recently used emoji object\n * This list is necessary to fill the recently used tab\n * @type {Array}\n * @default []\n * @example\n * <dt-emoji-picker :recentlyUsedEmojis=\"[emojiObject, emojiObject]\" />\n */\n // TODO try to simplify this to achieve an array of unicode characters and not an entire emoji data object\n recentlyUsedEmojis: {\n type: Array,\n default: () => [],\n },\n\n /**\n * The array with custom emojis object\n * This list is necessary to fill the custom tab\n * @type {Array}\n * @default []\n * @example\n * <dt-emoji-picker :customEmojis=\"[emojiObject, emojiObject]\" />\n */\n customEmojis: {\n type: Array,\n },\n\n /**\n * The skin tone to show the emojis\n * This prop gives the possibility to use the skin tone selected by the user previously\n * @type {String}\n * @default 'Default'\n * @values 'Default', 'Light', 'MediumLight', 'Medium', 'MediumDark', 'Dark'\n * @example\n * <dt-emoji-picker :skinTone=\"'Default'\" />\n */\n skinTone: {\n type: String,\n default: 'Default',\n },\n\n /**\n * Sets the search query that filters emojis.\n * @type {String}\n * @example\n * <dt-emoji-picker search-query=\"smile\" />\n */\n searchQuery: {\n type: String,\n default: '',\n },\n\n /**\n * Shows the search input\n * @type {Boolean}\n * @example\n * <dt-emoji-picker :show-search=\"false\" />\n */\n showSearch: {\n type: Boolean,\n default: true,\n },\n },\n\n data () {\n return {\n internalSearchQuery: this.searchQuery,\n highlightedEmoji: null,\n selectedTabset: {},\n scrollIntoTab: 0,\n i18n: new DialtoneLocalization(),\n };\n },\n\n computed: {\n showCustomEmojisTab () {\n return this.customEmojis?.length > 0;\n },\n\n showRecentlyUsedTab () {\n return this.recentlyUsedEmojis?.length > 0;\n },\n\n tabSetLabels () {\n return [\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_RECENTLY_USED_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_SMILEYS_AND_PEOPLE_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_NATURE_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_FOOD_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_ACTIVITY_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_TRAVEL_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_OBJECTS_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_SYMBOLS_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_FLAGS_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_CUSTOM_LABEL'),\n ];\n },\n\n searchPlaceholderLabel () {\n return this.i18n.$t('DIALTONE_EMOJI_PICKER_SEARCH_PLACEHOLDER_LABEL');\n },\n\n searchResultsLabel () {\n return this.i18n.$t('DIALTONE_EMOJI_PICKER_SEARCH_RESULTS_LABEL');\n },\n\n searchNoResultsLabel () {\n return this.i18n.$t('DIALTONE_EMOJI_PICKER_SEARCH_NO_RESULTS_LABEL');\n },\n\n skinSelectorButtonTooltipLabel () {\n return this.i18n.$t('DIALTONE_EMOJI_PICKER_SKIN_SELECTOR_BUTTON_TOOLTIP_LABEL');\n },\n\n addEmojiLabel () {\n return this.i18n.$t('DIALTONE_EMOJI_PICKER_ADD_EMOJI_LABEL');\n },\n },\n\n watch: {\n searchQuery (value) {\n this.internalSearchQuery = value;\n },\n },\n\n methods: {\n scrollToSelectedTabset (tabId) {\n this.internalSearchQuery = '';\n this.selectedTabset = { ...this.selectedTabset, tabId };\n },\n\n updateScrollIntoTab (value) {\n this.scrollIntoTab = value;\n },\n\n updateHighlightedEmoji (emoji) {\n this.highlightedEmoji = emoji;\n },\n },\n};\n</script>\n"],"names":["_sfc_main","DtTabGroup","DtTab","DtIconClock","DtIconSatisfied","DtIconLivingThing","DtIconFood","DtIconObject","DtIconTransportation","DtIconLightbulb","DtIconHeart","DtIconFlag","DtIconTiktok","tabsData","tab","index","newVal","id","parseId","skin","refKey","event","tabId","DtInput","DtIconSearch","DtIconClose","DtButton","value","emojisImported","CDN_URL","updateTabLabels","label","updateTabsOrder","newValue","newFilter","_a","_","emoji","i","el","indexEmoji","searchStr","obj","nameIncludesSearchStr","keywordsIncludeSearchStr","keyword","fn","delay","timeout","args","len","tabIndex","focusFirstEmoji","vm","tabElement","container","offsetTop","isFirst","indexTab","emojiRef","position","EMOJIS_PER_ROW","numberOfMissingEmojis","emojiToJump","previousTab","emojisInPreviousTab","lastEmojiPosition","_b","direction","entries","entry","target","_c","_d","_e","_f","child","DtTooltip","EMOJI_PICKER_SKIN_TONE_MODIFIERS","oldVal","EmojiTabset","EmojiSearch","EmojiSelector","EmojiDescription","EmojiSkinSelector","DialtoneLocalization"],"mappings":"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"}
1
+ {"version":3,"file":"emoji-picker.js","sources":["../../../components/emoji_picker/modules/emoji_tabset.vue","../../../components/emoji_picker/modules/emoji_search.vue","../../../components/emoji_picker/modules/emoji_selector.vue","../../../components/emoji_picker/modules/emoji_description.vue","../../../components/emoji_picker/modules/emoji_skin_selector.vue","../../../components/emoji_picker/emoji_picker.vue"],"sourcesContent":["<template>\n <div class=\"d-emoji-picker__tabset\">\n <dt-tab-group\n :selected=\"selectedTab\"\n size=\"sm\"\n tab-list-class=\"d-emoji-picker__tabset-list\"\n >\n <template #tabs>\n <dt-tab\n v-for=\"(tab, index) in tabs\"\n :id=\"tab.id\"\n :key=\"tab.id\"\n :ref=\"`tabsetRef-${index}`\"\n :label=\"tab.label\"\n :panel-id=\"tab.panelId\"\n :tabindex=\"index + 1\"\n aria-controls=\"d-emoji-picker-list\"\n @keydown=\"handleKeyDown($event, tab.id)\"\n @click.capture.stop=\"selectTabset(tab.id)\"\n >\n <component\n :is=\"tab.icon\"\n size=\"400\"\n />\n </dt-tab>\n </template>\n </dt-tab-group>\n </div>\n</template>\n\n<script>\nimport { DtTab, DtTabGroup } from '@/components/tab';\nimport {\n DtIconClock,\n DtIconSatisfied,\n DtIconLivingThing,\n DtIconFood,\n DtIconObject,\n DtIconTransportation,\n DtIconLightbulb,\n DtIconHeart,\n DtIconFlag,\n DtIconTiktok,\n} from '@dialpad/dialtone-icons/vue2';\n\nexport default {\n name: 'EmojiTabset',\n\n components: {\n DtTabGroup,\n DtTab,\n },\n\n props: {\n /**\n * Whether to show the recently used tab or not\n * @type {Boolean}\n * @default false\n */\n showRecentlyUsedTab: {\n type: Boolean,\n default: false,\n },\n\n showCustomEmojisTab: {\n type: Boolean,\n default: false,\n },\n\n scrollIntoTab: {\n type: Number,\n required: true,\n },\n\n emojiFilter: {\n type: String,\n default: '',\n },\n\n /**\n * The labels for the aria-label\n * @type {Array}\n * @required\n */\n tabSetLabels: {\n type: Array,\n required: true,\n },\n },\n\n data () {\n return {\n selectedTab: '1',\n tabsetRef: [],\n TABS_DATA: [\n { label: this.tabSetLabels[0], icon: DtIconClock },\n { label: this.tabSetLabels[1], icon: DtIconSatisfied },\n { label: this.tabSetLabels[2], icon: DtIconLivingThing },\n { label: this.tabSetLabels[3], icon: DtIconFood },\n { label: this.tabSetLabels[4], icon: DtIconObject },\n { label: this.tabSetLabels[5], icon: DtIconTransportation },\n { label: this.tabSetLabels[6], icon: DtIconLightbulb },\n { label: this.tabSetLabels[7], icon: DtIconHeart },\n { label: this.tabSetLabels[8], icon: DtIconFlag },\n { label: this.tabSetLabels[9], icon: DtIconTiktok },\n ],\n };\n },\n\n computed: {\n tabs () {\n // if showRecentlyUsedTab is false remove first index of TABS_DATA\n const tabsData = this.showRecentlyUsedTab ? this.TABS_DATA : this.TABS_DATA.slice(1);\n // if showCustomEmojisTab is false remove last index of TABS_DATA\n if (!this.showCustomEmojisTab) {\n tabsData.pop();\n }\n\n return tabsData.map((tab, index) => ({\n ...tab,\n // IDs on dt-tab component need to be on string\n id: (index + 1).toString(),\n panelId: (index + 1).toString(),\n }));\n },\n\n isSearching () {\n return this.emojiFilter.length > 0;\n },\n },\n\n watch: {\n scrollIntoTab: function (newVal) {\n if (!this.isSearching) {\n this.selectedTab = (newVal + 1).toString();\n }\n },\n\n isSearching: function (newVal) {\n if (newVal) {\n this.selectedTab = null;\n }\n },\n },\n\n mounted () {\n this.$nextTick(() => {\n this.setTabsetRef();\n });\n },\n\n methods: {\n selectTabset (id) {\n // IDs on scrollToTab need to be on number\n const parseId = parseInt(id);\n // IDs on dt-tab component need to be on string\n this.selectedTab = id;\n this.$emit('selected-tabset', parseId);\n },\n\n setTabsetRef () {\n this.tabs.forEach((skin, index) => {\n const refKey = `tabsetRef-${index}`;\n if (this.$refs[refKey]) {\n this.$set(this.tabsetRef, index, this.$refs[refKey][0].$el);\n }\n });\n },\n\n focusTabset () {\n if (this.tabsetRef[0]) {\n this.tabsetRef[0].focus();\n }\n },\n\n // eslint-disable-next-line complexity\n handleKeyDown (event, tabId) {\n if (event.key === 'Enter') {\n this.selectTabset(tabId);\n if (this.tabsetRef[tabId - 1]) {\n this.tabsetRef[tabId - 1].blur();\n }\n }\n\n if (event.key === 'Tab') {\n event.preventDefault();\n if (event.shiftKey) {\n this.$emit('focus-skin-selector');\n } else {\n this.$emit('focus-search-input');\n }\n }\n\n if (event.key === 'ArrowDown') {\n this.$emit('focus-search-input');\n }\n },\n },\n};\n</script>\n","<template>\n <div class=\"d-emoji-picker__search d-emoji-picker__alignment\">\n <dt-input\n id=\"searchInput\"\n ref=\"searchInputRef\"\n :placeholder=\"searchPlaceholderLabel\"\n :value=\"modelValue\"\n @input=\"updateModelValue\"\n @keydown.up=\"focusTabset\"\n @keydown.down.prevent=\"focusEmojiSelector\"\n @keydown.enter=\"selectFirstEmoji\"\n >\n <template #leftIcon>\n <dt-icon-search\n size=\"200\"\n />\n </template>\n <template\n v-if=\"modelValue.length > 0\"\n #rightIcon\n >\n <dt-button\n importance=\"clear\"\n size=\"xs\"\n class=\"d-emoji-picker__search-x-button\"\n circle\n kind=\"muted\"\n @click=\"clearSearch\"\n >\n <template #icon>\n <dt-icon-close\n size=\"200\"\n />\n </template>\n </dt-button>\n </template>\n </dt-input>\n </div>\n</template>\n\n<script>\nimport { DtIconSearch, DtIconClose } from '@dialpad/dialtone-icons/vue2';\nimport { DtInput } from '@/components/input';\nimport { DtButton } from '@/components/button';\n\nexport default {\n name: 'EmojiSearch',\n\n components: {\n DtInput,\n DtIconSearch,\n DtIconClose,\n DtButton,\n },\n\n props: {\n searchPlaceholderLabel: {\n type: String,\n required: true,\n },\n\n modelValue: {\n type: String,\n default: '',\n },\n },\n\n mounted () {\n this.focusSearchInput();\n },\n\n methods: {\n updateModelValue (value) {\n this.$emit('update:model-value', value);\n },\n\n focusEmojiSelector () {\n this.$emit('focus-emoji-selector');\n },\n\n focusTabset () {\n this.$emit('focus-tabset');\n },\n\n selectFirstEmoji () {\n this.$emit('select-first-emoji');\n },\n\n clearSearch () {\n this.$emit('update:model-value', '');\n this.focusSearchInput();\n },\n\n focusSearchInput () {\n this.$refs.searchInputRef.focus();\n },\n },\n};\n</script>\n","<template>\n <div\n class=\"d-emoji-picker__selector\"\n >\n <div\n id=\"d-emoji-picker-list\"\n ref=\"listRef\"\n class=\"d-emoji-picker__list\"\n >\n <p\n v-if=\"emojiFilter\"\n class=\"d-emoji-picker__search-label d-emoji-picker__alignment\"\n >\n {{ filteredEmojis.length > 0 ? searchResultsLabel : searchNoResultsLabel }}\n </p>\n <div\n v-else\n ref=\"tabCategoryRef\"\n class=\"d-emoji-picker__category d-emoji-picker__alignment\"\n >\n <p>\n {{ fixedLabel }}\n </p>\n </div>\n <div\n v-for=\"(tabLabel, indexTab) in tabLabels\"\n v-show=\"!emojiFilter\"\n :key=\"indexTab\"\n :ref=\"`tabLabelRef-${indexTab}`\"\n class=\"d-emoji-picker__alignment\"\n >\n <p\n v-if=\"indexTab\"\n >\n {{ tabLabel.label }}\n </p>\n <div\n class=\"d-emoji-picker__tab\"\n >\n <button\n v-for=\"(emoji, indexEmoji) in\n (emojis[tabs[indexTab] + skinTone] ? emojis[tabs[indexTab] + skinTone] : emojis[tabs[indexTab]])\"\n :key=\"emoji.shortname\"\n :ref=\"`emojiRef-${indexTab}`\"\n type=\"button\"\n :aria-label=\"emoji.name\"\n @click=\"event => handleEmojiSelection(emoji, event)\"\n @focusin=\"$emit('highlighted-emoji', emoji)\"\n @focusout=\"$emit('highlighted-emoji', null)\"\n @mouseover=\"$emit('highlighted-emoji', emoji)\"\n @mouseleave=\"$emit('highlighted-emoji', null)\"\n @keydown=\"event => handleKeyDown(event, indexTab, indexEmoji, emoji)\"\n >\n <img\n class=\"d-icon d-icon--size-500\"\n :alt=\"emoji.name\"\n :aria-label=\"emoji.name\"\n :title=\"emoji.name\"\n :src=\"getImgSrc(emoji)\"\n @error=\"handleImageError\"\n >\n </button>\n </div>\n </div>\n <div\n v-if=\"emojiFilter\"\n class=\"d-emoji-picker__alignment\"\n >\n <div\n class=\"d-emoji-picker__tab \"\n data-qa=\"filtered-emojis\"\n >\n <button\n v-for=\"(emoji, index) in filteredEmojis\"\n :key=\"emoji.shortname\"\n :ref=\"`filteredEmoji-${index}`\"\n type=\"button\"\n :aria-label=\"emoji.name\"\n :class=\"{\n 'hover-emoji': (index === 0 && hoverFirstEmoji),\n }\"\n @click=\"event => handleEmojiSelection(emoji, event)\"\n @focusin=\"$emit('highlighted-emoji', emoji)\"\n @focusout=\"$emit('highlighted-emoji', null)\"\n @mouseover=\"hoverEmoji(emoji)\"\n @mouseleave=\"hoverEmoji(null)\"\n @keydown=\"event => handleKeyDownFilteredEmojis(event, index, emoji)\"\n >\n <img\n class=\"d-icon d-icon--size-500\"\n :alt=\"emoji.name\"\n :aria-label=\"emoji.name\"\n :title=\"emoji.name\"\n :src=\"`${CDN_URL + emoji.unicode_character}.png`\"\n >\n </button>\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script>\n/* eslint-disable max-len */\n/* eslint-disable max-lines */\nimport { emojisGrouped as emojisImported } from '@dialpad/dialtone-emojis';\nimport { CDN_URL, EMOJIS_PER_ROW } from '@/components/emoji_picker/emoji_picker_constants';\n\nexport default {\n name: 'EmojiSelector',\n\n props: {\n emojiFilter: {\n type: String,\n default: '',\n },\n\n skinTone: {\n type: String,\n required: true,\n },\n\n tabSetLabels: {\n type: Array,\n required: true,\n },\n\n selectedTabset: {\n type: Object,\n required: true,\n },\n\n searchResultsLabel: {\n type: String,\n required: true,\n },\n\n searchNoResultsLabel: {\n type: String,\n required: true,\n },\n\n recentlyUsedEmojis: {\n type: Array,\n default: () => [],\n },\n\n customEmojis: {\n type: Array,\n default: () => [],\n },\n },\n\n data () {\n return {\n tabLabelsRefs: [],\n emojiRefs: [],\n emojiFilteredRefs: [],\n isFiltering: false,\n hoverFirstEmoji: true,\n fixedLabel: '',\n filteredEmojis: [],\n TABS_DATA: ['Recently used', 'People', 'Nature', 'Food', 'Activity', 'Travel', 'Objects', 'Symbols', 'Flags', 'Custom'],\n tabLabelObserver: null,\n };\n },\n\n computed: {\n /* eslint-disable-next-line complexity */\n currentEmojis () {\n return [\n ...this.emojis[`People${this.skinTone}`] || [],\n ...this.emojis.Nature || [],\n ...this.emojis.Food || [],\n ...this.emojis[`Activity${this.skinTone}`] || [],\n ...this.emojis.Travel || [],\n ...this.emojis[`Objects${this.skinTone}`] || [],\n ...this.emojis.Symbols || [],\n ...this.emojis.Flags || [],\n ];\n },\n\n emojis () {\n return emojisImported;\n },\n\n CDN_URL () {\n return CDN_URL;\n },\n\n tabLabels () {\n let updateTabLabels = this.tabSetLabels.map((label) => ({ label }));\n\n if (!this.recentlyUsedEmojis.length) {\n updateTabLabels = this.tabSetLabels.slice(1).map((label) => ({ label }));\n }\n\n if (!this.customEmojis.length) {\n updateTabLabels.pop();\n }\n\n return updateTabLabels;\n },\n\n tabs () {\n const updateTabsOrder = this.recentlyUsedEmojis.length ? this.TABS_DATA.slice() : this.TABS_DATA.slice(1);\n\n if (!this.customEmojis.length) {\n updateTabsOrder.pop();\n }\n\n return updateTabsOrder;\n },\n },\n\n watch: {\n currentEmojis: {\n handler () {\n this.searchByNameAndKeywords();\n },\n\n immediate: true,\n },\n\n recentlyUsedEmojis: {\n handler (newValue) {\n this.emojis['Recently used'] = newValue;\n },\n\n immediate: true,\n },\n\n customEmojis: {\n handler (newValue) {\n this.emojis.Custom = newValue;\n },\n\n immediate: true,\n },\n\n emojiFilter: {\n handler (newFilter) {\n this.resetScroll();\n if (newFilter) {\n this.isFiltering = true;\n } else {\n this.isFiltering = false;\n this.$emit('highlighted-emoji', null);\n }\n\n this.debouncedSearch();\n },\n },\n\n selectedTabset: {\n handler (newValue) {\n this.scrollToTab(newValue.tabId);\n },\n\n deep: true,\n },\n },\n\n created () {\n this.debouncedSearch = this.debounce(this.searchByNameAndKeywords, 300);\n },\n\n mounted () {\n this.$nextTick(() => {\n this.setupEmojiRefs();\n this.setupFilteredRefs();\n this.setupTabLabelRefs();\n this.setTabLabelObserver();\n this.setBottomScrollListener();\n });\n },\n\n beforeDestroy () {\n if (this.tabLabelObserver) {\n this.tabLabelObserver.disconnect();\n }\n\n if (this.$refs.listRef && this.handleScroll) {\n this.$refs.listRef.removeEventListener('scroll', this.handleScroll);\n }\n },\n\n methods: {\n setupTabLabelRefs () {\n this.tabSetLabels?.forEach((_, index) => {\n const refKey = `tabLabelRef-${index}`;\n if (this.$refs[refKey]) {\n this.$set(this.tabLabelsRefs, index, { ref: this.$refs[refKey] });\n }\n });\n },\n\n setupFilteredRefs () {\n // it is necessary to clean the array before setting the new refs\n this.emojiFilteredRefs = [];\n\n this.filteredEmojis.forEach((emoji, index) => {\n const refKey = `filteredEmoji-${index}`;\n if (this.$refs[refKey]) {\n this.setFilteredRef(this.$refs[refKey], index);\n }\n });\n },\n\n setupEmojiRefs () {\n for (let i = 0; i < this.tabs.length; i++) {\n const refKey = `emojiRef-${i}`;\n if (this.$refs[refKey]) {\n this.$refs[refKey].forEach((el, indexEmoji) => {\n if (el) {\n this.setEmojiRef(el, i, indexEmoji);\n }\n });\n }\n }\n },\n\n searchByNameAndKeywords () {\n const searchStr = this.emojiFilter.toLowerCase();\n this.filteredEmojis = this.currentEmojis.filter(function (obj) {\n const nameIncludesSearchStr = obj.name.toLowerCase().includes(searchStr);\n const keywordsIncludeSearchStr = obj.keywords.some(function (keyword) {\n return keyword.toLowerCase().includes(searchStr);\n });\n return nameIncludesSearchStr || keywordsIncludeSearchStr;\n });\n this.$nextTick(function () {\n if (searchStr) {\n this.hoverEmoji(this.filteredEmojis[0], true);\n this.setupFilteredRefs();\n }\n });\n },\n\n debounce: function (fn, delay) {\n if (delay === undefined) { delay = 300; }\n let timeout;\n return function () {\n const args = []; let len = arguments.length;\n while (len--) args[len] = arguments[len];\n\n clearTimeout(timeout);\n timeout = setTimeout(function () {\n fn.apply(undefined, args);\n }, delay);\n };\n },\n\n getImgSrc: function (emoji) {\n // TODO Update json structure to have a property for custom emojis and avoid using date_added\n if (emoji.date_added) { // if custom emoji\n return emoji.image;\n } else { // if regular emoji\n return this.CDN_URL + emoji.unicode_character + '.png';\n }\n },\n\n handleImageError: function (event) {\n event.target.parentNode.style.display = 'none';\n },\n\n scrollToTab: function (tabIndex, focusFirstEmoji) {\n const vm = this;\n if (focusFirstEmoji === undefined) { focusFirstEmoji = true; }\n const tabElement = vm.tabLabelsRefs[tabIndex - 1].ref[0];\n\n vm.$nextTick(function () {\n const container = vm.$refs.listRef;\n const offsetTop = tabIndex === 1 ? 0 : tabElement.offsetTop - 15;\n\n container.scrollTop = offsetTop;\n\n if (focusFirstEmoji) {\n vm.focusEmoji(tabIndex - 1, 0);\n }\n });\n },\n\n resetScroll: function () {\n const container = this.$refs.listRef;\n container.scrollTop = 0;\n },\n\n focusEmojiSelector: function () {\n this.focusEmoji(0, 0);\n },\n\n hoverEmoji (emoji, isFirst) {\n if (isFirst === undefined) { isFirst = false; }\n this.hoverFirstEmoji = isFirst;\n this.$emit('highlighted-emoji', emoji);\n },\n\n setEmojiRef: function (el, indexTab, indexEmoji) {\n if (!this.emojiRefs[indexTab]) {\n this.$set(this.emojiRefs, indexTab, []);\n }\n this.$set(this.emojiRefs[indexTab], indexEmoji, el);\n },\n\n setFilteredRef: function (el, index) {\n this.$set(this.emojiFilteredRefs, index, el);\n },\n\n focusEmoji: function (indexTab, indexEmoji) {\n // eslint-disable-next-line max-len\n const emojiRef = this.isFiltering ? this.emojiFilteredRefs[indexEmoji]?.[0] : this.emojiRefs[indexTab] && this.emojiRefs[indexTab][indexEmoji];\n if (emojiRef) {\n emojiRef.focus();\n return true;\n }\n\n return false;\n },\n\n // eslint-disable-next-line complexity\n handleKeyDown: function (event, indexTab, indexEmoji, emoji) {\n event.preventDefault();\n\n if (event.key === 'ArrowUp') {\n const position = indexEmoji % EMOJIS_PER_ROW;\n\n if (indexTab === 0) {\n // we are on the first emoji tab, then we should jump to the last row of the last emoji tab\n const numberOfMissingEmojis =\n EMOJIS_PER_ROW - (this.emojiRefs[this.emojiRefs.length - 1].length % EMOJIS_PER_ROW);\n\n const emojiToJump =\n this.emojiRefs[this.emojiRefs.length - 1].length + numberOfMissingEmojis - (EMOJIS_PER_ROW - position);\n\n if (!this.focusEmoji(this.emojiRefs.length - 1, emojiToJump)) {\n // if there is no emoji in this position, jump to the last emoji of the row\n this.focusEmoji(this.emojiRefs.length - 1, this.emojiRefs[this.emojiRefs.length - 1].length - 1);\n }\n return;\n }\n\n // if we are not on the first tab, we should jump to the previous row of the current tab\n if (!this.focusEmoji(indexTab, indexEmoji - EMOJIS_PER_ROW)) {\n // if there is no previous row, we should jump to emoji in the sampe position of the previous tab\n const previousTab = indexTab - 1 < 0 ? 0 : indexTab - 1;\n const emojisInPreviousTab = this.emojiRefs[previousTab].length;\n const lastEmojiPosition = emojisInPreviousTab - (emojisInPreviousTab % EMOJIS_PER_ROW) + position;\n\n if (!this.focusEmoji(previousTab, lastEmojiPosition)) {\n // if there is no emoji in this position, jump to the last emoji of the row\n this.focusEmoji(indexTab - 1, this.emojiRefs[indexTab - 1].length - 1);\n }\n }\n }\n\n if (event.key === 'ArrowDown') {\n if (!this.focusEmoji(indexTab, indexEmoji + EMOJIS_PER_ROW)) {\n // if cannot go down\n\n // Calculate position from cell 0 to cell 8\n const position = indexEmoji % EMOJIS_PER_ROW;\n\n // check if it exists a next row in the current tab\n if (this.emojiRefs?.[indexTab]?.[indexEmoji + (EMOJIS_PER_ROW - position)]) {\n // if it exists, we should focus the last emoji of the next row in the current tab\n this.focusEmoji(indexTab, this.emojiRefs[indexTab].length - 1);\n // if we are at the end of the list it will do nothing\n } else {\n // We don't have next row, we are in the last of the tab, then jump\n // to the next tab but in the equal emoji position in row 0.\n\n if (!this.focusEmoji(indexTab + 1, position)) {\n // We are on the bottom!, should jump to the same position emoji in the first row of the first tabset\n // if it doesn't has, jump to the last\n if (!this.focusEmoji(0, position)) {\n this.focusEmoji(0, this.emojiRefs[0].length - 1);\n }\n }\n }\n }\n }\n\n if (event.key === 'ArrowLeft') {\n this.handleHorizontalNavigation('left', indexTab, indexEmoji);\n }\n\n if (event.key === 'ArrowRight') {\n this.handleHorizontalNavigation('right', indexTab, indexEmoji);\n }\n\n if (event.key === 'Tab' && !event.shiftKey) {\n if (this.focusEmoji(indexTab + 1, 0)) {\n this.scrollToTab((indexTab + 1) + 1, false);\n } else {\n // We are on the last emoji tabset, jump to the skin selector\n this.$emit('focus-skin-selector');\n }\n }\n\n if (event.key === 'Tab' && event.shiftKey) {\n if (this.focusEmoji(indexTab, 0) && indexTab > 0) {\n this.scrollToTab(indexTab, true);\n } else {\n this.scrollToTab(1, false);\n this.$emit('focus-search-input');\n }\n }\n\n if (event.key === 'Enter') {\n this.handleEmojiSelection(emoji, event);\n }\n },\n\n /* eslint-disable-next-line complexity */\n handleHorizontalNavigation: function (direction, indexTab, indexEmoji) {\n if (this.isFiltering) {\n if (direction === 'left') {\n this.handleArrowLeftFiltered(indexTab, indexEmoji);\n } else if (direction === 'right') {\n this.handleArrowRightFiltered(indexTab, indexEmoji);\n }\n } else {\n if (direction === 'left') {\n this.handleArrowLeft(indexTab, indexEmoji);\n } else if (direction === 'right') {\n this.handleArrowRight(indexTab, indexEmoji);\n }\n }\n },\n\n handleArrowLeftFiltered: function (indexTab, indexEmoji) {\n if (!this.focusEmoji(0, indexEmoji - 1)) {\n this.focusEmoji(0, this.emojiFilteredRefs.length - 1);\n }\n },\n\n handleArrowRightFiltered: function (indexTab, indexEmoji) {\n if (!this.focusEmoji(0, indexEmoji + 1)) {\n this.focusEmoji(0, 0);\n }\n },\n\n handleArrowLeft: function (indexTab, indexEmoji) {\n if (!this.focusEmoji(indexTab, indexEmoji - 1)) {\n if (this.emojiRefs[indexTab - 1]) {\n this.focusEmoji(indexTab - 1, this.emojiRefs[indexTab - 1].length - 1);\n } else {\n this.focusEmoji(this.emojiRefs.length - 1, this.emojiRefs[this.emojiRefs.length - 1].length - 1);\n }\n }\n },\n\n handleArrowRight: function (indexTab, indexEmoji) {\n if (!this.focusEmoji(indexTab, indexEmoji + 1)) {\n if (!this.focusEmoji(indexTab + 1, 0)) {\n this.focusEmoji(0, 0);\n }\n }\n },\n\n handleEmojiSelection (emoji, event) {\n this.$emit('selected-emoji', { ...emoji, shift_key: event.shiftKey });\n },\n\n // @TODO(improvement): Sync with simplified Vue 3 version\n /* eslint-disable-next-line complexity */\n handleKeyDownFilteredEmojis (event, indexEmoji, emoji) {\n event.preventDefault();\n this.hoverFirstEmoji = false;\n\n if (event.key === 'ArrowUp') {\n const position = indexEmoji % EMOJIS_PER_ROW;\n if (!this.focusEmoji(0, indexEmoji - EMOJIS_PER_ROW)) {\n const lastEmojiPosition =\n this.emojiFilteredRefs.length - (this.emojiFilteredRefs.length % EMOJIS_PER_ROW) + position;\n\n this.focusEmoji(0, lastEmojiPosition);\n\n if (!this.focusEmoji(0, lastEmojiPosition)) {\n this.focusEmoji(0, this.emojiFilteredRefs.length - 1);\n }\n }\n }\n\n if (event.key === 'ArrowDown') {\n if (!this.focusEmoji(0, indexEmoji + EMOJIS_PER_ROW)) {\n const position = indexEmoji % EMOJIS_PER_ROW;\n\n if (this.emojiFilteredRefs?.[indexEmoji + (EMOJIS_PER_ROW - position)]) {\n this.focusEmoji(0, this.emojiFilteredRefs.length - 1);\n } else {\n this.focusEmoji(0, position);\n }\n }\n }\n\n if (event.key === 'ArrowLeft') {\n this.handleHorizontalNavigation('left', 0, indexEmoji);\n }\n\n if (event.key === 'ArrowRight') {\n this.handleHorizontalNavigation('right', 0, indexEmoji);\n }\n\n if (event.key === 'Tab') {\n this.$emit('focus-skin-selector');\n }\n\n if (event.key === 'Enter') {\n this.handleEmojiSelection(emoji, event);\n }\n },\n\n setBottomScrollListener () {\n this.handleScroll = () => {\n const container = this.$refs.listRef;\n if (container.scrollTop + container.clientHeight >= container.scrollHeight) {\n this.$emit('scroll-bottom-reached');\n }\n };\n\n this.$refs.listRef.addEventListener('scroll', this.handleScroll);\n },\n\n setTabLabelObserver () {\n this.tabLabelObserver = new IntersectionObserver(entries => {\n /* eslint-disable-next-line complexity */\n entries.forEach(entry => {\n const { target } = entry;\n const index = parseInt(target.dataset.index);\n\n if (entry.isIntersecting && target.offsetTop <= this.$refs.tabCategoryRef?.offsetTop + 50) {\n this.fixedLabel = this.tabLabels[index - 1]?.label ?? this.tabLabels[0]?.label;\n this.$emit('scroll-into-tab', index - 1);\n } else if (entry.boundingClientRect.bottom <= this.$refs.tabCategoryRef?.getBoundingClientRect().bottom) {\n this.$emit('scroll-into-tab', index);\n this.fixedLabel = this.tabLabels[index]?.label;\n } else if (index === 1) {\n this.$emit('scroll-into-tab', index);\n this.fixedLabel = this.tabLabels[0]?.label;\n }\n });\n });\n\n this.tabLabelObserver.observe(this.$refs.tabCategoryRef);\n\n Array.from(this.$refs.listRef.children).forEach((child, index) => {\n this.tabLabelObserver.observe(child);\n child.dataset.index = index;\n });\n },\n\n focusLastEmoji () {\n this.scrollToTab(this.tabs.length, true);\n },\n\n },\n\n};\n</script>\n","<template>\n <div class=\"d-emoji-picker__data\">\n <img\n v-if=\"emoji\"\n class=\"d-icon d-icon--size-500\"\n :alt=\"emoji.name\"\n :aria-label=\"emoji.name\"\n :title=\"emoji.name\"\n :src=\"getImgSrc(emoji)\"\n >\n <div>{{ emoji?.name }}</div>\n </div>\n</template>\n\n<script>\nimport { CDN_URL } from '@/components/emoji_picker/emoji_picker_constants';\n\nexport default {\n name: 'EmojiDescription',\n\n props: {\n /**\n * Emoji data\n * @type {Object}\n * @default null\n */\n emoji: {\n type: Object,\n default: () => null,\n },\n },\n\n data () {\n return {\n CDN_URL,\n };\n },\n\n methods: {\n getImgSrc (emoji) {\n if (emoji.date_added) { // if custom emoji\n return emoji.image;\n } else { // if regular emoji\n return `${CDN_URL + emoji.unicode_character}.png`;\n }\n },\n },\n};\n</script>\n","<template>\n <div data-qa=\"skin-selector\">\n <div\n v-show=\"isOpen\"\n class=\"d-emoji-picker__skin-list\"\n >\n <button\n v-for=\"(skin, index) in skinList\"\n :key=\"skin.name\"\n :ref=\"`skinRef-${index}`\"\n :class=\"{\n 'selected': skinSelected?.skinCode === skin.skinCode,\n }\"\n @click=\"selectSkin(skin)\"\n @keydown=\"event => handleKeyDown(event, skin, index)\"\n >\n <img\n class=\"d-icon d-icon--size-500\"\n :alt=\"skin.name\"\n :aria-label=\"skin.name\"\n :title=\"skin.name\"\n :src=\"`${cdnUrl + skin.unicode_output}.png`\"\n >\n </button>\n </div>\n <div\n v-show=\"!isOpen\"\n class=\"d-emoji-picker__skin-selected\"\n >\n <dt-tooltip placement=\"top-end\">\n {{ skinSelectorButtonTooltipLabel }}\n <template #anchor>\n <button\n ref=\"skinSelectorRef\"\n :aria-label=\"skinSelectorButtonTooltipLabel\"\n tabindex=\"-1\"\n @click=\"toggleSkinList\"\n @keydown=\"event => handleKeyDown(event)\"\n >\n <img\n class=\"d-icon d-icon--size-500\"\n :alt=\"skinSelected?.name\"\n :aria-label=\"skinSelected?.name\"\n :title=\"skinSelected?.name\"\n :src=\"`${cdnUrl + skinSelected?.unicode_output}.png`\"\n >\n </button>\n </template>\n </dt-tooltip>\n </div>\n </div>\n</template>\n\n<script>\nimport DtTooltip from '@/components/tooltip/tooltip.vue';\nimport { CDN_URL, EMOJI_PICKER_SKIN_TONE_MODIFIERS } from '@/components/emoji_picker/emoji_picker_constants';\n\nexport default {\n name: 'EmojiSkinSelector',\n\n components: {\n DtTooltip,\n },\n\n props: {\n skinTone: {\n type: String,\n required: true,\n },\n\n isHovering: {\n type: Boolean,\n default: false,\n },\n\n skinSelectorButtonTooltipLabel: {\n type: String,\n required: true,\n },\n },\n\n data () {\n return {\n isOpen: false,\n skinSelected: null,\n skinsRef: [],\n cdnUrl: CDN_URL,\n };\n },\n\n computed: {\n skinPassedIn () {\n return this.skinList.find(skin => skin.skinTone === this.skinTone);\n },\n\n skinList () {\n return [\n {\n name: ':wave_tone1:',\n unicode_output: '1f44b-1f3fb',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.LIGHT,\n skinCode: '_tone1',\n },\n {\n name: ':wave_tone2:',\n unicode_output: '1f44b-1f3fc',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM_LIGHT,\n skinCode: '_tone2',\n },\n {\n name: ':wave_tone3:',\n unicode_output: '1f44b-1f3fd',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM,\n skinCode: '_tone3',\n },\n {\n name: ':wave_tone4:',\n unicode_output: '1f44b-1f3fe',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.MEDIUM_DARK,\n skinCode: '_tone4',\n },\n {\n name: ':wave_tone5:',\n unicode_output: '1f44b-1f3ff',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.DARK,\n skinCode: '_tone5',\n },\n {\n name: ':wave:',\n unicode_output: '1f44b',\n skinTone: EMOJI_PICKER_SKIN_TONE_MODIFIERS.DEFAULT,\n skinCode: '',\n },\n ];\n },\n },\n\n watch: {\n isHovering (newVal) {\n if (newVal) {\n this.isOpen = false;\n }\n },\n\n skinTone (newVal, oldVal) {\n if (newVal !== oldVal) {\n this.skinSelected = this.skinPassedIn;\n }\n },\n },\n\n mounted () {\n this.skinSelected = this.skinPassedIn;\n this.$nextTick(() => {\n this.setupSkinRefs();\n });\n },\n\n methods: {\n setupSkinRefs () {\n this.skinList.forEach((skin, index) => {\n const refKey = `skinRef-${index}`;\n if (this.$refs[refKey]) {\n this.$set(this.skinsRef, index, this.$refs[refKey][0]);\n }\n });\n },\n\n focusSkinSelector () {\n if (this.$refs.skinSelectorRef) {\n this.$refs.skinSelectorRef.focus();\n }\n },\n\n selectSkin (skin) {\n this.skinSelected = skin;\n this.isOpen = false;\n this.$emit('skin-tone', skin.skinTone);\n this.$nextTick(() => {\n this.focusSkinSelector();\n });\n },\n\n handleKeyDown (event, skin, index) {\n event.preventDefault();\n\n if (event.key === 'ArrowLeft') {\n if (index === 0) this.skinsRef[this.skinsRef.length - 1]?.focus();\n this.skinsRef[index - 1]?.focus();\n }\n\n if (event.key === 'ArrowRight') {\n if (this.skinsRef.length) this.skinsRef[0]?.focus();\n this.skinsRef[index + 1]?.focus();\n }\n\n if (event.key === 'Enter') {\n if (skin) { this.selectSkin(skin); } else {\n this.toggleSkinList();\n }\n }\n\n if (event.key === 'Tab') {\n if (event.shiftKey) {\n this.$emit('focus-last-emoji');\n } else {\n this.$emit('focus-tabset');\n }\n }\n },\n\n toggleSkinList () {\n this.isOpen = !this.isOpen;\n this.$nextTick(() => {\n if (this.skinsRef[0]) {\n this.skinsRef[0].focus();\n }\n });\n },\n },\n};\n</script>\n","<template>\n <div\n class=\"d-emoji-picker\"\n >\n <div class=\"d-emoji-picker--header\">\n <emoji-tabset\n ref=\"tabsetRef\"\n :emoji-filter=\"internalSearchQuery\"\n :show-custom-emojis-tab=\"showCustomEmojisTab\"\n :show-recently-used-tab=\"showRecentlyUsedTab\"\n :scroll-into-tab=\"scrollIntoTab\"\n :tab-set-labels=\"tabSetLabels\"\n @focus-skin-selector=\"$refs.skinSelectorRef.focusSkinSelector()\"\n @focus-search-input=\"showSearch\n ? $refs.searchInputRef.focusSearchInput()\n : $refs.emojiSelectorRef.focusEmojiSelector()\"\n @selected-tabset=\"scrollToSelectedTabset\"\n @keydown.esc.native=\"$emit('close')\"\n />\n </div>\n <div class=\"d-emoji-picker--body\">\n <emoji-search\n v-if=\"showSearch\"\n ref=\"searchInputRef\"\n :model-value=\"internalSearchQuery\"\n :search-placeholder-label=\"searchPlaceholderLabel\"\n @update:model-value=\"newValue => internalSearchQuery = newValue\"\n @select-first-emoji=\"$emit('selected-emoji', highlightedEmoji)\"\n @focus-tabset=\"$refs.tabsetRef.focusTabset()\"\n @focus-emoji-selector=\"$refs.emojiSelectorRef.focusEmojiSelector()\"\n @keydown.esc.native=\"$emit('close')\"\n />\n <emoji-selector\n ref=\"emojiSelectorRef\"\n :emoji-filter=\"internalSearchQuery\"\n :skin-tone=\"skinTone\"\n :tab-set-labels=\"tabSetLabels\"\n :search-results-label=\"searchResultsLabel\"\n :search-no-results-label=\"searchNoResultsLabel\"\n :recently-used-emojis=\"recentlyUsedEmojis\"\n :custom-emojis=\"customEmojis\"\n :selected-tabset=\"selectedTabset\"\n @scroll-into-tab=\"updateScrollIntoTab\"\n @highlighted-emoji=\"updateHighlightedEmoji\"\n @selected-emoji=\"$emit('selected-emoji', $event)\"\n @focus-skin-selector=\"$refs.skinSelectorRef.focusSkinSelector()\"\n @focus-search-input=\"showSearch ? $refs.searchInputRef.focusSearchInput() : $refs.tabsetRef.focusTabset()\"\n @keydown.esc.native=\"$emit('close')\"\n @scroll-bottom-reached=\"$emit('scroll-bottom-reached')\"\n />\n </div>\n <div class=\"d-emoji-picker--footer\">\n <dt-button\n v-if=\"showCustomEmojisTab && !highlightedEmoji\"\n importance=\"outlined\"\n :aria-label=\"addEmojiLabel\"\n class=\"d-emoji-picker__add-emoji\"\n @click=\"$emit('add-emoji')\"\n >\n {{ addEmojiLabel }}\n </dt-button>\n <emoji-description :emoji=\"highlightedEmoji\" />\n <emoji-skin-selector\n ref=\"skinSelectorRef\"\n :is-hovering=\"!!highlightedEmoji\"\n :skin-selector-button-tooltip-label=\"skinSelectorButtonTooltipLabel\"\n :skin-tone=\"skinTone\"\n @skin-tone=\"$emit('skin-tone', $event)\"\n @focus-tabset=\"$refs.tabsetRef.focusTabset()\"\n @focus-last-emoji=\"$refs.emojiSelectorRef.focusLastEmoji()\"\n @keydown.esc.native=\"$emit('close')\"\n />\n </div>\n </div>\n</template>\n\n<script>\nimport EmojiTabset from './modules/emoji_tabset.vue';\nimport EmojiSearch from './modules/emoji_search.vue';\nimport EmojiSelector from './modules/emoji_selector.vue';\nimport EmojiDescription from './modules/emoji_description.vue';\nimport EmojiSkinSelector from './modules/emoji_skin_selector.vue';\nimport { DtButton } from '../button';\nimport { DialtoneLocalization } from '@/localization';\n\nexport default {\n name: 'DtEmojiPicker',\n\n components: {\n EmojiTabset,\n EmojiSearch,\n EmojiSelector,\n EmojiDescription,\n EmojiSkinSelector,\n DtButton,\n },\n\n props: {\n /**\n * The array with recently used emoji object\n * This list is necessary to fill the recently used tab\n * @type {Array}\n * @default []\n * @example\n * <dt-emoji-picker :recentlyUsedEmojis=\"[emojiObject, emojiObject]\" />\n */\n // TODO try to simplify this to achieve an array of unicode characters and not an entire emoji data object\n recentlyUsedEmojis: {\n type: Array,\n default: () => [],\n },\n\n /**\n * The array with custom emojis object\n * This list is necessary to fill the custom tab\n * @type {Array}\n * @default []\n * @example\n * <dt-emoji-picker :customEmojis=\"[emojiObject, emojiObject]\" />\n */\n customEmojis: {\n type: Array,\n },\n\n /**\n * The skin tone to show the emojis\n * This prop gives the possibility to use the skin tone selected by the user previously\n * @type {String}\n * @default 'Default'\n * @values 'Default', 'Light', 'MediumLight', 'Medium', 'MediumDark', 'Dark'\n * @example\n * <dt-emoji-picker :skinTone=\"'Default'\" />\n */\n skinTone: {\n type: String,\n default: 'Default',\n },\n\n /**\n * Sets the search query that filters emojis.\n * @type {String}\n * @example\n * <dt-emoji-picker search-query=\"smile\" />\n */\n searchQuery: {\n type: String,\n default: '',\n },\n\n /**\n * Shows the search input\n * @type {Boolean}\n * @example\n * <dt-emoji-picker :show-search=\"false\" />\n */\n showSearch: {\n type: Boolean,\n default: true,\n },\n },\n\n data () {\n return {\n internalSearchQuery: this.searchQuery,\n highlightedEmoji: null,\n selectedTabset: {},\n scrollIntoTab: 0,\n i18n: new DialtoneLocalization(),\n };\n },\n\n computed: {\n showCustomEmojisTab () {\n return this.customEmojis?.length > 0;\n },\n\n showRecentlyUsedTab () {\n return this.recentlyUsedEmojis?.length > 0;\n },\n\n tabSetLabels () {\n return [\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_RECENTLY_USED_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_SMILEYS_AND_PEOPLE_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_NATURE_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_FOOD_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_ACTIVITY_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_TRAVEL_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_OBJECTS_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_SYMBOLS_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_FLAGS_LABEL'),\n this.i18n.$t('DIALTONE_EMOJI_PICKER_TABSET_CUSTOM_LABEL'),\n ];\n },\n\n searchPlaceholderLabel () {\n return this.i18n.$t('DIALTONE_EMOJI_PICKER_SEARCH_PLACEHOLDER_LABEL');\n },\n\n searchResultsLabel () {\n return this.i18n.$t('DIALTONE_EMOJI_PICKER_SEARCH_RESULTS_LABEL');\n },\n\n searchNoResultsLabel () {\n return this.i18n.$t('DIALTONE_EMOJI_PICKER_SEARCH_NO_RESULTS_LABEL');\n },\n\n skinSelectorButtonTooltipLabel () {\n return this.i18n.$t('DIALTONE_EMOJI_PICKER_SKIN_SELECTOR_BUTTON_TOOLTIP_LABEL');\n },\n\n addEmojiLabel () {\n return this.i18n.$t('DIALTONE_EMOJI_PICKER_ADD_EMOJI_LABEL');\n },\n },\n\n watch: {\n searchQuery (value) {\n this.internalSearchQuery = value;\n },\n },\n\n methods: {\n scrollToSelectedTabset (tabId) {\n this.internalSearchQuery = '';\n this.selectedTabset = { ...this.selectedTabset, tabId };\n },\n\n updateScrollIntoTab (value) {\n this.scrollIntoTab = value;\n },\n\n updateHighlightedEmoji (emoji) {\n this.highlightedEmoji = emoji;\n },\n },\n};\n</script>\n"],"names":["_sfc_main","DtTabGroup","DtTab","DtIconClock","DtIconSatisfied","DtIconLivingThing","DtIconFood","DtIconObject","DtIconTransportation","DtIconLightbulb","DtIconHeart","DtIconFlag","DtIconTiktok","tabsData","tab","index","newVal","id","parseId","skin","refKey","event","tabId","DtInput","DtIconSearch","DtIconClose","DtButton","value","emojisImported","CDN_URL","updateTabLabels","label","updateTabsOrder","newValue","newFilter","_a","_","emoji","i","el","indexEmoji","searchStr","obj","nameIncludesSearchStr","keywordsIncludeSearchStr","keyword","fn","delay","timeout","args","len","tabIndex","focusFirstEmoji","vm","tabElement","container","offsetTop","isFirst","indexTab","emojiRef","position","EMOJIS_PER_ROW","numberOfMissingEmojis","emojiToJump","previousTab","emojisInPreviousTab","lastEmojiPosition","_b","direction","entries","entry","target","_c","_d","_e","_f","child","DtTooltip","EMOJI_PICKER_SKIN_TONE_MODIFIERS","oldVal","EmojiTabset","EmojiSearch","EmojiSelector","EmojiDescription","EmojiSkinSelector","DialtoneLocalization"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"emoji-row-constants.cjs","sources":["../../../recipes/conversation_view/emoji_row/emoji_row_constants.js"],"sourcesContent":["export const REACTIONS_ATTRIBUTES = [\n 'emojiUnicodeOrShortname',\n 'isSelected',\n 'names',\n 'num',\n];\n\nexport default {\n REACTIONS_ATTRIBUTES,\n};\n"],"names":["REACTIONS_ATTRIBUTES","emoji_row_constants"],"mappings":"4GAAY,MAACA,EAAuB,CAClC,0BACA,aACA,QACA,KACF,EAEeC,EAAA,CACb,qBAAAD,CACF"}
1
+ {"version":3,"file":"emoji-row-constants.cjs","sources":["../../../recipes/conversation_view/emoji_row/emoji_row_constants.js"],"sourcesContent":["export const REACTIONS_ATTRIBUTES = [\n 'emojiUnicodeOrShortname',\n 'isSelected',\n 'names',\n 'num',\n];\n\nexport default {\n REACTIONS_ATTRIBUTES,\n};\n"],"names":["REACTIONS_ATTRIBUTES","emoji_row_constants"],"mappings":"4GAAY,MAACA,EAAuB,CAClC,0BACA,aACA,QACA,KACF,EAEAC,EAAe,CACb,qBAAAD,CACF"}
@@ -1 +1 @@
1
- {"version":3,"file":"emoji-row-constants.js","sources":["../../../recipes/conversation_view/emoji_row/emoji_row_constants.js"],"sourcesContent":["export const REACTIONS_ATTRIBUTES = [\n 'emojiUnicodeOrShortname',\n 'isSelected',\n 'names',\n 'num',\n];\n\nexport default {\n REACTIONS_ATTRIBUTES,\n};\n"],"names":["REACTIONS_ATTRIBUTES","emoji_row_constants"],"mappings":"AAAY,MAACA,IAAuB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAEeC,IAAA;AAAA,EACb,sBAAAD;AACF;"}
1
+ {"version":3,"file":"emoji-row-constants.js","sources":["../../../recipes/conversation_view/emoji_row/emoji_row_constants.js"],"sourcesContent":["export const REACTIONS_ATTRIBUTES = [\n 'emojiUnicodeOrShortname',\n 'isSelected',\n 'names',\n 'num',\n];\n\nexport default {\n REACTIONS_ATTRIBUTES,\n};\n"],"names":["REACTIONS_ATTRIBUTES","emoji_row_constants"],"mappings":"AAAY,MAACA,IAAuB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAEAC,IAAe;AAAA,EACb,sBAAAD;AACF;"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const n=require("./emoji-row-constants.cjs"),a=require("../../localization/index.cjs"),s=require("../../_plugin-vue2_normalizer-e_CkxkSV.cjs"),c=require("../tooltip/tooltip.cjs"),l=require("../button/button.cjs"),m=require("../emoji/emoji.cjs"),_=require("../emoji-text-wrapper/emoji-text-wrapper.cjs"),d={name:"DtRecipeEmojiRow",components:{DtTooltip:c.default,DtButton:l.default,DtEmoji:m.default,DtEmojiTextWrapper:_.default},props:{reactions:{type:Array,default:()=>[],validator:i=>{for(const e of i)if(!n.REACTIONS_ATTRIBUTES.every(o=>e[o]!==void 0))return!1;return!0}}},emits:["emoji-clicked","emoji-hovered"],data(){return{i18n:new a.DialtoneLocalization}},methods:{emojiClicked(i){this.$emit("emoji-clicked",i.emojiUnicodeOrShortname)},emojiHovered(i,e){this.$emit("emoji-hovered",{reaction:i.emojiUnicodeOrShortname,state:e})},reactionLabel(i){return this.i18n.$t("DIALTONE_EMOJI_ROW_REACTION_LABEL",{names:i.names,reaction:i.emojiUnicodeOrShortname})}}};var u=function(){var e=this,t=e._self._c;return t("span",{staticClass:"d-recipe-emoji-row"},[e._l(e.reactions,function(o){return t("span",{key:o.unicodeOutput},[t("dt-tooltip",{staticClass:"d-recipe-emoji-row__tooltip",attrs:{"content-class":"d-recipe-emoji-row__tooltip-content",sticky:"popper"},on:{shown:r=>e.emojiHovered(o,r)},scopedSlots:e._u([{key:"anchor",fn:function({attrs:r}){return[t("dt-button",{class:["d-recipe-emoji-row__reaction",o.isSelected?"d-recipe-emoji-row__reaction--selected":""],attrs:{importance:"clear",size:"sm","data-qa":"feed-item-reaction-button","aria-label":e.reactionLabel(o),attrs:r},on:{click:function(v){return e.emojiClicked(o)}}},[t("span",{staticClass:"d-recipe-emoji-row__emoji"},[t("dt-emoji",{attrs:{size:"200",code:o.emojiUnicodeOrShortname}})],1),t("span",{staticClass:"d-recipe-emoji-row__reaction-number"},[e._v(" "+e._s(o.num)+" ")])])]}}],null,!0)},[t("span",{attrs:{"aria-hidden":"true"}},[t("dt-emoji-text-wrapper",{attrs:{size:"200"}},[e._v(" "+e._s(e.reactionLabel(o))+" ")])],1)])],1)}),e._t("picker")],2)},p=[],j=s.n(d,u,p);const f=j.exports;exports.default=f;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const n=require("./emoji-row-constants.cjs"),a=require("../../localization/index.cjs"),s=require("../../_plugin-vue2_normalizer-e_CkxkSV.cjs"),c=require("../emoji-text-wrapper/emoji-text-wrapper.cjs"),l=require("../emoji/emoji.cjs"),m=require("../button/button.cjs"),_=require("../tooltip/tooltip.cjs"),d={name:"DtRecipeEmojiRow",components:{DtTooltip:_.default,DtButton:m.default,DtEmoji:l.default,DtEmojiTextWrapper:c.default},props:{reactions:{type:Array,default:()=>[],validator:i=>{for(const e of i)if(!n.REACTIONS_ATTRIBUTES.every(o=>e[o]!==void 0))return!1;return!0}}},emits:["emoji-clicked","emoji-hovered"],data(){return{i18n:new a.DialtoneLocalization}},methods:{emojiClicked(i){this.$emit("emoji-clicked",i.emojiUnicodeOrShortname)},emojiHovered(i,e){this.$emit("emoji-hovered",{reaction:i.emojiUnicodeOrShortname,state:e})},reactionLabel(i){return this.i18n.$t("DIALTONE_EMOJI_ROW_REACTION_LABEL",{names:i.names,reaction:i.emojiUnicodeOrShortname})}}};var u=function(){var e=this,t=e._self._c;return t("span",{staticClass:"d-recipe-emoji-row"},[e._l(e.reactions,function(o){return t("span",{key:o.unicodeOutput},[t("dt-tooltip",{staticClass:"d-recipe-emoji-row__tooltip",attrs:{"content-class":"d-recipe-emoji-row__tooltip-content",sticky:"popper"},on:{shown:r=>e.emojiHovered(o,r)},scopedSlots:e._u([{key:"anchor",fn:function({attrs:r}){return[t("dt-button",{class:["d-recipe-emoji-row__reaction",o.isSelected?"d-recipe-emoji-row__reaction--selected":""],attrs:{importance:"clear",size:"sm","data-qa":"feed-item-reaction-button","aria-label":e.reactionLabel(o),attrs:r},on:{click:function(v){return e.emojiClicked(o)}}},[t("span",{staticClass:"d-recipe-emoji-row__emoji"},[t("dt-emoji",{attrs:{size:"200",code:o.emojiUnicodeOrShortname}})],1),t("span",{staticClass:"d-recipe-emoji-row__reaction-number"},[e._v(" "+e._s(o.num)+" ")])])]}}],null,!0)},[t("span",{attrs:{"aria-hidden":"true"}},[t("dt-emoji-text-wrapper",{attrs:{size:"200"}},[e._v(" "+e._s(e.reactionLabel(o))+" ")])],1)])],1)}),e._t("picker")],2)},p=[],j=s.n(d,u,p);const f=j.exports;exports.default=f;
2
2
  //# sourceMappingURL=emoji-row.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"emoji-row.cjs","sources":["../../../recipes/conversation_view/emoji_row/emoji_row.vue"],"sourcesContent":["<template>\n <span class=\"d-recipe-emoji-row\">\n <span\n v-for=\"reaction in reactions\"\n :key=\"reaction.unicodeOutput\"\n >\n <dt-tooltip\n class=\"d-recipe-emoji-row__tooltip\"\n content-class=\"d-recipe-emoji-row__tooltip-content\"\n sticky=\"popper\"\n @shown=\"(shown) => emojiHovered(reaction, shown)\"\n >\n <span aria-hidden=\"true\">\n <dt-emoji-text-wrapper size=\"200\">\n {{ reactionLabel(reaction) }}\n </dt-emoji-text-wrapper>\n </span>\n <template #anchor=\"{ attrs }\">\n <dt-button\n importance=\"clear\"\n size=\"sm\"\n data-qa=\"feed-item-reaction-button\"\n :class=\"[\n 'd-recipe-emoji-row__reaction',\n reaction.isSelected ? 'd-recipe-emoji-row__reaction--selected' : '',\n ]\"\n :aria-label=\"reactionLabel(reaction)\"\n :attrs=\"attrs\"\n @click=\"emojiClicked(reaction)\"\n >\n <span class=\"d-recipe-emoji-row__emoji\">\n <dt-emoji\n size=\"200\"\n :code=\"reaction.emojiUnicodeOrShortname\"\n />\n </span>\n <span class=\"d-recipe-emoji-row__reaction-number\">\n {{ reaction.num }}\n </span>\n </dt-button>\n </template>\n </dt-tooltip>\n </span>\n <!-- TODO: Replace picker slot with a button with localized text and emit any event needed -->\n <!-- @slot Slot for emoji picker component, including the anchor. -->\n <slot name=\"picker\" />\n </span>\n</template>\n\n<script>\nimport { REACTIONS_ATTRIBUTES } from './emoji_row_constants.js';\nimport { DtButton } from '@/components/button';\nimport { DtTooltip } from '@/components/tooltip';\nimport { DtEmoji } from '@/components/emoji';\nimport { DtEmojiTextWrapper } from '@/components/emoji_text_wrapper';\nimport { DialtoneLocalization } from '@/localization';\n\nexport default {\n name: 'DtRecipeEmojiRow',\n\n components: { DtTooltip, DtButton, DtEmoji, DtEmojiTextWrapper },\n\n props: {\n /**\n * Provide an array of reaction objects to be shown.\n */\n reactions: {\n type: Array,\n default: () => [],\n validator: (reactions) => {\n for (const reaction of reactions) {\n const validInput = REACTIONS_ATTRIBUTES.every((attribute) => reaction[attribute] !== undefined ?? false);\n if (!validInput) return false;\n }\n return true;\n },\n },\n },\n\n emits: [\n 'emoji-clicked',\n 'emoji-hovered',\n ],\n\n data () {\n return {\n i18n: new DialtoneLocalization(),\n };\n },\n\n methods: {\n emojiClicked (reaction) {\n this.$emit('emoji-clicked', reaction.emojiUnicodeOrShortname);\n },\n\n emojiHovered (reaction, state) {\n this.$emit('emoji-hovered', {\n reaction: reaction.emojiUnicodeOrShortname,\n state,\n });\n },\n\n reactionLabel (reaction) {\n return this.i18n.$t('DIALTONE_EMOJI_ROW_REACTION_LABEL', {\n names: reaction.names,\n reaction: reaction.emojiUnicodeOrShortname,\n });\n },\n },\n};\n</script>\n"],"names":["_sfc_main","DtTooltip","DtButton","DtEmoji","DtEmojiTextWrapper","reactions","reaction","REACTIONS_ATTRIBUTES","attribute","DialtoneLocalization","state"],"mappings":"2ZAyDAA,EAAA,CACA,KAAA,mBAEA,WAAA,CAAA,UAAAC,EAAA,QAAA,SAAAC,UAAAC,QAAAA,EAAAA,QAAAC,mBAAAA,EAAAA,OAAA,EAEA,MAAA,CAIA,UAAA,CACA,KAAA,MACA,QAAA,IAAA,CAAA,EACA,UAAAC,GAAA,CACA,UAAAC,KAAAD,EAEA,GAAA,CADAE,uBAAA,MAAAC,GAAAF,EAAAE,CAAA,IAAA,MAAA,EACA,MAAA,GAEA,MAAA,EACA,CACA,CACA,EAEA,MAAA,CACA,gBACA,eACA,EAEA,MAAA,CACA,MAAA,CACA,KAAA,IAAAC,EAAAA,oBACA,CACA,EAEA,QAAA,CACA,aAAAH,EAAA,CACA,KAAA,MAAA,gBAAAA,EAAA,uBAAA,CACA,EAEA,aAAAA,EAAAI,EAAA,CACA,KAAA,MAAA,gBAAA,CACA,SAAAJ,EAAA,wBACA,MAAAI,CACA,CAAA,CACA,EAEA,cAAAJ,EAAA,CACA,OAAA,KAAA,KAAA,GAAA,oCAAA,CACA,MAAAA,EAAA,MACA,SAAAA,EAAA,uBACA,CAAA,CACA,CACA,CACA"}
1
+ {"version":3,"file":"emoji-row.cjs","sources":["../../../recipes/conversation_view/emoji_row/emoji_row.vue"],"sourcesContent":["<template>\n <span class=\"d-recipe-emoji-row\">\n <span\n v-for=\"reaction in reactions\"\n :key=\"reaction.unicodeOutput\"\n >\n <dt-tooltip\n class=\"d-recipe-emoji-row__tooltip\"\n content-class=\"d-recipe-emoji-row__tooltip-content\"\n sticky=\"popper\"\n @shown=\"(shown) => emojiHovered(reaction, shown)\"\n >\n <span aria-hidden=\"true\">\n <dt-emoji-text-wrapper size=\"200\">\n {{ reactionLabel(reaction) }}\n </dt-emoji-text-wrapper>\n </span>\n <template #anchor=\"{ attrs }\">\n <dt-button\n importance=\"clear\"\n size=\"sm\"\n data-qa=\"feed-item-reaction-button\"\n :class=\"[\n 'd-recipe-emoji-row__reaction',\n reaction.isSelected ? 'd-recipe-emoji-row__reaction--selected' : '',\n ]\"\n :aria-label=\"reactionLabel(reaction)\"\n :attrs=\"attrs\"\n @click=\"emojiClicked(reaction)\"\n >\n <span class=\"d-recipe-emoji-row__emoji\">\n <dt-emoji\n size=\"200\"\n :code=\"reaction.emojiUnicodeOrShortname\"\n />\n </span>\n <span class=\"d-recipe-emoji-row__reaction-number\">\n {{ reaction.num }}\n </span>\n </dt-button>\n </template>\n </dt-tooltip>\n </span>\n <!-- TODO: Replace picker slot with a button with localized text and emit any event needed -->\n <!-- @slot Slot for emoji picker component, including the anchor. -->\n <slot name=\"picker\" />\n </span>\n</template>\n\n<script>\nimport { REACTIONS_ATTRIBUTES } from './emoji_row_constants.js';\nimport { DtButton } from '@/components/button';\nimport { DtTooltip } from '@/components/tooltip';\nimport { DtEmoji } from '@/components/emoji';\nimport { DtEmojiTextWrapper } from '@/components/emoji_text_wrapper';\nimport { DialtoneLocalization } from '@/localization';\n\nexport default {\n name: 'DtRecipeEmojiRow',\n\n components: { DtTooltip, DtButton, DtEmoji, DtEmojiTextWrapper },\n\n props: {\n /**\n * Provide an array of reaction objects to be shown.\n */\n reactions: {\n type: Array,\n default: () => [],\n validator: (reactions) => {\n for (const reaction of reactions) {\n const validInput = REACTIONS_ATTRIBUTES.every((attribute) => reaction[attribute] !== undefined);\n if (!validInput) return false;\n }\n return true;\n },\n },\n },\n\n emits: [\n 'emoji-clicked',\n 'emoji-hovered',\n ],\n\n data () {\n return {\n i18n: new DialtoneLocalization(),\n };\n },\n\n methods: {\n emojiClicked (reaction) {\n this.$emit('emoji-clicked', reaction.emojiUnicodeOrShortname);\n },\n\n emojiHovered (reaction, state) {\n this.$emit('emoji-hovered', {\n reaction: reaction.emojiUnicodeOrShortname,\n state,\n });\n },\n\n reactionLabel (reaction) {\n return this.i18n.$t('DIALTONE_EMOJI_ROW_REACTION_LABEL', {\n names: reaction.names,\n reaction: reaction.emojiUnicodeOrShortname,\n });\n },\n },\n};\n</script>\n"],"names":["_sfc_main","DtTooltip","DtButton","DtEmoji","DtEmojiTextWrapper","reactions","reaction","REACTIONS_ATTRIBUTES","attribute","DialtoneLocalization","state"],"mappings":"2ZAyDAA,EAAA,CACA,KAAA,mBAEA,WAAA,CAAA,UAAAC,EAAAA,QAAA,SAAAC,UAAA,QAAAC,EAAAA,QAAA,mBAAAC,EAAAA,OAAA,EAEA,MAAA,CAIA,UAAA,CACA,KAAA,MACA,QAAA,IAAA,CAAA,EACA,UAAAC,GAAA,CACA,UAAAC,KAAAD,EAEA,GAAA,CADAE,EAAAA,qBAAA,MAAAC,GAAAF,EAAAE,CAAA,IAAA,MAAA,EACA,MAAA,GAEA,MAAA,EACA,CACA,CACA,EAEA,MAAA,CACA,gBACA,eACA,EAEA,MAAA,CACA,MAAA,CACA,KAAA,IAAAC,EAAAA,oBACA,CACA,EAEA,QAAA,CACA,aAAAH,EAAA,CACA,KAAA,MAAA,gBAAAA,EAAA,uBAAA,CACA,EAEA,aAAAA,EAAAI,EAAA,CACA,KAAA,MAAA,gBAAA,CACA,SAAAJ,EAAA,wBACA,MAAAI,CACA,CAAA,CACA,EAEA,cAAAJ,EAAA,CACA,OAAA,KAAA,KAAA,GAAA,oCAAA,CACA,MAAAA,EAAA,MACA,SAAAA,EAAA,uBACA,CAAA,CACA,CACA,CACA"}
@@ -1,13 +1,13 @@
1
1
  import { REACTIONS_ATTRIBUTES as n } from "./emoji-row-constants.js";
2
2
  import { DialtoneLocalization as a } from "../../localization/index.js";
3
3
  import { n as s } from "../../_plugin-vue2_normalizer-DSLOjnn3.js";
4
- import m from "../tooltip/tooltip.js";
5
- import c from "../button/button.js";
6
- import p from "../emoji/emoji.js";
7
- import d from "../emoji-text-wrapper/emoji-text-wrapper.js";
4
+ import m from "../emoji-text-wrapper/emoji-text-wrapper.js";
5
+ import c from "../emoji/emoji.js";
6
+ import p from "../button/button.js";
7
+ import d from "../tooltip/tooltip.js";
8
8
  const _ = {
9
9
  name: "DtRecipeEmojiRow",
10
- components: { DtTooltip: m, DtButton: c, DtEmoji: p, DtEmojiTextWrapper: d },
10
+ components: { DtTooltip: d, DtButton: p, DtEmoji: c, DtEmojiTextWrapper: m },
11
11
  props: {
12
12
  /**
13
13
  * Provide an array of reaction objects to be shown.
@@ -1 +1 @@
1
- {"version":3,"file":"emoji-row.js","sources":["../../../recipes/conversation_view/emoji_row/emoji_row.vue"],"sourcesContent":["<template>\n <span class=\"d-recipe-emoji-row\">\n <span\n v-for=\"reaction in reactions\"\n :key=\"reaction.unicodeOutput\"\n >\n <dt-tooltip\n class=\"d-recipe-emoji-row__tooltip\"\n content-class=\"d-recipe-emoji-row__tooltip-content\"\n sticky=\"popper\"\n @shown=\"(shown) => emojiHovered(reaction, shown)\"\n >\n <span aria-hidden=\"true\">\n <dt-emoji-text-wrapper size=\"200\">\n {{ reactionLabel(reaction) }}\n </dt-emoji-text-wrapper>\n </span>\n <template #anchor=\"{ attrs }\">\n <dt-button\n importance=\"clear\"\n size=\"sm\"\n data-qa=\"feed-item-reaction-button\"\n :class=\"[\n 'd-recipe-emoji-row__reaction',\n reaction.isSelected ? 'd-recipe-emoji-row__reaction--selected' : '',\n ]\"\n :aria-label=\"reactionLabel(reaction)\"\n :attrs=\"attrs\"\n @click=\"emojiClicked(reaction)\"\n >\n <span class=\"d-recipe-emoji-row__emoji\">\n <dt-emoji\n size=\"200\"\n :code=\"reaction.emojiUnicodeOrShortname\"\n />\n </span>\n <span class=\"d-recipe-emoji-row__reaction-number\">\n {{ reaction.num }}\n </span>\n </dt-button>\n </template>\n </dt-tooltip>\n </span>\n <!-- TODO: Replace picker slot with a button with localized text and emit any event needed -->\n <!-- @slot Slot for emoji picker component, including the anchor. -->\n <slot name=\"picker\" />\n </span>\n</template>\n\n<script>\nimport { REACTIONS_ATTRIBUTES } from './emoji_row_constants.js';\nimport { DtButton } from '@/components/button';\nimport { DtTooltip } from '@/components/tooltip';\nimport { DtEmoji } from '@/components/emoji';\nimport { DtEmojiTextWrapper } from '@/components/emoji_text_wrapper';\nimport { DialtoneLocalization } from '@/localization';\n\nexport default {\n name: 'DtRecipeEmojiRow',\n\n components: { DtTooltip, DtButton, DtEmoji, DtEmojiTextWrapper },\n\n props: {\n /**\n * Provide an array of reaction objects to be shown.\n */\n reactions: {\n type: Array,\n default: () => [],\n validator: (reactions) => {\n for (const reaction of reactions) {\n const validInput = REACTIONS_ATTRIBUTES.every((attribute) => reaction[attribute] !== undefined ?? false);\n if (!validInput) return false;\n }\n return true;\n },\n },\n },\n\n emits: [\n 'emoji-clicked',\n 'emoji-hovered',\n ],\n\n data () {\n return {\n i18n: new DialtoneLocalization(),\n };\n },\n\n methods: {\n emojiClicked (reaction) {\n this.$emit('emoji-clicked', reaction.emojiUnicodeOrShortname);\n },\n\n emojiHovered (reaction, state) {\n this.$emit('emoji-hovered', {\n reaction: reaction.emojiUnicodeOrShortname,\n state,\n });\n },\n\n reactionLabel (reaction) {\n return this.i18n.$t('DIALTONE_EMOJI_ROW_REACTION_LABEL', {\n names: reaction.names,\n reaction: reaction.emojiUnicodeOrShortname,\n });\n },\n },\n};\n</script>\n"],"names":["_sfc_main","DtTooltip","DtButton","DtEmoji","DtEmojiTextWrapper","reactions","reaction","REACTIONS_ATTRIBUTES","attribute","DialtoneLocalization","state"],"mappings":";;;;;;;AAyDA,MAAAA,IAAA;AAAA,EACA,MAAA;AAAA,EAEA,YAAA,EAAA,WAAAC,GAAA,UAAAC,GAAA,SAAAC,GAAA,oBAAAC,EAAA;AAAA,EAEA,OAAA;AAAA;AAAA;AAAA;AAAA,IAIA,WAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA,MAAA,CAAA;AAAA,MACA,WAAA,CAAAC,MAAA;AACA,mBAAAC,KAAAD;AAEA,cAAA,CADAE,EAAA,MAAA,CAAAC,MAAAF,EAAAE,CAAA,MAAA,MAAA,EACA,QAAA;AAEA,eAAA;AAAA,MACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AACA,WAAA;AAAA,MACA,MAAA,IAAAC,EAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA,IACA,aAAAH,GAAA;AACA,WAAA,MAAA,iBAAAA,EAAA,uBAAA;AAAA,IACA;AAAA,IAEA,aAAAA,GAAAI,GAAA;AACA,WAAA,MAAA,iBAAA;AAAA,QACA,UAAAJ,EAAA;AAAA,QACA,OAAAI;AAAA,MACA,CAAA;AAAA,IACA;AAAA,IAEA,cAAAJ,GAAA;AACA,aAAA,KAAA,KAAA,GAAA,qCAAA;AAAA,QACA,OAAAA,EAAA;AAAA,QACA,UAAAA,EAAA;AAAA,MACA,CAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"emoji-row.js","sources":["../../../recipes/conversation_view/emoji_row/emoji_row.vue"],"sourcesContent":["<template>\n <span class=\"d-recipe-emoji-row\">\n <span\n v-for=\"reaction in reactions\"\n :key=\"reaction.unicodeOutput\"\n >\n <dt-tooltip\n class=\"d-recipe-emoji-row__tooltip\"\n content-class=\"d-recipe-emoji-row__tooltip-content\"\n sticky=\"popper\"\n @shown=\"(shown) => emojiHovered(reaction, shown)\"\n >\n <span aria-hidden=\"true\">\n <dt-emoji-text-wrapper size=\"200\">\n {{ reactionLabel(reaction) }}\n </dt-emoji-text-wrapper>\n </span>\n <template #anchor=\"{ attrs }\">\n <dt-button\n importance=\"clear\"\n size=\"sm\"\n data-qa=\"feed-item-reaction-button\"\n :class=\"[\n 'd-recipe-emoji-row__reaction',\n reaction.isSelected ? 'd-recipe-emoji-row__reaction--selected' : '',\n ]\"\n :aria-label=\"reactionLabel(reaction)\"\n :attrs=\"attrs\"\n @click=\"emojiClicked(reaction)\"\n >\n <span class=\"d-recipe-emoji-row__emoji\">\n <dt-emoji\n size=\"200\"\n :code=\"reaction.emojiUnicodeOrShortname\"\n />\n </span>\n <span class=\"d-recipe-emoji-row__reaction-number\">\n {{ reaction.num }}\n </span>\n </dt-button>\n </template>\n </dt-tooltip>\n </span>\n <!-- TODO: Replace picker slot with a button with localized text and emit any event needed -->\n <!-- @slot Slot for emoji picker component, including the anchor. -->\n <slot name=\"picker\" />\n </span>\n</template>\n\n<script>\nimport { REACTIONS_ATTRIBUTES } from './emoji_row_constants.js';\nimport { DtButton } from '@/components/button';\nimport { DtTooltip } from '@/components/tooltip';\nimport { DtEmoji } from '@/components/emoji';\nimport { DtEmojiTextWrapper } from '@/components/emoji_text_wrapper';\nimport { DialtoneLocalization } from '@/localization';\n\nexport default {\n name: 'DtRecipeEmojiRow',\n\n components: { DtTooltip, DtButton, DtEmoji, DtEmojiTextWrapper },\n\n props: {\n /**\n * Provide an array of reaction objects to be shown.\n */\n reactions: {\n type: Array,\n default: () => [],\n validator: (reactions) => {\n for (const reaction of reactions) {\n const validInput = REACTIONS_ATTRIBUTES.every((attribute) => reaction[attribute] !== undefined);\n if (!validInput) return false;\n }\n return true;\n },\n },\n },\n\n emits: [\n 'emoji-clicked',\n 'emoji-hovered',\n ],\n\n data () {\n return {\n i18n: new DialtoneLocalization(),\n };\n },\n\n methods: {\n emojiClicked (reaction) {\n this.$emit('emoji-clicked', reaction.emojiUnicodeOrShortname);\n },\n\n emojiHovered (reaction, state) {\n this.$emit('emoji-hovered', {\n reaction: reaction.emojiUnicodeOrShortname,\n state,\n });\n },\n\n reactionLabel (reaction) {\n return this.i18n.$t('DIALTONE_EMOJI_ROW_REACTION_LABEL', {\n names: reaction.names,\n reaction: reaction.emojiUnicodeOrShortname,\n });\n },\n },\n};\n</script>\n"],"names":["_sfc_main","DtTooltip","DtButton","DtEmoji","DtEmojiTextWrapper","reactions","reaction","REACTIONS_ATTRIBUTES","attribute","DialtoneLocalization","state"],"mappings":";;;;;;;AAyDA,MAAAA,IAAA;AAAA,EACA,MAAA;AAAA,EAEA,YAAA,EAAA,WAAAC,GAAA,UAAAC,GAAA,SAAAC,GAAA,oBAAAC,EAAA;AAAA,EAEA,OAAA;AAAA;AAAA;AAAA;AAAA,IAIA,WAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA,MAAA,CAAA;AAAA,MACA,WAAA,CAAAC,MAAA;AACA,mBAAAC,KAAAD;AAEA,cAAA,CADAE,EAAA,MAAA,CAAAC,MAAAF,EAAAE,CAAA,MAAA,MAAA,EACA,QAAA;AAEA,eAAA;AAAA,MACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AACA,WAAA;AAAA,MACA,MAAA,IAAAC,EAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA,IACA,aAAAH,GAAA;AACA,WAAA,MAAA,iBAAAA,EAAA,uBAAA;AAAA,IACA;AAAA,IAEA,aAAAA,GAAAI,GAAA;AACA,WAAA,MAAA,iBAAA;AAAA,QACA,UAAAJ,EAAA;AAAA,QACA,OAAAI;AAAA,MACA,CAAA;AAAA,IACA;AAAA,IAEA,cAAAJ,GAAA;AACA,aAAA,KAAA,KAAA,GAAA,qCAAA;AAAA,QACA,OAAAA,EAAA;AAAA,QACA,UAAAA,EAAA;AAAA,MACA,CAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;;;;"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const i=require("../../common/emoji/index.cjs"),a=require("../icon/icon-constants.cjs"),c=require("../../_plugin-vue2_normalizer-e_CkxkSV.cjs"),o=require("../emoji/emoji.cjs"),l={name:"DtEmojiTextWrapper",components:{DtEmoji:o.default},props:{elementType:{type:String,default:"div"},size:{type:String,default:"500",validator:e=>Object.keys(a.ICON_SIZE_MODIFIERS).includes(e)}},data(){return{loadingEmojiJson:!0}},async created(){this.loadingEmojiJson=!1},methods:{replaceDtEmojis(e,t){if(!e.length)return t;const s=e.map(r=>r.replace(/\*/g,"\\*")),n=new RegExp(`(${s.join("|")})`,"g");return t.split(n).filter(r=>r.trim()!=="").map(r=>e.includes(r)?this.$createElement(o.default,{props:{code:r,size:this.size}}):this.$createElement("span",{class:"d-emoji-text-wrapper__text"},r))},searchVNodes(e){if(!e.tag&&e.text)return this.searchCodes(e.text);const t=e.children?e.children.map(s=>this.searchVNodes(s)):[];return this.$createElement(e.tag,e.data,t)},replaceVueComponentVNodeContent(e){},searchCodes(e){const t=i.findShortCodes(e),s=i.findEmojis(e),n=[...t,...s];return this.replaceDtEmojis(n,e)}},render(e){const t=this.$slots.default||[];return e(this.elementType,{"data-qa":"emoji-text-wrapper",class:"d-emoji-text-wrapper"},this.loadingEmojiJson?t:t.map(s=>this.searchVNodes(s)))}},d=null,p=null;var m=c.n(l,d,p);const u=m.exports;exports.default=u;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const i=require("../../common/emoji/index.cjs"),a=require("../icon/icon-constants.cjs"),c=require("../../_plugin-vue2_normalizer-e_CkxkSV.cjs"),o=require("../emoji/emoji.cjs"),l={name:"DtEmojiTextWrapper",components:{DtEmoji:o.default},props:{elementType:{type:String,default:"div"},size:{type:String,default:"500",validator:e=>Object.keys(a.ICON_SIZE_MODIFIERS).includes(e)}},data(){return{loadingEmojiJson:!0}},async created(){this.loadingEmojiJson=!1},methods:{replaceDtEmojis(e,t){if(!e.length)return t;const s=e.map(r=>r.replace(/\*/g,"\\*")),n=new RegExp(`(${s.join("|")})`,"g");return t.split(n).filter(r=>r.trim()!=="").map(r=>e.includes(r)?this.$createElement(o.default,{props:{code:r,size:this.size}}):this.$createElement("span",{class:"d-emoji-text-wrapper__text"},r))},searchVNodes(e){if(!e.tag&&e.text)return this.searchCodes(e.text);const t=e.children?e.children.map(s=>this.searchVNodes(s)):[];return this.$createElement(e.tag,e.data,t)},replaceVueComponentVNodeContent(){},searchCodes(e){const t=i.findShortCodes(e),s=i.findEmojis(e),n=[...t,...s];return this.replaceDtEmojis(n,e)}},render(e){const t=this.$slots.default||[];return e(this.elementType,{"data-qa":"emoji-text-wrapper",class:"d-emoji-text-wrapper"},this.loadingEmojiJson?t:t.map(s=>this.searchVNodes(s)))}},d=null,p=null;var m=c.n(l,d,p);const u=m.exports;exports.default=u;
2
2
  //# sourceMappingURL=emoji-text-wrapper.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"emoji-text-wrapper.cjs","sources":["../../../components/emoji_text_wrapper/emoji_text_wrapper.vue"],"sourcesContent":["<script>\nimport { DtEmoji } from '../emoji';\nimport { findEmojis, findShortCodes } from '@/common/emoji';\nimport { ICON_SIZE_MODIFIERS } from '@/components/icon/icon_constants';\n\n/**\n * Wrapper to find and replace shortcodes like :smile: or unicode chars such as 😄 with our custom Emojis implementation.\n * @see https://dialtone.dialpad.com/components/emoji_text_wrapper.html\n */\nexport default {\n name: 'DtEmojiTextWrapper',\n\n components: {\n DtEmoji,\n },\n\n props: {\n /**\n * Element type (tag name) to use for the wrapper.\n */\n elementType: {\n type: String,\n default: 'div',\n },\n\n /**\n * The icon size to render the emojis at: 100 to 800\n */\n size: {\n type: String,\n default: '500',\n validator: (t) => Object.keys(ICON_SIZE_MODIFIERS).includes(t),\n },\n },\n\n data () {\n return {\n loadingEmojiJson: true,\n };\n },\n\n async created () {\n this.loadingEmojiJson = false;\n },\n\n methods: {\n /**\n * Replaces the valid codes from the text content with a DtEmoji component.\n * @returns {Array<VNode|string>}\n */\n replaceDtEmojis (replaceList, textContent) {\n if (!replaceList.length) return textContent;\n // Escape the asterisk to avoid breaking the regex for the asterisk emoji\n const escapedReplaceList = replaceList.map(item =>\n item.replace(/\\*/g, '\\\\*'),\n );\n\n const regexp = new RegExp(`(${escapedReplaceList.join('|')})`, 'g');\n const items = textContent.split(regexp);\n\n return items\n .filter(item => item.trim() !== '')\n .map((item) => {\n if (replaceList.includes(item)) {\n return this.$createElement(DtEmoji, {\n props: { code: item, size: this.size },\n });\n }\n return this.$createElement('span', { class: 'd-emoji-text-wrapper__text' }, item);\n });\n },\n\n /**\n * Recursively search the Vue virtual DOM to find text\n * @param VNode\n * @returns {VNode|*}\n */\n searchVNodes (VNode) {\n // If VNode has no tag, it is a text node\n if (!VNode.tag && VNode.text) {\n return this.searchCodes(VNode.text);\n }\n\n const children = VNode.children ? VNode.children.map(VNodeChild => this.searchVNodes(VNodeChild)) : [];\n return this.$createElement(VNode.tag, VNode.data, children);\n },\n\n // TODO: Find a way to crawl vue components\n replaceVueComponentVNodeContent (VNode) {\n //\n },\n\n /**\n * Find codes in text.\n * @param textContent string\n * @returns {Array<VNode|string>|string}\n */\n searchCodes (textContent) {\n const shortcodes = findShortCodes(textContent);\n const emojis = findEmojis(textContent);\n\n const replaceList = [...shortcodes, ...emojis];\n return this.replaceDtEmojis(replaceList, textContent);\n },\n },\n\n render (h) {\n const defaultSlotContent = this.$slots.default || [];\n return h(\n this.elementType,\n {\n 'data-qa': 'emoji-text-wrapper',\n class: 'd-emoji-text-wrapper',\n },\n this.loadingEmojiJson\n ? defaultSlotContent\n : defaultSlotContent.map(VNode => this.searchVNodes(VNode)),\n );\n },\n};\n</script>\n"],"names":["_sfc_main","DtEmoji","t","ICON_SIZE_MODIFIERS","replaceList","textContent","escapedReplaceList","item","regexp","VNode","children","VNodeChild","shortcodes","findShortCodes","emojis","findEmojis","h","defaultSlotContent"],"mappings":"4RASAA,EAAA,CACA,KAAA,qBAEA,WAAA,CACA,QAAAC,EAAA,OACA,EAEA,MAAA,CAIA,YAAA,CACA,KAAA,OACA,QAAA,KACA,EAKA,KAAA,CACA,KAAA,OACA,QAAA,MACA,UAAAC,GAAA,OAAA,KAAAC,qBAAA,EAAA,SAAAD,CAAA,CACA,CACA,EAEA,MAAA,CACA,MAAA,CACA,iBAAA,EACA,CACA,EAEA,MAAA,SAAA,CACA,KAAA,iBAAA,EACA,EAEA,QAAA,CAKA,gBAAAE,EAAAC,EAAA,CACA,GAAA,CAAAD,EAAA,OAAA,OAAAC,EAEA,MAAAC,EAAAF,EAAA,IAAAG,GACAA,EAAA,QAAA,MAAA,KAAA,CACA,EAEAC,EAAA,IAAA,OAAA,IAAAF,EAAA,KAAA,GAAA,CAAA,IAAA,GAAA,EAGA,OAFAD,EAAA,MAAAG,CAAA,EAGA,OAAAD,GAAAA,EAAA,KAAA,IAAA,EAAA,EACA,IAAAA,GACAH,EAAA,SAAAG,CAAA,EACA,KAAA,eAAAN,UAAA,CACA,MAAA,CAAA,KAAAM,EAAA,KAAA,KAAA,IAAA,CACA,CAAA,EAEA,KAAA,eAAA,OAAA,CAAA,MAAA,4BAAA,EAAAA,CAAA,CACA,CACA,EAOA,aAAAE,EAAA,CAEA,GAAA,CAAAA,EAAA,KAAAA,EAAA,KACA,OAAA,KAAA,YAAAA,EAAA,IAAA,EAGA,MAAAC,EAAAD,EAAA,SAAAA,EAAA,SAAA,IAAAE,GAAA,KAAA,aAAAA,CAAA,CAAA,EAAA,CAAA,EACA,OAAA,KAAA,eAAAF,EAAA,IAAAA,EAAA,KAAAC,CAAA,CACA,EAGA,gCAAAD,EAAA,CAEA,EAOA,YAAAJ,EAAA,CACA,MAAAO,EAAAC,iBAAAR,CAAA,EACAS,EAAAC,aAAAV,CAAA,EAEAD,EAAA,CAAA,GAAAQ,EAAA,GAAAE,CAAA,EACA,OAAA,KAAA,gBAAAV,EAAAC,CAAA,CACA,CACA,EAEA,OAAAW,EAAA,CACA,MAAAC,EAAA,KAAA,OAAA,SAAA,CAAA,EACA,OAAAD,EACA,KAAA,YACA,CACA,UAAA,qBACA,MAAA,sBACA,EACA,KAAA,iBACAC,EACAA,EAAA,IAAAR,GAAA,KAAA,aAAAA,CAAA,CAAA,CACA,CACA,CACA"}
1
+ {"version":3,"file":"emoji-text-wrapper.cjs","sources":["../../../components/emoji_text_wrapper/emoji_text_wrapper.vue"],"sourcesContent":["<script>\nimport { DtEmoji } from '../emoji';\nimport { findEmojis, findShortCodes } from '@/common/emoji';\nimport { ICON_SIZE_MODIFIERS } from '@/components/icon/icon_constants';\n\n/**\n * Wrapper to find and replace shortcodes like :smile: or unicode chars such as 😄 with our custom Emojis implementation.\n * @see https://dialtone.dialpad.com/components/emoji_text_wrapper.html\n */\nexport default {\n name: 'DtEmojiTextWrapper',\n\n components: {\n DtEmoji,\n },\n\n props: {\n /**\n * Element type (tag name) to use for the wrapper.\n */\n elementType: {\n type: String,\n default: 'div',\n },\n\n /**\n * The icon size to render the emojis at: 100 to 800\n */\n size: {\n type: String,\n default: '500',\n validator: (t) => Object.keys(ICON_SIZE_MODIFIERS).includes(t),\n },\n },\n\n data () {\n return {\n loadingEmojiJson: true,\n };\n },\n\n async created () {\n this.loadingEmojiJson = false;\n },\n\n methods: {\n /**\n * Replaces the valid codes from the text content with a DtEmoji component.\n * @returns {Array<VNode|string>}\n */\n replaceDtEmojis (replaceList, textContent) {\n if (!replaceList.length) return textContent;\n // Escape the asterisk to avoid breaking the regex for the asterisk emoji\n const escapedReplaceList = replaceList.map(item =>\n item.replace(/\\*/g, '\\\\*'),\n );\n\n const regexp = new RegExp(`(${escapedReplaceList.join('|')})`, 'g');\n const items = textContent.split(regexp);\n\n return items\n .filter(item => item.trim() !== '')\n .map((item) => {\n if (replaceList.includes(item)) {\n return this.$createElement(DtEmoji, {\n props: { code: item, size: this.size },\n });\n }\n return this.$createElement('span', { class: 'd-emoji-text-wrapper__text' }, item);\n });\n },\n\n /**\n * Recursively search the Vue virtual DOM to find text\n * @param VNode\n * @returns {VNode|*}\n */\n searchVNodes (VNode) {\n // If VNode has no tag, it is a text node\n if (!VNode.tag && VNode.text) {\n return this.searchCodes(VNode.text);\n }\n\n const children = VNode.children ? VNode.children.map(VNodeChild => this.searchVNodes(VNodeChild)) : [];\n return this.$createElement(VNode.tag, VNode.data, children);\n },\n\n // TODO: Find a way to crawl vue components\n replaceVueComponentVNodeContent () {\n //\n },\n\n /**\n * Find codes in text.\n * @param textContent string\n * @returns {Array<VNode|string>|string}\n */\n searchCodes (textContent) {\n const shortcodes = findShortCodes(textContent);\n const emojis = findEmojis(textContent);\n\n const replaceList = [...shortcodes, ...emojis];\n return this.replaceDtEmojis(replaceList, textContent);\n },\n },\n\n render (h) {\n const defaultSlotContent = this.$slots.default || [];\n return h(\n this.elementType,\n {\n 'data-qa': 'emoji-text-wrapper',\n class: 'd-emoji-text-wrapper',\n },\n this.loadingEmojiJson\n ? defaultSlotContent\n : defaultSlotContent.map(VNode => this.searchVNodes(VNode)),\n );\n },\n};\n</script>\n"],"names":["_sfc_main","DtEmoji","t","ICON_SIZE_MODIFIERS","replaceList","textContent","escapedReplaceList","item","regexp","VNode","children","VNodeChild","shortcodes","findShortCodes","emojis","findEmojis","h","defaultSlotContent"],"mappings":"4RASAA,EAAA,CACA,KAAA,qBAEA,WAAA,CACA,QAAAC,EAAAA,OACA,EAEA,MAAA,CAIA,YAAA,CACA,KAAA,OACA,QAAA,KACA,EAKA,KAAA,CACA,KAAA,OACA,QAAA,MACA,UAAAC,GAAA,OAAA,KAAAC,qBAAA,EAAA,SAAAD,CAAA,CACA,CACA,EAEA,MAAA,CACA,MAAA,CACA,iBAAA,EACA,CACA,EAEA,MAAA,SAAA,CACA,KAAA,iBAAA,EACA,EAEA,QAAA,CAKA,gBAAAE,EAAAC,EAAA,CACA,GAAA,CAAAD,EAAA,OAAA,OAAAC,EAEA,MAAAC,EAAAF,EAAA,IAAAG,GACAA,EAAA,QAAA,MAAA,KAAA,CACA,EAEAC,EAAA,IAAA,OAAA,IAAAF,EAAA,KAAA,GAAA,CAAA,IAAA,GAAA,EAGA,OAFAD,EAAA,MAAAG,CAAA,EAGA,OAAAD,GAAAA,EAAA,KAAA,IAAA,EAAA,EACA,IAAAA,GACAH,EAAA,SAAAG,CAAA,EACA,KAAA,eAAAN,UAAA,CACA,MAAA,CAAA,KAAAM,EAAA,KAAA,KAAA,IAAA,CACA,CAAA,EAEA,KAAA,eAAA,OAAA,CAAA,MAAA,4BAAA,EAAAA,CAAA,CACA,CACA,EAOA,aAAAE,EAAA,CAEA,GAAA,CAAAA,EAAA,KAAAA,EAAA,KACA,OAAA,KAAA,YAAAA,EAAA,IAAA,EAGA,MAAAC,EAAAD,EAAA,SAAAA,EAAA,SAAA,IAAAE,GAAA,KAAA,aAAAA,CAAA,CAAA,EAAA,CAAA,EACA,OAAA,KAAA,eAAAF,EAAA,IAAAA,EAAA,KAAAC,CAAA,CACA,EAGA,iCAAA,CAEA,EAOA,YAAAL,EAAA,CACA,MAAAO,EAAAC,EAAAA,eAAAR,CAAA,EACAS,EAAAC,EAAAA,WAAAV,CAAA,EAEAD,EAAA,CAAA,GAAAQ,EAAA,GAAAE,CAAA,EACA,OAAA,KAAA,gBAAAV,EAAAC,CAAA,CACA,CACA,EAEA,OAAAW,EAAA,CACA,MAAAC,EAAA,KAAA,OAAA,SAAA,CAAA,EACA,OAAAD,EACA,KAAA,YACA,CACA,UAAA,qBACA,MAAA,sBACA,EACA,KAAA,iBACAC,EACAA,EAAA,IAAAR,GAAA,KAAA,aAAAA,CAAA,CAAA,CACA,CACA,CACA"}
@@ -58,7 +58,7 @@ const m = {
58
58
  return this.$createElement(e.tag, e.data, t);
59
59
  },
60
60
  // TODO: Find a way to crawl vue components
61
- replaceVueComponentVNodeContent(e) {
61
+ replaceVueComponentVNodeContent() {
62
62
  },
63
63
  /**
64
64
  * Find codes in text.
@@ -1 +1 @@
1
- {"version":3,"file":"emoji-text-wrapper.js","sources":["../../../components/emoji_text_wrapper/emoji_text_wrapper.vue"],"sourcesContent":["<script>\nimport { DtEmoji } from '../emoji';\nimport { findEmojis, findShortCodes } from '@/common/emoji';\nimport { ICON_SIZE_MODIFIERS } from '@/components/icon/icon_constants';\n\n/**\n * Wrapper to find and replace shortcodes like :smile: or unicode chars such as 😄 with our custom Emojis implementation.\n * @see https://dialtone.dialpad.com/components/emoji_text_wrapper.html\n */\nexport default {\n name: 'DtEmojiTextWrapper',\n\n components: {\n DtEmoji,\n },\n\n props: {\n /**\n * Element type (tag name) to use for the wrapper.\n */\n elementType: {\n type: String,\n default: 'div',\n },\n\n /**\n * The icon size to render the emojis at: 100 to 800\n */\n size: {\n type: String,\n default: '500',\n validator: (t) => Object.keys(ICON_SIZE_MODIFIERS).includes(t),\n },\n },\n\n data () {\n return {\n loadingEmojiJson: true,\n };\n },\n\n async created () {\n this.loadingEmojiJson = false;\n },\n\n methods: {\n /**\n * Replaces the valid codes from the text content with a DtEmoji component.\n * @returns {Array<VNode|string>}\n */\n replaceDtEmojis (replaceList, textContent) {\n if (!replaceList.length) return textContent;\n // Escape the asterisk to avoid breaking the regex for the asterisk emoji\n const escapedReplaceList = replaceList.map(item =>\n item.replace(/\\*/g, '\\\\*'),\n );\n\n const regexp = new RegExp(`(${escapedReplaceList.join('|')})`, 'g');\n const items = textContent.split(regexp);\n\n return items\n .filter(item => item.trim() !== '')\n .map((item) => {\n if (replaceList.includes(item)) {\n return this.$createElement(DtEmoji, {\n props: { code: item, size: this.size },\n });\n }\n return this.$createElement('span', { class: 'd-emoji-text-wrapper__text' }, item);\n });\n },\n\n /**\n * Recursively search the Vue virtual DOM to find text\n * @param VNode\n * @returns {VNode|*}\n */\n searchVNodes (VNode) {\n // If VNode has no tag, it is a text node\n if (!VNode.tag && VNode.text) {\n return this.searchCodes(VNode.text);\n }\n\n const children = VNode.children ? VNode.children.map(VNodeChild => this.searchVNodes(VNodeChild)) : [];\n return this.$createElement(VNode.tag, VNode.data, children);\n },\n\n // TODO: Find a way to crawl vue components\n replaceVueComponentVNodeContent (VNode) {\n //\n },\n\n /**\n * Find codes in text.\n * @param textContent string\n * @returns {Array<VNode|string>|string}\n */\n searchCodes (textContent) {\n const shortcodes = findShortCodes(textContent);\n const emojis = findEmojis(textContent);\n\n const replaceList = [...shortcodes, ...emojis];\n return this.replaceDtEmojis(replaceList, textContent);\n },\n },\n\n render (h) {\n const defaultSlotContent = this.$slots.default || [];\n return h(\n this.elementType,\n {\n 'data-qa': 'emoji-text-wrapper',\n class: 'd-emoji-text-wrapper',\n },\n this.loadingEmojiJson\n ? defaultSlotContent\n : defaultSlotContent.map(VNode => this.searchVNodes(VNode)),\n );\n },\n};\n</script>\n"],"names":["_sfc_main","DtEmoji","t","ICON_SIZE_MODIFIERS","replaceList","textContent","escapedReplaceList","item","regexp","VNode","children","VNodeChild","shortcodes","findShortCodes","emojis","findEmojis","h","defaultSlotContent"],"mappings":";;;;AASA,MAAAA,IAAA;AAAA,EACA,MAAA;AAAA,EAEA,YAAA;AAAA,IACA,SAAAC;AAAA,EACA;AAAA,EAEA,OAAA;AAAA;AAAA;AAAA;AAAA,IAIA,aAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,MACA,WAAA,CAAAC,MAAA,OAAA,KAAAC,CAAA,EAAA,SAAAD,CAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AACA,WAAA;AAAA,MACA,kBAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,MAAA,UAAA;AACA,SAAA,mBAAA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAKA,gBAAAE,GAAAC,GAAA;AACA,UAAA,CAAAD,EAAA,OAAA,QAAAC;AAEA,YAAAC,IAAAF,EAAA;AAAA,QAAA,CAAAG,MACAA,EAAA,QAAA,OAAA,KAAA;AAAA,MACA,GAEAC,IAAA,IAAA,OAAA,IAAAF,EAAA,KAAA,GAAA,CAAA,KAAA,GAAA;AAGA,aAFAD,EAAA,MAAAG,CAAA,EAGA,OAAA,CAAAD,MAAAA,EAAA,KAAA,MAAA,EAAA,EACA,IAAA,CAAAA,MACAH,EAAA,SAAAG,CAAA,IACA,KAAA,eAAAN,GAAA;AAAA,QACA,OAAA,EAAA,MAAAM,GAAA,MAAA,KAAA,KAAA;AAAA,MACA,CAAA,IAEA,KAAA,eAAA,QAAA,EAAA,OAAA,6BAAA,GAAAA,CAAA,CACA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,aAAAE,GAAA;AAEA,UAAA,CAAAA,EAAA,OAAAA,EAAA;AACA,eAAA,KAAA,YAAAA,EAAA,IAAA;AAGA,YAAAC,IAAAD,EAAA,WAAAA,EAAA,SAAA,IAAA,CAAAE,MAAA,KAAA,aAAAA,CAAA,CAAA,IAAA,CAAA;AACA,aAAA,KAAA,eAAAF,EAAA,KAAAA,EAAA,MAAAC,CAAA;AAAA,IACA;AAAA;AAAA,IAGA,gCAAAD,GAAA;AAAA,IAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,YAAAJ,GAAA;AACA,YAAAO,IAAAC,EAAAR,CAAA,GACAS,IAAAC,EAAAV,CAAA,GAEAD,IAAA,CAAA,GAAAQ,GAAA,GAAAE,CAAA;AACA,aAAA,KAAA,gBAAAV,GAAAC,CAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAAW,GAAA;AACA,UAAAC,IAAA,KAAA,OAAA,WAAA,CAAA;AACA,WAAAD;AAAA,MACA,KAAA;AAAA,MACA;AAAA,QACA,WAAA;AAAA,QACA,OAAA;AAAA,MACA;AAAA,MACA,KAAA,mBACAC,IACAA,EAAA,IAAA,CAAAR,MAAA,KAAA,aAAAA,CAAA,CAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;"}
1
+ {"version":3,"file":"emoji-text-wrapper.js","sources":["../../../components/emoji_text_wrapper/emoji_text_wrapper.vue"],"sourcesContent":["<script>\nimport { DtEmoji } from '../emoji';\nimport { findEmojis, findShortCodes } from '@/common/emoji';\nimport { ICON_SIZE_MODIFIERS } from '@/components/icon/icon_constants';\n\n/**\n * Wrapper to find and replace shortcodes like :smile: or unicode chars such as 😄 with our custom Emojis implementation.\n * @see https://dialtone.dialpad.com/components/emoji_text_wrapper.html\n */\nexport default {\n name: 'DtEmojiTextWrapper',\n\n components: {\n DtEmoji,\n },\n\n props: {\n /**\n * Element type (tag name) to use for the wrapper.\n */\n elementType: {\n type: String,\n default: 'div',\n },\n\n /**\n * The icon size to render the emojis at: 100 to 800\n */\n size: {\n type: String,\n default: '500',\n validator: (t) => Object.keys(ICON_SIZE_MODIFIERS).includes(t),\n },\n },\n\n data () {\n return {\n loadingEmojiJson: true,\n };\n },\n\n async created () {\n this.loadingEmojiJson = false;\n },\n\n methods: {\n /**\n * Replaces the valid codes from the text content with a DtEmoji component.\n * @returns {Array<VNode|string>}\n */\n replaceDtEmojis (replaceList, textContent) {\n if (!replaceList.length) return textContent;\n // Escape the asterisk to avoid breaking the regex for the asterisk emoji\n const escapedReplaceList = replaceList.map(item =>\n item.replace(/\\*/g, '\\\\*'),\n );\n\n const regexp = new RegExp(`(${escapedReplaceList.join('|')})`, 'g');\n const items = textContent.split(regexp);\n\n return items\n .filter(item => item.trim() !== '')\n .map((item) => {\n if (replaceList.includes(item)) {\n return this.$createElement(DtEmoji, {\n props: { code: item, size: this.size },\n });\n }\n return this.$createElement('span', { class: 'd-emoji-text-wrapper__text' }, item);\n });\n },\n\n /**\n * Recursively search the Vue virtual DOM to find text\n * @param VNode\n * @returns {VNode|*}\n */\n searchVNodes (VNode) {\n // If VNode has no tag, it is a text node\n if (!VNode.tag && VNode.text) {\n return this.searchCodes(VNode.text);\n }\n\n const children = VNode.children ? VNode.children.map(VNodeChild => this.searchVNodes(VNodeChild)) : [];\n return this.$createElement(VNode.tag, VNode.data, children);\n },\n\n // TODO: Find a way to crawl vue components\n replaceVueComponentVNodeContent () {\n //\n },\n\n /**\n * Find codes in text.\n * @param textContent string\n * @returns {Array<VNode|string>|string}\n */\n searchCodes (textContent) {\n const shortcodes = findShortCodes(textContent);\n const emojis = findEmojis(textContent);\n\n const replaceList = [...shortcodes, ...emojis];\n return this.replaceDtEmojis(replaceList, textContent);\n },\n },\n\n render (h) {\n const defaultSlotContent = this.$slots.default || [];\n return h(\n this.elementType,\n {\n 'data-qa': 'emoji-text-wrapper',\n class: 'd-emoji-text-wrapper',\n },\n this.loadingEmojiJson\n ? defaultSlotContent\n : defaultSlotContent.map(VNode => this.searchVNodes(VNode)),\n );\n },\n};\n</script>\n"],"names":["_sfc_main","DtEmoji","t","ICON_SIZE_MODIFIERS","replaceList","textContent","escapedReplaceList","item","regexp","VNode","children","VNodeChild","shortcodes","findShortCodes","emojis","findEmojis","h","defaultSlotContent"],"mappings":";;;;AASA,MAAAA,IAAA;AAAA,EACA,MAAA;AAAA,EAEA,YAAA;AAAA,IACA,SAAAC;AAAA,EACA;AAAA,EAEA,OAAA;AAAA;AAAA;AAAA;AAAA,IAIA,aAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,MACA,WAAA,CAAAC,MAAA,OAAA,KAAAC,CAAA,EAAA,SAAAD,CAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AACA,WAAA;AAAA,MACA,kBAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,MAAA,UAAA;AACA,SAAA,mBAAA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAKA,gBAAAE,GAAAC,GAAA;AACA,UAAA,CAAAD,EAAA,OAAA,QAAAC;AAEA,YAAAC,IAAAF,EAAA;AAAA,QAAA,CAAAG,MACAA,EAAA,QAAA,OAAA,KAAA;AAAA,MACA,GAEAC,IAAA,IAAA,OAAA,IAAAF,EAAA,KAAA,GAAA,CAAA,KAAA,GAAA;AAGA,aAFAD,EAAA,MAAAG,CAAA,EAGA,OAAA,CAAAD,MAAAA,EAAA,KAAA,MAAA,EAAA,EACA,IAAA,CAAAA,MACAH,EAAA,SAAAG,CAAA,IACA,KAAA,eAAAN,GAAA;AAAA,QACA,OAAA,EAAA,MAAAM,GAAA,MAAA,KAAA,KAAA;AAAA,MACA,CAAA,IAEA,KAAA,eAAA,QAAA,EAAA,OAAA,6BAAA,GAAAA,CAAA,CACA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,aAAAE,GAAA;AAEA,UAAA,CAAAA,EAAA,OAAAA,EAAA;AACA,eAAA,KAAA,YAAAA,EAAA,IAAA;AAGA,YAAAC,IAAAD,EAAA,WAAAA,EAAA,SAAA,IAAA,CAAAE,MAAA,KAAA,aAAAA,CAAA,CAAA,IAAA,CAAA;AACA,aAAA,KAAA,eAAAF,EAAA,KAAAA,EAAA,MAAAC,CAAA;AAAA,IACA;AAAA;AAAA,IAGA,kCAAA;AAAA,IAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,YAAAL,GAAA;AACA,YAAAO,IAAAC,EAAAR,CAAA,GACAS,IAAAC,EAAAV,CAAA,GAEAD,IAAA,CAAA,GAAAQ,GAAA,GAAAE,CAAA;AACA,aAAA,KAAA,gBAAAV,GAAAC,CAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAAW,GAAA;AACA,UAAAC,IAAA,KAAA,OAAA,WAAA,CAAA;AACA,WAAAD;AAAA,MACA,KAAA;AAAA,MACA;AAAA,QACA,WAAA;AAAA,QACA,OAAA;AAAA,MACA;AAAA,MACA,KAAA,mBACAC,IACAA,EAAA,IAAA,CAAAR,MAAA,KAAA,aAAAA,CAAA,CAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"empty-state-constants.cjs","sources":["../../../components/empty_state/empty_state_constants.js"],"sourcesContent":["export const EMPTY_STATE_SIZE_MODIFIERS = {\n sm: 'd-empty-state--size-sm',\n md: 'd-empty-state--size-md',\n lg: 'd-empty-state--size-lg',\n};\n\nexport const EMPTY_STATE_CONTENT_SIZE_MODIFIERS = {\n sm: 'd-empty-state__content--sm',\n md: 'd-empty-state__content--md',\n lg: 'd-empty-state__content--lg',\n};\n\nexport const EMPTY_STATE_HEADLINE_SIZE_MODIFIERS = {\n sm: 'd-headline--md',\n md: 'd-headline--xl',\n lg: 'd-headline--xxl',\n};\n\nexport const EMPTY_STATE_BODY_SIZE_MODIFIERS = {\n sm: 'd-body--sm',\n md: 'd-body--sm',\n lg: 'd-body--md',\n};\n\nexport default {\n EMPTY_STATE_SIZE_MODIFIERS,\n EMPTY_STATE_CONTENT_SIZE_MODIFIERS,\n EMPTY_STATE_HEADLINE_SIZE_MODIFIERS,\n EMPTY_STATE_BODY_SIZE_MODIFIERS,\n};\n"],"names":["EMPTY_STATE_SIZE_MODIFIERS","EMPTY_STATE_CONTENT_SIZE_MODIFIERS","EMPTY_STATE_HEADLINE_SIZE_MODIFIERS","EMPTY_STATE_BODY_SIZE_MODIFIERS","empty_state_constants"],"mappings":"4GAAY,MAACA,EAA6B,CACxC,GAAI,yBACJ,GAAI,yBACJ,GAAI,wBACN,EAEaC,EAAqC,CAChD,GAAI,6BACJ,GAAI,6BACJ,GAAI,4BACN,EAEaC,EAAsC,CACjD,GAAI,iBACJ,GAAI,iBACJ,GAAI,iBACN,EAEaC,EAAkC,CAC7C,GAAI,aACJ,GAAI,aACJ,GAAI,YACN,EAEeC,EAAA,CACb,2BAAAJ,EACA,mCAAAC,EACA,oCAAAC,EACA,gCAAAC,CACF"}
1
+ {"version":3,"file":"empty-state-constants.cjs","sources":["../../../components/empty_state/empty_state_constants.js"],"sourcesContent":["export const EMPTY_STATE_SIZE_MODIFIERS = {\n sm: 'd-empty-state--size-sm',\n md: 'd-empty-state--size-md',\n lg: 'd-empty-state--size-lg',\n};\n\nexport const EMPTY_STATE_CONTENT_SIZE_MODIFIERS = {\n sm: 'd-empty-state__content--sm',\n md: 'd-empty-state__content--md',\n lg: 'd-empty-state__content--lg',\n};\n\nexport const EMPTY_STATE_HEADLINE_SIZE_MODIFIERS = {\n sm: 'd-headline--md',\n md: 'd-headline--xl',\n lg: 'd-headline--xxl',\n};\n\nexport const EMPTY_STATE_BODY_SIZE_MODIFIERS = {\n sm: 'd-body--sm',\n md: 'd-body--sm',\n lg: 'd-body--md',\n};\n\nexport default {\n EMPTY_STATE_SIZE_MODIFIERS,\n EMPTY_STATE_CONTENT_SIZE_MODIFIERS,\n EMPTY_STATE_HEADLINE_SIZE_MODIFIERS,\n EMPTY_STATE_BODY_SIZE_MODIFIERS,\n};\n"],"names":["EMPTY_STATE_SIZE_MODIFIERS","EMPTY_STATE_CONTENT_SIZE_MODIFIERS","EMPTY_STATE_HEADLINE_SIZE_MODIFIERS","EMPTY_STATE_BODY_SIZE_MODIFIERS","empty_state_constants"],"mappings":"4GAAY,MAACA,EAA6B,CACxC,GAAI,yBACJ,GAAI,yBACJ,GAAI,wBACN,EAEaC,EAAqC,CAChD,GAAI,6BACJ,GAAI,6BACJ,GAAI,4BACN,EAEaC,EAAsC,CACjD,GAAI,iBACJ,GAAI,iBACJ,GAAI,iBACN,EAEaC,EAAkC,CAC7C,GAAI,aACJ,GAAI,aACJ,GAAI,YACN,EAEAC,EAAe,CACb,2BAAAJ,EACA,mCAAAC,EACA,oCAAAC,EACA,gCAAAC,CACF"}
@@ -1 +1 @@
1
- {"version":3,"file":"empty-state-constants.js","sources":["../../../components/empty_state/empty_state_constants.js"],"sourcesContent":["export const EMPTY_STATE_SIZE_MODIFIERS = {\n sm: 'd-empty-state--size-sm',\n md: 'd-empty-state--size-md',\n lg: 'd-empty-state--size-lg',\n};\n\nexport const EMPTY_STATE_CONTENT_SIZE_MODIFIERS = {\n sm: 'd-empty-state__content--sm',\n md: 'd-empty-state__content--md',\n lg: 'd-empty-state__content--lg',\n};\n\nexport const EMPTY_STATE_HEADLINE_SIZE_MODIFIERS = {\n sm: 'd-headline--md',\n md: 'd-headline--xl',\n lg: 'd-headline--xxl',\n};\n\nexport const EMPTY_STATE_BODY_SIZE_MODIFIERS = {\n sm: 'd-body--sm',\n md: 'd-body--sm',\n lg: 'd-body--md',\n};\n\nexport default {\n EMPTY_STATE_SIZE_MODIFIERS,\n EMPTY_STATE_CONTENT_SIZE_MODIFIERS,\n EMPTY_STATE_HEADLINE_SIZE_MODIFIERS,\n EMPTY_STATE_BODY_SIZE_MODIFIERS,\n};\n"],"names":["EMPTY_STATE_SIZE_MODIFIERS","EMPTY_STATE_CONTENT_SIZE_MODIFIERS","EMPTY_STATE_HEADLINE_SIZE_MODIFIERS","EMPTY_STATE_BODY_SIZE_MODIFIERS","empty_state_constants"],"mappings":"AAAY,MAACA,IAA6B;AAAA,EACxC,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN,GAEaC,IAAqC;AAAA,EAChD,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN,GAEaC,IAAsC;AAAA,EACjD,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN,GAEaC,IAAkC;AAAA,EAC7C,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN,GAEeC,IAAA;AAAA,EACb,4BAAAJ;AAAA,EACA,oCAAAC;AAAA,EACA,qCAAAC;AAAA,EACA,iCAAAC;AACF;"}
1
+ {"version":3,"file":"empty-state-constants.js","sources":["../../../components/empty_state/empty_state_constants.js"],"sourcesContent":["export const EMPTY_STATE_SIZE_MODIFIERS = {\n sm: 'd-empty-state--size-sm',\n md: 'd-empty-state--size-md',\n lg: 'd-empty-state--size-lg',\n};\n\nexport const EMPTY_STATE_CONTENT_SIZE_MODIFIERS = {\n sm: 'd-empty-state__content--sm',\n md: 'd-empty-state__content--md',\n lg: 'd-empty-state__content--lg',\n};\n\nexport const EMPTY_STATE_HEADLINE_SIZE_MODIFIERS = {\n sm: 'd-headline--md',\n md: 'd-headline--xl',\n lg: 'd-headline--xxl',\n};\n\nexport const EMPTY_STATE_BODY_SIZE_MODIFIERS = {\n sm: 'd-body--sm',\n md: 'd-body--sm',\n lg: 'd-body--md',\n};\n\nexport default {\n EMPTY_STATE_SIZE_MODIFIERS,\n EMPTY_STATE_CONTENT_SIZE_MODIFIERS,\n EMPTY_STATE_HEADLINE_SIZE_MODIFIERS,\n EMPTY_STATE_BODY_SIZE_MODIFIERS,\n};\n"],"names":["EMPTY_STATE_SIZE_MODIFIERS","EMPTY_STATE_CONTENT_SIZE_MODIFIERS","EMPTY_STATE_HEADLINE_SIZE_MODIFIERS","EMPTY_STATE_BODY_SIZE_MODIFIERS","empty_state_constants"],"mappings":"AAAY,MAACA,IAA6B;AAAA,EACxC,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN,GAEaC,IAAqC;AAAA,EAChD,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN,GAEaC,IAAsC;AAAA,EACjD,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN,GAEaC,IAAkC;AAAA,EAC7C,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN,GAEAC,IAAe;AAAA,EACb,4BAAAJ;AAAA,EACA,oCAAAC;AAAA,EACA,qCAAAC;AAAA,EACA,iCAAAC;AACF;"}
@@ -1 +1 @@
1
- {"version":3,"file":"empty-state.cjs","sources":["../../../components/empty_state/empty_state.vue"],"sourcesContent":["<template>\n <dt-stack\n :class=\"emptyStateClasses\"\n >\n <span\n v-if=\"showIllustration\"\n class=\"d-empty-state__illustration\"\n >\n <!-- @slot Slot for the illustration. Displays when size is 'lg' or 'md'. Overrides icon. -->\n <slot name=\"illustration\" />\n </span>\n\n <span\n v-if=\"showIcon\"\n class=\"d-empty-state__icon\"\n >\n <!-- @slot Slot for the icon. Displayed if illustration is not provided. -->\n <slot\n name=\"icon\"\n :icon-size=\"'800'\"\n />\n </span>\n\n <dt-stack\n gap=\"450\"\n :class=\"['d-empty-state__content', contentClass]\"\n >\n <div :class=\"['d-empty-state__header-text', headlineClass]\">\n {{ headerText }}\n </div>\n\n <p\n v-if=\"bodyText\"\n :class=\"['d-empty-state__body-text', bodyClass]\"\n >\n {{ bodyText }}\n </p>\n </dt-stack>\n\n <slot name=\"body\" />\n </dt-stack>\n</template>\n\n<script>\nimport {\n EMPTY_STATE_BODY_SIZE_MODIFIERS,\n EMPTY_STATE_CONTENT_SIZE_MODIFIERS,\n EMPTY_STATE_HEADLINE_SIZE_MODIFIERS,\n EMPTY_STATE_SIZE_MODIFIERS,\n} from './empty_state_constants.js';\nimport { DtStack } from '@/components/stack';\n\nexport default {\n name: 'DtEmptyState',\n\n components: {\n DtStack,\n },\n\n props: {\n /**\n * The empty state size.\n * @values 'sm', 'md', 'lg'\n */\n size: {\n type: String,\n default: 'lg',\n validator: (s) => Object.keys(EMPTY_STATE_SIZE_MODIFIERS).includes(s),\n },\n\n /**\n * Header text\n * @type {String}\n */\n headerText: {\n type: String,\n required: true,\n },\n\n /**\n * Body text\n * @type {String}\n */\n bodyText: {\n type: String,\n default: null,\n },\n },\n\n computed: {\n hasIcon () {\n return this.$scopedSlots.icon && this.$scopedSlots.icon();\n },\n\n hasIllustration () {\n return this.$scopedSlots.illustration && this.$scopedSlots.illustration();\n },\n\n isSmallSize () {\n return this.size === 'sm';\n },\n\n /**\n * Icon will be shown in lg and md size only if illustration is not provided\n * Icon will always be shown in sm size\n */\n showIcon () {\n return this.hasIcon && (!this.hasIllustration || this.isSmallSize);\n },\n\n /**\n * Illustration will always be shown in lg and md size\n * Illustration will not be shown in sm size\n */\n showIllustration () {\n return this.hasIllustration && !this.isSmallSize;\n },\n\n sizeClass () {\n return EMPTY_STATE_SIZE_MODIFIERS[this.size];\n },\n\n emptyStateClasses () {\n return ['d-empty-state', this.sizeClass];\n },\n\n contentClass () {\n return EMPTY_STATE_CONTENT_SIZE_MODIFIERS[this.size];\n },\n\n headlineClass () {\n return EMPTY_STATE_HEADLINE_SIZE_MODIFIERS[this.size];\n },\n\n bodyClass () {\n return EMPTY_STATE_BODY_SIZE_MODIFIERS[this.size];\n },\n },\n\n mounted () {\n if (!this.bodyText && !this.$slots.body) {\n console.error('DtEmptyState: You should provide either bodyText or content on body slot.');\n }\n },\n};\n</script>\n"],"names":["_sfc_main","DtStack","s","EMPTY_STATE_SIZE_MODIFIERS","EMPTY_STATE_CONTENT_SIZE_MODIFIERS","EMPTY_STATE_HEADLINE_SIZE_MODIFIERS","EMPTY_STATE_BODY_SIZE_MODIFIERS"],"mappings":"mPAoDAA,EAAA,CACA,KAAA,eAEA,WAAA,CACA,QAAAC,EAAA,OACA,EAEA,MAAA,CAKA,KAAA,CACA,KAAA,OACA,QAAA,KACA,UAAAC,GAAA,OAAA,KAAAC,4BAAA,EAAA,SAAAD,CAAA,CACA,EAMA,WAAA,CACA,KAAA,OACA,SAAA,EACA,EAMA,SAAA,CACA,KAAA,OACA,QAAA,IACA,CACA,EAEA,SAAA,CACA,SAAA,CACA,OAAA,KAAA,aAAA,MAAA,KAAA,aAAA,MACA,EAEA,iBAAA,CACA,OAAA,KAAA,aAAA,cAAA,KAAA,aAAA,cACA,EAEA,aAAA,CACA,OAAA,KAAA,OAAA,IACA,EAMA,UAAA,CACA,OAAA,KAAA,UAAA,CAAA,KAAA,iBAAA,KAAA,YACA,EAMA,kBAAA,CACA,OAAA,KAAA,iBAAA,CAAA,KAAA,WACA,EAEA,WAAA,CACA,OAAAC,EAAA,2BAAA,KAAA,IAAA,CACA,EAEA,mBAAA,CACA,MAAA,CAAA,gBAAA,KAAA,SAAA,CACA,EAEA,cAAA,CACA,OAAAC,EAAA,mCAAA,KAAA,IAAA,CACA,EAEA,eAAA,CACA,OAAAC,EAAA,oCAAA,KAAA,IAAA,CACA,EAEA,WAAA,CACA,OAAAC,EAAA,gCAAA,KAAA,IAAA,CACA,CACA,EAEA,SAAA,CACA,CAAA,KAAA,UAAA,CAAA,KAAA,OAAA,MACA,QAAA,MAAA,2EAAA,CAEA,CACA"}
1
+ {"version":3,"file":"empty-state.cjs","sources":["../../../components/empty_state/empty_state.vue"],"sourcesContent":["<template>\n <dt-stack\n :class=\"emptyStateClasses\"\n >\n <span\n v-if=\"showIllustration\"\n class=\"d-empty-state__illustration\"\n >\n <!-- @slot Slot for the illustration. Displays when size is 'lg' or 'md'. Overrides icon. -->\n <slot name=\"illustration\" />\n </span>\n\n <span\n v-if=\"showIcon\"\n class=\"d-empty-state__icon\"\n >\n <!-- @slot Slot for the icon. Displayed if illustration is not provided. -->\n <slot\n name=\"icon\"\n :icon-size=\"'800'\"\n />\n </span>\n\n <dt-stack\n gap=\"450\"\n :class=\"['d-empty-state__content', contentClass]\"\n >\n <div :class=\"['d-empty-state__header-text', headlineClass]\">\n {{ headerText }}\n </div>\n\n <p\n v-if=\"bodyText\"\n :class=\"['d-empty-state__body-text', bodyClass]\"\n >\n {{ bodyText }}\n </p>\n </dt-stack>\n\n <slot name=\"body\" />\n </dt-stack>\n</template>\n\n<script>\nimport {\n EMPTY_STATE_BODY_SIZE_MODIFIERS,\n EMPTY_STATE_CONTENT_SIZE_MODIFIERS,\n EMPTY_STATE_HEADLINE_SIZE_MODIFIERS,\n EMPTY_STATE_SIZE_MODIFIERS,\n} from './empty_state_constants.js';\nimport { DtStack } from '@/components/stack';\n\nexport default {\n name: 'DtEmptyState',\n\n components: {\n DtStack,\n },\n\n props: {\n /**\n * The empty state size.\n * @values 'sm', 'md', 'lg'\n */\n size: {\n type: String,\n default: 'lg',\n validator: (s) => Object.keys(EMPTY_STATE_SIZE_MODIFIERS).includes(s),\n },\n\n /**\n * Header text\n * @type {String}\n */\n headerText: {\n type: String,\n required: true,\n },\n\n /**\n * Body text\n * @type {String}\n */\n bodyText: {\n type: String,\n default: null,\n },\n },\n\n computed: {\n hasIcon () {\n return this.$scopedSlots.icon && this.$scopedSlots.icon();\n },\n\n hasIllustration () {\n return this.$scopedSlots.illustration && this.$scopedSlots.illustration();\n },\n\n isSmallSize () {\n return this.size === 'sm';\n },\n\n /**\n * Icon will be shown in lg and md size only if illustration is not provided\n * Icon will always be shown in sm size\n */\n showIcon () {\n return this.hasIcon && (!this.hasIllustration || this.isSmallSize);\n },\n\n /**\n * Illustration will always be shown in lg and md size\n * Illustration will not be shown in sm size\n */\n showIllustration () {\n return this.hasIllustration && !this.isSmallSize;\n },\n\n sizeClass () {\n return EMPTY_STATE_SIZE_MODIFIERS[this.size];\n },\n\n emptyStateClasses () {\n return ['d-empty-state', this.sizeClass];\n },\n\n contentClass () {\n return EMPTY_STATE_CONTENT_SIZE_MODIFIERS[this.size];\n },\n\n headlineClass () {\n return EMPTY_STATE_HEADLINE_SIZE_MODIFIERS[this.size];\n },\n\n bodyClass () {\n return EMPTY_STATE_BODY_SIZE_MODIFIERS[this.size];\n },\n },\n\n mounted () {\n if (!this.bodyText && !this.$slots.body) {\n console.error('DtEmptyState: You should provide either bodyText or content on body slot.');\n }\n },\n};\n</script>\n"],"names":["_sfc_main","DtStack","s","EMPTY_STATE_SIZE_MODIFIERS","EMPTY_STATE_CONTENT_SIZE_MODIFIERS","EMPTY_STATE_HEADLINE_SIZE_MODIFIERS","EMPTY_STATE_BODY_SIZE_MODIFIERS"],"mappings":"mPAoDAA,EAAA,CACA,KAAA,eAEA,WAAA,CACA,QAAAC,EAAAA,OACA,EAEA,MAAA,CAKA,KAAA,CACA,KAAA,OACA,QAAA,KACA,UAAAC,GAAA,OAAA,KAAAC,4BAAA,EAAA,SAAAD,CAAA,CACA,EAMA,WAAA,CACA,KAAA,OACA,SAAA,EACA,EAMA,SAAA,CACA,KAAA,OACA,QAAA,IACA,CACA,EAEA,SAAA,CACA,SAAA,CACA,OAAA,KAAA,aAAA,MAAA,KAAA,aAAA,KAAA,CACA,EAEA,iBAAA,CACA,OAAA,KAAA,aAAA,cAAA,KAAA,aAAA,aAAA,CACA,EAEA,aAAA,CACA,OAAA,KAAA,OAAA,IACA,EAMA,UAAA,CACA,OAAA,KAAA,UAAA,CAAA,KAAA,iBAAA,KAAA,YACA,EAMA,kBAAA,CACA,OAAA,KAAA,iBAAA,CAAA,KAAA,WACA,EAEA,WAAA,CACA,OAAAC,EAAAA,2BAAA,KAAA,IAAA,CACA,EAEA,mBAAA,CACA,MAAA,CAAA,gBAAA,KAAA,SAAA,CACA,EAEA,cAAA,CACA,OAAAC,EAAAA,mCAAA,KAAA,IAAA,CACA,EAEA,eAAA,CACA,OAAAC,EAAAA,oCAAA,KAAA,IAAA,CACA,EAEA,WAAA,CACA,OAAAC,EAAAA,gCAAA,KAAA,IAAA,CACA,CACA,EAEA,SAAA,CACA,CAAA,KAAA,UAAA,CAAA,KAAA,OAAA,MACA,QAAA,MAAA,2EAAA,CAEA,CACA"}
@@ -1,4 +1,4 @@
1
- import { EMPTY_STATE_SIZE_MODIFIERS as o, EMPTY_STATE_CONTENT_SIZE_MODIFIERS as a, EMPTY_STATE_HEADLINE_SIZE_MODIFIERS as i, EMPTY_STATE_BODY_SIZE_MODIFIERS as n } from "./empty-state-constants.js";
1
+ import { EMPTY_STATE_BODY_SIZE_MODIFIERS as a, EMPTY_STATE_HEADLINE_SIZE_MODIFIERS as i, EMPTY_STATE_CONTENT_SIZE_MODIFIERS as n, EMPTY_STATE_SIZE_MODIFIERS as o } from "./empty-state-constants.js";
2
2
  import { n as r } from "../../_plugin-vue2_normalizer-DSLOjnn3.js";
3
3
  import l from "../stack/stack.js";
4
4
  const _ = {
@@ -64,13 +64,13 @@ const _ = {
64
64
  return ["d-empty-state", this.sizeClass];
65
65
  },
66
66
  contentClass() {
67
- return a[this.size];
67
+ return n[this.size];
68
68
  },
69
69
  headlineClass() {
70
70
  return i[this.size];
71
71
  },
72
72
  bodyClass() {
73
- return n[this.size];
73
+ return a[this.size];
74
74
  }
75
75
  },
76
76
  mounted() {