@nextcloud/vue 8.21.0 → 8.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (483) hide show
  1. package/CHANGELOG.md +100 -0
  2. package/README.md +71 -65
  3. package/dist/Components/NcActionButton.cjs +2 -167
  4. package/dist/Components/NcActionButton.cjs.map +1 -1
  5. package/dist/Components/NcActionButton.mjs +2 -167
  6. package/dist/Components/NcActionButton.mjs.map +1 -1
  7. package/dist/Components/NcActionButtonGroup.cjs +1 -1
  8. package/dist/Components/NcActionButtonGroup.mjs +1 -1
  9. package/dist/Components/NcActionCaption.cjs +2 -2
  10. package/dist/Components/NcActionCaption.cjs.map +1 -1
  11. package/dist/Components/NcActionCaption.mjs +2 -2
  12. package/dist/Components/NcActionCaption.mjs.map +1 -1
  13. package/dist/Components/NcActionCheckbox.cjs +1 -1
  14. package/dist/Components/NcActionCheckbox.mjs +1 -1
  15. package/dist/Components/NcActionInput.cjs +1 -1
  16. package/dist/Components/NcActionInput.mjs +1 -1
  17. package/dist/Components/NcActionLink.cjs +1 -1
  18. package/dist/Components/NcActionLink.mjs +1 -1
  19. package/dist/Components/NcActionRadio.cjs +1 -1
  20. package/dist/Components/NcActionRadio.mjs +1 -1
  21. package/dist/Components/NcActionRouter.cjs +1 -1
  22. package/dist/Components/NcActionRouter.mjs +1 -1
  23. package/dist/Components/NcActionText.cjs +1 -1
  24. package/dist/Components/NcActionText.mjs +1 -1
  25. package/dist/Components/NcActionTextEditable.cjs +1 -1
  26. package/dist/Components/NcActionTextEditable.mjs +1 -1
  27. package/dist/Components/NcActions.cjs +1 -1
  28. package/dist/Components/NcActions.mjs +1 -1
  29. package/dist/Components/NcAppContent.cjs +1 -1
  30. package/dist/Components/NcAppContent.mjs +1 -1
  31. package/dist/Components/NcAppNavigation.cjs +1 -1
  32. package/dist/Components/NcAppNavigation.mjs +1 -1
  33. package/dist/Components/NcAppNavigationCaption.cjs +1 -1
  34. package/dist/Components/NcAppNavigationCaption.mjs +1 -1
  35. package/dist/Components/NcAppNavigationItem.cjs +1 -1
  36. package/dist/Components/NcAppNavigationItem.mjs +1 -1
  37. package/dist/Components/NcAppNavigationNewItem.cjs +1 -1
  38. package/dist/Components/NcAppNavigationNewItem.mjs +1 -1
  39. package/dist/Components/NcAppNavigationSearch.cjs +1 -1
  40. package/dist/Components/NcAppNavigationSearch.mjs +1 -1
  41. package/dist/Components/NcAppNavigationSettings.cjs +1 -1
  42. package/dist/Components/NcAppNavigationSettings.mjs +1 -1
  43. package/dist/Components/NcAppNavigationToggle.cjs +1 -1
  44. package/dist/Components/NcAppNavigationToggle.mjs +1 -1
  45. package/dist/Components/NcAppSettingsDialog.cjs +1 -1
  46. package/dist/Components/NcAppSettingsDialog.mjs +1 -1
  47. package/dist/Components/NcAppSidebar.cjs +1 -1
  48. package/dist/Components/NcAppSidebar.mjs +1 -1
  49. package/dist/Components/NcAvatar.cjs +1 -1
  50. package/dist/Components/NcAvatar.mjs +1 -1
  51. package/dist/Components/NcBreadcrumb.cjs +1 -1
  52. package/dist/Components/NcBreadcrumb.mjs +1 -1
  53. package/dist/Components/NcBreadcrumbs.cjs +1 -1
  54. package/dist/Components/NcBreadcrumbs.mjs +1 -1
  55. package/dist/Components/NcButton.cjs +2 -2
  56. package/dist/Components/NcButton.cjs.map +1 -1
  57. package/dist/Components/NcButton.mjs +2 -2
  58. package/dist/Components/NcButton.mjs.map +1 -1
  59. package/dist/Components/NcCheckboxRadioSwitch.cjs +1 -1
  60. package/dist/Components/NcCheckboxRadioSwitch.mjs +1 -1
  61. package/dist/Components/NcChip.cjs +5 -5
  62. package/dist/Components/NcChip.mjs +4 -4
  63. package/dist/Components/NcCollectionList.cjs +1 -1
  64. package/dist/Components/NcCollectionList.mjs +1 -1
  65. package/dist/Components/NcColorPicker.cjs +1 -1
  66. package/dist/Components/NcColorPicker.mjs +1 -1
  67. package/dist/Components/NcContent.cjs +1 -1
  68. package/dist/Components/NcContent.mjs +1 -1
  69. package/dist/Components/NcCounterBubble.cjs +1 -1
  70. package/dist/Components/NcCounterBubble.mjs +1 -1
  71. package/dist/Components/NcDashboardWidget.cjs +1 -1
  72. package/dist/Components/NcDashboardWidget.mjs +1 -1
  73. package/dist/Components/NcDashboardWidgetItem.cjs +1 -1
  74. package/dist/Components/NcDashboardWidgetItem.mjs +1 -1
  75. package/dist/Components/NcDateTime.cjs +1 -1
  76. package/dist/Components/NcDateTime.mjs +1 -1
  77. package/dist/Components/NcDateTimePicker.cjs +6 -6
  78. package/dist/Components/NcDateTimePicker.mjs +6 -6
  79. package/dist/Components/NcDateTimePickerNative.cjs +22 -18
  80. package/dist/Components/NcDateTimePickerNative.cjs.map +1 -1
  81. package/dist/Components/NcDateTimePickerNative.mjs +22 -18
  82. package/dist/Components/NcDateTimePickerNative.mjs.map +1 -1
  83. package/dist/Components/NcDialog.cjs +1 -1
  84. package/dist/Components/NcDialog.mjs +1 -1
  85. package/dist/Components/NcDialogButton.cjs +1 -1
  86. package/dist/Components/NcDialogButton.mjs +1 -1
  87. package/dist/Components/NcEmojiPicker.cjs +1 -1
  88. package/dist/Components/NcEmojiPicker.mjs +1 -1
  89. package/dist/Components/NcHeaderButton.cjs +2 -2
  90. package/dist/Components/NcHeaderButton.cjs.map +1 -1
  91. package/dist/Components/NcHeaderButton.mjs +2 -2
  92. package/dist/Components/NcHeaderButton.mjs.map +1 -1
  93. package/dist/Components/NcHeaderMenu.cjs +1 -1
  94. package/dist/Components/NcHeaderMenu.mjs +1 -1
  95. package/dist/Components/NcInputField.cjs +1 -1
  96. package/dist/Components/NcInputField.mjs +1 -1
  97. package/dist/Components/NcListItem.cjs +1 -1
  98. package/dist/Components/NcListItem.mjs +1 -1
  99. package/dist/Components/NcListItemIcon.cjs +1 -1
  100. package/dist/Components/NcListItemIcon.mjs +1 -1
  101. package/dist/Components/NcModal.cjs +59 -61
  102. package/dist/Components/NcModal.cjs.map +1 -1
  103. package/dist/Components/NcModal.mjs +59 -61
  104. package/dist/Components/NcModal.mjs.map +1 -1
  105. package/dist/Components/NcPasswordField.cjs +1 -1
  106. package/dist/Components/NcPasswordField.mjs +1 -1
  107. package/dist/Components/NcPopover.cjs +1 -1
  108. package/dist/Components/NcPopover.mjs +1 -1
  109. package/dist/Components/NcRelatedResourcesPanel.cjs +1 -1
  110. package/dist/Components/NcRelatedResourcesPanel.mjs +1 -1
  111. package/dist/Components/NcRichContenteditable.cjs +2 -2
  112. package/dist/Components/NcRichContenteditable.mjs +2 -2
  113. package/dist/Components/NcRichText.cjs +2 -2
  114. package/dist/Components/NcRichText.mjs +3 -3
  115. package/dist/Components/NcSelect.cjs +1 -1
  116. package/dist/Components/NcSelect.mjs +1 -1
  117. package/dist/Components/NcSelectTags.cjs +1 -1
  118. package/dist/Components/NcSelectTags.mjs +1 -1
  119. package/dist/Components/NcSettingsInputText.cjs +1 -1
  120. package/dist/Components/NcSettingsInputText.mjs +1 -1
  121. package/dist/Components/NcSettingsSection.cjs +1 -1
  122. package/dist/Components/NcSettingsSection.mjs +1 -1
  123. package/dist/Components/NcSettingsSelectGroup.cjs +1 -1
  124. package/dist/Components/NcSettingsSelectGroup.mjs +1 -1
  125. package/dist/Components/NcTextField.cjs +1 -1
  126. package/dist/Components/NcTextField.mjs +1 -1
  127. package/dist/Components/NcTimezonePicker.cjs +1 -1
  128. package/dist/Components/NcTimezonePicker.mjs +1 -1
  129. package/dist/Components/NcUserBubble.cjs +1 -1
  130. package/dist/Components/NcUserBubble.mjs +1 -1
  131. package/dist/Components/NcUserStatusIcon.cjs +1 -1
  132. package/dist/Components/NcUserStatusIcon.mjs +1 -1
  133. package/dist/Composables/useHotKey.cjs +22 -5
  134. package/dist/Composables/useHotKey.cjs.map +1 -1
  135. package/dist/Composables/useHotKey.mjs +22 -5
  136. package/dist/Composables/useHotKey.mjs.map +1 -1
  137. package/dist/Directives/Linkify.cjs +14 -2
  138. package/dist/Directives/Linkify.cjs.map +1 -1
  139. package/dist/Directives/Linkify.mjs +11 -1
  140. package/dist/Directives/Linkify.mjs.map +1 -1
  141. package/dist/Functions/contactsMenu.cjs +21 -0
  142. package/dist/Functions/contactsMenu.cjs.map +1 -0
  143. package/dist/Functions/contactsMenu.mjs +21 -0
  144. package/dist/Functions/contactsMenu.mjs.map +1 -0
  145. package/dist/Functions/reference.cjs +1 -1
  146. package/dist/Functions/reference.mjs +1 -1
  147. package/dist/Functions/usernameToColor.cjs +1 -1
  148. package/dist/Functions/usernameToColor.mjs +1 -1
  149. package/dist/Mixins/richEditor.cjs +1 -2
  150. package/dist/Mixins/richEditor.cjs.map +1 -1
  151. package/dist/Mixins/richEditor.mjs +1 -2
  152. package/dist/Mixins/richEditor.mjs.map +1 -1
  153. package/dist/assets/{NcActionButton-CNq6xIdS.css → NcActionButton-BYN2SUN0.css} +21 -21
  154. package/dist/assets/{NcActionCaption-JVhz4Wp7.css → NcActionCaption-BNDtcWJ7.css} +4 -4
  155. package/dist/assets/{NcActionCheckbox-DeW2CCVc.css → NcActionCheckbox-Dan0EvGm.css} +18 -18
  156. package/dist/assets/{NcActionInput-CNRERfyh.css → NcActionInput-Dz21fyVD.css} +69 -65
  157. package/dist/assets/{NcActionLink-CC6a7Hsf.css → NcActionLink-BG9B9dP4.css} +6 -5
  158. package/dist/assets/{NcActionRadio-DC7Wp9rR.css → NcActionRadio-C87waXE-.css} +18 -18
  159. package/dist/assets/{NcActionRouter-CsIBHw6E.css → NcActionRouter-BAGuUfFu.css} +6 -5
  160. package/dist/assets/{NcActionText-BSD_HYx4.css → NcActionText-Cjp26Bn0.css} +6 -5
  161. package/dist/assets/{NcActionTextEditable-Cg16Q4zr.css → NcActionTextEditable-1TXeJ5zp.css} +68 -64
  162. package/dist/assets/{NcActions-DM_LoRlx.css → NcActions-C4SuFczn.css} +12 -15
  163. package/dist/assets/{NcAppContent-D97xom6z.css → NcAppContent-BO0ksFwD.css} +19 -19
  164. package/dist/assets/{NcAppNavigation-CBN6X2dT.css → NcAppNavigation-CJj8AvqM.css} +13 -13
  165. package/dist/assets/{NcAppNavigationCaption-Dt5K_hKD.css → NcAppNavigationCaption-DU9PxTvu.css} +9 -9
  166. package/dist/assets/{NcAppNavigationItem-CNZsPcla.css → NcAppNavigationItem-lh9Say1M.css} +39 -39
  167. package/dist/assets/{NcAppNavigationNewItem-CQ1f40wK.css → NcAppNavigationNewItem-fUP3wQTQ.css} +37 -37
  168. package/dist/assets/{NcAppNavigationSettings-BV_QS8jh.css → NcAppNavigationSettings-vd47rlNY.css} +14 -14
  169. package/dist/assets/{NcAppNavigationToggle-Chtb7sE7.css → NcAppNavigationToggle-B6FCDJp7.css} +3 -3
  170. package/dist/assets/{NcAvatar-xe4gdFKk.css → NcAvatar-CcJlFpcI.css} +25 -25
  171. package/dist/assets/{NcButton-BHDLon1_.css → NcButton-CfOAX-eQ.css} +47 -47
  172. package/dist/assets/{NcCheckboxRadioSwitch-D0kAZROF.css → NcCheckboxRadioSwitch-DuFrRU9C.css} +45 -42
  173. package/dist/assets/{NcColorPicker-Dw2wy2tU.css → NcColorPicker-C1DuuANb.css} +28 -28
  174. package/dist/assets/{NcCounterBubble-DdYmHnng.css → NcCounterBubble-CI-DxLjL.css} +7 -7
  175. package/dist/assets/{NcDashboardWidgetItem-BtOuK4mf.css → NcDashboardWidgetItem-B8_6-_k8.css} +16 -16
  176. package/dist/assets/{NcDateTimePicker-Dp2wSSiQ.css → NcDateTimePicker-MkokZozI.css} +22 -18
  177. package/dist/assets/NcDateTimePickerNative-DVGEymgr.css +60 -0
  178. package/dist/assets/{NcEmojiPicker-BNCW1Q94.css → NcEmojiPicker-rk5qcSl7.css} +75 -57
  179. package/dist/assets/{NcHeaderButton-DH4Qtw3P.css → NcHeaderButton-BPkJ5wxD.css} +7 -7
  180. package/dist/assets/{NcHeaderMenu-C2XbJMYL.css → NcHeaderMenu-BYjnMPPl.css} +11 -11
  181. package/dist/assets/{NcInputField-CUsdr7lV.css → NcInputField-CzryIHRa.css} +32 -32
  182. package/dist/assets/{NcListItem-BBu5UTTe.css → NcListItem-GE5S37TT.css} +48 -47
  183. package/dist/assets/{NcMentionBubble-Bt71nB8X.css → NcMentionBubble-BL05HUeF.css} +12 -13
  184. package/dist/assets/{NcModal-BBKX-T6V.css → NcModal-ZfCDJxwd.css} +63 -61
  185. package/dist/assets/{NcPasswordField-DZ6dcMzH.css → NcPasswordField-whtKJFcB.css} +2 -2
  186. package/dist/assets/{NcPopover-TS4CW9MJ.css → NcPopover-DpakVVxI.css} +16 -5
  187. package/dist/assets/{NcRelatedResourcesPanel-DIhZx6lY.css → NcRelatedResourcesPanel-DSf7TVcC.css} +14 -14
  188. package/dist/assets/{NcRichContenteditable-DkYYyQTJ.css → NcRichContenteditable-BV6g3dmd.css} +53 -42
  189. package/dist/assets/NcRichText-zt8ALFHi.css +323 -0
  190. package/dist/assets/{NcSettingsSection-Dlaob2ni.css → NcSettingsSection-_mX6UqM_.css} +9 -9
  191. package/dist/assets/{NcUserBubble-CNid1YOT.css → NcUserBubble-BsTKRhKz.css} +11 -11
  192. package/dist/assets/{referencePickerModal-BhhuyO3J.css → referencePickerModal-CTumspFH.css} +46 -46
  193. package/dist/chunks/ChevronLeft-BK4j9oVH.mjs +37 -0
  194. package/dist/chunks/ChevronLeft-BK4j9oVH.mjs.map +1 -0
  195. package/dist/chunks/ChevronLeft-CAiEPWc5.cjs +36 -0
  196. package/dist/chunks/ChevronLeft-CAiEPWc5.cjs.map +1 -0
  197. package/dist/chunks/{GenColors-DpvFVzBN.mjs → GenColors-Bp97WTnT.mjs} +1 -1
  198. package/dist/chunks/{GenColors-DpvFVzBN.mjs.map → GenColors-Bp97WTnT.mjs.map} +1 -1
  199. package/dist/chunks/{GenColors-iV_vrBr4.cjs → GenColors-DH0trnvh.cjs} +1 -1
  200. package/dist/chunks/{GenColors-iV_vrBr4.cjs.map → GenColors-DH0trnvh.cjs.map} +1 -1
  201. package/dist/chunks/NcActionButton-CEysTg4c.mjs +177 -0
  202. package/dist/chunks/NcActionButton-CEysTg4c.mjs.map +1 -0
  203. package/dist/chunks/NcActionButton-DcpUnqA7.cjs +176 -0
  204. package/dist/chunks/NcActionButton-DcpUnqA7.cjs.map +1 -0
  205. package/dist/chunks/{NcActionButtonGroup-ue4dTx-p.mjs → NcActionButtonGroup-CCsqO10Q.mjs} +1 -1
  206. package/dist/chunks/{NcActionButtonGroup-ue4dTx-p.mjs.map → NcActionButtonGroup-CCsqO10Q.mjs.map} +1 -1
  207. package/dist/chunks/{NcActionButtonGroup-C0nQ7J_W.cjs → NcActionButtonGroup-CljgCf7q.cjs} +1 -1
  208. package/dist/chunks/{NcActionButtonGroup-C0nQ7J_W.cjs.map → NcActionButtonGroup-CljgCf7q.cjs.map} +1 -1
  209. package/dist/chunks/{NcActionCheckbox-C_wvm9IO.mjs → NcActionCheckbox-BnL71Qmi.mjs} +2 -2
  210. package/dist/chunks/{NcActionCheckbox-C_wvm9IO.mjs.map → NcActionCheckbox-BnL71Qmi.mjs.map} +1 -1
  211. package/dist/chunks/{NcActionCheckbox-DwU16qcU.cjs → NcActionCheckbox-Dd5Y6f63.cjs} +2 -2
  212. package/dist/chunks/{NcActionCheckbox-DwU16qcU.cjs.map → NcActionCheckbox-Dd5Y6f63.cjs.map} +1 -1
  213. package/dist/chunks/{NcActionInput-D0qZP5ag.cjs → NcActionInput-Co580YPc.cjs} +7 -7
  214. package/dist/chunks/{NcActionInput-D0qZP5ag.cjs.map → NcActionInput-Co580YPc.cjs.map} +1 -1
  215. package/dist/chunks/{NcActionInput-4-s29xoN.mjs → NcActionInput-DbFfZx2L.mjs} +7 -7
  216. package/dist/chunks/{NcActionInput-4-s29xoN.mjs.map → NcActionInput-DbFfZx2L.mjs.map} +1 -1
  217. package/dist/chunks/{NcActionRadio-vHwjWOHS.cjs → NcActionRadio-BQ0jAh5V.cjs} +16 -8
  218. package/dist/chunks/NcActionRadio-BQ0jAh5V.cjs.map +1 -0
  219. package/dist/chunks/{NcActionRadio-Dl6W62Vm.mjs → NcActionRadio-CCTupqRR.mjs} +14 -8
  220. package/dist/chunks/NcActionRadio-CCTupqRR.mjs.map +1 -0
  221. package/dist/chunks/{NcActionTextEditable-97R7dFen.cjs → NcActionTextEditable-C-ZP8_Tn.cjs} +8 -4
  222. package/dist/chunks/NcActionTextEditable-C-ZP8_Tn.cjs.map +1 -0
  223. package/dist/chunks/{NcActionTextEditable-DZCFtqIP.mjs → NcActionTextEditable-JRD-G0CT.mjs} +8 -4
  224. package/dist/chunks/NcActionTextEditable-JRD-G0CT.mjs.map +1 -0
  225. package/dist/chunks/{NcActions-CCYNSnCn.cjs → NcActions-B9hBFogn.cjs} +5 -30
  226. package/dist/chunks/{NcActions-NA1n25Vt.mjs.map → NcActions-B9hBFogn.cjs.map} +1 -1
  227. package/dist/chunks/{NcActions-NA1n25Vt.mjs → NcActions-DV02tDLT.mjs} +5 -30
  228. package/dist/chunks/{NcActions-CCYNSnCn.cjs.map → NcActions-DV02tDLT.mjs.map} +1 -1
  229. package/dist/chunks/{NcAppContent-CIMgDnJM.mjs → NcAppContent-D3ku3oxL.mjs} +18 -8
  230. package/dist/chunks/NcAppContent-D3ku3oxL.mjs.map +1 -0
  231. package/dist/chunks/{NcAppContent-DdzUMomS.cjs → NcAppContent-DdfRZmsz.cjs} +18 -8
  232. package/dist/chunks/NcAppContent-DdfRZmsz.cjs.map +1 -0
  233. package/dist/chunks/{NcAppNavigation-BuKJwvwT.cjs → NcAppNavigation-DQnt1SXa.cjs} +42 -9
  234. package/dist/chunks/NcAppNavigation-DQnt1SXa.cjs.map +1 -0
  235. package/dist/chunks/{NcAppNavigation-wz0Fsxe4.mjs → NcAppNavigation-ZFb93kAU.mjs} +42 -9
  236. package/dist/chunks/NcAppNavigation-ZFb93kAU.mjs.map +1 -0
  237. package/dist/chunks/{NcAppNavigationCaption-DBKM-x5x.mjs → NcAppNavigationCaption-DXufL2i4.mjs} +3 -3
  238. package/dist/chunks/{NcAppNavigationCaption-DBKM-x5x.mjs.map → NcAppNavigationCaption-DXufL2i4.mjs.map} +1 -1
  239. package/dist/chunks/{NcAppNavigationCaption-DUPonEWi.cjs → NcAppNavigationCaption-LypfQqMe.cjs} +3 -3
  240. package/dist/chunks/{NcAppNavigationCaption-DUPonEWi.cjs.map → NcAppNavigationCaption-LypfQqMe.cjs.map} +1 -1
  241. package/dist/chunks/{NcAppNavigationItem-Y_CVXzId.cjs → NcAppNavigationItem-D-1kyfhH.cjs} +12 -12
  242. package/dist/chunks/NcAppNavigationItem-D-1kyfhH.cjs.map +1 -0
  243. package/dist/chunks/{NcAppNavigationItem-BkkuFdfa.mjs → NcAppNavigationItem-rJoyDMUX.mjs} +11 -11
  244. package/dist/chunks/NcAppNavigationItem-rJoyDMUX.mjs.map +1 -0
  245. package/dist/chunks/{NcAppNavigationNewItem-BFFG7VDH.mjs → NcAppNavigationNewItem-CO4Mau1P.mjs} +3 -3
  246. package/dist/chunks/{NcAppNavigationNewItem-BFFG7VDH.mjs.map → NcAppNavigationNewItem-CO4Mau1P.mjs.map} +1 -1
  247. package/dist/chunks/{NcAppNavigationNewItem-B76-cCDH.cjs → NcAppNavigationNewItem-DV3fOuWq.cjs} +3 -3
  248. package/dist/chunks/{NcAppNavigationNewItem-B76-cCDH.cjs.map → NcAppNavigationNewItem-DV3fOuWq.cjs.map} +1 -1
  249. package/dist/chunks/{NcAppNavigationSearch-DVBgbwyd.cjs → NcAppNavigationSearch-BVBeLYXH.cjs} +3 -3
  250. package/dist/chunks/{NcAppNavigationSearch-DVBgbwyd.cjs.map → NcAppNavigationSearch-BVBeLYXH.cjs.map} +1 -1
  251. package/dist/chunks/{NcAppNavigationSearch-Bg-WTyms.mjs → NcAppNavigationSearch-DpaZRVqv.mjs} +3 -3
  252. package/dist/chunks/{NcAppNavigationSearch-Bg-WTyms.mjs.map → NcAppNavigationSearch-DpaZRVqv.mjs.map} +1 -1
  253. package/dist/chunks/{NcAppNavigationSettings-BH5t68oV.cjs → NcAppNavigationSettings-CpBSr0CG.cjs} +5 -6
  254. package/dist/chunks/{NcAppNavigationSettings-BH5t68oV.cjs.map → NcAppNavigationSettings-CpBSr0CG.cjs.map} +1 -1
  255. package/dist/chunks/{NcAppNavigationSettings-CieV4qU5.mjs → NcAppNavigationSettings-DgUbSU0v.mjs} +5 -6
  256. package/dist/chunks/{NcAppNavigationSettings-CieV4qU5.mjs.map → NcAppNavigationSettings-DgUbSU0v.mjs.map} +1 -1
  257. package/dist/chunks/{NcAppNavigationToggle-Dwg-dMWx.cjs → NcAppNavigationToggle-BbDj_xom.cjs} +10 -6
  258. package/dist/chunks/NcAppNavigationToggle-BbDj_xom.cjs.map +1 -0
  259. package/dist/chunks/{NcAppNavigationToggle-Dw0ZPjy2.mjs → NcAppNavigationToggle-Z_4QmE4l.mjs} +10 -6
  260. package/dist/chunks/NcAppNavigationToggle-Z_4QmE4l.mjs.map +1 -0
  261. package/dist/chunks/{NcAppSettingsDialog-Dkl3cqU-.cjs → NcAppSettingsDialog-CLTp2nax.cjs} +3 -3
  262. package/dist/chunks/{NcAppSettingsDialog-Dkl3cqU-.cjs.map → NcAppSettingsDialog-CLTp2nax.cjs.map} +1 -1
  263. package/dist/chunks/{NcAppSettingsDialog-B4GS8urN.mjs → NcAppSettingsDialog-DEPymL7F.mjs} +3 -3
  264. package/dist/chunks/{NcAppSettingsDialog-B4GS8urN.mjs.map → NcAppSettingsDialog-DEPymL7F.mjs.map} +1 -1
  265. package/dist/chunks/{NcAppSidebar-DaJVGxLh.mjs → NcAppSidebar-C149M_Fz.mjs} +4 -4
  266. package/dist/chunks/{NcAppSidebar-DaJVGxLh.mjs.map → NcAppSidebar-C149M_Fz.mjs.map} +1 -1
  267. package/dist/chunks/{NcAppSidebar-B75YJPC-.cjs → NcAppSidebar-CGra4INE.cjs} +4 -4
  268. package/dist/chunks/{NcAppSidebar-B75YJPC-.cjs.map → NcAppSidebar-CGra4INE.cjs.map} +1 -1
  269. package/dist/chunks/{NcAvatar-DypzACJs.cjs → NcAvatar-BGtTigLZ.cjs} +37 -15
  270. package/dist/chunks/NcAvatar-BGtTigLZ.cjs.map +1 -0
  271. package/dist/chunks/{NcAvatar-B8e2YFLI.mjs → NcAvatar-DTd55tcm.mjs} +37 -15
  272. package/dist/chunks/NcAvatar-DTd55tcm.mjs.map +1 -0
  273. package/dist/chunks/{NcBreadcrumb-DVn5-KGF.cjs → NcBreadcrumb-DxF8JaOu.cjs} +1 -1
  274. package/dist/chunks/{NcBreadcrumb-DVn5-KGF.cjs.map → NcBreadcrumb-DxF8JaOu.cjs.map} +1 -1
  275. package/dist/chunks/{NcBreadcrumb-MucRC9Y6.mjs → NcBreadcrumb-bWA_vFfP.mjs} +1 -1
  276. package/dist/chunks/{NcBreadcrumb-MucRC9Y6.mjs.map → NcBreadcrumb-bWA_vFfP.mjs.map} +1 -1
  277. package/dist/chunks/{NcBreadcrumbs-JqPHfTRj.cjs → NcBreadcrumbs-IhjgM1JZ.cjs} +4 -4
  278. package/dist/chunks/{NcBreadcrumbs-JqPHfTRj.cjs.map → NcBreadcrumbs-IhjgM1JZ.cjs.map} +1 -1
  279. package/dist/chunks/{NcBreadcrumbs-D59osZ3o.mjs → NcBreadcrumbs-sClaGRTt.mjs} +3 -3
  280. package/dist/chunks/{NcBreadcrumbs-D59osZ3o.mjs.map → NcBreadcrumbs-sClaGRTt.mjs.map} +1 -1
  281. package/dist/chunks/{NcCheckboxRadioSwitch-DdquK4fW.cjs → NcCheckboxRadioSwitch-BeqHHlB9.cjs} +3 -3
  282. package/dist/chunks/{NcCheckboxRadioSwitch-DdquK4fW.cjs.map → NcCheckboxRadioSwitch-BeqHHlB9.cjs.map} +1 -1
  283. package/dist/chunks/{NcCheckboxRadioSwitch-R1y0mLbC.mjs → NcCheckboxRadioSwitch-TK3dfQ23.mjs} +3 -3
  284. package/dist/chunks/{NcCheckboxRadioSwitch-R1y0mLbC.mjs.map → NcCheckboxRadioSwitch-TK3dfQ23.mjs.map} +1 -1
  285. package/dist/chunks/{NcCollectionList-BBs48HVU.cjs → NcCollectionList-960B7fbH.cjs} +8 -8
  286. package/dist/chunks/{NcCollectionList-BBs48HVU.cjs.map → NcCollectionList-960B7fbH.cjs.map} +1 -1
  287. package/dist/chunks/{NcCollectionList-COYakeMz.mjs → NcCollectionList-AVScwDI5.mjs} +7 -7
  288. package/dist/chunks/{NcCollectionList-COYakeMz.mjs.map → NcCollectionList-AVScwDI5.mjs.map} +1 -1
  289. package/dist/chunks/{NcColorPicker-Df6UVuYn.cjs → NcColorPicker-Cfc8caOi.cjs} +23 -18
  290. package/dist/chunks/NcColorPicker-Cfc8caOi.cjs.map +1 -0
  291. package/dist/chunks/{NcColorPicker-8wU8rMbF.mjs → NcColorPicker-CxUVj8Z0.mjs} +23 -18
  292. package/dist/chunks/NcColorPicker-CxUVj8Z0.mjs.map +1 -0
  293. package/dist/chunks/{NcContent-BXi18ILU.cjs → NcContent-8DrfnMbH.cjs} +2 -2
  294. package/dist/chunks/{NcContent-BXi18ILU.cjs.map → NcContent-8DrfnMbH.cjs.map} +1 -1
  295. package/dist/chunks/{NcContent-BEcHmywv.mjs → NcContent-CUGljSwq.mjs} +2 -2
  296. package/dist/chunks/{NcContent-BEcHmywv.mjs.map → NcContent-CUGljSwq.mjs.map} +1 -1
  297. package/dist/chunks/{NcCounterBubble-DF2rwIo4.cjs → NcCounterBubble-BRrUO34D.cjs} +19 -8
  298. package/dist/chunks/{NcCounterBubble-DF2rwIo4.cjs.map → NcCounterBubble-BRrUO34D.cjs.map} +1 -1
  299. package/dist/chunks/{NcCounterBubble-M1q9GRkH.mjs → NcCounterBubble-CDfRYl8B.mjs} +19 -8
  300. package/dist/chunks/{NcCounterBubble-M1q9GRkH.mjs.map → NcCounterBubble-CDfRYl8B.mjs.map} +1 -1
  301. package/dist/chunks/{NcDashboardWidget-GDdmCQm-.mjs → NcDashboardWidget-52sFYtbl.mjs} +4 -4
  302. package/dist/chunks/{NcDashboardWidget-GDdmCQm-.mjs.map → NcDashboardWidget-52sFYtbl.mjs.map} +1 -1
  303. package/dist/chunks/{NcDashboardWidget-Bu-WC7kg.cjs → NcDashboardWidget-DLT7_5SX.cjs} +4 -4
  304. package/dist/chunks/{NcDashboardWidget-Bu-WC7kg.cjs.map → NcDashboardWidget-DLT7_5SX.cjs.map} +1 -1
  305. package/dist/chunks/{NcDashboardWidgetItem-CI59K-wE.cjs → NcDashboardWidgetItem-D8hdHDZu.cjs} +6 -6
  306. package/dist/chunks/{NcDashboardWidgetItem-CI59K-wE.cjs.map → NcDashboardWidgetItem-D8hdHDZu.cjs.map} +1 -1
  307. package/dist/chunks/{NcDashboardWidgetItem-vMP_Z6ay.mjs → NcDashboardWidgetItem-DU3WZN-y.mjs} +5 -5
  308. package/dist/chunks/{NcDashboardWidgetItem-vMP_Z6ay.mjs.map → NcDashboardWidgetItem-DU3WZN-y.mjs.map} +1 -1
  309. package/dist/chunks/{NcDateTime-CaJHhgab.cjs → NcDateTime-BRGrNYn0.cjs} +1 -1
  310. package/dist/chunks/{NcDateTime-CaJHhgab.cjs.map → NcDateTime-BRGrNYn0.cjs.map} +1 -1
  311. package/dist/chunks/{NcDateTime-D5UaJ0tw.mjs → NcDateTime-CGh9MkHy.mjs} +1 -1
  312. package/dist/chunks/{NcDateTime-D5UaJ0tw.mjs.map → NcDateTime-CGh9MkHy.mjs.map} +1 -1
  313. package/dist/chunks/{NcDialog-CzWTz2Qr.mjs → NcDialog-B9vjcT1J.mjs} +1 -1
  314. package/dist/chunks/{NcDialog-CzWTz2Qr.mjs.map → NcDialog-B9vjcT1J.mjs.map} +1 -1
  315. package/dist/chunks/{NcDialog-CWGgSCpv.cjs → NcDialog-CfYmQm13.cjs} +1 -1
  316. package/dist/chunks/{NcDialog-CWGgSCpv.cjs.map → NcDialog-CfYmQm13.cjs.map} +1 -1
  317. package/dist/chunks/{NcDialogButton-B5jVZIGf.mjs → NcDialogButton-B2SWZUHD.mjs} +2 -2
  318. package/dist/chunks/{NcDialogButton-B5jVZIGf.mjs.map → NcDialogButton-B2SWZUHD.mjs.map} +1 -1
  319. package/dist/chunks/{NcDialogButton-B7d1LWFN.cjs → NcDialogButton-HxcYXT5L.cjs} +2 -2
  320. package/dist/chunks/{NcDialogButton-B7d1LWFN.cjs.map → NcDialogButton-HxcYXT5L.cjs.map} +1 -1
  321. package/dist/chunks/{NcEmojiPicker-BSoMzxJl.mjs → NcEmojiPicker-BXZBDiWy.mjs} +70 -43
  322. package/dist/chunks/NcEmojiPicker-BXZBDiWy.mjs.map +1 -0
  323. package/dist/chunks/{NcEmojiPicker-XRtfmbk_.cjs → NcEmojiPicker-Cpll3Z7O.cjs} +70 -43
  324. package/dist/chunks/NcEmojiPicker-Cpll3Z7O.cjs.map +1 -0
  325. package/dist/chunks/{NcHeaderMenu-CzS2doDR.cjs → NcHeaderMenu-BaHhnhN0.cjs} +3 -4
  326. package/dist/chunks/NcHeaderMenu-BaHhnhN0.cjs.map +1 -0
  327. package/dist/chunks/{NcHeaderMenu-vLqcJ-_w.mjs → NcHeaderMenu-CLcpStap.mjs} +3 -4
  328. package/dist/chunks/NcHeaderMenu-CLcpStap.mjs.map +1 -0
  329. package/dist/chunks/{NcInputConfirmCancel-DwmLGFYb.mjs → NcInputConfirmCancel-ruvJ51Mx.mjs} +2 -2
  330. package/dist/chunks/{NcInputConfirmCancel-DwmLGFYb.mjs.map → NcInputConfirmCancel-ruvJ51Mx.mjs.map} +1 -1
  331. package/dist/chunks/{NcInputConfirmCancel-CYQsG_3t.cjs → NcInputConfirmCancel-usP54-1l.cjs} +2 -2
  332. package/dist/chunks/{NcInputConfirmCancel-CYQsG_3t.cjs.map → NcInputConfirmCancel-usP54-1l.cjs.map} +1 -1
  333. package/dist/chunks/{NcInputField-ixTTHy3h.mjs → NcInputField-CU5a68Pc.mjs} +6 -7
  334. package/dist/chunks/NcInputField-CU5a68Pc.mjs.map +1 -0
  335. package/dist/chunks/{NcInputField-CbBdbdE8.cjs → NcInputField-DkhKrb8k.cjs} +6 -7
  336. package/dist/chunks/NcInputField-DkhKrb8k.cjs.map +1 -0
  337. package/dist/chunks/{NcListItem-DMaVvwXJ.cjs → NcListItem-DD-ogntB.cjs} +7 -12
  338. package/dist/chunks/{NcListItem-DMaVvwXJ.cjs.map → NcListItem-DD-ogntB.cjs.map} +1 -1
  339. package/dist/chunks/{NcListItem-DCh0J8Z4.mjs → NcListItem-Du0jflbS.mjs} +7 -12
  340. package/dist/chunks/{NcListItem-DCh0J8Z4.mjs.map → NcListItem-Du0jflbS.mjs.map} +1 -1
  341. package/dist/chunks/{NcListItemIcon-C6Ok3G7x.mjs → NcListItemIcon-21-8tZ2J.mjs} +2 -3
  342. package/dist/chunks/{NcListItemIcon-C6Ok3G7x.mjs.map → NcListItemIcon-21-8tZ2J.mjs.map} +1 -1
  343. package/dist/chunks/{NcListItemIcon-BLvWsnbD.cjs → NcListItemIcon-BP2C6QPu.cjs} +2 -3
  344. package/dist/chunks/{NcListItemIcon-BLvWsnbD.cjs.map → NcListItemIcon-BP2C6QPu.cjs.map} +1 -1
  345. package/dist/chunks/{NcPasswordField-CAGGdgVF.mjs → NcPasswordField-C6zTx4jJ.mjs} +16 -13
  346. package/dist/chunks/NcPasswordField-C6zTx4jJ.mjs.map +1 -0
  347. package/dist/chunks/{NcPasswordField-DLuNgJF2.cjs → NcPasswordField-DbFsY4Md.cjs} +18 -15
  348. package/dist/chunks/NcPasswordField-DbFsY4Md.cjs.map +1 -0
  349. package/dist/chunks/{NcPopover-MxwUgZu1.cjs → NcPopover-BKlH1mbx.cjs} +12 -13
  350. package/dist/chunks/NcPopover-BKlH1mbx.cjs.map +1 -0
  351. package/dist/chunks/{NcPopover-DzYbNu-I.mjs → NcPopover-DFCPlZpS.mjs} +12 -13
  352. package/dist/chunks/NcPopover-DFCPlZpS.mjs.map +1 -0
  353. package/dist/chunks/{NcRelatedResourcesPanel-BRoP-NiB.cjs → NcRelatedResourcesPanel-BlasfRyj.cjs} +11 -6
  354. package/dist/chunks/NcRelatedResourcesPanel-BlasfRyj.cjs.map +1 -0
  355. package/dist/chunks/{NcRelatedResourcesPanel-Bts9eDYA.mjs → NcRelatedResourcesPanel-D1wjzlCt.mjs} +11 -6
  356. package/dist/chunks/NcRelatedResourcesPanel-D1wjzlCt.mjs.map +1 -0
  357. package/dist/chunks/{NcRichContenteditable-BznZW1Mm.mjs → NcRichContenteditable-BGdgK6Rt.mjs} +21 -21
  358. package/dist/chunks/NcRichContenteditable-BGdgK6Rt.mjs.map +1 -0
  359. package/dist/chunks/{NcRichContenteditable-GOiGqL9S.cjs → NcRichContenteditable-DVD649BN.cjs} +21 -21
  360. package/dist/chunks/NcRichContenteditable-DVD649BN.cjs.map +1 -0
  361. package/dist/chunks/{NcRichText-BNxuFkK-.cjs → NcRichText-CnnsKa8W.cjs} +28 -41
  362. package/dist/chunks/NcRichText-CnnsKa8W.cjs.map +1 -0
  363. package/dist/chunks/{NcRichText-CytzoTXW.mjs → NcRichText-LKapJOAf.mjs} +29 -42
  364. package/dist/chunks/NcRichText-LKapJOAf.mjs.map +1 -0
  365. package/dist/chunks/{NcSelect-DvGJHzaa.mjs → NcSelect-BvpEfjtz.mjs} +3 -3
  366. package/dist/chunks/{NcSelect-DvGJHzaa.mjs.map → NcSelect-BvpEfjtz.mjs.map} +1 -1
  367. package/dist/chunks/{NcSelect-Cp83bFsi.cjs → NcSelect-Cr_CFqNk.cjs} +3 -3
  368. package/dist/chunks/{NcSelect-Cp83bFsi.cjs.map → NcSelect-Cr_CFqNk.cjs.map} +1 -1
  369. package/dist/chunks/{NcSelectTags-Bi9DIwx_.cjs → NcSelectTags-BxJEJZ0W.cjs} +2 -2
  370. package/dist/chunks/{NcSelectTags-Bi9DIwx_.cjs.map → NcSelectTags-BxJEJZ0W.cjs.map} +1 -1
  371. package/dist/chunks/{NcSelectTags-B4PjZQtt.mjs → NcSelectTags-yVos6fB8.mjs} +2 -2
  372. package/dist/chunks/{NcSelectTags-B4PjZQtt.mjs.map → NcSelectTags-yVos6fB8.mjs.map} +1 -1
  373. package/dist/chunks/{NcSettingsInputText-DhZ_giTf.mjs → NcSettingsInputText-DzjW5iHT.mjs} +2 -2
  374. package/dist/chunks/{NcSettingsInputText-DhZ_giTf.mjs.map → NcSettingsInputText-DzjW5iHT.mjs.map} +1 -1
  375. package/dist/chunks/{NcSettingsInputText-BYq049Qz.cjs → NcSettingsInputText-GL0a7etX.cjs} +2 -2
  376. package/dist/chunks/{NcSettingsInputText-BYq049Qz.cjs.map → NcSettingsInputText-GL0a7etX.cjs.map} +1 -1
  377. package/dist/chunks/{NcSettingsSection-B7SqDXbX.mjs → NcSettingsSection-BXxHFEGz.mjs} +4 -4
  378. package/dist/chunks/{NcSettingsSection-B7SqDXbX.mjs.map → NcSettingsSection-BXxHFEGz.mjs.map} +1 -1
  379. package/dist/chunks/{NcSettingsSection-Dn7Qmknm.cjs → NcSettingsSection-CJYVADt2.cjs} +4 -4
  380. package/dist/chunks/{NcSettingsSection-Dn7Qmknm.cjs.map → NcSettingsSection-CJYVADt2.cjs.map} +1 -1
  381. package/dist/chunks/{NcSettingsSelectGroup-DypyXuEW.cjs → NcSettingsSelectGroup-BTnOlySM.cjs} +3 -3
  382. package/dist/chunks/{NcSettingsSelectGroup-DypyXuEW.cjs.map → NcSettingsSelectGroup-BTnOlySM.cjs.map} +1 -1
  383. package/dist/chunks/{NcSettingsSelectGroup-BAhG6V1R.mjs → NcSettingsSelectGroup-BiI2D550.mjs} +3 -3
  384. package/dist/chunks/{NcSettingsSelectGroup-BAhG6V1R.mjs.map → NcSettingsSelectGroup-BiI2D550.mjs.map} +1 -1
  385. package/dist/chunks/{NcTextField-rCaBV_TN.cjs → NcTextField-BKXPIe0I.cjs} +9 -5
  386. package/dist/chunks/NcTextField-BKXPIe0I.cjs.map +1 -0
  387. package/dist/chunks/{NcTextField-8RXOuqAy.mjs → NcTextField-CIiNGo2q.mjs} +9 -5
  388. package/dist/chunks/NcTextField-CIiNGo2q.mjs.map +1 -0
  389. package/dist/chunks/{NcTimezonePicker-D64nWJh7.mjs → NcTimezonePicker-B5lkrpg4.mjs} +4 -4
  390. package/dist/chunks/{NcTimezonePicker-D64nWJh7.mjs.map → NcTimezonePicker-B5lkrpg4.mjs.map} +1 -1
  391. package/dist/chunks/{NcTimezonePicker-B5ps-VnZ.cjs → NcTimezonePicker-CouwhWKh.cjs} +4 -4
  392. package/dist/chunks/{NcTimezonePicker-B5ps-VnZ.cjs.map → NcTimezonePicker-CouwhWKh.cjs.map} +1 -1
  393. package/dist/chunks/{NcUserBubble-Q0TscgXh.mjs → NcUserBubble-7svwYkFv.mjs} +5 -5
  394. package/dist/chunks/{NcUserBubble-Q0TscgXh.mjs.map → NcUserBubble-7svwYkFv.mjs.map} +1 -1
  395. package/dist/chunks/{NcUserBubble-Cg86HaKF.cjs → NcUserBubble-CT8n4fXf.cjs} +5 -5
  396. package/dist/chunks/{NcUserBubble-Cg86HaKF.cjs.map → NcUserBubble-CT8n4fXf.cjs.map} +1 -1
  397. package/dist/chunks/{NcUserStatusIcon-CvuiXAZR.mjs → NcUserStatusIcon-BRDxSfqh.mjs} +3 -3
  398. package/dist/chunks/{NcUserStatusIcon-CvuiXAZR.mjs.map → NcUserStatusIcon-BRDxSfqh.mjs.map} +1 -1
  399. package/dist/chunks/{NcUserStatusIcon-CP1EGHie.cjs → NcUserStatusIcon-CRX6G1lZ.cjs} +3 -3
  400. package/dist/chunks/{NcUserStatusIcon-CP1EGHie.cjs.map → NcUserStatusIcon-CRX6G1lZ.cjs.map} +1 -1
  401. package/dist/chunks/{ScopeComponent-ClDcATYc.cjs → ScopeComponent-DumACiuv.cjs} +1 -1
  402. package/dist/chunks/{ScopeComponent-ClDcATYc.cjs.map → ScopeComponent-DumACiuv.cjs.map} +1 -1
  403. package/dist/chunks/{ScopeComponent-BLLOK04K.mjs → ScopeComponent-l9iK4gT7.mjs} +1 -1
  404. package/dist/chunks/{ScopeComponent-BLLOK04K.mjs.map → ScopeComponent-l9iK4gT7.mjs.map} +1 -1
  405. package/dist/chunks/_l10n-BFZBMn-A.mjs +130 -0
  406. package/dist/chunks/_l10n-BFZBMn-A.mjs.map +1 -0
  407. package/dist/chunks/_l10n-CUjmuQOi.cjs +129 -0
  408. package/dist/chunks/{_l10n-Ch5mEdUH.cjs.map → _l10n-CUjmuQOi.cjs.map} +1 -1
  409. package/dist/chunks/{index-bI_wyL5-.cjs → index-BiECbTbJ.cjs} +3 -4
  410. package/dist/chunks/index-BiECbTbJ.cjs.map +1 -0
  411. package/dist/chunks/{index-bjwozrEX.mjs → index-G8WQDZ8G.mjs} +3 -4
  412. package/dist/chunks/index-G8WQDZ8G.mjs.map +1 -0
  413. package/dist/chunks/logger-3HuiEIF6.cjs +4 -0
  414. package/dist/chunks/logger-3HuiEIF6.cjs.map +1 -0
  415. package/dist/chunks/logger-D3RVzcfQ.mjs +5 -0
  416. package/dist/chunks/logger-D3RVzcfQ.mjs.map +1 -0
  417. package/dist/chunks/{referencePickerModal-C4eGo6D2.cjs → referencePickerModal-C81hzdRI.cjs} +14 -14
  418. package/dist/chunks/referencePickerModal-C81hzdRI.cjs.map +1 -0
  419. package/dist/chunks/{referencePickerModal-C6YJvRC9.mjs → referencePickerModal-O217yxI1.mjs} +14 -14
  420. package/dist/chunks/referencePickerModal-O217yxI1.mjs.map +1 -0
  421. package/dist/chunks/{usernameToColor-Cx2qDZ1W.mjs → usernameToColor-D4cWttCX.mjs} +1 -1
  422. package/dist/chunks/{usernameToColor-Cx2qDZ1W.mjs.map → usernameToColor-D4cWttCX.mjs.map} +1 -1
  423. package/dist/chunks/{usernameToColor-CWxjw-Pq.cjs → usernameToColor-D_kVgtXG.cjs} +1 -1
  424. package/dist/chunks/{usernameToColor-CWxjw-Pq.cjs.map → usernameToColor-D_kVgtXG.cjs.map} +1 -1
  425. package/dist/composables/useFormatDateTime.d.ts +20 -21
  426. package/dist/composables/useIsDarkTheme/index.d.ts +0 -1
  427. package/dist/functions/contactsMenu/index.d.ts +40 -0
  428. package/dist/functions/dialog/index.d.ts +0 -1
  429. package/dist/functions/index.d.ts +1 -0
  430. package/dist/index.cjs +56 -53
  431. package/dist/index.cjs.map +1 -1
  432. package/dist/index.mjs +57 -54
  433. package/dist/index.mjs.map +1 -1
  434. package/dist/plugin.d.ts +0 -1
  435. package/dist/utils/logger.d.ts +5 -0
  436. package/package.json +29 -11
  437. package/dist/assets/NcDateTimePickerNative-BfZfqRvD.css +0 -47
  438. package/dist/assets/NcRichText-BlRmdWCX.css +0 -412
  439. package/dist/chunks/Linkify-BtgR-dXX.mjs +0 -14
  440. package/dist/chunks/Linkify-BtgR-dXX.mjs.map +0 -1
  441. package/dist/chunks/Linkify-yeOn5L6T.cjs +0 -15
  442. package/dist/chunks/Linkify-yeOn5L6T.cjs.map +0 -1
  443. package/dist/chunks/NcActionRadio-Dl6W62Vm.mjs.map +0 -1
  444. package/dist/chunks/NcActionRadio-vHwjWOHS.cjs.map +0 -1
  445. package/dist/chunks/NcActionTextEditable-97R7dFen.cjs.map +0 -1
  446. package/dist/chunks/NcActionTextEditable-DZCFtqIP.mjs.map +0 -1
  447. package/dist/chunks/NcAppContent-CIMgDnJM.mjs.map +0 -1
  448. package/dist/chunks/NcAppContent-DdzUMomS.cjs.map +0 -1
  449. package/dist/chunks/NcAppNavigation-BuKJwvwT.cjs.map +0 -1
  450. package/dist/chunks/NcAppNavigation-wz0Fsxe4.mjs.map +0 -1
  451. package/dist/chunks/NcAppNavigationItem-BkkuFdfa.mjs.map +0 -1
  452. package/dist/chunks/NcAppNavigationItem-Y_CVXzId.cjs.map +0 -1
  453. package/dist/chunks/NcAppNavigationToggle-Dw0ZPjy2.mjs.map +0 -1
  454. package/dist/chunks/NcAppNavigationToggle-Dwg-dMWx.cjs.map +0 -1
  455. package/dist/chunks/NcAvatar-B8e2YFLI.mjs.map +0 -1
  456. package/dist/chunks/NcAvatar-DypzACJs.cjs.map +0 -1
  457. package/dist/chunks/NcColorPicker-8wU8rMbF.mjs.map +0 -1
  458. package/dist/chunks/NcColorPicker-Df6UVuYn.cjs.map +0 -1
  459. package/dist/chunks/NcEmojiPicker-BSoMzxJl.mjs.map +0 -1
  460. package/dist/chunks/NcEmojiPicker-XRtfmbk_.cjs.map +0 -1
  461. package/dist/chunks/NcHeaderMenu-CzS2doDR.cjs.map +0 -1
  462. package/dist/chunks/NcHeaderMenu-vLqcJ-_w.mjs.map +0 -1
  463. package/dist/chunks/NcInputField-CbBdbdE8.cjs.map +0 -1
  464. package/dist/chunks/NcInputField-ixTTHy3h.mjs.map +0 -1
  465. package/dist/chunks/NcPasswordField-CAGGdgVF.mjs.map +0 -1
  466. package/dist/chunks/NcPasswordField-DLuNgJF2.cjs.map +0 -1
  467. package/dist/chunks/NcPopover-DzYbNu-I.mjs.map +0 -1
  468. package/dist/chunks/NcPopover-MxwUgZu1.cjs.map +0 -1
  469. package/dist/chunks/NcRelatedResourcesPanel-BRoP-NiB.cjs.map +0 -1
  470. package/dist/chunks/NcRelatedResourcesPanel-Bts9eDYA.mjs.map +0 -1
  471. package/dist/chunks/NcRichContenteditable-BznZW1Mm.mjs.map +0 -1
  472. package/dist/chunks/NcRichContenteditable-GOiGqL9S.cjs.map +0 -1
  473. package/dist/chunks/NcRichText-BNxuFkK-.cjs.map +0 -1
  474. package/dist/chunks/NcRichText-CytzoTXW.mjs.map +0 -1
  475. package/dist/chunks/NcTextField-8RXOuqAy.mjs.map +0 -1
  476. package/dist/chunks/NcTextField-rCaBV_TN.cjs.map +0 -1
  477. package/dist/chunks/_l10n-B-QPoWAJ.mjs +0 -132
  478. package/dist/chunks/_l10n-B-QPoWAJ.mjs.map +0 -1
  479. package/dist/chunks/_l10n-Ch5mEdUH.cjs +0 -131
  480. package/dist/chunks/index-bI_wyL5-.cjs.map +0 -1
  481. package/dist/chunks/index-bjwozrEX.mjs.map +0 -1
  482. package/dist/chunks/referencePickerModal-C4eGo6D2.cjs.map +0 -1
  483. package/dist/chunks/referencePickerModal-C6YJvRC9.mjs.map +0 -1
@@ -1,9 +1,9 @@
1
- require('../assets/NcAppNavigationToggle-Chtb7sE7.css');
1
+ require('../assets/NcAppNavigationToggle-B6FCDJp7.css');
2
2
  "use strict";
3
3
  const Components_NcButton = require("../Components/NcButton.cjs");
4
- const _l10n = require("./_l10n-Ch5mEdUH.cjs");
4
+ const _l10n = require("./_l10n-CUjmuQOi.cjs");
5
5
  const _pluginVue2_normalizer = require("./_plugin-vue2_normalizer-V0q-tHlQ.cjs");
6
- _l10n.register(_l10n.t19);
6
+ _l10n.register(_l10n.t18);
7
7
  const _sfc_main$2 = {
8
8
  name: "MenuIcon",
9
9
  emits: ["click"],
@@ -70,6 +70,7 @@ var __component__$1 = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
70
70
  null
71
71
  );
72
72
  const MenuOpenIcon = __component__$1.exports;
73
+ const disableKeyboardShortcuts = window.OCP?.Accessibility?.disableKeyboardShortcuts?.();
73
74
  const _sfc_main = {
74
75
  name: "NcAppNavigationToggle",
75
76
  components: {
@@ -89,9 +90,12 @@ const _sfc_main = {
89
90
  }
90
91
  },
91
92
  emits: ["update:open"],
93
+ setup() {
94
+ return { disableKeyboardShortcuts };
95
+ },
92
96
  computed: {
93
97
  label() {
94
- return this.open ? _l10n.t("Close navigation") : _l10n.t("Open navigation");
98
+ return this.open ? _l10n.t("Close navigation") : _l10n.t("Open navigation {shortcut}", { shortcut: disableKeyboardShortcuts ? "" : "[n]" }).trim();
95
99
  }
96
100
  },
97
101
  methods: {
@@ -106,7 +110,7 @@ const _sfc_main = {
106
110
  };
107
111
  var _sfc_render = function render3() {
108
112
  var _vm = this, _c = _vm._self._c;
109
- return _c("div", { staticClass: "app-navigation-toggle-wrapper" }, [_c("NcButton", { staticClass: "app-navigation-toggle", attrs: { "type": "tertiary", "aria-expanded": _vm.open ? "true" : "false", "aria-label": _vm.label, "title": _vm.label, "aria-controls": "app-navigation-vue" }, on: { "click": _vm.toggleNavigation }, scopedSlots: _vm._u([{ key: "icon", fn: function() {
113
+ return _c("div", { staticClass: "app-navigation-toggle-wrapper" }, [_c("NcButton", { staticClass: "app-navigation-toggle", attrs: { "type": "tertiary", "aria-expanded": _vm.open ? "true" : "false", "aria-label": _vm.label, "title": _vm.label, "aria-controls": "app-navigation-vue", "aria-keyshortcuts": _vm.disableKeyboardShortcuts ? "" : "n" }, on: { "click": _vm.toggleNavigation }, scopedSlots: _vm._u([{ key: "icon", fn: function() {
110
114
  return [_vm.open ? _c("MenuOpenIcon", { attrs: { "size": 20 } }) : _c("MenuIcon", { attrs: { "size": 20 } })];
111
115
  }, proxy: true }]) })], 1);
112
116
  };
@@ -117,7 +121,7 @@ var __component__ = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
117
121
  _sfc_staticRenderFns,
118
122
  false,
119
123
  null,
120
- "75672696"
124
+ "87a1d6fa"
121
125
  );
122
126
  const NcAppNavigationToggle = __component__.exports;
123
127
  exports.NcAppNavigationToggle = NcAppNavigationToggle;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcAppNavigationToggle-BbDj_xom.cjs","sources":["../../node_modules/vue-material-design-icons/Menu.vue","../../node_modules/vue-material-design-icons/MenuOpen.vue","../../src/components/NcAppNavigationToggle/NcAppNavigationToggle.vue"],"sourcesContent":["<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon menu-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M3,6H21V8H3V6M3,11H21V13H3V11M3,16H21V18H3V16Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"MenuIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>","<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon menu-open-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M21,15.61L19.59,17L14.58,12L19.59,7L21,8.39L17.44,12L21,15.61M3,6H16V8H3V6M3,13V11H13V13H3M3,18V16H16V18H3Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"MenuOpenIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>","<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<template>\n\t<div class=\"app-navigation-toggle-wrapper\">\n\t\t<NcButton class=\"app-navigation-toggle\"\n\t\t\ttype=\"tertiary\"\n\t\t\t:aria-expanded=\"open ? 'true' : 'false'\"\n\t\t\t:aria-label=\"label\"\n\t\t\t:title=\"label\"\n\t\t\taria-controls=\"app-navigation-vue\"\n\t\t\t:aria-keyshortcuts=\"disableKeyboardShortcuts ? '' : 'n'\"\n\t\t\t@click=\"toggleNavigation\">\n\t\t\t<template #icon>\n\t\t\t\t<MenuOpenIcon v-if=\"open\" :size=\"20\" />\n\t\t\t\t<MenuIcon v-else :size=\"20\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t</div>\n</template>\n\n<script>\nimport NcButton from '../NcButton/index.js'\nimport { t } from '../../l10n.js'\n\nimport MenuIcon from 'vue-material-design-icons/Menu.vue'\nimport MenuOpenIcon from 'vue-material-design-icons/MenuOpen.vue'\n\nconst disableKeyboardShortcuts = window.OCP?.Accessibility?.disableKeyboardShortcuts?.()\n\nexport default {\n\tname: 'NcAppNavigationToggle',\n\n\tcomponents: {\n\t\tNcButton,\n\t\tMenuIcon,\n\t\tMenuOpenIcon,\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Tracks whether the toggle has been clicked or not.\n\t\t * If it has been clicked, switches between the different MenuIcons\n\t\t * and emits a boolean indicating its opened status\n\t\t */\n\t\topen: {\n\t\t\ttype: Boolean,\n\t\t\trequired: true,\n\t\t},\n\t},\n\n\temits: ['update:open'],\n\n\tsetup() {\n\t\treturn { disableKeyboardShortcuts }\n\t},\n\n\tcomputed: {\n\t\tlabel() {\n\t\t\treturn this.open\n\t\t\t\t? t('Close navigation')\n\t\t\t\t: t('Open navigation {shortcut}', { shortcut: disableKeyboardShortcuts ? '' : '[n]' }).trim()\n\t\t},\n\t},\n\tmethods: {\n\t\t/**\n\t\t * Once the toggle has been clicked, emits the toggle status\n\t\t * so parent components can gauge the status of the navigation button\n\t\t */\n\t\ttoggleNavigation() {\n\t\t\tthis.$emit('update:open', !this.open)\n\t\t},\n\t},\n}\n</script>\n\n<style scoped lang=\"scss\">\n.app-navigation-toggle-wrapper {\n\tposition: absolute;\n\ttop: var(--app-navigation-padding);\n\tinset-inline-end: calc(0px - var(--app-navigation-padding));\n\tmargin-inline-end: calc(-1 * var(--default-clickable-area));\n}\n\nbutton.app-navigation-toggle {\n\tbackground-color: var(--color-main-background);\n}\n</style>\n"],"names":["_sfc_main","NcButton","t"],"mappings":";;;;;AAoBA,MAAAA,cAAA;AAAA,EACA,MAAA;AAAA,EACA,OAAA,CAAA,OAAA;AAAA,EACA,OAAA;AAAA,IACA,OAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,IACA,WAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,IACA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;;AChBA,MAAAA,cAAA;AAAA,EACA,MAAA;AAAA,EACA,OAAA,CAAA,OAAA;AAAA,EACA,OAAA;AAAA,IACA,OAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,IACA,WAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,IACA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;;ACNA,MAAA,2BAAA,OAAA,KAAA,eAAA,2BAAA;AAEA,MAAA,YAAA;AAAA,EACA,MAAA;AAAA,EAEA,YAAA;AAAA,IACA,UAAAC;AAAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA,CAAA,aAAA;AAAA,EAEA,QAAA;AACA,WAAA,EAAA,yBAAA;AAAA,EACA;AAAA,EAEA,UAAA;AAAA,IACA,QAAA;AACA,aAAA,KAAA,OACAC,MAAAA,EAAA,kBAAA,IACAA,QAAA,8BAAA,EAAA,UAAA,2BAAA,KAAA,MAAA,CAAA,EAAA,KAAA;AAAA,IACA;AAAA,EACA;AAAA,EACA,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAKA,mBAAA;AACA,WAAA,MAAA,eAAA,CAAA,KAAA,IAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;;;","x_google_ignoreList":[0,1]}
@@ -1,8 +1,8 @@
1
- import '../assets/NcAppNavigationToggle-Chtb7sE7.css';
1
+ import '../assets/NcAppNavigationToggle-B6FCDJp7.css';
2
2
  import NcButton from "../Components/NcButton.mjs";
3
- import { r as register, C as t19, a as t } from "./_l10n-B-QPoWAJ.mjs";
3
+ import { r as register, C as t18, a as t } from "./_l10n-BFZBMn-A.mjs";
4
4
  import { n as normalizeComponent } from "./_plugin-vue2_normalizer-DU4iP6Vu.mjs";
5
- register(t19);
5
+ register(t18);
6
6
  const _sfc_main$2 = {
7
7
  name: "MenuIcon",
8
8
  emits: ["click"],
@@ -69,6 +69,7 @@ var __component__$1 = /* @__PURE__ */ normalizeComponent(
69
69
  null
70
70
  );
71
71
  const MenuOpenIcon = __component__$1.exports;
72
+ const disableKeyboardShortcuts = window.OCP?.Accessibility?.disableKeyboardShortcuts?.();
72
73
  const _sfc_main = {
73
74
  name: "NcAppNavigationToggle",
74
75
  components: {
@@ -88,9 +89,12 @@ const _sfc_main = {
88
89
  }
89
90
  },
90
91
  emits: ["update:open"],
92
+ setup() {
93
+ return { disableKeyboardShortcuts };
94
+ },
91
95
  computed: {
92
96
  label() {
93
- return this.open ? t("Close navigation") : t("Open navigation");
97
+ return this.open ? t("Close navigation") : t("Open navigation {shortcut}", { shortcut: disableKeyboardShortcuts ? "" : "[n]" }).trim();
94
98
  }
95
99
  },
96
100
  methods: {
@@ -105,7 +109,7 @@ const _sfc_main = {
105
109
  };
106
110
  var _sfc_render = function render3() {
107
111
  var _vm = this, _c = _vm._self._c;
108
- return _c("div", { staticClass: "app-navigation-toggle-wrapper" }, [_c("NcButton", { staticClass: "app-navigation-toggle", attrs: { "type": "tertiary", "aria-expanded": _vm.open ? "true" : "false", "aria-label": _vm.label, "title": _vm.label, "aria-controls": "app-navigation-vue" }, on: { "click": _vm.toggleNavigation }, scopedSlots: _vm._u([{ key: "icon", fn: function() {
112
+ return _c("div", { staticClass: "app-navigation-toggle-wrapper" }, [_c("NcButton", { staticClass: "app-navigation-toggle", attrs: { "type": "tertiary", "aria-expanded": _vm.open ? "true" : "false", "aria-label": _vm.label, "title": _vm.label, "aria-controls": "app-navigation-vue", "aria-keyshortcuts": _vm.disableKeyboardShortcuts ? "" : "n" }, on: { "click": _vm.toggleNavigation }, scopedSlots: _vm._u([{ key: "icon", fn: function() {
109
113
  return [_vm.open ? _c("MenuOpenIcon", { attrs: { "size": 20 } }) : _c("MenuIcon", { attrs: { "size": 20 } })];
110
114
  }, proxy: true }]) })], 1);
111
115
  };
@@ -116,7 +120,7 @@ var __component__ = /* @__PURE__ */ normalizeComponent(
116
120
  _sfc_staticRenderFns,
117
121
  false,
118
122
  null,
119
- "75672696"
123
+ "87a1d6fa"
120
124
  );
121
125
  const NcAppNavigationToggle = __component__.exports;
122
126
  export {
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcAppNavigationToggle-Z_4QmE4l.mjs","sources":["../../node_modules/vue-material-design-icons/Menu.vue","../../node_modules/vue-material-design-icons/MenuOpen.vue","../../src/components/NcAppNavigationToggle/NcAppNavigationToggle.vue"],"sourcesContent":["<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon menu-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M3,6H21V8H3V6M3,11H21V13H3V11M3,16H21V18H3V16Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"MenuIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>","<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon menu-open-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M21,15.61L19.59,17L14.58,12L19.59,7L21,8.39L17.44,12L21,15.61M3,6H16V8H3V6M3,13V11H13V13H3M3,18V16H16V18H3Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"MenuOpenIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>","<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<template>\n\t<div class=\"app-navigation-toggle-wrapper\">\n\t\t<NcButton class=\"app-navigation-toggle\"\n\t\t\ttype=\"tertiary\"\n\t\t\t:aria-expanded=\"open ? 'true' : 'false'\"\n\t\t\t:aria-label=\"label\"\n\t\t\t:title=\"label\"\n\t\t\taria-controls=\"app-navigation-vue\"\n\t\t\t:aria-keyshortcuts=\"disableKeyboardShortcuts ? '' : 'n'\"\n\t\t\t@click=\"toggleNavigation\">\n\t\t\t<template #icon>\n\t\t\t\t<MenuOpenIcon v-if=\"open\" :size=\"20\" />\n\t\t\t\t<MenuIcon v-else :size=\"20\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t</div>\n</template>\n\n<script>\nimport NcButton from '../NcButton/index.js'\nimport { t } from '../../l10n.js'\n\nimport MenuIcon from 'vue-material-design-icons/Menu.vue'\nimport MenuOpenIcon from 'vue-material-design-icons/MenuOpen.vue'\n\nconst disableKeyboardShortcuts = window.OCP?.Accessibility?.disableKeyboardShortcuts?.()\n\nexport default {\n\tname: 'NcAppNavigationToggle',\n\n\tcomponents: {\n\t\tNcButton,\n\t\tMenuIcon,\n\t\tMenuOpenIcon,\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Tracks whether the toggle has been clicked or not.\n\t\t * If it has been clicked, switches between the different MenuIcons\n\t\t * and emits a boolean indicating its opened status\n\t\t */\n\t\topen: {\n\t\t\ttype: Boolean,\n\t\t\trequired: true,\n\t\t},\n\t},\n\n\temits: ['update:open'],\n\n\tsetup() {\n\t\treturn { disableKeyboardShortcuts }\n\t},\n\n\tcomputed: {\n\t\tlabel() {\n\t\t\treturn this.open\n\t\t\t\t? t('Close navigation')\n\t\t\t\t: t('Open navigation {shortcut}', { shortcut: disableKeyboardShortcuts ? '' : '[n]' }).trim()\n\t\t},\n\t},\n\tmethods: {\n\t\t/**\n\t\t * Once the toggle has been clicked, emits the toggle status\n\t\t * so parent components can gauge the status of the navigation button\n\t\t */\n\t\ttoggleNavigation() {\n\t\t\tthis.$emit('update:open', !this.open)\n\t\t},\n\t},\n}\n</script>\n\n<style scoped lang=\"scss\">\n.app-navigation-toggle-wrapper {\n\tposition: absolute;\n\ttop: var(--app-navigation-padding);\n\tinset-inline-end: calc(0px - var(--app-navigation-padding));\n\tmargin-inline-end: calc(-1 * var(--default-clickable-area));\n}\n\nbutton.app-navigation-toggle {\n\tbackground-color: var(--color-main-background);\n}\n</style>\n"],"names":["_sfc_main"],"mappings":";;;;AAoBA,MAAAA,cAAA;AAAA,EACA,MAAA;AAAA,EACA,OAAA,CAAA,OAAA;AAAA,EACA,OAAA;AAAA,IACA,OAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,IACA,WAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,IACA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;;AChBA,MAAAA,cAAA;AAAA,EACA,MAAA;AAAA,EACA,OAAA,CAAA,OAAA;AAAA,EACA,OAAA;AAAA,IACA,OAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,IACA,WAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,IACA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;;ACNA,MAAA,2BAAA,OAAA,KAAA,eAAA,2BAAA;AAEA,MAAA,YAAA;AAAA,EACA,MAAA;AAAA,EAEA,YAAA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA,CAAA,aAAA;AAAA,EAEA,QAAA;AACA,WAAA,EAAA,yBAAA;AAAA,EACA;AAAA,EAEA,UAAA;AAAA,IACA,QAAA;AACA,aAAA,KAAA,OACA,EAAA,kBAAA,IACA,EAAA,8BAAA,EAAA,UAAA,2BAAA,KAAA,MAAA,CAAA,EAAA,KAAA;AAAA,IACA;AAAA,EACA;AAAA,EACA,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAKA,mBAAA;AACA,WAAA,MAAA,eAAA,CAAA,KAAA,IAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;;","x_google_ignoreList":[0,1]}
@@ -1,16 +1,16 @@
1
1
  require('../assets/NcAppSettingsDialog-kKMMsdb3.css');
2
2
  "use strict";
3
- const NcDialog = require("./NcDialog-CWGgSCpv.cjs");
3
+ const NcDialog = require("./NcDialog-CfYmQm13.cjs");
4
4
  const Components_NcVNodes = require("../Components/NcVNodes.cjs");
5
5
  const Composables_useIsMobile = require("../Composables/useIsMobile.cjs");
6
- const _l10n = require("./_l10n-Ch5mEdUH.cjs");
6
+ const _l10n = require("./_l10n-CUjmuQOi.cjs");
7
7
  const debounce = require("debounce");
8
8
  const Vue = require("vue");
9
9
  const _pluginVue2_normalizer = require("./_plugin-vue2_normalizer-V0q-tHlQ.cjs");
10
10
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
11
11
  const debounce__default = /* @__PURE__ */ _interopDefault(debounce);
12
12
  const Vue__default = /* @__PURE__ */ _interopDefault(Vue);
13
- _l10n.register(_l10n.t45);
13
+ _l10n.register(_l10n.t44);
14
14
  const _sfc_main = {
15
15
  name: "NcAppSettingsDialog",
16
16
  components: {
@@ -1 +1 @@
1
- {"version":3,"file":"NcAppSettingsDialog-Dkl3cqU-.cjs","sources":["../../src/components/NcAppSettingsDialog/NcAppSettingsDialog.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nJust nest the `AppSettingSections` component into `NcAppSettingsDialog`,\nproviding the section's name prop. You can put your settings within each\n`NcAppSettingsSection` component.\n\n```vue\n<template>\n\t<div>\n\t\t<NcButton @click=\"settingsOpen = true\">Show Settings</NcButton>\n\t\t<NcAppSettingsDialog :open.sync=\"settingsOpen\" :show-navigation=\"true\" name=\"Application settings\">\n\t\t\t<NcAppSettingsSection id=\"asci-name-1\" name=\"Example name 1\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-2\" name=\"Example name 2\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-3\" name=\"Example name 3\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-4\" name=\"Example name 4\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-5\" name=\"Example name 5\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-6\" name=\"Example name 6\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-7\" name=\"Example name 7\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-8\" name=\"Example name 8\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-9\" name=\"Example name 9\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-10\" name=\"Example name 10\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t</NcAppSettingsDialog>\n\t</div>\n</template>\n\n<script>\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\tsettingsOpen: false,\n\t\t}\n\t},\n}\n</script>\n```\n\nYou can also add icons to the section navigation:\n\n```vue\n<template>\n\t<div>\n\t\t<NcButton @click=\"settingsOpen = true\">Show Settings</NcButton>\n\t\t<NcAppSettingsDialog :open.sync=\"settingsOpen\" :show-navigation=\"true\" name=\"Application settings\">\n\t\t\t<NcAppSettingsSection id=\"asci-name-1\" name=\"Instagram\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Instagram :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tInstagram setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-2\" name=\"Mastodon\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Mastodon :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tMastodon setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-3\" name=\"Twitch\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Twitch :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tTwitch setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-4\" name=\"Twitter\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Twitter :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tTwitter setting\n\t\t\t</NcAppSettingsSection>\n\t\t</NcAppSettingsDialog>\n\t</div>\n</template>\n\n<script>\nimport Instagram from 'vue-material-design-icons/Instagram.vue'\nimport Mastodon from 'vue-material-design-icons/Mastodon.vue'\nimport Twitch from 'vue-material-design-icons/Twitch.vue'\nimport Twitter from 'vue-material-design-icons/Twitter.vue'\n\nexport default {\n\tcomponents: {\n\t\tInstagram,\n\t\tMastodon,\n\t\tTwitch,\n\t\tTwitter,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tsettingsOpen: false,\n\t\t}\n\t},\n}\n</script>\n```\n</docs>\n\n<template>\n\t<NcDialog v-if=\"open\"\n\t\t:navigation-aria-label=\"settingsNavigationAriaLabel\"\n\t\tv-bind=\"dialogProperties\"\n\t\t@update:open=\"handleCloseModal\">\n\t\t<template v-if=\"hasNavigation\" #navigation=\"{ isCollapsed }\">\n\t\t\t<ul v-if=\"!isCollapsed\"\n\t\t\t\tclass=\"navigation-list\">\n\t\t\t\t<li v-for=\"section in sections\" :key=\"section.id\">\n\t\t\t\t\t<a :aria-current=\"`${section.id === selectedSection}`\"\n\t\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t\t'navigation-list__link': true,\n\t\t\t\t\t\t\t'navigation-list__link--active': section.id === selectedSection,\n\t\t\t\t\t\t\t'navigation-list__link--icon': hasNavigationIcons,\n\t\t\t\t\t\t}\"\n\t\t\t\t\t\t:href=\"`#settings-section_${section.id}`\"\n\t\t\t\t\t\ttabindex=\"0\"\n\t\t\t\t\t\t@click.prevent=\"handleSettingsNavigationClick(section.id)\"\n\t\t\t\t\t\t@keydown.enter=\"handleSettingsNavigationClick(section.id)\">\n\t\t\t\t\t\t<div v-if=\"hasNavigationIcons\" class=\"navigation-list__link-icon\">\n\t\t\t\t\t\t\t<NcVNodes v-if=\"section.icon\" :vnodes=\"section.icon\" />\n\t\t\t\t\t\t</div>\n\t\t\t\t\t\t<span class=\"navigation-list__link-text\">\n\t\t\t\t\t\t\t{{ section.name }}\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</a>\n\t\t\t\t</li>\n\t\t\t</ul>\n\t\t</template>\n\t\t<div ref=\"settingsScroller\">\n\t\t\t<slot />\n\t\t</div>\n\t</NcDialog>\n</template>\n\n<script>\nimport NcDialog from '../NcDialog/index.js'\nimport NcVNodes from '../NcVNodes/index.js'\nimport { useIsMobile } from '../../composables/useIsMobile/index.js'\nimport { t } from '../../l10n.js'\n\nimport debounce from 'debounce'\nimport Vue from 'vue'\n\nexport default {\n\n\tname: 'NcAppSettingsDialog',\n\n\tcomponents: {\n\t\tNcDialog,\n\t\tNcVNodes,\n\t},\n\n\tprovide() {\n\t\treturn {\n\t\t\tregisterSection: this.registerSection,\n\t\t\tunregisterSection: this.unregisterSection,\n\t\t}\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Determines the open / closed state of the modal\n\t\t */\n\t\topen: {\n\t\t\ttype: Boolean,\n\t\t\trequired: true,\n\t\t},\n\t\t/**\n\t\t * Shows the navigation on desktop if true\n\t\t */\n\t\tshowNavigation: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Selector for the popover container\n\t\t */\n\t\tcontainer: {\n\t\t\ttype: String,\n\t\t\tdefault: 'body',\n\t\t},\n\n\t\t/**\n\t\t * Name of the settings\n\t\t */\n\t\tname: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Additional elements to add to the focus trap\n\t\t */\n\t\tadditionalTrapElements: {\n\t\t\ttype: Array,\n\t\t\tdefault: () => [],\n\t\t},\n\n\t},\n\n\temits: ['update:open'],\n\n\tsetup() {\n\t\treturn {\n\t\t\tisMobile: useIsMobile(),\n\t\t}\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tselectedSection: '',\n\t\t\tlinkClicked: false,\n\t\t\taddedScrollListener: false,\n\t\t\tscroller: null,\n\t\t\t/**\n\t\t\t * Currently registered settings sections\n\t\t\t * @type {{ id: string, name: string, icon?: import('vue').VNode[] }[]}\n\t\t\t */\n\t\t\tsections: [],\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tdialogProperties() {\n\t\t\treturn {\n\t\t\t\tadditionalTrapElements: this.additionalTrapElements,\n\t\t\t\tcloseOnClickOutside: true,\n\t\t\t\tclass: 'app-settings',\n\t\t\t\tcontainer: this.container,\n\t\t\t\tcontentClasses: 'app-settings__content',\n\t\t\t\tsize: 'large',\n\t\t\t\tname: this.name,\n\t\t\t\tnavigationClasses: 'app-settings__navigation',\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Check if one or more navigation entries provide icons\n\t\t */\n\t\thasNavigationIcons() {\n\t\t\treturn this.sections.some(({ icon }) => !!icon)\n\t\t},\n\n\t\thasNavigation() {\n\t\t\tif (this.isMobile || !this.showNavigation) {\n\t\t\t\treturn false\n\t\t\t} else {\n\t\t\t\treturn true\n\t\t\t}\n\t\t},\n\n\t\tsettingsNavigationAriaLabel() {\n\t\t\treturn t('Settings navigation')\n\t\t},\n\t},\n\n\tupdated() {\n\t\t// Check that the scroller element has been mounted\n\t\tif (!this.$refs.settingsScroller) {\n\t\t\treturn\n\t\t}\n\t\t// Get the scroller element\n\t\tthis.scroller = this.$refs.settingsScroller\n\t\tif (!this.addedScrollListener) {\n\t\t\tthis.scroller.addEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = true\n\t\t}\n\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Called when a new section is registered\n\t\t * @param {string} id The section ID\n\t\t * @param {string} name The section name\n\t\t * @param {import('vue').VNode[]|undefined} icon Optional icon component\n\t\t */\n\t\tregisterSection(id, name, icon) {\n\t\t\t// Check for the uniqueness of section names\n\t\t\tif (this.sections.some(({ id: otherId }) => id === otherId)) {\n\t\t\t\tthrow new Error(`Duplicate section id found: ${id}. Settings navigation sections must have unique section ids.`)\n\t\t\t}\n\t\t\tif (this.sections.some(({ name: otherName }) => name === otherName)) {\n\t\t\t\tVue.util.warn(`Duplicate section name found: ${name}. Settings navigation sections must have unique section names.`)\n\t\t\t}\n\n\t\t\tconst newSections = [...this.sections, { id, name, icon }]\n\t\t\t// Sort sections by order in slots\n\t\t\tthis.sections = newSections.sort(({ id: idA }, { id: idB }) => {\n\t\t\t\tconst indexOf = (id) => this.$slots.default?.findIndex?.(vnode => vnode?.componentOptions?.propsData?.id === id) ?? -1\n\t\t\t\treturn indexOf(idA) - indexOf(idB)\n\t\t\t})\n\n\t\t\t// If this is the first section registered, set it as selected\n\t\t\tif (this.sections.length === 1) {\n\t\t\t\tthis.selectedSection = id\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Called when a section is unregistered to remove it from dialog\n\t\t * @param {string} id The section ID\n\t\t */\n\t\tunregisterSection(id) {\n\t\t\tthis.sections = this.sections.filter(({ id: otherId }) => id !== otherId)\n\n\t\t\t// If the current section is unregistered, set the first section as selected\n\t\t\tif (this.selectedSection === id) {\n\t\t\t\tthis.selectedSection = this.sections[0]?.id ?? ''\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Scrolls the content to the selected settings section.absolute\n\t\t *\n\t\t * @param {string} item the ID of the section\n\t\t */\n\t\thandleSettingsNavigationClick(item) {\n\t\t\tthis.linkClicked = true\n\t\t\tdocument.getElementById('settings-section_' + item).scrollIntoView({\n\t\t\t\tbehavior: 'smooth',\n\t\t\t\tinline: 'nearest',\n\t\t\t})\n\t\t\tthis.selectedSection = item\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.linkClicked = false\n\t\t\t}, 1000)\n\t\t},\n\n\t\thandleCloseModal(isOpen) {\n\t\t\tif (isOpen) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tthis.$emit('update:open', false)\n\t\t\t// Remove scroll listener each time the modal is closed\n\t\t\tthis.scroller.removeEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = false\n\t\t\tthis.scroller.scrollTop = 0\n\t\t},\n\n\t\thandleScroll() {\n\t\t\tif (!this.linkClicked) {\n\t\t\t\tthis.unfocusNavigationItem()\n\t\t\t}\n\t\t},\n\n\t\t// Remove selected section once the user starts scrolling\n\t\tunfocusNavigationItem: debounce(function() {\n\t\t\tthis.selectedSection = ''\n\t\t\tif (document.activeElement.className.includes('navigation-list__link')) {\n\t\t\t\tdocument.activeElement.blur()\n\t\t\t}\n\t\t}, 300),\n\t},\n}\n\n</script>\n\n<style lang=\"scss\" scoped>\n.app-settings {\n\t:deep &__navigation {\n\t\tmin-width: 200px;\n\t\tmargin-right: calc(4 * var(--default-grid-baseline));\n\t\toverflow-x: hidden;\n\t\toverflow-y: auto;\n\t\tposition: relative;\n\t}\n\t:deep &__content {\n\t\tbox-sizing: border-box;\n\t\tpadding-inline: calc(4 * var(--default-grid-baseline));\n\t}\n}\n\n.navigation-list {\n\theight: 100%;\n\tbox-sizing: border-box;\n\toverflow-y: auto;\n\tpadding: calc(3 * var(--default-grid-baseline));\n\n\t&__link {\n\t\tdisplay: flex;\n\t\talign-content: center;\n\t\tfont-size: 16px;\n\t\theight: var(--default-clickable-area);\n\t\tmargin: 4px 0;\n\t\tline-height: var(--default-clickable-area);\n\t\tborder-radius: var(--border-radius-element, var(--border-radius-pill));\n\t\tfont-weight: bold;\n\t\tpadding: 0 calc(4 * var(--default-grid-baseline));\n\t\tcursor: pointer;\n\t\twhite-space: nowrap;\n\t\ttext-overflow: ellipsis;\n\t\toverflow: hidden;\n\t\tbackground-color: transparent;\n\t\tborder: none;\n\n\t\t&:hover,\n\t\t&:focus {\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\n\t\t&--active {\n\t\t\tbackground-color: var(--color-primary-element-light) !important;\n\t\t}\n\n\t\t&--icon {\n\t\t\tpadding-inline-start: calc(2 * var(--default-grid-baseline));\n\t\t\tgap: var(--default-grid-baseline);\n\t\t}\n\n\t\t&-icon {\n\t\t\tdisplay: flex;\n\t\t\tjustify-content: center;\n\t\t\talign-content: center;\n\t\t\twidth: calc(var(--default-clickable-area) - 2 * var(--default-grid-baseline));\n\t\t\tmax-width: calc(var(--default-clickable-area) - 2 * var(--default-grid-baseline));\n\t\t}\n\t}\n}\n\n@media only screen and (max-width: $breakpoint-small-mobile) {\n\t.app-settings {\n\t\t:deep .dialog__name {\n\t\t\tpadding-inline-start: 16px;\n\t\t}\n\t}\n}\n</style>\n"],"names":["NcDialog","NcVNodes","useIsMobile","t","Vue","id","debounce"],"mappings":"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"}
1
+ {"version":3,"file":"NcAppSettingsDialog-CLTp2nax.cjs","sources":["../../src/components/NcAppSettingsDialog/NcAppSettingsDialog.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nJust nest the `AppSettingSections` component into `NcAppSettingsDialog`,\nproviding the section's name prop. You can put your settings within each\n`NcAppSettingsSection` component.\n\n```vue\n<template>\n\t<div>\n\t\t<NcButton @click=\"settingsOpen = true\">Show Settings</NcButton>\n\t\t<NcAppSettingsDialog :open.sync=\"settingsOpen\" :show-navigation=\"true\" name=\"Application settings\">\n\t\t\t<NcAppSettingsSection id=\"asci-name-1\" name=\"Example name 1\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-2\" name=\"Example name 2\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-3\" name=\"Example name 3\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-4\" name=\"Example name 4\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-5\" name=\"Example name 5\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-6\" name=\"Example name 6\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-7\" name=\"Example name 7\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-8\" name=\"Example name 8\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-9\" name=\"Example name 9\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-10\" name=\"Example name 10\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t</NcAppSettingsDialog>\n\t</div>\n</template>\n\n<script>\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\tsettingsOpen: false,\n\t\t}\n\t},\n}\n</script>\n```\n\nYou can also add icons to the section navigation:\n\n```vue\n<template>\n\t<div>\n\t\t<NcButton @click=\"settingsOpen = true\">Show Settings</NcButton>\n\t\t<NcAppSettingsDialog :open.sync=\"settingsOpen\" :show-navigation=\"true\" name=\"Application settings\">\n\t\t\t<NcAppSettingsSection id=\"asci-name-1\" name=\"Instagram\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Instagram :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tInstagram setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-2\" name=\"Mastodon\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Mastodon :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tMastodon setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-3\" name=\"Twitch\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Twitch :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tTwitch setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-4\" name=\"Twitter\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Twitter :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tTwitter setting\n\t\t\t</NcAppSettingsSection>\n\t\t</NcAppSettingsDialog>\n\t</div>\n</template>\n\n<script>\nimport Instagram from 'vue-material-design-icons/Instagram.vue'\nimport Mastodon from 'vue-material-design-icons/Mastodon.vue'\nimport Twitch from 'vue-material-design-icons/Twitch.vue'\nimport Twitter from 'vue-material-design-icons/Twitter.vue'\n\nexport default {\n\tcomponents: {\n\t\tInstagram,\n\t\tMastodon,\n\t\tTwitch,\n\t\tTwitter,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tsettingsOpen: false,\n\t\t}\n\t},\n}\n</script>\n```\n</docs>\n\n<template>\n\t<NcDialog v-if=\"open\"\n\t\t:navigation-aria-label=\"settingsNavigationAriaLabel\"\n\t\tv-bind=\"dialogProperties\"\n\t\t@update:open=\"handleCloseModal\">\n\t\t<template v-if=\"hasNavigation\" #navigation=\"{ isCollapsed }\">\n\t\t\t<ul v-if=\"!isCollapsed\"\n\t\t\t\tclass=\"navigation-list\">\n\t\t\t\t<li v-for=\"section in sections\" :key=\"section.id\">\n\t\t\t\t\t<a :aria-current=\"`${section.id === selectedSection}`\"\n\t\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t\t'navigation-list__link': true,\n\t\t\t\t\t\t\t'navigation-list__link--active': section.id === selectedSection,\n\t\t\t\t\t\t\t'navigation-list__link--icon': hasNavigationIcons,\n\t\t\t\t\t\t}\"\n\t\t\t\t\t\t:href=\"`#settings-section_${section.id}`\"\n\t\t\t\t\t\ttabindex=\"0\"\n\t\t\t\t\t\t@click.prevent=\"handleSettingsNavigationClick(section.id)\"\n\t\t\t\t\t\t@keydown.enter=\"handleSettingsNavigationClick(section.id)\">\n\t\t\t\t\t\t<div v-if=\"hasNavigationIcons\" class=\"navigation-list__link-icon\">\n\t\t\t\t\t\t\t<NcVNodes v-if=\"section.icon\" :vnodes=\"section.icon\" />\n\t\t\t\t\t\t</div>\n\t\t\t\t\t\t<span class=\"navigation-list__link-text\">\n\t\t\t\t\t\t\t{{ section.name }}\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</a>\n\t\t\t\t</li>\n\t\t\t</ul>\n\t\t</template>\n\t\t<div ref=\"settingsScroller\">\n\t\t\t<slot />\n\t\t</div>\n\t</NcDialog>\n</template>\n\n<script>\nimport NcDialog from '../NcDialog/index.js'\nimport NcVNodes from '../NcVNodes/index.js'\nimport { useIsMobile } from '../../composables/useIsMobile/index.js'\nimport { t } from '../../l10n.js'\n\nimport debounce from 'debounce'\nimport Vue from 'vue'\n\nexport default {\n\n\tname: 'NcAppSettingsDialog',\n\n\tcomponents: {\n\t\tNcDialog,\n\t\tNcVNodes,\n\t},\n\n\tprovide() {\n\t\treturn {\n\t\t\tregisterSection: this.registerSection,\n\t\t\tunregisterSection: this.unregisterSection,\n\t\t}\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Determines the open / closed state of the modal\n\t\t */\n\t\topen: {\n\t\t\ttype: Boolean,\n\t\t\trequired: true,\n\t\t},\n\t\t/**\n\t\t * Shows the navigation on desktop if true\n\t\t */\n\t\tshowNavigation: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Selector for the popover container\n\t\t */\n\t\tcontainer: {\n\t\t\ttype: String,\n\t\t\tdefault: 'body',\n\t\t},\n\n\t\t/**\n\t\t * Name of the settings\n\t\t */\n\t\tname: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Additional elements to add to the focus trap\n\t\t */\n\t\tadditionalTrapElements: {\n\t\t\ttype: Array,\n\t\t\tdefault: () => [],\n\t\t},\n\n\t},\n\n\temits: ['update:open'],\n\n\tsetup() {\n\t\treturn {\n\t\t\tisMobile: useIsMobile(),\n\t\t}\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tselectedSection: '',\n\t\t\tlinkClicked: false,\n\t\t\taddedScrollListener: false,\n\t\t\tscroller: null,\n\t\t\t/**\n\t\t\t * Currently registered settings sections\n\t\t\t * @type {{ id: string, name: string, icon?: import('vue').VNode[] }[]}\n\t\t\t */\n\t\t\tsections: [],\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tdialogProperties() {\n\t\t\treturn {\n\t\t\t\tadditionalTrapElements: this.additionalTrapElements,\n\t\t\t\tcloseOnClickOutside: true,\n\t\t\t\tclass: 'app-settings',\n\t\t\t\tcontainer: this.container,\n\t\t\t\tcontentClasses: 'app-settings__content',\n\t\t\t\tsize: 'large',\n\t\t\t\tname: this.name,\n\t\t\t\tnavigationClasses: 'app-settings__navigation',\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Check if one or more navigation entries provide icons\n\t\t */\n\t\thasNavigationIcons() {\n\t\t\treturn this.sections.some(({ icon }) => !!icon)\n\t\t},\n\n\t\thasNavigation() {\n\t\t\tif (this.isMobile || !this.showNavigation) {\n\t\t\t\treturn false\n\t\t\t} else {\n\t\t\t\treturn true\n\t\t\t}\n\t\t},\n\n\t\tsettingsNavigationAriaLabel() {\n\t\t\treturn t('Settings navigation')\n\t\t},\n\t},\n\n\tupdated() {\n\t\t// Check that the scroller element has been mounted\n\t\tif (!this.$refs.settingsScroller) {\n\t\t\treturn\n\t\t}\n\t\t// Get the scroller element\n\t\tthis.scroller = this.$refs.settingsScroller\n\t\tif (!this.addedScrollListener) {\n\t\t\tthis.scroller.addEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = true\n\t\t}\n\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Called when a new section is registered\n\t\t * @param {string} id The section ID\n\t\t * @param {string} name The section name\n\t\t * @param {import('vue').VNode[]|undefined} icon Optional icon component\n\t\t */\n\t\tregisterSection(id, name, icon) {\n\t\t\t// Check for the uniqueness of section names\n\t\t\tif (this.sections.some(({ id: otherId }) => id === otherId)) {\n\t\t\t\tthrow new Error(`Duplicate section id found: ${id}. Settings navigation sections must have unique section ids.`)\n\t\t\t}\n\t\t\tif (this.sections.some(({ name: otherName }) => name === otherName)) {\n\t\t\t\tVue.util.warn(`Duplicate section name found: ${name}. Settings navigation sections must have unique section names.`)\n\t\t\t}\n\n\t\t\tconst newSections = [...this.sections, { id, name, icon }]\n\t\t\t// Sort sections by order in slots\n\t\t\tthis.sections = newSections.sort(({ id: idA }, { id: idB }) => {\n\t\t\t\tconst indexOf = (id) => this.$slots.default?.findIndex?.(vnode => vnode?.componentOptions?.propsData?.id === id) ?? -1\n\t\t\t\treturn indexOf(idA) - indexOf(idB)\n\t\t\t})\n\n\t\t\t// If this is the first section registered, set it as selected\n\t\t\tif (this.sections.length === 1) {\n\t\t\t\tthis.selectedSection = id\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Called when a section is unregistered to remove it from dialog\n\t\t * @param {string} id The section ID\n\t\t */\n\t\tunregisterSection(id) {\n\t\t\tthis.sections = this.sections.filter(({ id: otherId }) => id !== otherId)\n\n\t\t\t// If the current section is unregistered, set the first section as selected\n\t\t\tif (this.selectedSection === id) {\n\t\t\t\tthis.selectedSection = this.sections[0]?.id ?? ''\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Scrolls the content to the selected settings section.absolute\n\t\t *\n\t\t * @param {string} item the ID of the section\n\t\t */\n\t\thandleSettingsNavigationClick(item) {\n\t\t\tthis.linkClicked = true\n\t\t\tdocument.getElementById('settings-section_' + item).scrollIntoView({\n\t\t\t\tbehavior: 'smooth',\n\t\t\t\tinline: 'nearest',\n\t\t\t})\n\t\t\tthis.selectedSection = item\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.linkClicked = false\n\t\t\t}, 1000)\n\t\t},\n\n\t\thandleCloseModal(isOpen) {\n\t\t\tif (isOpen) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tthis.$emit('update:open', false)\n\t\t\t// Remove scroll listener each time the modal is closed\n\t\t\tthis.scroller.removeEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = false\n\t\t\tthis.scroller.scrollTop = 0\n\t\t},\n\n\t\thandleScroll() {\n\t\t\tif (!this.linkClicked) {\n\t\t\t\tthis.unfocusNavigationItem()\n\t\t\t}\n\t\t},\n\n\t\t// Remove selected section once the user starts scrolling\n\t\tunfocusNavigationItem: debounce(function() {\n\t\t\tthis.selectedSection = ''\n\t\t\tif (document.activeElement.className.includes('navigation-list__link')) {\n\t\t\t\tdocument.activeElement.blur()\n\t\t\t}\n\t\t}, 300),\n\t},\n}\n\n</script>\n\n<style lang=\"scss\" scoped>\n.app-settings {\n\t:deep &__navigation {\n\t\tmin-width: 200px;\n\t\tmargin-right: calc(4 * var(--default-grid-baseline));\n\t\toverflow-x: hidden;\n\t\toverflow-y: auto;\n\t\tposition: relative;\n\t}\n\t:deep &__content {\n\t\tbox-sizing: border-box;\n\t\tpadding-inline: calc(4 * var(--default-grid-baseline));\n\t}\n}\n\n.navigation-list {\n\theight: 100%;\n\tbox-sizing: border-box;\n\toverflow-y: auto;\n\tpadding: calc(3 * var(--default-grid-baseline));\n\n\t&__link {\n\t\tdisplay: flex;\n\t\talign-content: center;\n\t\tfont-size: 16px;\n\t\theight: var(--default-clickable-area);\n\t\tmargin: 4px 0;\n\t\tline-height: var(--default-clickable-area);\n\t\tborder-radius: var(--border-radius-element, var(--border-radius-pill));\n\t\tfont-weight: bold;\n\t\tpadding: 0 calc(4 * var(--default-grid-baseline));\n\t\tcursor: pointer;\n\t\twhite-space: nowrap;\n\t\ttext-overflow: ellipsis;\n\t\toverflow: hidden;\n\t\tbackground-color: transparent;\n\t\tborder: none;\n\n\t\t&:hover,\n\t\t&:focus {\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\n\t\t&--active {\n\t\t\tbackground-color: var(--color-primary-element-light) !important;\n\t\t}\n\n\t\t&--icon {\n\t\t\tpadding-inline-start: calc(2 * var(--default-grid-baseline));\n\t\t\tgap: var(--default-grid-baseline);\n\t\t}\n\n\t\t&-icon {\n\t\t\tdisplay: flex;\n\t\t\tjustify-content: center;\n\t\t\talign-content: center;\n\t\t\twidth: calc(var(--default-clickable-area) - 2 * var(--default-grid-baseline));\n\t\t\tmax-width: calc(var(--default-clickable-area) - 2 * var(--default-grid-baseline));\n\t\t}\n\t}\n}\n\n@media only screen and (max-width: $breakpoint-small-mobile) {\n\t.app-settings {\n\t\t:deep .dialog__name {\n\t\t\tpadding-inline-start: 16px;\n\t\t}\n\t}\n}\n</style>\n"],"names":["NcDialog","NcVNodes","useIsMobile","t","Vue","id","debounce"],"mappings":"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"}
@@ -1,12 +1,12 @@
1
1
  import '../assets/NcAppSettingsDialog-kKMMsdb3.css';
2
- import { N as NcDialog } from "./NcDialog-CzWTz2Qr.mjs";
2
+ import { N as NcDialog } from "./NcDialog-B9vjcT1J.mjs";
3
3
  import NcVNodes from "../Components/NcVNodes.mjs";
4
4
  import { useIsMobile } from "../Composables/useIsMobile.mjs";
5
- import { r as register, m as t45, a as t } from "./_l10n-B-QPoWAJ.mjs";
5
+ import { r as register, l as t44, a as t } from "./_l10n-BFZBMn-A.mjs";
6
6
  import debounce from "debounce";
7
7
  import Vue from "vue";
8
8
  import { n as normalizeComponent } from "./_plugin-vue2_normalizer-DU4iP6Vu.mjs";
9
- register(t45);
9
+ register(t44);
10
10
  const _sfc_main = {
11
11
  name: "NcAppSettingsDialog",
12
12
  components: {
@@ -1 +1 @@
1
- {"version":3,"file":"NcAppSettingsDialog-B4GS8urN.mjs","sources":["../../src/components/NcAppSettingsDialog/NcAppSettingsDialog.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nJust nest the `AppSettingSections` component into `NcAppSettingsDialog`,\nproviding the section's name prop. You can put your settings within each\n`NcAppSettingsSection` component.\n\n```vue\n<template>\n\t<div>\n\t\t<NcButton @click=\"settingsOpen = true\">Show Settings</NcButton>\n\t\t<NcAppSettingsDialog :open.sync=\"settingsOpen\" :show-navigation=\"true\" name=\"Application settings\">\n\t\t\t<NcAppSettingsSection id=\"asci-name-1\" name=\"Example name 1\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-2\" name=\"Example name 2\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-3\" name=\"Example name 3\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-4\" name=\"Example name 4\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-5\" name=\"Example name 5\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-6\" name=\"Example name 6\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-7\" name=\"Example name 7\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-8\" name=\"Example name 8\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-9\" name=\"Example name 9\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-10\" name=\"Example name 10\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t</NcAppSettingsDialog>\n\t</div>\n</template>\n\n<script>\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\tsettingsOpen: false,\n\t\t}\n\t},\n}\n</script>\n```\n\nYou can also add icons to the section navigation:\n\n```vue\n<template>\n\t<div>\n\t\t<NcButton @click=\"settingsOpen = true\">Show Settings</NcButton>\n\t\t<NcAppSettingsDialog :open.sync=\"settingsOpen\" :show-navigation=\"true\" name=\"Application settings\">\n\t\t\t<NcAppSettingsSection id=\"asci-name-1\" name=\"Instagram\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Instagram :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tInstagram setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-2\" name=\"Mastodon\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Mastodon :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tMastodon setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-3\" name=\"Twitch\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Twitch :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tTwitch setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-4\" name=\"Twitter\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Twitter :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tTwitter setting\n\t\t\t</NcAppSettingsSection>\n\t\t</NcAppSettingsDialog>\n\t</div>\n</template>\n\n<script>\nimport Instagram from 'vue-material-design-icons/Instagram.vue'\nimport Mastodon from 'vue-material-design-icons/Mastodon.vue'\nimport Twitch from 'vue-material-design-icons/Twitch.vue'\nimport Twitter from 'vue-material-design-icons/Twitter.vue'\n\nexport default {\n\tcomponents: {\n\t\tInstagram,\n\t\tMastodon,\n\t\tTwitch,\n\t\tTwitter,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tsettingsOpen: false,\n\t\t}\n\t},\n}\n</script>\n```\n</docs>\n\n<template>\n\t<NcDialog v-if=\"open\"\n\t\t:navigation-aria-label=\"settingsNavigationAriaLabel\"\n\t\tv-bind=\"dialogProperties\"\n\t\t@update:open=\"handleCloseModal\">\n\t\t<template v-if=\"hasNavigation\" #navigation=\"{ isCollapsed }\">\n\t\t\t<ul v-if=\"!isCollapsed\"\n\t\t\t\tclass=\"navigation-list\">\n\t\t\t\t<li v-for=\"section in sections\" :key=\"section.id\">\n\t\t\t\t\t<a :aria-current=\"`${section.id === selectedSection}`\"\n\t\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t\t'navigation-list__link': true,\n\t\t\t\t\t\t\t'navigation-list__link--active': section.id === selectedSection,\n\t\t\t\t\t\t\t'navigation-list__link--icon': hasNavigationIcons,\n\t\t\t\t\t\t}\"\n\t\t\t\t\t\t:href=\"`#settings-section_${section.id}`\"\n\t\t\t\t\t\ttabindex=\"0\"\n\t\t\t\t\t\t@click.prevent=\"handleSettingsNavigationClick(section.id)\"\n\t\t\t\t\t\t@keydown.enter=\"handleSettingsNavigationClick(section.id)\">\n\t\t\t\t\t\t<div v-if=\"hasNavigationIcons\" class=\"navigation-list__link-icon\">\n\t\t\t\t\t\t\t<NcVNodes v-if=\"section.icon\" :vnodes=\"section.icon\" />\n\t\t\t\t\t\t</div>\n\t\t\t\t\t\t<span class=\"navigation-list__link-text\">\n\t\t\t\t\t\t\t{{ section.name }}\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</a>\n\t\t\t\t</li>\n\t\t\t</ul>\n\t\t</template>\n\t\t<div ref=\"settingsScroller\">\n\t\t\t<slot />\n\t\t</div>\n\t</NcDialog>\n</template>\n\n<script>\nimport NcDialog from '../NcDialog/index.js'\nimport NcVNodes from '../NcVNodes/index.js'\nimport { useIsMobile } from '../../composables/useIsMobile/index.js'\nimport { t } from '../../l10n.js'\n\nimport debounce from 'debounce'\nimport Vue from 'vue'\n\nexport default {\n\n\tname: 'NcAppSettingsDialog',\n\n\tcomponents: {\n\t\tNcDialog,\n\t\tNcVNodes,\n\t},\n\n\tprovide() {\n\t\treturn {\n\t\t\tregisterSection: this.registerSection,\n\t\t\tunregisterSection: this.unregisterSection,\n\t\t}\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Determines the open / closed state of the modal\n\t\t */\n\t\topen: {\n\t\t\ttype: Boolean,\n\t\t\trequired: true,\n\t\t},\n\t\t/**\n\t\t * Shows the navigation on desktop if true\n\t\t */\n\t\tshowNavigation: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Selector for the popover container\n\t\t */\n\t\tcontainer: {\n\t\t\ttype: String,\n\t\t\tdefault: 'body',\n\t\t},\n\n\t\t/**\n\t\t * Name of the settings\n\t\t */\n\t\tname: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Additional elements to add to the focus trap\n\t\t */\n\t\tadditionalTrapElements: {\n\t\t\ttype: Array,\n\t\t\tdefault: () => [],\n\t\t},\n\n\t},\n\n\temits: ['update:open'],\n\n\tsetup() {\n\t\treturn {\n\t\t\tisMobile: useIsMobile(),\n\t\t}\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tselectedSection: '',\n\t\t\tlinkClicked: false,\n\t\t\taddedScrollListener: false,\n\t\t\tscroller: null,\n\t\t\t/**\n\t\t\t * Currently registered settings sections\n\t\t\t * @type {{ id: string, name: string, icon?: import('vue').VNode[] }[]}\n\t\t\t */\n\t\t\tsections: [],\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tdialogProperties() {\n\t\t\treturn {\n\t\t\t\tadditionalTrapElements: this.additionalTrapElements,\n\t\t\t\tcloseOnClickOutside: true,\n\t\t\t\tclass: 'app-settings',\n\t\t\t\tcontainer: this.container,\n\t\t\t\tcontentClasses: 'app-settings__content',\n\t\t\t\tsize: 'large',\n\t\t\t\tname: this.name,\n\t\t\t\tnavigationClasses: 'app-settings__navigation',\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Check if one or more navigation entries provide icons\n\t\t */\n\t\thasNavigationIcons() {\n\t\t\treturn this.sections.some(({ icon }) => !!icon)\n\t\t},\n\n\t\thasNavigation() {\n\t\t\tif (this.isMobile || !this.showNavigation) {\n\t\t\t\treturn false\n\t\t\t} else {\n\t\t\t\treturn true\n\t\t\t}\n\t\t},\n\n\t\tsettingsNavigationAriaLabel() {\n\t\t\treturn t('Settings navigation')\n\t\t},\n\t},\n\n\tupdated() {\n\t\t// Check that the scroller element has been mounted\n\t\tif (!this.$refs.settingsScroller) {\n\t\t\treturn\n\t\t}\n\t\t// Get the scroller element\n\t\tthis.scroller = this.$refs.settingsScroller\n\t\tif (!this.addedScrollListener) {\n\t\t\tthis.scroller.addEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = true\n\t\t}\n\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Called when a new section is registered\n\t\t * @param {string} id The section ID\n\t\t * @param {string} name The section name\n\t\t * @param {import('vue').VNode[]|undefined} icon Optional icon component\n\t\t */\n\t\tregisterSection(id, name, icon) {\n\t\t\t// Check for the uniqueness of section names\n\t\t\tif (this.sections.some(({ id: otherId }) => id === otherId)) {\n\t\t\t\tthrow new Error(`Duplicate section id found: ${id}. Settings navigation sections must have unique section ids.`)\n\t\t\t}\n\t\t\tif (this.sections.some(({ name: otherName }) => name === otherName)) {\n\t\t\t\tVue.util.warn(`Duplicate section name found: ${name}. Settings navigation sections must have unique section names.`)\n\t\t\t}\n\n\t\t\tconst newSections = [...this.sections, { id, name, icon }]\n\t\t\t// Sort sections by order in slots\n\t\t\tthis.sections = newSections.sort(({ id: idA }, { id: idB }) => {\n\t\t\t\tconst indexOf = (id) => this.$slots.default?.findIndex?.(vnode => vnode?.componentOptions?.propsData?.id === id) ?? -1\n\t\t\t\treturn indexOf(idA) - indexOf(idB)\n\t\t\t})\n\n\t\t\t// If this is the first section registered, set it as selected\n\t\t\tif (this.sections.length === 1) {\n\t\t\t\tthis.selectedSection = id\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Called when a section is unregistered to remove it from dialog\n\t\t * @param {string} id The section ID\n\t\t */\n\t\tunregisterSection(id) {\n\t\t\tthis.sections = this.sections.filter(({ id: otherId }) => id !== otherId)\n\n\t\t\t// If the current section is unregistered, set the first section as selected\n\t\t\tif (this.selectedSection === id) {\n\t\t\t\tthis.selectedSection = this.sections[0]?.id ?? ''\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Scrolls the content to the selected settings section.absolute\n\t\t *\n\t\t * @param {string} item the ID of the section\n\t\t */\n\t\thandleSettingsNavigationClick(item) {\n\t\t\tthis.linkClicked = true\n\t\t\tdocument.getElementById('settings-section_' + item).scrollIntoView({\n\t\t\t\tbehavior: 'smooth',\n\t\t\t\tinline: 'nearest',\n\t\t\t})\n\t\t\tthis.selectedSection = item\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.linkClicked = false\n\t\t\t}, 1000)\n\t\t},\n\n\t\thandleCloseModal(isOpen) {\n\t\t\tif (isOpen) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tthis.$emit('update:open', false)\n\t\t\t// Remove scroll listener each time the modal is closed\n\t\t\tthis.scroller.removeEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = false\n\t\t\tthis.scroller.scrollTop = 0\n\t\t},\n\n\t\thandleScroll() {\n\t\t\tif (!this.linkClicked) {\n\t\t\t\tthis.unfocusNavigationItem()\n\t\t\t}\n\t\t},\n\n\t\t// Remove selected section once the user starts scrolling\n\t\tunfocusNavigationItem: debounce(function() {\n\t\t\tthis.selectedSection = ''\n\t\t\tif (document.activeElement.className.includes('navigation-list__link')) {\n\t\t\t\tdocument.activeElement.blur()\n\t\t\t}\n\t\t}, 300),\n\t},\n}\n\n</script>\n\n<style lang=\"scss\" scoped>\n.app-settings {\n\t:deep &__navigation {\n\t\tmin-width: 200px;\n\t\tmargin-right: calc(4 * var(--default-grid-baseline));\n\t\toverflow-x: hidden;\n\t\toverflow-y: auto;\n\t\tposition: relative;\n\t}\n\t:deep &__content {\n\t\tbox-sizing: border-box;\n\t\tpadding-inline: calc(4 * var(--default-grid-baseline));\n\t}\n}\n\n.navigation-list {\n\theight: 100%;\n\tbox-sizing: border-box;\n\toverflow-y: auto;\n\tpadding: calc(3 * var(--default-grid-baseline));\n\n\t&__link {\n\t\tdisplay: flex;\n\t\talign-content: center;\n\t\tfont-size: 16px;\n\t\theight: var(--default-clickable-area);\n\t\tmargin: 4px 0;\n\t\tline-height: var(--default-clickable-area);\n\t\tborder-radius: var(--border-radius-element, var(--border-radius-pill));\n\t\tfont-weight: bold;\n\t\tpadding: 0 calc(4 * var(--default-grid-baseline));\n\t\tcursor: pointer;\n\t\twhite-space: nowrap;\n\t\ttext-overflow: ellipsis;\n\t\toverflow: hidden;\n\t\tbackground-color: transparent;\n\t\tborder: none;\n\n\t\t&:hover,\n\t\t&:focus {\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\n\t\t&--active {\n\t\t\tbackground-color: var(--color-primary-element-light) !important;\n\t\t}\n\n\t\t&--icon {\n\t\t\tpadding-inline-start: calc(2 * var(--default-grid-baseline));\n\t\t\tgap: var(--default-grid-baseline);\n\t\t}\n\n\t\t&-icon {\n\t\t\tdisplay: flex;\n\t\t\tjustify-content: center;\n\t\t\talign-content: center;\n\t\t\twidth: calc(var(--default-clickable-area) - 2 * var(--default-grid-baseline));\n\t\t\tmax-width: calc(var(--default-clickable-area) - 2 * var(--default-grid-baseline));\n\t\t}\n\t}\n}\n\n@media only screen and (max-width: $breakpoint-small-mobile) {\n\t.app-settings {\n\t\t:deep .dialog__name {\n\t\t\tpadding-inline-start: 16px;\n\t\t}\n\t}\n}\n</style>\n"],"names":["id"],"mappings":"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"}
1
+ {"version":3,"file":"NcAppSettingsDialog-DEPymL7F.mjs","sources":["../../src/components/NcAppSettingsDialog/NcAppSettingsDialog.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nJust nest the `AppSettingSections` component into `NcAppSettingsDialog`,\nproviding the section's name prop. You can put your settings within each\n`NcAppSettingsSection` component.\n\n```vue\n<template>\n\t<div>\n\t\t<NcButton @click=\"settingsOpen = true\">Show Settings</NcButton>\n\t\t<NcAppSettingsDialog :open.sync=\"settingsOpen\" :show-navigation=\"true\" name=\"Application settings\">\n\t\t\t<NcAppSettingsSection id=\"asci-name-1\" name=\"Example name 1\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-2\" name=\"Example name 2\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-3\" name=\"Example name 3\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-4\" name=\"Example name 4\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-5\" name=\"Example name 5\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-6\" name=\"Example name 6\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-7\" name=\"Example name 7\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-8\" name=\"Example name 8\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-9\" name=\"Example name 9\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-10\" name=\"Example name 10\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t</NcAppSettingsDialog>\n\t</div>\n</template>\n\n<script>\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\tsettingsOpen: false,\n\t\t}\n\t},\n}\n</script>\n```\n\nYou can also add icons to the section navigation:\n\n```vue\n<template>\n\t<div>\n\t\t<NcButton @click=\"settingsOpen = true\">Show Settings</NcButton>\n\t\t<NcAppSettingsDialog :open.sync=\"settingsOpen\" :show-navigation=\"true\" name=\"Application settings\">\n\t\t\t<NcAppSettingsSection id=\"asci-name-1\" name=\"Instagram\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Instagram :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tInstagram setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-2\" name=\"Mastodon\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Mastodon :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tMastodon setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-3\" name=\"Twitch\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Twitch :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\t<p style=\"height: 100vh;\">\n\t\t\t\t\tTwitch setting\n\t\t\t\t</p>\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-4\" name=\"Twitter\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Twitter :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tTwitter setting\n\t\t\t</NcAppSettingsSection>\n\t\t</NcAppSettingsDialog>\n\t</div>\n</template>\n\n<script>\nimport Instagram from 'vue-material-design-icons/Instagram.vue'\nimport Mastodon from 'vue-material-design-icons/Mastodon.vue'\nimport Twitch from 'vue-material-design-icons/Twitch.vue'\nimport Twitter from 'vue-material-design-icons/Twitter.vue'\n\nexport default {\n\tcomponents: {\n\t\tInstagram,\n\t\tMastodon,\n\t\tTwitch,\n\t\tTwitter,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tsettingsOpen: false,\n\t\t}\n\t},\n}\n</script>\n```\n</docs>\n\n<template>\n\t<NcDialog v-if=\"open\"\n\t\t:navigation-aria-label=\"settingsNavigationAriaLabel\"\n\t\tv-bind=\"dialogProperties\"\n\t\t@update:open=\"handleCloseModal\">\n\t\t<template v-if=\"hasNavigation\" #navigation=\"{ isCollapsed }\">\n\t\t\t<ul v-if=\"!isCollapsed\"\n\t\t\t\tclass=\"navigation-list\">\n\t\t\t\t<li v-for=\"section in sections\" :key=\"section.id\">\n\t\t\t\t\t<a :aria-current=\"`${section.id === selectedSection}`\"\n\t\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t\t'navigation-list__link': true,\n\t\t\t\t\t\t\t'navigation-list__link--active': section.id === selectedSection,\n\t\t\t\t\t\t\t'navigation-list__link--icon': hasNavigationIcons,\n\t\t\t\t\t\t}\"\n\t\t\t\t\t\t:href=\"`#settings-section_${section.id}`\"\n\t\t\t\t\t\ttabindex=\"0\"\n\t\t\t\t\t\t@click.prevent=\"handleSettingsNavigationClick(section.id)\"\n\t\t\t\t\t\t@keydown.enter=\"handleSettingsNavigationClick(section.id)\">\n\t\t\t\t\t\t<div v-if=\"hasNavigationIcons\" class=\"navigation-list__link-icon\">\n\t\t\t\t\t\t\t<NcVNodes v-if=\"section.icon\" :vnodes=\"section.icon\" />\n\t\t\t\t\t\t</div>\n\t\t\t\t\t\t<span class=\"navigation-list__link-text\">\n\t\t\t\t\t\t\t{{ section.name }}\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</a>\n\t\t\t\t</li>\n\t\t\t</ul>\n\t\t</template>\n\t\t<div ref=\"settingsScroller\">\n\t\t\t<slot />\n\t\t</div>\n\t</NcDialog>\n</template>\n\n<script>\nimport NcDialog from '../NcDialog/index.js'\nimport NcVNodes from '../NcVNodes/index.js'\nimport { useIsMobile } from '../../composables/useIsMobile/index.js'\nimport { t } from '../../l10n.js'\n\nimport debounce from 'debounce'\nimport Vue from 'vue'\n\nexport default {\n\n\tname: 'NcAppSettingsDialog',\n\n\tcomponents: {\n\t\tNcDialog,\n\t\tNcVNodes,\n\t},\n\n\tprovide() {\n\t\treturn {\n\t\t\tregisterSection: this.registerSection,\n\t\t\tunregisterSection: this.unregisterSection,\n\t\t}\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Determines the open / closed state of the modal\n\t\t */\n\t\topen: {\n\t\t\ttype: Boolean,\n\t\t\trequired: true,\n\t\t},\n\t\t/**\n\t\t * Shows the navigation on desktop if true\n\t\t */\n\t\tshowNavigation: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Selector for the popover container\n\t\t */\n\t\tcontainer: {\n\t\t\ttype: String,\n\t\t\tdefault: 'body',\n\t\t},\n\n\t\t/**\n\t\t * Name of the settings\n\t\t */\n\t\tname: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Additional elements to add to the focus trap\n\t\t */\n\t\tadditionalTrapElements: {\n\t\t\ttype: Array,\n\t\t\tdefault: () => [],\n\t\t},\n\n\t},\n\n\temits: ['update:open'],\n\n\tsetup() {\n\t\treturn {\n\t\t\tisMobile: useIsMobile(),\n\t\t}\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tselectedSection: '',\n\t\t\tlinkClicked: false,\n\t\t\taddedScrollListener: false,\n\t\t\tscroller: null,\n\t\t\t/**\n\t\t\t * Currently registered settings sections\n\t\t\t * @type {{ id: string, name: string, icon?: import('vue').VNode[] }[]}\n\t\t\t */\n\t\t\tsections: [],\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tdialogProperties() {\n\t\t\treturn {\n\t\t\t\tadditionalTrapElements: this.additionalTrapElements,\n\t\t\t\tcloseOnClickOutside: true,\n\t\t\t\tclass: 'app-settings',\n\t\t\t\tcontainer: this.container,\n\t\t\t\tcontentClasses: 'app-settings__content',\n\t\t\t\tsize: 'large',\n\t\t\t\tname: this.name,\n\t\t\t\tnavigationClasses: 'app-settings__navigation',\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Check if one or more navigation entries provide icons\n\t\t */\n\t\thasNavigationIcons() {\n\t\t\treturn this.sections.some(({ icon }) => !!icon)\n\t\t},\n\n\t\thasNavigation() {\n\t\t\tif (this.isMobile || !this.showNavigation) {\n\t\t\t\treturn false\n\t\t\t} else {\n\t\t\t\treturn true\n\t\t\t}\n\t\t},\n\n\t\tsettingsNavigationAriaLabel() {\n\t\t\treturn t('Settings navigation')\n\t\t},\n\t},\n\n\tupdated() {\n\t\t// Check that the scroller element has been mounted\n\t\tif (!this.$refs.settingsScroller) {\n\t\t\treturn\n\t\t}\n\t\t// Get the scroller element\n\t\tthis.scroller = this.$refs.settingsScroller\n\t\tif (!this.addedScrollListener) {\n\t\t\tthis.scroller.addEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = true\n\t\t}\n\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Called when a new section is registered\n\t\t * @param {string} id The section ID\n\t\t * @param {string} name The section name\n\t\t * @param {import('vue').VNode[]|undefined} icon Optional icon component\n\t\t */\n\t\tregisterSection(id, name, icon) {\n\t\t\t// Check for the uniqueness of section names\n\t\t\tif (this.sections.some(({ id: otherId }) => id === otherId)) {\n\t\t\t\tthrow new Error(`Duplicate section id found: ${id}. Settings navigation sections must have unique section ids.`)\n\t\t\t}\n\t\t\tif (this.sections.some(({ name: otherName }) => name === otherName)) {\n\t\t\t\tVue.util.warn(`Duplicate section name found: ${name}. Settings navigation sections must have unique section names.`)\n\t\t\t}\n\n\t\t\tconst newSections = [...this.sections, { id, name, icon }]\n\t\t\t// Sort sections by order in slots\n\t\t\tthis.sections = newSections.sort(({ id: idA }, { id: idB }) => {\n\t\t\t\tconst indexOf = (id) => this.$slots.default?.findIndex?.(vnode => vnode?.componentOptions?.propsData?.id === id) ?? -1\n\t\t\t\treturn indexOf(idA) - indexOf(idB)\n\t\t\t})\n\n\t\t\t// If this is the first section registered, set it as selected\n\t\t\tif (this.sections.length === 1) {\n\t\t\t\tthis.selectedSection = id\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Called when a section is unregistered to remove it from dialog\n\t\t * @param {string} id The section ID\n\t\t */\n\t\tunregisterSection(id) {\n\t\t\tthis.sections = this.sections.filter(({ id: otherId }) => id !== otherId)\n\n\t\t\t// If the current section is unregistered, set the first section as selected\n\t\t\tif (this.selectedSection === id) {\n\t\t\t\tthis.selectedSection = this.sections[0]?.id ?? ''\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Scrolls the content to the selected settings section.absolute\n\t\t *\n\t\t * @param {string} item the ID of the section\n\t\t */\n\t\thandleSettingsNavigationClick(item) {\n\t\t\tthis.linkClicked = true\n\t\t\tdocument.getElementById('settings-section_' + item).scrollIntoView({\n\t\t\t\tbehavior: 'smooth',\n\t\t\t\tinline: 'nearest',\n\t\t\t})\n\t\t\tthis.selectedSection = item\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.linkClicked = false\n\t\t\t}, 1000)\n\t\t},\n\n\t\thandleCloseModal(isOpen) {\n\t\t\tif (isOpen) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tthis.$emit('update:open', false)\n\t\t\t// Remove scroll listener each time the modal is closed\n\t\t\tthis.scroller.removeEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = false\n\t\t\tthis.scroller.scrollTop = 0\n\t\t},\n\n\t\thandleScroll() {\n\t\t\tif (!this.linkClicked) {\n\t\t\t\tthis.unfocusNavigationItem()\n\t\t\t}\n\t\t},\n\n\t\t// Remove selected section once the user starts scrolling\n\t\tunfocusNavigationItem: debounce(function() {\n\t\t\tthis.selectedSection = ''\n\t\t\tif (document.activeElement.className.includes('navigation-list__link')) {\n\t\t\t\tdocument.activeElement.blur()\n\t\t\t}\n\t\t}, 300),\n\t},\n}\n\n</script>\n\n<style lang=\"scss\" scoped>\n.app-settings {\n\t:deep &__navigation {\n\t\tmin-width: 200px;\n\t\tmargin-right: calc(4 * var(--default-grid-baseline));\n\t\toverflow-x: hidden;\n\t\toverflow-y: auto;\n\t\tposition: relative;\n\t}\n\t:deep &__content {\n\t\tbox-sizing: border-box;\n\t\tpadding-inline: calc(4 * var(--default-grid-baseline));\n\t}\n}\n\n.navigation-list {\n\theight: 100%;\n\tbox-sizing: border-box;\n\toverflow-y: auto;\n\tpadding: calc(3 * var(--default-grid-baseline));\n\n\t&__link {\n\t\tdisplay: flex;\n\t\talign-content: center;\n\t\tfont-size: 16px;\n\t\theight: var(--default-clickable-area);\n\t\tmargin: 4px 0;\n\t\tline-height: var(--default-clickable-area);\n\t\tborder-radius: var(--border-radius-element, var(--border-radius-pill));\n\t\tfont-weight: bold;\n\t\tpadding: 0 calc(4 * var(--default-grid-baseline));\n\t\tcursor: pointer;\n\t\twhite-space: nowrap;\n\t\ttext-overflow: ellipsis;\n\t\toverflow: hidden;\n\t\tbackground-color: transparent;\n\t\tborder: none;\n\n\t\t&:hover,\n\t\t&:focus {\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\n\t\t&--active {\n\t\t\tbackground-color: var(--color-primary-element-light) !important;\n\t\t}\n\n\t\t&--icon {\n\t\t\tpadding-inline-start: calc(2 * var(--default-grid-baseline));\n\t\t\tgap: var(--default-grid-baseline);\n\t\t}\n\n\t\t&-icon {\n\t\t\tdisplay: flex;\n\t\t\tjustify-content: center;\n\t\t\talign-content: center;\n\t\t\twidth: calc(var(--default-clickable-area) - 2 * var(--default-grid-baseline));\n\t\t\tmax-width: calc(var(--default-clickable-area) - 2 * var(--default-grid-baseline));\n\t\t}\n\t}\n}\n\n@media only screen and (max-width: $breakpoint-small-mobile) {\n\t.app-settings {\n\t\t:deep .dialog__name {\n\t\t\tpadding-inline-start: 16px;\n\t\t}\n\t}\n}\n</style>\n"],"names":["id"],"mappings":"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"}
@@ -1,9 +1,9 @@
1
1
  import '../assets/NcAppSidebar-BntAj6H-.css';
2
2
  import { Portal } from "@linusborg/vue-simple-portal";
3
3
  import NcVNodes from "../Components/NcVNodes.mjs";
4
- import { N as NcCheckboxRadioSwitch } from "./NcCheckboxRadioSwitch-R1y0mLbC.mjs";
4
+ import { N as NcCheckboxRadioSwitch } from "./NcCheckboxRadioSwitch-TK3dfQ23.mjs";
5
5
  import { n as normalizeComponent } from "./_plugin-vue2_normalizer-DU4iP6Vu.mjs";
6
- import { N as NcActions } from "./NcActions-NA1n25Vt.mjs";
6
+ import { N as NcActions } from "./NcActions-DV02tDLT.mjs";
7
7
  import NcLoadingIcon from "../Components/NcLoadingIcon.mjs";
8
8
  import NcButton from "../Components/NcButton.mjs";
9
9
  import NcEmptyContent from "../Components/NcEmptyContent.mjs";
@@ -12,7 +12,7 @@ import { directive as directive$1 } from "../Directives/Linkify.mjs";
12
12
  import { useIsSmallMobile } from "../Composables/useIsMobile.mjs";
13
13
  import { G as GenRandomId } from "./GenRandomId-CMooMQt0.mjs";
14
14
  import { g as getTrapStack } from "./focusTrap-Cecv_gjR.mjs";
15
- import { r as register, P as t14, a as t } from "./_l10n-B-QPoWAJ.mjs";
15
+ import { r as register, O as t13, a as t } from "./_l10n-BFZBMn-A.mjs";
16
16
  import { A as ArrowRight } from "./ArrowRight-CY2b9hgN.mjs";
17
17
  import { C as Close } from "./Close-BtLPUSdO.mjs";
18
18
  import { vOnClickOutside } from "@vueuse/components";
@@ -245,7 +245,7 @@ var __component__$4 = /* @__PURE__ */ normalizeComponent(
245
245
  "d9f30f05"
246
246
  );
247
247
  const NcAppSidebarTabs = __component__$4.exports;
248
- register(t14);
248
+ register(t13);
249
249
  const _sfc_main$3 = {
250
250
  name: "DockRightIcon",
251
251
  emits: ["click"],