@nextcloud/vue 8.12.0 → 8.14.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +68 -2
- package/README.md +5 -0
- package/dist/Components/NcActionButton.cjs +3 -3
- package/dist/Components/NcActionButton.cjs.map +1 -1
- package/dist/Components/NcActionButton.mjs +3 -3
- package/dist/Components/NcActionButton.mjs.map +1 -1
- package/dist/Components/NcActionButtonGroup.cjs +1 -1
- package/dist/Components/NcActionButtonGroup.mjs +1 -1
- package/dist/Components/NcActionCaption.cjs +2 -2
- package/dist/Components/NcActionCaption.cjs.map +1 -1
- package/dist/Components/NcActionCaption.mjs +2 -2
- package/dist/Components/NcActionCaption.mjs.map +1 -1
- package/dist/Components/NcActionCheckbox.cjs +6 -8
- package/dist/Components/NcActionCheckbox.cjs.map +1 -1
- package/dist/Components/NcActionCheckbox.mjs +6 -8
- package/dist/Components/NcActionCheckbox.mjs.map +1 -1
- package/dist/Components/NcActionInput.cjs +1 -1
- package/dist/Components/NcActionInput.mjs +1 -1
- package/dist/Components/NcActionLink.cjs +3 -3
- package/dist/Components/NcActionLink.cjs.map +1 -1
- package/dist/Components/NcActionLink.mjs +3 -3
- package/dist/Components/NcActionLink.mjs.map +1 -1
- package/dist/Components/NcActionRadio.cjs +6 -8
- package/dist/Components/NcActionRadio.cjs.map +1 -1
- package/dist/Components/NcActionRadio.mjs +6 -8
- package/dist/Components/NcActionRadio.mjs.map +1 -1
- package/dist/Components/NcActionRouter.cjs +3 -3
- package/dist/Components/NcActionRouter.cjs.map +1 -1
- package/dist/Components/NcActionRouter.mjs +3 -3
- package/dist/Components/NcActionRouter.mjs.map +1 -1
- package/dist/Components/NcActionSeparator.cjs +2 -2
- package/dist/Components/NcActionSeparator.cjs.map +1 -1
- package/dist/Components/NcActionSeparator.mjs +2 -2
- package/dist/Components/NcActionSeparator.mjs.map +1 -1
- package/dist/Components/NcActionText.cjs +3 -3
- package/dist/Components/NcActionText.cjs.map +1 -1
- package/dist/Components/NcActionText.mjs +3 -3
- package/dist/Components/NcActionText.mjs.map +1 -1
- package/dist/Components/NcActionTextEditable.cjs +4 -4
- package/dist/Components/NcActionTextEditable.cjs.map +1 -1
- package/dist/Components/NcActionTextEditable.mjs +4 -4
- package/dist/Components/NcActionTextEditable.mjs.map +1 -1
- package/dist/Components/NcActions.cjs +1 -1
- package/dist/Components/NcActions.mjs +1 -1
- package/dist/Components/NcAppContent.cjs +1 -1
- package/dist/Components/NcAppContent.mjs +1 -1
- package/dist/Components/NcAppContentDetails.cjs.map +1 -1
- package/dist/Components/NcAppContentDetails.mjs.map +1 -1
- package/dist/Components/NcAppContentList.cjs.map +1 -1
- package/dist/Components/NcAppContentList.mjs.map +1 -1
- package/dist/Components/NcAppNavigation.cjs +1 -1
- package/dist/Components/NcAppNavigation.mjs +1 -1
- package/dist/Components/NcAppNavigationCaption.cjs +1 -1
- package/dist/Components/NcAppNavigationCaption.mjs +1 -1
- package/dist/Components/NcAppNavigationIconBullet.cjs +2 -2
- package/dist/Components/NcAppNavigationIconBullet.cjs.map +1 -1
- package/dist/Components/NcAppNavigationIconBullet.mjs +2 -2
- package/dist/Components/NcAppNavigationIconBullet.mjs.map +1 -1
- package/dist/Components/NcAppNavigationItem.cjs +1 -1
- package/dist/Components/NcAppNavigationItem.mjs +1 -1
- package/dist/Components/NcAppNavigationList.cjs +2 -2
- package/dist/Components/NcAppNavigationList.cjs.map +1 -1
- package/dist/Components/NcAppNavigationList.mjs +2 -2
- package/dist/Components/NcAppNavigationList.mjs.map +1 -1
- package/dist/Components/NcAppNavigationNew.cjs +2 -2
- package/dist/Components/NcAppNavigationNew.cjs.map +1 -1
- package/dist/Components/NcAppNavigationNew.mjs +2 -2
- package/dist/Components/NcAppNavigationNew.mjs.map +1 -1
- package/dist/Components/NcAppNavigationNewItem.cjs +1 -1
- package/dist/Components/NcAppNavigationNewItem.mjs +1 -1
- package/dist/Components/NcAppNavigationSettings.cjs +1 -1
- package/dist/Components/NcAppNavigationSettings.mjs +1 -1
- package/dist/Components/NcAppNavigationSpacer.cjs +2 -2
- package/dist/Components/NcAppNavigationSpacer.cjs.map +1 -1
- package/dist/Components/NcAppNavigationSpacer.mjs +2 -2
- package/dist/Components/NcAppNavigationSpacer.mjs.map +1 -1
- package/dist/Components/NcAppNavigationToggle.cjs +1 -21
- package/dist/Components/NcAppNavigationToggle.cjs.map +1 -1
- package/dist/Components/NcAppNavigationToggle.mjs +1 -21
- package/dist/Components/NcAppNavigationToggle.mjs.map +1 -1
- package/dist/Components/NcAppSettingsDialog.cjs +1 -1
- package/dist/Components/NcAppSettingsDialog.mjs +1 -1
- package/dist/Components/NcAppSettingsSection.cjs +3 -3
- package/dist/Components/NcAppSettingsSection.cjs.map +1 -1
- package/dist/Components/NcAppSettingsSection.mjs +3 -3
- package/dist/Components/NcAppSettingsSection.mjs.map +1 -1
- package/dist/Components/NcAppSidebar.cjs +1 -1
- package/dist/Components/NcAppSidebar.mjs +1 -1
- package/dist/Components/NcAppSidebarTab.cjs +2 -2
- package/dist/Components/NcAppSidebarTab.cjs.map +1 -1
- package/dist/Components/NcAppSidebarTab.mjs +2 -2
- package/dist/Components/NcAppSidebarTab.mjs.map +1 -1
- package/dist/Components/NcAvatar.cjs +1 -1
- package/dist/Components/NcAvatar.mjs +1 -1
- package/dist/Components/NcBreadcrumb.cjs +1 -1
- package/dist/Components/NcBreadcrumb.mjs +1 -1
- package/dist/Components/NcBreadcrumbs.cjs +1 -1
- package/dist/Components/NcBreadcrumbs.mjs +1 -1
- package/dist/Components/NcButton.cjs +15 -3
- package/dist/Components/NcButton.cjs.map +1 -1
- package/dist/Components/NcButton.mjs +15 -3
- package/dist/Components/NcButton.mjs.map +1 -1
- package/dist/Components/NcCheckboxRadioSwitch.cjs +1 -1
- package/dist/Components/NcCheckboxRadioSwitch.mjs +1 -1
- package/dist/Components/NcChip.cjs +111 -0
- package/dist/Components/NcChip.cjs.map +1 -0
- package/dist/Components/NcChip.mjs +112 -0
- package/dist/Components/NcChip.mjs.map +1 -0
- package/dist/Components/NcCollectionList.cjs +3 -0
- package/dist/Components/NcCollectionList.cjs.map +1 -0
- package/dist/Components/NcCollectionList.mjs +4 -0
- package/dist/Components/NcCollectionList.mjs.map +1 -0
- package/dist/Components/NcColorPicker.cjs +1 -1
- package/dist/Components/NcColorPicker.mjs +1 -1
- package/dist/Components/NcContent.cjs +1 -1
- package/dist/Components/NcContent.mjs +1 -1
- package/dist/Components/NcCounterBubble.cjs +2 -2
- package/dist/Components/NcCounterBubble.cjs.map +1 -1
- package/dist/Components/NcCounterBubble.mjs +2 -2
- package/dist/Components/NcCounterBubble.mjs.map +1 -1
- package/dist/Components/NcDashboardWidget.cjs +1 -1
- package/dist/Components/NcDashboardWidget.mjs +1 -1
- package/dist/Components/NcDashboardWidgetItem.cjs +1 -1
- package/dist/Components/NcDashboardWidgetItem.mjs +1 -1
- package/dist/Components/NcDateTime.cjs +1 -1
- package/dist/Components/NcDateTime.mjs +1 -1
- package/dist/Components/NcDateTimePicker.cjs +8 -29
- package/dist/Components/NcDateTimePicker.cjs.map +1 -1
- package/dist/Components/NcDateTimePicker.mjs +8 -29
- package/dist/Components/NcDateTimePicker.mjs.map +1 -1
- package/dist/Components/NcDateTimePickerNative.cjs +3 -24
- package/dist/Components/NcDateTimePickerNative.cjs.map +1 -1
- package/dist/Components/NcDateTimePickerNative.mjs +3 -24
- package/dist/Components/NcDateTimePickerNative.mjs.map +1 -1
- package/dist/Components/NcDialog.cjs +1 -1
- package/dist/Components/NcDialog.mjs +1 -1
- package/dist/Components/NcDialogButton.cjs +1 -1
- package/dist/Components/NcDialogButton.mjs +1 -1
- package/dist/Components/NcEllipsisedOption.cjs +9 -3
- package/dist/Components/NcEllipsisedOption.cjs.map +1 -1
- package/dist/Components/NcEllipsisedOption.mjs +9 -3
- package/dist/Components/NcEllipsisedOption.mjs.map +1 -1
- package/dist/Components/NcEmojiPicker.cjs +1 -1
- package/dist/Components/NcEmojiPicker.mjs +1 -1
- package/dist/Components/NcEmptyContent.cjs +2 -2
- package/dist/Components/NcEmptyContent.cjs.map +1 -1
- package/dist/Components/NcEmptyContent.mjs +2 -2
- package/dist/Components/NcEmptyContent.mjs.map +1 -1
- package/dist/Components/NcGuestContent.cjs +2 -2
- package/dist/Components/NcGuestContent.cjs.map +1 -1
- package/dist/Components/NcGuestContent.mjs +2 -2
- package/dist/Components/NcGuestContent.mjs.map +1 -1
- package/dist/Components/NcHeaderMenu.cjs +1 -1
- package/dist/Components/NcHeaderMenu.mjs +1 -1
- package/dist/Components/NcHighlight.cjs +1 -1
- package/dist/Components/NcHighlight.mjs +1 -1
- package/dist/Components/NcIconSvgWrapper.cjs +1 -1
- package/dist/Components/NcIconSvgWrapper.mjs +1 -1
- package/dist/Components/NcInputField.cjs +3 -3
- package/dist/Components/NcInputField.cjs.map +1 -1
- package/dist/Components/NcInputField.mjs +3 -3
- package/dist/Components/NcInputField.mjs.map +1 -1
- package/dist/Components/NcListItem.cjs +1 -1
- package/dist/Components/NcListItem.mjs +1 -1
- package/dist/Components/NcListItemIcon.cjs +1 -1
- package/dist/Components/NcListItemIcon.mjs +1 -1
- package/dist/Components/NcLoadingIcon.cjs +2 -2
- package/dist/Components/NcLoadingIcon.cjs.map +1 -1
- package/dist/Components/NcLoadingIcon.mjs +2 -2
- package/dist/Components/NcLoadingIcon.mjs.map +1 -1
- package/dist/Components/NcModal.cjs +32 -55
- package/dist/Components/NcModal.cjs.map +1 -1
- package/dist/Components/NcModal.mjs +30 -55
- package/dist/Components/NcModal.mjs.map +1 -1
- package/dist/Components/NcNoteCard.cjs +2 -2
- package/dist/Components/NcNoteCard.cjs.map +1 -1
- package/dist/Components/NcNoteCard.mjs +2 -2
- package/dist/Components/NcNoteCard.mjs.map +1 -1
- package/dist/Components/NcPasswordField.cjs +1 -1
- package/dist/Components/NcPasswordField.mjs +1 -1
- package/dist/Components/NcPopover.cjs +1 -1
- package/dist/Components/NcPopover.mjs +1 -1
- package/dist/Components/NcProgressBar.cjs +1 -1
- package/dist/Components/NcProgressBar.mjs +1 -1
- package/dist/Components/NcRelatedResourcesPanel.cjs +1 -1
- package/dist/Components/NcRelatedResourcesPanel.mjs +1 -1
- package/dist/Components/NcRichContenteditable.cjs +2 -2
- package/dist/Components/NcRichContenteditable.mjs +2 -2
- package/dist/Components/NcRichText.cjs +2 -23
- package/dist/Components/NcRichText.cjs.map +1 -1
- package/dist/Components/NcRichText.mjs +3 -24
- package/dist/Components/NcRichText.mjs.map +1 -1
- package/dist/Components/NcSelect.cjs +1 -1
- package/dist/Components/NcSelect.mjs +1 -1
- package/dist/Components/NcSelectTags.cjs +1 -1
- package/dist/Components/NcSelectTags.mjs +1 -1
- package/dist/Components/NcSettingsInputText.cjs +1 -1
- package/dist/Components/NcSettingsInputText.mjs +1 -1
- package/dist/Components/NcSettingsSection.cjs +1 -1
- package/dist/Components/NcSettingsSection.mjs +1 -1
- package/dist/Components/NcSettingsSelectGroup.cjs +1 -22
- package/dist/Components/NcSettingsSelectGroup.cjs.map +1 -1
- package/dist/Components/NcSettingsSelectGroup.mjs +1 -22
- package/dist/Components/NcSettingsSelectGroup.mjs.map +1 -1
- package/dist/Components/NcTextArea.cjs +3 -3
- package/dist/Components/NcTextArea.cjs.map +1 -1
- package/dist/Components/NcTextArea.mjs +3 -3
- package/dist/Components/NcTextArea.mjs.map +1 -1
- package/dist/Components/NcTextField.cjs +1 -1
- package/dist/Components/NcTextField.mjs +1 -1
- package/dist/Components/NcTimezonePicker.cjs +1 -1
- package/dist/Components/NcTimezonePicker.mjs +1 -1
- package/dist/Components/NcUserBubble.cjs +1 -1
- package/dist/Components/NcUserBubble.mjs +1 -1
- package/dist/Components/NcUserStatusIcon.cjs +1 -1
- package/dist/Components/NcUserStatusIcon.mjs +1 -1
- package/dist/Components/NcVNodes.cjs.map +1 -1
- package/dist/Components/NcVNodes.mjs.map +1 -1
- package/dist/Composables/useIsFullscreen.cjs +0 -21
- package/dist/Composables/useIsFullscreen.cjs.map +1 -1
- package/dist/Composables/useIsFullscreen.mjs +0 -21
- package/dist/Composables/useIsFullscreen.mjs.map +1 -1
- package/dist/Composables/useIsMobile.cjs +0 -21
- package/dist/Composables/useIsMobile.cjs.map +1 -1
- package/dist/Composables/useIsMobile.mjs +0 -21
- package/dist/Composables/useIsMobile.mjs.map +1 -1
- package/dist/Directives/Focus.cjs +0 -21
- package/dist/Directives/Focus.cjs.map +1 -1
- package/dist/Directives/Focus.mjs +0 -21
- package/dist/Directives/Focus.mjs.map +1 -1
- package/dist/Directives/Linkify.cjs +1 -1
- package/dist/Directives/Linkify.cjs.map +1 -1
- package/dist/Directives/Linkify.mjs +1 -1
- package/dist/Directives/Linkify.mjs.map +1 -1
- package/dist/Directives/Tooltip.cjs +1 -23
- package/dist/Directives/Tooltip.cjs.map +1 -1
- package/dist/Directives/Tooltip.mjs +1 -23
- package/dist/Directives/Tooltip.mjs.map +1 -1
- package/dist/Functions/a11y.cjs +0 -21
- package/dist/Functions/a11y.cjs.map +1 -1
- package/dist/Functions/a11y.mjs +0 -21
- package/dist/Functions/a11y.mjs.map +1 -1
- package/dist/Functions/emoji.cjs +1 -1
- package/dist/Functions/emoji.mjs +1 -1
- package/dist/Functions/reference.cjs +1 -1
- package/dist/Functions/reference.mjs +1 -1
- package/dist/Functions/usernameToColor.cjs +1 -1
- package/dist/Functions/usernameToColor.mjs +1 -1
- package/dist/Mixins/clickOutsideOptions.cjs +0 -21
- package/dist/Mixins/clickOutsideOptions.cjs.map +1 -1
- package/dist/Mixins/clickOutsideOptions.mjs +0 -21
- package/dist/Mixins/clickOutsideOptions.mjs.map +1 -1
- package/dist/Mixins/isFullscreen.cjs +0 -21
- package/dist/Mixins/isFullscreen.cjs.map +1 -1
- package/dist/Mixins/isFullscreen.mjs +0 -21
- package/dist/Mixins/isFullscreen.mjs.map +1 -1
- package/dist/Mixins/isMobile.cjs +0 -21
- package/dist/Mixins/isMobile.cjs.map +1 -1
- package/dist/Mixins/isMobile.mjs +0 -21
- package/dist/Mixins/isMobile.mjs.map +1 -1
- package/dist/Mixins/richEditor.cjs +2 -2
- package/dist/Mixins/richEditor.mjs +2 -2
- package/dist/assets/NcActionButton-D90PTEA5.css +107 -0
- package/dist/assets/{NcActionButtonGroup-CvloX35s.css → NcActionButtonGroup-CQxLn2fv.css} +6 -20
- package/dist/assets/NcActionCaption-B7FZTc3Y.css +32 -0
- package/dist/assets/NcActionCheckbox-C-PJVvtb.css +78 -0
- package/dist/assets/NcActionInput-C_3Csa6A.css +220 -0
- package/dist/assets/NcActionLink-Db_ZlqWs.css +92 -0
- package/dist/assets/NcActionRadio-CpCvyMa_.css +78 -0
- package/dist/assets/NcActionRouter-DidTlbov.css +103 -0
- package/dist/assets/NcActionSeparator-CEbb5P6P.css +24 -0
- package/dist/assets/NcActionText-DCx1DWXe.css +107 -0
- package/dist/assets/NcActionTextEditable-Dud9NOdm.css +238 -0
- package/dist/assets/NcActions-JDMMURyt.css +83 -0
- package/dist/assets/NcAppContent-B1ZWQTUv.css +125 -0
- package/dist/assets/NcAppNavigation-DvCTUTpR.css +103 -0
- package/dist/assets/NcAppNavigationCaption-Cgexlz2n.css +48 -0
- package/dist/assets/NcAppNavigationIconBullet-By_0o2dG.css +30 -0
- package/dist/assets/NcAppNavigationItem-Cas1plMr.css +211 -0
- package/dist/assets/NcAppNavigationList-BIbyyT7b.css +29 -0
- package/dist/assets/NcAppNavigationNew-BKfawNII.css +27 -0
- package/dist/assets/{NcAppNavigationNewItem-DF3nldsK.css → NcAppNavigationNewItem-Dw2sHtEO.css} +58 -68
- package/dist/assets/NcAppNavigationSettings-DtCFYPKb.css +79 -0
- package/dist/assets/NcAppNavigationSpacer-CfNqmQeR.css +6 -0
- package/dist/assets/NcAppNavigationToggle-DvYpNzHv.css +27 -0
- package/dist/assets/NcAppSettingsDialog-YgAGku7I.css +74 -0
- package/dist/assets/NcAppSettingsSection-AUZ2NjMX.css +30 -0
- package/dist/assets/{NcAppSidebar-DixS4RLm.css → NcAppSidebar-GLK326IR.css} +126 -172
- package/dist/assets/NcAppSidebarTab-BieYhqvk.css +34 -0
- package/dist/assets/NcAvatar-m0lTnGXX.css +129 -0
- package/dist/assets/NcBreadcrumb-DOvK-XG1.css +68 -0
- package/dist/assets/NcBreadcrumbs-CPUAM38l.css +37 -0
- package/dist/assets/NcButton-BHxZm42y.css +210 -0
- package/dist/assets/{NcCheckboxRadioSwitch-DArK1Q95.css → NcCheckboxRadioSwitch-BkBep4wT.css} +58 -86
- package/dist/assets/NcChip-CQm1mq2C.css +61 -0
- package/dist/assets/NcCollectionList-ETQTqkqt.css +221 -0
- package/dist/assets/NcColorPicker-Ctv2cwt1.css +122 -0
- package/dist/assets/NcContent--2CGtswk.css +82 -0
- package/dist/assets/NcCounterBubble-BlAq2Vim.css +53 -0
- package/dist/assets/NcDashboardWidget-CpstyXok.css +73 -0
- package/dist/assets/NcDashboardWidgetItem-Qe5SSOhA.css +85 -0
- package/dist/assets/{NcDateTimePicker-3FfsWOh0.css → NcDateTimePicker-BR1KY59N.css} +39 -77
- package/dist/assets/NcDateTimePickerNative-BAcKr0B3.css +47 -0
- package/dist/assets/NcDialog-j6_6dpiF.css +132 -0
- package/dist/assets/NcEllipsisedOption-DZK2vWD1.css +34 -0
- package/dist/assets/{NcEmojiPicker-XL3oUsqE.css → NcEmojiPicker-ielwHIhs.css} +16 -44
- package/dist/assets/NcEmptyContent-BU0QVo3d.css +65 -0
- package/dist/assets/NcGuestContent-BLJ37yLM.css +50 -0
- package/dist/assets/NcHeaderMenu-CuAI7Fgb.css +77 -0
- package/dist/assets/NcIconSvgWrapper-BwsJ8wBM.css +39 -0
- package/dist/assets/NcInputConfirmCancel-SGr0-6w8.css +39 -0
- package/dist/assets/{NcInputField-CXoTqF9T.css → NcInputField-CrdP183e.css} +43 -56
- package/dist/assets/NcListItem-DTaecNLV.css +156 -0
- package/dist/assets/NcListItemIcon-DxPdaRV5.css +64 -0
- package/dist/assets/NcLoadingIcon-BSONDy7x.css +21 -0
- package/dist/assets/NcMentionBubble-C6t8od-_.css +73 -0
- package/dist/assets/NcModal-CYa2IEvm.css +282 -0
- package/dist/assets/NcNoteCard-BLPU1den.css +50 -0
- package/dist/assets/{NcPopover-BwI1hPzy.css → NcPopover-BDlL00qZ.css} +6 -20
- package/dist/assets/NcProgressBar-BsqdCn-x.css +56 -0
- package/dist/assets/NcRelatedResourcesPanel-BE9CQ8s8.css +158 -0
- package/dist/assets/{NcRichContenteditable-C-eZyVQM.css → NcRichContenteditable-CkvTrjfG.css} +58 -100
- package/dist/assets/NcRichText-BzeK2YTS.css +217 -0
- package/dist/assets/{NcSelect-Fmyu7qyl.css → NcSelect-BQt_SpyP.css} +10 -22
- package/dist/assets/NcSettingsInputText-DbTNj9E6.css +35 -0
- package/dist/assets/NcSettingsSection-DZwOPKg1.css +56 -0
- package/dist/assets/NcSettingsSelectGroup-CzD7YrGm.css +23 -0
- package/dist/assets/{NcTextArea-XCi8a16Y.css → NcTextArea-D8bZi2fT.css} +30 -42
- package/dist/assets/NcUserBubble-DMjZyrGY.css +48 -0
- package/dist/assets/NcUserStatusIcon-DMxcdM51.css +30 -0
- package/dist/assets/{Tooltip-jHgt4m-W.css → Tooltip-4CSl8xev.css} +10 -30
- package/dist/assets/referencePickerModal-9BcmmfUy.css +413 -0
- package/dist/chunks/{GenColors-CAUl-IDP.cjs → GenColors-Dt-3yZwf.cjs} +1 -23
- package/dist/chunks/GenColors-Dt-3yZwf.cjs.map +1 -0
- package/dist/chunks/{GenColors-DcjtQMk3.mjs → GenColors-DtEnxSd9.mjs} +1 -23
- package/dist/chunks/GenColors-DtEnxSd9.mjs.map +1 -0
- package/dist/chunks/GenRandomId-BQDud3d4.cjs +5 -0
- package/dist/chunks/GenRandomId-BQDud3d4.cjs.map +1 -0
- package/dist/chunks/GenRandomId-CMooMQt0.mjs +6 -0
- package/dist/chunks/GenRandomId-CMooMQt0.mjs.map +1 -0
- package/dist/chunks/Linkify-BtgR-dXX.mjs +14 -0
- package/dist/chunks/Linkify-BtgR-dXX.mjs.map +1 -0
- package/dist/chunks/Linkify-yeOn5L6T.cjs +15 -0
- package/dist/chunks/Linkify-yeOn5L6T.cjs.map +1 -0
- package/dist/chunks/{NcActionButtonGroup-D650-6zv.mjs → NcActionButtonGroup-B62_HajM.mjs} +3 -3
- package/dist/chunks/NcActionButtonGroup-B62_HajM.mjs.map +1 -0
- package/dist/chunks/{NcActionButtonGroup-D7hycpXY.cjs → NcActionButtonGroup-DKtkuRy5.cjs} +3 -3
- package/dist/chunks/NcActionButtonGroup-DKtkuRy5.cjs.map +1 -0
- package/dist/chunks/{NcActionInput-BqG7gSLn.mjs → NcActionInput-DvbN3P1D.mjs} +9 -9
- package/dist/chunks/NcActionInput-DvbN3P1D.mjs.map +1 -0
- package/dist/chunks/{NcActionInput-CHucaM0V.cjs → NcActionInput-Dw1TL9ig.cjs} +9 -9
- package/dist/chunks/NcActionInput-Dw1TL9ig.cjs.map +1 -0
- package/dist/chunks/{NcActions-CocYka0Y.mjs → NcActions-CL3YRRgz.mjs} +6 -6
- package/dist/chunks/NcActions-CL3YRRgz.mjs.map +1 -0
- package/dist/chunks/{NcActions-JX6wbAVA.cjs → NcActions-DRSoPS6a.cjs} +6 -6
- package/dist/chunks/NcActions-DRSoPS6a.cjs.map +1 -0
- package/dist/chunks/{NcAppContent-wlhVbyg0.mjs → NcAppContent-Cgay0O3i.mjs} +5 -5
- package/dist/chunks/NcAppContent-Cgay0O3i.mjs.map +1 -0
- package/dist/chunks/{NcAppContent-CkO1Y93z.cjs → NcAppContent-ibyvoVc4.cjs} +5 -5
- package/dist/chunks/NcAppContent-ibyvoVc4.cjs.map +1 -0
- package/dist/chunks/{NcAppNavigation-Du3J8BTm.cjs → NcAppNavigation-Cw8qnf4l.cjs} +5 -6
- package/dist/chunks/NcAppNavigation-Cw8qnf4l.cjs.map +1 -0
- package/dist/chunks/{NcAppNavigation-BKiDVBw7.mjs → NcAppNavigation-D15PXjlO.mjs} +5 -6
- package/dist/chunks/NcAppNavigation-D15PXjlO.mjs.map +1 -0
- package/dist/chunks/{NcAppNavigationCaption-BoN0P7tD.cjs → NcAppNavigationCaption-CO8Hwyrb.cjs} +3 -3
- package/dist/chunks/NcAppNavigationCaption-CO8Hwyrb.cjs.map +1 -0
- package/dist/chunks/{NcAppNavigationCaption-CKTQZ_u_.mjs → NcAppNavigationCaption-DsGPHQvj.mjs} +3 -3
- package/dist/chunks/NcAppNavigationCaption-DsGPHQvj.mjs.map +1 -0
- package/dist/chunks/{NcAppNavigationItem-D_lh17am.cjs → NcAppNavigationItem-BVLg_dnQ.cjs} +11 -13
- package/dist/chunks/NcAppNavigationItem-BVLg_dnQ.cjs.map +1 -0
- package/dist/chunks/{NcAppNavigationItem-qe8jnLow.mjs → NcAppNavigationItem-fKe0Oi-K.mjs} +11 -13
- package/dist/chunks/NcAppNavigationItem-fKe0Oi-K.mjs.map +1 -0
- package/dist/chunks/{NcAppNavigationNewItem-B107Beoc.mjs → NcAppNavigationNewItem-BEVsUTrd.mjs} +3 -3
- package/dist/chunks/NcAppNavigationNewItem-BEVsUTrd.mjs.map +1 -0
- package/dist/chunks/{NcAppNavigationNewItem-DyxVXE5t.cjs → NcAppNavigationNewItem-DlC2GWGK.cjs} +3 -3
- package/dist/chunks/NcAppNavigationNewItem-DlC2GWGK.cjs.map +1 -0
- package/dist/chunks/{NcAppNavigationSettings-CmP_tXFm.cjs → NcAppNavigationSettings-BidyunnY.cjs} +5 -5
- package/dist/chunks/NcAppNavigationSettings-BidyunnY.cjs.map +1 -0
- package/dist/chunks/{NcAppNavigationSettings-DZ1-Sbdz.mjs → NcAppNavigationSettings-CEHSXiJt.mjs} +5 -5
- package/dist/chunks/NcAppNavigationSettings-CEHSXiJt.mjs.map +1 -0
- package/dist/chunks/{NcAppNavigationToggle-zCGgvNDT.mjs → NcAppNavigationToggle-CdNG26lR.mjs} +4 -4
- package/dist/chunks/NcAppNavigationToggle-CdNG26lR.mjs.map +1 -0
- package/dist/chunks/{NcAppNavigationToggle-hmEUqxbP.cjs → NcAppNavigationToggle-DFhfV_Ic.cjs} +4 -4
- package/dist/chunks/NcAppNavigationToggle-DFhfV_Ic.cjs.map +1 -0
- package/dist/chunks/{NcAppSettingsDialog-D9cNYQ8b.mjs → NcAppSettingsDialog-BExa9wmg.mjs} +6 -7
- package/dist/chunks/NcAppSettingsDialog-BExa9wmg.mjs.map +1 -0
- package/dist/chunks/{NcAppSettingsDialog-YqNhco1P.cjs → NcAppSettingsDialog-Zy4akEYz.cjs} +6 -7
- package/dist/chunks/NcAppSettingsDialog-Zy4akEYz.cjs.map +1 -0
- package/dist/chunks/{NcAppSidebar-CQWODfsy.mjs → NcAppSidebar-CYd47NKe.mjs} +91 -67
- package/dist/chunks/NcAppSidebar-CYd47NKe.mjs.map +1 -0
- package/dist/chunks/{NcAppSidebar-J15zHyfq.cjs → NcAppSidebar-kuqm78Wl.cjs} +91 -67
- package/dist/chunks/NcAppSidebar-kuqm78Wl.cjs.map +1 -0
- package/dist/chunks/{NcAvatar-CX3OX2C4.mjs → NcAvatar-BC884DnC.mjs} +11 -32
- package/dist/chunks/NcAvatar-BC884DnC.mjs.map +1 -0
- package/dist/chunks/{NcAvatar-CYzikYku.cjs → NcAvatar-BX8J9gZF.cjs} +11 -32
- package/dist/chunks/NcAvatar-BX8J9gZF.cjs.map +1 -0
- package/dist/chunks/{NcBreadcrumb-DytGDsr8.mjs → NcBreadcrumb-BVLavjOe.mjs} +4 -4
- package/dist/chunks/NcBreadcrumb-BVLavjOe.mjs.map +1 -0
- package/dist/chunks/{NcBreadcrumb-jMJw2OQJ.cjs → NcBreadcrumb-DbuEPD5w.cjs} +4 -4
- package/dist/chunks/NcBreadcrumb-DbuEPD5w.cjs.map +1 -0
- package/dist/chunks/{NcBreadcrumbs-BqFPBZ-h.mjs → NcBreadcrumbs-BBO2DLP1.mjs} +8 -33
- package/dist/chunks/NcBreadcrumbs-BBO2DLP1.mjs.map +1 -0
- package/dist/chunks/{NcBreadcrumbs-CzObAKB-.cjs → NcBreadcrumbs-iIR1Tw0r.cjs} +8 -33
- package/dist/chunks/NcBreadcrumbs-iIR1Tw0r.cjs.map +1 -0
- package/dist/chunks/{NcCheckboxRadioSwitch-CIHl8lnP.cjs → NcCheckboxRadioSwitch-B0HYTOsR.cjs} +12 -6
- package/dist/chunks/NcCheckboxRadioSwitch-B0HYTOsR.cjs.map +1 -0
- package/dist/chunks/{NcCheckboxRadioSwitch-CpupDtee.mjs → NcCheckboxRadioSwitch-D2GbHtCS.mjs} +12 -6
- package/dist/chunks/NcCheckboxRadioSwitch-D2GbHtCS.mjs.map +1 -0
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_919d07b7_lang-CPc4BraS.cjs +4 -0
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_919d07b7_lang-CPc4BraS.cjs.map +1 -0
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_919d07b7_lang-ScT6WV__.mjs +3 -0
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_919d07b7_lang-ScT6WV__.mjs.map +1 -0
- package/dist/chunks/NcCollectionList-3O-OrcfS.mjs +428 -0
- package/dist/chunks/NcCollectionList-3O-OrcfS.mjs.map +1 -0
- package/dist/chunks/NcCollectionList-D4oNsvJ0.cjs +430 -0
- package/dist/chunks/NcCollectionList-D4oNsvJ0.cjs.map +1 -0
- package/dist/chunks/{NcColorPicker-BEs2B-HB.mjs → NcColorPicker-D7awy8o_.mjs} +6 -6
- package/dist/chunks/NcColorPicker-D7awy8o_.mjs.map +1 -0
- package/dist/chunks/{NcColorPicker-KrvDMhej.cjs → NcColorPicker-hOteJtis.cjs} +6 -6
- package/dist/chunks/NcColorPicker-hOteJtis.cjs.map +1 -0
- package/dist/chunks/NcContent-CQn8oXxp.mjs +105 -0
- package/dist/chunks/NcContent-CQn8oXxp.mjs.map +1 -0
- package/dist/chunks/NcContent-Dr9e_aYA.cjs +104 -0
- package/dist/chunks/NcContent-Dr9e_aYA.cjs.map +1 -0
- package/dist/chunks/{NcDashboardWidget-BvNtltPU.cjs → NcDashboardWidget-DnDLhRmV.cjs} +6 -6
- package/dist/chunks/NcDashboardWidget-DnDLhRmV.cjs.map +1 -0
- package/dist/chunks/{NcDashboardWidget-Da715DSB.mjs → NcDashboardWidget-hTBgsnwG.mjs} +6 -6
- package/dist/chunks/NcDashboardWidget-hTBgsnwG.mjs.map +1 -0
- package/dist/chunks/{NcDashboardWidgetItem-CKv_fb-1.cjs → NcDashboardWidgetItem-BorZC7ZL.cjs} +4 -4
- package/dist/chunks/NcDashboardWidgetItem-BorZC7ZL.cjs.map +1 -0
- package/dist/chunks/{NcDashboardWidgetItem-BkJTg3kj.mjs → NcDashboardWidgetItem-CorJJt6-.mjs} +4 -4
- package/dist/chunks/NcDashboardWidgetItem-CorJJt6-.mjs.map +1 -0
- package/dist/chunks/{NcDateTime-CpJDGhl7.mjs → NcDateTime-Eat0YWPN.mjs} +1 -22
- package/dist/chunks/NcDateTime-Eat0YWPN.mjs.map +1 -0
- package/dist/chunks/{NcDateTime-Cy5Bp0d2.cjs → NcDateTime-K3Rie9qv.cjs} +1 -22
- package/dist/chunks/NcDateTime-K3Rie9qv.cjs.map +1 -0
- package/dist/chunks/{NcDialog-C7KRNdTc.cjs → NcDialog-DGaf6Udc.cjs} +8 -6
- package/dist/chunks/NcDialog-DGaf6Udc.cjs.map +1 -0
- package/dist/chunks/{NcDialog-B3ZaXnpn.mjs → NcDialog-VincZ0XS.mjs} +8 -6
- package/dist/chunks/NcDialog-VincZ0XS.mjs.map +1 -0
- package/dist/chunks/{NcDialogButton-CLWLvwpm.cjs → NcDialogButton-CNWF4urB.cjs} +9 -2
- package/dist/chunks/NcDialogButton-CNWF4urB.cjs.map +1 -0
- package/dist/chunks/{NcDialogButton-BV3Kf9U7.mjs → NcDialogButton-JvyN3X6S.mjs} +9 -2
- package/dist/chunks/NcDialogButton-JvyN3X6S.mjs.map +1 -0
- package/dist/chunks/{NcEmojiPicker-LFuZ15M5.cjs → NcEmojiPicker-DCT0-SIC.cjs} +9 -9
- package/dist/chunks/NcEmojiPicker-DCT0-SIC.cjs.map +1 -0
- package/dist/chunks/{NcEmojiPicker-SqbRSwu2.mjs → NcEmojiPicker-ziqKge9K.mjs} +9 -9
- package/dist/chunks/NcEmojiPicker-ziqKge9K.mjs.map +1 -0
- package/dist/chunks/{NcHeaderMenu-830tFszI.cjs → NcHeaderMenu-D-Jo3l41.cjs} +6 -6
- package/dist/chunks/NcHeaderMenu-D-Jo3l41.cjs.map +1 -0
- package/dist/chunks/{NcHeaderMenu-2n5GDt37.mjs → NcHeaderMenu-Da6Ob-6t.mjs} +6 -6
- package/dist/chunks/NcHeaderMenu-Da6Ob-6t.mjs.map +1 -0
- package/dist/chunks/{NcIconSvgWrapper-KWEbPRC9.mjs → NcIconSvgWrapper-Ckqpz-vm.mjs} +3 -3
- package/dist/chunks/NcIconSvgWrapper-Ckqpz-vm.mjs.map +1 -0
- package/dist/chunks/{NcIconSvgWrapper-O61kZVNp.cjs → NcIconSvgWrapper-DaSgIT19.cjs} +3 -3
- package/dist/chunks/NcIconSvgWrapper-DaSgIT19.cjs.map +1 -0
- package/dist/chunks/{NcInputConfirmCancel-CJ7nPGEd.cjs → NcInputConfirmCancel-Bt_VDaTA.cjs} +7 -10
- package/dist/chunks/NcInputConfirmCancel-Bt_VDaTA.cjs.map +1 -0
- package/dist/chunks/{NcInputConfirmCancel-XXXgXoSw.mjs → NcInputConfirmCancel-BvsvyKxD.mjs} +7 -10
- package/dist/chunks/NcInputConfirmCancel-BvsvyKxD.mjs.map +1 -0
- package/dist/chunks/{NcListItem-CxpC4EKk.cjs → NcListItem-BwUN8FaS.cjs} +5 -6
- package/dist/chunks/{NcListItem-DrTIia88.mjs.map → NcListItem-BwUN8FaS.cjs.map} +1 -1
- package/dist/chunks/{NcListItem-DrTIia88.mjs → NcListItem-DwIZ95t7.mjs} +5 -6
- package/dist/chunks/{NcListItem-CxpC4EKk.cjs.map → NcListItem-DwIZ95t7.mjs.map} +1 -1
- package/dist/chunks/{NcListItemIcon-CTTJYWzN.mjs → NcListItemIcon-DhW1Fob8.mjs} +6 -6
- package/dist/chunks/NcListItemIcon-DhW1Fob8.mjs.map +1 -0
- package/dist/chunks/{NcListItemIcon-44A7fm62.cjs → NcListItemIcon-JeS1a2jI.cjs} +6 -6
- package/dist/chunks/NcListItemIcon-JeS1a2jI.cjs.map +1 -0
- package/dist/chunks/{NcPasswordField-DN-kdAfl.cjs → NcPasswordField-9h22h-sl.cjs} +5 -4
- package/dist/chunks/NcPasswordField-9h22h-sl.cjs.map +1 -0
- package/dist/chunks/{NcPasswordField-Z6BCKScy.mjs → NcPasswordField-xauR6801.mjs} +4 -3
- package/dist/chunks/NcPasswordField-xauR6801.mjs.map +1 -0
- package/dist/chunks/{NcPopover-BS1bBSkg.cjs → NcPopover-Cl1AvQ5o.cjs} +2 -2
- package/dist/chunks/NcPopover-Cl1AvQ5o.cjs.map +1 -0
- package/dist/chunks/{NcPopover-foxJPAfG.mjs → NcPopover-VxUr4c6P.mjs} +2 -2
- package/dist/chunks/NcPopover-VxUr4c6P.mjs.map +1 -0
- package/dist/chunks/{NcProgressBar-mFqoqB4L.cjs → NcProgressBar-BnKA91Pj.cjs} +3 -3
- package/dist/chunks/NcProgressBar-BnKA91Pj.cjs.map +1 -0
- package/dist/chunks/{NcProgressBar-BafFcKiu.mjs → NcProgressBar-CZtllSde.mjs} +3 -3
- package/dist/chunks/NcProgressBar-CZtllSde.mjs.map +1 -0
- package/dist/chunks/{NcRelatedResourcesPanel-Dcm2wvfd.cjs → NcRelatedResourcesPanel-Be1fGCiu.cjs} +10 -10
- package/dist/chunks/NcRelatedResourcesPanel-Be1fGCiu.cjs.map +1 -0
- package/dist/chunks/{NcRelatedResourcesPanel-D3QlWSNc.mjs → NcRelatedResourcesPanel-mSjo_nq5.mjs} +10 -10
- package/dist/chunks/NcRelatedResourcesPanel-mSjo_nq5.mjs.map +1 -0
- package/dist/chunks/{NcRichContenteditable-DljQv8gw.cjs → NcRichContenteditable-BbPOC-_I.cjs} +60 -48
- package/dist/chunks/NcRichContenteditable-BbPOC-_I.cjs.map +1 -0
- package/dist/chunks/{NcRichContenteditable-BB-qsHEm.mjs → NcRichContenteditable-CakN30zF.mjs} +60 -48
- package/dist/chunks/NcRichContenteditable-CakN30zF.mjs.map +1 -0
- package/dist/chunks/{NcRichText-BDVKgmY5.cjs → NcRichText-65CdQLUw.cjs} +9 -8
- package/dist/chunks/NcRichText-65CdQLUw.cjs.map +1 -0
- package/dist/chunks/{NcRichText-BT4VjvXi.mjs → NcRichText-CCM1HmZE.mjs} +9 -8
- package/dist/chunks/NcRichText-CCM1HmZE.mjs.map +1 -0
- package/dist/chunks/NcSavingIndicatorIcon-Bhy7wcoT.mjs.map +1 -1
- package/dist/chunks/NcSavingIndicatorIcon-BzKAIkhk.cjs.map +1 -1
- package/dist/chunks/{NcSelect-CNm4fmR6.mjs → NcSelect-CKgXIbQN.mjs} +5 -5
- package/dist/chunks/NcSelect-CKgXIbQN.mjs.map +1 -0
- package/dist/chunks/{NcSelect-DckQCxxX.cjs → NcSelect-CmV2Q0A0.cjs} +5 -5
- package/dist/chunks/NcSelect-CmV2Q0A0.cjs.map +1 -0
- package/dist/chunks/{NcSelectTags-nCqLANFH.mjs → NcSelectTags-BIha_vfa.mjs} +2 -23
- package/dist/chunks/NcSelectTags-BIha_vfa.mjs.map +1 -0
- package/dist/chunks/{NcSelectTags-CnkBJ3vP.cjs → NcSelectTags-eQRTXuQr.cjs} +2 -23
- package/dist/chunks/NcSelectTags-eQRTXuQr.cjs.map +1 -0
- package/dist/chunks/{NcSettingsInputText-Dd3wEwGy.cjs → NcSettingsInputText-Cdw4mTrp.cjs} +5 -5
- package/dist/chunks/NcSettingsInputText-Cdw4mTrp.cjs.map +1 -0
- package/dist/chunks/{NcSettingsInputText-D-S5LBmN.mjs → NcSettingsInputText-DDJdALzH.mjs} +5 -5
- package/dist/chunks/NcSettingsInputText-DDJdALzH.mjs.map +1 -0
- package/dist/chunks/{NcSettingsSection-B0-LmypW.mjs → NcSettingsSection-CFn4bRnA.mjs} +4 -4
- package/dist/chunks/NcSettingsSection-CFn4bRnA.mjs.map +1 -0
- package/dist/chunks/{NcSettingsSection-ayl3nvdL.cjs → NcSettingsSection-uZhZY4jp.cjs} +4 -4
- package/dist/chunks/NcSettingsSection-uZhZY4jp.cjs.map +1 -0
- package/dist/chunks/{NcSettingsSelectGroup-C51Km4wj.mjs → NcSettingsSelectGroup-BJIByip9.mjs} +6 -6
- package/dist/chunks/NcSettingsSelectGroup-BJIByip9.mjs.map +1 -0
- package/dist/chunks/{NcSettingsSelectGroup-Dc7oy0Jg.cjs → NcSettingsSelectGroup-fY7wG4iL.cjs} +6 -6
- package/dist/chunks/NcSettingsSelectGroup-fY7wG4iL.cjs.map +1 -0
- package/dist/chunks/{NcTextField-BmaDUUfq.mjs → NcTextField-CjEhJrIE.mjs} +2 -2
- package/dist/chunks/NcTextField-CjEhJrIE.mjs.map +1 -0
- package/dist/chunks/{NcTextField-BmOKGaQ4.cjs → NcTextField-DGywgzwv.cjs} +2 -2
- package/dist/chunks/NcTextField-DGywgzwv.cjs.map +1 -0
- package/dist/chunks/NcTimezonePicker-DLFrgfqk.cjs +184 -0
- package/dist/chunks/NcTimezonePicker-DLFrgfqk.cjs.map +1 -0
- package/dist/chunks/NcTimezonePicker-J8vQyRH8.mjs +185 -0
- package/dist/chunks/NcTimezonePicker-J8vQyRH8.mjs.map +1 -0
- package/dist/chunks/{NcUserBubble-BJp-ZBGW.mjs → NcUserBubble-C1ecV_fU.mjs} +4 -4
- package/dist/chunks/NcUserBubble-C1ecV_fU.mjs.map +1 -0
- package/dist/chunks/{NcUserBubble-BsQJPVXD.cjs → NcUserBubble-C4fdYO4b.cjs} +4 -4
- package/dist/chunks/NcUserBubble-C4fdYO4b.cjs.map +1 -0
- package/dist/chunks/{NcUserStatusIcon-Ba9ajMhK.cjs → NcUserStatusIcon-BqUz25xE.cjs} +9 -37
- package/dist/chunks/NcUserStatusIcon-BqUz25xE.cjs.map +1 -0
- package/dist/chunks/{NcUserStatusIcon-BkO1ZAdq.mjs → NcUserStatusIcon-DQyfBtYn.mjs} +9 -36
- package/dist/chunks/NcUserStatusIcon-DQyfBtYn.mjs.map +1 -0
- package/dist/chunks/ScopeComponent-00_hPc9T.mjs +13 -0
- package/dist/chunks/ScopeComponent-00_hPc9T.mjs.map +1 -0
- package/dist/chunks/ScopeComponent-ByTiGqjs.cjs +12 -0
- package/dist/chunks/ScopeComponent-ByTiGqjs.cjs.map +1 -0
- package/dist/chunks/_l10n-CWsOa8mM.cjs +125 -0
- package/dist/chunks/{_l10n-BYPqjHzt.cjs.map → _l10n-CWsOa8mM.cjs.map} +1 -1
- package/dist/chunks/_l10n-DDx8P-X1.mjs +126 -0
- package/dist/chunks/_l10n-DDx8P-X1.mjs.map +1 -0
- package/dist/chunks/actionGlobal-DqVa7c7G.mjs +25 -0
- package/dist/chunks/actionGlobal-DqVa7c7G.mjs.map +1 -0
- package/dist/chunks/actionGlobal-L0Ls8tPJ.cjs +24 -0
- package/dist/chunks/actionGlobal-L0Ls8tPJ.cjs.map +1 -0
- package/dist/chunks/{actionText-BnA6RS9I.cjs → actionText-BcrK4uH1.cjs} +1 -43
- package/dist/chunks/actionText-BcrK4uH1.cjs.map +1 -0
- package/dist/chunks/{actionText-BaGktsVf.mjs → actionText-fFcUPi2g.mjs} +1 -43
- package/dist/chunks/actionText-fFcUPi2g.mjs.map +1 -0
- package/dist/chunks/{autolink-Bgjz08wN.cjs → autolink-BAgL31EZ.cjs} +7 -24
- package/dist/chunks/autolink-BAgL31EZ.cjs.map +1 -0
- package/dist/chunks/{autolink-DA7VzS8Y.mjs → autolink-cbuFALXr.mjs} +7 -24
- package/dist/chunks/autolink-cbuFALXr.mjs.map +1 -0
- package/dist/chunks/{emoji-CWr00EYY.cjs → emoji-BCCCB3t3.cjs} +9 -30
- package/dist/chunks/emoji-BCCCB3t3.cjs.map +1 -0
- package/dist/chunks/{emoji-CbOkKZx5.mjs → emoji-V6ytyzoR.mjs} +9 -30
- package/dist/chunks/emoji-V6ytyzoR.mjs.map +1 -0
- package/dist/chunks/focusTrap-Cecv_gjR.mjs +7 -0
- package/dist/chunks/focusTrap-Cecv_gjR.mjs.map +1 -0
- package/dist/chunks/focusTrap-EeXFmjdI.cjs +6 -0
- package/dist/chunks/focusTrap-EeXFmjdI.cjs.map +1 -0
- package/dist/chunks/getAvatarUrl-6z9qRNH-.cjs +10 -0
- package/dist/chunks/getAvatarUrl-6z9qRNH-.cjs.map +1 -0
- package/dist/chunks/getAvatarUrl-DxvUjKMi.mjs +11 -0
- package/dist/chunks/getAvatarUrl-DxvUjKMi.mjs.map +1 -0
- package/dist/chunks/{index-Dl-SBuhJ.cjs → index-BANjku4q.cjs} +0 -21
- package/dist/chunks/index-BANjku4q.cjs.map +1 -0
- package/dist/chunks/index-BwyQ2N-M.mjs.map +1 -1
- package/dist/chunks/{index-DYccGIvD.mjs → index-CsogA-K5.mjs} +0 -21
- package/dist/chunks/index-CsogA-K5.mjs.map +1 -0
- package/dist/chunks/{index-BRQQ9NaL.mjs → index-DbA2OZyf.mjs} +4 -25
- package/dist/chunks/index-DbA2OZyf.mjs.map +1 -0
- package/dist/chunks/index-Dsgv-f-l.cjs.map +1 -1
- package/dist/chunks/{index-D0euettC.cjs → index-oIpl1nrk.cjs} +4 -25
- package/dist/chunks/index-oIpl1nrk.cjs.map +1 -0
- package/dist/chunks/referencePickerModal-Dab6KzWL.cjs +1115 -0
- package/dist/chunks/referencePickerModal-Dab6KzWL.cjs.map +1 -0
- package/dist/chunks/referencePickerModal-KbBRUf9r.mjs +1113 -0
- package/dist/chunks/referencePickerModal-KbBRUf9r.mjs.map +1 -0
- package/dist/chunks/usernameToColor-BzDTLedj.cjs +27 -0
- package/dist/chunks/usernameToColor-BzDTLedj.cjs.map +1 -0
- package/dist/chunks/usernameToColor-CB3rGdYw.mjs +26 -0
- package/dist/chunks/usernameToColor-CB3rGdYw.mjs.map +1 -0
- package/dist/components/NcCollectionList/service.d.ts +47 -0
- package/dist/composables/actions/useActionText.d.ts +14 -0
- package/dist/composables/useFormatDateTime.d.ts +6 -6
- package/dist/functions/a11y/index.d.ts +2 -19
- package/dist/functions/emoji/emoji.d.ts +23 -27
- package/dist/functions/emoji/index.d.ts +2 -19
- package/dist/functions/reference/widgets.d.ts +4 -0
- package/dist/index.cjs +63 -92
- package/dist/index.cjs.map +1 -1
- package/dist/index.mjs +65 -94
- package/dist/index.mjs.map +1 -1
- package/dist/utils/UserStatus.d.ts +2 -19
- package/dist/utils/getAvatarUrl.d.ts +2 -19
- package/dist/vendor.LICENSE.txt +4 -4
- package/package.json +11 -9
- package/LICENSE +0 -661
- package/dist/assets/NcActionButton-D08gPtwM.css +0 -139
- package/dist/assets/NcActionCaption-sfcjBZnu.css +0 -46
- package/dist/assets/NcActionCheckbox-DTlI7y7p.css +0 -110
- package/dist/assets/NcActionInput-B8l22cnm.css +0 -271
- package/dist/assets/NcActionLink-ufhOZDI9.css +0 -124
- package/dist/assets/NcActionRadio-syUIsm9B.css +0 -110
- package/dist/assets/NcActionRouter-BbTCI4sn.css +0 -135
- package/dist/assets/NcActionSeparator-CB59y4di.css +0 -38
- package/dist/assets/NcActionText-Ceh88fy8.css +0 -139
- package/dist/assets/NcActionTextEditable-BoxziChR.css +0 -287
- package/dist/assets/NcActions-N_Y6Nzew.css +0 -111
- package/dist/assets/NcAppContent-C08OMmgh.css +0 -153
- package/dist/assets/NcAppNavigation-DlFgsfe2.css +0 -131
- package/dist/assets/NcAppNavigationCaption-DnApJ5OW.css +0 -62
- package/dist/assets/NcAppNavigationIconBullet-B8q3pUL5.css +0 -44
- package/dist/assets/NcAppNavigationItem-OJEHVyVk.css +0 -235
- package/dist/assets/NcAppNavigationList-DnIxrbVX.css +0 -43
- package/dist/assets/NcAppNavigationNew-BPZ1O8Xm.css +0 -41
- package/dist/assets/NcAppNavigationSettings-BCkvRAy8.css +0 -93
- package/dist/assets/NcAppNavigationSpacer-Cb4q1zb5.css +0 -6
- package/dist/assets/NcAppNavigationToggle-0yhQ9xse.css +0 -41
- package/dist/assets/NcAppSettingsDialog-CajWZJNV.css +0 -88
- package/dist/assets/NcAppSettingsSection-BDvzWKkd.css +0 -44
- package/dist/assets/NcAppSidebarTab-CBFET-hQ.css +0 -48
- package/dist/assets/NcAvatar-C2EFGp-3.css +0 -143
- package/dist/assets/NcBreadcrumb-AES5eSWo.css +0 -82
- package/dist/assets/NcBreadcrumbs-tYrp1DVs.css +0 -51
- package/dist/assets/NcButton-DZS360ia.css +0 -204
- package/dist/assets/NcColorPicker-CzKZjMxY.css +0 -136
- package/dist/assets/NcContent-Cuv2HvFH.css +0 -110
- package/dist/assets/NcCounterBubble-CWi_P1Tb.css +0 -67
- package/dist/assets/NcDashboardWidget-CGOA8X60.css +0 -87
- package/dist/assets/NcDashboardWidgetItem-BevETFRF.css +0 -99
- package/dist/assets/NcDateTimePickerNative-CV_VuzvQ.css +0 -61
- package/dist/assets/NcDialog-DFMxsFp5.css +0 -160
- package/dist/assets/NcEllipsisedOption-ClDzkIX6.css +0 -48
- package/dist/assets/NcEmptyContent-BY1-Gge4.css +0 -79
- package/dist/assets/NcGuestContent-CeRLfUEi.css +0 -78
- package/dist/assets/NcHeaderMenu-N5y8yFGd.css +0 -91
- package/dist/assets/NcIconSvgWrapper-DF9sBD2g.css +0 -53
- package/dist/assets/NcInputConfirmCancel-UcHrm0al.css +0 -53
- package/dist/assets/NcListItem-DMYcn1cc.css +0 -170
- package/dist/assets/NcListItemIcon-CuPMgXoB.css +0 -78
- package/dist/assets/NcLoadingIcon-gxK0ujO0.css +0 -35
- package/dist/assets/NcMentionBubble-DmzU72Mw.css +0 -84
- package/dist/assets/NcModal-Cof88czY.css +0 -299
- package/dist/assets/NcNoteCard-e7-Bxio8.css +0 -64
- package/dist/assets/NcProgressBar-D5VftcJm.css +0 -70
- package/dist/assets/NcRelatedResourcesPanel-BrXxbjgR.css +0 -200
- package/dist/assets/NcRichText-Cdp_2wEm.css +0 -240
- package/dist/assets/NcSettingsInputText-CU65Coab.css +0 -49
- package/dist/assets/NcSettingsSection-TX28tYCG.css +0 -70
- package/dist/assets/NcSettingsSelectGroup-CPauLI-o.css +0 -37
- package/dist/assets/NcUserBubble-D5ieZC-f.css +0 -62
- package/dist/assets/NcUserStatusIcon-BcLArDqV.css +0 -44
- package/dist/assets/referencePickerModal-BaGbKZky.css +0 -539
- package/dist/chunks/GenColors-CAUl-IDP.cjs.map +0 -1
- package/dist/chunks/GenColors-DcjtQMk3.mjs.map +0 -1
- package/dist/chunks/GenRandomId-CXkjMlAT.mjs +0 -27
- package/dist/chunks/GenRandomId-CXkjMlAT.mjs.map +0 -1
- package/dist/chunks/GenRandomId-kBCcgMJd.cjs +0 -26
- package/dist/chunks/GenRandomId-kBCcgMJd.cjs.map +0 -1
- package/dist/chunks/Linkify-BBPJHBma.mjs +0 -35
- package/dist/chunks/Linkify-BBPJHBma.mjs.map +0 -1
- package/dist/chunks/Linkify-CIO279AG.cjs +0 -36
- package/dist/chunks/Linkify-CIO279AG.cjs.map +0 -1
- package/dist/chunks/NcActionButtonGroup-D650-6zv.mjs.map +0 -1
- package/dist/chunks/NcActionButtonGroup-D7hycpXY.cjs.map +0 -1
- package/dist/chunks/NcActionInput-BqG7gSLn.mjs.map +0 -1
- package/dist/chunks/NcActionInput-CHucaM0V.cjs.map +0 -1
- package/dist/chunks/NcActions-CocYka0Y.mjs.map +0 -1
- package/dist/chunks/NcActions-JX6wbAVA.cjs.map +0 -1
- package/dist/chunks/NcAppContent-CkO1Y93z.cjs.map +0 -1
- package/dist/chunks/NcAppContent-wlhVbyg0.mjs.map +0 -1
- package/dist/chunks/NcAppNavigation-BKiDVBw7.mjs.map +0 -1
- package/dist/chunks/NcAppNavigation-Du3J8BTm.cjs.map +0 -1
- package/dist/chunks/NcAppNavigationCaption-BoN0P7tD.cjs.map +0 -1
- package/dist/chunks/NcAppNavigationCaption-CKTQZ_u_.mjs.map +0 -1
- package/dist/chunks/NcAppNavigationItem-D_lh17am.cjs.map +0 -1
- package/dist/chunks/NcAppNavigationItem-qe8jnLow.mjs.map +0 -1
- package/dist/chunks/NcAppNavigationNewItem-B107Beoc.mjs.map +0 -1
- package/dist/chunks/NcAppNavigationNewItem-DyxVXE5t.cjs.map +0 -1
- package/dist/chunks/NcAppNavigationSettings-CmP_tXFm.cjs.map +0 -1
- package/dist/chunks/NcAppNavigationSettings-DZ1-Sbdz.mjs.map +0 -1
- package/dist/chunks/NcAppNavigationToggle-hmEUqxbP.cjs.map +0 -1
- package/dist/chunks/NcAppNavigationToggle-zCGgvNDT.mjs.map +0 -1
- package/dist/chunks/NcAppSettingsDialog-D9cNYQ8b.mjs.map +0 -1
- package/dist/chunks/NcAppSettingsDialog-YqNhco1P.cjs.map +0 -1
- package/dist/chunks/NcAppSidebar-CQWODfsy.mjs.map +0 -1
- package/dist/chunks/NcAppSidebar-J15zHyfq.cjs.map +0 -1
- package/dist/chunks/NcAvatar-CX3OX2C4.mjs.map +0 -1
- package/dist/chunks/NcAvatar-CYzikYku.cjs.map +0 -1
- package/dist/chunks/NcBreadcrumb-DytGDsr8.mjs.map +0 -1
- package/dist/chunks/NcBreadcrumb-jMJw2OQJ.cjs.map +0 -1
- package/dist/chunks/NcBreadcrumbs-BqFPBZ-h.mjs.map +0 -1
- package/dist/chunks/NcBreadcrumbs-CzObAKB-.cjs.map +0 -1
- package/dist/chunks/NcCheckboxRadioSwitch-CIHl8lnP.cjs.map +0 -1
- package/dist/chunks/NcCheckboxRadioSwitch-CpupDtee.mjs.map +0 -1
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_6d6e6a47_lang-CAFQAKcK.mjs +0 -3
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_6d6e6a47_lang-CAFQAKcK.mjs.map +0 -1
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_6d6e6a47_lang-D2wGnjg7.cjs +0 -4
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_6d6e6a47_lang-D2wGnjg7.cjs.map +0 -1
- package/dist/chunks/NcColorPicker-BEs2B-HB.mjs.map +0 -1
- package/dist/chunks/NcColorPicker-KrvDMhej.cjs.map +0 -1
- package/dist/chunks/NcContent-CcrNrpVC.mjs +0 -104
- package/dist/chunks/NcContent-CcrNrpVC.mjs.map +0 -1
- package/dist/chunks/NcContent-DChC6Khv.cjs +0 -103
- package/dist/chunks/NcContent-DChC6Khv.cjs.map +0 -1
- package/dist/chunks/NcDashboardWidget-BvNtltPU.cjs.map +0 -1
- package/dist/chunks/NcDashboardWidget-Da715DSB.mjs.map +0 -1
- package/dist/chunks/NcDashboardWidgetItem-BkJTg3kj.mjs.map +0 -1
- package/dist/chunks/NcDashboardWidgetItem-CKv_fb-1.cjs.map +0 -1
- package/dist/chunks/NcDateTime-CpJDGhl7.mjs.map +0 -1
- package/dist/chunks/NcDateTime-Cy5Bp0d2.cjs.map +0 -1
- package/dist/chunks/NcDialog-B3ZaXnpn.mjs.map +0 -1
- package/dist/chunks/NcDialog-C7KRNdTc.cjs.map +0 -1
- package/dist/chunks/NcDialogButton-BV3Kf9U7.mjs.map +0 -1
- package/dist/chunks/NcDialogButton-CLWLvwpm.cjs.map +0 -1
- package/dist/chunks/NcEmojiPicker-LFuZ15M5.cjs.map +0 -1
- package/dist/chunks/NcEmojiPicker-SqbRSwu2.mjs.map +0 -1
- package/dist/chunks/NcHeaderMenu-2n5GDt37.mjs.map +0 -1
- package/dist/chunks/NcHeaderMenu-830tFszI.cjs.map +0 -1
- package/dist/chunks/NcIconSvgWrapper-KWEbPRC9.mjs.map +0 -1
- package/dist/chunks/NcIconSvgWrapper-O61kZVNp.cjs.map +0 -1
- package/dist/chunks/NcInputConfirmCancel-CJ7nPGEd.cjs.map +0 -1
- package/dist/chunks/NcInputConfirmCancel-XXXgXoSw.mjs.map +0 -1
- package/dist/chunks/NcListItemIcon-44A7fm62.cjs.map +0 -1
- package/dist/chunks/NcListItemIcon-CTTJYWzN.mjs.map +0 -1
- package/dist/chunks/NcPasswordField-DN-kdAfl.cjs.map +0 -1
- package/dist/chunks/NcPasswordField-Z6BCKScy.mjs.map +0 -1
- package/dist/chunks/NcPopover-BS1bBSkg.cjs.map +0 -1
- package/dist/chunks/NcPopover-foxJPAfG.mjs.map +0 -1
- package/dist/chunks/NcProgressBar-BafFcKiu.mjs.map +0 -1
- package/dist/chunks/NcProgressBar-mFqoqB4L.cjs.map +0 -1
- package/dist/chunks/NcRelatedResourcesPanel-D3QlWSNc.mjs.map +0 -1
- package/dist/chunks/NcRelatedResourcesPanel-Dcm2wvfd.cjs.map +0 -1
- package/dist/chunks/NcRichContenteditable-BB-qsHEm.mjs.map +0 -1
- package/dist/chunks/NcRichContenteditable-DljQv8gw.cjs.map +0 -1
- package/dist/chunks/NcRichText-BDVKgmY5.cjs.map +0 -1
- package/dist/chunks/NcRichText-BT4VjvXi.mjs.map +0 -1
- package/dist/chunks/NcSelect-CNm4fmR6.mjs.map +0 -1
- package/dist/chunks/NcSelect-DckQCxxX.cjs.map +0 -1
- package/dist/chunks/NcSelectTags-CnkBJ3vP.cjs.map +0 -1
- package/dist/chunks/NcSelectTags-nCqLANFH.mjs.map +0 -1
- package/dist/chunks/NcSettingsInputText-D-S5LBmN.mjs.map +0 -1
- package/dist/chunks/NcSettingsInputText-Dd3wEwGy.cjs.map +0 -1
- package/dist/chunks/NcSettingsSection-B0-LmypW.mjs.map +0 -1
- package/dist/chunks/NcSettingsSection-ayl3nvdL.cjs.map +0 -1
- package/dist/chunks/NcSettingsSelectGroup-C51Km4wj.mjs.map +0 -1
- package/dist/chunks/NcSettingsSelectGroup-Dc7oy0Jg.cjs.map +0 -1
- package/dist/chunks/NcTextField-BmOKGaQ4.cjs.map +0 -1
- package/dist/chunks/NcTextField-BmaDUUfq.mjs.map +0 -1
- package/dist/chunks/NcTimezonePicker-BSgT2QA5.mjs +0 -4049
- package/dist/chunks/NcTimezonePicker-BSgT2QA5.mjs.map +0 -1
- package/dist/chunks/NcTimezonePicker-iD8mrVb_.cjs +0 -4048
- package/dist/chunks/NcTimezonePicker-iD8mrVb_.cjs.map +0 -1
- package/dist/chunks/NcUserBubble-BJp-ZBGW.mjs.map +0 -1
- package/dist/chunks/NcUserBubble-BsQJPVXD.cjs.map +0 -1
- package/dist/chunks/NcUserStatusIcon-Ba9ajMhK.cjs.map +0 -1
- package/dist/chunks/NcUserStatusIcon-BkO1ZAdq.mjs.map +0 -1
- package/dist/chunks/ScopeComponent-BpyBuaF3.cjs +0 -33
- package/dist/chunks/ScopeComponent-BpyBuaF3.cjs.map +0 -1
- package/dist/chunks/ScopeComponent-Dy6ublmy.mjs +0 -34
- package/dist/chunks/ScopeComponent-Dy6ublmy.mjs.map +0 -1
- package/dist/chunks/_l10n-BYPqjHzt.cjs +0 -121
- package/dist/chunks/_l10n-hRR5zBTZ.mjs +0 -122
- package/dist/chunks/_l10n-hRR5zBTZ.mjs.map +0 -1
- package/dist/chunks/actionGlobal-BfK-CImU.cjs +0 -45
- package/dist/chunks/actionGlobal-BfK-CImU.cjs.map +0 -1
- package/dist/chunks/actionGlobal-DV5ZiuS0.mjs +0 -46
- package/dist/chunks/actionGlobal-DV5ZiuS0.mjs.map +0 -1
- package/dist/chunks/actionText-BaGktsVf.mjs.map +0 -1
- package/dist/chunks/actionText-BnA6RS9I.cjs.map +0 -1
- package/dist/chunks/autolink-Bgjz08wN.cjs.map +0 -1
- package/dist/chunks/autolink-DA7VzS8Y.mjs.map +0 -1
- package/dist/chunks/emoji-CWr00EYY.cjs.map +0 -1
- package/dist/chunks/emoji-CbOkKZx5.mjs.map +0 -1
- package/dist/chunks/focusTrap-Dsmd28wG.cjs +0 -27
- package/dist/chunks/focusTrap-Dsmd28wG.cjs.map +0 -1
- package/dist/chunks/focusTrap-hWDNhn4t.mjs +0 -28
- package/dist/chunks/focusTrap-hWDNhn4t.mjs.map +0 -1
- package/dist/chunks/getAvatarUrl-BBvqBOJD.mjs +0 -32
- package/dist/chunks/getAvatarUrl-BBvqBOJD.mjs.map +0 -1
- package/dist/chunks/getAvatarUrl-C40xfr4C.cjs +0 -31
- package/dist/chunks/getAvatarUrl-C40xfr4C.cjs.map +0 -1
- package/dist/chunks/index-BRQQ9NaL.mjs.map +0 -1
- package/dist/chunks/index-D0euettC.cjs.map +0 -1
- package/dist/chunks/index-DYccGIvD.mjs.map +0 -1
- package/dist/chunks/index-Dl-SBuhJ.cjs.map +0 -1
- package/dist/chunks/logger-BcZGm6Un.cjs +0 -24
- package/dist/chunks/logger-BcZGm6Un.cjs.map +0 -1
- package/dist/chunks/logger-C7ZZ6zFQ.mjs +0 -25
- package/dist/chunks/logger-C7ZZ6zFQ.mjs.map +0 -1
- package/dist/chunks/referencePickerModal-CFPdv-m1.mjs +0 -3469
- package/dist/chunks/referencePickerModal-CFPdv-m1.mjs.map +0 -1
- package/dist/chunks/referencePickerModal-m0FcnvxK.cjs +0 -3471
- package/dist/chunks/referencePickerModal-m0FcnvxK.cjs.map +0 -1
- package/dist/chunks/usernameToColor-CLlyFMmy.mjs +0 -47
- package/dist/chunks/usernameToColor-CLlyFMmy.mjs.map +0 -1
- package/dist/chunks/usernameToColor-cfXKb46d.cjs +0 -48
- package/dist/chunks/usernameToColor-cfXKb46d.cjs.map +0 -1
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
require('../assets/NcAppSidebar-
|
|
1
|
+
require('../assets/NcAppSidebar-GLK326IR.css');
|
|
2
2
|
"use strict";
|
|
3
|
+
const vueSimplePortal = require("@linusborg/vue-simple-portal");
|
|
3
4
|
const Components_NcVNodes = require("../Components/NcVNodes.cjs");
|
|
4
|
-
const NcCheckboxRadioSwitch = require("./NcCheckboxRadioSwitch-
|
|
5
|
+
const NcCheckboxRadioSwitch = require("./NcCheckboxRadioSwitch-B0HYTOsR.cjs");
|
|
5
6
|
const _pluginVue2_normalizer = require("./_plugin-vue2_normalizer-DbFIE4_M.cjs");
|
|
6
|
-
const NcActions = require("./NcActions-
|
|
7
|
+
const NcActions = require("./NcActions-DRSoPS6a.cjs");
|
|
7
8
|
const Components_NcLoadingIcon = require("../Components/NcLoadingIcon.cjs");
|
|
8
9
|
const Components_NcButton = require("../Components/NcButton.cjs");
|
|
9
10
|
const Components_NcEmptyContent = require("../Components/NcEmptyContent.cjs");
|
|
10
11
|
const Directives_Focus = require("../Directives/Focus.cjs");
|
|
11
12
|
const Directives_Linkify = require("../Directives/Linkify.cjs");
|
|
12
13
|
const Composables_useIsMobile = require("../Composables/useIsMobile.cjs");
|
|
13
|
-
const GenRandomId = require("./GenRandomId-
|
|
14
|
-
const focusTrap$1 = require("./focusTrap-
|
|
15
|
-
const _l10n = require("./_l10n-
|
|
16
|
-
const vueFrag = require("vue-frag");
|
|
14
|
+
const GenRandomId = require("./GenRandomId-BQDud3d4.cjs");
|
|
15
|
+
const focusTrap$1 = require("./focusTrap-EeXFmjdI.cjs");
|
|
16
|
+
const _l10n = require("./_l10n-CWsOa8mM.cjs");
|
|
17
17
|
const ArrowRight = require("./ArrowRight-DaYrccVG.cjs");
|
|
18
18
|
const Close = require("./Close-C2VrgKj3.cjs");
|
|
19
19
|
const components = require("@vueuse/components");
|
|
@@ -41,6 +41,13 @@ const _sfc_main$4 = {
|
|
|
41
41
|
active: {
|
|
42
42
|
type: String,
|
|
43
43
|
default: ""
|
|
44
|
+
},
|
|
45
|
+
/**
|
|
46
|
+
* Force the tab navigation to display even if there is only one tab
|
|
47
|
+
*/
|
|
48
|
+
forceTabs: {
|
|
49
|
+
type: Boolean,
|
|
50
|
+
default: false
|
|
44
51
|
}
|
|
45
52
|
},
|
|
46
53
|
emits: ["update:active"],
|
|
@@ -65,6 +72,9 @@ const _sfc_main$4 = {
|
|
|
65
72
|
hasMultipleTabs() {
|
|
66
73
|
return this.tabs.length > 1;
|
|
67
74
|
},
|
|
75
|
+
showForSingleTab() {
|
|
76
|
+
return this.forceTabs && this.tabs.length === 1;
|
|
77
|
+
},
|
|
68
78
|
currentTabIndex() {
|
|
69
79
|
return this.tabs.findIndex((tab) => tab.id === this.activeTab);
|
|
70
80
|
}
|
|
@@ -174,63 +184,47 @@ const _sfc_main$4 = {
|
|
|
174
184
|
};
|
|
175
185
|
var _sfc_render$4 = function render() {
|
|
176
186
|
var _vm = this, _c = _vm._self._c;
|
|
177
|
-
return _c("div", { staticClass: "app-sidebar-tabs" }, [_vm.hasMultipleTabs ? _c("div", { staticClass: "app-sidebar-tabs__nav", attrs: { "role": "tablist" }, on: { "keydown": [function($event) {
|
|
178
|
-
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "left", 37, $event.key, ["Left", "ArrowLeft"]))
|
|
179
|
-
|
|
180
|
-
if (
|
|
181
|
-
return null;
|
|
182
|
-
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey)
|
|
183
|
-
return null;
|
|
187
|
+
return _c("div", { staticClass: "app-sidebar-tabs" }, [_vm.hasMultipleTabs || _vm.showForSingleTab ? _c("div", { staticClass: "app-sidebar-tabs__nav", attrs: { "role": "tablist" }, on: { "keydown": [function($event) {
|
|
188
|
+
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "left", 37, $event.key, ["Left", "ArrowLeft"])) return null;
|
|
189
|
+
if ("button" in $event && $event.button !== 0) return null;
|
|
190
|
+
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey) return null;
|
|
184
191
|
$event.preventDefault();
|
|
185
192
|
$event.stopPropagation();
|
|
186
193
|
return _vm.focusPreviousTab.apply(null, arguments);
|
|
187
194
|
}, function($event) {
|
|
188
|
-
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "right", 39, $event.key, ["Right", "ArrowRight"]))
|
|
189
|
-
|
|
190
|
-
if (
|
|
191
|
-
return null;
|
|
192
|
-
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey)
|
|
193
|
-
return null;
|
|
195
|
+
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "right", 39, $event.key, ["Right", "ArrowRight"])) return null;
|
|
196
|
+
if ("button" in $event && $event.button !== 2) return null;
|
|
197
|
+
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey) return null;
|
|
194
198
|
$event.preventDefault();
|
|
195
199
|
$event.stopPropagation();
|
|
196
200
|
return _vm.focusNextTab.apply(null, arguments);
|
|
197
201
|
}, function($event) {
|
|
198
|
-
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "tab", 9, $event.key, "Tab"))
|
|
199
|
-
|
|
200
|
-
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey)
|
|
201
|
-
return null;
|
|
202
|
+
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "tab", 9, $event.key, "Tab")) return null;
|
|
203
|
+
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey) return null;
|
|
202
204
|
$event.preventDefault();
|
|
203
205
|
$event.stopPropagation();
|
|
204
206
|
return _vm.focusActiveTabContent.apply(null, arguments);
|
|
205
207
|
}, function($event) {
|
|
206
|
-
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "home", void 0, $event.key, void 0))
|
|
207
|
-
|
|
208
|
-
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey)
|
|
209
|
-
return null;
|
|
208
|
+
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "home", void 0, $event.key, void 0)) return null;
|
|
209
|
+
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey) return null;
|
|
210
210
|
$event.preventDefault();
|
|
211
211
|
$event.stopPropagation();
|
|
212
212
|
return _vm.focusFirstTab.apply(null, arguments);
|
|
213
213
|
}, function($event) {
|
|
214
|
-
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "end", void 0, $event.key, void 0))
|
|
215
|
-
|
|
216
|
-
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey)
|
|
217
|
-
return null;
|
|
214
|
+
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "end", void 0, $event.key, void 0)) return null;
|
|
215
|
+
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey) return null;
|
|
218
216
|
$event.preventDefault();
|
|
219
217
|
$event.stopPropagation();
|
|
220
218
|
return _vm.focusLastTab.apply(null, arguments);
|
|
221
219
|
}, function($event) {
|
|
222
|
-
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "page-up", void 0, $event.key, void 0))
|
|
223
|
-
|
|
224
|
-
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey)
|
|
225
|
-
return null;
|
|
220
|
+
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "page-up", void 0, $event.key, void 0)) return null;
|
|
221
|
+
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey) return null;
|
|
226
222
|
$event.preventDefault();
|
|
227
223
|
$event.stopPropagation();
|
|
228
224
|
return _vm.focusFirstTab.apply(null, arguments);
|
|
229
225
|
}, function($event) {
|
|
230
|
-
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "page-down", void 0, $event.key, void 0))
|
|
231
|
-
|
|
232
|
-
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey)
|
|
233
|
-
return null;
|
|
226
|
+
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "page-down", void 0, $event.key, void 0)) return null;
|
|
227
|
+
if ($event.ctrlKey || $event.shiftKey || $event.altKey || $event.metaKey) return null;
|
|
234
228
|
$event.preventDefault();
|
|
235
229
|
$event.stopPropagation();
|
|
236
230
|
return _vm.focusLastTab.apply(null, arguments);
|
|
@@ -249,12 +243,12 @@ var __component__$4 = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
|
|
|
249
243
|
_sfc_staticRenderFns$4,
|
|
250
244
|
false,
|
|
251
245
|
null,
|
|
252
|
-
"
|
|
246
|
+
"77326a9c",
|
|
253
247
|
null,
|
|
254
248
|
null
|
|
255
249
|
);
|
|
256
250
|
const NcAppSidebarTabs = __component__$4.exports;
|
|
257
|
-
_l10n.register(_l10n.
|
|
251
|
+
_l10n.register(_l10n.t14);
|
|
258
252
|
const _sfc_main$3 = {
|
|
259
253
|
name: "DockRightIcon",
|
|
260
254
|
emits: ["click"],
|
|
@@ -363,7 +357,7 @@ const StarOutline = __component__$1.exports;
|
|
|
363
357
|
const _sfc_main = {
|
|
364
358
|
name: "NcAppSidebar",
|
|
365
359
|
components: {
|
|
366
|
-
|
|
360
|
+
Teleport: vueSimplePortal.Portal,
|
|
367
361
|
NcActions: NcActions.NcActions,
|
|
368
362
|
NcAppSidebarTabs,
|
|
369
363
|
ArrowRight: ArrowRight.ArrowRight,
|
|
@@ -380,7 +374,12 @@ const _sfc_main = {
|
|
|
380
374
|
linkify: Directives_Linkify.directive,
|
|
381
375
|
ClickOutside: components.vOnClickOutside
|
|
382
376
|
},
|
|
383
|
-
|
|
377
|
+
inject: {
|
|
378
|
+
ncContentSelector: {
|
|
379
|
+
from: "NcContent:selector",
|
|
380
|
+
default: void 0
|
|
381
|
+
}
|
|
382
|
+
},
|
|
384
383
|
props: {
|
|
385
384
|
active: {
|
|
386
385
|
type: String,
|
|
@@ -466,6 +465,13 @@ const _sfc_main = {
|
|
|
466
465
|
type: Boolean,
|
|
467
466
|
default: false
|
|
468
467
|
},
|
|
468
|
+
/**
|
|
469
|
+
* Force the tab navigation to display even if there is only one tab
|
|
470
|
+
*/
|
|
471
|
+
forceTabs: {
|
|
472
|
+
type: Boolean,
|
|
473
|
+
default: false
|
|
474
|
+
},
|
|
469
475
|
/**
|
|
470
476
|
* Linkify the name
|
|
471
477
|
*/
|
|
@@ -484,22 +490,36 @@ const _sfc_main = {
|
|
|
484
490
|
/**
|
|
485
491
|
* Allow to conditionally show the sidebar
|
|
486
492
|
* You can also use `v-if` on the sidebar, but using the open prop allow to keep
|
|
487
|
-
* the sidebar inside the DOM for performance if it is opened and closed
|
|
493
|
+
* the sidebar inside the DOM for performance if it is opened and closed multiple times.
|
|
488
494
|
*
|
|
489
495
|
* When using the `open` property to close the sidebar a built-in toggle button will be shown to reopen it,
|
|
490
|
-
* similar to the app navigation.
|
|
496
|
+
* similar to the app navigation. You can remove this button with the `no-toggle` prop.
|
|
491
497
|
*/
|
|
492
498
|
open: {
|
|
493
499
|
type: Boolean,
|
|
494
500
|
default: true
|
|
495
501
|
},
|
|
496
502
|
/**
|
|
497
|
-
* Custom classes to assign to the sidebar toggle button
|
|
503
|
+
* Custom classes to assign to the sidebar toggle button.
|
|
498
504
|
* If needed this can be used to assign styles to the button using `:deep()` selector.
|
|
499
505
|
*/
|
|
500
506
|
toggleClasses: {
|
|
501
507
|
type: [String, Array, Object],
|
|
502
508
|
default: ""
|
|
509
|
+
},
|
|
510
|
+
/**
|
|
511
|
+
* Custom attrs to assign to the sidebar toggle button.
|
|
512
|
+
*/
|
|
513
|
+
toggleAttrs: {
|
|
514
|
+
type: Object,
|
|
515
|
+
default: void 0
|
|
516
|
+
},
|
|
517
|
+
/**
|
|
518
|
+
* Do not add the built-in toggle button with `open` prop.
|
|
519
|
+
*/
|
|
520
|
+
noToggle: {
|
|
521
|
+
type: Boolean,
|
|
522
|
+
default: false
|
|
503
523
|
}
|
|
504
524
|
},
|
|
505
525
|
emits: [
|
|
@@ -553,10 +573,12 @@ const _sfc_main = {
|
|
|
553
573
|
},
|
|
554
574
|
open() {
|
|
555
575
|
this.toggleFocusTrap();
|
|
576
|
+
this.checkToggleButtonContainerAvailability();
|
|
556
577
|
}
|
|
557
578
|
},
|
|
558
579
|
created() {
|
|
559
580
|
this.preserveElementToReturnFocus();
|
|
581
|
+
this.checkToggleButtonContainerAvailability();
|
|
560
582
|
},
|
|
561
583
|
mounted() {
|
|
562
584
|
if (this.elementToReturnFocus) {
|
|
@@ -584,7 +606,6 @@ const _sfc_main = {
|
|
|
584
606
|
}
|
|
585
607
|
},
|
|
586
608
|
initFocusTrap() {
|
|
587
|
-
var _a;
|
|
588
609
|
if (this.focusTrap) {
|
|
589
610
|
return;
|
|
590
611
|
}
|
|
@@ -592,10 +613,7 @@ const _sfc_main = {
|
|
|
592
613
|
// The sidebar itself
|
|
593
614
|
this.$refs.sidebar,
|
|
594
615
|
// Nextcloud Server header navigarion
|
|
595
|
-
document.querySelector("#header")
|
|
596
|
-
// The app navigation toggle. Navigation can be opened above the sidebar
|
|
597
|
-
// Take the parent element, because the focus-trap requires a container with elements, not the element itself
|
|
598
|
-
(_a = document.querySelector('[aria-controls="app-navigation-vue"]')) == null ? void 0 : _a.parentElement
|
|
616
|
+
document.querySelector("#header")
|
|
599
617
|
], {
|
|
600
618
|
allowOutsideClick: true,
|
|
601
619
|
fallbackFocus: this.$refs.closeButton,
|
|
@@ -689,6 +707,16 @@ const _sfc_main = {
|
|
|
689
707
|
this.preserveElementToReturnFocus();
|
|
690
708
|
this.$refs.tabs.focusActiveTabContent();
|
|
691
709
|
},
|
|
710
|
+
/**
|
|
711
|
+
* Check if the toggle button container is available
|
|
712
|
+
*/
|
|
713
|
+
checkToggleButtonContainerAvailability() {
|
|
714
|
+
if (this.open === false && !this.noToggle && !this.ncContentSelector) {
|
|
715
|
+
console.warn(
|
|
716
|
+
"[NcAppSidebar] It looks like you want to use NcAppSidebar with the built-in toggle button. This feature is only available when NcAppSidebar is used in NcContent."
|
|
717
|
+
);
|
|
718
|
+
}
|
|
719
|
+
},
|
|
692
720
|
/**
|
|
693
721
|
* Emit name change event to parent component
|
|
694
722
|
*
|
|
@@ -718,17 +746,16 @@ const _sfc_main = {
|
|
|
718
746
|
};
|
|
719
747
|
var _sfc_render = function render5() {
|
|
720
748
|
var _vm = this, _c = _vm._self._c;
|
|
721
|
-
return _c("
|
|
749
|
+
return _c("transition", { attrs: { "appear": "", "name": "slide-right" }, on: { "before-enter": _vm.onBeforeEnter, "after-enter": _vm.onAfterEnter, "before-leave": _vm.onBeforeLeave, "after-leave": _vm.onAfterLeave } }, [_c("aside", { directives: [{ name: "show", rawName: "v-show", value: _vm.open, expression: "open" }], ref: "sidebar", staticClass: "app-sidebar", attrs: { "id": "app-sidebar-vue", "aria-labelledby": "app-sidebar-vue-".concat(_vm.uid, "__header") }, on: { "keydown": function($event) {
|
|
750
|
+
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "esc", 27, $event.key, ["Esc", "Escape"])) return null;
|
|
751
|
+
return _vm.onKeydownEsc.apply(null, arguments);
|
|
752
|
+
} } }, [_vm.ncContentSelector && !_vm.open && !_vm.noToggle ? _c("Teleport", { attrs: { "selector": _vm.ncContentSelector } }, [_c("NcButton", _vm._b({ staticClass: "app-sidebar__toggle", class: _vm.toggleClasses, attrs: { "aria-label": _vm.t("Open sidebar"), "type": "tertiary" }, on: { "click": function($event) {
|
|
722
753
|
return _vm.$emit("update:open", true);
|
|
723
754
|
} }, scopedSlots: _vm._u([{ key: "icon", fn: function() {
|
|
724
755
|
return [_vm._t("toggle-icon", function() {
|
|
725
756
|
return [_c("IconDockRight", { attrs: { "size": 20 } })];
|
|
726
757
|
})];
|
|
727
|
-
}, proxy: true }], null, true) }
|
|
728
|
-
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "esc", 27, $event.key, ["Esc", "Escape"]))
|
|
729
|
-
return null;
|
|
730
|
-
return _vm.onKeydownEsc.apply(null, arguments);
|
|
731
|
-
} } }, [_c("header", { staticClass: "app-sidebar-header", class: {
|
|
758
|
+
}, proxy: true }], null, true) }, "NcButton", _vm.toggleAttrs, false))], 1) : _vm._e(), _c("header", { staticClass: "app-sidebar-header", class: {
|
|
732
759
|
"app-sidebar-header--with-figure": _vm.hasFigure,
|
|
733
760
|
"app-sidebar-header--compact": _vm.compact
|
|
734
761
|
} }, [_c("div", { staticClass: "app-sidebar-header__info" }, [_vm.hasFigure && !_vm.empty ? _c("div", { staticClass: "app-sidebar-header__figure", class: {
|
|
@@ -736,8 +763,7 @@ var _sfc_render = function render5() {
|
|
|
736
763
|
}, style: {
|
|
737
764
|
backgroundImage: "url(".concat(_vm.background, ")")
|
|
738
765
|
}, attrs: { "tabindex": "0" }, on: { "click": _vm.onFigureClick, "keydown": function($event) {
|
|
739
|
-
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter"))
|
|
740
|
-
return null;
|
|
766
|
+
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")) return null;
|
|
741
767
|
return _vm.onFigureClick.apply(null, arguments);
|
|
742
768
|
} } }, [_vm._t("header")], 2) : _vm._e(), !_vm.empty ? _c("div", { staticClass: "app-sidebar-header__desc", class: {
|
|
743
769
|
"app-sidebar-header__desc--with-tertiary-action": _vm.canStar || _vm.$slots["tertiary-actions"],
|
|
@@ -752,15 +778,13 @@ var _sfc_render = function render5() {
|
|
|
752
778
|
return [_vm.starLoading ? _c("NcLoadingIcon") : _vm.isStarred ? _c("Star", { attrs: { "size": 20 } }) : _c("StarOutline", { attrs: { "size": 20 } })];
|
|
753
779
|
}, proxy: true }], null, false, 2575459756) }) : _vm._e()];
|
|
754
780
|
})], 2) : _vm._e(), _c("div", { staticClass: "app-sidebar-header__name-container" }, [_c("div", { staticClass: "app-sidebar-header__mainname-container" }, [_c("h2", { directives: [{ name: "show", rawName: "v-show", value: !_vm.nameEditable, expression: "!nameEditable" }, { name: "linkify", rawName: "v-linkify", value: { text: _vm.name, linkify: _vm.linkifyName }, expression: "{text: name, linkify: linkifyName}" }], ref: "header", staticClass: "app-sidebar-header__mainname", attrs: { "id": "app-sidebar-vue-".concat(_vm.uid, "__header"), "aria-label": _vm.title, "title": _vm.title, "tabindex": _vm.nameEditable ? 0 : -1 }, on: { "click": function($event) {
|
|
755
|
-
if ($event.target !== $event.currentTarget)
|
|
756
|
-
return null;
|
|
781
|
+
if ($event.target !== $event.currentTarget) return null;
|
|
757
782
|
return _vm.editName.apply(null, arguments);
|
|
758
783
|
} } }, [_vm._v(" " + _vm._s(_vm.name) + " ")]), _vm.nameEditable ? [_c("form", { directives: [{ name: "click-outside", rawName: "v-click-outside", value: () => _vm.onSubmitName(), expression: "() => onSubmitName()" }], staticClass: "app-sidebar-header__mainname-form", on: { "submit": function($event) {
|
|
759
784
|
$event.preventDefault();
|
|
760
785
|
return _vm.onSubmitName.apply(null, arguments);
|
|
761
786
|
} } }, [_c("input", { directives: [{ name: "focus", rawName: "v-focus" }], ref: "nameInput", staticClass: "app-sidebar-header__mainname-input", attrs: { "type": "text", "placeholder": _vm.namePlaceholder }, domProps: { "value": _vm.name }, on: { "keydown": function($event) {
|
|
762
|
-
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "esc", 27, $event.key, ["Esc", "Escape"]))
|
|
763
|
-
return null;
|
|
787
|
+
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "esc", 27, $event.key, ["Esc", "Escape"])) return null;
|
|
764
788
|
$event.stopPropagation();
|
|
765
789
|
return _vm.onDismissEditing.apply(null, arguments);
|
|
766
790
|
}, "input": _vm.onNameInput } }), _c("NcButton", { attrs: { "type": "tertiary-no-background", "aria-label": _vm.changeNameTranslated, "native-type": "submit" }, scopedSlots: _vm._u([{ key: "icon", fn: function() {
|
|
@@ -772,9 +796,9 @@ var _sfc_render = function render5() {
|
|
|
772
796
|
return _vm.closeSidebar.apply(null, arguments);
|
|
773
797
|
} }, scopedSlots: _vm._u([{ key: "icon", fn: function() {
|
|
774
798
|
return [_c("Close", { attrs: { "size": 20 } })];
|
|
775
|
-
}, proxy: true }]) }), _vm.$slots["description"] && !_vm.empty ? _c("div", { staticClass: "app-sidebar-header__description" }, [_vm._t("description")], 2) : _vm._e()], 1), _c("NcAppSidebarTabs", { directives: [{ name: "show", rawName: "v-show", value: !_vm.loading, expression: "!loading" }], ref: "tabs", attrs: { "active": _vm.active }, on: { "update:active": _vm.onUpdateActive } }, [_vm._t("default")], 2), _vm.loading ? _c("NcEmptyContent", { scopedSlots: _vm._u([{ key: "icon", fn: function() {
|
|
799
|
+
}, proxy: true }]) }), _vm.$slots["description"] && !_vm.empty ? _c("div", { staticClass: "app-sidebar-header__description" }, [_vm._t("description")], 2) : _vm._e()], 1), _c("NcAppSidebarTabs", { directives: [{ name: "show", rawName: "v-show", value: !_vm.loading, expression: "!loading" }], ref: "tabs", attrs: { "active": _vm.active, "force-tabs": _vm.forceTabs }, on: { "update:active": _vm.onUpdateActive } }, [_vm._t("default")], 2), _vm.loading ? _c("NcEmptyContent", { scopedSlots: _vm._u([{ key: "icon", fn: function() {
|
|
776
800
|
return [_c("NcLoadingIcon", { attrs: { "size": 64 } })];
|
|
777
|
-
}, proxy: true }], null, false, 826850984) }) : _vm._e()], 1)])
|
|
801
|
+
}, proxy: true }], null, false, 826850984) }) : _vm._e()], 1)]);
|
|
778
802
|
};
|
|
779
803
|
var _sfc_staticRenderFns = [];
|
|
780
804
|
var __component__ = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
|
|
@@ -783,7 +807,7 @@ var __component__ = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
|
|
|
783
807
|
_sfc_staticRenderFns,
|
|
784
808
|
false,
|
|
785
809
|
null,
|
|
786
|
-
"
|
|
810
|
+
"71840ce6",
|
|
787
811
|
null,
|
|
788
812
|
null
|
|
789
813
|
);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NcAppSidebar-kuqm78Wl.cjs","sources":["../../src/components/NcAppSidebar/NcAppSidebarTabs.vue","../../node_modules/vue-material-design-icons/DockRight.vue","../../node_modules/vue-material-design-icons/Star.vue","../../node_modules/vue-material-design-icons/StarOutline.vue","../../src/components/NcAppSidebar/NcAppSidebar.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<!-- Follows the tab aria guidelines\n\thttps://www.w3.org/TR/wai-aria-practices/examples/tabs/tabs-1/tabs.html -->\n<template>\n\t<div class=\"app-sidebar-tabs\">\n\t\t<!-- tabs navigation -->\n\t\t<!-- 33 and 34 code is for page up and page down -->\n\t\t<div v-if=\"hasMultipleTabs || showForSingleTab\"\n\t\t\trole=\"tablist\"\n\t\t\tclass=\"app-sidebar-tabs__nav\"\n\t\t\t@keydown.left.exact.prevent.stop=\"focusPreviousTab\"\n\t\t\t@keydown.right.exact.prevent.stop=\"focusNextTab\"\n\t\t\t@keydown.tab.exact.prevent.stop=\"focusActiveTabContent\"\n\t\t\t@keydown.home.exact.prevent.stop=\"focusFirstTab\"\n\t\t\t@keydown.end.exact.prevent.stop=\"focusLastTab\"\n\t\t\t@keydown.page-up.exact.prevent.stop=\"focusFirstTab\"\n\t\t\t@keydown.page-down.exact.prevent.stop=\"focusLastTab\">\n\t\t\t<NcCheckboxRadioSwitch v-for=\"tab in tabs\"\n\t\t\t\t:key=\"tab.id\"\n\t\t\t\t:aria-controls=\"`tab-${tab.id}`\"\n\t\t\t\t:aria-selected=\"String(activeTab === tab.id)\"\n\t\t\t\t:button-variant=\"true\"\n\t\t\t\t:checked=\"activeTab === tab.id\"\n\t\t\t\t:wrapper-id=\"`tab-button-${tab.id}`\"\n\t\t\t\t:tabindex=\"activeTab === tab.id ? 0 : -1\"\n\t\t\t\tbutton-variant-grouped=\"horizontal\"\n\t\t\t\tclass=\"app-sidebar-tabs__tab\"\n\t\t\t\t:class=\"{ active: tab.id === activeTab }\"\n\t\t\t\trole=\"tab\"\n\t\t\t\ttype=\"button\"\n\t\t\t\t@update:checked=\"setActive(tab.id)\">\n\t\t\t\t<span class=\"app-sidebar-tabs__tab-caption\">\n\t\t\t\t\t{{ tab.name }}\n\t\t\t\t</span>\n\t\t\t\t<template #icon>\n\t\t\t\t\t<NcVNodes :vnodes=\"tab.renderIcon()\">\n\t\t\t\t\t\t<span class=\"app-sidebar-tabs__tab-icon\" :class=\"tab.icon\" />\n\t\t\t\t\t</NcVNodes>\n\t\t\t\t</template>\n\t\t\t</NcCheckboxRadioSwitch>\n\t\t</div>\n\n\t\t<!-- tabs content -->\n\t\t<div :class=\"{'app-sidebar-tabs__content--multiple': hasMultipleTabs}\"\n\t\t\tclass=\"app-sidebar-tabs__content\">\n\t\t\t<!-- @slot Tabs content - NcAppSidebarTab components or any content if there is no tabs -->\n\t\t\t<slot />\n\t\t</div>\n\t</div>\n</template>\n\n<script>\nimport NcVNodes from '../NcVNodes/index.js'\nimport NcCheckboxRadioSwitch from '../NcCheckboxRadioSwitch/index.js'\n\nexport default {\n\tname: 'NcAppSidebarTabs',\n\n\tcomponents: {\n\t\tNcCheckboxRadioSwitch,\n\t\tNcVNodes,\n\t},\n\n\tprovide() {\n\t\treturn {\n\t\t\tregisterTab: this.registerTab,\n\t\t\tunregisterTab: this.unregisterTab,\n\t\t\t// Getter as an alternative to Vue 2.7 computed(() => this.activeTab)\n\t\t\tgetActiveTab: () => this.activeTab,\n\t\t\t// Used to check whether the tab header is shown so the tabs can reference the tab header for `aria-labelledby` or not\n\t\t\tisTablistShown: () => this.hasMultipleTabs,\n\t\t}\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Id of the tab to activate\n\t\t */\n\t\tactive: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t\t/**\n\t\t * Force the tab navigation to display even if there is only one tab\n\t\t */\n\t\tforceTabs: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t},\n\n\temits: ['update:active'],\n\n\tdata() {\n\t\treturn {\n\t\t\t/**\n\t\t\t * Tab descriptions from the passed NcSidebarTab components' props to build the tab navbar from.\n\t\t\t */\n\t\t\ttabs: [],\n\t\t\t/**\n\t\t\t * Local active (open) tab's ID. It allows to use component without active.sync\n\t\t\t */\n\t\t\tactiveTab: '',\n\t\t}\n\t},\n\n\tcomputed: {\n\t\t/**\n\t\t * Has multiple tabs. If only one tab - its content is shown without navigation\n\t\t *\n\t\t * @return {boolean}\n\t\t */\n\t\thasMultipleTabs() {\n\t\t\treturn this.tabs.length > 1\n\t\t},\n\n\t\tshowForSingleTab() {\n\t\t\treturn this.forceTabs && this.tabs.length === 1\n\t\t},\n\n\t\tcurrentTabIndex() {\n\t\t\treturn this.tabs.findIndex((tab) => tab.id === this.activeTab)\n\t\t},\n\t},\n\n\twatch: {\n\t\tactive(active) {\n\t\t\t// Prevent running it twice\n\t\t\tif (active !== this.activeTab) {\n\t\t\t\tthis.updateActive()\n\t\t\t}\n\t\t},\n\t},\n\n\tmethods: {\n\n\t\t/**\n\t\t * Set the current active tab\n\t\t *\n\t\t * @param {string} id the id of the tab\n\t\t */\n\t\tsetActive(id) {\n\t\t\tthis.activeTab = id\n\t\t\t/**\n\t\t\t * @property {string} active - active tab's id\n\t\t\t */\n\t\t\tthis.$emit('update:active', this.activeTab)\n\t\t},\n\n\t\t/**\n\t\t * Focus the previous tab\n\t\t * and emit to the parent component\n\t\t */\n\t\tfocusPreviousTab() {\n\t\t\tif (this.currentTabIndex > 0) {\n\t\t\t\tthis.setActive(this.tabs[this.currentTabIndex - 1].id)\n\t\t\t}\n\t\t\tthis.focusActiveTab()\n\t\t},\n\n\t\t/**\n\t\t * Focus the next tab\n\t\t * and emit to the parent component\n\t\t */\n\t\tfocusNextTab() {\n\t\t\tif (this.currentTabIndex < this.tabs.length - 1) {\n\t\t\t\tthis.setActive(this.tabs[this.currentTabIndex + 1].id)\n\t\t\t}\n\t\t\tthis.focusActiveTab()\n\t\t},\n\n\t\t/**\n\t\t * Focus the first tab\n\t\t * and emit to the parent component\n\t\t */\n\t\tfocusFirstTab() {\n\t\t\tthis.setActive(this.tabs[0].id)\n\t\t\tthis.focusActiveTab()\n\t\t},\n\n\t\t/**\n\t\t * Focus the last tab\n\t\t * and emit to the parent component\n\t\t */\n\t\tfocusLastTab() {\n\t\t\tthis.setActive(this.tabs[this.tabs.length - 1].id)\n\t\t\tthis.focusActiveTab()\n\t\t},\n\n\t\t/**\n\t\t * Focus the current active tab\n\t\t */\n\t\tfocusActiveTab() {\n\t\t\tthis.$el.querySelector(`#tab-button-${this.activeTab}`).focus()\n\t\t},\n\n\t\t/**\n\t\t * Focus the content on tab\n\t\t * see aria accessibility guidelines\n\t\t */\n\t\tfocusActiveTabContent() {\n\t\t\tthis.$el.querySelector('#tab-' + this.activeTab).focus()\n\t\t},\n\n\t\t/**\n\t\t * Update the current active tab\n\t\t */\n\t\tupdateActive() {\n\t\t\tthis.activeTab = this.active\n\t\t\t&& this.tabs.some(tab => tab.id === this.active)\n\t\t\t\t? this.active\n\t\t\t\t: this.tabs.length > 0\n\t\t\t\t\t? this.tabs[0].id\n\t\t\t\t\t: ''\n\t\t},\n\n\t\t/**\n\t\t * Register child tab in the tabs\n\t\t *\n\t\t * @param {object} tab child tab passed to slot\n\t\t */\n\t\tregisterTab(tab) {\n\t\t\tthis.tabs.push(tab)\n\t\t\tthis.tabs.sort((a, b) => {\n\t\t\t\tif (a.order === b.order) {\n\t\t\t\t\treturn OC.Util.naturalSortCompare(a.name, b.name)\n\t\t\t\t}\n\t\t\t\treturn a.order - b.order\n\t\t\t})\n\t\t\tthis.updateActive()\n\t\t},\n\n\t\t/**\n\t\t * Unregister child tab from the tabs\n\t\t *\n\t\t * @param {string} id tab's id\n\t\t */\n\t\tunregisterTab(id) {\n\t\t\tconst tabIndex = this.tabs.findIndex((tab) => tab.id === id)\n\t\t\tif (tabIndex !== -1) {\n\t\t\t\tthis.tabs.splice(tabIndex, 1)\n\t\t\t}\n\t\t\tif (this.activeTab === id) {\n\t\t\t\tthis.updateActive()\n\t\t\t}\n\t\t},\n\t},\n}\n</script>\n<style lang=\"scss\" scoped>\n.app-sidebar-tabs {\n\tdisplay: flex;\n\tflex-direction: column;\n\tmin-height: 0;\n\tflex: 1 1 100%;\n\n\t&__nav {\n\t\tdisplay: flex;\n\t\tjustify-content: stretch;\n\t\tmargin: 10px 8px 0 8px;\n\t\tborder-bottom: 1px solid var(--color-border);\n\n\t\t// Override checkbox-radio-switch styles so that it looks like tabs\n\t\t& :deep(.checkbox-radio-switch--button-variant) {\n\t\t\tborder: unset !important;\n\t\t\tborder-radius: 0 !important;\n\t\t\t.checkbox-content {\n\t\t\t\tpadding: var(--default-grid-baseline);\n\t\t\t\tborder-radius: var(--default-grid-baseline) var(--default-grid-baseline) 0 0 !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t\tborder-bottom: var(--default-grid-baseline) solid transparent !important;\n\t\t\t\t.checkbox-content__icon--checked > * {\n\t\t\t\t\tcolor: var(--color-main-text) !important;\n\t\t\t\t}\n\t\t\t}\n\t\t\t&.checkbox-radio-switch--checked .checkbox-radio-switch__content{\n\t\t\t\tbackground: transparent !important;\n\t\t\t\tcolor: var(--color-main-text) !important;\n\t\t\t\tborder-bottom: var(--default-grid-baseline) solid var(--color-primary-element) !important;\n\t\t\t}\n\t\t}\n\t}\n\n\t&__tab {\n\t\tflex: 1 1;\n\t\t&.active {\n\t\t\tcolor: var(--color-primary-element);\n\t\t}\n\n\t\t&-caption {\n\t\t\tflex: 0 1 100%;\n\t\t\twidth: 100%;\n\t\t\toverflow: hidden;\n\t\t\twhite-space: nowrap;\n\t\t\ttext-overflow: ellipsis;\n\t\t\ttext-align: center;\n\t\t}\n\n\t\t&-icon {\n\t\t\tdisplay: flex;\n\t\t\talign-items: center;\n\t\t\tjustify-content: center;\n\t\t\tbackground-size: 20px;\n\t\t}\n\n\t\t// Override max-width to use all available space\n\t\t:deep(.checkbox-radio-switch__content) {\n\t\t\tmax-width: unset;\n\t\t}\n\t}\n\n\t&__content {\n\t\tposition: relative;\n\t\tmin-height: 256px;\n\t\theight: 100%;\n\t\t// force the use of the tab component if more than one tab\n\t\t// you can just put raw content if you don't use tabs\n\t\t&--multiple > :not(section) {\n\t\t\tdisplay: none;\n\t\t}\n\t}\n}\n</style>\n","<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : true\"\n :aria-label=\"title\"\n class=\"material-design-icon dock-right-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M20 4H4A2 2 0 0 0 2 6V18A2 2 0 0 0 4 20H20A2 2 0 0 0 22 18V6A2 2 0 0 0 20 4M15 18H4V6H15Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"DockRightIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>","<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : true\"\n :aria-label=\"title\"\n class=\"material-design-icon star-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M12,17.27L18.18,21L16.54,13.97L22,9.24L14.81,8.62L12,2L9.19,8.62L2,9.24L7.45,13.97L5.82,21L12,17.27Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"StarIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>","<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : true\"\n :aria-label=\"title\"\n class=\"material-design-icon star-outline-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M12,15.39L8.24,17.66L9.23,13.38L5.91,10.5L10.29,10.13L12,6.09L13.71,10.13L18.09,10.5L14.77,13.38L15.76,17.66M22,9.24L14.81,8.63L12,2L9.19,8.63L2,9.24L7.45,13.97L5.82,21L12,17.27L18.18,21L16.54,13.97L22,9.24Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"StarOutlineIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>","<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n### General description\n\nThis component provides a way to include the standardised sidebar.\nThe standard properties like name, subname, starred, etc. allow to automatically\ninclude a standard-header like it's used by the files app.\n\nTo conditionally show the sidebar either use `v-if` on the sidebar component,\nor use the `open` property of the component to controll the state.\nUsing `v-show` directly will result in usability issues due to internal focus trap handling.\n\n### Standard usage\n\n```vue\n<template>\n\t<NcAppSidebar\n\t\t:starred=\"starred\"\n\t\tname=\"cat-picture.jpg\"\n\t\tsubname=\"last edited 3 weeks ago\">\n\t\t<NcAppSidebarTab name=\"Search\" id=\"search-tab\">\n\t\t\t<template #icon>\n\t\t\t\t<Magnify :size=\"20\" />\n\t\t\t</template>\n\t\t\tSearch tab content\n\t\t</NcAppSidebarTab>\n\t\t<NcAppSidebarTab name=\"Settings\" id=\"settings-tab\">\n\t\t\t<template #icon>\n\t\t\t\t<Cog :size=\"20\" />\n\t\t\t</template>\n\t\t\tSettings tab content\n\t\t</NcAppSidebarTab>\n\t\t<NcAppSidebarTab name=\"Sharing\" id=\"share-tab\">\n\t\t\t<template #icon>\n\t\t\t\t<ShareVariant :size=\"20\" />\n\t\t\t</template>\n\t\t\tSharing tab content\n\t\t</NcAppSidebarTab>\n\t</NcAppSidebar>\n</template>\n<script>\n\timport Magnify from 'vue-material-design-icons/Magnify.vue'\n\timport Cog from 'vue-material-design-icons/Cog.vue'\n\timport ShareVariant from 'vue-material-design-icons/ShareVariant.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tMagnify,\n\t\t\tCog,\n\t\t\tShareVariant,\n\t\t},\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\tstarred: false,\n\t\t\t}\n\t\t},\n\t}\n</script>\n```\n\n### One tab\n\nSingle tab is rendered without navigation.\n\n```vue\n<template>\n\t<div>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"forceTabs\">Force tab navigation</NcCheckboxRadioSwitch>\n\t\t<NcAppSidebar\n\t\t\tname=\"cat-picture.jpg\"\n\t\t\t:force-tabs=\"forceTabs\"\n\t\t\tsubname=\"last edited 3 weeks ago\">\n\t\t\t<NcAppSidebarTab name=\"Settings\" id=\"settings-tab\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Cog :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tSingle tab content\n\t\t\t</NcAppSidebarTab>\n\t\t</NcAppSidebar>\n\t</div>\n</template>\n<script>\nimport Cog from 'vue-material-design-icons/Cog.vue'\n\nexport default {\n\tcomponents: {\n\t\tCog,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tforceTabs: false,\n\t\t}\n\t},\n}\n</script>\n```\n\n### Dynamic tabs\n\n```vue\n<template>\n\t<div>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"showTabs[0]\">Show search tab</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"showTabs[1]\">Show settings tab</NcCheckboxRadioSwitch>\n\t\t<NcCheckboxRadioSwitch :checked.sync=\"showTabs[2]\">Show sharing tab</NcCheckboxRadioSwitch>\n\t\t<NcAppSidebar\n\t\t\tname=\"cat-picture.jpg\"\n\t\t\tsubname=\"last edited 3 weeks ago\">\n\t\t\t<NcAppSidebarTab v-if=\"showTabs[0]\" name=\"Search\" id=\"search-tab\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Magnify :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tSearch tab content\n\t\t\t</NcAppSidebarTab>\n\t\t\t<NcAppSidebarTab v-if=\"showTabs[1]\" name=\"Settings\" id=\"settings-tab\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Cog :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tSettings\n\t\t\t</NcAppSidebarTab>\n\t\t\t<NcAppSidebarTab v-if=\"showTabs[2]\" name=\"Sharing\" id=\"share-tab\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<ShareVariant :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tSharing tab content\n\t\t\t</NcAppSidebarTab>\n\t\t</NcAppSidebar>\n\t</div>\n</template>\n<script>\nimport Magnify from 'vue-material-design-icons/Magnify.vue'\nimport Cog from 'vue-material-design-icons/Cog.vue'\nimport ShareVariant from 'vue-material-design-icons/ShareVariant.vue'\n\nexport default {\n\tcomponents: {\n\t\tMagnify,\n\t\tCog,\n\t\tShareVariant,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tshowTabs: [true, true, false],\n\t\t}\n\t},\n}\n</script>\n```\n\n### Custom order\n\n```vue\n<template>\n\t<NcAppSidebar\n\t\tname=\"cat-picture.jpg\"\n\t\tsubname=\"last edited 3 weeks ago\">\n\t\t<NcAppSidebarTab name=\"Search\" id=\"search-tab\" :order=\"3\">\n\t\t\t<template #icon>\n\t\t\t\t<Magnify :size=\"20\" />\n\t\t\t</template>\n\t\t\tSearch tab content\n\t\t</NcAppSidebarTab>\n\t\t<NcAppSidebarTab name=\"Settings\" id=\"settings-tab\" :order=\"2\">\n\t\t\t<template #icon>\n\t\t\t\t<Cog :size=\"20\" />\n\t\t\t</template>\n\t\t\tSettings tab content\n\t\t</NcAppSidebarTab>\n\t\t<NcAppSidebarTab name=\"Sharing\" id=\"share-tab\" :order=\"1\">\n\t\t\t<template #icon>\n\t\t\t\t<ShareVariant :size=\"20\" />\n\t\t\t</template>\n\t\t\tSharing tab content\n\t\t</NcAppSidebarTab>\n\t</NcAppSidebar>\n</template>\n<script>\nimport Magnify from 'vue-material-design-icons/Magnify.vue'\nimport Cog from 'vue-material-design-icons/Cog.vue'\nimport ShareVariant from 'vue-material-design-icons/ShareVariant.vue'\n\nexport default {\n\tcomponents: {\n\t\tMagnify,\n\t\tCog,\n\t\tShareVariant,\n\t},\n}\n</script>\n```\n\n### Activating tab programmatically\n\n```vue\n<template>\n\t<div>\n\t\t<NcSelect v-model=\"active\" :options=\"['search-tab', 'settings-tab', 'share-tab']\" />\n\t\t<NcAppSidebar\n\t\t\tname=\"cat-picture.jpg\"\n\t\t\tsubname=\"last edited 3 weeks ago\"\n\t\t\t:active.sync=\"active\">\n\t\t\t<NcAppSidebarTab name=\"Search\" id=\"search-tab\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Magnify :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tSearch tab content\n\t\t\t</NcAppSidebarTab>\n\t\t\t<NcAppSidebarTab name=\"Settings\" id=\"settings-tab\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Cog :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tSettings\n\t\t\t</NcAppSidebarTab>\n\t\t\t<NcAppSidebarTab name=\"Sharing\" id=\"share-tab\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<ShareVariant :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tSharing tab content\n\t\t\t</NcAppSidebarTab>\n\t\t</NcAppSidebar>\n\t</div>\n</template>\n<script>\nimport Magnify from 'vue-material-design-icons/Magnify.vue'\nimport Cog from 'vue-material-design-icons/Cog.vue'\nimport ShareVariant from 'vue-material-design-icons/ShareVariant.vue'\n\nexport default {\n\tcomponents: {\n\t\tMagnify,\n\t\tCog,\n\t\tShareVariant,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tactive: 'search-tab',\n\t\t}\n\t},\n}\n</script>\n```\n\n### Editable name\n\n```vue\n<template>\n\t<NcAppSidebar\n\t\t:name.sync=\"name\"\n\t\t:name-editable=\"true\"\n\t\tname-placeholder=\"Filename\"\n\t\tsubname=\"last edited 3 weeks ago\">\n\t\t<!-- Insert your slots and tabs here -->\n\t</NcAppSidebar>\n</template>\n<script>\n\texport default {\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\tname: 'cat-picture.jpg',\n\t\t\t}\n\t\t},\n\t}\n</script>\n```\n\n### Editable name after click with custom tertiary action\n\n```vue\n<template>\n\t<NcAppSidebar\n\t\t:name=\"name\"\n\t\t:name-editable.sync=\"nameEditable\"\n\t\t:name-placeholder=\"namePlaceholder\"\n\t\t:subname=\"subname\"\n\t\t@update:name=\"nameUpdate\">\n\t\t<template #tertiary-actions>\n\t\t\t<form>\n\t\t\t\t<input type=\"checkbox\" @click=\"toggledCheckbox\"/>\n\t\t\t</form>\n\t\t</template>\n\t</NcAppSidebar>\n</template>\n<script>\n\texport default {\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\tname: 'cat-picture.jpg',\n\t\t\t\tnamePlaceholder: 'Filename',\n\t\t\t\tsubname: 'last edited 3 weeks ago',\n\t\t\t\tnameEditable: false\n\t\t\t}\n\t\t},\n\t\tmethods: {\n\t\t\tnameUpdate(e) {\n\t\t\t\tthis.name = e\n\t\t\t},\n\t\t\ttoggledCheckbox() {\n\t\t\t\talert('toggle')\n\t\t\t}\n\t\t}\n\t}\n</script>\n```\n\n### Custom subname\n\nInstead of using the `subname` prop you can use the same called slot. This is handy if you need to add accessible information.\nLike in the following example where the goal is to show a star icon to mark the file a favorite.\nSimplying adding `★` would not work as screen readers might not or wrongly announce the icon meaning this information is lost.\n\nA working alternative would be using an icon together with an `aria-label`:\n\n```vue\n\t<template>\n\t\t<NcAppSidebar name=\"cat-picture.jpg\">\n\t\t\t<template #subname>\n\t\t\t\t<NcIconSvgWrapper inline :path=\"mdiStar\" name=\"Favorite\" />\n\t\t\t\t123 KiB, a month ago\n\t\t\t</template>\n\t\t</NcAppSidebar>\n\t</template>\n\t<script>\n\timport { mdiStar } from '@mdi/js'\n\n\texport default {\n\t\tsetup() {\n\t\t\treturn {\n\t\t\t\tmdiStar,\n\t\t\t}\n\t\t}\n\t}\n\t</script>\n```\n\n### Empty sidebar for e.g. empty content component.\n\n```vue\n\t<template>\n\t\t<NcAppSidebar\n\t\t\tname=\"cat-picture.jpg\"\n\t\t\t:empty=\"true\">\n\t\t\t<NcEmptyContent name=\"Content not found.\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Magnify :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t</NcEmptyContent>\n\t\t</NcAppSidebar>\n\t</template>\n\t<script>\n\timport Magnify from 'vue-material-design-icons/Magnify.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tMagnify,\n\t\t},\n\t}\n\t</script>\n```\n\n### Conditionally show the sidebar with `open`\n\nIf the sidebar should be shown conditionally, you can use `open` prop to define sidebar visibility.\nIt automatically shows a toggle button to open the sidebar if it is closed.\n\nYou can also use `--app-sidebar-offset` CSS variable to preserve space\nfor the toggle button, for example, in top bar of `NcAppContent`.\n\nThe built-in toggle button can be removed with `no-toggle` prop.\n\nNote: the built-in toggle button is only available then NcAppSidebar is used in NcContent.\n\n```vue\n<template>\n\t<!-- This is in most cases NcContent -->\n\t<NcContent app-name=\"styleguidist\" class=\"content-styleguidist\">\n\t\t<NcAppContent>\n\t\t\t<div class=\"top-bar\">\n\t\t\t\t<NcButton type=\"primary\">Start a call</NcButton>\n\t\t\t</div>\n\t\t</NcAppContent>\n\t\t<!-- The sidebar -->\n\t\t<NcAppSidebar\n\t\t\t:open.sync=\"showSidebar\"\n\t\t\tname=\"cat-picture.jpg\"\n\t\t\tsubname=\"last edited 3 weeks ago\">\n\t\t\t<NcAppSidebarTab name=\"Settings\" id=\"settings-tab\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Cog :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tSingle tab content\n\t\t\t</NcAppSidebarTab>\n\t\t</NcAppSidebar>\n\t</NcContent>\n</template>\n\n<script>\nimport Cog from 'vue-material-design-icons/Cog'\n\nexport default {\n\tcomponents: {\n\t\tCog,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tshowSidebar: true,\n\t\t}\n\t},\n}\n</script>\n<style scoped>\n/* This styles just mock NcContent and NcAppContent */\n.content-styleguidist {\n\tposition: relative !important;\n\t/* Just to prevent jumping when the sidebar is hidden */\n\tmin-height: 360px;\n}\n\n.main-content {\n\tposition: absolute;\n\theight: 100%;\n\twidth: 100%;\n}\n\n/* Fix styles on this style guide page */\n@media only screen and (max-width: 512px) {\n\t:deep(aside) {\n\t\twidth: calc(100vw - 64px) !important;\n\t}\n}\n\n.top-bar {\n\tdisplay: flex;\n\tjustify-content: flex-end;\n\t/* preserve space for toggle button */\n\tpadding-inline-end: var(--app-sidebar-offset);\n\t/* same as on toggle button, but doesn't have to be the same */\n\tmargin: var(--app-sidebar-padding);\n}\n</style>\n```\n\n### Conditionally show the sidebar programmatically with `v-if`\n\nIf the sidebar should be shown conditionally without any explicit toggle button, you can use `v-if`.\n\n**Note about performance**: using `v-if` might result in bad performance and loosing sidebar content state.\n\n**Note about `v-show`**: using `v-show` to hide sidebar will result in usability issues due to active focus trap on mobile.\n\n```vue\n<template>\n\t<!-- This is in most cases NcContent -->\n\t<NcContent app-name=\"styleguidist\" class=\"content-styleguidist\">\n\t\t<NcAppContent>\n\t\t\t<div class=\"top-bar\">\n\t\t\t\t<NcButton @click.prevent=\"showSidebar = true\">\n\t\t\t\t\tToggle sidebar\n\t\t\t\t</NcButton>\n\t\t\t</div>\n\t\t</NcAppContent>\n\t\t<!-- The sidebar -->\n\t\t<NcAppSidebar\n\t\t\tv-if=\"showSidebar\"\n\t\t\tname=\"cat-picture.jpg\"\n\t\t\tsubname=\"last edited 3 weeks ago\"\n\t\t\t@close=\"showSidebar = false\">\n\t\t\t<NcAppSidebarTab name=\"Settings\" id=\"settings-tab\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Cog :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tSingle tab content\n\t\t\t</NcAppSidebarTab>\n\t\t</NcAppSidebar>\n\t</NcContent>\n</template>\n\n<script>\nimport Cog from 'vue-material-design-icons/Cog'\n\nexport default {\n\tcomponents: {\n\t\tCog,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tshowSidebar: true,\n\t\t}\n\t},\n}\n</script>\n<style scoped>\n/* This styles just mock NcContent and NcAppContent */\n.content-styleguidist {\n\tposition: relative !important;\n\t/* Just to prevent jumping when the sidebar is hidden */\n\tmin-height: 360px;\n}\n\n.main-content {\n\tposition: absolute;\n\theight: 100%;\n\twidth: 100%;\n}\n\n/* Fix styles on this style guide page */\n@media only screen and (max-width: 512px) {\n\t:deep(aside) {\n\t\twidth: calc(100vw - 64px) !important;\n\t}\n}\n\n.top-bar {\n\tdisplay: flex;\n\tjustify-content: flex-end;\n\t/* preserve space for toggle button */\n\tpadding-inline-end: var(--app-sidebar-offset);\n\t/* same as on toggle button, but doesn't have to be the same */\n\tmargin: var(--app-sidebar-padding);\n}\n</style>\n```\n</docs>\n\n<template>\n\t<transition appear\n\t\tname=\"slide-right\"\n\t\t@before-enter=\"onBeforeEnter\"\n\t\t@after-enter=\"onAfterEnter\"\n\t\t@before-leave=\"onBeforeLeave\"\n\t\t@after-leave=\"onAfterLeave\">\n\t\t<aside v-show=\"open\"\n\t\t\tid=\"app-sidebar-vue\"\n\t\t\tref=\"sidebar\"\n\t\t\tclass=\"app-sidebar\"\n\t\t\t:aria-labelledby=\"`app-sidebar-vue-${uid}__header`\"\n\t\t\t@keydown.esc=\"onKeydownEsc\">\n\t\t\t<!--\n\t\t\t\tWe cannot render toggle button inside sidebar (aside#app-sidebar-vue), because it is hidden then the toggle is needed.\n\t\t\t\tBut we also need transition with the sidebar to be the root of this component to use it as a single UI element, allowing to use `v-show`.\n\t\t\t\tSo we cannot render the toggle button directly in this component.\n\t\t\t\tAs a simple solution - render it in the content to keep correct position.\n\t\t\t-->\n\t\t\t<Teleport v-if=\"ncContentSelector && !open && !noToggle\" :selector=\"ncContentSelector\">\n\t\t\t\t<NcButton :aria-label=\"t('Open sidebar')\"\n\t\t\t\t\tclass=\"app-sidebar__toggle\"\n\t\t\t\t\t:class=\"toggleClasses\"\n\t\t\t\t\ttype=\"tertiary\"\n\t\t\t\t\tv-bind=\"toggleAttrs\"\n\t\t\t\t\t@click=\"$emit('update:open', true)\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<!-- @slot Custom icon for the toggle button, defaults to the dock-right icon from MDI -->\n\t\t\t\t\t\t<slot name=\"toggle-icon\">\n\t\t\t\t\t\t\t<IconDockRight :size=\"20\" />\n\t\t\t\t\t\t</slot>\n\t\t\t\t\t</template>\n\t\t\t\t</NcButton>\n\t\t\t</Teleport>\n\n\t\t\t<header :class=\"{\n\t\t\t\t\t'app-sidebar-header--with-figure': hasFigure,\n\t\t\t\t\t'app-sidebar-header--compact': compact,\n\t\t\t\t}\"\n\t\t\t\tclass=\"app-sidebar-header\">\n\t\t\t\t<!-- container for figure and description, allows easy switching to compact mode -->\n\t\t\t\t<div class=\"app-sidebar-header__info\">\n\t\t\t\t\t<!-- sidebar header illustration/figure -->\n\t\t\t\t\t<div v-if=\"hasFigure && !empty\"\n\t\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t\t'app-sidebar-header__figure--with-action': hasFigureClickListener\n\t\t\t\t\t\t}\"\n\t\t\t\t\t\tclass=\"app-sidebar-header__figure\"\n\t\t\t\t\t\t:style=\"{\n\t\t\t\t\t\t\tbackgroundImage: `url(${background})`\n\t\t\t\t\t\t}\"\n\t\t\t\t\t\ttabindex=\"0\"\n\t\t\t\t\t\t@click=\"onFigureClick\"\n\t\t\t\t\t\t@keydown.enter=\"onFigureClick\">\n\t\t\t\t\t\t<slot class=\"app-sidebar-header__background\" name=\"header\" />\n\t\t\t\t\t</div>\n\n\t\t\t\t\t<!-- sidebar details -->\n\t\t\t\t\t<div v-if=\"!empty\"\n\t\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t\t'app-sidebar-header__desc--with-tertiary-action': canStar || $slots['tertiary-actions'],\n\t\t\t\t\t\t\t'app-sidebar-header__desc--editable': nameEditable && !subname,\n\t\t\t\t\t\t\t'app-sidebar-header__desc--with-subname--editable': nameEditable && subname,\n\t\t\t\t\t\t\t'app-sidebar-header__desc--without-actions': !$slots['secondary-actions'],\n\t\t\t\t\t\t}\"\n\t\t\t\t\t\tclass=\"app-sidebar-header__desc\">\n\t\t\t\t\t\t<!-- favourite icon -->\n\t\t\t\t\t\t<div v-if=\"canStar || $slots['tertiary-actions']\" class=\"app-sidebar-header__tertiary-actions\">\n\t\t\t\t\t\t\t<slot name=\"tertiary-actions\">\n\t\t\t\t\t\t\t\t<NcButton v-if=\"canStar\"\n\t\t\t\t\t\t\t\t\t:aria-label=\"favoriteTranslated\"\n\t\t\t\t\t\t\t\t\t:pressed=\"isStarred\"\n\t\t\t\t\t\t\t\t\tclass=\"app-sidebar-header__star\"\n\t\t\t\t\t\t\t\t\ttype=\"secondary\"\n\t\t\t\t\t\t\t\t\t@click.prevent=\"toggleStarred\">\n\t\t\t\t\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t\t\t\t\t<NcLoadingIcon v-if=\"starLoading\" />\n\t\t\t\t\t\t\t\t\t\t<Star v-else-if=\"isStarred\" :size=\"20\" />\n\t\t\t\t\t\t\t\t\t\t<StarOutline v-else :size=\"20\" />\n\t\t\t\t\t\t\t\t\t</template>\n\t\t\t\t\t\t\t\t</NcButton>\n\t\t\t\t\t\t\t</slot>\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t<!-- name -->\n\t\t\t\t\t\t<div class=\"app-sidebar-header__name-container\">\n\t\t\t\t\t\t\t<div class=\"app-sidebar-header__mainname-container\">\n\t\t\t\t\t\t\t\t<!-- main name -->\n\t\t\t\t\t\t\t\t<h2 v-show=\"!nameEditable\"\n\t\t\t\t\t\t\t\t\t:id=\"`app-sidebar-vue-${uid}__header`\"\n\t\t\t\t\t\t\t\t\tref=\"header\"\n\t\t\t\t\t\t\t\t\tv-linkify=\"{text: name, linkify: linkifyName}\"\n\t\t\t\t\t\t\t\t\t:aria-label=\"title\"\n\t\t\t\t\t\t\t\t\t:title=\"title\"\n\t\t\t\t\t\t\t\t\tclass=\"app-sidebar-header__mainname\"\n\t\t\t\t\t\t\t\t\t:tabindex=\"nameEditable ? 0 : -1\"\n\t\t\t\t\t\t\t\t\t@click.self=\"editName\">\n\t\t\t\t\t\t\t\t\t{{ name }}\n\t\t\t\t\t\t\t\t</h2>\n\t\t\t\t\t\t\t\t<template v-if=\"nameEditable\">\n\t\t\t\t\t\t\t\t\t<form v-click-outside=\"() => onSubmitName()\"\n\t\t\t\t\t\t\t\t\t\tclass=\"app-sidebar-header__mainname-form\"\n\t\t\t\t\t\t\t\t\t\t@submit.prevent=\"onSubmitName\">\n\t\t\t\t\t\t\t\t\t\t<input ref=\"nameInput\"\n\t\t\t\t\t\t\t\t\t\t\tv-focus\n\t\t\t\t\t\t\t\t\t\t\tclass=\"app-sidebar-header__mainname-input\"\n\t\t\t\t\t\t\t\t\t\t\ttype=\"text\"\n\t\t\t\t\t\t\t\t\t\t\t:placeholder=\"namePlaceholder\"\n\t\t\t\t\t\t\t\t\t\t\t:value=\"name\"\n\t\t\t\t\t\t\t\t\t\t\t@keydown.esc.stop=\"onDismissEditing\"\n\t\t\t\t\t\t\t\t\t\t\t@input=\"onNameInput\">\n\t\t\t\t\t\t\t\t\t\t<NcButton type=\"tertiary-no-background\"\n\t\t\t\t\t\t\t\t\t\t\t:aria-label=\"changeNameTranslated\"\n\t\t\t\t\t\t\t\t\t\t\tnative-type=\"submit\">\n\t\t\t\t\t\t\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t\t\t\t\t\t\t<ArrowRight :size=\"20\" />\n\t\t\t\t\t\t\t\t\t\t\t</template>\n\t\t\t\t\t\t\t\t\t\t</NcButton>\n\t\t\t\t\t\t\t\t\t</form>\n\t\t\t\t\t\t\t\t</template>\n\t\t\t\t\t\t\t\t<!-- header main menu -->\n\t\t\t\t\t\t\t\t<NcActions v-if=\"$slots['secondary-actions']\"\n\t\t\t\t\t\t\t\t\tclass=\"app-sidebar-header__menu\"\n\t\t\t\t\t\t\t\t\t:force-menu=\"forceMenu\">\n\t\t\t\t\t\t\t\t\t<slot name=\"secondary-actions\" />\n\t\t\t\t\t\t\t\t</NcActions>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t<!-- secondary name -->\n\t\t\t\t\t\t\t<p v-if=\"subname.trim() !== '' || $slots['subname']\"\n\t\t\t\t\t\t\t\t:title=\"subtitle || undefined\"\n\t\t\t\t\t\t\t\tclass=\"app-sidebar-header__subname\">\n\t\t\t\t\t\t\t\t<!-- @slot Alternative to the `subname` prop can be used for more complex conent. It will be rendered within a `p` tag. -->\n\t\t\t\t\t\t\t\t<slot name=\"subname\">\n\t\t\t\t\t\t\t\t\t{{ subname }}\n\t\t\t\t\t\t\t\t</slot>\n\t\t\t\t\t\t\t</p>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\n\t\t\t\t<NcButton ref=\"closeButton\"\n\t\t\t\t\t:title=\"closeTranslated\"\n\t\t\t\t\t:aria-label=\"closeTranslated\"\n\t\t\t\t\ttype=\"tertiary\"\n\t\t\t\t\tclass=\"app-sidebar__close\"\n\t\t\t\t\t@click.prevent=\"closeSidebar\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<Close :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t</NcButton>\n\n\t\t\t\t<div v-if=\"$slots['description'] && !empty\" class=\"app-sidebar-header__description\">\n\t\t\t\t\t<slot name=\"description\" />\n\t\t\t\t</div>\n\t\t\t</header>\n\n\t\t\t<NcAppSidebarTabs v-show=\"!loading\"\n\t\t\t\tref=\"tabs\"\n\t\t\t\t:active=\"active\"\n\t\t\t\t:force-tabs=\"forceTabs\"\n\t\t\t\t@update:active=\"onUpdateActive\">\n\t\t\t\t<slot />\n\t\t\t</NcAppSidebarTabs>\n\n\t\t\t<NcEmptyContent v-if=\"loading\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<NcLoadingIcon :size=\"64\" />\n\t\t\t\t</template>\n\t\t\t</NcEmptyContent>\n\t\t</aside>\n\t</transition>\n</template>\n\n<script>\n// TODO: This is built-in for vue3 just drop the import\nimport { Portal as Teleport } from '@linusborg/vue-simple-portal'\n\nimport NcAppSidebarTabs from './NcAppSidebarTabs.vue'\nimport NcActions from '../NcActions/index.js'\nimport NcLoadingIcon from '../NcLoadingIcon/index.js'\nimport NcButton from '../NcButton/index.js'\nimport NcEmptyContent from '../NcEmptyContent/index.js'\nimport Focus from '../../directives/Focus/index.js'\nimport Linkify from '../../directives/Linkify/index.js'\nimport { useIsSmallMobile } from '../../composables/useIsMobile/index.js'\nimport GenRandomId from '../../utils/GenRandomId.js'\nimport { getTrapStack } from '../../utils/focusTrap.js'\nimport { t } from '../../l10n.js'\n\nimport ArrowRight from 'vue-material-design-icons/ArrowRight.vue'\nimport Close from 'vue-material-design-icons/Close.vue'\nimport IconDockRight from 'vue-material-design-icons/DockRight.vue'\nimport Star from 'vue-material-design-icons/Star.vue'\nimport StarOutline from 'vue-material-design-icons/StarOutline.vue'\n\nimport { vOnClickOutside as ClickOutside } from '@vueuse/components'\nimport { createFocusTrap } from 'focus-trap'\n\nexport default {\n\tname: 'NcAppSidebar',\n\n\tcomponents: {\n\t\tTeleport,\n\t\tNcActions,\n\t\tNcAppSidebarTabs,\n\t\tArrowRight,\n\t\tIconDockRight,\n\t\tNcButton,\n\t\tNcLoadingIcon,\n\t\tNcEmptyContent,\n\t\tClose,\n\t\tStar,\n\t\tStarOutline,\n\t},\n\n\tdirectives: {\n\t\tfocus: Focus,\n\t\tlinkify: Linkify,\n\t\tClickOutside,\n\t},\n\n\tinject: {\n\t\tncContentSelector: {\n\t\t\tfrom: 'NcContent:selector',\n\t\t\tdefault: undefined,\n\t\t},\n\t},\n\n\tprops: {\n\t\tactive: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t\tname: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * Allow to edit the sidebar name.\n\t\t */\n\t\tnameEditable: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t\tnamePlaceholder: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t\tsubname: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t\t/**\n\t\t * Title to display for the subname.\n\t\t */\n\t\tsubtitle: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Url to the top header background image\n\t\t * Applied with css\n\t\t */\n\t\tbackground: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Enable the favourite icon if not null\n\t\t * See fired events\n\t\t */\n\t\tstarred: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: null,\n\t\t},\n\t\t/**\n\t\t * Show loading spinner instead of the star icon\n\t\t */\n\t\tstarLoading: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t\t/**\n\t\t * Show loading spinner instead of tabs\n\t\t */\n\t\tloading: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Display the sidebar in compact mode\n\t\t */\n\t\tcompact: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Only display close button and default slot content.\n\t\t * Don't display other header content and primary and secondary actions.\n\t\t * Useful when showing the EmptyContent component as content.\n\t\t */\n\t\tempty: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Force the actions to display in a three dot menu\n\t\t */\n\t\tforceMenu: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t\t/**\n\t\t * Force the tab navigation to display even if there is only one tab\n\t\t */\n\t\tforceTabs: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t\t/**\n\t\t * Linkify the name\n\t\t */\n\t\tlinkifyName: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t\t/**\n\t\t * Title to display for the name.\n\t\t * Can be set to the same text in case it's too long.\n\t\t */\n\t\ttitle: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Allow to conditionally show the sidebar\n\t\t * You can also use `v-if` on the sidebar, but using the open prop allow to keep\n\t\t * the sidebar inside the DOM for performance if it is opened and closed multiple times.\n\t\t *\n\t\t * When using the `open` property to close the sidebar a built-in toggle button will be shown to reopen it,\n\t\t * similar to the app navigation. You can remove this button with the `no-toggle` prop.\n\t\t */\n\t\topen: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * Custom classes to assign to the sidebar toggle button.\n\t\t * If needed this can be used to assign styles to the button using `:deep()` selector.\n\t\t */\n\t\ttoggleClasses: {\n\t\t\ttype: [String, Array, Object],\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Custom attrs to assign to the sidebar toggle button.\n\t\t */\n\t\ttoggleAttrs: {\n\t\t\ttype: Object,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Do not add the built-in toggle button with `open` prop.\n\t\t */\n\t\tnoToggle: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t},\n\n\temits: [\n\t\t'close',\n\t\t'closing',\n\t\t'closed',\n\t\t'opening',\n\t\t'opened',\n\t\t'figure-click',\n\t\t'update:active',\n\t\t'update:name',\n\t\t'update:nameEditable',\n\t\t'update:open',\n\t\t'update:starred',\n\t\t'submit-name',\n\t\t'dismiss-editing',\n\t],\n\n\tsetup() {\n\t\treturn {\n\t\t\tuid: GenRandomId(),\n\t\t\tisMobile: useIsSmallMobile(),\n\t\t}\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tchangeNameTranslated: t('Change name'),\n\t\t\tcloseTranslated: t('Close sidebar'),\n\t\t\tfavoriteTranslated: t('Favorite'),\n\t\t\tisStarred: this.starred,\n\t\t\tfocusTrap: null,\n\t\t\telementToReturnFocus: null,\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tcanStar() {\n\t\t\treturn this.isStarred !== null\n\t\t},\n\t\thasFigure() {\n\t\t\treturn this.$slots.header || this.background\n\t\t},\n\t\thasFigureClickListener() {\n\t\t\treturn this.$listeners['figure-click']\n\t\t},\n\t},\n\n\twatch: {\n\t\tstarred() {\n\t\t\tthis.isStarred = this.starred\n\t\t},\n\n\t\tisMobile() {\n\t\t\tthis.toggleFocusTrap()\n\t\t},\n\n\t\topen() {\n\t\t\tthis.toggleFocusTrap()\n\n\t\t\tthis.checkToggleButtonContainerAvailability()\n\t\t},\n\t},\n\n\tcreated() {\n\t\tthis.preserveElementToReturnFocus()\n\n\t\tthis.checkToggleButtonContainerAvailability()\n\t},\n\n\tmounted() {\n\t\t// Focus sidebar on open only if it was opened by a user interaction\n\t\tif (this.elementToReturnFocus) {\n\t\t\tthis.focus()\n\t\t}\n\n\t\tthis.toggleFocusTrap()\n\t},\n\n\tbeforeDestroy() {\n\t\t// Make sure that the 'closed' event is dispatched even if this element is destroyed before the 'after-leave' event is received.\n\t\tthis.$emit('closed')\n\t\tthis.focusTrap?.deactivate()\n\t},\n\n\tmethods: {\n\t\tt,\n\n\t\tpreserveElementToReturnFocus() {\n\t\t\t// Save the element that had focus before the sidebar was opened to return back on close\n\t\t\tif (document.activeElement && document.activeElement !== document.body) {\n\t\t\t\tthis.elementToReturnFocus = document.activeElement\n\n\t\t\t\t// Special case for menus (NcActions)\n\t\t\t\t// If a sidebar was opened from a menu item, we want to return focus to the menu trigger instead of the item\n\t\t\t\tif (this.elementToReturnFocus.getAttribute('role') === 'menuitem') {\n\t\t\t\t\tconst menu = this.elementToReturnFocus.closest('[role=\"menu\"]')\n\t\t\t\t\tif (menu) {\n\t\t\t\t\t\tconst menuTrigger = document.querySelector(`[aria-controls=\"${menu.id}\"]`)\n\t\t\t\t\t\tthis.elementToReturnFocus = menuTrigger\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\tinitFocusTrap() {\n\t\t\tif (this.focusTrap) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tthis.focusTrap = createFocusTrap([\n\t\t\t\t// The sidebar itself\n\t\t\t\tthis.$refs.sidebar,\n\t\t\t\t// Nextcloud Server header navigarion\n\t\t\t\tdocument.querySelector('#header'),\n\t\t\t], {\n\t\t\t\tallowOutsideClick: true,\n\t\t\t\tfallbackFocus: this.$refs.closeButton,\n\t\t\t\ttrapStack: getTrapStack(),\n\t\t\t\tescapeDeactivates: false,\n\t\t\t})\n\t\t},\n\n\t\t/**\n\t\t * Activate focus trap if it is currently needed, otherwise deactivate\n\t\t */\n\t\ttoggleFocusTrap() {\n\t\t\tif (this.open && this.isMobile) {\n\t\t\t\tthis.initFocusTrap()\n\t\t\t\tthis.focusTrap.activate()\n\t\t\t} else {\n\t\t\t\tthis.focusTrap?.deactivate()\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Close the sidebar on pressing the escape key on mobile\n\t\t *\n\t\t * @param {KeyboardEvent} event key down event\n\t\t */\n\t\tonKeydownEsc(event) {\n\t\t\tif (this.isMobile) {\n\t\t\t\tevent.stopPropagation()\n\t\t\t\tthis.closeSidebar()\n\t\t\t}\n\t\t},\n\n\t\tonBeforeEnter(element) {\n\t\t\t/**\n\t\t\t * The sidebar is opening and the transition is in progress\n\t\t\t *\n\t\t\t * @type {HTMLElement}\n\t\t\t * @deprecated\n\t\t\t */\n\t\t\tthis.$emit('opening', element)\n\t\t},\n\t\tonAfterEnter(element) {\n\t\t\t/**\n\t\t\t * The sidebar is opened and the transition is complete\n\t\t\t *\n\t\t\t * @type {HTMLElement}\n\t\t\t */\n\t\t\tthis.$emit('opened', element)\n\t\t},\n\t\tonBeforeLeave(element) {\n\t\t\t/**\n\t\t\t * The sidebar is closing and the transition is in progress\n\t\t\t *\n\t\t\t * @type {HTMLElement}\n\t\t\t * @deprecated\n\t\t\t */\n\t\t\tthis.$emit('closing', element)\n\t\t},\n\t\tonAfterLeave(element) {\n\t\t\t/**\n\t\t\t * The sidebar is closed and the transition is complete\n\t\t\t *\n\t\t\t * @type {HTMLElement}\n\t\t\t */\n\t\t\tthis.$emit('closed', element)\n\n\t\t\t// Return focus to the element that had focus before the sidebar was opened\n\t\t\tthis.elementToReturnFocus?.focus({ focusVisible: true })\n\t\t\tthis.elementToReturnFocus = null\n\t\t},\n\n\t\t/**\n\t\t * Used to tell parent component the user asked to close the sidebar\n\t\t *\n\t\t * @param {Event} e close icon click event\n\t\t */\n\t\tcloseSidebar(e) {\n\t\t\t/**\n\t\t\t * The user clicked to closed the sidebar\n\t\t\t *\n\t\t\t * @type {Event}\n\t\t\t */\n\t\t\tthis.$emit('close', e)\n\t\t\t/**\n\t\t\t * Current open state emitted after the transitions are finished\n\t\t\t * @type {boolean}\n\t\t\t */\n\t\t\tthis.$emit('update:open', false)\n\t\t},\n\n\t\t/**\n\t\t * Emit figure click event to parent component\n\t\t *\n\t\t * @param {Event} e click event\n\t\t */\n\t\tonFigureClick(e) {\n\t\t\t/**\n\t\t\t * The figure/background header has been clicked\n\t\t\t *\n\t\t\t * @type {Event}\n\t\t\t */\n\t\t\tthis.$emit('figure-click', e)\n\t\t},\n\n\t\t/**\n\t\t * Toggle the favourite state\n\t\t * and emit to the parent component\n\t\t */\n\t\ttoggleStarred() {\n\t\t\tthis.isStarred = !this.isStarred\n\t\t\t/**\n\t\t\t * Emitted when the starred value changes\n\t\t\t *\n\t\t\t * @type {boolean}\n\t\t\t */\n\t\t\tthis.$emit('update:starred', this.isStarred)\n\t\t},\n\n\t\teditName() {\n\t\t\t/**\n\t\t\t * Emitted when the nameEditable value changes\n\t\t\t *\n\t\t\t * @type {boolean}\n\t\t\t */\n\t\t\tthis.$emit('update:nameEditable', true)\n\t\t\t// Focus the name input\n\t\t\tif (this.nameEditable) {\n\t\t\t\tthis.$nextTick(\n\t\t\t\t\t() => this.$refs.nameInput.focus(),\n\t\t\t\t)\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Focus the sidebar\n\t\t * @public\n\t\t */\n\t\tfocus() {\n\t\t\tthis.$refs.header.focus()\n\t\t},\n\n\t\t/**\n\t\t * Focus the active tab\n\t\t * @public\n\t\t */\n\t\tfocusActiveTabContent() {\n\t\t\t// If a tab is focused then probably a new trigger element moved the focus to the sidebar\n\t\t\tthis.preserveElementToReturnFocus()\n\n\t\t\tthis.$refs.tabs.focusActiveTabContent()\n\t\t},\n\n\t\t/**\n\t\t * Check if the toggle button container is available\n\t\t */\n\t\tcheckToggleButtonContainerAvailability() {\n\t\t\t// Toggle button must be rendered, but there is no element to teleport it to\n\t\t\tif (this.open === false && !this.noToggle && !this.ncContentSelector) {\n\t\t\t\tconsole.warn(\n\t\t\t\t\t'[NcAppSidebar] It looks like you want to use NcAppSidebar with the built-in toggle button. '\n\t\t\t\t\t+ 'This feature is only available when NcAppSidebar is used in NcContent.',\n\t\t\t\t)\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Emit name change event to parent component\n\t\t *\n\t\t * @param {Event} event input event\n\t\t */\n\t\tonNameInput(event) {\n\t\t\t/**\n\t\t\t * Emitted when the name value changes\n\t\t\t *\n\t\t\t * @type {string|Date}\n\t\t\t */\n\t\t\tthis.$emit('update:name', event.target.value)\n\t\t},\n\n\t\t/**\n\t\t * Emit when the name form edit confirm button is pressed in order\n\t\t * to change the name.\n\t\t *\n\t\t * @param {Event} event submit event\n\t\t */\n\t\tonSubmitName(event) {\n\t\t\t// Disable editing\n\t\t\tthis.$emit('update:nameEditable', false)\n\t\t\t/**\n\t\t\t * Emitted when the name edit input has been submitted\n\t\t\t *\n\t\t\t * @type {Event}\n\t\t\t */\n\t\t\tthis.$emit('submit-name', event)\n\t\t},\n\t\tonDismissEditing() {\n\t\t\t// Disable editing\n\t\t\tthis.$emit('update:nameEditable', false)\n\t\t\t/**\n\t\t\t * Emitted when the name edit has been cancelled\n\t\t\t *\n\t\t\t * @type {Event}\n\t\t\t */\n\t\t\tthis.$emit('dismiss-editing')\n\t\t},\n\t\tonUpdateActive(activeTab) {\n\t\t\t/**\n\t\t\t * The active tab changed\n\t\t\t *\n\t\t\t * @type {string}\n\t\t\t */\n\t\t\tthis.$emit('update:active', activeTab)\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\">\n// Allows to use transition over a custom CSS property (CSS Variable)\n// Ignored on old browsers resulting in slightly noticeable jump\n@property --app-sidebar-offset {\n syntax: '<length>';\n initial-value: 0;\n inherits: true;\n}\n\n.content {\n\t// A padding between the toggle button and the page border\n\t--app-sidebar-padding: #{$app-navigation-padding};\n\t// A padding between the toggle button and the page border\n\t--app-sidebar-offset: 0;\n\t// Explicitly disable transition by default to enable it only when sidebar animation is active\n\t// !important to override styles from an older version, because it's global non-scoped styles\n\ttransition: --app-sidebar-offset 0ms !important;\n}\n\n// When AppSidebar is animation is active - also apply transition for the toggle button offset\n.content:has(.app-sidebar.slide-right-enter-active),\n.content:has(.app-sidebar.slide-right-leave-active) {\n\ttransition: --app-sidebar-offset var(--animation-quick);\n}\n\n.content:has(.app-sidebar__toggle) {\n\t--app-sidebar-offset: calc(var(--app-sidebar-padding) + var(--default-clickable-area));\n}\n</style>\n\n<style lang=\"scss\" scoped>\n$desc-input-padding: 7px;\n\n// name and subname\n$desc-name-height: 30px;\n$desc-subname-height: 22px;\n$desc-height: $desc-name-height + $desc-subname-height;\n\n$top-buttons-spacing: $app-navigation-padding; // align with app navigation\n\n/*\n\tSidebar: to be used within #content\n\tapp-content will be shrinked properly\n*/\n.app-sidebar {\n\t--app-sidebar-width: clamp(300px, 27vw, 500px);\n\twidth: var(--app-sidebar-width);\n\n\tz-index: 1500;\n\ttop: 0;\n\tright: 0;\n\tdisplay: flex;\n\toverflow-x: hidden;\n\toverflow-y: auto;\n\tflex-direction: column;\n\tflex-shrink: 0;\n\theight: 100%;\n\tborder-left: 1px solid var(--color-border);\n\tbackground: var(--color-main-background);\n\t// Make close button positioned relative to the header\n\tposition: relative;\n\n\t&__toggle {\n\t\tposition: absolute !important;\n\t\tinset-block-start: var(--app-sidebar-padding);\n\t\tinset-inline-end: var(--app-sidebar-padding);\n\t\t// app-content has z-index 1000 so we need 1001\n\t\tz-index: 1001;\n\t}\n\n\t.app-sidebar-header {\n\t\t> .app-sidebar__close {\n\t\t\tposition: absolute;\n\t\t\tz-index: 100;\n\t\t\ttop: $top-buttons-spacing;\n\t\t\tright: $top-buttons-spacing;\n\t\t\twidth: var(--default-clickable-area);\n\t\t\theight: var(--default-clickable-area);\n\t\t\topacity: $opacity_normal;\n\t\t\tborder-radius: calc(var(--default-clickable-area) / 2);\n\t\t\t&:hover,\n\t\t\t&:active,\n\t\t\t&:focus {\n\t\t\t\topacity: $opacity_full;\n\t\t\t\tbackground-color: $action-background-hover;\n\t\t\t}\n\t\t}\n\n\t\t// Compact mode only affects a sidebar with a figure\n\t\t&--compact.app-sidebar-header--with-figure {\n\t\t\t.app-sidebar-header__info {\n\t\t\t\tflex-direction: row;\n\n\t\t\t\t.app-sidebar-header__figure {\n\t\t\t\t\t--figure-size: calc($desc-height + var(--app-sidebar-padding));\n\t\t\t\t\tz-index: 2;\n\t\t\t\t\twidth: var(--figure-size);\n\t\t\t\t\theight: var(--figure-size);\n\t\t\t\t\tmargin: calc(var(--app-sidebar-padding) / 2);\n\t\t\t\t\tborder-radius: 3px;\n\t\t\t\t\tflex: 0 0 auto;\n\t\t\t\t}\n\t\t\t\t.app-sidebar-header__desc {\n\t\t\t\t\tpadding-left: 0;\n\t\t\t\t\tflex: 1 1 auto;\n\t\t\t\t\tmin-width: 0;\n\t\t\t\t\tpadding-right: calc(2 * var(--default-clickable-area) + $top-buttons-spacing);\n\t\t\t\t\tpadding-top: var(--app-sidebar-padding);\n\n\t\t\t\t\t&.app-sidebar-header__desc--without-actions {\n\t\t\t\t\t\tpadding-right: calc(var(--default-clickable-area) + $top-buttons-spacing);\n\t\t\t\t\t}\n\n\t\t\t\t\t.app-sidebar-header__tertiary-actions {\n\t\t\t\t\t\tz-index: 3; // above star\n\t\t\t\t\t\tposition: absolute;\n\t\t\t\t\t\ttop: calc(var(--app-sidebar-padding) / 2);\n\t\t\t\t\t\tleft: calc(-1 * var(--default-clickable-area));\n\t\t\t\t\t\tgap: 0; // override gap\n\t\t\t\t\t}\n\t\t\t\t\t.app-sidebar-header__menu {\n\t\t\t\t\t\ttop: $top-buttons-spacing;\n\t\t\t\t\t\tright: calc(var(--default-clickable-area) + $top-buttons-spacing); // left of the close button\n\t\t\t\t\t\tposition: absolute;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// sidebar without figure\n\t\t&:not(.app-sidebar-header--with-figure) {\n\t\t\t// align the menu with the close button\n\t\t\t.app-sidebar-header__menu {\n\t\t\t\tposition: absolute;\n\t\t\t\ttop: $top-buttons-spacing;\n\t\t\t\tright: calc($top-buttons-spacing + var(--default-clickable-area));\n\t\t\t}\n\t\t\t// increase the padding to not overlap the menu\n\t\t\t.app-sidebar-header__desc {\n\t\t\t\tpadding-right: calc(var(--default-clickable-area) * 2 + $top-buttons-spacing);\n\n\t\t\t\t&.app-sidebar-header__desc--without-actions {\n\t\t\t\t\tpadding-right: calc(var(--default-clickable-area) + $top-buttons-spacing);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// the container with the figure and the description\n\t\t.app-sidebar-header__info {\n\t\t\tdisplay: flex;\n\t\t\tflex-direction: column;\n\t\t}\n\n\t\t// header background\n\t\t&__figure {\n\t\t\twidth: 100%;\n\t\t\theight: 250px;\n\t\t\tmax-height: 250px;\n\t\t\tbackground-repeat: no-repeat;\n\t\t\tbackground-position: center;\n\t\t\tbackground-size: contain;\n\t\t\t&--with-action {\n\t\t\t\tcursor: pointer;\n\t\t\t}\n\t\t}\n\n\t\t// description\n\t\t&__desc {\n\t\t\tposition: relative;\n\t\t\tdisplay: flex;\n\t\t\tflex-direction: row;\n\t\t\tjustify-content: center;\n\t\t\talign-items: center;\n\t\t\tpadding-inline: var(--app-sidebar-padding);\n\t\t\tpadding-block: #{$top-buttons-spacing} calc(var(--app-sidebar-padding) / 2);\n\t\t\tgap: 0 4px;\n\n\t\t\t// custom overrides\n\t\t\t&--with-tertiary-action {\n\t\t\t\tpadding-left: 6px;\n\t\t\t}\n\n\t\t\t&--editable .app-sidebar-header__mainname-form,\n\t\t\t&--with-subname--editable .app-sidebar-header__mainname-form {\n\t\t\t\tmargin-top: -2px;\n\t\t\t\tmargin-bottom: -2px;\n\t\t\t}\n\n\t\t\t&--with-subname--editable .app-sidebar-header__subname {\n\t\t\t\tmargin-top: -2px;\n\t\t\t}\n\n\t\t\t.app-sidebar-header__tertiary-actions {\n\t\t\t\tdisplay: flex;\n\t\t\t\theight: var(--default-clickable-area);\n\t\t\t\twidth: var(--default-clickable-area);\n\t\t\t\tjustify-content: center;\n\t\t\t\tflex: 0 0 auto;\n\n\t\t\t\t.app-sidebar-header__star {\n\t\t\t\t\t// Override default Button component styles\n\t\t\t\t\tbox-shadow: none;\n\t\t\t\t\t&:not([aria-pressed='true']):hover {\n\t\t\t\t\t\tbox-shadow: none;\n\t\t\t\t\t\tbackground-color: var(--color-background-hover);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// names\n\t\t\t.app-sidebar-header__name-container {\n\t\t\t\tflex: 1 1 auto;\n\t\t\t\tdisplay: flex;\n\t\t\t\tflex-direction: column;\n\t\t\t\tjustify-content: center;\n\t\t\t\tmin-width: 0;\n\n\t\t\t\t.app-sidebar-header__mainname-container {\n\t\t\t\t\tdisplay: flex;\n\t\t\t\t\talign-items: center;\n\t\t\t\t\tmin-height: var(--default-clickable-area);\n\n\t\t\t\t\t// main name\n\t\t\t\t\t.app-sidebar-header__mainname {\n\t\t\t\t\t\tpadding: 0;\n\t\t\t\t\t\tmin-height: 30px;\n\t\t\t\t\t\tfont-size: 20px;\n\t\t\t\t\t\tline-height: $desc-name-height;\n\n\t\t\t\t\t\t// Needs 'deep' as the link is generated by the linkify directive\n\t\t\t\t\t\t&:deep(.linkified) {\n\t\t\t\t\t\t\tcursor: pointer;\n\t\t\t\t\t\t\ttext-decoration: underline;\n\t\t\t\t\t\t\tmargin: 0;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t.app-sidebar-header__mainname-form {\n\t\t\t\t\t\tdisplay: flex;\n\t\t\t\t\t\tflex: 1 1 auto;\n\t\t\t\t\t\talign-items: center;\n\n\t\t\t\t\t\tinput.app-sidebar-header__mainname-input {\n\t\t\t\t\t\t\tflex: 1 1 auto;\n\t\t\t\t\t\t\tmargin: 0;\n\t\t\t\t\t\t\tpadding: $desc-input-padding;\n\t\t\t\t\t\t\tfont-size: 20px;\n\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// main menu\n\t\t\t\t\t.app-sidebar-header__menu {\n\t\t\t\t\t\tmargin-left: 5px;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// shared between main and subname\n\t\t\t\t.app-sidebar-header__mainname,\n\t\t\t\t.app-sidebar-header__subname {\n\t\t\t\t\toverflow: hidden;\n\t\t\t\t\twidth: 100%;\n\t\t\t\t\tmargin: 0;\n\t\t\t\t\twhite-space: nowrap;\n\t\t\t\t\ttext-overflow: ellipsis;\n\t\t\t\t}\n\n\t\t\t\t// subname\n\t\t\t\t.app-sidebar-header__subname {\n\t\t\t\t\tcolor: var(--color-text-maxcontrast);\n\t\t\t\t\tfont-size: var(--default-font-size);\n\t\t\t\t\tpadding: 0;\n\n\t\t\t\t\t* {\n\t\t\t\t\t\tvertical-align: text-bottom;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// sidebar description slot\n\t\t&__description {\n\t\t\tdisplay: flex;\n\t\t\talign-items: center;\n\t\t\tmargin: 0 10px;\n\t\t}\n\t}\n}\n\n// Make the sidebar full-width on small screens\n@media only screen and (max-width: $breakpoint-small-mobile) {\n\t.app-sidebar {\n\t\tposition: absolute;\n\t\t--app-sidebar-width: 100vw;\n\t}\n}\n\n.slide-right-leave-active,\n.slide-right-enter-active {\n\ttransition-duration: var(--animation-quick);\n\ttransition-property: margin-right;\n}\n\n.slide-right-enter-to,\n.slide-right-leave {\n\tmargin-right: 0;\n}\n\n.slide-right-enter,\n.slide-right-leave-to {\n\tmargin-right: calc(-1 * var(--app-sidebar-width));\n}\n</style>\n\n<style lang=\"scss\">\n// ! slots specific designs, cannot be scoped\n// if any button inside the description slot, increase visual padding\n.app-sidebar-header__description {\n\tbutton, .button,\n\tinput[type='button'],\n\tinput[type='submit'],\n\tinput[type='reset'] {\n\t\tpadding: 6px 22px;\n\t}\n}\n\n</style>\n"],"names":["_sfc_main","NcCheckboxRadioSwitch","NcVNodes","Teleport","NcActions","ArrowRight","NcButton","NcLoadingIcon","NcEmptyContent","Close","Focus","Linkify","ClickOutside","GenRandomId","useIsSmallMobile","t","createFocusTrap","getTrapStack"],"mappings":"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","x_google_ignoreList":[1,2,3]}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import '../assets/NcMentionBubble-
|
|
2
|
-
import '../assets/NcAvatar-
|
|
3
|
-
import { N as NcActions } from "./NcActions-
|
|
1
|
+
import '../assets/NcMentionBubble-C6t8od-_.css';
|
|
2
|
+
import '../assets/NcAvatar-m0lTnGXX.css';
|
|
3
|
+
import { N as NcActions } from "./NcActions-CL3YRRgz.mjs";
|
|
4
4
|
import NcActionLink from "../Components/NcActionLink.mjs";
|
|
5
5
|
import NcActionRouter from "../Components/NcActionRouter.mjs";
|
|
6
6
|
import NcActionText from "../Components/NcActionText.mjs";
|
|
7
7
|
import NcButton from "../Components/NcButton.mjs";
|
|
8
|
-
import { N as NcIconSvgWrapper } from "./NcIconSvgWrapper-
|
|
8
|
+
import { N as NcIconSvgWrapper } from "./NcIconSvgWrapper-Ckqpz-vm.mjs";
|
|
9
9
|
import NcLoadingIcon from "../Components/NcLoadingIcon.mjs";
|
|
10
|
-
import { N as NcUserStatusIcon, g as getUserStatusText } from "./NcUserStatusIcon-
|
|
11
|
-
import { u as usernameToColor } from "./usernameToColor-
|
|
12
|
-
import { g as getAvatarUrl } from "./getAvatarUrl-
|
|
10
|
+
import { N as NcUserStatusIcon, g as getUserStatusText } from "./NcUserStatusIcon-DQyfBtYn.mjs";
|
|
11
|
+
import { u as usernameToColor } from "./usernameToColor-CB3rGdYw.mjs";
|
|
12
|
+
import { g as getAvatarUrl } from "./getAvatarUrl-DxvUjKMi.mjs";
|
|
13
13
|
import "../Composables/useIsFullscreen.mjs";
|
|
14
14
|
import "../Composables/useIsMobile.mjs";
|
|
15
15
|
/* empty css */
|
|
@@ -22,33 +22,12 @@ import { getCurrentUser } from "@nextcloud/auth";
|
|
|
22
22
|
import axios from "@nextcloud/axios";
|
|
23
23
|
import { getCapabilities } from "@nextcloud/capabilities";
|
|
24
24
|
import { generateOcsUrl, generateUrl } from "@nextcloud/router";
|
|
25
|
-
import { r as register, n as
|
|
26
|
-
import { g as getRoute } from "./autolink-
|
|
25
|
+
import { r as register, n as t10, a as t } from "./_l10n-DDx8P-X1.mjs";
|
|
26
|
+
import { g as getRoute } from "./autolink-cbuFALXr.mjs";
|
|
27
27
|
import { D as DotsHorizontal } from "./DotsHorizontal-C0STD_HU.mjs";
|
|
28
28
|
import { subscribe, unsubscribe } from "@nextcloud/event-bus";
|
|
29
29
|
import { getBuilder } from "@nextcloud/browser-storage";
|
|
30
30
|
import { vOnClickOutside } from "@vueuse/components";
|
|
31
|
-
/**
|
|
32
|
-
* @copyright Copyright (c) 2020 Georg Ehrke <georg-nextcloud@ehrke.email>
|
|
33
|
-
*
|
|
34
|
-
* @author Georg Ehrke <georg-nextcloud@ehrke.email>
|
|
35
|
-
*
|
|
36
|
-
* @license AGPL-3.0-or-later
|
|
37
|
-
*
|
|
38
|
-
* This program is free software: you can redistribute it and/or modify
|
|
39
|
-
* it under the terms of the GNU Affero General Public License as
|
|
40
|
-
* published by the Free Software Foundation, either version 3 of the
|
|
41
|
-
* License, or (at your option) any later version.
|
|
42
|
-
*
|
|
43
|
-
* This program is distributed in the hope that it will be useful,
|
|
44
|
-
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
45
|
-
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
46
|
-
* GNU Affero General Public License for more details.
|
|
47
|
-
*
|
|
48
|
-
* You should have received a copy of the GNU Affero General Public License
|
|
49
|
-
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
50
|
-
*
|
|
51
|
-
*/
|
|
52
31
|
const userStatus = {
|
|
53
32
|
data() {
|
|
54
33
|
return {
|
|
@@ -100,7 +79,7 @@ const userStatus = {
|
|
|
100
79
|
}
|
|
101
80
|
}
|
|
102
81
|
};
|
|
103
|
-
register(
|
|
82
|
+
register(t10);
|
|
104
83
|
const browserStorage = getBuilder("nextcloud").persist().build();
|
|
105
84
|
function getUserHasAvatar(userId) {
|
|
106
85
|
const flag = browserStorage.getItem("user-has-avatar." + userId);
|
|
@@ -583,7 +562,7 @@ var __component__ = /* @__PURE__ */ normalizeComponent(
|
|
|
583
562
|
_sfc_staticRenderFns,
|
|
584
563
|
false,
|
|
585
564
|
null,
|
|
586
|
-
"
|
|
565
|
+
"b7cf7dd2",
|
|
587
566
|
null,
|
|
588
567
|
null
|
|
589
568
|
);
|