@nextcloud/vue 9.0.0-rc.5 → 9.0.0-rc.7

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 (543) hide show
  1. package/CHANGELOG.md +139 -4
  2. package/README.md +5 -4
  3. package/dist/assets/{NcActionButton-Dz2EBAuD.css → NcActionButton-D7bnKlOt.css} +18 -18
  4. package/dist/assets/{NcActionButtonGroup-BLIEEeG3.css → NcActionButtonGroup-CRTH2v24.css} +8 -8
  5. package/dist/assets/{NcActionCheckbox--lTDnNsx.css → NcActionCheckbox-BeT6fCCy.css} +12 -12
  6. package/dist/assets/{NcActionInput-BZCvMPVy.css → NcActionInput-Cma_lx5u.css} +63 -63
  7. package/dist/assets/{NcActionLink-VngQl-C2.css → NcActionLink-DjrAv1MG.css} +13 -13
  8. package/dist/assets/{NcActionRadio-DnAjyubC.css → NcActionRadio-DgdLD238.css} +12 -12
  9. package/dist/assets/{NcActionRouter-CBVOuCQ3.css → NcActionRouter-DeYzeM5W.css} +16 -16
  10. package/dist/assets/{NcActionText-BtzLDZeJ.css → NcActionText-D9InmayH.css} +18 -18
  11. package/dist/assets/{NcActionTextEditable-D5stkJZK.css → NcActionTextEditable-m6K3-kXV.css} +61 -61
  12. package/dist/assets/{NcActions-CG3xO48Y.css → NcActions-9-KEdXq2.css} +13 -13
  13. package/dist/assets/{NcAppContent-vj2DL4Yr.css → NcAppContent-BC1UrvXW.css} +23 -23
  14. package/dist/assets/{NcAppNavigation-C6-8ErA_.css → NcAppNavigation-DzSqLZLH.css} +38 -12
  15. package/dist/assets/{NcAppNavigationCaption-B6mZd0E3.css → NcAppNavigationCaption-HUg9fMCm.css} +7 -7
  16. package/dist/assets/{NcAppNavigationIconBullet-CeBYVy6t.css → NcAppNavigationIconBullet-DLQJkObX.css} +3 -3
  17. package/dist/assets/{NcAppNavigationItem-CFT8K0Dn.css → NcAppNavigationItem-E3wkH_dN.css} +43 -39
  18. package/dist/assets/{NcAppNavigationList-CLLHyHIn.css → NcAppNavigationList--36j6Acm.css} +2 -2
  19. package/dist/assets/{NcAppNavigationNew-Ba3wWpcY.css → NcAppNavigationNew-Bn8zj5lM.css} +3 -3
  20. package/dist/assets/{NcAppNavigationNewItem-CCu1yQxq.css → NcAppNavigationNewItem-Dmdd1YSE.css} +39 -33
  21. package/dist/assets/{NcAppNavigationSearch-Ct6uMFNo.css → NcAppNavigationSearch-CQamlS4X.css} +5 -5
  22. package/dist/assets/{NcAppNavigationSettings-B0I7HR1V.css → NcAppNavigationSettings-Bt0dnsjR.css} +7 -8
  23. package/dist/assets/{NcAppSettingsDialog-BtS89pIY.css → NcAppSettingsDialog-CW1IxPWr.css} +10 -10
  24. package/dist/assets/{NcAppSettingsSection-DnDcGk1v.css → NcAppSettingsSection-C4JF60e-.css} +3 -3
  25. package/dist/assets/{NcAppSidebar-DlLDB8Ba.css → NcAppSidebar-DUiFE7vz.css} +58 -58
  26. package/dist/assets/{NcAppSidebarTab-cWhpTGp7.css → NcAppSidebarTab-Xd3HTDbw.css} +4 -4
  27. package/dist/assets/NcAvatar-DhTOlvlb.css +134 -0
  28. package/dist/assets/{NcBreadcrumb-CV3DgRKn.css → NcBreadcrumb-CHjeSh0y.css} +15 -15
  29. package/dist/assets/{NcBreadcrumbs-D2wff82k.css → NcBreadcrumbs-DYfGaSjT.css} +6 -6
  30. package/dist/assets/{NcButton-Cl53rV4b.css → NcButton-BjcEkfk2.css} +77 -64
  31. package/dist/assets/{NcCheckboxRadioSwitch-Cbnc4p0H.css → NcCheckboxRadioSwitch-CJW-RB5j.css} +54 -44
  32. package/dist/assets/{NcChip-1ZmWY_6e.css → NcChip-Cjdo3xPB.css} +9 -9
  33. package/dist/assets/{NcCollectionList-C7_FPg95.css → NcCollectionList-D9dOsdP2.css} +42 -42
  34. package/dist/assets/{NcColorPicker-DlQH2IqY.css → NcColorPicker-BUxqqYfq.css} +28 -28
  35. package/dist/assets/{NcContent-D1ab_Xg2.css → NcContent-CVIwhwfc.css} +12 -9
  36. package/dist/assets/{NcCounterBubble-C0CtLaMW.css → NcCounterBubble-ZnteskDR.css} +7 -7
  37. package/dist/assets/{NcDashboardWidget-CTP_ajin.css → NcDashboardWidget-DD06i7ws.css} +12 -12
  38. package/dist/assets/{NcDashboardWidgetItem-DYwI3Qof.css → NcDashboardWidgetItem-DPVZ3Oso.css} +12 -12
  39. package/dist/assets/{NcDateTimePicker-D10v2GzZ.css → NcDateTimePicker-D0VMSpM3.css} +236 -233
  40. package/dist/assets/{NcDateTimePickerNative-B7hWPWho.css → NcDateTimePickerNative-BP6eg8aU.css} +13 -13
  41. package/dist/assets/{NcDialog-B9626mow.css → NcDialog-GKchMDSB.css} +15 -15
  42. package/dist/assets/{NcEllipsisedOption-BNLv_eyF.css → NcEllipsisedOption-CPWbbgBy.css} +5 -5
  43. package/dist/assets/NcEmojiPicker-BO_GV-CM.css +547 -0
  44. package/dist/assets/{NcGuestContent-bgqNfxTA.css → NcGuestContent-j8ai4O1K.css} +2 -2
  45. package/dist/assets/{NcHeaderButton-Ct8k0yDh.css → NcHeaderButton-CVOQgRjm.css} +11 -7
  46. package/dist/assets/{NcHeaderMenu-CP5Nn6tY.css → NcHeaderMenu-BkGG39vE.css} +15 -11
  47. package/dist/assets/{NcIconSvgWrapper-CJfAwN6-.css → NcIconSvgWrapper-D6qXQDNo.css} +10 -10
  48. package/dist/assets/{NcInputConfirmCancel-DNNS3DDJ.css → NcInputConfirmCancel-BrdZEfr2.css} +5 -5
  49. package/dist/assets/{NcInputField-BeU51nfg.css → NcInputField-CVSrajMb.css} +68 -47
  50. package/dist/assets/NcListItem-BRTO5Id3.css +177 -0
  51. package/dist/assets/{NcListItemIcon-BVhiRo5R.css → NcListItemIcon-OOjV0jWx.css} +13 -13
  52. package/dist/assets/{NcLoadingIcon-DlDKflKI.css → NcLoadingIcon-CWUlo4XY.css} +5 -2
  53. package/dist/assets/{NcMentionBubble-lpms2_3A.css → NcMentionBubble-ptHUq68a.css} +9 -9
  54. package/dist/assets/{NcModal-eBU7G0XQ.css → NcModal-ok4bUsLE.css} +61 -61
  55. package/dist/assets/{NcNoteCard-BTnxwjLX.css → NcNoteCard-l5nIN9Hg.css} +21 -17
  56. package/dist/assets/{NcPasswordField-CWRwNMKF.css → NcPasswordField-CAKOUN91.css} +2 -2
  57. package/dist/assets/{NcPopover-BzkXE_af.css → NcPopover-CZ3pMU6Y.css} +16 -16
  58. package/dist/assets/{NcProgressBar--z-WqmX4.css → NcProgressBar-BAPOXMAL.css} +16 -15
  59. package/dist/assets/{NcRelatedResourcesPanel-9I4RRIks.css → NcRelatedResourcesPanel-BVdRCi64.css} +65 -65
  60. package/dist/assets/{NcRichContenteditable-Dj22Kx6E.css → NcRichContenteditable-zvOx7ivB.css} +21 -21
  61. package/dist/assets/{NcRichText-Fp8zf8zq.css → NcRichText-DujetYXl.css} +88 -88
  62. package/dist/assets/NcSelectUsers-BWhtNRbI.css +4 -0
  63. package/dist/assets/{NcSettingsInputText-B2b1M_wK.css → NcSettingsInputText-Dj_6fuUU.css} +5 -5
  64. package/dist/assets/{NcSettingsSection-CxQtVrUq.css → NcSettingsSection-f5rBJsKJ.css} +7 -7
  65. package/dist/assets/{NcSettingsSelectGroup-BuKKmCtO.css → NcSettingsSelectGroup-BxvEAWNm.css} +3 -3
  66. package/dist/assets/NcTextArea-D7H1UNAd.css +136 -0
  67. package/dist/assets/{NcUserBubble-CqaL0Oxv.css → NcUserBubble-ChgvvPPf.css} +8 -8
  68. package/dist/assets/{NcUserStatusIcon-BcLND4gJ.css → NcUserStatusIcon-D8HqS9GC.css} +11 -7
  69. package/dist/assets/{referencePickerModal-D80hwmre.css → referencePickerModal-B9tq1n_R.css} +60 -77
  70. package/dist/chunks/ArrowRight-DRKHUZMH.mjs.map +1 -1
  71. package/dist/chunks/ChevronDown-FiGpp0KT.mjs.map +1 -1
  72. package/dist/chunks/ChevronUp-DPXFp1ss.mjs.map +1 -1
  73. package/dist/chunks/Close-D6ngJ4t9.mjs.map +1 -1
  74. package/dist/chunks/{NcActionButton-Bd35_0n4.mjs → NcActionButton-DseKq57Q.mjs} +8 -7
  75. package/dist/chunks/NcActionButton-DseKq57Q.mjs.map +1 -0
  76. package/dist/chunks/{NcActionButtonGroup-zqttoOi7.mjs → NcActionButtonGroup-eJGS5If0.mjs} +4 -4
  77. package/dist/chunks/{NcActionButtonGroup-zqttoOi7.mjs.map → NcActionButtonGroup-eJGS5If0.mjs.map} +1 -1
  78. package/dist/chunks/NcActionCaption-Fumfjzxj.mjs.map +1 -1
  79. package/dist/chunks/{NcActionCheckbox-DLPDTACR.mjs → NcActionCheckbox-CwrO3g3I.mjs} +3 -3
  80. package/dist/chunks/NcActionCheckbox-CwrO3g3I.mjs.map +1 -0
  81. package/dist/chunks/{NcActionInput-uNqbQcU9.mjs → NcActionInput-Cby01w-7.mjs} +22 -24
  82. package/dist/chunks/NcActionInput-Cby01w-7.mjs.map +1 -0
  83. package/dist/chunks/{NcActionLink-BEo7zmXX.mjs → NcActionLink-afakPM_N.mjs} +8 -9
  84. package/dist/chunks/NcActionLink-afakPM_N.mjs.map +1 -0
  85. package/dist/chunks/{NcActionRadio-CPoWB58D.mjs → NcActionRadio-ByCpOD0q.mjs} +5 -5
  86. package/dist/chunks/NcActionRadio-ByCpOD0q.mjs.map +1 -0
  87. package/dist/chunks/{NcActionRouter-ERoQjJKv.mjs → NcActionRouter-oT-YU_jf.mjs} +10 -11
  88. package/dist/chunks/NcActionRouter-oT-YU_jf.mjs.map +1 -0
  89. package/dist/chunks/{NcActionText-16Mj4-P1.mjs → NcActionText-uKvLcEY6.mjs} +5 -5
  90. package/dist/chunks/NcActionText-uKvLcEY6.mjs.map +1 -0
  91. package/dist/chunks/{NcActionTextEditable-rS1GklQ7.mjs → NcActionTextEditable-CoAscywz.mjs} +7 -7
  92. package/dist/chunks/NcActionTextEditable-CoAscywz.mjs.map +1 -0
  93. package/dist/chunks/{NcActions-CyXKvnrY.mjs → NcActions-BOqfKgN5.mjs} +69 -21
  94. package/dist/chunks/NcActions-BOqfKgN5.mjs.map +1 -0
  95. package/dist/chunks/{NcAppContent-BK8bOVDx.mjs → NcAppContent-CBiklfOg.mjs} +11 -11
  96. package/dist/chunks/NcAppContent-CBiklfOg.mjs.map +1 -0
  97. package/dist/chunks/NcAppContentDetails.vue_vue_type_script_setup_true_lang-Dnf4r_Ng.mjs.map +1 -1
  98. package/dist/chunks/{NcAppContentList-DnLY_sWw.mjs → NcAppContentList-DYFsuDKh.mjs} +7 -1
  99. package/dist/chunks/NcAppContentList-DYFsuDKh.mjs.map +1 -0
  100. package/dist/chunks/NcAppNavigation-VmhZBTF5.mjs +174 -0
  101. package/dist/chunks/NcAppNavigation-VmhZBTF5.mjs.map +1 -0
  102. package/dist/chunks/{NcAppNavigationCaption-DxfUoJBO.mjs → NcAppNavigationCaption-zs07YHtS.mjs} +7 -5
  103. package/dist/chunks/NcAppNavigationCaption-zs07YHtS.mjs.map +1 -0
  104. package/dist/chunks/{NcAppNavigationIconBullet-B1kc4u65.mjs → NcAppNavigationIconBullet-PrlhOoE9.mjs} +6 -3
  105. package/dist/chunks/NcAppNavigationIconBullet-PrlhOoE9.mjs.map +1 -0
  106. package/dist/chunks/{NcAppNavigationItem-CSiMEh0V.mjs → NcAppNavigationItem-DpimA76Q.mjs} +43 -26
  107. package/dist/chunks/NcAppNavigationItem-DpimA76Q.mjs.map +1 -0
  108. package/dist/chunks/{NcAppNavigationList-DX_Yo23V.mjs → NcAppNavigationList-BX0wE-dB.mjs} +3 -3
  109. package/dist/chunks/{NcAppNavigationList-DX_Yo23V.mjs.map → NcAppNavigationList-BX0wE-dB.mjs.map} +1 -1
  110. package/dist/chunks/{NcAppNavigationNew-CLbVKk5X.mjs → NcAppNavigationNew-Y50s6jTC.mjs} +14 -4
  111. package/dist/chunks/NcAppNavigationNew-Y50s6jTC.mjs.map +1 -0
  112. package/dist/chunks/{NcAppNavigationNewItem-B4TH71qQ.mjs → NcAppNavigationNewItem-CkWp0oFr.mjs} +8 -8
  113. package/dist/chunks/NcAppNavigationNewItem-CkWp0oFr.mjs.map +1 -0
  114. package/dist/chunks/{NcAppNavigationSearch-BOZ5dS_m.mjs → NcAppNavigationSearch-Cs14jpSe.mjs} +8 -9
  115. package/dist/chunks/NcAppNavigationSearch-Cs14jpSe.mjs.map +1 -0
  116. package/dist/chunks/NcAppNavigationSettings-D_u5pIPX.mjs +98 -0
  117. package/dist/chunks/NcAppNavigationSettings-D_u5pIPX.mjs.map +1 -0
  118. package/dist/chunks/NcAppNavigationSpacer-BvkBfuVw.mjs.map +1 -1
  119. package/dist/chunks/{NcAppSettingsDialog-B4rJQ7w_.mjs → NcAppSettingsDialog-Dy2SrGfl.mjs} +15 -9
  120. package/dist/chunks/NcAppSettingsDialog-Dy2SrGfl.mjs.map +1 -0
  121. package/dist/chunks/{NcAppSettingsSection-CssmXyZ0.mjs → NcAppSettingsSection-tccU68DQ.mjs} +9 -3
  122. package/dist/chunks/NcAppSettingsSection-tccU68DQ.mjs.map +1 -0
  123. package/dist/chunks/{NcAppSidebar-D0azvKne.mjs → NcAppSidebar-BNTlPC1G.mjs} +41 -27
  124. package/dist/chunks/NcAppSidebar-BNTlPC1G.mjs.map +1 -0
  125. package/dist/chunks/NcAppSidebarHeader.vue_vue_type_script_setup_true_lang-0j0aFDeK.mjs.map +1 -1
  126. package/dist/chunks/{NcAppSidebarTab-D1RmFRTu.mjs → NcAppSidebarTab-Cjetm3Fs.mjs} +9 -6
  127. package/dist/chunks/NcAppSidebarTab-Cjetm3Fs.mjs.map +1 -0
  128. package/dist/chunks/{NcAvatar-Ccw1N-kB.mjs → NcAvatar-42dhVtul.mjs} +40 -48
  129. package/dist/chunks/NcAvatar-42dhVtul.mjs.map +1 -0
  130. package/dist/chunks/NcBlurHash-BiFktE2N.mjs.map +1 -1
  131. package/dist/chunks/{NcBreadcrumb-C9ma2_SJ.mjs → NcBreadcrumb-C86Yxww0.mjs} +28 -24
  132. package/dist/chunks/NcBreadcrumb-C86Yxww0.mjs.map +1 -0
  133. package/dist/chunks/{NcBreadcrumbs-kg_aktAn.mjs → NcBreadcrumbs-BTFyDGO2.mjs} +43 -40
  134. package/dist/chunks/NcBreadcrumbs-BTFyDGO2.mjs.map +1 -0
  135. package/dist/chunks/{NcButton-Df1eAyJ3.mjs → NcButton-DkC5k3Lb.mjs} +48 -30
  136. package/dist/chunks/NcButton-DkC5k3Lb.mjs.map +1 -0
  137. package/dist/chunks/{NcCheckboxRadioSwitch-D8tOjXwB.mjs → NcCheckboxRadioSwitch-iCknuL0_.mjs} +136 -82
  138. package/dist/chunks/NcCheckboxRadioSwitch-iCknuL0_.mjs.map +1 -0
  139. package/dist/chunks/{NcChip-Bf2JVPf_.mjs → NcChip-Dplke0gD.mjs} +8 -8
  140. package/dist/chunks/NcChip-Dplke0gD.mjs.map +1 -0
  141. package/dist/chunks/{NcCollectionList-DtD-RXl8.mjs → NcCollectionList-IC-VyCa-.mjs} +25 -21
  142. package/dist/chunks/NcCollectionList-IC-VyCa-.mjs.map +1 -0
  143. package/dist/chunks/{NcColorPicker-BRIu0Qel.mjs → NcColorPicker-BPd1i3-9.mjs} +38 -26
  144. package/dist/chunks/NcColorPicker-BPd1i3-9.mjs.map +1 -0
  145. package/dist/chunks/{NcContent-BmXFlXrh.mjs → NcContent-BAiLhI_2.mjs} +9 -8
  146. package/dist/chunks/{NcContent-BmXFlXrh.mjs.map → NcContent-BAiLhI_2.mjs.map} +1 -1
  147. package/dist/chunks/{NcCounterBubble-Bop3e-Tr.mjs → NcCounterBubble-CxxHHh8i.mjs} +3 -3
  148. package/dist/chunks/{NcCounterBubble-Bop3e-Tr.mjs.map → NcCounterBubble-CxxHHh8i.mjs.map} +1 -1
  149. package/dist/chunks/{NcDashboardWidget-cBZ_Ub8Q.mjs → NcDashboardWidget-P6DhIXT2.mjs} +52 -10
  150. package/dist/chunks/NcDashboardWidget-P6DhIXT2.mjs.map +1 -0
  151. package/dist/chunks/{NcDashboardWidgetItem-BnUtMMCC.mjs → NcDashboardWidgetItem-GGmhjTfk.mjs} +7 -7
  152. package/dist/chunks/NcDashboardWidgetItem-GGmhjTfk.mjs.map +1 -0
  153. package/dist/chunks/NcDateTime.vue_vue_type_script_setup_true_lang-B0Lci6v0.mjs.map +1 -1
  154. package/dist/chunks/{NcDateTimePicker-Dliaj0xD.mjs → NcDateTimePicker-DmeWERxv.mjs} +35 -27
  155. package/dist/chunks/NcDateTimePicker-DmeWERxv.mjs.map +1 -0
  156. package/dist/chunks/{NcDateTimePickerNative-CEm70Aaw.mjs → NcDateTimePickerNative-BiU3SIRj.mjs} +5 -5
  157. package/dist/chunks/NcDateTimePickerNative-BiU3SIRj.mjs.map +1 -0
  158. package/dist/chunks/{NcDialog-B_4Lud9m.mjs → NcDialog-DmKbeOcJ.mjs} +21 -23
  159. package/dist/chunks/NcDialog-DmKbeOcJ.mjs.map +1 -0
  160. package/dist/chunks/{NcDialogButton.vue_vue_type_script_setup_true_lang-d1zLHPqM.mjs → NcDialogButton.vue_vue_type_script_setup_true_lang-BvBSeEuo.mjs} +6 -6
  161. package/dist/chunks/NcDialogButton.vue_vue_type_script_setup_true_lang-BvBSeEuo.mjs.map +1 -0
  162. package/dist/chunks/{NcEllipsisedOption-C8uNDC-j.mjs → NcEllipsisedOption-dT-CtXYp.mjs} +3 -3
  163. package/dist/chunks/NcEllipsisedOption-dT-CtXYp.mjs.map +1 -0
  164. package/dist/chunks/{NcEmojiPicker-DZXHV_Me.mjs → NcEmojiPicker-VUnUOWfg.mjs} +127 -121
  165. package/dist/chunks/NcEmojiPicker-VUnUOWfg.mjs.map +1 -0
  166. package/dist/chunks/NcEmptyContent-BdOezubv.mjs.map +1 -1
  167. package/dist/chunks/{NcGuestContent-mLXi-A-D.mjs → NcGuestContent-CfCh49o0.mjs} +3 -3
  168. package/dist/chunks/NcGuestContent-CfCh49o0.mjs.map +1 -0
  169. package/dist/chunks/{NcHeaderButton-D6LMZ6iL.mjs → NcHeaderButton-DafXYbXB.mjs} +4 -4
  170. package/dist/chunks/NcHeaderButton-DafXYbXB.mjs.map +1 -0
  171. package/dist/chunks/{NcHeaderMenu-O0loxc_q.mjs → NcHeaderMenu-fnBUbMrU.mjs} +25 -24
  172. package/dist/chunks/NcHeaderMenu-fnBUbMrU.mjs.map +1 -0
  173. package/dist/chunks/NcHighlight.vue_vue_type_script_lang-DnWQDM_2.mjs.map +1 -1
  174. package/dist/chunks/{NcIconSvgWrapper-CprKb_SE.mjs → NcIconSvgWrapper-5AA93z-F.mjs} +4 -4
  175. package/dist/chunks/{NcIconSvgWrapper-CprKb_SE.mjs.map → NcIconSvgWrapper-5AA93z-F.mjs.map} +1 -1
  176. package/dist/chunks/{NcInputConfirmCancel-RRwim02d.mjs → NcInputConfirmCancel-DC6lvX7Z.mjs} +11 -5
  177. package/dist/chunks/NcInputConfirmCancel-DC6lvX7Z.mjs.map +1 -0
  178. package/dist/chunks/{NcInputField-DEHb834Z.mjs → NcInputField-DugqxUR2.mjs} +17 -15
  179. package/dist/chunks/NcInputField-DugqxUR2.mjs.map +1 -0
  180. package/dist/chunks/{NcListItem-C6WoTIa4.mjs → NcListItem-C2YXq4EL.mjs} +8 -13
  181. package/dist/chunks/NcListItem-C2YXq4EL.mjs.map +1 -0
  182. package/dist/chunks/{NcListItemIcon-5OKjuvJE.mjs → NcListItemIcon-Du1PyhkH.mjs} +11 -10
  183. package/dist/chunks/NcListItemIcon-Du1PyhkH.mjs.map +1 -0
  184. package/dist/chunks/{NcLoadingIcon-Dm3kRPrf.mjs → NcLoadingIcon-b_ajZ_nQ.mjs} +3 -3
  185. package/dist/chunks/NcLoadingIcon-b_ajZ_nQ.mjs.map +1 -0
  186. package/dist/chunks/{NcMentionBubble.vue_vue_type_style_index_0_scoped_25f4d6e1_lang-aMwzB20D.mjs → NcMentionBubble.vue_vue_type_style_index_0_scoped_45238efd_lang-D6LzDiYf.mjs} +2 -2
  187. package/dist/chunks/NcMentionBubble.vue_vue_type_style_index_0_scoped_45238efd_lang-D6LzDiYf.mjs.map +1 -0
  188. package/dist/chunks/{NcModal-n7KHhtoD.mjs → NcModal-Jb_FjSoh.mjs} +60 -57
  189. package/dist/chunks/NcModal-Jb_FjSoh.mjs.map +1 -0
  190. package/dist/chunks/{NcNoteCard-B5CvOJmh.mjs → NcNoteCard-BBnJMdJu.mjs} +11 -7
  191. package/dist/chunks/NcNoteCard-BBnJMdJu.mjs.map +1 -0
  192. package/dist/chunks/{NcPasswordField-JRyxT6wU.mjs → NcPasswordField-F-JcomYe.mjs} +11 -12
  193. package/dist/chunks/NcPasswordField-F-JcomYe.mjs.map +1 -0
  194. package/dist/chunks/{NcPopover-DLoAYZgv.mjs → NcPopover-D8iSVK-p.mjs} +41 -13
  195. package/dist/chunks/NcPopover-D8iSVK-p.mjs.map +1 -0
  196. package/dist/chunks/NcProgressBar-DDMAo4h-.mjs +94 -0
  197. package/dist/chunks/NcProgressBar-DDMAo4h-.mjs.map +1 -0
  198. package/dist/chunks/{NcRelatedResourcesPanel-BBcAt5Fj.mjs → NcRelatedResourcesPanel-BpH5XQ76.mjs} +104 -100
  199. package/dist/chunks/NcRelatedResourcesPanel-BpH5XQ76.mjs.map +1 -0
  200. package/dist/chunks/{NcRichContenteditable-BD6rWjXe.mjs → NcRichContenteditable-CknkQPrW.mjs} +81 -32
  201. package/dist/chunks/NcRichContenteditable-CknkQPrW.mjs.map +1 -0
  202. package/dist/chunks/{NcRichText-BwC3HU1U.mjs → NcRichText-4S-Bcw6_.mjs} +414 -388
  203. package/dist/chunks/NcRichText-4S-Bcw6_.mjs.map +1 -0
  204. package/dist/chunks/{NcSavingIndicatorIcon.vue_vue_type_script_setup_true_lang-DlRBo3QU.mjs → NcSavingIndicatorIcon.vue_vue_type_script_setup_true_lang-jUf1K561.mjs} +2 -2
  205. package/dist/chunks/{NcSavingIndicatorIcon.vue_vue_type_script_setup_true_lang-DlRBo3QU.mjs.map → NcSavingIndicatorIcon.vue_vue_type_script_setup_true_lang-jUf1K561.mjs.map} +1 -1
  206. package/dist/chunks/{NcSelect-DlAtugnK.mjs → NcSelect-CqmU4nl3.mjs} +10 -11
  207. package/dist/chunks/NcSelect-CqmU4nl3.mjs.map +1 -0
  208. package/dist/chunks/{NcSelectTags-N96Vc2rX.mjs → NcSelectTags-CcsDvt0V.mjs} +17 -16
  209. package/dist/chunks/NcSelectTags-CcsDvt0V.mjs.map +1 -0
  210. package/dist/chunks/{NcSelectUsers-BEoD3M8_.mjs → NcSelectUsers-BLzx7FTX.mjs} +5 -5
  211. package/dist/chunks/NcSelectUsers-BLzx7FTX.mjs.map +1 -0
  212. package/dist/chunks/{NcSettingsInputText-Dh5pxW31.mjs → NcSettingsInputText-BmOtUODF.mjs} +4 -4
  213. package/dist/chunks/NcSettingsInputText-BmOtUODF.mjs.map +1 -0
  214. package/dist/chunks/{NcSettingsSection-DOYZpyIW.mjs → NcSettingsSection-B1XS0NQu.mjs} +4 -4
  215. package/dist/chunks/{NcSettingsSection-DOYZpyIW.mjs.map → NcSettingsSection-B1XS0NQu.mjs.map} +1 -1
  216. package/dist/chunks/{NcSettingsSelectGroup-CUvIP57B.mjs → NcSettingsSelectGroup-BmtDlJ3e.mjs} +15 -17
  217. package/dist/chunks/NcSettingsSelectGroup-BmtDlJ3e.mjs.map +1 -0
  218. package/dist/chunks/{NcTextArea-BTKWGbc1.mjs → NcTextArea-CLM4W-yg.mjs} +19 -10
  219. package/dist/chunks/NcTextArea-CLM4W-yg.mjs.map +1 -0
  220. package/dist/chunks/{NcTextField.vue_vue_type_script_setup_true_lang-DM5tkqJq.mjs → NcTextField.vue_vue_type_script_setup_true_lang-BN-Pgz4E.mjs} +9 -12
  221. package/dist/chunks/NcTextField.vue_vue_type_script_setup_true_lang-BN-Pgz4E.mjs.map +1 -0
  222. package/dist/chunks/NcThemeProvider.vue_vue_type_script_setup_true_lang-nUDJsDGI.mjs.map +1 -1
  223. package/dist/chunks/{NcTimezonePicker.vue_vue_type_script_setup_true_lang-CZ5IafBy.mjs → NcTimezonePicker.vue_vue_type_script_setup_true_lang-CERjSiE5.mjs} +4 -4
  224. package/dist/chunks/NcTimezonePicker.vue_vue_type_script_setup_true_lang-CERjSiE5.mjs.map +1 -0
  225. package/dist/chunks/{NcUserBubble-DpGJJxHd.mjs → NcUserBubble-CxGixaPY.mjs} +9 -9
  226. package/dist/chunks/NcUserBubble-CxGixaPY.mjs.map +1 -0
  227. package/dist/chunks/{NcUserStatusIcon-DJ_IKC46.mjs → NcUserStatusIcon-BUBFkE3m.mjs} +15 -14
  228. package/dist/chunks/NcUserStatusIcon-BUBFkE3m.mjs.map +1 -0
  229. package/dist/chunks/NcVNodes.vue_vue_type_script_lang-BqUHinRZ.mjs.map +1 -1
  230. package/dist/chunks/_l10n-CiWgAjJZ.mjs +111 -0
  231. package/dist/chunks/_l10n-CiWgAjJZ.mjs.map +1 -0
  232. package/dist/chunks/actionGlobal-BZFdtdJL.mjs.map +1 -1
  233. package/dist/chunks/{actionText-DdSwf9le.mjs → actionText-DYzDdbVe.mjs} +5 -4
  234. package/dist/chunks/{actionText-DdSwf9le.mjs.map → actionText-DYzDdbVe.mjs.map} +1 -1
  235. package/dist/chunks/{autolink-Y0rlJ_CI.mjs → autolink-U5pBzLgI.mjs} +9 -8
  236. package/dist/chunks/autolink-U5pBzLgI.mjs.map +1 -0
  237. package/dist/chunks/{colors-Bws_qBuw.mjs → colors-C_np5wf3.mjs} +10 -3
  238. package/dist/chunks/colors-C_np5wf3.mjs.map +1 -0
  239. package/dist/chunks/constants-Bls5liKo.mjs.map +1 -1
  240. package/dist/chunks/constants-DrSznhwy.mjs +11 -0
  241. package/dist/chunks/constants-DrSznhwy.mjs.map +1 -0
  242. package/dist/chunks/createElementId-DhjFt1I9.mjs.map +1 -1
  243. package/dist/chunks/{customPickerElements-CH9vlHLd.mjs → customPickerElements-4pQTZUnk.mjs} +7 -7
  244. package/dist/chunks/customPickerElements-4pQTZUnk.mjs.map +1 -0
  245. package/dist/chunks/emoji-BY_D0V5K.mjs.map +1 -1
  246. package/dist/chunks/{focusTrap-DmkaYJTC.mjs → focusTrap-HJQ4pqHV.mjs} +6 -3
  247. package/dist/chunks/focusTrap-HJQ4pqHV.mjs.map +1 -0
  248. package/dist/chunks/legacy-DcjXBL_t.mjs +6 -0
  249. package/dist/chunks/legacy-DcjXBL_t.mjs.map +1 -0
  250. package/dist/chunks/logger-D3RVzcfQ.mjs.map +1 -1
  251. package/dist/chunks/mdi-DXaZM2k3.mjs +49 -0
  252. package/dist/chunks/{mdi-D6fu5i4r.mjs.map → mdi-DXaZM2k3.mjs.map} +1 -1
  253. package/dist/chunks/{referencePickerModal-BA3NmGQ-.mjs → referencePickerModal-tSRu6940.mjs} +129 -82
  254. package/dist/chunks/referencePickerModal-tSRu6940.mjs.map +1 -0
  255. package/dist/chunks/rtl-v0UOPAM7.mjs.map +1 -1
  256. package/dist/chunks/useNcActions-CiGWxAJE.mjs.map +1 -1
  257. package/dist/chunks/{useTrapStackControl-b3A_383w.mjs → useTrapStackControl-B6cEicto.mjs} +3 -4
  258. package/dist/chunks/useTrapStackControl-B6cEicto.mjs.map +1 -0
  259. package/dist/components/NcActionButton/NcActionButton.vue.d.ts +2 -1
  260. package/dist/components/NcActionButton/index.mjs +1 -1
  261. package/dist/components/NcActionButtonGroup/index.mjs +1 -1
  262. package/dist/components/NcActionCheckbox/index.mjs +1 -1
  263. package/dist/components/NcActionInput/NcActionInput.vue.d.ts +1934 -0
  264. package/dist/components/NcActionInput/index.mjs +1 -1
  265. package/dist/components/NcActionLink/index.mjs +1 -1
  266. package/dist/components/NcActionRadio/index.mjs +1 -1
  267. package/dist/components/NcActionRouter/NcActionRouter.vue.d.ts +1 -5
  268. package/dist/components/NcActionRouter/index.mjs +1 -1
  269. package/dist/components/NcActionText/index.mjs +1 -1
  270. package/dist/components/NcActionTextEditable/index.mjs +1 -1
  271. package/dist/components/NcActions/NcActions.vue.d.ts +504 -0
  272. package/dist/components/NcActions/index.mjs +1 -1
  273. package/dist/components/NcActions/useNcActions.d.ts +1 -1
  274. package/dist/components/NcAppContent/index.mjs +1 -1
  275. package/dist/components/NcAppContentList/NcAppContentList.vue.d.ts +12 -0
  276. package/dist/components/NcAppContentList/index.mjs +1 -1
  277. package/dist/components/NcAppNavigation/NcAppNavigation.vue.d.ts +59 -57
  278. package/dist/components/NcAppNavigation/index.d.ts +4 -0
  279. package/dist/components/NcAppNavigation/index.mjs +1 -1
  280. package/dist/components/NcAppNavigationCaption/NcAppNavigationCaption.vue.d.ts +347 -0
  281. package/dist/components/NcAppNavigationCaption/index.mjs +1 -1
  282. package/dist/components/NcAppNavigationIconBullet/NcAppNavigationIconBullet.vue.d.ts +6 -0
  283. package/dist/components/NcAppNavigationIconBullet/index.mjs +1 -1
  284. package/dist/components/NcAppNavigationItem/NcAppNavigationIconCollapsible.vue.d.ts +155 -0
  285. package/dist/components/NcAppNavigationItem/NcAppNavigationItem.vue.d.ts +1233 -0
  286. package/dist/components/NcAppNavigationItem/NcInputConfirmCancel.vue.d.ts +183 -0
  287. package/dist/components/NcAppNavigationItem/index.mjs +1 -1
  288. package/dist/components/NcAppNavigationList/index.d.ts +4 -0
  289. package/dist/components/NcAppNavigationList/index.mjs +1 -1
  290. package/dist/components/NcAppNavigationNew/NcAppNavigationNew.vue.d.ts +191 -0
  291. package/dist/components/NcAppNavigationNew/index.mjs +1 -1
  292. package/dist/components/NcAppNavigationNewItem/NcAppNavigationNewItem.vue.d.ts +270 -0
  293. package/dist/components/NcAppNavigationNewItem/index.mjs +1 -1
  294. package/dist/components/NcAppNavigationSearch/NcAppNavigationSearch.vue.d.ts +14 -14
  295. package/dist/components/NcAppNavigationSearch/index.mjs +1 -1
  296. package/dist/components/NcAppNavigationSettings/NcAppNavigationSettings.vue.d.ts +1 -0
  297. package/dist/components/NcAppNavigationSettings/index.mjs +1 -1
  298. package/dist/components/NcAppSettingsDialog/NcAppSettingsDialog.vue.d.ts +351 -0
  299. package/dist/components/NcAppSettingsDialog/index.mjs +1 -1
  300. package/dist/components/NcAppSettingsSection/NcAppSettingsSection.vue.d.ts +12 -0
  301. package/dist/components/NcAppSettingsSection/index.mjs +1 -1
  302. package/dist/components/NcAppSidebar/NcAppSidebar.vue.d.ts +1011 -0
  303. package/dist/components/NcAppSidebar/index.mjs +1 -1
  304. package/dist/components/NcAppSidebarTab/NcAppSidebarTab.vue.d.ts +6 -0
  305. package/dist/components/NcAppSidebarTab/index.mjs +1 -1
  306. package/dist/components/NcAvatar/NcAvatar.vue.d.ts +977 -0
  307. package/dist/components/NcAvatar/index.mjs +1 -1
  308. package/dist/components/NcBreadcrumb/NcBreadcrumb.vue.d.ts +658 -0
  309. package/dist/components/NcBreadcrumb/index.mjs +1 -1
  310. package/dist/components/NcBreadcrumbs/NcBreadcrumbs.vue.d.ts +1251 -0
  311. package/dist/components/NcBreadcrumbs/index.mjs +1 -1
  312. package/dist/components/NcButton/NcButton.vue.d.ts +15 -10
  313. package/dist/components/NcButton/index.mjs +1 -1
  314. package/dist/components/NcCheckboxRadioSwitch/index.mjs +1 -1
  315. package/dist/components/NcChip/NcChip.vue.d.ts +2 -0
  316. package/dist/components/NcChip/index.mjs +1 -1
  317. package/dist/components/NcCollectionList/NcCollectionList.vue.d.ts +2412 -0
  318. package/dist/components/NcCollectionList/NcCollectionListItem.vue.d.ts +1374 -0
  319. package/dist/components/NcCollectionList/index.mjs +1 -1
  320. package/dist/components/NcCollectionList/service.d.ts +7 -0
  321. package/dist/components/NcCollectionList/useCollections.d.ts +1 -5
  322. package/dist/components/NcColorPicker/NcColorPicker.vue.d.ts +5 -2
  323. package/dist/components/NcColorPicker/index.mjs +1 -1
  324. package/dist/components/NcContent/constants.d.ts +9 -0
  325. package/dist/components/NcContent/index.mjs +1 -1
  326. package/dist/components/NcCounterBubble/index.mjs +1 -1
  327. package/dist/components/NcDashboardWidget/NcDashboardWidget.vue.d.ts +2438 -0
  328. package/dist/components/NcDashboardWidget/index.mjs +1 -1
  329. package/dist/components/NcDashboardWidgetItem/NcDashboardWidgetItem.vue.d.ts +1482 -0
  330. package/dist/components/NcDashboardWidgetItem/index.mjs +1 -1
  331. package/dist/components/NcDateTimePicker/NcDateTimePicker.vue.d.ts +6 -4
  332. package/dist/components/NcDateTimePicker/index.mjs +1 -1
  333. package/dist/components/NcDateTimePickerNative/index.mjs +1 -1
  334. package/dist/components/NcDialog/NcDialog.vue.d.ts +6 -5
  335. package/dist/components/NcDialog/index.mjs +1 -1
  336. package/dist/components/NcDialogButton/index.mjs +1 -1
  337. package/dist/components/NcEllipsisedOption/NcEllipsisedOption.vue.d.ts +95 -0
  338. package/dist/components/NcEllipsisedOption/index.mjs +1 -1
  339. package/dist/components/NcEmojiPicker/NcEmojiPicker.vue.d.ts +561 -0
  340. package/dist/components/NcEmojiPicker/index.mjs +1 -1
  341. package/dist/components/NcGuestContent/index.mjs +1 -1
  342. package/dist/components/NcHeaderButton/index.mjs +1 -1
  343. package/dist/components/NcHeaderMenu/NcHeaderMenu.vue.d.ts +319 -0
  344. package/dist/components/NcHeaderMenu/index.mjs +1 -1
  345. package/dist/components/NcHighlight/NcHighlight.vue.d.ts +1 -1
  346. package/dist/components/NcIconSvgWrapper/index.mjs +1 -1
  347. package/dist/components/NcInputField/NcInputField.vue.d.ts +8 -8
  348. package/dist/components/NcInputField/index.mjs +1 -1
  349. package/dist/components/NcListItem/NcListItem.vue.d.ts +652 -0
  350. package/dist/components/NcListItem/index.mjs +1 -1
  351. package/dist/components/NcListItemIcon/NcListItemIcon.vue.d.ts +1094 -0
  352. package/dist/components/NcListItemIcon/index.mjs +1 -1
  353. package/dist/components/NcLoadingIcon/index.mjs +1 -1
  354. package/dist/components/NcModal/index.mjs +1 -1
  355. package/dist/components/NcNoteCard/index.mjs +1 -1
  356. package/dist/components/NcPasswordField/NcPasswordField.vue.d.ts +14 -14
  357. package/dist/components/NcPasswordField/index.mjs +1 -1
  358. package/dist/components/NcPopover/NcPopoverTriggerProvider.vue.d.ts +12 -0
  359. package/dist/components/NcPopover/index.mjs +1 -1
  360. package/dist/components/NcProgressBar/NcProgressBar.vue.d.ts +48 -1
  361. package/dist/components/NcProgressBar/index.d.ts +4 -0
  362. package/dist/components/NcProgressBar/index.mjs +1 -1
  363. package/dist/components/NcRelatedResourcesPanel/NcRelatedResourcesPanel.vue.d.ts +463 -0
  364. package/dist/components/NcRelatedResourcesPanel/NcResource.vue.d.ts +149 -0
  365. package/dist/components/NcRelatedResourcesPanel/NcTeamResources.vue.d.ts +175 -0
  366. package/dist/components/NcRelatedResourcesPanel/index.mjs +1 -1
  367. package/dist/components/NcRichContenteditable/NcAutoCompleteResult.vue.d.ts +30 -0
  368. package/dist/components/NcRichContenteditable/NcMentionBubble.vue.d.ts +30 -0
  369. package/dist/components/NcRichContenteditable/NcRichContenteditable.vue.d.ts +28 -3
  370. package/dist/components/NcRichContenteditable/index.mjs +1 -1
  371. package/dist/components/NcRichText/NcReferenceList.vue.d.ts +268 -0
  372. package/dist/components/NcRichText/NcReferencePicker/NcProviderList.vue.d.ts +197 -0
  373. package/dist/components/NcRichText/NcReferencePicker/NcRawLinkInput.vue.d.ts +447 -0
  374. package/dist/components/NcRichText/NcReferencePicker/NcReferencePicker.vue.d.ts +1002 -0
  375. package/dist/components/NcRichText/NcReferencePicker/NcReferencePickerModal.vue.d.ts +1167 -0
  376. package/dist/components/NcRichText/NcReferencePicker/NcSearch.vue.d.ts +275 -0
  377. package/dist/components/NcRichText/NcReferencePicker/NcSearchResult.vue.d.ts +69 -0
  378. package/dist/components/NcRichText/NcReferenceWidget.vue.d.ts +187 -0
  379. package/dist/components/NcRichText/NcRichText.vue.d.ts +405 -0
  380. package/dist/components/NcRichText/autolink.d.ts +18 -7
  381. package/dist/components/NcRichText/index.d.ts +6 -6
  382. package/dist/components/NcRichText/index.mjs +17 -17
  383. package/dist/components/NcSavingIndicatorIcon/index.mjs +1 -1
  384. package/dist/components/NcSelect/NcSelect.vue.d.ts +99 -0
  385. package/dist/components/NcSelect/index.mjs +1 -1
  386. package/dist/components/NcSelectTags/NcSelectTags.vue.d.ts +183 -0
  387. package/dist/components/NcSelectTags/api.d.ts +3 -0
  388. package/dist/components/NcSelectTags/index.mjs +1 -1
  389. package/dist/components/NcSelectUsers/index.mjs +1 -1
  390. package/dist/components/NcSettingsInputText/index.mjs +1 -1
  391. package/dist/components/NcSettingsSection/index.mjs +1 -1
  392. package/dist/components/NcSettingsSelectGroup/NcSettingsSelectGroup.vue.d.ts +243 -0
  393. package/dist/components/NcSettingsSelectGroup/index.mjs +1 -1
  394. package/dist/components/NcTextArea/NcTextArea.vue.d.ts +4 -5
  395. package/dist/components/NcTextArea/index.mjs +1 -1
  396. package/dist/components/NcTextField/NcTextField.vue.d.ts +14 -14
  397. package/dist/components/NcTextField/index.mjs +1 -1
  398. package/dist/components/NcTimezonePicker/index.mjs +1 -1
  399. package/dist/components/NcTimezonePicker/timezoneDataProviderService.d.ts +0 -2
  400. package/dist/components/NcUserBubble/NcUserBubble.vue.d.ts +2 -2
  401. package/dist/components/NcUserBubble/index.mjs +1 -1
  402. package/dist/components/NcUserStatusIcon/index.mjs +1 -1
  403. package/dist/components/index.d.ts +6 -6
  404. package/dist/composables/useFormatDateTime/index.d.ts +2 -0
  405. package/dist/composables/useFormatDateTime/index.mjs +1 -1
  406. package/dist/composables/useFormatDateTime/index.mjs.map +1 -1
  407. package/dist/composables/useHotKey/index.mjs.map +1 -1
  408. package/dist/composables/useIsDarkTheme/constants.d.ts +1 -1
  409. package/dist/composables/useIsDarkTheme/index.d.ts +2 -1
  410. package/dist/composables/useIsDarkTheme/index.mjs.map +1 -1
  411. package/dist/composables/useIsFullscreen/index.mjs.map +1 -1
  412. package/dist/composables/useIsMobile/index.mjs.map +1 -1
  413. package/dist/composables/useTrapStackControl.d.ts +1 -1
  414. package/dist/directives/Focus/index.mjs.map +1 -1
  415. package/dist/directives/Linkify/index.mjs +1 -2
  416. package/dist/directives/Linkify/index.mjs.map +1 -1
  417. package/dist/functions/a11y/index.d.ts +2 -4
  418. package/dist/functions/a11y/index.mjs +2 -2
  419. package/dist/functions/a11y/index.mjs.map +1 -1
  420. package/dist/functions/contactsMenu/index.mjs.map +1 -1
  421. package/dist/functions/dialog/index.d.ts +1 -0
  422. package/dist/functions/dialog/index.mjs +1 -1
  423. package/dist/functions/dialog/index.mjs.map +1 -1
  424. package/dist/functions/emoji/emoji.d.ts +2 -2
  425. package/dist/functions/emoji/index.d.ts +1 -1
  426. package/dist/functions/isDarkTheme/index.d.ts +2 -1
  427. package/dist/functions/isDarkTheme/index.mjs.map +1 -1
  428. package/dist/functions/preloadImage/index.d.ts +1 -0
  429. package/dist/functions/preloadImage/index.mjs.map +1 -1
  430. package/dist/functions/reference/index.d.ts +3 -3
  431. package/dist/functions/reference/index.mjs +10 -10
  432. package/dist/functions/reference/widgets.d.ts +1 -0
  433. package/dist/functions/registerReference/index.d.ts +2 -2
  434. package/dist/functions/registerReference/index.mjs +5 -5
  435. package/dist/functions/usernameToColor/index.mjs +1 -1
  436. package/dist/functions/usernameToColor/index.mjs.map +1 -1
  437. package/dist/index.d.ts +1 -1
  438. package/dist/index.mjs +92 -91
  439. package/dist/index.mjs.map +1 -1
  440. package/dist/l10n.d.ts +1 -1
  441. package/dist/mixins/actionText.d.ts +1 -0
  442. package/dist/utils/UserStatus.d.ts +6 -1
  443. package/dist/utils/focusTrap.d.ts +6 -0
  444. package/dist/utils/getAvatarUrl.d.ts +1 -0
  445. package/dist/utils/legacy.d.ts +5 -0
  446. package/package.json +54 -47
  447. package/dist/assets/NcAppNavigationToggle-B4XuIU5N.css +0 -27
  448. package/dist/assets/NcAvatar-j5lkSXJF.css +0 -132
  449. package/dist/assets/NcEmojiPicker-CeVpBSVx.css +0 -576
  450. package/dist/assets/NcListItem-BBaZDZQK.css +0 -186
  451. package/dist/assets/NcSelectUsers-2-PyuY9Z.css +0 -4
  452. package/dist/assets/NcTextArea-BLRA2iY6.css +0 -112
  453. package/dist/chunks/ArrowLeft-BiZLJltw.mjs +0 -49
  454. package/dist/chunks/ArrowLeft-BiZLJltw.mjs.map +0 -1
  455. package/dist/chunks/Check-5i4xKnkl.mjs +0 -49
  456. package/dist/chunks/Check-5i4xKnkl.mjs.map +0 -1
  457. package/dist/chunks/DotsHorizontal-BJ_GCGpi.mjs +0 -49
  458. package/dist/chunks/DotsHorizontal-BJ_GCGpi.mjs.map +0 -1
  459. package/dist/chunks/NcActionButton-Bd35_0n4.mjs.map +0 -1
  460. package/dist/chunks/NcActionCheckbox-DLPDTACR.mjs.map +0 -1
  461. package/dist/chunks/NcActionInput-uNqbQcU9.mjs.map +0 -1
  462. package/dist/chunks/NcActionLink-BEo7zmXX.mjs.map +0 -1
  463. package/dist/chunks/NcActionRadio-CPoWB58D.mjs.map +0 -1
  464. package/dist/chunks/NcActionRouter-ERoQjJKv.mjs.map +0 -1
  465. package/dist/chunks/NcActionText-16Mj4-P1.mjs.map +0 -1
  466. package/dist/chunks/NcActionTextEditable-rS1GklQ7.mjs.map +0 -1
  467. package/dist/chunks/NcActions-CyXKvnrY.mjs.map +0 -1
  468. package/dist/chunks/NcAppContent-BK8bOVDx.mjs.map +0 -1
  469. package/dist/chunks/NcAppContentList-DnLY_sWw.mjs.map +0 -1
  470. package/dist/chunks/NcAppNavigation-Ccjr0Wxc.mjs +0 -167
  471. package/dist/chunks/NcAppNavigation-Ccjr0Wxc.mjs.map +0 -1
  472. package/dist/chunks/NcAppNavigationCaption-DxfUoJBO.mjs.map +0 -1
  473. package/dist/chunks/NcAppNavigationIconBullet-B1kc4u65.mjs.map +0 -1
  474. package/dist/chunks/NcAppNavigationItem-CSiMEh0V.mjs.map +0 -1
  475. package/dist/chunks/NcAppNavigationNew-CLbVKk5X.mjs.map +0 -1
  476. package/dist/chunks/NcAppNavigationNewItem-B4TH71qQ.mjs.map +0 -1
  477. package/dist/chunks/NcAppNavigationSearch-BOZ5dS_m.mjs.map +0 -1
  478. package/dist/chunks/NcAppNavigationSettings-9FtV3wC6.mjs +0 -138
  479. package/dist/chunks/NcAppNavigationSettings-9FtV3wC6.mjs.map +0 -1
  480. package/dist/chunks/NcAppNavigationToggle-D8aIKSiz.mjs +0 -137
  481. package/dist/chunks/NcAppNavigationToggle-D8aIKSiz.mjs.map +0 -1
  482. package/dist/chunks/NcAppSettingsDialog-B4rJQ7w_.mjs.map +0 -1
  483. package/dist/chunks/NcAppSettingsSection-CssmXyZ0.mjs.map +0 -1
  484. package/dist/chunks/NcAppSidebar-D0azvKne.mjs.map +0 -1
  485. package/dist/chunks/NcAppSidebarTab-D1RmFRTu.mjs.map +0 -1
  486. package/dist/chunks/NcAvatar-Ccw1N-kB.mjs.map +0 -1
  487. package/dist/chunks/NcBreadcrumb-C9ma2_SJ.mjs.map +0 -1
  488. package/dist/chunks/NcBreadcrumbs-kg_aktAn.mjs.map +0 -1
  489. package/dist/chunks/NcButton-Df1eAyJ3.mjs.map +0 -1
  490. package/dist/chunks/NcCheckboxRadioSwitch-D8tOjXwB.mjs.map +0 -1
  491. package/dist/chunks/NcChip-Bf2JVPf_.mjs.map +0 -1
  492. package/dist/chunks/NcCollectionList-DtD-RXl8.mjs.map +0 -1
  493. package/dist/chunks/NcColorPicker-BRIu0Qel.mjs.map +0 -1
  494. package/dist/chunks/NcDashboardWidget-cBZ_Ub8Q.mjs.map +0 -1
  495. package/dist/chunks/NcDashboardWidgetItem-BnUtMMCC.mjs.map +0 -1
  496. package/dist/chunks/NcDateTimePicker-Dliaj0xD.mjs.map +0 -1
  497. package/dist/chunks/NcDateTimePickerNative-CEm70Aaw.mjs.map +0 -1
  498. package/dist/chunks/NcDialog-B_4Lud9m.mjs.map +0 -1
  499. package/dist/chunks/NcDialogButton.vue_vue_type_script_setup_true_lang-d1zLHPqM.mjs.map +0 -1
  500. package/dist/chunks/NcEllipsisedOption-C8uNDC-j.mjs.map +0 -1
  501. package/dist/chunks/NcEmojiPicker-DZXHV_Me.mjs.map +0 -1
  502. package/dist/chunks/NcGuestContent-mLXi-A-D.mjs.map +0 -1
  503. package/dist/chunks/NcHeaderButton-D6LMZ6iL.mjs.map +0 -1
  504. package/dist/chunks/NcHeaderMenu-O0loxc_q.mjs.map +0 -1
  505. package/dist/chunks/NcInputConfirmCancel-RRwim02d.mjs.map +0 -1
  506. package/dist/chunks/NcInputField-DEHb834Z.mjs.map +0 -1
  507. package/dist/chunks/NcListItem-C6WoTIa4.mjs.map +0 -1
  508. package/dist/chunks/NcListItemIcon-5OKjuvJE.mjs.map +0 -1
  509. package/dist/chunks/NcLoadingIcon-Dm3kRPrf.mjs.map +0 -1
  510. package/dist/chunks/NcMentionBubble.vue_vue_type_style_index_0_scoped_25f4d6e1_lang-aMwzB20D.mjs.map +0 -1
  511. package/dist/chunks/NcModal-n7KHhtoD.mjs.map +0 -1
  512. package/dist/chunks/NcNoteCard-B5CvOJmh.mjs.map +0 -1
  513. package/dist/chunks/NcPasswordField-JRyxT6wU.mjs.map +0 -1
  514. package/dist/chunks/NcPopover-DLoAYZgv.mjs.map +0 -1
  515. package/dist/chunks/NcProgressBar-Bx8bMkd4.mjs +0 -148
  516. package/dist/chunks/NcProgressBar-Bx8bMkd4.mjs.map +0 -1
  517. package/dist/chunks/NcRelatedResourcesPanel-BBcAt5Fj.mjs.map +0 -1
  518. package/dist/chunks/NcRichContenteditable-BD6rWjXe.mjs.map +0 -1
  519. package/dist/chunks/NcRichText-BwC3HU1U.mjs.map +0 -1
  520. package/dist/chunks/NcSelect-DlAtugnK.mjs.map +0 -1
  521. package/dist/chunks/NcSelectTags-N96Vc2rX.mjs.map +0 -1
  522. package/dist/chunks/NcSelectUsers-BEoD3M8_.mjs.map +0 -1
  523. package/dist/chunks/NcSettingsInputText-Dh5pxW31.mjs.map +0 -1
  524. package/dist/chunks/NcSettingsSelectGroup-CUvIP57B.mjs.map +0 -1
  525. package/dist/chunks/NcTextArea-BTKWGbc1.mjs.map +0 -1
  526. package/dist/chunks/NcTextField.vue_vue_type_script_setup_true_lang-DM5tkqJq.mjs.map +0 -1
  527. package/dist/chunks/NcTimezonePicker.vue_vue_type_script_setup_true_lang-CZ5IafBy.mjs.map +0 -1
  528. package/dist/chunks/NcUserBubble-DpGJJxHd.mjs.map +0 -1
  529. package/dist/chunks/NcUserStatusIcon-DJ_IKC46.mjs.map +0 -1
  530. package/dist/chunks/_l10n-_R1HqC4N.mjs +0 -108
  531. package/dist/chunks/_l10n-_R1HqC4N.mjs.map +0 -1
  532. package/dist/chunks/autolink-Y0rlJ_CI.mjs.map +0 -1
  533. package/dist/chunks/colors-Bws_qBuw.mjs.map +0 -1
  534. package/dist/chunks/customPickerElements-CH9vlHLd.mjs.map +0 -1
  535. package/dist/chunks/focusTrap-DmkaYJTC.mjs.map +0 -1
  536. package/dist/chunks/mdi-D6fu5i4r.mjs +0 -37
  537. package/dist/chunks/referencePickerModal-BA3NmGQ-.mjs.map +0 -1
  538. package/dist/chunks/useTrapStackControl-b3A_383w.mjs.map +0 -1
  539. package/dist/components/NcAppNavigationToggle/index.d.ts +0 -5
  540. package/dist/components/NcAppNavigationToggle/index.mjs +0 -5
  541. package/dist/components/NcAppNavigationToggle/index.mjs.map +0 -1
  542. package/dist/vendor.LICENSE.txt +0 -137
  543. /package/dist/components/{NcAppNavigationToggle → NcAppNavigation}/NcAppNavigationToggle.vue.d.ts +0 -0
@@ -1,4 +1,4 @@
1
- import '../assets/NcHeaderMenu-CP5Nn6tY.css';
1
+ import '../assets/NcHeaderMenu-BkGG39vE.css';
2
2
  import { defineComponent, ref, computed, useTemplateRef, watch, nextTick, createBlock, openBlock, resolveDynamicComponent, normalizeClass, unref, withCtx, createVNode, createElementBlock, createCommentVNode, withDirectives, withModifiers, renderSlot, toDisplayString, createElementVNode, vShow } from "vue";
3
3
  import { onClickOutside } from "@vueuse/core";
4
4
  import { createFocusTrap } from "focus-trap";
@@ -7,21 +7,26 @@ import { useHotKey } from "../composables/useHotKey/index.mjs";
7
7
  import "../composables/useIsDarkTheme/index.mjs";
8
8
  import "../composables/useIsFullscreen/index.mjs";
9
9
  import "../composables/useIsMobile/index.mjs";
10
- import { g as getTrapStack } from "./focusTrap-DmkaYJTC.mjs";
10
+ import { u as useTrapStackControl } from "./useTrapStackControl-B6cEicto.mjs";
11
11
  import { c as createElementId } from "./createElementId-DhjFt1I9.mjs";
12
- import { N as NcButton } from "./NcButton-Df1eAyJ3.mjs";
12
+ import { g as getTrapStack } from "./focusTrap-HJQ4pqHV.mjs";
13
+ import { N as NcButton } from "./NcButton-DkC5k3Lb.mjs";
13
14
  import { _ as _export_sfc } from "./_plugin-vue_export-helper-1tPrXgE0.mjs";
14
15
  const _hoisted_1 = ["id"];
15
16
  const _hoisted_2 = { class: "header-menu__caret" };
16
17
  const _hoisted_3 = ["id"];
18
+ const _hoisted_4 = {
19
+ ref: "content-container-key",
20
+ class: "header-menu__content"
21
+ };
17
22
  const _sfc_main = /* @__PURE__ */ defineComponent({
18
23
  __name: "NcHeaderMenu",
19
24
  props: {
20
25
  id: {},
21
- ariaLabel: {},
26
+ ariaLabel: { default: () => void 0 },
22
27
  open: { type: Boolean, default: false },
23
28
  isNav: { type: Boolean, default: false },
24
- description: {},
29
+ description: { default: () => void 0 },
25
30
  excludeClickOutsideSelectors: { default: () => [] }
26
31
  },
27
32
  emits: ["closed", "opened", "update:open"],
@@ -32,14 +37,15 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
32
37
  const focusTrap = ref();
33
38
  const isOpened = ref(__props.open);
34
39
  const wrapperTag = computed(() => __props.isNav ? "nav" : "div");
35
- const contentContainer = useTemplateRef("contentContainer");
36
- const headerMenu = useTemplateRef("headerMenu");
37
- const triggerButton = useTemplateRef("triggerButton");
38
- const ignore = computed(
39
- () => Array.isArray(__props.excludeClickOutsideSelectors) ? __props.excludeClickOutsideSelectors : __props.excludeClickOutsideSelectors.split(" ")
40
- );
40
+ const contentContainer = useTemplateRef("content-container-key");
41
+ const headerMenu = useTemplateRef("header-menu-key");
42
+ const triggerButton = useTemplateRef("trigger-button-key");
43
+ const ignore = computed(() => Array.isArray(__props.excludeClickOutsideSelectors) ? __props.excludeClickOutsideSelectors : __props.excludeClickOutsideSelectors.split(" "));
41
44
  onClickOutside(headerMenu, () => setMenuState(false), { ignore });
42
45
  useHotKey("Escape", () => setMenuState(false), { prevent: true });
46
+ useTrapStackControl(isOpened, {
47
+ disabled: () => !__props.isNav
48
+ });
43
49
  watch(() => __props.open, (state) => setMenuState(state));
44
50
  function toggleMenu() {
45
51
  setMenuState(!isOpened.value);
@@ -83,8 +89,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
83
89
  return (_ctx, _cache) => {
84
90
  return openBlock(), createBlock(resolveDynamicComponent(wrapperTag.value), {
85
91
  id: _ctx.id,
86
- ref_key: "headerMenu",
87
- ref: headerMenu,
92
+ ref: "header-menu-key",
88
93
  "aria-labelledby": _ctx.isNav ? unref(triggerId) : null,
89
94
  class: normalizeClass([{ "header-menu--opened": isOpened.value }, "header-menu"]),
90
95
  onFocusout: onFocusOut
@@ -92,11 +97,11 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
92
97
  default: withCtx(() => [
93
98
  createVNode(unref(NcButton), {
94
99
  id: _ctx.isNav ? unref(triggerId) : null,
95
- ref_key: "triggerButton",
96
- ref: triggerButton,
97
- class: "header-menu__trigger",
100
+ ref: "trigger-button-key",
98
101
  "aria-controls": `header-menu-${_ctx.id}`,
99
102
  "aria-expanded": isOpened.value.toString(),
103
+ "aria-label": _ctx.ariaLabel,
104
+ class: "header-menu__trigger",
100
105
  size: "large",
101
106
  variant: "tertiary-no-background",
102
107
  onClick: withModifiers(toggleMenu, ["prevent"])
@@ -105,7 +110,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
105
110
  renderSlot(_ctx.$slots, "trigger", {}, void 0, true)
106
111
  ]),
107
112
  _: 3
108
- }, 8, ["id", "aria-controls", "aria-expanded"]),
113
+ }, 8, ["id", "aria-controls", "aria-expanded", "aria-label"]),
109
114
  _ctx.description ? (openBlock(), createElementBlock("span", {
110
115
  key: 0,
111
116
  id: unref(descriptionId),
@@ -118,11 +123,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
118
123
  id: `header-menu-${_ctx.id}`,
119
124
  class: "header-menu__wrapper"
120
125
  }, [
121
- createElementVNode("div", {
122
- ref_key: "contentContainer",
123
- ref: contentContainer,
124
- class: "header-menu__content"
125
- }, [
126
+ createElementVNode("div", _hoisted_4, [
126
127
  renderSlot(_ctx.$slots, "default", {}, void 0, true)
127
128
  ], 512)
128
129
  ], 8, _hoisted_3), [
@@ -134,8 +135,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
134
135
  };
135
136
  }
136
137
  });
137
- const NcHeaderMenu = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-2484d53f"]]);
138
+ const NcHeaderMenu = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-24286a7c"]]);
138
139
  export {
139
140
  NcHeaderMenu as N
140
141
  };
141
- //# sourceMappingURL=NcHeaderMenu-O0loxc_q.mjs.map
142
+ //# sourceMappingURL=NcHeaderMenu-fnBUbMrU.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcHeaderMenu-fnBUbMrU.mjs","sources":["../../src/components/NcHeaderMenu/NcHeaderMenu.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nThis component is made to be used in the Nextcloud top header.\n\n```\n<template>\n\t<div id=\"nextcloud-header\">\n\t\t<NcHeaderMenu id=\"search\"\n\t\t\taria-label=\"Search\">\n\t\t\t<template #trigger>\n\t\t\t\t<Magnify />\n\t\t\t</template>\n\t\t\t<div>\n\t\t\t\t<NcTextField label=\"Search for files, comments, contacts …\"\n\t\t\t\t\tstyle=\"padding-inline: 8px;\"\n\t\t\t\t\ttype=\"search\"\n\t\t\t\t\tv-model=\"query\" />\n\t\t\t\t<NcEmptyContent\n\t\t\t\t\tname=\"Search\"\n\t\t\t\t\t:description=\"query ? `No results for '${query}'` : 'Start typing to search'\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<Magnify />\n\t\t\t\t\t</template>\n\t\t\t\t</NcEmptyContent>\n\t\t\t</div>\n\t\t</NcHeaderMenu>\n\t</div>\n</template>\n<script>\nimport Magnify from 'vue-material-design-icons/Magnify'\n\nexport default {\n\tcomponents: {\n\t\tMagnify,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tquery: '',\n\t\t}\n\t},\n}\n</script>\n<style>\n#nextcloud-header {\n\tdisplay: flex;\n\tjustify-content: end;\n\tbackground-color: var(--color-primary);\n\theight: var(--header-height, 50px);\n\tpadding-inline-end: 12px;\n}\n</style>\n```\n</docs>\n\n<script setup lang=\"ts\">\nimport type { FocusTrap } from 'focus-trap'\nimport type { Slot } from 'vue'\n\nimport { onClickOutside } from '@vueuse/core'\nimport { createFocusTrap } from 'focus-trap'\nimport { computed, nextTick, ref, useTemplateRef, watch } from 'vue'\nimport { useHotKey } from '../../composables/index.js'\nimport { useTrapStackControl } from '../../composables/useTrapStackControl.ts'\nimport { createElementId } from '../../utils/createElementId.ts'\nimport { getTrapStack } from '../../utils/focusTrap.js'\nimport NcButton from '../NcButton/index.ts'\n\nconst {\n\tariaLabel = undefined,\n\tdescription = undefined,\n\texcludeClickOutsideSelectors = [],\n\topen = false,\n\tisNav = false,\n} = defineProps<{\n\t/**\n\t * Unique id for this menu\n\t */\n\tid: string\n\n\t/**\n\t * aria-label attribute of the menu open button\n\t */\n\tariaLabel?: string\n\n\t/**\n\t * Current menu open state\n\t */\n\topen?: boolean\n\n\t/**\n\t * Pass `true` if the header menu is used for website navigation\n\t *\n\t * The wrapper tag will be set to `nav` and its `aria-labelledby`\n\t * will be associated with the menu open button\n\t */\n\tisNav?: boolean\n\n\t/**\n\t * Additional visually hidden description text for the menu\n\t * open button\n\t */\n\tdescription?: string\n\n\t/**\n\t * A query-selector or an array of query-selectors\n\t * to be ignored when clicking outside an element\n\t */\n\texcludeClickOutsideSelectors?: string | string[]\n}>()\n\nconst emit = defineEmits<{\n\t/** Emitted when the menu is fully closed (animation done) */\n\tclosed: []\n\n\t/** Emitted when the menu is fully opened (animation done) */\n\topened: []\n\n\t/** Updated open state */\n\t'update:open': [v: boolean]\n}>()\n\ndefineSlots<{\n\t/** The menu content */\n\tdefault?: Slot\n\t/** Icon trigger slot. Make sure the svg path is at least 16px. Usually mdi icon works at 20px */\n\ttrigger?: Slot\n}>()\n\n/** Id of the menu description */\nconst descriptionId = createElementId()\n/** Id of the trigger button */\nconst triggerId = createElementId()\n/** The active focus trap (if any) */\nconst focusTrap = ref<FocusTrap>()\n/** Is the menu currently opened */\nconst isOpened = ref(open)\n/** HTML tag to use for the header menu */\nconst wrapperTag = computed(() => isNav ? 'nav' : 'div')\n\n/** The menu content container element */\nconst contentContainer = useTemplateRef('content-container-key')\n/** The overall header menu wrapping element (<nav> or <div>) */\nconst headerMenu = useTemplateRef<HTMLElement>('header-menu-key')\n/** The menu trigger button */\nconst triggerButton = useTemplateRef('trigger-button-key')\n\n// Handle click outside of the menu -> should close the menu\nconst ignore = computed(() => Array.isArray(excludeClickOutsideSelectors)\n\t? excludeClickOutsideSelectors\n\t: excludeClickOutsideSelectors.split(' '))\nonClickOutside(headerMenu, () => setMenuState(false), { ignore })\n\n// Pressing escape should close the menu\nuseHotKey('Escape', () => setMenuState(false), { prevent: true })\n\n// When component has its own custom focus management\n// The global focus trap stack should be paused\nuseTrapStackControl(isOpened, {\n\tdisabled: () => !isNav,\n})\n\n// Watch the open prop to adjust the internal opened state\nwatch(() => open, (state: boolean) => setMenuState(state))\n\n/**\n * Toggle the current menu open state\n */\nfunction toggleMenu() {\n\tsetMenuState(!isOpened.value)\n}\n\n/**\n * Set the menu opened state\n *\n * @param state The opened state to set\n */\nasync function setMenuState(state: boolean) {\n\tif (state === isOpened.value) {\n\t\treturn\n\t}\n\n\tisOpened.value = state\n\temit('update:open', state)\n\n\t// wait one tick to make sure the rendering finished\n\tawait nextTick()\n\t// either add or clear the focus trap\n\tawait (state ? addFocusTrap() : clearFocusTrap())\n\n\t// Emit signal to mark finished toggling\n\t// @ts-expect-error This seems to be broken in Vue's typescript macro compiler...\n\temit(state ? 'opened' : 'closed')\n}\n\n/**\n * When this is role navigation, then we cannot apply a focus trap.\n * In this case we close the menu on focus-out.\n *\n * @param event the focus event\n */\nfunction onFocusOut(event: FocusEvent) {\n\t// Is not a navigation\n\tif (!isNav) {\n\t\treturn\n\t}\n\n\t// Event target is not a node\n\tif (!(event.relatedTarget instanceof Node)) {\n\t\treturn\n\t}\n\n\tif (headerMenu.value?.contains(event.relatedTarget)) {\n\t\tsetMenuState(false)\n\t}\n}\n\n/**\n * Add focus trap for accessibility.\n * Shall only be used when all children are mounted\n * and available in the DOM. We use $nextTick for that.\n */\nasync function addFocusTrap() {\n\t// We cannot add the focus trap on navigation roles\n\t// also skip if already set\n\tif (isNav || focusTrap.value) {\n\t\treturn\n\t}\n\n\t// Init focus trap\n\tfocusTrap.value = createFocusTrap(contentContainer.value!, {\n\t\tallowOutsideClick: true,\n\t\ttrapStack: getTrapStack(),\n\t\tfallbackFocus: triggerButton.value?.$el,\n\t})\n\tfocusTrap.value.activate()\n}\n\n/**\n * Deactivate and clear the focus trap\n */\nfunction clearFocusTrap() {\n\tfocusTrap.value?.deactivate()\n\tfocusTrap.value = undefined\n}\n</script>\n\n<template>\n\t<component\n\t\t:is=\"wrapperTag\"\n\t\t:id=\"id\"\n\t\tref=\"header-menu-key\"\n\t\t:aria-labelledby=\"isNav ? triggerId : null\"\n\t\t:class=\"{ 'header-menu--opened': isOpened }\"\n\t\tclass=\"header-menu\"\n\t\t@focusout=\"onFocusOut\">\n\t\t<!-- Trigger -->\n\t\t<NcButton\n\t\t\t:id=\"isNav ? triggerId : null\"\n\t\t\tref=\"trigger-button-key\"\n\t\t\t:aria-controls=\"`header-menu-${id}`\"\n\t\t\t:aria-expanded=\"isOpened.toString()\"\n\t\t\t:aria-label\n\t\t\tclass=\"header-menu__trigger\"\n\t\t\tsize=\"large\"\n\t\t\tvariant=\"tertiary-no-background\"\n\t\t\t@click.prevent=\"toggleMenu\">\n\t\t\t<template #icon>\n\t\t\t\t<slot name=\"trigger\" />\n\t\t\t</template>\n\t\t</NcButton>\n\n\t\t<span\n\t\t\tv-if=\"description\"\n\t\t\t:id=\"descriptionId\"\n\t\t\tclass=\"header-menu__description hidden-visually\">\n\t\t\t{{ description }}\n\t\t</span>\n\n\t\t<!-- Visual triangle -->\n\t\t<div v-show=\"isOpened\" class=\"header-menu__caret\" />\n\n\t\t<!-- Menu opened content -->\n\t\t<div\n\t\t\tv-show=\"isOpened\"\n\t\t\t:id=\"`header-menu-${id}`\"\n\t\t\tclass=\"header-menu__wrapper\">\n\t\t\t<div ref=\"content-container-key\" class=\"header-menu__content\">\n\t\t\t\t<slot />\n\t\t\t</div>\n\t\t</div>\n\t</component>\n</template>\n\n<style lang=\"scss\" scoped>\n@use './header-menu__trigger.scss';\n\n// content inner and outer margin\n// Also used for menu top-right positioning\n$externalMargin: 8px;\n\n.header-menu {\n\t&__wrapper {\n\t\tposition: fixed;\n\t\tz-index: 2000;\n\t\ttop: var(--header-height);\n\t\tinset-inline-end: 0;\n\t\tbox-sizing: border-box;\n\t\tmargin: 0 $externalMargin;\n\t\tborder-radius: var(--border-radius-element);\n\t\tbackground-color: var(--color-main-background);\n\n\t\tfilter: drop-shadow(0 1px 5px var(--color-box-shadow));\n\t}\n\n\t&__caret {\n\t\tposition: absolute;\n\t\tz-index: 2001; // Because __wrapper is 2000.\n\t\tbottom: 0;\n\t\tinset-inline-start: calc(50% - 10px);\n\t\twidth: 0;\n\t\theight: 0;\n\t\tcontent: ' ';\n\t\tpointer-events: none;\n\t\tborder: 10px solid transparent;\n\t\tborder-bottom-color: var(--color-main-background);\n\t}\n\n\t&__content {\n\t\toverflow: auto;\n\t\twidth: 350px;\n\t\tmax-width: calc(100vw - 2 * $externalMargin);\n\t\tmin-height: calc(var(--default-clickable-area) * 1.5);\n\t\tmax-height: calc(100vh - var(--header-height) * 2);\n\t\t:deep(.empty-content) {\n\t\t\tmargin: 12vh 10px;\n\t\t}\n\t}\n}\n</style>\n"],"names":["_openBlock","_createBlock","_resolveDynamicComponent","id","isNav","_unref","_normalizeClass","_createVNode","ariaLabel","_renderSlot","description","_createElementBlock","_withDirectives","_createElementVNode"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"NcHighlight.vue_vue_type_script_lang-DnWQDM_2.mjs","sources":["../../src/utils/findRanges.ts","../../src/components/NcHighlight/NcHighlight.vue"],"sourcesContent":["/*!\n * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\n\nexport interface StringRange {\n\tstart: number\n\tend: number\n}\n\n/**\n * Find the ranges of a substr in a given string\n *\n * @param text - The text to search in\n * @param search - The text to search for\n * @return The array of ranges to highlight\n */\nexport function findRanges(text: string, search: string): StringRange[] {\n\tconst ranges: StringRange[] = []\n\n\tlet currentIndex = 0\n\tlet index = text.toLowerCase().indexOf(search.toLowerCase(), currentIndex)\n\t// Variable to track that we don't iterate more often than the length of the text.\n\t// Shouldn't happen anyway, but just to be sure to not hang the browser for some reason.\n\tlet i = 0\n\twhile (index > -1 && i++ < text.length) {\n\t\tcurrentIndex = index + search.length\n\t\tranges.push({ start: index, end: currentIndex })\n\n\t\tindex = text.toLowerCase().indexOf(search.toLowerCase(), currentIndex)\n\t}\n\treturn ranges\n}\n","<!--\n - SPDX-FileCopyrightText: 2021 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n\n### General description\n\nHighlight a string with html &lt;strong&gt;. Accepts a substring to highlight or an array with ranges.\n\n### Usage\n\n```vue\n<template>\n\t<div>\n\t\t<NcHighlight text=\"Highlight me please!\" search=\"me\" />\n\t\t<br />\n\t\t<NcHighlight text=\"Highlight me please!\" :highlight=\"[{ start: 4, end: 12 }]\" />\n\t</div>\n</template>\n```\n</docs>\n\n<script lang=\"ts\">\nimport type { PropType } from 'vue'\nimport type { StringRange } from '../../utils/findRanges.ts'\n\nimport { defineComponent, h } from 'vue'\nimport { findRanges } from '../../utils/findRanges.ts'\n\n/**\n * Represents one chunk of the input text\n */\ninterface HighlightChunk extends StringRange {\n\thighlight: boolean\n\ttext: string\n}\n\nexport default defineComponent({\n\tname: 'NcHighlight',\n\tprops: {\n\t\t/**\n\t\t * The string to display\n\t\t */\n\t\ttext: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * The string to match and highlight\n\t\t */\n\t\tsearch: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * The ranges to highlight, takes precedence over the search prop.\n\t\t */\n\t\thighlight: {\n\t\t\ttype: Array as PropType<StringRange[]>,\n\t\t\tdefault: () => [],\n\t\t},\n\t},\n\tcomputed: {\n\t\t/**\n\t\t * The indice ranges which should be highlighted.\n\t\t * If an array with ranges is provided, we use it. Otherwise\n\t\t * we calculate it based on the provided substring to highlight.\n\t\t *\n\t\t * @return The array of ranges to highlight\n\t\t */\n\t\tranges(): StringRange[] {\n\t\t\tlet ranges: StringRange[] = []\n\t\t\t// If the search term and the highlight array is empty, return early with empty array\n\t\t\tif (!this.search && this.highlight.length === 0) {\n\t\t\t\treturn ranges\n\t\t\t}\n\n\t\t\t// If there are ranges to highlight provided, we use this array.\n\t\t\tif (this.highlight.length > 0) {\n\t\t\t\tranges = this.highlight\n\t\t\t// Otherwise we check the text to highlight for matches of the search term.\n\t\t\t} else {\n\t\t\t\tranges = findRanges(this.text, this.search)\n\t\t\t}\n\n\t\t\t/**\n\t\t\t * Ensure that the start of each range is equal to or smaller than the end\n\t\t\t */\n\t\t\tranges.forEach((range, i) => {\n\t\t\t\tif (range.end < range.start) {\n\t\t\t\t\tranges[i] = {\n\t\t\t\t\t\tstart: range.end,\n\t\t\t\t\t\tend: range.start,\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t})\n\n\t\t\t/**\n\t\t\t * Validate the ranges array to be within the string length\n\t\t\t * and discard ranges which are completely out of bonds.\n\t\t\t */\n\t\t\tranges = ranges.reduce<StringRange[]>((validRanges, range) => {\n\t\t\t\tif (range.start < this.text.length && range.end > 0) {\n\t\t\t\t\tvalidRanges.push({\n\t\t\t\t\t\tstart: (range.start < 0) ? 0 : range.start,\n\t\t\t\t\t\tend: (range.end > this.text.length) ? this.text.length : range.end,\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t\treturn validRanges\n\t\t\t}, [])\n\n\t\t\t/**\n\t\t\t * Sort ranges ascendingly (necessary for next step)\n\t\t\t */\n\t\t\tranges.sort((a, b) => {\n\t\t\t\treturn a.start - b.start\n\t\t\t})\n\n\t\t\t/**\n\t\t\t * Merge overlapping or adjacent ranges\n\t\t\t */\n\t\t\tranges = ranges.reduce<StringRange[]>((mergedRanges, range) => {\n\t\t\t\t// If there are no ranges, just add the range\n\t\t\t\tif (!mergedRanges.length) {\n\t\t\t\t\tmergedRanges.push(range)\n\t\t\t\t} else {\n\t\t\t\t\t// If the range overlaps the last range, merge them\n\t\t\t\t\tconst idx = mergedRanges.length - 1\n\t\t\t\t\tif (mergedRanges[idx].end >= range.start) {\n\t\t\t\t\t\tmergedRanges[idx] = {\n\t\t\t\t\t\t\tstart: mergedRanges[idx].start,\n\t\t\t\t\t\t\tend: Math.max(mergedRanges[idx].end, range.end),\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tmergedRanges.push(range)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn mergedRanges\n\t\t\t}, [])\n\n\t\t\treturn ranges\n\t\t},\n\t\t/**\n\t\t * Calculate the different chunks to show based on the ranges to highlight.\n\t\t */\n\t\tchunks(): HighlightChunk[] {\n\t\t\t// If the ranges array is empty, show only one chunk with all text\n\t\t\tif (this.ranges.length === 0) {\n\t\t\t\treturn [{\n\t\t\t\t\tstart: 0,\n\t\t\t\t\tend: this.text.length,\n\t\t\t\t\thighlight: false,\n\t\t\t\t\ttext: this.text,\n\t\t\t\t}]\n\t\t\t}\n\n\t\t\t// Calculate the chunks\n\t\t\tconst chunks: HighlightChunk[] = []\n\t\t\tlet currentIndex = 0\n\t\t\tlet currentRange = 0\n\t\t\t// Iterate over all characters in the text\n\t\t\twhile (currentIndex < this.text.length) {\n\t\t\t\t// Get the first range to highlight\n\t\t\t\tconst range = this.ranges[currentRange]\n\t\t\t\t// If the range starts at the current index, construct a chunk to highlight,\n\t\t\t\t// set the next range and continue with the next iteration.\n\t\t\t\tif (range.start === currentIndex) {\n\t\t\t\t\tchunks.push({\n\t\t\t\t\t\t...range,\n\t\t\t\t\t\thighlight: true,\n\t\t\t\t\t\ttext: this.text.slice(range.start, range.end),\n\t\t\t\t\t})\n\t\t\t\t\tcurrentRange++\n\t\t\t\t\tcurrentIndex = range.end\n\t\t\t\t\t// If this was the last range to highlight and we haven't reached the end of the text,\n\t\t\t\t\t// add the rest of the text without highlighting.\n\t\t\t\t\tif (currentRange >= this.ranges.length && currentIndex < this.text.length) {\n\t\t\t\t\t\tchunks.push({\n\t\t\t\t\t\t\tstart: currentIndex,\n\t\t\t\t\t\t\tend: this.text.length,\n\t\t\t\t\t\t\thighlight: false,\n\t\t\t\t\t\t\ttext: this.text.slice(currentIndex),\n\t\t\t\t\t\t})\n\t\t\t\t\t\t// Set the current index so the while loop ends.\n\t\t\t\t\t\tcurrentIndex = this.text.length\n\t\t\t\t\t}\n\t\t\t\t\tcontinue\n\t\t\t\t}\n\t\t\t\t// If the current range does start after the current index, construct a chunk without\n\t\t\t\t// highlighting and set the current index to the start of the current range.\n\t\t\t\tchunks.push({\n\t\t\t\t\tstart: currentIndex,\n\t\t\t\t\tend: range.start,\n\t\t\t\t\thighlight: false,\n\t\t\t\t\ttext: this.text.slice(currentIndex, range.start),\n\t\t\t\t})\n\t\t\t\tcurrentIndex = range.start\n\t\t\t}\n\t\t\treturn chunks\n\t\t},\n\t},\n\n\t/**\n\t * The render function to display the component\n\t */\n\trender() {\n\t\tif (!this.ranges.length) {\n\t\t\treturn h('span', {}, this.text)\n\t\t}\n\n\t\treturn h('span', {}, this.chunks.map(chunk => {\n\t\t\treturn chunk.highlight ? h('strong', {}, chunk.text) : chunk.text\n\t\t}))\n\t},\n})\n</script>\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"NcHighlight.vue_vue_type_script_lang-DnWQDM_2.mjs","sources":["../../src/utils/findRanges.ts","../../src/components/NcHighlight/NcHighlight.vue"],"sourcesContent":["/*!\n * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\n\nexport interface StringRange {\n\tstart: number\n\tend: number\n}\n\n/**\n * Find the ranges of a substr in a given string\n *\n * @param text - The text to search in\n * @param search - The text to search for\n * @return The array of ranges to highlight\n */\nexport function findRanges(text: string, search: string): StringRange[] {\n\tconst ranges: StringRange[] = []\n\n\tlet currentIndex = 0\n\tlet index = text.toLowerCase().indexOf(search.toLowerCase(), currentIndex)\n\t// Variable to track that we don't iterate more often than the length of the text.\n\t// Shouldn't happen anyway, but just to be sure to not hang the browser for some reason.\n\tlet i = 0\n\twhile (index > -1 && i++ < text.length) {\n\t\tcurrentIndex = index + search.length\n\t\tranges.push({ start: index, end: currentIndex })\n\n\t\tindex = text.toLowerCase().indexOf(search.toLowerCase(), currentIndex)\n\t}\n\treturn ranges\n}\n","<!--\n - SPDX-FileCopyrightText: 2021 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n\n### General description\n\nHighlight a string with html &lt;strong&gt;. Accepts a substring to highlight or an array with ranges.\n\n### Usage\n\n```vue\n<template>\n\t<div>\n\t\t<NcHighlight text=\"Highlight me please!\" search=\"me\" />\n\t\t<br />\n\t\t<NcHighlight text=\"Highlight me please!\" :highlight=\"[{ start: 4, end: 12 }]\" />\n\t</div>\n</template>\n```\n</docs>\n\n<script lang=\"ts\">\nimport type { PropType } from 'vue'\nimport type { StringRange } from '../../utils/findRanges.ts'\n\nimport { defineComponent, h } from 'vue'\nimport { findRanges } from '../../utils/findRanges.ts'\n\n/**\n * Represents one chunk of the input text\n */\nexport interface HighlightChunk extends StringRange {\n\thighlight: boolean\n\ttext: string\n}\n\nexport default defineComponent({\n\tname: 'NcHighlight',\n\tprops: {\n\t\t/**\n\t\t * The string to display\n\t\t */\n\t\ttext: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * The string to match and highlight\n\t\t */\n\t\tsearch: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * The ranges to highlight, takes precedence over the search prop.\n\t\t */\n\t\thighlight: {\n\t\t\ttype: Array as PropType<StringRange[]>,\n\t\t\tdefault: () => [],\n\t\t},\n\t},\n\n\tcomputed: {\n\t\t/**\n\t\t * The indice ranges which should be highlighted.\n\t\t * If an array with ranges is provided, we use it. Otherwise\n\t\t * we calculate it based on the provided substring to highlight.\n\t\t *\n\t\t * @return The array of ranges to highlight\n\t\t */\n\t\tranges(): StringRange[] {\n\t\t\tlet ranges: StringRange[] = []\n\t\t\t// If the search term and the highlight array is empty, return early with empty array\n\t\t\tif (!this.search && this.highlight.length === 0) {\n\t\t\t\treturn ranges\n\t\t\t}\n\n\t\t\t// If there are ranges to highlight provided, we use this array.\n\t\t\tif (this.highlight.length > 0) {\n\t\t\t\tranges = this.highlight\n\t\t\t// Otherwise we check the text to highlight for matches of the search term.\n\t\t\t} else {\n\t\t\t\tranges = findRanges(this.text, this.search)\n\t\t\t}\n\n\t\t\t/**\n\t\t\t * Ensure that the start of each range is equal to or smaller than the end\n\t\t\t */\n\t\t\tranges.forEach((range, i) => {\n\t\t\t\tif (range.end < range.start) {\n\t\t\t\t\tranges[i] = {\n\t\t\t\t\t\tstart: range.end,\n\t\t\t\t\t\tend: range.start,\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t})\n\n\t\t\t/**\n\t\t\t * Validate the ranges array to be within the string length\n\t\t\t * and discard ranges which are completely out of bonds.\n\t\t\t */\n\t\t\tranges = ranges.reduce<StringRange[]>((validRanges, range) => {\n\t\t\t\tif (range.start < this.text.length && range.end > 0) {\n\t\t\t\t\tvalidRanges.push({\n\t\t\t\t\t\tstart: (range.start < 0) ? 0 : range.start,\n\t\t\t\t\t\tend: (range.end > this.text.length) ? this.text.length : range.end,\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t\treturn validRanges\n\t\t\t}, [])\n\n\t\t\t/**\n\t\t\t * Sort ranges ascendingly (necessary for next step)\n\t\t\t */\n\t\t\tranges.sort((a, b) => {\n\t\t\t\treturn a.start - b.start\n\t\t\t})\n\n\t\t\t/**\n\t\t\t * Merge overlapping or adjacent ranges\n\t\t\t */\n\t\t\tranges = ranges.reduce<StringRange[]>((mergedRanges, range) => {\n\t\t\t\t// If there are no ranges, just add the range\n\t\t\t\tif (!mergedRanges.length) {\n\t\t\t\t\tmergedRanges.push(range)\n\t\t\t\t} else {\n\t\t\t\t\t// If the range overlaps the last range, merge them\n\t\t\t\t\tconst idx = mergedRanges.length - 1\n\t\t\t\t\tif (mergedRanges[idx]!.end >= range.start) {\n\t\t\t\t\t\tmergedRanges[idx] = {\n\t\t\t\t\t\t\tstart: mergedRanges[idx]!.start,\n\t\t\t\t\t\t\tend: Math.max(mergedRanges[idx]!.end, range.end),\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tmergedRanges.push(range)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn mergedRanges\n\t\t\t}, [])\n\n\t\t\treturn ranges\n\t\t},\n\n\t\t/**\n\t\t * Calculate the different chunks to show based on the ranges to highlight.\n\t\t */\n\t\tchunks(): HighlightChunk[] {\n\t\t\t// If the ranges array is empty, show only one chunk with all text\n\t\t\tif (this.ranges.length === 0) {\n\t\t\t\treturn [{\n\t\t\t\t\tstart: 0,\n\t\t\t\t\tend: this.text.length,\n\t\t\t\t\thighlight: false,\n\t\t\t\t\ttext: this.text,\n\t\t\t\t}]\n\t\t\t}\n\n\t\t\t// Calculate the chunks\n\t\t\tconst chunks: HighlightChunk[] = []\n\t\t\tlet currentIndex = 0\n\t\t\tlet currentRange = 0\n\t\t\t// Iterate over all characters in the text\n\t\t\twhile (currentIndex < this.text.length) {\n\t\t\t\t// Get the first range to highlight\n\t\t\t\tconst range = this.ranges[currentRange]!\n\t\t\t\t// If the range starts at the current index, construct a chunk to highlight,\n\t\t\t\t// set the next range and continue with the next iteration.\n\t\t\t\tif (range.start === currentIndex) {\n\t\t\t\t\tchunks.push({\n\t\t\t\t\t\t...range,\n\t\t\t\t\t\thighlight: true,\n\t\t\t\t\t\ttext: this.text.slice(range.start, range.end),\n\t\t\t\t\t})\n\t\t\t\t\tcurrentRange++\n\t\t\t\t\tcurrentIndex = range.end\n\t\t\t\t\t// If this was the last range to highlight and we haven't reached the end of the text,\n\t\t\t\t\t// add the rest of the text without highlighting.\n\t\t\t\t\tif (currentRange >= this.ranges.length && currentIndex < this.text.length) {\n\t\t\t\t\t\tchunks.push({\n\t\t\t\t\t\t\tstart: currentIndex,\n\t\t\t\t\t\t\tend: this.text.length,\n\t\t\t\t\t\t\thighlight: false,\n\t\t\t\t\t\t\ttext: this.text.slice(currentIndex),\n\t\t\t\t\t\t})\n\t\t\t\t\t\t// Set the current index so the while loop ends.\n\t\t\t\t\t\tcurrentIndex = this.text.length\n\t\t\t\t\t}\n\t\t\t\t\tcontinue\n\t\t\t\t}\n\t\t\t\t// If the current range does start after the current index, construct a chunk without\n\t\t\t\t// highlighting and set the current index to the start of the current range.\n\t\t\t\tchunks.push({\n\t\t\t\t\tstart: currentIndex,\n\t\t\t\t\tend: range.start,\n\t\t\t\t\thighlight: false,\n\t\t\t\t\ttext: this.text.slice(currentIndex, range.start),\n\t\t\t\t})\n\t\t\t\tcurrentIndex = range.start\n\t\t\t}\n\t\t\treturn chunks\n\t\t},\n\t},\n\n\t/**\n\t * The render function to display the component\n\t */\n\trender() {\n\t\tif (!this.ranges.length) {\n\t\t\treturn h('span', {}, this.text)\n\t\t}\n\n\t\treturn h('span', {}, this.chunks.map((chunk) => {\n\t\t\treturn chunk.highlight ? h('strong', {}, chunk.text) : chunk.text\n\t\t}))\n\t},\n})\n</script>\n"],"names":[],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import '../assets/NcIconSvgWrapper-CJfAwN6-.css';
1
+ import '../assets/NcIconSvgWrapper-D6qXQDNo.css';
2
2
  import { defineComponent, useCssVars, computed, warn, createElementBlock, openBlock, normalizeClass, createElementVNode } from "vue";
3
3
  import DOMPurify from "dompurify";
4
4
  import { _ as _export_sfc } from "./_plugin-vue_export-helper-1tPrXgE0.mjs";
@@ -22,7 +22,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
22
22
  },
23
23
  setup(__props) {
24
24
  useCssVars((_ctx) => ({
25
- "a360429a": iconSize.value
25
+ "0c3ef411": iconSize.value
26
26
  }));
27
27
  const props = __props;
28
28
  const iconSize = computed(() => typeof props.size === "number" ? `${props.size}px` : props.size);
@@ -61,8 +61,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
61
61
  };
62
62
  }
63
63
  });
64
- const NcIconSvgWrapper = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-bd3d356d"]]);
64
+ const NcIconSvgWrapper = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-5a43cff9"]]);
65
65
  export {
66
66
  NcIconSvgWrapper as N
67
67
  };
68
- //# sourceMappingURL=NcIconSvgWrapper-CprKb_SE.mjs.map
68
+ //# sourceMappingURL=NcIconSvgWrapper-5AA93z-F.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"NcIconSvgWrapper-CprKb_SE.mjs","sources":["../../src/components/NcIconSvgWrapper/NcIconSvgWrapper.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n### Description\n\nRender raw SVG string icons.\n\n### Usage within `icon`-slot\n\n```vue\n<template>\n\t<div class=\"grid\">\n\t\t<NcButton aria-label=\"Close\">\n\t\t\t<template #icon>\n\t\t\t\t<NcIconSvgWrapper :svg=\"closeSvg\" name=\"Close\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t\t<NcButton aria-label=\"Settings\">\n\t\t\t<template #icon>\n\t\t\t\t<NcIconSvgWrapper :svg=\"cogSvg\" name=\"Cog\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t\t<NcButton aria-label=\"Add\">\n\t\t\t<template #icon>\n\t\t\t\t<NcIconSvgWrapper :svg=\"plusSvg\" name=\"Plus\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t\t<NcButton aria-label=\"Send\">\n\t\t\t<template #icon>\n\t\t\t\t<NcIconSvgWrapper :path=\"mdiSend\" name=\"Send\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t\t<NcButton aria-label=\"Star\">\n\t\t\t<template #icon>\n\t\t\t\t<NcIconSvgWrapper :path=\"mdiStar\" name=\"Star\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t</div>\n</template>\n\n<script>\nimport closeSvg from '@mdi/svg/svg/close.svg?raw'\nimport cogSvg from '@mdi/svg/svg/cog.svg?raw'\nimport plusSvg from '@mdi/svg/svg/plus.svg?raw'\nimport { mdiSend } from '@mdi/js'\nimport { mdiStar } from '@mdi/js'\n\nexport default {\n\tsetup() {\n\t\t// This icons are static data, so you do not need to put them into `data` which will make them reactive\n\t\treturn {\n\t\t\tcloseSvg,\n\t\t\tcogSvg,\n\t\t\tplusSvg,\n\t\t\tmdiSend,\n\t\t\tmdiStar,\n\t\t}\n\t},\n}\n</script>\n\n<style>\n.grid {\n\tdisplay: grid;\n\tgrid-template-columns: repeat(5, max-content);\n\tgap: 10px;\n}\n</style>\n```\n\n### Inline usage inside text\n\n```vue\n<template>\n\t<p>\n\t\tThis is my <NcIconSvgWrapper inline :path=\"mdiStar\" /> Favorite\n\t</p>\n</template>\n<script>\nimport { mdiStar } from '@mdi/js'\n\nexport default {\n\tsetup() {\n\t\treturn {\n\t\t\tmdiStar,\n\t\t}\n\t},\n}\n</script>\n```\n\n### Directional usage\n\nThe `directional` property allows to enable a language direction aware icon.\nThis icon component can be used in places where an language direction aware icon should be used,\nfor example if an arrow pointing to the left it used it often points in the wrong direction for right-to-left languages.\nIn this cases this icon can be used which will always point into the logical \"start\" direction.\n\n```vue\n<template>\n\t<div class=\"wrapper\">\n\t\t<NcButton @click=\"isRtl = !isRtl\">Toggle RTL</NcButton>\n\t\t<div class=\"directional\" :dir=\"isRtl ? 'rtl' : 'ltr'\">\n\t\t\t<NcButton alignment=\"start\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<NcIconSvgWrapper directional :path=\"mdiChevronLeft\" />\n\t\t\t\t</template>\n\t\t\t\tPrevious\n\t\t\t</NcButton>\n\t\t\t<NcButton alignment=\"end-reverse\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<NcIconSvgWrapper directional :path=\"mdiChevronRight\" />\n\t\t\t\t</template>\n\t\t\t\tNext\n\t\t\t</NcButton>\n\t\t</div>\n\t</div>\n</template>\n\n<script>\nimport { mdiChevronLeft, mdiChevronRight } from '@mdi/js'\n\nexport default {\n\tsetup() {\n\t\treturn {\n\t\t\tmdiChevronLeft,\n\t\t\tmdiChevronRight,\n\t\t}\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tisRtl: false\n\t\t}\n\t},\n}\n</script>\n<style scoped>\n.wrapper {\n\tdisplay: flex;\n\tflex-direction: column;\n\tgap: calc(2 * var(--default-grid-baseline));\n\tmax-width: 300px;\n}\n\n.directional {\n\tdisplay: flex;\n\tflex-direction: row;\n\tgap: calc(2 * var(--default-grid-baseline));\n}\n\n.directional * {\n\tflex: 1 50%;\n}\n</style>\n```\n</docs>\n\n<script setup lang=\"ts\">\nimport { computed, warn } from 'vue'\nimport DOMPurify from 'dompurify'\n\nconst props = withDefaults(defineProps<{\n\t/**\n\t * Make the icon directional, meaning it is langauge direction aware.\n\t * If the icon is placed in a right-to-left context it will be mirrored vertically.\n\t */\n\tdirectional?: boolean\n\n\t/**\n\t * Set if the icon should be used as inline content e.g. within text.\n\t * By default the icon is made a block element for use inside `icon`-slots.\n\t */\n\tinline?: boolean\n\n\t/**\n\t * Raw SVG string to render\n\t */\n\tsvg?: string\n\n\t/**\n\t * Label of the icon, used in aria-label\n\t */\n\tname?: string\n\n\t/**\n\t * Raw SVG path to render. Takes precedence over the SVG string in the `svg` prop.\n\t */\n\tpath?: string\n\n\t/**\n\t * Size of the icon to show. Only use if not using within an icon slot.\n\t * Defaults to 20px which is the Nextcloud icon size for all icon slots.\n\t */\n\tsize?: number | 'auto'\n}>(), {\n\tname: undefined,\n\tpath: '',\n\tsize: 20,\n\tsvg: '',\n})\n\n/**\n * Icon size used in CSS\n */\nconst iconSize = computed(() => typeof props.size === 'number' ? `${props.size}px` : props.size)\n\n/**\n * The sanitized SVG or undefined if path shall be used\n */\nconst cleanSvg = computed(() => {\n\tif (!props.svg || props.path) {\n\t\treturn\n\t}\n\n\tconst svg = DOMPurify.sanitize(props.svg)\n\n\tconst svgDocument = new DOMParser().parseFromString(svg, 'image/svg+xml')\n\n\tif (svgDocument.querySelector('parsererror')) {\n\t\twarn('SVG is not valid')\n\t\treturn ''\n\t}\n\n\tif (svgDocument.documentElement.id) {\n\t\tsvgDocument.documentElement.removeAttribute('id')\n\t}\n\n\treturn svgDocument.documentElement.outerHTML\n})\n</script>\n\n<template>\n\t<span :aria-hidden=\"name ? undefined : 'true'\"\n\t\t:aria-label=\"name || undefined\"\n\t\tclass=\"icon-vue\"\n\t\t:class=\"{\n\t\t\t'icon-vue--directional': directional,\n\t\t\t'icon-vue--inline': inline,\n\t\t}\"\n\t\trole=\"img\">\n\t\t<svg v-if=\"!cleanSvg\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\n\t\t\t<path :d=\"path\" />\n\t\t</svg>\n\t\t<!-- eslint-disable-next-line vue/no-v-text-v-html-on-component,vue/no-v-html -->\n\t\t<span v-else v-html=\"cleanSvg\" />\n\t</span>\n</template>\n\n<style lang=\"scss\" scoped>\n.icon-vue {\n\tdisplay: flex;\n\tjustify-content: center;\n\talign-items: center;\n\tmin-width: var(--default-clickable-area);\n\tmin-height: var(--default-clickable-area);\n\topacity: 1;\n\n\t&#{&}--inline {\n\t\tdisplay: inline-flex !important;\n\t\tmin-width: fit-content;\n\t\tmin-height: fit-content;\n\t\tvertical-align: text-bottom;\n\t}\n\n\t// Icon svg wrapper\n\tspan {\n\t\tline-height: 0;\n\t}\n\n\t&:deep(svg) {\n\t\tfill: currentColor;\n\t\twidth: v-bind('iconSize');\n\t\theight: v-bind('iconSize');\n\t\tmax-width: v-bind('iconSize');\n\t\tmax-height: v-bind('iconSize');\n\t}\n\n\t&--directional:deep(svg:dir(rtl)) {\n\t\ttransform: scaleX(-1);\n\t}\n}\n</style>\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAoKA,UAAM,QAAQ;AA2Cd,UAAM,WAAW,SAAS,MAAM,OAAO,MAAM,SAAS,WAAW,GAAG,MAAM,IAAI,OAAO,MAAM,IAAI;AAKzF,UAAA,WAAW,SAAS,MAAM;AAC/B,UAAI,CAAC,MAAM,OAAO,MAAM,MAAM;AAC7B;AAAA,MAAA;AAGD,YAAM,MAAM,UAAU,SAAS,MAAM,GAAG;AAExC,YAAM,cAAc,IAAI,UAAA,EAAY,gBAAgB,KAAK,eAAe;AAEpE,UAAA,YAAY,cAAc,aAAa,GAAG;AAC7C,aAAK,kBAAkB;AAChB,eAAA;AAAA,MAAA;AAGJ,UAAA,YAAY,gBAAgB,IAAI;AACvB,oBAAA,gBAAgB,gBAAgB,IAAI;AAAA,MAAA;AAGjD,aAAO,YAAY,gBAAgB;AAAA,IAAA,CACnC;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"NcIconSvgWrapper-5AA93z-F.mjs","sources":["../../src/components/NcIconSvgWrapper/NcIconSvgWrapper.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n### Description\n\nRender raw SVG string icons.\n\n### Usage within `icon`-slot\n\n```vue\n<template>\n\t<div class=\"grid\">\n\t\t<NcButton aria-label=\"Close\">\n\t\t\t<template #icon>\n\t\t\t\t<NcIconSvgWrapper :svg=\"closeSvg\" name=\"Close\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t\t<NcButton aria-label=\"Settings\">\n\t\t\t<template #icon>\n\t\t\t\t<NcIconSvgWrapper :svg=\"cogSvg\" name=\"Cog\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t\t<NcButton aria-label=\"Add\">\n\t\t\t<template #icon>\n\t\t\t\t<NcIconSvgWrapper :svg=\"plusSvg\" name=\"Plus\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t\t<NcButton aria-label=\"Send\">\n\t\t\t<template #icon>\n\t\t\t\t<NcIconSvgWrapper :path=\"mdiSend\" name=\"Send\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t\t<NcButton aria-label=\"Star\">\n\t\t\t<template #icon>\n\t\t\t\t<NcIconSvgWrapper :path=\"mdiStar\" name=\"Star\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t</div>\n</template>\n\n<script>\nimport closeSvg from '@mdi/svg/svg/close.svg?raw'\nimport cogSvg from '@mdi/svg/svg/cog.svg?raw'\nimport plusSvg from '@mdi/svg/svg/plus.svg?raw'\nimport { mdiSend } from '@mdi/js'\nimport { mdiStar } from '@mdi/js'\n\nexport default {\n\tsetup() {\n\t\t// This icons are static data, so you do not need to put them into `data` which will make them reactive\n\t\treturn {\n\t\t\tcloseSvg,\n\t\t\tcogSvg,\n\t\t\tplusSvg,\n\t\t\tmdiSend,\n\t\t\tmdiStar,\n\t\t}\n\t},\n}\n</script>\n\n<style>\n.grid {\n\tdisplay: grid;\n\tgrid-template-columns: repeat(5, max-content);\n\tgap: 10px;\n}\n</style>\n```\n\n### Inline usage inside text\n\n```vue\n<template>\n\t<p>\n\t\tThis is my <NcIconSvgWrapper inline :path=\"mdiStar\" /> Favorite\n\t</p>\n</template>\n<script>\nimport { mdiStar } from '@mdi/js'\n\nexport default {\n\tsetup() {\n\t\treturn {\n\t\t\tmdiStar,\n\t\t}\n\t},\n}\n</script>\n```\n\n### Directional usage\n\nThe `directional` property allows to enable a language direction aware icon.\nThis icon component can be used in places where an language direction aware icon should be used,\nfor example if an arrow pointing to the left it used it often points in the wrong direction for right-to-left languages.\nIn this cases this icon can be used which will always point into the logical \"start\" direction.\n\n```vue\n<template>\n\t<div class=\"wrapper\">\n\t\t<NcButton @click=\"isRtl = !isRtl\">Toggle RTL</NcButton>\n\t\t<div class=\"directional\" :dir=\"isRtl ? 'rtl' : 'ltr'\">\n\t\t\t<NcButton alignment=\"start\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<NcIconSvgWrapper directional :path=\"mdiChevronLeft\" />\n\t\t\t\t</template>\n\t\t\t\tPrevious\n\t\t\t</NcButton>\n\t\t\t<NcButton alignment=\"end-reverse\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<NcIconSvgWrapper directional :path=\"mdiChevronRight\" />\n\t\t\t\t</template>\n\t\t\t\tNext\n\t\t\t</NcButton>\n\t\t</div>\n\t</div>\n</template>\n\n<script>\nimport { mdiChevronLeft, mdiChevronRight } from '@mdi/js'\n\nexport default {\n\tsetup() {\n\t\treturn {\n\t\t\tmdiChevronLeft,\n\t\t\tmdiChevronRight,\n\t\t}\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tisRtl: false\n\t\t}\n\t},\n}\n</script>\n<style scoped>\n.wrapper {\n\tdisplay: flex;\n\tflex-direction: column;\n\tgap: calc(2 * var(--default-grid-baseline));\n\tmax-width: 300px;\n}\n\n.directional {\n\tdisplay: flex;\n\tflex-direction: row;\n\tgap: calc(2 * var(--default-grid-baseline));\n}\n\n.directional * {\n\tflex: 1 50%;\n}\n</style>\n```\n</docs>\n\n<script setup lang=\"ts\">\nimport DOMPurify from 'dompurify'\nimport { computed, warn } from 'vue'\n\nconst props = withDefaults(defineProps<{\n\t/**\n\t * Make the icon directional, meaning it is langauge direction aware.\n\t * If the icon is placed in a right-to-left context it will be mirrored vertically.\n\t */\n\tdirectional?: boolean\n\n\t/**\n\t * Set if the icon should be used as inline content e.g. within text.\n\t * By default the icon is made a block element for use inside `icon`-slots.\n\t */\n\tinline?: boolean\n\n\t/**\n\t * Raw SVG string to render\n\t */\n\tsvg?: string\n\n\t/**\n\t * Label of the icon, used in aria-label\n\t */\n\tname?: string\n\n\t/**\n\t * Raw SVG path to render. Takes precedence over the SVG string in the `svg` prop.\n\t */\n\tpath?: string\n\n\t/**\n\t * Size of the icon to show. Only use if not using within an icon slot.\n\t * Defaults to 20px which is the Nextcloud icon size for all icon slots.\n\t */\n\tsize?: number | 'auto'\n}>(), {\n\tname: undefined,\n\tpath: '',\n\tsize: 20,\n\tsvg: '',\n})\n\n/**\n * Icon size used in CSS\n */\nconst iconSize = computed(() => typeof props.size === 'number' ? `${props.size}px` : props.size)\n\n/**\n * The sanitized SVG or undefined if path shall be used\n */\nconst cleanSvg = computed(() => {\n\tif (!props.svg || props.path) {\n\t\treturn\n\t}\n\n\tconst svg = DOMPurify.sanitize(props.svg)\n\n\tconst svgDocument = new DOMParser().parseFromString(svg, 'image/svg+xml')\n\n\tif (svgDocument.querySelector('parsererror')) {\n\t\twarn('SVG is not valid')\n\t\treturn ''\n\t}\n\n\tif (svgDocument.documentElement.id) {\n\t\tsvgDocument.documentElement.removeAttribute('id')\n\t}\n\n\treturn svgDocument.documentElement.outerHTML\n})\n</script>\n\n<template>\n\t<span\n\t\t:aria-hidden=\"name ? undefined : 'true'\"\n\t\t:aria-label=\"name || undefined\"\n\t\tclass=\"icon-vue\"\n\t\t:class=\"{\n\t\t\t'icon-vue--directional': directional,\n\t\t\t'icon-vue--inline': inline,\n\t\t}\"\n\t\trole=\"img\">\n\t\t<svg v-if=\"!cleanSvg\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\n\t\t\t<path :d=\"path\" />\n\t\t</svg>\n\t\t<!-- eslint-disable-next-line vue/no-v-text-v-html-on-component,vue/no-v-html -->\n\t\t<span v-else v-html=\"cleanSvg\" />\n\t</span>\n</template>\n\n<style lang=\"scss\" scoped>\n.icon-vue {\n\tdisplay: flex;\n\tjustify-content: center;\n\talign-items: center;\n\tmin-width: var(--default-clickable-area);\n\tmin-height: var(--default-clickable-area);\n\topacity: 1;\n\n\t&#{&}--inline {\n\t\tdisplay: inline-flex !important;\n\t\tmin-width: fit-content;\n\t\tmin-height: fit-content;\n\t\tvertical-align: text-bottom;\n\t}\n\n\t// Icon svg wrapper\n\tspan {\n\t\tline-height: 0;\n\t}\n\n\t&:deep(svg) {\n\t\tfill: currentColor;\n\t\twidth: v-bind('iconSize');\n\t\theight: v-bind('iconSize');\n\t\tmax-width: v-bind('iconSize');\n\t\tmax-height: v-bind('iconSize');\n\t}\n\n\t&--directional:deep(svg:dir(rtl)) {\n\t\ttransform: scaleX(-1);\n\t}\n}\n</style>\n"],"names":["_createElementBlock","name","directional","inline","_openBlock","_createElementVNode","path"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAoKA,UAAM,QAAQ;AA2Cd,UAAM,WAAW,SAAS,MAAM,OAAO,MAAM,SAAS,WAAW,GAAG,MAAM,IAAI,OAAO,MAAM,IAAI;AAK/F,UAAM,WAAW,SAAS,MAAM;AAC/B,UAAI,CAAC,MAAM,OAAO,MAAM,MAAM;AAC7B;AAAA,MACD;AAEA,YAAM,MAAM,UAAU,SAAS,MAAM,GAAG;AAExC,YAAM,cAAc,IAAI,UAAA,EAAY,gBAAgB,KAAK,eAAe;AAExE,UAAI,YAAY,cAAc,aAAa,GAAG;AAC7C,aAAK,kBAAkB;AACvB,eAAO;AAAA,MACR;AAEA,UAAI,YAAY,gBAAgB,IAAI;AACnC,oBAAY,gBAAgB,gBAAgB,IAAI;AAAA,MACjD;AAEA,aAAO,YAAY,gBAAgB;AAAA,IACpC,CAAC;;0BAIAA,mBAcO,QAAA;AAAA,QAbL,eAAaC,KAAAA,OAAO,SAAS;AAAA,QAC7B,cAAYA,KAAAA,QAAQ;AAAA,QACrB,uBAAM,YAAU;AAAA,mCACsBC,KAAAA;AAAAA,8BAAoCC,KAAAA;AAAAA,QAAAA;QAI1E,MAAK;AAAA,MAAA;SACO,SAAA,SAAZC,aAAAJ,mBAEM,OAFN,YAEM;AAAA,UADLK,mBAAkB,QAAA,EAAX,GAAGC,KAAAA,QAAI,MAAA,GAAA,UAAA;AAAA,QAAA,oBAGfN,mBAAiC,QAAA;AAAA;UAApB,WAAQ,SAAA;AAAA,QAAA;;;;;;"}
@@ -1,8 +1,8 @@
1
- import '../assets/NcInputConfirmCancel-DNNS3DDJ.css';
2
- import { r as register, i as t13, a as t } from "./_l10n-_R1HqC4N.mjs";
1
+ import '../assets/NcInputConfirmCancel-BrdZEfr2.css';
3
2
  import { I as IconArrowRight } from "./ArrowRight-DRKHUZMH.mjs";
4
3
  import { I as IconClose } from "./Close-D6ngJ4t9.mjs";
5
- import { N as NcButton } from "./NcButton-Df1eAyJ3.mjs";
4
+ import { r as register, h as t13, a as t } from "./_l10n-CiWgAjJZ.mjs";
5
+ import { N as NcButton } from "./NcButton-DkC5k3Lb.mjs";
6
6
  import { resolveComponent, createElementBlock, openBlock, createElementVNode, withModifiers, withKeys, withDirectives, createVNode, vModelText, withCtx } from "vue";
7
7
  import { _ as _export_sfc } from "./_plugin-vue_export-helper-1tPrXgE0.mjs";
8
8
  register(t13);
@@ -21,10 +21,16 @@ const _sfc_main = {
21
21
  default: false,
22
22
  type: Boolean
23
23
  },
24
+ /**
25
+ * Placeholder of the edit field
26
+ */
24
27
  placeholder: {
25
28
  default: "",
26
29
  type: String
27
30
  },
31
+ /**
32
+ * The current name (model value)
33
+ */
28
34
  modelValue: {
29
35
  default: "",
30
36
  type: String
@@ -110,8 +116,8 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
110
116
  ], 32)
111
117
  ]);
112
118
  }
113
- const NcInputConfirmCancel = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-71f6ed5a"]]);
119
+ const NcInputConfirmCancel = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-dd457d48"]]);
114
120
  export {
115
121
  NcInputConfirmCancel as N
116
122
  };
117
- //# sourceMappingURL=NcInputConfirmCancel-RRwim02d.mjs.map
123
+ //# sourceMappingURL=NcInputConfirmCancel-DC6lvX7Z.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcInputConfirmCancel-DC6lvX7Z.mjs","sources":["../../src/components/NcAppNavigationItem/NcInputConfirmCancel.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n# Usage\n\n```\n<NcInputConfirmCancel @confirm=\"alert('confirm')\" @cancel=\"alert('cancel')\" />\n```\n</docs>\n\n<template>\n\t<div class=\"app-navigation-input-confirm\">\n\t\t<form\n\t\t\t@submit.prevent=\"confirm\"\n\t\t\t@keydown.esc.exact.stop.prevent=\"cancel\"\n\t\t\t@click.stop.prevent>\n\t\t\t<input\n\t\t\t\tref=\"input\"\n\t\t\t\tv-model=\"valueModel\"\n\t\t\t\ttype=\"text\"\n\t\t\t\tclass=\"app-navigation-input-confirm__input\"\n\t\t\t\t:placeholder=\"placeholder\">\n\n\t\t\t<NcButton\n\t\t\t\t:aria-label=\"labelConfirm\"\n\t\t\t\ttype=\"submit\"\n\t\t\t\tvariant=\"primary\"\n\t\t\t\t@click.stop.prevent=\"confirm\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<IconArrowRight :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t</NcButton>\n\n\t\t\t<NcButton\n\t\t\t\t:aria-label=\"labelCancel\"\n\t\t\t\ttype=\"reset\"\n\t\t\t\t:variant=\"primary ? 'primary' : 'tertiary'\"\n\t\t\t\t@click.stop.prevent=\"cancel\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<IconClose :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t</NcButton>\n\t\t</form>\n\t</div>\n</template>\n\n<script>\nimport IconArrowRight from 'vue-material-design-icons/ArrowRight.vue'\nimport IconClose from 'vue-material-design-icons/Close.vue'\nimport { t } from '../../l10n.ts'\nimport NcButton from '../NcButton/index.js'\n\nexport default {\n\tname: 'NcInputConfirmCancel',\n\n\tcomponents: {\n\t\tIconArrowRight,\n\t\tIconClose,\n\t\tNcButton,\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * If this element is used on a primary element set to true for primary styling.\n\t\t */\n\t\tprimary: {\n\t\t\tdefault: false,\n\t\t\ttype: Boolean,\n\t\t},\n\n\t\t/**\n\t\t * Placeholder of the edit field\n\t\t */\n\t\tplaceholder: {\n\t\t\tdefault: '',\n\t\t\ttype: String,\n\t\t},\n\n\t\t/**\n\t\t * The current name (model value)\n\t\t */\n\t\tmodelValue: {\n\t\t\tdefault: '',\n\t\t\ttype: String,\n\t\t},\n\t},\n\n\temits: [\n\t\t'cancel',\n\t\t'confirm',\n\t\t'update:modelValue',\n\t],\n\n\tdata() {\n\t\treturn {\n\t\t\tlabelConfirm: t('Confirm changes'),\n\t\t\tlabelCancel: t('Cancel changes'),\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tvalueModel: {\n\t\t\tget() { return this.modelValue },\n\t\t\tset(newValue) {\n\t\t\t\tthis.$emit('update:modelValue', newValue)\n\t\t\t},\n\t\t},\n\t},\n\n\tmethods: {\n\t\tconfirm() {\n\t\t\tthis.$emit('confirm')\n\t\t},\n\n\t\tcancel() {\n\t\t\tthis.$emit('cancel')\n\t\t},\n\n\t\tfocusInput() {\n\t\t\tthis.$refs.input.focus()\n\t\t},\n\t},\n}\n</script>\n\n<style scoped lang=\"scss\">\n$input-height: 34px;\n$input-padding: 7px;\n$input-margin: 5px;\n\n.app-navigation-input-confirm {\n\tflex: 1 0 100%;\n\twidth: 100%;\n\n\tform {\n\t\tdisplay: flex;\n\t}\n\n\t&__input {\n\t\theight: $input-height;\n\t\tflex: 1 1 100%;\n\t\tfont-size: 100% !important;\n\t\tmargin: $input-margin !important;\n\t\tmargin-inline-start: -1px - $input-padding !important;\n\t\tpadding: $input-padding !important;\n\n\t\t&:active,\n\t\t&:focus,\n\t\t&:hover {\n\t\t\toutline: none;\n\t\t\tbackground-color: var(--color-main-background);\n\t\t\tcolor: var(--color-main-text);\n\t\t\tborder-color: var(--color-primary-element);\n\t\t}\n\t}\n}\n</style>\n"],"names":["_openBlock","_createElementBlock","_createElementVNode","_createVNode"],"mappings":";;;;;;;AAuDA,MAAK,YAAU;AAAA,EACd,MAAM;AAAA,EAEN,YAAY;AAAA,IACX;AAAA,IACA;AAAA,IACA;AAAA;EAGD,OAAO;AAAA;AAAA;AAAA;AAAA,IAIN,SAAS;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA;;;;IAMP,aAAa;AAAA,MACZ,SAAS;AAAA,MACT,MAAM;AAAA;;;;IAMP,YAAY;AAAA,MACX,SAAS;AAAA,MACT,MAAM;AAAA;;EAIR,OAAO;AAAA,IACN;AAAA,IACA;AAAA,IACA;AAAA;EAGD,OAAO;AACN,WAAO;AAAA,MACN,cAAc,EAAE,iBAAiB;AAAA,MACjC,aAAa,EAAE,gBAAgB;AAAA,IAChC;AAAA,EACD;AAAA,EAEA,UAAU;AAAA,IACT,YAAY;AAAA,MACX,MAAM;AAAE,eAAO,KAAK;AAAA,MAAW;AAAA,MAC/B,IAAI,UAAU;AACb,aAAK,MAAM,qBAAqB,QAAQ;AAAA,MACzC;AAAA;;EAIF,SAAS;AAAA,IACR,UAAU;AACT,WAAK,MAAM,SAAS;AAAA,IACrB;AAAA,IAEA,SAAS;AACR,WAAK,MAAM,QAAQ;AAAA,IACpB;AAAA,IAEA,aAAa;AACZ,WAAK,MAAM,MAAM,MAAK;AAAA,IACvB;AAAA;AAEF;AA/GM,MAAA,aAAA,EAAA,OAAM,+BAA8B;;;;;;AAAzC,SAAAA,UAAA,GAAAC,mBAgCM,OAhCN,YAgCM;AAAA,IA/BLC,mBA8BO,QAAA;AAAA,MA7BL,+DAAgB,SAAA,WAAA,SAAA,QAAA,GAAA,IAAA,GAAO,CAAA,SAAA,CAAA;AAAA,MACvB,yEAAgC,SAAA,UAAA,SAAA,OAAA,GAAA,IAAA,GAAM,CAAA,SAAA,QAAA,SAAA,CAAA,GAAA,CAAA,KAAA,CAAA;AAAA,MACtC,iDAAD,MAAA;AAAA,MAAA,GAAmB,CAAA,QAAA,SAAA,CAAA;AAAA;qBACnBA,mBAK4B,SAAA;AAAA,QAJ3B,KAAI;AAAA,qEACK,SAAA,aAAU;AAAA,QACnB,MAAK;AAAA,QACL,OAAM;AAAA,QACL,aAAa,OAAA;AAAA;qBAHL,SAAA,UAAU;AAAA;MAKpBC,YAQW,qBAAA;AAAA,QAPT,cAAY,MAAA;AAAA,QACb,MAAK;AAAA,QACL,SAAQ;AAAA,QACP,uBAAoB,SAAA,SAAO,CAAA,QAAA,SAAA,CAAA;AAAA;QACjB,cACV,MAA6B;AAAA,UAA7BA,YAA6B,2BAAA,EAAZ,MAAM,GAAE,CAAA;AAAA;;;MAI3BA,YAQW,qBAAA;AAAA,QAPT,cAAY,MAAA;AAAA,QACb,MAAK;AAAA,QACJ,SAAS,OAAA,UAAO,YAAA;AAAA,QAChB,uBAAoB,SAAA,QAAM,CAAA,QAAA,SAAA,CAAA;AAAA;QAChB,cACV,MAAwB;AAAA,UAAxBA,YAAwB,sBAAA,EAAZ,MAAM,GAAE,CAAA;AAAA;;;;;;;"}
@@ -1,9 +1,10 @@
1
- import '../assets/NcInputField-BeU51nfg.css';
2
- import { defineComponent, mergeModels, useModel, useAttrs, useTemplateRef, computed, warn, createElementBlock, openBlock, normalizeClass, createElementVNode, createCommentVNode, withDirectives, createBlock, mergeProps, toDisplayString, renderSlot, vShow, unref, withCtx, createTextVNode } from "vue";
3
- import { d as mdiCheck, e as mdiAlertCircle } from "./mdi-D6fu5i4r.mjs";
4
- import { N as NcButton } from "./NcButton-Df1eAyJ3.mjs";
5
- import { N as NcIconSvgWrapper } from "./NcIconSvgWrapper-CprKb_SE.mjs";
1
+ import '../assets/NcInputField-CVSrajMb.css';
2
+ import { defineComponent, mergeModels, useModel, useAttrs, useTemplateRef, computed, warn, createElementBlock, openBlock, normalizeClass, unref, createElementVNode, createCommentVNode, withDirectives, createBlock, mergeProps, toDisplayString, renderSlot, vShow, withCtx, createTextVNode } from "vue";
3
+ import { d as mdiCheck, e as mdiAlertCircle } from "./mdi-DXaZM2k3.mjs";
6
4
  import { c as createElementId } from "./createElementId-DhjFt1I9.mjs";
5
+ import { i as isLegacy } from "./legacy-DcjXBL_t.mjs";
6
+ import { N as NcButton } from "./NcButton-DkC5k3Lb.mjs";
7
+ import { N as NcIconSvgWrapper } from "./NcIconSvgWrapper-5AA93z-F.mjs";
7
8
  import { _ as _export_sfc } from "./_plugin-vue_export-helper-1tPrXgE0.mjs";
8
9
  const _hoisted_1 = { class: "input-field__main-wrapper" };
9
10
  const _hoisted_2 = ["id", "aria-describedby", "disabled", "placeholder", "type", "value"];
@@ -38,18 +39,19 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
38
39
  "modelValue": { required: true },
39
40
  "modelModifiers": {}
40
41
  }),
41
- emits: /* @__PURE__ */ mergeModels(["trailing-button-click"], ["update:modelValue"]),
42
+ emits: /* @__PURE__ */ mergeModels(["trailingButtonClick"], ["update:modelValue"]),
42
43
  setup(__props, { expose: __expose, emit: __emit }) {
43
- const props = __props;
44
44
  const modelValue = useModel(__props, "modelValue");
45
+ const props = __props;
45
46
  const emit = __emit;
46
47
  __expose({
47
48
  focus,
48
49
  select
49
50
  });
50
51
  const attrs = useAttrs();
51
- const input = useTemplateRef("input");
52
+ const input = useTemplateRef("input-key");
52
53
  const hasTrailingIcon = computed(() => props.showTrailingButton || props.success);
54
+ const internalPlaceholder = computed(() => props.placeholder || (isLegacy ? props.label : void 0));
53
55
  const isValidLabel = computed(() => {
54
56
  const isValidLabel2 = props.label || props.labelOutside;
55
57
  if (!isValidLabel2) {
@@ -86,19 +88,19 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
86
88
  "input-field--leading-icon": !!_ctx.$slots.icon,
87
89
  "input-field--trailing-icon": hasTrailingIcon.value,
88
90
  "input-field--pill": _ctx.pill,
89
- "input-field--success": _ctx.success
91
+ "input-field--success": _ctx.success,
92
+ "input-field--legacy": unref(isLegacy)
90
93
  }, _ctx.$props.class]])
91
94
  }, [
92
95
  createElementVNode("div", _hoisted_1, [
93
96
  createElementVNode("input", mergeProps(_ctx.$attrs, {
94
97
  id: _ctx.id,
95
- ref_key: "input",
96
- ref: input,
98
+ ref: "input-key",
97
99
  "aria-describedby": ariaDescribedby.value,
98
100
  "aria-live": "polite",
99
101
  class: ["input-field__input", _ctx.inputClass],
100
102
  disabled: _ctx.disabled,
101
- placeholder: _ctx.placeholder || _ctx.label,
103
+ placeholder: internalPlaceholder.value,
102
104
  type: _ctx.type,
103
105
  value: modelValue.value.toString(),
104
106
  onInput: handleInput
@@ -119,7 +121,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
119
121
  "aria-label": _ctx.trailingButtonLabel,
120
122
  disabled: _ctx.disabled,
121
123
  variant: "tertiary-no-background",
122
- onClick: _cache[0] || (_cache[0] = ($event) => emit("trailing-button-click", $event))
124
+ onClick: _cache[0] || (_cache[0] = ($event) => emit("trailingButtonClick", $event))
123
125
  }, {
124
126
  icon: withCtx(() => [
125
127
  renderSlot(_ctx.$slots, "trailing-button-icon", {}, void 0, true)
@@ -155,8 +157,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
155
157
  };
156
158
  }
157
159
  });
158
- const NcInputField = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-7e9dfc46"]]);
160
+ const NcInputField = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-dd9bf35e"]]);
159
161
  export {
160
162
  NcInputField as N
161
163
  };
162
- //# sourceMappingURL=NcInputField-DEHb834Z.mjs.map
164
+ //# sourceMappingURL=NcInputField-DugqxUR2.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcInputField-DugqxUR2.mjs","sources":["../../src/components/NcInputField/NcInputField.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n### Description\n\nThis component is used by the other Fields components.\nIt extends and styles an HTMLInputElement.\n\nYou cannot use it as is. This is here for documentation purposes.\nSee the other field components.\n\nFor a list of all available props and attributes, please check the [HTMLInputElement documentation](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#attributes)\n\n</docs>\n\n<script setup lang=\"ts\">\nimport type { Slot } from 'vue'\nimport type { VueClassType } from '../../utils/VueTypes.ts'\n\nimport { mdiAlertCircle, mdiCheck } from '@mdi/js'\nimport { computed, useAttrs, useTemplateRef, warn } from 'vue'\nimport { createElementId } from '../../utils/createElementId.ts'\nimport { isLegacy } from '../../utils/legacy.ts'\nimport NcButton from '../NcButton/index.ts'\nimport NcIconSvgWrapper from '../NcIconSvgWrapper/index.ts'\n\nexport interface NcInputFieldProps {\n\t/**\n\t * Class to add to the root component.\n\t */\n\tclass?: VueClassType\n\n\t/**\n\t * Class to add to the input field.\n\t * Necessary to use NcInputField in the NcActionInput component.\n\t */\n\tinputClass?: VueClassType\n\n\t/**\n\t * HTML id of the input field\n\t */\n\tid?: string\n\n\t/**\n\t * The input label, always provide one for accessibility purposes.\n\t * On Nextcloud before version 32 this will also be used as a placeholder unless the placeholder\n\t * prop is populated with a different string.\n\t *\n\t * Note: If the background color is not `--color-main-background` consider using an external label instead (see `labelOutside`).\n\t */\n\tlabel?: string\n\n\t/**\n\t * Pass in true if you want to use an external label. This is useful\n\t * if you need a label that looks different from the one provided by\n\t * this component\n\t */\n\tlabelOutside?: boolean\n\n\t/**\n\t * The type of the input element\n\t */\n\ttype?: 'text' | 'password' | 'email' | 'tel' | 'url' | 'search' | 'number'\n\n\t/**\n\t * The placeholder of the input.\n\t * On Nextcloud before version 32 this would default to the `label` prop.\n\t * On Nextcloud 32 and on v9 of this library it will no longer have a default value.\n\t */\n\tplaceholder?: string\n\n\t/**\n\t * Controls whether to display the trailing button.\n\t */\n\tshowTrailingButton?: boolean\n\n\t/**\n\t * Label of the trailing button\n\t *\n\t * Required when showTrailingButton is set\n\t */\n\ttrailingButtonLabel?: string\n\n\t/**\n\t * Toggles the success state of the component. Adds a checkmark icon.\n\t */\n\tsuccess?: boolean\n\n\t/**\n\t * Toggles the error state of the component. Adds an error icon.\n\t */\n\terror?: boolean\n\n\t/**\n\t * Additional helper text message\n\t *\n\t * This will be displayed beneath the input field. In case the field is\n\t * also marked as having an error, the text will be displayed in red.\n\t */\n\thelperText?: string\n\n\t/**\n\t * Disable the input field\n\t */\n\tdisabled?: boolean\n\n\t/**\n\t * Specifies whether the input should have a pill form.\n\t * By default, input has rounded corners.\n\t */\n\tpill?: boolean\n}\n\ndefineOptions({\n\tinheritAttrs: false,\n})\n\n/**\n * The value of the input field\n * If type is 'number' and a number is passed as value than the type of `update:value` will also be 'number'\n */\nconst modelValue = defineModel<string | number>({ required: true })\n\nconst props = withDefaults(defineProps<NcInputFieldProps>(), {\n\tclass: '',\n\thelperText: '',\n\tid: () => createElementId(),\n\tinputClass: '',\n\tlabel: undefined,\n\tplaceholder: undefined,\n\ttrailingButtonLabel: undefined,\n\ttype: 'text',\n})\n\nconst emit = defineEmits<{\n\ttrailingButtonClick: [event: MouseEvent]\n}>()\n\ndefineSlots<{\n\t/**\n\t * Leading icon, set the size to 20.\n\t */\n\ticon?: Slot\n\n\t/**\n\t * Icon for the trailing button.\n\t */\n\t'trailing-button-icon'?: Slot\n}>()\n\n// public API\ndefineExpose({\n\tfocus,\n\tselect,\n})\n\nconst attrs = useAttrs()\n\nconst input = useTemplateRef('input-key')\n\nconst hasTrailingIcon = computed(() => props.showTrailingButton || props.success)\n\nconst internalPlaceholder = computed(() => props.placeholder || (isLegacy ? props.label : undefined))\n\nconst isValidLabel = computed(() => {\n\tconst isValidLabel = props.label || props.labelOutside\n\tif (!isValidLabel) {\n\t\twarn('You need to add a label to the NcInputField component. Either use the prop label or use an external one, as per the example in the documentation.')\n\t}\n\treturn isValidLabel\n})\n\nconst ariaDescribedby = computed(() => {\n\tconst ariaDescribedby: string[] = []\n\tif (props.helperText) {\n\t\tariaDescribedby.push(`${props.id}-helper-text`)\n\t}\n\tif (attrs['aria-describedby']) {\n\t\tariaDescribedby.push(String(attrs['aria-describedby']))\n\t}\n\treturn ariaDescribedby.join(' ') || undefined\n})\n\n/**\n * Focus the input element\n *\n * @param options - Focus options\n * @public\n */\nfunction focus(options?: FocusOptions) {\n\tinput.value!.focus(options)\n}\n\n/**\n * Select all the text in the input\n *\n * @public\n */\nfunction select() {\n\tinput.value!.select()\n}\n\n/**\n * Handle the input event of the HTML input.\n * Parses numbers in case of numeric type.\n *\n * @param event - The input event\n */\nfunction handleInput(event: Event) {\n\tconst target = event.target as HTMLInputElement\n\tmodelValue.value = props.type === 'number' && typeof modelValue.value === 'number'\n\t\t? parseFloat(target.value)\n\t\t: target.value\n}\n</script>\n\n<template>\n\t<div\n\t\tclass=\"input-field\"\n\t\t:class=\"[{\n\t\t\t'input-field--disabled': disabled,\n\t\t\t'input-field--error': error,\n\t\t\t'input-field--label-outside': labelOutside || !isValidLabel,\n\t\t\t'input-field--leading-icon': !!$slots.icon,\n\t\t\t'input-field--trailing-icon': hasTrailingIcon,\n\t\t\t'input-field--pill': pill,\n\t\t\t'input-field--success': success,\n\t\t\t'input-field--legacy': isLegacy,\n\t\t}, $props.class]\">\n\t\t<div class=\"input-field__main-wrapper\">\n\t\t\t<input\n\t\t\t\tv-bind=\"$attrs\"\n\t\t\t\t:id\n\t\t\t\tref=\"input-key\"\n\t\t\t\t:aria-describedby=\"ariaDescribedby\"\n\t\t\t\taria-live=\"polite\"\n\t\t\t\tclass=\"input-field__input\"\n\t\t\t\t:class=\"inputClass\"\n\t\t\t\t:disabled\n\t\t\t\t:placeholder=\"internalPlaceholder\"\n\t\t\t\t:type\n\t\t\t\t:value=\"modelValue.toString()\"\n\t\t\t\t@input=\"handleInput\">\n\t\t\t<!-- Label -->\n\t\t\t<label\n\t\t\t\tv-if=\"!labelOutside && isValidLabel\"\n\t\t\t\tclass=\"input-field__label\"\n\t\t\t\t:for=\"id\">\n\t\t\t\t{{ label }}\n\t\t\t</label>\n\n\t\t\t<!-- Leading icon -->\n\t\t\t<div v-show=\"!!$slots.icon\" class=\"input-field__icon input-field__icon--leading\">\n\t\t\t\t<slot name=\"icon\" />\n\t\t\t</div>\n\n\t\t\t<!-- trailing button -->\n\t\t\t<NcButton\n\t\t\t\tv-if=\"showTrailingButton\"\n\t\t\t\tclass=\"input-field__trailing-button\"\n\t\t\t\t:aria-label=\"trailingButtonLabel\"\n\t\t\t\t:disabled=\"disabled\"\n\t\t\t\tvariant=\"tertiary-no-background\"\n\t\t\t\t@click=\"emit('trailingButtonClick', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<slot name=\"trailing-button-icon\" />\n\t\t\t\t</template>\n\t\t\t</NcButton>\n\n\t\t\t<!-- Success and error icons -->\n\t\t\t<div\n\t\t\t\tv-else-if=\"success || error\"\n\t\t\t\tclass=\"input-field__icon input-field__icon--trailing\">\n\t\t\t\t<NcIconSvgWrapper v-if=\"success\" :path=\"mdiCheck\" />\n\t\t\t\t<NcIconSvgWrapper v-else :path=\"mdiAlertCircle\" />\n\t\t\t</div>\n\t\t</div>\n\t\t<p\n\t\t\tv-if=\"helperText\"\n\t\t\t:id=\"`${id}-helper-text`\"\n\t\t\tclass=\"input-field__helper-text-message\">\n\t\t\t<NcIconSvgWrapper v-if=\"success\" class=\"input-field__helper-text-message__icon\" :path=\"mdiCheck\" />\n\t\t\t<NcIconSvgWrapper v-else-if=\"error\" class=\"input-field__helper-text-message__icon\" :path=\"mdiAlertCircle\" />\n\t\t\t{{ helperText }}\n\t\t</p>\n\t</div>\n</template>\n\n<style lang=\"scss\" scoped>\n\n.input-field {\n\t--input-border-color: var(--color-border-maxcontrast);\n\t--input-border-radius: var(--border-radius-element);\n\t// Used e.g. if border width differs between focused and unfocused we need to compensate to prevent jumping\n\t--input-border-width-offset: calc(var(--border-width-input-focused, 2px) - var(--border-width-input, 2px));\n\t// The padding before the input can start (leading button or border)\n\t--input-padding-start: var(--border-radius-element);\n\t// The padding where the input has to end (trailing button or border)\n\t--input-padding-end: var(--border-radius-element);\n\t// positional styles\n\tposition: relative;\n\twidth: 100%;\n\tmargin-block-start: 6px; // for the label in active state\n\n\t&--disabled {\n\t\topacity: 0.4;\n\t\tfilter: saturate(0.4);\n\t}\n\n\t// If there is no internal label we reset the margin reserved for it\n\t&--label-outside {\n\t\tmargin-block-start: 0;\n\t}\n\n\t&--leading-icon {\n\t\t--input-padding-start: calc(var(--default-clickable-area) - var(--default-grid-baseline));\n\t}\n\n\t&--trailing-icon {\n\t\t--input-padding-end: calc(var(--default-clickable-area) - var(--default-grid-baseline));\n\t}\n\n\t&--pill {\n\t\t--input-border-radius: var(--border-radius-pill);\n\t}\n\n\t&__main-wrapper {\n\t\theight: var(--default-clickable-area);\n\t\tpadding: var(--border-width-input, 2px);\n\t\tposition: relative;\n\n\t\t&:not(:has([disabled])):has(input:focus),\n\t\t&:not(:has([disabled])):has(input:active) {\n\t\t\tpadding: 0;\n\t\t}\n\t}\n\n\t&__input {\n\t\tbackground-color: var(--color-main-background);\n\t\tcolor: var(--color-main-text);\n\t\tborder: none;\n\t\tborder-radius: var(--input-border-radius);\n\t\tbox-shadow:\n\t\t\t0 -1px var(--input-border-color),\n\t\t\t0 0 0 1px color-mix(in srgb, var(--input-border-color), 65% transparent);\n\n\t\tcursor: pointer;\n\t\t-webkit-appearance: textfield !important;\n\t\t-moz-appearance: textfield !important;\n\t\tappearance: textfield !important;\n\n\t\tfont-size: var(--default-font-size);\n\t\ttext-overflow: ellipsis;\n\n\t\theight: 100% !important;\n\t\tmin-height: unset;\n\t\twidth: 100%;\n\t\tpadding-block: var(--input-border-width-offset);\n\t\tpadding-inline: calc(var(--input-padding-start) + var(--input-border-width-offset)) calc(var(--input-padding-end) + var(--input-border-width-offset));\n\n\t\t&::placeholder {\n\t\t\tcolor: var(--color-text-maxcontrast);\n\t\t}\n\n\t\t// prevent Blink and WebKit to add an additional button when type is set to search\n\t\t// we have our properly styled trailing button anyways.\n\t\t&::-webkit-search-cancel-button {\n\t\t\t// its a weird bug in Blink that this rule must not be grouped with the other selectors below.\n\t\t\t// otherwise it is not recognized by Blink\n\t\t\tdisplay: none;\n\t\t}\n\t\t&::-webkit-search-decoration,\n\t\t&::-webkit-search-results-button,\n\t\t&::-webkit-search-results-decoration,\n\t\t&::-ms-clear {\n\t\t\tdisplay: none;\n\t\t}\n\n\t\t&:hover:not([disabled]) {\n\t\t\tbox-shadow: 0 0 0 1px var(--input-border-color);;\n\t\t}\n\n\t\t&:active:not([disabled]),\n\t\t&:focus:not([disabled]) {\n\t\t\t--input-border-color: var(--color-main-text);\n\t\t\t// Reset padding offset when focused\n\t\t\t--input-border-width-offset: 0px;\n\t\t\tborder: var(--border-width-input-focused, 2px) solid var(--input-border-color);\n\t\t\tbox-shadow: 0 0 0 2px var(--color-main-background) !important;\n\t\t}\n\n\t\t&:focus + .input-field__label,\n\t\t&:hover:not(:placeholder-shown) + .input-field__label {\n\t\t\tcolor: var(--color-main-text);\n\t\t}\n\n\t\t&:focus {\n\t\t\tcursor: text;\n\t\t}\n\n\t\t&:disabled {\n\t\t\tcursor: default;\n\t\t}\n\n\t\t&:focus-visible {\n\t\t\tbox-shadow: unset !important; // Override server rules\n\t\t}\n\t}\n\n\t// Hide placeholder while not focussed -> show label instead (only if internal label is used)\n\t&:not(&--label-outside) &__input:not(:focus)::placeholder {\n\t\topacity: 0;\n\t}\n\n\t&__label {\n\t\t--input-label-font-size: var(--default-font-size);\n\t\tfont-size: var(--input-label-font-size);\n\n\t\tposition: absolute;\n\t\tmargin-inline: var(--input-padding-start) var(--input-padding-end);\n\t\tmax-width: fit-content;\n\t\tinset-block-start: calc((var(--default-clickable-area) - 1lh) / 2); // center the label vertically\n\t\tinset-inline: var(--border-width-input-focused, 2px);\n\n\t\t// Fix color so that users do not think the input already has content\n\t\tcolor: var(--color-text-maxcontrast);\n\t\t// only one line labels are allowed\n\t\twhite-space: nowrap;\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\t// forward events to input\n\t\tpointer-events: none;\n\t\t// Position transition\n\t\ttransition: height var(--animation-quick), inset-block-start var(--animation-quick), font-size var(--animation-quick), color var(--animation-quick), background-color var(--animation-quick) var(--animation-slow);\n\t}\n\n\t&__input:focus + &__label,\n\t&__input:not(:placeholder-shown) + &__label {\n\t\t--input-label-font-size: 13px; // minimum allowed font size for accessibility\n\t\tline-height: 1.5; // minimum allowed line height for accessibility\n\t\t// 1.5 * font-size = line-height; line-height / 2 for centering and make it negative as we need to move outside the element\n\t\tinset-block-start: calc(-1.5 * var(--input-label-font-size) / 2);\n\t\tfont-weight: 500;\n\t\tborder-radius: var(--default-grid-baseline) var(--default-grid-baseline) 0 0;\n\t\tbackground-color: var(--color-main-background);\n\t\tpadding-inline: var(--default-grid-baseline);\n\t\tmargin-inline: calc(var(--input-padding-start) - var(--default-grid-baseline)) calc(var(--input-padding-end) - var(--default-grid-baseline));\n\n\t\ttransition: height var(--animation-quick), inset-block-start var(--animation-quick), font-size var(--animation-quick), color var(--animation-quick);\n\t}\n\n\t&__icon {\n\t\tposition: absolute;\n\t\theight: var(--default-clickable-area);\n\t\twidth: var(--default-clickable-area);\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: center;\n\t\topacity: 0.7;\n\n\t\tinset-block-end: 0;\n\n\t\t&--leading {\n\t\t\tinset-inline-start: 0px;\n\t\t}\n\n\t\t&--trailing {\n\t\t\tinset-inline-end: 0px;\n\t\t}\n\t}\n\n\t&__trailing-button {\n\t\t--button-size: calc(var(--default-clickable-area) - 2 * var(--border-width-input-focused, 2px)) !important;\n\t\t--button-radius: calc(var(--input-border-radius) - var(--border-width-input-focused, 2px)); // lower radius as size is smaller\n\n\t\t&.button-vue {\n\t\t\tposition: absolute;\n\t\t\ttop: var(--border-width-input-focused, 2px);\n\t\t\tinset-inline-end: var(--border-width-input-focused, 2px);\n\n\t\t\t&:focus-visible {\n\t\t\t\tbox-shadow: none !important;\n\t\t\t}\n\t\t}\n\t}\n\n\t&__helper-text-message {\n\t\tpadding-block: 4px;\n\t\tpadding-inline: var(--border-radius-element);\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tcolor: var(--color-text-maxcontrast);\n\n\t\t&__icon {\n\t\t\tmargin-inline-end: 8px;\n\t\t}\n\t}\n\n\t&--error {\n\t\t.input-field__helper-text-message,\n\t\t.input-field__icon--trailing {\n\t\t\tcolor: var(--color-text-error, var(--color-error));\n\t\t}\n\t}\n\n\t&--error .input-field__input,\n\t&__input:user-invalid {\n\t\t--input-border-color: var(--color-border-error, var(--color-error)) !important; //Override hover border color\n\t\t&:focus-visible {\n\t\t\tbox-shadow: rgb(248, 250, 252) 0px 0px 0px 2px, var(--color-primary-element) 0px 0px 0px 4px, rgba(0, 0, 0, 0.05) 0px 1px 2px 0px\n\t\t}\n\t}\n\n\t&--success {\n\t\t.input-field__input {\n\t\t\t--input-border-color: var(--color-border-success, var(--color-success)) !important; //Override hover border color\n\t\t\t&:focus-visible {\n\t\t\t\tbox-shadow: rgb(248, 250, 252) 0px 0px 0px 2px, var(--color-primary-element) 0px 0px 0px 4px, rgba(0, 0, 0, 0.05) 0px 1px 2px 0px\n\t\t\t}\n\t\t}\n\t\t.input-field__helper-text-message__icon {\n\t\t\tcolor: var(--color-border-success, var(--color-success));\n\t\t}\n\t}\n\n\t&--legacy {\n\t\t.input-field__input {\n\t\t\tbox-shadow: 0 0 0 1px var(--input-border-color) inset;\n\t\t}\n\n\t\t.input-field__main-wrapper:hover:not(:has([disabled])) {\n\t\t\tpadding: 0;\n\n\t\t\t.input-field__input {\n\t\t\t\t--input-border-color: var(--color-main-text);\n\t\t\t\t// Reset padding offset when focused\n\t\t\t\t--input-border-width-offset: 0px;\n\t\t\t\tborder: var(--border-width-input-focused, 2px) solid var(--input-border-color);\n\t\t\t\tbox-shadow: 0 0 0 2px var(--color-main-background) !important;\n\t\t\t}\n\t\t}\n\t}\n}\n</style>\n"],"names":["_useModel","isValidLabel","ariaDescribedby","_createElementBlock","disabled","error","labelOutside","$slots","pill","success","_unref","$props","_createElementVNode","_mergeProps","id","inputClass","type","label","_withDirectives","_renderSlot","showTrailingButton","_createBlock","trailingButtonLabel","_openBlock","helperText","_createTextVNode"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
- import '../assets/NcListItem-BBaZDZQK.css';
2
- import { N as NcActions } from "./NcActions-CyXKvnrY.mjs";
3
- import { N as NcCounterBubble } from "./NcCounterBubble-Bop3e-Tr.mjs";
1
+ import '../assets/NcListItem-BRTO5Id3.css';
2
+ import { N as NcActions } from "./NcActions-BOqfKgN5.mjs";
3
+ import { N as NcCounterBubble } from "./NcCounterBubble-CxxHHh8i.mjs";
4
4
  import { _ as _sfc_main$1 } from "./NcVNodes.vue_vue_type_script_lang-BqUHinRZ.mjs";
5
5
  import { resolveComponent, createBlock, openBlock, resolveDynamicComponent, normalizeProps, guardReactiveProps, withCtx, createElementVNode, mergeProps, normalizeClass, createElementBlock, createCommentVNode, withDirectives, withKeys, renderSlot, createTextVNode, toDisplayString, vShow, createVNode, createSlots } from "vue";
6
6
  import { _ as _export_sfc } from "./_plugin-vue_export-helper-1tPrXgE0.mjs";
@@ -41,6 +41,9 @@ const _sfc_main = {
41
41
  type: String,
42
42
  default: "#"
43
43
  },
44
+ /**
45
+ * The HTML target attribute used for the link
46
+ */
44
47
  target: {
45
48
  type: String,
46
49
  default: ""
@@ -131,13 +134,6 @@ const _sfc_main = {
131
134
  "click",
132
135
  "update:menuOpen"
133
136
  ],
134
- setup() {
135
- const [major] = window._oc_config?.version.split(".", 2) ?? [];
136
- const isLegacy = major && Number.parseInt(major) < 30;
137
- return {
138
- isLegacy
139
- };
140
- },
141
137
  data() {
142
138
  return {
143
139
  hovered: false,
@@ -280,7 +276,6 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
280
276
  ref: "list-item",
281
277
  class: normalizeClass(["list-item", {
282
278
  "list-item--compact": $props.compact,
283
- "list-item--legacy": $setup.isLegacy,
284
279
  "list-item--one-line": $props.oneLine
285
280
  }]),
286
281
  onMouseover: _cache[4] || (_cache[4] = (...args) => $options.handleMouseover && $options.handleMouseover(...args)),
@@ -375,8 +370,8 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
375
370
  _: 3
376
371
  }, 16);
377
372
  }
378
- const NcListItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-40915be5"]]);
373
+ const NcListItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-56c9c89e"]]);
379
374
  export {
380
375
  NcListItem as N
381
376
  };
382
- //# sourceMappingURL=NcListItem-C6WoTIa4.mjs.map
377
+ //# sourceMappingURL=NcListItem-C2YXq4EL.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcListItem-C2YXq4EL.mjs","sources":["../../src/components/NcListItem/NcListItem.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2021 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n\n### Default Usage\n\n```vue\n<template>\n\t<ul>\n\t\t<NcListItem active\n\t\t\tbold\n\t\t\t:counter-number=\"123\"\n\t\t\tcounterType=\"highlighted\"\n\t\t\tdetails=\"1h\"\n\t\t\tname=\"This is an active element with highlighted counter\">\n\t\t\t<template #icon>\n\t\t\t\t<NcAvatar disable-menu :size=\"44\" user=\"janedoe\" display-name=\"Jane Doe\" />\n\t\t\t</template>\n\t\t\t<template #subname>\n\t\t\t\tIn this slot you can put both text and other components such as icons\n\t\t\t</template>\n\t\t\t<template #indicator>\n\t\t\t\t<!-- Color dot -->\n\t\t\t\t<CheckboxBlankCircle :size=\"16\" fill-color=\"#fff\" />\n\t\t\t</template>\n\t\t\t<template #actions>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton one\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton two\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton three\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem\n\t\t\tname=\"This is an active element with outlined counter\"\n\t\t\t:bold=\"false\"\n\t\t\t:active=\"true\"\n\t\t\t:counter-number=\"123\"\n\t\t\tcounterType=\"outlined\">\n\t\t\t<template #icon>\n\t\t\t\t<NcAvatar disable-menu :size=\"44\" user=\"janedoe\" display-name=\"Jane Doe\" />\n\t\t\t</template>\n\t\t\t<template #subname>\n\t\t\t\tIn this slot you can put both text and other components such as icons\n\t\t\t</template>\n\t\t\t<template #indicator>\n\t\t\t\t<!-- Color dot -->\n\t\t\t\t<CheckboxBlankCircle :size=\"16\" fill-color=\"#fff\" />\n\t\t\t</template>\n\t\t\t<template #actions>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton one\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton two\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton three\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem\n\t\t\tname=\"This is an active element with normal counter\"\n\t\t\t:bold=\"false\"\n\t\t\t:active=\"true\"\n\t\t\t:counter-number=\"123\">\n\t\t\t<template #icon>\n\t\t\t\t<NcAvatar disable-menu :size=\"44\" user=\"janedoe\" display-name=\"Jane Doe\" />\n\t\t\t</template>\n\t\t\t<template #subname>\n\t\t\t\tIn this slot you can put both text and other components such as icons\n\t\t\t</template>\n\t\t\t<template #details>\n\t\t\t\t<LinkIcon :size=\"16\"/>\n\t\t\t</template>\n\t\t\t<template #indicator>\n\t\t\t\t<!-- Color dot -->\n\t\t\t\t<CheckboxBlankCircle :size=\"16\" fill-color=\"#fff\" />\n\t\t\t</template>\n\t\t\t<template #actions>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton one\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton two\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton three\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem\n\t\t\tname=\"Name of the element with highlighted counter\"\n\t\t\tbold\n\t\t\t:force-display-actions=\"true\"\n\t\t\tdetails=\"1h\"\n\t\t\t:counter-number=\"123\"\n\t\t\tcounterType=\"highlighted\">\n\t\t\t<template #icon>\n\t\t\t\t<NcAvatar disable-menu :size=\"44\" user=\"janedoe\" display-name=\"Jane Doe\" />\n\t\t\t</template>\n\t\t\t<template #subname>\n\t\t\t\tIn this slot you can put both text and other components such as icons\n\t\t\t</template>\n\t\t\t<template #actions>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton one\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton two\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton three\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem\n\t\t\tname=\"Name of the element with outlined counter\"\n\t\t\t:bold=\"false\"\n\t\t\t:force-display-actions=\"true\"\n\t\t\t:counter-number=\"123\"\n\t\t\tcounterType=\"outlined\">\n\t\t\t<template #icon>\n\t\t\t\t<NcAvatar disable-menu :size=\"44\" user=\"janedoe\" display-name=\"Jane Doe\" />\n\t\t\t</template>\n\t\t\t<template #subname>\n\t\t\t\tIn this slot you can put both text and other components such as icons\n\t\t\t</template>\n\t\t\t<template #actions>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton one\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton two\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton three\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem\n\t\t\tname=\"Name of the element with normal counter\"\n\t\t\t:bold=\"false\"\n\t\t\t:force-display-actions=\"true\"\n\t\t\tdetails=\"1h\"\n\t\t\t:counter-number=\"123\">\n\t\t\t<template #icon>\n\t\t\t\t<NcAvatar disable-menu :size=\"44\" user=\"janedoe\" display-name=\"Jane Doe\" />\n\t\t\t</template>\n\t\t\t<template #subname>\n\t\t\t\tIn this slot you can put both text and other components such as icons\n\t\t\t</template>\n\t\t\t<template #actions>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton one\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton two\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton three\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem\n\t\t\tname=\"Name of the element\"\n\t\t\t:bold=\"false\">\n\t\t\t<template #icon>\n\t\t\t\t<NcAvatar disable-menu :size=\"44\" user=\"janedoe\" display-name=\"Jane Doe\" />\n\t\t\t</template>\n\t\t\t<template #name>\n\t\t\t\t<span style=\"display: flex; gap: 0.5rem; color: var(--color-favorite);\">\n\t\t\t\t\tFlexible styling within the first line of the component\n\t\t\t\t\t<div style=\"color: var(--color-text-error, var(--color-error));\">\n\t\t\t\t\t\tlike this.\n\t\t\t\t\t</div>\n\t\t\t\t</span>\n\t\t\t</template>\n\t\t\t<template #subname>\n\t\t\t\tIn this slot you can put both text and other components such as icons\n\t\t\t</template>\n\t\t\t<template #details>\n\t\t\t\t<LinkIcon :size=\"16\"/>\n\t\t\t</template>\n\t\t\t<template #indicator>\n\t\t\t\t<!-- Color dot -->\n\t\t\t\t<CheckboxBlankCircle :size=\"16\" fill-color=\"#0082c9\"/>\n\t\t\t</template>\n\t\t\t<template #actions>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton one\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton two\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton three\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem\n\t\t\tname=\"Without subname, Name of the element\"\n\t\t\t:bold=\"false\"\n\t\t\tdetails=\"1h\">\n\t\t\t<template #icon>\n\t\t\t\t<NcAvatar disable-menu :size=\"44\" user=\"janedoe\" display-name=\"Jane Doe\" />\n\t\t\t</template>\n\t\t\t<template #indicator>\n\t\t\t\t<!-- Color dot -->\n\t\t\t\t<CheckboxBlankCircle :size=\"16\" fill-color=\"#0082c9\"/>\n\t\t\t</template>\n\t\t</NcListItem>\n\t</ul>\n</template>\n\n<script>\n\timport CheckboxBlankCircle from 'vue-material-design-icons/CheckboxBlankCircle'\n\timport LinkIcon from 'vue-material-design-icons/Link'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tCheckboxBlankCircle,\n\t\t\tLinkIcon,\n\t\t}\n\t}\n</script>\n\n```\n\n### NcListItem one line mode\n```vue\n<NcListItem active\n\t:bold=\"false\"\n\t:counter-number=\"123\"\n\tcounterType=\"highlighted\"\n\tdetails=\"1h\"\n\tname=\"This is an active element with highlighted counter\"\n\tone-line>\n\t<template #icon>\n\t\t<NcAvatar disable-menu :size=\"34\" user=\"janedoe\" display-name=\"Jane Doe\" />\n\t</template>\n\t<template #subname>\n\t\tIn this slot you can put both text and other components such as icons\n\t</template>\n\t<template #indicator>\n\t\t<!-- Color dot -->\n\t\t<CheckboxBlankCircle :size=\"20\" fill-color=\"#fff\" />\n\t</template>\n\t<template #actions>\n\t\t<NcActionButton>\n\t\t\tButton one\n\t\t</NcActionButton>\n\t\t<NcActionButton>\n\t\t\tButton two\n\t\t</NcActionButton>\n\t\t<NcActionButton>\n\t\t\tButton three\n\t\t</NcActionButton>\n\t</template>\n</NcListItem>\n```\n### NcListItem with extra actions slot and customized icon\n\nThe `extra-actions` slot can be used to add other interactive components.\n\nThe `actions-icon` slot can be used to pass icon to the inner NcActions component.\n\n```vue\n<template>\n\t<div>\n\t\t<NcListItem\n\t\t\tname=\"This is an active element with extra actions slot\"\n\t\t\tbold\n\t\t\t:active=\"true\"\n\t\t\t:force-display-actions=\"true\">\n\t\t\t<template #icon>\n\t\t\t\t<NcAvatar disable-menu :size=\"44\" user=\"janedoe\" display-name=\"Jane Doe\" />\n\t\t\t</template>\n\t\t\t<template #extra-actions>\n\t\t\t\t<NcButton variant=\"primary\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<IconCog :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t</NcButton>\n\t\t\t</template>\n\t\t\t<template #actions-icon>\n\t\t\t\t<IconNoteText :size=\"20\" />\n\t\t\t</template>\n\t\t\t<template #actions>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton one\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton two\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton three\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem\n\t\t\tname=\"This is an element with extra actions slot\"\n\t\t\tbold>\n\t\t\t<template #icon>\n\t\t\t\t<NcAvatar disable-menu :size=\"44\" user=\"janedoe\" display-name=\"Jane Doe\" />\n\t\t\t</template>\n\t\t\t<template #extra-actions>\n\t\t\t\t<NcButton variant=\"tertiary\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<IconPencil :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t</NcButton>\n\t\t\t\t<NcButton variant=\"tertiary\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<IconCog :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t</NcButton>\n\t\t\t</template>\n\t\t\t<template #actions-icon>\n\t\t\t\t<IconNoteText :size=\"20\" />\n\t\t\t</template>\n\t\t\t<template #actions>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton one\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton two\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton three\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcListItem>\n\t</div>\n</template>\n<script>\n\timport IconCog from 'vue-material-design-icons/Cog.vue'\n\timport IconNoteText from 'vue-material-design-icons/NoteText.vue'\n\timport IconPencil from 'vue-material-design-icons/Pencil.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tIconCog,\n\t\t\tIconNoteText,\n\t\t\tIconPencil,\n\t\t},\n\t}\n</script>\n```\n### NcListItem compact mode\n```vue\n<template>\n\t<ul style=\"width: 350px;\">\n\t\t<NcListItem active\n\t\t\tcompact\n\t\t\tname=\"Active item\">\n\t\t\t<template #icon>\n\t\t\t\t<IconNoteText :size=\"20\" />\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem compact\n\t\t\tname=\"Name of the element\">\n\t\t\t<template #icon>\n\t\t\t\t<IconNoteText :size=\"20\" />\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem compact\n\t\t\tname=\"Name of the element\"\n\t\t\t:counter-number=\"1\">\n\t\t\t<template #icon>\n\t\t\t\t<IconNoteText :size=\"20\" />\n\t\t\t</template>\n\t\t\t<template #subname>\n\t\t\t\tThis one is with subname\n\t\t\t</template>\n\t\t\t<template #actions>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton one\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton two\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem compact\n\t\t\tname=\"Name of the element\"\n\t\t\t:counter-number=\"3\">\n\t\t\t<template #icon>\n\t\t\t\t<IconNoteText :size=\"20\" />\n\t\t\t</template>\n\t\t\t<template #subname>\n\t\t\t\tThis one is with subname\n\t\t\t</template>\n\t\t\t<template #actions>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton one\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton>\n\t\t\t\t\tButton two\n\t\t\t\t</NcActionButton>\n\t\t\t</template>\n\t\t</NcListItem>\n\t\t<NcListItem compact\n\t\t\tname=\"Name of the element\"\n\t\t\t:counter-number=\"4\"\n\t\t\thref=\"https://nextcloud.com\">\n\t\t\t<template #icon>\n\t\t\t\t<IconNoteText :size=\"20\" />\n\t\t\t</template>\n\t\t\t<template #subname>\n\t\t\t\tThis one is with an external link\n\t\t\t</template>\n\t\t</NcListItem>\n\t</ul>\n</template>\n<script>\n\timport IconNoteText from 'vue-material-design-icons/NoteText.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tIconNoteText,\n\t\t},\n\t}\n</script>\n```\n</docs>\n\n<template>\n\t<!-- This wrapper can be either a router link or a `<li>` -->\n\t<component\n\t\t:is=\"to ? 'router-link' : 'NcVNodes'\"\n\t\tv-slot=\"{ href: routerLinkHref, navigate, isActive }\"\n\t\tv-bind=\"{ ...to && { custom: true, to } }\">\n\t\t<li\n\t\t\tclass=\"list-item__wrapper\"\n\t\t\t:class=\"{ 'list-item__wrapper--active': active ?? isActive }\"\n\t\t\tv-bind=\"$attrs\">\n\t\t\t<div\n\t\t\t\tref=\"list-item\"\n\t\t\t\tclass=\"list-item\"\n\t\t\t\t:class=\"{\n\t\t\t\t\t'list-item--compact': compact,\n\t\t\t\t\t'list-item--one-line': oneLine,\n\t\t\t\t}\"\n\t\t\t\t@mouseover=\"handleMouseover\"\n\t\t\t\t@mouseleave=\"handleMouseleave\">\n\t\t\t\t<a\n\t\t\t\t\t:id=\"anchorId || undefined\"\n\t\t\t\t\t:aria-label=\"linkAriaLabel\"\n\t\t\t\t\tclass=\"list-item__anchor\"\n\t\t\t\t\t:href=\"routerLinkHref || href\"\n\t\t\t\t\t:target=\"target || (href === '#' ? undefined : '_blank')\"\n\t\t\t\t\t:rel=\"href === '#' ? undefined : 'noopener noreferrer'\"\n\t\t\t\t\t@focus=\"showActions\"\n\t\t\t\t\t@focusout=\"handleBlur\"\n\t\t\t\t\t@click=\"onClick($event, navigate, routerLinkHref)\"\n\t\t\t\t\t@keydown.esc=\"hideActions\">\n\t\t\t\t\t<!-- @slot This slot is used for the NcAvatar or icon, the content of this slot must not be interactive -->\n\t\t\t\t\t<slot name=\"icon\" />\n\n\t\t\t\t\t<!-- Main content -->\n\t\t\t\t\t<div class=\"list-item-content\">\n\t\t\t\t\t\t<div class=\"list-item-content__main\">\n\t\t\t\t\t\t\t<div class=\"list-item-content__name\">\n\t\t\t\t\t\t\t\t<!-- @slot Slot for the first line of the component. prop 'name' is used as a fallback is no slots are provided -->\n\t\t\t\t\t\t\t\t<slot name=\"name\">{{ name }}</slot>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tv-if=\"hasSubname\"\n\t\t\t\t\t\t\t\tclass=\"list-item-content__subname\"\n\t\t\t\t\t\t\t\t:class=\"{ 'list-item-content__subname--bold': bold }\">\n\t\t\t\t\t\t\t\t<!-- @slot Slot for the second line of the component -->\n\t\t\t\t\t\t\t\t<slot name=\"subname\" />\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t\t<div class=\"list-item-content__details\">\n\t\t\t\t\t\t\t<div v-if=\"showDetails\" class=\"list-item-details__details\">\n\t\t\t\t\t\t\t\t<!-- @slot This slot is used for some details in form of icon (prop `details` as a fallback) -->\n\t\t\t\t\t\t\t\t<slot name=\"details\">{{ details }}</slot>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t<!-- Counter and indicator -->\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tv-if=\"counterNumber !== 0 || hasIndicator\"\n\t\t\t\t\t\t\t\tv-show=\"showAdditionalElements\"\n\t\t\t\t\t\t\t\tclass=\"list-item-details__extra\">\n\t\t\t\t\t\t\t\t<NcCounterBubble\n\t\t\t\t\t\t\t\t\tv-if=\"counterNumber !== 0\"\n\t\t\t\t\t\t\t\t\t:count=\"counterNumber\"\n\t\t\t\t\t\t\t\t\t:active=\"active ?? isActive\"\n\t\t\t\t\t\t\t\t\tclass=\"list-item-details__counter\"\n\t\t\t\t\t\t\t\t\t:type=\"counterType\" />\n\n\t\t\t\t\t\t\t\t<span v-if=\"hasIndicator\" class=\"list-item-details__indicator\">\n\t\t\t\t\t\t\t\t\t<!-- @slot This slot is used for some indicator in form of icon -->\n\t\t\t\t\t\t\t\t\t<slot name=\"indicator\" />\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</a>\n\n\t\t\t\t<div v-if=\"$slots['extra-actions']\" class=\"list-item-content__extra-actions\">\n\t\t\t\t\t<!-- @slot Extra elements next to the right side quick menu -->\n\t\t\t\t\t<slot name=\"extra-actions\" />\n\t\t\t\t</div>\n\n\t\t\t\t<!-- Actions -->\n\t\t\t\t<div\n\t\t\t\t\tv-show=\"forceDisplayActions || displayActionsOnHoverFocus\"\n\t\t\t\t\tclass=\"list-item-content__actions\"\n\t\t\t\t\t@focusout=\"handleBlur\">\n\t\t\t\t\t<NcActions\n\t\t\t\t\t\tref=\"actions\"\n\t\t\t\t\t\t:primary=\"active ?? isActive\"\n\t\t\t\t\t\t:force-menu=\"forceMenu\"\n\t\t\t\t\t\t:aria-label=\"actionsAriaLabel\"\n\t\t\t\t\t\t@update:open=\"handleActionsUpdateOpen\">\n\t\t\t\t\t\t<template v-if=\"$slots['actions-icon']\" #icon>\n\t\t\t\t\t\t\t<!-- @slot Provide the custom icon for the right side quick menu -->\n\t\t\t\t\t\t\t<slot name=\"actions-icon\" />\n\t\t\t\t\t\t</template>\n\t\t\t\t\t\t<!-- @slot Provide the actions for the right side quick menu -->\n\t\t\t\t\t\t<slot name=\"actions\" />\n\t\t\t\t\t</NcActions>\n\t\t\t\t</div>\n\n\t\t\t\t<div v-if=\"$slots.extra\" class=\"list-item__extra\">\n\t\t\t\t\t<!-- @slot Extra elements below the item -->\n\t\t\t\t\t<slot name=\"extra\" />\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</li>\n\t</component>\n</template>\n\n<script>\nimport NcActions from '../NcActions/index.js'\nimport NcCounterBubble from '../NcCounterBubble/index.ts'\nimport NcVNodes from '../NcVNodes/index.ts'\n\nexport default {\n\tname: 'NcListItem',\n\n\tcomponents: {\n\t\tNcActions,\n\t\tNcCounterBubble,\n\t\tNcVNodes,\n\t},\n\n\tinheritAttrs: false,\n\n\tprops: {\n\t\t/**\n\t\t * The details text displayed in the upper right part of the component\n\t\t */\n\t\tdetails: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Name (first line of text)\n\t\t */\n\t\tname: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * The route for the router link.\n\t\t */\n\t\tto: {\n\t\t\ttype: [String, Object],\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * The value for the external link\n\t\t */\n\t\thref: {\n\t\t\ttype: String,\n\t\t\tdefault: '#',\n\t\t},\n\n\t\t/**\n\t\t * The HTML target attribute used for the link\n\t\t */\n\t\ttarget: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Id for the `<a>` element\n\t\t */\n\t\tanchorId: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Make subname bold\n\t\t */\n\t\tbold: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Show the NcListItem in compact design\n\t\t */\n\t\tcompact: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Toggle the active state of the component\n\t\t */\n\t\tactive: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Aria label for the wrapper element\n\t\t */\n\t\tlinkAriaLabel: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Aria label for the actions toggle\n\t\t */\n\t\tactionsAriaLabel: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * If different from 0 this component will display the\n\t\t * NcCounterBubble component\n\t\t */\n\t\tcounterNumber: {\n\t\t\ttype: [Number, String],\n\t\t\tdefault: 0,\n\t\t},\n\n\t\t/**\n\t\t * Outlined or highlighted state of the counter\n\t\t */\n\t\tcounterType: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t\tvalidator(value) {\n\t\t\t\treturn ['highlighted', 'outlined', ''].indexOf(value) !== -1\n\t\t\t},\n\t\t},\n\n\t\t/**\n\t\t * To be used only when the elements in the actions menu are very important\n\t\t */\n\t\tforceDisplayActions: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Force the actions to display in a three dot menu\n\t\t */\n\t\tforceMenu: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Show the list component layout\n\t\t */\n\t\toneLine: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t},\n\n\temits: [\n\t\t'click',\n\t\t'update:menuOpen',\n\t],\n\n\tdata() {\n\t\treturn {\n\t\t\thovered: false,\n\t\t\thasActions: false,\n\t\t\thasSubname: false,\n\t\t\tdisplayActionsOnHoverFocus: false,\n\t\t\tmenuOpen: false,\n\t\t\thasIndicator: false,\n\t\t\thasDetails: false,\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tshowAdditionalElements() {\n\t\t\treturn !this.displayActionsOnHoverFocus || this.forceDisplayActions\n\t\t},\n\n\t\tshowDetails() {\n\t\t\treturn (this.details !== '' || this.hasDetails)\n\t\t\t\t&& (!this.displayActionsOnHoverFocus || this.forceDisplayActions)\n\t\t},\n\t},\n\n\twatch: {\n\n\t\tmenuOpen(newValue) {\n\t\t\t// A click outside both the menu and the root element hides the actions again\n\t\t\tif (!newValue && !this.hovered) {\n\t\t\t\tthis.displayActionsOnHoverFocus = false\n\t\t\t}\n\t\t},\n\t},\n\n\tmounted() {\n\t\tthis.checkSlots()\n\t},\n\n\tupdated() {\n\t\tthis.checkSlots()\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Handle link click\n\t\t *\n\t\t * @param {MouseEvent|KeyboardEvent} event - Native click or keydown event\n\t\t * @param {Function} [navigate] - VueRouter link's navigate if any\n\t\t * @param {string} [routerLinkHref] - VueRouter link's href\n\t\t */\n\t\tonClick(event, navigate, routerLinkHref) {\n\t\t\t// Always forward native event\n\t\t\tthis.$emit('click', event)\n\t\t\t// Do not navigate with control keys - it is opening in a new tab\n\t\t\tif (event.metaKey || event.altKey || event.ctrlKey || event.shiftKey) {\n\t\t\t\treturn\n\t\t\t}\n\t\t\t// Prevent default link behaviour if it's a router-link and navigate manually\n\t\t\tif (routerLinkHref) {\n\t\t\t\tnavigate?.(event)\n\t\t\t\tevent.preventDefault()\n\t\t\t}\n\t\t},\n\n\t\tshowActions() {\n\t\t\tif (this.hasActions) {\n\t\t\t\tthis.displayActionsOnHoverFocus = true\n\t\t\t}\n\t\t\tthis.hovered = false\n\t\t},\n\n\t\thideActions() {\n\t\t\tthis.displayActionsOnHoverFocus = false\n\t\t},\n\n\t\t/**\n\t\t * @param {FocusEvent} event UI event\n\t\t */\n\t\thandleBlur(event) {\n\t\t\t// do not hide if open\n\t\t\tif (this.menuOpen) {\n\t\t\t\treturn\n\t\t\t}\n\t\t\t// do not hide if focus is kept within\n\t\t\t// On component unmounting Vue 3 resets the template ref to null,\n\t\t\t// so we can ignore this check\n\t\t\tif (this.$refs['list-item']?.contains(event.relatedTarget)) {\n\t\t\t\treturn\n\t\t\t}\n\t\t\tthis.hideActions()\n\t\t},\n\n\t\t/**\n\t\t * Hide the actions on mouseleave unless the menu is open\n\t\t */\n\t\thandleMouseleave() {\n\t\t\tif (!this.menuOpen) {\n\t\t\t\tthis.displayActionsOnHoverFocus = false\n\t\t\t}\n\t\t\tthis.hovered = false\n\t\t},\n\n\t\thandleMouseover() {\n\t\t\tthis.showActions()\n\t\t\tthis.hovered = true\n\t\t},\n\n\t\thandleActionsUpdateOpen(e) {\n\t\t\tthis.menuOpen = e\n\t\t\tthis.$emit('update:menuOpen', e)\n\t\t},\n\n\t\t// Check if subname and actions slots are populated\n\t\tcheckSlots() {\n\t\t\tif (this.hasActions !== !!this.$slots.actions) {\n\t\t\t\tthis.hasActions = !!this.$slots.actions\n\t\t\t}\n\t\t\tif (this.hasSubname !== !!this.$slots.subname) {\n\t\t\t\tthis.hasSubname = !!this.$slots.subname\n\t\t\t}\n\t\t\tif (this.hasIndicator !== !!this.$slots.indicator) {\n\t\t\t\tthis.hasIndicator = !!this.$slots.indicator\n\t\t\t}\n\t\t\tif (this.hasDetails !== !!this.$slots.details) {\n\t\t\t\tthis.hasDetails = !!this.$slots.details\n\t\t\t}\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n\n.list-item__wrapper {\n\tdisplay: flex;\n\tposition: relative;\n\twidth: 100%;\n\t// padding for the focus-visible styles. Width is reduced to compensate it\n\tpadding: 2px 4px;\n\t// The first and lastelement needs also padding for the box shadow of the focus-visible effect\n\t&:first-of-type {\n\t\tpadding-block-start: 4px;\n\t}\n\t&:last-of-type {\n\t\tpadding-block-end: 4px\n\t}\n\n\t&--active,\n\t&.active {\n\t\t.list-item {\n\t\t\tbackground-color: var(--color-primary-element);\n\t\t\tcolor: var(--color-primary-element-text) !important;\n\n\t\t\t&:hover,\n\t\t\t&:focus-within,\n\t\t\t&:has(:focus-visible),\n\t\t\t&:has(:active) {\n\t\t\t\tbackground-color: var(--color-primary-element-hover);\n\t\t\t}\n\t\t}\n\n\t\t.list-item-content__name,\n\t\t.list-item-content__subname,\n\t\t.list-item-content__details,\n\t\t.list-item-details__details {\n\t\t\tcolor: var(--color-primary-element-text) !important;\n\t\t}\n\t}\n\t.list-item-content__name,\n\t.list-item-content__subname,\n\t.list-item-content__details,\n\t.list-item-details__details {\n\t\twhite-space: nowrap;\n\t\tmargin-block: 0;\n\t\tmargin-inline: 0 auto;\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t}\n}\n\n.list-item-content__name {\n\tmin-width: 100px;\n\tflex: 1 1 10%;\n\tfont-weight: 500;\n}\n\n.list-item-content__subname {\n\tflex: 1 0;\n\tmin-width: 0;\n\tcolor: var(--color-text-maxcontrast);\n\t&--bold {\n\t\tfont-weight: 500;\n\t}\n}\n\n// NcListItem\n.list-item {\n\t--list-item-padding: var(--default-grid-baseline);\n\t// The content are two lines of text and respect the 1.5 line height\n\t--list-item-height: 2lh;\n\t--list-item-border-radius: var(--border-radius-element, 32px);\n\t// General styles\n\tbox-sizing: border-box;\n\tdisplay: flex;\n\tposition: relative;\n\tflex: 0 0 auto;\n\tjustify-content: flex-start;\n\tpadding: var(--list-item-padding);\n\twidth: 100%;\n\tborder-radius: var(--border-radius-element, 32px);\n\tcursor: pointer;\n\ttransition: background-color var(--animation-quick) ease-in-out;\n\tlist-style: none;\n\n\t&:hover,\n\t&:focus-within,\n\t&:has(:active),\n\t&:has(:focus-visible) {\n\t\tbackground-color: var(--color-background-hover);\n\t}\n\n\t&:has(&__anchor:focus-visible) {\n\t\toutline: 2px solid var(--color-main-text);\n\t\tbox-shadow: 0 0 0 4px var(--color-main-background);\n\t}\n\n\t&--compact {\n\t\t--list-item-padding: calc(0.5 * var(--default-grid-baseline)) var(--default-grid-baseline);\n\n\t\t&:not(:has(.list-item-content__subname)) {\n\t\t\t--list-item-height: var(--default-clickable-area);\n\t\t}\n\t}\n\n\t&--one-line {\n\t\t--list-item-height: var(--default-clickable-area);\n\t\t--list-item-border-radius: var(--border-radius-element, calc(var(--default-clickable-area) / 2));\n\t\t--list-item-padding: var(--default-grid-baseline);\n\n\t\t.list-item-content__main {\n\t\t\tdisplay: flex;\n\t\t\tjustify-content: start;\n\t\t\tgap: 12px;\n\t\t\tmin-width: 0;\n\t\t}\n\t\t.list-item-content__details {\n\t\t\tflex-direction: row;\n\t\t\talign-items: center;\n\t\t\tjustify-content: end;\n\t\t}\n\t\t.list-item-content__name {\n\t\t\talign-self: center;\n\t\t\tmax-width: 300px;\n\t\t}\n\t}\n\n\t&__anchor {\n\t\tcolor: inherit;\n\t\tdisplay: flex;\n\t\tflex: 1 0 auto;\n\t\talign-items: center;\n\t\theight: var(--list-item-height);\n\t\tmin-width: 0;\n\n\t\t// This is handled by the parent container\n\t\t&:focus-visible {\n\t\t\toutline: none;\n\t\t}\n\t}\n\n\t&-content {\n\t\tdisplay: flex;\n\t\tflex: 1 0;\n\t\tjustify-content: space-between;\n\t\tpadding-inline-start: calc(2 * var(--default-grid-baseline));\n\t\tmin-width: 0;\n\n\t\t&__main {\n\t\t\tflex: 1 0;\n\t\t\twidth: 0;\n\t\t\tmargin: auto 0;\n\n\t\t\t&--oneline {\n\t\t\t\tdisplay: flex;\n\t\t\t}\n\t\t}\n\n\t\t&__details {\n\t\t\tdisplay: flex;\n\t\t\tflex-direction: column;\n\t\t\tjustify-content: end;\n\t\t\talign-items: end;\n\t\t}\n\n\t\t&__actions,\n\t\t&__extra-actions {\n\t\t\tflex: 0 0 auto;\n\t\t\talign-self: center;\n\t\t\tjustify-content: center;\n\t\t\tmargin-inline-start: var(--default-grid-baseline);\n\t\t}\n\n\t\t&__extra-actions {\n\t\t\tdisplay: flex;\n\t\t\talign-items: center;\n\t\t\tgap: var(--default-grid-baseline);\n\t\t}\n\t}\n\n\t&-details {\n\t\t&__details {\n\t\t\tcolor: var(--color-text-maxcontrast);\n\t\t\tmargin: 0 9px !important;\n\t\t\tfont-weight: normal;\n\t\t}\n\t\t&__extra {\n\t\t\tmargin: 2px 4px 0 4px;\n\t\t\tdisplay: flex;\n\t\t\talign-items: center;\n\t\t}\n\t\t&__indicator {\n\t\t\tmargin: 0 5px;\n\t\t}\n\t}\n\n\t&__extra {\n\t\tmargin-top: var(--default-grid-baseline);\n\t}\n}\n\n</style>\n"],"names":["NcVNodes","_openBlock","_createBlock","_resolveDynamicComponent","_normalizeProps","_guardReactiveProps","_withCtx","_createElementVNode","_mergeProps","_renderSlot","_createElementBlock","_normalizeClass","_withDirectives","_createVNode","_vShow"],"mappings":"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"}