@nextcloud/vue 9.4.0 → 9.6.0

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 (361) hide show
  1. package/CHANGELOG.md +37 -0
  2. package/dist/assets/{NcAppContent-zKcAQ2bt.css → NcAppContent-BC7DBer3.css} +22 -19
  3. package/dist/assets/{NcButton--Fj4gghF.css → NcButton-CCY9S6Db.css} +48 -49
  4. package/dist/assets/NcFilePicker-CimiKIH1.css +6 -0
  5. package/dist/assets/{NcInputField-D7X6Iz5N.css → NcInputField-DR0FULeu.css} +44 -43
  6. package/dist/assets/{NcListItem-CWa6A_FV.css → NcListItem-Cat18cSx.css} +41 -41
  7. package/dist/assets/{NcModal-bYmoCrzo.css → NcModal-CUh8AdAE.css} +62 -63
  8. package/dist/assets/{NcProgressBar-BAPOXMAL.css → NcProgressBar-D1DYRrCN.css} +23 -12
  9. package/dist/assets/{NcRadioGroupButton-kVqVEDKS.css → NcRadioGroupButton-xGU7fVa3.css} +9 -1
  10. package/dist/assets/{NcRichContenteditable-C4KtXEvK.css → NcRichContenteditable-Do20Rmk1.css} +11 -11
  11. package/dist/assets/{NcRichText-3BHy89Ls.css → NcRichText-ZpC0uhOy.css} +93 -93
  12. package/dist/assets/NcSelectUsers-YF5729PJ.css +4 -0
  13. package/dist/assets/{NcTextArea-_-yGXq-j.css → NcTextArea-DF9NgPUa.css} +30 -28
  14. package/dist/chunks/{ArrowRight-DRKHUZMH.mjs → ArrowRight-B1ncAhus.mjs} +2 -2
  15. package/dist/chunks/{ArrowRight-DRKHUZMH.mjs.map → ArrowRight-B1ncAhus.mjs.map} +1 -1
  16. package/dist/chunks/{ChevronDown-FiGpp0KT.mjs → ChevronDown-C6gc637b.mjs} +2 -2
  17. package/dist/chunks/{ChevronDown-FiGpp0KT.mjs.map → ChevronDown-C6gc637b.mjs.map} +1 -1
  18. package/dist/chunks/{ChevronUp-DPXFp1ss.mjs → ChevronUp-ChH8oB7p.mjs} +2 -2
  19. package/dist/chunks/{ChevronUp-DPXFp1ss.mjs.map → ChevronUp-ChH8oB7p.mjs.map} +1 -1
  20. package/dist/chunks/{Close-D6ngJ4t9.mjs → Close-CuhcJnX2.mjs} +2 -2
  21. package/dist/chunks/{Close-D6ngJ4t9.mjs.map → Close-CuhcJnX2.mjs.map} +1 -1
  22. package/dist/chunks/{NcActionButton-DNXoAooH.mjs → NcActionButton-BuRnYpJX.mjs} +3 -3
  23. package/dist/chunks/{NcActionButton-DNXoAooH.mjs.map → NcActionButton-BuRnYpJX.mjs.map} +1 -1
  24. package/dist/chunks/{NcActionButtonGroup-C4oY8x5z.mjs → NcActionButtonGroup-CrbcMWK-.mjs} +3 -3
  25. package/dist/chunks/{NcActionButtonGroup-C4oY8x5z.mjs.map → NcActionButtonGroup-CrbcMWK-.mjs.map} +1 -1
  26. package/dist/chunks/{NcActionCaption-Cgd3J8jw.mjs → NcActionCaption-f7L9gBlT.mjs} +2 -2
  27. package/dist/chunks/{NcActionCaption-Cgd3J8jw.mjs.map → NcActionCaption-f7L9gBlT.mjs.map} +1 -1
  28. package/dist/chunks/{NcActionCheckbox-DeHAMd23.mjs → NcActionCheckbox-CjawS972.mjs} +3 -3
  29. package/dist/chunks/{NcActionCheckbox-DeHAMd23.mjs.map → NcActionCheckbox-CjawS972.mjs.map} +1 -1
  30. package/dist/chunks/{NcActionInput-Cgazb3df.mjs → NcActionInput-BrI5iKHo.mjs} +7 -7
  31. package/dist/chunks/{NcActionInput-Cgazb3df.mjs.map → NcActionInput-BrI5iKHo.mjs.map} +1 -1
  32. package/dist/chunks/{NcActionLink-Cd69py4e.mjs → NcActionLink-CCszAEdZ.mjs} +2 -2
  33. package/dist/chunks/{NcActionLink-Cd69py4e.mjs.map → NcActionLink-CCszAEdZ.mjs.map} +1 -1
  34. package/dist/chunks/{NcActionRadio-DILn0DxW.mjs → NcActionRadio-BV9Ra5tq.mjs} +3 -3
  35. package/dist/chunks/{NcActionRadio-DILn0DxW.mjs.map → NcActionRadio-BV9Ra5tq.mjs.map} +1 -1
  36. package/dist/chunks/{NcActionRouter-DtxPh20B.mjs → NcActionRouter-CvDVCQiQ.mjs} +2 -2
  37. package/dist/chunks/{NcActionRouter-DtxPh20B.mjs.map → NcActionRouter-CvDVCQiQ.mjs.map} +1 -1
  38. package/dist/chunks/{NcActionSeparator-Doekl1NX.mjs → NcActionSeparator-B9pNQaji.mjs} +2 -2
  39. package/dist/chunks/{NcActionSeparator-Doekl1NX.mjs.map → NcActionSeparator-B9pNQaji.mjs.map} +1 -1
  40. package/dist/chunks/{NcActionText-Bd1fgVqA.mjs → NcActionText-SU4ghOlw.mjs} +2 -2
  41. package/dist/chunks/{NcActionText-Bd1fgVqA.mjs.map → NcActionText-SU4ghOlw.mjs.map} +1 -1
  42. package/dist/chunks/{NcActionTextEditable-DL4idmon.mjs → NcActionTextEditable-BC66QDvV.mjs} +3 -3
  43. package/dist/chunks/{NcActionTextEditable-DL4idmon.mjs.map → NcActionTextEditable-BC66QDvV.mjs.map} +1 -1
  44. package/dist/chunks/{NcActions-CCXgfwjS.mjs → NcActions-B_QR93qv.mjs} +5 -5
  45. package/dist/chunks/{NcActions-CCXgfwjS.mjs.map → NcActions-B_QR93qv.mjs.map} +1 -1
  46. package/dist/chunks/{NcAppContent-DHTZAiBV.mjs → NcAppContent-D27Kyq5N.mjs} +16 -13
  47. package/dist/chunks/NcAppContent-D27Kyq5N.mjs.map +1 -0
  48. package/dist/chunks/{NcAppContentDetails.vue_vue_type_script_setup_true_lang-Dnf4r_Ng.mjs → NcAppContentDetails.vue_vue_type_script_setup_true_lang-BWl5Pw5g.mjs} +2 -2
  49. package/dist/chunks/{NcAppContentDetails.vue_vue_type_script_setup_true_lang-Dnf4r_Ng.mjs.map → NcAppContentDetails.vue_vue_type_script_setup_true_lang-BWl5Pw5g.mjs.map} +1 -1
  50. package/dist/chunks/{NcAppContentList-DYFsuDKh.mjs → NcAppContentList-Copx3Ver.mjs} +2 -2
  51. package/dist/chunks/{NcAppContentList-DYFsuDKh.mjs.map → NcAppContentList-Copx3Ver.mjs.map} +1 -1
  52. package/dist/chunks/{NcAppNavigation--KrbROgq.mjs → NcAppNavigation-DQzgUarc.mjs} +6 -6
  53. package/dist/chunks/{NcAppNavigation--KrbROgq.mjs.map → NcAppNavigation-DQzgUarc.mjs.map} +1 -1
  54. package/dist/chunks/{NcAppNavigationCaption-Dj1-JWNN.mjs → NcAppNavigationCaption-DsM6rzrK.mjs} +3 -3
  55. package/dist/chunks/{NcAppNavigationCaption-Dj1-JWNN.mjs.map → NcAppNavigationCaption-DsM6rzrK.mjs.map} +1 -1
  56. package/dist/chunks/{NcAppNavigationIconBullet-PrlhOoE9.mjs → NcAppNavigationIconBullet-BmU-dPcY.mjs} +2 -2
  57. package/dist/chunks/{NcAppNavigationIconBullet-PrlhOoE9.mjs.map → NcAppNavigationIconBullet-BmU-dPcY.mjs.map} +1 -1
  58. package/dist/chunks/{NcAppNavigationItem-DhsEitgm.mjs → NcAppNavigationItem-XSXn3qhJ.mjs} +11 -11
  59. package/dist/chunks/{NcAppNavigationItem-DhsEitgm.mjs.map → NcAppNavigationItem-XSXn3qhJ.mjs.map} +1 -1
  60. package/dist/chunks/{NcAppNavigationList-BX0wE-dB.mjs → NcAppNavigationList-CGSWabRB.mjs} +2 -2
  61. package/dist/chunks/{NcAppNavigationList-BX0wE-dB.mjs.map → NcAppNavigationList-CGSWabRB.mjs.map} +1 -1
  62. package/dist/chunks/{NcAppNavigationNew-WS0F9mau.mjs → NcAppNavigationNew-BkybFzV0.mjs} +3 -3
  63. package/dist/chunks/{NcAppNavigationNew-WS0F9mau.mjs.map → NcAppNavigationNew-BkybFzV0.mjs.map} +1 -1
  64. package/dist/chunks/{NcAppNavigationNewItem-DhSxNT1C.mjs → NcAppNavigationNewItem-CNb-I7xZ.mjs} +4 -4
  65. package/dist/chunks/{NcAppNavigationNewItem-DhSxNT1C.mjs.map → NcAppNavigationNewItem-CNb-I7xZ.mjs.map} +1 -1
  66. package/dist/chunks/{NcAppNavigationSearch-BHsw27kG.mjs → NcAppNavigationSearch-DpcjjmY5.mjs} +6 -6
  67. package/dist/chunks/{NcAppNavigationSearch-BHsw27kG.mjs.map → NcAppNavigationSearch-DpcjjmY5.mjs.map} +1 -1
  68. package/dist/chunks/{NcAppNavigationSettings-sbSJX76f.mjs → NcAppNavigationSettings-CxjLIB1E.mjs} +6 -6
  69. package/dist/chunks/{NcAppNavigationSettings-sbSJX76f.mjs.map → NcAppNavigationSettings-CxjLIB1E.mjs.map} +1 -1
  70. package/dist/chunks/{NcAppNavigationSpacer-BvkBfuVw.mjs → NcAppNavigationSpacer-CIRC4ZEj.mjs} +2 -2
  71. package/dist/chunks/{NcAppNavigationSpacer-BvkBfuVw.mjs.map → NcAppNavigationSpacer-CIRC4ZEj.mjs.map} +1 -1
  72. package/dist/chunks/{NcAppSettingsDialog-Bg2wk6rG.mjs → NcAppSettingsDialog-Brgi3W2x.mjs} +7 -7
  73. package/dist/chunks/{NcAppSettingsDialog-Bg2wk6rG.mjs.map → NcAppSettingsDialog-Brgi3W2x.mjs.map} +1 -1
  74. package/dist/chunks/{NcAppSettingsSection-B2pFK0UK.mjs → NcAppSettingsSection-B-ak1kbx.mjs} +2 -2
  75. package/dist/chunks/{NcAppSettingsSection-B2pFK0UK.mjs.map → NcAppSettingsSection-B-ak1kbx.mjs.map} +1 -1
  76. package/dist/chunks/{NcAppSettingsShortcutsSection-D--3hFzE.mjs → NcAppSettingsShortcutsSection-HmIjAN0a.mjs} +4 -4
  77. package/dist/chunks/{NcAppSettingsShortcutsSection-D--3hFzE.mjs.map → NcAppSettingsShortcutsSection-HmIjAN0a.mjs.map} +1 -1
  78. package/dist/chunks/{NcAppSidebar-BnTLeCUs.mjs → NcAppSidebar-KwLsRcZO.mjs} +10 -10
  79. package/dist/chunks/{NcAppSidebar-BnTLeCUs.mjs.map → NcAppSidebar-KwLsRcZO.mjs.map} +1 -1
  80. package/dist/chunks/{NcAppSidebarHeader.vue_vue_type_script_setup_true_lang-0j0aFDeK.mjs → NcAppSidebarHeader.vue_vue_type_script_setup_true_lang-Bk4yFBHY.mjs} +2 -2
  81. package/dist/chunks/{NcAppSidebarHeader.vue_vue_type_script_setup_true_lang-0j0aFDeK.mjs.map → NcAppSidebarHeader.vue_vue_type_script_setup_true_lang-Bk4yFBHY.mjs.map} +1 -1
  82. package/dist/chunks/{NcAppSidebarTab-Cjetm3Fs.mjs → NcAppSidebarTab-DOSDDbGA.mjs} +2 -2
  83. package/dist/chunks/{NcAppSidebarTab-Cjetm3Fs.mjs.map → NcAppSidebarTab-DOSDDbGA.mjs.map} +1 -1
  84. package/dist/chunks/{NcAssistantButton-DRcoUE6a.mjs → NcAssistantButton-DxNbEbqt.mjs} +5 -5
  85. package/dist/chunks/{NcAssistantButton-DRcoUE6a.mjs.map → NcAssistantButton-DxNbEbqt.mjs.map} +1 -1
  86. package/dist/chunks/{NcAssistantContent-BR3lWBWC.mjs → NcAssistantContent-DWv2sak_.mjs} +2 -2
  87. package/dist/chunks/{NcAssistantContent-BR3lWBWC.mjs.map → NcAssistantContent-DWv2sak_.mjs.map} +1 -1
  88. package/dist/chunks/{NcAssistantIcon-DsJh5rb7.mjs → NcAssistantIcon-Cf0B3EsL.mjs} +2 -2
  89. package/dist/chunks/{NcAssistantIcon-DsJh5rb7.mjs.map → NcAssistantIcon-Cf0B3EsL.mjs.map} +1 -1
  90. package/dist/chunks/{NcAvatar-xQb0quUq.mjs → NcAvatar-ruClKRzS.mjs} +12 -12
  91. package/dist/chunks/{NcAvatar-xQb0quUq.mjs.map → NcAvatar-ruClKRzS.mjs.map} +1 -1
  92. package/dist/chunks/{NcBlurHash-Cp7enp4q.mjs → NcBlurHash-B3MufoB_.mjs} +2 -2
  93. package/dist/chunks/{NcBlurHash-Cp7enp4q.mjs.map → NcBlurHash-B3MufoB_.mjs.map} +1 -1
  94. package/dist/chunks/{NcBreadcrumb-D-e0UGiz.mjs → NcBreadcrumb-D2NtMTnk.mjs} +4 -4
  95. package/dist/chunks/{NcBreadcrumb-D-e0UGiz.mjs.map → NcBreadcrumb-D2NtMTnk.mjs.map} +1 -1
  96. package/dist/chunks/{NcBreadcrumbs-CGztlUEK.mjs → NcBreadcrumbs-DDutZRtm.mjs} +7 -7
  97. package/dist/chunks/{NcBreadcrumbs-CGztlUEK.mjs.map → NcBreadcrumbs-DDutZRtm.mjs.map} +1 -1
  98. package/dist/chunks/{NcButton-CzpKEx4V.mjs → NcButton-lQra4n2g.mjs} +4 -4
  99. package/dist/chunks/{NcButton-CzpKEx4V.mjs.map → NcButton-lQra4n2g.mjs.map} +1 -1
  100. package/dist/chunks/{NcCheckboxRadioSwitch-ChNSuhe6.mjs → NcCheckboxRadioSwitch-D0gFwEVl.mjs} +5 -5
  101. package/dist/chunks/{NcCheckboxRadioSwitch-ChNSuhe6.mjs.map → NcCheckboxRadioSwitch-D0gFwEVl.mjs.map} +1 -1
  102. package/dist/chunks/{NcChip-CaOkERH3.mjs → NcChip-CrVOU2RM.mjs} +6 -6
  103. package/dist/chunks/{NcChip-CaOkERH3.mjs.map → NcChip-CrVOU2RM.mjs.map} +1 -1
  104. package/dist/chunks/{NcCollectionList-Dme-TR38.mjs → NcCollectionList-pWG42SU1.mjs} +7 -7
  105. package/dist/chunks/{NcCollectionList-Dme-TR38.mjs.map → NcCollectionList-pWG42SU1.mjs.map} +1 -1
  106. package/dist/chunks/{NcColorPicker-5Pw0z8WG.mjs → NcColorPicker-D07Se8Xb.mjs} +7 -7
  107. package/dist/chunks/{NcColorPicker-5Pw0z8WG.mjs.map → NcColorPicker-D07Se8Xb.mjs.map} +1 -1
  108. package/dist/chunks/{NcContent-DOmmHvxx.mjs → NcContent-D69ktIEB.mjs} +5 -5
  109. package/dist/chunks/{NcContent-DOmmHvxx.mjs.map → NcContent-D69ktIEB.mjs.map} +1 -1
  110. package/dist/chunks/{NcCounterBubble-CxxHHh8i.mjs → NcCounterBubble-VUNXKsnk.mjs} +2 -2
  111. package/dist/chunks/{NcCounterBubble-CxxHHh8i.mjs.map → NcCounterBubble-VUNXKsnk.mjs.map} +1 -1
  112. package/dist/chunks/{NcDashboardWidget-Ddt4Ze_7.mjs → NcDashboardWidget-CvpYMKur.mjs} +6 -6
  113. package/dist/chunks/{NcDashboardWidget-Ddt4Ze_7.mjs.map → NcDashboardWidget-CvpYMKur.mjs.map} +1 -1
  114. package/dist/chunks/{NcDashboardWidgetItem-Cu-899WY.mjs → NcDashboardWidgetItem-ZKImQn7Y.mjs} +5 -5
  115. package/dist/chunks/{NcDashboardWidgetItem-Cu-899WY.mjs.map → NcDashboardWidgetItem-ZKImQn7Y.mjs.map} +1 -1
  116. package/dist/chunks/{NcDateTime.vue_vue_type_script_setup_true_lang-BhB8yA4U.mjs → NcDateTime.vue_vue_type_script_setup_true_lang-B4upiZjL.mjs} +2 -2
  117. package/dist/chunks/{NcDateTime.vue_vue_type_script_setup_true_lang-BhB8yA4U.mjs.map → NcDateTime.vue_vue_type_script_setup_true_lang-B4upiZjL.mjs.map} +1 -1
  118. package/dist/chunks/{NcDateTimePicker-CF8TMzyS.mjs → NcDateTimePicker-DksKisgE.mjs} +6 -6
  119. package/dist/chunks/{NcDateTimePicker-CF8TMzyS.mjs.map → NcDateTimePicker-DksKisgE.mjs.map} +1 -1
  120. package/dist/chunks/{NcDateTimePickerNative-DvvKjw_h.mjs → NcDateTimePickerNative-BvtMQDIe.mjs} +4 -4
  121. package/dist/chunks/{NcDateTimePickerNative-DvvKjw_h.mjs.map → NcDateTimePickerNative-BvtMQDIe.mjs.map} +1 -1
  122. package/dist/chunks/{NcDialog-Cnd9YBlk.mjs → NcDialog-nDc1gW50.mjs} +4 -4
  123. package/dist/chunks/{NcDialog-Cnd9YBlk.mjs.map → NcDialog-nDc1gW50.mjs.map} +1 -1
  124. package/dist/chunks/{NcDialogButton.vue_vue_type_script_setup_true_lang-BnCX7Duz.mjs → NcDialogButton.vue_vue_type_script_setup_true_lang-Z_bOZAn_.mjs} +6 -6
  125. package/dist/chunks/{NcDialogButton.vue_vue_type_script_setup_true_lang-BnCX7Duz.mjs.map → NcDialogButton.vue_vue_type_script_setup_true_lang-Z_bOZAn_.mjs.map} +1 -1
  126. package/dist/chunks/{NcEllipsisedOption-dT-CtXYp.mjs → NcEllipsisedOption-D6Amb91K.mjs} +2 -2
  127. package/dist/chunks/{NcEllipsisedOption-dT-CtXYp.mjs.map → NcEllipsisedOption-D6Amb91K.mjs.map} +1 -1
  128. package/dist/chunks/{NcEmojiPicker-DpA4_bLX.mjs → NcEmojiPicker-DGgqTnHp.mjs} +10 -10
  129. package/dist/chunks/{NcEmojiPicker-DpA4_bLX.mjs.map → NcEmojiPicker-DGgqTnHp.mjs.map} +1 -1
  130. package/dist/chunks/{NcEmptyContent-B8-90BSI.mjs → NcEmptyContent-CDgWCt_m.mjs} +2 -2
  131. package/dist/chunks/{NcEmptyContent-B8-90BSI.mjs.map → NcEmptyContent-CDgWCt_m.mjs.map} +1 -1
  132. package/dist/chunks/NcFilePicker-DtOsHB4q.mjs +303 -0
  133. package/dist/chunks/NcFilePicker-DtOsHB4q.mjs.map +1 -0
  134. package/dist/chunks/{NcFormBox-BYjllt0m.mjs → NcFormBox-wP5mpW88.mjs} +2 -2
  135. package/dist/chunks/{NcFormBox-BYjllt0m.mjs.map → NcFormBox-wP5mpW88.mjs.map} +1 -1
  136. package/dist/chunks/{NcFormBoxButton-RDIKiZIH.mjs → NcFormBoxButton-JvZ6_2E3.mjs} +4 -4
  137. package/dist/chunks/{NcFormBoxButton-RDIKiZIH.mjs.map → NcFormBoxButton-JvZ6_2E3.mjs.map} +1 -1
  138. package/dist/chunks/{NcFormBoxCopyButton.vue_vue_type_script_setup_true_lang-KhOQ1B7a.mjs → NcFormBoxCopyButton.vue_vue_type_script_setup_true_lang-CjJ09v8E.mjs} +5 -5
  139. package/dist/chunks/{NcFormBoxCopyButton.vue_vue_type_script_setup_true_lang-KhOQ1B7a.mjs.map → NcFormBoxCopyButton.vue_vue_type_script_setup_true_lang-CjJ09v8E.mjs.map} +1 -1
  140. package/dist/chunks/{NcFormBoxItem-BAAPOa6z.mjs → NcFormBoxItem-B7YVodqN.mjs} +2 -2
  141. package/dist/chunks/{NcFormBoxItem-BAAPOa6z.mjs.map → NcFormBoxItem-B7YVodqN.mjs.map} +1 -1
  142. package/dist/chunks/{NcFormBoxSwitch-m9uRjJzl.mjs → NcFormBoxSwitch-DP4dD4xe.mjs} +4 -4
  143. package/dist/chunks/{NcFormBoxSwitch-m9uRjJzl.mjs.map → NcFormBoxSwitch-DP4dD4xe.mjs.map} +1 -1
  144. package/dist/chunks/{NcFormGroup-Bf8Mme1o.mjs → NcFormGroup-B3a2iUnT.mjs} +2 -2
  145. package/dist/chunks/{NcFormGroup-Bf8Mme1o.mjs.map → NcFormGroup-B3a2iUnT.mjs.map} +1 -1
  146. package/dist/chunks/{NcGuestContent-CfCh49o0.mjs → NcGuestContent-_z22nZMF.mjs} +2 -2
  147. package/dist/chunks/{NcGuestContent-CfCh49o0.mjs.map → NcGuestContent-_z22nZMF.mjs.map} +1 -1
  148. package/dist/chunks/{NcHeaderButton-CIb5SvFk.mjs → NcHeaderButton-CXu9xIQP.mjs} +3 -3
  149. package/dist/chunks/{NcHeaderButton-CIb5SvFk.mjs.map → NcHeaderButton-CXu9xIQP.mjs.map} +1 -1
  150. package/dist/chunks/{NcHeaderMenu-CeJZT5-m.mjs → NcHeaderMenu-CYU4Y3h5.mjs} +3 -3
  151. package/dist/chunks/{NcHeaderMenu-CeJZT5-m.mjs.map → NcHeaderMenu-CYU4Y3h5.mjs.map} +1 -1
  152. package/dist/chunks/{NcHotkey-CrVhA2O_.mjs → NcHotkey-DYevuX3i.mjs} +3 -3
  153. package/dist/chunks/{NcHotkey-CrVhA2O_.mjs.map → NcHotkey-DYevuX3i.mjs.map} +1 -1
  154. package/dist/chunks/{NcHotkeyList-BhA2GxR9.mjs → NcHotkeyList-CHLWkWfY.mjs} +3 -3
  155. package/dist/chunks/{NcHotkeyList-BhA2GxR9.mjs.map → NcHotkeyList-CHLWkWfY.mjs.map} +1 -1
  156. package/dist/chunks/{NcIconSvgWrapper-BvLanNaW.mjs → NcIconSvgWrapper-De-2-ukl.mjs} +2 -2
  157. package/dist/chunks/{NcIconSvgWrapper-BvLanNaW.mjs.map → NcIconSvgWrapper-De-2-ukl.mjs.map} +1 -1
  158. package/dist/chunks/{NcIconToggleSwitch-CSrdR61T.mjs → NcIconToggleSwitch-B7kfYo0B.mjs} +3 -3
  159. package/dist/chunks/{NcIconToggleSwitch-CSrdR61T.mjs.map → NcIconToggleSwitch-B7kfYo0B.mjs.map} +1 -1
  160. package/dist/chunks/{NcInputConfirmCancel-x3Xhif7e.mjs → NcInputConfirmCancel-Ch0byKa3.mjs} +6 -6
  161. package/dist/chunks/{NcInputConfirmCancel-x3Xhif7e.mjs.map → NcInputConfirmCancel-Ch0byKa3.mjs.map} +1 -1
  162. package/dist/chunks/{NcInputField-tt_Gi9ja.mjs → NcInputField-CPL-a_MM.mjs} +6 -6
  163. package/dist/chunks/{NcInputField-tt_Gi9ja.mjs.map → NcInputField-CPL-a_MM.mjs.map} +1 -1
  164. package/dist/chunks/{NcKbd-DF1Ugt3x.mjs → NcKbd-DE1emmb_.mjs} +3 -3
  165. package/dist/chunks/{NcKbd-DF1Ugt3x.mjs.map → NcKbd-DE1emmb_.mjs.map} +1 -1
  166. package/dist/chunks/{NcListItem-BnLZJxLv.mjs → NcListItem-DfFmqnmW.mjs} +12 -10
  167. package/dist/chunks/NcListItem-DfFmqnmW.mjs.map +1 -0
  168. package/dist/chunks/{NcListItemIcon-DLmp04cL.mjs → NcListItemIcon-DJJR4RtI.mjs} +4 -4
  169. package/dist/chunks/{NcListItemIcon-DLmp04cL.mjs.map → NcListItemIcon-DJJR4RtI.mjs.map} +1 -1
  170. package/dist/chunks/{NcLoadingIcon-b_ajZ_nQ.mjs → NcLoadingIcon-CInLzPtA.mjs} +2 -2
  171. package/dist/chunks/{NcLoadingIcon-b_ajZ_nQ.mjs.map → NcLoadingIcon-CInLzPtA.mjs.map} +1 -1
  172. package/dist/chunks/{NcModal-PlfVmTTk.mjs → NcModal-kyWZ3UFC.mjs} +24 -9
  173. package/dist/chunks/NcModal-kyWZ3UFC.mjs.map +1 -0
  174. package/dist/chunks/{NcNoteCard-Cok_4Fld.mjs → NcNoteCard-CWiO3Dse.mjs} +3 -3
  175. package/dist/chunks/{NcNoteCard-Cok_4Fld.mjs.map → NcNoteCard-CWiO3Dse.mjs.map} +1 -1
  176. package/dist/chunks/{NcPasswordField-DYF18Cdo.mjs → NcPasswordField-BOLzDHBJ.mjs} +5 -5
  177. package/dist/chunks/{NcPasswordField-DYF18Cdo.mjs.map → NcPasswordField-BOLzDHBJ.mjs.map} +1 -1
  178. package/dist/chunks/{NcPopover-OqcYrWOx.mjs → NcPopover-CtdLAkEU.mjs} +2 -2
  179. package/dist/chunks/{NcPopover-OqcYrWOx.mjs.map → NcPopover-CtdLAkEU.mjs.map} +1 -1
  180. package/dist/chunks/{NcProgressBar-DDMAo4h-.mjs → NcProgressBar-JyXXoHLT.mjs} +25 -14
  181. package/dist/chunks/NcProgressBar-JyXXoHLT.mjs.map +1 -0
  182. package/dist/chunks/{NcRadioGroup-Bjl3n_1z.mjs → NcRadioGroup-LkOsE5Mc.mjs} +4 -4
  183. package/dist/chunks/{NcRadioGroup-Bjl3n_1z.mjs.map → NcRadioGroup-LkOsE5Mc.mjs.map} +1 -1
  184. package/dist/chunks/{NcRadioGroupButton-Bul-9Tl1.mjs → NcRadioGroupButton-BtE_SLVd.mjs} +14 -6
  185. package/dist/chunks/NcRadioGroupButton-BtE_SLVd.mjs.map +1 -0
  186. package/dist/chunks/{NcRelatedResourcesPanel-Dzp_b_xS.mjs → NcRelatedResourcesPanel-Cn27rj0H.mjs} +8 -8
  187. package/dist/chunks/{NcRelatedResourcesPanel-Dzp_b_xS.mjs.map → NcRelatedResourcesPanel-Cn27rj0H.mjs.map} +1 -1
  188. package/dist/chunks/{NcRichContenteditable-BgsA20P4.mjs → NcRichContenteditable-BREsny-v.mjs} +58 -39
  189. package/dist/chunks/NcRichContenteditable-BREsny-v.mjs.map +1 -0
  190. package/dist/chunks/{NcRichText-H-0TWixL.mjs → NcRichText-D_ssz6sB.mjs} +41 -10
  191. package/dist/chunks/NcRichText-D_ssz6sB.mjs.map +1 -0
  192. package/dist/chunks/{NcSavingIndicatorIcon.vue_vue_type_script_setup_true_lang-jUf1K561.mjs → NcSavingIndicatorIcon.vue_vue_type_script_setup_true_lang-CA0r_04W.mjs} +2 -2
  193. package/dist/chunks/{NcSavingIndicatorIcon.vue_vue_type_script_setup_true_lang-jUf1K561.mjs.map → NcSavingIndicatorIcon.vue_vue_type_script_setup_true_lang-CA0r_04W.mjs.map} +1 -1
  194. package/dist/chunks/{NcSelect-rH_0zphV.mjs → NcSelect-B1uITk_3.mjs} +7 -7
  195. package/dist/chunks/{NcSelect-rH_0zphV.mjs.map → NcSelect-B1uITk_3.mjs.map} +1 -1
  196. package/dist/chunks/{NcSelectTags-DPJzQw5S.mjs → NcSelectTags-B3_tcJAf.mjs} +5 -5
  197. package/dist/chunks/{NcSelectTags-DPJzQw5S.mjs.map → NcSelectTags-B3_tcJAf.mjs.map} +1 -1
  198. package/dist/chunks/{NcSelectUsers-DbOv_9kW.mjs → NcSelectUsers-B9ZFtd6B.mjs} +6 -6
  199. package/dist/chunks/NcSelectUsers-B9ZFtd6B.mjs.map +1 -0
  200. package/dist/chunks/{NcSettingsSection-EAR0ylbd.mjs → NcSettingsSection-DIcgD1vo.mjs} +3 -3
  201. package/dist/chunks/{NcSettingsSection-EAR0ylbd.mjs.map → NcSettingsSection-DIcgD1vo.mjs.map} +1 -1
  202. package/dist/chunks/{NcSettingsSelectGroup-BS2sLZQO.mjs → NcSettingsSelectGroup-CupkYUPJ.mjs} +5 -5
  203. package/dist/chunks/{NcSettingsSelectGroup-BS2sLZQO.mjs.map → NcSettingsSelectGroup-CupkYUPJ.mjs.map} +1 -1
  204. package/dist/chunks/{NcTextArea-CWA3KOiC.mjs → NcTextArea-CseOD9aM.mjs} +5 -5
  205. package/dist/chunks/{NcTextArea-CWA3KOiC.mjs.map → NcTextArea-CseOD9aM.mjs.map} +1 -1
  206. package/dist/chunks/{NcTextField.vue_vue_type_script_setup_true_lang-Cv9c1EWI.mjs → NcTextField.vue_vue_type_script_setup_true_lang-B-4HNjYH.mjs} +6 -6
  207. package/dist/chunks/{NcTextField.vue_vue_type_script_setup_true_lang-Cv9c1EWI.mjs.map → NcTextField.vue_vue_type_script_setup_true_lang-B-4HNjYH.mjs.map} +1 -1
  208. package/dist/chunks/{NcThemeProvider.vue_vue_type_script_setup_true_lang-DWn1DRTx.mjs → NcThemeProvider.vue_vue_type_script_setup_true_lang-wie70gn4.mjs} +2 -2
  209. package/dist/chunks/{NcThemeProvider.vue_vue_type_script_setup_true_lang-DWn1DRTx.mjs.map → NcThemeProvider.vue_vue_type_script_setup_true_lang-wie70gn4.mjs.map} +1 -1
  210. package/dist/chunks/{NcTimezonePicker.vue_vue_type_script_setup_true_lang-t72lL380.mjs → NcTimezonePicker.vue_vue_type_script_setup_true_lang-8CBGI3yi.mjs} +5 -5
  211. package/dist/chunks/{NcTimezonePicker.vue_vue_type_script_setup_true_lang-t72lL380.mjs.map → NcTimezonePicker.vue_vue_type_script_setup_true_lang-8CBGI3yi.mjs.map} +1 -1
  212. package/dist/chunks/{NcUserBubble-DlY4DCgO.mjs → NcUserBubble-BE6yD-R0.mjs} +4 -4
  213. package/dist/chunks/{NcUserBubble-DlY4DCgO.mjs.map → NcUserBubble-BE6yD-R0.mjs.map} +1 -1
  214. package/dist/chunks/{NcUserStatusIcon-lVNMmh5G.mjs → NcUserStatusIcon-JWiuiAXe.mjs} +4 -4
  215. package/dist/chunks/{NcUserStatusIcon-lVNMmh5G.mjs.map → NcUserStatusIcon-JWiuiAXe.mjs.map} +1 -1
  216. package/dist/chunks/_l10n-BklkVPDO.mjs +145 -0
  217. package/dist/chunks/_l10n-BklkVPDO.mjs.map +1 -0
  218. package/dist/chunks/{appName-DtnLUijR.mjs → appName-DyNMVZpX.mjs} +12 -7
  219. package/dist/chunks/appName-DyNMVZpX.mjs.map +1 -0
  220. package/dist/chunks/{colors-DhRGyJCn.mjs → colors-BfjxNgsx.mjs} +2 -2
  221. package/dist/chunks/{colors-DhRGyJCn.mjs.map → colors-BfjxNgsx.mjs.map} +1 -1
  222. package/dist/chunks/{customPickerElements-4pQTZUnk.mjs → customPickerElements-Cu7bLbap.mjs} +9 -9
  223. package/dist/chunks/{customPickerElements-4pQTZUnk.mjs.map → customPickerElements-Cu7bLbap.mjs.map} +1 -1
  224. package/dist/chunks/{emoji-BY_D0V5K.mjs → emoji-V9hqFgPs.mjs} +16 -5
  225. package/dist/chunks/emoji-V9hqFgPs.mjs.map +1 -0
  226. package/dist/chunks/{referencePickerModal-VfCXswe3.mjs → referencePickerModal-D09ZVhqa.mjs} +14 -14
  227. package/dist/chunks/{referencePickerModal-VfCXswe3.mjs.map → referencePickerModal-D09ZVhqa.mjs.map} +1 -1
  228. package/dist/chunks/{useCopy-D-6Kls-z.mjs → useCopy-Dgw864OI.mjs} +2 -2
  229. package/dist/chunks/{useCopy-D-6Kls-z.mjs.map → useCopy-Dgw864OI.mjs.map} +1 -1
  230. package/dist/components/NcActionButton/index.mjs +1 -1
  231. package/dist/components/NcActionButtonGroup/index.mjs +1 -1
  232. package/dist/components/NcActionCaption/index.mjs +1 -1
  233. package/dist/components/NcActionCheckbox/index.mjs +1 -1
  234. package/dist/components/NcActionInput/index.mjs +1 -1
  235. package/dist/components/NcActionLink/index.mjs +1 -1
  236. package/dist/components/NcActionRadio/index.mjs +1 -1
  237. package/dist/components/NcActionRouter/index.mjs +1 -1
  238. package/dist/components/NcActionSeparator/index.mjs +1 -1
  239. package/dist/components/NcActionText/index.mjs +1 -1
  240. package/dist/components/NcActionTextEditable/index.mjs +1 -1
  241. package/dist/components/NcActions/index.mjs +1 -1
  242. package/dist/components/NcAppContent/NcAppContent.vue.d.ts +2 -0
  243. package/dist/components/NcAppContent/index.mjs +1 -1
  244. package/dist/components/NcAppContentDetails/index.mjs +1 -1
  245. package/dist/components/NcAppContentList/index.mjs +1 -1
  246. package/dist/components/NcAppNavigation/index.mjs +1 -1
  247. package/dist/components/NcAppNavigationCaption/index.mjs +1 -1
  248. package/dist/components/NcAppNavigationIconBullet/index.mjs +1 -1
  249. package/dist/components/NcAppNavigationItem/index.mjs +1 -1
  250. package/dist/components/NcAppNavigationList/index.mjs +1 -1
  251. package/dist/components/NcAppNavigationNew/index.mjs +1 -1
  252. package/dist/components/NcAppNavigationNewItem/index.mjs +1 -1
  253. package/dist/components/NcAppNavigationSearch/index.mjs +1 -1
  254. package/dist/components/NcAppNavigationSettings/index.mjs +1 -1
  255. package/dist/components/NcAppNavigationSpacer/index.mjs +1 -1
  256. package/dist/components/NcAppSettingsDialog/index.mjs +1 -1
  257. package/dist/components/NcAppSettingsSection/index.mjs +1 -1
  258. package/dist/components/NcAppSettingsSectionShortcuts/index.mjs +1 -1
  259. package/dist/components/NcAppSettingsShortcutsSection/index.mjs +1 -1
  260. package/dist/components/NcAppSidebar/index.mjs +1 -1
  261. package/dist/components/NcAppSidebarHeader/index.mjs +1 -1
  262. package/dist/components/NcAppSidebarTab/index.mjs +1 -1
  263. package/dist/components/NcAssistantButton/index.mjs +1 -1
  264. package/dist/components/NcAssistantContent/index.mjs +1 -1
  265. package/dist/components/NcAssistantIcon/index.mjs +1 -1
  266. package/dist/components/NcAvatar/index.mjs +1 -1
  267. package/dist/components/NcBlurHash/index.mjs +1 -1
  268. package/dist/components/NcBreadcrumb/index.mjs +1 -1
  269. package/dist/components/NcBreadcrumbs/index.mjs +1 -1
  270. package/dist/components/NcButton/index.mjs +1 -1
  271. package/dist/components/NcCheckboxRadioSwitch/index.mjs +1 -1
  272. package/dist/components/NcChip/index.mjs +1 -1
  273. package/dist/components/NcCollectionList/index.mjs +1 -1
  274. package/dist/components/NcColorPicker/index.mjs +1 -1
  275. package/dist/components/NcContent/index.mjs +1 -1
  276. package/dist/components/NcCounterBubble/index.mjs +1 -1
  277. package/dist/components/NcDashboardWidget/index.mjs +1 -1
  278. package/dist/components/NcDashboardWidgetItem/index.mjs +1 -1
  279. package/dist/components/NcDateTime/index.mjs +1 -1
  280. package/dist/components/NcDateTimePicker/index.mjs +1 -1
  281. package/dist/components/NcDateTimePickerNative/index.mjs +1 -1
  282. package/dist/components/NcDialog/index.mjs +1 -1
  283. package/dist/components/NcDialogButton/index.mjs +1 -1
  284. package/dist/components/NcEllipsisedOption/index.mjs +1 -1
  285. package/dist/components/NcEmojiPicker/NcEmojiPicker.vue.d.ts +1 -1
  286. package/dist/components/NcEmojiPicker/index.mjs +1 -1
  287. package/dist/components/NcEmptyContent/index.mjs +1 -1
  288. package/dist/components/NcFilePicker/NcFilePicker.vue.d.ts +132 -0
  289. package/dist/components/NcFilePicker/index.d.ts +6 -0
  290. package/dist/components/NcFilePicker/index.mjs +5 -0
  291. package/dist/components/NcFilePicker/index.mjs.map +1 -0
  292. package/dist/components/NcFormBox/index.mjs +1 -1
  293. package/dist/components/NcFormBoxButton/index.mjs +1 -1
  294. package/dist/components/NcFormBoxCopyButton/index.mjs +1 -1
  295. package/dist/components/NcFormBoxSwitch/index.mjs +1 -1
  296. package/dist/components/NcFormGroup/index.mjs +1 -1
  297. package/dist/components/NcGuestContent/index.mjs +1 -1
  298. package/dist/components/NcHeaderButton/index.mjs +1 -1
  299. package/dist/components/NcHeaderMenu/index.mjs +1 -1
  300. package/dist/components/NcHotkey/index.mjs +1 -1
  301. package/dist/components/NcHotkeyList/index.mjs +1 -1
  302. package/dist/components/NcIconSvgWrapper/index.mjs +1 -1
  303. package/dist/components/NcInputField/index.mjs +1 -1
  304. package/dist/components/NcKbd/index.mjs +1 -1
  305. package/dist/components/NcListItem/NcListItem.vue.d.ts +2 -1
  306. package/dist/components/NcListItem/index.mjs +1 -1
  307. package/dist/components/NcListItemIcon/index.mjs +1 -1
  308. package/dist/components/NcLoadingIcon/index.mjs +1 -1
  309. package/dist/components/NcModal/index.mjs +1 -1
  310. package/dist/components/NcNoteCard/index.mjs +1 -1
  311. package/dist/components/NcPasswordField/index.mjs +1 -1
  312. package/dist/components/NcPopover/index.mjs +1 -1
  313. package/dist/components/NcProgressBar/NcProgressBar.vue.d.ts +9 -0
  314. package/dist/components/NcProgressBar/index.mjs +1 -1
  315. package/dist/components/NcRadioGroup/index.mjs +1 -1
  316. package/dist/components/NcRadioGroupButton/NcRadioGroupButton.vue.d.ts +4 -0
  317. package/dist/components/NcRadioGroupButton/index.mjs +1 -1
  318. package/dist/components/NcRelatedResourcesPanel/index.mjs +1 -1
  319. package/dist/components/NcRichContenteditable/NcRichContenteditable.vue.d.ts +5 -3
  320. package/dist/components/NcRichContenteditable/index.mjs +3 -3
  321. package/dist/components/NcRichText/NcRichText.vue.d.ts +7 -0
  322. package/dist/components/NcRichText/index.mjs +10 -10
  323. package/dist/components/NcRichText/remarkStripCode.d.ts +2 -0
  324. package/dist/components/NcSavingIndicatorIcon/index.mjs +1 -1
  325. package/dist/components/NcSelect/index.mjs +1 -1
  326. package/dist/components/NcSelectTags/index.mjs +1 -1
  327. package/dist/components/NcSelectUsers/NcSelectUsers.vue.d.ts +5 -5
  328. package/dist/components/NcSelectUsers/index.d.ts +1 -0
  329. package/dist/components/NcSelectUsers/index.mjs +1 -1
  330. package/dist/components/NcSettingsSection/index.mjs +1 -1
  331. package/dist/components/NcSettingsSelectGroup/index.mjs +1 -1
  332. package/dist/components/NcTextArea/index.mjs +1 -1
  333. package/dist/components/NcTextField/index.mjs +1 -1
  334. package/dist/components/NcThemeProvider/index.mjs +1 -1
  335. package/dist/components/NcTimezonePicker/index.mjs +1 -1
  336. package/dist/components/NcUserBubble/index.mjs +1 -1
  337. package/dist/components/NcUserStatusIcon/index.mjs +1 -1
  338. package/dist/components/index.d.ts +1 -0
  339. package/dist/composables/useFormatDateTime/index.mjs +1 -1
  340. package/dist/functions/emoji/emoji.d.ts +11 -5
  341. package/dist/functions/emoji/index.mjs +3 -3
  342. package/dist/functions/reference/index.mjs +10 -10
  343. package/dist/functions/registerReference/index.mjs +9 -9
  344. package/dist/functions/usernameToColor/index.mjs +1 -1
  345. package/dist/index.mjs +141 -139
  346. package/dist/index.mjs.map +1 -1
  347. package/dist/utils/appName.d.ts +6 -2
  348. package/package.json +30 -29
  349. package/dist/assets/NcSelectUsers-zQin7DzE.css +0 -4
  350. package/dist/chunks/NcAppContent-DHTZAiBV.mjs.map +0 -1
  351. package/dist/chunks/NcListItem-BnLZJxLv.mjs.map +0 -1
  352. package/dist/chunks/NcModal-PlfVmTTk.mjs.map +0 -1
  353. package/dist/chunks/NcProgressBar-DDMAo4h-.mjs.map +0 -1
  354. package/dist/chunks/NcRadioGroupButton-Bul-9Tl1.mjs.map +0 -1
  355. package/dist/chunks/NcRichContenteditable-BgsA20P4.mjs.map +0 -1
  356. package/dist/chunks/NcRichText-H-0TWixL.mjs.map +0 -1
  357. package/dist/chunks/NcSelectUsers-DbOv_9kW.mjs.map +0 -1
  358. package/dist/chunks/_l10n-BSFzy-71.mjs +0 -145
  359. package/dist/chunks/_l10n-BSFzy-71.mjs.map +0 -1
  360. package/dist/chunks/appName-DtnLUijR.mjs.map +0 -1
  361. package/dist/chunks/emoji-BY_D0V5K.mjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"NcEmojiPicker-DpA4_bLX.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\n\t\tref=\"popover\"\n\t\tv-model:shown=\"open\"\n\t\t:container=\"container\"\n\t\tpopupRole=\"dialog\"\n\t\t:noFocusTrap=\"true /* Handled manually to remove emoji buttons from TAB sequence */\"\n\t\t@afterShow=\"afterShow\"\n\t\t@afterHide=\"afterHide\">\n\t\t<template #trigger=\"slotProps\">\n\t\t\t<slot v-bind=\"slotProps\" />\n\t\t</template>\n\t\t<div class=\"nc-emoji-picker-container\">\n\t\t\t<Picker\n\t\t\t\tref=\"picker\"\n\t\t\t\tcolor=\"var(--color-primary-element)\"\n\t\t\t\t:data=\"emojiIndex\"\n\t\t\t\t:emoji=\"previewFallbackEmoji\"\n\t\t\t\t:i18n\n\t\t\t\t:native\n\t\t\t\t:emojiSize=\"20\"\n\t\t\t\t:perLine=\"8\"\n\t\t\t\t:pickerStyles=\"{ width: '320px' }\"\n\t\t\t\t:showPreview\n\t\t\t\t:skin=\"currentSkinTone\"\n\t\t\t\t:showSkinTones=\"false\"\n\t\t\t\t:title=\"previewFallbackName\"\n\t\t\t\trole=\"dialog\"\n\t\t\t\taria-modal=\"true\"\n\t\t\t\t:aria-label=\"t('Emoji picker')\"\n\t\t\t\tv-bind=\"$attrs\"\n\t\t\t\t@keydown.tab.prevent=\"handleTabNavigationSkippingEmojis\"\n\t\t\t\t@select=\"select\">\n\t\t\t\t<template #searchTemplate=\"{ onSearch }\">\n\t\t\t\t\t<div class=\"search__wrapper\">\n\t\t\t\t\t\t<NcTextField\n\t\t\t\t\t\t\tref=\"search\"\n\t\t\t\t\t\t\tv-model=\"search\"\n\t\t\t\t\t\t\tclass=\"search\"\n\t\t\t\t\t\t\t:label=\"t('Search')\"\n\t\t\t\t\t\t\t:labelVisible=\"true\"\n\t\t\t\t\t\t\t:placeholder=\"i18n.search\"\n\t\t\t\t\t\t\ttrailingButtonIcon=\"close\"\n\t\t\t\t\t\t\t:trailingButtonLabel=\"t('Clear search')\"\n\t\t\t\t\t\t\t:showTrailingButton=\"search !== ''\"\n\t\t\t\t\t\t\t@keydown.left=\"callPickerArrowHandlerWithScrollFix('onArrowLeft', $event)\"\n\t\t\t\t\t\t\t@keydown.right=\"callPickerArrowHandlerWithScrollFix('onArrowRight', $event)\"\n\t\t\t\t\t\t\t@keydown.down=\"callPickerArrowHandlerWithScrollFix('onArrowDown', $event)\"\n\t\t\t\t\t\t\t@keydown.up=\"callPickerArrowHandlerWithScrollFix('onArrowUp', $event)\"\n\t\t\t\t\t\t\t@keydown.enter=\"$refs.picker.onEnter($event)\"\n\t\t\t\t\t\t\t@trailingButtonClick=\"clearSearch(); onSearch('');\"\n\t\t\t\t\t\t\t@update:modelValue=\"onSearch(search)\" />\n\t\t\t\t\t\t<NcColorPicker\n\t\t\t\t\t\t\tpaletteOnly\n\t\t\t\t\t\t\t:container\n\t\t\t\t\t\t\t:palette=\"skinTonePalette\"\n\t\t\t\t\t\t\t:modelValue=\"currentColor.color\"\n\t\t\t\t\t\t\t@update:modelValue=\"onChangeSkinTone\">\n\t\t\t\t\t\t\t<NcButton :aria-label=\"t('Skin tone')\" variant=\"tertiary-no-background\">\n\t\t\t\t\t\t\t\t<template #icon>\n\t\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\t</template>\n\t\t\t\t\t\t\t</NcButton>\n\t\t\t\t\t\t</NcColorPicker>\n\t\t\t\t\t</div>\n\t\t\t\t</template>\n\t\t\t\t<template v-if=\"allowUnselect && selectedEmoji\" #customCategory>\n\t\t\t\t\t<div class=\"emoji-mart-category-label\">\n\t\t\t\t\t\t<h3 class=\"emoji-mart-category-label\">\n\t\t\t\t\t\t\t{{ t('Selected') }}\n\t\t\t\t\t\t</h3>\n\t\t\t\t\t</div>\n\t\t\t\t\t<Emoji\n\t\t\t\t\t\tclass=\"emoji-selected\"\n\t\t\t\t\t\t:data=\"emojiIndex\"\n\t\t\t\t\t\t:emoji=\"selectedEmoji\"\n\t\t\t\t\t\tnative\n\t\t\t\t\t\t:size=\"32\"\n\t\t\t\t\t\t@click=\"unselect\" />\n\t\t\t\t\t<Emoji\n\t\t\t\t\t\tclass=\"emoji-delete\"\n\t\t\t\t\t\t:data=\"emojiIndex\"\n\t\t\t\t\t\temoji=\":x:\"\n\t\t\t\t\t\tnative\n\t\t\t\t\t\t:size=\"10\"\n\t\t\t\t\t\t@click=\"unselect\" />\n\t\t\t\t</template>\n\t\t\t</Picker>\n\t\t</div>\n\t</NcPopover>\n</template>\n\n<script>\nimport data from 'emoji-mart-vue-fast/data/all.json'\nimport { Emoji, EmojiIndex, Picker } from 'emoji-mart-vue-fast/src/index.js'\nimport { isFocusable } from 'tabbable'\nimport IconCircle from 'vue-material-design-icons/Circle.vue'\nimport NcColorPicker from '../NcColorPicker/NcColorPicker.vue'\nimport { useTrapStackControl } from '../../composables/useTrapStackControl.ts'\nimport { getCurrentSkinTone, setCurrentSkinTone } from '../../functions/emoji/emoji.ts'\nimport { t } from '../../l10n.ts'\nimport { Color } from '../../utils/colors.ts'\nimport NcButton from '../NcButton/index.ts'\nimport NcPopover from '../NcPopover/index.js'\nimport NcTextField from '../NcTextField/index.ts'\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\tIconCircle,\n\t\tNcButton,\n\t\tNcColorPicker,\n\t\tNcPopover,\n\t\tNcTextField,\n\t\tEmoji,\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\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\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\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\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\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\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: [Boolean, String, Object, Element],\n\t\t\tdefault: 'body',\n\t\t},\n\t},\n\n\temits: [\n\t\t'select',\n\t\t'selectData',\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 *\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\tcreated() {\n\t\t// Component has its own custom focus management\n\t\t// The global focus trap stack should be paused\n\t\tuseTrapStackControl(() => this.open)\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 *\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('selectData', 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\t// But only if there is no focus target outside the picker, for example, input element that received focus by click closing the emoji picker\n\t\t\tif (!document.activeElement || this.$refs.picker.$el.contains(document.activeElement) || !isFocusable(document.activeElement)) {\n\t\t\t\tthis.$refs.popover.$el.querySelector('button, [role=\"button\"]')?.focus()\n\t\t\t}\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 *\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 *\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 scoped lang=\"scss\">\n@use \"sass:meta\";\n\n.nc-emoji-picker-container :deep() {\n\t@include meta.load-css('emoji-mart-vue-fast/css/emoji-mart.css');\n}\n\n.nc-emoji-picker-container :deep(.emoji-mart) {\n\tbackground-color: var(--color-main-background) !important;\n\tborder: 0;\n\tcolor: var(--color-main-text) !important;\n\tdisplay: flex !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);\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\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-inline-start: -21px;\n\tmargin-top: -3px;\n}\n</style>\n"],"names":["_sfc_main","_hoisted_3","_createElementBlock","_mergeProps","_createElementVNode","_openBlock","NcTextField","_createBlock","_withCtx","_renderSlot","_createVNode","_withKeys","_normalizeStyle","_toDisplayString"],"mappings":"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","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"NcEmojiPicker-DGgqTnHp.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\n\t\tref=\"popover\"\n\t\tv-model:shown=\"open\"\n\t\t:container=\"container\"\n\t\tpopupRole=\"dialog\"\n\t\t:noFocusTrap=\"true /* Handled manually to remove emoji buttons from TAB sequence */\"\n\t\t@afterShow=\"afterShow\"\n\t\t@afterHide=\"afterHide\">\n\t\t<template #trigger=\"slotProps\">\n\t\t\t<slot v-bind=\"slotProps\" />\n\t\t</template>\n\t\t<div class=\"nc-emoji-picker-container\">\n\t\t\t<Picker\n\t\t\t\tref=\"picker\"\n\t\t\t\tcolor=\"var(--color-primary-element)\"\n\t\t\t\t:data=\"emojiIndex\"\n\t\t\t\t:emoji=\"previewFallbackEmoji\"\n\t\t\t\t:i18n\n\t\t\t\t:native\n\t\t\t\t:emojiSize=\"20\"\n\t\t\t\t:perLine=\"8\"\n\t\t\t\t:pickerStyles=\"{ width: '320px' }\"\n\t\t\t\t:showPreview\n\t\t\t\t:skin=\"currentSkinTone\"\n\t\t\t\t:showSkinTones=\"false\"\n\t\t\t\t:title=\"previewFallbackName\"\n\t\t\t\trole=\"dialog\"\n\t\t\t\taria-modal=\"true\"\n\t\t\t\t:aria-label=\"t('Emoji picker')\"\n\t\t\t\tv-bind=\"$attrs\"\n\t\t\t\t@keydown.tab.prevent=\"handleTabNavigationSkippingEmojis\"\n\t\t\t\t@select=\"select\">\n\t\t\t\t<template #searchTemplate=\"{ onSearch }\">\n\t\t\t\t\t<div class=\"search__wrapper\">\n\t\t\t\t\t\t<NcTextField\n\t\t\t\t\t\t\tref=\"search\"\n\t\t\t\t\t\t\tv-model=\"search\"\n\t\t\t\t\t\t\tclass=\"search\"\n\t\t\t\t\t\t\t:label=\"t('Search')\"\n\t\t\t\t\t\t\t:labelVisible=\"true\"\n\t\t\t\t\t\t\t:placeholder=\"i18n.search\"\n\t\t\t\t\t\t\ttrailingButtonIcon=\"close\"\n\t\t\t\t\t\t\t:trailingButtonLabel=\"t('Clear search')\"\n\t\t\t\t\t\t\t:showTrailingButton=\"search !== ''\"\n\t\t\t\t\t\t\t@keydown.left=\"callPickerArrowHandlerWithScrollFix('onArrowLeft', $event)\"\n\t\t\t\t\t\t\t@keydown.right=\"callPickerArrowHandlerWithScrollFix('onArrowRight', $event)\"\n\t\t\t\t\t\t\t@keydown.down=\"callPickerArrowHandlerWithScrollFix('onArrowDown', $event)\"\n\t\t\t\t\t\t\t@keydown.up=\"callPickerArrowHandlerWithScrollFix('onArrowUp', $event)\"\n\t\t\t\t\t\t\t@keydown.enter=\"$refs.picker.onEnter($event)\"\n\t\t\t\t\t\t\t@trailingButtonClick=\"clearSearch(); onSearch('');\"\n\t\t\t\t\t\t\t@update:modelValue=\"onSearch(search)\" />\n\t\t\t\t\t\t<NcColorPicker\n\t\t\t\t\t\t\tpaletteOnly\n\t\t\t\t\t\t\t:container\n\t\t\t\t\t\t\t:palette=\"skinTonePalette\"\n\t\t\t\t\t\t\t:modelValue=\"currentColor.color\"\n\t\t\t\t\t\t\t@update:modelValue=\"onChangeSkinTone\">\n\t\t\t\t\t\t\t<NcButton :aria-label=\"t('Skin tone')\" variant=\"tertiary-no-background\">\n\t\t\t\t\t\t\t\t<template #icon>\n\t\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\t</template>\n\t\t\t\t\t\t\t</NcButton>\n\t\t\t\t\t\t</NcColorPicker>\n\t\t\t\t\t</div>\n\t\t\t\t</template>\n\t\t\t\t<template v-if=\"allowUnselect && selectedEmoji\" #customCategory>\n\t\t\t\t\t<div class=\"emoji-mart-category-label\">\n\t\t\t\t\t\t<h3 class=\"emoji-mart-category-label\">\n\t\t\t\t\t\t\t{{ t('Selected') }}\n\t\t\t\t\t\t</h3>\n\t\t\t\t\t</div>\n\t\t\t\t\t<Emoji\n\t\t\t\t\t\tclass=\"emoji-selected\"\n\t\t\t\t\t\t:data=\"emojiIndex\"\n\t\t\t\t\t\t:emoji=\"selectedEmoji\"\n\t\t\t\t\t\tnative\n\t\t\t\t\t\t:size=\"32\"\n\t\t\t\t\t\t@click=\"unselect\" />\n\t\t\t\t\t<Emoji\n\t\t\t\t\t\tclass=\"emoji-delete\"\n\t\t\t\t\t\t:data=\"emojiIndex\"\n\t\t\t\t\t\temoji=\":x:\"\n\t\t\t\t\t\tnative\n\t\t\t\t\t\t:size=\"10\"\n\t\t\t\t\t\t@click=\"unselect\" />\n\t\t\t\t</template>\n\t\t\t</Picker>\n\t\t</div>\n\t</NcPopover>\n</template>\n\n<script>\nimport data from 'emoji-mart-vue-fast/data/all.json'\nimport { Emoji, EmojiIndex, Picker } from 'emoji-mart-vue-fast/src/index.js'\nimport { isFocusable } from 'tabbable'\nimport IconCircle from 'vue-material-design-icons/Circle.vue'\nimport NcColorPicker from '../NcColorPicker/NcColorPicker.vue'\nimport { useTrapStackControl } from '../../composables/useTrapStackControl.ts'\nimport { getCurrentSkinTone, setCurrentSkinTone } from '../../functions/emoji/emoji.ts'\nimport { t } from '../../l10n.ts'\nimport { Color } from '../../utils/colors.ts'\nimport NcButton from '../NcButton/index.ts'\nimport NcPopover from '../NcPopover/index.js'\nimport NcTextField from '../NcTextField/index.ts'\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\tIconCircle,\n\t\tNcButton,\n\t\tNcColorPicker,\n\t\tNcPopover,\n\t\tNcTextField,\n\t\tEmoji,\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\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\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\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\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\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\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: [Boolean, String, Object, Element],\n\t\t\tdefault: 'body',\n\t\t},\n\t},\n\n\temits: [\n\t\t'select',\n\t\t'selectData',\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 *\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\tcreated() {\n\t\t// Component has its own custom focus management\n\t\t// The global focus trap stack should be paused\n\t\tuseTrapStackControl(() => this.open)\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 *\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('selectData', 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\t// But only if there is no focus target outside the picker, for example, input element that received focus by click closing the emoji picker\n\t\t\tif (!document.activeElement || this.$refs.picker.$el.contains(document.activeElement) || !isFocusable(document.activeElement)) {\n\t\t\t\tthis.$refs.popover.$el.querySelector('button, [role=\"button\"]')?.focus()\n\t\t\t}\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 *\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 *\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 scoped lang=\"scss\">\n@use \"sass:meta\";\n\n.nc-emoji-picker-container :deep() {\n\t@include meta.load-css('emoji-mart-vue-fast/css/emoji-mart.css');\n}\n\n.nc-emoji-picker-container :deep(.emoji-mart) {\n\tbackground-color: var(--color-main-background) !important;\n\tborder: 0;\n\tcolor: var(--color-main-text) !important;\n\tdisplay: flex !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);\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\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-inline-start: -21px;\n\tmargin-top: -3px;\n}\n</style>\n"],"names":["_sfc_main","_hoisted_3","_createElementBlock","_mergeProps","_createElementVNode","_openBlock","NcTextField","_createBlock","_withCtx","_renderSlot","_createVNode","_withKeys","_normalizeStyle","_toDisplayString"],"mappings":"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","x_google_ignoreList":[0]}
@@ -1,5 +1,5 @@
1
1
  import '../assets/NcEmptyContent-CLjlZ-UT.css';
2
- import { defineComponent, createElementBlock, openBlock, unref, createCommentVNode, renderSlot, createTextVNode, toDisplayString } from "vue";
2
+ import { defineComponent, openBlock, createElementBlock, unref, renderSlot, createCommentVNode, createTextVNode, toDisplayString } from "vue";
3
3
  import { c as createElementId } from "./createElementId-DhjFt1I9.mjs";
4
4
  import { _ as _export_sfc } from "./_plugin-vue_export-helper-1tPrXgE0.mjs";
5
5
  const _hoisted_1 = ["aria-labelledby"];
@@ -59,4 +59,4 @@ const NcEmptyContent = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "da
59
59
  export {
60
60
  NcEmptyContent as N
61
61
  };
62
- //# sourceMappingURL=NcEmptyContent-B8-90BSI.mjs.map
62
+ //# sourceMappingURL=NcEmptyContent-CDgWCt_m.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"NcEmptyContent-B8-90BSI.mjs","sources":["../../src/components/NcEmptyContent/NcEmptyContent.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n### Basic use\n\nUse this component to display a message about an empty content.\nProviding an icon, name, and a description is strongly advised.\n\n```\n<template>\n\t<NcEmptyContent name=\"No comments\"\n\t\tdescription=\"Start writing comments and they will appear here.\">\n\t\t<template #icon>\n\t\t\t<Comment />\n\t\t</template>\n\t</NcEmptyContent>\n</template>\n\n<script>\nimport Comment from 'vue-material-design-icons/Comment.vue'\n\nexport default {\n\tcomponents: {\n\t\tComment,\n\t},\n}\n</script>\n```\n#### With custom svg\n\n```\n<template>\n\t<NcEmptyContent\n\t\tname=\"No files in here\">\n\t\t<template #icon>\n\t\t\t<NcIconSvgWrapper :svg=\"folderSvg\" />\n\t\t</template>\n\t</NcEmptyContent>\n</template>\n\n<script>\nimport folderSvg from '@mdi/svg/svg/folder.svg?raw'\n\nexport default {\n\tcomponents: {\n\t\tComment,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tfolderSvg,\n\t\t}\n\t},\n}\n</script>\n```\n\nYou can also customize the name using the `#name` slot\nand add actions. But to keep the style consistent across Nextcloud\nconsider only using header elements as the root elements for the name slot.\n\n```\n<template>\n\t<NcEmptyContent\n\t\tdescription=\"No comments in here\">\n\t\t<template #icon>\n\t\t\t<Comment />\n\t\t</template>\n\t\t<template #name>\n\t\t\t<h1 class=\"empty-content__name\">\n\t\t\t\tNo comments\n\t\t\t</h1>\n\t\t</template>\n\t\t<template #action>\n\t\t\t<NcButton variant=\"primary\">\n\t\t\t\tAdd a comment!\n\t\t\t</NcButton>\n\t\t</template>\n\t</NcEmptyContent>\n</template>\n\n<script>\nimport Comment from 'vue-material-design-icons/Comment.vue'\n\nexport default {\n\tcomponents: {\n\t\tComment,\n\t},\n}\n</script>\n```\n\nSimilar to the `#name` slot, you could also use the `#description` slot.\nThe content will be rendered within a paragraph so you can use any inline element,\nlike a link.\n\n```\n<template>\n\t<NcEmptyContent\n\t\tname=\"No comments\">\n\t\t<template #icon>\n\t\t\t<Comment />\n\t\t</template>\n\t\t<template #description>\n\t\t\t<a href=\"https://en.wikipedia.org/wiki/Comment\">What is even a comment?</a>\n\t\t</template>\n\t</NcEmptyContent>\n</template>\n\n<script>\nimport Comment from 'vue-material-design-icons/Comment.vue'\n\nexport default {\n\tcomponents: {\n\t\tComment,\n\t},\n}\n</script>\n```\n</docs>\n\n<script setup lang=\"ts\">\nimport type { Slot } from 'vue'\n\nimport { createElementId } from '../../utils/createElementId.ts'\n\nwithDefaults(defineProps<{\n\t/**\n\t * Desription of the empty content\n\t *\n\t * @example 'No comments yet, start the conversation!'\n\t */\n\tdescription?: string\n\n\t/**\n\t * A header message about an empty content shown.\n\t *\n\t * @example 'No comments'\n\t */\n\tname?: string\n}>(), {\n\tdescription: '',\n\tname: '',\n})\n\ndefineSlots<{\n\t/**\n\t * Optional slot for a button or the like\n\t */\n\taction?: Slot\n\n\t/**\n\t * Optional slot for adding an icon\n\t */\n\ticon?: Slot\n\n\t/**\n\t * Allow to add custom formatted name as an alternative to the name property.\n\t * The content passed shall be enclosed by a header element.\n\t */\n\tname?: Slot\n\n\t/**\n\t * Optional formatted description rendered inside a paragraph as an alternative to the description property.\n\t */\n\tdescription?: Slot\n}>()\n\nconst nameId = createElementId()\n</script>\n\n<template>\n\t<div :aria-labelledby=\"nameId\" class=\"empty-content\" role=\"note\">\n\t\t<div v-if=\"$slots.icon\" class=\"empty-content__icon\" aria-hidden=\"true\">\n\t\t\t<slot name=\"icon\" />\n\t\t</div>\n\t\t<div v-if=\"name !== '' || $slots.name\" :id=\"nameId\" class=\"empty-content__name\">\n\t\t\t<slot name=\"name\">\n\t\t\t\t{{ name }}\n\t\t\t</slot>\n\t\t</div>\n\t\t<p v-if=\"description !== '' || $slots.description\" class=\"empty-content__description\">\n\t\t\t<slot name=\"description\">\n\t\t\t\t{{ description }}\n\t\t\t</slot>\n\t\t</p>\n\t\t<div v-if=\"$slots.action\" class=\"empty-content__action\">\n\t\t\t<slot name=\"action\" />\n\t\t</div>\n\t</div>\n</template>\n\n<style lang=\"scss\" scoped>\n.empty-content {\n\tdisplay: flex;\n\talign-items: center;\n\tflex-direction: column;\n\tjustify-content: center;\n\t/* In case of using in a flex container - flex in advance */\n\tflex-grow: 1;\n\tpadding: var(--default-grid-baseline);\n\n\t.modal-wrapper & {\n\t\tmargin-top: 5vh;\n\t\tmargin-bottom: 5vh;\n\t}\n\n\t&__icon {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: center;\n\t\twidth: 64px;\n\t\theight: 64px;\n\t\tmargin: 0 auto 15px;\n\t\topacity: .4;\n\t\tbackground-repeat: no-repeat;\n\t\tbackground-position: center;\n\t\tbackground-size: 64px;\n\n\t\t:deep(svg) {\n\t\t\twidth: 64px !important;\n\t\t\theight: 64px !important;\n\t\t\tmax-width: 64px !important;\n\t\t\tmax-height: 64px !important;\n\t\t}\n\t}\n\n\t&__name {\n\t\tmargin-bottom: 10px;\n\t\ttext-align: center;\n\t\tfont-weight: bold;\n\t\tfont-size: 20px;\n\t\tline-height: 30px;\n\t}\n\n\t&__description {\n\t\tcolor: var(--color-text-maxcontrast);\n\t\ttext-align: center;\n\t\ttext-wrap-style: balance;\n\t}\n\n\t&__action {\n\t\tmargin-top: 8px;\n\n\t\t.modal-wrapper & {\n\t\t\tmargin-top: 20px;\n\t\t\tdisplay: flex;\n\t\t}\n\t}\n}\n</style>\n"],"names":["_createElementBlock","_unref","$slots","_openBlock","_renderSlot","name","description"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AA0KA,UAAM,SAAS,gBAAA;;0BAIdA,mBAiBM,OAAA;AAAA,QAjBA,mBAAiBC,MAAA,MAAA;AAAA,QAAQ,OAAM;AAAA,QAAgB,MAAK;AAAA,MAAA;QAC9CC,KAAAA,OAAO,QAAlBC,aAAAH,mBAEM,OAFN,YAEM;AAAA,UADLI,WAAoB,KAAA,QAAA,QAAA,CAAA,GAAA,QAAA,IAAA;AAAA,QAAA;QAEVC,KAAAA,SAAI,MAAWH,KAAAA,OAAO,qBAAjCF,mBAIM,OAAA;AAAA;UAJkC,IAAIC,MAAA,MAAA;AAAA,UAAQ,OAAM;AAAA,QAAA;UACzDG,WAEO,yBAFP,MAEO;AAAA,4CADHC,KAAAA,IAAI,GAAA,CAAA;AAAA,UAAA;;QAGAC,KAAAA,gBAAW,MAAWJ,KAAAA,OAAO,eAAtCC,aAAAH,mBAII,KAJJ,YAII;AAAA,UAHHI,WAEO,gCAFP,MAEO;AAAA,4CADHE,KAAAA,WAAW,GAAA,CAAA;AAAA,UAAA;;QAGLJ,KAAAA,OAAO,UAAlBC,aAAAH,mBAEM,OAFN,YAEM;AAAA,UADLI,WAAsB,KAAA,QAAA,UAAA,CAAA,GAAA,QAAA,IAAA;AAAA,QAAA;;;;;;"}
1
+ {"version":3,"file":"NcEmptyContent-CDgWCt_m.mjs","sources":["../../src/components/NcEmptyContent/NcEmptyContent.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n### Basic use\n\nUse this component to display a message about an empty content.\nProviding an icon, name, and a description is strongly advised.\n\n```\n<template>\n\t<NcEmptyContent name=\"No comments\"\n\t\tdescription=\"Start writing comments and they will appear here.\">\n\t\t<template #icon>\n\t\t\t<Comment />\n\t\t</template>\n\t</NcEmptyContent>\n</template>\n\n<script>\nimport Comment from 'vue-material-design-icons/Comment.vue'\n\nexport default {\n\tcomponents: {\n\t\tComment,\n\t},\n}\n</script>\n```\n#### With custom svg\n\n```\n<template>\n\t<NcEmptyContent\n\t\tname=\"No files in here\">\n\t\t<template #icon>\n\t\t\t<NcIconSvgWrapper :svg=\"folderSvg\" />\n\t\t</template>\n\t</NcEmptyContent>\n</template>\n\n<script>\nimport folderSvg from '@mdi/svg/svg/folder.svg?raw'\n\nexport default {\n\tcomponents: {\n\t\tComment,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tfolderSvg,\n\t\t}\n\t},\n}\n</script>\n```\n\nYou can also customize the name using the `#name` slot\nand add actions. But to keep the style consistent across Nextcloud\nconsider only using header elements as the root elements for the name slot.\n\n```\n<template>\n\t<NcEmptyContent\n\t\tdescription=\"No comments in here\">\n\t\t<template #icon>\n\t\t\t<Comment />\n\t\t</template>\n\t\t<template #name>\n\t\t\t<h1 class=\"empty-content__name\">\n\t\t\t\tNo comments\n\t\t\t</h1>\n\t\t</template>\n\t\t<template #action>\n\t\t\t<NcButton variant=\"primary\">\n\t\t\t\tAdd a comment!\n\t\t\t</NcButton>\n\t\t</template>\n\t</NcEmptyContent>\n</template>\n\n<script>\nimport Comment from 'vue-material-design-icons/Comment.vue'\n\nexport default {\n\tcomponents: {\n\t\tComment,\n\t},\n}\n</script>\n```\n\nSimilar to the `#name` slot, you could also use the `#description` slot.\nThe content will be rendered within a paragraph so you can use any inline element,\nlike a link.\n\n```\n<template>\n\t<NcEmptyContent\n\t\tname=\"No comments\">\n\t\t<template #icon>\n\t\t\t<Comment />\n\t\t</template>\n\t\t<template #description>\n\t\t\t<a href=\"https://en.wikipedia.org/wiki/Comment\">What is even a comment?</a>\n\t\t</template>\n\t</NcEmptyContent>\n</template>\n\n<script>\nimport Comment from 'vue-material-design-icons/Comment.vue'\n\nexport default {\n\tcomponents: {\n\t\tComment,\n\t},\n}\n</script>\n```\n</docs>\n\n<script setup lang=\"ts\">\nimport type { Slot } from 'vue'\n\nimport { createElementId } from '../../utils/createElementId.ts'\n\nwithDefaults(defineProps<{\n\t/**\n\t * Desription of the empty content\n\t *\n\t * @example 'No comments yet, start the conversation!'\n\t */\n\tdescription?: string\n\n\t/**\n\t * A header message about an empty content shown.\n\t *\n\t * @example 'No comments'\n\t */\n\tname?: string\n}>(), {\n\tdescription: '',\n\tname: '',\n})\n\ndefineSlots<{\n\t/**\n\t * Optional slot for a button or the like\n\t */\n\taction?: Slot\n\n\t/**\n\t * Optional slot for adding an icon\n\t */\n\ticon?: Slot\n\n\t/**\n\t * Allow to add custom formatted name as an alternative to the name property.\n\t * The content passed shall be enclosed by a header element.\n\t */\n\tname?: Slot\n\n\t/**\n\t * Optional formatted description rendered inside a paragraph as an alternative to the description property.\n\t */\n\tdescription?: Slot\n}>()\n\nconst nameId = createElementId()\n</script>\n\n<template>\n\t<div :aria-labelledby=\"nameId\" class=\"empty-content\" role=\"note\">\n\t\t<div v-if=\"$slots.icon\" class=\"empty-content__icon\" aria-hidden=\"true\">\n\t\t\t<slot name=\"icon\" />\n\t\t</div>\n\t\t<div v-if=\"name !== '' || $slots.name\" :id=\"nameId\" class=\"empty-content__name\">\n\t\t\t<slot name=\"name\">\n\t\t\t\t{{ name }}\n\t\t\t</slot>\n\t\t</div>\n\t\t<p v-if=\"description !== '' || $slots.description\" class=\"empty-content__description\">\n\t\t\t<slot name=\"description\">\n\t\t\t\t{{ description }}\n\t\t\t</slot>\n\t\t</p>\n\t\t<div v-if=\"$slots.action\" class=\"empty-content__action\">\n\t\t\t<slot name=\"action\" />\n\t\t</div>\n\t</div>\n</template>\n\n<style lang=\"scss\" scoped>\n.empty-content {\n\tdisplay: flex;\n\talign-items: center;\n\tflex-direction: column;\n\tjustify-content: center;\n\t/* In case of using in a flex container - flex in advance */\n\tflex-grow: 1;\n\tpadding: var(--default-grid-baseline);\n\n\t.modal-wrapper & {\n\t\tmargin-top: 5vh;\n\t\tmargin-bottom: 5vh;\n\t}\n\n\t&__icon {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: center;\n\t\twidth: 64px;\n\t\theight: 64px;\n\t\tmargin: 0 auto 15px;\n\t\topacity: .4;\n\t\tbackground-repeat: no-repeat;\n\t\tbackground-position: center;\n\t\tbackground-size: 64px;\n\n\t\t:deep(svg) {\n\t\t\twidth: 64px !important;\n\t\t\theight: 64px !important;\n\t\t\tmax-width: 64px !important;\n\t\t\tmax-height: 64px !important;\n\t\t}\n\t}\n\n\t&__name {\n\t\tmargin-bottom: 10px;\n\t\ttext-align: center;\n\t\tfont-weight: bold;\n\t\tfont-size: 20px;\n\t\tline-height: 30px;\n\t}\n\n\t&__description {\n\t\tcolor: var(--color-text-maxcontrast);\n\t\ttext-align: center;\n\t\ttext-wrap-style: balance;\n\t}\n\n\t&__action {\n\t\tmargin-top: 8px;\n\n\t\t.modal-wrapper & {\n\t\t\tmargin-top: 20px;\n\t\t\tdisplay: flex;\n\t\t}\n\t}\n}\n</style>\n"],"names":["_createElementBlock","_unref","$slots","_openBlock","_renderSlot","name","description"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AA0KA,UAAM,SAAS,gBAAA;;0BAIdA,mBAiBM,OAAA;AAAA,QAjBA,mBAAiBC,MAAA,MAAA;AAAA,QAAQ,OAAM;AAAA,QAAgB,MAAK;AAAA,MAAA;QAC9CC,KAAAA,OAAO,QAAlBC,aAAAH,mBAEM,OAFN,YAEM;AAAA,UADLI,WAAoB,KAAA,QAAA,QAAA,CAAA,GAAA,QAAA,IAAA;AAAA,QAAA;QAEVC,KAAAA,SAAI,MAAWH,KAAAA,OAAO,qBAAjCF,mBAIM,OAAA;AAAA;UAJkC,IAAIC,MAAA,MAAA;AAAA,UAAQ,OAAM;AAAA,QAAA;UACzDG,WAEO,yBAFP,MAEO;AAAA,4CADHC,KAAAA,IAAI,GAAA,CAAA;AAAA,UAAA;;QAGAC,KAAAA,gBAAW,MAAWJ,KAAAA,OAAO,eAAtCC,aAAAH,mBAII,KAJJ,YAII;AAAA,UAHHI,WAEO,gCAFP,MAEO;AAAA,4CADHE,KAAAA,WAAW,GAAA,CAAA;AAAA,UAAA;;QAGLJ,KAAAA,OAAO,UAAlBC,aAAAH,mBAEM,OAFN,YAEM;AAAA,UADLI,WAAsB,KAAA,QAAA,UAAA,CAAA,GAAA,QAAA,IAAA;AAAA,QAAA;;;;;;"}
@@ -0,0 +1,303 @@
1
+ import '../assets/NcFilePicker-CimiKIH1.css';
2
+ import { openBlock, createElementBlock, mergeProps, createElementVNode, toDisplayString, createCommentVNode, defineComponent, useTemplateRef, computed, normalizeClass, createVNode, withCtx, createBlock, createTextVNode, unref, Fragment, renderList, renderSlot, nextTick } from "vue";
3
+ import { _ as _export_sfc } from "./_plugin-vue_export-helper-1tPrXgE0.mjs";
4
+ import { N as NcActionButton } from "./NcActionButton-BuRnYpJX.mjs";
5
+ import { N as NcActionCaption } from "./NcActionCaption-f7L9gBlT.mjs";
6
+ import { N as NcActions } from "./NcActions-B_QR93qv.mjs";
7
+ import { N as NcIconSvgWrapper } from "./NcIconSvgWrapper-De-2-ukl.mjs";
8
+ import { N as NcLoadingIcon } from "./NcLoadingIcon-CInLzPtA.mjs";
9
+ import { getGettextBuilder } from "@nextcloud/l10n/gettext";
10
+ const _sfc_main$3 = {
11
+ name: "FolderUploadIcon",
12
+ emits: ["click"],
13
+ props: {
14
+ title: {
15
+ type: String
16
+ },
17
+ fillColor: {
18
+ type: String,
19
+ default: "currentColor"
20
+ },
21
+ size: {
22
+ type: Number,
23
+ default: 24
24
+ }
25
+ }
26
+ };
27
+ const _hoisted_1$3 = ["aria-hidden", "aria-label"];
28
+ const _hoisted_2$2 = ["fill", "width", "height"];
29
+ const _hoisted_3$2 = { d: "M20,6A2,2 0 0,1 22,8V18A2,2 0 0,1 20,20H4A2,2 0 0,1 2,18V6A2,2 0 0,1 4,4H10L12,6H20M10.75,13H14V17H16V13H19.25L15,8.75" };
30
+ const _hoisted_4$2 = { key: 0 };
31
+ function _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {
32
+ return openBlock(), createElementBlock("span", mergeProps(_ctx.$attrs, {
33
+ "aria-hidden": $props.title ? null : "true",
34
+ "aria-label": $props.title,
35
+ class: "material-design-icon folder-upload-icon",
36
+ role: "img",
37
+ onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$emit("click", $event))
38
+ }), [
39
+ (openBlock(), createElementBlock("svg", {
40
+ fill: $props.fillColor,
41
+ class: "material-design-icon__svg",
42
+ width: $props.size,
43
+ height: $props.size,
44
+ viewBox: "0 0 24 24"
45
+ }, [
46
+ createElementVNode("path", _hoisted_3$2, [
47
+ $props.title ? (openBlock(), createElementBlock("title", _hoisted_4$2, toDisplayString($props.title), 1)) : createCommentVNode("", true)
48
+ ])
49
+ ], 8, _hoisted_2$2))
50
+ ], 16, _hoisted_1$3);
51
+ }
52
+ const IconFolderUpload = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["render", _sfc_render$2]]);
53
+ const _sfc_main$2 = {
54
+ name: "PlusIcon",
55
+ emits: ["click"],
56
+ props: {
57
+ title: {
58
+ type: String
59
+ },
60
+ fillColor: {
61
+ type: String,
62
+ default: "currentColor"
63
+ },
64
+ size: {
65
+ type: Number,
66
+ default: 24
67
+ }
68
+ }
69
+ };
70
+ const _hoisted_1$2 = ["aria-hidden", "aria-label"];
71
+ const _hoisted_2$1 = ["fill", "width", "height"];
72
+ const _hoisted_3$1 = { d: "M19,13H13V19H11V13H5V11H11V5H13V11H19V13Z" };
73
+ const _hoisted_4$1 = { key: 0 };
74
+ function _sfc_render$1(_ctx, _cache, $props, $setup, $data, $options) {
75
+ return openBlock(), createElementBlock("span", mergeProps(_ctx.$attrs, {
76
+ "aria-hidden": $props.title ? null : "true",
77
+ "aria-label": $props.title,
78
+ class: "material-design-icon plus-icon",
79
+ role: "img",
80
+ onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$emit("click", $event))
81
+ }), [
82
+ (openBlock(), createElementBlock("svg", {
83
+ fill: $props.fillColor,
84
+ class: "material-design-icon__svg",
85
+ width: $props.size,
86
+ height: $props.size,
87
+ viewBox: "0 0 24 24"
88
+ }, [
89
+ createElementVNode("path", _hoisted_3$1, [
90
+ $props.title ? (openBlock(), createElementBlock("title", _hoisted_4$1, toDisplayString($props.title), 1)) : createCommentVNode("", true)
91
+ ])
92
+ ], 8, _hoisted_2$1))
93
+ ], 16, _hoisted_1$2);
94
+ }
95
+ const IconPlus = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["render", _sfc_render$1]]);
96
+ const _sfc_main$1 = {
97
+ name: "UploadIcon",
98
+ emits: ["click"],
99
+ props: {
100
+ title: {
101
+ type: String
102
+ },
103
+ fillColor: {
104
+ type: String,
105
+ default: "currentColor"
106
+ },
107
+ size: {
108
+ type: Number,
109
+ default: 24
110
+ }
111
+ }
112
+ };
113
+ const _hoisted_1$1 = ["aria-hidden", "aria-label"];
114
+ const _hoisted_2 = ["fill", "width", "height"];
115
+ const _hoisted_3 = { d: "M9,16V10H5L12,3L19,10H15V16H9M5,20V18H19V20H5Z" };
116
+ const _hoisted_4 = { key: 0 };
117
+ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
118
+ return openBlock(), createElementBlock("span", mergeProps(_ctx.$attrs, {
119
+ "aria-hidden": $props.title ? null : "true",
120
+ "aria-label": $props.title,
121
+ class: "material-design-icon upload-icon",
122
+ role: "img",
123
+ onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$emit("click", $event))
124
+ }), [
125
+ (openBlock(), createElementBlock("svg", {
126
+ fill: $props.fillColor,
127
+ class: "material-design-icon__svg",
128
+ width: $props.size,
129
+ height: $props.size,
130
+ viewBox: "0 0 24 24"
131
+ }, [
132
+ createElementVNode("path", _hoisted_3, [
133
+ $props.title ? (openBlock(), createElementBlock("title", _hoisted_4, toDisplayString($props.title), 1)) : createCommentVNode("", true)
134
+ ])
135
+ ], 8, _hoisted_2))
136
+ ], 16, _hoisted_1$1);
137
+ }
138
+ const IconUpload = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["render", _sfc_render]]);
139
+ /*!
140
+ * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
141
+ * SPDX-License-Identifier: AGPL-3.0-or-later
142
+ */
143
+ const gtBuilder = getGettextBuilder().detectLanguage();
144
+ const gt = gtBuilder.build();
145
+ gt.ngettext.bind(gt);
146
+ const t = gt.gettext.bind(gt);
147
+ const _hoisted_1 = ["accept", "multiple"];
148
+ const _sfc_main = /* @__PURE__ */ defineComponent({
149
+ __name: "NcFilePicker",
150
+ props: {
151
+ accept: { default: void 0 },
152
+ actionCaption: { default: "" },
153
+ actions: { default: () => [] },
154
+ directory: { type: Boolean },
155
+ directoryOnly: { type: Boolean },
156
+ disabled: { type: Boolean },
157
+ iconOnly: { type: Boolean },
158
+ label: { default: void 0 },
159
+ loading: { type: Boolean },
160
+ multiple: { type: Boolean },
161
+ variant: { default: "primary" }
162
+ },
163
+ emits: ["pick"],
164
+ setup(__props, { expose: __expose, emit: __emit }) {
165
+ const props = __props;
166
+ const emit = __emit;
167
+ __expose({
168
+ reset
169
+ });
170
+ const formElement = useTemplateRef("form");
171
+ const inputElement = useTemplateRef("input");
172
+ const currentLabel = computed(() => {
173
+ if (props.loading) {
174
+ return t("Uploading …");
175
+ } else if (props.label) {
176
+ return props.label;
177
+ } else if (props.directoryOnly) {
178
+ return t("Pick folder");
179
+ }
180
+ return props.multiple ? t("Pick files") : t("Pick file");
181
+ });
182
+ const canUploadFolders = computed(() => {
183
+ return (props.directory || props.directoryOnly) && "webkitdirectory" in HTMLInputElement.prototype;
184
+ });
185
+ function triggerPickFiles(uploadFolders) {
186
+ reset();
187
+ if (canUploadFolders.value) {
188
+ inputElement.value.webkitdirectory = uploadFolders;
189
+ }
190
+ nextTick(() => inputElement.value.click());
191
+ }
192
+ function onPick() {
193
+ const files = inputElement.value?.files ? Array.from(inputElement.value.files) : [];
194
+ emit("pick", files);
195
+ }
196
+ function reset() {
197
+ formElement.value.reset();
198
+ }
199
+ return (_ctx, _cache) => {
200
+ return openBlock(), createElementBlock("form", {
201
+ ref: "form",
202
+ class: normalizeClass(_ctx.$style.filePicker)
203
+ }, [
204
+ createVNode(NcActions, {
205
+ "aria-label": currentLabel.value,
206
+ disabled: _ctx.disabled || _ctx.loading,
207
+ menuName: _ctx.iconOnly ? void 0 : currentLabel.value,
208
+ forceName: !_ctx.iconOnly,
209
+ variant: _ctx.variant
210
+ }, {
211
+ icon: withCtx(() => [
212
+ !_ctx.loading ? renderSlot(_ctx.$slots, "icon", { key: 0 }, () => [
213
+ createVNode(IconPlus, { size: 20 })
214
+ ]) : (openBlock(), createBlock(NcLoadingIcon, { key: 1 }))
215
+ ]),
216
+ default: withCtx(() => [
217
+ _ctx.actionCaption ? (openBlock(), createBlock(NcActionCaption, {
218
+ key: 0,
219
+ name: _ctx.actionCaption
220
+ }, null, 8, ["name"])) : createCommentVNode("", true),
221
+ !_ctx.directoryOnly ? (openBlock(), createBlock(NcActionButton, {
222
+ key: 1,
223
+ closeAfterClick: "",
224
+ onClick: _cache[0] || (_cache[0] = ($event) => triggerPickFiles(false))
225
+ }, {
226
+ icon: withCtx(() => [
227
+ createVNode(IconUpload, { size: 20 })
228
+ ]),
229
+ default: withCtx(() => [
230
+ createTextVNode(" " + toDisplayString(canUploadFolders.value || _ctx.$slots.actions ? _ctx.multiple ? unref(t)("Upload files") : unref(t)("Upload file") : currentLabel.value), 1)
231
+ ]),
232
+ _: 1
233
+ })) : createCommentVNode("", true),
234
+ canUploadFolders.value ? (openBlock(), createBlock(NcActionButton, {
235
+ key: 2,
236
+ closeAfterClick: "",
237
+ onClick: _cache[1] || (_cache[1] = ($event) => triggerPickFiles(true))
238
+ }, {
239
+ icon: withCtx(() => [
240
+ createVNode(IconFolderUpload, {
241
+ style: { "color": "var(--color-primary-element)" },
242
+ size: 20
243
+ })
244
+ ]),
245
+ default: withCtx(() => [
246
+ createTextVNode(" " + toDisplayString(!_ctx.directoryOnly || _ctx.$slots.actions ? unref(t)("Upload folder") : currentLabel.value), 1)
247
+ ]),
248
+ _: 1
249
+ })) : createCommentVNode("", true),
250
+ (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.actions, (group) => {
251
+ return openBlock(), createElementBlock(Fragment, null, [
252
+ group.caption ? (openBlock(), createBlock(NcActionCaption, {
253
+ key: group.caption,
254
+ name: group.caption
255
+ }, null, 8, ["name"])) : createCommentVNode("", true),
256
+ (openBlock(true), createElementBlock(Fragment, null, renderList(group.actions ?? [group], (action) => {
257
+ return openBlock(), createBlock(NcActionButton, {
258
+ key: action.label,
259
+ closeAfterClick: "",
260
+ onClick: action.onClick
261
+ }, {
262
+ icon: withCtx(() => [
263
+ createVNode(NcIconSvgWrapper, {
264
+ svg: action.iconSvg
265
+ }, null, 8, ["svg"])
266
+ ]),
267
+ default: withCtx(() => [
268
+ createTextVNode(" " + toDisplayString(action.label), 1)
269
+ ]),
270
+ _: 2
271
+ }, 1032, ["onClick"]);
272
+ }), 128))
273
+ ], 64);
274
+ }), 256))
275
+ ]),
276
+ _: 3
277
+ }, 8, ["aria-label", "disabled", "menuName", "forceName", "variant"]),
278
+ createElementVNode("input", {
279
+ ref: "input",
280
+ accept: _ctx.accept?.join(", "),
281
+ "aria-hidden": "true",
282
+ class: "hidden-visually",
283
+ multiple: _ctx.multiple,
284
+ type: "file",
285
+ onChange: onPick
286
+ }, null, 40, _hoisted_1),
287
+ renderSlot(_ctx.$slots, "default")
288
+ ], 2);
289
+ };
290
+ }
291
+ });
292
+ const filePicker = "_filePicker_UHtO-";
293
+ const style0 = {
294
+ filePicker
295
+ };
296
+ const cssModules = {
297
+ "$style": style0
298
+ };
299
+ const NcFilePicker = /* @__PURE__ */ _export_sfc(_sfc_main, [["__cssModules", cssModules]]);
300
+ export {
301
+ NcFilePicker as N
302
+ };
303
+ //# sourceMappingURL=NcFilePicker-DtOsHB4q.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcFilePicker-DtOsHB4q.mjs","sources":["../../node_modules/vue-material-design-icons/FolderUpload.vue","../../node_modules/vue-material-design-icons/Plus.vue","../../node_modules/vue-material-design-icons/Upload.vue","../../src/l10n.ts","../../src/components/NcFilePicker/NcFilePicker.vue"],"sourcesContent":["<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon folder-upload-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=\"M20,6A2,2 0 0,1 22,8V18A2,2 0 0,1 20,20H4A2,2 0 0,1 2,18V6A2,2 0 0,1 4,4H10L12,6H20M10.75,13H14V17H16V13H19.25L15,8.75\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"FolderUploadIcon\",\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>","<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon plus-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=\"M19,13H13V19H11V13H5V11H11V5H13V11H19V13Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"PlusIcon\",\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>","<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon upload-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=\"M9,16V10H5L12,3L19,10H15V16H9M5,20V18H19V20H5Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"UploadIcon\",\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// This is only a dummy file, the real translations are injected by the vite plugin from build/l10n-plugin!\nimport { getGettextBuilder } from '@nextcloud/l10n/gettext'\n\nconst gtBuilder = getGettextBuilder().detectLanguage()\nconst gt = gtBuilder.build()\n\nconst n = gt.ngettext.bind(gt)\nconst t = gt.gettext.bind(gt)\n\nexport { n, t }\n","<!--\n - SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<script setup lang=\"ts\">\nimport type { Slot } from 'vue'\n\nimport { computed, nextTick, useTemplateRef } from 'vue'\nimport IconFolderUpload from 'vue-material-design-icons/FolderUpload.vue'\nimport IconPlus from 'vue-material-design-icons/Plus.vue'\nimport IconUpload from 'vue-material-design-icons/Upload.vue'\nimport NcActionButton from '../NcActionButton/NcActionButton.vue'\nimport NcActionCaption from '../NcActionCaption/NcActionCaption.vue'\nimport NcActions from '../NcActions/NcActions.vue'\nimport NcIconSvgWrapper from '../NcIconSvgWrapper/NcIconSvgWrapper.vue'\nimport NcLoadingIcon from '../NcLoadingIcon/NcLoadingIcon.vue'\nimport { t } from '../../l10n.js'\n\nexport interface FilePickerItem {\n\t/**\n\t * SVG icon (as string) for the action\n\t */\n\ticonSvg: string\n\t/**\n\t * Label of the action\n\t */\n\tlabel: string\n\t/**\n\t * Callback when the action is clicked\n\t */\n\tonClick: () => void\n}\n\nexport interface FilePickerItemGroup {\n\t/**\n\t * Caption for the action group\n\t */\n\tcaption: string\n\t/**\n\t * Actions within this group\n\t */\n\tactions: FilePickerItem[]\n}\n\nconst props = withDefaults(defineProps<{\n\t/**\n\t * File types to accept\n\t */\n\taccept?: string[]\n\n\t/**\n\t * Optional menu caption to be shown above the actions\n\t */\n\tactionCaption?: string\n\n\t/**\n\t * Additional actions to be shown within the picker menu\n\t */\n\tactions?: FilePickerItem[] | FilePickerItemGroup[]\n\n\t/**\n\t * Allow picking a directory\n\t */\n\tdirectory?: boolean\n\n\t/**\n\t * Disable picking files and only allow picking a directory\n\t */\n\tdirectoryOnly?: boolean\n\n\t/**\n\t * Disabled state of the picker\n\t */\n\tdisabled?: boolean\n\n\t/**\n\t * If set then the label is only used for accessibility but not shown visually\n\t */\n\ticonOnly?: boolean\n\n\t/**\n\t * Label of the picker\n\t *\n\t * @default 'Pick file' or 'Pick files' depending on `multiple`\n\t */\n\tlabel?: string\n\n\t/**\n\t * If set then the picker will be set into a loading state.\n\t * This means the picker is disabled, a loading spinner is shown and the label is adjusted.\n\t */\n\tloading?: boolean\n\n\t/**\n\t * Can the user pick multiple files.\n\t * This is ignored when picking folder (by browser limitations).\n\t */\n\tmultiple?: boolean\n\n\t/**\n\t * The variant of the button\n\t */\n\tvariant?: 'primary' | 'secondary' | 'tertiary'\n}>(), {\n\tactions: () => [],\n\taccept: undefined,\n\tactionCaption: '',\n\tlabel: undefined,\n\tvariant: 'primary',\n})\n\nconst emit = defineEmits<{\n\tpick: [files: File[]]\n}>()\n\ndefineSlots<{\n\t/**\n\t * Optional custom icon for the picker menu\n\t */\n\ticon?: Slot\n\n\t/**\n\t * Optional content to be shown in the picker.\n\t * This can be used e.g. for a progress bar or similar.\n\t */\n\tdefault?: Slot\n}>()\n\ndefineExpose({\n\treset,\n})\n\nconst formElement = useTemplateRef('form')\nconst inputElement = useTemplateRef('input')\n\n/**\n * The current label to be used as menu name and accessible name of the picker.\n */\nconst currentLabel = computed(() => {\n\tif (props.loading) {\n\t\treturn t('Uploading …')\n\t} else if (props.label) {\n\t\treturn props.label\n\t} else if (props.directoryOnly) {\n\t\treturn t('Pick folder')\n\t}\n\treturn props.multiple ? t('Pick files') : t('Pick file')\n})\n\n/**\n * Check whether the current browser supports uploading directories\n * Hint: This does not check if the current connection supports this, as some browsers require a secure context!\n */\nconst canUploadFolders = computed(() => {\n\treturn (props.directory || props.directoryOnly) && 'webkitdirectory' in HTMLInputElement.prototype\n})\n\n/**\n * Trigger file picker\n *\n * @param uploadFolders - Whether to upload folders or files\n */\nfunction triggerPickFiles(uploadFolders: boolean) {\n\t// Without reset selecting the same file doesn't trigger the change event\n\treset()\n\n\t// Only if the browser supports picking folders and the user selected \"pick folder\" we set the file input to directory picking.\n\tif (canUploadFolders.value) {\n\t\tinputElement.value!.webkitdirectory = uploadFolders\n\t}\n\n\t// Wait for the reset and the `webkitdirectory` to be dispatched in DOM\n\tnextTick(() => inputElement.value!.click())\n}\n\n/**\n * Handle picking some local files\n */\nfunction onPick() {\n\tconst files = inputElement.value?.files ? Array.from(inputElement.value.files) : []\n\temit('pick', files)\n}\n\n/**\n * Reset the picker state of the currently selected files.\n */\nfunction reset() {\n\tformElement.value!.reset()\n}\n</script>\n\n<template>\n\t<form\n\t\tref=\"form\"\n\t\t:class=\"$style.filePicker\">\n\t\t<NcActions\n\t\t\t:aria-label=\"currentLabel\"\n\t\t\t:disabled=\"disabled || loading\"\n\t\t\t:menuName=\"iconOnly ? undefined : currentLabel\"\n\t\t\t:forceName=\"!iconOnly\"\n\t\t\t:variant>\n\t\t\t<template #icon>\n\t\t\t\t<slot v-if=\"!loading\" name=\"icon\">\n\t\t\t\t\t<IconPlus :size=\"20\" />\n\t\t\t\t</slot>\n\t\t\t\t<NcLoadingIcon v-else />\n\t\t\t</template>\n\n\t\t\t<NcActionCaption v-if=\"actionCaption\" :name=\"actionCaption\" />\n\n\t\t\t<NcActionButton\n\t\t\t\tv-if=\"!directoryOnly\"\n\t\t\t\tcloseAfterClick\n\t\t\t\t@click=\"triggerPickFiles(false)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<IconUpload :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<!-- If this is not the only action in the NcActions this is a menu entry and we need a generic name - otherwise this will be a single button where we need to apply the label -->\n\t\t\t\t{{ canUploadFolders || $slots.actions ? (multiple ? t('Upload files') : t('Upload file')) : currentLabel }}\n\t\t\t</NcActionButton>\n\n\t\t\t<NcActionButton\n\t\t\t\tv-if=\"canUploadFolders\"\n\t\t\t\tcloseAfterClick\n\t\t\t\t@click=\"triggerPickFiles(true)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<IconFolderUpload style=\"color: var(--color-primary-element)\" :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<!-- If this is not the only action in the NcActions this is a menu entry and we need a generic name - otherwise this will be a single button where we need to apply the label -->\n\t\t\t\t{{ !directoryOnly || $slots.actions ? t('Upload folder') : currentLabel }}\n\t\t\t</NcActionButton>\n\n\t\t\t<template v-for=\"group of actions\">\n\t\t\t\t<NcActionCaption\n\t\t\t\t\tv-if=\"(group as FilePickerItemGroup).caption\"\n\t\t\t\t\t:key=\"(group as FilePickerItemGroup).caption\"\n\t\t\t\t\t:name=\"(group as FilePickerItemGroup).caption\" />\n\n\t\t\t\t<NcActionButton\n\t\t\t\t\tv-for=\"action of (group as FilePickerItemGroup).actions ?? [group as FilePickerItem]\"\n\t\t\t\t\t:key=\"action.label\"\n\t\t\t\t\tcloseAfterClick\n\t\t\t\t\t@click=\"action.onClick\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<NcIconSvgWrapper :svg=\"action.iconSvg\" />\n\t\t\t\t\t</template>\n\t\t\t\t\t{{ action.label }}\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcActions>\n\n\t\t<!-- Hidden files picker input - also hidden for accessibility as otherwise such users also loose the ability to pick files -->\n\t\t<input\n\t\t\tref=\"input\"\n\t\t\t:accept=\"accept?.join(', ')\"\n\t\t\taria-hidden=\"true\"\n\t\t\tclass=\"hidden-visually\"\n\t\t\t:multiple\n\t\t\ttype=\"file\"\n\t\t\t@change=\"onPick\">\n\n\t\t<slot />\n\t</form>\n</template>\n\n<style module>\n.filePicker {\n\tdisplay: inline-flex;\n\talign-items: center;\n\theight: var(--default-clickable-area);\n}\n</style>\n\n<docs>\nThis component allows to pick local files (or directories) which can be used to upload them to Nextcloud or directly process them in the browser.\n\n### Exposed methods\n\n- `function reset(): void`\n This method allows to reset the internal state of the file picker to clear the current selection\n\n### Example\n\n```vue\n<template>\n\t<div>\n\t\t<div class=\"wrapper\">\n\t\t\t<NcFilePicker ref=\"picker\"\n\t\t\t\tdirectory\n\t\t\t\t@pick=\"selectedFiles = $event\" />\n\n\t\t\t<NcButton variant=\"tertiary\"\n\t\t\t\t@click=\"clearPicker\">\n\t\t\t\tClear\n\t\t\t</NcButton>\n\t\t</div>\n\n\t\t<h3>Selected files:</h3>\n\t\t<ul>\n\t\t\t<li v-for=\"file in selectedFiles\" key=\"file.name\">\n\t\t\t\t{{ file.webkitRelativePath || file.name }}\n\t\t\t</li>\n\t\t</ul>\n\t</div>\n</template>\n<script>\n\texport default {\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\tselectedFiles: [],\n\t\t\t}\n\t\t},\n\t\tmethods: {\n\t\t\t/**\n\t\t\t * This will clear the selected files from the picker.\n\t\t\t */\n\t\t\tclearPicker() {\n\t\t\t\tthis.$refs.picker.reset()\n\t\t\t},\n\t\t},\n\t}\n</script>\n<style scoped>\n.wrapper {\n\tdisplay: flex;\n\tgap: 10px;\n}\n</style>\n```\n</docs>\n"],"names":["_sfc_main","_hoisted_3","_createElementBlock","_mergeProps","_createElementVNode","_openBlock","_normalizeClass","$style","_createVNode","disabled","loading","iconOnly","variant","_renderSlot","_createBlock","actionCaption","directoryOnly","_createTextVNode","_toDisplayString","$slots","multiple","_unref","_Fragment","_renderList","actions","accept"],"mappings":"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","x_google_ignoreList":[0,1,2]}
@@ -1,5 +1,5 @@
1
1
  import '../assets/NcFormBox-CRdHJkrd.css';
2
- import { defineComponent, useCssModule, provide, createElementBlock, openBlock, normalizeClass, renderSlot } from "vue";
2
+ import { defineComponent, useCssModule, provide, openBlock, createElementBlock, normalizeClass, renderSlot } from "vue";
3
3
  import { N as NC_FORM_BOX_CONTEXT_KEY } from "./useNcFormBox-Djlh582y.mjs";
4
4
  import { _ as _export_sfc } from "./_plugin-vue_export-helper-1tPrXgE0.mjs";
5
5
  const _sfc_main = /* @__PURE__ */ defineComponent({
@@ -42,4 +42,4 @@ const NcFormBox = /* @__PURE__ */ _export_sfc(_sfc_main, [["__cssModules", cssMo
42
42
  export {
43
43
  NcFormBox as N
44
44
  };
45
- //# sourceMappingURL=NcFormBox-BYjllt0m.mjs.map
45
+ //# sourceMappingURL=NcFormBox-wP5mpW88.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"NcFormBox-BYjllt0m.mjs","sources":["../../src/components/NcFormBox/NcFormBox.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<script setup lang=\"ts\">\nimport type { Slot } from 'vue'\n\nimport { provide, useCssModule } from 'vue'\nimport { NC_FORM_BOX_CONTEXT_KEY } from './useNcFormBox.ts'\n\ndefineProps<{\n\t/**\n\t * Display the group as a row instead of a column\n\t */\n\trow?: boolean\n}>()\n\ndefineSlots<{\n\t/**\n\t * Grouped content\n\t */\n\tdefault?: Slot<{\n\t\t/**\n\t\t * Class to add on a custom item to apply the border radius effect\n\t\t */\n\t\titemClass: string\n\t}>\n}>()\n\nconst style = useCssModule()\n\nprovide(NC_FORM_BOX_CONTEXT_KEY, {\n\tisInFormBox: true,\n\tformBoxItemClass: style.ncFormBox__item,\n})\n</script>\n\n<template>\n\t<div :class=\"[$style.ncFormBox, row ? $style.ncFormBox_row : $style.ncFormBox_col]\">\n\t\t<slot :itemClass=\"$style.ncFormBox__item\" />\n\t</div>\n</template>\n\n<style lang=\"scss\" module>\n.ncFormBox {\n\tdisplay: flex;\n\tflex-direction: column;\n\tgap: calc(1 * var(--default-grid-baseline));\n\n\t&.ncFormBox_row {\n\t\tflex-direction: row;\n\t}\n}\n\n.ncFormBox__item {\n\tborder-radius: var(--border-radius-small) !important;\n}\n\n.ncFormBox_col {\n\tflex-direction: column;\n\n\t.ncFormBox__item {\n\t\t&:first-child {\n\t\t\tborder-start-start-radius: var(--border-radius-element) !important;\n\t\t\tborder-start-end-radius: var(--border-radius-element) !important;\n\t\t}\n\n\t\t&:last-child {\n\t\t\tborder-end-start-radius: var(--border-radius-element) !important;\n\t\t\tborder-end-end-radius: var(--border-radius-element) !important;\n\t\t}\n\t}\n}\n\n.ncFormBox_row {\n\tflex-direction: row;\n\n\t.ncFormBox__item {\n\t\tflex: 1 1;\n\n\t\t&:first-child {\n\t\t\tborder-start-start-radius: var(--border-radius-element) !important;\n\t\t\tborder-end-start-radius: var(--border-radius-element) !important;\n\t\t}\n\n\t\t&:last-child {\n\t\t\tborder-end-end-radius: var(--border-radius-element) !important;\n\t\t\tborder-start-end-radius: var(--border-radius-element) !important;\n\t\t}\n\t}\n}\n</style>\n\n<docs>\n### General\n\nA container of supported components with a small gap and rounded corners forming a solid group.\n\nCurrently supported components:\n- **`<NcFormBoxButton>`**: an action button/link with an optional description specially for the `<NcFormBox>` context\n- **`<NcFormBoxCopyButton>`**: a special case of a button to copy a text to the clipboard\n- **`<NcFormBoxSwitch>`**: a toggle switch replacing `<NcCheckboxRadioSwitch type=\"switch\">` in a box\n- **`<NcButton>`**: a general button in case there is a kind of primary action within a box\n\n**Note**: if the group has a semantic meaning, consider wrapping the `<NcFormBox>` into `<NcFormGroup>` component with a label.\n\n```vue\n<script>\nimport { mdiArrowRight, mdiFolderOpenOutline, mdiPlus } from '@mdi/js'\n\nexport default {\n\tsetup() {\n\t\treturn { mdiArrowRight, mdiFolderOpenOutline, mdiPlus }\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\ttext: 'Text',\n\t\t\tswitchValue: false,\n\t\t}\n\t},\n}\n</script>\n\n<template>\n\t<div style=\"display: flex; flex-direction: column; gap: calc(6 * var(--default-grid-baseline));\">\n\t\t<NcFormBox>\n\t\t\t<NcFormBoxCopyButton label=\"WebDAV URL\" value=\"https://cloud.example.tld/remote.php/dav/files/user\" />\n\t\t</NcFormBox>\n\n\t\t<NcFormGroup label=\"Account settings\">\n\t\t\t<NcFormBox>\n\t\t\t\t<NcFormBoxButton label=\"user@example.com\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<NcIconSvgWrapper :path=\"mdiArrowRight\" inline />\n\t\t\t\t\t</template>\n\t\t\t\t</NcFormBoxButton>\n\t\t\t\t<NcFormBoxButton label=\"sales@example.com\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<NcIconSvgWrapper :path=\"mdiArrowRight\" inline />\n\t\t\t\t\t</template>\n\t\t\t\t</NcFormBoxButton>\n\t\t\t\t<NcButton wide>\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<NcIconSvgWrapper :path=\"mdiPlus\" />\n\t\t\t\t\t</template>\n\t\t\t\t\tAdd mail account\n\t\t\t\t</NcButton>\n\t\t\t</NcFormBox>\n\t\t</NcFormGroup>\n\n\t\t<NcFormGroup label=\"Device settings\">\n\t\t\t<NcFormBox>\n\t\t\t\t<NcFormBoxSwitch v-model=\"switchValue\" label=\"Turn camera and microphone off by default\" />\n\t\t\t\t<NcFormBoxSwitch v-model=\"switchValue\" label=\"Blur camera background by default\" />\n\t\t\t\t<NcFormBoxSwitch\n\t\t\t\t\tv-model=\"switchValue\"\n\t\t\t\t\tlabel=\"Skip device preview before joining a call\"\n\t\t\t\t\tdescription=\"Will always show if recording consent is required\" />\n\t\t\t</NcFormBox>\n\t\t</NcFormGroup>\n\n\t\t<NcFormBox>\n\t\t\t<NcFormBoxButton\n\t\t\t\tlabel=\"Attachments folder\"\n\t\t\t\tdescription=\"/Talk\"\n\t\t\t\tinverted-accent>\n\t\t\t\t<template #icon>\n\t\t\t\t\t<NcIconSvgWrapper :path=\"mdiFolderOpenOutline\" inline />\n\t\t\t\t</template>\n\t\t\t</NcFormBoxButton>\n\t\t</NcFormBox>\n\t</div>\n</template>\n```\n\n### Advanced usage\n\nScoped slot prop `itemClass` can be used to apply the same border radius effect to custom components.\nCreate an issue if you need a composable to inject the class into a custom component.\n\n```vue\n<template>\n\t<NcFormBox v-slot=\"{ itemClass }\">\n\t\t<button class=\"native-button\" :class=\"itemClass\">\n\t\t\tFirst native button\n\t\t</button>\n\t\t<button class=\"native-button\" :class=\"itemClass\">\n\t\t\tSecond native button\n\t\t</button>\n\t\t<button class=\"native-button\" :class=\"itemClass\">\n\t\t\tThird native button\n\t\t</button>\n\t</NcFormBox>\n</template>\n\n<style scoped>\n.native-button {\n\t/* Remove default server margin around a native button */\n\tmargin: 0 !important;\n}\n</style>\n```\n</docs>\n"],"names":["_createElementBlock","_normalizeClass","$style","row","_renderSlot"],"mappings":";;;;;;;;;AA8BA,UAAM,QAAQ,aAAA;AAEd,YAAQ,yBAAyB;AAAA,MAChC,aAAa;AAAA,MACb,kBAAkB,MAAM;AAAA,IAAA,CACxB;;0BAIAA,mBAEM,OAAA;AAAA,QAFA,OAAKC,eAAA,CAAGC,KAAAA,OAAO,WAAWC,KAAAA,MAAMD,KAAAA,OAAO,gBAAgBA,KAAAA,OAAO,aAAa,CAAA;AAAA,MAAA;QAChFE,WAA4C,KAAA,QAAA,WAAA;AAAA,UAArC,WAAWF,KAAAA,OAAO;AAAA,QAAA;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"NcFormBox-wP5mpW88.mjs","sources":["../../src/components/NcFormBox/NcFormBox.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<script setup lang=\"ts\">\nimport type { Slot } from 'vue'\n\nimport { provide, useCssModule } from 'vue'\nimport { NC_FORM_BOX_CONTEXT_KEY } from './useNcFormBox.ts'\n\ndefineProps<{\n\t/**\n\t * Display the group as a row instead of a column\n\t */\n\trow?: boolean\n}>()\n\ndefineSlots<{\n\t/**\n\t * Grouped content\n\t */\n\tdefault?: Slot<{\n\t\t/**\n\t\t * Class to add on a custom item to apply the border radius effect\n\t\t */\n\t\titemClass: string\n\t}>\n}>()\n\nconst style = useCssModule()\n\nprovide(NC_FORM_BOX_CONTEXT_KEY, {\n\tisInFormBox: true,\n\tformBoxItemClass: style.ncFormBox__item,\n})\n</script>\n\n<template>\n\t<div :class=\"[$style.ncFormBox, row ? $style.ncFormBox_row : $style.ncFormBox_col]\">\n\t\t<slot :itemClass=\"$style.ncFormBox__item\" />\n\t</div>\n</template>\n\n<style lang=\"scss\" module>\n.ncFormBox {\n\tdisplay: flex;\n\tflex-direction: column;\n\tgap: calc(1 * var(--default-grid-baseline));\n\n\t&.ncFormBox_row {\n\t\tflex-direction: row;\n\t}\n}\n\n.ncFormBox__item {\n\tborder-radius: var(--border-radius-small) !important;\n}\n\n.ncFormBox_col {\n\tflex-direction: column;\n\n\t.ncFormBox__item {\n\t\t&:first-child {\n\t\t\tborder-start-start-radius: var(--border-radius-element) !important;\n\t\t\tborder-start-end-radius: var(--border-radius-element) !important;\n\t\t}\n\n\t\t&:last-child {\n\t\t\tborder-end-start-radius: var(--border-radius-element) !important;\n\t\t\tborder-end-end-radius: var(--border-radius-element) !important;\n\t\t}\n\t}\n}\n\n.ncFormBox_row {\n\tflex-direction: row;\n\n\t.ncFormBox__item {\n\t\tflex: 1 1;\n\n\t\t&:first-child {\n\t\t\tborder-start-start-radius: var(--border-radius-element) !important;\n\t\t\tborder-end-start-radius: var(--border-radius-element) !important;\n\t\t}\n\n\t\t&:last-child {\n\t\t\tborder-end-end-radius: var(--border-radius-element) !important;\n\t\t\tborder-start-end-radius: var(--border-radius-element) !important;\n\t\t}\n\t}\n}\n</style>\n\n<docs>\n### General\n\nA container of supported components with a small gap and rounded corners forming a solid group.\n\nCurrently supported components:\n- **`<NcFormBoxButton>`**: an action button/link with an optional description specially for the `<NcFormBox>` context\n- **`<NcFormBoxCopyButton>`**: a special case of a button to copy a text to the clipboard\n- **`<NcFormBoxSwitch>`**: a toggle switch replacing `<NcCheckboxRadioSwitch type=\"switch\">` in a box\n- **`<NcButton>`**: a general button in case there is a kind of primary action within a box\n\n**Note**: if the group has a semantic meaning, consider wrapping the `<NcFormBox>` into `<NcFormGroup>` component with a label.\n\n```vue\n<script>\nimport { mdiArrowRight, mdiFolderOpenOutline, mdiPlus } from '@mdi/js'\n\nexport default {\n\tsetup() {\n\t\treturn { mdiArrowRight, mdiFolderOpenOutline, mdiPlus }\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\ttext: 'Text',\n\t\t\tswitchValue: false,\n\t\t}\n\t},\n}\n</script>\n\n<template>\n\t<div style=\"display: flex; flex-direction: column; gap: calc(6 * var(--default-grid-baseline));\">\n\t\t<NcFormBox>\n\t\t\t<NcFormBoxCopyButton label=\"WebDAV URL\" value=\"https://cloud.example.tld/remote.php/dav/files/user\" />\n\t\t</NcFormBox>\n\n\t\t<NcFormGroup label=\"Account settings\">\n\t\t\t<NcFormBox>\n\t\t\t\t<NcFormBoxButton label=\"user@example.com\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<NcIconSvgWrapper :path=\"mdiArrowRight\" inline />\n\t\t\t\t\t</template>\n\t\t\t\t</NcFormBoxButton>\n\t\t\t\t<NcFormBoxButton label=\"sales@example.com\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<NcIconSvgWrapper :path=\"mdiArrowRight\" inline />\n\t\t\t\t\t</template>\n\t\t\t\t</NcFormBoxButton>\n\t\t\t\t<NcButton wide>\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<NcIconSvgWrapper :path=\"mdiPlus\" />\n\t\t\t\t\t</template>\n\t\t\t\t\tAdd mail account\n\t\t\t\t</NcButton>\n\t\t\t</NcFormBox>\n\t\t</NcFormGroup>\n\n\t\t<NcFormGroup label=\"Device settings\">\n\t\t\t<NcFormBox>\n\t\t\t\t<NcFormBoxSwitch v-model=\"switchValue\" label=\"Turn camera and microphone off by default\" />\n\t\t\t\t<NcFormBoxSwitch v-model=\"switchValue\" label=\"Blur camera background by default\" />\n\t\t\t\t<NcFormBoxSwitch\n\t\t\t\t\tv-model=\"switchValue\"\n\t\t\t\t\tlabel=\"Skip device preview before joining a call\"\n\t\t\t\t\tdescription=\"Will always show if recording consent is required\" />\n\t\t\t</NcFormBox>\n\t\t</NcFormGroup>\n\n\t\t<NcFormBox>\n\t\t\t<NcFormBoxButton\n\t\t\t\tlabel=\"Attachments folder\"\n\t\t\t\tdescription=\"/Talk\"\n\t\t\t\tinverted-accent>\n\t\t\t\t<template #icon>\n\t\t\t\t\t<NcIconSvgWrapper :path=\"mdiFolderOpenOutline\" inline />\n\t\t\t\t</template>\n\t\t\t</NcFormBoxButton>\n\t\t</NcFormBox>\n\t</div>\n</template>\n```\n\n### Advanced usage\n\nScoped slot prop `itemClass` can be used to apply the same border radius effect to custom components.\nCreate an issue if you need a composable to inject the class into a custom component.\n\n```vue\n<template>\n\t<NcFormBox v-slot=\"{ itemClass }\">\n\t\t<button class=\"native-button\" :class=\"itemClass\">\n\t\t\tFirst native button\n\t\t</button>\n\t\t<button class=\"native-button\" :class=\"itemClass\">\n\t\t\tSecond native button\n\t\t</button>\n\t\t<button class=\"native-button\" :class=\"itemClass\">\n\t\t\tThird native button\n\t\t</button>\n\t</NcFormBox>\n</template>\n\n<style scoped>\n.native-button {\n\t/* Remove default server margin around a native button */\n\tmargin: 0 !important;\n}\n</style>\n```\n</docs>\n"],"names":["_createElementBlock","_normalizeClass","$style","row","_renderSlot"],"mappings":";;;;;;;;;AA8BA,UAAM,QAAQ,aAAA;AAEd,YAAQ,yBAAyB;AAAA,MAChC,aAAa;AAAA,MACb,kBAAkB,MAAM;AAAA,IAAA,CACxB;;0BAIAA,mBAEM,OAAA;AAAA,QAFA,OAAKC,eAAA,CAAGC,KAAAA,OAAO,WAAWC,KAAAA,MAAMD,KAAAA,OAAO,gBAAgBA,KAAAA,OAAO,aAAa,CAAA;AAAA,MAAA;QAChFE,WAA4C,KAAA,QAAA,WAAA;AAAA,UAArC,WAAWF,KAAAA,OAAO;AAAA,QAAA;;;;;;;;;;;;;;;;;;;;"}
@@ -1,8 +1,8 @@
1
1
  import '../assets/NcFormBoxButton-BWfU7d2r.css';
2
- import { reactive, inject, computed, defineComponent, toRef, createBlock, openBlock, mergeProps, unref, createSlots, withCtx, renderSlot, createTextVNode, toDisplayString, createCommentVNode } from "vue";
2
+ import { reactive, inject, computed, defineComponent, toRef, openBlock, createBlock, mergeProps, unref, createSlots, withCtx, renderSlot, createTextVNode, toDisplayString, createCommentVNode } from "vue";
3
3
  import { s as mdiOpenInNew, t as mdiArrowTopRight } from "./mdi-CpchYUUV.mjs";
4
- import { N as NcFormBoxItem } from "./NcFormBoxItem-BAAPOa6z.mjs";
5
- import { N as NcIconSvgWrapper } from "./NcIconSvgWrapper-BvLanNaW.mjs";
4
+ import { N as NcFormBoxItem } from "./NcFormBoxItem-B7YVodqN.mjs";
5
+ import { N as NcIconSvgWrapper } from "./NcIconSvgWrapper-De-2-ukl.mjs";
6
6
  import { routerKey } from "vue-router";
7
7
  import { _ as _export_sfc } from "./_plugin-vue_export-helper-1tPrXgE0.mjs";
8
8
  /*!
@@ -142,4 +142,4 @@ const NcFormBoxButton = /* @__PURE__ */ _export_sfc(_sfc_main, [["__cssModules",
142
142
  export {
143
143
  NcFormBoxButton as N
144
144
  };
145
- //# sourceMappingURL=NcFormBoxButton-RDIKiZIH.mjs.map
145
+ //# sourceMappingURL=NcFormBoxButton-JvZ6_2E3.mjs.map