@nextcloud/vue 8.0.0-beta.6 → 8.0.0-beta.8

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 (568) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/dist/Components/NcActionButton.cjs +49 -1
  3. package/dist/Components/NcActionButton.cjs.map +1 -1
  4. package/dist/Components/NcActionButton.mjs +48 -12
  5. package/dist/Components/NcActionButton.mjs.map +1 -1
  6. package/dist/Components/NcActionButtonGroup.cjs +30 -1
  7. package/dist/Components/NcActionButtonGroup.cjs.map +1 -1
  8. package/dist/Components/NcActionButtonGroup.mjs +30 -9
  9. package/dist/Components/NcActionButtonGroup.mjs.map +1 -1
  10. package/dist/Components/NcActionCaption.cjs +29 -1
  11. package/dist/Components/NcActionCaption.cjs.map +1 -1
  12. package/dist/Components/NcActionCaption.mjs +29 -9
  13. package/dist/Components/NcActionCaption.mjs.map +1 -1
  14. package/dist/Components/NcActionCheckbox.cjs +78 -1
  15. package/dist/Components/NcActionCheckbox.cjs.map +1 -1
  16. package/dist/Components/NcActionCheckbox.mjs +80 -19
  17. package/dist/Components/NcActionCheckbox.mjs.map +1 -1
  18. package/dist/Components/NcActionInput.cjs +226 -1
  19. package/dist/Components/NcActionInput.cjs.map +1 -1
  20. package/dist/Components/NcActionInput.mjs +227 -68
  21. package/dist/Components/NcActionInput.mjs.map +1 -1
  22. package/dist/Components/NcActionLink.cjs +69 -1
  23. package/dist/Components/NcActionLink.cjs.map +1 -1
  24. package/dist/Components/NcActionLink.mjs +65 -13
  25. package/dist/Components/NcActionLink.mjs.map +1 -1
  26. package/dist/Components/NcActionRadio.cjs +85 -1
  27. package/dist/Components/NcActionRadio.cjs.map +1 -1
  28. package/dist/Components/NcActionRadio.mjs +87 -19
  29. package/dist/Components/NcActionRadio.mjs.map +1 -1
  30. package/dist/Components/NcActionRouter.cjs +42 -1
  31. package/dist/Components/NcActionRouter.cjs.map +1 -1
  32. package/dist/Components/NcActionRouter.mjs +41 -12
  33. package/dist/Components/NcActionRouter.mjs.map +1 -1
  34. package/dist/Components/NcActionSeparator.cjs +20 -1
  35. package/dist/Components/NcActionSeparator.cjs.map +1 -1
  36. package/dist/Components/NcActionSeparator.mjs +20 -9
  37. package/dist/Components/NcActionSeparator.mjs.map +1 -1
  38. package/dist/Components/NcActionText.cjs +23 -1
  39. package/dist/Components/NcActionText.cjs.map +1 -1
  40. package/dist/Components/NcActionText.mjs +20 -8
  41. package/dist/Components/NcActionText.mjs.map +1 -1
  42. package/dist/Components/NcActionTextEditable.cjs +81 -1
  43. package/dist/Components/NcActionTextEditable.cjs.map +1 -1
  44. package/dist/Components/NcActionTextEditable.mjs +79 -22
  45. package/dist/Components/NcActionTextEditable.mjs.map +1 -1
  46. package/dist/Components/NcActions.cjs +455 -1
  47. package/dist/Components/NcActions.cjs.map +1 -1
  48. package/dist/Components/NcActions.mjs +459 -100
  49. package/dist/Components/NcActions.mjs.map +1 -1
  50. package/dist/Components/NcAppContent.cjs +218 -1
  51. package/dist/Components/NcAppContent.cjs.map +1 -1
  52. package/dist/Components/NcAppContent.mjs +220 -66
  53. package/dist/Components/NcAppContent.mjs.map +1 -1
  54. package/dist/Components/NcAppContentDetails.cjs +19 -1
  55. package/dist/Components/NcAppContentDetails.cjs.map +1 -1
  56. package/dist/Components/NcAppContentDetails.mjs +18 -7
  57. package/dist/Components/NcAppContentDetails.mjs.map +1 -1
  58. package/dist/Components/NcAppContentList.cjs +29 -1
  59. package/dist/Components/NcAppContentList.cjs.map +1 -1
  60. package/dist/Components/NcAppContentList.mjs +29 -8
  61. package/dist/Components/NcAppContentList.mjs.map +1 -1
  62. package/dist/Components/NcAppNavigation.cjs +66 -1
  63. package/dist/Components/NcAppNavigation.cjs.map +1 -1
  64. package/dist/Components/NcAppNavigation.mjs +67 -28
  65. package/dist/Components/NcAppNavigation.mjs.map +1 -1
  66. package/dist/Components/NcAppNavigationCaption.cjs +44 -1
  67. package/dist/Components/NcAppNavigationCaption.cjs.map +1 -1
  68. package/dist/Components/NcAppNavigationCaption.mjs +40 -9
  69. package/dist/Components/NcAppNavigationCaption.mjs.map +1 -1
  70. package/dist/Components/NcAppNavigationIconBullet.cjs +40 -1
  71. package/dist/Components/NcAppNavigationIconBullet.cjs.map +1 -1
  72. package/dist/Components/NcAppNavigationIconBullet.mjs +40 -15
  73. package/dist/Components/NcAppNavigationIconBullet.mjs.map +1 -1
  74. package/dist/Components/NcAppNavigationItem.cjs +386 -1
  75. package/dist/Components/NcAppNavigationItem.cjs.map +1 -1
  76. package/dist/Components/NcAppNavigationItem.mjs +382 -81
  77. package/dist/Components/NcAppNavigationItem.mjs.map +1 -1
  78. package/dist/Components/NcAppNavigationNew.cjs +50 -1
  79. package/dist/Components/NcAppNavigationNew.cjs.map +1 -1
  80. package/dist/Components/NcAppNavigationNew.mjs +51 -14
  81. package/dist/Components/NcAppNavigationNew.mjs.map +1 -1
  82. package/dist/Components/NcAppNavigationNewItem.cjs +87 -1
  83. package/dist/Components/NcAppNavigationNewItem.cjs.map +1 -1
  84. package/dist/Components/NcAppNavigationNewItem.mjs +83 -17
  85. package/dist/Components/NcAppNavigationNewItem.mjs.map +1 -1
  86. package/dist/Components/NcAppNavigationSettings.cjs +69 -1
  87. package/dist/Components/NcAppNavigationSettings.cjs.map +1 -1
  88. package/dist/Components/NcAppNavigationSettings.mjs +60 -21
  89. package/dist/Components/NcAppNavigationSettings.mjs.map +1 -1
  90. package/dist/Components/NcAppNavigationSpacer.cjs +20 -1
  91. package/dist/Components/NcAppNavigationSpacer.cjs.map +1 -1
  92. package/dist/Components/NcAppNavigationSpacer.mjs +20 -9
  93. package/dist/Components/NcAppNavigationSpacer.mjs.map +1 -1
  94. package/dist/Components/NcAppNavigationToggle.cjs +25 -1
  95. package/dist/Components/NcAppNavigationToggle.cjs.map +1 -1
  96. package/dist/Components/NcAppNavigationToggle.mjs +21 -1
  97. package/dist/Components/NcAppNavigationToggle.mjs.map +1 -1
  98. package/dist/Components/NcAppSettingsDialog.cjs +207 -1
  99. package/dist/Components/NcAppSettingsDialog.cjs.map +1 -1
  100. package/dist/Components/NcAppSettingsDialog.mjs +209 -48
  101. package/dist/Components/NcAppSettingsDialog.mjs.map +1 -1
  102. package/dist/Components/NcAppSettingsSection.cjs +39 -1
  103. package/dist/Components/NcAppSettingsSection.cjs.map +1 -1
  104. package/dist/Components/NcAppSettingsSection.mjs +39 -13
  105. package/dist/Components/NcAppSettingsSection.mjs.map +1 -1
  106. package/dist/Components/NcAppSidebar.cjs +443 -1
  107. package/dist/Components/NcAppSidebar.cjs.map +1 -1
  108. package/dist/Components/NcAppSidebar.mjs +409 -92
  109. package/dist/Components/NcAppSidebar.mjs.map +1 -1
  110. package/dist/Components/NcAppSidebarTab.cjs +83 -1
  111. package/dist/Components/NcAppSidebarTab.cjs.map +1 -1
  112. package/dist/Components/NcAppSidebarTab.mjs +83 -20
  113. package/dist/Components/NcAppSidebarTab.mjs.map +1 -1
  114. package/dist/Components/NcAvatar.cjs +3 -1
  115. package/dist/Components/NcAvatar.cjs.map +1 -1
  116. package/dist/Components/NcAvatar.mjs +1 -1
  117. package/dist/Components/NcBreadcrumb.cjs +175 -1
  118. package/dist/Components/NcBreadcrumb.cjs.map +1 -1
  119. package/dist/Components/NcBreadcrumb.mjs +175 -35
  120. package/dist/Components/NcBreadcrumb.mjs.map +1 -1
  121. package/dist/Components/NcBreadcrumbs.cjs +372 -1
  122. package/dist/Components/NcBreadcrumbs.cjs.map +1 -1
  123. package/dist/Components/NcBreadcrumbs.mjs +373 -142
  124. package/dist/Components/NcBreadcrumbs.mjs.map +1 -1
  125. package/dist/Components/NcButton.cjs +226 -1
  126. package/dist/Components/NcButton.cjs.map +1 -1
  127. package/dist/Components/NcButton.mjs +226 -24
  128. package/dist/Components/NcButton.mjs.map +1 -1
  129. package/dist/Components/NcCheckboxRadioSwitch.cjs +237 -1
  130. package/dist/Components/NcCheckboxRadioSwitch.cjs.map +1 -1
  131. package/dist/Components/NcCheckboxRadioSwitch.mjs +243 -57
  132. package/dist/Components/NcCheckboxRadioSwitch.mjs.map +1 -1
  133. package/dist/Components/NcColorPicker.cjs +118 -1
  134. package/dist/Components/NcColorPicker.cjs.map +1 -1
  135. package/dist/Components/NcColorPicker.mjs +124 -46
  136. package/dist/Components/NcColorPicker.mjs.map +1 -1
  137. package/dist/Components/NcContent.cjs +25 -1
  138. package/dist/Components/NcContent.cjs.map +1 -1
  139. package/dist/Components/NcContent.mjs +24 -8
  140. package/dist/Components/NcContent.mjs.map +1 -1
  141. package/dist/Components/NcCounterBubble.cjs +47 -1
  142. package/dist/Components/NcCounterBubble.cjs.map +1 -1
  143. package/dist/Components/NcCounterBubble.mjs +46 -12
  144. package/dist/Components/NcCounterBubble.mjs.map +1 -1
  145. package/dist/Components/NcDashboardWidget.cjs +133 -1
  146. package/dist/Components/NcDashboardWidget.cjs.map +1 -1
  147. package/dist/Components/NcDashboardWidget.mjs +128 -39
  148. package/dist/Components/NcDashboardWidget.mjs.map +1 -1
  149. package/dist/Components/NcDashboardWidgetItem.cjs +138 -1
  150. package/dist/Components/NcDashboardWidgetItem.cjs.map +1 -1
  151. package/dist/Components/NcDashboardWidgetItem.mjs +129 -22
  152. package/dist/Components/NcDashboardWidgetItem.mjs.map +1 -1
  153. package/dist/Components/NcDateTime.cjs +125 -0
  154. package/dist/Components/{NcDatetime.mjs.map → NcDateTime.cjs.map} +1 -1
  155. package/dist/Components/NcDateTime.mjs +129 -0
  156. package/dist/Components/{NcDatetime.cjs.map → NcDateTime.mjs.map} +1 -1
  157. package/dist/Components/NcDateTimePicker.cjs +217 -0
  158. package/dist/Components/NcDateTimePicker.cjs.map +1 -0
  159. package/dist/Components/NcDateTimePicker.mjs +228 -0
  160. package/dist/Components/NcDateTimePicker.mjs.map +1 -0
  161. package/dist/Components/NcDateTimePickerNative.cjs +199 -1
  162. package/dist/Components/NcDateTimePickerNative.cjs.map +1 -1
  163. package/dist/Components/NcDateTimePickerNative.mjs +195 -58
  164. package/dist/Components/NcDateTimePickerNative.mjs.map +1 -1
  165. package/dist/Components/NcEllipsisedOption.cjs +74 -1
  166. package/dist/Components/NcEllipsisedOption.cjs.map +1 -1
  167. package/dist/Components/NcEllipsisedOption.mjs +73 -20
  168. package/dist/Components/NcEllipsisedOption.mjs.map +1 -1
  169. package/dist/Components/NcEmojiPicker.cjs +175 -1
  170. package/dist/Components/NcEmojiPicker.cjs.map +1 -1
  171. package/dist/Components/NcEmojiPicker.mjs +173 -53
  172. package/dist/Components/NcEmojiPicker.mjs.map +1 -1
  173. package/dist/Components/NcEmptyContent.cjs +54 -1
  174. package/dist/Components/NcEmptyContent.cjs.map +1 -1
  175. package/dist/Components/NcEmptyContent.mjs +46 -10
  176. package/dist/Components/NcEmptyContent.mjs.map +1 -1
  177. package/dist/Components/NcGuestContent.cjs +26 -1
  178. package/dist/Components/NcGuestContent.cjs.map +1 -1
  179. package/dist/Components/NcGuestContent.mjs +24 -11
  180. package/dist/Components/NcGuestContent.mjs.map +1 -1
  181. package/dist/Components/NcHeaderMenu.cjs +167 -1
  182. package/dist/Components/NcHeaderMenu.cjs.map +1 -1
  183. package/dist/Components/NcHeaderMenu.mjs +161 -49
  184. package/dist/Components/NcHeaderMenu.mjs.map +1 -1
  185. package/dist/Components/NcHighlight.cjs +3 -1
  186. package/dist/Components/NcHighlight.cjs.map +1 -1
  187. package/dist/Components/NcHighlight.mjs +1 -1
  188. package/dist/Components/NcIconSvgWrapper.cjs +44 -1
  189. package/dist/Components/NcIconSvgWrapper.cjs.map +1 -1
  190. package/dist/Components/NcIconSvgWrapper.mjs +45 -15
  191. package/dist/Components/NcIconSvgWrapper.mjs.map +1 -1
  192. package/dist/Components/NcInputField.cjs +210 -1
  193. package/dist/Components/NcInputField.cjs.map +1 -1
  194. package/dist/Components/NcInputField.mjs +211 -38
  195. package/dist/Components/NcInputField.mjs.map +1 -1
  196. package/dist/Components/NcListItem.cjs +237 -1
  197. package/dist/Components/NcListItem.cjs.map +1 -1
  198. package/dist/Components/NcListItem.mjs +233 -57
  199. package/dist/Components/NcListItem.mjs.map +1 -1
  200. package/dist/Components/NcListItemIcon.cjs +150 -1
  201. package/dist/Components/NcListItemIcon.cjs.map +1 -1
  202. package/dist/Components/NcListItemIcon.mjs +142 -26
  203. package/dist/Components/NcListItemIcon.mjs.map +1 -1
  204. package/dist/Components/NcLoadingIcon.cjs +54 -1
  205. package/dist/Components/NcLoadingIcon.cjs.map +1 -1
  206. package/dist/Components/NcLoadingIcon.mjs +54 -14
  207. package/dist/Components/NcLoadingIcon.mjs.map +1 -1
  208. package/dist/Components/NcModal.cjs +405 -1
  209. package/dist/Components/NcModal.cjs.map +1 -1
  210. package/dist/Components/NcModal.mjs +401 -103
  211. package/dist/Components/NcModal.mjs.map +1 -1
  212. package/dist/Components/NcNoteCard.cjs +71 -1
  213. package/dist/Components/NcNoteCard.cjs.map +1 -1
  214. package/dist/Components/NcNoteCard.mjs +71 -37
  215. package/dist/Components/NcNoteCard.mjs.map +1 -1
  216. package/dist/Components/NcPasswordField.cjs +152 -1
  217. package/dist/Components/NcPasswordField.cjs.map +1 -1
  218. package/dist/Components/NcPasswordField.mjs +157 -53
  219. package/dist/Components/NcPasswordField.mjs.map +1 -1
  220. package/dist/Components/NcPopover.cjs +125 -1
  221. package/dist/Components/NcPopover.cjs.map +1 -1
  222. package/dist/Components/NcPopover.mjs +124 -41
  223. package/dist/Components/NcPopover.mjs.map +1 -1
  224. package/dist/Components/NcProgressBar.cjs +57 -1
  225. package/dist/Components/NcProgressBar.cjs.map +1 -1
  226. package/dist/Components/NcProgressBar.mjs +57 -15
  227. package/dist/Components/NcProgressBar.mjs.map +1 -1
  228. package/dist/Components/NcRelatedResourcesPanel.cjs +168 -1
  229. package/dist/Components/NcRelatedResourcesPanel.cjs.map +1 -1
  230. package/dist/Components/NcRelatedResourcesPanel.mjs +166 -60
  231. package/dist/Components/NcRelatedResourcesPanel.mjs.map +1 -1
  232. package/dist/Components/NcRichContenteditable.cjs +478 -1
  233. package/dist/Components/NcRichContenteditable.cjs.map +1 -1
  234. package/dist/Components/NcRichContenteditable.mjs +447 -127
  235. package/dist/Components/NcRichContenteditable.mjs.map +1 -1
  236. package/dist/Components/NcRichText.cjs +44 -1
  237. package/dist/Components/NcRichText.cjs.map +1 -1
  238. package/dist/Components/NcRichText.mjs +25 -4
  239. package/dist/Components/NcRichText.mjs.map +1 -1
  240. package/dist/Components/NcSavingIndicatorIcon.cjs +59 -1
  241. package/dist/Components/NcSavingIndicatorIcon.cjs.map +1 -1
  242. package/dist/Components/NcSavingIndicatorIcon.mjs +56 -9
  243. package/dist/Components/NcSavingIndicatorIcon.mjs.map +1 -1
  244. package/dist/Components/NcSelect.cjs +406 -1
  245. package/dist/Components/NcSelect.cjs.map +1 -1
  246. package/dist/Components/NcSelect.mjs +402 -49
  247. package/dist/Components/NcSelect.mjs.map +1 -1
  248. package/dist/Components/NcSelectTags.cjs +251 -2
  249. package/dist/Components/NcSelectTags.cjs.map +1 -1
  250. package/dist/Components/NcSelectTags.mjs +236 -73
  251. package/dist/Components/NcSelectTags.mjs.map +1 -1
  252. package/dist/Components/NcSettingsInputText.cjs +90 -1
  253. package/dist/Components/NcSettingsInputText.cjs.map +1 -1
  254. package/dist/Components/NcSettingsInputText.mjs +88 -19
  255. package/dist/Components/NcSettingsInputText.mjs.map +1 -1
  256. package/dist/Components/NcSettingsSection.cjs +62 -1
  257. package/dist/Components/NcSettingsSection.cjs.map +1 -1
  258. package/dist/Components/NcSettingsSection.mjs +62 -15
  259. package/dist/Components/NcSettingsSection.mjs.map +1 -1
  260. package/dist/Components/NcSettingsSelectGroup.cjs +26 -1
  261. package/dist/Components/NcSettingsSelectGroup.cjs.map +1 -1
  262. package/dist/Components/NcSettingsSelectGroup.mjs +24 -53
  263. package/dist/Components/NcSettingsSelectGroup.mjs.map +1 -1
  264. package/dist/Components/NcTextField.cjs +74 -1
  265. package/dist/Components/NcTextField.cjs.map +1 -1
  266. package/dist/Components/NcTextField.mjs +77 -21
  267. package/dist/Components/NcTextField.mjs.map +1 -1
  268. package/dist/Components/NcTimezonePicker.cjs +4387 -614
  269. package/dist/Components/NcTimezonePicker.cjs.map +1 -1
  270. package/dist/Components/NcTimezonePicker.mjs +4372 -663
  271. package/dist/Components/NcTimezonePicker.mjs.map +1 -1
  272. package/dist/Components/NcUserBubble.cjs +189 -1
  273. package/dist/Components/NcUserBubble.cjs.map +1 -1
  274. package/dist/Components/NcUserBubble.mjs +190 -47
  275. package/dist/Components/NcUserBubble.mjs.map +1 -1
  276. package/dist/Components/NcVNodes.cjs +35 -1
  277. package/dist/Components/NcVNodes.cjs.map +1 -1
  278. package/dist/Components/NcVNodes.mjs +35 -8
  279. package/dist/Components/NcVNodes.mjs.map +1 -1
  280. package/dist/Directives/Focus.cjs +30 -1
  281. package/dist/Directives/Focus.cjs.map +1 -1
  282. package/dist/Directives/Focus.mjs +28 -5
  283. package/dist/Directives/Focus.mjs.map +1 -1
  284. package/dist/Directives/Linkify.cjs +8 -1
  285. package/dist/Directives/Linkify.cjs.map +1 -1
  286. package/dist/Directives/Linkify.mjs +6 -6
  287. package/dist/Directives/Linkify.mjs.map +1 -1
  288. package/dist/Directives/Tooltip.cjs +37 -1
  289. package/dist/Directives/Tooltip.cjs.map +1 -1
  290. package/dist/Directives/Tooltip.mjs +29 -4
  291. package/dist/Directives/Tooltip.mjs.map +1 -1
  292. package/dist/Functions/emoji.cjs +36 -1
  293. package/dist/Functions/emoji.cjs.map +1 -1
  294. package/dist/Functions/emoji.mjs +32 -11
  295. package/dist/Functions/emoji.mjs.map +1 -1
  296. package/dist/Functions/usernameToColor.cjs +39 -1
  297. package/dist/Functions/usernameToColor.cjs.map +1 -1
  298. package/dist/Functions/usernameToColor.mjs +32 -11
  299. package/dist/Functions/usernameToColor.mjs.map +1 -1
  300. package/dist/Mixins/clickOutsideOptions.cjs +40 -1
  301. package/dist/Mixins/clickOutsideOptions.cjs.map +1 -1
  302. package/dist/Mixins/clickOutsideOptions.mjs +39 -4
  303. package/dist/Mixins/clickOutsideOptions.mjs.map +1 -1
  304. package/dist/Mixins/isFullscreen.cjs +44 -1
  305. package/dist/Mixins/isFullscreen.cjs.map +1 -1
  306. package/dist/Mixins/isFullscreen.mjs +42 -11
  307. package/dist/Mixins/isFullscreen.mjs.map +1 -1
  308. package/dist/Mixins/isMobile.cjs +87 -1
  309. package/dist/Mixins/isMobile.cjs.map +1 -1
  310. package/dist/Mixins/isMobile.mjs +86 -11
  311. package/dist/Mixins/isMobile.mjs.map +1 -1
  312. package/dist/Mixins/richEditor.cjs +10 -1
  313. package/dist/Mixins/richEditor.cjs.map +1 -1
  314. package/dist/Mixins/richEditor.mjs +2 -2
  315. package/dist/assets/{index28.css → NcAppNavigationToggle-2cc5b864.css} +16 -2
  316. package/dist/assets/NcInputConfirmCancel-2ba60a52.css +51 -0
  317. package/dist/assets/NcMentionBubble-6e887c5f.css +81 -0
  318. package/dist/assets/{index46.css → NcSettingsSelectGroup-0d38d76b.css} +15 -2
  319. package/dist/assets/index-01e5adf4.css +79 -0
  320. package/dist/assets/index-03ec5f40.css +60 -0
  321. package/dist/assets/{index.css → index-0557f12a.css} +26 -2
  322. package/dist/assets/index-0ab8e182.css +128 -0
  323. package/dist/assets/index-0adc989c.css +96 -0
  324. package/dist/assets/index-1151d229.css +41 -0
  325. package/dist/assets/index-165fce0e.css +82 -0
  326. package/dist/assets/index-194e9415.css +163 -0
  327. package/dist/assets/index-1beccc92.css +140 -0
  328. package/dist/assets/index-1cf8eeb4.css +97 -0
  329. package/dist/assets/index-23e64bbb.css +59 -0
  330. package/dist/assets/{index50.css → index-24f6c355.css} +67 -3
  331. package/dist/assets/index-294382c8.css +879 -0
  332. package/dist/assets/index-2a8e4ca1.css +540 -0
  333. package/dist/assets/index-2d4de2fc.css +38 -0
  334. package/dist/assets/{index2.css → index-30e099f7.css} +17 -2
  335. package/dist/assets/{NcInputConfirmCancel.css → index-33da80f0.css} +32 -2
  336. package/dist/assets/index-34dfc54e.css +88 -0
  337. package/dist/assets/index-3764a447.css +99 -0
  338. package/dist/assets/index-376d2dec.css +243 -0
  339. package/dist/assets/{index17.css → index-441b6552.css} +25 -2
  340. package/dist/assets/index-4a775ba1.css +204 -0
  341. package/dist/assets/index-4ebacc78.css +107 -0
  342. package/dist/assets/index-4ef32afd.css +128 -0
  343. package/dist/assets/{index47.css → index-5072b6ee.css} +77 -3
  344. package/dist/assets/index-50b0766d.css +202 -0
  345. package/dist/assets/index-5eff69c7.css +149 -0
  346. package/dist/assets/index-5fa0ac5a.css +46 -0
  347. package/dist/assets/index-61b63a8f.css +57 -0
  348. package/dist/assets/index-6405cd50.css +76 -0
  349. package/dist/assets/index-6416f636.css +83 -0
  350. package/dist/assets/index-6c47e88a.css +46 -0
  351. package/dist/assets/index-76a58945.css +68 -0
  352. package/dist/assets/index-76dd9f11.css +5 -0
  353. package/dist/assets/index-7768d5e5.css +148 -0
  354. package/dist/assets/index-7813bab3.css +66 -0
  355. package/dist/assets/index-793eae6b.css +234 -0
  356. package/dist/assets/index-8aa4712e.css +51 -0
  357. package/dist/assets/{index27.css → index-8f52a20f.css} +16 -2
  358. package/dist/assets/index-9354264c.css +80 -0
  359. package/dist/assets/index-93ad846c.css +259 -0
  360. package/dist/assets/index-a2b51bce.css +47 -0
  361. package/dist/assets/index-a2d55f92.css +204 -0
  362. package/dist/assets/{index13.css → index-a9e4fe04.css} +27 -2
  363. package/dist/assets/{NcAppNavigationToggle.css → index-b8f13a1f.css} +13 -2
  364. package/dist/assets/index-b991895f.css +87 -0
  365. package/dist/assets/{index48.css → index-baf8711a.css} +67 -3
  366. package/dist/assets/index-becfbea7.css +128 -0
  367. package/dist/assets/index-c6f0da2e.css +69 -0
  368. package/dist/assets/index-c7905a53.css +44 -0
  369. package/dist/assets/index-d211cae8.css +93 -0
  370. package/dist/assets/{index22.css → index-d646553d.css} +22 -2
  371. package/dist/assets/index-de0326c7.css +304 -0
  372. package/dist/assets/index-ed4adf1d.css +115 -0
  373. package/dist/assets/index-edee3304.css +52 -0
  374. package/dist/assets/index-fbdeb5ab.css +303 -0
  375. package/dist/assets/index-fc61f2d8.css +41 -0
  376. package/dist/assets/index-fec4bb7b.css +132 -0
  377. package/dist/assets/referencePickerModal-0acecb5e.css +482 -0
  378. package/dist/chunks/GenColors-38246c38.mjs +46 -0
  379. package/dist/chunks/{GenColors-8097de04.cjs.map → GenColors-38246c38.mjs.map} +1 -1
  380. package/dist/chunks/GenColors-eedcc70a.cjs +45 -0
  381. package/dist/chunks/{GenColors-85cb6194.mjs.map → GenColors-eedcc70a.cjs.map} +1 -1
  382. package/dist/{assets/index29.css → chunks/GenRandomId-c214d235.cjs} +8 -5
  383. package/dist/chunks/{GenRandomId-67df40eb.cjs.map → GenRandomId-c214d235.cjs.map} +1 -1
  384. package/dist/chunks/GenRandomId-cb9ccebe.mjs +25 -0
  385. package/dist/chunks/{GenRandomId-1e1b509a.mjs.map → GenRandomId-cb9ccebe.mjs.map} +1 -1
  386. package/dist/chunks/Linkify-39f20c9a.mjs +33 -0
  387. package/dist/chunks/{Linkify-a0faf443.mjs.map → Linkify-39f20c9a.mjs.map} +1 -1
  388. package/dist/chunks/Linkify-40cdd635.cjs +32 -0
  389. package/dist/chunks/{Linkify-a4db36a9.cjs.map → Linkify-40cdd635.cjs.map} +1 -1
  390. package/dist/chunks/NcAppNavigationToggle-960658a0.cjs +49 -0
  391. package/dist/chunks/NcAppNavigationToggle-960658a0.cjs.map +1 -0
  392. package/dist/chunks/NcAppNavigationToggle-d868f651.mjs +55 -0
  393. package/dist/chunks/NcAppNavigationToggle-d868f651.mjs.map +1 -0
  394. package/dist/chunks/NcInputConfirmCancel-0c4bee9a.cjs +83 -0
  395. package/dist/chunks/NcInputConfirmCancel-0c4bee9a.cjs.map +1 -0
  396. package/dist/chunks/NcInputConfirmCancel-f881168d.mjs +89 -0
  397. package/dist/chunks/NcInputConfirmCancel-f881168d.mjs.map +1 -0
  398. package/dist/chunks/NcRichText-1c3d2654.mjs +302 -0
  399. package/dist/chunks/{NcRichText-13b09624.mjs.map → NcRichText-1c3d2654.mjs.map} +1 -1
  400. package/dist/chunks/NcRichText-d385dc10.cjs +289 -0
  401. package/dist/chunks/{NcRichText-1e8854a1.cjs.map → NcRichText-d385dc10.cjs.map} +1 -1
  402. package/dist/chunks/NcSettingsSelectGroup-0f4a0f94.mjs +192 -0
  403. package/dist/chunks/NcSettingsSelectGroup-0f4a0f94.mjs.map +1 -0
  404. package/dist/chunks/NcSettingsSelectGroup-47d9c113.cjs +183 -0
  405. package/dist/chunks/NcSettingsSelectGroup-47d9c113.cjs.map +1 -0
  406. package/dist/chunks/ScopeComponent-1c75ec38.cjs +28 -0
  407. package/dist/chunks/{ScopeComponent-f6122f5a.cjs.map → ScopeComponent-1c75ec38.cjs.map} +1 -1
  408. package/dist/chunks/ScopeComponent-97a014a1.mjs +29 -0
  409. package/dist/chunks/{ScopeComponent-dbcd0e07.mjs.map → ScopeComponent-97a014a1.mjs.map} +1 -1
  410. package/dist/chunks/_plugin-vue2_normalizer-71e2aa87.mjs +32 -0
  411. package/dist/chunks/_plugin-vue2_normalizer-71e2aa87.mjs.map +1 -0
  412. package/dist/chunks/_plugin-vue2_normalizer-7f9efb60.cjs +31 -0
  413. package/dist/chunks/_plugin-vue2_normalizer-7f9efb60.cjs.map +1 -0
  414. package/dist/chunks/actionGlobal-8c1c28c9.mjs +50 -0
  415. package/dist/chunks/{actionGlobal-cda46023.mjs.map → actionGlobal-8c1c28c9.mjs.map} +1 -1
  416. package/dist/chunks/actionGlobal-9e29e11b.cjs +49 -0
  417. package/dist/chunks/{actionGlobal-ec7003e8.cjs.map → actionGlobal-9e29e11b.cjs.map} +1 -1
  418. package/dist/chunks/actionText-9f5c55bd.mjs +121 -0
  419. package/dist/chunks/{actionText-6c35d3fc.mjs.map → actionText-9f5c55bd.mjs.map} +1 -1
  420. package/dist/chunks/actionText-b0bd6eb7.cjs +120 -0
  421. package/dist/chunks/{actionText-bef01778.cjs.map → actionText-b0bd6eb7.cjs.map} +1 -1
  422. package/dist/chunks/focusTrap-14985831.cjs +26 -0
  423. package/dist/chunks/{focusTrap-173aba65.mjs.map → focusTrap-14985831.cjs.map} +1 -1
  424. package/dist/chunks/focusTrap-5d0f71d4.mjs +27 -0
  425. package/dist/chunks/{focusTrap-139520e2.cjs.map → focusTrap-5d0f71d4.mjs.map} +1 -1
  426. package/dist/chunks/index-20a9ace9.mjs +149 -0
  427. package/dist/chunks/{index-cd3f1f8f.mjs.map → index-20a9ace9.mjs.map} +1 -1
  428. package/dist/chunks/index-2a5b8ace.cjs +434 -0
  429. package/dist/chunks/index-2a5b8ace.cjs.map +1 -0
  430. package/dist/chunks/index-4398f925.cjs +149 -0
  431. package/dist/chunks/{index-c4cd0463.cjs.map → index-4398f925.cjs.map} +1 -1
  432. package/dist/chunks/index-5f2a5f57.mjs +155 -0
  433. package/dist/chunks/{index-9c621303.mjs.map → index-5f2a5f57.mjs.map} +1 -1
  434. package/dist/chunks/index-6c221fa0.mjs +447 -0
  435. package/dist/chunks/index-6c221fa0.mjs.map +1 -0
  436. package/dist/chunks/index-e894376a.cjs +148 -0
  437. package/dist/chunks/{index-df3f51c6.cjs.map → index-e894376a.cjs.map} +1 -1
  438. package/dist/chunks/l10n-27a75c40.mjs +31 -0
  439. package/dist/chunks/l10n-27a75c40.mjs.map +1 -0
  440. package/dist/chunks/l10n-4326316a.cjs +8 -0
  441. package/dist/chunks/l10n-4326316a.cjs.map +1 -0
  442. package/dist/chunks/l10n-903083c4.cjs +29 -0
  443. package/dist/chunks/l10n-903083c4.cjs.map +1 -0
  444. package/dist/chunks/l10n-c5f5f001.mjs +10 -0
  445. package/dist/chunks/l10n-c5f5f001.mjs.map +1 -0
  446. package/dist/chunks/logger-3612e664.mjs +25 -0
  447. package/dist/chunks/{logger-01af1a78.cjs.map → logger-3612e664.mjs.map} +1 -1
  448. package/dist/chunks/logger-4998b668.cjs +24 -0
  449. package/dist/chunks/{logger-ccc7ee65.mjs.map → logger-4998b668.cjs.map} +1 -1
  450. package/dist/chunks/referencePickerModal-0fde503d.mjs +877 -0
  451. package/dist/chunks/referencePickerModal-0fde503d.mjs.map +1 -0
  452. package/dist/chunks/referencePickerModal-9b4ff88d.cjs +858 -0
  453. package/dist/chunks/referencePickerModal-9b4ff88d.cjs.map +1 -0
  454. package/dist/index.cjs +251 -1
  455. package/dist/index.cjs.map +1 -1
  456. package/dist/index.mjs +286 -140
  457. package/dist/index.mjs.map +1 -1
  458. package/package.json +7 -7
  459. package/dist/Components/NcDatetime.cjs +0 -1
  460. package/dist/Components/NcDatetime.mjs +0 -44
  461. package/dist/Components/NcDatetimePicker.cjs +0 -1
  462. package/dist/Components/NcDatetimePicker.cjs.map +0 -1
  463. package/dist/Components/NcDatetimePicker.mjs +0 -69
  464. package/dist/Components/NcDatetimePicker.mjs.map +0 -1
  465. package/dist/assets/NcMentionBubble.css +0 -21
  466. package/dist/assets/index10.css +0 -21
  467. package/dist/assets/index11.css +0 -21
  468. package/dist/assets/index12.css +0 -21
  469. package/dist/assets/index14.css +0 -21
  470. package/dist/assets/index15.css +0 -21
  471. package/dist/assets/index16.css +0 -21
  472. package/dist/assets/index18.css +0 -21
  473. package/dist/assets/index19.css +0 -21
  474. package/dist/assets/index20.css +0 -21
  475. package/dist/assets/index21.css +0 -21
  476. package/dist/assets/index23.css +0 -21
  477. package/dist/assets/index24.css +0 -1
  478. package/dist/assets/index25.css +0 -21
  479. package/dist/assets/index26.css +0 -21
  480. package/dist/assets/index3.css +0 -21
  481. package/dist/assets/index30.css +0 -21
  482. package/dist/assets/index31.css +0 -21
  483. package/dist/assets/index32.css +0 -21
  484. package/dist/assets/index33.css +0 -21
  485. package/dist/assets/index34.css +0 -21
  486. package/dist/assets/index35.css +0 -21
  487. package/dist/assets/index36.css +0 -21
  488. package/dist/assets/index37.css +0 -21
  489. package/dist/assets/index38.css +0 -21
  490. package/dist/assets/index39.css +0 -21
  491. package/dist/assets/index4.css +0 -21
  492. package/dist/assets/index40.css +0 -21
  493. package/dist/assets/index41.css +0 -21
  494. package/dist/assets/index42.css +0 -21
  495. package/dist/assets/index43.css +0 -42
  496. package/dist/assets/index44.css +0 -21
  497. package/dist/assets/index45.css +0 -42
  498. package/dist/assets/index49.css +0 -42
  499. package/dist/assets/index5.css +0 -21
  500. package/dist/assets/index51.css +0 -21
  501. package/dist/assets/index52.css +0 -21
  502. package/dist/assets/index53.css +0 -42
  503. package/dist/assets/index54.css +0 -21
  504. package/dist/assets/index55.css +0 -21
  505. package/dist/assets/index56.css +0 -21
  506. package/dist/assets/index57.css +0 -21
  507. package/dist/assets/index58.css +0 -42
  508. package/dist/assets/index6.css +0 -21
  509. package/dist/assets/index7.css +0 -21
  510. package/dist/assets/index8.css +0 -21
  511. package/dist/assets/index9.css +0 -21
  512. package/dist/assets/referencePickerModal.css +0 -21
  513. package/dist/chunks/GenColors-8097de04.cjs +0 -1
  514. package/dist/chunks/GenColors-85cb6194.mjs +0 -25
  515. package/dist/chunks/GenRandomId-1e1b509a.mjs +0 -4
  516. package/dist/chunks/GenRandomId-67df40eb.cjs +0 -1
  517. package/dist/chunks/IsMobileState-151fc57d.cjs +0 -1
  518. package/dist/chunks/IsMobileState-151fc57d.cjs.map +0 -1
  519. package/dist/chunks/IsMobileState-e1fe5f58.mjs +0 -15
  520. package/dist/chunks/IsMobileState-e1fe5f58.mjs.map +0 -1
  521. package/dist/chunks/Linkify-a0faf443.mjs +0 -5
  522. package/dist/chunks/Linkify-a4db36a9.cjs +0 -1
  523. package/dist/chunks/NcAppNavigationToggle-5aa396d7.mjs +0 -23
  524. package/dist/chunks/NcAppNavigationToggle-5aa396d7.mjs.map +0 -1
  525. package/dist/chunks/NcAppNavigationToggle-c566f66e.cjs +0 -1
  526. package/dist/chunks/NcAppNavigationToggle-c566f66e.cjs.map +0 -1
  527. package/dist/chunks/NcInputConfirmCancel-77c2b04f.cjs +0 -1
  528. package/dist/chunks/NcInputConfirmCancel-77c2b04f.cjs.map +0 -1
  529. package/dist/chunks/NcInputConfirmCancel-c440e1b1.mjs +0 -43
  530. package/dist/chunks/NcInputConfirmCancel-c440e1b1.mjs.map +0 -1
  531. package/dist/chunks/NcMentionBubble.vue_vue_type_style_index_0_scoped_357e6d0e_lang-b35c2f97.cjs.map +0 -1
  532. package/dist/chunks/NcMentionBubble.vue_vue_type_style_index_0_scoped_357e6d0e_lang-b99cdc21.mjs.map +0 -1
  533. package/dist/chunks/NcRichText-13b09624.mjs +0 -123
  534. package/dist/chunks/NcRichText-1e8854a1.cjs +0 -1
  535. package/dist/chunks/ScopeComponent-dbcd0e07.mjs +0 -8
  536. package/dist/chunks/ScopeComponent-f6122f5a.cjs +0 -1
  537. package/dist/chunks/_plugin-vue2_normalizer-5b4c43a4.mjs +0 -24
  538. package/dist/chunks/_plugin-vue2_normalizer-5b4c43a4.mjs.map +0 -1
  539. package/dist/chunks/_plugin-vue2_normalizer-764a4c12.cjs +0 -1
  540. package/dist/chunks/_plugin-vue2_normalizer-764a4c12.cjs.map +0 -1
  541. package/dist/chunks/actionGlobal-cda46023.mjs +0 -15
  542. package/dist/chunks/actionGlobal-ec7003e8.cjs +0 -1
  543. package/dist/chunks/actionText-6c35d3fc.mjs +0 -23
  544. package/dist/chunks/actionText-bef01778.cjs +0 -1
  545. package/dist/chunks/focusTrap-139520e2.cjs +0 -1
  546. package/dist/chunks/focusTrap-173aba65.mjs +0 -6
  547. package/dist/chunks/index-12fa9b26.cjs +0 -1
  548. package/dist/chunks/index-12fa9b26.cjs.map +0 -1
  549. package/dist/chunks/index-7aa3fc24.mjs +0 -171
  550. package/dist/chunks/index-7aa3fc24.mjs.map +0 -1
  551. package/dist/chunks/index-9c621303.mjs +0 -46
  552. package/dist/chunks/index-c4cd0463.cjs +0 -3
  553. package/dist/chunks/index-cd3f1f8f.mjs +0 -43
  554. package/dist/chunks/index-df3f51c6.cjs +0 -1
  555. package/dist/chunks/l10n-05baf7da.mjs +0 -5
  556. package/dist/chunks/l10n-05baf7da.mjs.map +0 -1
  557. package/dist/chunks/l10n-46d0c1c0.cjs +0 -1
  558. package/dist/chunks/l10n-46d0c1c0.cjs.map +0 -1
  559. package/dist/chunks/l10n-9a5a6afc.mjs +0 -18
  560. package/dist/chunks/l10n-9a5a6afc.mjs.map +0 -1
  561. package/dist/chunks/l10n-dacb6440.cjs +0 -1
  562. package/dist/chunks/l10n-dacb6440.cjs.map +0 -1
  563. package/dist/chunks/logger-01af1a78.cjs +0 -1
  564. package/dist/chunks/logger-ccc7ee65.mjs +0 -5
  565. package/dist/chunks/referencePickerModal-2b16b319.mjs +0 -428
  566. package/dist/chunks/referencePickerModal-2b16b319.mjs.map +0 -1
  567. package/dist/chunks/referencePickerModal-44160fb3.cjs +0 -1
  568. package/dist/chunks/referencePickerModal-44160fb3.cjs.map +0 -1
@@ -1,4 +1,24 @@
1
- import { N as p } from "../chunks/NcAppNavigationToggle-5aa396d7.mjs";
1
+ import { N as p } from "../chunks/NcAppNavigationToggle-d868f651.mjs";
2
+ /**
3
+ * @copyright 2019 Christoph Wurst <christoph@winzerhof-wurst.at>
4
+ *
5
+ * @author 2019 Christoph Wurst <christoph@winzerhof-wurst.at>
6
+ *
7
+ * @license AGPL-3.0-or-later
8
+ *
9
+ * This program is free software: you can redistribute it and/or modify
10
+ * it under the terms of the GNU Affero General Public License as
11
+ * published by the Free Software Foundation, either version 3 of the
12
+ * License, or (at your option) any later version.
13
+ *
14
+ * This program is distributed in the hope that it will be useful,
15
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17
+ * GNU Affero General Public License for more details.
18
+ *
19
+ * You should have received a copy of the GNU Affero General Public License
20
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
21
+ */
2
22
  export {
3
23
  p as NcAppNavigationSpacer,
4
24
  p as default
@@ -1 +1 @@
1
- {"version":3,"file":"NcAppNavigationToggle.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
1
+ {"version":3,"file":"NcAppNavigationToggle.mjs","sources":["../../src/components/NcAppNavigationToggle/index.js"],"sourcesContent":["/**\n * @copyright 2019 Christoph Wurst <christoph@winzerhof-wurst.at>\n *\n * @author 2019 Christoph Wurst <christoph@winzerhof-wurst.at>\n *\n * @license AGPL-3.0-or-later\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 */\nimport NcAppNavigationToggle from './NcAppNavigationToggle.vue'\n\nexport default NcAppNavigationToggle\nexport { NcAppNavigationToggle as NcAppNavigationSpacer }\n"],"names":[],"mappings":";AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;"}
@@ -1 +1,207 @@
1
- var f=require("../assets/index44.css");const r=require("./NcModal.cjs"),c=require("../Mixins/isMobile.cjs"),d=require("../chunks/l10n-46d0c1c0.cjs"),p=require("debounce"),h=require("../chunks/_plugin-vue2_normalizer-764a4c12.cjs");const u={name:"NcAppSettingsDialog",components:{NcModal:r},mixins:[c],props:{open:{type:Boolean,required:!0},showNavigation:{type:Boolean,default:!1},container:{type:String,default:"body"},name:{type:String,default:""},additionalTrapElements:{type:Array,default:()=>[]}},emits:["update:open"],data(){return{selectedSection:"",linkClicked:!1,addedScrollListener:!1,scroller:null}},computed:{hasNavigation(){return!(this.isMobile||!this.showNavigation)},settingsNavigationAriaLabel(){return d.t("Settings navigation")}},mounted(){this.selectedSection=this.$slots.default[0].componentOptions.propsData.id},updated(){this.$refs.settingsScroller&&(this.scroller=this.$refs.settingsScroller,this.addedScrollListener||(this.scroller.addEventListener("scroll",this.handleScroll),this.addedScrollListener=!0))},methods:{getSettingsNavigation(t){const n=t.filter(e=>e.componentOptions).map(e=>{var s,a;return{id:(s=e.componentOptions.propsData)==null?void 0:s.id,name:(a=e.componentOptions.propsData)==null?void 0:a.name}}),l=t.map(e=>e.name),i=t.map(e=>e.id);return n.forEach((e,s)=>{const a=[...l],o=[...i];if(a.splice(s,1),o.splice(s,1),a.includes(e.name))throw new Error(`Duplicate section name found: ${e}. Settings navigation sections must have unique section names.`);if(o.includes(e.id))throw new Error(`Duplicate section id found: ${e}. Settings navigation sections must have unique section ids.`)}),n},handleSettingsNavigationClick(t){this.linkClicked=!0,document.getElementById("settings-section_"+t).scrollIntoView({behavior:"smooth",inline:"nearest"}),this.selectedSection=t,setTimeout(()=>{this.linkClicked=!1},1e3)},handleCloseModal(){this.$emit("update:open",!1),this.scroller.removeEventListener("scroll",this.handleScroll),this.addedScrollListener=!1,this.scroller.scrollTop=0},handleScroll(){this.linkClicked||this.unfocusNavigationItem()},unfocusNavigationItem:p(function(){this.selectedSection="",document.activeElement.className.includes("navigation-list__link")&&document.activeElement.blur()},300),handleLinkKeydown(t,n){t.code==="Enter"&&this.handleSettingsNavigationClick(n)}},render(t){const n=()=>this.hasNavigation?[t("div",{attrs:{class:"app-settings__navigation",role:"tablist","aria-label":this.settingsNavigationAriaLabel}},[t("ul",{attrs:{class:"navigation-list",role:"tablist"}},this.getSettingsNavigation(this.$slots.default).map(i=>l(i)))])]:[],l=i=>t("li",{},[t("a",{class:{"navigation-list__link":!0,"navigation-list__link--active":i.id===this.selectedSection},attrs:{role:"tab","aria-selected":i.id===this.selectedSection,tabindex:"0"},on:{click:()=>this.handleSettingsNavigationClick(i.id),keydown:()=>this.handleLinkKeydown(event,i.id)}},i.name)]);if(this.open)return t("NcModal",{class:["app-settings-modal"],attrs:{container:this.container,size:"large",additionalTrapElements:this.additionalTrapElements},on:{close:()=>{this.handleCloseModal()}}},[t("div",{attrs:{class:"app-settings"}},[t("h2",{attrs:{class:"app-settings__name"}},this.name),t("div",{attrs:{class:"app-settings__wrapper"}},[...n(),t("div",{attrs:{class:"app-settings__content"},ref:"settingsScroller"},this.$slots.default)])])])}},g=null,m=null;var v=h.normalizeComponent(u,g,m,!1,null,"0ff961d8",null,null);const S=v.exports;module.exports=S;
1
+ var N = require("../assets/index-1cf8eeb4.css");
2
+ const r = require("./NcModal.cjs"), c = require("../Mixins/isMobile.cjs"), d = require("../chunks/l10n-903083c4.cjs"), u = require("debounce"), p = require("../chunks/_plugin-vue2_normalizer-7f9efb60.cjs"), g = (t) => t && t.__esModule ? t : { default: t }, h = /* @__PURE__ */ g(u);
3
+ const f = {
4
+ name: "NcAppSettingsDialog",
5
+ components: {
6
+ NcModal: r
7
+ },
8
+ mixins: [c],
9
+ props: {
10
+ /**
11
+ * Determines the open / closed state of the modal
12
+ */
13
+ open: {
14
+ type: Boolean,
15
+ required: !0
16
+ },
17
+ /**
18
+ * Shows the navigation on desktop if true
19
+ */
20
+ showNavigation: {
21
+ type: Boolean,
22
+ default: !1
23
+ },
24
+ /**
25
+ * Selector for the popover container
26
+ */
27
+ container: {
28
+ type: String,
29
+ default: "body"
30
+ },
31
+ /**
32
+ * Name of the settings
33
+ */
34
+ name: {
35
+ type: String,
36
+ default: ""
37
+ },
38
+ /**
39
+ * Additional elements to add to the focus trap
40
+ */
41
+ additionalTrapElements: {
42
+ type: Array,
43
+ default: () => []
44
+ }
45
+ },
46
+ emits: ["update:open"],
47
+ data() {
48
+ return {
49
+ selectedSection: "",
50
+ linkClicked: !1,
51
+ addedScrollListener: !1,
52
+ scroller: null
53
+ };
54
+ },
55
+ computed: {
56
+ hasNavigation() {
57
+ return !(this.isMobile || !this.showNavigation);
58
+ },
59
+ settingsNavigationAriaLabel() {
60
+ return d.t("Settings navigation");
61
+ }
62
+ },
63
+ mounted() {
64
+ this.selectedSection = this.$slots.default[0].componentOptions.propsData.id;
65
+ },
66
+ updated() {
67
+ this.$refs.settingsScroller && (this.scroller = this.$refs.settingsScroller, this.addedScrollListener || (this.scroller.addEventListener("scroll", this.handleScroll), this.addedScrollListener = !0));
68
+ },
69
+ methods: {
70
+ /**
71
+ * Builds the settings navigation menu
72
+ *
73
+ * @param {object} slots The default slots object passed from the render function.
74
+ * @return {Array} the navigation items
75
+ */
76
+ getSettingsNavigation(t) {
77
+ const n = t.filter((e) => e.componentOptions).map((e) => {
78
+ var s, a;
79
+ return {
80
+ id: (s = e.componentOptions.propsData) == null ? void 0 : s.id,
81
+ name: (a = e.componentOptions.propsData) == null ? void 0 : a.name
82
+ };
83
+ }), o = t.map((e) => e.name), i = t.map((e) => e.id);
84
+ return n.forEach((e, s) => {
85
+ const a = [...o], l = [...i];
86
+ if (a.splice(s, 1), l.splice(s, 1), a.includes(e.name))
87
+ throw new Error(`Duplicate section name found: ${e}. Settings navigation sections must have unique section names.`);
88
+ if (l.includes(e.id))
89
+ throw new Error(`Duplicate section id found: ${e}. Settings navigation sections must have unique section ids.`);
90
+ }), n;
91
+ },
92
+ /**
93
+ * Scrolls the content to the selected settings section.absolute
94
+ *
95
+ * @param {string} item the ID of the section
96
+ */
97
+ handleSettingsNavigationClick(t) {
98
+ this.linkClicked = !0, document.getElementById("settings-section_" + t).scrollIntoView({
99
+ behavior: "smooth",
100
+ inline: "nearest"
101
+ }), this.selectedSection = t, setTimeout(() => {
102
+ this.linkClicked = !1;
103
+ }, 1e3);
104
+ },
105
+ handleCloseModal() {
106
+ this.$emit("update:open", !1), this.scroller.removeEventListener("scroll", this.handleScroll), this.addedScrollListener = !1, this.scroller.scrollTop = 0;
107
+ },
108
+ handleScroll() {
109
+ this.linkClicked || this.unfocusNavigationItem();
110
+ },
111
+ // Remove selected section once the user starts scrolling
112
+ unfocusNavigationItem: h.default(function() {
113
+ this.selectedSection = "", document.activeElement.className.includes("navigation-list__link") && document.activeElement.blur();
114
+ }, 300),
115
+ handleLinkKeydown(t, n) {
116
+ t.code === "Enter" && this.handleSettingsNavigationClick(n);
117
+ }
118
+ },
119
+ render(t) {
120
+ const n = () => this.hasNavigation ? [t("div", {
121
+ attrs: {
122
+ class: "app-settings__navigation",
123
+ role: "tablist",
124
+ "aria-label": this.settingsNavigationAriaLabel
125
+ }
126
+ }, [t("ul", {
127
+ attrs: {
128
+ class: "navigation-list",
129
+ role: "tablist"
130
+ }
131
+ }, this.getSettingsNavigation(this.$slots.default).map((i) => o(i)))])] : [], o = (i) => t("li", {}, [t("a", {
132
+ class: {
133
+ "navigation-list__link": !0,
134
+ "navigation-list__link--active": i.id === this.selectedSection
135
+ },
136
+ attrs: {
137
+ role: "tab",
138
+ "aria-selected": i.id === this.selectedSection,
139
+ tabindex: "0"
140
+ },
141
+ on: {
142
+ click: () => this.handleSettingsNavigationClick(i.id),
143
+ keydown: () => this.handleLinkKeydown(event, i.id)
144
+ }
145
+ }, i.name)]);
146
+ if (this.open)
147
+ return t("NcModal", {
148
+ class: [
149
+ "app-settings-modal"
150
+ ],
151
+ attrs: {
152
+ container: this.container,
153
+ size: "large",
154
+ additionalTrapElements: this.additionalTrapElements
155
+ },
156
+ on: {
157
+ close: () => {
158
+ this.handleCloseModal();
159
+ }
160
+ }
161
+ }, [
162
+ // main app-settings root element
163
+ t("div", {
164
+ attrs: {
165
+ class: "app-settings"
166
+ }
167
+ }, [
168
+ // app-settings name
169
+ t("h2", {
170
+ attrs: {
171
+ class: "app-settings__name"
172
+ }
173
+ }, this.name),
174
+ // app-settings navigation + content
175
+ t(
176
+ "div",
177
+ {
178
+ attrs: {
179
+ class: "app-settings__wrapper"
180
+ }
181
+ },
182
+ [
183
+ ...n(),
184
+ t("div", {
185
+ attrs: {
186
+ class: "app-settings__content"
187
+ },
188
+ ref: "settingsScroller"
189
+ }, this.$slots.default)
190
+ ]
191
+ )
192
+ ])
193
+ ]);
194
+ }
195
+ }, m = null, _ = null;
196
+ var v = /* @__PURE__ */ p.normalizeComponent(
197
+ f,
198
+ m,
199
+ _,
200
+ !1,
201
+ null,
202
+ "0ff961d8",
203
+ null,
204
+ null
205
+ );
206
+ const S = v.exports;
207
+ module.exports = S;
@@ -1 +1 @@
1
- {"version":3,"file":"NcAppSettingsDialog.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
1
+ {"version":3,"file":"NcAppSettingsDialog.cjs","sources":["../../src/components/NcAppSettingsDialog/NcAppSettingsDialog.vue"],"sourcesContent":["<!--\n - @copyright Copyright (c) 2020 Marco Ambrosini <marcoambrosini@icloud.com>\n -\n - @author Marco Ambrosini <marcoambrosini@icloud.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>\nJust nest the `AppSettingSections` component into `NcAppSettingsDialog`,\nproviding the section's name prop. You can put your settings within each\n`NcAppSettingsSection` component.\n\n```vue\n<template>\n\t<div>\n\t\t<NcButton @click=\"settingsOpen = true\">Show Settings</NcButton>\n\t\t<NcAppSettingsDialog :open.sync=\"settingsOpen\" :show-navigation=\"true\" name=\"Application settings\">\n\t\t\t<NcAppSettingsSection id=\"asci-name-1\" name=\"Example name 1\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-2\" name=\"Example name 2\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-3\" name=\"Example name 3\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-4\" name=\"Example name 4\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-5\" name=\"Example name 5\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-6\" name=\"Example name 6\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-7\" name=\"Example name 7\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-8\" name=\"Example name 8\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-9\" name=\"Example name 9\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-10\" name=\"Example name 10\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t</NcAppSettingsDialog>\n\t</div>\n</template>\n\n<script>\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\tsettingsOpen: false,\n\t\t}\n\t},\n}\n</script>\n```\n</docs>\n\n<script>\nimport NcModal from '../NcModal/index.js'\nimport isMobile from '../../mixins/isMobile/index.js'\nimport { t } from '../../l10n.js'\n\nimport debounce from 'debounce'\n\nexport default {\n\n\tname: 'NcAppSettingsDialog',\n\n\tcomponents: {\n\t\tNcModal,\n\t},\n\n\tmixins: [isMobile],\n\n\tprops: {\n\t\t/**\n\t\t * Determines the open / closed state of the modal\n\t\t */\n\t\topen: {\n\t\t\ttype: Boolean,\n\t\t\trequired: true,\n\t\t},\n\t\t/**\n\t\t * Shows the navigation on desktop if true\n\t\t */\n\t\tshowNavigation: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Selector for the popover container\n\t\t */\n\t\tcontainer: {\n\t\t\ttype: String,\n\t\t\tdefault: 'body',\n\t\t},\n\n\t\t/**\n\t\t * Name of the settings\n\t\t */\n\t\tname: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Additional elements to add to the focus trap\n\t\t */\n\t\tadditionalTrapElements: {\n\t\t\ttype: Array,\n\t\t\tdefault: () => [],\n\t\t},\n\n\t},\n\n\temits: ['update:open'],\n\n\tdata() {\n\t\treturn {\n\t\t\tselectedSection: '',\n\t\t\tlinkClicked: false,\n\t\t\taddedScrollListener: false,\n\t\t\tscroller: null,\n\t\t}\n\t},\n\n\tcomputed: {\n\n\t\thasNavigation() {\n\t\t\tif (this.isMobile || !this.showNavigation) {\n\t\t\t\treturn false\n\t\t\t} else {\n\t\t\t\treturn true\n\t\t\t}\n\t\t},\n\n\t\tsettingsNavigationAriaLabel() {\n\t\t\treturn t('Settings navigation')\n\t\t},\n\t},\n\n\tmounted() {\n\t\t// Select first settings section\n\t\tthis.selectedSection = this.$slots.default[0].componentOptions.propsData.id\n\t},\n\n\tupdated() {\n\t\t// Check that the scroller element has been mounted\n\t\tif (!this.$refs.settingsScroller) {\n\t\t\treturn\n\t\t}\n\t\t// Get the scroller element\n\t\tthis.scroller = this.$refs.settingsScroller\n\t\tif (!this.addedScrollListener) {\n\t\t\tthis.scroller.addEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = true\n\t\t}\n\n\t},\n\n\tmethods: {\n\n\t\t/**\n\t\t * Builds the settings navigation menu\n\t\t *\n\t\t * @param {object} slots The default slots object passed from the render function.\n\t\t * @return {Array} the navigation items\n\t\t */\n\t\tgetSettingsNavigation(slots) {\n\t\t\t// Array of navigationitems strings\n\t\t\tconst navigationItems = slots.filter(vNode => vNode.componentOptions).map(vNode => {\n\t\t\t\treturn {\n\t\t\t\t\tid: vNode.componentOptions.propsData?.id,\n\t\t\t\t\tname: vNode.componentOptions.propsData?.name,\n\t\t\t\t}\n\t\t\t})\n\t\t\tconst navigationNames = slots.map(item => item.name)\n\t\t\tconst navigationIds = slots.map(item => item.id)\n\n\t\t\t// Check for the uniqueness of section names\n\t\t\tnavigationItems.forEach((element, index) => {\n\t\t\t\tconst newNamesArray = [...navigationNames]\n\t\t\t\tconst newIdArray = [...navigationIds]\n\t\t\t\tnewNamesArray.splice(index, 1)\n\t\t\t\tnewIdArray.splice(index, 1)\n\t\t\t\tif (newNamesArray.includes(element.name)) {\n\t\t\t\t\tthrow new Error(`Duplicate section name found: ${element}. Settings navigation sections must have unique section names.`)\n\t\t\t\t}\n\t\t\t\tif (newIdArray.includes(element.id)) {\n\t\t\t\t\tthrow new Error(`Duplicate section id found: ${element}. Settings navigation sections must have unique section ids.`)\n\t\t\t\t}\n\t\t\t})\n\t\t\treturn navigationItems\n\t\t},\n\n\t\t/**\n\t\t * Scrolls the content to the selected settings section.absolute\n\t\t *\n\t\t * @param {string} item the ID of the section\n\t\t */\n\t\thandleSettingsNavigationClick(item) {\n\t\t\tthis.linkClicked = true\n\t\t\tdocument.getElementById('settings-section_' + item).scrollIntoView({\n\t\t\t\tbehavior: 'smooth',\n\t\t\t\tinline: 'nearest',\n\t\t\t})\n\t\t\tthis.selectedSection = item\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.linkClicked = false\n\t\t\t}, 1000)\n\t\t},\n\n\t\thandleCloseModal() {\n\t\t\tthis.$emit('update:open', false)\n\t\t\t// Remove scroll listener each time the modal is closed\n\t\t\tthis.scroller.removeEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = false\n\t\t\tthis.scroller.scrollTop = 0\n\t\t},\n\n\t\thandleScroll() {\n\t\t\tif (!this.linkClicked) {\n\t\t\t\tthis.unfocusNavigationItem()\n\t\t\t}\n\t\t},\n\n\t\t// Remove selected section once the user starts scrolling\n\t\tunfocusNavigationItem: debounce(function() {\n\t\t\tthis.selectedSection = ''\n\t\t\tif (document.activeElement.className.includes('navigation-list__link')) {\n\t\t\t\tdocument.activeElement.blur()\n\t\t\t}\n\t\t}, 300),\n\n\t\thandleLinkKeydown(keyDownEvent, item) {\n\t\t\tif (keyDownEvent.code === 'Enter') {\n\t\t\t\tthis.handleSettingsNavigationClick(item)\n\t\t\t}\n\t\t},\n\t},\n\n\trender(h) {\n\t\t/**\n\t\t * Build the navigation\n\t\t *\n\t\t * @return {object} the navigation\n\t\t */\n\t\tconst createAppSettingsNavigation = () => {\n\t\t\tif (this.hasNavigation) {\n\t\t\t\treturn [h('div', {\n\t\t\t\t\tattrs: {\n\t\t\t\t\t\tclass: 'app-settings__navigation',\n\t\t\t\t\t\trole: 'tablist',\n\t\t\t\t\t\t'aria-label': this.settingsNavigationAriaLabel,\n\t\t\t\t\t},\n\t\t\t\t}, [h('ul', {\n\t\t\t\t\tattrs: {\n\t\t\t\t\t\tclass: 'navigation-list',\n\t\t\t\t\t\trole: 'tablist',\n\t\t\t\t\t},\n\t\t\t\t}, this.getSettingsNavigation(this.$slots.default).map(item => {\n\t\t\t\t\treturn createListElement(item)\n\t\t\t\t}))])]\n\t\t\t} else {\n\t\t\t\treturn []\n\t\t\t}\n\t\t}\n\n\t\t/**\n\t\t * Build each list element in the navigation\n\t\t *\n\t\t * @param {object} item the navigation item\n\t\t * @return {object} the list element\n\t\t */\n\t\tconst createListElement = (item) => h('li', {}, [h('a', {\n\t\t\tclass: {\n\t\t\t\t'navigation-list__link': true,\n\t\t\t\t'navigation-list__link--active': item.id === this.selectedSection,\n\t\t\t},\n\n\t\t\tattrs: {\n\t\t\t\trole: 'tab',\n\t\t\t\t'aria-selected': item.id === this.selectedSection,\n\t\t\t\ttabindex: '0',\n\t\t\t},\n\n\t\t\ton: {\n\t\t\t\tclick: () => this.handleSettingsNavigationClick(item.id),\n\t\t\t\tkeydown: () => this.handleLinkKeydown(event, item.id),\n\t\t\t},\n\t\t}, item.name)])\n\n\t\t// Return value of the render function\n\t\tif (this.open) {\n\t\t\treturn h('NcModal', {\n\t\t\t\tclass: [\n\t\t\t\t\t'app-settings-modal',\n\t\t\t\t],\n\t\t\t\tattrs: {\n\t\t\t\t\tcontainer: this.container,\n\t\t\t\t\tsize: 'large',\n\t\t\t\t\tadditionalTrapElements: this.additionalTrapElements,\n\t\t\t\t},\n\t\t\t\ton: {\n\t\t\t\t\tclose: () => { this.handleCloseModal() },\n\t\t\t\t},\n\t\t\t}, [\n\t\t\t\t// main app-settings root element\n\t\t\t\th('div', {\n\t\t\t\t\tattrs: {\n\t\t\t\t\t\tclass: 'app-settings',\n\t\t\t\t\t},\n\t\t\t\t}, [\n\t\t\t\t\t// app-settings name\n\t\t\t\t\th('h2', {\n\t\t\t\t\t\tattrs: {\n\t\t\t\t\t\t\tclass: 'app-settings__name',\n\t\t\t\t\t\t},\n\t\t\t\t\t}, this.name),\n\n\t\t\t\t\t// app-settings navigation + content\n\t\t\t\t\th(\n\t\t\t\t\t\t'div',\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tattrs: {\n\t\t\t\t\t\t\t\tclass: 'app-settings__wrapper',\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t[\n\t\t\t\t\t\t\t...createAppSettingsNavigation(),\n\t\t\t\t\t\t\th('div', {\n\t\t\t\t\t\t\t\tattrs: {\n\t\t\t\t\t\t\t\t\tclass: 'app-settings__content',\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\tref: 'settingsScroller',\n\t\t\t\t\t\t\t}, this.$slots.default),\n\t\t\t\t\t\t],\n\t\t\t\t\t),\n\t\t\t\t]),\n\t\t\t])\n\t\t} else {\n\t\t\treturn undefined\n\t\t}\n\t},\n}\n\n</script>\n\n<style lang=\"scss\" scoped>\n\n.app-settings-modal :deep(.modal-wrapper .modal-container) {\n\tdisplay: flex;\n\toverflow: hidden;\n}\n\n.app-settings {\n\twidth: 100%;\n\tdisplay: flex;\n\tflex-direction: column;\n\tmin-width: 0;\n\t&__name {\n\t\tmin-height: $clickable-area;\n\t\theight: $clickable-area;\n\t\tline-height: $clickable-area;\n\t\tpadding-top: 4px; // Same as the close button top spacing\n\t\ttext-align: center;\n\t}\n\t&__wrapper {\n\t\tdisplay: flex;\n\t\twidth: 100%;\n\t\toverflow: hidden;\n\t\theight: 100%;\n\t\tposition: relative;\n\t}\n\t&__navigation {\n\t\tmin-width: 200px;\n\t\tmargin-right: 20px;\n\t\toverflow-x: hidden;\n\t\toverflow-y: auto;\n\t\tposition: relative;\n\t\theight: 100%;\n\t}\n\t&__content {\n\t\tmax-width: 100vw;\n\t\toverflow-y: auto;\n\t\toverflow-x: hidden;\n\t\tpadding: 24px;\n\t\twidth: 100%;\n\t}\n}\n\n.navigation-list {\n\theight: 100%;\n\tbox-sizing: border-box;\n\toverflow-y: auto;\n\tpadding: 12px;\n\t&__link {\n\t\tdisplay: block;\n\t\tfont-size: 16px;\n\t\theight: $clickable-area;\n\t\tmargin: 4px 0;\n\t\tline-height: $clickable-area;\n\t\tborder-radius: var(--border-radius-pill);\n\t\tfont-weight: bold;\n\t\tpadding: 0 20px;\n\t\tcursor: pointer;\n\t\twhite-space: nowrap;\n\t\ttext-overflow: ellipsis;\n\t\toverflow: hidden;\n\t\tbackground-color: transparent;\n\t\tborder: none;\n\t\t&:hover,\n\t\t&:focus {\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\t\t&--active {\n\t\t\tbackground-color: var(--color-primary-element-light) !important;\n\t\t}\n\t}\n}\n\n</style>\n"],"names":["_sfc_main","Components_NcModal","Mixins_isMobile","l10n","slots","navigationItems","vNode","_a","_b","navigationNames","item","navigationIds","element","index","newNamesArray","newIdArray","debounce__default","keyDownEvent","h","createAppSettingsNavigation","createListElement"],"mappings":"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"}
@@ -1,52 +1,213 @@
1
- import "../assets/index23.css";
1
+ import "../assets/index-1cf8eeb4.css";
2
2
  import r from "./NcModal.mjs";
3
- import d from "../Mixins/isMobile.mjs";
4
- import { t as c } from "../chunks/l10n-9a5a6afc.mjs";
3
+ import c from "../Mixins/isMobile.mjs";
4
+ import { t as d } from "../chunks/l10n-27a75c40.mjs";
5
5
  import p from "debounce";
6
- import { n as h } from "../chunks/_plugin-vue2_normalizer-5b4c43a4.mjs";
7
- const m = { name: "NcAppSettingsDialog", components: { NcModal: r }, mixins: [d], props: { open: { type: Boolean, required: !0 }, showNavigation: { type: Boolean, default: !1 }, container: { type: String, default: "body" }, name: { type: String, default: "" }, additionalTrapElements: { type: Array, default: () => [] } }, emits: ["update:open"], data() {
8
- return { selectedSection: "", linkClicked: !1, addedScrollListener: !1, scroller: null };
9
- }, computed: { hasNavigation() {
10
- return !(this.isMobile || !this.showNavigation);
11
- }, settingsNavigationAriaLabel() {
12
- return c("Settings navigation");
13
- } }, mounted() {
14
- this.selectedSection = this.$slots.default[0].componentOptions.propsData.id;
15
- }, updated() {
16
- this.$refs.settingsScroller && (this.scroller = this.$refs.settingsScroller, this.addedScrollListener || (this.scroller.addEventListener("scroll", this.handleScroll), this.addedScrollListener = !0));
17
- }, methods: { getSettingsNavigation(t) {
18
- const n = t.filter((e) => e.componentOptions).map((e) => {
19
- var s, a;
20
- return { id: (s = e.componentOptions.propsData) == null ? void 0 : s.id, name: (a = e.componentOptions.propsData) == null ? void 0 : a.name };
21
- }), o = t.map((e) => e.name), i = t.map((e) => e.id);
22
- return n.forEach((e, s) => {
23
- const a = [...o], l = [...i];
24
- if (a.splice(s, 1), l.splice(s, 1), a.includes(e.name))
25
- throw new Error(`Duplicate section name found: ${e}. Settings navigation sections must have unique section names.`);
26
- if (l.includes(e.id))
27
- throw new Error(`Duplicate section id found: ${e}. Settings navigation sections must have unique section ids.`);
28
- }), n;
29
- }, handleSettingsNavigationClick(t) {
30
- this.linkClicked = !0, document.getElementById("settings-section_" + t).scrollIntoView({ behavior: "smooth", inline: "nearest" }), this.selectedSection = t, setTimeout(() => {
31
- this.linkClicked = !1;
32
- }, 1e3);
33
- }, handleCloseModal() {
34
- this.$emit("update:open", !1), this.scroller.removeEventListener("scroll", this.handleScroll), this.addedScrollListener = !1, this.scroller.scrollTop = 0;
35
- }, handleScroll() {
36
- this.linkClicked || this.unfocusNavigationItem();
37
- }, unfocusNavigationItem: p(function() {
38
- this.selectedSection = "", document.activeElement.className.includes("navigation-list__link") && document.activeElement.blur();
39
- }, 300), handleLinkKeydown(t, n) {
40
- t.code === "Enter" && this.handleSettingsNavigationClick(n);
41
- } }, render(t) {
42
- const n = () => this.hasNavigation ? [t("div", { attrs: { class: "app-settings__navigation", role: "tablist", "aria-label": this.settingsNavigationAriaLabel } }, [t("ul", { attrs: { class: "navigation-list", role: "tablist" } }, this.getSettingsNavigation(this.$slots.default).map((i) => o(i)))])] : [], o = (i) => t("li", {}, [t("a", { class: { "navigation-list__link": !0, "navigation-list__link--active": i.id === this.selectedSection }, attrs: { role: "tab", "aria-selected": i.id === this.selectedSection, tabindex: "0" }, on: { click: () => this.handleSettingsNavigationClick(i.id), keydown: () => this.handleLinkKeydown(event, i.id) } }, i.name)]);
43
- if (this.open)
44
- return t("NcModal", { class: ["app-settings-modal"], attrs: { container: this.container, size: "large", additionalTrapElements: this.additionalTrapElements }, on: { close: () => {
45
- this.handleCloseModal();
46
- } } }, [t("div", { attrs: { class: "app-settings" } }, [t("h2", { attrs: { class: "app-settings__name" } }, this.name), t("div", { attrs: { class: "app-settings__wrapper" } }, [...n(), t("div", { attrs: { class: "app-settings__content" }, ref: "settingsScroller" }, this.$slots.default)])])]);
47
- } }, g = null, u = null;
48
- var v = h(m, g, u, !1, null, "0ff961d8", null, null);
49
- const E = v.exports;
6
+ import { n as u } from "../chunks/_plugin-vue2_normalizer-71e2aa87.mjs";
7
+ const g = {
8
+ name: "NcAppSettingsDialog",
9
+ components: {
10
+ NcModal: r
11
+ },
12
+ mixins: [c],
13
+ props: {
14
+ /**
15
+ * Determines the open / closed state of the modal
16
+ */
17
+ open: {
18
+ type: Boolean,
19
+ required: !0
20
+ },
21
+ /**
22
+ * Shows the navigation on desktop if true
23
+ */
24
+ showNavigation: {
25
+ type: Boolean,
26
+ default: !1
27
+ },
28
+ /**
29
+ * Selector for the popover container
30
+ */
31
+ container: {
32
+ type: String,
33
+ default: "body"
34
+ },
35
+ /**
36
+ * Name of the settings
37
+ */
38
+ name: {
39
+ type: String,
40
+ default: ""
41
+ },
42
+ /**
43
+ * Additional elements to add to the focus trap
44
+ */
45
+ additionalTrapElements: {
46
+ type: Array,
47
+ default: () => []
48
+ }
49
+ },
50
+ emits: ["update:open"],
51
+ data() {
52
+ return {
53
+ selectedSection: "",
54
+ linkClicked: !1,
55
+ addedScrollListener: !1,
56
+ scroller: null
57
+ };
58
+ },
59
+ computed: {
60
+ hasNavigation() {
61
+ return !(this.isMobile || !this.showNavigation);
62
+ },
63
+ settingsNavigationAriaLabel() {
64
+ return d("Settings navigation");
65
+ }
66
+ },
67
+ mounted() {
68
+ this.selectedSection = this.$slots.default[0].componentOptions.propsData.id;
69
+ },
70
+ updated() {
71
+ this.$refs.settingsScroller && (this.scroller = this.$refs.settingsScroller, this.addedScrollListener || (this.scroller.addEventListener("scroll", this.handleScroll), this.addedScrollListener = !0));
72
+ },
73
+ methods: {
74
+ /**
75
+ * Builds the settings navigation menu
76
+ *
77
+ * @param {object} slots The default slots object passed from the render function.
78
+ * @return {Array} the navigation items
79
+ */
80
+ getSettingsNavigation(t) {
81
+ const n = t.filter((e) => e.componentOptions).map((e) => {
82
+ var s, a;
83
+ return {
84
+ id: (s = e.componentOptions.propsData) == null ? void 0 : s.id,
85
+ name: (a = e.componentOptions.propsData) == null ? void 0 : a.name
86
+ };
87
+ }), o = t.map((e) => e.name), i = t.map((e) => e.id);
88
+ return n.forEach((e, s) => {
89
+ const a = [...o], l = [...i];
90
+ if (a.splice(s, 1), l.splice(s, 1), a.includes(e.name))
91
+ throw new Error(`Duplicate section name found: ${e}. Settings navigation sections must have unique section names.`);
92
+ if (l.includes(e.id))
93
+ throw new Error(`Duplicate section id found: ${e}. Settings navigation sections must have unique section ids.`);
94
+ }), n;
95
+ },
96
+ /**
97
+ * Scrolls the content to the selected settings section.absolute
98
+ *
99
+ * @param {string} item the ID of the section
100
+ */
101
+ handleSettingsNavigationClick(t) {
102
+ this.linkClicked = !0, document.getElementById("settings-section_" + t).scrollIntoView({
103
+ behavior: "smooth",
104
+ inline: "nearest"
105
+ }), this.selectedSection = t, setTimeout(() => {
106
+ this.linkClicked = !1;
107
+ }, 1e3);
108
+ },
109
+ handleCloseModal() {
110
+ this.$emit("update:open", !1), this.scroller.removeEventListener("scroll", this.handleScroll), this.addedScrollListener = !1, this.scroller.scrollTop = 0;
111
+ },
112
+ handleScroll() {
113
+ this.linkClicked || this.unfocusNavigationItem();
114
+ },
115
+ // Remove selected section once the user starts scrolling
116
+ unfocusNavigationItem: p(function() {
117
+ this.selectedSection = "", document.activeElement.className.includes("navigation-list__link") && document.activeElement.blur();
118
+ }, 300),
119
+ handleLinkKeydown(t, n) {
120
+ t.code === "Enter" && this.handleSettingsNavigationClick(n);
121
+ }
122
+ },
123
+ render(t) {
124
+ const n = () => this.hasNavigation ? [t("div", {
125
+ attrs: {
126
+ class: "app-settings__navigation",
127
+ role: "tablist",
128
+ "aria-label": this.settingsNavigationAriaLabel
129
+ }
130
+ }, [t("ul", {
131
+ attrs: {
132
+ class: "navigation-list",
133
+ role: "tablist"
134
+ }
135
+ }, this.getSettingsNavigation(this.$slots.default).map((i) => o(i)))])] : [], o = (i) => t("li", {}, [t("a", {
136
+ class: {
137
+ "navigation-list__link": !0,
138
+ "navigation-list__link--active": i.id === this.selectedSection
139
+ },
140
+ attrs: {
141
+ role: "tab",
142
+ "aria-selected": i.id === this.selectedSection,
143
+ tabindex: "0"
144
+ },
145
+ on: {
146
+ click: () => this.handleSettingsNavigationClick(i.id),
147
+ keydown: () => this.handleLinkKeydown(event, i.id)
148
+ }
149
+ }, i.name)]);
150
+ if (this.open)
151
+ return t("NcModal", {
152
+ class: [
153
+ "app-settings-modal"
154
+ ],
155
+ attrs: {
156
+ container: this.container,
157
+ size: "large",
158
+ additionalTrapElements: this.additionalTrapElements
159
+ },
160
+ on: {
161
+ close: () => {
162
+ this.handleCloseModal();
163
+ }
164
+ }
165
+ }, [
166
+ // main app-settings root element
167
+ t("div", {
168
+ attrs: {
169
+ class: "app-settings"
170
+ }
171
+ }, [
172
+ // app-settings name
173
+ t("h2", {
174
+ attrs: {
175
+ class: "app-settings__name"
176
+ }
177
+ }, this.name),
178
+ // app-settings navigation + content
179
+ t(
180
+ "div",
181
+ {
182
+ attrs: {
183
+ class: "app-settings__wrapper"
184
+ }
185
+ },
186
+ [
187
+ ...n(),
188
+ t("div", {
189
+ attrs: {
190
+ class: "app-settings__content"
191
+ },
192
+ ref: "settingsScroller"
193
+ }, this.$slots.default)
194
+ ]
195
+ )
196
+ ])
197
+ ]);
198
+ }
199
+ }, m = null, h = null;
200
+ var f = /* @__PURE__ */ u(
201
+ g,
202
+ m,
203
+ h,
204
+ !1,
205
+ null,
206
+ "0ff961d8",
207
+ null,
208
+ null
209
+ );
210
+ const b = f.exports;
50
211
  export {
51
- E as default
212
+ b as default
52
213
  };
@@ -1 +1 @@
1
- {"version":3,"file":"NcAppSettingsDialog.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"NcAppSettingsDialog.mjs","sources":["../../src/components/NcAppSettingsDialog/NcAppSettingsDialog.vue"],"sourcesContent":["<!--\n - @copyright Copyright (c) 2020 Marco Ambrosini <marcoambrosini@icloud.com>\n -\n - @author Marco Ambrosini <marcoambrosini@icloud.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>\nJust nest the `AppSettingSections` component into `NcAppSettingsDialog`,\nproviding the section's name prop. You can put your settings within each\n`NcAppSettingsSection` component.\n\n```vue\n<template>\n\t<div>\n\t\t<NcButton @click=\"settingsOpen = true\">Show Settings</NcButton>\n\t\t<NcAppSettingsDialog :open.sync=\"settingsOpen\" :show-navigation=\"true\" name=\"Application settings\">\n\t\t\t<NcAppSettingsSection id=\"asci-name-1\" name=\"Example name 1\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-2\" name=\"Example name 2\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-3\" name=\"Example name 3\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-4\" name=\"Example name 4\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-5\" name=\"Example name 5\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-6\" name=\"Example name 6\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-7\" name=\"Example name 7\">\n\t\t\t\tSome example content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-8\" name=\"Example name 8\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-9\" name=\"Example name 9\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t\t<NcAppSettingsSection id=\"asci-name-10\" name=\"Example name 10\">\n\t\t\t\tSome more content\n\t\t\t</NcAppSettingsSection>\n\t\t</NcAppSettingsDialog>\n\t</div>\n</template>\n\n<script>\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\tsettingsOpen: false,\n\t\t}\n\t},\n}\n</script>\n```\n</docs>\n\n<script>\nimport NcModal from '../NcModal/index.js'\nimport isMobile from '../../mixins/isMobile/index.js'\nimport { t } from '../../l10n.js'\n\nimport debounce from 'debounce'\n\nexport default {\n\n\tname: 'NcAppSettingsDialog',\n\n\tcomponents: {\n\t\tNcModal,\n\t},\n\n\tmixins: [isMobile],\n\n\tprops: {\n\t\t/**\n\t\t * Determines the open / closed state of the modal\n\t\t */\n\t\topen: {\n\t\t\ttype: Boolean,\n\t\t\trequired: true,\n\t\t},\n\t\t/**\n\t\t * Shows the navigation on desktop if true\n\t\t */\n\t\tshowNavigation: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Selector for the popover container\n\t\t */\n\t\tcontainer: {\n\t\t\ttype: String,\n\t\t\tdefault: 'body',\n\t\t},\n\n\t\t/**\n\t\t * Name of the settings\n\t\t */\n\t\tname: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Additional elements to add to the focus trap\n\t\t */\n\t\tadditionalTrapElements: {\n\t\t\ttype: Array,\n\t\t\tdefault: () => [],\n\t\t},\n\n\t},\n\n\temits: ['update:open'],\n\n\tdata() {\n\t\treturn {\n\t\t\tselectedSection: '',\n\t\t\tlinkClicked: false,\n\t\t\taddedScrollListener: false,\n\t\t\tscroller: null,\n\t\t}\n\t},\n\n\tcomputed: {\n\n\t\thasNavigation() {\n\t\t\tif (this.isMobile || !this.showNavigation) {\n\t\t\t\treturn false\n\t\t\t} else {\n\t\t\t\treturn true\n\t\t\t}\n\t\t},\n\n\t\tsettingsNavigationAriaLabel() {\n\t\t\treturn t('Settings navigation')\n\t\t},\n\t},\n\n\tmounted() {\n\t\t// Select first settings section\n\t\tthis.selectedSection = this.$slots.default[0].componentOptions.propsData.id\n\t},\n\n\tupdated() {\n\t\t// Check that the scroller element has been mounted\n\t\tif (!this.$refs.settingsScroller) {\n\t\t\treturn\n\t\t}\n\t\t// Get the scroller element\n\t\tthis.scroller = this.$refs.settingsScroller\n\t\tif (!this.addedScrollListener) {\n\t\t\tthis.scroller.addEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = true\n\t\t}\n\n\t},\n\n\tmethods: {\n\n\t\t/**\n\t\t * Builds the settings navigation menu\n\t\t *\n\t\t * @param {object} slots The default slots object passed from the render function.\n\t\t * @return {Array} the navigation items\n\t\t */\n\t\tgetSettingsNavigation(slots) {\n\t\t\t// Array of navigationitems strings\n\t\t\tconst navigationItems = slots.filter(vNode => vNode.componentOptions).map(vNode => {\n\t\t\t\treturn {\n\t\t\t\t\tid: vNode.componentOptions.propsData?.id,\n\t\t\t\t\tname: vNode.componentOptions.propsData?.name,\n\t\t\t\t}\n\t\t\t})\n\t\t\tconst navigationNames = slots.map(item => item.name)\n\t\t\tconst navigationIds = slots.map(item => item.id)\n\n\t\t\t// Check for the uniqueness of section names\n\t\t\tnavigationItems.forEach((element, index) => {\n\t\t\t\tconst newNamesArray = [...navigationNames]\n\t\t\t\tconst newIdArray = [...navigationIds]\n\t\t\t\tnewNamesArray.splice(index, 1)\n\t\t\t\tnewIdArray.splice(index, 1)\n\t\t\t\tif (newNamesArray.includes(element.name)) {\n\t\t\t\t\tthrow new Error(`Duplicate section name found: ${element}. Settings navigation sections must have unique section names.`)\n\t\t\t\t}\n\t\t\t\tif (newIdArray.includes(element.id)) {\n\t\t\t\t\tthrow new Error(`Duplicate section id found: ${element}. Settings navigation sections must have unique section ids.`)\n\t\t\t\t}\n\t\t\t})\n\t\t\treturn navigationItems\n\t\t},\n\n\t\t/**\n\t\t * Scrolls the content to the selected settings section.absolute\n\t\t *\n\t\t * @param {string} item the ID of the section\n\t\t */\n\t\thandleSettingsNavigationClick(item) {\n\t\t\tthis.linkClicked = true\n\t\t\tdocument.getElementById('settings-section_' + item).scrollIntoView({\n\t\t\t\tbehavior: 'smooth',\n\t\t\t\tinline: 'nearest',\n\t\t\t})\n\t\t\tthis.selectedSection = item\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.linkClicked = false\n\t\t\t}, 1000)\n\t\t},\n\n\t\thandleCloseModal() {\n\t\t\tthis.$emit('update:open', false)\n\t\t\t// Remove scroll listener each time the modal is closed\n\t\t\tthis.scroller.removeEventListener('scroll', this.handleScroll)\n\t\t\tthis.addedScrollListener = false\n\t\t\tthis.scroller.scrollTop = 0\n\t\t},\n\n\t\thandleScroll() {\n\t\t\tif (!this.linkClicked) {\n\t\t\t\tthis.unfocusNavigationItem()\n\t\t\t}\n\t\t},\n\n\t\t// Remove selected section once the user starts scrolling\n\t\tunfocusNavigationItem: debounce(function() {\n\t\t\tthis.selectedSection = ''\n\t\t\tif (document.activeElement.className.includes('navigation-list__link')) {\n\t\t\t\tdocument.activeElement.blur()\n\t\t\t}\n\t\t}, 300),\n\n\t\thandleLinkKeydown(keyDownEvent, item) {\n\t\t\tif (keyDownEvent.code === 'Enter') {\n\t\t\t\tthis.handleSettingsNavigationClick(item)\n\t\t\t}\n\t\t},\n\t},\n\n\trender(h) {\n\t\t/**\n\t\t * Build the navigation\n\t\t *\n\t\t * @return {object} the navigation\n\t\t */\n\t\tconst createAppSettingsNavigation = () => {\n\t\t\tif (this.hasNavigation) {\n\t\t\t\treturn [h('div', {\n\t\t\t\t\tattrs: {\n\t\t\t\t\t\tclass: 'app-settings__navigation',\n\t\t\t\t\t\trole: 'tablist',\n\t\t\t\t\t\t'aria-label': this.settingsNavigationAriaLabel,\n\t\t\t\t\t},\n\t\t\t\t}, [h('ul', {\n\t\t\t\t\tattrs: {\n\t\t\t\t\t\tclass: 'navigation-list',\n\t\t\t\t\t\trole: 'tablist',\n\t\t\t\t\t},\n\t\t\t\t}, this.getSettingsNavigation(this.$slots.default).map(item => {\n\t\t\t\t\treturn createListElement(item)\n\t\t\t\t}))])]\n\t\t\t} else {\n\t\t\t\treturn []\n\t\t\t}\n\t\t}\n\n\t\t/**\n\t\t * Build each list element in the navigation\n\t\t *\n\t\t * @param {object} item the navigation item\n\t\t * @return {object} the list element\n\t\t */\n\t\tconst createListElement = (item) => h('li', {}, [h('a', {\n\t\t\tclass: {\n\t\t\t\t'navigation-list__link': true,\n\t\t\t\t'navigation-list__link--active': item.id === this.selectedSection,\n\t\t\t},\n\n\t\t\tattrs: {\n\t\t\t\trole: 'tab',\n\t\t\t\t'aria-selected': item.id === this.selectedSection,\n\t\t\t\ttabindex: '0',\n\t\t\t},\n\n\t\t\ton: {\n\t\t\t\tclick: () => this.handleSettingsNavigationClick(item.id),\n\t\t\t\tkeydown: () => this.handleLinkKeydown(event, item.id),\n\t\t\t},\n\t\t}, item.name)])\n\n\t\t// Return value of the render function\n\t\tif (this.open) {\n\t\t\treturn h('NcModal', {\n\t\t\t\tclass: [\n\t\t\t\t\t'app-settings-modal',\n\t\t\t\t],\n\t\t\t\tattrs: {\n\t\t\t\t\tcontainer: this.container,\n\t\t\t\t\tsize: 'large',\n\t\t\t\t\tadditionalTrapElements: this.additionalTrapElements,\n\t\t\t\t},\n\t\t\t\ton: {\n\t\t\t\t\tclose: () => { this.handleCloseModal() },\n\t\t\t\t},\n\t\t\t}, [\n\t\t\t\t// main app-settings root element\n\t\t\t\th('div', {\n\t\t\t\t\tattrs: {\n\t\t\t\t\t\tclass: 'app-settings',\n\t\t\t\t\t},\n\t\t\t\t}, [\n\t\t\t\t\t// app-settings name\n\t\t\t\t\th('h2', {\n\t\t\t\t\t\tattrs: {\n\t\t\t\t\t\t\tclass: 'app-settings__name',\n\t\t\t\t\t\t},\n\t\t\t\t\t}, this.name),\n\n\t\t\t\t\t// app-settings navigation + content\n\t\t\t\t\th(\n\t\t\t\t\t\t'div',\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tattrs: {\n\t\t\t\t\t\t\t\tclass: 'app-settings__wrapper',\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t[\n\t\t\t\t\t\t\t...createAppSettingsNavigation(),\n\t\t\t\t\t\t\th('div', {\n\t\t\t\t\t\t\t\tattrs: {\n\t\t\t\t\t\t\t\t\tclass: 'app-settings__content',\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\tref: 'settingsScroller',\n\t\t\t\t\t\t\t}, this.$slots.default),\n\t\t\t\t\t\t],\n\t\t\t\t\t),\n\t\t\t\t]),\n\t\t\t])\n\t\t} else {\n\t\t\treturn undefined\n\t\t}\n\t},\n}\n\n</script>\n\n<style lang=\"scss\" scoped>\n\n.app-settings-modal :deep(.modal-wrapper .modal-container) {\n\tdisplay: flex;\n\toverflow: hidden;\n}\n\n.app-settings {\n\twidth: 100%;\n\tdisplay: flex;\n\tflex-direction: column;\n\tmin-width: 0;\n\t&__name {\n\t\tmin-height: $clickable-area;\n\t\theight: $clickable-area;\n\t\tline-height: $clickable-area;\n\t\tpadding-top: 4px; // Same as the close button top spacing\n\t\ttext-align: center;\n\t}\n\t&__wrapper {\n\t\tdisplay: flex;\n\t\twidth: 100%;\n\t\toverflow: hidden;\n\t\theight: 100%;\n\t\tposition: relative;\n\t}\n\t&__navigation {\n\t\tmin-width: 200px;\n\t\tmargin-right: 20px;\n\t\toverflow-x: hidden;\n\t\toverflow-y: auto;\n\t\tposition: relative;\n\t\theight: 100%;\n\t}\n\t&__content {\n\t\tmax-width: 100vw;\n\t\toverflow-y: auto;\n\t\toverflow-x: hidden;\n\t\tpadding: 24px;\n\t\twidth: 100%;\n\t}\n}\n\n.navigation-list {\n\theight: 100%;\n\tbox-sizing: border-box;\n\toverflow-y: auto;\n\tpadding: 12px;\n\t&__link {\n\t\tdisplay: block;\n\t\tfont-size: 16px;\n\t\theight: $clickable-area;\n\t\tmargin: 4px 0;\n\t\tline-height: $clickable-area;\n\t\tborder-radius: var(--border-radius-pill);\n\t\tfont-weight: bold;\n\t\tpadding: 0 20px;\n\t\tcursor: pointer;\n\t\twhite-space: nowrap;\n\t\ttext-overflow: ellipsis;\n\t\toverflow: hidden;\n\t\tbackground-color: transparent;\n\t\tborder: none;\n\t\t&:hover,\n\t\t&:focus {\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\t\t&--active {\n\t\t\tbackground-color: var(--color-primary-element-light) !important;\n\t\t}\n\t}\n}\n\n</style>\n"],"names":["_sfc_main","NcModal","isMobile","t","slots","navigationItems","vNode","_a","_b","navigationNames","item","navigationIds","element","index","newNamesArray","newIdArray","debounce","keyDownEvent","h","createAppSettingsNavigation","createListElement"],"mappings":"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"}
@@ -1 +1,39 @@
1
- var p=require("../assets/index22.css");const s=require("../chunks/_plugin-vue2_normalizer-764a4c12.cjs");const n={name:"NcAppSettingsSection",props:{name:{type:String,required:!0},id:{type:String,required:!0,validator(t){return/^[a-z0-9\-_]+$/.test(t)}}},computed:{htmlId(){return"settings-section_"+this.id}}};var i=function(){var t=this,e=t._self._c;return e("div",{staticClass:"app-settings-section",attrs:{id:t.htmlId}},[e("h3",{staticClass:"app-settings-section__name"},[t._v(" "+t._s(t.name)+" ")]),t._t("default")],2)},r=[],a=s.normalizeComponent(n,i,r,!1,null,"a8066fd5",null,null);const o=a.exports;module.exports=o;
1
+ var o = require("../assets/index-1151d229.css");
2
+ const s = require("../chunks/_plugin-vue2_normalizer-7f9efb60.cjs");
3
+ const i = {
4
+ name: "NcAppSettingsSection",
5
+ props: {
6
+ name: {
7
+ type: String,
8
+ required: !0
9
+ },
10
+ id: {
11
+ type: String,
12
+ required: !0,
13
+ validator(e) {
14
+ return /^[a-z0-9\-_]+$/.test(e);
15
+ }
16
+ }
17
+ },
18
+ computed: {
19
+ // generate an id for each settingssection based on the name without whitespaces
20
+ htmlId() {
21
+ return "settings-section_" + this.id;
22
+ }
23
+ }
24
+ };
25
+ var r = function() {
26
+ var t = this, n = t._self._c;
27
+ return n("div", { staticClass: "app-settings-section", attrs: { id: t.htmlId } }, [n("h3", { staticClass: "app-settings-section__name" }, [t._v(" " + t._s(t.name) + " ")]), t._t("default")], 2);
28
+ }, _ = [], a = /* @__PURE__ */ s.normalizeComponent(
29
+ i,
30
+ r,
31
+ _,
32
+ !1,
33
+ null,
34
+ "a8066fd5",
35
+ null,
36
+ null
37
+ );
38
+ const c = a.exports;
39
+ module.exports = c;
@@ -1 +1 @@
1
- {"version":3,"file":"NcAppSettingsSection.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
1
+ {"version":3,"file":"NcAppSettingsSection.cjs","sources":["../../src/components/NcAppSettingsSection/NcAppSettingsSection.vue"],"sourcesContent":["<!--\n - @copyright Copyright (c) 2020 Marco Ambrosini <marcoambrosini@icloud.com>\n -\n - @author Marco Ambrosini <marcoambrosini@icloud.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<div :id=\"htmlId\" class=\"app-settings-section\">\n\t\t<h3 class=\"app-settings-section__name\">\n\t\t\t{{ name }}\n\t\t</h3>\n\t\t<slot />\n\t</div>\n</template>\n\n<script>\nexport default {\n\tname: 'NcAppSettingsSection',\n\n\tprops: {\n\t\tname: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\tid: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t\tvalidator(id) {\n\t\t\t\t// Only alphanumeric, dash and underscore\n\t\t\t\treturn /^[a-z0-9\\-_]+$/.test(id)\n\t\t\t},\n\t\t},\n\t},\n\tcomputed: {\n\t\t// generate an id for each settingssection based on the name without whitespaces\n\t\thtmlId() {\n\t\t\treturn 'settings-section_' + this.id\n\t\t},\n\t},\n}\n\n</script>\n\n<style lang=\"scss\" scoped>\n.app-settings-section {\n\tmargin-bottom: 80px;\n\t&__name {\n\t\tfont-size: 20px;\n\t\tmargin: 0;\n\t\tpadding: 20px 0;\n\t\tfont-weight: bold;\n\t\toverflow: hidden;\n\t\twhite-space: nowrap;\n\t\ttext-overflow: ellipsis;\n\t}\n}\n</style>\n"],"names":["_sfc_main","id"],"mappings":";;AAgCA,MAAAA,IAAA;AAAA,EACA,MAAA;AAAA,EAEA,OAAA;AAAA,IACA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA,IAEA,IAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAAC,GAAA;AAEA,eAAA,iBAAA,KAAAA,CAAA;AAAA,MACA;AAAA,IACA;AAAA,EACA;AAAA,EACA,UAAA;AAAA;AAAA,IAEA,SAAA;AACA,aAAA,sBAAA,KAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;"}