@nextcloud/vue 8.31.0 â 8.32.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 +17 -0
- package/dist/Components/NcActionButton.cjs +1 -1
- package/dist/Components/NcActionButton.mjs +1 -1
- package/dist/Components/NcActionButtonGroup.cjs +1 -1
- package/dist/Components/NcActionButtonGroup.mjs +1 -1
- package/dist/Components/NcActionCheckbox.cjs +1 -1
- package/dist/Components/NcActionCheckbox.mjs +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 +1 -1
- package/dist/Components/NcActionRadio.mjs +1 -1
- package/dist/Components/NcActionRouter.cjs +2 -2
- package/dist/Components/NcActionRouter.mjs +2 -2
- package/dist/Components/NcActionText.cjs +2 -2
- package/dist/Components/NcActionText.mjs +2 -2
- package/dist/Components/NcActionTextEditable.cjs +1 -1
- package/dist/Components/NcActionTextEditable.mjs +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/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/NcAppNavigationItem.cjs +1 -1
- package/dist/Components/NcAppNavigationItem.mjs +1 -1
- package/dist/Components/NcAppNavigationNew.cjs +1 -1
- package/dist/Components/NcAppNavigationNew.mjs +1 -1
- package/dist/Components/NcAppNavigationNewItem.cjs +1 -1
- package/dist/Components/NcAppNavigationNewItem.mjs +1 -1
- package/dist/Components/NcAppNavigationSearch.cjs +1 -1
- package/dist/Components/NcAppNavigationSearch.mjs +1 -1
- package/dist/Components/NcAppNavigationSettings.cjs +1 -1
- package/dist/Components/NcAppNavigationSettings.mjs +1 -1
- package/dist/Components/NcAppNavigationToggle.cjs +1 -1
- package/dist/Components/NcAppNavigationToggle.mjs +1 -1
- package/dist/Components/NcAppSettingsDialog.cjs +1 -1
- package/dist/Components/NcAppSettingsDialog.mjs +1 -1
- package/dist/Components/NcAppSettingsSection.cjs +2 -63
- package/dist/Components/NcAppSettingsSection.cjs.map +1 -1
- package/dist/Components/NcAppSettingsSection.mjs +2 -63
- 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 +3 -2
- package/dist/Components/NcAppSidebarTab.cjs.map +1 -1
- package/dist/Components/NcAppSidebarTab.mjs +3 -2
- package/dist/Components/NcAppSidebarTab.mjs.map +1 -1
- package/dist/Components/NcAssistantButton.cjs +1 -1
- package/dist/Components/NcAssistantButton.mjs +1 -1
- package/dist/Components/NcAssistantIcon.cjs +1 -1
- package/dist/Components/NcAssistantIcon.mjs +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 +1 -1
- package/dist/Components/NcButton.mjs +1 -1
- package/dist/Components/NcCheckboxRadioSwitch.cjs +1 -1
- package/dist/Components/NcCheckboxRadioSwitch.mjs +1 -1
- package/dist/Components/NcChip.cjs +14 -8
- package/dist/Components/NcChip.cjs.map +1 -1
- package/dist/Components/NcChip.mjs +14 -8
- package/dist/Components/NcChip.mjs.map +1 -1
- package/dist/Components/NcCollectionList.cjs +1 -1
- package/dist/Components/NcCollectionList.mjs +1 -1
- 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 +1 -1
- package/dist/Components/NcCounterBubble.mjs +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/NcDateTimePicker.cjs +32 -19
- package/dist/Components/NcDateTimePicker.cjs.map +1 -1
- package/dist/Components/NcDateTimePicker.mjs +32 -19
- package/dist/Components/NcDateTimePicker.mjs.map +1 -1
- package/dist/Components/NcDateTimePickerNative.cjs +32 -14
- package/dist/Components/NcDateTimePickerNative.cjs.map +1 -1
- package/dist/Components/NcDateTimePickerNative.mjs +32 -14
- 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 +1 -1
- package/dist/Components/NcEllipsisedOption.mjs +1 -1
- package/dist/Components/NcEmojiPicker.cjs +1 -1
- package/dist/Components/NcEmojiPicker.mjs +1 -1
- package/dist/Components/NcEmptyContent.cjs +2 -1
- package/dist/Components/NcEmptyContent.cjs.map +1 -1
- package/dist/Components/NcEmptyContent.mjs +2 -1
- package/dist/Components/NcEmptyContent.mjs.map +1 -1
- package/dist/Components/NcHeaderButton.cjs +1 -1
- package/dist/Components/NcHeaderButton.mjs +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 +1 -1
- package/dist/Components/NcInputField.mjs +1 -1
- package/dist/Components/NcKbd.cjs +1 -1
- package/dist/Components/NcKbd.mjs +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/NcModal.cjs +33 -18
- package/dist/Components/NcModal.cjs.map +1 -1
- package/dist/Components/NcModal.mjs +33 -18
- package/dist/Components/NcModal.mjs.map +1 -1
- package/dist/Components/NcNoteCard.cjs +2 -2
- package/dist/Components/NcNoteCard.mjs +2 -2
- 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/NcRadioGroup.cjs +1 -1
- package/dist/Components/NcRadioGroup.mjs +1 -1
- package/dist/Components/NcRadioGroupButton.cjs +1 -1
- package/dist/Components/NcRadioGroupButton.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 +3 -3
- package/dist/Components/NcRichText.mjs +4 -4
- 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/NcSelectUsers.cjs +1 -1
- package/dist/Components/NcSelectUsers.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 -1
- package/dist/Components/NcSettingsSelectGroup.mjs +1 -1
- package/dist/Components/NcTextArea.cjs +1 -1
- package/dist/Components/NcTextArea.mjs +1 -1
- package/dist/Components/NcTextField.cjs +1 -1
- package/dist/Components/NcTextField.mjs +1 -1
- package/dist/Components/NcThemeProvider.cjs +1 -1
- package/dist/Components/NcThemeProvider.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 +2 -1
- package/dist/Components/NcVNodes.cjs.map +1 -1
- package/dist/Components/NcVNodes.mjs +2 -1
- package/dist/Components/NcVNodes.mjs.map +1 -1
- package/dist/Composables/useFormatDateTime.cjs +27 -12
- package/dist/Composables/useFormatDateTime.cjs.map +1 -1
- package/dist/Composables/useFormatDateTime.mjs +27 -12
- package/dist/Composables/useFormatDateTime.mjs.map +1 -1
- package/dist/Composables/useHotKey.cjs +2 -1
- package/dist/Composables/useHotKey.cjs.map +1 -1
- package/dist/Composables/useHotKey.mjs +2 -1
- package/dist/Composables/useHotKey.mjs.map +1 -1
- package/dist/Composables/useIsDarkTheme.cjs +5 -2
- package/dist/Composables/useIsDarkTheme.cjs.map +1 -1
- package/dist/Composables/useIsDarkTheme.mjs +5 -2
- package/dist/Composables/useIsDarkTheme.mjs.map +1 -1
- package/dist/Composables/useIsMobile.cjs.map +1 -1
- package/dist/Composables/useIsMobile.mjs.map +1 -1
- package/dist/Directives/Linkify.cjs +2 -1
- package/dist/Directives/Linkify.cjs.map +1 -1
- package/dist/Directives/Linkify.mjs +2 -1
- package/dist/Directives/Linkify.mjs.map +1 -1
- package/dist/Functions/contactsMenu.cjs +3 -2
- package/dist/Functions/contactsMenu.cjs.map +1 -1
- package/dist/Functions/contactsMenu.mjs +3 -2
- package/dist/Functions/contactsMenu.mjs.map +1 -1
- package/dist/Functions/dialog.cjs +20 -5
- package/dist/Functions/dialog.cjs.map +1 -1
- package/dist/Functions/dialog.mjs +20 -5
- package/dist/Functions/dialog.mjs.map +1 -1
- package/dist/Functions/emoji.cjs +1 -1
- package/dist/Functions/emoji.mjs +1 -1
- package/dist/Functions/reference.cjs +2 -2
- package/dist/Functions/reference.mjs +2 -2
- package/dist/Functions/registerReference.cjs +1 -1
- package/dist/Functions/registerReference.mjs +1 -1
- package/dist/Functions/usernameToColor.cjs +2 -2
- package/dist/Functions/usernameToColor.cjs.map +1 -1
- package/dist/Functions/usernameToColor.mjs +2 -2
- package/dist/Functions/usernameToColor.mjs.map +1 -1
- package/dist/Mixins/isMobile.cjs.map +1 -1
- package/dist/Mixins/isMobile.mjs.map +1 -1
- package/dist/Mixins/richEditor.cjs +1 -1
- package/dist/Mixins/richEditor.mjs +1 -1
- package/dist/assets/{NcActionInput-DXZaAilC.css â NcActionInput-DsGwr3wt.css} +65 -65
- package/dist/assets/{NcAppContent-DerHKU6P.css â NcAppContent-BpjG38I8.css} +23 -23
- package/dist/assets/{NcAppNavigation-R4E_wTZ-.css â NcAppNavigation-Bg4Oe7WC.css} +12 -12
- package/dist/assets/{NcAppNavigationItem-Kua1hP7u.css â NcAppNavigationItem-UaB3qdsS.css} +36 -36
- package/dist/assets/{NcAppSettingsDialog-DiJpVNeb.css â NcAppSettingsDialog-DH3DIIwL.css} +10 -10
- package/dist/assets/{NcAppSettingsSection-IzrCzLDw.css â NcAppSettingsSection-Dq0eTGEp.css} +3 -3
- package/dist/assets/{NcAppSidebar-CJYtNcF0.css â NcAppSidebar-Bd2cj1W-.css} +44 -44
- package/dist/assets/{NcAvatar-BdAXbXdR.css â NcAvatar-Cm4kVIfS.css} +24 -24
- package/dist/assets/{NcButton-D8AOCliw.css â NcButton-uQUvp7DS.css} +46 -46
- package/dist/assets/{NcCollectionList-DInDhsAS.css â NcCollectionList-hRgvNUMR.css} +15 -15
- package/dist/assets/{NcColorPicker-CGI9ElwB.css â NcColorPicker-CCqpXoam.css} +43 -35
- package/dist/assets/{NcContent-BedDNXST.css â NcContent-IIXgAj_u.css} +10 -10
- package/dist/assets/{NcDateTimePicker-4Zw7r2r4.css â NcDateTimePicker-C6sMtYzL.css} +13 -13
- package/dist/assets/{NcEmojiPicker-CrjOSMLF.css â NcEmojiPicker-B-iLLj37.css} +122 -122
- package/dist/assets/{NcModal-BzkYPomo.css â NcModal-4ZPVUmG2.css} +62 -62
- package/dist/assets/{NcRadioGroupButton-B1hPj4B8.css â NcRadioGroupButton-6mf16D0h.css} +16 -15
- package/dist/assets/{NcRelatedResourcesPanel-d2OxhjiL.css â NcRelatedResourcesPanel-BgMc8bue.css} +17 -17
- package/dist/assets/{NcRichContenteditable-BoM95AVW.css â NcRichContenteditable-Ds_cptgr.css} +11 -11
- package/dist/assets/{NcRichText-BDx2fupZ.css â NcRichText-CVy4zTPr.css} +2 -2
- package/dist/assets/{referencePickerModal-CTpc6_U6.css â referencePickerModal-CGtNx7ew.css} +6 -6
- package/dist/chunks/{NcActionButton-CVW8aRkE.mjs â NcActionButton-CZsSFAT4.mjs} +5 -5
- package/dist/chunks/{NcActionButton-CVW8aRkE.mjs.map â NcActionButton-CZsSFAT4.mjs.map} +1 -1
- package/dist/chunks/{NcActionButton-CFXzNoFT.cjs â NcActionButton-lJ0IA3IS.cjs} +5 -5
- package/dist/chunks/{NcActionButton-CFXzNoFT.cjs.map â NcActionButton-lJ0IA3IS.cjs.map} +1 -1
- package/dist/chunks/{NcActionButtonGroup-BOr5Of3k.mjs â NcActionButtonGroup-CIvAeDpU.mjs} +3 -3
- package/dist/chunks/{NcActionButtonGroup-BOr5Of3k.mjs.map â NcActionButtonGroup-CIvAeDpU.mjs.map} +1 -1
- package/dist/chunks/{NcActionButtonGroup-Bwuy2WZQ.cjs â NcActionButtonGroup-CQZL14Nz.cjs} +3 -3
- package/dist/chunks/{NcActionButtonGroup-Bwuy2WZQ.cjs.map â NcActionButtonGroup-CQZL14Nz.cjs.map} +1 -1
- package/dist/chunks/{NcActionCheckbox-C05ls65i.mjs â NcActionCheckbox-BAuN4ZMC.mjs} +2 -2
- package/dist/chunks/{NcActionCheckbox-C05ls65i.mjs.map â NcActionCheckbox-BAuN4ZMC.mjs.map} +1 -1
- package/dist/chunks/{NcActionCheckbox-Dg_1Ovt0.cjs â NcActionCheckbox-BvMmq0jL.cjs} +2 -2
- package/dist/chunks/{NcActionCheckbox-Dg_1Ovt0.cjs.map â NcActionCheckbox-BvMmq0jL.cjs.map} +1 -1
- package/dist/chunks/{NcActionInput-CoG-fZq9.mjs â NcActionInput-CfznemNH.mjs} +9 -9
- package/dist/chunks/{NcActionInput-CoG-fZq9.mjs.map â NcActionInput-CfznemNH.mjs.map} +1 -1
- package/dist/chunks/{NcActionInput-iIJpNS_Q.cjs â NcActionInput-DfjLV0Gg.cjs} +9 -9
- package/dist/chunks/{NcActionInput-iIJpNS_Q.cjs.map â NcActionInput-DfjLV0Gg.cjs.map} +1 -1
- package/dist/chunks/{NcActionRadio-Bpbs2dPm.mjs â NcActionRadio-Bg5VuF7I.mjs} +2 -2
- package/dist/chunks/{NcActionRadio-Bpbs2dPm.mjs.map â NcActionRadio-Bg5VuF7I.mjs.map} +1 -1
- package/dist/chunks/{NcActionRadio-Dtrwffyh.cjs â NcActionRadio-CBh6AlC4.cjs} +2 -2
- package/dist/chunks/{NcActionRadio-Dtrwffyh.cjs.map â NcActionRadio-CBh6AlC4.cjs.map} +1 -1
- package/dist/chunks/{NcActionTextEditable-BpahzGpr.cjs â NcActionTextEditable-BhucWrOO.cjs} +6 -6
- package/dist/chunks/{NcActionTextEditable-BpahzGpr.cjs.map â NcActionTextEditable-BhucWrOO.cjs.map} +1 -1
- package/dist/chunks/{NcActionTextEditable-DRwDJjPd.mjs â NcActionTextEditable-CSP4OjpU.mjs} +6 -6
- package/dist/chunks/{NcActionTextEditable-DRwDJjPd.mjs.map â NcActionTextEditable-CSP4OjpU.mjs.map} +1 -1
- package/dist/chunks/{NcActions-C832pWHO.mjs â NcActions-A918mfXE.mjs} +82 -64
- package/dist/chunks/{NcActions-C832pWHO.mjs.map â NcActions-A918mfXE.mjs.map} +1 -1
- package/dist/chunks/{NcActions-B7oXbiVt.cjs â NcActions-D3N_As6c.cjs} +82 -64
- package/dist/chunks/{NcActions-B7oXbiVt.cjs.map â NcActions-D3N_As6c.cjs.map} +1 -1
- package/dist/chunks/{NcAppContent-Djy38ou2.cjs â NcAppContent-CCyPMvUa.cjs} +27 -31
- package/dist/chunks/NcAppContent-CCyPMvUa.cjs.map +1 -0
- package/dist/chunks/{NcAppContent-C9NGJE6n.mjs â NcAppContent-DFlcxER-.mjs} +27 -31
- package/dist/chunks/NcAppContent-DFlcxER-.mjs.map +1 -0
- package/dist/chunks/{NcAppNavigation-C0Oc0gQ6.cjs â NcAppNavigation-CCHYn0D6.cjs} +7 -6
- package/dist/chunks/{NcAppNavigation-C0Oc0gQ6.cjs.map â NcAppNavigation-CCHYn0D6.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigation-DjtmN3dS.mjs â NcAppNavigation-CLF6-i2t.mjs} +7 -6
- package/dist/chunks/{NcAppNavigation-DjtmN3dS.mjs.map â NcAppNavigation-CLF6-i2t.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationCaption-CsoHaLXg.mjs â NcAppNavigationCaption-CsG8P-1P.mjs} +3 -3
- package/dist/chunks/{NcAppNavigationCaption-CsoHaLXg.mjs.map â NcAppNavigationCaption-CsG8P-1P.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationCaption-D4-hEmCi.cjs â NcAppNavigationCaption-DhW300oH.cjs} +3 -3
- package/dist/chunks/{NcAppNavigationCaption-D4-hEmCi.cjs.map â NcAppNavigationCaption-DhW300oH.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationItem-DvVYHshm.mjs â NcAppNavigationItem-CwuKVEUN.mjs} +9 -9
- package/dist/chunks/{NcAppNavigationItem-DvVYHshm.mjs.map â NcAppNavigationItem-CwuKVEUN.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationItem-ZOXUMmX5.cjs â NcAppNavigationItem-HZVy5JEa.cjs} +9 -9
- package/dist/chunks/{NcAppNavigationItem-ZOXUMmX5.cjs.map â NcAppNavigationItem-HZVy5JEa.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationNew-AiFYSCW1.mjs â NcAppNavigationNew-DbqusDUV.mjs} +2 -2
- package/dist/chunks/{NcAppNavigationNew-AiFYSCW1.mjs.map â NcAppNavigationNew-DbqusDUV.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationNew-BqNIa8N9.cjs â NcAppNavigationNew-T56pahiu.cjs} +2 -2
- package/dist/chunks/{NcAppNavigationNew-BqNIa8N9.cjs.map â NcAppNavigationNew-T56pahiu.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationNewItem-CdlWkGU3.mjs â NcAppNavigationNewItem-BsnZWCLW.mjs} +2 -2
- package/dist/chunks/{NcAppNavigationNewItem-CdlWkGU3.mjs.map â NcAppNavigationNewItem-BsnZWCLW.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationNewItem-BuEkCd2H.cjs â NcAppNavigationNewItem-DMRZwa_y.cjs} +2 -2
- package/dist/chunks/{NcAppNavigationNewItem-BuEkCd2H.cjs.map â NcAppNavigationNewItem-DMRZwa_y.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationSearch-BXjB3FEJ.cjs â NcAppNavigationSearch-BlG1xMok.cjs} +9 -5
- package/dist/chunks/{NcAppNavigationSearch-BXjB3FEJ.cjs.map â NcAppNavigationSearch-BlG1xMok.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationSearch-CsIzwF6F.mjs â NcAppNavigationSearch-DCMN2cWp.mjs} +9 -5
- package/dist/chunks/{NcAppNavigationSearch-CsIzwF6F.mjs.map â NcAppNavigationSearch-DCMN2cWp.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationSettings-CkFZMLtH.cjs â NcAppNavigationSettings-DlIDzhxh.cjs} +5 -5
- package/dist/chunks/{NcAppNavigationSettings-CkFZMLtH.cjs.map â NcAppNavigationSettings-DlIDzhxh.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationSettings-Dq2O3kRz.mjs â NcAppNavigationSettings-n8OaxTbE.mjs} +5 -5
- package/dist/chunks/{NcAppNavigationSettings-Dq2O3kRz.mjs.map â NcAppNavigationSettings-n8OaxTbE.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationToggle-DlWpnYdz.mjs â NcAppNavigationToggle-ClYKr8Zn.mjs} +14 -13
- package/dist/chunks/{NcAppNavigationToggle-DlWpnYdz.mjs.map â NcAppNavigationToggle-ClYKr8Zn.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationToggle-C2vtZ3uV.cjs â NcAppNavigationToggle-Cn1UvxNP.cjs} +14 -13
- package/dist/chunks/{NcAppNavigationToggle-C2vtZ3uV.cjs.map â NcAppNavigationToggle-Cn1UvxNP.cjs.map} +1 -1
- package/dist/chunks/NcAppSettingsDialog-Cpjr8Tca.mjs +132 -0
- package/dist/chunks/NcAppSettingsDialog-Cpjr8Tca.mjs.map +1 -0
- package/dist/chunks/NcAppSettingsDialog-R6Y-tl6d.cjs +134 -0
- package/dist/chunks/NcAppSettingsDialog-R6Y-tl6d.cjs.map +1 -0
- package/dist/chunks/NcAppSettingsSection-BNVlt4g0.mjs +88 -0
- package/dist/chunks/NcAppSettingsSection-BNVlt4g0.mjs.map +1 -0
- package/dist/chunks/NcAppSettingsSection-CTqViPnP.cjs +87 -0
- package/dist/chunks/NcAppSettingsSection-CTqViPnP.cjs.map +1 -0
- package/dist/chunks/{NcAppSidebar-Bda_fc-F.mjs â NcAppSidebar-CVcOP4bk.mjs} +20 -17
- package/dist/chunks/{NcAppSidebar-Bda_fc-F.mjs.map â NcAppSidebar-CVcOP4bk.mjs.map} +1 -1
- package/dist/chunks/{NcAppSidebar-Cx2ZxU4N.cjs â NcAppSidebar-Ddt82bsA.cjs} +20 -17
- package/dist/chunks/{NcAppSidebar-Cx2ZxU4N.cjs.map â NcAppSidebar-Ddt82bsA.cjs.map} +1 -1
- package/dist/chunks/{NcAssistantButton-zriu0Kiz.cjs â NcAssistantButton-WQvWhoAr.cjs} +5 -5
- package/dist/chunks/{NcAssistantButton-zriu0Kiz.cjs.map â NcAssistantButton-WQvWhoAr.cjs.map} +1 -1
- package/dist/chunks/{NcAssistantButton-Dk28Wilk.mjs â NcAssistantButton-lDdWOemf.mjs} +5 -5
- package/dist/chunks/{NcAssistantButton-Dk28Wilk.mjs.map â NcAssistantButton-lDdWOemf.mjs.map} +1 -1
- package/dist/chunks/{NcAssistantIcon-CtEF1hjA.mjs â NcAssistantIcon-BTjYuSQ9.mjs} +5 -5
- package/dist/chunks/{NcAssistantIcon-CtEF1hjA.mjs.map â NcAssistantIcon-BTjYuSQ9.mjs.map} +1 -1
- package/dist/chunks/{NcAssistantIcon-B-Udgta_.cjs â NcAssistantIcon-RDQ8YhZE.cjs} +5 -5
- package/dist/chunks/{NcAssistantIcon-B-Udgta_.cjs.map â NcAssistantIcon-RDQ8YhZE.cjs.map} +1 -1
- package/dist/chunks/{NcAvatar-CuYtFEdJ.mjs â NcAvatar-Cupl4prm.mjs} +31 -29
- package/dist/chunks/NcAvatar-Cupl4prm.mjs.map +1 -0
- package/dist/chunks/{NcAvatar-bd-5zXWN.cjs â NcAvatar-D_0Aw88L.cjs} +31 -29
- package/dist/chunks/NcAvatar-D_0Aw88L.cjs.map +1 -0
- package/dist/chunks/{NcBreadcrumb-ChxXdE2m.cjs â NcBreadcrumb-FbePEaGS.cjs} +22 -6
- package/dist/chunks/{NcBreadcrumb-ChxXdE2m.cjs.map â NcBreadcrumb-FbePEaGS.cjs.map} +1 -1
- package/dist/chunks/{NcBreadcrumb-D1106x4x.mjs â NcBreadcrumb-VJGW992x.mjs} +22 -6
- package/dist/chunks/{NcBreadcrumb-D1106x4x.mjs.map â NcBreadcrumb-VJGW992x.mjs.map} +1 -1
- package/dist/chunks/{NcBreadcrumbs-XAvQ1MIp.cjs â NcBreadcrumbs-CrNBCyUa.cjs} +47 -29
- package/dist/chunks/{NcBreadcrumbs-C9Zo0nca.mjs.map â NcBreadcrumbs-CrNBCyUa.cjs.map} +1 -1
- package/dist/chunks/{NcBreadcrumbs-C9Zo0nca.mjs â NcBreadcrumbs-DJSAcn8x.mjs} +47 -29
- package/dist/chunks/{NcBreadcrumbs-XAvQ1MIp.cjs.map â NcBreadcrumbs-DJSAcn8x.mjs.map} +1 -1
- package/dist/chunks/{NcButton-CWPBzbcC.mjs â NcButton-D3CaJu1f.mjs} +38 -22
- package/dist/chunks/{NcButton-CWPBzbcC.mjs.map â NcButton-D3CaJu1f.mjs.map} +1 -1
- package/dist/chunks/{NcButton-DOsCAjiE.cjs â NcButton-DK7bNZIL.cjs} +38 -22
- package/dist/chunks/{NcButton-DOsCAjiE.cjs.map â NcButton-DK7bNZIL.cjs.map} +1 -1
- package/dist/chunks/{NcCheckboxRadioSwitch-yVj7slxL.cjs â NcCheckboxRadioSwitch-CDFUoj2J.cjs} +8 -8
- package/dist/chunks/{NcCheckboxRadioSwitch-yVj7slxL.cjs.map â NcCheckboxRadioSwitch-CDFUoj2J.cjs.map} +1 -1
- package/dist/chunks/{NcCheckboxRadioSwitch-CLnWsBwK.mjs â NcCheckboxRadioSwitch-ezquUuPz.mjs} +8 -8
- package/dist/chunks/{NcCheckboxRadioSwitch-CLnWsBwK.mjs.map â NcCheckboxRadioSwitch-ezquUuPz.mjs.map} +1 -1
- package/dist/chunks/{NcCollectionList-5_ghrfiE.mjs â NcCollectionList-w-7M5HGN.mjs} +17 -16
- package/dist/chunks/{NcCollectionList-5_ghrfiE.mjs.map â NcCollectionList-w-7M5HGN.mjs.map} +1 -1
- package/dist/chunks/{NcCollectionList-DZh_7a3g.cjs â NcCollectionList-zAI6Ysc0.cjs} +17 -16
- package/dist/chunks/{NcCollectionList-DZh_7a3g.cjs.map â NcCollectionList-zAI6Ysc0.cjs.map} +1 -1
- package/dist/chunks/NcColorPicker-DpLU-oKM.mjs +157 -0
- package/dist/chunks/NcColorPicker-DpLU-oKM.mjs.map +1 -0
- package/dist/chunks/NcColorPicker-F-UP8OaJ.cjs +156 -0
- package/dist/chunks/NcColorPicker-F-UP8OaJ.cjs.map +1 -0
- package/dist/chunks/{NcContent-CGBJ782F.mjs â NcContent-C0_AA_wt.mjs} +7 -7
- package/dist/chunks/{NcContent-CGBJ782F.mjs.map â NcContent-C0_AA_wt.mjs.map} +1 -1
- package/dist/chunks/{NcContent-I3cwZc0Z.cjs â NcContent-DITvuNbF.cjs} +7 -7
- package/dist/chunks/{NcContent-I3cwZc0Z.cjs.map â NcContent-DITvuNbF.cjs.map} +1 -1
- package/dist/chunks/{NcCounterBubble-oxV8oMlX.mjs â NcCounterBubble-BKPpoBiy.mjs} +6 -4
- package/dist/chunks/{NcCounterBubble-oxV8oMlX.mjs.map â NcCounterBubble-BKPpoBiy.mjs.map} +1 -1
- package/dist/chunks/{NcCounterBubble-hyvazclA.cjs â NcCounterBubble-B_H3NCef.cjs} +6 -4
- package/dist/chunks/{NcCounterBubble-hyvazclA.cjs.map â NcCounterBubble-B_H3NCef.cjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidget-DKUU16oT.cjs â NcDashboardWidget--n1nzfhg.cjs} +4 -4
- package/dist/chunks/{NcDashboardWidget-DKUU16oT.cjs.map â NcDashboardWidget--n1nzfhg.cjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidget-_Bi63nDZ.mjs â NcDashboardWidget-CEL-DhKX.mjs} +4 -4
- package/dist/chunks/{NcDashboardWidget-_Bi63nDZ.mjs.map â NcDashboardWidget-CEL-DhKX.mjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidgetItem-D4q57Lg_.mjs â NcDashboardWidgetItem-DeQtScn8.mjs} +4 -4
- package/dist/chunks/{NcDashboardWidgetItem-D4q57Lg_.mjs.map â NcDashboardWidgetItem-DeQtScn8.mjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidgetItem-BhGOOhKF.cjs â NcDashboardWidgetItem-loanO02A.cjs} +4 -4
- package/dist/chunks/{NcDashboardWidgetItem-BhGOOhKF.cjs.map â NcDashboardWidgetItem-loanO02A.cjs.map} +1 -1
- package/dist/chunks/{NcDialog-Du-BeUCp.mjs â NcDialog-BM_wTqUn.mjs} +3 -3
- package/dist/chunks/{NcDialog-Du-BeUCp.mjs.map â NcDialog-BM_wTqUn.mjs.map} +1 -1
- package/dist/chunks/{NcDialog-B2tW1DtP.cjs â NcDialog-CG2sufkb.cjs} +3 -3
- package/dist/chunks/{NcDialog-B2tW1DtP.cjs.map â NcDialog-CG2sufkb.cjs.map} +1 -1
- package/dist/chunks/{NcDialogButton-DtGSMhif.mjs â NcDialogButton-Cr0wVMne.mjs} +6 -5
- package/dist/chunks/{NcDialogButton-DtGSMhif.mjs.map â NcDialogButton-Cr0wVMne.mjs.map} +1 -1
- package/dist/chunks/{NcDialogButton-BB84DliS.cjs â NcDialogButton-DkfxsIhv.cjs} +6 -5
- package/dist/chunks/{NcDialogButton-BB84DliS.cjs.map â NcDialogButton-DkfxsIhv.cjs.map} +1 -1
- package/dist/chunks/{NcEmojiPicker-B2SLfIBu.mjs â NcEmojiPicker-BV_iVlIv.mjs} +14 -13
- package/dist/chunks/NcEmojiPicker-BV_iVlIv.mjs.map +1 -0
- package/dist/chunks/{NcEmojiPicker-q_n1Rd8U.cjs â NcEmojiPicker-fgsuVz7X.cjs} +20 -19
- package/dist/chunks/NcEmojiPicker-fgsuVz7X.cjs.map +1 -0
- package/dist/chunks/{NcHeaderButton-AKzxd51V.cjs â NcHeaderButton-CNQVz4QP.cjs} +2 -2
- package/dist/chunks/{NcHeaderButton-AKzxd51V.cjs.map â NcHeaderButton-CNQVz4QP.cjs.map} +1 -1
- package/dist/chunks/{NcHeaderButton-BORaK-yT.mjs â NcHeaderButton-TJML067P.mjs} +2 -2
- package/dist/chunks/{NcHeaderButton-BORaK-yT.mjs.map â NcHeaderButton-TJML067P.mjs.map} +1 -1
- package/dist/chunks/{NcHeaderMenu-CBP4SYca.cjs â NcHeaderMenu-BzyFhg55.cjs} +10 -8
- package/dist/chunks/{NcHeaderMenu-CBP4SYca.cjs.map â NcHeaderMenu-BzyFhg55.cjs.map} +1 -1
- package/dist/chunks/{NcHeaderMenu-CkD6cjnH.mjs â NcHeaderMenu-D5ddiKnF.mjs} +10 -8
- package/dist/chunks/{NcHeaderMenu-CkD6cjnH.mjs.map â NcHeaderMenu-D5ddiKnF.mjs.map} +1 -1
- package/dist/chunks/{NcIconSvgWrapper-BreCg8pX.mjs â NcIconSvgWrapper-BCVwmZN2.mjs} +2 -2
- package/dist/chunks/{NcIconSvgWrapper-BreCg8pX.mjs.map â NcIconSvgWrapper-BCVwmZN2.mjs.map} +1 -1
- package/dist/chunks/{NcIconSvgWrapper-D-aKMbf3.cjs â NcIconSvgWrapper-DoVPfeNg.cjs} +2 -2
- package/dist/chunks/{NcIconSvgWrapper-D-aKMbf3.cjs.map â NcIconSvgWrapper-DoVPfeNg.cjs.map} +1 -1
- package/dist/chunks/{NcInputConfirmCancel-21vM2JHp.mjs â NcInputConfirmCancel-C8WnMK2V.mjs} +3 -3
- package/dist/chunks/{NcInputConfirmCancel-21vM2JHp.mjs.map â NcInputConfirmCancel-C8WnMK2V.mjs.map} +1 -1
- package/dist/chunks/{NcInputConfirmCancel-BqZm3WBG.cjs â NcInputConfirmCancel-DVVTaxWi.cjs} +3 -3
- package/dist/chunks/{NcInputConfirmCancel-BqZm3WBG.cjs.map â NcInputConfirmCancel-DVVTaxWi.cjs.map} +1 -1
- package/dist/chunks/{NcInputField-kKgY_2GV.mjs â NcInputField-1ujONIvp.mjs} +8 -7
- package/dist/chunks/{NcInputField-kKgY_2GV.mjs.map â NcInputField-1ujONIvp.mjs.map} +1 -1
- package/dist/chunks/{NcInputField-Dry3uU_8.cjs â NcInputField-LBv3nCrt.cjs} +8 -7
- package/dist/chunks/{NcInputField-Dry3uU_8.cjs.map â NcInputField-LBv3nCrt.cjs.map} +1 -1
- package/dist/chunks/{NcListItem-D_-a7WR9.cjs â NcListItem-DFEvD1TA.cjs} +9 -7
- package/dist/chunks/{NcListItem-D_-a7WR9.cjs.map â NcListItem-DFEvD1TA.cjs.map} +1 -1
- package/dist/chunks/{NcListItem-B3ETbT9w.mjs â NcListItem-DNMfT12A.mjs} +9 -7
- package/dist/chunks/{NcListItem-B3ETbT9w.mjs.map â NcListItem-DNMfT12A.mjs.map} +1 -1
- package/dist/chunks/{NcListItemIcon-CYR8eKOU.cjs â NcListItemIcon-OzD38-2R.cjs} +6 -5
- package/dist/chunks/{NcListItemIcon-CYR8eKOU.cjs.map â NcListItemIcon-OzD38-2R.cjs.map} +1 -1
- package/dist/chunks/{NcListItemIcon-bQZej-L0.mjs â NcListItemIcon-PNp6Wael.mjs} +6 -5
- package/dist/chunks/{NcListItemIcon-bQZej-L0.mjs.map â NcListItemIcon-PNp6Wael.mjs.map} +1 -1
- package/dist/chunks/{NcPasswordField-9LYKS0t_.mjs â NcPasswordField-D2iDTTpp.mjs} +29 -16
- package/dist/chunks/{NcPasswordField-9LYKS0t_.mjs.map â NcPasswordField-D2iDTTpp.mjs.map} +1 -1
- package/dist/chunks/{NcPasswordField-DPGGwGEl.cjs â NcPasswordField-lqTDeja4.cjs} +29 -16
- package/dist/chunks/{NcPasswordField-DPGGwGEl.cjs.map â NcPasswordField-lqTDeja4.cjs.map} +1 -1
- package/dist/chunks/{NcPopover-DkX3Esbr.cjs â NcPopover-DrXnNOgM.cjs} +14 -10
- package/dist/chunks/{NcPopover-DMUA5d7U.mjs.map â NcPopover-DrXnNOgM.cjs.map} +1 -1
- package/dist/chunks/{NcPopover-DMUA5d7U.mjs â NcPopover-nzbq2IjT.mjs} +14 -10
- package/dist/chunks/{NcPopover-DkX3Esbr.cjs.map â NcPopover-nzbq2IjT.mjs.map} +1 -1
- package/dist/chunks/{NcProgressBar-D7zYeXBH.mjs â NcProgressBar-BwnuvxiZ.mjs} +2 -2
- package/dist/chunks/{NcProgressBar-D7zYeXBH.mjs.map â NcProgressBar-BwnuvxiZ.mjs.map} +1 -1
- package/dist/chunks/{NcProgressBar-DvxA9bq5.cjs â NcProgressBar-D10gQgAY.cjs} +2 -2
- package/dist/chunks/{NcProgressBar-DvxA9bq5.cjs.map â NcProgressBar-D10gQgAY.cjs.map} +1 -1
- package/dist/chunks/{NcRadioGroup-BZ-humrK.cjs â NcRadioGroup-DsnIVQZJ.cjs} +23 -5
- package/dist/chunks/{NcRadioGroup-VKZJ0Vnh.mjs.map â NcRadioGroup-DsnIVQZJ.cjs.map} +1 -1
- package/dist/chunks/{NcRadioGroup-VKZJ0Vnh.mjs â NcRadioGroup-sZaH_3Y0.mjs} +23 -5
- package/dist/chunks/{NcRadioGroup-BZ-humrK.cjs.map â NcRadioGroup-sZaH_3Y0.mjs.map} +1 -1
- package/dist/chunks/{NcRadioGroupButton-QLL4wM7A.mjs â NcRadioGroupButton-B6m10k9G.mjs} +9 -9
- package/dist/chunks/{NcRadioGroupButton-QLL4wM7A.mjs.map â NcRadioGroupButton-B6m10k9G.mjs.map} +1 -1
- package/dist/chunks/{NcRadioGroupButton-7UZaDiJ2.cjs â NcRadioGroupButton-CDf_01-t.cjs} +9 -9
- package/dist/chunks/{NcRadioGroupButton-7UZaDiJ2.cjs.map â NcRadioGroupButton-CDf_01-t.cjs.map} +1 -1
- package/dist/chunks/{NcRelatedResourcesPanel-jvOEQWWO.mjs â NcRelatedResourcesPanel-Q6jZk-Pm.mjs} +49 -40
- package/dist/chunks/NcRelatedResourcesPanel-Q6jZk-Pm.mjs.map +1 -0
- package/dist/chunks/{NcRelatedResourcesPanel-jHQ2bRko.cjs â NcRelatedResourcesPanel-bfv-6W_Z.cjs} +50 -41
- package/dist/chunks/NcRelatedResourcesPanel-bfv-6W_Z.cjs.map +1 -0
- package/dist/chunks/{NcRichContenteditable-iQhj1-AH.mjs â NcRichContenteditable-8_poOeSx.mjs} +54 -31
- package/dist/chunks/{NcRichContenteditable-BILbjzSU.cjs.map â NcRichContenteditable-8_poOeSx.mjs.map} +1 -1
- package/dist/chunks/{NcRichContenteditable-BILbjzSU.cjs â NcRichContenteditable-CtLNSs0S.cjs} +54 -31
- package/dist/chunks/{NcRichContenteditable-iQhj1-AH.mjs.map â NcRichContenteditable-CtLNSs0S.cjs.map} +1 -1
- package/dist/chunks/{NcRichText-DYcfsH5s.cjs â NcRichText-CEsiozf5.cjs} +112 -121
- package/dist/chunks/NcRichText-CEsiozf5.cjs.map +1 -0
- package/dist/chunks/{NcRichText-B7M7rNqC.mjs â NcRichText-Dnx5x9WS.mjs} +114 -121
- package/dist/chunks/NcRichText-Dnx5x9WS.mjs.map +1 -0
- package/dist/chunks/{NcSelect-PvjbF3jF.mjs â NcSelect-TjZw7TJ_.mjs} +41 -24
- package/dist/chunks/{NcSelect-PvjbF3jF.mjs.map â NcSelect-TjZw7TJ_.mjs.map} +1 -1
- package/dist/chunks/{NcSelect-s3_u0qvy.cjs â NcSelect-bo6wla87.cjs} +41 -24
- package/dist/chunks/{NcSelect-s3_u0qvy.cjs.map â NcSelect-bo6wla87.cjs.map} +1 -1
- package/dist/chunks/{NcSelectTags-DYUCDZ_e.mjs â NcSelectTags-CytnLDOw.mjs} +52 -31
- package/dist/chunks/NcSelectTags-CytnLDOw.mjs.map +1 -0
- package/dist/chunks/{NcSelectTags-e4Gjcx_7.cjs â NcSelectTags-D2OSaAfO.cjs} +52 -31
- package/dist/chunks/NcSelectTags-D2OSaAfO.cjs.map +1 -0
- package/dist/chunks/{NcSelectUsers-CMF_h9c0.mjs â NcSelectUsers-Bm0877Tm.mjs} +7 -6
- package/dist/chunks/{NcSelectUsers-CMF_h9c0.mjs.map â NcSelectUsers-Bm0877Tm.mjs.map} +1 -1
- package/dist/chunks/{NcSelectUsers-Bmwhu14K.cjs â NcSelectUsers-wcRyExkC.cjs} +7 -6
- package/dist/chunks/{NcSelectUsers-Bmwhu14K.cjs.map â NcSelectUsers-wcRyExkC.cjs.map} +1 -1
- package/dist/chunks/{NcSettingsInputText-BQVh24zT.mjs â NcSettingsInputText-DPAtsY2T.mjs} +3 -3
- package/dist/chunks/{NcSettingsInputText-BQVh24zT.mjs.map â NcSettingsInputText-DPAtsY2T.mjs.map} +1 -1
- package/dist/chunks/{NcSettingsInputText-DWihH7ke.cjs â NcSettingsInputText-DaFMiOS6.cjs} +3 -3
- package/dist/chunks/{NcSettingsInputText-DWihH7ke.cjs.map â NcSettingsInputText-DaFMiOS6.cjs.map} +1 -1
- package/dist/chunks/{NcSettingsSection-evNvfEg2.mjs â NcSettingsSection-CX5q924g.mjs} +4 -3
- package/dist/chunks/{NcSettingsSection-evNvfEg2.mjs.map â NcSettingsSection-CX5q924g.mjs.map} +1 -1
- package/dist/chunks/{NcSettingsSection-Dgc7SEuu.cjs â NcSettingsSection-r4NOxKIz.cjs} +4 -3
- package/dist/chunks/{NcSettingsSection-Dgc7SEuu.cjs.map â NcSettingsSection-r4NOxKIz.cjs.map} +1 -1
- package/dist/chunks/{NcSettingsSelectGroup-C-YAk1f8.mjs â NcSettingsSelectGroup-CR4XLrgs.mjs} +25 -9
- package/dist/chunks/{NcSettingsSelectGroup-C-YAk1f8.mjs.map â NcSettingsSelectGroup-CR4XLrgs.mjs.map} +1 -1
- package/dist/chunks/{NcSettingsSelectGroup-X1pBwmAZ.cjs â NcSettingsSelectGroup-DYYAPkgp.cjs} +25 -9
- package/dist/chunks/{NcSettingsSelectGroup-X1pBwmAZ.cjs.map â NcSettingsSelectGroup-DYYAPkgp.cjs.map} +1 -1
- package/dist/chunks/{NcTextArea-DHmD6-6s.mjs â NcTextArea-If_ygOSv.mjs} +5 -5
- package/dist/chunks/{NcTextArea-DHmD6-6s.mjs.map â NcTextArea-If_ygOSv.mjs.map} +1 -1
- package/dist/chunks/{NcTextArea-DkVtHTpD.cjs â NcTextArea-iDhGI-Ko.cjs} +5 -5
- package/dist/chunks/{NcTextArea-DkVtHTpD.cjs.map â NcTextArea-iDhGI-Ko.cjs.map} +1 -1
- package/dist/chunks/{NcTextField-D_IMz2MR.mjs â NcTextField-BE9R1pLt.mjs} +31 -17
- package/dist/chunks/{NcTextField-D_IMz2MR.mjs.map â NcTextField-BE9R1pLt.mjs.map} +1 -1
- package/dist/chunks/{NcTextField-Cp3tulze.cjs â NcTextField-OPiMgNR7.cjs} +31 -17
- package/dist/chunks/{NcTextField-Cp3tulze.cjs.map â NcTextField-OPiMgNR7.cjs.map} +1 -1
- package/dist/chunks/{NcThemeProvider-BqGPTeWg.cjs â NcThemeProvider-DbNRSwkX.cjs} +2 -2
- package/dist/chunks/{NcThemeProvider-BqGPTeWg.cjs.map â NcThemeProvider-DbNRSwkX.cjs.map} +1 -1
- package/dist/chunks/{NcThemeProvider-25ResoIv.mjs â NcThemeProvider-E_S5rhIQ.mjs} +2 -2
- package/dist/chunks/{NcThemeProvider-25ResoIv.mjs.map â NcThemeProvider-E_S5rhIQ.mjs.map} +1 -1
- package/dist/chunks/{NcTimezonePicker-Cu1FrSIX.mjs â NcTimezonePicker-D4y736xC.mjs} +5 -5
- package/dist/chunks/{NcTimezonePicker-Cu1FrSIX.mjs.map â NcTimezonePicker-D4y736xC.mjs.map} +1 -1
- package/dist/chunks/{NcTimezonePicker-Co7jDP7N.cjs â NcTimezonePicker-DPpWz5fa.cjs} +5 -5
- package/dist/chunks/{NcTimezonePicker-Co7jDP7N.cjs.map â NcTimezonePicker-DPpWz5fa.cjs.map} +1 -1
- package/dist/chunks/{NcUserBubble-Be2B8iJY.mjs â NcUserBubble-8Mts76ii.mjs} +7 -6
- package/dist/chunks/{NcUserBubble-Be2B8iJY.mjs.map â NcUserBubble-8Mts76ii.mjs.map} +1 -1
- package/dist/chunks/{NcUserBubble-CdX6H9-M.cjs â NcUserBubble-Bb9WBP1S.cjs} +7 -6
- package/dist/chunks/{NcUserBubble-CdX6H9-M.cjs.map â NcUserBubble-Bb9WBP1S.cjs.map} +1 -1
- package/dist/chunks/{NcUserStatusIcon-C83nB_8T.mjs â NcUserStatusIcon-BWxo_etm.mjs} +11 -8
- package/dist/chunks/{NcUserStatusIcon-C83nB_8T.mjs.map â NcUserStatusIcon-BWxo_etm.mjs.map} +1 -1
- package/dist/chunks/{NcUserStatusIcon-DhZabBIY.cjs â NcUserStatusIcon-DV2H-KfR.cjs} +11 -8
- package/dist/chunks/{NcUserStatusIcon-DhZabBIY.cjs.map â NcUserStatusIcon-DV2H-KfR.cjs.map} +1 -1
- package/dist/chunks/{ScopeComponent-9wtS_FpN.cjs â ScopeComponent-CDX-s-IV.cjs} +2 -2
- package/dist/chunks/{ScopeComponent-9wtS_FpN.cjs.map â ScopeComponent-CDX-s-IV.cjs.map} +1 -1
- package/dist/chunks/{ScopeComponent-305QOaqN.mjs â ScopeComponent-DsONbC6w.mjs} +2 -2
- package/dist/chunks/{ScopeComponent-305QOaqN.mjs.map â ScopeComponent-DsONbC6w.mjs.map} +1 -1
- package/dist/chunks/{_l10n-DM-VRK9x.cjs â _l10n-9b4TMo5Q.cjs} +2 -6
- package/dist/chunks/{_l10n-DM-VRK9x.cjs.map â _l10n-9b4TMo5Q.cjs.map} +1 -1
- package/dist/chunks/{_l10n-BEfeU7gr.mjs â _l10n-DSLCwJSN.mjs} +41 -45
- package/dist/chunks/_l10n-DSLCwJSN.mjs.map +1 -0
- package/dist/chunks/{actionText-D2-z0ud3.cjs â actionText-D_3-6fCH.cjs} +2 -2
- package/dist/chunks/{actionText-D2-z0ud3.cjs.map â actionText-D_3-6fCH.cjs.map} +1 -1
- package/dist/chunks/{actionText-BMig9Egt.mjs â actionText-ZM1k96ts.mjs} +2 -2
- package/dist/chunks/{actionText-BMig9Egt.mjs.map â actionText-ZM1k96ts.mjs.map} +1 -1
- package/dist/chunks/{GenColors-DIH749TS.mjs â colors-BMiIMYXK.mjs} +42 -48
- package/dist/chunks/colors-BMiIMYXK.mjs.map +1 -0
- package/dist/chunks/{GenColors-BVouTbTJ.cjs â colors-DcbJ13is.cjs} +41 -47
- package/dist/chunks/colors-DcbJ13is.cjs.map +1 -0
- package/dist/chunks/createElementId-5skgwxOP.mjs +9 -0
- package/dist/chunks/{createElementId-DhjFt1I9.mjs.map â createElementId-5skgwxOP.mjs.map} +1 -1
- package/dist/chunks/createElementId-DaJhnLzq.cjs +8 -0
- package/dist/chunks/{createElementId-lalylSCf.cjs.map â createElementId-DaJhnLzq.cjs.map} +1 -1
- package/dist/chunks/{customPickerElements-DLFtgReB.mjs â customPickerElements-BPROmh4T.mjs} +43 -21
- package/dist/chunks/{customPickerElements-DLFtgReB.mjs.map â customPickerElements-BPROmh4T.mjs.map} +1 -1
- package/dist/chunks/{customPickerElements-GyIIOHiQ.cjs â customPickerElements-DBEOrbce.cjs} +43 -21
- package/dist/chunks/{customPickerElements-GyIIOHiQ.cjs.map â customPickerElements-DBEOrbce.cjs.map} +1 -1
- package/dist/chunks/{emoji-VgSjNTd5.cjs â emoji-BCCCB3t3.cjs} +4 -3
- package/dist/chunks/{emoji-VgSjNTd5.cjs.map â emoji-BCCCB3t3.cjs.map} +1 -1
- package/dist/chunks/{emoji-BY_D0V5K.mjs â emoji-V6ytyzoR.mjs} +4 -3
- package/dist/chunks/{emoji-BY_D0V5K.mjs.map â emoji-V6ytyzoR.mjs.map} +1 -1
- package/dist/chunks/{focusTrap-HJQ4pqHV.mjs â focusTrap-BibOtksr.mjs} +3 -2
- package/dist/chunks/{focusTrap-DUTqW_IG.cjs.map â focusTrap-BibOtksr.mjs.map} +1 -1
- package/dist/chunks/{focusTrap-DUTqW_IG.cjs â focusTrap-DhhUL4JZ.cjs} +3 -2
- package/dist/chunks/{focusTrap-HJQ4pqHV.mjs.map â focusTrap-DhhUL4JZ.cjs.map} +1 -1
- package/dist/chunks/getAvatarUrl-C8Q41hfR.mjs +16 -0
- package/dist/chunks/{getAvatarUrl-IhLacDEr.mjs.map â getAvatarUrl-C8Q41hfR.mjs.map} +1 -1
- package/dist/chunks/getAvatarUrl-DwWyuiUZ.cjs +15 -0
- package/dist/chunks/{getAvatarUrl-Du9Y3cPO.cjs.map â getAvatarUrl-DwWyuiUZ.cjs.map} +1 -1
- package/dist/chunks/{index-TmAR7I2T.mjs â index-BsEMR4S4.mjs} +9 -9
- package/dist/chunks/{index-TmAR7I2T.mjs.map â index-BsEMR4S4.mjs.map} +1 -1
- package/dist/chunks/{index-Dr9k4hIP.cjs â index-CmwBGDjr.cjs} +22 -4
- package/dist/chunks/{index-CxTT94_h.mjs.map â index-CmwBGDjr.cjs.map} +1 -1
- package/dist/chunks/{index-CgkN1xho.cjs â index-D_jGr37E.cjs} +9 -9
- package/dist/chunks/{index-CgkN1xho.cjs.map â index-D_jGr37E.cjs.map} +1 -1
- package/dist/chunks/{index-CxTT94_h.mjs â index-JArK0Dbx.mjs} +22 -4
- package/dist/chunks/{index-Dr9k4hIP.cjs.map â index-JArK0Dbx.mjs.map} +1 -1
- package/dist/chunks/legacy-DUgfmdiS.cjs +6 -0
- package/dist/chunks/{legacy-MK4GvP26.mjs.map â legacy-DUgfmdiS.cjs.map} +1 -1
- package/dist/chunks/legacy-NU_qxPFK.mjs +7 -0
- package/dist/chunks/{legacy-KBXhWdRy.cjs.map â legacy-NU_qxPFK.mjs.map} +1 -1
- package/dist/chunks/{mdi-DXu6GWVJ.mjs â mdi-CKSXwCsV.mjs} +8 -6
- package/dist/chunks/{mdi-DXu6GWVJ.mjs.map â mdi-CKSXwCsV.mjs.map} +1 -1
- package/dist/chunks/{mdi-BBwE-MZC.cjs â mdi-Nhb6SBw8.cjs} +3 -1
- package/dist/chunks/{mdi-BBwE-MZC.cjs.map â mdi-Nhb6SBw8.cjs.map} +1 -1
- package/dist/chunks/{referencePickerModal-BcAnnsxZ.cjs â referencePickerModal-CusxgEsK.cjs} +66 -35
- package/dist/chunks/referencePickerModal-CusxgEsK.cjs.map +1 -0
- package/dist/chunks/{referencePickerModal-CN4C9eDc.mjs â referencePickerModal-DpJUQ5fq.mjs} +66 -35
- package/dist/chunks/referencePickerModal-DpJUQ5fq.mjs.map +1 -0
- package/dist/chunks/useAppSettingsDialog-CPqmms-u.cjs +9 -0
- package/dist/chunks/useAppSettingsDialog-CPqmms-u.cjs.map +1 -0
- package/dist/chunks/useAppSettingsDialog-Dn48dw1k.mjs +10 -0
- package/dist/chunks/useAppSettingsDialog-Dn48dw1k.mjs.map +1 -0
- package/dist/chunks/{useModelMigration-EhAWvqDD.mjs â useModelMigration-DBUi8saj.mjs} +2 -2
- package/dist/chunks/useModelMigration-DBUi8saj.mjs.map +1 -0
- package/dist/chunks/{useModelMigration-D5zhrNXr.cjs â useModelMigration-HPf30klj.cjs} +2 -2
- package/dist/chunks/useModelMigration-HPf30klj.cjs.map +1 -0
- package/dist/chunks/{useTrapStackControl-BnLfCgGU.mjs â useTrapStackControl-2gEo3rvr.mjs} +2 -2
- package/dist/chunks/{useTrapStackControl-BnLfCgGU.mjs.map â useTrapStackControl-2gEo3rvr.mjs.map} +1 -1
- package/dist/chunks/{useTrapStackControl-XYABY64G.cjs â useTrapStackControl-dthvITlQ.cjs} +2 -2
- package/dist/chunks/{useTrapStackControl-XYABY64G.cjs.map â useTrapStackControl-dthvITlQ.cjs.map} +1 -1
- package/dist/components/NcAppSettingsDialog/index.d.ts +5 -0
- package/dist/components/NcAppSettingsDialog/useAppSettingsDialog.d.ts +24 -0
- package/dist/components/NcColorPicker/index.d.ts +5 -0
- package/dist/composables/index.d.ts +9 -0
- package/dist/composables/useHotKey/index.d.ts +4 -2
- package/dist/composables/useIsMobile/index.d.ts +23 -0
- package/dist/composables/useModelMigration.d.ts +1 -1
- package/dist/index.cjs +67 -67
- package/dist/index.mjs +67 -67
- package/dist/utils/colors.d.ts +36 -0
- package/package.json +10 -10
- package/dist/chunks/GenColors-BVouTbTJ.cjs.map +0 -1
- package/dist/chunks/GenColors-DIH749TS.mjs.map +0 -1
- package/dist/chunks/NcAppContent-C9NGJE6n.mjs.map +0 -1
- package/dist/chunks/NcAppContent-Djy38ou2.cjs.map +0 -1
- package/dist/chunks/NcAppSettingsDialog-DVFw09eD.mjs +0 -223
- package/dist/chunks/NcAppSettingsDialog-DVFw09eD.mjs.map +0 -1
- package/dist/chunks/NcAppSettingsDialog-DalEoC9H.cjs +0 -225
- package/dist/chunks/NcAppSettingsDialog-DalEoC9H.cjs.map +0 -1
- package/dist/chunks/NcAvatar-CuYtFEdJ.mjs.map +0 -1
- package/dist/chunks/NcAvatar-bd-5zXWN.cjs.map +0 -1
- package/dist/chunks/NcColorPicker-Cae6XNoK.mjs +0 -255
- package/dist/chunks/NcColorPicker-Cae6XNoK.mjs.map +0 -1
- package/dist/chunks/NcColorPicker-D-E2dT4Q.cjs +0 -254
- package/dist/chunks/NcColorPicker-D-E2dT4Q.cjs.map +0 -1
- package/dist/chunks/NcEmojiPicker-B2SLfIBu.mjs.map +0 -1
- package/dist/chunks/NcEmojiPicker-q_n1Rd8U.cjs.map +0 -1
- package/dist/chunks/NcRelatedResourcesPanel-jHQ2bRko.cjs.map +0 -1
- package/dist/chunks/NcRelatedResourcesPanel-jvOEQWWO.mjs.map +0 -1
- package/dist/chunks/NcRichText-B7M7rNqC.mjs.map +0 -1
- package/dist/chunks/NcRichText-DYcfsH5s.cjs.map +0 -1
- package/dist/chunks/NcSelectTags-DYUCDZ_e.mjs.map +0 -1
- package/dist/chunks/NcSelectTags-e4Gjcx_7.cjs.map +0 -1
- package/dist/chunks/_l10n-BEfeU7gr.mjs.map +0 -1
- package/dist/chunks/createElementId-DhjFt1I9.mjs +0 -8
- package/dist/chunks/createElementId-lalylSCf.cjs +0 -7
- package/dist/chunks/getAvatarUrl-Du9Y3cPO.cjs +0 -14
- package/dist/chunks/getAvatarUrl-IhLacDEr.mjs +0 -15
- package/dist/chunks/legacy-KBXhWdRy.cjs +0 -5
- package/dist/chunks/legacy-MK4GvP26.mjs +0 -6
- package/dist/chunks/referencePickerModal-BcAnnsxZ.cjs.map +0 -1
- package/dist/chunks/referencePickerModal-CN4C9eDc.mjs.map +0 -1
- package/dist/chunks/useModelMigration-D5zhrNXr.cjs.map +0 -1
- package/dist/chunks/useModelMigration-EhAWvqDD.mjs.map +0 -1
|
@@ -1,34 +1,34 @@
|
|
|
1
1
|
import '../assets/NcMentionBubble-CaztX9Pv.css';
|
|
2
|
-
import '../assets/NcAvatar-
|
|
2
|
+
import '../assets/NcAvatar-Cm4kVIfS.css';
|
|
3
3
|
import { getCurrentUser } from "@nextcloud/auth";
|
|
4
4
|
import axios from "@nextcloud/axios";
|
|
5
5
|
import { getBuilder } from "@nextcloud/browser-storage";
|
|
6
6
|
import { unsubscribe, subscribe } from "@nextcloud/event-bus";
|
|
7
7
|
import { generateOcsUrl, generateUrl } from "@nextcloud/router";
|
|
8
8
|
import { vOnClickOutside } from "@vueuse/components";
|
|
9
|
-
import { N as NcActions, D as DotsHorizontalIcon } from "./NcActions-
|
|
9
|
+
import { N as NcActions, D as DotsHorizontalIcon } from "./NcActions-A918mfXE.mjs";
|
|
10
10
|
import { g as getRoute } from "./autolink-D2pIbi92.mjs";
|
|
11
11
|
import { useIsDarkTheme } from "../Composables/useIsDarkTheme.mjs";
|
|
12
12
|
import { getEnabledContactsMenuActions } from "../Functions/contactsMenu.mjs";
|
|
13
13
|
import { usernameToColor } from "../Functions/usernameToColor.mjs";
|
|
14
|
-
import { r as register,
|
|
14
|
+
import { r as register, s as t10, a as t } from "./_l10n-DSLCwJSN.mjs";
|
|
15
15
|
import "../Composables/useIsFullscreen.mjs";
|
|
16
16
|
import "../Composables/useIsMobile.mjs";
|
|
17
17
|
import "escape-html";
|
|
18
18
|
import "striptags";
|
|
19
19
|
import "vue";
|
|
20
|
-
import { g as getAvatarUrl } from "./getAvatarUrl-
|
|
20
|
+
import { g as getAvatarUrl } from "./getAvatarUrl-C8Q41hfR.mjs";
|
|
21
21
|
/* empty css */
|
|
22
22
|
import { n as normalizeComponent } from "./_plugin-vue2_normalizer-DU4iP6Vu.mjs";
|
|
23
23
|
import { getCapabilities } from "@nextcloud/capabilities";
|
|
24
24
|
import { l as logger } from "./logger-D3RVzcfQ.mjs";
|
|
25
|
-
import { N as NcUserStatusIcon, g as getUserStatusText } from "./NcUserStatusIcon-
|
|
26
|
-
import { N as NcActionButton } from "./NcActionButton-
|
|
25
|
+
import { N as NcUserStatusIcon, g as getUserStatusText } from "./NcUserStatusIcon-BWxo_etm.mjs";
|
|
26
|
+
import { N as NcActionButton } from "./NcActionButton-CZsSFAT4.mjs";
|
|
27
27
|
import NcActionLink from "../Components/NcActionLink.mjs";
|
|
28
28
|
import NcActionRouter from "../Components/NcActionRouter.mjs";
|
|
29
29
|
import NcActionText from "../Components/NcActionText.mjs";
|
|
30
|
-
import { N as NcButton } from "./NcButton-
|
|
31
|
-
import { N as NcIconSvgWrapper } from "./NcIconSvgWrapper-
|
|
30
|
+
import { N as NcButton } from "./NcButton-D3CaJu1f.mjs";
|
|
31
|
+
import { N as NcIconSvgWrapper } from "./NcIconSvgWrapper-BCVwmZN2.mjs";
|
|
32
32
|
import NcLoadingIcon from "../Components/NcLoadingIcon.mjs";
|
|
33
33
|
register(t10);
|
|
34
34
|
const userStatus = {
|
|
@@ -51,6 +51,7 @@ const userStatus = {
|
|
|
51
51
|
* @return {Promise<void>}
|
|
52
52
|
*/
|
|
53
53
|
async fetchUserStatus(userId) {
|
|
54
|
+
var _a, _b;
|
|
54
55
|
if (!userId) {
|
|
55
56
|
return;
|
|
56
57
|
}
|
|
@@ -72,11 +73,11 @@ const userStatus = {
|
|
|
72
73
|
this.userStatus.message = message || "";
|
|
73
74
|
this.userStatus.icon = icon || "";
|
|
74
75
|
this.hasStatus = true;
|
|
75
|
-
} catch (
|
|
76
|
-
if (
|
|
76
|
+
} catch (error) {
|
|
77
|
+
if (error.response.status === 404 && ((_b = (_a = error.response.data.ocs) == null ? void 0 : _a.data) == null ? void 0 : _b.length) === 0) {
|
|
77
78
|
return;
|
|
78
79
|
}
|
|
79
|
-
logger.error(
|
|
80
|
+
logger.error("Could not fetch user status", { error });
|
|
80
81
|
}
|
|
81
82
|
}
|
|
82
83
|
}
|
|
@@ -278,13 +279,14 @@ const _sfc_main = {
|
|
|
278
279
|
},
|
|
279
280
|
computed: {
|
|
280
281
|
avatarAriaLabel() {
|
|
282
|
+
var _a, _b;
|
|
281
283
|
if (!this.hasMenu) {
|
|
282
284
|
return;
|
|
283
285
|
}
|
|
284
286
|
if (this.canDisplayUserStatus || this.showUserStatusIconOnAvatar) {
|
|
285
|
-
return t("Avatar of {displayName}, {status}", { displayName: this.displayName
|
|
287
|
+
return t("Avatar of {displayName}, {status}", { displayName: (_a = this.displayName) != null ? _a : this.user, status: getUserStatusText(this.userStatus.status) });
|
|
286
288
|
}
|
|
287
|
-
return t("Avatar of {displayName}", { displayName: this.displayName
|
|
289
|
+
return t("Avatar of {displayName}", { displayName: (_b = this.displayName) != null ? _b : this.user });
|
|
288
290
|
},
|
|
289
291
|
canDisplayUserStatus() {
|
|
290
292
|
return !this.hideStatus && this.showUserStatus && this.hasStatus && ["online", "away", "busy", "dnd"].includes(this.userStatus.status);
|
|
@@ -315,13 +317,14 @@ const _sfc_main = {
|
|
|
315
317
|
return typeof this.url !== "undefined";
|
|
316
318
|
},
|
|
317
319
|
hasMenu() {
|
|
320
|
+
var _a;
|
|
318
321
|
if (this.disableMenu) {
|
|
319
322
|
return false;
|
|
320
323
|
}
|
|
321
324
|
if (this.isMenuLoaded) {
|
|
322
325
|
return this.menu.length > 0;
|
|
323
326
|
}
|
|
324
|
-
return !(this.user === getCurrentUser()
|
|
327
|
+
return !(this.user === ((_a = getCurrentUser()) == null ? void 0 : _a.uid) || this.userDoesNotExist || this.url);
|
|
325
328
|
},
|
|
326
329
|
/**
|
|
327
330
|
* True if initials should be shown as the user icon fallback
|
|
@@ -339,13 +342,13 @@ const _sfc_main = {
|
|
|
339
342
|
initialsWrapperStyle() {
|
|
340
343
|
const { r, g, b } = usernameToColor(this.userIdentifier);
|
|
341
344
|
return {
|
|
342
|
-
backgroundColor:
|
|
345
|
+
backgroundColor: "rgba(".concat(r, ", ").concat(g, ", ").concat(b, ", 0.1)")
|
|
343
346
|
};
|
|
344
347
|
},
|
|
345
348
|
initialsStyle() {
|
|
346
349
|
const { r, g, b } = usernameToColor(this.userIdentifier);
|
|
347
350
|
return {
|
|
348
|
-
color:
|
|
351
|
+
color: "rgb(".concat(r, ", ").concat(g, ", ").concat(b, ")")
|
|
349
352
|
};
|
|
350
353
|
},
|
|
351
354
|
tooltip() {
|
|
@@ -367,7 +370,7 @@ const _sfc_main = {
|
|
|
367
370
|
if (user === "") {
|
|
368
371
|
return initials;
|
|
369
372
|
}
|
|
370
|
-
const filteredChars = user.match(
|
|
373
|
+
const filteredChars = user.match(new RegExp("[\\p{L}\\p{N}\\s]", "gu"));
|
|
371
374
|
if (!filteredChars) {
|
|
372
375
|
return initials;
|
|
373
376
|
}
|
|
@@ -407,7 +410,7 @@ const _sfc_main = {
|
|
|
407
410
|
iconSvg: action.iconSvg(this.contactsMenuData)
|
|
408
411
|
});
|
|
409
412
|
} catch (error) {
|
|
410
|
-
logger.error(
|
|
413
|
+
logger.error("Failed to render ContactsMenu action ".concat(action.id), {
|
|
411
414
|
error,
|
|
412
415
|
action
|
|
413
416
|
});
|
|
@@ -420,14 +423,12 @@ const _sfc_main = {
|
|
|
420
423
|
return p.innerHTML;
|
|
421
424
|
}
|
|
422
425
|
if (!this.hideStatus && this.showUserStatus && (this.userStatus.icon || this.userStatus.message)) {
|
|
423
|
-
const emojiIcon =
|
|
424
|
-
<text x="50%" y="50%" text-anchor="middle" style="dominant-baseline: central; font-size: 85%">${escape(this.userStatus.icon)}</text>
|
|
425
|
-
</svg>`;
|
|
426
|
+
const emojiIcon = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16">\n <text x="50%" y="50%" text-anchor="middle" style="dominant-baseline: central; font-size: 85%">'.concat(escape(this.userStatus.icon), "</text>\n </svg>");
|
|
426
427
|
return [{
|
|
427
428
|
ncActionComponent: NcActionText,
|
|
428
429
|
ncActionComponentProps: {},
|
|
429
430
|
iconSvg: this.userStatus.icon ? emojiIcon : void 0,
|
|
430
|
-
text:
|
|
431
|
+
text: "".concat(this.userStatus.message)
|
|
431
432
|
}].concat(actions);
|
|
432
433
|
}
|
|
433
434
|
return actions;
|
|
@@ -498,10 +499,10 @@ const _sfc_main = {
|
|
|
498
499
|
this.contactsMenuLoading = true;
|
|
499
500
|
try {
|
|
500
501
|
const user = encodeURIComponent(this.user);
|
|
501
|
-
const { data } = await axios.post(generateUrl("contactsmenu/findOne"),
|
|
502
|
+
const { data } = await axios.post(generateUrl("contactsmenu/findOne"), "shareType=0&shareWith=".concat(user));
|
|
502
503
|
this.contactsMenuData = data;
|
|
503
504
|
this.contactsMenuActions = data.topAction ? [data.topAction].concat(data.actions) : data.actions;
|
|
504
|
-
} catch {
|
|
505
|
+
} catch (e) {
|
|
505
506
|
this.contactsMenuOpenState = false;
|
|
506
507
|
}
|
|
507
508
|
this.contactsMenuLoading = false;
|
|
@@ -541,12 +542,13 @@ const _sfc_main = {
|
|
|
541
542
|
* @return {string}
|
|
542
543
|
*/
|
|
543
544
|
avatarUrlGenerator(user, size) {
|
|
545
|
+
var _a;
|
|
544
546
|
let avatarUrl = getAvatarUrl(user, {
|
|
545
547
|
size,
|
|
546
548
|
isDarkTheme: this.isDarkTheme,
|
|
547
549
|
isGuest: this.isGuest
|
|
548
550
|
});
|
|
549
|
-
if (user === getCurrentUser()
|
|
551
|
+
if (user === ((_a = getCurrentUser()) == null ? void 0 : _a.uid) && typeof window.oc_userconfig !== "undefined") {
|
|
550
552
|
avatarUrl += "?v=" + window.oc_userconfig.avatar.version;
|
|
551
553
|
}
|
|
552
554
|
return avatarUrl;
|
|
@@ -579,8 +581,8 @@ const _sfc_main = {
|
|
|
579
581
|
this.isAvatarLoaded = true;
|
|
580
582
|
setUserHasAvatar(this.user, true);
|
|
581
583
|
};
|
|
582
|
-
img.onerror = () => {
|
|
583
|
-
logger.debug("Invalid avatar url", url);
|
|
584
|
+
img.onerror = (error) => {
|
|
585
|
+
logger.debug("Invalid avatar url", { error, url });
|
|
584
586
|
this.avatarUrlLoaded = null;
|
|
585
587
|
this.avatarSrcSetLoaded = null;
|
|
586
588
|
this.userDoesNotExist = true;
|
|
@@ -621,11 +623,11 @@ var __component__ = /* @__PURE__ */ normalizeComponent(
|
|
|
621
623
|
_sfc_staticRenderFns,
|
|
622
624
|
false,
|
|
623
625
|
null,
|
|
624
|
-
"
|
|
626
|
+
"936fbce2"
|
|
625
627
|
);
|
|
626
628
|
const NcAvatar = __component__.exports;
|
|
627
629
|
export {
|
|
628
630
|
NcAvatar as N,
|
|
629
631
|
userStatus as u
|
|
630
632
|
};
|
|
631
|
-
//# sourceMappingURL=NcAvatar-
|
|
633
|
+
//# sourceMappingURL=NcAvatar-Cupl4prm.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NcAvatar-Cupl4prm.mjs","sources":["../../src/mixins/userStatus.js","../../src/components/NcAvatar/NcAvatar.vue"],"sourcesContent":["/**\n * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\n\nimport { getCurrentUser } from '@nextcloud/auth'\nimport axios from '@nextcloud/axios'\nimport { getCapabilities } from '@nextcloud/capabilities'\nimport { generateOcsUrl } from '@nextcloud/router'\nimport { logger } from '../utils/logger.ts'\n\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\thasStatus: false,\n\t\t\tuserStatus: {\n\t\t\t\tstatus: null,\n\t\t\t\tmessage: null,\n\t\t\t\ticon: null,\n\t\t\t},\n\t\t}\n\t},\n\tmethods: {\n\t\t/**\n\t\t * Fetches the user-status from the server\n\t\t *\n\t\t * @param {string} userId UserId of the user to fetch the status for\n\t\t *\n\t\t * @return {Promise<void>}\n\t\t */\n\t\tasync fetchUserStatus(userId) {\n\t\t\tif (!userId) {\n\t\t\t\treturn\n\t\t\t}\n\t\t\tconst capabilities = getCapabilities()\n\t\t\tif (!Object.hasOwn(capabilities, 'user_status') || !capabilities.user_status.enabled) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\t// User status endpoint is not available for guests.\n\t\t\tif (!getCurrentUser()) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\ttry {\n\t\t\t\tconst { data } = await axios.get(generateOcsUrl('apps/user_status/api/v1/statuses/{userId}', { userId }))\n\t\t\t\tconst {\n\t\t\t\t\tstatus,\n\t\t\t\t\tmessage,\n\t\t\t\t\ticon,\n\t\t\t\t} = data.ocs.data\n\t\t\t\tthis.userStatus.status = status\n\t\t\t\tthis.userStatus.message = message || ''\n\t\t\t\tthis.userStatus.icon = icon || ''\n\t\t\t\tthis.hasStatus = true\n\t\t\t} catch (error) {\n\t\t\t\tif (error.response.status === 404 && error.response.data.ocs?.data?.length === 0) {\n\t\t\t\t\t// User just has no status set, so don't log it\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\tlogger.error('Could not fetch user status', { error })\n\t\t\t}\n\t\t},\n\t},\n}\n","<!--\n - SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n\n### Basic user avatar\n\n```vue\n\t<NcAvatar user=\"willywonka\" display-name=\"Willy Wonka\" />\n```\n\n### Avatar with image\n\n```vue\n\t<NcAvatar url=\"favicon-touch.png\" />\n```\n\n### Avatar with material design icon\n\n```\n<template>\n\t<NcAvatar>\n\t\t<template #icon>\n\t\t\t<AccountMultiple :size=\"20\" />\n\t\t</template>\n\t</NcAvatar>\n</template>\n<script>\nimport AccountMultiple from 'vue-material-design-icons/AccountMultiple.vue'\n\nexport default {\n\tcomponents: {\n\t\tAccountMultiple,\n\t},\n}\n</script>\n```\n\n### Avatar with preloaded status\n```\n<template>\n\t<div>\n\t\t<NcAvatar user=\"janedoe\"\n\t\t\tdisplay-name=\"Jane Doe\"\n\t\t\t:preloaded-user-status=\"status.online\">\n\t\t</NcAvatar>\n\t\t<NcAvatar user=\"janedoe\"\n\t\t\tdisplay-name=\"Jane Doe\"\n\t\t\t:preloaded-user-status=\"status.away\">\n\t\t</NcAvatar>\n\t\t<NcAvatar user=\"janedoe\"\n\t\t\tdisplay-name=\"Jane Doe\"\n\t\t\t:preloaded-user-status=\"status.dnd\">\n\t\t</NcAvatar>\n\t\t<NcAvatar user=\"janedoe\"\n\t\t\tdisplay-name=\"Jane Doe\"\n\t\t\t:preloaded-user-status=\"status.custom\">\n\t\t</NcAvatar>\n\t</div>\n</template>\n\n<script>\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\tstatus: {\n\t\t\t\tonline: {\n\t\t\t\t\ticon: '',\n\t\t\t\t\tstatus: 'online',\n\t\t\t\t\tmessage: 'Available',\n\t\t\t\t},\n\t\t\t\taway: {\n\t\t\t\t\ticon: '',\n\t\t\t\t\tstatus: 'away',\n\t\t\t\t\tmessage: 'Away',\n\t\t\t\t},\n\t\t\t\tdnd: {\n\t\t\t\t\ticon: '',\n\t\t\t\t\tstatus: 'dnd',\n\t\t\t\t\tmessage: 'Busy',\n\t\t\t\t},\n\t\t\t\tcustom: {\n\t\t\t\t\ticon: 'đ',\n\t\t\t\t\tstatus: 'online',\n\t\t\t\t\tmessage: 'In a meeting',\n\t\t\t\t}\n\t\t\t},\n\t\t}\n\t},\n}\n</script>\n```\n\n### Avatar for non-users\n\n```vue\n\t<NcAvatar display-name=\"Robbie Hyeon-Jeong\" :is-no-user=\"true\" />\n```\n\n### Avatar on complex background\n\n```\n<template>\n\t<div class=\"avatar-background\">\n\t\t<NcAvatar class=\"avatar\" :is-no-user=\"true\" display-name=\"Cecilia Rohese\" />\n\t</div>\n</template>\n<style scoped>\n.avatar-background {\n\twidth: 80px;\n\theight: 60px;\n\tbackground: linear-gradient(to bottom, #0057b8 0%, #0057b8 49.99%, #ffd700 50%, #ffd700 100%);\n}\n\n.avatar {\n\tmargin: 15px 25px;\n}\n</style>\n```\n\n### Avatar size\n\n```vue\n<template>\n\t<div>\n\t\t<div v-for=\"size in [15, 24, 34, 44, 180]\">\n\t\t\t<span>\n\t\t\t\t{{ size }}px\n\t\t\t</span>\n\t\t\t<NcAvatar user=\"alice-smith\"\n\t\t\t\tdisplay-name=\"Alice Smith\"\n\t\t\t\t:size=\"size\"\n\t\t\t\t:preloaded-user-status=\"status.online\" />\n\t\t\t<NcAvatar user=\"bob-doe\"\n\t\t\t\tdisplay-name=\"Bob Doe\"\n\t\t\t\t:size=\"size\"\n\t\t\t\t:preloaded-user-status=\"status.meeting\" />\n\t\t</div>\n\t\t<div>\n\t\t\t<div>\n\t\t\t\tCustom: {{ customSize }}px\n\t\t\t</div>\n\t\t\t<NcAvatar user=\"alice-smith\"\n\t\t\t\tdisplay-name=\"Alice Smith\"\n\t\t\t\t:size=\"customSize\"\n\t\t\t\t:preloaded-user-status=\"status.online\" />\n\t\t\t<NcAvatar user=\"bob-doe\"\n\t\t\t\tdisplay-name=\"Bob Doe\"\n\t\t\t\t:size=\"customSize\"\n\t\t\t\t:preloaded-user-status=\"status.meeting\" />\n\t\t</div>\n\t\t<div>\n\t\t\t<input type=\"range\" v-model=\"customSize\" :min=\"15\" :max=\"180\" step=\"1\" />\n\t\t</div>\n\t</div>\n</template>\n\n<script>\nimport AccountMultiple from 'vue-material-design-icons/AccountMultiple.vue'\n\nexport default {\n\tcomponents: {\n\t\tAccountMultiple,\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tcustomSize: 20,\n\t\t\tstatus: {\n\t\t\t\tonline: {\n\t\t\t\t\ticon: '',\n\t\t\t\t\tstatus: 'online',\n\t\t\t\t\tmessage: 'Available',\n\t\t\t\t},\n\t\t\t\tmeeting: {\n\t\t\t\t\ticon: 'đ',\n\t\t\t\t\tstatus: 'online',\n\t\t\t\t\tmessage: 'In a meeting',\n\t\t\t\t},\n\t\t\t},\n\t\t}\n\t},\n}\n</script>\n```\n\n</docs>\n\n<template>\n\t<span\n\t\tv-click-outside=\"closeMenu\"\n\t\t:title=\"tooltip\"\n\t\t:class=\"{\n\t\t\t'avatardiv--unknown': userDoesNotExist,\n\t\t\t'avatardiv--with-menu': hasMenu,\n\t\t\t'avatardiv--with-menu-loading': contactsMenuLoading,\n\t\t}\"\n\t\t:style=\"avatarStyle\"\n\t\tclass=\"avatardiv popovermenu-wrapper\">\n\t\t<!-- @slot Icon slot -->\n\t\t<slot name=\"icon\">\n\t\t\t<!-- Avatar icon or image -->\n\t\t\t<span v-if=\"iconClass\" :class=\"iconClass\" class=\"avatar-class-icon\" />\n\t\t\t<img\n\t\t\t\tv-else-if=\"isAvatarLoaded && !userDoesNotExist\"\n\t\t\t\t:src=\"avatarUrlLoaded\"\n\t\t\t\t:srcset=\"avatarSrcSetLoaded\"\n\t\t\t\talt=\"\">\n\t\t</slot>\n\n\t\t<!-- Contact menu -->\n\t\t<!-- We show a button if the menu is not loaded yet. -->\n\t\t<NcButton\n\t\t\tv-if=\"hasMenu && menu.length === 0\"\n\t\t\t:aria-label=\"avatarAriaLabel\"\n\t\t\tclass=\"action-item action-item__menutoggle\"\n\t\t\tvariant=\"tertiary-no-background\"\n\t\t\t@click=\"toggleMenu\">\n\t\t\t<template #icon>\n\t\t\t\t<NcLoadingIcon v-if=\"contactsMenuLoading\" />\n\t\t\t\t<IconDotsHorizontal v-else :size=\"20\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t\t<NcActions\n\t\t\tv-else-if=\"hasMenu\"\n\t\t\t:aria-label=\"avatarAriaLabel\"\n\t\t\t:container=\"menuContainer\"\n\t\t\tforce-menu\n\t\t\tmanual-open\n\t\t\t:open.sync=\"contactsMenuOpenState\"\n\t\t\tvariant=\"tertiary-no-background\"\n\t\t\t@click=\"toggleMenu\">\n\t\t\t<component\n\t\t\t\t:is=\"item.ncActionComponent\"\n\t\t\t\tv-for=\"(item, key) in menu\"\n\t\t\t\t:key=\"key\"\n\t\t\t\tv-bind=\"item.ncActionComponentProps\"\n\t\t\t\tv-on=\"item.ncActionComponentHandlers\">\n\t\t\t\t<template v-if=\"item.iconSvg\" #icon>\n\t\t\t\t\t<NcIconSvgWrapper :svg=\"item.iconSvg\" />\n\t\t\t\t</template>\n\t\t\t\t{{ item.text }}\n\t\t\t</component>\n\t\t\t<template v-if=\"contactsMenuLoading\" #icon>\n\t\t\t\t<NcLoadingIcon />\n\t\t\t</template>\n\t\t</NcActions>\n\n\t\t<!-- Avatar status -->\n\t\t<span v-if=\"showUserStatusIconOnAvatar\" class=\"avatardiv__user-status avatardiv__user-status--icon\">\n\t\t\t{{ userStatus.icon }}\n\t\t</span>\n\t\t<NcUserStatusIcon\n\t\t\tv-else-if=\"canDisplayUserStatus\"\n\t\t\tclass=\"avatardiv__user-status\"\n\t\t\t:status=\"userStatus.status\"\n\t\t\t:aria-hidden=\"String(hasMenu)\" />\n\n\t\t<!-- Show the letter if no avatar nor icon class -->\n\t\t<span\n\t\t\tv-if=\"showInitials\"\n\t\t\t:style=\"initialsWrapperStyle\"\n\t\t\tclass=\"avatardiv__initials-wrapper\">\n\t\t\t<span :style=\"initialsStyle\" class=\"avatardiv__initials\">\n\t\t\t\t{{ initials }}\n\t\t\t</span>\n\t\t</span>\n\t</span>\n</template>\n\n<script>\nimport { getCurrentUser } from '@nextcloud/auth'\nimport axios from '@nextcloud/axios'\nimport { getBuilder } from '@nextcloud/browser-storage'\nimport { subscribe, unsubscribe } from '@nextcloud/event-bus'\nimport { generateUrl } from '@nextcloud/router'\nimport { vOnClickOutside as ClickOutside } from '@vueuse/components'\nimport IconDotsHorizontal from 'vue-material-design-icons/DotsHorizontal.vue'\nimport { getRoute } from '../../components/NcRichText/autolink.js'\nimport { useIsDarkTheme } from '../../composables/useIsDarkTheme/index.ts'\nimport { getEnabledContactsMenuActions } from '../../functions/contactsMenu/index.ts'\nimport usernameToColor from '../../functions/usernameToColor/index.js'\nimport { t } from '../../l10n.js'\nimport { userStatus } from '../../mixins/index.js'\nimport { getAvatarUrl } from '../../utils/getAvatarUrl.ts'\nimport { logger } from '../../utils/logger.ts'\nimport { getUserStatusText } from '../../utils/UserStatus.ts'\nimport NcActionButton from '../NcActionButton/index.js'\nimport NcActionLink from '../NcActionLink/index.js'\nimport NcActionRouter from '../NcActionRouter/index.js'\nimport NcActions from '../NcActions/index.js'\nimport NcActionText from '../NcActionText/index.js'\nimport NcButton from '../NcButton/index.js'\nimport NcIconSvgWrapper from '../NcIconSvgWrapper/index.js'\nimport NcLoadingIcon from '../NcLoadingIcon/index.js'\nimport NcUserStatusIcon from '../NcUserStatusIcon/index.js'\n\nconst browserStorage = getBuilder('nextcloud').persist().build()\n\n/**\n * @param {string} userId The id of the user\n */\nfunction getUserHasAvatar(userId) {\n\tconst flag = browserStorage.getItem('user-has-avatar.' + userId)\n\tif (typeof flag === 'string') {\n\t\treturn Boolean(flag)\n\t}\n\treturn null\n}\n\n/**\n * @param {string} userId The id of the user\n * @param {boolean} flag Has the user an avatar\n */\nfunction setUserHasAvatar(userId, flag) {\n\tif (userId) {\n\t\tbrowserStorage.setItem('user-has-avatar.' + userId, flag)\n\t}\n}\n\nexport default {\n\tname: 'NcAvatar',\n\n\tdirectives: {\n\t\tClickOutside,\n\t},\n\n\tcomponents: {\n\t\tIconDotsHorizontal,\n\t\tNcActions,\n\t\tNcButton,\n\t\tNcIconSvgWrapper,\n\t\tNcLoadingIcon,\n\t\tNcUserStatusIcon,\n\t},\n\n\tmixins: [userStatus],\n\tprops: {\n\t\t/**\n\t\t * Set a custom url to the avatar image\n\t\t * either the url, user or displayName property must be defined\n\t\t */\n\t\turl: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Set a css icon-class for an icon to be used instead of the avatar.\n\t\t */\n\t\ticonClass: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Set the user id to fetch the avatar\n\t\t * either the url, user or displayName property must be defined\n\t\t */\n\t\tuser: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Do not show the user status on the avatar.\n\t\t */\n\t\thideStatus: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Whether or not to display the user-status.\n\t\t *\n\t\t * @deprecated - Use `hideStatus` instead. Will be removed with v9.\n\t\t */\n\t\tshowUserStatus: {\n\t\t\ttype: Boolean,\n\t\t\t// eslint-disable-next-line vue/no-boolean-default\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * Show the verbose user status (e.g. \"online\" / \"away\") instead of just the status icon.\n\t\t */\n\t\tverboseStatus: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Whether or not to the status-icon should be used instead of online/away\n\t\t *\n\t\t * @deprecated - Use `verboseStatus` instead. Will be removed with v9.\n\t\t */\n\t\tshowUserStatusCompact: {\n\t\t\ttype: Boolean,\n\t\t\t// eslint-disable-next-line vue/no-boolean-default\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * When the user status was preloaded via another source it can be handed in with this property to save the request.\n\t\t * If this property is not set the status will be fetched automatically.\n\t\t * If a preloaded no-status is available provide this object with properties \"status\", \"icon\" and \"message\" set to null.\n\t\t */\n\t\tpreloadedUserStatus: {\n\t\t\ttype: Object,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Is the user a guest user (then we have to user a different endpoint)\n\t\t */\n\t\tisGuest: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Set a display name that will be rendered as a tooltip\n\t\t * either the url, user or displayName property must be defined\n\t\t * specify just the displayname to generate a placeholder avatar without\n\t\t * trying to fetch the avatar based on the user id\n\t\t */\n\t\tdisplayName: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Set a size in px for the rendered avatar\n\t\t */\n\t\tsize: {\n\t\t\ttype: Number,\n\t\t\tdefault: 32,\n\t\t},\n\n\t\t/**\n\t\t * Do not automatically generate a placeholder avatars if there is no real avatar is available.\n\t\t */\n\t\tnoPlaceholder: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Placeholder avatars will be automatically generated when this is set to true.\n\t\t *\n\t\t * @deprecated - Use `noPlaceholder` instead. Will be removed in v9.\n\t\t */\n\t\tallowPlaceholder: {\n\t\t\ttype: Boolean,\n\t\t\t// eslint-disable-next-line vue/no-boolean-default\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * Disable the tooltip\n\t\t */\n\t\tdisableTooltip: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Disable the menu\n\t\t */\n\t\tdisableMenu: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Declares a custom tooltip when not null\n\t\t * Fallback will be the displayName\n\t\t *\n\t\t * requires disableTooltip not to be set to true\n\t\t */\n\t\ttooltipMessage: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Declares username is not a user's name, when true.\n\t\t * Prevents loading user's avatar from server and forces generating colored initials,\n\t\t * i.e. if the user is a group\n\t\t */\n\t\tisNoUser: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Selector for the popover menu container\n\t\t */\n\t\tmenuContainer: {\n\t\t\ttype: [Boolean, String, Object, Element],\n\t\t\tdefault: 'body',\n\t\t},\n\t},\n\n\tsetup() {\n\t\tconst isDarkTheme = useIsDarkTheme()\n\n\t\treturn {\n\t\t\tisDarkTheme,\n\t\t}\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tavatarUrlLoaded: null,\n\t\t\tavatarSrcSetLoaded: null,\n\t\t\tuserDoesNotExist: false,\n\t\t\tisAvatarLoaded: false,\n\t\t\tisMenuLoaded: false,\n\t\t\tcontactsMenuLoading: false,\n\t\t\tcontactsMenuData: {},\n\t\t\tcontactsMenuActions: [],\n\t\t\tcontactsMenuOpenState: false,\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tavatarAriaLabel() {\n\t\t\t// aria-label is only allowed on interactive elements\n\t\t\tif (!this.hasMenu) {\n\t\t\t\treturn\n\t\t\t}\n\t\t\tif (this.canDisplayUserStatus || this.showUserStatusIconOnAvatar) {\n\t\t\t\treturn t('Avatar of {displayName}, {status}', { displayName: this.displayName ?? this.user, status: getUserStatusText(this.userStatus.status) })\n\t\t\t}\n\t\t\treturn t('Avatar of {displayName}', { displayName: this.displayName ?? this.user })\n\t\t},\n\n\t\tcanDisplayUserStatus() {\n\t\t\treturn !this.hideStatus\n\t\t\t\t&& this.showUserStatus\n\t\t\t\t&& this.hasStatus\n\t\t\t\t&& ['online', 'away', 'busy', 'dnd'].includes(this.userStatus.status)\n\t\t},\n\n\t\tshowUserStatusIconOnAvatar() {\n\t\t\treturn !this.hideStatus\n\t\t\t\t&& this.showUserStatus\n\t\t\t\t&& !this.verboseStatus\n\t\t\t\t&& this.showUserStatusCompact\n\t\t\t\t&& this.hasStatus\n\t\t\t\t&& this.userStatus.status !== 'dnd'\n\t\t\t\t&& this.userStatus.icon\n\t\t},\n\n\t\t/**\n\t\t * The user identifier, either the display name if set or the user property\n\t\t * If both properties are not set an empty string is returned\n\t\t */\n\t\tuserIdentifier() {\n\t\t\tif (this.isDisplayNameDefined) {\n\t\t\t\treturn this.displayName\n\t\t\t}\n\t\t\tif (this.isUserDefined) {\n\t\t\t\treturn this.user\n\t\t\t}\n\t\t\treturn ''\n\t\t},\n\n\t\tisUserDefined() {\n\t\t\treturn typeof this.user !== 'undefined'\n\t\t},\n\n\t\tisDisplayNameDefined() {\n\t\t\treturn typeof this.displayName !== 'undefined'\n\t\t},\n\n\t\tisUrlDefined() {\n\t\t\treturn typeof this.url !== 'undefined'\n\t\t},\n\n\t\thasMenu() {\n\t\t\tif (this.disableMenu) {\n\t\t\t\treturn false\n\t\t\t}\n\t\t\tif (this.isMenuLoaded) {\n\t\t\t\treturn this.menu.length > 0\n\t\t\t}\n\t\t\treturn !(this.user === getCurrentUser()?.uid || this.userDoesNotExist || this.url)\n\t\t},\n\n\t\t/**\n\t\t * True if initials should be shown as the user icon fallback\n\t\t */\n\t\tshowInitials() {\n\t\t\treturn !this.noPlaceholder && this.allowPlaceholder && this.userDoesNotExist && !(this.iconClass || this.$slots.icon)\n\t\t},\n\n\t\tavatarStyle() {\n\t\t\treturn {\n\t\t\t\t'--avatar-size': this.size + 'px',\n\t\t\t\tlineHeight: this.showInitials ? (this.size + 'px') : 0,\n\t\t\t\tfontSize: Math.round(this.size * 0.45) + 'px',\n\t\t\t}\n\t\t},\n\n\t\tinitialsWrapperStyle() {\n\t\t\tconst { r, g, b } = usernameToColor(this.userIdentifier)\n\t\t\treturn {\n\t\t\t\tbackgroundColor: `rgba(${r}, ${g}, ${b}, 0.1)`,\n\t\t\t}\n\t\t},\n\n\t\tinitialsStyle() {\n\t\t\tconst { r, g, b } = usernameToColor(this.userIdentifier)\n\t\t\treturn {\n\t\t\t\tcolor: `rgb(${r}, ${g}, ${b})`,\n\t\t\t}\n\t\t},\n\n\t\ttooltip() {\n\t\t\tif (this.disableTooltip) {\n\t\t\t\treturn false\n\t\t\t}\n\t\t\tif (this.tooltipMessage) {\n\t\t\t\treturn this.tooltipMessage\n\t\t\t}\n\n\t\t\treturn this.displayName\n\t\t},\n\n\t\t/**\n\t\t * Get the (max. two) initials of the user as uppcase string\n\t\t */\n\t\tinitials() {\n\t\t\tlet initials = '?'\n\t\t\tif (this.showInitials) {\n\t\t\t\tconst user = this.userIdentifier.trim()\n\t\t\t\tif (user === '') {\n\t\t\t\t\treturn initials\n\t\t\t\t}\n\n\t\t\t\t/**\n\t\t\t\t * Filtered user name, without special characters so only letters and numbers are allowed (prevent e.g. '(' as an initial)\n\t\t\t\t * \\p{L}: Letters of all languages\n\t\t\t\t * \\p{N}: Numbers of all languages\n\t\t\t\t * \\s: White space for breaking the string\n\t\t\t\t *\n\t\t\t\t * @type {string}\n\t\t\t\t */\n\t\t\t\tconst filteredChars = user.match(/[\\p{L}\\p{N}\\s]/gu)\n\t\t\t\tif (!filteredChars) {\n\t\t\t\t\treturn initials\n\t\t\t\t}\n\n\t\t\t\tconst filtered = filteredChars.join('')\n\t\t\t\tconst idx = filtered.lastIndexOf(' ')\n\t\t\t\tinitials = String.fromCodePoint(filtered.codePointAt(0))\n\t\t\t\tif (idx !== -1) {\n\t\t\t\t\tinitials = initials.concat(String.fromCodePoint(filtered.codePointAt(idx + 1)))\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn initials.toLocaleUpperCase()\n\t\t},\n\n\t\tmenu() {\n\t\t\tconst actions = this.contactsMenuActions.map((item) => {\n\t\t\t\tconst route = getRoute(this.$router, item.hyperlink)\n\t\t\t\treturn {\n\t\t\t\t\tncActionComponent: route ? NcActionRouter : NcActionLink,\n\t\t\t\t\tncActionComponentProps: route\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tto: route,\n\t\t\t\t\t\t\t\ticon: item.icon,\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {\n\t\t\t\t\t\t\t\thref: item.hyperlink,\n\t\t\t\t\t\t\t\ticon: item.icon,\n\t\t\t\t\t\t\t},\n\t\t\t\t\ttext: item.title,\n\t\t\t\t}\n\t\t\t})\n\n\t\t\tfor (const action of getEnabledContactsMenuActions(this.contactsMenuData)) {\n\t\t\t\ttry {\n\t\t\t\t\tactions.push({\n\t\t\t\t\t\tncActionComponent: NcActionButton,\n\t\t\t\t\t\tncActionComponentProps: {},\n\t\t\t\t\t\tncActionComponentHandlers: {\n\t\t\t\t\t\t\tclick: () => action.callback(this.contactsMenuData),\n\t\t\t\t\t\t},\n\t\t\t\t\t\ttext: action.displayName(this.contactsMenuData),\n\t\t\t\t\t\ticonSvg: action.iconSvg(this.contactsMenuData),\n\t\t\t\t\t})\n\t\t\t\t} catch (error) {\n\t\t\t\t\tlogger.error(`Failed to render ContactsMenu action ${action.id}`, {\n\t\t\t\t\t\terror,\n\t\t\t\t\t\taction,\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t/**\n\t\t\t * @param {string} html The HTML to escape\n\t\t\t */\n\t\t\tfunction escape(html) {\n\t\t\t\tconst text = document.createTextNode(html)\n\t\t\t\tconst p = document.createElement('p')\n\t\t\t\tp.appendChild(text)\n\t\t\t\treturn p.innerHTML\n\t\t\t}\n\n\t\t\tif (!this.hideStatus && this.showUserStatus && (this.userStatus.icon || this.userStatus.message)) {\n\t\t\t\t// NcAction's URL icons are inverted in dark mode, so we need to pass SVG image in the icon slot\n\t\t\t\tconst emojiIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 16 16\">\n\t\t\t\t\t<text x=\"50%\" y=\"50%\" text-anchor=\"middle\" style=\"dominant-baseline: central; font-size: 85%\">${escape(this.userStatus.icon)}</text>\n\t\t\t\t</svg>`\n\t\t\t\treturn [{\n\t\t\t\t\tncActionComponent: NcActionText,\n\t\t\t\t\tncActionComponentProps: {},\n\t\t\t\t\ticonSvg: this.userStatus.icon ? emojiIcon : undefined,\n\t\t\t\t\ttext: `${this.userStatus.message}`,\n\t\t\t\t}].concat(actions)\n\t\t\t}\n\n\t\t\treturn actions\n\t\t},\n\t},\n\n\twatch: {\n\t\turl() {\n\t\t\tthis.userDoesNotExist = false\n\t\t\tthis.loadAvatarUrl()\n\t\t},\n\n\t\tuser() {\n\t\t\tthis.userDoesNotExist = false\n\t\t\tthis.isMenuLoaded = false\n\t\t\tthis.loadAvatarUrl()\n\t\t},\n\t},\n\n\tmounted() {\n\t\tthis.loadAvatarUrl()\n\t\tsubscribe('settings:avatar:updated', this.loadAvatarUrl)\n\t\tsubscribe('settings:display-name:updated', this.loadAvatarUrl)\n\t\tif (!this.hideStatus && this.showUserStatus && this.user && !this.isNoUser) {\n\t\t\tif (!this.preloadedUserStatus) {\n\t\t\t\tthis.fetchUserStatus(this.user)\n\t\t\t} else {\n\t\t\t\tthis.userStatus.status = this.preloadedUserStatus.status || ''\n\t\t\t\tthis.userStatus.message = this.preloadedUserStatus.message || ''\n\t\t\t\tthis.userStatus.icon = this.preloadedUserStatus.icon || ''\n\t\t\t\tthis.hasStatus = this.preloadedUserStatus.status !== null\n\t\t\t}\n\t\t\tsubscribe('user_status:status.updated', this.handleUserStatusUpdated)\n\t\t}\n\t},\n\n\tbeforeDestroy() {\n\t\tunsubscribe('settings:avatar:updated', this.loadAvatarUrl)\n\t\tunsubscribe('settings:display-name:updated', this.loadAvatarUrl)\n\t\tunsubscribe('user_status:status.updated', this.handleUserStatusUpdated)\n\t},\n\n\tmethods: {\n\t\tt,\n\t\thandleUserStatusUpdated(state) {\n\t\t\tif (this.user === state.userId) {\n\t\t\t\tthis.userStatus = {\n\t\t\t\t\tstatus: state.status,\n\t\t\t\t\ticon: state.icon,\n\t\t\t\t\tmessage: state.message,\n\t\t\t\t}\n\t\t\t\tthis.hasStatus = state.status !== null\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Toggle the popover menu on click or enter\n\t\t *\n\t\t * @param {KeyboardEvent|MouseEvent} event the UI event\n\t\t */\n\t\tasync toggleMenu(event) {\n\t\t\tif (event.type === 'keydown' && event.key !== 'Enter') {\n\t\t\t\treturn\n\t\t\t}\n\t\t\tif (!this.contactsMenuOpenState) {\n\t\t\t\tawait this.fetchContactsMenu()\n\t\t\t}\n\t\t\tthis.contactsMenuOpenState = !this.contactsMenuOpenState\n\t\t},\n\n\t\tcloseMenu() {\n\t\t\tthis.contactsMenuOpenState = false\n\t\t},\n\n\t\tasync fetchContactsMenu() {\n\t\t\tthis.contactsMenuLoading = true\n\t\t\ttry {\n\t\t\t\tconst user = encodeURIComponent(this.user)\n\t\t\t\tconst { data } = await axios.post(generateUrl('contactsmenu/findOne'), `shareType=0&shareWith=${user}`)\n\t\t\t\tthis.contactsMenuData = data\n\t\t\t\tthis.contactsMenuActions = data.topAction ? [data.topAction].concat(data.actions) : data.actions\n\t\t\t} catch {\n\t\t\t\tthis.contactsMenuOpenState = false\n\t\t\t}\n\t\t\tthis.contactsMenuLoading = false\n\t\t\tthis.isMenuLoaded = true\n\t\t},\n\n\t\t/**\n\t\t * Handle avatar loading if user or url defined\n\t\t */\n\t\tloadAvatarUrl() {\n\t\t\tthis.isAvatarLoaded = false\n\n\t\t\t/** Only run avatar image loading if either user or url property is defined */\n\t\t\tif (!this.isUrlDefined && (!this.isUserDefined || this.isNoUser || this.iconClass)) {\n\t\t\t\tthis.isAvatarLoaded = true\n\t\t\t\tthis.userDoesNotExist = true\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\t// Directly use the url if defined\n\t\t\tif (this.isUrlDefined) {\n\t\t\t\tthis.updateImageIfValid(this.url)\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tif (this.size <= 64) {\n\t\t\t\tconst avatarUrl = this.avatarUrlGenerator(this.user, 64)\n\t\t\t\tconst srcset = [\n\t\t\t\t\tavatarUrl + ' 1x',\n\t\t\t\t\tthis.avatarUrlGenerator(this.user, 512) + ' 8x',\n\t\t\t\t].join(', ')\n\n\t\t\t\tthis.updateImageIfValid(avatarUrl, srcset)\n\t\t\t} else {\n\t\t\t\tconst avatarUrl = this.avatarUrlGenerator(this.user, 512)\n\t\t\t\tthis.updateImageIfValid(avatarUrl)\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Generate an avatar url from the server's avatar endpoint\n\t\t *\n\t\t * @param {string} user the user id\n\t\t * @param {number} size the desired size\n\t\t * @return {string}\n\t\t */\n\t\tavatarUrlGenerator(user, size) {\n\t\t\tlet avatarUrl = getAvatarUrl(user, {\n\t\t\t\tsize,\n\t\t\t\tisDarkTheme: this.isDarkTheme,\n\t\t\t\tisGuest: this.isGuest,\n\t\t\t})\n\n\t\t\tif (user === getCurrentUser()?.uid && typeof window.oc_userconfig !== 'undefined') {\n\t\t\t\tavatarUrl += '?v=' + window.oc_userconfig.avatar.version\n\t\t\t}\n\n\t\t\treturn avatarUrl\n\t\t},\n\n\t\t/**\n\t\t * Check if the provided url is valid and update Avatar if so\n\t\t *\n\t\t * @param {string} url the avatar url\n\t\t * @param {Array} srcset the avatar srcset\n\t\t */\n\t\tupdateImageIfValid(url, srcset = null) {\n\t\t\t// skip loading\n\t\t\tconst userHasAvatar = getUserHasAvatar(this.user)\n\t\t\tif (this.isUserDefined && typeof userHasAvatar === 'boolean') {\n\t\t\t\tthis.isAvatarLoaded = true\n\t\t\t\tthis.avatarUrlLoaded = url\n\t\t\t\tif (srcset) {\n\t\t\t\t\tthis.avatarSrcSetLoaded = srcset\n\t\t\t\t}\n\t\t\t\tif (userHasAvatar === false) {\n\t\t\t\t\tthis.userDoesNotExist = true\n\t\t\t\t}\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tconst img = new Image()\n\t\t\timg.onload = () => {\n\t\t\t\tthis.avatarUrlLoaded = url\n\t\t\t\tif (srcset) {\n\t\t\t\t\tthis.avatarSrcSetLoaded = srcset\n\t\t\t\t}\n\t\t\t\tthis.isAvatarLoaded = true\n\t\t\t\t// re-get to avoid concurrent access\n\t\t\t\tsetUserHasAvatar(this.user, true)\n\t\t\t}\n\t\t\timg.onerror = (error) => {\n\t\t\t\tlogger.debug('Invalid avatar url', { error, url })\n\t\t\t\t// Avatar is invalid, reset\n\t\t\t\tthis.avatarUrlLoaded = null\n\t\t\t\tthis.avatarSrcSetLoaded = null\n\n\t\t\t\tthis.userDoesNotExist = true\n\t\t\t\tthis.isAvatarLoaded = false\n\t\t\t\tsetUserHasAvatar(this.user, false)\n\t\t\t}\n\n\t\t\tif (srcset) {\n\t\t\t\timg.srcset = srcset\n\t\t\t}\n\t\t\timg.src = url\n\t\t},\n\t},\n}\n</script>\n\n<style scoped lang=\"scss\">\n.avatardiv {\n\tposition: relative;\n\tdisplay: inline-block;\n\twidth: var(--avatar-size);\n\theight: var(--avatar-size);\n\n\t&--unknown {\n\t\tposition: relative;\n\t\tbackground-color: var(--color-main-background);\n\t\twhite-space: normal;\n\t}\n\n\t&:not(&--unknown) {\n\t\t// White/black background for avatars with transparency\n\t\tbackground-color: var(--color-main-background) !important;\n\t\tbox-shadow: 0 0 5px rgba(0, 0, 0, 0.05) inset;\n\t}\n\n\t&--with-menu {\n\t\tcursor: pointer;\n\t\t.action-item {\n\t\t\tposition: absolute;\n\t\t\ttop: 0;\n\t\t\tleft: 0;\n\t\t}\n\t\t:deep(.action-item__menutoggle) {\n\t\t\tcursor: pointer;\n\t\t\topacity: 0;\n\t\t}\n\t\t&:focus-within,\n\t\t&:hover,\n\t\t&#{&}-loading {\n\t\t\t:deep(.action-item__menutoggle) {\n\t\t\t\topacity: 1;\n\t\t\t}\n\t\t\timg {\n\t\t\t\topacity: 0.3;\n\t\t\t}\n\t\t}\n\t\t:deep(.action-item__menutoggle),\n\t\timg {\n\t\t\ttransition: opacity var(--animation-quick);\n\t\t}\n\t\t:deep() {\n\t\t\t.button-vue,\n\t\t\t.button-vue__icon {\n\t\t\t\theight: var(--avatar-size);\n\t\t\t\tmin-height: var(--avatar-size);\n\t\t\t\twidth: var(--avatar-size) !important;\n\t\t\t\tmin-width: var(--avatar-size);\n\t\t\t}\n\t\t}\n\t\t& > :deep(.button-vue),\n\t\t& > :deep(.action-item .button-vue) {\n\t\t\t--button-radius: calc(var(--avatar-size) / 2);\n\t\t}\n\t}\n\n\t.avatardiv__initials-wrapper {\n\t\tdisplay: block;\n\t\theight: var(--avatar-size);\n\t\twidth: var(--avatar-size);\n\t\tbackground-color: var(--color-main-background);\n\t\tborder-radius: calc(var(--avatar-size) / 2);\n\n\t\t.avatardiv__initials {\n\t\t\tposition: absolute;\n\t\t\ttop: 0;\n\t\t\tleft: 0;\n\t\t\tdisplay: block;\n\t\t\twidth: 100%;\n\t\t\ttext-align: center;\n\t\t\tfont-weight: normal;\n\t\t}\n\t}\n\n\timg {\n\t\t// Cover entire area\n\t\twidth: 100%;\n\t\theight: 100%;\n\t\t// Keep ratio\n\t\tobject-fit: cover;\n\t}\n\n\t.material-design-icon {\n\t\twidth: var(--avatar-size);\n\t\theight: var(--avatar-size);\n\t}\n\n\t.avatardiv__user-status {\n\t\t// Size of the status icon to make it:\n\t\t// - đĢ Orbital: the status icon's center is positioned on the avatar circle\n\t\t// - âšī¸ Best-fit: the status icon is as large as possible without exceeding the avatar box\n\t\t// See PR for math explanation: PR #6004\n\t\t--avatar-status-size-orbital: calc(var(--avatar-size) * (1 - 1 / sqrt(2)));\n\t\t// Limit the status icon size to minimum font size to keep it readable\n\t\t// Ideally avatars with a smaller should not be used with the status icon at all\n\t\t--avatar-status-size-min: var(--font-size-small);\n\t\t--avatar-status-size: max(var(--avatar-status-size-orbital), var(--avatar-status-size-min));\n\t\tbox-sizing: border-box;\n\t\tposition: absolute;\n\t\tinset-inline-end: 0;\n\t\tinset-block-end: 0;\n\t\theight: var(--avatar-status-size);\n\t\twidth: var(--avatar-status-size);\n\t\tline-height: 1;\n\t\tfont-size: calc(var(--avatar-status-size) / 1.2);\n\t\tbackground-color: var(--color-main-background);\n\t\tbackground-repeat: no-repeat;\n\t\tbackground-size: var(--avatar-status-size);\n\t\tbackground-position: center;\n\t\tborder-radius: 50%;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: center;\n\n\t\t.acli:hover & {\n\t\t\tborder-color: var(--color-background-hover);\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\t\t.acli.active & {\n\t\t\tborder-color: var(--color-primary-element-light);\n\t\t\tbackground-color: var(--color-primary-element-light);\n\t\t}\n\n\t\t&--icon {\n\t\t\tborder: none;\n\t\t\tbackground-color: transparent;\n\t\t}\n\t}\n\n\t.popovermenu-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t}\n}\n\n.avatar-class-icon {\n\tdisplay: block;\n\tborder-radius: calc(var(--avatar-size) / 2);\n\tbackground-color: var(--color-background-darker);\n\theight: 100%;\n}\n\n</style>\n"],"names":["ClickOutside","IconDotsHorizontal"],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
require('../assets/NcMentionBubble-CaztX9Pv.css');
|
|
2
|
-
require('../assets/NcAvatar-
|
|
2
|
+
require('../assets/NcAvatar-Cm4kVIfS.css');
|
|
3
3
|
"use strict";
|
|
4
4
|
const auth = require("@nextcloud/auth");
|
|
5
5
|
const axios = require("@nextcloud/axios");
|
|
@@ -7,29 +7,29 @@ const browserStorage$1 = require("@nextcloud/browser-storage");
|
|
|
7
7
|
const eventBus = require("@nextcloud/event-bus");
|
|
8
8
|
const router = require("@nextcloud/router");
|
|
9
9
|
const components = require("@vueuse/components");
|
|
10
|
-
const NcActions = require("./NcActions-
|
|
10
|
+
const NcActions = require("./NcActions-D3N_As6c.cjs");
|
|
11
11
|
const autolink = require("./autolink-BPlRHRHR.cjs");
|
|
12
12
|
const Composables_useIsDarkTheme = require("../Composables/useIsDarkTheme.cjs");
|
|
13
13
|
const Functions_contactsMenu = require("../Functions/contactsMenu.cjs");
|
|
14
14
|
const Functions_usernameToColor = require("../Functions/usernameToColor.cjs");
|
|
15
|
-
const _l10n = require("./_l10n-
|
|
15
|
+
const _l10n = require("./_l10n-9b4TMo5Q.cjs");
|
|
16
16
|
require("../Composables/useIsFullscreen.cjs");
|
|
17
17
|
require("../Composables/useIsMobile.cjs");
|
|
18
18
|
require("escape-html");
|
|
19
19
|
require("striptags");
|
|
20
20
|
require("vue");
|
|
21
|
-
const getAvatarUrl = require("./getAvatarUrl-
|
|
21
|
+
const getAvatarUrl = require("./getAvatarUrl-DwWyuiUZ.cjs");
|
|
22
22
|
;/* empty css */
|
|
23
23
|
const _pluginVue2_normalizer = require("./_plugin-vue2_normalizer-V0q-tHlQ.cjs");
|
|
24
24
|
const capabilities = require("@nextcloud/capabilities");
|
|
25
25
|
const logger = require("./logger-3HuiEIF6.cjs");
|
|
26
|
-
const NcUserStatusIcon = require("./NcUserStatusIcon-
|
|
27
|
-
const NcActionButton = require("./NcActionButton-
|
|
26
|
+
const NcUserStatusIcon = require("./NcUserStatusIcon-DV2H-KfR.cjs");
|
|
27
|
+
const NcActionButton = require("./NcActionButton-lJ0IA3IS.cjs");
|
|
28
28
|
const Components_NcActionLink = require("../Components/NcActionLink.cjs");
|
|
29
29
|
const Components_NcActionRouter = require("../Components/NcActionRouter.cjs");
|
|
30
30
|
const Components_NcActionText = require("../Components/NcActionText.cjs");
|
|
31
|
-
const NcButton = require("./NcButton-
|
|
32
|
-
const NcIconSvgWrapper = require("./NcIconSvgWrapper-
|
|
31
|
+
const NcButton = require("./NcButton-DK7bNZIL.cjs");
|
|
32
|
+
const NcIconSvgWrapper = require("./NcIconSvgWrapper-DoVPfeNg.cjs");
|
|
33
33
|
const Components_NcLoadingIcon = require("../Components/NcLoadingIcon.cjs");
|
|
34
34
|
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
|
35
35
|
const axios__default = /* @__PURE__ */ _interopDefault(axios);
|
|
@@ -54,6 +54,7 @@ const userStatus = {
|
|
|
54
54
|
* @return {Promise<void>}
|
|
55
55
|
*/
|
|
56
56
|
async fetchUserStatus(userId) {
|
|
57
|
+
var _a, _b;
|
|
57
58
|
if (!userId) {
|
|
58
59
|
return;
|
|
59
60
|
}
|
|
@@ -75,11 +76,11 @@ const userStatus = {
|
|
|
75
76
|
this.userStatus.message = message || "";
|
|
76
77
|
this.userStatus.icon = icon || "";
|
|
77
78
|
this.hasStatus = true;
|
|
78
|
-
} catch (
|
|
79
|
-
if (
|
|
79
|
+
} catch (error) {
|
|
80
|
+
if (error.response.status === 404 && ((_b = (_a = error.response.data.ocs) == null ? void 0 : _a.data) == null ? void 0 : _b.length) === 0) {
|
|
80
81
|
return;
|
|
81
82
|
}
|
|
82
|
-
logger.logger.error(
|
|
83
|
+
logger.logger.error("Could not fetch user status", { error });
|
|
83
84
|
}
|
|
84
85
|
}
|
|
85
86
|
}
|
|
@@ -281,13 +282,14 @@ const _sfc_main = {
|
|
|
281
282
|
},
|
|
282
283
|
computed: {
|
|
283
284
|
avatarAriaLabel() {
|
|
285
|
+
var _a, _b;
|
|
284
286
|
if (!this.hasMenu) {
|
|
285
287
|
return;
|
|
286
288
|
}
|
|
287
289
|
if (this.canDisplayUserStatus || this.showUserStatusIconOnAvatar) {
|
|
288
|
-
return _l10n.t("Avatar of {displayName}, {status}", { displayName: this.displayName
|
|
290
|
+
return _l10n.t("Avatar of {displayName}, {status}", { displayName: (_a = this.displayName) != null ? _a : this.user, status: NcUserStatusIcon.getUserStatusText(this.userStatus.status) });
|
|
289
291
|
}
|
|
290
|
-
return _l10n.t("Avatar of {displayName}", { displayName: this.displayName
|
|
292
|
+
return _l10n.t("Avatar of {displayName}", { displayName: (_b = this.displayName) != null ? _b : this.user });
|
|
291
293
|
},
|
|
292
294
|
canDisplayUserStatus() {
|
|
293
295
|
return !this.hideStatus && this.showUserStatus && this.hasStatus && ["online", "away", "busy", "dnd"].includes(this.userStatus.status);
|
|
@@ -318,13 +320,14 @@ const _sfc_main = {
|
|
|
318
320
|
return typeof this.url !== "undefined";
|
|
319
321
|
},
|
|
320
322
|
hasMenu() {
|
|
323
|
+
var _a;
|
|
321
324
|
if (this.disableMenu) {
|
|
322
325
|
return false;
|
|
323
326
|
}
|
|
324
327
|
if (this.isMenuLoaded) {
|
|
325
328
|
return this.menu.length > 0;
|
|
326
329
|
}
|
|
327
|
-
return !(this.user === auth.getCurrentUser()
|
|
330
|
+
return !(this.user === ((_a = auth.getCurrentUser()) == null ? void 0 : _a.uid) || this.userDoesNotExist || this.url);
|
|
328
331
|
},
|
|
329
332
|
/**
|
|
330
333
|
* True if initials should be shown as the user icon fallback
|
|
@@ -342,13 +345,13 @@ const _sfc_main = {
|
|
|
342
345
|
initialsWrapperStyle() {
|
|
343
346
|
const { r, g, b } = Functions_usernameToColor.usernameToColor(this.userIdentifier);
|
|
344
347
|
return {
|
|
345
|
-
backgroundColor:
|
|
348
|
+
backgroundColor: "rgba(".concat(r, ", ").concat(g, ", ").concat(b, ", 0.1)")
|
|
346
349
|
};
|
|
347
350
|
},
|
|
348
351
|
initialsStyle() {
|
|
349
352
|
const { r, g, b } = Functions_usernameToColor.usernameToColor(this.userIdentifier);
|
|
350
353
|
return {
|
|
351
|
-
color:
|
|
354
|
+
color: "rgb(".concat(r, ", ").concat(g, ", ").concat(b, ")")
|
|
352
355
|
};
|
|
353
356
|
},
|
|
354
357
|
tooltip() {
|
|
@@ -370,7 +373,7 @@ const _sfc_main = {
|
|
|
370
373
|
if (user === "") {
|
|
371
374
|
return initials;
|
|
372
375
|
}
|
|
373
|
-
const filteredChars = user.match(
|
|
376
|
+
const filteredChars = user.match(new RegExp("[\\p{L}\\p{N}\\s]", "gu"));
|
|
374
377
|
if (!filteredChars) {
|
|
375
378
|
return initials;
|
|
376
379
|
}
|
|
@@ -410,7 +413,7 @@ const _sfc_main = {
|
|
|
410
413
|
iconSvg: action.iconSvg(this.contactsMenuData)
|
|
411
414
|
});
|
|
412
415
|
} catch (error) {
|
|
413
|
-
logger.logger.error(
|
|
416
|
+
logger.logger.error("Failed to render ContactsMenu action ".concat(action.id), {
|
|
414
417
|
error,
|
|
415
418
|
action
|
|
416
419
|
});
|
|
@@ -423,14 +426,12 @@ const _sfc_main = {
|
|
|
423
426
|
return p.innerHTML;
|
|
424
427
|
}
|
|
425
428
|
if (!this.hideStatus && this.showUserStatus && (this.userStatus.icon || this.userStatus.message)) {
|
|
426
|
-
const emojiIcon =
|
|
427
|
-
<text x="50%" y="50%" text-anchor="middle" style="dominant-baseline: central; font-size: 85%">${escape(this.userStatus.icon)}</text>
|
|
428
|
-
</svg>`;
|
|
429
|
+
const emojiIcon = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16">\n <text x="50%" y="50%" text-anchor="middle" style="dominant-baseline: central; font-size: 85%">'.concat(escape(this.userStatus.icon), "</text>\n </svg>");
|
|
429
430
|
return [{
|
|
430
431
|
ncActionComponent: Components_NcActionText,
|
|
431
432
|
ncActionComponentProps: {},
|
|
432
433
|
iconSvg: this.userStatus.icon ? emojiIcon : void 0,
|
|
433
|
-
text:
|
|
434
|
+
text: "".concat(this.userStatus.message)
|
|
434
435
|
}].concat(actions);
|
|
435
436
|
}
|
|
436
437
|
return actions;
|
|
@@ -501,10 +502,10 @@ const _sfc_main = {
|
|
|
501
502
|
this.contactsMenuLoading = true;
|
|
502
503
|
try {
|
|
503
504
|
const user = encodeURIComponent(this.user);
|
|
504
|
-
const { data } = await axios__default.default.post(router.generateUrl("contactsmenu/findOne"),
|
|
505
|
+
const { data } = await axios__default.default.post(router.generateUrl("contactsmenu/findOne"), "shareType=0&shareWith=".concat(user));
|
|
505
506
|
this.contactsMenuData = data;
|
|
506
507
|
this.contactsMenuActions = data.topAction ? [data.topAction].concat(data.actions) : data.actions;
|
|
507
|
-
} catch {
|
|
508
|
+
} catch (e) {
|
|
508
509
|
this.contactsMenuOpenState = false;
|
|
509
510
|
}
|
|
510
511
|
this.contactsMenuLoading = false;
|
|
@@ -544,12 +545,13 @@ const _sfc_main = {
|
|
|
544
545
|
* @return {string}
|
|
545
546
|
*/
|
|
546
547
|
avatarUrlGenerator(user, size) {
|
|
548
|
+
var _a;
|
|
547
549
|
let avatarUrl = getAvatarUrl.getAvatarUrl(user, {
|
|
548
550
|
size,
|
|
549
551
|
isDarkTheme: this.isDarkTheme,
|
|
550
552
|
isGuest: this.isGuest
|
|
551
553
|
});
|
|
552
|
-
if (user === auth.getCurrentUser()
|
|
554
|
+
if (user === ((_a = auth.getCurrentUser()) == null ? void 0 : _a.uid) && typeof window.oc_userconfig !== "undefined") {
|
|
553
555
|
avatarUrl += "?v=" + window.oc_userconfig.avatar.version;
|
|
554
556
|
}
|
|
555
557
|
return avatarUrl;
|
|
@@ -582,8 +584,8 @@ const _sfc_main = {
|
|
|
582
584
|
this.isAvatarLoaded = true;
|
|
583
585
|
setUserHasAvatar(this.user, true);
|
|
584
586
|
};
|
|
585
|
-
img.onerror = () => {
|
|
586
|
-
logger.logger.debug("Invalid avatar url", url);
|
|
587
|
+
img.onerror = (error) => {
|
|
588
|
+
logger.logger.debug("Invalid avatar url", { error, url });
|
|
587
589
|
this.avatarUrlLoaded = null;
|
|
588
590
|
this.avatarSrcSetLoaded = null;
|
|
589
591
|
this.userDoesNotExist = true;
|
|
@@ -624,9 +626,9 @@ var __component__ = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
|
|
|
624
626
|
_sfc_staticRenderFns,
|
|
625
627
|
false,
|
|
626
628
|
null,
|
|
627
|
-
"
|
|
629
|
+
"936fbce2"
|
|
628
630
|
);
|
|
629
631
|
const NcAvatar = __component__.exports;
|
|
630
632
|
exports.NcAvatar = NcAvatar;
|
|
631
633
|
exports.userStatus = userStatus;
|
|
632
|
-
//# sourceMappingURL=NcAvatar-
|
|
634
|
+
//# sourceMappingURL=NcAvatar-D_0Aw88L.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NcAvatar-D_0Aw88L.cjs","sources":["../../src/mixins/userStatus.js","../../src/components/NcAvatar/NcAvatar.vue"],"sourcesContent":["/**\n * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\n\nimport { getCurrentUser } from '@nextcloud/auth'\nimport axios from '@nextcloud/axios'\nimport { getCapabilities } from '@nextcloud/capabilities'\nimport { generateOcsUrl } from '@nextcloud/router'\nimport { logger } from '../utils/logger.ts'\n\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\thasStatus: false,\n\t\t\tuserStatus: {\n\t\t\t\tstatus: null,\n\t\t\t\tmessage: null,\n\t\t\t\ticon: null,\n\t\t\t},\n\t\t}\n\t},\n\tmethods: {\n\t\t/**\n\t\t * Fetches the user-status from the server\n\t\t *\n\t\t * @param {string} userId UserId of the user to fetch the status for\n\t\t *\n\t\t * @return {Promise<void>}\n\t\t */\n\t\tasync fetchUserStatus(userId) {\n\t\t\tif (!userId) {\n\t\t\t\treturn\n\t\t\t}\n\t\t\tconst capabilities = getCapabilities()\n\t\t\tif (!Object.hasOwn(capabilities, 'user_status') || !capabilities.user_status.enabled) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\t// User status endpoint is not available for guests.\n\t\t\tif (!getCurrentUser()) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\ttry {\n\t\t\t\tconst { data } = await axios.get(generateOcsUrl('apps/user_status/api/v1/statuses/{userId}', { userId }))\n\t\t\t\tconst {\n\t\t\t\t\tstatus,\n\t\t\t\t\tmessage,\n\t\t\t\t\ticon,\n\t\t\t\t} = data.ocs.data\n\t\t\t\tthis.userStatus.status = status\n\t\t\t\tthis.userStatus.message = message || ''\n\t\t\t\tthis.userStatus.icon = icon || ''\n\t\t\t\tthis.hasStatus = true\n\t\t\t} catch (error) {\n\t\t\t\tif (error.response.status === 404 && error.response.data.ocs?.data?.length === 0) {\n\t\t\t\t\t// User just has no status set, so don't log it\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\tlogger.error('Could not fetch user status', { error })\n\t\t\t}\n\t\t},\n\t},\n}\n","<!--\n - SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n\n### Basic user avatar\n\n```vue\n\t<NcAvatar user=\"willywonka\" display-name=\"Willy Wonka\" />\n```\n\n### Avatar with image\n\n```vue\n\t<NcAvatar url=\"favicon-touch.png\" />\n```\n\n### Avatar with material design icon\n\n```\n<template>\n\t<NcAvatar>\n\t\t<template #icon>\n\t\t\t<AccountMultiple :size=\"20\" />\n\t\t</template>\n\t</NcAvatar>\n</template>\n<script>\nimport AccountMultiple from 'vue-material-design-icons/AccountMultiple.vue'\n\nexport default {\n\tcomponents: {\n\t\tAccountMultiple,\n\t},\n}\n</script>\n```\n\n### Avatar with preloaded status\n```\n<template>\n\t<div>\n\t\t<NcAvatar user=\"janedoe\"\n\t\t\tdisplay-name=\"Jane Doe\"\n\t\t\t:preloaded-user-status=\"status.online\">\n\t\t</NcAvatar>\n\t\t<NcAvatar user=\"janedoe\"\n\t\t\tdisplay-name=\"Jane Doe\"\n\t\t\t:preloaded-user-status=\"status.away\">\n\t\t</NcAvatar>\n\t\t<NcAvatar user=\"janedoe\"\n\t\t\tdisplay-name=\"Jane Doe\"\n\t\t\t:preloaded-user-status=\"status.dnd\">\n\t\t</NcAvatar>\n\t\t<NcAvatar user=\"janedoe\"\n\t\t\tdisplay-name=\"Jane Doe\"\n\t\t\t:preloaded-user-status=\"status.custom\">\n\t\t</NcAvatar>\n\t</div>\n</template>\n\n<script>\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\tstatus: {\n\t\t\t\tonline: {\n\t\t\t\t\ticon: '',\n\t\t\t\t\tstatus: 'online',\n\t\t\t\t\tmessage: 'Available',\n\t\t\t\t},\n\t\t\t\taway: {\n\t\t\t\t\ticon: '',\n\t\t\t\t\tstatus: 'away',\n\t\t\t\t\tmessage: 'Away',\n\t\t\t\t},\n\t\t\t\tdnd: {\n\t\t\t\t\ticon: '',\n\t\t\t\t\tstatus: 'dnd',\n\t\t\t\t\tmessage: 'Busy',\n\t\t\t\t},\n\t\t\t\tcustom: {\n\t\t\t\t\ticon: 'đ',\n\t\t\t\t\tstatus: 'online',\n\t\t\t\t\tmessage: 'In a meeting',\n\t\t\t\t}\n\t\t\t},\n\t\t}\n\t},\n}\n</script>\n```\n\n### Avatar for non-users\n\n```vue\n\t<NcAvatar display-name=\"Robbie Hyeon-Jeong\" :is-no-user=\"true\" />\n```\n\n### Avatar on complex background\n\n```\n<template>\n\t<div class=\"avatar-background\">\n\t\t<NcAvatar class=\"avatar\" :is-no-user=\"true\" display-name=\"Cecilia Rohese\" />\n\t</div>\n</template>\n<style scoped>\n.avatar-background {\n\twidth: 80px;\n\theight: 60px;\n\tbackground: linear-gradient(to bottom, #0057b8 0%, #0057b8 49.99%, #ffd700 50%, #ffd700 100%);\n}\n\n.avatar {\n\tmargin: 15px 25px;\n}\n</style>\n```\n\n### Avatar size\n\n```vue\n<template>\n\t<div>\n\t\t<div v-for=\"size in [15, 24, 34, 44, 180]\">\n\t\t\t<span>\n\t\t\t\t{{ size }}px\n\t\t\t</span>\n\t\t\t<NcAvatar user=\"alice-smith\"\n\t\t\t\tdisplay-name=\"Alice Smith\"\n\t\t\t\t:size=\"size\"\n\t\t\t\t:preloaded-user-status=\"status.online\" />\n\t\t\t<NcAvatar user=\"bob-doe\"\n\t\t\t\tdisplay-name=\"Bob Doe\"\n\t\t\t\t:size=\"size\"\n\t\t\t\t:preloaded-user-status=\"status.meeting\" />\n\t\t</div>\n\t\t<div>\n\t\t\t<div>\n\t\t\t\tCustom: {{ customSize }}px\n\t\t\t</div>\n\t\t\t<NcAvatar user=\"alice-smith\"\n\t\t\t\tdisplay-name=\"Alice Smith\"\n\t\t\t\t:size=\"customSize\"\n\t\t\t\t:preloaded-user-status=\"status.online\" />\n\t\t\t<NcAvatar user=\"bob-doe\"\n\t\t\t\tdisplay-name=\"Bob Doe\"\n\t\t\t\t:size=\"customSize\"\n\t\t\t\t:preloaded-user-status=\"status.meeting\" />\n\t\t</div>\n\t\t<div>\n\t\t\t<input type=\"range\" v-model=\"customSize\" :min=\"15\" :max=\"180\" step=\"1\" />\n\t\t</div>\n\t</div>\n</template>\n\n<script>\nimport AccountMultiple from 'vue-material-design-icons/AccountMultiple.vue'\n\nexport default {\n\tcomponents: {\n\t\tAccountMultiple,\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tcustomSize: 20,\n\t\t\tstatus: {\n\t\t\t\tonline: {\n\t\t\t\t\ticon: '',\n\t\t\t\t\tstatus: 'online',\n\t\t\t\t\tmessage: 'Available',\n\t\t\t\t},\n\t\t\t\tmeeting: {\n\t\t\t\t\ticon: 'đ',\n\t\t\t\t\tstatus: 'online',\n\t\t\t\t\tmessage: 'In a meeting',\n\t\t\t\t},\n\t\t\t},\n\t\t}\n\t},\n}\n</script>\n```\n\n</docs>\n\n<template>\n\t<span\n\t\tv-click-outside=\"closeMenu\"\n\t\t:title=\"tooltip\"\n\t\t:class=\"{\n\t\t\t'avatardiv--unknown': userDoesNotExist,\n\t\t\t'avatardiv--with-menu': hasMenu,\n\t\t\t'avatardiv--with-menu-loading': contactsMenuLoading,\n\t\t}\"\n\t\t:style=\"avatarStyle\"\n\t\tclass=\"avatardiv popovermenu-wrapper\">\n\t\t<!-- @slot Icon slot -->\n\t\t<slot name=\"icon\">\n\t\t\t<!-- Avatar icon or image -->\n\t\t\t<span v-if=\"iconClass\" :class=\"iconClass\" class=\"avatar-class-icon\" />\n\t\t\t<img\n\t\t\t\tv-else-if=\"isAvatarLoaded && !userDoesNotExist\"\n\t\t\t\t:src=\"avatarUrlLoaded\"\n\t\t\t\t:srcset=\"avatarSrcSetLoaded\"\n\t\t\t\talt=\"\">\n\t\t</slot>\n\n\t\t<!-- Contact menu -->\n\t\t<!-- We show a button if the menu is not loaded yet. -->\n\t\t<NcButton\n\t\t\tv-if=\"hasMenu && menu.length === 0\"\n\t\t\t:aria-label=\"avatarAriaLabel\"\n\t\t\tclass=\"action-item action-item__menutoggle\"\n\t\t\tvariant=\"tertiary-no-background\"\n\t\t\t@click=\"toggleMenu\">\n\t\t\t<template #icon>\n\t\t\t\t<NcLoadingIcon v-if=\"contactsMenuLoading\" />\n\t\t\t\t<IconDotsHorizontal v-else :size=\"20\" />\n\t\t\t</template>\n\t\t</NcButton>\n\t\t<NcActions\n\t\t\tv-else-if=\"hasMenu\"\n\t\t\t:aria-label=\"avatarAriaLabel\"\n\t\t\t:container=\"menuContainer\"\n\t\t\tforce-menu\n\t\t\tmanual-open\n\t\t\t:open.sync=\"contactsMenuOpenState\"\n\t\t\tvariant=\"tertiary-no-background\"\n\t\t\t@click=\"toggleMenu\">\n\t\t\t<component\n\t\t\t\t:is=\"item.ncActionComponent\"\n\t\t\t\tv-for=\"(item, key) in menu\"\n\t\t\t\t:key=\"key\"\n\t\t\t\tv-bind=\"item.ncActionComponentProps\"\n\t\t\t\tv-on=\"item.ncActionComponentHandlers\">\n\t\t\t\t<template v-if=\"item.iconSvg\" #icon>\n\t\t\t\t\t<NcIconSvgWrapper :svg=\"item.iconSvg\" />\n\t\t\t\t</template>\n\t\t\t\t{{ item.text }}\n\t\t\t</component>\n\t\t\t<template v-if=\"contactsMenuLoading\" #icon>\n\t\t\t\t<NcLoadingIcon />\n\t\t\t</template>\n\t\t</NcActions>\n\n\t\t<!-- Avatar status -->\n\t\t<span v-if=\"showUserStatusIconOnAvatar\" class=\"avatardiv__user-status avatardiv__user-status--icon\">\n\t\t\t{{ userStatus.icon }}\n\t\t</span>\n\t\t<NcUserStatusIcon\n\t\t\tv-else-if=\"canDisplayUserStatus\"\n\t\t\tclass=\"avatardiv__user-status\"\n\t\t\t:status=\"userStatus.status\"\n\t\t\t:aria-hidden=\"String(hasMenu)\" />\n\n\t\t<!-- Show the letter if no avatar nor icon class -->\n\t\t<span\n\t\t\tv-if=\"showInitials\"\n\t\t\t:style=\"initialsWrapperStyle\"\n\t\t\tclass=\"avatardiv__initials-wrapper\">\n\t\t\t<span :style=\"initialsStyle\" class=\"avatardiv__initials\">\n\t\t\t\t{{ initials }}\n\t\t\t</span>\n\t\t</span>\n\t</span>\n</template>\n\n<script>\nimport { getCurrentUser } from '@nextcloud/auth'\nimport axios from '@nextcloud/axios'\nimport { getBuilder } from '@nextcloud/browser-storage'\nimport { subscribe, unsubscribe } from '@nextcloud/event-bus'\nimport { generateUrl } from '@nextcloud/router'\nimport { vOnClickOutside as ClickOutside } from '@vueuse/components'\nimport IconDotsHorizontal from 'vue-material-design-icons/DotsHorizontal.vue'\nimport { getRoute } from '../../components/NcRichText/autolink.js'\nimport { useIsDarkTheme } from '../../composables/useIsDarkTheme/index.ts'\nimport { getEnabledContactsMenuActions } from '../../functions/contactsMenu/index.ts'\nimport usernameToColor from '../../functions/usernameToColor/index.js'\nimport { t } from '../../l10n.js'\nimport { userStatus } from '../../mixins/index.js'\nimport { getAvatarUrl } from '../../utils/getAvatarUrl.ts'\nimport { logger } from '../../utils/logger.ts'\nimport { getUserStatusText } from '../../utils/UserStatus.ts'\nimport NcActionButton from '../NcActionButton/index.js'\nimport NcActionLink from '../NcActionLink/index.js'\nimport NcActionRouter from '../NcActionRouter/index.js'\nimport NcActions from '../NcActions/index.js'\nimport NcActionText from '../NcActionText/index.js'\nimport NcButton from '../NcButton/index.js'\nimport NcIconSvgWrapper from '../NcIconSvgWrapper/index.js'\nimport NcLoadingIcon from '../NcLoadingIcon/index.js'\nimport NcUserStatusIcon from '../NcUserStatusIcon/index.js'\n\nconst browserStorage = getBuilder('nextcloud').persist().build()\n\n/**\n * @param {string} userId The id of the user\n */\nfunction getUserHasAvatar(userId) {\n\tconst flag = browserStorage.getItem('user-has-avatar.' + userId)\n\tif (typeof flag === 'string') {\n\t\treturn Boolean(flag)\n\t}\n\treturn null\n}\n\n/**\n * @param {string} userId The id of the user\n * @param {boolean} flag Has the user an avatar\n */\nfunction setUserHasAvatar(userId, flag) {\n\tif (userId) {\n\t\tbrowserStorage.setItem('user-has-avatar.' + userId, flag)\n\t}\n}\n\nexport default {\n\tname: 'NcAvatar',\n\n\tdirectives: {\n\t\tClickOutside,\n\t},\n\n\tcomponents: {\n\t\tIconDotsHorizontal,\n\t\tNcActions,\n\t\tNcButton,\n\t\tNcIconSvgWrapper,\n\t\tNcLoadingIcon,\n\t\tNcUserStatusIcon,\n\t},\n\n\tmixins: [userStatus],\n\tprops: {\n\t\t/**\n\t\t * Set a custom url to the avatar image\n\t\t * either the url, user or displayName property must be defined\n\t\t */\n\t\turl: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Set a css icon-class for an icon to be used instead of the avatar.\n\t\t */\n\t\ticonClass: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Set the user id to fetch the avatar\n\t\t * either the url, user or displayName property must be defined\n\t\t */\n\t\tuser: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Do not show the user status on the avatar.\n\t\t */\n\t\thideStatus: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Whether or not to display the user-status.\n\t\t *\n\t\t * @deprecated - Use `hideStatus` instead. Will be removed with v9.\n\t\t */\n\t\tshowUserStatus: {\n\t\t\ttype: Boolean,\n\t\t\t// eslint-disable-next-line vue/no-boolean-default\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * Show the verbose user status (e.g. \"online\" / \"away\") instead of just the status icon.\n\t\t */\n\t\tverboseStatus: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Whether or not to the status-icon should be used instead of online/away\n\t\t *\n\t\t * @deprecated - Use `verboseStatus` instead. Will be removed with v9.\n\t\t */\n\t\tshowUserStatusCompact: {\n\t\t\ttype: Boolean,\n\t\t\t// eslint-disable-next-line vue/no-boolean-default\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * When the user status was preloaded via another source it can be handed in with this property to save the request.\n\t\t * If this property is not set the status will be fetched automatically.\n\t\t * If a preloaded no-status is available provide this object with properties \"status\", \"icon\" and \"message\" set to null.\n\t\t */\n\t\tpreloadedUserStatus: {\n\t\t\ttype: Object,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Is the user a guest user (then we have to user a different endpoint)\n\t\t */\n\t\tisGuest: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Set a display name that will be rendered as a tooltip\n\t\t * either the url, user or displayName property must be defined\n\t\t * specify just the displayname to generate a placeholder avatar without\n\t\t * trying to fetch the avatar based on the user id\n\t\t */\n\t\tdisplayName: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Set a size in px for the rendered avatar\n\t\t */\n\t\tsize: {\n\t\t\ttype: Number,\n\t\t\tdefault: 32,\n\t\t},\n\n\t\t/**\n\t\t * Do not automatically generate a placeholder avatars if there is no real avatar is available.\n\t\t */\n\t\tnoPlaceholder: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Placeholder avatars will be automatically generated when this is set to true.\n\t\t *\n\t\t * @deprecated - Use `noPlaceholder` instead. Will be removed in v9.\n\t\t */\n\t\tallowPlaceholder: {\n\t\t\ttype: Boolean,\n\t\t\t// eslint-disable-next-line vue/no-boolean-default\n\t\t\tdefault: true,\n\t\t},\n\n\t\t/**\n\t\t * Disable the tooltip\n\t\t */\n\t\tdisableTooltip: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Disable the menu\n\t\t */\n\t\tdisableMenu: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Declares a custom tooltip when not null\n\t\t * Fallback will be the displayName\n\t\t *\n\t\t * requires disableTooltip not to be set to true\n\t\t */\n\t\ttooltipMessage: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Declares username is not a user's name, when true.\n\t\t * Prevents loading user's avatar from server and forces generating colored initials,\n\t\t * i.e. if the user is a group\n\t\t */\n\t\tisNoUser: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Selector for the popover menu container\n\t\t */\n\t\tmenuContainer: {\n\t\t\ttype: [Boolean, String, Object, Element],\n\t\t\tdefault: 'body',\n\t\t},\n\t},\n\n\tsetup() {\n\t\tconst isDarkTheme = useIsDarkTheme()\n\n\t\treturn {\n\t\t\tisDarkTheme,\n\t\t}\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tavatarUrlLoaded: null,\n\t\t\tavatarSrcSetLoaded: null,\n\t\t\tuserDoesNotExist: false,\n\t\t\tisAvatarLoaded: false,\n\t\t\tisMenuLoaded: false,\n\t\t\tcontactsMenuLoading: false,\n\t\t\tcontactsMenuData: {},\n\t\t\tcontactsMenuActions: [],\n\t\t\tcontactsMenuOpenState: false,\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tavatarAriaLabel() {\n\t\t\t// aria-label is only allowed on interactive elements\n\t\t\tif (!this.hasMenu) {\n\t\t\t\treturn\n\t\t\t}\n\t\t\tif (this.canDisplayUserStatus || this.showUserStatusIconOnAvatar) {\n\t\t\t\treturn t('Avatar of {displayName}, {status}', { displayName: this.displayName ?? this.user, status: getUserStatusText(this.userStatus.status) })\n\t\t\t}\n\t\t\treturn t('Avatar of {displayName}', { displayName: this.displayName ?? this.user })\n\t\t},\n\n\t\tcanDisplayUserStatus() {\n\t\t\treturn !this.hideStatus\n\t\t\t\t&& this.showUserStatus\n\t\t\t\t&& this.hasStatus\n\t\t\t\t&& ['online', 'away', 'busy', 'dnd'].includes(this.userStatus.status)\n\t\t},\n\n\t\tshowUserStatusIconOnAvatar() {\n\t\t\treturn !this.hideStatus\n\t\t\t\t&& this.showUserStatus\n\t\t\t\t&& !this.verboseStatus\n\t\t\t\t&& this.showUserStatusCompact\n\t\t\t\t&& this.hasStatus\n\t\t\t\t&& this.userStatus.status !== 'dnd'\n\t\t\t\t&& this.userStatus.icon\n\t\t},\n\n\t\t/**\n\t\t * The user identifier, either the display name if set or the user property\n\t\t * If both properties are not set an empty string is returned\n\t\t */\n\t\tuserIdentifier() {\n\t\t\tif (this.isDisplayNameDefined) {\n\t\t\t\treturn this.displayName\n\t\t\t}\n\t\t\tif (this.isUserDefined) {\n\t\t\t\treturn this.user\n\t\t\t}\n\t\t\treturn ''\n\t\t},\n\n\t\tisUserDefined() {\n\t\t\treturn typeof this.user !== 'undefined'\n\t\t},\n\n\t\tisDisplayNameDefined() {\n\t\t\treturn typeof this.displayName !== 'undefined'\n\t\t},\n\n\t\tisUrlDefined() {\n\t\t\treturn typeof this.url !== 'undefined'\n\t\t},\n\n\t\thasMenu() {\n\t\t\tif (this.disableMenu) {\n\t\t\t\treturn false\n\t\t\t}\n\t\t\tif (this.isMenuLoaded) {\n\t\t\t\treturn this.menu.length > 0\n\t\t\t}\n\t\t\treturn !(this.user === getCurrentUser()?.uid || this.userDoesNotExist || this.url)\n\t\t},\n\n\t\t/**\n\t\t * True if initials should be shown as the user icon fallback\n\t\t */\n\t\tshowInitials() {\n\t\t\treturn !this.noPlaceholder && this.allowPlaceholder && this.userDoesNotExist && !(this.iconClass || this.$slots.icon)\n\t\t},\n\n\t\tavatarStyle() {\n\t\t\treturn {\n\t\t\t\t'--avatar-size': this.size + 'px',\n\t\t\t\tlineHeight: this.showInitials ? (this.size + 'px') : 0,\n\t\t\t\tfontSize: Math.round(this.size * 0.45) + 'px',\n\t\t\t}\n\t\t},\n\n\t\tinitialsWrapperStyle() {\n\t\t\tconst { r, g, b } = usernameToColor(this.userIdentifier)\n\t\t\treturn {\n\t\t\t\tbackgroundColor: `rgba(${r}, ${g}, ${b}, 0.1)`,\n\t\t\t}\n\t\t},\n\n\t\tinitialsStyle() {\n\t\t\tconst { r, g, b } = usernameToColor(this.userIdentifier)\n\t\t\treturn {\n\t\t\t\tcolor: `rgb(${r}, ${g}, ${b})`,\n\t\t\t}\n\t\t},\n\n\t\ttooltip() {\n\t\t\tif (this.disableTooltip) {\n\t\t\t\treturn false\n\t\t\t}\n\t\t\tif (this.tooltipMessage) {\n\t\t\t\treturn this.tooltipMessage\n\t\t\t}\n\n\t\t\treturn this.displayName\n\t\t},\n\n\t\t/**\n\t\t * Get the (max. two) initials of the user as uppcase string\n\t\t */\n\t\tinitials() {\n\t\t\tlet initials = '?'\n\t\t\tif (this.showInitials) {\n\t\t\t\tconst user = this.userIdentifier.trim()\n\t\t\t\tif (user === '') {\n\t\t\t\t\treturn initials\n\t\t\t\t}\n\n\t\t\t\t/**\n\t\t\t\t * Filtered user name, without special characters so only letters and numbers are allowed (prevent e.g. '(' as an initial)\n\t\t\t\t * \\p{L}: Letters of all languages\n\t\t\t\t * \\p{N}: Numbers of all languages\n\t\t\t\t * \\s: White space for breaking the string\n\t\t\t\t *\n\t\t\t\t * @type {string}\n\t\t\t\t */\n\t\t\t\tconst filteredChars = user.match(/[\\p{L}\\p{N}\\s]/gu)\n\t\t\t\tif (!filteredChars) {\n\t\t\t\t\treturn initials\n\t\t\t\t}\n\n\t\t\t\tconst filtered = filteredChars.join('')\n\t\t\t\tconst idx = filtered.lastIndexOf(' ')\n\t\t\t\tinitials = String.fromCodePoint(filtered.codePointAt(0))\n\t\t\t\tif (idx !== -1) {\n\t\t\t\t\tinitials = initials.concat(String.fromCodePoint(filtered.codePointAt(idx + 1)))\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn initials.toLocaleUpperCase()\n\t\t},\n\n\t\tmenu() {\n\t\t\tconst actions = this.contactsMenuActions.map((item) => {\n\t\t\t\tconst route = getRoute(this.$router, item.hyperlink)\n\t\t\t\treturn {\n\t\t\t\t\tncActionComponent: route ? NcActionRouter : NcActionLink,\n\t\t\t\t\tncActionComponentProps: route\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tto: route,\n\t\t\t\t\t\t\t\ticon: item.icon,\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {\n\t\t\t\t\t\t\t\thref: item.hyperlink,\n\t\t\t\t\t\t\t\ticon: item.icon,\n\t\t\t\t\t\t\t},\n\t\t\t\t\ttext: item.title,\n\t\t\t\t}\n\t\t\t})\n\n\t\t\tfor (const action of getEnabledContactsMenuActions(this.contactsMenuData)) {\n\t\t\t\ttry {\n\t\t\t\t\tactions.push({\n\t\t\t\t\t\tncActionComponent: NcActionButton,\n\t\t\t\t\t\tncActionComponentProps: {},\n\t\t\t\t\t\tncActionComponentHandlers: {\n\t\t\t\t\t\t\tclick: () => action.callback(this.contactsMenuData),\n\t\t\t\t\t\t},\n\t\t\t\t\t\ttext: action.displayName(this.contactsMenuData),\n\t\t\t\t\t\ticonSvg: action.iconSvg(this.contactsMenuData),\n\t\t\t\t\t})\n\t\t\t\t} catch (error) {\n\t\t\t\t\tlogger.error(`Failed to render ContactsMenu action ${action.id}`, {\n\t\t\t\t\t\terror,\n\t\t\t\t\t\taction,\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t/**\n\t\t\t * @param {string} html The HTML to escape\n\t\t\t */\n\t\t\tfunction escape(html) {\n\t\t\t\tconst text = document.createTextNode(html)\n\t\t\t\tconst p = document.createElement('p')\n\t\t\t\tp.appendChild(text)\n\t\t\t\treturn p.innerHTML\n\t\t\t}\n\n\t\t\tif (!this.hideStatus && this.showUserStatus && (this.userStatus.icon || this.userStatus.message)) {\n\t\t\t\t// NcAction's URL icons are inverted in dark mode, so we need to pass SVG image in the icon slot\n\t\t\t\tconst emojiIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 16 16\">\n\t\t\t\t\t<text x=\"50%\" y=\"50%\" text-anchor=\"middle\" style=\"dominant-baseline: central; font-size: 85%\">${escape(this.userStatus.icon)}</text>\n\t\t\t\t</svg>`\n\t\t\t\treturn [{\n\t\t\t\t\tncActionComponent: NcActionText,\n\t\t\t\t\tncActionComponentProps: {},\n\t\t\t\t\ticonSvg: this.userStatus.icon ? emojiIcon : undefined,\n\t\t\t\t\ttext: `${this.userStatus.message}`,\n\t\t\t\t}].concat(actions)\n\t\t\t}\n\n\t\t\treturn actions\n\t\t},\n\t},\n\n\twatch: {\n\t\turl() {\n\t\t\tthis.userDoesNotExist = false\n\t\t\tthis.loadAvatarUrl()\n\t\t},\n\n\t\tuser() {\n\t\t\tthis.userDoesNotExist = false\n\t\t\tthis.isMenuLoaded = false\n\t\t\tthis.loadAvatarUrl()\n\t\t},\n\t},\n\n\tmounted() {\n\t\tthis.loadAvatarUrl()\n\t\tsubscribe('settings:avatar:updated', this.loadAvatarUrl)\n\t\tsubscribe('settings:display-name:updated', this.loadAvatarUrl)\n\t\tif (!this.hideStatus && this.showUserStatus && this.user && !this.isNoUser) {\n\t\t\tif (!this.preloadedUserStatus) {\n\t\t\t\tthis.fetchUserStatus(this.user)\n\t\t\t} else {\n\t\t\t\tthis.userStatus.status = this.preloadedUserStatus.status || ''\n\t\t\t\tthis.userStatus.message = this.preloadedUserStatus.message || ''\n\t\t\t\tthis.userStatus.icon = this.preloadedUserStatus.icon || ''\n\t\t\t\tthis.hasStatus = this.preloadedUserStatus.status !== null\n\t\t\t}\n\t\t\tsubscribe('user_status:status.updated', this.handleUserStatusUpdated)\n\t\t}\n\t},\n\n\tbeforeDestroy() {\n\t\tunsubscribe('settings:avatar:updated', this.loadAvatarUrl)\n\t\tunsubscribe('settings:display-name:updated', this.loadAvatarUrl)\n\t\tunsubscribe('user_status:status.updated', this.handleUserStatusUpdated)\n\t},\n\n\tmethods: {\n\t\tt,\n\t\thandleUserStatusUpdated(state) {\n\t\t\tif (this.user === state.userId) {\n\t\t\t\tthis.userStatus = {\n\t\t\t\t\tstatus: state.status,\n\t\t\t\t\ticon: state.icon,\n\t\t\t\t\tmessage: state.message,\n\t\t\t\t}\n\t\t\t\tthis.hasStatus = state.status !== null\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Toggle the popover menu on click or enter\n\t\t *\n\t\t * @param {KeyboardEvent|MouseEvent} event the UI event\n\t\t */\n\t\tasync toggleMenu(event) {\n\t\t\tif (event.type === 'keydown' && event.key !== 'Enter') {\n\t\t\t\treturn\n\t\t\t}\n\t\t\tif (!this.contactsMenuOpenState) {\n\t\t\t\tawait this.fetchContactsMenu()\n\t\t\t}\n\t\t\tthis.contactsMenuOpenState = !this.contactsMenuOpenState\n\t\t},\n\n\t\tcloseMenu() {\n\t\t\tthis.contactsMenuOpenState = false\n\t\t},\n\n\t\tasync fetchContactsMenu() {\n\t\t\tthis.contactsMenuLoading = true\n\t\t\ttry {\n\t\t\t\tconst user = encodeURIComponent(this.user)\n\t\t\t\tconst { data } = await axios.post(generateUrl('contactsmenu/findOne'), `shareType=0&shareWith=${user}`)\n\t\t\t\tthis.contactsMenuData = data\n\t\t\t\tthis.contactsMenuActions = data.topAction ? [data.topAction].concat(data.actions) : data.actions\n\t\t\t} catch {\n\t\t\t\tthis.contactsMenuOpenState = false\n\t\t\t}\n\t\t\tthis.contactsMenuLoading = false\n\t\t\tthis.isMenuLoaded = true\n\t\t},\n\n\t\t/**\n\t\t * Handle avatar loading if user or url defined\n\t\t */\n\t\tloadAvatarUrl() {\n\t\t\tthis.isAvatarLoaded = false\n\n\t\t\t/** Only run avatar image loading if either user or url property is defined */\n\t\t\tif (!this.isUrlDefined && (!this.isUserDefined || this.isNoUser || this.iconClass)) {\n\t\t\t\tthis.isAvatarLoaded = true\n\t\t\t\tthis.userDoesNotExist = true\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\t// Directly use the url if defined\n\t\t\tif (this.isUrlDefined) {\n\t\t\t\tthis.updateImageIfValid(this.url)\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tif (this.size <= 64) {\n\t\t\t\tconst avatarUrl = this.avatarUrlGenerator(this.user, 64)\n\t\t\t\tconst srcset = [\n\t\t\t\t\tavatarUrl + ' 1x',\n\t\t\t\t\tthis.avatarUrlGenerator(this.user, 512) + ' 8x',\n\t\t\t\t].join(', ')\n\n\t\t\t\tthis.updateImageIfValid(avatarUrl, srcset)\n\t\t\t} else {\n\t\t\t\tconst avatarUrl = this.avatarUrlGenerator(this.user, 512)\n\t\t\t\tthis.updateImageIfValid(avatarUrl)\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Generate an avatar url from the server's avatar endpoint\n\t\t *\n\t\t * @param {string} user the user id\n\t\t * @param {number} size the desired size\n\t\t * @return {string}\n\t\t */\n\t\tavatarUrlGenerator(user, size) {\n\t\t\tlet avatarUrl = getAvatarUrl(user, {\n\t\t\t\tsize,\n\t\t\t\tisDarkTheme: this.isDarkTheme,\n\t\t\t\tisGuest: this.isGuest,\n\t\t\t})\n\n\t\t\tif (user === getCurrentUser()?.uid && typeof window.oc_userconfig !== 'undefined') {\n\t\t\t\tavatarUrl += '?v=' + window.oc_userconfig.avatar.version\n\t\t\t}\n\n\t\t\treturn avatarUrl\n\t\t},\n\n\t\t/**\n\t\t * Check if the provided url is valid and update Avatar if so\n\t\t *\n\t\t * @param {string} url the avatar url\n\t\t * @param {Array} srcset the avatar srcset\n\t\t */\n\t\tupdateImageIfValid(url, srcset = null) {\n\t\t\t// skip loading\n\t\t\tconst userHasAvatar = getUserHasAvatar(this.user)\n\t\t\tif (this.isUserDefined && typeof userHasAvatar === 'boolean') {\n\t\t\t\tthis.isAvatarLoaded = true\n\t\t\t\tthis.avatarUrlLoaded = url\n\t\t\t\tif (srcset) {\n\t\t\t\t\tthis.avatarSrcSetLoaded = srcset\n\t\t\t\t}\n\t\t\t\tif (userHasAvatar === false) {\n\t\t\t\t\tthis.userDoesNotExist = true\n\t\t\t\t}\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tconst img = new Image()\n\t\t\timg.onload = () => {\n\t\t\t\tthis.avatarUrlLoaded = url\n\t\t\t\tif (srcset) {\n\t\t\t\t\tthis.avatarSrcSetLoaded = srcset\n\t\t\t\t}\n\t\t\t\tthis.isAvatarLoaded = true\n\t\t\t\t// re-get to avoid concurrent access\n\t\t\t\tsetUserHasAvatar(this.user, true)\n\t\t\t}\n\t\t\timg.onerror = (error) => {\n\t\t\t\tlogger.debug('Invalid avatar url', { error, url })\n\t\t\t\t// Avatar is invalid, reset\n\t\t\t\tthis.avatarUrlLoaded = null\n\t\t\t\tthis.avatarSrcSetLoaded = null\n\n\t\t\t\tthis.userDoesNotExist = true\n\t\t\t\tthis.isAvatarLoaded = false\n\t\t\t\tsetUserHasAvatar(this.user, false)\n\t\t\t}\n\n\t\t\tif (srcset) {\n\t\t\t\timg.srcset = srcset\n\t\t\t}\n\t\t\timg.src = url\n\t\t},\n\t},\n}\n</script>\n\n<style scoped lang=\"scss\">\n.avatardiv {\n\tposition: relative;\n\tdisplay: inline-block;\n\twidth: var(--avatar-size);\n\theight: var(--avatar-size);\n\n\t&--unknown {\n\t\tposition: relative;\n\t\tbackground-color: var(--color-main-background);\n\t\twhite-space: normal;\n\t}\n\n\t&:not(&--unknown) {\n\t\t// White/black background for avatars with transparency\n\t\tbackground-color: var(--color-main-background) !important;\n\t\tbox-shadow: 0 0 5px rgba(0, 0, 0, 0.05) inset;\n\t}\n\n\t&--with-menu {\n\t\tcursor: pointer;\n\t\t.action-item {\n\t\t\tposition: absolute;\n\t\t\ttop: 0;\n\t\t\tleft: 0;\n\t\t}\n\t\t:deep(.action-item__menutoggle) {\n\t\t\tcursor: pointer;\n\t\t\topacity: 0;\n\t\t}\n\t\t&:focus-within,\n\t\t&:hover,\n\t\t&#{&}-loading {\n\t\t\t:deep(.action-item__menutoggle) {\n\t\t\t\topacity: 1;\n\t\t\t}\n\t\t\timg {\n\t\t\t\topacity: 0.3;\n\t\t\t}\n\t\t}\n\t\t:deep(.action-item__menutoggle),\n\t\timg {\n\t\t\ttransition: opacity var(--animation-quick);\n\t\t}\n\t\t:deep() {\n\t\t\t.button-vue,\n\t\t\t.button-vue__icon {\n\t\t\t\theight: var(--avatar-size);\n\t\t\t\tmin-height: var(--avatar-size);\n\t\t\t\twidth: var(--avatar-size) !important;\n\t\t\t\tmin-width: var(--avatar-size);\n\t\t\t}\n\t\t}\n\t\t& > :deep(.button-vue),\n\t\t& > :deep(.action-item .button-vue) {\n\t\t\t--button-radius: calc(var(--avatar-size) / 2);\n\t\t}\n\t}\n\n\t.avatardiv__initials-wrapper {\n\t\tdisplay: block;\n\t\theight: var(--avatar-size);\n\t\twidth: var(--avatar-size);\n\t\tbackground-color: var(--color-main-background);\n\t\tborder-radius: calc(var(--avatar-size) / 2);\n\n\t\t.avatardiv__initials {\n\t\t\tposition: absolute;\n\t\t\ttop: 0;\n\t\t\tleft: 0;\n\t\t\tdisplay: block;\n\t\t\twidth: 100%;\n\t\t\ttext-align: center;\n\t\t\tfont-weight: normal;\n\t\t}\n\t}\n\n\timg {\n\t\t// Cover entire area\n\t\twidth: 100%;\n\t\theight: 100%;\n\t\t// Keep ratio\n\t\tobject-fit: cover;\n\t}\n\n\t.material-design-icon {\n\t\twidth: var(--avatar-size);\n\t\theight: var(--avatar-size);\n\t}\n\n\t.avatardiv__user-status {\n\t\t// Size of the status icon to make it:\n\t\t// - đĢ Orbital: the status icon's center is positioned on the avatar circle\n\t\t// - âšī¸ Best-fit: the status icon is as large as possible without exceeding the avatar box\n\t\t// See PR for math explanation: PR #6004\n\t\t--avatar-status-size-orbital: calc(var(--avatar-size) * (1 - 1 / sqrt(2)));\n\t\t// Limit the status icon size to minimum font size to keep it readable\n\t\t// Ideally avatars with a smaller should not be used with the status icon at all\n\t\t--avatar-status-size-min: var(--font-size-small);\n\t\t--avatar-status-size: max(var(--avatar-status-size-orbital), var(--avatar-status-size-min));\n\t\tbox-sizing: border-box;\n\t\tposition: absolute;\n\t\tinset-inline-end: 0;\n\t\tinset-block-end: 0;\n\t\theight: var(--avatar-status-size);\n\t\twidth: var(--avatar-status-size);\n\t\tline-height: 1;\n\t\tfont-size: calc(var(--avatar-status-size) / 1.2);\n\t\tbackground-color: var(--color-main-background);\n\t\tbackground-repeat: no-repeat;\n\t\tbackground-size: var(--avatar-status-size);\n\t\tbackground-position: center;\n\t\tborder-radius: 50%;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: center;\n\n\t\t.acli:hover & {\n\t\t\tborder-color: var(--color-background-hover);\n\t\t\tbackground-color: var(--color-background-hover);\n\t\t}\n\t\t.acli.active & {\n\t\t\tborder-color: var(--color-primary-element-light);\n\t\t\tbackground-color: var(--color-primary-element-light);\n\t\t}\n\n\t\t&--icon {\n\t\t\tborder: none;\n\t\t\tbackground-color: transparent;\n\t\t}\n\t}\n\n\t.popovermenu-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t}\n}\n\n.avatar-class-icon {\n\tdisplay: block;\n\tborder-radius: calc(var(--avatar-size) / 2);\n\tbackground-color: var(--color-background-darker);\n\theight: 100%;\n}\n\n</style>\n"],"names":["capabilities","getCapabilities","getCurrentUser","axios","generateOcsUrl","logger","getBuilder","ClickOutside","IconDotsHorizontal","NcActions","NcButton","NcIconSvgWrapper","NcLoadingIcon","NcUserStatusIcon","useIsDarkTheme","t","getUserStatusText","usernameToColor","getRoute","NcActionRouter","NcActionLink","getEnabledContactsMenuActions","NcActionButton","NcActionText","subscribe","unsubscribe","generateUrl","getAvatarUrl"],"mappings":"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"}
|