@nextcloud/vue 8.22.0 → 8.23.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 (451) hide show
  1. package/CHANGELOG.md +78 -0
  2. package/README.md +71 -65
  3. package/dist/Components/NcActionButton.cjs +1 -1
  4. package/dist/Components/NcActionButton.mjs +1 -1
  5. package/dist/Components/NcActionButtonGroup.cjs +1 -1
  6. package/dist/Components/NcActionButtonGroup.mjs +1 -1
  7. package/dist/Components/NcActionCaption.cjs +2 -2
  8. package/dist/Components/NcActionCaption.cjs.map +1 -1
  9. package/dist/Components/NcActionCaption.mjs +2 -2
  10. package/dist/Components/NcActionCaption.mjs.map +1 -1
  11. package/dist/Components/NcActionCheckbox.cjs +1 -1
  12. package/dist/Components/NcActionCheckbox.mjs +1 -1
  13. package/dist/Components/NcActionInput.cjs +1 -1
  14. package/dist/Components/NcActionInput.mjs +1 -1
  15. package/dist/Components/NcActionLink.cjs +1 -1
  16. package/dist/Components/NcActionLink.mjs +1 -1
  17. package/dist/Components/NcActionRadio.cjs +1 -1
  18. package/dist/Components/NcActionRadio.mjs +1 -1
  19. package/dist/Components/NcActionRouter.cjs +1 -1
  20. package/dist/Components/NcActionRouter.mjs +1 -1
  21. package/dist/Components/NcActionText.cjs +1 -1
  22. package/dist/Components/NcActionText.mjs +1 -1
  23. package/dist/Components/NcActionTextEditable.cjs +1 -1
  24. package/dist/Components/NcActionTextEditable.mjs +1 -1
  25. package/dist/Components/NcActions.cjs +1 -1
  26. package/dist/Components/NcActions.mjs +1 -1
  27. package/dist/Components/NcAppContent.cjs +1 -1
  28. package/dist/Components/NcAppContent.mjs +1 -1
  29. package/dist/Components/NcAppNavigation.cjs +1 -1
  30. package/dist/Components/NcAppNavigation.mjs +1 -1
  31. package/dist/Components/NcAppNavigationCaption.cjs +1 -1
  32. package/dist/Components/NcAppNavigationCaption.mjs +1 -1
  33. package/dist/Components/NcAppNavigationItem.cjs +1 -1
  34. package/dist/Components/NcAppNavigationItem.mjs +1 -1
  35. package/dist/Components/NcAppNavigationNewItem.cjs +1 -1
  36. package/dist/Components/NcAppNavigationNewItem.mjs +1 -1
  37. package/dist/Components/NcAppNavigationSearch.cjs +1 -1
  38. package/dist/Components/NcAppNavigationSearch.mjs +1 -1
  39. package/dist/Components/NcAppNavigationSettings.cjs +1 -1
  40. package/dist/Components/NcAppNavigationSettings.mjs +1 -1
  41. package/dist/Components/NcAppNavigationToggle.cjs +1 -1
  42. package/dist/Components/NcAppNavigationToggle.mjs +1 -1
  43. package/dist/Components/NcAppSettingsDialog.cjs +1 -1
  44. package/dist/Components/NcAppSettingsDialog.mjs +1 -1
  45. package/dist/Components/NcAppSidebar.cjs +1 -1
  46. package/dist/Components/NcAppSidebar.mjs +1 -1
  47. package/dist/Components/NcAvatar.cjs +1 -1
  48. package/dist/Components/NcAvatar.mjs +1 -1
  49. package/dist/Components/NcBreadcrumb.cjs +1 -1
  50. package/dist/Components/NcBreadcrumb.mjs +1 -1
  51. package/dist/Components/NcBreadcrumbs.cjs +1 -1
  52. package/dist/Components/NcBreadcrumbs.mjs +1 -1
  53. package/dist/Components/NcButton.cjs +2 -2
  54. package/dist/Components/NcButton.cjs.map +1 -1
  55. package/dist/Components/NcButton.mjs +2 -2
  56. package/dist/Components/NcButton.mjs.map +1 -1
  57. package/dist/Components/NcCheckboxRadioSwitch.cjs +1 -1
  58. package/dist/Components/NcCheckboxRadioSwitch.mjs +1 -1
  59. package/dist/Components/NcChip.cjs +3 -3
  60. package/dist/Components/NcChip.mjs +3 -3
  61. package/dist/Components/NcCollectionList.cjs +1 -1
  62. package/dist/Components/NcCollectionList.mjs +1 -1
  63. package/dist/Components/NcColorPicker.cjs +1 -1
  64. package/dist/Components/NcColorPicker.mjs +1 -1
  65. package/dist/Components/NcContent.cjs +1 -1
  66. package/dist/Components/NcContent.mjs +1 -1
  67. package/dist/Components/NcCounterBubble.cjs +1 -1
  68. package/dist/Components/NcCounterBubble.mjs +1 -1
  69. package/dist/Components/NcDashboardWidget.cjs +1 -1
  70. package/dist/Components/NcDashboardWidget.mjs +1 -1
  71. package/dist/Components/NcDashboardWidgetItem.cjs +1 -1
  72. package/dist/Components/NcDashboardWidgetItem.mjs +1 -1
  73. package/dist/Components/NcDateTime.cjs +1 -1
  74. package/dist/Components/NcDateTime.mjs +1 -1
  75. package/dist/Components/NcDateTimePicker.cjs +5 -5
  76. package/dist/Components/NcDateTimePicker.mjs +5 -5
  77. package/dist/Components/NcDateTimePickerNative.cjs +22 -18
  78. package/dist/Components/NcDateTimePickerNative.cjs.map +1 -1
  79. package/dist/Components/NcDateTimePickerNative.mjs +22 -18
  80. package/dist/Components/NcDateTimePickerNative.mjs.map +1 -1
  81. package/dist/Components/NcDialog.cjs +1 -1
  82. package/dist/Components/NcDialog.mjs +1 -1
  83. package/dist/Components/NcDialogButton.cjs +1 -1
  84. package/dist/Components/NcDialogButton.mjs +1 -1
  85. package/dist/Components/NcEmojiPicker.cjs +1 -1
  86. package/dist/Components/NcEmojiPicker.mjs +1 -1
  87. package/dist/Components/NcHeaderButton.cjs +2 -2
  88. package/dist/Components/NcHeaderButton.cjs.map +1 -1
  89. package/dist/Components/NcHeaderButton.mjs +2 -2
  90. package/dist/Components/NcHeaderButton.mjs.map +1 -1
  91. package/dist/Components/NcHeaderMenu.cjs +1 -1
  92. package/dist/Components/NcHeaderMenu.mjs +1 -1
  93. package/dist/Components/NcInputField.cjs +1 -1
  94. package/dist/Components/NcInputField.mjs +1 -1
  95. package/dist/Components/NcListItem.cjs +1 -1
  96. package/dist/Components/NcListItem.mjs +1 -1
  97. package/dist/Components/NcListItemIcon.cjs +1 -1
  98. package/dist/Components/NcListItemIcon.mjs +1 -1
  99. package/dist/Components/NcModal.cjs +50 -20
  100. package/dist/Components/NcModal.cjs.map +1 -1
  101. package/dist/Components/NcModal.mjs +51 -21
  102. package/dist/Components/NcModal.mjs.map +1 -1
  103. package/dist/Components/NcPasswordField.cjs +1 -1
  104. package/dist/Components/NcPasswordField.mjs +1 -1
  105. package/dist/Components/NcPopover.cjs +1 -1
  106. package/dist/Components/NcPopover.mjs +1 -1
  107. package/dist/Components/NcRelatedResourcesPanel.cjs +1 -1
  108. package/dist/Components/NcRelatedResourcesPanel.mjs +1 -1
  109. package/dist/Components/NcRichContenteditable.cjs +2 -2
  110. package/dist/Components/NcRichContenteditable.mjs +2 -2
  111. package/dist/Components/NcRichText.cjs +2 -2
  112. package/dist/Components/NcRichText.mjs +3 -3
  113. package/dist/Components/NcSelect.cjs +1 -1
  114. package/dist/Components/NcSelect.mjs +1 -1
  115. package/dist/Components/NcSelectTags.cjs +1 -1
  116. package/dist/Components/NcSelectTags.mjs +1 -1
  117. package/dist/Components/NcSettingsInputText.cjs +1 -1
  118. package/dist/Components/NcSettingsInputText.mjs +1 -1
  119. package/dist/Components/NcSettingsSection.cjs +1 -1
  120. package/dist/Components/NcSettingsSection.mjs +1 -1
  121. package/dist/Components/NcSettingsSelectGroup.cjs +1 -1
  122. package/dist/Components/NcSettingsSelectGroup.mjs +1 -1
  123. package/dist/Components/NcTextField.cjs +1 -1
  124. package/dist/Components/NcTextField.mjs +1 -1
  125. package/dist/Components/NcTimezonePicker.cjs +1 -1
  126. package/dist/Components/NcTimezonePicker.mjs +1 -1
  127. package/dist/Components/NcUserBubble.cjs +1 -1
  128. package/dist/Components/NcUserBubble.mjs +1 -1
  129. package/dist/Components/NcUserStatusIcon.cjs +1 -1
  130. package/dist/Components/NcUserStatusIcon.mjs +1 -1
  131. package/dist/Directives/Linkify.cjs +14 -2
  132. package/dist/Directives/Linkify.cjs.map +1 -1
  133. package/dist/Directives/Linkify.mjs +11 -1
  134. package/dist/Directives/Linkify.mjs.map +1 -1
  135. package/dist/Functions/reference.cjs +1 -1
  136. package/dist/Functions/reference.mjs +1 -1
  137. package/dist/Functions/usernameToColor.cjs +1 -1
  138. package/dist/Functions/usernameToColor.mjs +1 -1
  139. package/dist/Mixins/richEditor.cjs +1 -2
  140. package/dist/Mixins/richEditor.cjs.map +1 -1
  141. package/dist/Mixins/richEditor.mjs +1 -2
  142. package/dist/Mixins/richEditor.mjs.map +1 -1
  143. package/dist/assets/{NcActionButton-BT4157Cp.css → NcActionButton-BYN2SUN0.css} +4 -2
  144. package/dist/assets/{NcActionCaption-JVhz4Wp7.css → NcActionCaption-BNDtcWJ7.css} +4 -4
  145. package/dist/assets/{NcActionCheckbox-DeW2CCVc.css → NcActionCheckbox-Dan0EvGm.css} +18 -18
  146. package/dist/assets/{NcActionInput-CNRERfyh.css → NcActionInput-Dz21fyVD.css} +69 -65
  147. package/dist/assets/{NcActionLink-BNtI-AlZ.css → NcActionLink-BG9B9dP4.css} +4 -2
  148. package/dist/assets/{NcActionRadio-DC7Wp9rR.css → NcActionRadio-C87waXE-.css} +18 -18
  149. package/dist/assets/{NcActionRouter-As2g7t6k.css → NcActionRouter-BAGuUfFu.css} +4 -2
  150. package/dist/assets/{NcActionText-NhGjKgRO.css → NcActionText-Cjp26Bn0.css} +4 -2
  151. package/dist/assets/{NcActionTextEditable-Cg16Q4zr.css → NcActionTextEditable-1TXeJ5zp.css} +68 -64
  152. package/dist/assets/{NcActions-DM_LoRlx.css → NcActions-C4SuFczn.css} +12 -15
  153. package/dist/assets/{NcAppContent-CsPEhdzg.css → NcAppContent-BO0ksFwD.css} +19 -19
  154. package/dist/assets/{NcAppNavigationCaption-Dt5K_hKD.css → NcAppNavigationCaption-DU9PxTvu.css} +9 -9
  155. package/dist/assets/{NcAppNavigationItem-DIv6Iu_R.css → NcAppNavigationItem-lh9Say1M.css} +9 -9
  156. package/dist/assets/{NcAppNavigationNewItem-CQ1f40wK.css → NcAppNavigationNewItem-fUP3wQTQ.css} +37 -37
  157. package/dist/assets/{NcAppNavigationSettings-BV_QS8jh.css → NcAppNavigationSettings-vd47rlNY.css} +14 -14
  158. package/dist/assets/{NcAvatar-DstXjzVh.css → NcAvatar-CcJlFpcI.css} +25 -25
  159. package/dist/assets/{NcButton-BHDLon1_.css → NcButton-CfOAX-eQ.css} +47 -47
  160. package/dist/assets/{NcColorPicker-Dw2wy2tU.css → NcColorPicker-C1DuuANb.css} +28 -28
  161. package/dist/assets/{NcCounterBubble-DdYmHnng.css → NcCounterBubble-CI-DxLjL.css} +7 -7
  162. package/dist/assets/{NcDateTimePicker-BmtdlJm4.css → NcDateTimePicker-BtV9Fz-n.css} +22 -17
  163. package/dist/assets/NcDateTimePickerNative-DVGEymgr.css +60 -0
  164. package/dist/assets/{NcEmojiPicker-BNCW1Q94.css → NcEmojiPicker-rk5qcSl7.css} +75 -57
  165. package/dist/assets/{NcHeaderButton-DH4Qtw3P.css → NcHeaderButton-BPkJ5wxD.css} +7 -7
  166. package/dist/assets/{NcHeaderMenu-C2XbJMYL.css → NcHeaderMenu-BYjnMPPl.css} +11 -11
  167. package/dist/assets/{NcInputField-CUsdr7lV.css → NcInputField-CzryIHRa.css} +32 -32
  168. package/dist/assets/{NcListItem-DQ2Dk7jn.css → NcListItem-GE5S37TT.css} +48 -47
  169. package/dist/assets/{NcMentionBubble-Bt71nB8X.css → NcMentionBubble-BL05HUeF.css} +12 -13
  170. package/dist/assets/{NcModal-IUKZfPNs.css → NcModal-ZfCDJxwd.css} +63 -61
  171. package/dist/assets/{NcPasswordField-B0VbIU2n.css → NcPasswordField-whtKJFcB.css} +2 -2
  172. package/dist/assets/{NcPopover-TS4CW9MJ.css → NcPopover-DpakVVxI.css} +16 -5
  173. package/dist/assets/{NcRelatedResourcesPanel-DIhZx6lY.css → NcRelatedResourcesPanel-DSf7TVcC.css} +14 -14
  174. package/dist/assets/{NcRichContenteditable-DoDTb8p_.css → NcRichContenteditable-BV6g3dmd.css} +41 -39
  175. package/dist/assets/NcRichText-zt8ALFHi.css +323 -0
  176. package/dist/assets/{NcUserBubble-CNid1YOT.css → NcUserBubble-BsTKRhKz.css} +11 -11
  177. package/dist/assets/{referencePickerModal-BhhuyO3J.css → referencePickerModal-CTumspFH.css} +46 -46
  178. package/dist/chunks/{GenColors-l51faA-J.mjs → GenColors-DfwXw1-o.mjs} +1 -1
  179. package/dist/chunks/{GenColors-l51faA-J.mjs.map → GenColors-DfwXw1-o.mjs.map} +1 -1
  180. package/dist/chunks/{GenColors-NLLtT2OM.cjs → GenColors-Di5GSft7.cjs} +1 -1
  181. package/dist/chunks/{GenColors-NLLtT2OM.cjs.map → GenColors-Di5GSft7.cjs.map} +1 -1
  182. package/dist/chunks/{NcActionButton-82_1gdid.mjs → NcActionButton-CEysTg4c.mjs} +1 -1
  183. package/dist/chunks/{NcActionButton-82_1gdid.mjs.map → NcActionButton-CEysTg4c.mjs.map} +1 -1
  184. package/dist/chunks/{NcActionButton-DHOce_KX.cjs → NcActionButton-DcpUnqA7.cjs} +1 -1
  185. package/dist/chunks/{NcActionButton-DHOce_KX.cjs.map → NcActionButton-DcpUnqA7.cjs.map} +1 -1
  186. package/dist/chunks/{NcActionButtonGroup-BSh2wd9F.mjs → NcActionButtonGroup-3v-qy9C0.mjs} +1 -1
  187. package/dist/chunks/{NcActionButtonGroup-BSh2wd9F.mjs.map → NcActionButtonGroup-3v-qy9C0.mjs.map} +1 -1
  188. package/dist/chunks/{NcActionButtonGroup-MCHURlnG.cjs → NcActionButtonGroup-x6D7S13W.cjs} +1 -1
  189. package/dist/chunks/{NcActionButtonGroup-MCHURlnG.cjs.map → NcActionButtonGroup-x6D7S13W.cjs.map} +1 -1
  190. package/dist/chunks/{NcActionCheckbox-C_wvm9IO.mjs → NcActionCheckbox-BnL71Qmi.mjs} +2 -2
  191. package/dist/chunks/{NcActionCheckbox-C_wvm9IO.mjs.map → NcActionCheckbox-BnL71Qmi.mjs.map} +1 -1
  192. package/dist/chunks/{NcActionCheckbox-DwU16qcU.cjs → NcActionCheckbox-Dd5Y6f63.cjs} +2 -2
  193. package/dist/chunks/{NcActionCheckbox-DwU16qcU.cjs.map → NcActionCheckbox-Dd5Y6f63.cjs.map} +1 -1
  194. package/dist/chunks/{NcActionInput-D1yrXgXY.mjs → NcActionInput-BAM8T3gm.mjs} +6 -6
  195. package/dist/chunks/{NcActionInput-D1yrXgXY.mjs.map → NcActionInput-BAM8T3gm.mjs.map} +1 -1
  196. package/dist/chunks/{NcActionInput-DlLBUp3P.cjs → NcActionInput-VR510EDJ.cjs} +6 -6
  197. package/dist/chunks/{NcActionInput-DlLBUp3P.cjs.map → NcActionInput-VR510EDJ.cjs.map} +1 -1
  198. package/dist/chunks/{NcActionRadio-vHwjWOHS.cjs → NcActionRadio-BQ0jAh5V.cjs} +16 -8
  199. package/dist/chunks/NcActionRadio-BQ0jAh5V.cjs.map +1 -0
  200. package/dist/chunks/{NcActionRadio-Dl6W62Vm.mjs → NcActionRadio-CCTupqRR.mjs} +14 -8
  201. package/dist/chunks/NcActionRadio-CCTupqRR.mjs.map +1 -0
  202. package/dist/chunks/{NcActionTextEditable-97R7dFen.cjs → NcActionTextEditable-C-ZP8_Tn.cjs} +8 -4
  203. package/dist/chunks/NcActionTextEditable-C-ZP8_Tn.cjs.map +1 -0
  204. package/dist/chunks/{NcActionTextEditable-DZCFtqIP.mjs → NcActionTextEditable-JRD-G0CT.mjs} +8 -4
  205. package/dist/chunks/NcActionTextEditable-JRD-G0CT.mjs.map +1 -0
  206. package/dist/chunks/{NcActions-BVdJOuja.mjs → NcActions-D3hGxwlc.mjs} +5 -30
  207. package/dist/chunks/{NcActions-Vrs_fNJp.cjs.map → NcActions-D3hGxwlc.mjs.map} +1 -1
  208. package/dist/chunks/{NcActions-Vrs_fNJp.cjs → NcActions-DTICeoTz.cjs} +5 -30
  209. package/dist/chunks/{NcActions-BVdJOuja.mjs.map → NcActions-DTICeoTz.cjs.map} +1 -1
  210. package/dist/chunks/{NcAppContent-BuY1ebnE.mjs → NcAppContent-BKQ-H04y.mjs} +14 -5
  211. package/dist/chunks/NcAppContent-BKQ-H04y.mjs.map +1 -0
  212. package/dist/chunks/{NcAppContent-BhXzPGUR.cjs → NcAppContent-BOt6_YA7.cjs} +14 -5
  213. package/dist/chunks/NcAppContent-BOt6_YA7.cjs.map +1 -0
  214. package/dist/chunks/{NcAppNavigation-Dgg_3EFP.mjs → NcAppNavigation-B_92V8o3.mjs} +1 -1
  215. package/dist/chunks/{NcAppNavigation-Dgg_3EFP.mjs.map → NcAppNavigation-B_92V8o3.mjs.map} +1 -1
  216. package/dist/chunks/{NcAppNavigation-3qOqHlZL.cjs → NcAppNavigation-D7W-4cVo.cjs} +1 -1
  217. package/dist/chunks/{NcAppNavigation-3qOqHlZL.cjs.map → NcAppNavigation-D7W-4cVo.cjs.map} +1 -1
  218. package/dist/chunks/{NcAppNavigationCaption-BXzy7pSk.mjs → NcAppNavigationCaption-B3w692fN.mjs} +3 -3
  219. package/dist/chunks/{NcAppNavigationCaption-BXzy7pSk.mjs.map → NcAppNavigationCaption-B3w692fN.mjs.map} +1 -1
  220. package/dist/chunks/{NcAppNavigationCaption-BsR_h0__.cjs → NcAppNavigationCaption-BDqTyLIj.cjs} +3 -3
  221. package/dist/chunks/{NcAppNavigationCaption-BsR_h0__.cjs.map → NcAppNavigationCaption-BDqTyLIj.cjs.map} +1 -1
  222. package/dist/chunks/{NcAppNavigationItem-C8Qq4tF5.mjs → NcAppNavigationItem-CpcFOmJR.mjs} +6 -6
  223. package/dist/chunks/NcAppNavigationItem-CpcFOmJR.mjs.map +1 -0
  224. package/dist/chunks/{NcAppNavigationItem-boljzMEm.cjs → NcAppNavigationItem-DL9OwWo-.cjs} +6 -6
  225. package/dist/chunks/NcAppNavigationItem-DL9OwWo-.cjs.map +1 -0
  226. package/dist/chunks/{NcAppNavigationNewItem-DVPBJE3U.cjs → NcAppNavigationNewItem-BaKxxZqt.cjs} +3 -3
  227. package/dist/chunks/{NcAppNavigationNewItem-DVPBJE3U.cjs.map → NcAppNavigationNewItem-BaKxxZqt.cjs.map} +1 -1
  228. package/dist/chunks/{NcAppNavigationNewItem-B_xMcFfc.mjs → NcAppNavigationNewItem-BvQaVuL6.mjs} +3 -3
  229. package/dist/chunks/{NcAppNavigationNewItem-B_xMcFfc.mjs.map → NcAppNavigationNewItem-BvQaVuL6.mjs.map} +1 -1
  230. package/dist/chunks/{NcAppNavigationSearch-BcTPJyAH.cjs → NcAppNavigationSearch-Q0eMy5I2.cjs} +2 -2
  231. package/dist/chunks/{NcAppNavigationSearch-BcTPJyAH.cjs.map → NcAppNavigationSearch-Q0eMy5I2.cjs.map} +1 -1
  232. package/dist/chunks/{NcAppNavigationSearch-C_TVvxZh.mjs → NcAppNavigationSearch-gytpBKme.mjs} +2 -2
  233. package/dist/chunks/{NcAppNavigationSearch-C_TVvxZh.mjs.map → NcAppNavigationSearch-gytpBKme.mjs.map} +1 -1
  234. package/dist/chunks/{NcAppNavigationSettings-CST0dabX.mjs → NcAppNavigationSettings-CZFm1d-N.mjs} +4 -5
  235. package/dist/chunks/{NcAppNavigationSettings-CST0dabX.mjs.map → NcAppNavigationSettings-CZFm1d-N.mjs.map} +1 -1
  236. package/dist/chunks/{NcAppNavigationSettings-DO0f3tDe.cjs → NcAppNavigationSettings-CwwmvKYV.cjs} +4 -5
  237. package/dist/chunks/{NcAppNavigationSettings-DO0f3tDe.cjs.map → NcAppNavigationSettings-CwwmvKYV.cjs.map} +1 -1
  238. package/dist/chunks/{NcAppNavigationToggle-DC1ueYFW.cjs → NcAppNavigationToggle-Br1hcFGt.cjs} +1 -1
  239. package/dist/chunks/{NcAppNavigationToggle-DC1ueYFW.cjs.map → NcAppNavigationToggle-Br1hcFGt.cjs.map} +1 -1
  240. package/dist/chunks/{NcAppNavigationToggle-CyRacXd1.mjs → NcAppNavigationToggle-Pr8bEpDs.mjs} +1 -1
  241. package/dist/chunks/{NcAppNavigationToggle-CyRacXd1.mjs.map → NcAppNavigationToggle-Pr8bEpDs.mjs.map} +1 -1
  242. package/dist/chunks/{NcAppSettingsDialog-BW0P_DJq.mjs → NcAppSettingsDialog-JPB-srka.mjs} +2 -2
  243. package/dist/chunks/{NcAppSettingsDialog-BW0P_DJq.mjs.map → NcAppSettingsDialog-JPB-srka.mjs.map} +1 -1
  244. package/dist/chunks/{NcAppSettingsDialog-CcCa2tJf.cjs → NcAppSettingsDialog-z9v6V6ye.cjs} +2 -2
  245. package/dist/chunks/{NcAppSettingsDialog-CcCa2tJf.cjs.map → NcAppSettingsDialog-z9v6V6ye.cjs.map} +1 -1
  246. package/dist/chunks/{NcAppSidebar-Dq-zojSu.cjs → NcAppSidebar-BY33yoNX.cjs} +3 -3
  247. package/dist/chunks/{NcAppSidebar-Dq-zojSu.cjs.map → NcAppSidebar-BY33yoNX.cjs.map} +1 -1
  248. package/dist/chunks/{NcAppSidebar-BC_h_duv.mjs → NcAppSidebar-cEQy8s50.mjs} +3 -3
  249. package/dist/chunks/{NcAppSidebar-BC_h_duv.mjs.map → NcAppSidebar-cEQy8s50.mjs.map} +1 -1
  250. package/dist/chunks/{NcAvatar-CT6DLUhQ.mjs → NcAvatar-BjwyJw34.mjs} +11 -12
  251. package/dist/chunks/NcAvatar-BjwyJw34.mjs.map +1 -0
  252. package/dist/chunks/{NcAvatar-D4E0ptkW.cjs → NcAvatar-CQtsmbBW.cjs} +11 -12
  253. package/dist/chunks/NcAvatar-CQtsmbBW.cjs.map +1 -0
  254. package/dist/chunks/{NcBreadcrumb-B0-rwsl8.cjs → NcBreadcrumb-DrlhnNbV.cjs} +1 -1
  255. package/dist/chunks/{NcBreadcrumb-B0-rwsl8.cjs.map → NcBreadcrumb-DrlhnNbV.cjs.map} +1 -1
  256. package/dist/chunks/{NcBreadcrumb-LVdLi11j.mjs → NcBreadcrumb-GHiD-Sw7.mjs} +1 -1
  257. package/dist/chunks/{NcBreadcrumb-LVdLi11j.mjs.map → NcBreadcrumb-GHiD-Sw7.mjs.map} +1 -1
  258. package/dist/chunks/{NcBreadcrumbs-C1L5IrRV.cjs → NcBreadcrumbs-Cde4tv8l.cjs} +3 -3
  259. package/dist/chunks/{NcBreadcrumbs-C1L5IrRV.cjs.map → NcBreadcrumbs-Cde4tv8l.cjs.map} +1 -1
  260. package/dist/chunks/{NcBreadcrumbs-BiRI0VOa.mjs → NcBreadcrumbs-D0Hhym9A.mjs} +3 -3
  261. package/dist/chunks/{NcBreadcrumbs-BiRI0VOa.mjs.map → NcBreadcrumbs-D0Hhym9A.mjs.map} +1 -1
  262. package/dist/chunks/{NcCheckboxRadioSwitch-Dm_27r-z.mjs → NcCheckboxRadioSwitch-CCuKA55c.mjs} +1 -1
  263. package/dist/chunks/{NcCheckboxRadioSwitch-Dm_27r-z.mjs.map → NcCheckboxRadioSwitch-CCuKA55c.mjs.map} +1 -1
  264. package/dist/chunks/{NcCheckboxRadioSwitch-DP-rnk4f.cjs → NcCheckboxRadioSwitch-RjEq0SqY.cjs} +1 -1
  265. package/dist/chunks/{NcCheckboxRadioSwitch-DP-rnk4f.cjs.map → NcCheckboxRadioSwitch-RjEq0SqY.cjs.map} +1 -1
  266. package/dist/chunks/{NcCollectionList-C4JoCivp.mjs → NcCollectionList-BNxu1MWE.mjs} +5 -5
  267. package/dist/chunks/{NcCollectionList-C4JoCivp.mjs.map → NcCollectionList-BNxu1MWE.mjs.map} +1 -1
  268. package/dist/chunks/{NcCollectionList-tLuZ9fZk.cjs → NcCollectionList-fyDi2W_B.cjs} +5 -5
  269. package/dist/chunks/{NcCollectionList-tLuZ9fZk.cjs.map → NcCollectionList-fyDi2W_B.cjs.map} +1 -1
  270. package/dist/chunks/{NcColorPicker-rWet3ND8.cjs → NcColorPicker-CTQlyVCL.cjs} +23 -18
  271. package/dist/chunks/NcColorPicker-CTQlyVCL.cjs.map +1 -0
  272. package/dist/chunks/{NcColorPicker-CODhE5KL.mjs → NcColorPicker-ph8Nubq7.mjs} +23 -18
  273. package/dist/chunks/NcColorPicker-ph8Nubq7.mjs.map +1 -0
  274. package/dist/chunks/{NcContent-CmCMVNVu.cjs → NcContent-CJNhr5lF.cjs} +1 -1
  275. package/dist/chunks/{NcContent-CmCMVNVu.cjs.map → NcContent-CJNhr5lF.cjs.map} +1 -1
  276. package/dist/chunks/{NcContent-D7q7hI8k.mjs → NcContent-RlppaZCX.mjs} +1 -1
  277. package/dist/chunks/{NcContent-D7q7hI8k.mjs.map → NcContent-RlppaZCX.mjs.map} +1 -1
  278. package/dist/chunks/{NcCounterBubble-DF2rwIo4.cjs → NcCounterBubble-BRrUO34D.cjs} +19 -8
  279. package/dist/chunks/{NcCounterBubble-DF2rwIo4.cjs.map → NcCounterBubble-BRrUO34D.cjs.map} +1 -1
  280. package/dist/chunks/{NcCounterBubble-M1q9GRkH.mjs → NcCounterBubble-CDfRYl8B.mjs} +19 -8
  281. package/dist/chunks/{NcCounterBubble-M1q9GRkH.mjs.map → NcCounterBubble-CDfRYl8B.mjs.map} +1 -1
  282. package/dist/chunks/{NcDashboardWidget-DND0u_84.cjs → NcDashboardWidget-CirRHHmT.cjs} +3 -3
  283. package/dist/chunks/{NcDashboardWidget-DND0u_84.cjs.map → NcDashboardWidget-CirRHHmT.cjs.map} +1 -1
  284. package/dist/chunks/{NcDashboardWidget-CU5MNmVJ.mjs → NcDashboardWidget-Dg12xu50.mjs} +3 -3
  285. package/dist/chunks/{NcDashboardWidget-CU5MNmVJ.mjs.map → NcDashboardWidget-Dg12xu50.mjs.map} +1 -1
  286. package/dist/chunks/{NcDashboardWidgetItem-DXmFRgPS.cjs → NcDashboardWidgetItem-COONyn0g.cjs} +3 -3
  287. package/dist/chunks/{NcDashboardWidgetItem-DXmFRgPS.cjs.map → NcDashboardWidgetItem-COONyn0g.cjs.map} +1 -1
  288. package/dist/chunks/{NcDashboardWidgetItem-D_LnB3eD.mjs → NcDashboardWidgetItem-DZGooEwA.mjs} +3 -3
  289. package/dist/chunks/{NcDashboardWidgetItem-D_LnB3eD.mjs.map → NcDashboardWidgetItem-DZGooEwA.mjs.map} +1 -1
  290. package/dist/chunks/{NcDateTime-DCay1-XL.cjs → NcDateTime-AFZif5Dn.cjs} +1 -1
  291. package/dist/chunks/{NcDateTime-DCay1-XL.cjs.map → NcDateTime-AFZif5Dn.cjs.map} +1 -1
  292. package/dist/chunks/{NcDateTime-rpYgoLDg.mjs → NcDateTime-DBZ-vBfi.mjs} +1 -1
  293. package/dist/chunks/{NcDateTime-rpYgoLDg.mjs.map → NcDateTime-DBZ-vBfi.mjs.map} +1 -1
  294. package/dist/chunks/{NcDialog-CGqOzNXp.mjs → NcDialog-I_9fyJVt.mjs} +1 -1
  295. package/dist/chunks/{NcDialog-CGqOzNXp.mjs.map → NcDialog-I_9fyJVt.mjs.map} +1 -1
  296. package/dist/chunks/{NcDialog-CBQgMh0l.cjs → NcDialog-mcbLFc8o.cjs} +1 -1
  297. package/dist/chunks/{NcDialog-CBQgMh0l.cjs.map → NcDialog-mcbLFc8o.cjs.map} +1 -1
  298. package/dist/chunks/{NcDialogButton-C2I08MyR.mjs → NcDialogButton-DuJ3lE7e.mjs} +1 -1
  299. package/dist/chunks/{NcDialogButton-C2I08MyR.mjs.map → NcDialogButton-DuJ3lE7e.mjs.map} +1 -1
  300. package/dist/chunks/{NcDialogButton-F6xUMopP.cjs → NcDialogButton-FLqQdVLb.cjs} +1 -1
  301. package/dist/chunks/{NcDialogButton-F6xUMopP.cjs.map → NcDialogButton-FLqQdVLb.cjs.map} +1 -1
  302. package/dist/chunks/{NcEmojiPicker-DrJqoYXz.cjs → NcEmojiPicker-B1ot5iNB.cjs} +69 -42
  303. package/dist/chunks/NcEmojiPicker-B1ot5iNB.cjs.map +1 -0
  304. package/dist/chunks/{NcEmojiPicker-CUVGh_eA.mjs → NcEmojiPicker-DDCgW2zQ.mjs} +69 -42
  305. package/dist/chunks/NcEmojiPicker-DDCgW2zQ.mjs.map +1 -0
  306. package/dist/chunks/{NcHeaderMenu-CzS2doDR.cjs → NcHeaderMenu-BaHhnhN0.cjs} +3 -4
  307. package/dist/chunks/NcHeaderMenu-BaHhnhN0.cjs.map +1 -0
  308. package/dist/chunks/{NcHeaderMenu-vLqcJ-_w.mjs → NcHeaderMenu-CLcpStap.mjs} +3 -4
  309. package/dist/chunks/NcHeaderMenu-CLcpStap.mjs.map +1 -0
  310. package/dist/chunks/{NcInputConfirmCancel-C6zlmXZ4.mjs → NcInputConfirmCancel-C7a7Nha7.mjs} +1 -1
  311. package/dist/chunks/{NcInputConfirmCancel-C6zlmXZ4.mjs.map → NcInputConfirmCancel-C7a7Nha7.mjs.map} +1 -1
  312. package/dist/chunks/{NcInputConfirmCancel-C8hLDujR.cjs → NcInputConfirmCancel-XzKuYi6L.cjs} +1 -1
  313. package/dist/chunks/{NcInputConfirmCancel-C8hLDujR.cjs.map → NcInputConfirmCancel-XzKuYi6L.cjs.map} +1 -1
  314. package/dist/chunks/{NcInputField-ixTTHy3h.mjs → NcInputField-CU5a68Pc.mjs} +6 -7
  315. package/dist/chunks/NcInputField-CU5a68Pc.mjs.map +1 -0
  316. package/dist/chunks/{NcInputField-CbBdbdE8.cjs → NcInputField-DkhKrb8k.cjs} +6 -7
  317. package/dist/chunks/NcInputField-DkhKrb8k.cjs.map +1 -0
  318. package/dist/chunks/{NcListItem-P2z7dcyT.mjs → NcListItem-3e1MminS.mjs} +4 -4
  319. package/dist/chunks/{NcListItem-P2z7dcyT.mjs.map → NcListItem-3e1MminS.mjs.map} +1 -1
  320. package/dist/chunks/{NcListItem-B5pTDywA.cjs → NcListItem-9w7m2lJ_.cjs} +4 -4
  321. package/dist/chunks/{NcListItem-B5pTDywA.cjs.map → NcListItem-9w7m2lJ_.cjs.map} +1 -1
  322. package/dist/chunks/{NcListItemIcon-B1wOr_AY.mjs → NcListItemIcon-7x7iDHYw.mjs} +2 -3
  323. package/dist/chunks/{NcListItemIcon-B1wOr_AY.mjs.map → NcListItemIcon-7x7iDHYw.mjs.map} +1 -1
  324. package/dist/chunks/{NcListItemIcon-CC-LU_U9.cjs → NcListItemIcon-pOj8Vr2H.cjs} +2 -3
  325. package/dist/chunks/{NcListItemIcon-CC-LU_U9.cjs.map → NcListItemIcon-pOj8Vr2H.cjs.map} +1 -1
  326. package/dist/chunks/{NcPasswordField-D5Td9dcg.cjs → NcPasswordField-BS6bkHtv.cjs} +10 -6
  327. package/dist/chunks/NcPasswordField-BS6bkHtv.cjs.map +1 -0
  328. package/dist/chunks/{NcPasswordField-CZ94k5WH.mjs → NcPasswordField-Dpu9nI6h.mjs} +10 -6
  329. package/dist/chunks/NcPasswordField-Dpu9nI6h.mjs.map +1 -0
  330. package/dist/chunks/{NcPopover-MxwUgZu1.cjs → NcPopover-BKlH1mbx.cjs} +12 -13
  331. package/dist/chunks/NcPopover-BKlH1mbx.cjs.map +1 -0
  332. package/dist/chunks/{NcPopover-DzYbNu-I.mjs → NcPopover-DFCPlZpS.mjs} +12 -13
  333. package/dist/chunks/NcPopover-DFCPlZpS.mjs.map +1 -0
  334. package/dist/chunks/{NcRelatedResourcesPanel-BXztrC3l.cjs → NcRelatedResourcesPanel-BrkyIR3v.cjs} +8 -3
  335. package/dist/chunks/NcRelatedResourcesPanel-BrkyIR3v.cjs.map +1 -0
  336. package/dist/chunks/{NcRelatedResourcesPanel-DfYwqMxA.mjs → NcRelatedResourcesPanel-C6JIVMvN.mjs} +8 -3
  337. package/dist/chunks/NcRelatedResourcesPanel-C6JIVMvN.mjs.map +1 -0
  338. package/dist/chunks/{NcRichContenteditable-DS0VWcxG.mjs → NcRichContenteditable-3kkU0Uxu.mjs} +20 -20
  339. package/dist/chunks/NcRichContenteditable-3kkU0Uxu.mjs.map +1 -0
  340. package/dist/chunks/{NcRichContenteditable-fuOTy1W6.cjs → NcRichContenteditable-DJy0zZXx.cjs} +20 -20
  341. package/dist/chunks/NcRichContenteditable-DJy0zZXx.cjs.map +1 -0
  342. package/dist/chunks/{NcRichText-DA8kGDfO.mjs → NcRichText-C8SjsRK8.mjs} +29 -42
  343. package/dist/chunks/NcRichText-C8SjsRK8.mjs.map +1 -0
  344. package/dist/chunks/{NcRichText-B1WT1pJp.cjs → NcRichText-Ci72ylJ9.cjs} +28 -41
  345. package/dist/chunks/NcRichText-Ci72ylJ9.cjs.map +1 -0
  346. package/dist/chunks/{NcSelect-COvOHnPx.mjs → NcSelect-BQ-NFBXI.mjs} +2 -2
  347. package/dist/chunks/{NcSelect-COvOHnPx.mjs.map → NcSelect-BQ-NFBXI.mjs.map} +1 -1
  348. package/dist/chunks/{NcSelect-B7KNWVHM.cjs → NcSelect-YHwbPAJD.cjs} +2 -2
  349. package/dist/chunks/{NcSelect-B7KNWVHM.cjs.map → NcSelect-YHwbPAJD.cjs.map} +1 -1
  350. package/dist/chunks/{NcSelectTags-BBHWY-yn.cjs → NcSelectTags-BAMsfdw9.cjs} +2 -2
  351. package/dist/chunks/{NcSelectTags-BBHWY-yn.cjs.map → NcSelectTags-BAMsfdw9.cjs.map} +1 -1
  352. package/dist/chunks/{NcSelectTags-CF2Cot8w.mjs → NcSelectTags-BKtOWgrz.mjs} +2 -2
  353. package/dist/chunks/{NcSelectTags-CF2Cot8w.mjs.map → NcSelectTags-BKtOWgrz.mjs.map} +1 -1
  354. package/dist/chunks/{NcSettingsInputText-CeXJLtte.mjs → NcSettingsInputText-DC7H_6Uz.mjs} +1 -1
  355. package/dist/chunks/{NcSettingsInputText-CeXJLtte.mjs.map → NcSettingsInputText-DC7H_6Uz.mjs.map} +1 -1
  356. package/dist/chunks/{NcSettingsInputText-CxQDdc64.cjs → NcSettingsInputText-nb2XMaJW.cjs} +1 -1
  357. package/dist/chunks/{NcSettingsInputText-CxQDdc64.cjs.map → NcSettingsInputText-nb2XMaJW.cjs.map} +1 -1
  358. package/dist/chunks/{NcSettingsSection-DFNuk8_l.cjs → NcSettingsSection-6Sc6GBsM.cjs} +1 -1
  359. package/dist/chunks/{NcSettingsSection-DFNuk8_l.cjs.map → NcSettingsSection-6Sc6GBsM.cjs.map} +1 -1
  360. package/dist/chunks/{NcSettingsSection-DHX2Y1Ed.mjs → NcSettingsSection-BYKUjim0.mjs} +1 -1
  361. package/dist/chunks/{NcSettingsSection-DHX2Y1Ed.mjs.map → NcSettingsSection-BYKUjim0.mjs.map} +1 -1
  362. package/dist/chunks/{NcSettingsSelectGroup-BdBSXdjz.mjs → NcSettingsSelectGroup-CI2LoVeL.mjs} +2 -2
  363. package/dist/chunks/{NcSettingsSelectGroup-BdBSXdjz.mjs.map → NcSettingsSelectGroup-CI2LoVeL.mjs.map} +1 -1
  364. package/dist/chunks/{NcSettingsSelectGroup-DMPDJo9p.cjs → NcSettingsSelectGroup-DX4AaRte.cjs} +2 -2
  365. package/dist/chunks/{NcSettingsSelectGroup-DMPDJo9p.cjs.map → NcSettingsSelectGroup-DX4AaRte.cjs.map} +1 -1
  366. package/dist/chunks/{NcTextField-gOk0FWcs.mjs → NcTextField-9gC8or6j.mjs} +8 -4
  367. package/dist/chunks/NcTextField-9gC8or6j.mjs.map +1 -0
  368. package/dist/chunks/{NcTextField-BUAXFTZf.cjs → NcTextField-Pbox9mQE.cjs} +8 -4
  369. package/dist/chunks/NcTextField-Pbox9mQE.cjs.map +1 -0
  370. package/dist/chunks/{NcTimezonePicker-BvdhhPdA.cjs → NcTimezonePicker-DIwsRdu2.cjs} +2 -2
  371. package/dist/chunks/{NcTimezonePicker-BvdhhPdA.cjs.map → NcTimezonePicker-DIwsRdu2.cjs.map} +1 -1
  372. package/dist/chunks/{NcTimezonePicker-BThg06Qu.mjs → NcTimezonePicker-xSXSuNHX.mjs} +2 -2
  373. package/dist/chunks/{NcTimezonePicker-BThg06Qu.mjs.map → NcTimezonePicker-xSXSuNHX.mjs.map} +1 -1
  374. package/dist/chunks/{NcUserBubble-DCy2g6yy.mjs → NcUserBubble-BFvEaXLr.mjs} +5 -5
  375. package/dist/chunks/{NcUserBubble-DCy2g6yy.mjs.map → NcUserBubble-BFvEaXLr.mjs.map} +1 -1
  376. package/dist/chunks/{NcUserBubble-DgsM0rzH.cjs → NcUserBubble-rphdAcHS.cjs} +5 -5
  377. package/dist/chunks/{NcUserBubble-DgsM0rzH.cjs.map → NcUserBubble-rphdAcHS.cjs.map} +1 -1
  378. package/dist/chunks/{NcUserStatusIcon-BKwkHHPs.cjs → NcUserStatusIcon-CFLiHFkC.cjs} +1 -1
  379. package/dist/chunks/{NcUserStatusIcon-BKwkHHPs.cjs.map → NcUserStatusIcon-CFLiHFkC.cjs.map} +1 -1
  380. package/dist/chunks/{NcUserStatusIcon-CChMQi6E.mjs → NcUserStatusIcon-S5bBgRl6.mjs} +1 -1
  381. package/dist/chunks/{NcUserStatusIcon-CChMQi6E.mjs.map → NcUserStatusIcon-S5bBgRl6.mjs.map} +1 -1
  382. package/dist/chunks/{ScopeComponent-B1fKsMww.cjs → ScopeComponent-B5vclUCV.cjs} +1 -1
  383. package/dist/chunks/{ScopeComponent-B1fKsMww.cjs.map → ScopeComponent-B5vclUCV.cjs.map} +1 -1
  384. package/dist/chunks/{ScopeComponent-9cgy2zGu.mjs → ScopeComponent-CEMLuQd5.mjs} +1 -1
  385. package/dist/chunks/{ScopeComponent-9cgy2zGu.mjs.map → ScopeComponent-CEMLuQd5.mjs.map} +1 -1
  386. package/dist/chunks/_l10n-CjO_W5Dt.cjs +138 -0
  387. package/dist/chunks/{_l10n-ICucobx3.cjs.map → _l10n-CjO_W5Dt.cjs.map} +1 -1
  388. package/dist/chunks/_l10n-DDKxBWQL.mjs +139 -0
  389. package/dist/chunks/_l10n-DDKxBWQL.mjs.map +1 -0
  390. package/dist/chunks/{index-bI_wyL5-.cjs → index-BiECbTbJ.cjs} +3 -4
  391. package/dist/chunks/index-BiECbTbJ.cjs.map +1 -0
  392. package/dist/chunks/{index-bjwozrEX.mjs → index-G8WQDZ8G.mjs} +3 -4
  393. package/dist/chunks/index-G8WQDZ8G.mjs.map +1 -0
  394. package/dist/chunks/{referencePickerModal-C3zq9N4N.cjs → referencePickerModal-BkBu4cnq.cjs} +8 -8
  395. package/dist/chunks/referencePickerModal-BkBu4cnq.cjs.map +1 -0
  396. package/dist/chunks/{referencePickerModal-CwmjjIO7.mjs → referencePickerModal-CGG57Dy_.mjs} +8 -8
  397. package/dist/chunks/referencePickerModal-CGG57Dy_.mjs.map +1 -0
  398. package/dist/chunks/{usernameToColor-DNmwg81-.mjs → usernameToColor-BCZuxlEH.mjs} +1 -1
  399. package/dist/chunks/{usernameToColor-DNmwg81-.mjs.map → usernameToColor-BCZuxlEH.mjs.map} +1 -1
  400. package/dist/chunks/{usernameToColor-CRPbtFBh.cjs → usernameToColor-cVFS7tET.cjs} +1 -1
  401. package/dist/chunks/{usernameToColor-CRPbtFBh.cjs.map → usernameToColor-cVFS7tET.cjs.map} +1 -1
  402. package/dist/composables/useFormatDateTime.d.ts +0 -1
  403. package/dist/composables/useIsDarkTheme/index.d.ts +0 -1
  404. package/dist/functions/dialog/index.d.ts +0 -1
  405. package/dist/index.cjs +51 -51
  406. package/dist/index.mjs +54 -54
  407. package/dist/plugin.d.ts +0 -1
  408. package/package.json +28 -11
  409. package/dist/assets/NcDateTimePickerNative-CwDQUAiQ.css +0 -47
  410. package/dist/assets/NcRichText-BlRmdWCX.css +0 -412
  411. package/dist/chunks/Linkify-BtgR-dXX.mjs +0 -14
  412. package/dist/chunks/Linkify-BtgR-dXX.mjs.map +0 -1
  413. package/dist/chunks/Linkify-yeOn5L6T.cjs +0 -15
  414. package/dist/chunks/Linkify-yeOn5L6T.cjs.map +0 -1
  415. package/dist/chunks/NcActionRadio-Dl6W62Vm.mjs.map +0 -1
  416. package/dist/chunks/NcActionRadio-vHwjWOHS.cjs.map +0 -1
  417. package/dist/chunks/NcActionTextEditable-97R7dFen.cjs.map +0 -1
  418. package/dist/chunks/NcActionTextEditable-DZCFtqIP.mjs.map +0 -1
  419. package/dist/chunks/NcAppContent-BhXzPGUR.cjs.map +0 -1
  420. package/dist/chunks/NcAppContent-BuY1ebnE.mjs.map +0 -1
  421. package/dist/chunks/NcAppNavigationItem-C8Qq4tF5.mjs.map +0 -1
  422. package/dist/chunks/NcAppNavigationItem-boljzMEm.cjs.map +0 -1
  423. package/dist/chunks/NcAvatar-CT6DLUhQ.mjs.map +0 -1
  424. package/dist/chunks/NcAvatar-D4E0ptkW.cjs.map +0 -1
  425. package/dist/chunks/NcColorPicker-CODhE5KL.mjs.map +0 -1
  426. package/dist/chunks/NcColorPicker-rWet3ND8.cjs.map +0 -1
  427. package/dist/chunks/NcEmojiPicker-CUVGh_eA.mjs.map +0 -1
  428. package/dist/chunks/NcEmojiPicker-DrJqoYXz.cjs.map +0 -1
  429. package/dist/chunks/NcHeaderMenu-CzS2doDR.cjs.map +0 -1
  430. package/dist/chunks/NcHeaderMenu-vLqcJ-_w.mjs.map +0 -1
  431. package/dist/chunks/NcInputField-CbBdbdE8.cjs.map +0 -1
  432. package/dist/chunks/NcInputField-ixTTHy3h.mjs.map +0 -1
  433. package/dist/chunks/NcPasswordField-CZ94k5WH.mjs.map +0 -1
  434. package/dist/chunks/NcPasswordField-D5Td9dcg.cjs.map +0 -1
  435. package/dist/chunks/NcPopover-DzYbNu-I.mjs.map +0 -1
  436. package/dist/chunks/NcPopover-MxwUgZu1.cjs.map +0 -1
  437. package/dist/chunks/NcRelatedResourcesPanel-BXztrC3l.cjs.map +0 -1
  438. package/dist/chunks/NcRelatedResourcesPanel-DfYwqMxA.mjs.map +0 -1
  439. package/dist/chunks/NcRichContenteditable-DS0VWcxG.mjs.map +0 -1
  440. package/dist/chunks/NcRichContenteditable-fuOTy1W6.cjs.map +0 -1
  441. package/dist/chunks/NcRichText-B1WT1pJp.cjs.map +0 -1
  442. package/dist/chunks/NcRichText-DA8kGDfO.mjs.map +0 -1
  443. package/dist/chunks/NcTextField-BUAXFTZf.cjs.map +0 -1
  444. package/dist/chunks/NcTextField-gOk0FWcs.mjs.map +0 -1
  445. package/dist/chunks/_l10n-C6OUA0Ge.mjs +0 -130
  446. package/dist/chunks/_l10n-C6OUA0Ge.mjs.map +0 -1
  447. package/dist/chunks/_l10n-ICucobx3.cjs +0 -129
  448. package/dist/chunks/index-bI_wyL5-.cjs.map +0 -1
  449. package/dist/chunks/index-bjwozrEX.mjs.map +0 -1
  450. package/dist/chunks/referencePickerModal-C3zq9N4N.cjs.map +0 -1
  451. package/dist/chunks/referencePickerModal-CwmjjIO7.mjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"NcDialogButton-F6xUMopP.cjs","sources":["../../src/components/NcDialogButton/NcDialogButton.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nDialog button component used by NcDialog in the actions slot to display the buttons passed by the `buttons` prop.\n</docs>\n\n<template>\n\t<NcButton :aria-label=\"label\"\n\t\t:disabled=\"disabled\"\n\t\t:native-type=\"nativeType\"\n\t\t:type=\"type\"\n\t\t@click=\"handleClick\">\n\t\t{{ label }}\n\t\t<template #icon>\n\t\t\t<!-- @slot Allow to set a custom icon for the button -->\n\t\t\t<slot name=\"icon\">\n\t\t\t\t<!-- The loading state is an information that must be accessible -->\n\t\t\t\t<NcLoadingIcon v-if=\"isLoading\" :name=\"t('Loading …') /* TRANSLATORS: The button is in a loading state*/\" />\n\t\t\t\t<NcIconSvgWrapper v-else-if=\"icon !== undefined\" :svg=\"icon\" />\n\t\t\t</slot>\n\t\t</template>\n\t</NcButton>\n</template>\n\n<script setup>\nimport { ref } from 'vue'\nimport NcButton from '../NcButton/index.js'\nimport NcIconSvgWrapper from '../NcIconSvgWrapper/index.js'\nimport NcLoadingIcon from '../NcLoadingIcon/index.js'\nimport { t } from '../../l10n.js'\n\nconst props = defineProps({\n\t/**\n\t * The function that will be called when the button is pressed.\n\t * If the function returns `false` the click is ignored and the dialog will not be closed.\n\t * @type {() => unknown|false|Promise<unknown|false>}\n\t */\n\tcallback: {\n\t\ttype: Function,\n\t\trequired: false,\n\t\tdefault: () => {},\n\t},\n\n\t/**\n\t * The label of the button\n\t */\n\tlabel: {\n\t\ttype: String,\n\t\trequired: true,\n\t},\n\n\t/**\n\t * Optional inline SVG icon for the button\n\t */\n\ticon: {\n\t\ttype: String,\n\t\trequired: false,\n\t\tdefault: undefined,\n\t},\n\n\t/**\n\t * The button type, see NcButton\n\t * @type {'primary'|'secondary'|'error'|'warning'|'success'}\n\t */\n\ttype: {\n\t\ttype: String,\n\t\trequired: false,\n\t\tdefault: 'secondary',\n\t\tvalidator: (type) => typeof type === 'string' && ['primary', 'secondary', 'tertiary', 'error', 'warning', 'success'].includes(type),\n\t},\n\n\t/**\n\t * See `nativeType` of `NcButton`\n\t */\n\tnativeType: {\n\t\ttype: String,\n\t\trequired: false,\n\t\tdefault: 'button',\n\t\tvalidator(value) {\n\t\t\treturn ['submit', 'reset', 'button'].includes(value)\n\t\t},\n\t},\n\n\t/**\n\t * If the button should be shown as disabled\n\t */\n\tdisabled: {\n\t\ttype: Boolean,\n\t\tdefault: false,\n\t},\n})\n\nconst emit = defineEmits(['click'])\n\nconst isLoading = ref(false)\n\n/**\n * Handle clicking the button\n * @param {MouseEvent} e The click event\n */\nconst handleClick = async (e) => {\n\t// Do not re-emit while loading\n\tif (isLoading.value) {\n\t\treturn\n\t}\n\n\tisLoading.value = true\n\ttry {\n\t\tconst result = await props.callback?.()\n\t\tif (result !== false) {\n\t\t\t/**\n\t\t\t * The click event (`MouseEvent`) and the value returned by the callback\n\t\t\t */\n\t\t\temit('click', e, result)\n\t\t}\n\t} finally {\n\t\tisLoading.value = false\n\t}\n}\n</script>\n"],"names":["ref"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiGA,UAAM,YAAYA,IAAG,IAAC,KAAK;AAM3B,UAAM,cAAc,OAAO,MAAM;AAEhC,UAAI,UAAU,OAAO;AACpB;AAAA,MACA;AAED,gBAAU,QAAQ;AAClB,UAAI;AACH,cAAM,SAAS,MAAM,MAAM,WAAY;AACvC,YAAI,WAAW,OAAO;AAIrB,eAAK,SAAS,GAAG,MAAM;AAAA,QACvB;AAAA,MACH,UAAW;AACT,kBAAU,QAAQ;AAAA,MAClB;AAAA,IACF;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"NcDialogButton-FLqQdVLb.cjs","sources":["../../src/components/NcDialogButton/NcDialogButton.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nDialog button component used by NcDialog in the actions slot to display the buttons passed by the `buttons` prop.\n</docs>\n\n<template>\n\t<NcButton :aria-label=\"label\"\n\t\t:disabled=\"disabled\"\n\t\t:native-type=\"nativeType\"\n\t\t:type=\"type\"\n\t\t@click=\"handleClick\">\n\t\t{{ label }}\n\t\t<template #icon>\n\t\t\t<!-- @slot Allow to set a custom icon for the button -->\n\t\t\t<slot name=\"icon\">\n\t\t\t\t<!-- The loading state is an information that must be accessible -->\n\t\t\t\t<NcLoadingIcon v-if=\"isLoading\" :name=\"t('Loading …') /* TRANSLATORS: The button is in a loading state*/\" />\n\t\t\t\t<NcIconSvgWrapper v-else-if=\"icon !== undefined\" :svg=\"icon\" />\n\t\t\t</slot>\n\t\t</template>\n\t</NcButton>\n</template>\n\n<script setup>\nimport { ref } from 'vue'\nimport NcButton from '../NcButton/index.js'\nimport NcIconSvgWrapper from '../NcIconSvgWrapper/index.js'\nimport NcLoadingIcon from '../NcLoadingIcon/index.js'\nimport { t } from '../../l10n.js'\n\nconst props = defineProps({\n\t/**\n\t * The function that will be called when the button is pressed.\n\t * If the function returns `false` the click is ignored and the dialog will not be closed.\n\t * @type {() => unknown|false|Promise<unknown|false>}\n\t */\n\tcallback: {\n\t\ttype: Function,\n\t\trequired: false,\n\t\tdefault: () => {},\n\t},\n\n\t/**\n\t * The label of the button\n\t */\n\tlabel: {\n\t\ttype: String,\n\t\trequired: true,\n\t},\n\n\t/**\n\t * Optional inline SVG icon for the button\n\t */\n\ticon: {\n\t\ttype: String,\n\t\trequired: false,\n\t\tdefault: undefined,\n\t},\n\n\t/**\n\t * The button type, see NcButton\n\t * @type {'primary'|'secondary'|'error'|'warning'|'success'}\n\t */\n\ttype: {\n\t\ttype: String,\n\t\trequired: false,\n\t\tdefault: 'secondary',\n\t\tvalidator: (type) => typeof type === 'string' && ['primary', 'secondary', 'tertiary', 'error', 'warning', 'success'].includes(type),\n\t},\n\n\t/**\n\t * See `nativeType` of `NcButton`\n\t */\n\tnativeType: {\n\t\ttype: String,\n\t\trequired: false,\n\t\tdefault: 'button',\n\t\tvalidator(value) {\n\t\t\treturn ['submit', 'reset', 'button'].includes(value)\n\t\t},\n\t},\n\n\t/**\n\t * If the button should be shown as disabled\n\t */\n\tdisabled: {\n\t\ttype: Boolean,\n\t\tdefault: false,\n\t},\n})\n\nconst emit = defineEmits(['click'])\n\nconst isLoading = ref(false)\n\n/**\n * Handle clicking the button\n * @param {MouseEvent} e The click event\n */\nconst handleClick = async (e) => {\n\t// Do not re-emit while loading\n\tif (isLoading.value) {\n\t\treturn\n\t}\n\n\tisLoading.value = true\n\ttry {\n\t\tconst result = await props.callback?.()\n\t\tif (result !== false) {\n\t\t\t/**\n\t\t\t * The click event (`MouseEvent`) and the value returned by the callback\n\t\t\t */\n\t\t\temit('click', e, result)\n\t\t}\n\t} finally {\n\t\tisLoading.value = false\n\t}\n}\n</script>\n"],"names":["ref"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiGA,UAAM,YAAYA,IAAG,IAAC,KAAK;AAM3B,UAAM,cAAc,OAAO,MAAM;AAEhC,UAAI,UAAU,OAAO;AACpB;AAAA,MACA;AAED,gBAAU,QAAQ;AAClB,UAAI;AACH,cAAM,SAAS,MAAM,MAAM,WAAY;AACvC,YAAI,WAAW,OAAO;AAIrB,eAAK,SAAS,GAAG,MAAM;AAAA,QACvB;AAAA,MACH,UAAW;AACT,kBAAU,QAAQ;AAAA,MAClB;AAAA,IACF;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,15 +1,15 @@
1
- require('../assets/NcEmojiPicker-BNCW1Q94.css');
1
+ require('../assets/NcEmojiPicker-rk5qcSl7.css');
2
2
  "use strict";
3
3
  const emojiMartVueFast = require("emoji-mart-vue-fast");
4
- const _l10n = require("./_l10n-ICucobx3.cjs");
4
+ const _l10n = require("./_l10n-CjO_W5Dt.cjs");
5
5
  const emoji = require("./emoji-VgSjNTd5.cjs");
6
- const GenColors = require("./GenColors-NLLtT2OM.cjs");
6
+ const GenColors = require("./GenColors-Di5GSft7.cjs");
7
7
  const data = require("emoji-mart-vue-fast/data/all.json");
8
8
  const _pluginVue2_normalizer = require("./_plugin-vue2_normalizer-V0q-tHlQ.cjs");
9
9
  const Components_NcButton = require("../Components/NcButton.cjs");
10
- const NcColorPicker = require("./NcColorPicker-rWet3ND8.cjs");
11
- const NcPopover = require("./NcPopover-MxwUgZu1.cjs");
12
- const NcTextField = require("./NcTextField-BUAXFTZf.cjs");
10
+ const NcColorPicker = require("./NcColorPicker-CTQlyVCL.cjs");
11
+ const NcPopover = require("./NcPopover-BKlH1mbx.cjs");
12
+ const NcTextField = require("./NcTextField-Pbox9mQE.cjs");
13
13
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
14
14
  const data__default = /* @__PURE__ */ _interopDefault(data);
15
15
  _l10n.register(_l10n.t5, _l10n.t14, _l10n.t34, _l10n.t39);
@@ -183,10 +183,7 @@ const _sfc_main = {
183
183
  t: _l10n.t,
184
184
  clearSearch() {
185
185
  this.search = "";
186
- const input = this.$refs.search?.$refs.inputField?.$refs.input;
187
- if (input) {
188
- input.focus();
189
- }
186
+ this.$refs.search.focus();
190
187
  },
191
188
  /**
192
189
  * Update the current skin tone by the result of the color picker
@@ -211,54 +208,84 @@ const _sfc_main = {
211
208
  this.$emit("unselect");
212
209
  },
213
210
  afterShow() {
214
- const picker = this.$refs.picker;
215
- picker.$el.addEventListener("keydown", this.checkKeyEvent);
216
- const input = this.$refs.search?.$refs.inputField?.$refs.input;
217
- if (input) {
218
- input.focus();
219
- }
211
+ this.$refs.search.focus();
220
212
  },
221
213
  afterHide() {
222
- const picker = this.$refs.picker;
223
- picker.$el.removeEventListener("keydown", this.checkKeyEvent);
214
+ this.$refs.popover.$el.querySelector('button, [role="button"]')?.focus();
224
215
  },
225
- checkKeyEvent(event) {
226
- if (event.key !== "Tab") {
227
- return;
228
- }
229
- const picker = this.$refs.picker;
230
- const focusableList = picker.$el.querySelectorAll(
231
- "button, input"
232
- );
233
- const last = focusableList.length - 1;
234
- if (focusableList.length <= 1) {
235
- event.preventDefault();
236
- return;
237
- }
238
- if (event.shiftKey === false && event.target === focusableList[last]) {
239
- event.preventDefault();
240
- focusableList[0].focus();
241
- } else if (event.shiftKey === true && event.target === focusableList[0]) {
242
- event.preventDefault();
243
- focusableList[last].focus();
216
+ /**
217
+ * Manually handle Tab navigation skipping emoji buttons.
218
+ * Navigation over emojis is handled by Arrow keys.
219
+ * @param {KeyboardEvent} event - Keyboard event
220
+ */
221
+ handleTabNavigationSkippingEmojis(event) {
222
+ const current = event.target;
223
+ const focusable = Array.from(this.$refs.picker.$el.querySelectorAll("button:not(.emoji-mart-emoji), input"));
224
+ if (!event.shiftKey) {
225
+ const nextNode = focusable.find((node) => current.compareDocumentPosition(node) & Node.DOCUMENT_POSITION_FOLLOWING) || focusable[0];
226
+ nextNode.focus();
227
+ } else {
228
+ const prevNode = focusable.findLast((node) => current.compareDocumentPosition(node) & Node.DOCUMENT_POSITION_PRECEDING) || focusable.at(-1);
229
+ prevNode.focus();
244
230
  }
231
+ },
232
+ /**
233
+ * Handle arrow navigation via <Picker>'s handlers with scroll bug fix
234
+ * @param {'onArrowLeft' | 'onArrowRight' | 'onArrowDown' | 'onArrowUp'} originalHandlerName - Picker's arrow keydown handler name
235
+ * @param {KeyboardEvent} event - Keyboard event
236
+ */
237
+ async callPickerArrowHandlerWithScrollFix(originalHandlerName, event) {
238
+ this.$refs.picker[originalHandlerName](event);
239
+ await this.$nextTick();
240
+ const selectedEmoji = this.$refs.picker.$el.querySelector(".emoji-mart-emoji-selected");
241
+ selectedEmoji?.scrollIntoView({
242
+ block: "center",
243
+ inline: "center"
244
+ });
245
245
  }
246
246
  }
247
247
  };
248
248
  var _sfc_render = function render2() {
249
249
  var _vm = this, _c = _vm._self._c;
250
- return _c("NcPopover", _vm._g(_vm._b({ attrs: { "shown": _vm.open, "container": _vm.container, "popup-role": "dialog" }, on: { "update:shown": function($event) {
250
+ return _c("NcPopover", _vm._g(_vm._b({ ref: "popover", attrs: {
251
+ "shown": _vm.open,
252
+ "container": _vm.container,
253
+ "popup-role": "dialog",
254
+ "focus-trap": false
255
+ /* Handled manually to remove emoji buttons from TAB sequence */
256
+ }, on: { "update:shown": function($event) {
251
257
  _vm.open = $event;
252
258
  }, "after-show": _vm.afterShow, "after-hide": _vm.afterHide }, scopedSlots: _vm._u([{ key: "trigger", fn: function(slotProps) {
253
259
  return [_vm._t("default", null, null, slotProps)];
254
- } }], null, true) }, "NcPopover", _vm.$attrs, false), _vm.$listeners), [_c("Picker", _vm._b({ ref: "picker", attrs: { "auto-focus": false, "color": "var(--color-primary-element)", "data": _vm.emojiIndex, "emoji": _vm.previewFallbackEmoji, "i18n": _vm.i18n, "native": _vm.native, "emoji-size": 20, "per-line": 8, "picker-styles": { width: "320px" }, "show-preview": _vm.showPreview, "skin": _vm.currentSkinTone, "show-skin-tones": false, "title": _vm.previewFallbackName, "role": "dialog", "aria-modal": "true", "aria-label": _vm.t("Emoji picker") }, on: { "select": _vm.select }, scopedSlots: _vm._u([{ key: "searchTemplate", fn: function(slotProps) {
260
+ } }], null, true) }, "NcPopover", _vm.$attrs, false), _vm.$listeners), [_c("Picker", _vm._b({ ref: "picker", staticClass: "nc-emoji-picker", attrs: { "color": "var(--color-primary-element)", "data": _vm.emojiIndex, "emoji": _vm.previewFallbackEmoji, "i18n": _vm.i18n, "native": _vm.native, "emoji-size": 20, "per-line": 8, "picker-styles": { width: "320px" }, "show-preview": _vm.showPreview, "skin": _vm.currentSkinTone, "show-skin-tones": false, "title": _vm.previewFallbackName, "role": "dialog", "aria-modal": "true", "aria-label": _vm.t("Emoji picker") }, on: { "select": _vm.select }, nativeOn: { "keydown": function($event) {
261
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "tab", 9, $event.key, "Tab")) return null;
262
+ $event.preventDefault();
263
+ return _vm.handleTabNavigationSkippingEmojis.apply(null, arguments);
264
+ } }, scopedSlots: _vm._u([{ key: "searchTemplate", fn: function({ onSearch }) {
255
265
  return [_c("div", { staticClass: "search__wrapper" }, [_c("NcTextField", { ref: "search", staticClass: "search", attrs: { "value": _vm.search, "label": _vm.t("Search"), "label-visible": true, "placeholder": _vm.i18n.search, "trailing-button-icon": "close", "trailing-button-label": _vm.t("Clear search"), "show-trailing-button": _vm.search !== "" }, on: { "update:value": [function($event) {
256
266
  _vm.search = $event;
257
267
  }, function($event) {
258
- return slotProps.onSearch(_vm.search);
268
+ return onSearch(_vm.search);
269
+ }], "keydown": [function($event) {
270
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "left", 37, $event.key, ["Left", "ArrowLeft"])) return null;
271
+ if ("button" in $event && $event.button !== 0) return null;
272
+ return _vm.callPickerArrowHandlerWithScrollFix("onArrowLeft", $event);
273
+ }, function($event) {
274
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "right", 39, $event.key, ["Right", "ArrowRight"])) return null;
275
+ if ("button" in $event && $event.button !== 2) return null;
276
+ return _vm.callPickerArrowHandlerWithScrollFix("onArrowRight", $event);
277
+ }, function($event) {
278
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "down", 40, $event.key, ["Down", "ArrowDown"])) return null;
279
+ return _vm.callPickerArrowHandlerWithScrollFix("onArrowDown", $event);
280
+ }, function($event) {
281
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "up", 38, $event.key, ["Up", "ArrowUp"])) return null;
282
+ return _vm.callPickerArrowHandlerWithScrollFix("onArrowUp", $event);
283
+ }, function($event) {
284
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")) return null;
285
+ return _vm.$refs.picker.onEnter.apply(null, arguments);
259
286
  }], "trailing-button-click": function($event) {
260
287
  _vm.clearSearch();
261
- slotProps.onSearch(_vm.search);
288
+ onSearch("");
262
289
  } } }), _c("NcColorPicker", { attrs: { "palette-only": "", "container": _vm.container, "palette": _vm.skinTonePalette, "value": _vm.currentColor.color }, on: { "update:value": _vm.onChangeSkinTone } }, [_c("NcButton", { attrs: { "aria-label": _vm.t("Skin tone"), "type": "tertiary-no-background" }, scopedSlots: _vm._u([{ key: "icon", fn: function() {
263
290
  return [_c("IconCircle", { style: { color: _vm.currentColor.color }, attrs: { "title": _vm.currentColor.name, "size": 20 } })];
264
291
  }, proxy: true }], null, true) })], 1)], 1)];
@@ -273,7 +300,7 @@ var __component__ = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
273
300
  _sfc_staticRenderFns,
274
301
  false,
275
302
  null,
276
- "ed4adfc3"
303
+ "6e39597a"
277
304
  );
278
305
  const NcEmojiPicker = __component__.exports;
279
306
  exports.NcEmojiPicker = NcEmojiPicker;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcEmojiPicker-B1ot5iNB.cjs","sources":["../../node_modules/vue-material-design-icons/Circle.vue","../../src/components/NcEmojiPicker/NcEmojiPicker.vue"],"sourcesContent":["<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon circle-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10,10 0 0,0 12,2Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"CircleIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>","<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n### General description\n\nThis component allows the user to pick an emoji.\n\n### Usage\n\n* Listen to the select event and pass in an HTML element that will be treated as a trigger:\n\n```vue\n<template>\n\t<div>\n\t\t<NcEmojiPicker @select=\"select\" style=\"display: inline-block\">\n\t\t\t<NcButton> Click Me </NcButton>\n\t\t</NcEmojiPicker>\n\t\t<span>selected emoji: {{ emoji }}</span>\n\t</div>\n</template>\n<script>\n\texport default {\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\temoji: '',\n\t\t\t}\n\t\t},\n\t\tmethods: {\n\t\t\tselect(emoji) {\n\t\t\t\tthis.emoji = emoji\n\t\t\t},\n\t\t},\n\t}\n</script>\n```\n\n* Showing a preview and keeping it open after a user selected an emoji\n\n```vue\n<template>\n\t<div>\n\t\t<NcEmojiPicker\n\t\t\t:close-on-select=\"false\"\n\t\t\t:show-preview=\"true\"\n\t\t\t@select=\"select\"\n\t\t\tstyle=\"display: inline-block\">\n\t\t\t<NcButton> Click Me </NcButton>\n\t\t</NcEmojiPicker>\n\t\t<span>selected emoji: {{ emoji }}</span>\n\t</div>\n</template>\n<script>\n\texport default {\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\temoji: '',\n\t\t\t}\n\t\t},\n\t\tmethods: {\n\t\t\tselect(emoji) {\n\t\t\t\tthis.emoji = emoji\n\t\t\t},\n\t\t},\n\t}\n</script>\n```\n\n* Allow unselecting a previously set emoji.\n\n```vue\n<template>\n\t<div>\n\t\t<NcEmojiPicker\n\t\t\t:show-preview=\"true\"\n\t\t\t:allow-unselect=\"true\"\n\t\t\t:selected-emoji=\"emoji\"\n\t\t\t@select=\"select\"\n\t\t\t@unselect=\"unselect\"\n\t\t\tstyle=\"display: inline-block\">\n\t\t\t<NcButton> Click Me </NcButton>\n\t\t</NcEmojiPicker>\n\t\t<span>selected emoji: {{ emoji }}</span>\n\t</div>\n</template>\n<script>\n\texport default {\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\temoji: '',\n\t\t\t}\n\t\t},\n\t\tmethods: {\n\t\t\tselect(emoji) {\n\t\t\t\tthis.emoji = emoji\n\t\t\t},\n\t\t\tunselect() {\n\t\t\t\tthis.emoji = ''\n\t\t\t},\n\t\t},\n\t}\n</script>\n```\n\n</docs>\n\n<template>\n\t<NcPopover ref=\"popover\"\n\t\t:shown.sync=\"open\"\n\t\t:container=\"container\"\n\t\tpopup-role=\"dialog\"\n\t\tv-bind=\"$attrs\"\n\t\t:focus-trap=\"false /* Handled manually to remove emoji buttons from TAB sequence */\"\n\t\tv-on=\"$listeners\"\n\t\t@after-show=\"afterShow\"\n\t\t@after-hide=\"afterHide\">\n\t\t<template #trigger=\"slotProps\">\n\t\t\t<slot v-bind=\"slotProps\" />\n\t\t</template>\n\t\t<Picker ref=\"picker\"\n\t\t\tclass=\"nc-emoji-picker\"\n\t\t\tcolor=\"var(--color-primary-element)\"\n\t\t\t:data=\"emojiIndex\"\n\t\t\t:emoji=\"previewFallbackEmoji\"\n\t\t\t:i18n=\"i18n\"\n\t\t\t:native=\"native\"\n\t\t\t:emoji-size=\"20\"\n\t\t\t:per-line=\"8\"\n\t\t\t:picker-styles=\"{ width: '320px' }\"\n\t\t\t:show-preview=\"showPreview\"\n\t\t\t:skin=\"currentSkinTone\"\n\t\t\t:show-skin-tones=\"false\"\n\t\t\t:title=\"previewFallbackName\"\n\t\t\trole=\"dialog\"\n\t\t\taria-modal=\"true\"\n\t\t\t:aria-label=\"t('Emoji picker')\"\n\t\t\tv-bind=\"$attrs\"\n\t\t\t@keydown.native.tab.prevent=\"handleTabNavigationSkippingEmojis\"\n\t\t\t@select=\"select\">\n\t\t\t<template #searchTemplate=\"{ onSearch }\">\n\t\t\t\t<div class=\"search__wrapper\">\n\t\t\t\t\t<NcTextField ref=\"search\"\n\t\t\t\t\t\tclass=\"search\"\n\t\t\t\t\t\t:value.sync=\"search\"\n\t\t\t\t\t\t:label=\"t('Search')\"\n\t\t\t\t\t\t:label-visible=\"true\"\n\t\t\t\t\t\t:placeholder=\"i18n.search\"\n\t\t\t\t\t\ttrailing-button-icon=\"close\"\n\t\t\t\t\t\t:trailing-button-label=\"t('Clear search')\"\n\t\t\t\t\t\t:show-trailing-button=\"search !== ''\"\n\t\t\t\t\t\t@keydown.left=\"callPickerArrowHandlerWithScrollFix('onArrowLeft', $event)\"\n\t\t\t\t\t\t@keydown.right=\"callPickerArrowHandlerWithScrollFix('onArrowRight', $event)\"\n\t\t\t\t\t\t@keydown.down=\"callPickerArrowHandlerWithScrollFix('onArrowDown', $event)\"\n\t\t\t\t\t\t@keydown.up=\"callPickerArrowHandlerWithScrollFix('onArrowUp', $event)\"\n\t\t\t\t\t\t@keydown.enter=\"$refs.picker.onEnter\"\n\t\t\t\t\t\t@trailing-button-click=\"clearSearch(); onSearch('');\"\n\t\t\t\t\t\t@update:value=\"onSearch(search)\" />\n\t\t\t\t\t<NcColorPicker palette-only\n\t\t\t\t\t\t:container=\"container\"\n\t\t\t\t\t\t:palette=\"skinTonePalette\"\n\t\t\t\t\t\t:value=\"currentColor.color\"\n\t\t\t\t\t\t@update:value=\"onChangeSkinTone\">\n\t\t\t\t\t\t<NcButton :aria-label=\"t('Skin tone')\" type=\"tertiary-no-background\">\n\t\t\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t\t\t<IconCircle :style=\"{ color: currentColor.color }\" :title=\"currentColor.name\" :size=\"20\" />\n\t\t\t\t\t\t\t</template>\n\t\t\t\t\t\t</NcButton>\n\t\t\t\t\t</NcColorPicker>\n\t\t\t\t</div>\n\t\t\t</template>\n\t\t\t<template v-if=\"allowUnselect && selectedEmoji\" #customCategory>\n\t\t\t\t<div class=\"emoji-mart-category-label\">\n\t\t\t\t\t<h3 class=\"emoji-mart-category-label\">\n\t\t\t\t\t\t{{ t('Selected') }}\n\t\t\t\t\t</h3>\n\t\t\t\t</div>\n\t\t\t\t<Emoji class=\"emoji-selected\"\n\t\t\t\t\t:data=\"emojiIndex\"\n\t\t\t\t\t:emoji=\"selectedEmoji\"\n\t\t\t\t\t:native=\"true\"\n\t\t\t\t\t:size=\"32\"\n\t\t\t\t\t@click=\"unselect\" />\n\t\t\t\t<Emoji class=\"emoji-delete\"\n\t\t\t\t\t:data=\"emojiIndex\"\n\t\t\t\t\temoji=\":x:\"\n\t\t\t\t\t:native=\"true\"\n\t\t\t\t\t:size=\"10\"\n\t\t\t\t\t@click=\"unselect\" />\n\t\t\t</template>\n\t\t</Picker>\n\t</NcPopover>\n</template>\n\n<script>\nimport { Picker, Emoji, EmojiIndex } from 'emoji-mart-vue-fast'\nimport { t } from '../../l10n.js'\nimport { getCurrentSkinTone, setCurrentSkinTone } from '../../functions/emoji/emoji.ts'\nimport { Color } from '../../utils/GenColors.js'\n\nimport data from 'emoji-mart-vue-fast/data/all.json'\nimport IconCircle from 'vue-material-design-icons/Circle.vue'\nimport NcButton from '../NcButton/index.js'\nimport NcColorPicker from '../NcColorPicker/NcColorPicker.vue'\nimport NcPopover from '../NcPopover/index.js'\nimport NcTextField from '../NcTextField/index.js'\n\n// Shared emoji index and skinTone for all NcEmojiPicker instances\n// Will be initialized on the first NcEmojiPicker creating\nlet emojiIndex\n\nconst i18n = {\n\tsearch: t('Search emoji'),\n\tnotfound: t('No emoji found'),\n\tcategories: {\n\t\tsearch: t('Search results'),\n\t\trecent: t('Frequently used'),\n\t\tsmileys: t('Smileys & Emotion'),\n\t\tpeople: t('People & Body'),\n\t\tnature: t('Animals & Nature'),\n\t\tfoods: t('Food & Drink'),\n\t\tactivity: t('Activities'),\n\t\tplaces: t('Travel & Places'),\n\t\tobjects: t('Objects'),\n\t\tsymbols: t('Symbols'),\n\t\tflags: t('Flags'),\n\t\tcustom: t('Custom'),\n\t},\n}\n\nconst skinTonePalette = [\n\tnew Color(255, 222, 52, t('Neutral skin color')),\n\tnew Color(228, 205, 166, t('Light skin tone')),\n\tnew Color(250, 221, 192, t('Medium light skin tone')),\n\tnew Color(174, 129, 87, t('Medium skin tone')),\n\tnew Color(158, 113, 88, t('Medium dark skin tone')),\n\tnew Color(96, 79, 69, t('Dark skin tone')),\n]\n\nexport default {\n\tname: 'NcEmojiPicker',\n\n\tcomponents: {\n\t\tEmoji,\n\t\tIconCircle,\n\t\tNcButton,\n\t\tNcColorPicker,\n\t\tNcPopover,\n\t\tNcTextField,\n\t\tPicker,\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * The emoji-set\n\t\t */\n\t\tactiveSet: {\n\t\t\ttype: String,\n\t\t\tdefault: 'native',\n\t\t},\n\t\t/**\n\t\t * Show preview section when hovering emoji\n\t\t */\n\t\tshowPreview: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t\t/**\n\t\t * Allow unselecting the selected emoji\n\t\t */\n\t\tallowUnselect: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t\t/**\n\t\t * Selected emoji to allow unselecting\n\t\t */\n\t\tselectedEmoji: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t\t/**\n\t\t * The fallback emoji in the preview section\n\t\t */\n\t\tpreviewFallbackEmoji: {\n\t\t\ttype: String,\n\t\t\tdefault: 'grinning',\n\t\t},\n\t\t/**\n\t\t * The fallback text in the preview section\n\t\t */\n\t\tpreviewFallbackName: {\n\t\t\ttype: String,\n\t\t\tdefault: t('Pick an emoji'),\n\t\t},\n\t\t/**\n\t\t * Whether to close the emoji picker after picking one\n\t\t */\n\t\tcloseOnSelect: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * Selector for the popover container\n\t\t */\n\t\tcontainer: {\n\t\t\ttype: [String, Object, Element, Boolean],\n\t\t\tdefault: 'body',\n\t\t},\n\t},\n\temits: [\n\t\t'select',\n\t\t'select-data',\n\t\t'unselect',\n\t],\n\n\tsetup() {\n\t\t// If this is the first instance of NcEmojiPicker - setup EmojiIndex\n\t\tif (!emojiIndex) {\n\t\t\temojiIndex = new EmojiIndex(data)\n\t\t}\n\n\t\treturn {\n\t\t\t// Non-reactive constants\n\t\t\temojiIndex,\n\t\t\tskinTonePalette,\n\t\t\ti18n,\n\t\t}\n\t},\n\n\tdata() {\n\t\tconst currentSkinTone = getCurrentSkinTone()\n\n\t\treturn {\n\t\t\t/**\n\t\t\t * The current active color from the skin tone palette\n\t\t\t */\n\t\t\tcurrentColor: skinTonePalette[currentSkinTone - 1],\n\t\t\t/**\n\t\t\t * The current active skin tone\n\t\t\t * @type {1|2|3|4|5|6}\n\t\t\t */\n\t\t\tcurrentSkinTone,\n\t\t\tsearch: '',\n\t\t\topen: false,\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tnative() {\n\t\t\treturn this.activeSet === 'native'\n\t\t},\n\t},\n\n\tmethods: {\n\t\tt,\n\n\t\tclearSearch() {\n\t\t\tthis.search = ''\n\t\t\tthis.$refs.search.focus()\n\t\t},\n\n\t\t/**\n\t\t * Update the current skin tone by the result of the color picker\n\t\t * @param {string} color Color set\n\t\t */\n\t\tonChangeSkinTone(color) {\n\t\t\tconst index = this.skinTonePalette.findIndex((tone) => tone.color.toLowerCase() === color.toLowerCase())\n\t\t\tif (index > -1) {\n\t\t\t\tthis.currentSkinTone = index + 1\n\t\t\t\tthis.currentColor = this.skinTonePalette[index]\n\t\t\t\tsetCurrentSkinTone(this.currentSkinTone)\n\t\t\t}\n\t\t},\n\n\t\tselect(emojiObject) {\n\t\t\t/**\n\t\t\t * Emits a string containing the emoji e.g. '👩🏿‍💻'\n\t\t\t */\n\t\t\tthis.$emit('select', emojiObject.native)\n\n\t\t\t/**\n\t\t\t * Emits a object with more data about the picked emoji\n\t\t\t */\n\t\t\tthis.$emit('select-data', emojiObject)\n\n\t\t\tif (this.closeOnSelect) {\n\t\t\t\tthis.open = false\n\t\t\t}\n\t\t},\n\n\t\tunselect() {\n\t\t\tthis.$emit('unselect')\n\t\t},\n\n\t\tafterShow() {\n\t\t\tthis.$refs.search.focus()\n\t\t},\n\n\t\tafterHide() {\n\t\t\t// Manually return focus to the trigger button, as we disabled focus-trap\n\t\t\tthis.$refs.popover.$el.querySelector('button, [role=\"button\"]')?.focus()\n\t\t},\n\n\t\t/**\n\t\t * Manually handle Tab navigation skipping emoji buttons.\n\t\t * Navigation over emojis is handled by Arrow keys.\n\t\t * @param {KeyboardEvent} event - Keyboard event\n\t\t */\n\t\thandleTabNavigationSkippingEmojis(event) {\n\t\t\tconst current = event.target\n\t\t\tconst focusable = Array.from(this.$refs.picker.$el.querySelectorAll('button:not(.emoji-mart-emoji), input'))\n\t\t\tif (!event.shiftKey) {\n\t\t\t\tconst nextNode = focusable.find((node) => current.compareDocumentPosition(node) & Node.DOCUMENT_POSITION_FOLLOWING) || focusable[0]\n\t\t\t\tnextNode.focus()\n\t\t\t} else {\n\t\t\t\tconst prevNode = focusable.findLast((node) => current.compareDocumentPosition(node) & Node.DOCUMENT_POSITION_PRECEDING) || focusable.at(-1)\n\t\t\t\tprevNode.focus()\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Handle arrow navigation via <Picker>'s handlers with scroll bug fix\n\t\t * @param {'onArrowLeft' | 'onArrowRight' | 'onArrowDown' | 'onArrowUp'} originalHandlerName - Picker's arrow keydown handler name\n\t\t * @param {KeyboardEvent} event - Keyboard event\n\t\t */\n\t\tasync callPickerArrowHandlerWithScrollFix(originalHandlerName, event) {\n\t\t\t// Call the original handler\n\t\t\t// See: https://github.com/serebrov/emoji-mart-vue/blob/a1ea72673a111cce78dc8caad8bc9ea3e02ad5bd/src/components/Picker.vue#L29\n\t\t\t// TODO: expose these methods via slot props in upstream library\n\t\t\tthis.$refs.picker[originalHandlerName](event)\n\n\t\t\t// Wait until emoji-mart-vue-fast scrolls\n\t\t\tawait this.$nextTick()\n\n\t\t\t// Scroll position is incorrect after emoji-mart-vue-fast scrolls...\n\t\t\t// It calculates scroll incorrectly.\n\t\t\t// It doesn't take into account, that emojis are wrapped into categories sections\n\t\t\t// See: https://github.com/serebrov/emoji-mart-vue/blob/a1ea72673a111cce78dc8caad8bc9ea3e02ad5bd/src/utils/picker.js#L244\n\t\t\t// Now scroll to the correct position\n\t\t\t// TODO: fix in upstream\n\t\t\tconst selectedEmoji = this.$refs.picker.$el.querySelector('.emoji-mart-emoji-selected')\n\t\t\tselectedEmoji?.scrollIntoView({\n\t\t\t\tblock: 'center',\n\t\t\t\tinline: 'center',\n\t\t\t})\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\">\n@import 'emoji-mart-vue-fast/css/emoji-mart.css';\n\n.nc-emoji-picker.emoji-mart {\n\tbackground-color: var(--color-main-background) !important;\n\tborder: 0;\n\tcolor: var(--color-main-text) !important;\n\n\t// Reset emoji-mart styles\n\tbutton {\n\t\tborder: none;\n\t\tbackground: transparent;\n\t\tfont-size: inherit;\n\t}\n\n\t.emoji-mart-bar,\n\t.emoji-mart-anchors,\n\t.emoji-mart-search,\n\t.emoji-mart-search input,\n\t.emoji-mart-category,\n\t.emoji-mart-category-label,\n\t.emoji-mart-category-label span,\n\t.emoji-mart-skin-swatches {\n\t\tbackground-color: transparent !important;\n\t\tborder-color: var(--color-border) !important;\n\t\tcolor: inherit !important;\n\t}\n\n\t.emoji-mart-anchors {\n\t\tpadding-block: 0;\n\t\tpadding-inline: calc(2 * var(--default-grid-baseline));\n\t}\n\n\t.emoji-mart-anchor {\n\t\tborder-radius: 0;\n\t\tmargin: 0 !important;\n\t\tpadding: 0 !important;\n\t\theight: var(--clickable-area-small);\n\t\tmin-width: var(--clickable-area-small);\n\n\t\t&:hover {\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\n\t\t&:focus-visible {\n\t\t\toutline: 2px solid var(--color-primary-element) !important;\n\t\t\toutline-offset: -2px;\n\t\t}\n\n\t\t// Icon\n\t\tdiv {\n\t\t\tdisplay: grid;\n\t\t\tplace-content: center;\n\t\t}\n\t}\n\n\t.emoji-mart-scroll {\n\t\tpadding-inline: calc(2 * var(--default-grid-baseline));\n\t\tpadding-block: 0 calc(2 * var(--default-grid-baseline));\n\t}\n\n\t.emoji-mart-category {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: repeat(8, 1fr);\n\t\tjustify-items: stretch;\n\n\t\t&.emoji-mart-no-results {\n\t\t\tgrid-template-columns: 1fr;\n\t\t\tfont-size: inherit;\n\t\t\tcolor: var(--color-text-maxcontrast) !important;\n\t\t}\n\t}\n\n\t/* Label element in the section grid */\n\tdiv.emoji-mart-category-label {\n\t\tgrid-column: span 8;\n\t\tjustify-self: stretch;\n\t}\n\n\t/* An actual heading inside the element */\n\th3.emoji-mart-category-label {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\t// Inline with buttons\n\t\theight: var(--default-clickable-area);\n\t\tmargin: 0;\n\t\t// Inline with input\n\t\tpadding-inline: calc(2 * var(--default-grid-baseline));\n\t\tpadding-block: 0;\n\t\tuser-select: none;\n\t}\n\n\t.emoji-mart-emoji {\n\t\taspect-ratio: 1 / 1;\n\t\ttext-align: center;\n\t\tmargin: 0 !important;\n\t\tpadding: 0 !important;\n\n\t\t&:hover,\n\t\t&:focus-visible,\n\t\t&.emoji-mart-emoji-selected {\n\t\t\tbackground-color: var(--color-background-hover) !important;\n\t\t\tborder: none;\n\t\t\tborder-radius: var(--border-radius-element, var(--border-radius-pill));\n\t\t\tbox-shadow: none !important;\n\t\t\toutline: 2px solid var(--color-primary-element) !important;\n\t\t\toutline-offset: -2px;\n\t\t}\n\n\t\t&::before {\n\t\t\tdisplay: none;\n\t\t}\n\n\t\tspan {\n\t\t\tcursor: pointer;\n\t\t}\n\t}\n}\n</style>\n\n<style scoped lang=\"scss\">\n.search__wrapper {\n\tdisplay: flex;\n\tflex-direction: row;\n\tgap: var(--default-grid-baseline);\n\talign-items: end;\n\tpadding-block: var(--default-grid-baseline);\n\tpadding-inline: calc(2 * var(--default-grid-baseline));\n}\n\n.row-selected {\n\tbutton, span {\n\t\tvertical-align: middle;\n\t}\n}\n\n.emoji-delete {\n\tvertical-align: top;\n\tmargin-left: -21px;\n\tmargin-top: -3px;\n}\n</style>\n"],"names":["_sfc_main","t","Color","Emoji","NcButton","NcColorPicker","NcPopover","NcTextField","Picker","EmojiIndex","data","getCurrentSkinTone","setCurrentSkinTone"],"mappings":"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","x_google_ignoreList":[0]}
@@ -1,14 +1,14 @@
1
- import '../assets/NcEmojiPicker-BNCW1Q94.css';
1
+ import '../assets/NcEmojiPicker-rk5qcSl7.css';
2
2
  import { Emoji, Picker, EmojiIndex } from "emoji-mart-vue-fast";
3
- import { r as register, z as t39, A as t34, n as t14, B as t5, a as t } from "./_l10n-C6OUA0Ge.mjs";
3
+ import { r as register, z as t39, A as t34, n as t14, B as t5, a as t } from "./_l10n-DDKxBWQL.mjs";
4
4
  import { g as getCurrentSkinTone, s as setCurrentSkinTone } from "./emoji-BY_D0V5K.mjs";
5
- import { C as Color } from "./GenColors-l51faA-J.mjs";
5
+ import { C as Color } from "./GenColors-DfwXw1-o.mjs";
6
6
  import data from "emoji-mart-vue-fast/data/all.json";
7
7
  import { n as normalizeComponent } from "./_plugin-vue2_normalizer-DU4iP6Vu.mjs";
8
8
  import NcButton from "../Components/NcButton.mjs";
9
- import { N as NcColorPicker } from "./NcColorPicker-CODhE5KL.mjs";
10
- import { N as NcPopover } from "./NcPopover-DzYbNu-I.mjs";
11
- import { N as NcTextField } from "./NcTextField-gOk0FWcs.mjs";
9
+ import { N as NcColorPicker } from "./NcColorPicker-ph8Nubq7.mjs";
10
+ import { N as NcPopover } from "./NcPopover-DFCPlZpS.mjs";
11
+ import { N as NcTextField } from "./NcTextField-9gC8or6j.mjs";
12
12
  register(t5, t14, t34, t39);
13
13
  const _sfc_main$1 = {
14
14
  name: "CircleIcon",
@@ -180,10 +180,7 @@ const _sfc_main = {
180
180
  t,
181
181
  clearSearch() {
182
182
  this.search = "";
183
- const input = this.$refs.search?.$refs.inputField?.$refs.input;
184
- if (input) {
185
- input.focus();
186
- }
183
+ this.$refs.search.focus();
187
184
  },
188
185
  /**
189
186
  * Update the current skin tone by the result of the color picker
@@ -208,54 +205,84 @@ const _sfc_main = {
208
205
  this.$emit("unselect");
209
206
  },
210
207
  afterShow() {
211
- const picker = this.$refs.picker;
212
- picker.$el.addEventListener("keydown", this.checkKeyEvent);
213
- const input = this.$refs.search?.$refs.inputField?.$refs.input;
214
- if (input) {
215
- input.focus();
216
- }
208
+ this.$refs.search.focus();
217
209
  },
218
210
  afterHide() {
219
- const picker = this.$refs.picker;
220
- picker.$el.removeEventListener("keydown", this.checkKeyEvent);
211
+ this.$refs.popover.$el.querySelector('button, [role="button"]')?.focus();
221
212
  },
222
- checkKeyEvent(event) {
223
- if (event.key !== "Tab") {
224
- return;
225
- }
226
- const picker = this.$refs.picker;
227
- const focusableList = picker.$el.querySelectorAll(
228
- "button, input"
229
- );
230
- const last = focusableList.length - 1;
231
- if (focusableList.length <= 1) {
232
- event.preventDefault();
233
- return;
234
- }
235
- if (event.shiftKey === false && event.target === focusableList[last]) {
236
- event.preventDefault();
237
- focusableList[0].focus();
238
- } else if (event.shiftKey === true && event.target === focusableList[0]) {
239
- event.preventDefault();
240
- focusableList[last].focus();
213
+ /**
214
+ * Manually handle Tab navigation skipping emoji buttons.
215
+ * Navigation over emojis is handled by Arrow keys.
216
+ * @param {KeyboardEvent} event - Keyboard event
217
+ */
218
+ handleTabNavigationSkippingEmojis(event) {
219
+ const current = event.target;
220
+ const focusable = Array.from(this.$refs.picker.$el.querySelectorAll("button:not(.emoji-mart-emoji), input"));
221
+ if (!event.shiftKey) {
222
+ const nextNode = focusable.find((node) => current.compareDocumentPosition(node) & Node.DOCUMENT_POSITION_FOLLOWING) || focusable[0];
223
+ nextNode.focus();
224
+ } else {
225
+ const prevNode = focusable.findLast((node) => current.compareDocumentPosition(node) & Node.DOCUMENT_POSITION_PRECEDING) || focusable.at(-1);
226
+ prevNode.focus();
241
227
  }
228
+ },
229
+ /**
230
+ * Handle arrow navigation via <Picker>'s handlers with scroll bug fix
231
+ * @param {'onArrowLeft' | 'onArrowRight' | 'onArrowDown' | 'onArrowUp'} originalHandlerName - Picker's arrow keydown handler name
232
+ * @param {KeyboardEvent} event - Keyboard event
233
+ */
234
+ async callPickerArrowHandlerWithScrollFix(originalHandlerName, event) {
235
+ this.$refs.picker[originalHandlerName](event);
236
+ await this.$nextTick();
237
+ const selectedEmoji = this.$refs.picker.$el.querySelector(".emoji-mart-emoji-selected");
238
+ selectedEmoji?.scrollIntoView({
239
+ block: "center",
240
+ inline: "center"
241
+ });
242
242
  }
243
243
  }
244
244
  };
245
245
  var _sfc_render = function render2() {
246
246
  var _vm = this, _c = _vm._self._c;
247
- return _c("NcPopover", _vm._g(_vm._b({ attrs: { "shown": _vm.open, "container": _vm.container, "popup-role": "dialog" }, on: { "update:shown": function($event) {
247
+ return _c("NcPopover", _vm._g(_vm._b({ ref: "popover", attrs: {
248
+ "shown": _vm.open,
249
+ "container": _vm.container,
250
+ "popup-role": "dialog",
251
+ "focus-trap": false
252
+ /* Handled manually to remove emoji buttons from TAB sequence */
253
+ }, on: { "update:shown": function($event) {
248
254
  _vm.open = $event;
249
255
  }, "after-show": _vm.afterShow, "after-hide": _vm.afterHide }, scopedSlots: _vm._u([{ key: "trigger", fn: function(slotProps) {
250
256
  return [_vm._t("default", null, null, slotProps)];
251
- } }], null, true) }, "NcPopover", _vm.$attrs, false), _vm.$listeners), [_c("Picker", _vm._b({ ref: "picker", attrs: { "auto-focus": false, "color": "var(--color-primary-element)", "data": _vm.emojiIndex, "emoji": _vm.previewFallbackEmoji, "i18n": _vm.i18n, "native": _vm.native, "emoji-size": 20, "per-line": 8, "picker-styles": { width: "320px" }, "show-preview": _vm.showPreview, "skin": _vm.currentSkinTone, "show-skin-tones": false, "title": _vm.previewFallbackName, "role": "dialog", "aria-modal": "true", "aria-label": _vm.t("Emoji picker") }, on: { "select": _vm.select }, scopedSlots: _vm._u([{ key: "searchTemplate", fn: function(slotProps) {
257
+ } }], null, true) }, "NcPopover", _vm.$attrs, false), _vm.$listeners), [_c("Picker", _vm._b({ ref: "picker", staticClass: "nc-emoji-picker", attrs: { "color": "var(--color-primary-element)", "data": _vm.emojiIndex, "emoji": _vm.previewFallbackEmoji, "i18n": _vm.i18n, "native": _vm.native, "emoji-size": 20, "per-line": 8, "picker-styles": { width: "320px" }, "show-preview": _vm.showPreview, "skin": _vm.currentSkinTone, "show-skin-tones": false, "title": _vm.previewFallbackName, "role": "dialog", "aria-modal": "true", "aria-label": _vm.t("Emoji picker") }, on: { "select": _vm.select }, nativeOn: { "keydown": function($event) {
258
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "tab", 9, $event.key, "Tab")) return null;
259
+ $event.preventDefault();
260
+ return _vm.handleTabNavigationSkippingEmojis.apply(null, arguments);
261
+ } }, scopedSlots: _vm._u([{ key: "searchTemplate", fn: function({ onSearch }) {
252
262
  return [_c("div", { staticClass: "search__wrapper" }, [_c("NcTextField", { ref: "search", staticClass: "search", attrs: { "value": _vm.search, "label": _vm.t("Search"), "label-visible": true, "placeholder": _vm.i18n.search, "trailing-button-icon": "close", "trailing-button-label": _vm.t("Clear search"), "show-trailing-button": _vm.search !== "" }, on: { "update:value": [function($event) {
253
263
  _vm.search = $event;
254
264
  }, function($event) {
255
- return slotProps.onSearch(_vm.search);
265
+ return onSearch(_vm.search);
266
+ }], "keydown": [function($event) {
267
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "left", 37, $event.key, ["Left", "ArrowLeft"])) return null;
268
+ if ("button" in $event && $event.button !== 0) return null;
269
+ return _vm.callPickerArrowHandlerWithScrollFix("onArrowLeft", $event);
270
+ }, function($event) {
271
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "right", 39, $event.key, ["Right", "ArrowRight"])) return null;
272
+ if ("button" in $event && $event.button !== 2) return null;
273
+ return _vm.callPickerArrowHandlerWithScrollFix("onArrowRight", $event);
274
+ }, function($event) {
275
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "down", 40, $event.key, ["Down", "ArrowDown"])) return null;
276
+ return _vm.callPickerArrowHandlerWithScrollFix("onArrowDown", $event);
277
+ }, function($event) {
278
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "up", 38, $event.key, ["Up", "ArrowUp"])) return null;
279
+ return _vm.callPickerArrowHandlerWithScrollFix("onArrowUp", $event);
280
+ }, function($event) {
281
+ if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")) return null;
282
+ return _vm.$refs.picker.onEnter.apply(null, arguments);
256
283
  }], "trailing-button-click": function($event) {
257
284
  _vm.clearSearch();
258
- slotProps.onSearch(_vm.search);
285
+ onSearch("");
259
286
  } } }), _c("NcColorPicker", { attrs: { "palette-only": "", "container": _vm.container, "palette": _vm.skinTonePalette, "value": _vm.currentColor.color }, on: { "update:value": _vm.onChangeSkinTone } }, [_c("NcButton", { attrs: { "aria-label": _vm.t("Skin tone"), "type": "tertiary-no-background" }, scopedSlots: _vm._u([{ key: "icon", fn: function() {
260
287
  return [_c("IconCircle", { style: { color: _vm.currentColor.color }, attrs: { "title": _vm.currentColor.name, "size": 20 } })];
261
288
  }, proxy: true }], null, true) })], 1)], 1)];
@@ -270,7 +297,7 @@ var __component__ = /* @__PURE__ */ normalizeComponent(
270
297
  _sfc_staticRenderFns,
271
298
  false,
272
299
  null,
273
- "ed4adfc3"
300
+ "6e39597a"
274
301
  );
275
302
  const NcEmojiPicker = __component__.exports;
276
303
  export {
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcEmojiPicker-DDCgW2zQ.mjs","sources":["../../node_modules/vue-material-design-icons/Circle.vue","../../src/components/NcEmojiPicker/NcEmojiPicker.vue"],"sourcesContent":["<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon circle-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10,10 0 0,0 12,2Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"CircleIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>","<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n### General description\n\nThis component allows the user to pick an emoji.\n\n### Usage\n\n* Listen to the select event and pass in an HTML element that will be treated as a trigger:\n\n```vue\n<template>\n\t<div>\n\t\t<NcEmojiPicker @select=\"select\" style=\"display: inline-block\">\n\t\t\t<NcButton> Click Me </NcButton>\n\t\t</NcEmojiPicker>\n\t\t<span>selected emoji: {{ emoji }}</span>\n\t</div>\n</template>\n<script>\n\texport default {\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\temoji: '',\n\t\t\t}\n\t\t},\n\t\tmethods: {\n\t\t\tselect(emoji) {\n\t\t\t\tthis.emoji = emoji\n\t\t\t},\n\t\t},\n\t}\n</script>\n```\n\n* Showing a preview and keeping it open after a user selected an emoji\n\n```vue\n<template>\n\t<div>\n\t\t<NcEmojiPicker\n\t\t\t:close-on-select=\"false\"\n\t\t\t:show-preview=\"true\"\n\t\t\t@select=\"select\"\n\t\t\tstyle=\"display: inline-block\">\n\t\t\t<NcButton> Click Me </NcButton>\n\t\t</NcEmojiPicker>\n\t\t<span>selected emoji: {{ emoji }}</span>\n\t</div>\n</template>\n<script>\n\texport default {\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\temoji: '',\n\t\t\t}\n\t\t},\n\t\tmethods: {\n\t\t\tselect(emoji) {\n\t\t\t\tthis.emoji = emoji\n\t\t\t},\n\t\t},\n\t}\n</script>\n```\n\n* Allow unselecting a previously set emoji.\n\n```vue\n<template>\n\t<div>\n\t\t<NcEmojiPicker\n\t\t\t:show-preview=\"true\"\n\t\t\t:allow-unselect=\"true\"\n\t\t\t:selected-emoji=\"emoji\"\n\t\t\t@select=\"select\"\n\t\t\t@unselect=\"unselect\"\n\t\t\tstyle=\"display: inline-block\">\n\t\t\t<NcButton> Click Me </NcButton>\n\t\t</NcEmojiPicker>\n\t\t<span>selected emoji: {{ emoji }}</span>\n\t</div>\n</template>\n<script>\n\texport default {\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\temoji: '',\n\t\t\t}\n\t\t},\n\t\tmethods: {\n\t\t\tselect(emoji) {\n\t\t\t\tthis.emoji = emoji\n\t\t\t},\n\t\t\tunselect() {\n\t\t\t\tthis.emoji = ''\n\t\t\t},\n\t\t},\n\t}\n</script>\n```\n\n</docs>\n\n<template>\n\t<NcPopover ref=\"popover\"\n\t\t:shown.sync=\"open\"\n\t\t:container=\"container\"\n\t\tpopup-role=\"dialog\"\n\t\tv-bind=\"$attrs\"\n\t\t:focus-trap=\"false /* Handled manually to remove emoji buttons from TAB sequence */\"\n\t\tv-on=\"$listeners\"\n\t\t@after-show=\"afterShow\"\n\t\t@after-hide=\"afterHide\">\n\t\t<template #trigger=\"slotProps\">\n\t\t\t<slot v-bind=\"slotProps\" />\n\t\t</template>\n\t\t<Picker ref=\"picker\"\n\t\t\tclass=\"nc-emoji-picker\"\n\t\t\tcolor=\"var(--color-primary-element)\"\n\t\t\t:data=\"emojiIndex\"\n\t\t\t:emoji=\"previewFallbackEmoji\"\n\t\t\t:i18n=\"i18n\"\n\t\t\t:native=\"native\"\n\t\t\t:emoji-size=\"20\"\n\t\t\t:per-line=\"8\"\n\t\t\t:picker-styles=\"{ width: '320px' }\"\n\t\t\t:show-preview=\"showPreview\"\n\t\t\t:skin=\"currentSkinTone\"\n\t\t\t:show-skin-tones=\"false\"\n\t\t\t:title=\"previewFallbackName\"\n\t\t\trole=\"dialog\"\n\t\t\taria-modal=\"true\"\n\t\t\t:aria-label=\"t('Emoji picker')\"\n\t\t\tv-bind=\"$attrs\"\n\t\t\t@keydown.native.tab.prevent=\"handleTabNavigationSkippingEmojis\"\n\t\t\t@select=\"select\">\n\t\t\t<template #searchTemplate=\"{ onSearch }\">\n\t\t\t\t<div class=\"search__wrapper\">\n\t\t\t\t\t<NcTextField ref=\"search\"\n\t\t\t\t\t\tclass=\"search\"\n\t\t\t\t\t\t:value.sync=\"search\"\n\t\t\t\t\t\t:label=\"t('Search')\"\n\t\t\t\t\t\t:label-visible=\"true\"\n\t\t\t\t\t\t:placeholder=\"i18n.search\"\n\t\t\t\t\t\ttrailing-button-icon=\"close\"\n\t\t\t\t\t\t:trailing-button-label=\"t('Clear search')\"\n\t\t\t\t\t\t:show-trailing-button=\"search !== ''\"\n\t\t\t\t\t\t@keydown.left=\"callPickerArrowHandlerWithScrollFix('onArrowLeft', $event)\"\n\t\t\t\t\t\t@keydown.right=\"callPickerArrowHandlerWithScrollFix('onArrowRight', $event)\"\n\t\t\t\t\t\t@keydown.down=\"callPickerArrowHandlerWithScrollFix('onArrowDown', $event)\"\n\t\t\t\t\t\t@keydown.up=\"callPickerArrowHandlerWithScrollFix('onArrowUp', $event)\"\n\t\t\t\t\t\t@keydown.enter=\"$refs.picker.onEnter\"\n\t\t\t\t\t\t@trailing-button-click=\"clearSearch(); onSearch('');\"\n\t\t\t\t\t\t@update:value=\"onSearch(search)\" />\n\t\t\t\t\t<NcColorPicker palette-only\n\t\t\t\t\t\t:container=\"container\"\n\t\t\t\t\t\t:palette=\"skinTonePalette\"\n\t\t\t\t\t\t:value=\"currentColor.color\"\n\t\t\t\t\t\t@update:value=\"onChangeSkinTone\">\n\t\t\t\t\t\t<NcButton :aria-label=\"t('Skin tone')\" type=\"tertiary-no-background\">\n\t\t\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t\t\t<IconCircle :style=\"{ color: currentColor.color }\" :title=\"currentColor.name\" :size=\"20\" />\n\t\t\t\t\t\t\t</template>\n\t\t\t\t\t\t</NcButton>\n\t\t\t\t\t</NcColorPicker>\n\t\t\t\t</div>\n\t\t\t</template>\n\t\t\t<template v-if=\"allowUnselect && selectedEmoji\" #customCategory>\n\t\t\t\t<div class=\"emoji-mart-category-label\">\n\t\t\t\t\t<h3 class=\"emoji-mart-category-label\">\n\t\t\t\t\t\t{{ t('Selected') }}\n\t\t\t\t\t</h3>\n\t\t\t\t</div>\n\t\t\t\t<Emoji class=\"emoji-selected\"\n\t\t\t\t\t:data=\"emojiIndex\"\n\t\t\t\t\t:emoji=\"selectedEmoji\"\n\t\t\t\t\t:native=\"true\"\n\t\t\t\t\t:size=\"32\"\n\t\t\t\t\t@click=\"unselect\" />\n\t\t\t\t<Emoji class=\"emoji-delete\"\n\t\t\t\t\t:data=\"emojiIndex\"\n\t\t\t\t\temoji=\":x:\"\n\t\t\t\t\t:native=\"true\"\n\t\t\t\t\t:size=\"10\"\n\t\t\t\t\t@click=\"unselect\" />\n\t\t\t</template>\n\t\t</Picker>\n\t</NcPopover>\n</template>\n\n<script>\nimport { Picker, Emoji, EmojiIndex } from 'emoji-mart-vue-fast'\nimport { t } from '../../l10n.js'\nimport { getCurrentSkinTone, setCurrentSkinTone } from '../../functions/emoji/emoji.ts'\nimport { Color } from '../../utils/GenColors.js'\n\nimport data from 'emoji-mart-vue-fast/data/all.json'\nimport IconCircle from 'vue-material-design-icons/Circle.vue'\nimport NcButton from '../NcButton/index.js'\nimport NcColorPicker from '../NcColorPicker/NcColorPicker.vue'\nimport NcPopover from '../NcPopover/index.js'\nimport NcTextField from '../NcTextField/index.js'\n\n// Shared emoji index and skinTone for all NcEmojiPicker instances\n// Will be initialized on the first NcEmojiPicker creating\nlet emojiIndex\n\nconst i18n = {\n\tsearch: t('Search emoji'),\n\tnotfound: t('No emoji found'),\n\tcategories: {\n\t\tsearch: t('Search results'),\n\t\trecent: t('Frequently used'),\n\t\tsmileys: t('Smileys & Emotion'),\n\t\tpeople: t('People & Body'),\n\t\tnature: t('Animals & Nature'),\n\t\tfoods: t('Food & Drink'),\n\t\tactivity: t('Activities'),\n\t\tplaces: t('Travel & Places'),\n\t\tobjects: t('Objects'),\n\t\tsymbols: t('Symbols'),\n\t\tflags: t('Flags'),\n\t\tcustom: t('Custom'),\n\t},\n}\n\nconst skinTonePalette = [\n\tnew Color(255, 222, 52, t('Neutral skin color')),\n\tnew Color(228, 205, 166, t('Light skin tone')),\n\tnew Color(250, 221, 192, t('Medium light skin tone')),\n\tnew Color(174, 129, 87, t('Medium skin tone')),\n\tnew Color(158, 113, 88, t('Medium dark skin tone')),\n\tnew Color(96, 79, 69, t('Dark skin tone')),\n]\n\nexport default {\n\tname: 'NcEmojiPicker',\n\n\tcomponents: {\n\t\tEmoji,\n\t\tIconCircle,\n\t\tNcButton,\n\t\tNcColorPicker,\n\t\tNcPopover,\n\t\tNcTextField,\n\t\tPicker,\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * The emoji-set\n\t\t */\n\t\tactiveSet: {\n\t\t\ttype: String,\n\t\t\tdefault: 'native',\n\t\t},\n\t\t/**\n\t\t * Show preview section when hovering emoji\n\t\t */\n\t\tshowPreview: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t\t/**\n\t\t * Allow unselecting the selected emoji\n\t\t */\n\t\tallowUnselect: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t\t/**\n\t\t * Selected emoji to allow unselecting\n\t\t */\n\t\tselectedEmoji: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t\t/**\n\t\t * The fallback emoji in the preview section\n\t\t */\n\t\tpreviewFallbackEmoji: {\n\t\t\ttype: String,\n\t\t\tdefault: 'grinning',\n\t\t},\n\t\t/**\n\t\t * The fallback text in the preview section\n\t\t */\n\t\tpreviewFallbackName: {\n\t\t\ttype: String,\n\t\t\tdefault: t('Pick an emoji'),\n\t\t},\n\t\t/**\n\t\t * Whether to close the emoji picker after picking one\n\t\t */\n\t\tcloseOnSelect: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * Selector for the popover container\n\t\t */\n\t\tcontainer: {\n\t\t\ttype: [String, Object, Element, Boolean],\n\t\t\tdefault: 'body',\n\t\t},\n\t},\n\temits: [\n\t\t'select',\n\t\t'select-data',\n\t\t'unselect',\n\t],\n\n\tsetup() {\n\t\t// If this is the first instance of NcEmojiPicker - setup EmojiIndex\n\t\tif (!emojiIndex) {\n\t\t\temojiIndex = new EmojiIndex(data)\n\t\t}\n\n\t\treturn {\n\t\t\t// Non-reactive constants\n\t\t\temojiIndex,\n\t\t\tskinTonePalette,\n\t\t\ti18n,\n\t\t}\n\t},\n\n\tdata() {\n\t\tconst currentSkinTone = getCurrentSkinTone()\n\n\t\treturn {\n\t\t\t/**\n\t\t\t * The current active color from the skin tone palette\n\t\t\t */\n\t\t\tcurrentColor: skinTonePalette[currentSkinTone - 1],\n\t\t\t/**\n\t\t\t * The current active skin tone\n\t\t\t * @type {1|2|3|4|5|6}\n\t\t\t */\n\t\t\tcurrentSkinTone,\n\t\t\tsearch: '',\n\t\t\topen: false,\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tnative() {\n\t\t\treturn this.activeSet === 'native'\n\t\t},\n\t},\n\n\tmethods: {\n\t\tt,\n\n\t\tclearSearch() {\n\t\t\tthis.search = ''\n\t\t\tthis.$refs.search.focus()\n\t\t},\n\n\t\t/**\n\t\t * Update the current skin tone by the result of the color picker\n\t\t * @param {string} color Color set\n\t\t */\n\t\tonChangeSkinTone(color) {\n\t\t\tconst index = this.skinTonePalette.findIndex((tone) => tone.color.toLowerCase() === color.toLowerCase())\n\t\t\tif (index > -1) {\n\t\t\t\tthis.currentSkinTone = index + 1\n\t\t\t\tthis.currentColor = this.skinTonePalette[index]\n\t\t\t\tsetCurrentSkinTone(this.currentSkinTone)\n\t\t\t}\n\t\t},\n\n\t\tselect(emojiObject) {\n\t\t\t/**\n\t\t\t * Emits a string containing the emoji e.g. '👩🏿‍💻'\n\t\t\t */\n\t\t\tthis.$emit('select', emojiObject.native)\n\n\t\t\t/**\n\t\t\t * Emits a object with more data about the picked emoji\n\t\t\t */\n\t\t\tthis.$emit('select-data', emojiObject)\n\n\t\t\tif (this.closeOnSelect) {\n\t\t\t\tthis.open = false\n\t\t\t}\n\t\t},\n\n\t\tunselect() {\n\t\t\tthis.$emit('unselect')\n\t\t},\n\n\t\tafterShow() {\n\t\t\tthis.$refs.search.focus()\n\t\t},\n\n\t\tafterHide() {\n\t\t\t// Manually return focus to the trigger button, as we disabled focus-trap\n\t\t\tthis.$refs.popover.$el.querySelector('button, [role=\"button\"]')?.focus()\n\t\t},\n\n\t\t/**\n\t\t * Manually handle Tab navigation skipping emoji buttons.\n\t\t * Navigation over emojis is handled by Arrow keys.\n\t\t * @param {KeyboardEvent} event - Keyboard event\n\t\t */\n\t\thandleTabNavigationSkippingEmojis(event) {\n\t\t\tconst current = event.target\n\t\t\tconst focusable = Array.from(this.$refs.picker.$el.querySelectorAll('button:not(.emoji-mart-emoji), input'))\n\t\t\tif (!event.shiftKey) {\n\t\t\t\tconst nextNode = focusable.find((node) => current.compareDocumentPosition(node) & Node.DOCUMENT_POSITION_FOLLOWING) || focusable[0]\n\t\t\t\tnextNode.focus()\n\t\t\t} else {\n\t\t\t\tconst prevNode = focusable.findLast((node) => current.compareDocumentPosition(node) & Node.DOCUMENT_POSITION_PRECEDING) || focusable.at(-1)\n\t\t\t\tprevNode.focus()\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Handle arrow navigation via <Picker>'s handlers with scroll bug fix\n\t\t * @param {'onArrowLeft' | 'onArrowRight' | 'onArrowDown' | 'onArrowUp'} originalHandlerName - Picker's arrow keydown handler name\n\t\t * @param {KeyboardEvent} event - Keyboard event\n\t\t */\n\t\tasync callPickerArrowHandlerWithScrollFix(originalHandlerName, event) {\n\t\t\t// Call the original handler\n\t\t\t// See: https://github.com/serebrov/emoji-mart-vue/blob/a1ea72673a111cce78dc8caad8bc9ea3e02ad5bd/src/components/Picker.vue#L29\n\t\t\t// TODO: expose these methods via slot props in upstream library\n\t\t\tthis.$refs.picker[originalHandlerName](event)\n\n\t\t\t// Wait until emoji-mart-vue-fast scrolls\n\t\t\tawait this.$nextTick()\n\n\t\t\t// Scroll position is incorrect after emoji-mart-vue-fast scrolls...\n\t\t\t// It calculates scroll incorrectly.\n\t\t\t// It doesn't take into account, that emojis are wrapped into categories sections\n\t\t\t// See: https://github.com/serebrov/emoji-mart-vue/blob/a1ea72673a111cce78dc8caad8bc9ea3e02ad5bd/src/utils/picker.js#L244\n\t\t\t// Now scroll to the correct position\n\t\t\t// TODO: fix in upstream\n\t\t\tconst selectedEmoji = this.$refs.picker.$el.querySelector('.emoji-mart-emoji-selected')\n\t\t\tselectedEmoji?.scrollIntoView({\n\t\t\t\tblock: 'center',\n\t\t\t\tinline: 'center',\n\t\t\t})\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\">\n@import 'emoji-mart-vue-fast/css/emoji-mart.css';\n\n.nc-emoji-picker.emoji-mart {\n\tbackground-color: var(--color-main-background) !important;\n\tborder: 0;\n\tcolor: var(--color-main-text) !important;\n\n\t// Reset emoji-mart styles\n\tbutton {\n\t\tborder: none;\n\t\tbackground: transparent;\n\t\tfont-size: inherit;\n\t}\n\n\t.emoji-mart-bar,\n\t.emoji-mart-anchors,\n\t.emoji-mart-search,\n\t.emoji-mart-search input,\n\t.emoji-mart-category,\n\t.emoji-mart-category-label,\n\t.emoji-mart-category-label span,\n\t.emoji-mart-skin-swatches {\n\t\tbackground-color: transparent !important;\n\t\tborder-color: var(--color-border) !important;\n\t\tcolor: inherit !important;\n\t}\n\n\t.emoji-mart-anchors {\n\t\tpadding-block: 0;\n\t\tpadding-inline: calc(2 * var(--default-grid-baseline));\n\t}\n\n\t.emoji-mart-anchor {\n\t\tborder-radius: 0;\n\t\tmargin: 0 !important;\n\t\tpadding: 0 !important;\n\t\theight: var(--clickable-area-small);\n\t\tmin-width: var(--clickable-area-small);\n\n\t\t&:hover {\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\n\t\t&:focus-visible {\n\t\t\toutline: 2px solid var(--color-primary-element) !important;\n\t\t\toutline-offset: -2px;\n\t\t}\n\n\t\t// Icon\n\t\tdiv {\n\t\t\tdisplay: grid;\n\t\t\tplace-content: center;\n\t\t}\n\t}\n\n\t.emoji-mart-scroll {\n\t\tpadding-inline: calc(2 * var(--default-grid-baseline));\n\t\tpadding-block: 0 calc(2 * var(--default-grid-baseline));\n\t}\n\n\t.emoji-mart-category {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: repeat(8, 1fr);\n\t\tjustify-items: stretch;\n\n\t\t&.emoji-mart-no-results {\n\t\t\tgrid-template-columns: 1fr;\n\t\t\tfont-size: inherit;\n\t\t\tcolor: var(--color-text-maxcontrast) !important;\n\t\t}\n\t}\n\n\t/* Label element in the section grid */\n\tdiv.emoji-mart-category-label {\n\t\tgrid-column: span 8;\n\t\tjustify-self: stretch;\n\t}\n\n\t/* An actual heading inside the element */\n\th3.emoji-mart-category-label {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\t// Inline with buttons\n\t\theight: var(--default-clickable-area);\n\t\tmargin: 0;\n\t\t// Inline with input\n\t\tpadding-inline: calc(2 * var(--default-grid-baseline));\n\t\tpadding-block: 0;\n\t\tuser-select: none;\n\t}\n\n\t.emoji-mart-emoji {\n\t\taspect-ratio: 1 / 1;\n\t\ttext-align: center;\n\t\tmargin: 0 !important;\n\t\tpadding: 0 !important;\n\n\t\t&:hover,\n\t\t&:focus-visible,\n\t\t&.emoji-mart-emoji-selected {\n\t\t\tbackground-color: var(--color-background-hover) !important;\n\t\t\tborder: none;\n\t\t\tborder-radius: var(--border-radius-element, var(--border-radius-pill));\n\t\t\tbox-shadow: none !important;\n\t\t\toutline: 2px solid var(--color-primary-element) !important;\n\t\t\toutline-offset: -2px;\n\t\t}\n\n\t\t&::before {\n\t\t\tdisplay: none;\n\t\t}\n\n\t\tspan {\n\t\t\tcursor: pointer;\n\t\t}\n\t}\n}\n</style>\n\n<style scoped lang=\"scss\">\n.search__wrapper {\n\tdisplay: flex;\n\tflex-direction: row;\n\tgap: var(--default-grid-baseline);\n\talign-items: end;\n\tpadding-block: var(--default-grid-baseline);\n\tpadding-inline: calc(2 * var(--default-grid-baseline));\n}\n\n.row-selected {\n\tbutton, span {\n\t\tvertical-align: middle;\n\t}\n}\n\n.emoji-delete {\n\tvertical-align: top;\n\tmargin-left: -21px;\n\tmargin-top: -3px;\n}\n</style>\n"],"names":["_sfc_main"],"mappings":"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","x_google_ignoreList":[0]}
@@ -1,5 +1,5 @@
1
- require('../assets/NcMentionBubble-Bt71nB8X.css');
2
- require('../assets/NcHeaderMenu-C2XbJMYL.css');
1
+ require('../assets/NcMentionBubble-BL05HUeF.css');
2
+ require('../assets/NcHeaderMenu-BYjnMPPl.css');
3
3
  "use strict";
4
4
  const components = require("@vueuse/components");
5
5
  const focusTrap = require("focus-trap");
@@ -10,7 +10,6 @@ require("../Composables/useIsMobile.cjs");
10
10
  require("@nextcloud/router");
11
11
  ;/* empty css */
12
12
  const _pluginVue2_normalizer = require("./_plugin-vue2_normalizer-V0q-tHlQ.cjs");
13
- require("linkify-string");
14
13
  require("escape-html");
15
14
  require("striptags");
16
15
  require("vue");
@@ -215,7 +214,7 @@ var __component__ = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
215
214
  _sfc_staticRenderFns,
216
215
  false,
217
216
  null,
218
- "0cca0699"
217
+ "ba584e05"
219
218
  );
220
219
  const NcHeaderMenu = __component__.exports;
221
220
  exports.NcHeaderMenu = NcHeaderMenu;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcHeaderMenu-BaHhnhN0.cjs","sources":["../../src/components/NcHeaderMenu/NcHeaderMenu.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nThis component is made to be used in the Nextcloud top header.\n\n```\n<template>\n\t<div id=\"nextcloud-header\">\n\t\t<NcHeaderMenu id=\"search\"\n\t\t\taria-label=\"Search\">\n\t\t\t<template #trigger>\n\t\t\t\t<Magnify />\n\t\t\t</template>\n\t\t\t<div>\n\t\t\t\t<NcTextField label=\"Search for files, comments, contacts…\"\n\t\t\t\tstyle=\"padding-inline: 8px;\"\n\t\t\t\ttype=\"search\"\n\t\t\t\t:value.sync=\"query\" />\n\t\t\t\t<NcEmptyContent\n\t\t\t\t\tname=\"Search\"\n\t\t\t\t\t:description=\"query ? `No results for '${query}'` : 'Start typing to search'\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<Magnify />\n\t\t\t\t\t</template>\n\t\t\t\t</NcEmptyContent>\n\t\t\t</div>\n\t\t</NcHeaderMenu>\n\t</div>\n</template>\n<script>\nimport Magnify from 'vue-material-design-icons/Magnify'\n\nexport default {\n\tcomponents: {\n\t\tMagnify,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tquery: '',\n\t\t}\n\t},\n}\n</script>\n<style>\n#nextcloud-header {\n\tdisplay: flex;\n\tjustify-content: right;\n\tbackground-color: var(--color-primary);\n\theight: var(--header-height, 50px);\n\tpadding-inline-end: 12px;\n}\n</style>\n```\n</docs>\n\n<template>\n\t<component :is=\"wrapperTag\"\n\t\t:id=\"id\"\n\t\tref=\"headerMenu\"\n\t\tv-click-outside=\"clickOutsideConfig\"\n\t\t:aria-labelledby=\"isNav ? triggerId : null\"\n\t\t:class=\"{ 'header-menu--opened': opened }\"\n\t\tclass=\"header-menu\"\n\t\tv-on=\"listeners\">\n\t\t<!-- Trigger -->\n\t\t<NcButton :id=\"isNav ? triggerId : null\"\n\t\t\tref=\"trigger\"\n\t\t\ttype=\"tertiary-no-background\"\n\t\t\tclass=\"header-menu__trigger\"\n\t\t\t:aria-label=\"ariaLabel\"\n\t\t\t:aria-describedby=\"description ? descriptionId : null\"\n\t\t\t:aria-controls=\"`header-menu-${id}`\"\n\t\t\t:aria-expanded=\"opened.toString()\"\n\t\t\tsize=\"large\"\n\t\t\t@click.prevent=\"toggleMenu\">\n\t\t\t<template #icon>\n\t\t\t\t<!-- @slot Icon trigger slot. Make sure the svg path\n\t\t\t\tis at least 16px. Usually mdi icon works at 20px -->\n\t\t\t\t<slot name=\"trigger\" />\n\t\t\t</template>\n\t\t</NcButton>\n\n\t\t<span v-if=\"description\"\n\t\t\t:id=\"descriptionId\"\n\t\t\tclass=\"header-menu__description hidden-visually\">\n\t\t\t{{ description }}\n\t\t</span>\n\n\t\t<!-- Visual triangle -->\n\t\t<div v-show=\"opened\" class=\"header-menu__carret\" />\n\n\t\t<!-- Menu opened content -->\n\t\t<div v-show=\"opened\"\n\t\t\t:id=\"`header-menu-${id}`\"\n\t\t\tclass=\"header-menu__wrapper\">\n\t\t\t<div ref=\"content\" class=\"header-menu__content\">\n\t\t\t\t<!-- @slot Main content -->\n\t\t\t\t<slot />\n\t\t\t</div>\n\t\t</div>\n\t</component>\n</template>\n\n<script>\nimport { vOnClickOutside as ClickOutside } from '@vueuse/components'\nimport { createFocusTrap } from 'focus-trap'\n\nimport GenRandomId from '../../utils/GenRandomId.js'\nimport { clickOutsideOptions } from '../../mixins/index.js'\nimport { getTrapStack } from '../../utils/focusTrap.js'\n\nimport NcButton from '../NcButton/index.js'\n\nexport default {\n\tname: 'NcHeaderMenu',\n\n\tcomponents: {\n\t\tNcButton,\n\t},\n\n\tdirectives: {\n\t\tClickOutside,\n\t},\n\n\tmixins: [\n\t\tclickOutsideOptions,\n\t],\n\n\tprops: {\n\t\t/**\n\t\t * Unique id for this menu\n\t\t */\n\t\tid: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * aria-label attribute of the menu open button\n\t\t */\n\t\tariaLabel: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Current menu open state\n\t\t */\n\t\topen: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Pass `true` if the header menu is used for website navigation\n\t\t *\n\t\t * The wrapper tag will be set to `nav` and its `aria-labelledby`\n\t\t * will be associated with the menu open button\n\t\t */\n\t\tisNav: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Additional visually hidden description text for the menu\n\t\t * open button\n\t\t */\n\t\tdescription: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\t},\n\n\temits: [\n\t\t'close',\n\t\t'closed',\n\t\t'open',\n\t\t'opened',\n\t\t'update:open',\n\t\t'cancel',\n\t],\n\n\tdata() {\n\t\treturn {\n\t\t\tfocusTrap: null,\n\t\t\topened: this.open,\n\t\t\tshortcutsDisabled: window.OCP?.Accessibility?.disableKeyboardShortcuts?.(),\n\t\t\ttriggerId: GenRandomId(),\n\t\t\tdescriptionId: GenRandomId(),\n\t\t}\n\t},\n\n\tcomputed: {\n\t\twrapperTag() {\n\t\t\treturn this.isNav ? 'nav' : 'div'\n\t\t},\n\n\t\tclickOutsideConfig() {\n\t\t\treturn [\n\t\t\t\tthis.closeMenu,\n\t\t\t\tthis.clickOutsideOptions,\n\t\t\t]\n\t\t},\n\n\t\tlisteners() {\n\t\t\tif (this.isNav) {\n\t\t\t\treturn {\n\t\t\t\t\tfocusout: this.onFocusOut,\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn null\n\t\t},\n\t},\n\n\twatch: {\n\t\topen(open) {\n\t\t\tif (open) {\n\t\t\t\tthis.openMenu()\n\t\t\t} else {\n\t\t\t\tthis.closeMenu()\n\t\t\t}\n\t\t},\n\t},\n\n\tmounted() {\n\t\tdocument.addEventListener('keydown', this.onKeyDown)\n\t},\n\tbeforeDestroy() {\n\t\tdocument.removeEventListener('keydown', this.onKeyDown)\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Toggle the current menu open state\n\t\t */\n\t\ttoggleMenu() {\n\t\t\t// Toggling current state\n\t\t\tif (!this.opened) {\n\t\t\t\tthis.openMenu()\n\t\t\t} else {\n\t\t\t\tthis.closeMenu()\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Close the current menu\n\t\t *\n\t\t * @param {boolean} cancelled emit a cancel event instead of close\n\t\t */\n\t\tcloseMenu(cancelled = false) {\n\t\t\t// Close the menu\n\t\t\tthis.opened = false\n\t\t\tthis.$emit(cancelled ? 'cancel' : 'close')\n\t\t\tthis.$emit('update:open', false)\n\n\t\t\t// Kill focus trap\n\t\t\tthis.clearFocusTrap()\n\n\t\t\t// Wait for component to finish rendering\n\t\t\tthis.$nextTick(() => {\n\t\t\t\tthis.$emit('closed')\n\t\t\t})\n\t\t},\n\n\t\t/**\n\t\t * Open the current menu\n\t\t */\n\t\topenMenu() {\n\t\t\t// Open the menu\n\t\t\tthis.opened = true\n\t\t\tthis.$emit('open')\n\t\t\tthis.$emit('update:open', true)\n\n\t\t\t// Wait for component to finish rendering\n\t\t\tthis.$nextTick(() => {\n\t\t\t\tthis.useFocusTrap()\n\t\t\t\tthis.$emit('opened')\n\t\t\t})\n\t\t},\n\n\t\tonKeyDown(event) {\n\t\t\tif (this.shortcutsDisabled || !this.opened) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\t// If escape have been pressed, we close\n\t\t\tif (event.key === 'Escape') {\n\t\t\t\tevent.preventDefault()\n\n\t\t\t\t/** User cancelled the menu by pressing escape */\n\t\t\t\tthis.closeMenu(true)\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * @param {FocusEvent} event The focus event\n\t\t */\n\t\tonFocusOut(event) {\n\t\t\tif (!this.$refs.headerMenu.contains(event.relatedTarget)) {\n\t\t\t\tthis.closeMenu()\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Add focus trap for accessibility.\n\t\t * Shall only be used when all children are mounted\n\t\t * and available in the DOM. We use $nextTick for that.\n\t\t */\n\t\tasync useFocusTrap() {\n\t\t\tif (this.isNav || this.focusTrap) {\n\t\t\t\treturn\n\t\t\t}\n\t\t\t// Init focus trap\n\t\t\tconst contentContainer = this.$refs.content\n\t\t\tthis.focusTrap = createFocusTrap(contentContainer, {\n\t\t\t\tallowOutsideClick: true,\n\t\t\t\ttrapStack: getTrapStack(),\n\t\t\t\tfallbackFocus: this.$refs.trigger,\n\t\t\t})\n\t\t\tthis.focusTrap.activate()\n\t\t},\n\t\tclearFocusTrap() {\n\t\t\tthis.focusTrap?.deactivate()\n\t\t\tthis.focusTrap = null\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n// content inner and outer margin\n// Also used for menu top-right positioning\n$externalMargin: 8px;\n\n@import './header-menu__trigger';\n\n.header-menu {\n\t&__wrapper {\n\t\tposition: fixed;\n\t\tz-index: 2000;\n\t\ttop: var(--header-height);\n\t\tinset-inline-end: 0;\n\t\tbox-sizing: border-box;\n\t\tmargin: 0 $externalMargin;\n\t\tborder-radius: 0 0 var(--border-radius) var(--border-radius);\n\t\tborder-radius: var(--border-radius-large);\n\t\tbackground-color: var(--color-main-background);\n\n\t\tfilter: drop-shadow(0 1px 5px var(--color-box-shadow));\n\t}\n\n\t&__carret {\n\t\tposition: absolute;\n\t\tz-index: 2001; // Because __wrapper is 2000.\n\t\tbottom: 0;\n\t\tinset-inline-start: calc(50% - 10px);\n\t\twidth: 0;\n\t\theight: 0;\n\t\tcontent: ' ';\n\t\tpointer-events: none;\n\t\tborder: 10px solid transparent;\n\t\tborder-bottom-color: var(--color-main-background);\n\t}\n\n\t&__content {\n\t\toverflow: auto;\n\t\twidth: 350px;\n\t\tmax-width: calc(100vw - 2 * $externalMargin);\n\t\tmin-height: calc(var(--default-clickable-area) * 1.5);\n\t\tmax-height: calc(100vh - var(--header-height) * 2);\n\t\t:deep(.empty-content) {\n\t\t\tmargin: 12vh 10px;\n\t\t}\n\t}\n}\n</style>\n"],"names":["NcButton","ClickOutside","clickOutsideOptions","GenRandomId","createFocusTrap","getTrapStack"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- import '../assets/NcMentionBubble-Bt71nB8X.css';
2
- import '../assets/NcHeaderMenu-C2XbJMYL.css';
1
+ import '../assets/NcMentionBubble-BL05HUeF.css';
2
+ import '../assets/NcHeaderMenu-BYjnMPPl.css';
3
3
  import { vOnClickOutside } from "@vueuse/components";
4
4
  import { createFocusTrap } from "focus-trap";
5
5
  import { G as GenRandomId } from "./GenRandomId-CMooMQt0.mjs";
@@ -9,7 +9,6 @@ import "../Composables/useIsMobile.mjs";
9
9
  import "@nextcloud/router";
10
10
  /* empty css */
11
11
  import { n as normalizeComponent } from "./_plugin-vue2_normalizer-DU4iP6Vu.mjs";
12
- import "linkify-string";
13
12
  import "escape-html";
14
13
  import "striptags";
15
14
  import "vue";
@@ -214,7 +213,7 @@ var __component__ = /* @__PURE__ */ normalizeComponent(
214
213
  _sfc_staticRenderFns,
215
214
  false,
216
215
  null,
217
- "0cca0699"
216
+ "ba584e05"
218
217
  );
219
218
  const NcHeaderMenu = __component__.exports;
220
219
  export {
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcHeaderMenu-CLcpStap.mjs","sources":["../../src/components/NcHeaderMenu/NcHeaderMenu.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nThis component is made to be used in the Nextcloud top header.\n\n```\n<template>\n\t<div id=\"nextcloud-header\">\n\t\t<NcHeaderMenu id=\"search\"\n\t\t\taria-label=\"Search\">\n\t\t\t<template #trigger>\n\t\t\t\t<Magnify />\n\t\t\t</template>\n\t\t\t<div>\n\t\t\t\t<NcTextField label=\"Search for files, comments, contacts…\"\n\t\t\t\tstyle=\"padding-inline: 8px;\"\n\t\t\t\ttype=\"search\"\n\t\t\t\t:value.sync=\"query\" />\n\t\t\t\t<NcEmptyContent\n\t\t\t\t\tname=\"Search\"\n\t\t\t\t\t:description=\"query ? `No results for '${query}'` : 'Start typing to search'\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<Magnify />\n\t\t\t\t\t</template>\n\t\t\t\t</NcEmptyContent>\n\t\t\t</div>\n\t\t</NcHeaderMenu>\n\t</div>\n</template>\n<script>\nimport Magnify from 'vue-material-design-icons/Magnify'\n\nexport default {\n\tcomponents: {\n\t\tMagnify,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tquery: '',\n\t\t}\n\t},\n}\n</script>\n<style>\n#nextcloud-header {\n\tdisplay: flex;\n\tjustify-content: right;\n\tbackground-color: var(--color-primary);\n\theight: var(--header-height, 50px);\n\tpadding-inline-end: 12px;\n}\n</style>\n```\n</docs>\n\n<template>\n\t<component :is=\"wrapperTag\"\n\t\t:id=\"id\"\n\t\tref=\"headerMenu\"\n\t\tv-click-outside=\"clickOutsideConfig\"\n\t\t:aria-labelledby=\"isNav ? triggerId : null\"\n\t\t:class=\"{ 'header-menu--opened': opened }\"\n\t\tclass=\"header-menu\"\n\t\tv-on=\"listeners\">\n\t\t<!-- Trigger -->\n\t\t<NcButton :id=\"isNav ? triggerId : null\"\n\t\t\tref=\"trigger\"\n\t\t\ttype=\"tertiary-no-background\"\n\t\t\tclass=\"header-menu__trigger\"\n\t\t\t:aria-label=\"ariaLabel\"\n\t\t\t:aria-describedby=\"description ? descriptionId : null\"\n\t\t\t:aria-controls=\"`header-menu-${id}`\"\n\t\t\t:aria-expanded=\"opened.toString()\"\n\t\t\tsize=\"large\"\n\t\t\t@click.prevent=\"toggleMenu\">\n\t\t\t<template #icon>\n\t\t\t\t<!-- @slot Icon trigger slot. Make sure the svg path\n\t\t\t\tis at least 16px. Usually mdi icon works at 20px -->\n\t\t\t\t<slot name=\"trigger\" />\n\t\t\t</template>\n\t\t</NcButton>\n\n\t\t<span v-if=\"description\"\n\t\t\t:id=\"descriptionId\"\n\t\t\tclass=\"header-menu__description hidden-visually\">\n\t\t\t{{ description }}\n\t\t</span>\n\n\t\t<!-- Visual triangle -->\n\t\t<div v-show=\"opened\" class=\"header-menu__carret\" />\n\n\t\t<!-- Menu opened content -->\n\t\t<div v-show=\"opened\"\n\t\t\t:id=\"`header-menu-${id}`\"\n\t\t\tclass=\"header-menu__wrapper\">\n\t\t\t<div ref=\"content\" class=\"header-menu__content\">\n\t\t\t\t<!-- @slot Main content -->\n\t\t\t\t<slot />\n\t\t\t</div>\n\t\t</div>\n\t</component>\n</template>\n\n<script>\nimport { vOnClickOutside as ClickOutside } from '@vueuse/components'\nimport { createFocusTrap } from 'focus-trap'\n\nimport GenRandomId from '../../utils/GenRandomId.js'\nimport { clickOutsideOptions } from '../../mixins/index.js'\nimport { getTrapStack } from '../../utils/focusTrap.js'\n\nimport NcButton from '../NcButton/index.js'\n\nexport default {\n\tname: 'NcHeaderMenu',\n\n\tcomponents: {\n\t\tNcButton,\n\t},\n\n\tdirectives: {\n\t\tClickOutside,\n\t},\n\n\tmixins: [\n\t\tclickOutsideOptions,\n\t],\n\n\tprops: {\n\t\t/**\n\t\t * Unique id for this menu\n\t\t */\n\t\tid: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * aria-label attribute of the menu open button\n\t\t */\n\t\tariaLabel: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Current menu open state\n\t\t */\n\t\topen: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Pass `true` if the header menu is used for website navigation\n\t\t *\n\t\t * The wrapper tag will be set to `nav` and its `aria-labelledby`\n\t\t * will be associated with the menu open button\n\t\t */\n\t\tisNav: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Additional visually hidden description text for the menu\n\t\t * open button\n\t\t */\n\t\tdescription: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\t},\n\n\temits: [\n\t\t'close',\n\t\t'closed',\n\t\t'open',\n\t\t'opened',\n\t\t'update:open',\n\t\t'cancel',\n\t],\n\n\tdata() {\n\t\treturn {\n\t\t\tfocusTrap: null,\n\t\t\topened: this.open,\n\t\t\tshortcutsDisabled: window.OCP?.Accessibility?.disableKeyboardShortcuts?.(),\n\t\t\ttriggerId: GenRandomId(),\n\t\t\tdescriptionId: GenRandomId(),\n\t\t}\n\t},\n\n\tcomputed: {\n\t\twrapperTag() {\n\t\t\treturn this.isNav ? 'nav' : 'div'\n\t\t},\n\n\t\tclickOutsideConfig() {\n\t\t\treturn [\n\t\t\t\tthis.closeMenu,\n\t\t\t\tthis.clickOutsideOptions,\n\t\t\t]\n\t\t},\n\n\t\tlisteners() {\n\t\t\tif (this.isNav) {\n\t\t\t\treturn {\n\t\t\t\t\tfocusout: this.onFocusOut,\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn null\n\t\t},\n\t},\n\n\twatch: {\n\t\topen(open) {\n\t\t\tif (open) {\n\t\t\t\tthis.openMenu()\n\t\t\t} else {\n\t\t\t\tthis.closeMenu()\n\t\t\t}\n\t\t},\n\t},\n\n\tmounted() {\n\t\tdocument.addEventListener('keydown', this.onKeyDown)\n\t},\n\tbeforeDestroy() {\n\t\tdocument.removeEventListener('keydown', this.onKeyDown)\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Toggle the current menu open state\n\t\t */\n\t\ttoggleMenu() {\n\t\t\t// Toggling current state\n\t\t\tif (!this.opened) {\n\t\t\t\tthis.openMenu()\n\t\t\t} else {\n\t\t\t\tthis.closeMenu()\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Close the current menu\n\t\t *\n\t\t * @param {boolean} cancelled emit a cancel event instead of close\n\t\t */\n\t\tcloseMenu(cancelled = false) {\n\t\t\t// Close the menu\n\t\t\tthis.opened = false\n\t\t\tthis.$emit(cancelled ? 'cancel' : 'close')\n\t\t\tthis.$emit('update:open', false)\n\n\t\t\t// Kill focus trap\n\t\t\tthis.clearFocusTrap()\n\n\t\t\t// Wait for component to finish rendering\n\t\t\tthis.$nextTick(() => {\n\t\t\t\tthis.$emit('closed')\n\t\t\t})\n\t\t},\n\n\t\t/**\n\t\t * Open the current menu\n\t\t */\n\t\topenMenu() {\n\t\t\t// Open the menu\n\t\t\tthis.opened = true\n\t\t\tthis.$emit('open')\n\t\t\tthis.$emit('update:open', true)\n\n\t\t\t// Wait for component to finish rendering\n\t\t\tthis.$nextTick(() => {\n\t\t\t\tthis.useFocusTrap()\n\t\t\t\tthis.$emit('opened')\n\t\t\t})\n\t\t},\n\n\t\tonKeyDown(event) {\n\t\t\tif (this.shortcutsDisabled || !this.opened) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\t// If escape have been pressed, we close\n\t\t\tif (event.key === 'Escape') {\n\t\t\t\tevent.preventDefault()\n\n\t\t\t\t/** User cancelled the menu by pressing escape */\n\t\t\t\tthis.closeMenu(true)\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * @param {FocusEvent} event The focus event\n\t\t */\n\t\tonFocusOut(event) {\n\t\t\tif (!this.$refs.headerMenu.contains(event.relatedTarget)) {\n\t\t\t\tthis.closeMenu()\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Add focus trap for accessibility.\n\t\t * Shall only be used when all children are mounted\n\t\t * and available in the DOM. We use $nextTick for that.\n\t\t */\n\t\tasync useFocusTrap() {\n\t\t\tif (this.isNav || this.focusTrap) {\n\t\t\t\treturn\n\t\t\t}\n\t\t\t// Init focus trap\n\t\t\tconst contentContainer = this.$refs.content\n\t\t\tthis.focusTrap = createFocusTrap(contentContainer, {\n\t\t\t\tallowOutsideClick: true,\n\t\t\t\ttrapStack: getTrapStack(),\n\t\t\t\tfallbackFocus: this.$refs.trigger,\n\t\t\t})\n\t\t\tthis.focusTrap.activate()\n\t\t},\n\t\tclearFocusTrap() {\n\t\t\tthis.focusTrap?.deactivate()\n\t\t\tthis.focusTrap = null\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n// content inner and outer margin\n// Also used for menu top-right positioning\n$externalMargin: 8px;\n\n@import './header-menu__trigger';\n\n.header-menu {\n\t&__wrapper {\n\t\tposition: fixed;\n\t\tz-index: 2000;\n\t\ttop: var(--header-height);\n\t\tinset-inline-end: 0;\n\t\tbox-sizing: border-box;\n\t\tmargin: 0 $externalMargin;\n\t\tborder-radius: 0 0 var(--border-radius) var(--border-radius);\n\t\tborder-radius: var(--border-radius-large);\n\t\tbackground-color: var(--color-main-background);\n\n\t\tfilter: drop-shadow(0 1px 5px var(--color-box-shadow));\n\t}\n\n\t&__carret {\n\t\tposition: absolute;\n\t\tz-index: 2001; // Because __wrapper is 2000.\n\t\tbottom: 0;\n\t\tinset-inline-start: calc(50% - 10px);\n\t\twidth: 0;\n\t\theight: 0;\n\t\tcontent: ' ';\n\t\tpointer-events: none;\n\t\tborder: 10px solid transparent;\n\t\tborder-bottom-color: var(--color-main-background);\n\t}\n\n\t&__content {\n\t\toverflow: auto;\n\t\twidth: 350px;\n\t\tmax-width: calc(100vw - 2 * $externalMargin);\n\t\tmin-height: calc(var(--default-clickable-area) * 1.5);\n\t\tmax-height: calc(100vh - var(--header-height) * 2);\n\t\t:deep(.empty-content) {\n\t\t\tmargin: 12vh 10px;\n\t\t}\n\t}\n}\n</style>\n"],"names":["ClickOutside"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import '../assets/NcInputConfirmCancel-EYtW7MxF.css';
2
2
  import NcButton from "../Components/NcButton.mjs";
3
- import { r as register, o as t12, a as t } from "./_l10n-C6OUA0Ge.mjs";
3
+ import { r as register, o as t12, a as t } from "./_l10n-DDKxBWQL.mjs";
4
4
  import { A as ArrowRight } from "./ArrowRight-CY2b9hgN.mjs";
5
5
  import { C as Close } from "./Close-BtLPUSdO.mjs";
6
6
  import { n as normalizeComponent } from "./_plugin-vue2_normalizer-DU4iP6Vu.mjs";
@@ -1 +1 @@
1
- {"version":3,"file":"NcInputConfirmCancel-C6zlmXZ4.mjs","sources":["../../src/components/NcAppNavigationItem/NcInputConfirmCancel.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n# Usage\n\n```\n<NcInputConfirmCancel @confirm=\"alert('confirm')\" @cancel=\"alert('cancel')\" />\n```\n</docs>\n<template>\n\t<div class=\"app-navigation-input-confirm\">\n\t\t<form @submit.prevent=\"confirm\"\n\t\t\t@keydown.esc.exact.stop.prevent=\"cancel\"\n\t\t\t@click.stop.prevent>\n\t\t\t<input ref=\"input\"\n\t\t\t\tv-model=\"valueModel\"\n\t\t\t\ttype=\"text\"\n\t\t\t\tclass=\"app-navigation-input-confirm__input\"\n\t\t\t\t:placeholder=\"placeholder\">\n\n\t\t\t<NcButton native-type=\"submit\"\n\t\t\t\ttype=\"primary\"\n\t\t\t\t:aria-label=\"labelConfirm\"\n\t\t\t\t@click.stop.prevent=\"confirm\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<ArrowRight :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t</NcButton>\n\n\t\t\t<NcButton native-type=\"reset\"\n\t\t\t\t:type=\"primary ? 'primary' : 'tertiary'\"\n\t\t\t\t:aria-label=\"labelCancel\"\n\t\t\t\t@click.stop.prevent=\"cancel\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Close :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t</NcButton>\n\t\t</form>\n\t</div>\n</template>\n<script>\nimport NcButton from '../NcButton/index.js'\nimport { t } from '../../l10n.js'\n\nimport ArrowRight from 'vue-material-design-icons/ArrowRight.vue'\nimport Close from 'vue-material-design-icons/Close.vue'\n\nexport default {\n\tname: 'NcInputConfirmCancel',\n\n\tcomponents: {\n\t\tNcButton,\n\t\tArrowRight,\n\t\tClose,\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * If this element is used on a primary element set to true for primary styling.\n\t\t */\n\t\tprimary: {\n\t\t\tdefault: false,\n\t\t\ttype: Boolean,\n\t\t},\n\n\t\tplaceholder: {\n\t\t\tdefault: '',\n\t\t\ttype: String,\n\t\t},\n\n\t\tvalue: {\n\t\t\tdefault: '',\n\t\t\ttype: String,\n\t\t},\n\t},\n\n\temits: [\n\t\t'input',\n\t\t'confirm',\n\t\t'cancel',\n\t],\n\n\tdata() {\n\t\treturn {\n\t\t\tlabelConfirm: t('Confirm changes'),\n\t\t\tlabelCancel: t('Cancel changes'),\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tvalueModel: {\n\t\t\tget() { return this.value },\n\t\t\tset(newValue) {\n\t\t\t\tthis.$emit('input', newValue)\n\t\t\t},\n\t\t},\n\t},\n\n\tmethods: {\n\t\tconfirm() {\n\t\t\tthis.$emit('confirm')\n\t\t},\n\t\tcancel() {\n\t\t\tthis.$emit('cancel')\n\t\t},\n\t\tfocusInput() {\n\t\t\tthis.$refs.input.focus()\n\t\t},\n\t},\n}\n</script>\n\n<style scoped lang=\"scss\">\n$input-height: 34px;\n$input-padding: 7px;\n$input-margin: 5px;\n\n.app-navigation-input-confirm {\n\tflex: 1 0 100%;\n\twidth: 100%;\n\n\tform {\n\t\tdisplay: flex;\n\t}\n\n\t&__input {\n\t\theight: $input-height;\n\t\tflex: 1 1 100%;\n\t\tfont-size: 100% !important;\n\t\tmargin: $input-margin !important;\n\t\tmargin-left: -1px - $input-padding !important;\n\t\tpadding: $input-padding !important;\n\n\t\t&:active,\n\t\t&:focus,\n\t\t&:hover {\n\t\t\toutline: none;\n\t\t\tbackground-color: var(--color-main-background);\n\t\t\tcolor: var(--color-main-text);\n\t\t\tborder-color: var(--color-primary-element);\n\t\t}\n\t}\n}\n</style>\n"],"names":[],"mappings":";;;;;;AAkDA,MAAA,YAAA;AAAA,EACA,MAAA;AAAA,EAEA,YAAA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA;AAAA;AAAA;AAAA,IAIA,SAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,IAEA,aAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,IAEA,OAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AACA,WAAA;AAAA,MACA,cAAA,EAAA,iBAAA;AAAA,MACA,aAAA,EAAA,gBAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,UAAA;AAAA,IACA,YAAA;AAAA,MACA,MAAA;AAAA,eAAA,KAAA;AAAA,MAAA;AAAA,MACA,IAAA,UAAA;AACA,aAAA,MAAA,SAAA,QAAA;AAAA,MACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA,IACA,UAAA;AACA,WAAA,MAAA,SAAA;AAAA,IACA;AAAA,IACA,SAAA;AACA,WAAA,MAAA,QAAA;AAAA,IACA;AAAA,IACA,aAAA;AACA,WAAA,MAAA,MAAA,MAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"NcInputConfirmCancel-C7a7Nha7.mjs","sources":["../../src/components/NcAppNavigationItem/NcInputConfirmCancel.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n# Usage\n\n```\n<NcInputConfirmCancel @confirm=\"alert('confirm')\" @cancel=\"alert('cancel')\" />\n```\n</docs>\n<template>\n\t<div class=\"app-navigation-input-confirm\">\n\t\t<form @submit.prevent=\"confirm\"\n\t\t\t@keydown.esc.exact.stop.prevent=\"cancel\"\n\t\t\t@click.stop.prevent>\n\t\t\t<input ref=\"input\"\n\t\t\t\tv-model=\"valueModel\"\n\t\t\t\ttype=\"text\"\n\t\t\t\tclass=\"app-navigation-input-confirm__input\"\n\t\t\t\t:placeholder=\"placeholder\">\n\n\t\t\t<NcButton native-type=\"submit\"\n\t\t\t\ttype=\"primary\"\n\t\t\t\t:aria-label=\"labelConfirm\"\n\t\t\t\t@click.stop.prevent=\"confirm\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<ArrowRight :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t</NcButton>\n\n\t\t\t<NcButton native-type=\"reset\"\n\t\t\t\t:type=\"primary ? 'primary' : 'tertiary'\"\n\t\t\t\t:aria-label=\"labelCancel\"\n\t\t\t\t@click.stop.prevent=\"cancel\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Close :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t</NcButton>\n\t\t</form>\n\t</div>\n</template>\n<script>\nimport NcButton from '../NcButton/index.js'\nimport { t } from '../../l10n.js'\n\nimport ArrowRight from 'vue-material-design-icons/ArrowRight.vue'\nimport Close from 'vue-material-design-icons/Close.vue'\n\nexport default {\n\tname: 'NcInputConfirmCancel',\n\n\tcomponents: {\n\t\tNcButton,\n\t\tArrowRight,\n\t\tClose,\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * If this element is used on a primary element set to true for primary styling.\n\t\t */\n\t\tprimary: {\n\t\t\tdefault: false,\n\t\t\ttype: Boolean,\n\t\t},\n\n\t\tplaceholder: {\n\t\t\tdefault: '',\n\t\t\ttype: String,\n\t\t},\n\n\t\tvalue: {\n\t\t\tdefault: '',\n\t\t\ttype: String,\n\t\t},\n\t},\n\n\temits: [\n\t\t'input',\n\t\t'confirm',\n\t\t'cancel',\n\t],\n\n\tdata() {\n\t\treturn {\n\t\t\tlabelConfirm: t('Confirm changes'),\n\t\t\tlabelCancel: t('Cancel changes'),\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tvalueModel: {\n\t\t\tget() { return this.value },\n\t\t\tset(newValue) {\n\t\t\t\tthis.$emit('input', newValue)\n\t\t\t},\n\t\t},\n\t},\n\n\tmethods: {\n\t\tconfirm() {\n\t\t\tthis.$emit('confirm')\n\t\t},\n\t\tcancel() {\n\t\t\tthis.$emit('cancel')\n\t\t},\n\t\tfocusInput() {\n\t\t\tthis.$refs.input.focus()\n\t\t},\n\t},\n}\n</script>\n\n<style scoped lang=\"scss\">\n$input-height: 34px;\n$input-padding: 7px;\n$input-margin: 5px;\n\n.app-navigation-input-confirm {\n\tflex: 1 0 100%;\n\twidth: 100%;\n\n\tform {\n\t\tdisplay: flex;\n\t}\n\n\t&__input {\n\t\theight: $input-height;\n\t\tflex: 1 1 100%;\n\t\tfont-size: 100% !important;\n\t\tmargin: $input-margin !important;\n\t\tmargin-left: -1px - $input-padding !important;\n\t\tpadding: $input-padding !important;\n\n\t\t&:active,\n\t\t&:focus,\n\t\t&:hover {\n\t\t\toutline: none;\n\t\t\tbackground-color: var(--color-main-background);\n\t\t\tcolor: var(--color-main-text);\n\t\t\tborder-color: var(--color-primary-element);\n\t\t}\n\t}\n}\n</style>\n"],"names":[],"mappings":";;;;;;AAkDA,MAAA,YAAA;AAAA,EACA,MAAA;AAAA,EAEA,YAAA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA;AAAA;AAAA;AAAA,IAIA,SAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,IAEA,aAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,IAEA,OAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AACA,WAAA;AAAA,MACA,cAAA,EAAA,iBAAA;AAAA,MACA,aAAA,EAAA,gBAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,UAAA;AAAA,IACA,YAAA;AAAA,MACA,MAAA;AAAA,eAAA,KAAA;AAAA,MAAA;AAAA,MACA,IAAA,UAAA;AACA,aAAA,MAAA,SAAA,QAAA;AAAA,MACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA,IACA,UAAA;AACA,WAAA,MAAA,SAAA;AAAA,IACA;AAAA,IACA,SAAA;AACA,WAAA,MAAA,QAAA;AAAA,IACA;AAAA,IACA,aAAA;AACA,WAAA,MAAA,MAAA,MAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}