@nextcloud/vue 8.23.1 → 8.24.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 (662) hide show
  1. package/CHANGELOG.md +254 -201
  2. package/README.md +6 -2
  3. package/dist/Components/NcActionButton.cjs +2 -1
  4. package/dist/Components/NcActionButton.mjs +2 -1
  5. package/dist/Components/NcActionButtonGroup.cjs +2 -1
  6. package/dist/Components/NcActionButtonGroup.mjs +2 -1
  7. package/dist/Components/NcActionCaption.cjs +1 -0
  8. package/dist/Components/NcActionCaption.mjs +1 -0
  9. package/dist/Components/NcActionCheckbox.cjs +2 -1
  10. package/dist/Components/NcActionCheckbox.mjs +2 -1
  11. package/dist/Components/NcActionInput.cjs +2 -1
  12. package/dist/Components/NcActionInput.mjs +2 -1
  13. package/dist/Components/NcActionLink.cjs +2 -1
  14. package/dist/Components/NcActionLink.mjs +2 -1
  15. package/dist/Components/NcActionRadio.cjs +2 -1
  16. package/dist/Components/NcActionRadio.mjs +2 -1
  17. package/dist/Components/NcActionRouter.cjs +2 -1
  18. package/dist/Components/NcActionRouter.mjs +2 -1
  19. package/dist/Components/NcActionSeparator.cjs +1 -0
  20. package/dist/Components/NcActionSeparator.mjs +1 -0
  21. package/dist/Components/NcActionText.cjs +2 -1
  22. package/dist/Components/NcActionText.mjs +2 -1
  23. package/dist/Components/NcActionTextEditable.cjs +2 -1
  24. package/dist/Components/NcActionTextEditable.mjs +2 -1
  25. package/dist/Components/NcActions.cjs +2 -1
  26. package/dist/Components/NcActions.mjs +2 -1
  27. package/dist/Components/NcAppContent.cjs +2 -1
  28. package/dist/Components/NcAppContent.mjs +2 -1
  29. package/dist/Components/NcAppContentDetails.cjs +1 -0
  30. package/dist/Components/NcAppContentDetails.mjs +1 -0
  31. package/dist/Components/NcAppContentList.cjs +1 -0
  32. package/dist/Components/NcAppContentList.mjs +1 -0
  33. package/dist/Components/NcAppNavigation.cjs +2 -1
  34. package/dist/Components/NcAppNavigation.mjs +2 -1
  35. package/dist/Components/NcAppNavigationCaption.cjs +2 -1
  36. package/dist/Components/NcAppNavigationCaption.mjs +2 -1
  37. package/dist/Components/NcAppNavigationIconBullet.cjs +1 -0
  38. package/dist/Components/NcAppNavigationIconBullet.mjs +1 -0
  39. package/dist/Components/NcAppNavigationItem.cjs +2 -1
  40. package/dist/Components/NcAppNavigationItem.mjs +2 -1
  41. package/dist/Components/NcAppNavigationList.cjs +1 -0
  42. package/dist/Components/NcAppNavigationList.mjs +1 -0
  43. package/dist/Components/NcAppNavigationNew.cjs +18 -3
  44. package/dist/Components/NcAppNavigationNew.cjs.map +1 -1
  45. package/dist/Components/NcAppNavigationNew.mjs +18 -3
  46. package/dist/Components/NcAppNavigationNew.mjs.map +1 -1
  47. package/dist/Components/NcAppNavigationNewItem.cjs +2 -1
  48. package/dist/Components/NcAppNavigationNewItem.mjs +2 -1
  49. package/dist/Components/NcAppNavigationSearch.cjs +2 -1
  50. package/dist/Components/NcAppNavigationSearch.mjs +2 -1
  51. package/dist/Components/NcAppNavigationSettings.cjs +2 -1
  52. package/dist/Components/NcAppNavigationSettings.mjs +2 -1
  53. package/dist/Components/NcAppNavigationSpacer.cjs +1 -0
  54. package/dist/Components/NcAppNavigationSpacer.mjs +1 -0
  55. package/dist/Components/NcAppNavigationToggle.cjs +2 -1
  56. package/dist/Components/NcAppNavigationToggle.mjs +2 -1
  57. package/dist/Components/NcAppSettingsDialog.cjs +2 -1
  58. package/dist/Components/NcAppSettingsDialog.mjs +2 -1
  59. package/dist/Components/NcAppSettingsSection.cjs +1 -0
  60. package/dist/Components/NcAppSettingsSection.mjs +1 -0
  61. package/dist/Components/NcAppSidebar.cjs +2 -1
  62. package/dist/Components/NcAppSidebar.mjs +2 -1
  63. package/dist/Components/NcAppSidebarTab.cjs +1 -0
  64. package/dist/Components/NcAppSidebarTab.cjs.map +1 -1
  65. package/dist/Components/NcAppSidebarTab.mjs +1 -0
  66. package/dist/Components/NcAppSidebarTab.mjs.map +1 -1
  67. package/dist/Components/NcAvatar.cjs +2 -1
  68. package/dist/Components/NcAvatar.mjs +2 -1
  69. package/dist/Components/NcBlurHash.cjs +4 -0
  70. package/dist/Components/NcBlurHash.cjs.map +1 -0
  71. package/dist/Components/NcBlurHash.mjs +5 -0
  72. package/dist/Components/NcBlurHash.mjs.map +1 -0
  73. package/dist/Components/NcBreadcrumb.cjs +2 -1
  74. package/dist/Components/NcBreadcrumb.mjs +2 -1
  75. package/dist/Components/NcBreadcrumbs.cjs +2 -1
  76. package/dist/Components/NcBreadcrumbs.mjs +2 -1
  77. package/dist/Components/NcButton.cjs +52 -10
  78. package/dist/Components/NcButton.cjs.map +1 -1
  79. package/dist/Components/NcButton.mjs +52 -10
  80. package/dist/Components/NcButton.mjs.map +1 -1
  81. package/dist/Components/NcCheckboxRadioSwitch.cjs +2 -1
  82. package/dist/Components/NcCheckboxRadioSwitch.mjs +2 -1
  83. package/dist/Components/NcChip.cjs +25 -10
  84. package/dist/Components/NcChip.cjs.map +1 -1
  85. package/dist/Components/NcChip.mjs +25 -10
  86. package/dist/Components/NcChip.mjs.map +1 -1
  87. package/dist/Components/NcCollectionList.cjs +2 -1
  88. package/dist/Components/NcCollectionList.mjs +2 -1
  89. package/dist/Components/NcColorPicker.cjs +2 -1
  90. package/dist/Components/NcColorPicker.mjs +2 -1
  91. package/dist/Components/NcContent.cjs +2 -1
  92. package/dist/Components/NcContent.mjs +2 -1
  93. package/dist/Components/NcCounterBubble.cjs +1 -0
  94. package/dist/Components/NcCounterBubble.mjs +1 -0
  95. package/dist/Components/NcDashboardWidget.cjs +2 -1
  96. package/dist/Components/NcDashboardWidget.mjs +2 -1
  97. package/dist/Components/NcDashboardWidgetItem.cjs +2 -1
  98. package/dist/Components/NcDashboardWidgetItem.mjs +2 -1
  99. package/dist/Components/NcDateTime.cjs +2 -1
  100. package/dist/Components/NcDateTime.mjs +2 -1
  101. package/dist/Components/NcDateTimePicker.cjs +6 -5
  102. package/dist/Components/NcDateTimePicker.cjs.map +1 -1
  103. package/dist/Components/NcDateTimePicker.mjs +7 -6
  104. package/dist/Components/NcDateTimePicker.mjs.map +1 -1
  105. package/dist/Components/NcDateTimePickerNative.cjs +2 -1
  106. package/dist/Components/NcDateTimePickerNative.cjs.map +1 -1
  107. package/dist/Components/NcDateTimePickerNative.mjs +2 -1
  108. package/dist/Components/NcDateTimePickerNative.mjs.map +1 -1
  109. package/dist/Components/NcDialog.cjs +2 -1
  110. package/dist/Components/NcDialog.mjs +2 -1
  111. package/dist/Components/NcDialogButton.cjs +2 -1
  112. package/dist/Components/NcDialogButton.mjs +2 -1
  113. package/dist/Components/NcEllipsisedOption.cjs +1 -0
  114. package/dist/Components/NcEllipsisedOption.cjs.map +1 -1
  115. package/dist/Components/NcEllipsisedOption.mjs +1 -0
  116. package/dist/Components/NcEmojiPicker.cjs +2 -1
  117. package/dist/Components/NcEmojiPicker.mjs +2 -1
  118. package/dist/Components/NcEmptyContent.cjs +3 -2
  119. package/dist/Components/NcEmptyContent.cjs.map +1 -1
  120. package/dist/Components/NcEmptyContent.mjs +3 -2
  121. package/dist/Components/NcEmptyContent.mjs.map +1 -1
  122. package/dist/Components/NcGuestContent.cjs +1 -0
  123. package/dist/Components/NcGuestContent.mjs +1 -0
  124. package/dist/Components/NcHeaderButton.cjs +4 -3
  125. package/dist/Components/NcHeaderButton.cjs.map +1 -1
  126. package/dist/Components/NcHeaderButton.mjs +4 -3
  127. package/dist/Components/NcHeaderButton.mjs.map +1 -1
  128. package/dist/Components/NcHeaderMenu.cjs +2 -1
  129. package/dist/Components/NcHeaderMenu.mjs +2 -1
  130. package/dist/Components/NcHighlight.cjs +1 -0
  131. package/dist/Components/NcHighlight.mjs +1 -0
  132. package/dist/Components/NcIconSvgWrapper.cjs +1 -0
  133. package/dist/Components/NcIconSvgWrapper.mjs +1 -0
  134. package/dist/Components/NcInputField.cjs +2 -1
  135. package/dist/Components/NcInputField.mjs +2 -1
  136. package/dist/Components/NcListItem.cjs +2 -1
  137. package/dist/Components/NcListItem.mjs +2 -1
  138. package/dist/Components/NcListItemIcon.cjs +2 -1
  139. package/dist/Components/NcListItemIcon.mjs +2 -1
  140. package/dist/Components/NcLoadingIcon.cjs +1 -0
  141. package/dist/Components/NcLoadingIcon.mjs +1 -0
  142. package/dist/Components/NcModal.cjs +25 -14
  143. package/dist/Components/NcModal.cjs.map +1 -1
  144. package/dist/Components/NcModal.mjs +25 -14
  145. package/dist/Components/NcModal.mjs.map +1 -1
  146. package/dist/Components/NcNoteCard.cjs +1 -0
  147. package/dist/Components/NcNoteCard.mjs +1 -0
  148. package/dist/Components/NcPasswordField.cjs +2 -1
  149. package/dist/Components/NcPasswordField.mjs +2 -1
  150. package/dist/Components/NcPopover.cjs +2 -1
  151. package/dist/Components/NcPopover.mjs +2 -1
  152. package/dist/Components/NcProgressBar.cjs +1 -0
  153. package/dist/Components/NcProgressBar.mjs +1 -0
  154. package/dist/Components/NcRelatedResourcesPanel.cjs +2 -1
  155. package/dist/Components/NcRelatedResourcesPanel.mjs +2 -1
  156. package/dist/Components/NcRichContenteditable.cjs +2 -1
  157. package/dist/Components/NcRichContenteditable.mjs +2 -1
  158. package/dist/Components/NcRichText.cjs +3 -2
  159. package/dist/Components/NcRichText.mjs +5 -4
  160. package/dist/Components/NcSavingIndicatorIcon.cjs +1 -0
  161. package/dist/Components/NcSavingIndicatorIcon.mjs +1 -0
  162. package/dist/Components/NcSelect.cjs +2 -1
  163. package/dist/Components/NcSelect.mjs +2 -1
  164. package/dist/Components/NcSelectTags.cjs +2 -1
  165. package/dist/Components/NcSelectTags.mjs +2 -1
  166. package/dist/Components/NcSettingsInputText.cjs +2 -1
  167. package/dist/Components/NcSettingsInputText.mjs +2 -1
  168. package/dist/Components/NcSettingsSection.cjs +2 -1
  169. package/dist/Components/NcSettingsSection.mjs +2 -1
  170. package/dist/Components/NcSettingsSelectGroup.cjs +2 -1
  171. package/dist/Components/NcSettingsSelectGroup.mjs +2 -1
  172. package/dist/Components/NcTextArea.cjs +1 -0
  173. package/dist/Components/NcTextArea.mjs +1 -0
  174. package/dist/Components/NcTextField.cjs +2 -1
  175. package/dist/Components/NcTextField.mjs +2 -1
  176. package/dist/Components/NcTimezonePicker.cjs +2 -1
  177. package/dist/Components/NcTimezonePicker.mjs +2 -1
  178. package/dist/Components/NcUserBubble.cjs +2 -1
  179. package/dist/Components/NcUserBubble.mjs +2 -1
  180. package/dist/Components/NcUserStatusIcon.cjs +2 -1
  181. package/dist/Components/NcUserStatusIcon.mjs +2 -1
  182. package/dist/Components/NcVNodes.cjs +1 -0
  183. package/dist/Components/NcVNodes.mjs +1 -0
  184. package/dist/Composables/useHotKey.cjs +1 -0
  185. package/dist/Composables/useHotKey.cjs.map +1 -1
  186. package/dist/Composables/useHotKey.mjs +1 -0
  187. package/dist/Composables/useHotKey.mjs.map +1 -1
  188. package/dist/Composables/useIsDarkTheme.cjs +1 -0
  189. package/dist/Composables/useIsDarkTheme.cjs.map +1 -1
  190. package/dist/Composables/useIsDarkTheme.mjs +1 -0
  191. package/dist/Composables/useIsDarkTheme.mjs.map +1 -1
  192. package/dist/Composables/useIsFullscreen.cjs +1 -0
  193. package/dist/Composables/useIsFullscreen.cjs.map +1 -1
  194. package/dist/Composables/useIsFullscreen.mjs +1 -0
  195. package/dist/Composables/useIsFullscreen.mjs.map +1 -1
  196. package/dist/Composables/useIsMobile.cjs +1 -0
  197. package/dist/Composables/useIsMobile.cjs.map +1 -1
  198. package/dist/Composables/useIsMobile.mjs +1 -0
  199. package/dist/Composables/useIsMobile.mjs.map +1 -1
  200. package/dist/Directives/Focus.cjs +1 -0
  201. package/dist/Directives/Focus.cjs.map +1 -1
  202. package/dist/Directives/Focus.mjs +1 -0
  203. package/dist/Directives/Focus.mjs.map +1 -1
  204. package/dist/Directives/Linkify.cjs +1 -0
  205. package/dist/Directives/Linkify.cjs.map +1 -1
  206. package/dist/Directives/Linkify.mjs +1 -0
  207. package/dist/Directives/Linkify.mjs.map +1 -1
  208. package/dist/Directives/Tooltip.cjs +1 -0
  209. package/dist/Directives/Tooltip.cjs.map +1 -1
  210. package/dist/Directives/Tooltip.mjs +1 -0
  211. package/dist/Directives/Tooltip.mjs.map +1 -1
  212. package/dist/Functions/a11y.cjs +1 -0
  213. package/dist/Functions/a11y.cjs.map +1 -1
  214. package/dist/Functions/a11y.mjs +1 -0
  215. package/dist/Functions/a11y.mjs.map +1 -1
  216. package/dist/Functions/contactsMenu.cjs +1 -0
  217. package/dist/Functions/contactsMenu.cjs.map +1 -1
  218. package/dist/Functions/contactsMenu.mjs +1 -0
  219. package/dist/Functions/contactsMenu.mjs.map +1 -1
  220. package/dist/Functions/dialog.cjs +1 -0
  221. package/dist/Functions/dialog.cjs.map +1 -1
  222. package/dist/Functions/dialog.mjs +1 -0
  223. package/dist/Functions/dialog.mjs.map +1 -1
  224. package/dist/Functions/emoji.cjs +1 -0
  225. package/dist/Functions/emoji.mjs +1 -0
  226. package/dist/Functions/isDarkTheme.cjs +1 -0
  227. package/dist/Functions/isDarkTheme.cjs.map +1 -1
  228. package/dist/Functions/isDarkTheme.mjs +1 -0
  229. package/dist/Functions/isDarkTheme.mjs.map +1 -1
  230. package/dist/Functions/preloadImage.cjs +19 -0
  231. package/dist/Functions/preloadImage.cjs.map +1 -0
  232. package/dist/Functions/preloadImage.mjs +17 -0
  233. package/dist/Functions/preloadImage.mjs.map +1 -0
  234. package/dist/Functions/reference.cjs +2 -1
  235. package/dist/Functions/reference.mjs +3 -2
  236. package/dist/Functions/registerReference.cjs +1 -0
  237. package/dist/Functions/registerReference.mjs +3 -2
  238. package/dist/Functions/usernameToColor.cjs +2 -1
  239. package/dist/Functions/usernameToColor.mjs +2 -1
  240. package/dist/Mixins/clickOutsideOptions.cjs +1 -0
  241. package/dist/Mixins/clickOutsideOptions.cjs.map +1 -1
  242. package/dist/Mixins/clickOutsideOptions.mjs +1 -0
  243. package/dist/Mixins/clickOutsideOptions.mjs.map +1 -1
  244. package/dist/Mixins/isFullscreen.cjs +1 -0
  245. package/dist/Mixins/isFullscreen.cjs.map +1 -1
  246. package/dist/Mixins/isFullscreen.mjs +1 -0
  247. package/dist/Mixins/isMobile.cjs +1 -0
  248. package/dist/Mixins/isMobile.cjs.map +1 -1
  249. package/dist/Mixins/isMobile.mjs +1 -0
  250. package/dist/Mixins/richEditor.cjs +1 -0
  251. package/dist/Mixins/richEditor.mjs +1 -0
  252. package/dist/assets/{NcActionButton-BYN2SUN0.css → NcActionButton-BqMeBMdA.css} +17 -16
  253. package/dist/assets/{NcActionCheckbox-Dan0EvGm.css → NcActionCheckbox-BlyPt7DF.css} +1 -0
  254. package/dist/assets/{NcActionInput-Dz21fyVD.css → NcActionInput-gUagFGC5.css} +2 -0
  255. package/dist/assets/{NcActionLink-BG9B9dP4.css → NcActionLink-DA3ebr8W.css} +1 -0
  256. package/dist/assets/{NcActionRadio-C87waXE-.css → NcActionRadio-CodyhP86.css} +1 -0
  257. package/dist/assets/{NcActionRouter-BAGuUfFu.css → NcActionRouter-DlqXQ6ai.css} +1 -0
  258. package/dist/assets/{NcActionText-Cjp26Bn0.css → NcActionText-Cvug6qMa.css} +1 -0
  259. package/dist/assets/{NcActionTextEditable-1TXeJ5zp.css → NcActionTextEditable-CasTVqIo.css} +62 -60
  260. package/dist/assets/{NcActions-C4SuFczn.css → NcActions-3STB3u9J.css} +11 -11
  261. package/dist/assets/{NcAppContent-BO0ksFwD.css → NcAppContent-JfRwJlWK.css} +23 -23
  262. package/dist/assets/{NcAppNavigation-CJj8AvqM.css → NcAppNavigation-DfTQlVGB.css} +12 -12
  263. package/dist/assets/{NcAppNavigationItem-lh9Say1M.css → NcAppNavigationItem-CdT6ce8-.css} +11 -4
  264. package/dist/assets/{NcAppNavigationNew-BcDuupzO.css → NcAppNavigationNew-Dbo2rvXH.css} +3 -3
  265. package/dist/assets/{NcAppNavigationNewItem-fUP3wQTQ.css → NcAppNavigationNewItem-D7wroqrc.css} +7 -0
  266. package/dist/assets/{NcAppNavigationSearch-Df50ss_2.css → NcAppNavigationSearch-CFtTLRbc.css} +6 -6
  267. package/dist/assets/{NcAppNavigationToggle-B6FCDJp7.css → NcAppNavigationToggle-C5IMygw1.css} +3 -3
  268. package/dist/assets/{NcAppSidebar-BntAj6H-.css → NcAppSidebar-Dun97zcC.css} +43 -43
  269. package/dist/assets/{NcAvatar-CcJlFpcI.css → NcAvatar-Cc-2PM1F.css} +24 -24
  270. package/dist/assets/NcBlurHash-7aGtE-_T.css +8 -0
  271. package/dist/assets/{NcBreadcrumb-Cjcyeimd.css → NcBreadcrumb-DqaFt2qu.css} +15 -15
  272. package/dist/assets/{NcButton-CfOAX-eQ.css → NcButton-DnNZaEy_.css} +47 -47
  273. package/dist/assets/{NcCheckboxRadioSwitch-DuFrRU9C.css → NcCheckboxRadioSwitch-DlEieXCj.css} +41 -41
  274. package/dist/assets/{NcChip-CIvAlds6.css → NcChip-BNLuZgd6.css} +9 -9
  275. package/dist/assets/{NcColorPicker-C1DuuANb.css → NcColorPicker-BayJGD4p.css} +28 -30
  276. package/dist/assets/{NcContent-CZamE_IP.css → NcContent-Bq-7EZQc.css} +9 -9
  277. package/dist/assets/{NcDateTimePicker-BtV9Fz-n.css → NcDateTimePicker-D07hGMOZ.css} +54 -7
  278. package/dist/assets/{NcDialog-Bzs9oxyt.css → NcDialog-BPI0CJvw.css} +15 -15
  279. package/dist/assets/{NcEmojiPicker-rk5qcSl7.css → NcEmojiPicker-Ca6U46T8.css} +19 -15
  280. package/dist/assets/{NcEmptyContent-BlXL6nnq.css → NcEmptyContent-CSsXYYcn.css} +9 -9
  281. package/dist/assets/{NcHeaderButton-BPkJ5wxD.css → NcHeaderButton-Dr6MgPDQ.css} +8 -7
  282. package/dist/assets/{NcHeaderMenu-BYjnMPPl.css → NcHeaderMenu-DN-HfTkh.css} +12 -11
  283. package/dist/assets/{NcInputConfirmCancel-EYtW7MxF.css → NcInputConfirmCancel-BanazdhC.css} +5 -5
  284. package/dist/assets/{NcInputField-CzryIHRa.css → NcInputField-GxJ-rf2p.css} +32 -32
  285. package/dist/assets/{NcListItem-GE5S37TT.css → NcListItem-DfaWGP5A.css} +44 -44
  286. package/dist/assets/{NcModal-ZfCDJxwd.css → NcModal-DXN1C02T.css} +61 -61
  287. package/dist/assets/{NcRelatedResourcesPanel-DSf7TVcC.css → NcRelatedResourcesPanel-DhStLIO2.css} +21 -21
  288. package/dist/assets/{NcRichText-zt8ALFHi.css → NcRichText-BwghUUnz.css} +3 -0
  289. package/dist/assets/{referencePickerModal-CTumspFH.css → referencePickerModal-Ba6soz9w.css} +8 -8
  290. package/dist/chunks/AlertCircleOutline-BrsasUsU.cjs +1 -0
  291. package/dist/chunks/AlertCircleOutline-DBxbepLy.mjs +1 -0
  292. package/dist/chunks/ArrowLeft-BP7yfzCQ.cjs +1 -0
  293. package/dist/chunks/ArrowLeft-DuT2LZOm.mjs +1 -0
  294. package/dist/chunks/ArrowRight-CY2b9hgN.mjs +1 -0
  295. package/dist/chunks/ArrowRight-DPARnmu3.cjs +1 -0
  296. package/dist/chunks/Check-BkThHPH7.mjs +1 -0
  297. package/dist/chunks/Check-Du8mPz_B.cjs +1 -0
  298. package/dist/chunks/ChevronDown-BlfyuflD.cjs +1 -0
  299. package/dist/chunks/ChevronDown-DFQfzh63.mjs +1 -0
  300. package/dist/chunks/ChevronLeft-BK4j9oVH.mjs +1 -0
  301. package/dist/chunks/ChevronLeft-CAiEPWc5.cjs +1 -0
  302. package/dist/chunks/ChevronRight-BUv-PtHh.mjs +1 -0
  303. package/dist/chunks/ChevronRight-ZCKVg9OI.cjs +1 -0
  304. package/dist/chunks/ChevronUp-Bpd__OBZ.cjs +1 -0
  305. package/dist/chunks/ChevronUp-C7Dy9Bph.mjs +1 -0
  306. package/dist/chunks/Close-BtLPUSdO.mjs +1 -0
  307. package/dist/chunks/Close-CqmXxEKi.cjs +1 -0
  308. package/dist/chunks/DotsHorizontal-BoI3vnhk.cjs +1 -0
  309. package/dist/chunks/DotsHorizontal-C6LNsw4N.mjs +1 -0
  310. package/dist/chunks/{GenColors-Di5GSft7.cjs → GenColors-CV4Niqso.cjs} +2 -1
  311. package/dist/chunks/{GenColors-Di5GSft7.cjs.map → GenColors-CV4Niqso.cjs.map} +1 -1
  312. package/dist/chunks/{GenColors-DfwXw1-o.mjs → GenColors-NALDypHH.mjs} +2 -1
  313. package/dist/chunks/{GenColors-DfwXw1-o.mjs.map → GenColors-NALDypHH.mjs.map} +1 -1
  314. package/dist/chunks/GenRandomId-BQDud3d4.cjs +1 -0
  315. package/dist/chunks/GenRandomId-BQDud3d4.cjs.map +1 -1
  316. package/dist/chunks/GenRandomId-CMooMQt0.mjs +1 -0
  317. package/dist/chunks/GenRandomId-CMooMQt0.mjs.map +1 -1
  318. package/dist/chunks/{NcActionButton-CEysTg4c.mjs → NcActionButton-BFxArTsE.mjs} +10 -9
  319. package/dist/chunks/{NcActionButton-DcpUnqA7.cjs.map → NcActionButton-BFxArTsE.mjs.map} +1 -1
  320. package/dist/chunks/{NcActionButton-DcpUnqA7.cjs → NcActionButton-ChQFsL4S.cjs} +10 -9
  321. package/dist/chunks/{NcActionButton-CEysTg4c.mjs.map → NcActionButton-ChQFsL4S.cjs.map} +1 -1
  322. package/dist/chunks/{NcActionButtonGroup-3v-qy9C0.mjs → NcActionButtonGroup-B5OcRwWQ.mjs} +2 -1
  323. package/dist/chunks/{NcActionButtonGroup-3v-qy9C0.mjs.map → NcActionButtonGroup-B5OcRwWQ.mjs.map} +1 -1
  324. package/dist/chunks/{NcActionButtonGroup-x6D7S13W.cjs → NcActionButtonGroup-BSFS4BYN.cjs} +2 -1
  325. package/dist/chunks/{NcActionButtonGroup-x6D7S13W.cjs.map → NcActionButtonGroup-BSFS4BYN.cjs.map} +1 -1
  326. package/dist/chunks/{NcActionCheckbox-BnL71Qmi.mjs → NcActionCheckbox-DSMKeccY.mjs} +2 -1
  327. package/dist/chunks/{NcActionCheckbox-BnL71Qmi.mjs.map → NcActionCheckbox-DSMKeccY.mjs.map} +1 -1
  328. package/dist/chunks/{NcActionCheckbox-Dd5Y6f63.cjs → NcActionCheckbox-JX-QaTD6.cjs} +2 -1
  329. package/dist/chunks/{NcActionCheckbox-Dd5Y6f63.cjs.map → NcActionCheckbox-JX-QaTD6.cjs.map} +1 -1
  330. package/dist/chunks/{NcActionInput-BAM8T3gm.mjs → NcActionInput-DXiL7Phe.mjs} +6 -5
  331. package/dist/chunks/{NcActionInput-BAM8T3gm.mjs.map → NcActionInput-DXiL7Phe.mjs.map} +1 -1
  332. package/dist/chunks/{NcActionInput-VR510EDJ.cjs → NcActionInput-DghifYMn.cjs} +6 -5
  333. package/dist/chunks/{NcActionInput-VR510EDJ.cjs.map → NcActionInput-DghifYMn.cjs.map} +1 -1
  334. package/dist/chunks/{NcActionRadio-BQ0jAh5V.cjs → NcActionRadio-BUCQ6VxA.cjs} +2 -1
  335. package/dist/chunks/{NcActionRadio-BQ0jAh5V.cjs.map → NcActionRadio-BUCQ6VxA.cjs.map} +1 -1
  336. package/dist/chunks/{NcActionRadio-CCTupqRR.mjs → NcActionRadio-yAm71xxU.mjs} +2 -1
  337. package/dist/chunks/{NcActionRadio-CCTupqRR.mjs.map → NcActionRadio-yAm71xxU.mjs.map} +1 -1
  338. package/dist/chunks/{NcActionTextEditable-JRD-G0CT.mjs → NcActionTextEditable-BYqqHPj2.mjs} +6 -5
  339. package/dist/chunks/NcActionTextEditable-BYqqHPj2.mjs.map +1 -0
  340. package/dist/chunks/{NcActionTextEditable-C-ZP8_Tn.cjs → NcActionTextEditable-s1Xqpg6x.cjs} +6 -5
  341. package/dist/chunks/NcActionTextEditable-s1Xqpg6x.cjs.map +1 -0
  342. package/dist/chunks/{NcActions-D3hGxwlc.mjs → NcActions-C_H0APKA.mjs} +52 -53
  343. package/dist/chunks/NcActions-C_H0APKA.mjs.map +1 -0
  344. package/dist/chunks/{NcActions-DTICeoTz.cjs → NcActions-C_gPnk6X.cjs} +51 -52
  345. package/dist/chunks/NcActions-C_gPnk6X.cjs.map +1 -0
  346. package/dist/chunks/{NcAppContent-BKQ-H04y.mjs → NcAppContent-DiOscHZ8.mjs} +58 -15
  347. package/dist/chunks/NcAppContent-DiOscHZ8.mjs.map +1 -0
  348. package/dist/chunks/{NcAppContent-BOt6_YA7.cjs → NcAppContent-PC4RbdhU.cjs} +58 -15
  349. package/dist/chunks/NcAppContent-PC4RbdhU.cjs.map +1 -0
  350. package/dist/chunks/{NcAppNavigation-D7W-4cVo.cjs → NcAppNavigation-B9Dd0YBs.cjs} +6 -5
  351. package/dist/chunks/NcAppNavigation-B9Dd0YBs.cjs.map +1 -0
  352. package/dist/chunks/{NcAppNavigation-B_92V8o3.mjs → NcAppNavigation-DD1CfV7A.mjs} +7 -6
  353. package/dist/chunks/NcAppNavigation-DD1CfV7A.mjs.map +1 -0
  354. package/dist/chunks/{NcAppNavigationCaption-B3w692fN.mjs → NcAppNavigationCaption-8NN7iPkz.mjs} +2 -1
  355. package/dist/chunks/{NcAppNavigationCaption-B3w692fN.mjs.map → NcAppNavigationCaption-8NN7iPkz.mjs.map} +1 -1
  356. package/dist/chunks/{NcAppNavigationCaption-BDqTyLIj.cjs → NcAppNavigationCaption-CuKecXh9.cjs} +2 -1
  357. package/dist/chunks/{NcAppNavigationCaption-BDqTyLIj.cjs.map → NcAppNavigationCaption-CuKecXh9.cjs.map} +1 -1
  358. package/dist/chunks/{NcAppNavigationItem-DL9OwWo-.cjs → NcAppNavigationItem-B2LzgJUC.cjs} +8 -7
  359. package/dist/chunks/NcAppNavigationItem-B2LzgJUC.cjs.map +1 -0
  360. package/dist/chunks/{NcAppNavigationItem-CpcFOmJR.mjs → NcAppNavigationItem-B50v2lmS.mjs} +8 -7
  361. package/dist/chunks/NcAppNavigationItem-B50v2lmS.mjs.map +1 -0
  362. package/dist/chunks/{NcAppNavigationNewItem-BvQaVuL6.mjs → NcAppNavigationNewItem-B7_0fFTF.mjs} +3 -2
  363. package/dist/chunks/{NcAppNavigationNewItem-BvQaVuL6.mjs.map → NcAppNavigationNewItem-B7_0fFTF.mjs.map} +1 -1
  364. package/dist/chunks/{NcAppNavigationNewItem-BaKxxZqt.cjs → NcAppNavigationNewItem-bRz_V5Y1.cjs} +3 -2
  365. package/dist/chunks/{NcAppNavigationNewItem-BaKxxZqt.cjs.map → NcAppNavigationNewItem-bRz_V5Y1.cjs.map} +1 -1
  366. package/dist/chunks/{NcAppNavigationSearch-Q0eMy5I2.cjs → NcAppNavigationSearch-B-HqHu3j.cjs} +5 -4
  367. package/dist/chunks/NcAppNavigationSearch-B-HqHu3j.cjs.map +1 -0
  368. package/dist/chunks/{NcAppNavigationSearch-gytpBKme.mjs → NcAppNavigationSearch-ChGonQL8.mjs} +5 -4
  369. package/dist/chunks/NcAppNavigationSearch-ChGonQL8.mjs.map +1 -0
  370. package/dist/chunks/{NcAppNavigationSettings-CZFm1d-N.mjs → NcAppNavigationSettings-9nG2gY_9.mjs} +2 -1
  371. package/dist/chunks/{NcAppNavigationSettings-CZFm1d-N.mjs.map → NcAppNavigationSettings-9nG2gY_9.mjs.map} +1 -1
  372. package/dist/chunks/{NcAppNavigationSettings-CwwmvKYV.cjs → NcAppNavigationSettings-C--IJ1A2.cjs} +2 -1
  373. package/dist/chunks/{NcAppNavigationSettings-CwwmvKYV.cjs.map → NcAppNavigationSettings-C--IJ1A2.cjs.map} +1 -1
  374. package/dist/chunks/{NcAppNavigationToggle-Pr8bEpDs.mjs → NcAppNavigationToggle-CJ5N3NI4.mjs} +5 -4
  375. package/dist/chunks/NcAppNavigationToggle-CJ5N3NI4.mjs.map +1 -0
  376. package/dist/chunks/{NcAppNavigationToggle-Br1hcFGt.cjs → NcAppNavigationToggle-FxOt_DlD.cjs} +5 -4
  377. package/dist/chunks/NcAppNavigationToggle-FxOt_DlD.cjs.map +1 -0
  378. package/dist/chunks/{NcAppSettingsDialog-JPB-srka.mjs → NcAppSettingsDialog-C2rBRxUv.mjs} +3 -2
  379. package/dist/chunks/{NcAppSettingsDialog-JPB-srka.mjs.map → NcAppSettingsDialog-C2rBRxUv.mjs.map} +1 -1
  380. package/dist/chunks/{NcAppSettingsDialog-z9v6V6ye.cjs → NcAppSettingsDialog-CSLft-a9.cjs} +3 -2
  381. package/dist/chunks/{NcAppSettingsDialog-z9v6V6ye.cjs.map → NcAppSettingsDialog-CSLft-a9.cjs.map} +1 -1
  382. package/dist/chunks/{NcAppSidebar-cEQy8s50.mjs → NcAppSidebar-19hVcGhv.mjs} +17 -16
  383. package/dist/chunks/NcAppSidebar-19hVcGhv.mjs.map +1 -0
  384. package/dist/chunks/{NcAppSidebar-BY33yoNX.cjs → NcAppSidebar-DVvZYd17.cjs} +13 -12
  385. package/dist/chunks/NcAppSidebar-DVvZYd17.cjs.map +1 -0
  386. package/dist/chunks/{NcAvatar-CQtsmbBW.cjs → NcAvatar--JVA_B6Y.cjs} +41 -17
  387. package/dist/chunks/NcAvatar--JVA_B6Y.cjs.map +1 -0
  388. package/dist/chunks/{NcAvatar-BjwyJw34.mjs → NcAvatar-DwORvUjC.mjs} +42 -18
  389. package/dist/chunks/NcAvatar-DwORvUjC.mjs.map +1 -0
  390. package/dist/chunks/NcBlurHash-CJ8retHx.cjs +115 -0
  391. package/dist/chunks/NcBlurHash-CJ8retHx.cjs.map +1 -0
  392. package/dist/chunks/NcBlurHash-do2wxY-0.mjs +116 -0
  393. package/dist/chunks/NcBlurHash-do2wxY-0.mjs.map +1 -0
  394. package/dist/chunks/{NcBreadcrumb-DrlhnNbV.cjs → NcBreadcrumb-B0ve-OJl.cjs} +6 -5
  395. package/dist/chunks/NcBreadcrumb-B0ve-OJl.cjs.map +1 -0
  396. package/dist/chunks/{NcBreadcrumb-GHiD-Sw7.mjs → NcBreadcrumb-DPF3ELzz.mjs} +6 -5
  397. package/dist/chunks/NcBreadcrumb-DPF3ELzz.mjs.map +1 -0
  398. package/dist/chunks/{NcBreadcrumbs-D0Hhym9A.mjs → NcBreadcrumbs-CL_IHuT9.mjs} +5 -4
  399. package/dist/chunks/{NcBreadcrumbs-D0Hhym9A.mjs.map → NcBreadcrumbs-CL_IHuT9.mjs.map} +1 -1
  400. package/dist/chunks/{NcBreadcrumbs-Cde4tv8l.cjs → NcBreadcrumbs-C_XQLT-h.cjs} +4 -3
  401. package/dist/chunks/{NcBreadcrumbs-Cde4tv8l.cjs.map → NcBreadcrumbs-C_XQLT-h.cjs.map} +1 -1
  402. package/dist/chunks/{NcCheckboxRadioSwitch-CCuKA55c.mjs → NcCheckboxRadioSwitch-BaMf0PDd.mjs} +7 -13
  403. package/dist/chunks/NcCheckboxRadioSwitch-BaMf0PDd.mjs.map +1 -0
  404. package/dist/chunks/{NcCheckboxRadioSwitch-RjEq0SqY.cjs → NcCheckboxRadioSwitch-DOxX6fqr.cjs} +7 -13
  405. package/dist/chunks/NcCheckboxRadioSwitch-DOxX6fqr.cjs.map +1 -0
  406. package/dist/chunks/{NcCollectionList-fyDi2W_B.cjs → NcCollectionList-DyZNTQFW.cjs} +6 -5
  407. package/dist/chunks/{NcCollectionList-fyDi2W_B.cjs.map → NcCollectionList-DyZNTQFW.cjs.map} +1 -1
  408. package/dist/chunks/{NcCollectionList-BNxu1MWE.mjs → NcCollectionList-iHUm6owG.mjs} +6 -5
  409. package/dist/chunks/{NcCollectionList-BNxu1MWE.mjs.map → NcCollectionList-iHUm6owG.mjs.map} +1 -1
  410. package/dist/chunks/{NcColorPicker-CTQlyVCL.cjs → NcColorPicker-CKIoVhox.cjs} +9 -8
  411. package/dist/chunks/NcColorPicker-CKIoVhox.cjs.map +1 -0
  412. package/dist/chunks/{NcColorPicker-ph8Nubq7.mjs → NcColorPicker-av-NHSU7.mjs} +9 -8
  413. package/dist/chunks/NcColorPicker-av-NHSU7.mjs.map +1 -0
  414. package/dist/chunks/{NcContent-CJNhr5lF.cjs → NcContent-EFEXh_OO.cjs} +6 -5
  415. package/dist/chunks/{NcContent-CJNhr5lF.cjs.map → NcContent-EFEXh_OO.cjs.map} +1 -1
  416. package/dist/chunks/{NcContent-RlppaZCX.mjs → NcContent-uiwRXAwA.mjs} +6 -5
  417. package/dist/chunks/{NcContent-RlppaZCX.mjs.map → NcContent-uiwRXAwA.mjs.map} +1 -1
  418. package/dist/chunks/NcCounterBubble-BRrUO34D.cjs +1 -0
  419. package/dist/chunks/NcCounterBubble-CDfRYl8B.mjs +1 -0
  420. package/dist/chunks/{NcDashboardWidget-CirRHHmT.cjs → NcDashboardWidget-3kbcJvFx.cjs} +4 -3
  421. package/dist/chunks/{NcDashboardWidget-CirRHHmT.cjs.map → NcDashboardWidget-3kbcJvFx.cjs.map} +1 -1
  422. package/dist/chunks/{NcDashboardWidget-Dg12xu50.mjs → NcDashboardWidget-DDaM0QjK.mjs} +4 -3
  423. package/dist/chunks/{NcDashboardWidget-Dg12xu50.mjs.map → NcDashboardWidget-DDaM0QjK.mjs.map} +1 -1
  424. package/dist/chunks/{NcDashboardWidgetItem-DZGooEwA.mjs → NcDashboardWidgetItem-C44gZwCP.mjs} +4 -3
  425. package/dist/chunks/{NcDashboardWidgetItem-DZGooEwA.mjs.map → NcDashboardWidgetItem-C44gZwCP.mjs.map} +1 -1
  426. package/dist/chunks/{NcDashboardWidgetItem-COONyn0g.cjs → NcDashboardWidgetItem-DOzM3reO.cjs} +4 -3
  427. package/dist/chunks/{NcDashboardWidgetItem-COONyn0g.cjs.map → NcDashboardWidgetItem-DOzM3reO.cjs.map} +1 -1
  428. package/dist/chunks/{NcDateTime-DBZ-vBfi.mjs → NcDateTime-BfJVNppR.mjs} +2 -1
  429. package/dist/chunks/{NcDateTime-DBZ-vBfi.mjs.map → NcDateTime-BfJVNppR.mjs.map} +1 -1
  430. package/dist/chunks/{NcDateTime-AFZif5Dn.cjs → NcDateTime-DNnBHGEQ.cjs} +2 -1
  431. package/dist/chunks/{NcDateTime-AFZif5Dn.cjs.map → NcDateTime-DNnBHGEQ.cjs.map} +1 -1
  432. package/dist/chunks/{NcDialog-I_9fyJVt.mjs → NcDialog-D3Z5tp_6.mjs} +28 -11
  433. package/dist/chunks/NcDialog-D3Z5tp_6.mjs.map +1 -0
  434. package/dist/chunks/{NcDialog-mcbLFc8o.cjs → NcDialog-DbCdhtw7.cjs} +28 -11
  435. package/dist/chunks/NcDialog-DbCdhtw7.cjs.map +1 -0
  436. package/dist/chunks/{NcDialogButton-DuJ3lE7e.mjs → NcDialogButton-BhPydgMe.mjs} +28 -9
  437. package/dist/chunks/NcDialogButton-BhPydgMe.mjs.map +1 -0
  438. package/dist/chunks/{NcDialogButton-FLqQdVLb.cjs → NcDialogButton-CYsTKE2g.cjs} +28 -9
  439. package/dist/chunks/NcDialogButton-CYsTKE2g.cjs.map +1 -0
  440. package/dist/chunks/{NcEmojiPicker-DDCgW2zQ.mjs → NcEmojiPicker-C5HYxVqp.mjs} +19 -11
  441. package/dist/chunks/NcEmojiPicker-C5HYxVqp.mjs.map +1 -0
  442. package/dist/chunks/{NcEmojiPicker-B1ot5iNB.cjs → NcEmojiPicker-DPHhky3J.cjs} +17 -9
  443. package/dist/chunks/NcEmojiPicker-DPHhky3J.cjs.map +1 -0
  444. package/dist/chunks/{NcHeaderMenu-BaHhnhN0.cjs → NcHeaderMenu-B287C-Vk.cjs} +6 -5
  445. package/dist/chunks/NcHeaderMenu-B287C-Vk.cjs.map +1 -0
  446. package/dist/chunks/{NcHeaderMenu-CLcpStap.mjs → NcHeaderMenu-Bc1ucNsv.mjs} +6 -5
  447. package/dist/chunks/NcHeaderMenu-Bc1ucNsv.mjs.map +1 -0
  448. package/dist/chunks/NcIconSvgWrapper-B_eOG2sZ.cjs +1 -0
  449. package/dist/chunks/NcIconSvgWrapper-B_eOG2sZ.cjs.map +1 -1
  450. package/dist/chunks/NcIconSvgWrapper-CHmdAuhg.mjs +1 -0
  451. package/dist/chunks/{NcInputConfirmCancel-C7a7Nha7.mjs → NcInputConfirmCancel-CvV0tE6s.mjs} +7 -6
  452. package/dist/chunks/NcInputConfirmCancel-CvV0tE6s.mjs.map +1 -0
  453. package/dist/chunks/{NcInputConfirmCancel-XzKuYi6L.cjs → NcInputConfirmCancel-DRhv_CTt.cjs} +7 -6
  454. package/dist/chunks/NcInputConfirmCancel-DRhv_CTt.cjs.map +1 -0
  455. package/dist/chunks/{NcInputField-DkhKrb8k.cjs → NcInputField-C61UUN46.cjs} +4 -3
  456. package/dist/chunks/NcInputField-C61UUN46.cjs.map +1 -0
  457. package/dist/chunks/{NcInputField-CU5a68Pc.mjs → NcInputField-DTtUueUZ.mjs} +4 -3
  458. package/dist/chunks/NcInputField-DTtUueUZ.mjs.map +1 -0
  459. package/dist/chunks/{NcListItem-3e1MminS.mjs → NcListItem-CA4CzIW8.mjs} +4 -3
  460. package/dist/chunks/NcListItem-CA4CzIW8.mjs.map +1 -0
  461. package/dist/chunks/{NcListItem-9w7m2lJ_.cjs → NcListItem-D5XlkLgC.cjs} +4 -3
  462. package/dist/chunks/NcListItem-D5XlkLgC.cjs.map +1 -0
  463. package/dist/chunks/{NcListItemIcon-pOj8Vr2H.cjs → NcListItemIcon-DIJ0vvYv.cjs} +2 -1
  464. package/dist/chunks/{NcListItemIcon-pOj8Vr2H.cjs.map → NcListItemIcon-DIJ0vvYv.cjs.map} +1 -1
  465. package/dist/chunks/{NcListItemIcon-7x7iDHYw.mjs → NcListItemIcon-DhENqcJ-.mjs} +2 -1
  466. package/dist/chunks/{NcListItemIcon-7x7iDHYw.mjs.map → NcListItemIcon-DhENqcJ-.mjs.map} +1 -1
  467. package/dist/chunks/{NcPasswordField-BS6bkHtv.cjs → NcPasswordField-DXJ93Wpz.cjs} +3 -2
  468. package/dist/chunks/{NcPasswordField-BS6bkHtv.cjs.map → NcPasswordField-DXJ93Wpz.cjs.map} +1 -1
  469. package/dist/chunks/{NcPasswordField-Dpu9nI6h.mjs → NcPasswordField-zMKko5oa.mjs} +3 -2
  470. package/dist/chunks/{NcPasswordField-Dpu9nI6h.mjs.map → NcPasswordField-zMKko5oa.mjs.map} +1 -1
  471. package/dist/chunks/{NcPopover-DFCPlZpS.mjs → NcPopover-C9KlPo4Z.mjs} +11 -4
  472. package/dist/chunks/NcPopover-C9KlPo4Z.mjs.map +1 -0
  473. package/dist/chunks/{NcPopover-BKlH1mbx.cjs → NcPopover-CA2Dalxs.cjs} +11 -4
  474. package/dist/chunks/NcPopover-CA2Dalxs.cjs.map +1 -0
  475. package/dist/chunks/NcProgressBar-DegJ2JjE.mjs +1 -0
  476. package/dist/chunks/NcProgressBar-Do5Y3u8S.cjs +1 -0
  477. package/dist/chunks/{NcRelatedResourcesPanel-C6JIVMvN.mjs → NcRelatedResourcesPanel-BxBE_1N3.mjs} +7 -6
  478. package/dist/chunks/NcRelatedResourcesPanel-BxBE_1N3.mjs.map +1 -0
  479. package/dist/chunks/{NcRelatedResourcesPanel-BrkyIR3v.cjs → NcRelatedResourcesPanel-X4vhm8hy.cjs} +7 -6
  480. package/dist/chunks/NcRelatedResourcesPanel-X4vhm8hy.cjs.map +1 -0
  481. package/dist/chunks/{NcRichContenteditable-DJy0zZXx.cjs → NcRichContenteditable-CC4jGcJn.cjs} +7 -6
  482. package/dist/chunks/{NcRichContenteditable-DJy0zZXx.cjs.map → NcRichContenteditable-CC4jGcJn.cjs.map} +1 -1
  483. package/dist/chunks/{NcRichContenteditable-3kkU0Uxu.mjs → NcRichContenteditable-Ct8cG0U6.mjs} +9 -8
  484. package/dist/chunks/{NcRichContenteditable-3kkU0Uxu.mjs.map → NcRichContenteditable-Ct8cG0U6.mjs.map} +1 -1
  485. package/dist/chunks/NcRichText-Ck9Sk6wk.cjs +3707 -0
  486. package/dist/chunks/NcRichText-Ck9Sk6wk.cjs.map +1 -0
  487. package/dist/chunks/NcRichText-h1RHm2bK.mjs +3679 -0
  488. package/dist/chunks/NcRichText-h1RHm2bK.mjs.map +1 -0
  489. package/dist/chunks/NcSavingIndicatorIcon-Bu-zt4pR.cjs +1 -0
  490. package/dist/chunks/NcSavingIndicatorIcon-nv1147dk.mjs +1 -0
  491. package/dist/chunks/{NcSelect-BQ-NFBXI.mjs → NcSelect-DrtYueu1.mjs} +3 -2
  492. package/dist/chunks/NcSelect-DrtYueu1.mjs.map +1 -0
  493. package/dist/chunks/{NcSelect-YHwbPAJD.cjs → NcSelect-vJq9dZPb.cjs} +3 -2
  494. package/dist/chunks/NcSelect-vJq9dZPb.cjs.map +1 -0
  495. package/dist/chunks/{NcSelectTags-BKtOWgrz.mjs → NcSelectTags--4zU4C41.mjs} +3 -2
  496. package/dist/chunks/{NcSelectTags-BKtOWgrz.mjs.map → NcSelectTags--4zU4C41.mjs.map} +1 -1
  497. package/dist/chunks/{NcSelectTags-BAMsfdw9.cjs → NcSelectTags-DvVm-C1N.cjs} +3 -2
  498. package/dist/chunks/{NcSelectTags-BAMsfdw9.cjs.map → NcSelectTags-DvVm-C1N.cjs.map} +1 -1
  499. package/dist/chunks/{NcSettingsInputText-nb2XMaJW.cjs → NcSettingsInputText-8EcoOEIo.cjs} +2 -1
  500. package/dist/chunks/{NcSettingsInputText-nb2XMaJW.cjs.map → NcSettingsInputText-8EcoOEIo.cjs.map} +1 -1
  501. package/dist/chunks/{NcSettingsInputText-DC7H_6Uz.mjs → NcSettingsInputText-DKscbkn_.mjs} +2 -1
  502. package/dist/chunks/{NcSettingsInputText-DC7H_6Uz.mjs.map → NcSettingsInputText-DKscbkn_.mjs.map} +1 -1
  503. package/dist/chunks/{NcSettingsSection-BYKUjim0.mjs → NcSettingsSection-DP3xDXrA.mjs} +2 -1
  504. package/dist/chunks/{NcSettingsSection-BYKUjim0.mjs.map → NcSettingsSection-DP3xDXrA.mjs.map} +1 -1
  505. package/dist/chunks/{NcSettingsSection-6Sc6GBsM.cjs → NcSettingsSection-DW5u2qWg.cjs} +2 -1
  506. package/dist/chunks/{NcSettingsSection-6Sc6GBsM.cjs.map → NcSettingsSection-DW5u2qWg.cjs.map} +1 -1
  507. package/dist/chunks/{NcSettingsSelectGroup-CI2LoVeL.mjs → NcSettingsSelectGroup-DHuru8HO.mjs} +3 -2
  508. package/dist/chunks/{NcSettingsSelectGroup-CI2LoVeL.mjs.map → NcSettingsSelectGroup-DHuru8HO.mjs.map} +1 -1
  509. package/dist/chunks/{NcSettingsSelectGroup-DX4AaRte.cjs → NcSettingsSelectGroup-DmnTgIg5.cjs} +3 -2
  510. package/dist/chunks/{NcSettingsSelectGroup-DX4AaRte.cjs.map → NcSettingsSelectGroup-DmnTgIg5.cjs.map} +1 -1
  511. package/dist/chunks/NcTextArea-BHERsE_g.mjs +1 -0
  512. package/dist/chunks/NcTextArea-CYLGAGcO.cjs +1 -0
  513. package/dist/chunks/NcTextArea-CYLGAGcO.cjs.map +1 -1
  514. package/dist/chunks/{NcTextField-9gC8or6j.mjs → NcTextField-DpLIIKYI.mjs} +3 -2
  515. package/dist/chunks/{NcTextField-9gC8or6j.mjs.map → NcTextField-DpLIIKYI.mjs.map} +1 -1
  516. package/dist/chunks/{NcTextField-Pbox9mQE.cjs → NcTextField-rilWP68p.cjs} +3 -2
  517. package/dist/chunks/{NcTextField-Pbox9mQE.cjs.map → NcTextField-rilWP68p.cjs.map} +1 -1
  518. package/dist/chunks/{NcTimezonePicker-xSXSuNHX.mjs → NcTimezonePicker-CGuLj6Bs.mjs} +3 -2
  519. package/dist/chunks/{NcTimezonePicker-xSXSuNHX.mjs.map → NcTimezonePicker-CGuLj6Bs.mjs.map} +1 -1
  520. package/dist/chunks/{NcTimezonePicker-DIwsRdu2.cjs → NcTimezonePicker-CQkZVQOW.cjs} +3 -2
  521. package/dist/chunks/{NcTimezonePicker-DIwsRdu2.cjs.map → NcTimezonePicker-CQkZVQOW.cjs.map} +1 -1
  522. package/dist/chunks/{NcUserBubble-rphdAcHS.cjs → NcUserBubble-Du4ecEXq.cjs} +3 -2
  523. package/dist/chunks/{NcUserBubble-rphdAcHS.cjs.map → NcUserBubble-Du4ecEXq.cjs.map} +1 -1
  524. package/dist/chunks/{NcUserBubble-BFvEaXLr.mjs → NcUserBubble-X7NIiLjg.mjs} +3 -2
  525. package/dist/chunks/{NcUserBubble-BFvEaXLr.mjs.map → NcUserBubble-X7NIiLjg.mjs.map} +1 -1
  526. package/dist/chunks/{NcUserStatusIcon-CFLiHFkC.cjs → NcUserStatusIcon-Cy942iqr.cjs} +3 -1
  527. package/dist/chunks/{NcUserStatusIcon-CFLiHFkC.cjs.map → NcUserStatusIcon-Cy942iqr.cjs.map} +1 -1
  528. package/dist/chunks/{NcUserStatusIcon-S5bBgRl6.mjs → NcUserStatusIcon-D1Mw6nKB.mjs} +3 -1
  529. package/dist/chunks/{NcUserStatusIcon-S5bBgRl6.mjs.map → NcUserStatusIcon-D1Mw6nKB.mjs.map} +1 -1
  530. package/dist/chunks/{ScopeComponent-CEMLuQd5.mjs → ScopeComponent-Dw8Duyxn.mjs} +2 -1
  531. package/dist/chunks/{ScopeComponent-CEMLuQd5.mjs.map → ScopeComponent-Dw8Duyxn.mjs.map} +1 -1
  532. package/dist/chunks/{ScopeComponent-B5vclUCV.cjs → ScopeComponent-Uz_pNcsJ.cjs} +2 -1
  533. package/dist/chunks/{ScopeComponent-B5vclUCV.cjs.map → ScopeComponent-Uz_pNcsJ.cjs.map} +1 -1
  534. package/dist/chunks/_l10n-DINju8Lo.cjs +139 -0
  535. package/dist/chunks/{_l10n-CjO_W5Dt.cjs.map → _l10n-DINju8Lo.cjs.map} +1 -1
  536. package/dist/chunks/_l10n-DKne-gFg.mjs +140 -0
  537. package/dist/chunks/_l10n-DKne-gFg.mjs.map +1 -0
  538. package/dist/chunks/_plugin-vue2_normalizer-DU4iP6Vu.mjs +1 -0
  539. package/dist/chunks/_plugin-vue2_normalizer-V0q-tHlQ.cjs +1 -0
  540. package/dist/chunks/actionGlobal-DqVa7c7G.mjs +1 -0
  541. package/dist/chunks/actionGlobal-DqVa7c7G.mjs.map +1 -1
  542. package/dist/chunks/actionGlobal-L0Ls8tPJ.cjs +1 -0
  543. package/dist/chunks/actionGlobal-L0Ls8tPJ.cjs.map +1 -1
  544. package/dist/chunks/actionText-BcrK4uH1.cjs +1 -0
  545. package/dist/chunks/actionText-BcrK4uH1.cjs.map +1 -1
  546. package/dist/chunks/actionText-fFcUPi2g.mjs +1 -0
  547. package/dist/chunks/actionText-fFcUPi2g.mjs.map +1 -1
  548. package/dist/chunks/autolink-BAgL31EZ.cjs +1 -0
  549. package/dist/chunks/autolink-BAgL31EZ.cjs.map +1 -1
  550. package/dist/chunks/autolink-cbuFALXr.mjs +1 -0
  551. package/dist/chunks/autolink-cbuFALXr.mjs.map +1 -1
  552. package/dist/chunks/emoji-BY_D0V5K.mjs +1 -0
  553. package/dist/chunks/emoji-BY_D0V5K.mjs.map +1 -1
  554. package/dist/chunks/emoji-VgSjNTd5.cjs +1 -0
  555. package/dist/chunks/emoji-VgSjNTd5.cjs.map +1 -1
  556. package/dist/chunks/focusTrap-DmkaYJTC.mjs +32 -0
  557. package/dist/chunks/focusTrap-DmkaYJTC.mjs.map +1 -0
  558. package/dist/chunks/focusTrap-Vbgxe8ZX.cjs +31 -0
  559. package/dist/chunks/focusTrap-Vbgxe8ZX.cjs.map +1 -0
  560. package/dist/chunks/getAvatarUrl-6z9qRNH-.cjs +1 -0
  561. package/dist/chunks/getAvatarUrl-DxvUjKMi.mjs +1 -0
  562. package/dist/chunks/{index-CtoB4eIp.mjs → index-56SXuvlv.mjs} +3 -2
  563. package/dist/chunks/{index-CtoB4eIp.mjs.map → index-56SXuvlv.mjs.map} +1 -1
  564. package/dist/chunks/index-BV85rPB7.cjs +1 -0
  565. package/dist/chunks/index-BV85rPB7.cjs.map +1 -1
  566. package/dist/chunks/index-BiECbTbJ.cjs +1 -0
  567. package/dist/chunks/index-BiECbTbJ.cjs.map +1 -1
  568. package/dist/chunks/index-Bz6q9mZw.mjs +1 -0
  569. package/dist/chunks/index-Bz6q9mZw.mjs.map +1 -1
  570. package/dist/chunks/index-DIJxEozm.cjs +1 -0
  571. package/dist/chunks/index-DIJxEozm.cjs.map +1 -1
  572. package/dist/chunks/index-G8WQDZ8G.mjs +1 -0
  573. package/dist/chunks/index-G8WQDZ8G.mjs.map +1 -1
  574. package/dist/chunks/logger-3HuiEIF6.cjs +1 -0
  575. package/dist/chunks/logger-D3RVzcfQ.mjs +1 -0
  576. package/dist/chunks/{referencePickerModal-BkBu4cnq.cjs → referencePickerModal-CIO6RuJz.cjs} +7 -6
  577. package/dist/chunks/{referencePickerModal-BkBu4cnq.cjs.map → referencePickerModal-CIO6RuJz.cjs.map} +1 -1
  578. package/dist/chunks/{referencePickerModal-CGG57Dy_.mjs → referencePickerModal-DTLuXI-A.mjs} +8 -7
  579. package/dist/chunks/{referencePickerModal-CGG57Dy_.mjs.map → referencePickerModal-DTLuXI-A.mjs.map} +1 -1
  580. package/dist/chunks/rtl-DLuwcTlm.cjs +5 -0
  581. package/dist/chunks/rtl-DLuwcTlm.cjs.map +1 -0
  582. package/dist/chunks/rtl-v0UOPAM7.mjs +6 -0
  583. package/dist/chunks/rtl-v0UOPAM7.mjs.map +1 -0
  584. package/dist/chunks/useModelMigration-D5zhrNXr.cjs +1 -0
  585. package/dist/chunks/useModelMigration-D5zhrNXr.cjs.map +1 -1
  586. package/dist/chunks/useModelMigration-EhAWvqDD.mjs +1 -0
  587. package/dist/chunks/useModelMigration-EhAWvqDD.mjs.map +1 -1
  588. package/dist/chunks/useTrapStackControl-BJmJdJak.cjs +22 -0
  589. package/dist/chunks/useTrapStackControl-BJmJdJak.cjs.map +1 -0
  590. package/dist/chunks/useTrapStackControl-b3A_383w.mjs +23 -0
  591. package/dist/chunks/useTrapStackControl-b3A_383w.mjs.map +1 -0
  592. package/dist/chunks/{usernameToColor-cVFS7tET.cjs → usernameToColor-BiO_8cQo.cjs} +2 -1
  593. package/dist/chunks/{usernameToColor-cVFS7tET.cjs.map → usernameToColor-BiO_8cQo.cjs.map} +1 -1
  594. package/dist/chunks/{usernameToColor-BCZuxlEH.mjs → usernameToColor-DLOoqQAF.mjs} +2 -1
  595. package/dist/chunks/{usernameToColor-BCZuxlEH.mjs.map → usernameToColor-DLOoqQAF.mjs.map} +1 -1
  596. package/dist/composables/useTrapStackControl.d.ts +12 -0
  597. package/dist/functions/index.d.ts +3 -2
  598. package/dist/functions/preloadImage/index.d.ts +9 -0
  599. package/dist/functions/reference/widgets.d.ts +1 -1
  600. package/dist/index.cjs +58 -52
  601. package/dist/index.cjs.map +1 -1
  602. package/dist/index.mjs +59 -53
  603. package/dist/index.mjs.map +1 -1
  604. package/dist/utils/focusTrap.d.ts +26 -0
  605. package/dist/utils/rtl.d.ts +5 -0
  606. package/dist/vendor.LICENSE.txt +128 -0
  607. package/package.json +23 -15
  608. package/dist/chunks/NcActionTextEditable-C-ZP8_Tn.cjs.map +0 -1
  609. package/dist/chunks/NcActionTextEditable-JRD-G0CT.mjs.map +0 -1
  610. package/dist/chunks/NcActions-D3hGxwlc.mjs.map +0 -1
  611. package/dist/chunks/NcActions-DTICeoTz.cjs.map +0 -1
  612. package/dist/chunks/NcAppContent-BKQ-H04y.mjs.map +0 -1
  613. package/dist/chunks/NcAppContent-BOt6_YA7.cjs.map +0 -1
  614. package/dist/chunks/NcAppNavigation-B_92V8o3.mjs.map +0 -1
  615. package/dist/chunks/NcAppNavigation-D7W-4cVo.cjs.map +0 -1
  616. package/dist/chunks/NcAppNavigationItem-CpcFOmJR.mjs.map +0 -1
  617. package/dist/chunks/NcAppNavigationItem-DL9OwWo-.cjs.map +0 -1
  618. package/dist/chunks/NcAppNavigationSearch-Q0eMy5I2.cjs.map +0 -1
  619. package/dist/chunks/NcAppNavigationSearch-gytpBKme.mjs.map +0 -1
  620. package/dist/chunks/NcAppNavigationToggle-Br1hcFGt.cjs.map +0 -1
  621. package/dist/chunks/NcAppNavigationToggle-Pr8bEpDs.mjs.map +0 -1
  622. package/dist/chunks/NcAppSidebar-BY33yoNX.cjs.map +0 -1
  623. package/dist/chunks/NcAppSidebar-cEQy8s50.mjs.map +0 -1
  624. package/dist/chunks/NcAvatar-BjwyJw34.mjs.map +0 -1
  625. package/dist/chunks/NcAvatar-CQtsmbBW.cjs.map +0 -1
  626. package/dist/chunks/NcBreadcrumb-DrlhnNbV.cjs.map +0 -1
  627. package/dist/chunks/NcBreadcrumb-GHiD-Sw7.mjs.map +0 -1
  628. package/dist/chunks/NcCheckboxRadioSwitch-CCuKA55c.mjs.map +0 -1
  629. package/dist/chunks/NcCheckboxRadioSwitch-RjEq0SqY.cjs.map +0 -1
  630. package/dist/chunks/NcColorPicker-CTQlyVCL.cjs.map +0 -1
  631. package/dist/chunks/NcColorPicker-ph8Nubq7.mjs.map +0 -1
  632. package/dist/chunks/NcDialog-I_9fyJVt.mjs.map +0 -1
  633. package/dist/chunks/NcDialog-mcbLFc8o.cjs.map +0 -1
  634. package/dist/chunks/NcDialogButton-DuJ3lE7e.mjs.map +0 -1
  635. package/dist/chunks/NcDialogButton-FLqQdVLb.cjs.map +0 -1
  636. package/dist/chunks/NcEmojiPicker-B1ot5iNB.cjs.map +0 -1
  637. package/dist/chunks/NcEmojiPicker-DDCgW2zQ.mjs.map +0 -1
  638. package/dist/chunks/NcHeaderMenu-BaHhnhN0.cjs.map +0 -1
  639. package/dist/chunks/NcHeaderMenu-CLcpStap.mjs.map +0 -1
  640. package/dist/chunks/NcInputConfirmCancel-C7a7Nha7.mjs.map +0 -1
  641. package/dist/chunks/NcInputConfirmCancel-XzKuYi6L.cjs.map +0 -1
  642. package/dist/chunks/NcInputField-CU5a68Pc.mjs.map +0 -1
  643. package/dist/chunks/NcInputField-DkhKrb8k.cjs.map +0 -1
  644. package/dist/chunks/NcListItem-3e1MminS.mjs.map +0 -1
  645. package/dist/chunks/NcListItem-9w7m2lJ_.cjs.map +0 -1
  646. package/dist/chunks/NcPopover-BKlH1mbx.cjs.map +0 -1
  647. package/dist/chunks/NcPopover-DFCPlZpS.mjs.map +0 -1
  648. package/dist/chunks/NcRelatedResourcesPanel-BrkyIR3v.cjs.map +0 -1
  649. package/dist/chunks/NcRelatedResourcesPanel-C6JIVMvN.mjs.map +0 -1
  650. package/dist/chunks/NcRichText-C8SjsRK8.mjs +0 -420
  651. package/dist/chunks/NcRichText-C8SjsRK8.mjs.map +0 -1
  652. package/dist/chunks/NcRichText-Ci72ylJ9.cjs +0 -449
  653. package/dist/chunks/NcRichText-Ci72ylJ9.cjs.map +0 -1
  654. package/dist/chunks/NcSelect-BQ-NFBXI.mjs.map +0 -1
  655. package/dist/chunks/NcSelect-YHwbPAJD.cjs.map +0 -1
  656. package/dist/chunks/_l10n-CjO_W5Dt.cjs +0 -138
  657. package/dist/chunks/_l10n-DDKxBWQL.mjs +0 -139
  658. package/dist/chunks/_l10n-DDKxBWQL.mjs.map +0 -1
  659. package/dist/chunks/focusTrap-Cecv_gjR.mjs +0 -7
  660. package/dist/chunks/focusTrap-Cecv_gjR.mjs.map +0 -1
  661. package/dist/chunks/focusTrap-EeXFmjdI.cjs +0 -6
  662. package/dist/chunks/focusTrap-EeXFmjdI.cjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"NcAppSidebarTab.cjs","sources":["../../src/components/NcAppSidebarTab/NcAppSidebarTab.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<!-- Follows the tab aria guidelines\n\thttps://www.w3.org/TR/wai-aria-practices/examples/tabs/tabs-1/tabs.html -->\n\n<template>\n\t<section :id=\"`tab-${id}`\"\n\t\t:class=\"{'app-sidebar__tab--active': isActive}\"\n\t\t:aria-hidden=\"!isActive\"\n\t\t:aria-label=\"isTablistShown() ? undefined : name\"\n\t\t:aria-labelledby=\"isTablistShown() ? `tab-button-${id}` : undefined\"\n\t\tclass=\"app-sidebar__tab\"\n\t\t:tabindex=\"isTablistShown() ? 0 : -1\"\n\t\t:role=\"isTablistShown() ? 'tabpanel' : undefined\"\n\t\t@scroll=\"onScroll\">\n\t\t<h3 class=\"hidden-visually\">\n\t\t\t{{ name }}\n\t\t</h3>\n\t\t<!-- @slot Tab panel content -->\n\t\t<slot />\n\t</section>\n</template>\n\n<script>\nexport default {\n\tname: 'NcAppSidebarTab',\n\n\tinject: ['registerTab', 'unregisterTab', 'getActiveTab', 'isTablistShown'],\n\n\tprops: {\n\t\tid: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * Tab name in navigation\n\t\t */\n\t\tname: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * Tab icon's html class in navigation. Used if #icon slot is not provided\n\t\t */\n\t\ticon: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Tab order in navigation. If not provided, name is used.\n\t\t */\n\t\torder: {\n\t\t\ttype: Number,\n\t\t\tdefault: 0,\n\t\t},\n\t},\n\n\temits: [\n\t\t'bottom-reached',\n\t\t'scroll',\n\t],\n\n\texpose: ['id', 'name', 'icon', 'order', 'renderIcon'],\n\n\tcomputed: {\n\t\t/**\n\t\t * Is the current tab an active tab, that should be shown?\n\t\t *\n\t\t * @return {boolean}\n\t\t */\n\t\tisActive() {\n\t\t\treturn this.getActiveTab() === this.id\n\t\t},\n\t},\n\n\tcreated() {\n\t\t// As the tab is created - register it in the tabs component\n\t\t// It's better to provide computed tab object, not component instance as it easy\n\t\tthis.registerTab(this)\n\t},\n\n\tbeforeDestroy() {\n\t\t// Unregister the tab from tabs\n\t\tthis.unregisterTab(this.id)\n\t},\n\n\tmethods: {\n\t\tonScroll(event) {\n\t\t\t// Are we scrolled to the very bottom ?\n\t\t\tif (this.$el.scrollHeight - this.$el.scrollTop === this.$el.clientHeight) {\n\t\t\t\t/**\n\t\t\t\t * Bottom scroll is reached\n\t\t\t\t *\n\t\t\t\t * @property {Event} event Native scroll event\n\t\t\t\t */\n\t\t\t\tthis.$emit('bottom-reached', event)\n\t\t\t}\n\t\t\t/**\n\t\t\t * @property {Event} event Native scroll event\n\t\t\t */\n\t\t\tthis.$emit('scroll', event)\n\t\t},\n\n\t\t/**\n\t\t * Render tab's icon slot if any\n\t\t *\n\t\t * @return {import('vue').VNode[]}\n\t\t */\n\t\trenderIcon() {\n\t\t\treturn this.$scopedSlots.icon?.()\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.app-sidebar__tab {\n\tdisplay: none;\n\tpadding: 10px;\n\tmin-height: 100%; // fill available height\n\tmax-height: 100%; // scroll inside\n\theight: 100%;\n\toverflow: auto;\n\n\t&:focus {\n\t\tborder-color: var(--color-primary-element);\n\t\tbox-shadow: 0 0 0.2em var(--color-primary-element);\n\t\toutline: 0;\n\t}\n\n\t&--active {\n\t\tdisplay: block;\n\t}\n}\n</style>\n"],"names":[],"mappings":";;AA2BA,MAAA,YAAA;AAAA,EACA,MAAA;AAAA,EAEA,QAAA,CAAA,eAAA,iBAAA,gBAAA,gBAAA;AAAA,EAEA,OAAA;AAAA,IACA,IAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,OAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,QAAA,CAAA,MAAA,QAAA,QAAA,SAAA,YAAA;AAAA,EAEA,UAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,WAAA;AACA,aAAA,KAAA,mBAAA,KAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,UAAA;AAGA,SAAA,YAAA,IAAA;AAAA,EACA;AAAA,EAEA,gBAAA;AAEA,SAAA,cAAA,KAAA,EAAA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA,IACA,SAAA,OAAA;AAEA,UAAA,KAAA,IAAA,eAAA,KAAA,IAAA,cAAA,KAAA,IAAA,cAAA;AAMA,aAAA,MAAA,kBAAA,KAAA;AAAA,MACA;AAIA,WAAA,MAAA,UAAA,KAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,aAAA;AACA,aAAA,KAAA,aAAA,OAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"NcAppSidebarTab.cjs","sources":["../../src/components/NcAppSidebarTab/NcAppSidebarTab.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<!-- Follows the tab aria guidelines\n\thttps://www.w3.org/TR/wai-aria-practices/examples/tabs/tabs-1/tabs.html -->\n\n<template>\n\t<section :id=\"`tab-${id}`\"\n\t\t:class=\"{'app-sidebar__tab--active': isActive}\"\n\t\t:aria-hidden=\"!isActive\"\n\t\t:aria-label=\"isTablistShown() ? undefined : name\"\n\t\t:aria-labelledby=\"isTablistShown() ? `tab-button-${id}` : undefined\"\n\t\tclass=\"app-sidebar__tab\"\n\t\t:tabindex=\"isTablistShown() ? 0 : -1\"\n\t\t:role=\"isTablistShown() ? 'tabpanel' : undefined\"\n\t\t@scroll=\"onScroll\">\n\t\t<h3 class=\"hidden-visually\">\n\t\t\t{{ name }}\n\t\t</h3>\n\t\t<!-- @slot Tab panel content -->\n\t\t<slot />\n\t</section>\n</template>\n\n<script>\nexport default {\n\tname: 'NcAppSidebarTab',\n\n\tinject: ['registerTab', 'unregisterTab', 'getActiveTab', 'isTablistShown'],\n\n\tprops: {\n\t\tid: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * Tab name in navigation\n\t\t */\n\t\tname: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * Tab icon's html class in navigation. Used if #icon slot is not provided\n\t\t */\n\t\ticon: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Tab order in navigation. If not provided, name is used.\n\t\t */\n\t\torder: {\n\t\t\ttype: Number,\n\t\t\tdefault: 0,\n\t\t},\n\t},\n\n\temits: [\n\t\t'bottom-reached',\n\t\t'scroll',\n\t],\n\n\texpose: ['id', 'name', 'icon', 'order', 'renderIcon'],\n\n\tcomputed: {\n\t\t/**\n\t\t * Is the current tab an active tab, that should be shown?\n\t\t *\n\t\t * @return {boolean}\n\t\t */\n\t\tisActive() {\n\t\t\treturn this.getActiveTab() === this.id\n\t\t},\n\t},\n\n\tcreated() {\n\t\t// As the tab is created - register it in the tabs component\n\t\t// It's better to provide computed tab object, not component instance as it easy\n\t\tthis.registerTab(this)\n\t},\n\n\tbeforeDestroy() {\n\t\t// Unregister the tab from tabs\n\t\tthis.unregisterTab(this.id)\n\t},\n\n\tmethods: {\n\t\tonScroll(event) {\n\t\t\t// Are we scrolled to the very bottom ?\n\t\t\tif (this.$el.scrollHeight - this.$el.scrollTop === this.$el.clientHeight) {\n\t\t\t\t/**\n\t\t\t\t * Bottom scroll is reached\n\t\t\t\t *\n\t\t\t\t * @property {Event} event Native scroll event\n\t\t\t\t */\n\t\t\t\tthis.$emit('bottom-reached', event)\n\t\t\t}\n\t\t\t/**\n\t\t\t * @property {Event} event Native scroll event\n\t\t\t */\n\t\t\tthis.$emit('scroll', event)\n\t\t},\n\n\t\t/**\n\t\t * Render tab's icon slot if any\n\t\t *\n\t\t * @return {import('vue').VNode[]}\n\t\t */\n\t\trenderIcon() {\n\t\t\treturn this.$scopedSlots.icon?.()\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.app-sidebar__tab {\n\tdisplay: none;\n\tpadding: 10px;\n\tmin-height: 100%; // fill available height\n\tmax-height: 100%; // scroll inside\n\theight: 100%;\n\toverflow: auto;\n\n\t&:focus {\n\t\tborder-color: var(--color-primary-element);\n\t\tbox-shadow: 0 0 0.2em var(--color-primary-element);\n\t\toutline: 0;\n\t}\n\n\t&--active {\n\t\tdisplay: block;\n\t}\n}\n</style>\n"],"names":[],"mappings":";;AA2BA,MAAA,YAAA;AAAA,EACA,MAAA;AAAA,EAEA,QAAA,CAAA,eAAA,iBAAA,gBAAA,gBAAA;AAAA,EAEA,OAAA;AAAA,IACA,IAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,OAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,QAAA,CAAA,MAAA,QAAA,QAAA,SAAA,YAAA;AAAA,EAEA,UAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,WAAA;AACA,aAAA,KAAA,aAAA,MAAA,KAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,UAAA;AAGA,SAAA,YAAA,IAAA;AAAA,EACA;AAAA,EAEA,gBAAA;AAEA,SAAA,cAAA,KAAA,EAAA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA,IACA,SAAA,OAAA;AAEA,UAAA,KAAA,IAAA,eAAA,KAAA,IAAA,cAAA,KAAA,IAAA,cAAA;AAMA,aAAA,MAAA,kBAAA,KAAA;AAAA,MACA;AAIA,WAAA,MAAA,UAAA,KAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,aAAA;AACA,aAAA,KAAA,aAAA,OAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;"}
@@ -85,3 +85,4 @@ const NcAppSidebarTab = __component__.exports;
85
85
  export {
86
86
  NcAppSidebarTab as default
87
87
  };
88
+ //# sourceMappingURL=NcAppSidebarTab.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"NcAppSidebarTab.mjs","sources":["../../src/components/NcAppSidebarTab/NcAppSidebarTab.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<!-- Follows the tab aria guidelines\n\thttps://www.w3.org/TR/wai-aria-practices/examples/tabs/tabs-1/tabs.html -->\n\n<template>\n\t<section :id=\"`tab-${id}`\"\n\t\t:class=\"{'app-sidebar__tab--active': isActive}\"\n\t\t:aria-hidden=\"!isActive\"\n\t\t:aria-label=\"isTablistShown() ? undefined : name\"\n\t\t:aria-labelledby=\"isTablistShown() ? `tab-button-${id}` : undefined\"\n\t\tclass=\"app-sidebar__tab\"\n\t\t:tabindex=\"isTablistShown() ? 0 : -1\"\n\t\t:role=\"isTablistShown() ? 'tabpanel' : undefined\"\n\t\t@scroll=\"onScroll\">\n\t\t<h3 class=\"hidden-visually\">\n\t\t\t{{ name }}\n\t\t</h3>\n\t\t<!-- @slot Tab panel content -->\n\t\t<slot />\n\t</section>\n</template>\n\n<script>\nexport default {\n\tname: 'NcAppSidebarTab',\n\n\tinject: ['registerTab', 'unregisterTab', 'getActiveTab', 'isTablistShown'],\n\n\tprops: {\n\t\tid: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * Tab name in navigation\n\t\t */\n\t\tname: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * Tab icon's html class in navigation. Used if #icon slot is not provided\n\t\t */\n\t\ticon: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Tab order in navigation. If not provided, name is used.\n\t\t */\n\t\torder: {\n\t\t\ttype: Number,\n\t\t\tdefault: 0,\n\t\t},\n\t},\n\n\temits: [\n\t\t'bottom-reached',\n\t\t'scroll',\n\t],\n\n\texpose: ['id', 'name', 'icon', 'order', 'renderIcon'],\n\n\tcomputed: {\n\t\t/**\n\t\t * Is the current tab an active tab, that should be shown?\n\t\t *\n\t\t * @return {boolean}\n\t\t */\n\t\tisActive() {\n\t\t\treturn this.getActiveTab() === this.id\n\t\t},\n\t},\n\n\tcreated() {\n\t\t// As the tab is created - register it in the tabs component\n\t\t// It's better to provide computed tab object, not component instance as it easy\n\t\tthis.registerTab(this)\n\t},\n\n\tbeforeDestroy() {\n\t\t// Unregister the tab from tabs\n\t\tthis.unregisterTab(this.id)\n\t},\n\n\tmethods: {\n\t\tonScroll(event) {\n\t\t\t// Are we scrolled to the very bottom ?\n\t\t\tif (this.$el.scrollHeight - this.$el.scrollTop === this.$el.clientHeight) {\n\t\t\t\t/**\n\t\t\t\t * Bottom scroll is reached\n\t\t\t\t *\n\t\t\t\t * @property {Event} event Native scroll event\n\t\t\t\t */\n\t\t\t\tthis.$emit('bottom-reached', event)\n\t\t\t}\n\t\t\t/**\n\t\t\t * @property {Event} event Native scroll event\n\t\t\t */\n\t\t\tthis.$emit('scroll', event)\n\t\t},\n\n\t\t/**\n\t\t * Render tab's icon slot if any\n\t\t *\n\t\t * @return {import('vue').VNode[]}\n\t\t */\n\t\trenderIcon() {\n\t\t\treturn this.$scopedSlots.icon?.()\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.app-sidebar__tab {\n\tdisplay: none;\n\tpadding: 10px;\n\tmin-height: 100%; // fill available height\n\tmax-height: 100%; // scroll inside\n\theight: 100%;\n\toverflow: auto;\n\n\t&:focus {\n\t\tborder-color: var(--color-primary-element);\n\t\tbox-shadow: 0 0 0.2em var(--color-primary-element);\n\t\toutline: 0;\n\t}\n\n\t&--active {\n\t\tdisplay: block;\n\t}\n}\n</style>\n"],"names":[],"mappings":";AA2BA,MAAA,YAAA;AAAA,EACA,MAAA;AAAA,EAEA,QAAA,CAAA,eAAA,iBAAA,gBAAA,gBAAA;AAAA,EAEA,OAAA;AAAA,IACA,IAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,OAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,QAAA,CAAA,MAAA,QAAA,QAAA,SAAA,YAAA;AAAA,EAEA,UAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,WAAA;AACA,aAAA,KAAA,mBAAA,KAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,UAAA;AAGA,SAAA,YAAA,IAAA;AAAA,EACA;AAAA,EAEA,gBAAA;AAEA,SAAA,cAAA,KAAA,EAAA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA,IACA,SAAA,OAAA;AAEA,UAAA,KAAA,IAAA,eAAA,KAAA,IAAA,cAAA,KAAA,IAAA,cAAA;AAMA,aAAA,MAAA,kBAAA,KAAA;AAAA,MACA;AAIA,WAAA,MAAA,UAAA,KAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,aAAA;AACA,aAAA,KAAA,aAAA,OAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"NcAppSidebarTab.mjs","sources":["../../src/components/NcAppSidebarTab/NcAppSidebarTab.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<!-- Follows the tab aria guidelines\n\thttps://www.w3.org/TR/wai-aria-practices/examples/tabs/tabs-1/tabs.html -->\n\n<template>\n\t<section :id=\"`tab-${id}`\"\n\t\t:class=\"{'app-sidebar__tab--active': isActive}\"\n\t\t:aria-hidden=\"!isActive\"\n\t\t:aria-label=\"isTablistShown() ? undefined : name\"\n\t\t:aria-labelledby=\"isTablistShown() ? `tab-button-${id}` : undefined\"\n\t\tclass=\"app-sidebar__tab\"\n\t\t:tabindex=\"isTablistShown() ? 0 : -1\"\n\t\t:role=\"isTablistShown() ? 'tabpanel' : undefined\"\n\t\t@scroll=\"onScroll\">\n\t\t<h3 class=\"hidden-visually\">\n\t\t\t{{ name }}\n\t\t</h3>\n\t\t<!-- @slot Tab panel content -->\n\t\t<slot />\n\t</section>\n</template>\n\n<script>\nexport default {\n\tname: 'NcAppSidebarTab',\n\n\tinject: ['registerTab', 'unregisterTab', 'getActiveTab', 'isTablistShown'],\n\n\tprops: {\n\t\tid: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * Tab name in navigation\n\t\t */\n\t\tname: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * Tab icon's html class in navigation. Used if #icon slot is not provided\n\t\t */\n\t\ticon: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Tab order in navigation. If not provided, name is used.\n\t\t */\n\t\torder: {\n\t\t\ttype: Number,\n\t\t\tdefault: 0,\n\t\t},\n\t},\n\n\temits: [\n\t\t'bottom-reached',\n\t\t'scroll',\n\t],\n\n\texpose: ['id', 'name', 'icon', 'order', 'renderIcon'],\n\n\tcomputed: {\n\t\t/**\n\t\t * Is the current tab an active tab, that should be shown?\n\t\t *\n\t\t * @return {boolean}\n\t\t */\n\t\tisActive() {\n\t\t\treturn this.getActiveTab() === this.id\n\t\t},\n\t},\n\n\tcreated() {\n\t\t// As the tab is created - register it in the tabs component\n\t\t// It's better to provide computed tab object, not component instance as it easy\n\t\tthis.registerTab(this)\n\t},\n\n\tbeforeDestroy() {\n\t\t// Unregister the tab from tabs\n\t\tthis.unregisterTab(this.id)\n\t},\n\n\tmethods: {\n\t\tonScroll(event) {\n\t\t\t// Are we scrolled to the very bottom ?\n\t\t\tif (this.$el.scrollHeight - this.$el.scrollTop === this.$el.clientHeight) {\n\t\t\t\t/**\n\t\t\t\t * Bottom scroll is reached\n\t\t\t\t *\n\t\t\t\t * @property {Event} event Native scroll event\n\t\t\t\t */\n\t\t\t\tthis.$emit('bottom-reached', event)\n\t\t\t}\n\t\t\t/**\n\t\t\t * @property {Event} event Native scroll event\n\t\t\t */\n\t\t\tthis.$emit('scroll', event)\n\t\t},\n\n\t\t/**\n\t\t * Render tab's icon slot if any\n\t\t *\n\t\t * @return {import('vue').VNode[]}\n\t\t */\n\t\trenderIcon() {\n\t\t\treturn this.$scopedSlots.icon?.()\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.app-sidebar__tab {\n\tdisplay: none;\n\tpadding: 10px;\n\tmin-height: 100%; // fill available height\n\tmax-height: 100%; // scroll inside\n\theight: 100%;\n\toverflow: auto;\n\n\t&:focus {\n\t\tborder-color: var(--color-primary-element);\n\t\tbox-shadow: 0 0 0.2em var(--color-primary-element);\n\t\toutline: 0;\n\t}\n\n\t&--active {\n\t\tdisplay: block;\n\t}\n}\n</style>\n"],"names":[],"mappings":";AA2BA,MAAA,YAAA;AAAA,EACA,MAAA;AAAA,EAEA,QAAA,CAAA,eAAA,iBAAA,gBAAA,gBAAA;AAAA,EAEA,OAAA;AAAA,IACA,IAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAKA,OAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA,IACA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,QAAA,CAAA,MAAA,QAAA,QAAA,SAAA,YAAA;AAAA,EAEA,UAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,WAAA;AACA,aAAA,KAAA,aAAA,MAAA,KAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,UAAA;AAGA,SAAA,YAAA,IAAA;AAAA,EACA;AAAA,EAEA,gBAAA;AAEA,SAAA,cAAA,KAAA,EAAA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA,IACA,SAAA,OAAA;AAEA,UAAA,KAAA,IAAA,eAAA,KAAA,IAAA,cAAA,KAAA,IAAA,cAAA;AAMA,aAAA,MAAA,kBAAA,KAAA;AAAA,MACA;AAIA,WAAA,MAAA,UAAA,KAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,aAAA;AACA,aAAA,KAAA,aAAA,OAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;"}
@@ -1,3 +1,4 @@
1
1
  "use strict";
2
- const NcAvatar = require("../chunks/NcAvatar-CQtsmbBW.cjs");
2
+ const NcAvatar = require("../chunks/NcAvatar--JVA_B6Y.cjs");
3
3
  module.exports = NcAvatar.NcAvatar;
4
+ //# sourceMappingURL=NcAvatar.cjs.map
@@ -1,4 +1,5 @@
1
- import { N } from "../chunks/NcAvatar-BjwyJw34.mjs";
1
+ import { N } from "../chunks/NcAvatar-DwORvUjC.mjs";
2
2
  export {
3
3
  N as default
4
4
  };
5
+ //# sourceMappingURL=NcAvatar.mjs.map
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ const NcBlurHash = require("../chunks/NcBlurHash-CJ8retHx.cjs");
3
+ module.exports = NcBlurHash.NcBlurHash;
4
+ //# sourceMappingURL=NcBlurHash.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcBlurHash.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;"}
@@ -0,0 +1,5 @@
1
+ import { N } from "../chunks/NcBlurHash-do2wxY-0.mjs";
2
+ export {
3
+ N as default
4
+ };
5
+ //# sourceMappingURL=NcBlurHash.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcBlurHash.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
@@ -1,3 +1,4 @@
1
1
  "use strict";
2
- const NcBreadcrumb = require("../chunks/NcBreadcrumb-DrlhnNbV.cjs");
2
+ const NcBreadcrumb = require("../chunks/NcBreadcrumb-B0ve-OJl.cjs");
3
3
  module.exports = NcBreadcrumb.NcBreadcrumb;
4
+ //# sourceMappingURL=NcBreadcrumb.cjs.map
@@ -1,4 +1,5 @@
1
- import { N } from "../chunks/NcBreadcrumb-GHiD-Sw7.mjs";
1
+ import { N } from "../chunks/NcBreadcrumb-DPF3ELzz.mjs";
2
2
  export {
3
3
  N as default
4
4
  };
5
+ //# sourceMappingURL=NcBreadcrumb.mjs.map
@@ -1,3 +1,4 @@
1
1
  "use strict";
2
- const NcBreadcrumbs = require("../chunks/NcBreadcrumbs-Cde4tv8l.cjs");
2
+ const NcBreadcrumbs = require("../chunks/NcBreadcrumbs-C_XQLT-h.cjs");
3
3
  module.exports = NcBreadcrumbs.NcBreadcrumbs;
4
+ //# sourceMappingURL=NcBreadcrumbs.cjs.map
@@ -1,4 +1,5 @@
1
- import { N } from "../chunks/NcBreadcrumbs-D0Hhym9A.mjs";
1
+ import { N } from "../chunks/NcBreadcrumbs-CL_IHuT9.mjs";
2
2
  export {
3
3
  N as default
4
4
  };
5
+ //# sourceMappingURL=NcBreadcrumbs.mjs.map
@@ -1,4 +1,4 @@
1
- require('../assets/NcButton-CfOAX-eQ.css');
1
+ require('../assets/NcButton-DnNZaEy_.css');
2
2
  "use strict";
3
3
  const _pluginVue2_normalizer = require("../chunks/_plugin-vue2_normalizer-V0q-tHlQ.cjs");
4
4
  const _sfc_main = {
@@ -39,14 +39,20 @@ const _sfc_main = {
39
39
  }
40
40
  },
41
41
  /**
42
- * Specifies the button type
43
- * Accepted values: primary, secondary, tertiary, tertiary-no-background, tertiary-on-primary, error, warning, success. If left empty,
44
- * the default button style will be applied.
42
+ * Specifies the HTML button type.
43
+ * Accepted values: submit, reset, button.
44
+ *
45
+ * For legacy reasons this can also be used to set the variant of the button (color schema).
46
+ * This is discouraged but the accepted values are:
47
+ * primary, secondary, tertiary, tertiary-no-background, tertiary-on-primary, error, warning, success.
48
+ *
49
+ * @default 'secondary' (will change with v9)
50
+ * @deprecated The behavior will change in v9 to only allow the native HTML button types - use `variant` instead for setting the appearance of the button.
45
51
  */
46
52
  type: {
47
53
  type: String,
48
54
  validator(value) {
49
- return ["primary", "secondary", "tertiary", "tertiary-no-background", "tertiary-on-primary", "error", "warning", "success"].includes(value);
55
+ return ["primary", "secondary", "tertiary", "tertiary-no-background", "tertiary-on-primary", "error", "warning", "success"].includes(value) || ["submit", "reset", "button"].includes(value);
50
56
  },
51
57
  default: "secondary"
52
58
  },
@@ -54,6 +60,8 @@ const _sfc_main = {
54
60
  * Specifies the button native type
55
61
  * Accepted values: submit, reset, button. If left empty,
56
62
  * the default "button" type will be used.
63
+ *
64
+ * @deprecated use `type` instead - will be removed with v9
57
65
  */
58
66
  nativeType: {
59
67
  type: String,
@@ -136,6 +144,21 @@ const _sfc_main = {
136
144
  pressed: {
137
145
  type: Boolean,
138
146
  default: null
147
+ },
148
+ /**
149
+ * Specifies the button variant.
150
+ *
151
+ * Accepted values: primary, secondary, tertiary, tertiary-no-background, tertiary-on-primary, error, warning, success.
152
+ *
153
+ * @default 'secondary'
154
+ * @since 8.24.0
155
+ */
156
+ variant: {
157
+ type: String,
158
+ validator(value) {
159
+ return ["primary", "secondary", "tertiary", "tertiary-no-background", "tertiary-on-primary", "error", "warning", "success"].includes(value);
160
+ },
161
+ default: "secondary"
139
162
  }
140
163
  },
141
164
  emits: ["update:pressed", "click"],
@@ -144,13 +167,31 @@ const _sfc_main = {
144
167
  * The real type to be used for the button, enforces `primary` for pressed state and, if stateful button, any other type for not pressed state
145
168
  * Otherwise the type property is used.
146
169
  */
147
- realType() {
170
+ realVariant() {
148
171
  if (this.pressed) {
149
172
  return "primary";
150
173
  }
151
- if (this.pressed === false && this.type === "primary") {
174
+ if (this.pressed === false && (this.type === "primary" || this.variant === "primary")) {
152
175
  return "secondary";
153
176
  }
177
+ if (this.type !== "secondary" && ["primary", "tertiary", "tertiary-no-background", "tertiary-on-primary", "error", "warning", "success"].includes(this.type)) {
178
+ return this.type;
179
+ }
180
+ return this.variant;
181
+ },
182
+ /**
183
+ * The HTML button type
184
+ */
185
+ realType() {
186
+ if (typeof this.pressed === "boolean") {
187
+ return "button";
188
+ }
189
+ if (this.nativeType !== "button") {
190
+ return this.nativeType;
191
+ }
192
+ if (["primary", "secondary", "tertiary", "tertiary-no-background", "tertiary-on-primary", "error", "warning", "success"].includes(this.type)) {
193
+ return this.nativeType;
194
+ }
154
195
  return this.type;
155
196
  },
156
197
  /**
@@ -200,7 +241,7 @@ const _sfc_main = {
200
241
  "button-vue--icon-only": hasIcon && !hasText,
201
242
  "button-vue--text-only": hasText && !hasIcon,
202
243
  "button-vue--icon-and-text": hasIcon && hasText,
203
- [`button-vue--vue-${this.realType}`]: this.realType,
244
+ [`button-vue--vue-${this.realVariant}`]: this.realVariant,
204
245
  "button-vue--wide": this.wide,
205
246
  [`button-vue--${this.flexAlignment}`]: this.flexAlignment !== "center",
206
247
  "button-vue--reverse": this.isReverseAligned,
@@ -212,7 +253,7 @@ const _sfc_main = {
212
253
  "aria-label": this.ariaLabel,
213
254
  "aria-pressed": hasPressed ? this.pressed.toString() : void 0,
214
255
  disabled: this.disabled,
215
- type: isLink ? null : this.nativeType,
256
+ type: isLink ? null : this.realType,
216
257
  role: isLink ? "button" : null,
217
258
  href: this.to ? href : this.href || null,
218
259
  target: isLink ? this.target || "_self" : null,
@@ -273,7 +314,8 @@ var __component__ = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
273
314
  _sfc_staticRenderFns,
274
315
  false,
275
316
  null,
276
- "b2be1481"
317
+ "3f8e123a"
277
318
  );
278
319
  const NcButton = __component__.exports;
279
320
  module.exports = NcButton;
321
+ //# sourceMappingURL=NcButton.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"NcButton.cjs","sources":["../../src/components/NcButton/NcButton.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n\n### General description\nGeneral purpose button component. See props for different options.\n[Use material design icons only for icons](https://www.npmjs.com/package/vue-material-design-icons) and remember to set their size to 20.\n\n### Usage\n### Custom icon slot\nTo be used with `vue-material-design-icons` only. For icon classes use the `default-icon` slot.\nIt can be used with one or multiple actions.\n```\n<template>\n<div class=\"wrapper\">\n\t<!-- Style selector -->\n\t<div class=\"grid\">\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"style\" value=\"text\" name=\"style\" type=\"radio\">Text only</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"style\" value=\"icon\" name=\"style\" type=\"radio\">Icon only</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"style\" value=\"icontext\" name=\"style\" type=\"radio\">Icon and text</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"disabled\" type=\"checkbox\">Disabled</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"size\" value=\"small\" name=\"size\" type=\"radio\">Small</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"size\" value=\"normal\" name=\"size\" type=\"radio\">Normal (default)</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"size\" value=\"large\" name=\"size\" type=\"radio\">Large</NcCheckboxRadioSwitch>\n\t</div>\n\n\t<h5>Standard buttons</h5>\n\t<div class=\"grid\">\n\t\t<p>Tertiary, no background</p>\n\t\t<p>Tertiary</p>\n\t\t<p>Secondary</p>\n\t\t<p>Primary</p>\n\t\t<NcButton\n\t\t\taria-label=\"Example text\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\ttype=\"tertiary-no-background\">\n\t\t\t<template v-if=\"style.indexOf('icon') !== -1\" #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\t<template v-if=\"style.indexOf('text') !== -1\">Example text</template>\n\t\t</NcButton>\n\t\t<NcButton\n\t\t\taria-label=\"Example text\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\ttype=\"tertiary\">\n\t\t\t<template v-if=\"style.indexOf('icon') !== -1\" #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\t<template v-if=\"style.indexOf('text') !== -1\">Example text</template>\n\t\t</NcButton>\n\t\t<NcButton\n\t\t\taria-label=\"Example text\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\">\n\t\t\t<template v-if=\"style.indexOf('icon') !== -1\" #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\t<template v-if=\"style.indexOf('text') !== -1\">Example text</template>\n\t\t</NcButton>\n\t\t<NcButton\n\t\t\taria-label=\"Example text\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\ttype=\"primary\">\n\t\t\t<template v-if=\"style.indexOf('icon') !== -1\" #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\t<template v-if=\"style.indexOf('text') !== -1\">Example text</template>\n\t\t</NcButton>\n\t</div>\n\n\t<!-- Wide button -->\n\t<h5>Wide button</h5>\n\t<NcButton\n\t\t:disabled=\"disabled\"\n\t\t:size=\"size\"\n\t\t:wide=\"true\"\n\t\ttext=\"Example text\">\n\t\t<template #icon>\n\t\t\t<Video\n\t\t\t\t:size=\"20\" />\n\t\t</template>\n\t\tExample text\n\t</NcButton>\n\n\t<!-- Special buttons -->\n\t<h5>Special buttons</h5>\n\t<div class=\"grid\">\n\t\t<p>Success</p>\n\t\t<p>Warning</p>\n\t\t<p>Error</p>\n\t\t<p> - </p>\n\t\t<NcButton\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\ttype=\"success\">\n\t\t\t<template #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\tExample text\n\t\t</NcButton>\n\t\t<NcButton\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\ttype=\"warning\">\n\t\t\t<template #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\tExample text\n\t\t</NcButton>\n\t\t<NcButton\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\ttype=\"error\">\n\t\t\t<template #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\tExample text\n\t\t</NcButton>\n\t\t<p> - </p>\n\t</div>\n</div>\n\n</template>\n<script>\nimport Video from 'vue-material-design-icons/Video.vue'\n\nexport default {\n\tcomponents: {\n\t\tVideo,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\ttoggled: false,\n\t\t\tdisabled: false,\n\t\t\tsize: 'normal',\n\t\t\tstyle: 'icontext',\n\t\t}\n\t}\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.wrapper {\n\tpadding: 0 12px;\n}\n\n.grid {\n\tdisplay: grid;\n\tgap: 12px;\n\tgrid-template-columns: 1fr 1fr 1fr 1fr;\n\tgrid-template-rows: repeat(auto-fill, auto);\n\tposition: relative;\n\tmargin: 12px 0;\n}\n\nh5 {\n\tfont-weight: bold;\n\tmargin: 40px 0 20px 0;\n}\n\np {\n\ttext-align: center;\n\tmargin: 4px 0 12px 0;\n\tcolor: var(--color-text-maxcontrast)\n}\n\nbutton {\n\tmargin: auto;\n}\n</style>\n```\n\n### Alignment\nSometimes it is required to change the icon alignment on the button, like for switching between pages as in following example:\n\n```vue\n<template>\n\t<div style=\"display: flex; flex-direction: column; gap: 12px;\">\n\t\t<NcButton aria-label=\"center (default)\" type=\"secondary\" wide>\n\t\t\t<template #icon>\n\t\t\t\t<IconLeft :size=\"20\" />\n\t\t\t</template>\n\t\t\tcenter (default)\n\t\t</NcButton>\n\t\t<NcButton alignment=\"center-reverse\" aria-label=\"center-reverse\" type=\"secondary\" wide>\n\t\t\t<template #icon>\n\t\t\t\t<IconRight :size=\"20\" />\n\t\t\t</template>\n\t\t\tcenter-reverse\n\t\t</NcButton>\n\t\t<div style=\"display: flex; gap: 12px;\">\n\t\t\t<div style=\"display: flex; flex-direction: column; gap: 12px; flex: 1\">\n\t\t\t\t<NcButton alignment=\"start\" aria-label=\"start\" type=\"secondary\" wide>\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<IconLeft :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t\tstart\n\t\t\t\t</NcButton>\n\t\t\t\t<NcButton alignment=\"start-reverse\" aria-label=\"start-reverse\" type=\"secondary\" wide>\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<IconRight :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t\tstart-reverse\n\t\t\t\t</NcButton>\n\t\t\t</div>\n\t\t\t<div style=\"display: flex; flex-direction: column; gap: 12px; flex: 1\">\n\t\t\t\t<NcButton alignment=\"end\" aria-label=\"end\" type=\"secondary\" wide>\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<IconLeft :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t\tend\n\t\t\t\t</NcButton>\n\t\t\t\t<NcButton alignment=\"end-reverse\" aria-label=\"end-reverse\" type=\"secondary\" wide>\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<IconRight :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t\tend-reverse\n\t\t\t\t</NcButton>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</template>\n<script>\nimport IconLeft from 'vue-material-design-icons/ArrowLeft.vue'\nimport IconRight from 'vue-material-design-icons/ArrowRight.vue'\n\nexport default {\n\tcomponents: {\n\t\tIconLeft,\n\t\tIconRight,\n\t},\n}\n</script>\n```\n\n### Pressed state\n\nIt is possible to make the button stateful by adding a pressed state, e.g. if you like to create a favorite button.\nThe button will have the required `aria` attribute for accessibility and visual style (`primary` when pressed, and the configured type otherwise).\n\nDo not change `text` or `aria-label` of the pressed/unpressed button. See: https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-pressed\n\n```vue\n<template>\n\t<div>\n\t\t<div style=\"display: flex; gap: 12px;\">\n\t\t\t<NcButton :pressed.sync=\"isFavorite\" aria-label=\"Favorite\" type=\"tertiary-no-background\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<IconStar v-if=\"isFavorite\" :size=\"20\" />\n\t\t\t\t\t<IconStarOutline v-else :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t</NcButton>\n\n\t\t\t<NcButton :pressed.sync=\"isFavorite\" type=\"tertiary\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<IconStar v-if=\"isFavorite\" :size=\"20\" />\n\t\t\t\t\t<IconStarOutline v-else :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tFavorite\n\t\t\t</NcButton>\n\n\t\t\t<NcButton :pressed.sync=\"isFavorite\" aria-label=\"Favorite\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<IconStar v-if=\"isFavorite\" :size=\"20\" />\n\t\t\t\t\t<IconStarOutline v-else :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t</NcButton>\n\t\t</div>\n\t\t<div>\n\t\t\tIt is {{ isFavorite ? 'a' : 'not a' }} favorite.\n\t\t</div>\n\t</div>\n</template>\n<script>\nimport IconStar from 'vue-material-design-icons/Star.vue'\nimport IconStarOutline from 'vue-material-design-icons/StarOutline.vue'\n\nexport default {\n\tcomponents: {\n\t\tIconStar,\n\t\tIconStarOutline,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tisFavorite: false,\n\t\t}\n\t},\n\tmethods: {\n\t\ttoggleFavorite() {\n\t\t\tthis.isFavorite = !this.isFavorite\n\t\t},\n\t},\n}\n</script>\n```\n\n### Usage example: Sorting table columns\nThe standard way to implement sortable table column headers should be like this:\n\n```vue\n<template>\n\t<table>\n\t\t<thead>\n\t\t\t<tr>\n\t\t\t\t<th :aria-sorted=\"sortedName\" class=\"row-name\">\n\t\t\t\t\t<NcButton alignment=\"start-reverse\"\n\t\t\t\t\t\t:wide=\"true\"\n\t\t\t\t\t\ttype=\"tertiary\"\n\t\t\t\t\t\t@click=\"sortName\">\n\t\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t\t<IconDown v-if=\"sortedName === 'ascending'\" class=\"sort-icon\" :size=\"20\" />\n\t\t\t\t\t\t\t<IconUp v-else-if=\"sortedName === 'descending'\" class=\"sort-icon\" :size=\"20\" />\n\t\t\t\t\t\t</template>\n\t\t\t\t\t\t<span class=\"table-header\">Name</span>\n\t\t\t\t\t</NcButton>\n\t\t\t\t</th>\n\t\t\t\t<th :aria-sorted=\"sortedSize\" class=\"row-size\">\n\t\t\t\t\t<NcButton alignment=\"end\"\n\t\t\t\t\t\t:wide=\"true\"\n\t\t\t\t\t\ttype=\"tertiary\"\n\t\t\t\t\t\t@click=\"sortSize\">\n\t\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t\t<IconDown v-if=\"sortedSize === 'ascending'\" class=\"sort-icon\" :size=\"20\" />\n\t\t\t\t\t\t\t<IconUp v-else-if=\"sortedSize === 'descending'\" class=\"sort-icon\" :size=\"20\" />\n\t\t\t\t\t\t</template>\n\t\t\t\t\t\t<span class=\"table-header\">Size</span>\n\t\t\t\t\t</NcButton>\n\t\t\t\t</th>\n\t\t\t</tr>\n\t\t</thead>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t<td class=\"row-name\">Lorem ipsum</td>\n\t\t\t\t<td class=\"row-size\">8 MiB</td>\n\t\t\t</tr>\n\t\t</tbody>\n\t</table>\n</template>\n<script>\nimport IconUp from 'vue-material-design-icons/MenuUp.vue'\nimport IconDown from 'vue-material-design-icons/MenuDown.vue'\n\nexport default {\n\tcomponents: {\n\t\tIconUp,\n\t\tIconDown,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tsortedName: null,\n\t\t\tsortedSize: null,\n\t\t}\n\t},\n\tmethods: {\n\t\tsortName() {\n\t\t\tif (this.sortedName === 'ascending') {\n\t\t\t\tthis.sortedName = 'descending'\n\t\t\t} else if (this.sortedName === 'descending') {\n\t\t\t\tthis.sortedName = null\n\t\t\t} else {\n\t\t\t\tthis.sortedName = 'ascending'\n\t\t\t}\n\t\t},\n\t\tsortSize() {\n\t\t\tif (this.sortedSize === 'ascending') {\n\t\t\t\tthis.sortedSize = 'descending'\n\t\t\t} else if (this.sortedSize === 'descending') {\n\t\t\t\tthis.sortedSize = null\n\t\t\t} else {\n\t\t\t\tthis.sortedSize = 'ascending'\n\t\t\t}\n\t\t},\n\t},\n}\n</script>\n<style>\ntable {\n\ttable-layout: fixed;\n\twidth: 300px;\n}\n\ntd.row-name {\n\tpadding-inline-start: 16px;\n}\n\ntd.row-size {\n\ttext-align: end;\n\tpadding-inline-end: 16px;\n}\n\n.table-header {\n\tfont-weight: normal;\n\tcolor: var(--color-text-maxcontrast);\n}\n\n.sort-icon {\n\tcolor: var(--color-text-maxcontrast);\n\tposition: relative;\n\tinset-inline: -10px;\n}\n\n.row-size .sort-icon {\n\tinset-inline: 10px;\n}\n</style>\n```\n\n</docs>\n\n<script>\n\nexport default {\n\tname: 'NcButton',\n\n\tinject: {\n\t\tgetNcPopoverTriggerAttrs: {\n\t\t\tfrom: 'NcPopover:trigger:attrs',\n\t\t\tdefault: () => () => ({}),\n\t\t},\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Set the text and icon alignment\n\t\t *\n\t\t * @default 'center'\n\t\t */\n\t\talignment: {\n\t\t\ttype: String,\n\t\t\tdefault: 'center',\n\t\t\tvalidator: (alignment) => ['start', 'start-reverse', 'center', 'center-reverse', 'end', 'end-reverse'].includes(alignment),\n\t\t},\n\n\t\t/**\n\t\t * Toggles the disabled state of the button on and off.\n\t\t */\n\t\tdisabled: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Specify the button size\n\t\t * Accepted values: `'small'`, `'normal'` (default), `'large'`\n\t\t */\n\t\tsize: {\n\t\t\ttype: String,\n\t\t\tdefault: 'normal',\n\t\t\tvalidator(value) {\n\t\t\t\treturn ['small', 'normal', 'large'].includes(value)\n\t\t\t},\n\t\t},\n\n\t\t/**\n\t\t * Specifies the button type\n\t\t * Accepted values: primary, secondary, tertiary, tertiary-no-background, tertiary-on-primary, error, warning, success. If left empty,\n\t\t * the default button style will be applied.\n\t\t */\n\t\ttype: {\n\t\t\ttype: String,\n\t\t\tvalidator(value) {\n\t\t\t\treturn ['primary', 'secondary', 'tertiary', 'tertiary-no-background', 'tertiary-on-primary', 'error', 'warning', 'success'].includes(value)\n\t\t\t},\n\t\t\tdefault: 'secondary',\n\t\t},\n\n\t\t/**\n\t\t * Specifies the button native type\n\t\t * Accepted values: submit, reset, button. If left empty,\n\t\t * the default \"button\" type will be used.\n\t\t */\n\t\tnativeType: {\n\t\t\ttype: String,\n\t\t\tvalidator(value) {\n\t\t\t\treturn ['submit', 'reset', 'button'].indexOf(value) !== -1\n\t\t\t},\n\t\t\tdefault: 'button',\n\t\t},\n\n\t\t/**\n\t\t * Specifies whether the button should span all the available width.\n\t\t * By default, buttons span the whole width of the container.\n\t\t */\n\t\twide: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Always try to provide an aria-label to your button. Make it more\n\t\t * specific than the button's name by provide some more context. E.g. if\n\t\t * the name of the button is \"send\" in the Mail app, the aria label could\n\t\t * be \"Send email\".\n\t\t */\n\t\tariaLabel: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Providing the href attribute turns the button component into an `a`\n\t\t * element.\n\t\t */\n\t\thref: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Target for the `a` element if `href` is set.\n\t\t */\n\t\ttarget: {\n\t\t\ttype: String,\n\t\t\tdefault: '_self',\n\t\t},\n\n\t\t/**\n\t\t * Providing the download attribute with href downloads file when clicking.\n\t\t */\n\t\tdownload: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Providing the to attribute turns the button component into a `router-link`\n\t\t * element. Takes precedence over the href attribute.\n\t\t */\n\t\tto: {\n\t\t\ttype: [String, Object],\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Pass in `true` if you want the matching behaviour of `router-link` to\n\t\t * be non-inclusive: https://router.vuejs.org/api/#exact\n\t\t */\n\t\texact: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t\t/**\n\t\t * @deprecated To be removed in @nextcloud/vue 9. Migration guide: remove ariaHidden prop from NcAction* components.\n\t\t * @todo Add a check in @nextcloud/vue 9 that this prop is not provided,\n\t\t * otherwise root element will inherit incorrect aria-hidden.\n\t\t */\n\t\tariaHidden: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * The pressed state of the button if it has a checked state\n\t\t * This will add the `aria-pressed` attribute and for the button to have the primary style in checked state.\n\t\t *\n\t\t * Pressed state is not supported for links\n\t\t */\n\t\tpressed: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: null,\n\t\t},\n\t},\n\n\temits: ['update:pressed', 'click'],\n\n\tcomputed: {\n\t\t/**\n\t\t * The real type to be used for the button, enforces `primary` for pressed state and, if stateful button, any other type for not pressed state\n\t\t * Otherwise the type property is used.\n\t\t */\n\t\trealType() {\n\t\t\t// Force *primary* when pressed\n\t\t\tif (this.pressed) {\n\t\t\t\treturn 'primary'\n\t\t\t}\n\t\t\t// If not pressed but button is configured as stateful button then the type must not be primary\n\t\t\tif (this.pressed === false && this.type === 'primary') {\n\t\t\t\treturn 'secondary'\n\t\t\t}\n\t\t\treturn this.type\n\t\t},\n\n\t\t/**\n\t\t * The flexbox alignment of the button content\n\t\t */\n\t\tflexAlignment() {\n\t\t\treturn this.alignment.split('-')[0]\n\t\t},\n\n\t\t/**\n\t\t * If the button content should be reversed (icon on the end)\n\t\t */\n\t\tisReverseAligned() {\n\t\t\treturn this.alignment.includes('-')\n\t\t},\n\n\t\tncPopoverTriggerAttrs() {\n\t\t\treturn this.getNcPopoverTriggerAttrs()\n\t\t},\n\t},\n\n\t/**\n\t * The render function to display the component\n\t *\n\t * @param {Function} h The function to create VNodes\n\t * @return {object|undefined} The created VNode\n\t */\n\trender(h) {\n\t\tconst hasText = !!this.$slots.default\n\t\tconst hasIcon = this.$slots?.icon\n\n\t\t/**\n\t\t * Always fill either the text prop or the ariaLabel one.\n\t\t */\n\t\tif (!hasText && !this.ariaLabel) {\n\t\t\tconsole.warn('You need to fill either the text or the ariaLabel props in the button component.', {\n\t\t\t\ttext: this.$slots.default?.[0]?.text,\n\t\t\t\tariaLabel: this.ariaLabel,\n\t\t\t},\n\t\t\tthis)\n\t\t}\n\n\t\tconst isLink = (this.to || this.href)\n\n\t\tconst hasPressed = !isLink && typeof this.pressed === 'boolean'\n\n\t\tconst renderButton = ({ href, navigate, isActive, isExactActive } = {}) => h(isLink ? 'a' : 'button',\n\t\t\t{\n\t\t\t\tclass: [\n\t\t\t\t\t'button-vue',\n\t\t\t\t\t`button-vue--size-${this.size}`,\n\t\t\t\t\t{\n\t\t\t\t\t\t'button-vue--icon-only': hasIcon && !hasText,\n\t\t\t\t\t\t'button-vue--text-only': hasText && !hasIcon,\n\t\t\t\t\t\t'button-vue--icon-and-text': hasIcon && hasText,\n\t\t\t\t\t\t[`button-vue--vue-${this.realType}`]: this.realType,\n\t\t\t\t\t\t'button-vue--wide': this.wide,\n\t\t\t\t\t\t[`button-vue--${this.flexAlignment}`]: this.flexAlignment !== 'center',\n\t\t\t\t\t\t'button-vue--reverse': this.isReverseAligned,\n\t\t\t\t\t\tactive: isActive,\n\t\t\t\t\t\t'router-link-exact-active': isExactActive,\n\t\t\t\t\t},\n\t\t\t\t],\n\t\t\t\tattrs: {\n\t\t\t\t\t'aria-label': this.ariaLabel,\n\t\t\t\t\t'aria-pressed': hasPressed ? this.pressed.toString() : undefined,\n\t\t\t\t\tdisabled: this.disabled,\n\t\t\t\t\ttype: isLink ? null : this.nativeType,\n\t\t\t\t\trole: isLink ? 'button' : null,\n\t\t\t\t\thref: this.to ? href : (this.href || null),\n\t\t\t\t\ttarget: isLink ? (this.target || '_self') : null,\n\t\t\t\t\trel: isLink ? 'nofollow noreferrer noopener' : null,\n\t\t\t\t\tdownload: (!this.to && this.href && this.download) ? this.download : null,\n\t\t\t\t\t// If this button is used as a popover trigger, we need to apply trigger attrs, e.g. aria attributes\n\t\t\t\t\t...this.ncPopoverTriggerAttrs,\n\t\t\t\t\t// Inherit all the component attrs\n\t\t\t\t\t...this.$attrs,\n\t\t\t\t},\n\t\t\t\ton: {\n\t\t\t\t\t...this.$listeners,\n\t\t\t\t\tclick: ($event) => {\n\t\t\t\t\t\tif (hasPressed) {\n\t\t\t\t\t\t\t/**\n\t\t\t\t\t\t\t * Update the current pressed state of the button (if the `pressed` property was configured)\n\t\t\t\t\t\t\t *\n\t\t\t\t\t\t\t * @property {boolean} newValue The new `pressed`-state\n\t\t\t\t\t\t\t */\n\t\t\t\t\t\t\tthis.$emit('update:pressed', !this.pressed)\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// We have to both navigate and emit the click event\n\t\t\t\t\t\tthis.$emit('click', $event)\n\t\t\t\t\t\tnavigate?.($event)\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t},\n\t\t\t[\n\t\t\t\th('span', { class: 'button-vue__wrapper' }, [\n\t\t\t\t\thasIcon\n\t\t\t\t\t\t? h('span', {\n\t\t\t\t\t\t\tclass: 'button-vue__icon',\n\t\t\t\t\t\t\tattrs: {\n\t\t\t\t\t\t\t\t'aria-hidden': 'true',\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t[this.$slots.icon],\n\t\t\t\t\t\t)\n\t\t\t\t\t\t: null,\n\t\t\t\t\thasText ? h('span', { class: 'button-vue__text' }, [this.$slots.default]) : null,\n\t\t\t\t]),\n\t\t\t],\n\t\t)\n\n\t\t// If we have a router-link, we wrap the button in it\n\t\tif (this.to) {\n\t\t\treturn h('router-link', {\n\t\t\t\tprops: {\n\t\t\t\t\tcustom: true,\n\t\t\t\t\tto: this.to,\n\t\t\t\t\texact: this.exact,\n\t\t\t\t},\n\t\t\t\tscopedSlots: {\n\t\t\t\t\tdefault: renderButton,\n\t\t\t\t},\n\t\t\t})\n\t\t}\n\t\t// Otherwise we simply return the button\n\t\treturn renderButton()\n\t},\n}\n\n</script>\n\n<style lang=\"scss\" scoped>\n.button-vue {\n\t// Setup different button sizes\n\t--button-size: var(--default-clickable-area);\n\t--button-radius: var(--border-radius-element, calc(var(--button-size) / 2));\n\t--button-padding: clamp(var(--default-grid-baseline), var(--button-radius), calc(var(--default-grid-baseline) * 4));\n\n\t&--size-small {\n\t\t--button-size: var(--clickable-area-small, 24px);\n\t\t--button-radius: var(--border-radius); // make the border radius even smaller for small buttons\n\t}\n\n\t&--size-large {\n\t\t--button-size: var(--clickable-area-large, 48px);\n\t}\n\n\t// General styles\n\tposition: relative;\n\twidth: fit-content;\n\toverflow: hidden;\n\tborder: 0;\n\tpadding: 0;\n\tfont-size: var(--default-font-size);\n\tfont-weight: bold;\n\tmin-height: var(--button-size);\n\tmin-width: var(--button-size);\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\t// Cursor pointer on element and all children\n\tcursor: pointer;\n\t& *,\n\tspan {\n\t\tcursor: pointer;\n\t}\n\tborder-radius: var(--button-radius);\n\ttransition-property: color, border-color, background-color;\n\ttransition-duration: 0.1s;\n\ttransition-timing-function: linear;\n\n\t// No outline feedback for focus. Handled with a toggled class in js (see data)\n\t&:focus {\n\t\toutline: none;\n\t}\n\n\t&:disabled {\n\t\tcursor: default;\n\t\t& * {\n\t\t\tcursor: default;\n\t\t}\n\t\topacity: $opacity_disabled;\n\t\t// Gives a wash out effect\n\t\tfilter: saturate($opacity_normal);\n\t}\n\n\t// Default button type\n\tcolor: var(--color-primary-element-light-text);\n\tbackground-color: var(--color-primary-element-light);\n\t&:hover:not(:disabled) {\n\t\tbackground-color: var(--color-primary-element-light-hover);\n\t}\n\n\t// Back to the default color for this button when active\n\t// TODO: add ripple effect\n\t&:active {\n\t\tbackground-color: var(--color-primary-element-light);\n\t}\n\n\t&__wrapper {\n\t\tdisplay: inline-flex;\n\t\talign-items: center;\n\t\tjustify-content: center;\n\t\twidth: 100%;\n\t}\n\n\t&--end &__wrapper {\n\t\tjustify-content: end;\n\t}\n\t&--start &__wrapper {\n\t\tjustify-content: start;\n\t}\n\t&--reverse &__wrapper {\n\t\tflex-direction: row-reverse;\n\t}\n\n\t&--reverse#{&}--icon-and-text {\n\t\tpadding-inline: var(--button-padding) var(--default-grid-baseline);\n\t}\n\n\t&__icon {\n\t\theight: var(--button-size);\n\t\twidth: var(--button-size);\n\t\tmin-height: var(--button-size);\n\t\tmin-width: var(--button-size);\n\t\tdisplay: flex;\n\t\tjustify-content: center;\n\t\talign-items: center;\n\t}\n\t// For small buttons we need to adjust the icon size\n\t&--size-small &__icon {\n\t\t:deep(> *) {\n\t\t\tmax-height: 16px;\n\t\t\tmax-width: 16px;\n\t\t}\n\t\t:deep(svg) {\n\t\t\theight: 16px;\n\t\t\twidth: 16px;\n\t\t}\n\t}\n\n\t&__text {\n\t\tfont-weight: bold;\n\t\tmargin-bottom: 1px;\n\t\tpadding: 2px 0;\n\t\twhite-space: nowrap;\n\t\ttext-overflow: ellipsis;\n\t\toverflow: hidden;\n\t}\n\n\t// Icon-only button\n\t&--icon-only {\n\t\tline-height: 1;\n\t\twidth: var(--button-size) !important;\n\t}\n\n\t// Text-only button\n\t&--text-only {\n\t\tpadding: 0 var(--button-padding);\n\t\t& .button-vue__text {\n\t\t\tmargin-left: 4px;\n\t\t\tmargin-right: 4px;\n\t\t}\n\t}\n\n\t// Icon and text button\n\t&--icon-and-text {\n\t\t// icon and text means the icon adds \"visual\" padding thus we need to adjust the text padding\n\t\t--button-padding: min(calc(var(--default-grid-baseline) + var(--button-radius)), calc(var(--default-grid-baseline) * 4));\n\t\t// Adjust padding as the icon already got some padding we need to reduce the padding on the icon side and only add larger padding to the text side\n\t\tpadding-block: 0;\n\t\tpadding-inline: var(--default-grid-baseline) var(--button-padding);\n\t}\n\n\t// Wide button spans the whole width of the container\n\t&--wide {\n\t\twidth: 100%;\n\t}\n\n\t&:focus-visible {\n\t\toutline: 2px solid var(--color-main-text) !important;\n\t\tbox-shadow: 0 0 0 4px var(--color-main-background) !important;\n\t\t&.button-vue--vue-tertiary-on-primary {\n\t\t\toutline: 2px solid var(--color-primary-element-text);\n\t\t\tborder-radius: var(--border-radius-element, var(--border-radius));\n\t\t\tbackground-color: transparent;\n\t\t}\n\t}\n\n\t// Button types\n\n\t// Primary\n\t&--vue-primary {\n\t\tbackground-color: var(--color-primary-element);\n\t\tcolor: var(--color-primary-element-text);\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: var(--color-primary-element-hover);\n\t\t}\n\t\t// Back to the default color for this button when active\n\t\t// TODO: add ripple effect\n\t\t&:active {\n\t\t\tbackground-color: var(--color-primary-element);\n\t\t}\n\t}\n\n\t// Secondary\n\t&--vue-secondary {\n\t\tcolor: var(--color-primary-element-light-text);\n\t\tbackground-color: var(--color-primary-element-light);\n\t\t&:hover:not(:disabled) {\n\t\t\tcolor: var(--color-primary-element-light-text);\n\t\t\tbackground-color: var(--color-primary-element-light-hover);\n\t\t}\n\t}\n\n\t// Tertiary\n\t&--vue-tertiary {\n\t\tcolor: var(--color-main-text);\n\t\tbackground-color: transparent;\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\t}\n\n\t// Tertiary, no background\n\t&--vue-tertiary-no-background {\n\t\tcolor: var(--color-main-text);\n\t\tbackground-color: transparent;\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: transparent;\n\t\t}\n\t}\n\n\t// Tertiary on primary color (like the header)\n\t&--vue-tertiary-on-primary {\n\t\tcolor: var(--color-primary-element-text);\n\t\tbackground-color: transparent;\n\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: transparent;\n\t\t}\n\t}\n\n\t// Success\n\t&--vue-success {\n\t\tbackground-color: var(--color-success);\n\t\tcolor: white;\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: var(--color-success-hover);\n\t\t}\n\t\t// Back to the default color for this button when active\n\t\t// : add ripple effect\n\t\t&:active {\n\t\t\tbackground-color: var(--color-success);\n\t\t}\n\t}\n\n\t// Warning\n\t&--vue-warning {\n\t\tbackground-color: var(--color-warning);\n\t\tcolor: white;\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: var(--color-warning-hover);\n\t\t}\n\t\t// Back to the default color for this button when active\n\t\t// TODO: add ripple effect\n\t\t&:active {\n\t\t\tbackground-color: var(--color-warning);\n\t\t}\n\t}\n\n\t// Error\n\t&--vue-error {\n\t\tbackground-color: var(--color-error);\n\t\tcolor: white;\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: var(--color-error-hover);\n\t\t}\n\t\t// Back to the default color for this button when active\n\t\t// TODO: add ripple effect\n\t\t&:active {\n\t\t\tbackground-color: var(--color-error);\n\t\t}\n\t}\n}\n\n</style>\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"NcButton.cjs","sources":["../../src/components/NcButton/NcButton.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n\n### General description\nGeneral purpose button component. See props for different options.\n[Use material design icons only for icons](https://www.npmjs.com/package/vue-material-design-icons) and remember to set their size to 20.\n\n### Usage\n### Custom icon slot\nTo be used with `vue-material-design-icons` only. For icon classes use the `default-icon` slot.\nIt can be used with one or multiple actions.\n```\n<template>\n<div class=\"wrapper\">\n\t<!-- Style selector -->\n\t<div class=\"grid\">\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"style\" value=\"text\" name=\"style\" type=\"radio\">Text only</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"style\" value=\"icon\" name=\"style\" type=\"radio\">Icon only</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"style\" value=\"icontext\" name=\"style\" type=\"radio\">Icon and text</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"disabled\" type=\"checkbox\">Disabled</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"size\" value=\"small\" name=\"size\" type=\"radio\">Small</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"size\" value=\"normal\" name=\"size\" type=\"radio\">Normal (default)</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"size\" value=\"large\" name=\"size\" type=\"radio\">Large</NcCheckboxRadioSwitch>\n\t</div>\n\n\t<h5>Standard buttons</h5>\n\t<div class=\"grid\">\n\t\t<p>Tertiary, no background</p>\n\t\t<p>Tertiary</p>\n\t\t<p>Secondary</p>\n\t\t<p>Primary</p>\n\t\t<NcButton\n\t\t\taria-label=\"Example text\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\tvariant=\"tertiary-no-background\">\n\t\t\t<template v-if=\"style.indexOf('icon') !== -1\" #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\t<template v-if=\"style.indexOf('text') !== -1\">Example text</template>\n\t\t</NcButton>\n\t\t<NcButton\n\t\t\taria-label=\"Example text\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\tvariant=\"tertiary\">\n\t\t\t<template v-if=\"style.indexOf('icon') !== -1\" #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\t<template v-if=\"style.indexOf('text') !== -1\">Example text</template>\n\t\t</NcButton>\n\t\t<NcButton\n\t\t\taria-label=\"Example text\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\">\n\t\t\t<template v-if=\"style.indexOf('icon') !== -1\" #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\t<template v-if=\"style.indexOf('text') !== -1\">Example text</template>\n\t\t</NcButton>\n\t\t<NcButton\n\t\t\taria-label=\"Example text\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\tvariant=\"primary\">\n\t\t\t<template v-if=\"style.indexOf('icon') !== -1\" #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\t<template v-if=\"style.indexOf('text') !== -1\">Example text</template>\n\t\t</NcButton>\n\t</div>\n\n\t<!-- Wide button -->\n\t<h5>Wide button</h5>\n\t<NcButton\n\t\t:disabled=\"disabled\"\n\t\t:size=\"size\"\n\t\t:wide=\"true\"\n\t\ttext=\"Example text\">\n\t\t<template #icon>\n\t\t\t<Video\n\t\t\t\t:size=\"20\" />\n\t\t</template>\n\t\tExample text\n\t</NcButton>\n\n\t<!-- Special buttons -->\n\t<h5>Special buttons</h5>\n\t<div class=\"grid\">\n\t\t<p>Success</p>\n\t\t<p>Warning</p>\n\t\t<p>Error</p>\n\t\t<p> - </p>\n\t\t<NcButton\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\tvariant=\"success\">\n\t\t\t<template #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\tExample text\n\t\t</NcButton>\n\t\t<NcButton\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\tvariant=\"warning\">\n\t\t\t<template #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\tExample text\n\t\t</NcButton>\n\t\t<NcButton\n\t\t\t:disabled=\"disabled\"\n\t\t\t:size=\"size\"\n\t\t\tvariant=\"error\">\n\t\t\t<template #icon>\n\t\t\t\t<Video\n\t\t\t\t\t:size=\"20\" />\n\t\t\t</template>\n\t\t\tExample text\n\t\t</NcButton>\n\t\t<p> - </p>\n\t</div>\n</div>\n\n</template>\n<script>\nimport Video from 'vue-material-design-icons/Video.vue'\n\nexport default {\n\tcomponents: {\n\t\tVideo,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\ttoggled: false,\n\t\t\tdisabled: false,\n\t\t\tsize: 'normal',\n\t\t\tstyle: 'icontext',\n\t\t}\n\t}\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.wrapper {\n\tpadding: 0 12px;\n}\n\n.grid {\n\tdisplay: grid;\n\tgap: 12px;\n\tgrid-template-columns: 1fr 1fr 1fr 1fr;\n\tgrid-template-rows: repeat(auto-fill, auto);\n\tposition: relative;\n\tmargin: 12px 0;\n}\n\nh5 {\n\tfont-weight: bold;\n\tmargin: 40px 0 20px 0;\n}\n\np {\n\ttext-align: center;\n\tmargin: 4px 0 12px 0;\n\tcolor: var(--color-text-maxcontrast)\n}\n\nbutton {\n\tmargin: auto;\n}\n</style>\n```\n\n### Alignment\nSometimes it is required to change the icon alignment on the button, like for switching between pages as in following example:\n\n```vue\n<template>\n\t<div style=\"display: flex; flex-direction: column; gap: 12px;\">\n\t\t<NcButton aria-label=\"center (default)\" variant=\"secondary\" wide>\n\t\t\t<template #icon>\n\t\t\t\t<IconLeft :size=\"20\" />\n\t\t\t</template>\n\t\t\tcenter (default)\n\t\t</NcButton>\n\t\t<NcButton alignment=\"center-reverse\" aria-label=\"center-reverse\" variant=\"secondary\" wide>\n\t\t\t<template #icon>\n\t\t\t\t<IconRight :size=\"20\" />\n\t\t\t</template>\n\t\t\tcenter-reverse\n\t\t</NcButton>\n\t\t<div style=\"display: flex; gap: 12px;\">\n\t\t\t<div style=\"display: flex; flex-direction: column; gap: 12px; flex: 1\">\n\t\t\t\t<NcButton alignment=\"start\" aria-label=\"start\" variant=\"secondary\" wide>\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<IconLeft :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t\tstart\n\t\t\t\t</NcButton>\n\t\t\t\t<NcButton alignment=\"start-reverse\" aria-label=\"start-reverse\" variant=\"secondary\" wide>\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<IconRight :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t\tstart-reverse\n\t\t\t\t</NcButton>\n\t\t\t</div>\n\t\t\t<div style=\"display: flex; flex-direction: column; gap: 12px; flex: 1\">\n\t\t\t\t<NcButton alignment=\"end\" aria-label=\"end\" variant=\"secondary\" wide>\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<IconLeft :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t\tend\n\t\t\t\t</NcButton>\n\t\t\t\t<NcButton alignment=\"end-reverse\" aria-label=\"end-reverse\" variant=\"secondary\" wide>\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<IconRight :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t\tend-reverse\n\t\t\t\t</NcButton>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</template>\n<script>\nimport IconLeft from 'vue-material-design-icons/ArrowLeft.vue'\nimport IconRight from 'vue-material-design-icons/ArrowRight.vue'\n\nexport default {\n\tcomponents: {\n\t\tIconLeft,\n\t\tIconRight,\n\t},\n}\n</script>\n```\n\n### Pressed state\n\nIt is possible to make the button stateful by adding a pressed state, e.g. if you like to create a favorite button.\nThe button will have the required `aria` attribute for accessibility and visual style (`primary` when pressed, and the configured variant otherwise).\n\nDo not change `text` or `aria-label` of the pressed/unpressed button. See: https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-pressed\n\n```vue\n<template>\n\t<div>\n\t\t<div style=\"display: flex; gap: 12px;\">\n\t\t\t<NcButton :pressed.sync=\"isFavorite\" aria-label=\"Favorite\" variant=\"tertiary-no-background\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<IconStar v-if=\"isFavorite\" :size=\"20\" />\n\t\t\t\t\t<IconStarOutline v-else :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t</NcButton>\n\n\t\t\t<NcButton :pressed.sync=\"isFavorite\" variant=\"tertiary\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<IconStar v-if=\"isFavorite\" :size=\"20\" />\n\t\t\t\t\t<IconStarOutline v-else :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tFavorite\n\t\t\t</NcButton>\n\n\t\t\t<NcButton :pressed.sync=\"isFavorite\" aria-label=\"Favorite\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<IconStar v-if=\"isFavorite\" :size=\"20\" />\n\t\t\t\t\t<IconStarOutline v-else :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t</NcButton>\n\t\t</div>\n\t\t<div>\n\t\t\tIt is {{ isFavorite ? 'a' : 'not a' }} favorite.\n\t\t</div>\n\t</div>\n</template>\n<script>\nimport IconStar from 'vue-material-design-icons/Star.vue'\nimport IconStarOutline from 'vue-material-design-icons/StarOutline.vue'\n\nexport default {\n\tcomponents: {\n\t\tIconStar,\n\t\tIconStarOutline,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tisFavorite: false,\n\t\t}\n\t},\n\tmethods: {\n\t\ttoggleFavorite() {\n\t\t\tthis.isFavorite = !this.isFavorite\n\t\t},\n\t},\n}\n</script>\n```\n\n### Usage example: Sorting table columns\nThe standard way to implement sortable table column headers should be like this:\n\n```vue\n<template>\n\t<table>\n\t\t<thead>\n\t\t\t<tr>\n\t\t\t\t<th :aria-sorted=\"sortedName\" class=\"row-name\">\n\t\t\t\t\t<NcButton alignment=\"start-reverse\"\n\t\t\t\t\t\t:wide=\"true\"\n\t\t\t\t\t\tvariant=\"tertiary\"\n\t\t\t\t\t\t@click=\"sortName\">\n\t\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t\t<IconDown v-if=\"sortedName === 'ascending'\" class=\"sort-icon\" :size=\"20\" />\n\t\t\t\t\t\t\t<IconUp v-else-if=\"sortedName === 'descending'\" class=\"sort-icon\" :size=\"20\" />\n\t\t\t\t\t\t</template>\n\t\t\t\t\t\t<span class=\"table-header\">Name</span>\n\t\t\t\t\t</NcButton>\n\t\t\t\t</th>\n\t\t\t\t<th :aria-sorted=\"sortedSize\" class=\"row-size\">\n\t\t\t\t\t<NcButton alignment=\"end\"\n\t\t\t\t\t\t:wide=\"true\"\n\t\t\t\t\t\tvariant=\"tertiary\"\n\t\t\t\t\t\t@click=\"sortSize\">\n\t\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t\t<IconDown v-if=\"sortedSize === 'ascending'\" class=\"sort-icon\" :size=\"20\" />\n\t\t\t\t\t\t\t<IconUp v-else-if=\"sortedSize === 'descending'\" class=\"sort-icon\" :size=\"20\" />\n\t\t\t\t\t\t</template>\n\t\t\t\t\t\t<span class=\"table-header\">Size</span>\n\t\t\t\t\t</NcButton>\n\t\t\t\t</th>\n\t\t\t</tr>\n\t\t</thead>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t<td class=\"row-name\">Lorem ipsum</td>\n\t\t\t\t<td class=\"row-size\">8 MiB</td>\n\t\t\t</tr>\n\t\t</tbody>\n\t</table>\n</template>\n<script>\nimport IconUp from 'vue-material-design-icons/MenuUp.vue'\nimport IconDown from 'vue-material-design-icons/MenuDown.vue'\n\nexport default {\n\tcomponents: {\n\t\tIconUp,\n\t\tIconDown,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tsortedName: null,\n\t\t\tsortedSize: null,\n\t\t}\n\t},\n\tmethods: {\n\t\tsortName() {\n\t\t\tif (this.sortedName === 'ascending') {\n\t\t\t\tthis.sortedName = 'descending'\n\t\t\t} else if (this.sortedName === 'descending') {\n\t\t\t\tthis.sortedName = null\n\t\t\t} else {\n\t\t\t\tthis.sortedName = 'ascending'\n\t\t\t}\n\t\t},\n\t\tsortSize() {\n\t\t\tif (this.sortedSize === 'ascending') {\n\t\t\t\tthis.sortedSize = 'descending'\n\t\t\t} else if (this.sortedSize === 'descending') {\n\t\t\t\tthis.sortedSize = null\n\t\t\t} else {\n\t\t\t\tthis.sortedSize = 'ascending'\n\t\t\t}\n\t\t},\n\t},\n}\n</script>\n<style>\ntable {\n\ttable-layout: fixed;\n\twidth: 300px;\n}\n\ntd.row-name {\n\tpadding-inline-start: 16px;\n}\n\ntd.row-size {\n\ttext-align: end;\n\tpadding-inline-end: 16px;\n}\n\n.table-header {\n\tfont-weight: normal;\n\tcolor: var(--color-text-maxcontrast);\n}\n\n.sort-icon {\n\tcolor: var(--color-text-maxcontrast);\n\tposition: relative;\n\tinset-inline: -10px;\n}\n\n.row-size .sort-icon {\n\tinset-inline: 10px;\n}\n</style>\n```\n\n</docs>\n\n<script>\n\nexport default {\n\tname: 'NcButton',\n\n\tinject: {\n\t\tgetNcPopoverTriggerAttrs: {\n\t\t\tfrom: 'NcPopover:trigger:attrs',\n\t\t\tdefault: () => () => ({}),\n\t\t},\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Set the text and icon alignment\n\t\t *\n\t\t * @default 'center'\n\t\t */\n\t\talignment: {\n\t\t\ttype: String,\n\t\t\tdefault: 'center',\n\t\t\tvalidator: (alignment) => ['start', 'start-reverse', 'center', 'center-reverse', 'end', 'end-reverse'].includes(alignment),\n\t\t},\n\n\t\t/**\n\t\t * Toggles the disabled state of the button on and off.\n\t\t */\n\t\tdisabled: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Specify the button size\n\t\t * Accepted values: `'small'`, `'normal'` (default), `'large'`\n\t\t */\n\t\tsize: {\n\t\t\ttype: String,\n\t\t\tdefault: 'normal',\n\t\t\tvalidator(value) {\n\t\t\t\treturn ['small', 'normal', 'large'].includes(value)\n\t\t\t},\n\t\t},\n\n\t\t/**\n\t\t * Specifies the HTML button type.\n\t\t * Accepted values: submit, reset, button.\n\t\t *\n\t\t * For legacy reasons this can also be used to set the variant of the button (color schema).\n\t\t * This is discouraged but the accepted values are:\n\t\t * primary, secondary, tertiary, tertiary-no-background, tertiary-on-primary, error, warning, success.\n\t\t *\n\t\t * @default 'secondary' (will change with v9)\n\t\t * @deprecated The behavior will change in v9 to only allow the native HTML button types - use `variant` instead for setting the appearance of the button.\n\t\t */\n\t\ttype: {\n\t\t\ttype: String,\n\t\t\tvalidator(value) {\n\t\t\t\treturn ['primary', 'secondary', 'tertiary', 'tertiary-no-background', 'tertiary-on-primary', 'error', 'warning', 'success'].includes(value)\n\t\t\t\t\t|| ['submit', 'reset', 'button'].includes(value)\n\t\t\t},\n\t\t\tdefault: 'secondary',\n\t\t},\n\n\t\t/**\n\t\t * Specifies the button native type\n\t\t * Accepted values: submit, reset, button. If left empty,\n\t\t * the default \"button\" type will be used.\n\t\t *\n\t\t * @deprecated use `type` instead - will be removed with v9\n\t\t */\n\t\tnativeType: {\n\t\t\ttype: String,\n\t\t\tvalidator(value) {\n\t\t\t\treturn ['submit', 'reset', 'button'].indexOf(value) !== -1\n\t\t\t},\n\t\t\tdefault: 'button',\n\t\t},\n\n\t\t/**\n\t\t * Specifies whether the button should span all the available width.\n\t\t * By default, buttons span the whole width of the container.\n\t\t */\n\t\twide: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Always try to provide an aria-label to your button. Make it more\n\t\t * specific than the button's name by provide some more context. E.g. if\n\t\t * the name of the button is \"send\" in the Mail app, the aria label could\n\t\t * be \"Send email\".\n\t\t */\n\t\tariaLabel: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Providing the href attribute turns the button component into an `a`\n\t\t * element.\n\t\t */\n\t\thref: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Target for the `a` element if `href` is set.\n\t\t */\n\t\ttarget: {\n\t\t\ttype: String,\n\t\t\tdefault: '_self',\n\t\t},\n\n\t\t/**\n\t\t * Providing the download attribute with href downloads file when clicking.\n\t\t */\n\t\tdownload: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Providing the to attribute turns the button component into a `router-link`\n\t\t * element. Takes precedence over the href attribute.\n\t\t */\n\t\tto: {\n\t\t\ttype: [String, Object],\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Pass in `true` if you want the matching behaviour of `router-link` to\n\t\t * be non-inclusive: https://router.vuejs.org/api/#exact\n\t\t */\n\t\texact: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t\t/**\n\t\t * @deprecated To be removed in @nextcloud/vue 9. Migration guide: remove ariaHidden prop from NcAction* components.\n\t\t * @todo Add a check in @nextcloud/vue 9 that this prop is not provided,\n\t\t * otherwise root element will inherit incorrect aria-hidden.\n\t\t */\n\t\tariaHidden: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * The pressed state of the button if it has a checked state\n\t\t * This will add the `aria-pressed` attribute and for the button to have the primary style in checked state.\n\t\t *\n\t\t * Pressed state is not supported for links\n\t\t */\n\t\tpressed: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Specifies the button variant.\n\t\t *\n\t\t * Accepted values: primary, secondary, tertiary, tertiary-no-background, tertiary-on-primary, error, warning, success.\n\t\t *\n\t\t * @default 'secondary'\n\t\t * @since 8.24.0\n\t\t */\n\t\t variant: {\n\t\t\ttype: String,\n\t\t\tvalidator(value) {\n\t\t\t\treturn ['primary', 'secondary', 'tertiary', 'tertiary-no-background', 'tertiary-on-primary', 'error', 'warning', 'success'].includes(value)\n\t\t\t},\n\t\t\tdefault: 'secondary',\n\t\t},\n\t},\n\n\temits: ['update:pressed', 'click'],\n\n\tcomputed: {\n\t\t/**\n\t\t * The real type to be used for the button, enforces `primary` for pressed state and, if stateful button, any other type for not pressed state\n\t\t * Otherwise the type property is used.\n\t\t */\n\t\trealVariant() {\n\t\t\t// Force *primary* when pressed\n\t\t\tif (this.pressed) {\n\t\t\t\treturn 'primary'\n\t\t\t}\n\t\t\t// If not pressed but button is configured as stateful button then the type must not be primary\n\t\t\tif (this.pressed === false && (this.type === 'primary' || this.variant === 'primary')) {\n\t\t\t\treturn 'secondary'\n\t\t\t}\n\t\t\t// handle legacy behavior\n\t\t\tif (this.type !== 'secondary' && ['primary', 'tertiary', 'tertiary-no-background', 'tertiary-on-primary', 'error', 'warning', 'success'].includes(this.type)) {\n\t\t\t\treturn this.type\n\t\t\t}\n\t\t\t// otherwise use the configured variant\n\t\t\treturn this.variant\n\t\t},\n\n\t\t/**\n\t\t * The HTML button type\n\t\t */\n\t\trealType() {\n\t\t\tif (typeof this.pressed === 'boolean') {\n\t\t\t\treturn 'button'\n\t\t\t}\n\t\t\t// Handle legacy behavior\n\t\t\tif (this.nativeType !== 'button') {\n\t\t\t\treturn this.nativeType\n\t\t\t}\n\t\t\t// Also handling legacy behavior: Ensure we do not conflict here\n\t\t\tif (['primary', 'secondary', 'tertiary', 'tertiary-no-background', 'tertiary-on-primary', 'error', 'warning', 'success'].includes(this.type)) {\n\t\t\t\treturn this.nativeType\n\t\t\t}\n\t\t\t// otherwise use the type\n\t\t\treturn this.type\n\t\t},\n\n\t\t/**\n\t\t * The flexbox alignment of the button content\n\t\t */\n\t\tflexAlignment() {\n\t\t\treturn this.alignment.split('-')[0]\n\t\t},\n\n\t\t/**\n\t\t * If the button content should be reversed (icon on the end)\n\t\t */\n\t\tisReverseAligned() {\n\t\t\treturn this.alignment.includes('-')\n\t\t},\n\n\t\tncPopoverTriggerAttrs() {\n\t\t\treturn this.getNcPopoverTriggerAttrs()\n\t\t},\n\t},\n\n\t/**\n\t * The render function to display the component\n\t *\n\t * @param {Function} h The function to create VNodes\n\t * @return {object|undefined} The created VNode\n\t */\n\trender(h) {\n\t\tconst hasText = !!this.$slots.default\n\t\tconst hasIcon = this.$slots?.icon\n\n\t\t/**\n\t\t * Always fill either the text prop or the ariaLabel one.\n\t\t */\n\t\tif (!hasText && !this.ariaLabel) {\n\t\t\tconsole.warn('You need to fill either the text or the ariaLabel props in the button component.', {\n\t\t\t\ttext: this.$slots.default?.[0]?.text,\n\t\t\t\tariaLabel: this.ariaLabel,\n\t\t\t},\n\t\t\tthis)\n\t\t}\n\n\t\tconst isLink = (this.to || this.href)\n\n\t\tconst hasPressed = !isLink && typeof this.pressed === 'boolean'\n\n\t\tconst renderButton = ({ href, navigate, isActive, isExactActive } = {}) => h(isLink ? 'a' : 'button',\n\t\t\t{\n\t\t\t\tclass: [\n\t\t\t\t\t'button-vue',\n\t\t\t\t\t`button-vue--size-${this.size}`,\n\t\t\t\t\t{\n\t\t\t\t\t\t'button-vue--icon-only': hasIcon && !hasText,\n\t\t\t\t\t\t'button-vue--text-only': hasText && !hasIcon,\n\t\t\t\t\t\t'button-vue--icon-and-text': hasIcon && hasText,\n\t\t\t\t\t\t[`button-vue--vue-${this.realVariant}`]: this.realVariant,\n\t\t\t\t\t\t'button-vue--wide': this.wide,\n\t\t\t\t\t\t[`button-vue--${this.flexAlignment}`]: this.flexAlignment !== 'center',\n\t\t\t\t\t\t'button-vue--reverse': this.isReverseAligned,\n\t\t\t\t\t\tactive: isActive,\n\t\t\t\t\t\t'router-link-exact-active': isExactActive,\n\t\t\t\t\t},\n\t\t\t\t],\n\t\t\t\tattrs: {\n\t\t\t\t\t'aria-label': this.ariaLabel,\n\t\t\t\t\t'aria-pressed': hasPressed ? this.pressed.toString() : undefined,\n\t\t\t\t\tdisabled: this.disabled,\n\t\t\t\t\ttype: isLink ? null : this.realType,\n\t\t\t\t\trole: isLink ? 'button' : null,\n\t\t\t\t\thref: this.to ? href : (this.href || null),\n\t\t\t\t\ttarget: isLink ? (this.target || '_self') : null,\n\t\t\t\t\trel: isLink ? 'nofollow noreferrer noopener' : null,\n\t\t\t\t\tdownload: (!this.to && this.href && this.download) ? this.download : null,\n\t\t\t\t\t// If this button is used as a popover trigger, we need to apply trigger attrs, e.g. aria attributes\n\t\t\t\t\t...this.ncPopoverTriggerAttrs,\n\t\t\t\t\t// Inherit all the component attrs\n\t\t\t\t\t...this.$attrs,\n\t\t\t\t},\n\t\t\t\ton: {\n\t\t\t\t\t...this.$listeners,\n\t\t\t\t\tclick: ($event) => {\n\t\t\t\t\t\tif (hasPressed) {\n\t\t\t\t\t\t\t/**\n\t\t\t\t\t\t\t * Update the current pressed state of the button (if the `pressed` property was configured)\n\t\t\t\t\t\t\t *\n\t\t\t\t\t\t\t * @property {boolean} newValue The new `pressed`-state\n\t\t\t\t\t\t\t */\n\t\t\t\t\t\t\tthis.$emit('update:pressed', !this.pressed)\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// We have to both navigate and emit the click event\n\t\t\t\t\t\tthis.$emit('click', $event)\n\t\t\t\t\t\tnavigate?.($event)\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t},\n\t\t\t[\n\t\t\t\th('span', { class: 'button-vue__wrapper' }, [\n\t\t\t\t\thasIcon\n\t\t\t\t\t\t? h('span', {\n\t\t\t\t\t\t\tclass: 'button-vue__icon',\n\t\t\t\t\t\t\tattrs: {\n\t\t\t\t\t\t\t\t'aria-hidden': 'true',\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t[this.$slots.icon],\n\t\t\t\t\t\t)\n\t\t\t\t\t\t: null,\n\t\t\t\t\thasText ? h('span', { class: 'button-vue__text' }, [this.$slots.default]) : null,\n\t\t\t\t]),\n\t\t\t],\n\t\t)\n\n\t\t// If we have a router-link, we wrap the button in it\n\t\tif (this.to) {\n\t\t\treturn h('router-link', {\n\t\t\t\tprops: {\n\t\t\t\t\tcustom: true,\n\t\t\t\t\tto: this.to,\n\t\t\t\t\texact: this.exact,\n\t\t\t\t},\n\t\t\t\tscopedSlots: {\n\t\t\t\t\tdefault: renderButton,\n\t\t\t\t},\n\t\t\t})\n\t\t}\n\t\t// Otherwise we simply return the button\n\t\treturn renderButton()\n\t},\n}\n\n</script>\n\n<style lang=\"scss\" scoped>\n.button-vue {\n\t// Setup different button sizes\n\t--button-size: var(--default-clickable-area);\n\t--button-radius: var(--border-radius-element, calc(var(--button-size) / 2));\n\t--button-padding: clamp(var(--default-grid-baseline), var(--button-radius), calc(var(--default-grid-baseline) * 4));\n\n\t&--size-small {\n\t\t--button-size: var(--clickable-area-small, 24px);\n\t\t--button-radius: var(--border-radius); // make the border radius even smaller for small buttons\n\t}\n\n\t&--size-large {\n\t\t--button-size: var(--clickable-area-large, 48px);\n\t}\n\n\t// General styles\n\tposition: relative;\n\twidth: fit-content;\n\toverflow: hidden;\n\tborder: 0;\n\tpadding: 0;\n\tfont-size: var(--default-font-size);\n\tfont-weight: bold;\n\tmin-height: var(--button-size);\n\tmin-width: var(--button-size);\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\t// Cursor pointer on element and all children\n\tcursor: pointer;\n\t& *,\n\tspan {\n\t\tcursor: pointer;\n\t}\n\tborder-radius: var(--button-radius);\n\ttransition-property: color, border-color, background-color;\n\ttransition-duration: 0.1s;\n\ttransition-timing-function: linear;\n\n\t// No outline feedback for focus. Handled with a toggled class in js (see data)\n\t&:focus {\n\t\toutline: none;\n\t}\n\n\t&:disabled {\n\t\tcursor: default;\n\t\t& * {\n\t\t\tcursor: default;\n\t\t}\n\t\topacity: $opacity_disabled;\n\t\t// Gives a wash out effect\n\t\tfilter: saturate($opacity_normal);\n\t}\n\n\t// Default button type\n\tcolor: var(--color-primary-element-light-text);\n\tbackground-color: var(--color-primary-element-light);\n\t&:hover:not(:disabled) {\n\t\tbackground-color: var(--color-primary-element-light-hover);\n\t}\n\n\t// Back to the default color for this button when active\n\t// TODO: add ripple effect\n\t&:active {\n\t\tbackground-color: var(--color-primary-element-light);\n\t}\n\n\t&__wrapper {\n\t\tdisplay: inline-flex;\n\t\talign-items: center;\n\t\tjustify-content: center;\n\t\twidth: 100%;\n\t}\n\n\t&--end &__wrapper {\n\t\tjustify-content: end;\n\t}\n\t&--start &__wrapper {\n\t\tjustify-content: start;\n\t}\n\t&--reverse &__wrapper {\n\t\tflex-direction: row-reverse;\n\t}\n\n\t&--reverse#{&}--icon-and-text {\n\t\tpadding-inline: var(--button-padding) var(--default-grid-baseline);\n\t}\n\n\t&__icon {\n\t\theight: var(--button-size);\n\t\twidth: var(--button-size);\n\t\tmin-height: var(--button-size);\n\t\tmin-width: var(--button-size);\n\t\tdisplay: flex;\n\t\tjustify-content: center;\n\t\talign-items: center;\n\t}\n\t// For small buttons we need to adjust the icon size\n\t&--size-small &__icon {\n\t\t:deep(> *) {\n\t\t\tmax-height: 16px;\n\t\t\tmax-width: 16px;\n\t\t}\n\t\t:deep(svg) {\n\t\t\theight: 16px;\n\t\t\twidth: 16px;\n\t\t}\n\t}\n\n\t&__text {\n\t\tfont-weight: bold;\n\t\tmargin-bottom: 1px;\n\t\tpadding: 2px 0;\n\t\twhite-space: nowrap;\n\t\ttext-overflow: ellipsis;\n\t\toverflow: hidden;\n\t}\n\n\t// Icon-only button\n\t&--icon-only {\n\t\tline-height: 1;\n\t\twidth: var(--button-size) !important;\n\t}\n\n\t// Text-only button\n\t&--text-only {\n\t\tpadding: 0 var(--button-padding);\n\t\t& .button-vue__text {\n\t\t\tmargin-left: 4px;\n\t\t\tmargin-right: 4px;\n\t\t}\n\t}\n\n\t// Icon and text button\n\t&--icon-and-text {\n\t\t// icon and text means the icon adds \"visual\" padding thus we need to adjust the text padding\n\t\t--button-padding: min(calc(var(--default-grid-baseline) + var(--button-radius)), calc(var(--default-grid-baseline) * 4));\n\t\t// Adjust padding as the icon already got some padding we need to reduce the padding on the icon side and only add larger padding to the text side\n\t\tpadding-block: 0;\n\t\tpadding-inline: var(--default-grid-baseline) var(--button-padding);\n\t}\n\n\t// Wide button spans the whole width of the container\n\t&--wide {\n\t\twidth: 100%;\n\t}\n\n\t&:focus-visible {\n\t\toutline: 2px solid var(--color-main-text) !important;\n\t\tbox-shadow: 0 0 0 4px var(--color-main-background) !important;\n\t\t&.button-vue--vue-tertiary-on-primary {\n\t\t\toutline: 2px solid var(--color-primary-element-text);\n\t\t\tborder-radius: var(--border-radius-element, var(--border-radius));\n\t\t\tbackground-color: transparent;\n\t\t}\n\t}\n\n\t// Button types\n\n\t// Primary\n\t&--vue-primary {\n\t\tbackground-color: var(--color-primary-element);\n\t\tcolor: var(--color-primary-element-text);\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: var(--color-primary-element-hover);\n\t\t}\n\t\t// Back to the default color for this button when active\n\t\t// TODO: add ripple effect\n\t\t&:active {\n\t\t\tbackground-color: var(--color-primary-element);\n\t\t}\n\t}\n\n\t// Secondary\n\t&--vue-secondary {\n\t\tcolor: var(--color-primary-element-light-text);\n\t\tbackground-color: var(--color-primary-element-light);\n\t\t&:hover:not(:disabled) {\n\t\t\tcolor: var(--color-primary-element-light-text);\n\t\t\tbackground-color: var(--color-primary-element-light-hover);\n\t\t}\n\t}\n\n\t// Tertiary\n\t&--vue-tertiary {\n\t\tcolor: var(--color-main-text);\n\t\tbackground-color: transparent;\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\t}\n\n\t// Tertiary, no background\n\t&--vue-tertiary-no-background {\n\t\tcolor: var(--color-main-text);\n\t\tbackground-color: transparent;\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: transparent;\n\t\t}\n\t}\n\n\t// Tertiary on primary color (like the header)\n\t&--vue-tertiary-on-primary {\n\t\tcolor: var(--color-primary-element-text);\n\t\tbackground-color: transparent;\n\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: transparent;\n\t\t}\n\t}\n\n\t// Success\n\t&--vue-success {\n\t\tbackground-color: var(--color-success);\n\t\tcolor: white;\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: var(--color-success-hover);\n\t\t}\n\t\t// Back to the default color for this button when active\n\t\t// : add ripple effect\n\t\t&:active {\n\t\t\tbackground-color: var(--color-success);\n\t\t}\n\t}\n\n\t// Warning\n\t&--vue-warning {\n\t\tbackground-color: var(--color-warning);\n\t\tcolor: white;\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: var(--color-warning-hover);\n\t\t}\n\t\t// Back to the default color for this button when active\n\t\t// TODO: add ripple effect\n\t\t&:active {\n\t\t\tbackground-color: var(--color-warning);\n\t\t}\n\t}\n\n\t// Error\n\t&--vue-error {\n\t\tbackground-color: var(--color-error);\n\t\tcolor: white;\n\t\t&:hover:not(:disabled) {\n\t\t\tbackground-color: var(--color-error-hover);\n\t\t}\n\t\t// Back to the default color for this button when active\n\t\t// TODO: add ripple effect\n\t\t&:active {\n\t\t\tbackground-color: var(--color-error);\n\t\t}\n\t}\n}\n\n</style>\n"],"names":[],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import '../assets/NcButton-CfOAX-eQ.css';
1
+ import '../assets/NcButton-DnNZaEy_.css';
2
2
  import { n as normalizeComponent } from "../chunks/_plugin-vue2_normalizer-DU4iP6Vu.mjs";
3
3
  const _sfc_main = {
4
4
  name: "NcButton",
@@ -38,14 +38,20 @@ const _sfc_main = {
38
38
  }
39
39
  },
40
40
  /**
41
- * Specifies the button type
42
- * Accepted values: primary, secondary, tertiary, tertiary-no-background, tertiary-on-primary, error, warning, success. If left empty,
43
- * the default button style will be applied.
41
+ * Specifies the HTML button type.
42
+ * Accepted values: submit, reset, button.
43
+ *
44
+ * For legacy reasons this can also be used to set the variant of the button (color schema).
45
+ * This is discouraged but the accepted values are:
46
+ * primary, secondary, tertiary, tertiary-no-background, tertiary-on-primary, error, warning, success.
47
+ *
48
+ * @default 'secondary' (will change with v9)
49
+ * @deprecated The behavior will change in v9 to only allow the native HTML button types - use `variant` instead for setting the appearance of the button.
44
50
  */
45
51
  type: {
46
52
  type: String,
47
53
  validator(value) {
48
- return ["primary", "secondary", "tertiary", "tertiary-no-background", "tertiary-on-primary", "error", "warning", "success"].includes(value);
54
+ return ["primary", "secondary", "tertiary", "tertiary-no-background", "tertiary-on-primary", "error", "warning", "success"].includes(value) || ["submit", "reset", "button"].includes(value);
49
55
  },
50
56
  default: "secondary"
51
57
  },
@@ -53,6 +59,8 @@ const _sfc_main = {
53
59
  * Specifies the button native type
54
60
  * Accepted values: submit, reset, button. If left empty,
55
61
  * the default "button" type will be used.
62
+ *
63
+ * @deprecated use `type` instead - will be removed with v9
56
64
  */
57
65
  nativeType: {
58
66
  type: String,
@@ -135,6 +143,21 @@ const _sfc_main = {
135
143
  pressed: {
136
144
  type: Boolean,
137
145
  default: null
146
+ },
147
+ /**
148
+ * Specifies the button variant.
149
+ *
150
+ * Accepted values: primary, secondary, tertiary, tertiary-no-background, tertiary-on-primary, error, warning, success.
151
+ *
152
+ * @default 'secondary'
153
+ * @since 8.24.0
154
+ */
155
+ variant: {
156
+ type: String,
157
+ validator(value) {
158
+ return ["primary", "secondary", "tertiary", "tertiary-no-background", "tertiary-on-primary", "error", "warning", "success"].includes(value);
159
+ },
160
+ default: "secondary"
138
161
  }
139
162
  },
140
163
  emits: ["update:pressed", "click"],
@@ -143,13 +166,31 @@ const _sfc_main = {
143
166
  * The real type to be used for the button, enforces `primary` for pressed state and, if stateful button, any other type for not pressed state
144
167
  * Otherwise the type property is used.
145
168
  */
146
- realType() {
169
+ realVariant() {
147
170
  if (this.pressed) {
148
171
  return "primary";
149
172
  }
150
- if (this.pressed === false && this.type === "primary") {
173
+ if (this.pressed === false && (this.type === "primary" || this.variant === "primary")) {
151
174
  return "secondary";
152
175
  }
176
+ if (this.type !== "secondary" && ["primary", "tertiary", "tertiary-no-background", "tertiary-on-primary", "error", "warning", "success"].includes(this.type)) {
177
+ return this.type;
178
+ }
179
+ return this.variant;
180
+ },
181
+ /**
182
+ * The HTML button type
183
+ */
184
+ realType() {
185
+ if (typeof this.pressed === "boolean") {
186
+ return "button";
187
+ }
188
+ if (this.nativeType !== "button") {
189
+ return this.nativeType;
190
+ }
191
+ if (["primary", "secondary", "tertiary", "tertiary-no-background", "tertiary-on-primary", "error", "warning", "success"].includes(this.type)) {
192
+ return this.nativeType;
193
+ }
153
194
  return this.type;
154
195
  },
155
196
  /**
@@ -199,7 +240,7 @@ const _sfc_main = {
199
240
  "button-vue--icon-only": hasIcon && !hasText,
200
241
  "button-vue--text-only": hasText && !hasIcon,
201
242
  "button-vue--icon-and-text": hasIcon && hasText,
202
- [`button-vue--vue-${this.realType}`]: this.realType,
243
+ [`button-vue--vue-${this.realVariant}`]: this.realVariant,
203
244
  "button-vue--wide": this.wide,
204
245
  [`button-vue--${this.flexAlignment}`]: this.flexAlignment !== "center",
205
246
  "button-vue--reverse": this.isReverseAligned,
@@ -211,7 +252,7 @@ const _sfc_main = {
211
252
  "aria-label": this.ariaLabel,
212
253
  "aria-pressed": hasPressed ? this.pressed.toString() : void 0,
213
254
  disabled: this.disabled,
214
- type: isLink ? null : this.nativeType,
255
+ type: isLink ? null : this.realType,
215
256
  role: isLink ? "button" : null,
216
257
  href: this.to ? href : this.href || null,
217
258
  target: isLink ? this.target || "_self" : null,
@@ -272,9 +313,10 @@ var __component__ = /* @__PURE__ */ normalizeComponent(
272
313
  _sfc_staticRenderFns,
273
314
  false,
274
315
  null,
275
- "b2be1481"
316
+ "3f8e123a"
276
317
  );
277
318
  const NcButton = __component__.exports;
278
319
  export {
279
320
  NcButton as default
280
321
  };
322
+ //# sourceMappingURL=NcButton.mjs.map