@nextcloud/vue 8.4.0 → 8.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (648) hide show
  1. package/CHANGELOG.md +70 -0
  2. package/dist/Components/NcActionButton.cjs +85 -23
  3. package/dist/Components/NcActionButton.cjs.map +1 -1
  4. package/dist/Components/NcActionButton.mjs +88 -24
  5. package/dist/Components/NcActionButton.mjs.map +1 -1
  6. package/dist/Components/NcActionButtonGroup.cjs +3 -45
  7. package/dist/Components/NcActionButtonGroup.cjs.map +1 -1
  8. package/dist/Components/NcActionButtonGroup.mjs +2 -48
  9. package/dist/Components/NcActionButtonGroup.mjs.map +1 -1
  10. package/dist/Components/NcActionCaption.cjs +8 -9
  11. package/dist/Components/NcActionCaption.cjs.map +1 -1
  12. package/dist/Components/NcActionCaption.mjs +8 -8
  13. package/dist/Components/NcActionCheckbox.cjs +4 -5
  14. package/dist/Components/NcActionCheckbox.cjs.map +1 -1
  15. package/dist/Components/NcActionCheckbox.mjs +13 -13
  16. package/dist/Components/NcActionInput.cjs +3 -234
  17. package/dist/Components/NcActionInput.cjs.map +1 -1
  18. package/dist/Components/NcActionInput.mjs +2 -242
  19. package/dist/Components/NcActionInput.mjs.map +1 -1
  20. package/dist/Components/NcActionLink.cjs +2 -3
  21. package/dist/Components/NcActionLink.cjs.map +1 -1
  22. package/dist/Components/NcActionLink.mjs +3 -3
  23. package/dist/Components/NcActionRadio.cjs +12 -13
  24. package/dist/Components/NcActionRadio.cjs.map +1 -1
  25. package/dist/Components/NcActionRadio.mjs +11 -11
  26. package/dist/Components/NcActionRouter.cjs +5 -6
  27. package/dist/Components/NcActionRouter.cjs.map +1 -1
  28. package/dist/Components/NcActionRouter.mjs +6 -6
  29. package/dist/Components/NcActionSeparator.cjs +6 -7
  30. package/dist/Components/NcActionSeparator.cjs.map +1 -1
  31. package/dist/Components/NcActionSeparator.mjs +9 -9
  32. package/dist/Components/NcActionText.cjs +7 -8
  33. package/dist/Components/NcActionText.cjs.map +1 -1
  34. package/dist/Components/NcActionText.mjs +10 -10
  35. package/dist/Components/NcActionTextEditable.cjs +4 -5
  36. package/dist/Components/NcActionTextEditable.cjs.map +1 -1
  37. package/dist/Components/NcActionTextEditable.mjs +5 -5
  38. package/dist/Components/NcActions.cjs +3 -483
  39. package/dist/Components/NcActions.cjs.map +1 -1
  40. package/dist/Components/NcActions.mjs +2 -489
  41. package/dist/Components/NcActions.mjs.map +1 -1
  42. package/dist/Components/NcAppContent.cjs +3 -222
  43. package/dist/Components/NcAppContent.cjs.map +1 -1
  44. package/dist/Components/NcAppContent.mjs +2 -230
  45. package/dist/Components/NcAppContent.mjs.map +1 -1
  46. package/dist/Components/NcAppContentDetails.cjs +1 -1
  47. package/dist/Components/NcAppContentDetails.mjs +1 -1
  48. package/dist/Components/NcAppContentList.cjs +1 -1
  49. package/dist/Components/NcAppContentList.mjs +1 -1
  50. package/dist/Components/NcAppNavigation.cjs +3 -101
  51. package/dist/Components/NcAppNavigation.cjs.map +1 -1
  52. package/dist/Components/NcAppNavigation.mjs +2 -106
  53. package/dist/Components/NcAppNavigation.mjs.map +1 -1
  54. package/dist/Components/NcAppNavigationCaption.cjs +3 -44
  55. package/dist/Components/NcAppNavigationCaption.cjs.map +1 -1
  56. package/dist/Components/NcAppNavigationCaption.mjs +2 -45
  57. package/dist/Components/NcAppNavigationCaption.mjs.map +1 -1
  58. package/dist/Components/NcAppNavigationIconBullet.cjs +5 -6
  59. package/dist/Components/NcAppNavigationIconBullet.cjs.map +1 -1
  60. package/dist/Components/NcAppNavigationIconBullet.mjs +8 -8
  61. package/dist/Components/NcAppNavigationItem.cjs +3 -498
  62. package/dist/Components/NcAppNavigationItem.cjs.map +1 -1
  63. package/dist/Components/NcAppNavigationItem.mjs +2 -508
  64. package/dist/Components/NcAppNavigationItem.mjs.map +1 -1
  65. package/dist/Components/NcAppNavigationNew.cjs +14 -15
  66. package/dist/Components/NcAppNavigationNew.cjs.map +1 -1
  67. package/dist/Components/NcAppNavigationNew.mjs +6 -6
  68. package/dist/Components/NcAppNavigationNewItem.cjs +3 -87
  69. package/dist/Components/NcAppNavigationNewItem.cjs.map +1 -1
  70. package/dist/Components/NcAppNavigationNewItem.mjs +2 -89
  71. package/dist/Components/NcAppNavigationNewItem.mjs.map +1 -1
  72. package/dist/Components/NcAppNavigationSettings.cjs +3 -102
  73. package/dist/Components/NcAppNavigationSettings.cjs.map +1 -1
  74. package/dist/Components/NcAppNavigationSettings.mjs +2 -103
  75. package/dist/Components/NcAppNavigationSettings.mjs.map +1 -1
  76. package/dist/Components/NcAppNavigationSpacer.cjs +10 -11
  77. package/dist/Components/NcAppNavigationSpacer.cjs.map +1 -1
  78. package/dist/Components/NcAppNavigationSpacer.mjs +10 -10
  79. package/dist/Components/NcAppNavigationToggle.cjs +1 -1
  80. package/dist/Components/NcAppNavigationToggle.mjs +1 -1
  81. package/dist/Components/NcAppSettingsDialog.cjs +3 -182
  82. package/dist/Components/NcAppSettingsDialog.cjs.map +1 -1
  83. package/dist/Components/NcAppSettingsDialog.mjs +2 -188
  84. package/dist/Components/NcAppSettingsDialog.mjs.map +1 -1
  85. package/dist/Components/NcAppSettingsSection.cjs +7 -11
  86. package/dist/Components/NcAppSettingsSection.cjs.map +1 -1
  87. package/dist/Components/NcAppSettingsSection.mjs +7 -10
  88. package/dist/Components/NcAppSettingsSection.mjs.map +1 -1
  89. package/dist/Components/NcAppSidebar.cjs +3 -552
  90. package/dist/Components/NcAppSidebar.cjs.map +1 -1
  91. package/dist/Components/NcAppSidebar.mjs +2 -567
  92. package/dist/Components/NcAppSidebar.mjs.map +1 -1
  93. package/dist/Components/NcAppSidebarTab.cjs +5 -7
  94. package/dist/Components/NcAppSidebarTab.cjs.map +1 -1
  95. package/dist/Components/NcAppSidebarTab.mjs +3 -4
  96. package/dist/Components/NcAppSidebarTab.mjs.map +1 -1
  97. package/dist/Components/NcAvatar.cjs +2 -2
  98. package/dist/Components/NcAvatar.mjs +1 -1
  99. package/dist/Components/NcBreadcrumb.cjs +3 -176
  100. package/dist/Components/NcBreadcrumb.cjs.map +1 -1
  101. package/dist/Components/NcBreadcrumb.mjs +2 -179
  102. package/dist/Components/NcBreadcrumb.mjs.map +1 -1
  103. package/dist/Components/NcBreadcrumbs.cjs +3 -411
  104. package/dist/Components/NcBreadcrumbs.cjs.map +1 -1
  105. package/dist/Components/NcBreadcrumbs.mjs +2 -420
  106. package/dist/Components/NcBreadcrumbs.mjs.map +1 -1
  107. package/dist/Components/NcButton.cjs +42 -30
  108. package/dist/Components/NcButton.cjs.map +1 -1
  109. package/dist/Components/NcButton.mjs +43 -30
  110. package/dist/Components/NcButton.mjs.map +1 -1
  111. package/dist/Components/NcCheckboxRadioSwitch.cjs +3 -600
  112. package/dist/Components/NcCheckboxRadioSwitch.cjs.map +1 -1
  113. package/dist/Components/NcCheckboxRadioSwitch.mjs +2 -604
  114. package/dist/Components/NcCheckboxRadioSwitch.mjs.map +1 -1
  115. package/dist/Components/NcColorPicker.cjs +3 -158
  116. package/dist/Components/NcColorPicker.cjs.map +1 -1
  117. package/dist/Components/NcColorPicker.mjs +2 -167
  118. package/dist/Components/NcColorPicker.mjs.map +1 -1
  119. package/dist/Components/NcContent.cjs +3 -25
  120. package/dist/Components/NcContent.cjs.map +1 -1
  121. package/dist/Components/NcContent.mjs +2 -25
  122. package/dist/Components/NcContent.mjs.map +1 -1
  123. package/dist/Components/NcCounterBubble.cjs +4 -5
  124. package/dist/Components/NcCounterBubble.cjs.map +1 -1
  125. package/dist/Components/NcCounterBubble.mjs +4 -4
  126. package/dist/Components/NcDashboardWidget.cjs +3 -134
  127. package/dist/Components/NcDashboardWidget.cjs.map +1 -1
  128. package/dist/Components/NcDashboardWidget.mjs +2 -139
  129. package/dist/Components/NcDashboardWidget.mjs.map +1 -1
  130. package/dist/Components/NcDashboardWidgetItem.cjs +3 -138
  131. package/dist/Components/NcDashboardWidgetItem.cjs.map +1 -1
  132. package/dist/Components/NcDashboardWidgetItem.mjs +2 -141
  133. package/dist/Components/NcDashboardWidgetItem.mjs.map +1 -1
  134. package/dist/Components/NcDateTime.cjs +2 -129
  135. package/dist/Components/NcDateTime.cjs.map +1 -1
  136. package/dist/Components/NcDateTime.mjs +2 -131
  137. package/dist/Components/NcDateTime.mjs.map +1 -1
  138. package/dist/Components/NcDateTimePicker.cjs +68 -50
  139. package/dist/Components/NcDateTimePicker.cjs.map +1 -1
  140. package/dist/Components/NcDateTimePicker.mjs +72 -53
  141. package/dist/Components/NcDateTimePicker.mjs.map +1 -1
  142. package/dist/Components/NcDateTimePickerNative.cjs +8 -9
  143. package/dist/Components/NcDateTimePickerNative.cjs.map +1 -1
  144. package/dist/Components/NcDateTimePickerNative.mjs +7 -7
  145. package/dist/Components/NcDialog.cjs +3 -172
  146. package/dist/Components/NcDialog.cjs.map +1 -1
  147. package/dist/Components/NcDialog.mjs +2 -177
  148. package/dist/Components/NcDialog.mjs.map +1 -1
  149. package/dist/Components/NcDialogButton.cjs +2 -68
  150. package/dist/Components/NcDialogButton.cjs.map +1 -1
  151. package/dist/Components/NcDialogButton.mjs +2 -72
  152. package/dist/Components/NcDialogButton.mjs.map +1 -1
  153. package/dist/Components/NcEllipsisedOption.cjs +4 -5
  154. package/dist/Components/NcEllipsisedOption.cjs.map +1 -1
  155. package/dist/Components/NcEllipsisedOption.mjs +14 -14
  156. package/dist/Components/NcEmojiPicker.cjs +3 -176
  157. package/dist/Components/NcEmojiPicker.cjs.map +1 -1
  158. package/dist/Components/NcEmojiPicker.mjs +2 -181
  159. package/dist/Components/NcEmojiPicker.mjs.map +1 -1
  160. package/dist/Components/NcEmptyContent.cjs +14 -16
  161. package/dist/Components/NcEmptyContent.cjs.map +1 -1
  162. package/dist/Components/NcEmptyContent.mjs +8 -9
  163. package/dist/Components/NcEmptyContent.mjs.map +1 -1
  164. package/dist/Components/NcGuestContent.cjs +8 -9
  165. package/dist/Components/NcGuestContent.cjs.map +1 -1
  166. package/dist/Components/NcGuestContent.mjs +7 -7
  167. package/dist/Components/NcHeaderMenu.cjs +3 -169
  168. package/dist/Components/NcHeaderMenu.cjs.map +1 -1
  169. package/dist/Components/NcHeaderMenu.mjs +2 -172
  170. package/dist/Components/NcHeaderMenu.mjs.map +1 -1
  171. package/dist/Components/NcHighlight.cjs +1 -1
  172. package/dist/Components/NcHighlight.mjs +1 -1
  173. package/dist/Components/NcIconSvgWrapper.cjs +3 -59
  174. package/dist/Components/NcIconSvgWrapper.cjs.map +1 -1
  175. package/dist/Components/NcIconSvgWrapper.mjs +2 -61
  176. package/dist/Components/NcIconSvgWrapper.mjs.map +1 -1
  177. package/dist/Components/NcInputField.cjs +10 -10
  178. package/dist/Components/NcInputField.cjs.map +1 -1
  179. package/dist/Components/NcInputField.mjs +10 -9
  180. package/dist/Components/NcInputField.mjs.map +1 -1
  181. package/dist/Components/NcListItem.cjs +3 -242
  182. package/dist/Components/NcListItem.cjs.map +1 -1
  183. package/dist/Components/NcListItem.mjs +2 -246
  184. package/dist/Components/NcListItem.mjs.map +1 -1
  185. package/dist/Components/NcListItemIcon.cjs +3 -160
  186. package/dist/Components/NcListItemIcon.cjs.map +1 -1
  187. package/dist/Components/NcListItemIcon.mjs +2 -162
  188. package/dist/Components/NcListItemIcon.mjs.map +1 -1
  189. package/dist/Components/NcLoadingIcon.cjs +9 -10
  190. package/dist/Components/NcLoadingIcon.cjs.map +1 -1
  191. package/dist/Components/NcLoadingIcon.mjs +10 -10
  192. package/dist/Components/NcModal.cjs +31 -23
  193. package/dist/Components/NcModal.cjs.map +1 -1
  194. package/dist/Components/NcModal.mjs +36 -28
  195. package/dist/Components/NcModal.mjs.map +1 -1
  196. package/dist/Components/NcNoteCard.cjs +8 -9
  197. package/dist/Components/NcNoteCard.cjs.map +1 -1
  198. package/dist/Components/NcNoteCard.mjs +8 -9
  199. package/dist/Components/NcNoteCard.mjs.map +1 -1
  200. package/dist/Components/NcPasswordField.cjs +2 -228
  201. package/dist/Components/NcPasswordField.cjs.map +1 -1
  202. package/dist/Components/NcPasswordField.mjs +2 -236
  203. package/dist/Components/NcPasswordField.mjs.map +1 -1
  204. package/dist/Components/NcPopover.cjs +3 -125
  205. package/dist/Components/NcPopover.cjs.map +1 -1
  206. package/dist/Components/NcPopover.mjs +2 -128
  207. package/dist/Components/NcPopover.mjs.map +1 -1
  208. package/dist/Components/NcProgressBar.cjs +3 -57
  209. package/dist/Components/NcProgressBar.cjs.map +1 -1
  210. package/dist/Components/NcProgressBar.mjs +2 -57
  211. package/dist/Components/NcProgressBar.mjs.map +1 -1
  212. package/dist/Components/NcRelatedResourcesPanel.cjs +3 -203
  213. package/dist/Components/NcRelatedResourcesPanel.cjs.map +1 -1
  214. package/dist/Components/NcRelatedResourcesPanel.mjs +2 -207
  215. package/dist/Components/NcRelatedResourcesPanel.mjs.map +1 -1
  216. package/dist/Components/NcRichContenteditable.cjs +5 -512
  217. package/dist/Components/NcRichContenteditable.cjs.map +1 -1
  218. package/dist/Components/NcRichContenteditable.mjs +5 -523
  219. package/dist/Components/NcRichContenteditable.mjs.map +1 -1
  220. package/dist/Components/NcRichText.cjs +1 -1
  221. package/dist/Components/NcRichText.mjs +3 -3
  222. package/dist/Components/NcSavingIndicatorIcon.cjs +2 -58
  223. package/dist/Components/NcSavingIndicatorIcon.cjs.map +1 -1
  224. package/dist/Components/NcSavingIndicatorIcon.mjs +2 -60
  225. package/dist/Components/NcSavingIndicatorIcon.mjs.map +1 -1
  226. package/dist/Components/NcSelect.cjs +3 -435
  227. package/dist/Components/NcSelect.cjs.map +1 -1
  228. package/dist/Components/NcSelect.mjs +2 -444
  229. package/dist/Components/NcSelect.mjs.map +1 -1
  230. package/dist/Components/NcSelectTags.cjs +2 -260
  231. package/dist/Components/NcSelectTags.cjs.map +1 -1
  232. package/dist/Components/NcSelectTags.mjs +2 -265
  233. package/dist/Components/NcSelectTags.mjs.map +1 -1
  234. package/dist/Components/NcSettingsInputText.cjs +3 -91
  235. package/dist/Components/NcSettingsInputText.cjs.map +1 -1
  236. package/dist/Components/NcSettingsInputText.mjs +2 -93
  237. package/dist/Components/NcSettingsInputText.mjs.map +1 -1
  238. package/dist/Components/NcSettingsSection.cjs +3 -96
  239. package/dist/Components/NcSettingsSection.cjs.map +1 -1
  240. package/dist/Components/NcSettingsSection.mjs +2 -97
  241. package/dist/Components/NcSettingsSection.mjs.map +1 -1
  242. package/dist/Components/NcSettingsSelectGroup.cjs +1 -1
  243. package/dist/Components/NcSettingsSelectGroup.mjs +1 -1
  244. package/dist/Components/NcTextArea.cjs +7 -8
  245. package/dist/Components/NcTextArea.cjs.map +1 -1
  246. package/dist/Components/NcTextArea.mjs +9 -9
  247. package/dist/Components/NcTextArea.mjs.map +1 -1
  248. package/dist/Components/NcTextField.cjs +2 -139
  249. package/dist/Components/NcTextField.cjs.map +1 -1
  250. package/dist/Components/NcTextField.mjs +2 -144
  251. package/dist/Components/NcTextField.mjs.map +1 -1
  252. package/dist/Components/NcTimezonePicker.cjs +2 -7198
  253. package/dist/Components/NcTimezonePicker.cjs.map +1 -1
  254. package/dist/Components/NcTimezonePicker.mjs +2 -7203
  255. package/dist/Components/NcTimezonePicker.mjs.map +1 -1
  256. package/dist/Components/NcUserBubble.cjs +3 -193
  257. package/dist/Components/NcUserBubble.cjs.map +1 -1
  258. package/dist/Components/NcUserBubble.mjs +2 -197
  259. package/dist/Components/NcUserBubble.mjs.map +1 -1
  260. package/dist/Components/NcUserStatusIcon.cjs +3 -0
  261. package/dist/Components/NcUserStatusIcon.cjs.map +1 -0
  262. package/dist/Components/NcUserStatusIcon.mjs +4 -0
  263. package/dist/Components/NcUserStatusIcon.mjs.map +1 -0
  264. package/dist/Components/NcVNodes.cjs +10 -11
  265. package/dist/Components/NcVNodes.cjs.map +1 -1
  266. package/dist/Components/NcVNodes.mjs +11 -12
  267. package/dist/Components/NcVNodes.mjs.map +1 -1
  268. package/dist/Directives/Linkify.cjs +4 -5
  269. package/dist/Directives/Linkify.cjs.map +1 -1
  270. package/dist/Directives/Linkify.mjs +5 -6
  271. package/dist/Directives/Linkify.mjs.map +1 -1
  272. package/dist/Directives/Tooltip.cjs +1 -1
  273. package/dist/Directives/Tooltip.mjs +3 -3
  274. package/dist/Functions/usernameToColor.cjs +2 -38
  275. package/dist/Functions/usernameToColor.cjs.map +1 -1
  276. package/dist/Functions/usernameToColor.mjs +2 -39
  277. package/dist/Functions/usernameToColor.mjs.map +1 -1
  278. package/dist/Mixins/richEditor.cjs +2 -2
  279. package/dist/Mixins/richEditor.mjs +2 -2
  280. package/dist/assets/{index-7868494b.css → NcActionButton-YVkNHN_x.css} +17 -16
  281. package/dist/assets/{index-5fa0ac5a.css → NcActionButtonGroup-oXobVIqQ.css} +14 -0
  282. package/dist/assets/{index-e0e6bab6.css → NcActionCheckbox-6Pvlr1E7.css} +1 -1
  283. package/dist/assets/{index-9020d9ca.css → NcActionInput-4zSvDkWm.css} +67 -67
  284. package/dist/assets/{index-4ba699a1.css → NcActionLink-zdzQgwtH.css} +1 -1
  285. package/dist/assets/{index-542cf50a.css → NcActionRadio-eOr9Sp-D.css} +1 -1
  286. package/dist/assets/{index-7fac55ed.css → NcActionRouter-MFTD6tYI.css} +1 -1
  287. package/dist/assets/{index-00012a4c.css → NcActionText-GJYwsw_U.css} +1 -1
  288. package/dist/assets/{index-93ad846c.css → NcActionTextEditable-JrYuWEDd.css} +1 -1
  289. package/dist/assets/{index-b0bba2fc.css → NcActions-vgT9ak04.css} +16 -11
  290. package/dist/assets/{index-4596132f.css → NcAppContent-SZz3PTd8.css} +0 -1
  291. package/dist/assets/{index-5784183b.css → NcAppNavigation-vjqOL-kR.css} +8 -8
  292. package/dist/assets/{index-fe84a063.css → NcAppNavigationCaption-l5yRGXZx.css} +6 -5
  293. package/dist/assets/{index-d8bc189c.css → NcAppNavigationItem-n-wauJE7.css} +5 -0
  294. package/dist/assets/{index-1a317434.css → NcAppNavigationNewItem-MQBvffq9.css} +5 -0
  295. package/dist/assets/{index-a9999048.css → NcAppSettingsDialog-0eOo3ERv.css} +16 -17
  296. package/dist/assets/{index-3b654875.css → NcAvatar-5H9cqcD1.css} +27 -27
  297. package/dist/assets/{index-c20f9f7e.css → NcBreadcrumb-M3hqCbqS.css} +26 -33
  298. package/dist/assets/{index-f5162bbd.css → NcBreadcrumbs-KBV0Jccv.css} +7 -8
  299. package/dist/assets/{index-f091e784.css → NcButton-4Wj3KJn8.css} +43 -43
  300. package/dist/assets/{index-7f77b8ae.css → NcCheckboxRadioSwitch-mgKotCbU.css} +52 -47
  301. package/dist/assets/{index-13720a46.css → NcColorPicker-CNX9fj56.css} +24 -24
  302. package/dist/assets/{index-a9e4fe04.css → NcContent-LWR23l9i.css} +42 -4
  303. package/dist/assets/{index-a7fc7815.css → NcDateTimePicker-amYL2HzW.css} +20 -20
  304. package/dist/assets/{index-86454928.css → NcDialog-DN-rY-55.css} +30 -19
  305. package/dist/assets/{index-2a8e4ca1.css → NcEmojiPicker-lBXbC6Jd.css} +36 -26
  306. package/dist/assets/{index-aacb7cf8.css → NcHeaderMenu-06vdn4tC.css} +17 -24
  307. package/dist/assets/NcIconSvgWrapper-arqrq5Bj.css +44 -0
  308. package/dist/assets/{index-2a1ec06b.css → NcInputField-L2Lld_iG.css} +41 -40
  309. package/dist/assets/{index-a3c23731.css → NcModal-UZh031V1.css} +64 -64
  310. package/dist/assets/{index-61b63a8f.css → NcProgressBar-w4-G5gQR.css} +19 -9
  311. package/dist/assets/{index-ab715d82.css → NcRelatedResourcesPanel-m3uf_nvH.css} +4 -4
  312. package/dist/assets/{index-dab51681.css → NcRichContenteditable-j9edXOEH.css} +26 -25
  313. package/dist/assets/{index-f9bfa317.css → NcSelect-GsLmwj9w.css} +13 -2
  314. package/dist/assets/{index-76a58945.css → NcSettingsSection-PEWm0eeL.css} +13 -13
  315. package/dist/assets/{index-97305c1f.css → NcTextArea-4rVwq6GK.css} +24 -23
  316. package/dist/assets/{index-c221fe05.css → NcUserBubble-jjzI5imn.css} +9 -9
  317. package/dist/assets/{index-57b305d3.css → NcUserStatusIcon-62u43_6P.css} +7 -10
  318. package/dist/assets/{referencePickerModal-3a127978.css → referencePickerModal-VxSowpb5.css} +84 -57
  319. package/dist/chunks/{AlertCircleOutline-7085c10f.cjs → AlertCircleOutline-VgVvRWpm.cjs} +1 -1
  320. package/dist/chunks/{AlertCircleOutline-7085c10f.cjs.map → AlertCircleOutline-VgVvRWpm.cjs.map} +1 -1
  321. package/dist/chunks/{AlertCircleOutline-b73838e0.mjs → AlertCircleOutline-lwSRucNO.mjs} +1 -1
  322. package/dist/chunks/{AlertCircleOutline-b73838e0.mjs.map → AlertCircleOutline-lwSRucNO.mjs.map} +1 -1
  323. package/dist/chunks/{ArrowLeft-2f9b9323.cjs → ArrowLeft-3KC2k3tR.cjs} +1 -1
  324. package/dist/chunks/{ArrowLeft-2f9b9323.cjs.map → ArrowLeft-3KC2k3tR.cjs.map} +1 -1
  325. package/dist/chunks/{ArrowLeft-3779ba88.mjs → ArrowLeft-buaCjhfr.mjs} +1 -1
  326. package/dist/chunks/{ArrowLeft-3779ba88.mjs.map → ArrowLeft-buaCjhfr.mjs.map} +1 -1
  327. package/dist/chunks/{ArrowRight-74a9fcb2.mjs → ArrowRight-4p6gv-9o.mjs} +1 -1
  328. package/dist/chunks/{ArrowRight-74a9fcb2.mjs.map → ArrowRight-4p6gv-9o.mjs.map} +1 -1
  329. package/dist/chunks/{ArrowRight-7315f6c1.cjs → ArrowRight-uEMed4kl.cjs} +1 -1
  330. package/dist/chunks/{ArrowRight-7315f6c1.cjs.map → ArrowRight-uEMed4kl.cjs.map} +1 -1
  331. package/dist/chunks/{Check-be8cd6af.cjs → Check-5uKO4aXx.cjs} +1 -1
  332. package/dist/chunks/{Check-be8cd6af.cjs.map → Check-5uKO4aXx.cjs.map} +1 -1
  333. package/dist/chunks/{Check-2ea0a88a.mjs → Check-FObi_cEO.mjs} +1 -1
  334. package/dist/chunks/{Check-2ea0a88a.mjs.map → Check-FObi_cEO.mjs.map} +1 -1
  335. package/dist/chunks/{ChevronDown-a72d365d.mjs → ChevronDown-TbRvziNU.mjs} +1 -1
  336. package/dist/chunks/{ChevronDown-a72d365d.mjs.map → ChevronDown-TbRvziNU.mjs.map} +1 -1
  337. package/dist/chunks/{ChevronDown-dc32e51d.cjs → ChevronDown-rdCNNu7u.cjs} +1 -1
  338. package/dist/chunks/{ChevronDown-dc32e51d.cjs.map → ChevronDown-rdCNNu7u.cjs.map} +1 -1
  339. package/dist/chunks/{ChevronRight-1a6a6cf2.mjs → ChevronRight-XOmSMmxA.mjs} +1 -1
  340. package/dist/chunks/{ChevronRight-1a6a6cf2.mjs.map → ChevronRight-XOmSMmxA.mjs.map} +1 -1
  341. package/dist/chunks/{ChevronRight-a4c1e0d3.cjs → ChevronRight-bp7fT1r7.cjs} +1 -1
  342. package/dist/chunks/{ChevronRight-a4c1e0d3.cjs.map → ChevronRight-bp7fT1r7.cjs.map} +1 -1
  343. package/dist/chunks/{Close-271f72e2.mjs → Close-5Hzp7J3v.mjs} +1 -1
  344. package/dist/chunks/{Close-271f72e2.mjs.map → Close-5Hzp7J3v.mjs.map} +1 -1
  345. package/dist/chunks/{Close-98cb6f12.cjs → Close-QFLrdRdG.cjs} +1 -1
  346. package/dist/chunks/{Close-98cb6f12.cjs.map → Close-QFLrdRdG.cjs.map} +1 -1
  347. package/dist/chunks/{DotsHorizontal-0ee7d901.mjs → DotsHorizontal-NssXDZGM.mjs} +1 -1
  348. package/dist/chunks/{DotsHorizontal-0ee7d901.mjs.map → DotsHorizontal-NssXDZGM.mjs.map} +1 -1
  349. package/dist/chunks/{DotsHorizontal-ac96129a.cjs → DotsHorizontal-dlN1WvqM.cjs} +1 -1
  350. package/dist/chunks/{DotsHorizontal-ac96129a.cjs.map → DotsHorizontal-dlN1WvqM.cjs.map} +1 -1
  351. package/dist/chunks/{GenColors-7495e6f6.cjs → GenColors-6ePwbl4k.cjs} +23 -18
  352. package/dist/chunks/GenColors-6ePwbl4k.cjs.map +1 -0
  353. package/dist/chunks/{GenColors-5c054042.mjs → GenColors-OwQiytMp.mjs} +16 -11
  354. package/dist/chunks/GenColors-OwQiytMp.mjs.map +1 -0
  355. package/dist/chunks/{GenRandomId-c214d235.cjs.map → GenRandomId-ULxaMkkr.cjs.map} +1 -1
  356. package/dist/chunks/{GenRandomId-cb9ccebe.mjs.map → GenRandomId-VodkdWbp.mjs.map} +1 -1
  357. package/dist/chunks/{Linkify-39f20c9a.mjs.map → Linkify-V7PfCeZ8.mjs.map} +1 -1
  358. package/dist/chunks/{Linkify-40cdd635.cjs.map → Linkify-f3s3nAe_.cjs.map} +1 -1
  359. package/dist/chunks/NcActionButtonGroup-qXVHIy0a.mjs +50 -0
  360. package/dist/chunks/NcActionButtonGroup-qXVHIy0a.mjs.map +1 -0
  361. package/dist/chunks/NcActionButtonGroup-wvQESxxh.cjs +45 -0
  362. package/dist/chunks/NcActionButtonGroup-wvQESxxh.cjs.map +1 -0
  363. package/dist/chunks/NcActionInput-2mvb7ZnC.cjs +234 -0
  364. package/dist/chunks/NcActionInput-2mvb7ZnC.cjs.map +1 -0
  365. package/dist/chunks/NcActionInput-Vdsm4Jt5.mjs +244 -0
  366. package/dist/chunks/NcActionInput-Vdsm4Jt5.mjs.map +1 -0
  367. package/dist/chunks/NcActions-4ml5sv6P.cjs +498 -0
  368. package/dist/chunks/NcActions-4ml5sv6P.cjs.map +1 -0
  369. package/dist/chunks/NcActions-5K-qjttC.mjs +506 -0
  370. package/dist/chunks/NcActions-5K-qjttC.mjs.map +1 -0
  371. package/dist/chunks/NcAppContent-agTfSSHS.mjs +231 -0
  372. package/dist/chunks/NcAppContent-agTfSSHS.mjs.map +1 -0
  373. package/dist/chunks/NcAppContent-kSymH_mo.cjs +221 -0
  374. package/dist/chunks/NcAppContent-kSymH_mo.cjs.map +1 -0
  375. package/dist/chunks/NcAppNavigation-biQcPFmk.mjs +122 -0
  376. package/dist/chunks/NcAppNavigation-biQcPFmk.mjs.map +1 -0
  377. package/dist/chunks/NcAppNavigation-rSC0k8c6.cjs +113 -0
  378. package/dist/chunks/NcAppNavigation-rSC0k8c6.cjs.map +1 -0
  379. package/dist/chunks/NcAppNavigationCaption-E3tdVsYJ.mjs +47 -0
  380. package/dist/chunks/NcAppNavigationCaption-E3tdVsYJ.mjs.map +1 -0
  381. package/dist/chunks/NcAppNavigationCaption-Mugp6fsR.cjs +43 -0
  382. package/dist/chunks/NcAppNavigationCaption-Mugp6fsR.cjs.map +1 -0
  383. package/dist/chunks/NcAppNavigationItem-CzK_gg7C.mjs +508 -0
  384. package/dist/chunks/NcAppNavigationItem-CzK_gg7C.mjs.map +1 -0
  385. package/dist/chunks/NcAppNavigationItem-r0MUwPP7.cjs +496 -0
  386. package/dist/chunks/NcAppNavigationItem-r0MUwPP7.cjs.map +1 -0
  387. package/dist/chunks/NcAppNavigationNewItem-IYhRBzud.cjs +86 -0
  388. package/dist/chunks/NcAppNavigationNewItem-IYhRBzud.cjs.map +1 -0
  389. package/dist/chunks/NcAppNavigationNewItem-X4Ac8vym.mjs +91 -0
  390. package/dist/chunks/NcAppNavigationNewItem-X4Ac8vym.mjs.map +1 -0
  391. package/dist/chunks/NcAppNavigationSettings-0hLCj-s5.mjs +105 -0
  392. package/dist/chunks/NcAppNavigationSettings-0hLCj-s5.mjs.map +1 -0
  393. package/dist/chunks/NcAppNavigationSettings-tvlinWey.cjs +102 -0
  394. package/dist/chunks/NcAppNavigationSettings-tvlinWey.cjs.map +1 -0
  395. package/dist/chunks/{NcAppNavigationToggle-0bc638a8.mjs → NcAppNavigationToggle-RXyDbzmn.mjs} +16 -17
  396. package/dist/chunks/{NcAppNavigationToggle-0bc638a8.mjs.map → NcAppNavigationToggle-RXyDbzmn.mjs.map} +1 -1
  397. package/dist/chunks/NcAppNavigationToggle-ZTz_EO18.cjs +109 -0
  398. package/dist/chunks/{NcAppNavigationToggle-6d192bea.cjs.map → NcAppNavigationToggle-ZTz_EO18.cjs.map} +1 -1
  399. package/dist/chunks/NcAppSettingsDialog-2tyARsR0.cjs +176 -0
  400. package/dist/chunks/NcAppSettingsDialog-2tyARsR0.cjs.map +1 -0
  401. package/dist/chunks/NcAppSettingsDialog-8HAKz-0l.mjs +184 -0
  402. package/dist/chunks/NcAppSettingsDialog-8HAKz-0l.mjs.map +1 -0
  403. package/dist/chunks/NcAppSidebar-PMmg9vsl.cjs +547 -0
  404. package/dist/chunks/NcAppSidebar-PMmg9vsl.cjs.map +1 -0
  405. package/dist/chunks/NcAppSidebar-qaRnOe4Y.mjs +565 -0
  406. package/dist/chunks/NcAppSidebar-qaRnOe4Y.mjs.map +1 -0
  407. package/dist/chunks/{index-309426ff.mjs → NcAvatar-5DJP61Ka.mjs} +73 -145
  408. package/dist/chunks/NcAvatar-5DJP61Ka.mjs.map +1 -0
  409. package/dist/chunks/{index-693e993c.cjs → NcAvatar-YQujzmop.cjs} +56 -128
  410. package/dist/chunks/NcAvatar-YQujzmop.cjs.map +1 -0
  411. package/dist/chunks/NcBreadcrumb-3Ez2uWmp.cjs +172 -0
  412. package/dist/chunks/NcBreadcrumb-3Ez2uWmp.cjs.map +1 -0
  413. package/dist/chunks/NcBreadcrumb-C2oZ_vji.mjs +179 -0
  414. package/dist/chunks/NcBreadcrumb-C2oZ_vji.mjs.map +1 -0
  415. package/dist/chunks/NcBreadcrumbs-H8ec0ouN.cjs +407 -0
  416. package/dist/chunks/NcBreadcrumbs-H8ec0ouN.cjs.map +1 -0
  417. package/dist/chunks/NcBreadcrumbs-tq1eD4Hk.mjs +418 -0
  418. package/dist/chunks/NcBreadcrumbs-tq1eD4Hk.mjs.map +1 -0
  419. package/dist/chunks/NcCheckboxRadioSwitch-BiREcGAk.mjs +607 -0
  420. package/dist/chunks/NcCheckboxRadioSwitch-BiREcGAk.mjs.map +1 -0
  421. package/dist/chunks/NcCheckboxRadioSwitch-xEweFZs1.cjs +603 -0
  422. package/dist/chunks/NcCheckboxRadioSwitch-xEweFZs1.cjs.map +1 -0
  423. package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_2603be83_lang-MzKjkB0t.mjs +3 -0
  424. package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_2603be83_lang-MzKjkB0t.mjs.map +1 -0
  425. package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_2603be83_lang-hGgZcPUX.cjs +3 -0
  426. package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_2603be83_lang-hGgZcPUX.cjs.map +1 -0
  427. package/dist/chunks/NcColorPicker-2IJNZMe-.cjs +161 -0
  428. package/dist/chunks/NcColorPicker-2IJNZMe-.cjs.map +1 -0
  429. package/dist/chunks/NcColorPicker-H0rZhQxw.mjs +172 -0
  430. package/dist/chunks/NcColorPicker-H0rZhQxw.mjs.map +1 -0
  431. package/dist/chunks/NcContent-ZgOMyq2k.cjs +123 -0
  432. package/dist/chunks/NcContent-ZgOMyq2k.cjs.map +1 -0
  433. package/dist/chunks/NcContent-lWYIO3gy.mjs +131 -0
  434. package/dist/chunks/NcContent-lWYIO3gy.mjs.map +1 -0
  435. package/dist/chunks/NcDashboardWidget-hQn58Jv6.mjs +141 -0
  436. package/dist/chunks/NcDashboardWidget-hQn58Jv6.mjs.map +1 -0
  437. package/dist/chunks/NcDashboardWidget-j44iStpo.cjs +134 -0
  438. package/dist/chunks/NcDashboardWidget-j44iStpo.cjs.map +1 -0
  439. package/dist/chunks/NcDashboardWidgetItem-Yp4ii3At.mjs +143 -0
  440. package/dist/chunks/NcDashboardWidgetItem-Yp4ii3At.mjs.map +1 -0
  441. package/dist/chunks/NcDashboardWidgetItem-f4Y_DBsU.cjs +137 -0
  442. package/dist/chunks/NcDashboardWidgetItem-f4Y_DBsU.cjs.map +1 -0
  443. package/dist/chunks/NcDateTime-1ZGz6Hwu.cjs +142 -0
  444. package/dist/chunks/NcDateTime-1ZGz6Hwu.cjs.map +1 -0
  445. package/dist/chunks/NcDateTime-sBcbqRB6.mjs +146 -0
  446. package/dist/chunks/NcDateTime-sBcbqRB6.mjs.map +1 -0
  447. package/dist/chunks/NcDialog-1Nrs9x8z.mjs +214 -0
  448. package/dist/chunks/NcDialog-1Nrs9x8z.mjs.map +1 -0
  449. package/dist/chunks/NcDialog-k6iHgTGm.cjs +206 -0
  450. package/dist/chunks/NcDialog-k6iHgTGm.cjs.map +1 -0
  451. package/dist/chunks/NcDialogButton-37xKCh_l.cjs +68 -0
  452. package/dist/chunks/NcDialogButton-37xKCh_l.cjs.map +1 -0
  453. package/dist/chunks/NcDialogButton-O4JZ53Dj.mjs +73 -0
  454. package/dist/chunks/NcDialogButton-O4JZ53Dj.mjs.map +1 -0
  455. package/dist/chunks/NcEmojiPicker--8moif3g.mjs +249 -0
  456. package/dist/chunks/NcEmojiPicker--8moif3g.mjs.map +1 -0
  457. package/dist/chunks/NcEmojiPicker-gGgrlLAJ.cjs +238 -0
  458. package/dist/chunks/NcEmojiPicker-gGgrlLAJ.cjs.map +1 -0
  459. package/dist/chunks/NcHeaderMenu-5dnFFhRA.cjs +183 -0
  460. package/dist/chunks/NcHeaderMenu-5dnFFhRA.cjs.map +1 -0
  461. package/dist/chunks/NcHeaderMenu-ePmuT5Kz.mjs +190 -0
  462. package/dist/chunks/NcHeaderMenu-ePmuT5Kz.mjs.map +1 -0
  463. package/dist/chunks/NcIconSvgWrapper-P-GkSjTH.mjs +85 -0
  464. package/dist/chunks/NcIconSvgWrapper-P-GkSjTH.mjs.map +1 -0
  465. package/dist/chunks/NcIconSvgWrapper-_lgitSfS.cjs +80 -0
  466. package/dist/chunks/NcIconSvgWrapper-_lgitSfS.cjs.map +1 -0
  467. package/dist/chunks/{NcInputConfirmCancel-a08c5cb4.mjs → NcInputConfirmCancel-HrSwS4LK.mjs} +12 -12
  468. package/dist/chunks/{NcInputConfirmCancel-a08c5cb4.mjs.map → NcInputConfirmCancel-HrSwS4LK.mjs.map} +1 -1
  469. package/dist/chunks/NcInputConfirmCancel-q4IYDSKH.cjs +91 -0
  470. package/dist/chunks/{NcInputConfirmCancel-b99898db.cjs.map → NcInputConfirmCancel-q4IYDSKH.cjs.map} +1 -1
  471. package/dist/chunks/NcListItem-_P2bxfeP.mjs +248 -0
  472. package/dist/chunks/NcListItem-_P2bxfeP.mjs.map +1 -0
  473. package/dist/chunks/NcListItem-wsOnBEF3.cjs +242 -0
  474. package/dist/chunks/NcListItem-wsOnBEF3.cjs.map +1 -0
  475. package/dist/chunks/NcListItemIcon-65Rgi-AZ.cjs +160 -0
  476. package/dist/chunks/NcListItemIcon-65Rgi-AZ.cjs.map +1 -0
  477. package/dist/chunks/NcListItemIcon-IXrbZUKU.mjs +164 -0
  478. package/dist/chunks/NcListItemIcon-IXrbZUKU.mjs.map +1 -0
  479. package/dist/chunks/NcPasswordField-XvXblBeQ.cjs +229 -0
  480. package/dist/chunks/NcPasswordField-XvXblBeQ.cjs.map +1 -0
  481. package/dist/chunks/NcPasswordField-kJ1PZotd.mjs +238 -0
  482. package/dist/chunks/NcPasswordField-kJ1PZotd.mjs.map +1 -0
  483. package/dist/chunks/NcPopover--SjyNre9.cjs +211 -0
  484. package/dist/chunks/NcPopover--SjyNre9.cjs.map +1 -0
  485. package/dist/chunks/NcPopover-yyItaFC6.mjs +218 -0
  486. package/dist/chunks/NcPopover-yyItaFC6.mjs.map +1 -0
  487. package/dist/chunks/NcProgressBar-hQCFE5H3.mjs +99 -0
  488. package/dist/chunks/NcProgressBar-hQCFE5H3.mjs.map +1 -0
  489. package/dist/chunks/NcProgressBar-yrdD1jxU.cjs +95 -0
  490. package/dist/chunks/NcProgressBar-yrdD1jxU.cjs.map +1 -0
  491. package/dist/chunks/NcRelatedResourcesPanel-1nj1tk0J.mjs +205 -0
  492. package/dist/chunks/NcRelatedResourcesPanel-1nj1tk0J.mjs.map +1 -0
  493. package/dist/chunks/NcRelatedResourcesPanel-KxXrRko3.cjs +199 -0
  494. package/dist/chunks/NcRelatedResourcesPanel-KxXrRko3.cjs.map +1 -0
  495. package/dist/chunks/NcRichContenteditable-A0FFbptl.cjs +504 -0
  496. package/dist/chunks/NcRichContenteditable-A0FFbptl.cjs.map +1 -0
  497. package/dist/chunks/NcRichContenteditable-VzFXqSYH.mjs +515 -0
  498. package/dist/chunks/NcRichContenteditable-VzFXqSYH.mjs.map +1 -0
  499. package/dist/chunks/{NcRichText-f729896c.cjs → NcRichText-N44WJqzt.cjs} +112 -71
  500. package/dist/chunks/NcRichText-N44WJqzt.cjs.map +1 -0
  501. package/dist/chunks/{NcRichText-e4bf7767.mjs → NcRichText-YSUTWw6M.mjs} +125 -81
  502. package/dist/chunks/NcRichText-YSUTWw6M.mjs.map +1 -0
  503. package/dist/chunks/NcSavingIndicatorIcon-IqoMFcDK.mjs +62 -0
  504. package/dist/chunks/NcSavingIndicatorIcon-IqoMFcDK.mjs.map +1 -0
  505. package/dist/chunks/NcSavingIndicatorIcon-wcQ0mBIL.cjs +59 -0
  506. package/dist/chunks/NcSavingIndicatorIcon-wcQ0mBIL.cjs.map +1 -0
  507. package/dist/chunks/NcSelect-H-xyiCqP.cjs +462 -0
  508. package/dist/chunks/NcSelect-H-xyiCqP.cjs.map +1 -0
  509. package/dist/chunks/NcSelect-roYZ16y8.mjs +474 -0
  510. package/dist/chunks/NcSelect-roYZ16y8.mjs.map +1 -0
  511. package/dist/chunks/NcSelectTags-3BfQQNLj.mjs +267 -0
  512. package/dist/chunks/NcSelectTags-3BfQQNLj.mjs.map +1 -0
  513. package/dist/chunks/NcSelectTags-iuvfaq_W.cjs +261 -0
  514. package/dist/chunks/NcSelectTags-iuvfaq_W.cjs.map +1 -0
  515. package/dist/chunks/NcSettingsInputText-JHuxEb64.cjs +91 -0
  516. package/dist/chunks/NcSettingsInputText-JHuxEb64.cjs.map +1 -0
  517. package/dist/chunks/NcSettingsInputText-RH5qyxcD.mjs +95 -0
  518. package/dist/chunks/NcSettingsInputText-RH5qyxcD.mjs.map +1 -0
  519. package/dist/chunks/NcSettingsSection-dsoWc5to.cjs +95 -0
  520. package/dist/chunks/NcSettingsSection-dsoWc5to.cjs.map +1 -0
  521. package/dist/chunks/NcSettingsSection-u3WizmVu.mjs +98 -0
  522. package/dist/chunks/NcSettingsSection-u3WizmVu.mjs.map +1 -0
  523. package/dist/chunks/{NcSettingsSelectGroup-ecc8bc5a.mjs → NcSettingsSelectGroup-l7ImtXiI.mjs} +5 -5
  524. package/dist/chunks/{NcSettingsSelectGroup-ecc8bc5a.mjs.map → NcSettingsSelectGroup-l7ImtXiI.mjs.map} +1 -1
  525. package/dist/chunks/{NcSettingsSelectGroup-b065ffc8.cjs → NcSettingsSelectGroup-obOOSE0Z.cjs} +9 -9
  526. package/dist/chunks/{NcSettingsSelectGroup-b065ffc8.cjs.map → NcSettingsSelectGroup-obOOSE0Z.cjs.map} +1 -1
  527. package/dist/chunks/NcTextField-5nK-T1Xg.cjs +140 -0
  528. package/dist/chunks/NcTextField-5nK-T1Xg.cjs.map +1 -0
  529. package/dist/chunks/NcTextField-JlIIeRJa.mjs +146 -0
  530. package/dist/chunks/NcTextField-JlIIeRJa.mjs.map +1 -0
  531. package/dist/chunks/NcTimezonePicker-1NMfD5lj.cjs +7195 -0
  532. package/dist/chunks/NcTimezonePicker-1NMfD5lj.cjs.map +1 -0
  533. package/dist/chunks/NcTimezonePicker-GDJZ0IwA.mjs +7201 -0
  534. package/dist/chunks/NcTimezonePicker-GDJZ0IwA.mjs.map +1 -0
  535. package/dist/chunks/NcUserBubble-ADV-rrgN.cjs +191 -0
  536. package/dist/chunks/NcUserBubble-ADV-rrgN.cjs.map +1 -0
  537. package/dist/chunks/NcUserBubble-HoPxl8_o.mjs +197 -0
  538. package/dist/chunks/NcUserBubble-HoPxl8_o.mjs.map +1 -0
  539. package/dist/chunks/NcUserStatusIcon-WSxqK-Ix.cjs +166 -0
  540. package/dist/chunks/NcUserStatusIcon-WSxqK-Ix.cjs.map +1 -0
  541. package/dist/chunks/NcUserStatusIcon-dgPMbNYQ.mjs +174 -0
  542. package/dist/chunks/NcUserStatusIcon-dgPMbNYQ.mjs.map +1 -0
  543. package/dist/chunks/{ScopeComponent-b039a43c.mjs → ScopeComponent-8lJfv9VF.mjs} +4 -4
  544. package/dist/chunks/{ScopeComponent-b039a43c.mjs.map → ScopeComponent-8lJfv9VF.mjs.map} +1 -1
  545. package/dist/chunks/{ScopeComponent-06c558d3.cjs → ScopeComponent-d_TBKnQk.cjs} +4 -4
  546. package/dist/chunks/{ScopeComponent-06c558d3.cjs.map → ScopeComponent-d_TBKnQk.cjs.map} +1 -1
  547. package/dist/chunks/_l10n-RVZyA63y.cjs +64 -0
  548. package/dist/chunks/_l10n-RVZyA63y.cjs.map +1 -0
  549. package/dist/chunks/_l10n-gZppkly8.mjs +66 -0
  550. package/dist/chunks/_l10n-gZppkly8.mjs.map +1 -0
  551. package/dist/chunks/_plugin-vue2_normalizer-DCfUPqga.cjs.map +1 -0
  552. package/dist/chunks/_plugin-vue2_normalizer-u6G_3nkj.mjs.map +1 -0
  553. package/dist/chunks/{actionGlobal-9e29e11b.cjs → actionGlobal-_f-PhW84.cjs} +3 -7
  554. package/dist/chunks/actionGlobal-_f-PhW84.cjs.map +1 -0
  555. package/dist/chunks/{actionGlobal-8c1c28c9.mjs → actionGlobal-ejpd0zqm.mjs} +3 -7
  556. package/dist/chunks/actionGlobal-ejpd0zqm.mjs.map +1 -0
  557. package/dist/chunks/{actionText-123f26b0.mjs → actionText-AoAs4kqP.mjs} +6 -2
  558. package/dist/chunks/{actionText-e450809c.cjs.map → actionText-AoAs4kqP.mjs.map} +1 -1
  559. package/dist/chunks/{actionText-e450809c.cjs → actionText-pGrMQtZ3.cjs} +6 -2
  560. package/dist/chunks/{actionText-123f26b0.mjs.map → actionText-pGrMQtZ3.cjs.map} +1 -1
  561. package/dist/chunks/emoji-mJIuLpNR.cjs +58 -0
  562. package/dist/chunks/emoji-mJIuLpNR.cjs.map +1 -0
  563. package/dist/chunks/emoji-tllD0Rvt.mjs +61 -0
  564. package/dist/chunks/emoji-tllD0Rvt.mjs.map +1 -0
  565. package/dist/chunks/{focusTrap-5d0f71d4.mjs.map → focusTrap-Py2bQ9-r.mjs.map} +1 -1
  566. package/dist/chunks/{focusTrap-14985831.cjs.map → focusTrap-n3H52LOw.cjs.map} +1 -1
  567. package/dist/chunks/{index-20a9ace9.mjs → index-2phCrsSH.mjs} +1 -1
  568. package/dist/chunks/{index-20a9ace9.mjs.map → index-2phCrsSH.mjs.map} +1 -1
  569. package/dist/chunks/{index-4398f925.cjs → index-AX_b-FPF.cjs} +2 -1
  570. package/dist/chunks/{index-4398f925.cjs.map → index-AX_b-FPF.cjs.map} +1 -1
  571. package/dist/chunks/{index-e894376a.cjs → index-FO4BaGaF.cjs} +1 -1
  572. package/dist/chunks/{index-e894376a.cjs.map → index-FO4BaGaF.cjs.map} +1 -1
  573. package/dist/chunks/{index-5f2a5f57.mjs → index-KrMGGc7j.mjs} +3 -2
  574. package/dist/chunks/{index-5f2a5f57.mjs.map → index-KrMGGc7j.mjs.map} +1 -1
  575. package/dist/chunks/{logger-3612e664.mjs.map → logger-3m1eQsSo.mjs.map} +1 -1
  576. package/dist/chunks/{logger-4998b668.cjs.map → logger-G6OKp5ly.cjs.map} +1 -1
  577. package/dist/chunks/{referencePickerModal-12fa2ad0.cjs → referencePickerModal-byTgSeys.cjs} +152 -170
  578. package/dist/chunks/{referencePickerModal-12fa2ad0.cjs.map → referencePickerModal-byTgSeys.cjs.map} +1 -1
  579. package/dist/chunks/{referencePickerModal-12935fb3.mjs → referencePickerModal-tEVbhwha.mjs} +171 -189
  580. package/dist/chunks/{referencePickerModal-12935fb3.mjs.map → referencePickerModal-tEVbhwha.mjs.map} +1 -1
  581. package/dist/chunks/usernameToColor-LY-6e04n.mjs +41 -0
  582. package/dist/chunks/usernameToColor-LY-6e04n.mjs.map +1 -0
  583. package/dist/chunks/usernameToColor-ty7b2Xom.cjs +39 -0
  584. package/dist/chunks/usernameToColor-ty7b2Xom.cjs.map +1 -0
  585. package/dist/functions/emoji/emoji.d.ts +50 -0
  586. package/dist/{Functions/emoji.mjs → functions/emoji/index.d.ts} +1 -16
  587. package/dist/index.cjs +163 -157
  588. package/dist/index.cjs.map +1 -1
  589. package/dist/index.mjs +157 -149
  590. package/dist/index.mjs.map +1 -1
  591. package/dist/utils/UserStatus.d.ts +1 -3
  592. package/package.json +6 -4
  593. package/dist/Functions/emoji.cjs +0 -36
  594. package/dist/Functions/emoji.cjs.map +0 -1
  595. package/dist/Functions/emoji.mjs.map +0 -1
  596. package/dist/chunks/GenColors-5c054042.mjs.map +0 -1
  597. package/dist/chunks/GenColors-7495e6f6.cjs.map +0 -1
  598. package/dist/chunks/NcAppNavigationToggle-6d192bea.cjs +0 -110
  599. package/dist/chunks/NcInputConfirmCancel-b99898db.cjs +0 -91
  600. package/dist/chunks/NcRichText-e4bf7767.mjs.map +0 -1
  601. package/dist/chunks/NcRichText-f729896c.cjs.map +0 -1
  602. package/dist/chunks/_l10n-72c5e29e.cjs +0 -62
  603. package/dist/chunks/_l10n-72c5e29e.cjs.map +0 -1
  604. package/dist/chunks/_l10n-f5af5269.mjs +0 -64
  605. package/dist/chunks/_l10n-f5af5269.mjs.map +0 -1
  606. package/dist/chunks/_plugin-vue2_normalizer-71e2aa87.mjs.map +0 -1
  607. package/dist/chunks/_plugin-vue2_normalizer-7f9efb60.cjs.map +0 -1
  608. package/dist/chunks/actionGlobal-8c1c28c9.mjs.map +0 -1
  609. package/dist/chunks/actionGlobal-9e29e11b.cjs.map +0 -1
  610. package/dist/chunks/index-309426ff.mjs.map +0 -1
  611. package/dist/chunks/index-693e993c.cjs.map +0 -1
  612. /package/dist/assets/{index-418d4e87.css → NcActionCaption-afJqyJO6.css} +0 -0
  613. /package/dist/assets/{index-018895f7.css → NcActionSeparator-l98xWbiL.css} +0 -0
  614. /package/dist/assets/{index-fc61f2d8.css → NcAppNavigationIconBullet-Nf3ARMLv.css} +0 -0
  615. /package/dist/assets/{index-0ac09203.css → NcAppNavigationNew-joyd78FM.css} +0 -0
  616. /package/dist/assets/{index-f78bd735.css → NcAppNavigationSettings-Jx_6RpSn.css} +0 -0
  617. /package/dist/assets/{index-76dd9f11.css → NcAppNavigationSpacer-MfL8GeCN.css} +0 -0
  618. /package/dist/assets/{NcAppNavigationToggle-48c375e8.css → NcAppNavigationToggle-upUgYNtL.css} +0 -0
  619. /package/dist/assets/{index-1f25a3c0.css → NcAppSettingsSection-ahfdhix_.css} +0 -0
  620. /package/dist/assets/{index-2d5cf6b2.css → NcAppSidebar-iU8Zp4Qk.css} +0 -0
  621. /package/dist/assets/{index-77a548be.css → NcAppSidebarTab-Phau6edJ.css} +0 -0
  622. /package/dist/assets/{index-17673ea1.css → NcCounterBubble-rgkmqN46.css} +0 -0
  623. /package/dist/assets/{index-6416f636.css → NcDashboardWidget-01deRW9Z.css} +0 -0
  624. /package/dist/assets/{index-e7eadba7.css → NcDashboardWidgetItem-S7fELANA.css} +0 -0
  625. /package/dist/assets/{index-8b327013.css → NcDateTimePickerNative-2pQS5L0H.css} +0 -0
  626. /package/dist/assets/{index-a2b51bce.css → NcEllipsisedOption-eoI10kvc.css} +0 -0
  627. /package/dist/assets/{index-c239a2fc.css → NcEmptyContent-pSz7F6Oe.css} +0 -0
  628. /package/dist/assets/{index-8aa4712e.css → NcGuestContent-mGGTzI2_.css} +0 -0
  629. /package/dist/assets/{NcInputConfirmCancel-45d1d76b.css → NcInputConfirmCancel-ks8z8dIn.css} +0 -0
  630. /package/dist/assets/{index-f24e102f.css → NcListItem-xcW2PRrk.css} +0 -0
  631. /package/dist/assets/{index-6f721577.css → NcListItemIcon-PQ2s6ZqX.css} +0 -0
  632. /package/dist/assets/{index-b8f13a1f.css → NcLoadingIcon-hZn7TJM8.css} +0 -0
  633. /package/dist/assets/{NcMentionBubble-6e887c5f.css → NcMentionBubble-2OXF_uEJ.css} +0 -0
  634. /package/dist/assets/{index-400b48a6.css → NcNoteCard-OTfZqVvP.css} +0 -0
  635. /package/dist/assets/{index-4ebacc78.css → NcPopover-MK4GcuPY.css} +0 -0
  636. /package/dist/assets/{index-6c47e88a.css → NcSettingsInputText-MPi6a3Yy.css} +0 -0
  637. /package/dist/assets/{NcSettingsSelectGroup-a29e2156.css → NcSettingsSelectGroup-_Jpb8yE3.css} +0 -0
  638. /package/dist/assets/{index-d211cae8.css → Tooltip-wOLIuz0Q.css} +0 -0
  639. /package/dist/chunks/{GenRandomId-c214d235.cjs → GenRandomId-ULxaMkkr.cjs} +0 -0
  640. /package/dist/chunks/{GenRandomId-cb9ccebe.mjs → GenRandomId-VodkdWbp.mjs} +0 -0
  641. /package/dist/chunks/{Linkify-39f20c9a.mjs → Linkify-V7PfCeZ8.mjs} +0 -0
  642. /package/dist/chunks/{Linkify-40cdd635.cjs → Linkify-f3s3nAe_.cjs} +0 -0
  643. /package/dist/chunks/{_plugin-vue2_normalizer-7f9efb60.cjs → _plugin-vue2_normalizer-DCfUPqga.cjs} +0 -0
  644. /package/dist/chunks/{_plugin-vue2_normalizer-71e2aa87.mjs → _plugin-vue2_normalizer-u6G_3nkj.mjs} +0 -0
  645. /package/dist/chunks/{focusTrap-5d0f71d4.mjs → focusTrap-Py2bQ9-r.mjs} +0 -0
  646. /package/dist/chunks/{focusTrap-14985831.cjs → focusTrap-n3H52LOw.cjs} +0 -0
  647. /package/dist/chunks/{logger-3612e664.mjs → logger-3m1eQsSo.mjs} +0 -0
  648. /package/dist/chunks/{logger-4998b668.cjs → logger-G6OKp5ly.cjs} +0 -0
@@ -0,0 +1,231 @@
1
+ import "../assets/NcAppContent-SZz3PTd8.css";
2
+ import l from "../Components/NcButton.mjs";
3
+ import { r as p, y as r, a as c } from "./_l10n-gZppkly8.mjs";
4
+ import "../Directives/Tooltip.mjs";
5
+ import { emit as a } from "@nextcloud/event-bus";
6
+ import { A as u } from "./ArrowRight-4p6gv-9o.mjs";
7
+ import { n as o } from "./_plugin-vue2_normalizer-u6G_3nkj.mjs";
8
+ import { VTooltip as h } from "floating-vue";
9
+ import { useIsMobile as f } from "../Composables/useIsMobile.mjs";
10
+ import { getBuilder as g } from "@nextcloud/browser-storage";
11
+ import { useSwipe as m } from "@vueuse/core";
12
+ import { Pane as d, Splitpanes as _ } from "splitpanes";
13
+ import "splitpanes/dist/splitpanes.css";
14
+ p(r);
15
+ const z = {
16
+ name: "NcAppDetailsToggle",
17
+ directives: {
18
+ tooltip: h
19
+ },
20
+ components: {
21
+ NcButton: l,
22
+ ArrowRight: u
23
+ },
24
+ computed: {
25
+ title() {
26
+ return c("Go back to the list");
27
+ }
28
+ },
29
+ beforeMount() {
30
+ this.toggleAppNavigationButton(!0);
31
+ },
32
+ beforeDestroy() {
33
+ this.toggleAppNavigationButton(!1);
34
+ },
35
+ methods: {
36
+ toggleAppNavigationButton(e = !0) {
37
+ const t = document.querySelector(".app-navigation .app-navigation-toggle");
38
+ t && (t.style.display = e ? "none" : null, e === !0 && a("toggle-navigation", { open: !1 }));
39
+ }
40
+ }
41
+ };
42
+ var S = function() {
43
+ var t = this, i = t._self._c;
44
+ return i("NcButton", { directives: [{ name: "tooltip", rawName: "v-tooltip", value: t.title, expression: "title" }], staticClass: "app-details-toggle", attrs: { "aria-label": t.title }, scopedSlots: t._u([{ key: "icon", fn: function() {
45
+ return [i("ArrowRight", { attrs: { size: 20 } })];
46
+ }, proxy: !0 }]) });
47
+ }, v = [], w = /* @__PURE__ */ o(
48
+ z,
49
+ S,
50
+ v,
51
+ !1,
52
+ null,
53
+ "5244e83e",
54
+ null,
55
+ null
56
+ );
57
+ const C = w.exports, n = g("nextcloud").persist().build(), N = {
58
+ name: "NcAppContent",
59
+ components: {
60
+ NcAppDetailsToggle: C,
61
+ Pane: d,
62
+ Splitpanes: _
63
+ },
64
+ props: {
65
+ /**
66
+ * Allows to disable the control by swipe of the app navigation open state
67
+ */
68
+ allowSwipeNavigation: {
69
+ type: Boolean,
70
+ default: !0
71
+ },
72
+ /**
73
+ * Allows you to set the default width of the resizable list in %
74
+ * Must be between listMinWidth and listMaxWidth
75
+ */
76
+ listSize: {
77
+ type: Number,
78
+ default: 20
79
+ },
80
+ /**
81
+ * Allows you to set the minimum width of the list column in %
82
+ */
83
+ listMinWidth: {
84
+ type: Number,
85
+ default: 15
86
+ },
87
+ /**
88
+ * Allows you to set the maximum width of the list column in %
89
+ */
90
+ listMaxWidth: {
91
+ type: Number,
92
+ default: 40
93
+ },
94
+ /**
95
+ * Specify the config key for the pane config sizes
96
+ * Default is the global var appName if you use the webpack-vue-config
97
+ */
98
+ paneConfigKey: {
99
+ type: String,
100
+ default: ""
101
+ },
102
+ /**
103
+ * When in mobile view, only the list or the details are shown
104
+ * If you provide a list, you need to provide a variable
105
+ * that will be set to true by the user when an element of
106
+ * the list gets selected. The details will then show a back
107
+ * arrow to return to the list that will update this prop to false.
108
+ */
109
+ showDetails: {
110
+ type: Boolean,
111
+ default: !0
112
+ },
113
+ /**
114
+ * Specify the `<h1>` page heading
115
+ */
116
+ pageHeading: {
117
+ type: String,
118
+ default: null
119
+ }
120
+ },
121
+ emits: [
122
+ "update:showDetails",
123
+ "resize:list"
124
+ ],
125
+ setup() {
126
+ return {
127
+ isMobile: f()
128
+ };
129
+ },
130
+ data() {
131
+ return {
132
+ contentHeight: 0,
133
+ hasList: !1,
134
+ swiping: {},
135
+ listPaneSize: this.restorePaneConfig()
136
+ };
137
+ },
138
+ computed: {
139
+ paneConfigID() {
140
+ if (this.paneConfigKey !== "")
141
+ return `pane-list-size-${this.paneConfigKey}`;
142
+ try {
143
+ return `pane-list-size-${appName}`;
144
+ } catch {
145
+ return console.info("[INFO] AppContent:", "falling back to global nextcloud pane config"), "pane-list-size-nextcloud";
146
+ }
147
+ },
148
+ detailsPaneSize() {
149
+ return this.listPaneSize ? 100 - this.listPaneSize : this.paneDefaults.details.size;
150
+ },
151
+ paneDefaults() {
152
+ return {
153
+ list: {
154
+ size: this.listSize,
155
+ min: this.listMinWidth,
156
+ max: this.listMaxWidth
157
+ },
158
+ // set the inverse values of the details column
159
+ // based on the provided (or default) values of the list column
160
+ details: {
161
+ size: 100 - this.listSize,
162
+ min: 100 - this.listMaxWidth,
163
+ max: 100 - this.listMinWidth
164
+ }
165
+ };
166
+ }
167
+ },
168
+ updated() {
169
+ this.checkListSlot();
170
+ },
171
+ mounted() {
172
+ this.allowSwipeNavigation && (this.swiping = m(this.$el, {
173
+ onSwipeEnd: this.handleSwipe
174
+ })), this.checkListSlot(), this.restorePaneConfig();
175
+ },
176
+ methods: {
177
+ /**
178
+ * handle the swipe event
179
+ *
180
+ * @param {TouchEvent} e The touch event
181
+ * @param {import('@vueuse/core').SwipeDirection} direction The swipe direction of the event
182
+ */
183
+ handleSwipe(e, t) {
184
+ Math.abs(this.swiping.lengthX) > 70 && (this.swiping.coordsStart.x < 300 / 2 && t === "right" ? a("toggle-navigation", {
185
+ open: !0
186
+ }) : this.swiping.coordsStart.x < 300 * 1.5 && t === "left" && a("toggle-navigation", {
187
+ open: !1
188
+ }));
189
+ },
190
+ handlePaneResize(e) {
191
+ const t = parseInt(e[0].size, 10);
192
+ n.setItem(this.paneConfigID, JSON.stringify(t)), this.listPaneSize = t, this.$emit("resize:list", { size: t }), console.debug("AppContent pane config", t);
193
+ },
194
+ // $slots is not reactive, we need to update this manually
195
+ checkListSlot() {
196
+ const e = !!this.$slots.list;
197
+ this.hasList !== e && (this.hasList = e);
198
+ },
199
+ // browserStorage is not reactive, we need to update this manually
200
+ restorePaneConfig() {
201
+ const e = parseInt(n.getItem(this.paneConfigID), 10);
202
+ if (!isNaN(e) && e !== this.listPaneSize)
203
+ return console.debug("AppContent pane config", e), this.listPaneSize = e, e;
204
+ },
205
+ /**
206
+ * The user clicked the back arrow from the details view
207
+ */
208
+ hideDetails() {
209
+ this.$emit("update:showDetails", !1);
210
+ }
211
+ }
212
+ };
213
+ var D = function() {
214
+ var t = this, i = t._self._c;
215
+ return i("main", { staticClass: "app-content no-snapper", class: { "app-content--has-list": t.hasList }, attrs: { id: "app-content-vue" } }, [t.pageHeading ? i("h1", { staticClass: "hidden-visually" }, [t._v(" " + t._s(t.pageHeading) + " ")]) : t._e(), t.hasList ? [t.isMobile ? i("div", { staticClass: "app-content-wrapper app-content-wrapper--mobile", class: t.showDetails ? "app-content-wrapper--show-details" : "app-content-wrapper--show-list" }, [t.hasList && t.showDetails ? i("NcAppDetailsToggle", { nativeOn: { click: function(s) {
216
+ return s.stopPropagation(), s.preventDefault(), t.hideDetails.apply(null, arguments);
217
+ } } }) : t._e(), t._t("list"), t._t("default")], 2) : i("div", { staticClass: "app-content-wrapper" }, [i("Splitpanes", { staticClass: "default-theme", on: { resized: t.handlePaneResize } }, [i("Pane", { staticClass: "splitpanes__pane-list", attrs: { size: t.listPaneSize || t.paneDefaults.list.size, "min-size": t.paneDefaults.list.min, "max-size": t.paneDefaults.list.max } }, [t._t("list")], 2), i("Pane", { staticClass: "splitpanes__pane-details", attrs: { size: t.detailsPaneSize, "min-size": t.paneDefaults.details.min, "max-size": t.paneDefaults.details.max } }, [t._t("default")], 2)], 1)], 1)] : t._t("default")], 2);
218
+ }, y = [], P = /* @__PURE__ */ o(
219
+ N,
220
+ D,
221
+ y,
222
+ !1,
223
+ null,
224
+ "27fc3f3a",
225
+ null,
226
+ null
227
+ );
228
+ const F = P.exports;
229
+ export {
230
+ F as N
231
+ };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcAppContent-agTfSSHS.mjs","sources":["../../src/components/NcAppContent/NcAppDetailsToggle.vue","../../src/components/NcAppContent/NcAppContent.vue"],"sourcesContent":["<!--\n - @copyright Copyright (c) 2021 John Molakvoæ <skjnldsv@protonmail.com>\n -\n - @author John Molakvoæ <skjnldsv@protonmail.com>\n -\n - @license GNU AGPL version 3 or any later version\n -\n - This program is free software: you can redistribute it and/or modify\n - it under the terms of the GNU Affero General Public License as\n - published by the Free Software Foundation, either version 3 of the\n - License, or (at your option) any later version.\n -\n - This program is distributed in the hope that it will be useful,\n - but WITHOUT ANY WARRANTY; without even the implied warranty of\n - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n - GNU Affero General Public License for more details.\n -\n - You should have received a copy of the GNU Affero General Public License\n - along with this program. If not, see <http://www.gnu.org/licenses/>.\n -\n -->\n\n<template>\n\t<NcButton v-tooltip=\"title\" :aria-label=\"title\" class=\"app-details-toggle\">\n\t\t<template #icon>\n\t\t\t<ArrowRight :size=\"20\" />\n\t\t</template>\n\t</NcButton>\n</template>\n\n<script>\nimport NcButton from '../NcButton/index.js'\nimport { t } from '../../l10n.js'\nimport Tooltip from '../../directives/Tooltip/index.js'\n\nimport { emit } from '@nextcloud/event-bus'\n\nimport ArrowRight from 'vue-material-design-icons/ArrowRight.vue'\n\nexport default {\n\tname: 'NcAppDetailsToggle',\n\n\tdirectives: {\n\t\ttooltip: Tooltip,\n\t},\n\n\tcomponents: {\n\t\tNcButton,\n\t\tArrowRight,\n\t},\n\n\tcomputed: {\n\t\ttitle() {\n\t\t\treturn t('Go back to the list')\n\t\t},\n\t},\n\n\tbeforeMount() {\n\t\tthis.toggleAppNavigationButton(true)\n\t},\n\n\tbeforeDestroy() {\n\t\tthis.toggleAppNavigationButton(false)\n\t},\n\n\tmethods: {\n\t\ttoggleAppNavigationButton(hide = true) {\n\t\t\tconst appNavigationToggle = document.querySelector('.app-navigation .app-navigation-toggle')\n\t\t\tif (appNavigationToggle) {\n\t\t\t\tappNavigationToggle.style.display = hide ? 'none' : null\n\n\t\t\t\t// If we hide the NavigationToggle, we need to make sure the Navigation is also closed\n\t\t\t\tif (hide === true) {\n\t\t\t\t\temit('toggle-navigation', { open: false })\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.app-details-toggle {\n\tposition: fixed;\n\twidth: $clickable-area;\n\theight: $clickable-area;\n\tpadding: $icon-margin;\n\tcursor: pointer;\n\topacity: .6;\n\ttransform: rotate(180deg);\n\tbackground-color: var(--color-main-background);\n\tz-index: 2000;\n\n\t&:active,\n\t&:hover,\n\t&:focus {\n\t\topacity: 1;\n\t}\n}\n</style>\n","<!--\n - @copyright Copyright (c) 2019 Christoph Wurst <christoph@winzerhof-wurst.at>\n -\n - @author Christoph Wurst <christoph@winzerhof-wurst.at>\n - @author Marco Ambrosini <marcoambrosini@icloud.com>\n - @author John Molakvoæ <skjnldsv@protonmail.com>\n -\n - @license GNU AGPL version 3 or any later version\n -\n - This program is free software: you can redistribute it and/or modify\n - it under the terms of the GNU Affero General Public License as\n - published by the Free Software Foundation, either version 3 of the\n - License, or (at your option) any later version.\n -\n - This program is distributed in the hope that it will be useful,\n - but WITHOUT ANY WARRANTY; without even the implied warranty of\n - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n - GNU Affero General Public License for more details.\n -\n - You should have received a copy of the GNU Affero General Public License\n - along with this program. If not, see <http://www.gnu.org/licenses/>.\n -\n -->\n<docs>\n### General description\n\nThis components provides a wrapper around the main app's content.\n\nSingle-column layouts can just use the default slot. A resizable column\ncan be added by providing content to the named slot `list`.\n\n### CSS variables\nIn the css section some css variables are declared and will be available for\nall the children of the NcAppContent component\n\n### Examples\n\n#### Usage: Single-column content\n```vue\n<template>\n\t<NcAppContent>\n\t\t<h2>Single-column main content</h2>\n\t</NcAppContent>\n</template>\n```\n\n#### Usage: Two resizable columns\n```vue\n<template>\n\t<NcAppContent>\n\t\t<template #list>\n\t\t\t<div>Resizable list content</div>\n\t\t</template>\n\n\t\t<div>Main content</div>\n\t</NcAppContent>\n</template>\n```\n\n#### Overriding Defaults\nThe default, min and max sizes (in percent) of the resizable list column can be overridden.\nThe list size must be between the min and the max width value.\n\n```\n<NcAppContent\n\t:list-size=\"35\"\n\t:list-min-width=\"20\"\n\t:list-max-width=\"45\"\n>...</NcAppContent>\n```\n</docs>\n\n<template>\n\t<main id=\"app-content-vue\" class=\"app-content no-snapper\" :class=\"{ 'app-content--has-list': hasList }\">\n\t\t<h1 v-if=\"pageHeading\" class=\"hidden-visually\">\n\t\t\t{{ pageHeading }}\n\t\t</h1>\n\n\t\t<template v-if=\"hasList\">\n\t\t\t<!-- Mobile view does not allow resizeable panes -->\n\t\t\t<div v-if=\"isMobile\"\n\t\t\t\t:class=\"showDetails ? 'app-content-wrapper--show-details' : 'app-content-wrapper--show-list'\"\n\t\t\t\tclass=\"app-content-wrapper app-content-wrapper--mobile\">\n\t\t\t\t<NcAppDetailsToggle v-if=\"hasList && showDetails\" @click.native.stop.prevent=\"hideDetails\" />\n\n\t\t\t\t<slot name=\"list\" />\n\t\t\t\t<slot />\n\t\t\t</div>\n\n\t\t\t<div v-else class=\"app-content-wrapper\">\n\t\t\t\t<Splitpanes class=\"default-theme\"\n\t\t\t\t\t@resized=\"handlePaneResize\">\n\t\t\t\t\t<Pane class=\"splitpanes__pane-list\"\n\t\t\t\t\t\t:size=\"listPaneSize || paneDefaults.list.size\"\n\t\t\t\t\t\t:min-size=\"paneDefaults.list.min\"\n\t\t\t\t\t\t:max-size=\"paneDefaults.list.max\">\n\t\t\t\t\t\t<!-- @slot Provide a list to the app content -->\n\t\t\t\t\t\t<slot name=\"list\" />\n\t\t\t\t\t</Pane>\n\n\t\t\t\t\t<Pane class=\"splitpanes__pane-details\"\n\t\t\t\t\t\t:size=\"detailsPaneSize\"\n\t\t\t\t\t\t:min-size=\"paneDefaults.details.min\"\n\t\t\t\t\t\t:max-size=\"paneDefaults.details.max\">\n\t\t\t\t\t\t<!-- @slot Provide the main content to the app content -->\n\t\t\t\t\t\t<slot />\n\t\t\t\t\t</Pane>\n\t\t\t\t</Splitpanes>\n\t\t\t</div>\n\t\t</template>\n\n\t\t<!-- @slot Provide the main content to the app content -->\n\t\t<slot v-else />\n\t</main>\n</template>\n\n<script>\nimport NcAppDetailsToggle from './NcAppDetailsToggle.vue'\nimport { useIsMobile } from '../../composables/useIsMobile/index.js'\n\nimport { getBuilder } from '@nextcloud/browser-storage'\nimport { emit } from '@nextcloud/event-bus'\nimport { useSwipe } from '@vueuse/core'\nimport { Splitpanes, Pane } from 'splitpanes'\n\nimport 'splitpanes/dist/splitpanes.css'\n\nconst browserStorage = getBuilder('nextcloud').persist().build()\n\n/**\n * App content container to be used for the main content of your app\n *\n */\nexport default {\n\tname: 'NcAppContent',\n\n\tcomponents: {\n\t\tNcAppDetailsToggle,\n\t\tPane,\n\t\tSplitpanes,\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Allows to disable the control by swipe of the app navigation open state\n\t\t */\n\t\tallowSwipeNavigation: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * Allows you to set the default width of the resizable list in %\n\t\t * Must be between listMinWidth and listMaxWidth\n\t\t */\n\t\tlistSize: {\n\t\t\ttype: Number,\n\t\t\tdefault: 20,\n\t\t},\n\n\t\t/**\n\t\t * Allows you to set the minimum width of the list column in %\n\t\t */\n\t\tlistMinWidth: {\n\t\t\ttype: Number,\n\t\t\tdefault: 15,\n\t\t},\n\n\t\t/**\n\t\t * Allows you to set the maximum width of the list column in %\n\t\t */\n\t\tlistMaxWidth: {\n\t\t\ttype: Number,\n\t\t\tdefault: 40,\n\t\t},\n\n\t\t/**\n\t\t * Specify the config key for the pane config sizes\n\t\t * Default is the global var appName if you use the webpack-vue-config\n\t\t */\n\t\tpaneConfigKey: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * When in mobile view, only the list or the details are shown\n\t\t * If you provide a list, you need to provide a variable\n\t\t * that will be set to true by the user when an element of\n\t\t * the list gets selected. The details will then show a back\n\t\t * arrow to return to the list that will update this prop to false.\n\t\t */\n\t\tshowDetails: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * Specify the `<h1>` page heading\n\t\t */\n\t\tpageHeading: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\t},\n\n\temits: [\n\t\t'update:showDetails',\n\t\t'resize:list',\n\t],\n\n\tsetup() {\n\t\treturn {\n\t\t\tisMobile: useIsMobile(),\n\t\t}\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tcontentHeight: 0,\n\t\t\thasList: false,\n\n\t\t\tswiping: {},\n\t\t\tlistPaneSize: this.restorePaneConfig(),\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tpaneConfigID() {\n\t\t\t// If provided, let's use it\n\t\t\tif (this.paneConfigKey !== '') {\n\t\t\t\treturn `pane-list-size-${this.paneConfigKey}`\n\t\t\t}\n\n\t\t\ttry {\n\t\t\t\t// Using the webpack-vue-config, appName is a global variable\n\t\t\t\t// This will throw a ReferenceError when the global variable is missing\n\t\t\t\t// In that case either you provide paneConfigKey or else it fallback\n\t\t\t\t// to a global storage key\n\t\t\t\treturn `pane-list-size-${appName}`\n\t\t\t} catch (e) {\n\t\t\t\tconsole.info('[INFO] AppContent:', 'falling back to global nextcloud pane config')\n\t\t\t\treturn 'pane-list-size-nextcloud'\n\t\t\t}\n\t\t},\n\n\t\tdetailsPaneSize() {\n\t\t\tif (this.listPaneSize) {\n\t\t\t\treturn 100 - this.listPaneSize\n\t\t\t}\n\t\t\treturn this.paneDefaults.details.size\n\t\t},\n\n\t\tpaneDefaults() {\n\t\t\treturn {\n\t\t\t\tlist: {\n\t\t\t\t\tsize: this.listSize,\n\t\t\t\t\tmin: this.listMinWidth,\n\t\t\t\t\tmax: this.listMaxWidth,\n\t\t\t\t},\n\n\t\t\t\t// set the inverse values of the details column\n\t\t\t\t// based on the provided (or default) values of the list column\n\t\t\t\tdetails: {\n\t\t\t\t\tsize: 100 - this.listSize,\n\t\t\t\t\tmin: 100 - this.listMaxWidth,\n\t\t\t\t\tmax: 100 - this.listMinWidth,\n\t\t\t\t},\n\t\t\t}\n\t\t},\n\t},\n\n\tupdated() {\n\t\tthis.checkListSlot()\n\t},\n\n\tmounted() {\n\t\tif (this.allowSwipeNavigation) {\n\t\t\tthis.swiping = useSwipe(this.$el, {\n\t\t\t\tonSwipeEnd: this.handleSwipe,\n\t\t\t})\n\t\t}\n\n\t\tthis.checkListSlot()\n\t\tthis.restorePaneConfig()\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * handle the swipe event\n\t\t *\n\t\t * @param {TouchEvent} e The touch event\n\t\t * @param {import('@vueuse/core').SwipeDirection} direction The swipe direction of the event\n\t\t */\n\t\thandleSwipe(e, direction) {\n\t\t\tconst minSwipeX = 70\n\t\t\tconst touchZone = 300\n\t\t\tif (Math.abs(this.swiping.lengthX) > minSwipeX) {\n\t\t\t\tif (this.swiping.coordsStart.x < (touchZone / 2) && direction === 'right') {\n\t\t\t\t\temit('toggle-navigation', {\n\t\t\t\t\t\topen: true,\n\t\t\t\t\t})\n\t\t\t\t} else if (this.swiping.coordsStart.x < touchZone * 1.5 && direction === 'left') {\n\t\t\t\t\temit('toggle-navigation', {\n\t\t\t\t\t\topen: false,\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\thandlePaneResize(event) {\n\t\t\tconst listPaneSize = parseInt(event[0].size, 10)\n\t\t\tbrowserStorage.setItem(this.paneConfigID, JSON.stringify(listPaneSize))\n\t\t\tthis.listPaneSize = listPaneSize\n\t\t\t/**\n\t\t\t * Emitted when the list pane is resized by the user\n\t\t\t */\n\t\t\tthis.$emit('resize:list', { size: listPaneSize })\n\t\t\tconsole.debug('AppContent pane config', listPaneSize)\n\t\t},\n\n\t\t// $slots is not reactive, we need to update this manually\n\t\tcheckListSlot() {\n\t\t\tconst hasListSlot = !!this.$slots.list\n\t\t\tif (this.hasList !== hasListSlot) {\n\t\t\t\tthis.hasList = hasListSlot\n\t\t\t}\n\t\t},\n\n\t\t// browserStorage is not reactive, we need to update this manually\n\t\trestorePaneConfig() {\n\t\t\tconst listPaneSize = parseInt(browserStorage.getItem(this.paneConfigID), 10)\n\t\t\tif (!isNaN(listPaneSize) && listPaneSize !== this.listPaneSize) {\n\t\t\t\tconsole.debug('AppContent pane config', listPaneSize)\n\t\t\t\tthis.listPaneSize = listPaneSize\n\t\t\t\treturn listPaneSize\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * The user clicked the back arrow from the details view\n\t\t */\n\t\thideDetails() {\n\t\t\tthis.$emit('update:showDetails', false)\n\t\t},\n\t},\n}\n</script>\n<style lang=\"scss\" scoped>\n\n.app-content {\n\tposition: initial;\n\tz-index: 1000;\n\tflex-basis: 100vw;\n\theight: 100%;\n\t// Overriding server styles TODO: cleanup!\n\tmargin: 0 !important;\n\tbackground-color: var(--color-main-background);\n\tmin-width: 0;\n\n\t&:not(.app-content--has-list) {\n\t\toverflow: auto;\n\t}\n}\n\n.app-content-wrapper {\n\tposition: relative;\n\twidth: 100%;\n\theight: 100%;\n}\n\n// Mobile list/details handling\n.app-content-wrapper--mobile {\n\t&.app-content-wrapper--show-list :deep() {\n\t\t.app-content-list {\n\t\t\tdisplay: flex;\n\t\t}\n\t\t.app-content-details {\n\t\t\tdisplay: none;\n\t\t}\n\t}\n\t&.app-content-wrapper--show-details :deep() {\n\t\t.app-content-list {\n\t\t\tdisplay: none;\n\t\t}\n\t\t.app-content-details {\n\t\t\tdisplay: block;\n\t\t}\n\t}\n}\n\n:deep(.splitpanes.default-theme) {\n\t.app-content-list {\n\t\tmax-width: none;\n\t\t/* Thin scrollbar is hard to catch on resizable columns */\n\t\tscrollbar-width: auto;\n\t}\n\n\t.splitpanes__pane {\n\t\tbackground-color: transparent;\n\t\ttransition: none;\n\n\t\t&-list {\n\t\t\tmin-width: 300px;\n\t\t\tposition: sticky;\n\t\t\ttop: var(--header-height);\n\n\t\t\t@media only screen and (width < $breakpoint-mobile) {\n\t\t\t\tdisplay: none;\n\t\t\t}\n\t\t}\n\n\t\t&-details {\n\t\t\toverflow-y: auto;\n\n\t\t\t@media only screen and (width < $breakpoint-mobile) {\n\t\t\t\tmin-width: 100%;\n\t\t\t}\n\t\t}\n\t}\n\n\t.splitpanes__splitter {\n\t\twidth: 9px;\n\t\tmargin-left: -5px;\n\t\tbackground-color: transparent;\n\t\tborder-left: none;\n\n\t\t&:before,\n\t\t&:after {\n\t\t\tdisplay: none;\n\t\t}\n\t}\n}\n</style>\n"],"names":["_sfc_main$1","VTooltip","NcButton","ArrowRight","t","hide","appNavigationToggle","emit","browserStorage","getBuilder","_sfc_main","NcAppDetailsToggle","Pane","Splitpanes","useIsMobile","useSwipe","direction","event","listPaneSize","hasListSlot"],"mappings":"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"}
@@ -0,0 +1,221 @@
1
+ var b = require("../assets/NcAppContent-SZz3PTd8.css");
2
+ const r = require("../Components/NcButton.cjs"), n = require("./_l10n-RVZyA63y.cjs");
3
+ require("../Directives/Tooltip.cjs");
4
+ const a = require("@nextcloud/event-bus"), u = require("./ArrowRight-uEMed4kl.cjs"), p = require("./_plugin-vue2_normalizer-DCfUPqga.cjs"), c = require("floating-vue"), h = require("../Composables/useIsMobile.cjs"), g = require("@nextcloud/browser-storage"), d = require("@vueuse/core"), o = require("splitpanes");
5
+ require("splitpanes/dist/splitpanes.css");
6
+ n.register(n.t23);
7
+ const f = {
8
+ name: "NcAppDetailsToggle",
9
+ directives: {
10
+ tooltip: c.VTooltip
11
+ },
12
+ components: {
13
+ NcButton: r,
14
+ ArrowRight: u.ArrowRight
15
+ },
16
+ computed: {
17
+ title() {
18
+ return n.t("Go back to the list");
19
+ }
20
+ },
21
+ beforeMount() {
22
+ this.toggleAppNavigationButton(!0);
23
+ },
24
+ beforeDestroy() {
25
+ this.toggleAppNavigationButton(!1);
26
+ },
27
+ methods: {
28
+ toggleAppNavigationButton(t = !0) {
29
+ const e = document.querySelector(".app-navigation .app-navigation-toggle");
30
+ e && (e.style.display = t ? "none" : null, t === !0 && a.emit("toggle-navigation", { open: !1 }));
31
+ }
32
+ }
33
+ };
34
+ var m = function() {
35
+ var e = this, i = e._self._c;
36
+ return i("NcButton", { directives: [{ name: "tooltip", rawName: "v-tooltip", value: e.title, expression: "title" }], staticClass: "app-details-toggle", attrs: { "aria-label": e.title }, scopedSlots: e._u([{ key: "icon", fn: function() {
37
+ return [i("ArrowRight", { attrs: { size: 20 } })];
38
+ }, proxy: !0 }]) });
39
+ }, _ = [], z = /* @__PURE__ */ p.normalizeComponent(
40
+ f,
41
+ m,
42
+ _,
43
+ !1,
44
+ null,
45
+ "5244e83e",
46
+ null,
47
+ null
48
+ );
49
+ const S = z.exports, l = g.getBuilder("nextcloud").persist().build(), w = {
50
+ name: "NcAppContent",
51
+ components: {
52
+ NcAppDetailsToggle: S,
53
+ Pane: o.Pane,
54
+ Splitpanes: o.Splitpanes
55
+ },
56
+ props: {
57
+ /**
58
+ * Allows to disable the control by swipe of the app navigation open state
59
+ */
60
+ allowSwipeNavigation: {
61
+ type: Boolean,
62
+ default: !0
63
+ },
64
+ /**
65
+ * Allows you to set the default width of the resizable list in %
66
+ * Must be between listMinWidth and listMaxWidth
67
+ */
68
+ listSize: {
69
+ type: Number,
70
+ default: 20
71
+ },
72
+ /**
73
+ * Allows you to set the minimum width of the list column in %
74
+ */
75
+ listMinWidth: {
76
+ type: Number,
77
+ default: 15
78
+ },
79
+ /**
80
+ * Allows you to set the maximum width of the list column in %
81
+ */
82
+ listMaxWidth: {
83
+ type: Number,
84
+ default: 40
85
+ },
86
+ /**
87
+ * Specify the config key for the pane config sizes
88
+ * Default is the global var appName if you use the webpack-vue-config
89
+ */
90
+ paneConfigKey: {
91
+ type: String,
92
+ default: ""
93
+ },
94
+ /**
95
+ * When in mobile view, only the list or the details are shown
96
+ * If you provide a list, you need to provide a variable
97
+ * that will be set to true by the user when an element of
98
+ * the list gets selected. The details will then show a back
99
+ * arrow to return to the list that will update this prop to false.
100
+ */
101
+ showDetails: {
102
+ type: Boolean,
103
+ default: !0
104
+ },
105
+ /**
106
+ * Specify the `<h1>` page heading
107
+ */
108
+ pageHeading: {
109
+ type: String,
110
+ default: null
111
+ }
112
+ },
113
+ emits: [
114
+ "update:showDetails",
115
+ "resize:list"
116
+ ],
117
+ setup() {
118
+ return {
119
+ isMobile: h.useIsMobile()
120
+ };
121
+ },
122
+ data() {
123
+ return {
124
+ contentHeight: 0,
125
+ hasList: !1,
126
+ swiping: {},
127
+ listPaneSize: this.restorePaneConfig()
128
+ };
129
+ },
130
+ computed: {
131
+ paneConfigID() {
132
+ if (this.paneConfigKey !== "")
133
+ return `pane-list-size-${this.paneConfigKey}`;
134
+ try {
135
+ return `pane-list-size-${appName}`;
136
+ } catch {
137
+ return console.info("[INFO] AppContent:", "falling back to global nextcloud pane config"), "pane-list-size-nextcloud";
138
+ }
139
+ },
140
+ detailsPaneSize() {
141
+ return this.listPaneSize ? 100 - this.listPaneSize : this.paneDefaults.details.size;
142
+ },
143
+ paneDefaults() {
144
+ return {
145
+ list: {
146
+ size: this.listSize,
147
+ min: this.listMinWidth,
148
+ max: this.listMaxWidth
149
+ },
150
+ // set the inverse values of the details column
151
+ // based on the provided (or default) values of the list column
152
+ details: {
153
+ size: 100 - this.listSize,
154
+ min: 100 - this.listMaxWidth,
155
+ max: 100 - this.listMinWidth
156
+ }
157
+ };
158
+ }
159
+ },
160
+ updated() {
161
+ this.checkListSlot();
162
+ },
163
+ mounted() {
164
+ this.allowSwipeNavigation && (this.swiping = d.useSwipe(this.$el, {
165
+ onSwipeEnd: this.handleSwipe
166
+ })), this.checkListSlot(), this.restorePaneConfig();
167
+ },
168
+ methods: {
169
+ /**
170
+ * handle the swipe event
171
+ *
172
+ * @param {TouchEvent} e The touch event
173
+ * @param {import('@vueuse/core').SwipeDirection} direction The swipe direction of the event
174
+ */
175
+ handleSwipe(t, e) {
176
+ Math.abs(this.swiping.lengthX) > 70 && (this.swiping.coordsStart.x < 300 / 2 && e === "right" ? a.emit("toggle-navigation", {
177
+ open: !0
178
+ }) : this.swiping.coordsStart.x < 300 * 1.5 && e === "left" && a.emit("toggle-navigation", {
179
+ open: !1
180
+ }));
181
+ },
182
+ handlePaneResize(t) {
183
+ const e = parseInt(t[0].size, 10);
184
+ l.setItem(this.paneConfigID, JSON.stringify(e)), this.listPaneSize = e, this.$emit("resize:list", { size: e }), console.debug("AppContent pane config", e);
185
+ },
186
+ // $slots is not reactive, we need to update this manually
187
+ checkListSlot() {
188
+ const t = !!this.$slots.list;
189
+ this.hasList !== t && (this.hasList = t);
190
+ },
191
+ // browserStorage is not reactive, we need to update this manually
192
+ restorePaneConfig() {
193
+ const t = parseInt(l.getItem(this.paneConfigID), 10);
194
+ if (!isNaN(t) && t !== this.listPaneSize)
195
+ return console.debug("AppContent pane config", t), this.listPaneSize = t, t;
196
+ },
197
+ /**
198
+ * The user clicked the back arrow from the details view
199
+ */
200
+ hideDetails() {
201
+ this.$emit("update:showDetails", !1);
202
+ }
203
+ }
204
+ };
205
+ var v = function() {
206
+ var e = this, i = e._self._c;
207
+ return i("main", { staticClass: "app-content no-snapper", class: { "app-content--has-list": e.hasList }, attrs: { id: "app-content-vue" } }, [e.pageHeading ? i("h1", { staticClass: "hidden-visually" }, [e._v(" " + e._s(e.pageHeading) + " ")]) : e._e(), e.hasList ? [e.isMobile ? i("div", { staticClass: "app-content-wrapper app-content-wrapper--mobile", class: e.showDetails ? "app-content-wrapper--show-details" : "app-content-wrapper--show-list" }, [e.hasList && e.showDetails ? i("NcAppDetailsToggle", { nativeOn: { click: function(s) {
208
+ return s.stopPropagation(), s.preventDefault(), e.hideDetails.apply(null, arguments);
209
+ } } }) : e._e(), e._t("list"), e._t("default")], 2) : i("div", { staticClass: "app-content-wrapper" }, [i("Splitpanes", { staticClass: "default-theme", on: { resized: e.handlePaneResize } }, [i("Pane", { staticClass: "splitpanes__pane-list", attrs: { size: e.listPaneSize || e.paneDefaults.list.size, "min-size": e.paneDefaults.list.min, "max-size": e.paneDefaults.list.max } }, [e._t("list")], 2), i("Pane", { staticClass: "splitpanes__pane-details", attrs: { size: e.detailsPaneSize, "min-size": e.paneDefaults.details.min, "max-size": e.paneDefaults.details.max } }, [e._t("default")], 2)], 1)], 1)] : e._t("default")], 2);
210
+ }, C = [], N = /* @__PURE__ */ p.normalizeComponent(
211
+ w,
212
+ v,
213
+ C,
214
+ !1,
215
+ null,
216
+ "27fc3f3a",
217
+ null,
218
+ null
219
+ );
220
+ const D = N.exports;
221
+ exports.NcAppContent = D;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NcAppContent-kSymH_mo.cjs","sources":["../../src/components/NcAppContent/NcAppDetailsToggle.vue","../../src/components/NcAppContent/NcAppContent.vue"],"sourcesContent":["<!--\n - @copyright Copyright (c) 2021 John Molakvoæ <skjnldsv@protonmail.com>\n -\n - @author John Molakvoæ <skjnldsv@protonmail.com>\n -\n - @license GNU AGPL version 3 or any later version\n -\n - This program is free software: you can redistribute it and/or modify\n - it under the terms of the GNU Affero General Public License as\n - published by the Free Software Foundation, either version 3 of the\n - License, or (at your option) any later version.\n -\n - This program is distributed in the hope that it will be useful,\n - but WITHOUT ANY WARRANTY; without even the implied warranty of\n - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n - GNU Affero General Public License for more details.\n -\n - You should have received a copy of the GNU Affero General Public License\n - along with this program. If not, see <http://www.gnu.org/licenses/>.\n -\n -->\n\n<template>\n\t<NcButton v-tooltip=\"title\" :aria-label=\"title\" class=\"app-details-toggle\">\n\t\t<template #icon>\n\t\t\t<ArrowRight :size=\"20\" />\n\t\t</template>\n\t</NcButton>\n</template>\n\n<script>\nimport NcButton from '../NcButton/index.js'\nimport { t } from '../../l10n.js'\nimport Tooltip from '../../directives/Tooltip/index.js'\n\nimport { emit } from '@nextcloud/event-bus'\n\nimport ArrowRight from 'vue-material-design-icons/ArrowRight.vue'\n\nexport default {\n\tname: 'NcAppDetailsToggle',\n\n\tdirectives: {\n\t\ttooltip: Tooltip,\n\t},\n\n\tcomponents: {\n\t\tNcButton,\n\t\tArrowRight,\n\t},\n\n\tcomputed: {\n\t\ttitle() {\n\t\t\treturn t('Go back to the list')\n\t\t},\n\t},\n\n\tbeforeMount() {\n\t\tthis.toggleAppNavigationButton(true)\n\t},\n\n\tbeforeDestroy() {\n\t\tthis.toggleAppNavigationButton(false)\n\t},\n\n\tmethods: {\n\t\ttoggleAppNavigationButton(hide = true) {\n\t\t\tconst appNavigationToggle = document.querySelector('.app-navigation .app-navigation-toggle')\n\t\t\tif (appNavigationToggle) {\n\t\t\t\tappNavigationToggle.style.display = hide ? 'none' : null\n\n\t\t\t\t// If we hide the NavigationToggle, we need to make sure the Navigation is also closed\n\t\t\t\tif (hide === true) {\n\t\t\t\t\temit('toggle-navigation', { open: false })\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.app-details-toggle {\n\tposition: fixed;\n\twidth: $clickable-area;\n\theight: $clickable-area;\n\tpadding: $icon-margin;\n\tcursor: pointer;\n\topacity: .6;\n\ttransform: rotate(180deg);\n\tbackground-color: var(--color-main-background);\n\tz-index: 2000;\n\n\t&:active,\n\t&:hover,\n\t&:focus {\n\t\topacity: 1;\n\t}\n}\n</style>\n","<!--\n - @copyright Copyright (c) 2019 Christoph Wurst <christoph@winzerhof-wurst.at>\n -\n - @author Christoph Wurst <christoph@winzerhof-wurst.at>\n - @author Marco Ambrosini <marcoambrosini@icloud.com>\n - @author John Molakvoæ <skjnldsv@protonmail.com>\n -\n - @license GNU AGPL version 3 or any later version\n -\n - This program is free software: you can redistribute it and/or modify\n - it under the terms of the GNU Affero General Public License as\n - published by the Free Software Foundation, either version 3 of the\n - License, or (at your option) any later version.\n -\n - This program is distributed in the hope that it will be useful,\n - but WITHOUT ANY WARRANTY; without even the implied warranty of\n - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n - GNU Affero General Public License for more details.\n -\n - You should have received a copy of the GNU Affero General Public License\n - along with this program. If not, see <http://www.gnu.org/licenses/>.\n -\n -->\n<docs>\n### General description\n\nThis components provides a wrapper around the main app's content.\n\nSingle-column layouts can just use the default slot. A resizable column\ncan be added by providing content to the named slot `list`.\n\n### CSS variables\nIn the css section some css variables are declared and will be available for\nall the children of the NcAppContent component\n\n### Examples\n\n#### Usage: Single-column content\n```vue\n<template>\n\t<NcAppContent>\n\t\t<h2>Single-column main content</h2>\n\t</NcAppContent>\n</template>\n```\n\n#### Usage: Two resizable columns\n```vue\n<template>\n\t<NcAppContent>\n\t\t<template #list>\n\t\t\t<div>Resizable list content</div>\n\t\t</template>\n\n\t\t<div>Main content</div>\n\t</NcAppContent>\n</template>\n```\n\n#### Overriding Defaults\nThe default, min and max sizes (in percent) of the resizable list column can be overridden.\nThe list size must be between the min and the max width value.\n\n```\n<NcAppContent\n\t:list-size=\"35\"\n\t:list-min-width=\"20\"\n\t:list-max-width=\"45\"\n>...</NcAppContent>\n```\n</docs>\n\n<template>\n\t<main id=\"app-content-vue\" class=\"app-content no-snapper\" :class=\"{ 'app-content--has-list': hasList }\">\n\t\t<h1 v-if=\"pageHeading\" class=\"hidden-visually\">\n\t\t\t{{ pageHeading }}\n\t\t</h1>\n\n\t\t<template v-if=\"hasList\">\n\t\t\t<!-- Mobile view does not allow resizeable panes -->\n\t\t\t<div v-if=\"isMobile\"\n\t\t\t\t:class=\"showDetails ? 'app-content-wrapper--show-details' : 'app-content-wrapper--show-list'\"\n\t\t\t\tclass=\"app-content-wrapper app-content-wrapper--mobile\">\n\t\t\t\t<NcAppDetailsToggle v-if=\"hasList && showDetails\" @click.native.stop.prevent=\"hideDetails\" />\n\n\t\t\t\t<slot name=\"list\" />\n\t\t\t\t<slot />\n\t\t\t</div>\n\n\t\t\t<div v-else class=\"app-content-wrapper\">\n\t\t\t\t<Splitpanes class=\"default-theme\"\n\t\t\t\t\t@resized=\"handlePaneResize\">\n\t\t\t\t\t<Pane class=\"splitpanes__pane-list\"\n\t\t\t\t\t\t:size=\"listPaneSize || paneDefaults.list.size\"\n\t\t\t\t\t\t:min-size=\"paneDefaults.list.min\"\n\t\t\t\t\t\t:max-size=\"paneDefaults.list.max\">\n\t\t\t\t\t\t<!-- @slot Provide a list to the app content -->\n\t\t\t\t\t\t<slot name=\"list\" />\n\t\t\t\t\t</Pane>\n\n\t\t\t\t\t<Pane class=\"splitpanes__pane-details\"\n\t\t\t\t\t\t:size=\"detailsPaneSize\"\n\t\t\t\t\t\t:min-size=\"paneDefaults.details.min\"\n\t\t\t\t\t\t:max-size=\"paneDefaults.details.max\">\n\t\t\t\t\t\t<!-- @slot Provide the main content to the app content -->\n\t\t\t\t\t\t<slot />\n\t\t\t\t\t</Pane>\n\t\t\t\t</Splitpanes>\n\t\t\t</div>\n\t\t</template>\n\n\t\t<!-- @slot Provide the main content to the app content -->\n\t\t<slot v-else />\n\t</main>\n</template>\n\n<script>\nimport NcAppDetailsToggle from './NcAppDetailsToggle.vue'\nimport { useIsMobile } from '../../composables/useIsMobile/index.js'\n\nimport { getBuilder } from '@nextcloud/browser-storage'\nimport { emit } from '@nextcloud/event-bus'\nimport { useSwipe } from '@vueuse/core'\nimport { Splitpanes, Pane } from 'splitpanes'\n\nimport 'splitpanes/dist/splitpanes.css'\n\nconst browserStorage = getBuilder('nextcloud').persist().build()\n\n/**\n * App content container to be used for the main content of your app\n *\n */\nexport default {\n\tname: 'NcAppContent',\n\n\tcomponents: {\n\t\tNcAppDetailsToggle,\n\t\tPane,\n\t\tSplitpanes,\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Allows to disable the control by swipe of the app navigation open state\n\t\t */\n\t\tallowSwipeNavigation: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * Allows you to set the default width of the resizable list in %\n\t\t * Must be between listMinWidth and listMaxWidth\n\t\t */\n\t\tlistSize: {\n\t\t\ttype: Number,\n\t\t\tdefault: 20,\n\t\t},\n\n\t\t/**\n\t\t * Allows you to set the minimum width of the list column in %\n\t\t */\n\t\tlistMinWidth: {\n\t\t\ttype: Number,\n\t\t\tdefault: 15,\n\t\t},\n\n\t\t/**\n\t\t * Allows you to set the maximum width of the list column in %\n\t\t */\n\t\tlistMaxWidth: {\n\t\t\ttype: Number,\n\t\t\tdefault: 40,\n\t\t},\n\n\t\t/**\n\t\t * Specify the config key for the pane config sizes\n\t\t * Default is the global var appName if you use the webpack-vue-config\n\t\t */\n\t\tpaneConfigKey: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * When in mobile view, only the list or the details are shown\n\t\t * If you provide a list, you need to provide a variable\n\t\t * that will be set to true by the user when an element of\n\t\t * the list gets selected. The details will then show a back\n\t\t * arrow to return to the list that will update this prop to false.\n\t\t */\n\t\tshowDetails: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * Specify the `<h1>` page heading\n\t\t */\n\t\tpageHeading: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\t},\n\n\temits: [\n\t\t'update:showDetails',\n\t\t'resize:list',\n\t],\n\n\tsetup() {\n\t\treturn {\n\t\t\tisMobile: useIsMobile(),\n\t\t}\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tcontentHeight: 0,\n\t\t\thasList: false,\n\n\t\t\tswiping: {},\n\t\t\tlistPaneSize: this.restorePaneConfig(),\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tpaneConfigID() {\n\t\t\t// If provided, let's use it\n\t\t\tif (this.paneConfigKey !== '') {\n\t\t\t\treturn `pane-list-size-${this.paneConfigKey}`\n\t\t\t}\n\n\t\t\ttry {\n\t\t\t\t// Using the webpack-vue-config, appName is a global variable\n\t\t\t\t// This will throw a ReferenceError when the global variable is missing\n\t\t\t\t// In that case either you provide paneConfigKey or else it fallback\n\t\t\t\t// to a global storage key\n\t\t\t\treturn `pane-list-size-${appName}`\n\t\t\t} catch (e) {\n\t\t\t\tconsole.info('[INFO] AppContent:', 'falling back to global nextcloud pane config')\n\t\t\t\treturn 'pane-list-size-nextcloud'\n\t\t\t}\n\t\t},\n\n\t\tdetailsPaneSize() {\n\t\t\tif (this.listPaneSize) {\n\t\t\t\treturn 100 - this.listPaneSize\n\t\t\t}\n\t\t\treturn this.paneDefaults.details.size\n\t\t},\n\n\t\tpaneDefaults() {\n\t\t\treturn {\n\t\t\t\tlist: {\n\t\t\t\t\tsize: this.listSize,\n\t\t\t\t\tmin: this.listMinWidth,\n\t\t\t\t\tmax: this.listMaxWidth,\n\t\t\t\t},\n\n\t\t\t\t// set the inverse values of the details column\n\t\t\t\t// based on the provided (or default) values of the list column\n\t\t\t\tdetails: {\n\t\t\t\t\tsize: 100 - this.listSize,\n\t\t\t\t\tmin: 100 - this.listMaxWidth,\n\t\t\t\t\tmax: 100 - this.listMinWidth,\n\t\t\t\t},\n\t\t\t}\n\t\t},\n\t},\n\n\tupdated() {\n\t\tthis.checkListSlot()\n\t},\n\n\tmounted() {\n\t\tif (this.allowSwipeNavigation) {\n\t\t\tthis.swiping = useSwipe(this.$el, {\n\t\t\t\tonSwipeEnd: this.handleSwipe,\n\t\t\t})\n\t\t}\n\n\t\tthis.checkListSlot()\n\t\tthis.restorePaneConfig()\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * handle the swipe event\n\t\t *\n\t\t * @param {TouchEvent} e The touch event\n\t\t * @param {import('@vueuse/core').SwipeDirection} direction The swipe direction of the event\n\t\t */\n\t\thandleSwipe(e, direction) {\n\t\t\tconst minSwipeX = 70\n\t\t\tconst touchZone = 300\n\t\t\tif (Math.abs(this.swiping.lengthX) > minSwipeX) {\n\t\t\t\tif (this.swiping.coordsStart.x < (touchZone / 2) && direction === 'right') {\n\t\t\t\t\temit('toggle-navigation', {\n\t\t\t\t\t\topen: true,\n\t\t\t\t\t})\n\t\t\t\t} else if (this.swiping.coordsStart.x < touchZone * 1.5 && direction === 'left') {\n\t\t\t\t\temit('toggle-navigation', {\n\t\t\t\t\t\topen: false,\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\thandlePaneResize(event) {\n\t\t\tconst listPaneSize = parseInt(event[0].size, 10)\n\t\t\tbrowserStorage.setItem(this.paneConfigID, JSON.stringify(listPaneSize))\n\t\t\tthis.listPaneSize = listPaneSize\n\t\t\t/**\n\t\t\t * Emitted when the list pane is resized by the user\n\t\t\t */\n\t\t\tthis.$emit('resize:list', { size: listPaneSize })\n\t\t\tconsole.debug('AppContent pane config', listPaneSize)\n\t\t},\n\n\t\t// $slots is not reactive, we need to update this manually\n\t\tcheckListSlot() {\n\t\t\tconst hasListSlot = !!this.$slots.list\n\t\t\tif (this.hasList !== hasListSlot) {\n\t\t\t\tthis.hasList = hasListSlot\n\t\t\t}\n\t\t},\n\n\t\t// browserStorage is not reactive, we need to update this manually\n\t\trestorePaneConfig() {\n\t\t\tconst listPaneSize = parseInt(browserStorage.getItem(this.paneConfigID), 10)\n\t\t\tif (!isNaN(listPaneSize) && listPaneSize !== this.listPaneSize) {\n\t\t\t\tconsole.debug('AppContent pane config', listPaneSize)\n\t\t\t\tthis.listPaneSize = listPaneSize\n\t\t\t\treturn listPaneSize\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * The user clicked the back arrow from the details view\n\t\t */\n\t\thideDetails() {\n\t\t\tthis.$emit('update:showDetails', false)\n\t\t},\n\t},\n}\n</script>\n<style lang=\"scss\" scoped>\n\n.app-content {\n\tposition: initial;\n\tz-index: 1000;\n\tflex-basis: 100vw;\n\theight: 100%;\n\t// Overriding server styles TODO: cleanup!\n\tmargin: 0 !important;\n\tbackground-color: var(--color-main-background);\n\tmin-width: 0;\n\n\t&:not(.app-content--has-list) {\n\t\toverflow: auto;\n\t}\n}\n\n.app-content-wrapper {\n\tposition: relative;\n\twidth: 100%;\n\theight: 100%;\n}\n\n// Mobile list/details handling\n.app-content-wrapper--mobile {\n\t&.app-content-wrapper--show-list :deep() {\n\t\t.app-content-list {\n\t\t\tdisplay: flex;\n\t\t}\n\t\t.app-content-details {\n\t\t\tdisplay: none;\n\t\t}\n\t}\n\t&.app-content-wrapper--show-details :deep() {\n\t\t.app-content-list {\n\t\t\tdisplay: none;\n\t\t}\n\t\t.app-content-details {\n\t\t\tdisplay: block;\n\t\t}\n\t}\n}\n\n:deep(.splitpanes.default-theme) {\n\t.app-content-list {\n\t\tmax-width: none;\n\t\t/* Thin scrollbar is hard to catch on resizable columns */\n\t\tscrollbar-width: auto;\n\t}\n\n\t.splitpanes__pane {\n\t\tbackground-color: transparent;\n\t\ttransition: none;\n\n\t\t&-list {\n\t\t\tmin-width: 300px;\n\t\t\tposition: sticky;\n\t\t\ttop: var(--header-height);\n\n\t\t\t@media only screen and (width < $breakpoint-mobile) {\n\t\t\t\tdisplay: none;\n\t\t\t}\n\t\t}\n\n\t\t&-details {\n\t\t\toverflow-y: auto;\n\n\t\t\t@media only screen and (width < $breakpoint-mobile) {\n\t\t\t\tmin-width: 100%;\n\t\t\t}\n\t\t}\n\t}\n\n\t.splitpanes__splitter {\n\t\twidth: 9px;\n\t\tmargin-left: -5px;\n\t\tbackground-color: transparent;\n\t\tborder-left: none;\n\n\t\t&:before,\n\t\t&:after {\n\t\t\tdisplay: none;\n\t\t}\n\t}\n}\n</style>\n"],"names":["_sfc_main$1","floatingVue","Components_NcButton","ArrowRight","_l10n","hide","appNavigationToggle","eventBus","browserStorage","browserStorage$1","_sfc_main","NcAppDetailsToggle","splitpanes","Composables_useIsMobile","core","e","direction","event","listPaneSize","hasListSlot"],"mappings":"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"}
@@ -0,0 +1,122 @@
1
+ import "../assets/NcAppNavigation-vjqOL-kR.css";
2
+ import { useIsMobile as n } from "../Composables/useIsMobile.mjs";
3
+ import { g as s } from "./focusTrap-Py2bQ9-r.mjs";
4
+ import { subscribe as p, emit as o, unsubscribe as r } from "@nextcloud/event-bus";
5
+ import { createFocusTrap as l } from "focus-trap";
6
+ import { N as g } from "./NcAppNavigationToggle-RXyDbzmn.mjs";
7
+ import u from "vue";
8
+ import { n as c } from "./_plugin-vue2_normalizer-u6G_3nkj.mjs";
9
+ const d = {
10
+ name: "NcAppNavigation",
11
+ components: {
12
+ NcAppNavigationToggle: g
13
+ },
14
+ // Injected from NcContent
15
+ inject: {
16
+ setHasAppNavigation: {
17
+ default: () => () => u.util.warn("NcAppNavigation is not mounted inside NcContent, this is probably an error."),
18
+ from: "NcContent:setHasAppNavigation"
19
+ }
20
+ },
21
+ props: {
22
+ /**
23
+ * The aria label to describe the navigation
24
+ */
25
+ ariaLabel: {
26
+ type: String,
27
+ default: ""
28
+ },
29
+ /**
30
+ * aria-labelledby attribute to describe the navigation
31
+ */
32
+ ariaLabelledby: {
33
+ type: String,
34
+ default: ""
35
+ }
36
+ },
37
+ setup() {
38
+ return {
39
+ isMobile: n()
40
+ };
41
+ },
42
+ data() {
43
+ return {
44
+ open: !this.isMobile,
45
+ focusTrap: null
46
+ };
47
+ },
48
+ watch: {
49
+ isMobile() {
50
+ this.open = !this.isMobile, this.toggleFocusTrap();
51
+ },
52
+ open() {
53
+ this.toggleFocusTrap();
54
+ }
55
+ },
56
+ mounted() {
57
+ this.setHasAppNavigation(!0), p("toggle-navigation", this.toggleNavigationByEventBus), o("navigation-toggled", {
58
+ open: this.open
59
+ }), this.focusTrap = l(this.$refs.appNavigationContainer, {
60
+ allowOutsideClick: !0,
61
+ fallbackFocus: this.$refs.appNavigationContainer,
62
+ trapStack: s(),
63
+ escapeDeactivates: !1
64
+ }), this.toggleFocusTrap();
65
+ },
66
+ unmounted() {
67
+ this.setHasAppNavigation(!1), r("toggle-navigation", this.toggleNavigationByEventBus), this.focusTrap.deactivate();
68
+ },
69
+ methods: {
70
+ /**
71
+ * Toggle the navigation
72
+ *
73
+ * @param {boolean} [state] set the state instead of inverting the current one
74
+ */
75
+ toggleNavigation(a) {
76
+ if (this.open === a) {
77
+ o("navigation-toggled", {
78
+ open: this.open
79
+ });
80
+ return;
81
+ }
82
+ this.open = typeof a > "u" ? !this.open : a;
83
+ const t = getComputedStyle(document.body), e = parseInt(t.getPropertyValue("--animation-quick")) || 100;
84
+ setTimeout(() => {
85
+ o("navigation-toggled", {
86
+ open: this.open
87
+ });
88
+ }, 1.5 * e);
89
+ },
90
+ toggleNavigationByEventBus({ open: a }) {
91
+ this.toggleNavigation(a);
92
+ },
93
+ /**
94
+ * Activate focus trap if it is currently needed, otherwise deactivate
95
+ */
96
+ toggleFocusTrap() {
97
+ this.isMobile && this.open ? this.focusTrap.activate() : this.focusTrap.deactivate();
98
+ },
99
+ handleEsc() {
100
+ this.isMobile && this.toggleNavigation(!1);
101
+ }
102
+ }
103
+ };
104
+ var f = function() {
105
+ var t = this, e = t._self._c;
106
+ return e("div", { ref: "appNavigationContainer", staticClass: "app-navigation", class: { "app-navigation--close": !t.open } }, [e("nav", { staticClass: "app-navigation__content", attrs: { id: "app-navigation-vue", "aria-hidden": t.open ? "false" : "true", "aria-label": t.ariaLabel || void 0, "aria-labelledby": t.ariaLabelledby || void 0, inert: !t.open || void 0 }, on: { keydown: function(i) {
107
+ return !i.type.indexOf("key") && t._k(i.keyCode, "esc", 27, i.key, ["Esc", "Escape"]) ? null : t.handleEsc.apply(null, arguments);
108
+ } } }, [t._t("default"), e("ul", { staticClass: "app-navigation__list" }, [t._t("list")], 2), t._t("footer")], 2), e("NcAppNavigationToggle", { attrs: { open: t.open }, on: { "update:open": t.toggleNavigation } })], 1);
109
+ }, v = [], h = /* @__PURE__ */ c(
110
+ d,
111
+ f,
112
+ v,
113
+ !1,
114
+ null,
115
+ "80612854",
116
+ null,
117
+ null
118
+ );
119
+ const A = h.exports;
120
+ export {
121
+ A as N
122
+ };