@nextcloud/vue 8.19.0 → 8.21.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 +62 -0
- package/dist/Components/NcActionButton.cjs +4 -4
- package/dist/Components/NcActionButton.mjs +4 -4
- package/dist/Components/NcActionButtonGroup.cjs +1 -1
- package/dist/Components/NcActionButtonGroup.mjs +1 -1
- package/dist/Components/NcActionCaption.cjs +1 -1
- package/dist/Components/NcActionCaption.mjs +1 -1
- package/dist/Components/NcActionCheckbox.cjs +2 -106
- package/dist/Components/NcActionCheckbox.cjs.map +1 -1
- package/dist/Components/NcActionCheckbox.mjs +2 -106
- package/dist/Components/NcActionCheckbox.mjs.map +1 -1
- package/dist/Components/NcActionInput.cjs +1 -1
- package/dist/Components/NcActionInput.mjs +1 -1
- package/dist/Components/NcActionLink.cjs +2 -2
- package/dist/Components/NcActionLink.mjs +2 -2
- package/dist/Components/NcActionRadio.cjs +2 -108
- package/dist/Components/NcActionRadio.cjs.map +1 -1
- package/dist/Components/NcActionRadio.mjs +2 -108
- package/dist/Components/NcActionRadio.mjs.map +1 -1
- package/dist/Components/NcActionRouter.cjs +2 -2
- package/dist/Components/NcActionRouter.mjs +2 -2
- package/dist/Components/NcActionSeparator.cjs +1 -1
- package/dist/Components/NcActionSeparator.mjs +1 -1
- package/dist/Components/NcActionText.cjs +2 -2
- package/dist/Components/NcActionText.mjs +2 -2
- package/dist/Components/NcActionTextEditable.cjs +2 -89
- package/dist/Components/NcActionTextEditable.cjs.map +1 -1
- package/dist/Components/NcActionTextEditable.mjs +2 -89
- package/dist/Components/NcActionTextEditable.mjs.map +1 -1
- package/dist/Components/NcActions.cjs +1 -1
- package/dist/Components/NcActions.mjs +1 -1
- package/dist/Components/NcAppContent.cjs +1 -1
- package/dist/Components/NcAppContent.mjs +1 -1
- package/dist/Components/NcAppNavigation.cjs +1 -1
- package/dist/Components/NcAppNavigation.mjs +1 -1
- package/dist/Components/NcAppNavigationCaption.cjs +1 -1
- package/dist/Components/NcAppNavigationCaption.mjs +1 -1
- package/dist/Components/NcAppNavigationIconBullet.cjs +1 -1
- package/dist/Components/NcAppNavigationIconBullet.mjs +1 -1
- package/dist/Components/NcAppNavigationItem.cjs +1 -1
- package/dist/Components/NcAppNavigationItem.mjs +1 -1
- package/dist/Components/NcAppNavigationList.cjs +1 -1
- package/dist/Components/NcAppNavigationList.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/NcAppNavigationSpacer.cjs +1 -1
- package/dist/Components/NcAppNavigationSpacer.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 +5 -8
- package/dist/Components/NcAppSettingsSection.cjs.map +1 -1
- package/dist/Components/NcAppSettingsSection.mjs +5 -8
- 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 -4
- package/dist/Components/NcAppSidebarTab.cjs.map +1 -1
- package/dist/Components/NcAppSidebarTab.mjs +3 -4
- package/dist/Components/NcAppSidebarTab.mjs.map +1 -1
- package/dist/Components/NcAvatar.cjs +1 -1
- package/dist/Components/NcAvatar.mjs +1 -1
- package/dist/Components/NcBreadcrumb.cjs +1 -1
- package/dist/Components/NcBreadcrumb.mjs +1 -1
- package/dist/Components/NcBreadcrumbs.cjs +1 -1
- package/dist/Components/NcBreadcrumbs.mjs +1 -1
- package/dist/Components/NcButton.cjs +7 -8
- package/dist/Components/NcButton.cjs.map +1 -1
- package/dist/Components/NcButton.mjs +7 -8
- package/dist/Components/NcButton.mjs.map +1 -1
- package/dist/Components/NcCheckboxRadioSwitch.cjs +1 -1
- package/dist/Components/NcCheckboxRadioSwitch.mjs +1 -1
- package/dist/Components/NcChip.cjs +8 -14
- package/dist/Components/NcChip.cjs.map +1 -1
- package/dist/Components/NcChip.mjs +8 -14
- 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/NcDateTime.cjs +1 -1
- package/dist/Components/NcDateTime.mjs +1 -1
- package/dist/Components/NcDateTimePicker.cjs +37 -17
- package/dist/Components/NcDateTimePicker.cjs.map +1 -1
- package/dist/Components/NcDateTimePicker.mjs +37 -17
- package/dist/Components/NcDateTimePicker.mjs.map +1 -1
- package/dist/Components/NcDateTimePickerNative.cjs +52 -21
- package/dist/Components/NcDateTimePickerNative.cjs.map +1 -1
- package/dist/Components/NcDateTimePickerNative.mjs +52 -21
- 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 +3 -3
- package/dist/Components/NcEllipsisedOption.cjs.map +1 -1
- package/dist/Components/NcEllipsisedOption.mjs +3 -3
- package/dist/Components/NcEllipsisedOption.mjs.map +1 -1
- package/dist/Components/NcEmojiPicker.cjs +1 -1
- package/dist/Components/NcEmojiPicker.mjs +1 -1
- package/dist/Components/NcEmptyContent.cjs +2 -3
- package/dist/Components/NcEmptyContent.cjs.map +1 -1
- package/dist/Components/NcEmptyContent.mjs +2 -3
- package/dist/Components/NcEmptyContent.mjs.map +1 -1
- package/dist/Components/NcGuestContent.cjs +1 -1
- package/dist/Components/NcGuestContent.mjs +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/NcIconSvgWrapper.cjs +1 -1
- package/dist/Components/NcIconSvgWrapper.mjs +1 -1
- package/dist/Components/NcInputField.cjs +2 -232
- package/dist/Components/NcInputField.cjs.map +1 -1
- package/dist/Components/NcInputField.mjs +2 -232
- package/dist/Components/NcInputField.mjs.map +1 -1
- package/dist/Components/NcListItem.cjs +1 -1
- package/dist/Components/NcListItem.mjs +1 -1
- package/dist/Components/NcListItemIcon.cjs +1 -1
- package/dist/Components/NcListItemIcon.mjs +1 -1
- package/dist/Components/NcLoadingIcon.cjs +1 -1
- package/dist/Components/NcLoadingIcon.mjs +1 -1
- package/dist/Components/NcModal.cjs +14 -15
- package/dist/Components/NcModal.cjs.map +1 -1
- package/dist/Components/NcModal.mjs +14 -15
- package/dist/Components/NcModal.mjs.map +1 -1
- package/dist/Components/NcNoteCard.cjs +6 -6
- package/dist/Components/NcNoteCard.cjs.map +1 -1
- package/dist/Components/NcNoteCard.mjs +6 -6
- package/dist/Components/NcNoteCard.mjs.map +1 -1
- package/dist/Components/NcPasswordField.cjs +1 -1
- package/dist/Components/NcPasswordField.mjs +1 -1
- package/dist/Components/NcPopover.cjs +1 -1
- package/dist/Components/NcPopover.mjs +1 -1
- package/dist/Components/NcProgressBar.cjs +1 -1
- package/dist/Components/NcProgressBar.mjs +1 -1
- package/dist/Components/NcRelatedResourcesPanel.cjs +1 -1
- package/dist/Components/NcRelatedResourcesPanel.mjs +1 -1
- package/dist/Components/NcRichContenteditable.cjs +2 -2
- package/dist/Components/NcRichContenteditable.mjs +2 -2
- package/dist/Components/NcRichText.cjs +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/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 +2 -179
- package/dist/Components/NcTextArea.cjs.map +1 -1
- package/dist/Components/NcTextArea.mjs +2 -179
- package/dist/Components/NcTextArea.mjs.map +1 -1
- package/dist/Components/NcTextField.cjs +1 -1
- package/dist/Components/NcTextField.mjs +1 -1
- package/dist/Components/NcTimezonePicker.cjs +1 -1
- package/dist/Components/NcTimezonePicker.mjs +1 -1
- package/dist/Components/NcUserBubble.cjs +1 -1
- package/dist/Components/NcUserBubble.mjs +1 -1
- package/dist/Components/NcUserStatusIcon.cjs +1 -1
- package/dist/Components/NcUserStatusIcon.mjs +1 -1
- package/dist/Components/NcVNodes.cjs +1 -2
- package/dist/Components/NcVNodes.cjs.map +1 -1
- package/dist/Components/NcVNodes.mjs +1 -2
- package/dist/Components/NcVNodes.mjs.map +1 -1
- package/dist/Composables/useHotKey.cjs +2 -4
- package/dist/Composables/useHotKey.cjs.map +1 -1
- package/dist/Composables/useHotKey.mjs +2 -4
- package/dist/Composables/useHotKey.mjs.map +1 -1
- package/dist/Composables/useIsDarkTheme.cjs +18 -0
- package/dist/Composables/useIsDarkTheme.cjs.map +1 -0
- package/dist/Composables/useIsDarkTheme.mjs +18 -0
- package/dist/Composables/useIsDarkTheme.mjs.map +1 -0
- package/dist/Directives/Linkify.cjs +1 -2
- package/dist/Directives/Linkify.cjs.map +1 -1
- package/dist/Directives/Linkify.mjs +1 -2
- package/dist/Directives/Linkify.mjs.map +1 -1
- package/dist/Directives/Tooltip.cjs +1 -1
- package/dist/Directives/Tooltip.mjs +1 -1
- package/dist/Functions/dialog.cjs +27 -0
- package/dist/Functions/dialog.cjs.map +1 -0
- package/dist/Functions/dialog.mjs +25 -0
- package/dist/Functions/dialog.mjs.map +1 -0
- package/dist/Functions/emoji.cjs +1 -1
- package/dist/Functions/emoji.mjs +1 -1
- package/dist/Functions/isDarkTheme.cjs +12 -0
- package/dist/Functions/isDarkTheme.cjs.map +1 -0
- package/dist/Functions/isDarkTheme.mjs +12 -0
- package/dist/Functions/isDarkTheme.mjs.map +1 -0
- 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 +1 -1
- package/dist/Functions/usernameToColor.mjs +1 -1
- package/dist/Mixins/richEditor.cjs +1 -1
- package/dist/Mixins/richEditor.mjs +1 -1
- package/dist/assets/{NcActionButton-D90PTEA5.css → NcActionButton-CNq6xIdS.css} +1 -1
- package/dist/assets/{NcActionCheckbox-sIGqnckr.css → NcActionCheckbox-DeW2CCVc.css} +11 -11
- package/dist/assets/{NcActionInput-C_3Csa6A.css → NcActionInput-CNRERfyh.css} +61 -61
- package/dist/assets/{NcActionLink-Db_ZlqWs.css → NcActionLink-CC6a7Hsf.css} +1 -1
- package/dist/assets/{NcActionRadio-DFcWmvae.css → NcActionRadio-DC7Wp9rR.css} +11 -11
- package/dist/assets/{NcActionRouter-DidTlbov.css → NcActionRouter-CsIBHw6E.css} +1 -1
- package/dist/assets/{NcActionText-DCx1DWXe.css → NcActionText-BSD_HYx4.css} +1 -1
- package/dist/assets/{NcActionTextEditable-Dud9NOdm.css → NcActionTextEditable-Cg16Q4zr.css} +59 -59
- package/dist/assets/{NcAppContent-DVBVZyuW.css → NcAppContent-D97xom6z.css} +29 -24
- package/dist/assets/{NcAppNavigation-fhylfTxx.css → NcAppNavigation-CBN6X2dT.css} +13 -13
- package/dist/assets/{NcAppNavigationItem-CxlG8Qdb.css → NcAppNavigationItem-CNZsPcla.css} +30 -30
- package/dist/assets/{NcAppNavigationToggle-DvYpNzHv.css → NcAppNavigationToggle-Chtb7sE7.css} +5 -5
- package/dist/assets/{NcAppSidebar-CpV7czJx.css → NcAppSidebar-BntAj6H-.css} +73 -73
- package/dist/assets/{NcCheckboxRadioSwitch-BzAGGne9.css → NcCheckboxRadioSwitch-D0kAZROF.css} +31 -31
- package/dist/assets/{NcChip-CEKw1zaK.css → NcChip-CIvAlds6.css} +10 -10
- package/dist/assets/{NcColorPicker-aCjZY65-.css → NcColorPicker-Dw2wy2tU.css} +28 -28
- package/dist/assets/{NcDateTimePicker-BFvU3We7.css → NcDateTimePicker-Dp2wSSiQ.css} +48 -33
- package/dist/assets/NcDateTimePickerNative-BfZfqRvD.css +47 -0
- package/dist/assets/{NcEllipsisedOption-DZK2vWD1.css → NcEllipsisedOption-DGr9_bIL.css} +5 -5
- package/dist/assets/{NcInputField-CQc5dRbY.css → NcInputField-CUsdr7lV.css} +33 -33
- package/dist/assets/{NcModal-Cg2K9DV5.css → NcModal-BBKX-T6V.css} +61 -61
- package/dist/assets/{NcPasswordField-DWd5gg73.css → NcPasswordField-DZ6dcMzH.css} +2 -2
- package/dist/assets/{NcRichContenteditable-BYEZK1DT.css → NcRichContenteditable-DkYYyQTJ.css} +10 -10
- package/dist/assets/NcRichText-BlRmdWCX.css +412 -0
- package/dist/assets/{NcSettingsInputText-DbTNj9E6.css → NcSettingsInputText-Bsp_6DjJ.css} +5 -5
- package/dist/assets/{NcSettingsSelectGroup-CzD7YrGm.css → NcSettingsSelectGroup-BEjOwCJQ.css} +2 -2
- package/dist/assets/{NcTextArea-D8bZi2fT.css → NcTextArea-fzbciv3V.css} +20 -20
- package/dist/assets/{referencePickerModal-9BcmmfUy.css → referencePickerModal-BhhuyO3J.css} +38 -38
- package/dist/chunks/{AlertCircleOutline-DLtiWgZd.cjs → AlertCircleOutline-BrsasUsU.cjs} +1 -1
- package/dist/chunks/AlertCircleOutline-BrsasUsU.cjs.map +1 -0
- package/dist/chunks/{AlertCircleOutline-DU3QwU5Y.mjs → AlertCircleOutline-DBxbepLy.mjs} +1 -1
- package/dist/chunks/AlertCircleOutline-DBxbepLy.mjs.map +1 -0
- package/dist/chunks/{ArrowLeft-CONurT5C.cjs → ArrowLeft-BP7yfzCQ.cjs} +1 -1
- package/dist/chunks/ArrowLeft-BP7yfzCQ.cjs.map +1 -0
- package/dist/chunks/{ArrowLeft-BhAxJBYx.mjs → ArrowLeft-DuT2LZOm.mjs} +1 -1
- package/dist/chunks/ArrowLeft-DuT2LZOm.mjs.map +1 -0
- package/dist/chunks/{ArrowRight-KsL2PC-o.mjs → ArrowRight-CY2b9hgN.mjs} +1 -1
- package/dist/chunks/ArrowRight-CY2b9hgN.mjs.map +1 -0
- package/dist/chunks/{ArrowRight-Bj5G_mG0.cjs → ArrowRight-DPARnmu3.cjs} +1 -1
- package/dist/chunks/ArrowRight-DPARnmu3.cjs.map +1 -0
- package/dist/chunks/{Check-XHAzUBkX.mjs → Check-BkThHPH7.mjs} +1 -1
- package/dist/chunks/Check-BkThHPH7.mjs.map +1 -0
- package/dist/chunks/{Check-fCbe4vqy.cjs → Check-Du8mPz_B.cjs} +1 -1
- package/dist/chunks/Check-Du8mPz_B.cjs.map +1 -0
- package/dist/chunks/{ChevronDown-CiFbcDUC.cjs → ChevronDown-BlfyuflD.cjs} +1 -1
- package/dist/chunks/ChevronDown-BlfyuflD.cjs.map +1 -0
- package/dist/chunks/{ChevronDown-D3Tfshug.mjs → ChevronDown-DFQfzh63.mjs} +1 -1
- package/dist/chunks/ChevronDown-DFQfzh63.mjs.map +1 -0
- package/dist/chunks/{ChevronRight-C3eVhc5a.mjs → ChevronRight-BUv-PtHh.mjs} +1 -1
- package/dist/chunks/ChevronRight-BUv-PtHh.mjs.map +1 -0
- package/dist/chunks/{ChevronRight-CWbdN5_r.cjs → ChevronRight-ZCKVg9OI.cjs} +1 -1
- package/dist/chunks/ChevronRight-ZCKVg9OI.cjs.map +1 -0
- package/dist/chunks/{ChevronUp-A2riTBrv.cjs → ChevronUp-Bpd__OBZ.cjs} +1 -1
- package/dist/chunks/ChevronUp-Bpd__OBZ.cjs.map +1 -0
- package/dist/chunks/{ChevronUp-ljACquzS.mjs → ChevronUp-C7Dy9Bph.mjs} +1 -1
- package/dist/chunks/ChevronUp-C7Dy9Bph.mjs.map +1 -0
- package/dist/chunks/{Close-B6ccm1RP.mjs → Close-BtLPUSdO.mjs} +1 -1
- package/dist/chunks/Close-BtLPUSdO.mjs.map +1 -0
- package/dist/chunks/{Close-B7lGu0cG.cjs → Close-CqmXxEKi.cjs} +1 -1
- package/dist/chunks/Close-CqmXxEKi.cjs.map +1 -0
- package/dist/chunks/{DotsHorizontal-DQfnwpao.cjs → DotsHorizontal-BoI3vnhk.cjs} +1 -1
- package/dist/chunks/DotsHorizontal-BoI3vnhk.cjs.map +1 -0
- package/dist/chunks/{DotsHorizontal-Cd2x8oz2.mjs → DotsHorizontal-C6LNsw4N.mjs} +1 -1
- package/dist/chunks/DotsHorizontal-C6LNsw4N.mjs.map +1 -0
- package/dist/chunks/{GenColors-BWE946ht.mjs → GenColors-DpvFVzBN.mjs} +3 -3
- package/dist/chunks/{GenColors-BWE946ht.mjs.map → GenColors-DpvFVzBN.mjs.map} +1 -1
- package/dist/chunks/{GenColors-Cay7TLwO.cjs → GenColors-iV_vrBr4.cjs} +3 -3
- package/dist/chunks/{GenColors-Cay7TLwO.cjs.map → GenColors-iV_vrBr4.cjs.map} +1 -1
- package/dist/chunks/{NcActionButtonGroup-BrN2mWdo.cjs → NcActionButtonGroup-C0nQ7J_W.cjs} +3 -3
- package/dist/chunks/{NcActionButtonGroup-BrN2mWdo.cjs.map → NcActionButtonGroup-C0nQ7J_W.cjs.map} +1 -1
- package/dist/chunks/{NcActionButtonGroup-B5RmRcow.mjs → NcActionButtonGroup-ue4dTx-p.mjs} +3 -3
- package/dist/chunks/{NcActionButtonGroup-B5RmRcow.mjs.map → NcActionButtonGroup-ue4dTx-p.mjs.map} +1 -1
- package/dist/chunks/NcActionCheckbox-C_wvm9IO.mjs +138 -0
- package/dist/chunks/NcActionCheckbox-C_wvm9IO.mjs.map +1 -0
- package/dist/chunks/NcActionCheckbox-DwU16qcU.cjs +137 -0
- package/dist/chunks/NcActionCheckbox-DwU16qcU.cjs.map +1 -0
- package/dist/chunks/{NcActionInput-BxlypAgV.mjs → NcActionInput-4-s29xoN.mjs} +46 -14
- package/dist/chunks/NcActionInput-4-s29xoN.mjs.map +1 -0
- package/dist/chunks/{NcActionInput-TP6P798j.cjs → NcActionInput-D0qZP5ag.cjs} +46 -14
- package/dist/chunks/NcActionInput-D0qZP5ag.cjs.map +1 -0
- package/dist/chunks/NcActionRadio-Dl6W62Vm.mjs +140 -0
- package/dist/chunks/NcActionRadio-Dl6W62Vm.mjs.map +1 -0
- package/dist/chunks/NcActionRadio-vHwjWOHS.cjs +139 -0
- package/dist/chunks/NcActionRadio-vHwjWOHS.cjs.map +1 -0
- package/dist/chunks/NcActionTextEditable-97R7dFen.cjs +121 -0
- package/dist/chunks/NcActionTextEditable-97R7dFen.cjs.map +1 -0
- package/dist/chunks/NcActionTextEditable-DZCFtqIP.mjs +122 -0
- package/dist/chunks/NcActionTextEditable-DZCFtqIP.mjs.map +1 -0
- package/dist/chunks/{NcActions-gOMT5VzC.cjs → NcActions-CCYNSnCn.cjs} +30 -37
- package/dist/chunks/{NcActions-gOMT5VzC.cjs.map → NcActions-CCYNSnCn.cjs.map} +1 -1
- package/dist/chunks/{NcActions-BgYpDq2n.mjs → NcActions-NA1n25Vt.mjs} +30 -37
- package/dist/chunks/{NcActions-BgYpDq2n.mjs.map → NcActions-NA1n25Vt.mjs.map} +1 -1
- package/dist/chunks/{NcAppContent-lEyly7Jk.mjs → NcAppContent-CIMgDnJM.mjs} +13 -9
- package/dist/chunks/NcAppContent-CIMgDnJM.mjs.map +1 -0
- package/dist/chunks/{NcAppContent-fXpgsMfG.cjs → NcAppContent-DdzUMomS.cjs} +13 -9
- package/dist/chunks/NcAppContent-DdzUMomS.cjs.map +1 -0
- package/dist/chunks/{NcAppNavigation-BleAA1U_.cjs → NcAppNavigation-BuKJwvwT.cjs} +3 -3
- package/dist/chunks/{NcAppNavigation-BleAA1U_.cjs.map → NcAppNavigation-BuKJwvwT.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigation-CxsxPI9x.mjs → NcAppNavigation-wz0Fsxe4.mjs} +3 -3
- package/dist/chunks/{NcAppNavigation-CxsxPI9x.mjs.map → NcAppNavigation-wz0Fsxe4.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationCaption-BQVV0F7Y.mjs → NcAppNavigationCaption-DBKM-x5x.mjs} +3 -3
- package/dist/chunks/{NcAppNavigationCaption-BQVV0F7Y.mjs.map → NcAppNavigationCaption-DBKM-x5x.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationCaption-BK-acRxg.cjs → NcAppNavigationCaption-DUPonEWi.cjs} +3 -3
- package/dist/chunks/{NcAppNavigationCaption-BK-acRxg.cjs.map → NcAppNavigationCaption-DUPonEWi.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationItem-MvvOWnip.mjs → NcAppNavigationItem-BkkuFdfa.mjs} +23 -27
- package/dist/chunks/NcAppNavigationItem-BkkuFdfa.mjs.map +1 -0
- package/dist/chunks/{NcAppNavigationItem-DfgovIvi.cjs → NcAppNavigationItem-Y_CVXzId.cjs} +23 -27
- package/dist/chunks/NcAppNavigationItem-Y_CVXzId.cjs.map +1 -0
- package/dist/chunks/{NcAppNavigationNewItem-C66Vvx3t.cjs → NcAppNavigationNewItem-B76-cCDH.cjs} +2 -2
- package/dist/chunks/{NcAppNavigationNewItem-C66Vvx3t.cjs.map → NcAppNavigationNewItem-B76-cCDH.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationNewItem-DyLB6t5e.mjs → NcAppNavigationNewItem-BFFG7VDH.mjs} +2 -2
- package/dist/chunks/{NcAppNavigationNewItem-DyLB6t5e.mjs.map → NcAppNavigationNewItem-BFFG7VDH.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationSearch-8jcfsc-r.mjs → NcAppNavigationSearch-Bg-WTyms.mjs} +6 -10
- package/dist/chunks/{NcAppNavigationSearch-8jcfsc-r.mjs.map → NcAppNavigationSearch-Bg-WTyms.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationSearch-CZRhuV6d.cjs → NcAppNavigationSearch-DVBgbwyd.cjs} +7 -11
- package/dist/chunks/{NcAppNavigationSearch-CZRhuV6d.cjs.map → NcAppNavigationSearch-DVBgbwyd.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationSettings-C-_G8yUn.cjs → NcAppNavigationSettings-BH5t68oV.cjs} +4 -4
- package/dist/chunks/NcAppNavigationSettings-BH5t68oV.cjs.map +1 -0
- package/dist/chunks/{NcAppNavigationSettings-DScz0UWm.mjs → NcAppNavigationSettings-CieV4qU5.mjs} +4 -4
- package/dist/chunks/NcAppNavigationSettings-CieV4qU5.mjs.map +1 -0
- package/dist/chunks/{NcAppNavigationToggle-BXainLDc.mjs → NcAppNavigationToggle-Dw0ZPjy2.mjs} +5 -5
- package/dist/chunks/NcAppNavigationToggle-Dw0ZPjy2.mjs.map +1 -0
- package/dist/chunks/{NcAppNavigationToggle-DAhbqsn_.cjs → NcAppNavigationToggle-Dwg-dMWx.cjs} +5 -5
- package/dist/chunks/NcAppNavigationToggle-Dwg-dMWx.cjs.map +1 -0
- package/dist/chunks/{NcAppSettingsDialog-BxDO8Ivr.mjs → NcAppSettingsDialog-B4GS8urN.mjs} +8 -15
- package/dist/chunks/{NcAppSettingsDialog-BxDO8Ivr.mjs.map → NcAppSettingsDialog-B4GS8urN.mjs.map} +1 -1
- package/dist/chunks/{NcAppSettingsDialog-niXwDCmG.cjs → NcAppSettingsDialog-Dkl3cqU-.cjs} +8 -15
- package/dist/chunks/{NcAppSettingsDialog-niXwDCmG.cjs.map → NcAppSettingsDialog-Dkl3cqU-.cjs.map} +1 -1
- package/dist/chunks/{NcAppSidebar-1S8EBs22.cjs → NcAppSidebar-B75YJPC-.cjs} +20 -23
- package/dist/chunks/NcAppSidebar-B75YJPC-.cjs.map +1 -0
- package/dist/chunks/{NcAppSidebar-D1Ss2put.mjs → NcAppSidebar-DaJVGxLh.mjs} +20 -23
- package/dist/chunks/NcAppSidebar-DaJVGxLh.mjs.map +1 -0
- package/dist/chunks/{NcAvatar-lRUjWiR6.mjs → NcAvatar-B8e2YFLI.mjs} +20 -22
- package/dist/chunks/{NcAvatar-lRUjWiR6.mjs.map → NcAvatar-B8e2YFLI.mjs.map} +1 -1
- package/dist/chunks/{NcAvatar-B238cv9d.cjs → NcAvatar-DypzACJs.cjs} +20 -22
- package/dist/chunks/{NcAvatar-B238cv9d.cjs.map → NcAvatar-DypzACJs.cjs.map} +1 -1
- package/dist/chunks/{NcBreadcrumb-Fqw2S2pM.cjs → NcBreadcrumb-DVn5-KGF.cjs} +5 -5
- package/dist/chunks/{NcBreadcrumb-Fqw2S2pM.cjs.map → NcBreadcrumb-DVn5-KGF.cjs.map} +1 -1
- package/dist/chunks/{NcBreadcrumb-ydWs_Sw8.mjs → NcBreadcrumb-MucRC9Y6.mjs} +5 -5
- package/dist/chunks/{NcBreadcrumb-ydWs_Sw8.mjs.map → NcBreadcrumb-MucRC9Y6.mjs.map} +1 -1
- package/dist/chunks/{NcBreadcrumbs-CPW9eMLa.mjs → NcBreadcrumbs-D59osZ3o.mjs} +26 -30
- package/dist/chunks/NcBreadcrumbs-D59osZ3o.mjs.map +1 -0
- package/dist/chunks/{NcBreadcrumbs-GKwJaai0.cjs → NcBreadcrumbs-JqPHfTRj.cjs} +26 -30
- package/dist/chunks/NcBreadcrumbs-JqPHfTRj.cjs.map +1 -0
- package/dist/chunks/{NcCheckboxRadioSwitch-COeeT-7G.cjs → NcCheckboxRadioSwitch-DdquK4fW.cjs} +57 -28
- package/dist/chunks/NcCheckboxRadioSwitch-DdquK4fW.cjs.map +1 -0
- package/dist/chunks/{NcCheckboxRadioSwitch-CvMEEI9x.mjs → NcCheckboxRadioSwitch-R1y0mLbC.mjs} +57 -28
- package/dist/chunks/NcCheckboxRadioSwitch-R1y0mLbC.mjs.map +1 -0
- package/dist/chunks/{NcCollectionList-DWyT_P3u.cjs → NcCollectionList-BBs48HVU.cjs} +6 -7
- package/dist/chunks/{NcCollectionList-DWyT_P3u.cjs.map → NcCollectionList-BBs48HVU.cjs.map} +1 -1
- package/dist/chunks/{NcCollectionList-CAM0Gyhi.mjs → NcCollectionList-COYakeMz.mjs} +6 -7
- package/dist/chunks/{NcCollectionList-CAM0Gyhi.mjs.map → NcCollectionList-COYakeMz.mjs.map} +1 -1
- package/dist/chunks/{NcColorPicker-Ddm2gbz0.mjs → NcColorPicker-8wU8rMbF.mjs} +43 -14
- package/dist/chunks/NcColorPicker-8wU8rMbF.mjs.map +1 -0
- package/dist/chunks/{NcColorPicker-Dy2BtsaH.cjs → NcColorPicker-Df6UVuYn.cjs} +43 -14
- package/dist/chunks/NcColorPicker-Df6UVuYn.cjs.map +1 -0
- package/dist/chunks/{NcContent-DKpTIl9F.mjs → NcContent-BEcHmywv.mjs} +4 -4
- package/dist/chunks/{NcContent-DKpTIl9F.mjs.map → NcContent-BEcHmywv.mjs.map} +1 -1
- package/dist/chunks/{NcContent-BTyHf5mF.cjs → NcContent-BXi18ILU.cjs} +4 -4
- package/dist/chunks/{NcContent-BTyHf5mF.cjs.map → NcContent-BXi18ILU.cjs.map} +1 -1
- package/dist/chunks/{NcCounterBubble-R8Tmi05i.cjs → NcCounterBubble-DF2rwIo4.cjs} +4 -6
- package/dist/chunks/{NcCounterBubble-R8Tmi05i.cjs.map → NcCounterBubble-DF2rwIo4.cjs.map} +1 -1
- package/dist/chunks/{NcCounterBubble-D1QC3eP1.mjs → NcCounterBubble-M1q9GRkH.mjs} +4 -6
- package/dist/chunks/{NcCounterBubble-D1QC3eP1.mjs.map → NcCounterBubble-M1q9GRkH.mjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidget-DhVJqy1d.cjs → NcDashboardWidget-Bu-WC7kg.cjs} +5 -5
- package/dist/chunks/{NcDashboardWidget-DhVJqy1d.cjs.map → NcDashboardWidget-Bu-WC7kg.cjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidget-DG9u5NLf.mjs → NcDashboardWidget-GDdmCQm-.mjs} +5 -5
- package/dist/chunks/{NcDashboardWidget-DG9u5NLf.mjs.map → NcDashboardWidget-GDdmCQm-.mjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidgetItem-DuntgAlo.cjs → NcDashboardWidgetItem-CI59K-wE.cjs} +3 -3
- package/dist/chunks/{NcDashboardWidgetItem-DuntgAlo.cjs.map → NcDashboardWidgetItem-CI59K-wE.cjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidgetItem-CHCygvjp.mjs → NcDashboardWidgetItem-vMP_Z6ay.mjs} +3 -3
- package/dist/chunks/{NcDashboardWidgetItem-CHCygvjp.mjs.map → NcDashboardWidgetItem-vMP_Z6ay.mjs.map} +1 -1
- package/dist/chunks/{NcDateTime-BfOmGrzK.cjs → NcDateTime-CaJHhgab.cjs} +1 -1
- package/dist/chunks/{NcDateTime-BfOmGrzK.cjs.map → NcDateTime-CaJHhgab.cjs.map} +1 -1
- package/dist/chunks/{NcDateTime-ciAHA2YL.mjs → NcDateTime-D5UaJ0tw.mjs} +1 -1
- package/dist/chunks/{NcDateTime-ciAHA2YL.mjs.map → NcDateTime-D5UaJ0tw.mjs.map} +1 -1
- package/dist/chunks/{NcDialog-D9l7GQQJ.cjs → NcDialog-CWGgSCpv.cjs} +3 -3
- package/dist/chunks/{NcDialog-D9l7GQQJ.cjs.map → NcDialog-CWGgSCpv.cjs.map} +1 -1
- package/dist/chunks/{NcDialog-DmcKxy4v.mjs → NcDialog-CzWTz2Qr.mjs} +3 -3
- package/dist/chunks/{NcDialog-DmcKxy4v.mjs.map → NcDialog-CzWTz2Qr.mjs.map} +1 -1
- package/dist/chunks/{NcDialogButton-CubYnLkp.mjs → NcDialogButton-B5jVZIGf.mjs} +3 -4
- package/dist/chunks/{NcDialogButton-CubYnLkp.mjs.map → NcDialogButton-B5jVZIGf.mjs.map} +1 -1
- package/dist/chunks/{NcDialogButton-C4-agMb3.cjs → NcDialogButton-B7d1LWFN.cjs} +3 -4
- package/dist/chunks/{NcDialogButton-C4-agMb3.cjs.map → NcDialogButton-B7d1LWFN.cjs.map} +1 -1
- package/dist/chunks/{NcEmojiPicker-C2DIjkqr.mjs → NcEmojiPicker-BSoMzxJl.mjs} +10 -12
- package/dist/chunks/NcEmojiPicker-BSoMzxJl.mjs.map +1 -0
- package/dist/chunks/{NcEmojiPicker-DrMA-XDR.cjs → NcEmojiPicker-XRtfmbk_.cjs} +10 -12
- package/dist/chunks/NcEmojiPicker-XRtfmbk_.cjs.map +1 -0
- package/dist/chunks/{NcHeaderMenu-Bis33gPF.cjs → NcHeaderMenu-CzS2doDR.cjs} +6 -8
- package/dist/chunks/{NcHeaderMenu-Bis33gPF.cjs.map → NcHeaderMenu-CzS2doDR.cjs.map} +1 -1
- package/dist/chunks/{NcHeaderMenu-DYGKi6bj.mjs → NcHeaderMenu-vLqcJ-_w.mjs} +6 -8
- package/dist/chunks/{NcHeaderMenu-DYGKi6bj.mjs.map → NcHeaderMenu-vLqcJ-_w.mjs.map} +1 -1
- package/dist/chunks/{NcIconSvgWrapper-Cb4bAwV6.cjs → NcIconSvgWrapper-B_eOG2sZ.cjs} +2 -2
- package/dist/chunks/{NcIconSvgWrapper-Cb4bAwV6.cjs.map → NcIconSvgWrapper-B_eOG2sZ.cjs.map} +1 -1
- package/dist/chunks/{NcIconSvgWrapper-DjrkBUkC.mjs → NcIconSvgWrapper-CHmdAuhg.mjs} +2 -2
- package/dist/chunks/{NcIconSvgWrapper-DjrkBUkC.mjs.map → NcIconSvgWrapper-CHmdAuhg.mjs.map} +1 -1
- package/dist/chunks/{NcInputConfirmCancel-bHJNQ1vm.cjs → NcInputConfirmCancel-CYQsG_3t.cjs} +4 -4
- package/dist/chunks/{NcInputConfirmCancel-bHJNQ1vm.cjs.map → NcInputConfirmCancel-CYQsG_3t.cjs.map} +1 -1
- package/dist/chunks/{NcInputConfirmCancel-PXVZ7mLT.mjs → NcInputConfirmCancel-DwmLGFYb.mjs} +4 -4
- package/dist/chunks/{NcInputConfirmCancel-PXVZ7mLT.mjs.map → NcInputConfirmCancel-DwmLGFYb.mjs.map} +1 -1
- package/dist/chunks/NcInputField-CbBdbdE8.cjs +260 -0
- package/dist/chunks/NcInputField-CbBdbdE8.cjs.map +1 -0
- package/dist/chunks/NcInputField-ixTTHy3h.mjs +261 -0
- package/dist/chunks/NcInputField-ixTTHy3h.mjs.map +1 -0
- package/dist/chunks/{NcListItem-D16FB3uo.mjs → NcListItem-DCh0J8Z4.mjs} +6 -7
- package/dist/chunks/{NcListItem-D16FB3uo.mjs.map → NcListItem-DCh0J8Z4.mjs.map} +1 -1
- package/dist/chunks/{NcListItem-Hx7E50yZ.cjs → NcListItem-DMaVvwXJ.cjs} +6 -7
- package/dist/chunks/{NcListItem-Hx7E50yZ.cjs.map → NcListItem-DMaVvwXJ.cjs.map} +1 -1
- package/dist/chunks/{NcListItemIcon-Do_af_2v.cjs → NcListItemIcon-BLvWsnbD.cjs} +5 -6
- package/dist/chunks/{NcListItemIcon-Do_af_2v.cjs.map → NcListItemIcon-BLvWsnbD.cjs.map} +1 -1
- package/dist/chunks/{NcListItemIcon-Bc4y0xg3.mjs → NcListItemIcon-C6Ok3G7x.mjs} +5 -6
- package/dist/chunks/{NcListItemIcon-Bc4y0xg3.mjs.map → NcListItemIcon-C6Ok3G7x.mjs.map} +1 -1
- package/dist/chunks/{NcPasswordField-DLXPfvQB.mjs → NcPasswordField-CAGGdgVF.mjs} +34 -10
- package/dist/chunks/NcPasswordField-CAGGdgVF.mjs.map +1 -0
- package/dist/chunks/{NcPasswordField-BQCunRtm.cjs → NcPasswordField-DLuNgJF2.cjs} +37 -13
- package/dist/chunks/NcPasswordField-DLuNgJF2.cjs.map +1 -0
- package/dist/chunks/{NcPopover-DbeCmze0.mjs → NcPopover-DzYbNu-I.mjs} +7 -11
- package/dist/chunks/{NcPopover-DbeCmze0.mjs.map → NcPopover-DzYbNu-I.mjs.map} +1 -1
- package/dist/chunks/{NcPopover-C0G7sLVP.cjs → NcPopover-MxwUgZu1.cjs} +7 -11
- package/dist/chunks/{NcPopover-C0G7sLVP.cjs.map → NcPopover-MxwUgZu1.cjs.map} +1 -1
- package/dist/chunks/{NcProgressBar-D_6Z7U5w.mjs → NcProgressBar-DegJ2JjE.mjs} +2 -2
- package/dist/chunks/{NcProgressBar-D_6Z7U5w.mjs.map → NcProgressBar-DegJ2JjE.mjs.map} +1 -1
- package/dist/chunks/{NcProgressBar-BrDAF_Zr.cjs → NcProgressBar-Do5Y3u8S.cjs} +2 -2
- package/dist/chunks/{NcProgressBar-BrDAF_Zr.cjs.map → NcProgressBar-Do5Y3u8S.cjs.map} +1 -1
- package/dist/chunks/{NcRelatedResourcesPanel-CsOAnfA1.cjs → NcRelatedResourcesPanel-BRoP-NiB.cjs} +16 -24
- package/dist/chunks/NcRelatedResourcesPanel-BRoP-NiB.cjs.map +1 -0
- package/dist/chunks/{NcRelatedResourcesPanel-DZICfdzQ.mjs → NcRelatedResourcesPanel-Bts9eDYA.mjs} +16 -24
- package/dist/chunks/NcRelatedResourcesPanel-Bts9eDYA.mjs.map +1 -0
- package/dist/chunks/{NcRichContenteditable-CCJdho4G.mjs → NcRichContenteditable-BznZW1Mm.mjs} +62 -116
- package/dist/chunks/NcRichContenteditable-BznZW1Mm.mjs.map +1 -0
- package/dist/chunks/{NcRichContenteditable-Ye5vABN5.cjs → NcRichContenteditable-GOiGqL9S.cjs} +62 -116
- package/dist/chunks/NcRichContenteditable-GOiGqL9S.cjs.map +1 -0
- package/dist/chunks/{NcRichText-7rxnpUCI.cjs → NcRichText-BNxuFkK-.cjs} +54 -18
- package/dist/chunks/NcRichText-BNxuFkK-.cjs.map +1 -0
- package/dist/chunks/{NcRichText-Xs-QVexE.mjs → NcRichText-CytzoTXW.mjs} +32 -18
- package/dist/chunks/NcRichText-CytzoTXW.mjs.map +1 -0
- package/dist/chunks/{NcSelect-CKgkjF4m.cjs → NcSelect-Cp83bFsi.cjs} +49 -21
- package/dist/chunks/NcSelect-Cp83bFsi.cjs.map +1 -0
- package/dist/chunks/{NcSelect-DRRPiPZG.mjs → NcSelect-DvGJHzaa.mjs} +49 -21
- package/dist/chunks/NcSelect-DvGJHzaa.mjs.map +1 -0
- package/dist/chunks/{NcSelectTags-CPc3qB8r.mjs → NcSelectTags-B4PjZQtt.mjs} +55 -11
- package/dist/chunks/NcSelectTags-B4PjZQtt.mjs.map +1 -0
- package/dist/chunks/{NcSelectTags-BceJx_FU.cjs → NcSelectTags-Bi9DIwx_.cjs} +55 -11
- package/dist/chunks/NcSelectTags-Bi9DIwx_.cjs.map +1 -0
- package/dist/chunks/{NcSettingsInputText-Cv_JwbFO.cjs → NcSettingsInputText-BYq049Qz.cjs} +37 -6
- package/dist/chunks/NcSettingsInputText-BYq049Qz.cjs.map +1 -0
- package/dist/chunks/{NcSettingsInputText-BF_v4yDP.mjs → NcSettingsInputText-DhZ_giTf.mjs} +37 -6
- package/dist/chunks/NcSettingsInputText-DhZ_giTf.mjs.map +1 -0
- package/dist/chunks/{NcSettingsSection-V9DkkSuI.mjs → NcSettingsSection-B7SqDXbX.mjs} +4 -5
- package/dist/chunks/NcSettingsSection-B7SqDXbX.mjs.map +1 -0
- package/dist/chunks/{NcSettingsSection-CA2JahBC.cjs → NcSettingsSection-Dn7Qmknm.cjs} +4 -5
- package/dist/chunks/NcSettingsSection-Dn7Qmknm.cjs.map +1 -0
- package/dist/chunks/{NcSettingsSelectGroup-Bx__1Iss.mjs → NcSettingsSelectGroup-BAhG6V1R.mjs} +39 -12
- package/dist/chunks/NcSettingsSelectGroup-BAhG6V1R.mjs.map +1 -0
- package/dist/chunks/{NcSettingsSelectGroup-8tK3uGkJ.cjs → NcSettingsSelectGroup-DypyXuEW.cjs} +39 -12
- package/dist/chunks/NcSettingsSelectGroup-DypyXuEW.cjs.map +1 -0
- package/dist/chunks/NcTextArea-BHERsE_g.mjs +207 -0
- package/dist/chunks/NcTextArea-BHERsE_g.mjs.map +1 -0
- package/dist/chunks/NcTextArea-CYLGAGcO.cjs +206 -0
- package/dist/chunks/NcTextArea-CYLGAGcO.cjs.map +1 -0
- package/dist/chunks/{NcTextField-CmXmPZ4h.mjs → NcTextField-8RXOuqAy.mjs} +25 -10
- package/dist/chunks/NcTextField-8RXOuqAy.mjs.map +1 -0
- package/dist/chunks/{NcTextField-BnZnDMjV.cjs → NcTextField-rCaBV_TN.cjs} +28 -13
- package/dist/chunks/NcTextField-rCaBV_TN.cjs.map +1 -0
- package/dist/chunks/{NcTimezonePicker-CPfvqXuN.cjs → NcTimezonePicker-B5ps-VnZ.cjs} +40 -9
- package/dist/chunks/NcTimezonePicker-B5ps-VnZ.cjs.map +1 -0
- package/dist/chunks/{NcTimezonePicker-BwygP9tV.mjs → NcTimezonePicker-D64nWJh7.mjs} +40 -9
- package/dist/chunks/NcTimezonePicker-D64nWJh7.mjs.map +1 -0
- package/dist/chunks/{NcUserBubble-TVnJaVQg.cjs → NcUserBubble-Cg86HaKF.cjs} +4 -5
- package/dist/chunks/{NcUserBubble-G7FKOk8N.mjs.map → NcUserBubble-Cg86HaKF.cjs.map} +1 -1
- package/dist/chunks/{NcUserBubble-G7FKOk8N.mjs → NcUserBubble-Q0TscgXh.mjs} +4 -5
- package/dist/chunks/{NcUserBubble-TVnJaVQg.cjs.map → NcUserBubble-Q0TscgXh.mjs.map} +1 -1
- package/dist/chunks/{NcUserStatusIcon-FtKzp5sl.cjs → NcUserStatusIcon-CP1EGHie.cjs} +6 -9
- package/dist/chunks/{NcUserStatusIcon-FtKzp5sl.cjs.map → NcUserStatusIcon-CP1EGHie.cjs.map} +1 -1
- package/dist/chunks/{NcUserStatusIcon-CPZOWw3t.mjs → NcUserStatusIcon-CvuiXAZR.mjs} +6 -9
- package/dist/chunks/{NcUserStatusIcon-CPZOWw3t.mjs.map → NcUserStatusIcon-CvuiXAZR.mjs.map} +1 -1
- package/dist/chunks/{ScopeComponent-BVnA9iVd.mjs → ScopeComponent-BLLOK04K.mjs} +1 -1
- package/dist/chunks/{ScopeComponent-BVnA9iVd.mjs.map → ScopeComponent-BLLOK04K.mjs.map} +1 -1
- package/dist/chunks/{ScopeComponent-B0gd6vEY.cjs → ScopeComponent-ClDcATYc.cjs} +1 -1
- package/dist/chunks/{ScopeComponent-B0gd6vEY.cjs.map → ScopeComponent-ClDcATYc.cjs.map} +1 -1
- package/dist/chunks/_l10n-B-QPoWAJ.mjs +132 -0
- package/dist/chunks/_l10n-B-QPoWAJ.mjs.map +1 -0
- package/dist/chunks/_l10n-Ch5mEdUH.cjs +131 -0
- package/dist/chunks/{_l10n-Ci9_UR5q.cjs.map → _l10n-Ch5mEdUH.cjs.map} +1 -1
- package/dist/chunks/{emoji-V6ytyzoR.mjs → emoji-BY_D0V5K.mjs} +2 -3
- package/dist/chunks/{emoji-V6ytyzoR.mjs.map → emoji-BY_D0V5K.mjs.map} +1 -1
- package/dist/chunks/{emoji-BCCCB3t3.cjs → emoji-VgSjNTd5.cjs} +2 -3
- package/dist/chunks/{emoji-BCCCB3t3.cjs.map → emoji-VgSjNTd5.cjs.map} +1 -1
- package/dist/chunks/{index-Dsgv-f-l.cjs → index-BV85rPB7.cjs} +3 -6
- package/dist/chunks/{index-Dsgv-f-l.cjs.map → index-BV85rPB7.cjs.map} +1 -1
- package/dist/chunks/{index-BwyQ2N-M.mjs → index-CtoB4eIp.mjs} +3 -6
- package/dist/chunks/{index-BwyQ2N-M.mjs.map → index-CtoB4eIp.mjs.map} +1 -1
- package/dist/chunks/{index-CC4ahXvG.cjs → index-bI_wyL5-.cjs} +10 -11
- package/dist/chunks/index-bI_wyL5-.cjs.map +1 -0
- package/dist/chunks/{index-CMZdBcqP.mjs → index-bjwozrEX.mjs} +10 -11
- package/dist/chunks/index-bjwozrEX.mjs.map +1 -0
- package/dist/chunks/{referencePickerModal--FRvx7tZ.cjs → referencePickerModal-C4eGo6D2.cjs} +29 -42
- package/dist/chunks/referencePickerModal-C4eGo6D2.cjs.map +1 -0
- package/dist/chunks/{referencePickerModal-ByI9zX0a.mjs → referencePickerModal-C6YJvRC9.mjs} +29 -42
- package/dist/chunks/referencePickerModal-C6YJvRC9.mjs.map +1 -0
- package/dist/chunks/useModelMigration-D5zhrNXr.cjs +25 -0
- package/dist/chunks/useModelMigration-D5zhrNXr.cjs.map +1 -0
- package/dist/chunks/useModelMigration-EhAWvqDD.mjs +24 -0
- package/dist/chunks/useModelMigration-EhAWvqDD.mjs.map +1 -0
- package/dist/chunks/{usernameToColor-u2MH9nY7.cjs → usernameToColor-CWxjw-Pq.cjs} +1 -1
- package/dist/chunks/{usernameToColor-u2MH9nY7.cjs.map → usernameToColor-CWxjw-Pq.cjs.map} +1 -1
- package/dist/chunks/{usernameToColor-D6FJP4ni.mjs → usernameToColor-Cx2qDZ1W.mjs} +1 -1
- package/dist/chunks/{usernameToColor-D6FJP4ni.mjs.map → usernameToColor-Cx2qDZ1W.mjs.map} +1 -1
- package/dist/composables/useIsDarkTheme/index.d.ts +16 -0
- package/dist/composables/useModelMigration.d.ts +12 -0
- package/dist/functions/dialog/index.d.ts +16 -0
- package/dist/functions/index.d.ts +10 -0
- package/dist/functions/isDarkTheme/index.d.ts +17 -0
- package/dist/index.cjs +73 -67
- package/dist/index.cjs.map +1 -1
- package/dist/index.mjs +66 -60
- package/dist/index.mjs.map +1 -1
- package/dist/vendor.LICENSE.txt +1 -1
- package/package.json +4 -3
- package/dist/assets/NcDateTimePickerNative-BAcKr0B3.css +0 -47
- package/dist/assets/NcRichText-DqDAPQPD.css +0 -217
- package/dist/chunks/AlertCircleOutline-DLtiWgZd.cjs.map +0 -1
- package/dist/chunks/AlertCircleOutline-DU3QwU5Y.mjs.map +0 -1
- package/dist/chunks/ArrowLeft-BhAxJBYx.mjs.map +0 -1
- package/dist/chunks/ArrowLeft-CONurT5C.cjs.map +0 -1
- package/dist/chunks/ArrowRight-Bj5G_mG0.cjs.map +0 -1
- package/dist/chunks/ArrowRight-KsL2PC-o.mjs.map +0 -1
- package/dist/chunks/Check-XHAzUBkX.mjs.map +0 -1
- package/dist/chunks/Check-fCbe4vqy.cjs.map +0 -1
- package/dist/chunks/ChevronDown-CiFbcDUC.cjs.map +0 -1
- package/dist/chunks/ChevronDown-D3Tfshug.mjs.map +0 -1
- package/dist/chunks/ChevronRight-C3eVhc5a.mjs.map +0 -1
- package/dist/chunks/ChevronRight-CWbdN5_r.cjs.map +0 -1
- package/dist/chunks/ChevronUp-A2riTBrv.cjs.map +0 -1
- package/dist/chunks/ChevronUp-ljACquzS.mjs.map +0 -1
- package/dist/chunks/Close-B6ccm1RP.mjs.map +0 -1
- package/dist/chunks/Close-B7lGu0cG.cjs.map +0 -1
- package/dist/chunks/DotsHorizontal-Cd2x8oz2.mjs.map +0 -1
- package/dist/chunks/DotsHorizontal-DQfnwpao.cjs.map +0 -1
- package/dist/chunks/NcActionInput-BxlypAgV.mjs.map +0 -1
- package/dist/chunks/NcActionInput-TP6P798j.cjs.map +0 -1
- package/dist/chunks/NcAppContent-fXpgsMfG.cjs.map +0 -1
- package/dist/chunks/NcAppContent-lEyly7Jk.mjs.map +0 -1
- package/dist/chunks/NcAppNavigationItem-DfgovIvi.cjs.map +0 -1
- package/dist/chunks/NcAppNavigationItem-MvvOWnip.mjs.map +0 -1
- package/dist/chunks/NcAppNavigationSettings-C-_G8yUn.cjs.map +0 -1
- package/dist/chunks/NcAppNavigationSettings-DScz0UWm.mjs.map +0 -1
- package/dist/chunks/NcAppNavigationToggle-BXainLDc.mjs.map +0 -1
- package/dist/chunks/NcAppNavigationToggle-DAhbqsn_.cjs.map +0 -1
- package/dist/chunks/NcAppSidebar-1S8EBs22.cjs.map +0 -1
- package/dist/chunks/NcAppSidebar-D1Ss2put.mjs.map +0 -1
- package/dist/chunks/NcBreadcrumbs-CPW9eMLa.mjs.map +0 -1
- package/dist/chunks/NcBreadcrumbs-GKwJaai0.cjs.map +0 -1
- package/dist/chunks/NcCheckboxRadioSwitch-COeeT-7G.cjs.map +0 -1
- package/dist/chunks/NcCheckboxRadioSwitch-CvMEEI9x.mjs.map +0 -1
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_00597cce_lang-CbxHILUm.cjs +0 -4
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_00597cce_lang-CbxHILUm.cjs.map +0 -1
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_00597cce_lang-pIxtu28F.mjs +0 -3
- package/dist/chunks/NcCheckboxRadioSwitch.vue_vue_type_style_index_0_scoped_00597cce_lang-pIxtu28F.mjs.map +0 -1
- package/dist/chunks/NcColorPicker-Ddm2gbz0.mjs.map +0 -1
- package/dist/chunks/NcColorPicker-Dy2BtsaH.cjs.map +0 -1
- package/dist/chunks/NcEmojiPicker-C2DIjkqr.mjs.map +0 -1
- package/dist/chunks/NcEmojiPicker-DrMA-XDR.cjs.map +0 -1
- package/dist/chunks/NcPasswordField-BQCunRtm.cjs.map +0 -1
- package/dist/chunks/NcPasswordField-DLXPfvQB.mjs.map +0 -1
- package/dist/chunks/NcRelatedResourcesPanel-CsOAnfA1.cjs.map +0 -1
- package/dist/chunks/NcRelatedResourcesPanel-DZICfdzQ.mjs.map +0 -1
- package/dist/chunks/NcRichContenteditable-CCJdho4G.mjs.map +0 -1
- package/dist/chunks/NcRichContenteditable-Ye5vABN5.cjs.map +0 -1
- package/dist/chunks/NcRichText-7rxnpUCI.cjs.map +0 -1
- package/dist/chunks/NcRichText-Xs-QVexE.mjs.map +0 -1
- package/dist/chunks/NcSelect-CKgkjF4m.cjs.map +0 -1
- package/dist/chunks/NcSelect-DRRPiPZG.mjs.map +0 -1
- package/dist/chunks/NcSelectTags-BceJx_FU.cjs.map +0 -1
- package/dist/chunks/NcSelectTags-CPc3qB8r.mjs.map +0 -1
- package/dist/chunks/NcSettingsInputText-BF_v4yDP.mjs.map +0 -1
- package/dist/chunks/NcSettingsInputText-Cv_JwbFO.cjs.map +0 -1
- package/dist/chunks/NcSettingsSection-CA2JahBC.cjs.map +0 -1
- package/dist/chunks/NcSettingsSection-V9DkkSuI.mjs.map +0 -1
- package/dist/chunks/NcSettingsSelectGroup-8tK3uGkJ.cjs.map +0 -1
- package/dist/chunks/NcSettingsSelectGroup-Bx__1Iss.mjs.map +0 -1
- package/dist/chunks/NcTextField-BnZnDMjV.cjs.map +0 -1
- package/dist/chunks/NcTextField-CmXmPZ4h.mjs.map +0 -1
- package/dist/chunks/NcTimezonePicker-BwygP9tV.mjs.map +0 -1
- package/dist/chunks/NcTimezonePicker-CPfvqXuN.cjs.map +0 -1
- package/dist/chunks/_l10n-Ci9_UR5q.cjs +0 -131
- package/dist/chunks/_l10n-JYjUKekn.mjs +0 -132
- package/dist/chunks/_l10n-JYjUKekn.mjs.map +0 -1
- package/dist/chunks/index-CC4ahXvG.cjs.map +0 -1
- package/dist/chunks/index-CMZdBcqP.mjs.map +0 -1
- package/dist/chunks/referencePickerModal--FRvx7tZ.cjs.map +0 -1
- package/dist/chunks/referencePickerModal-ByI9zX0a.mjs.map +0 -1
- /package/dist/assets/{NcActionButtonGroup-CQxLn2fv.css → NcActionButtonGroup-BND4GQdv.css} +0 -0
- /package/dist/assets/{NcActionCaption-B7FZTc3Y.css → NcActionCaption-JVhz4Wp7.css} +0 -0
- /package/dist/assets/{NcActionSeparator-CEbb5P6P.css → NcActionSeparator-Ct2RnclR.css} +0 -0
- /package/dist/assets/{NcActions-CkVHYk_-.css → NcActions-DM_LoRlx.css} +0 -0
- /package/dist/assets/{NcAppNavigationCaption-zgtPq3Od.css → NcAppNavigationCaption-Dt5K_hKD.css} +0 -0
- /package/dist/assets/{NcAppNavigationIconBullet-By_0o2dG.css → NcAppNavigationIconBullet-CeBYVy6t.css} +0 -0
- /package/dist/assets/{NcAppNavigationList-BIbyyT7b.css → NcAppNavigationList-DnKj0-Zq.css} +0 -0
- /package/dist/assets/{NcAppNavigationNew-BKfawNII.css → NcAppNavigationNew-BcDuupzO.css} +0 -0
- /package/dist/assets/{NcAppNavigationNewItem-Ce17FkDl.css → NcAppNavigationNewItem-CQ1f40wK.css} +0 -0
- /package/dist/assets/{NcAppNavigationSearch-BLGG_WBn.css → NcAppNavigationSearch-Df50ss_2.css} +0 -0
- /package/dist/assets/{NcAppNavigationSettings-AzpTlUym.css → NcAppNavigationSettings-BV_QS8jh.css} +0 -0
- /package/dist/assets/{NcAppNavigationSpacer-CfNqmQeR.css → NcAppNavigationSpacer-Fkr_mEI1.css} +0 -0
- /package/dist/assets/{NcAppSettingsDialog-QF6aTZ3s.css → NcAppSettingsDialog-kKMMsdb3.css} +0 -0
- /package/dist/assets/{NcAppSettingsSection-qU4SUZvh.css → NcAppSettingsSection-Bl2-D3_g.css} +0 -0
- /package/dist/assets/{NcAppSidebarTab-BieYhqvk.css → NcAppSidebarTab-Blv6UfuA.css} +0 -0
- /package/dist/assets/{NcAvatar-5N7xP8zN.css → NcAvatar-xe4gdFKk.css} +0 -0
- /package/dist/assets/{NcBreadcrumb-DOvK-XG1.css → NcBreadcrumb-Cjcyeimd.css} +0 -0
- /package/dist/assets/{NcBreadcrumbs-CPUAM38l.css → NcBreadcrumbs-CFRjXqRg.css} +0 -0
- /package/dist/assets/{NcButton-DYJAoXeG.css → NcButton-BHDLon1_.css} +0 -0
- /package/dist/assets/{NcCollectionList-ETQTqkqt.css → NcCollectionList-yjTCAR46.css} +0 -0
- /package/dist/assets/{NcContent-ZFNIjylG.css → NcContent-CZamE_IP.css} +0 -0
- /package/dist/assets/{NcCounterBubble-Dizdz4Hk.css → NcCounterBubble-DdYmHnng.css} +0 -0
- /package/dist/assets/{NcDashboardWidget-CpstyXok.css → NcDashboardWidget-BSTvIgiJ.css} +0 -0
- /package/dist/assets/{NcDashboardWidgetItem-BBZT17WU.css → NcDashboardWidgetItem-BtOuK4mf.css} +0 -0
- /package/dist/assets/{NcDialog-ByAK1rQ0.css → NcDialog-Bzs9oxyt.css} +0 -0
- /package/dist/assets/{NcEmojiPicker-B5dclDLD.css → NcEmojiPicker-BNCW1Q94.css} +0 -0
- /package/dist/assets/{NcEmptyContent-BU0QVo3d.css → NcEmptyContent-BlXL6nnq.css} +0 -0
- /package/dist/assets/{NcGuestContent-BLJ37yLM.css → NcGuestContent-B0ivUQHg.css} +0 -0
- /package/dist/assets/{NcHeaderButton-BybvB5sC.css → NcHeaderButton-DH4Qtw3P.css} +0 -0
- /package/dist/assets/{NcHeaderMenu-BCtvpsZj.css → NcHeaderMenu-C2XbJMYL.css} +0 -0
- /package/dist/assets/{NcIconSvgWrapper-BwsJ8wBM.css → NcIconSvgWrapper-BxyhLaB5.css} +0 -0
- /package/dist/assets/{NcInputConfirmCancel-SGr0-6w8.css → NcInputConfirmCancel-EYtW7MxF.css} +0 -0
- /package/dist/assets/{NcListItem-D-8LyMsI.css → NcListItem-BBu5UTTe.css} +0 -0
- /package/dist/assets/{NcListItemIcon--7OhLYWA.css → NcListItemIcon-UmX9YoH3.css} +0 -0
- /package/dist/assets/{NcLoadingIcon-BSONDy7x.css → NcLoadingIcon-x1d284UU.css} +0 -0
- /package/dist/assets/{NcMentionBubble-C6t8od-_.css → NcMentionBubble-Bt71nB8X.css} +0 -0
- /package/dist/assets/{NcNoteCard-CImn6F9p.css → NcNoteCard-C6xb7vi0.css} +0 -0
- /package/dist/assets/{NcPopover-BDlL00qZ.css → NcPopover-TS4CW9MJ.css} +0 -0
- /package/dist/assets/{NcProgressBar-BsqdCn-x.css → NcProgressBar--z-WqmX4.css} +0 -0
- /package/dist/assets/{NcRelatedResourcesPanel-BE9CQ8s8.css → NcRelatedResourcesPanel-DIhZx6lY.css} +0 -0
- /package/dist/assets/{NcSelect-EIXtZSVn.css → NcSelect-GdIw6cIy.css} +0 -0
- /package/dist/assets/{NcSettingsSection-CGaCS1X0.css → NcSettingsSection-Dlaob2ni.css} +0 -0
- /package/dist/assets/{NcUserBubble-Cv-q-rH5.css → NcUserBubble-CNid1YOT.css} +0 -0
- /package/dist/assets/{NcUserStatusIcon-DMxcdM51.css → NcUserStatusIcon-DAVSJFhS.css} +0 -0
- /package/dist/assets/{Tooltip-4CSl8xev.css → Tooltip-DQ4Plm4r.css} +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
require('../assets/NcSettingsSection-
|
|
1
|
+
require('../assets/NcSettingsSection-Dlaob2ni.css');
|
|
2
2
|
"use strict";
|
|
3
|
-
const _l10n = require("./_l10n-
|
|
3
|
+
const _l10n = require("./_l10n-Ch5mEdUH.cjs");
|
|
4
4
|
const _pluginVue2_normalizer = require("./_plugin-vue2_normalizer-V0q-tHlQ.cjs");
|
|
5
5
|
_l10n.register(_l10n.t24);
|
|
6
6
|
const _sfc_main$1 = {
|
|
@@ -22,7 +22,7 @@ const _sfc_main$1 = {
|
|
|
22
22
|
};
|
|
23
23
|
var _sfc_render$1 = function render() {
|
|
24
24
|
var _vm = this, _c = _vm._self._c;
|
|
25
|
-
return _c("span", _vm._b({ staticClass: "material-design-icon help-circle-icon", attrs: { "aria-hidden": _vm.title ? null : true, "aria-label": _vm.title, "role": "img" }, on: { "click": function($event) {
|
|
25
|
+
return _c("span", _vm._b({ staticClass: "material-design-icon help-circle-icon", attrs: { "aria-hidden": _vm.title ? null : "true", "aria-label": _vm.title, "role": "img" }, on: { "click": function($event) {
|
|
26
26
|
return _vm.$emit("click", $event);
|
|
27
27
|
} } }, "span", _vm.$attrs, false), [_c("svg", { staticClass: "material-design-icon__svg", attrs: { "fill": _vm.fillColor, "width": _vm.size, "height": _vm.size, "viewBox": "0 0 24 24" } }, [_c("path", { attrs: { "d": "M15.07,11.25L14.17,12.17C13.45,12.89 13,13.5 13,15H11V14.5C11,13.39 11.45,12.39 12.17,11.67L13.41,10.41C13.78,10.05 14,9.55 14,9C14,7.89 13.1,7 12,7A2,2 0 0,0 10,9H8A4,4 0 0,1 12,5A4,4 0 0,1 16,9C16,9.88 15.64,10.67 15.07,11.25M13,19H11V17H13M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12C22,6.47 17.5,2 12,2Z" } }, [_vm.title ? _c("title", [_vm._v(_vm._s(_vm.title))]) : _vm._e()])])]);
|
|
28
28
|
};
|
|
@@ -75,11 +75,10 @@ const _sfc_main = {
|
|
|
75
75
|
},
|
|
76
76
|
computed: {
|
|
77
77
|
forceLimitWidth() {
|
|
78
|
-
var _a, _b;
|
|
79
78
|
if (this.limitWidth) {
|
|
80
79
|
return true;
|
|
81
80
|
}
|
|
82
|
-
const [major] =
|
|
81
|
+
const [major] = window._oc_config?.version.split(".", 2) ?? [];
|
|
83
82
|
return major && Number.parseInt(major) >= 30;
|
|
84
83
|
},
|
|
85
84
|
hasDescription() {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NcSettingsSection-Dn7Qmknm.cjs","sources":["../../node_modules/vue-material-design-icons/HelpCircle.vue","../../src/components/NcSettingsSection/NcSettingsSection.vue"],"sourcesContent":["<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon help-circle-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M15.07,11.25L14.17,12.17C13.45,12.89 13,13.5 13,15H11V14.5C11,13.39 11.45,12.39 12.17,11.67L13.41,10.41C13.78,10.05 14,9.55 14,9C14,7.89 13.1,7 12,7A2,2 0 0,0 10,9H8A4,4 0 0,1 12,5A4,4 0 0,1 16,9C16,9.88 15.64,10.67 15.07,11.25M13,19H11V17H13M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12C22,6.47 17.5,2 12,2Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"HelpCircleIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>","<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n### General description\n\nThis component is to be used in the settings section of nextcloud.\n\n### Examples\n\n```vue\n<template>\n\t<div>\n\t\t<NcSettingsSection name=\"Two-factor authentication\"\n\t\t\tdescription=\"Two-factor authentication can be enforced for all accounts and specific groups. If they do not have a two-factor provider configured, they will be unable to log into the system.\"\n\t\t\tdoc-url=\"https://docs.nextcloud.com/server/19/go.php?to=admin-2fa\">\n\t\t\t<NcCheckboxRadioSwitch type=\"switch\">\n\t\t\t\tEnforce two-factor authentication\n\t\t\t</NcCheckboxRadioSwitch>\n\t\t</NcSettingsSection>\n\n\t\t<NcSettingsSection name=\"Server-side encryption\"\n\t\t\tdescription=\"Server-side encryption makes it possible to encrypt files which are uploaded to this server. This comes with limitations like a performance penalty, so enable this only if needed.\">\n\t\t\t<NcCheckboxRadioSwitch type=\"switch\">\n\t\t\t\tEnable server-side encryption\n\t\t\t</NcCheckboxRadioSwitch>\n\t\t</NcSettingsSection>\n\n\t\t<NcSettingsSection name=\"OAuth 2.0 clients\"\n\t\t\tdescription=\"OAuth 2.0 allows external services to request access to Nextcloud.\"\n\t\t\tdoc-url=\"https://docs.nextcloud.com/server/latest/admin_manual/configuration_server/oauth2.html\">\n\n\t\t\tAny content here\n\n\t\t</NcSettingsSection>\n\t</div>\n</template>\n```\n</docs>\n\n<template>\n\t<div class=\"settings-section\" :class=\"{'settings-section--limit-width': forceLimitWidth}\">\n\t\t<h2 class=\"settings-section__name\">\n\t\t\t{{ name }}\n\t\t\t<a v-if=\"hasDocUrl\"\n\t\t\t\t:href=\"docUrl\"\n\t\t\t\tclass=\"settings-section__info\"\n\t\t\t\t:title=\"docNameTranslated\"\n\t\t\t\t:aria-label=\"docNameTranslated\"\n\t\t\t\ttarget=\"_blank\"\n\t\t\t\trel=\"noreferrer nofollow\">\n\t\t\t\t<HelpCircle :size=\"20\" />\n\t\t\t</a>\n\t\t</h2>\n\t\t<p v-if=\"hasDescription\"\n\t\t\tclass=\"settings-section__desc\">\n\t\t\t{{ description }}\n\t\t</p>\n\t\t<slot />\n\t</div>\n</template>\n\n<script>\nimport { t } from '../../l10n.js'\n\nimport HelpCircle from 'vue-material-design-icons/HelpCircle.vue'\n\nexport default {\n\tname: 'NcSettingsSection',\n\n\tcomponents: {\n\t\tHelpCircle,\n\t},\n\n\tprops: {\n\t\tname: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\t\tdescription: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t\tdocUrl: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t\t/**\n\t\t * Limit the width of the setting's content\n\t\t *\n\t\t * Setting this to false allows unrestricted (width) settings content.\n\t\t * Note that the name and description have always a width limit.\n\t\t * @deprecated Will be removed with next version and will not be used on Nextcloud 30+ (always forced to true)\n\t\t */\n\t\tlimitWidth: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true,\n\t\t},\n\t},\n\n\tdata() {\n\t\treturn {\n\t\t\tdocNameTranslated: t('External documentation for {name}', {\n\t\t\t\tname: this.name,\n\t\t\t}),\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tforceLimitWidth() {\n\t\t\tif (this.limitWidth) {\n\t\t\t\treturn true\n\t\t\t}\n\t\t\t// Overwrite this on Nextcloud 30+ to always limit the width\n\t\t\tconst [major] = window._oc_config?.version.split('.', 2) ?? []\n\t\t\treturn major && Number.parseInt(major) >= 30\n\t\t},\n\n\t\thasDescription() {\n\t\t\treturn this.description.length > 0\n\t\t},\n\t\thasDocUrl() {\n\t\t\treturn this.docUrl.length > 0\n\t\t},\n\t},\n}\n\n</script>\n\n<style lang=\"scss\" scoped>\n$maxWidth: 900px;\n\n.settings-section {\n\tdisplay: block;\n\tmargin-bottom: auto;\n\tpadding: 30px;\n\n\t&:not(:last-child) {\n\t\tborder-bottom: 1px solid var(--color-border);\n\t}\n\n\t&--limit-width > * {\n\t\tmax-width: $maxWidth;\n\t}\n\n\t&__name {\n\t\tdisplay: inline-flex;\n\t\talign-items: center;\n\t\tjustify-content: center;\n\t\tfont-size: 20px;\n\t\tfont-weight: bold;\n\t\tmax-width: $maxWidth;\n\t\tmargin-top: 0; // Remove default heading margin\n\t}\n\n\t&__info {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: center;\n\t\twidth: var(--default-clickable-area);\n\t\theight: var(--default-clickable-area);\n\t\t// make sure to properly align the icon with the text\n\t\tmargin: calc($icon-margin * -1);\n\t\tmargin-left: 0;\n\t\tcolor: var(--color-text-maxcontrast);\n\n\t\t&:hover, &:focus, &:active {\n\t\t\tcolor: var(--color-main-text);\n\t\t}\n\t}\n\n\t&__desc {\n\t\tmargin-top: -.2em;\n\t\tmargin-bottom: 1em;\n\t\tcolor: var(--color-text-maxcontrast);\n\t\tmax-width: $maxWidth;\n\t}\n}\n\n</style>\n"],"names":["_sfc_main","t"],"mappings":";;;;AAoBA,MAAAA,cAAA;AAAA,EACA,MAAA;AAAA,EACA,OAAA,CAAA,OAAA;AAAA,EACA,OAAA;AAAA,IACA,OAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,IACA,WAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,IACA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;;ACiCA,MAAA,YAAA;AAAA,EACA,MAAA;AAAA,EAEA,YAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA,IACA,MAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,IACA;AAAA,IACA,aAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,IACA,QAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,YAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AACA,WAAA;AAAA,MACA,mBAAAC,MAAA,EAAA,qCAAA;AAAA,QACA,MAAA,KAAA;AAAA,MACA,CAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,UAAA;AAAA,IACA,kBAAA;AACA,UAAA,KAAA,YAAA;AACA,eAAA;AAAA,MACA;AAEA,YAAA,CAAA,KAAA,IAAA,OAAA,YAAA,QAAA,MAAA,KAAA,CAAA,KAAA,CAAA;AACA,aAAA,SAAA,OAAA,SAAA,KAAA,KAAA;AAAA,IACA;AAAA,IAEA,iBAAA;AACA,aAAA,KAAA,YAAA,SAAA;AAAA,IACA;AAAA,IACA,YAAA;AACA,aAAA,KAAA,OAAA,SAAA;AAAA,IACA;AAAA,EACA;AACA;;;;;;;;;;;;;;;;","x_google_ignoreList":[0]}
|
package/dist/chunks/{NcSettingsSelectGroup-Bx__1Iss.mjs → NcSettingsSelectGroup-BAhG6V1R.mjs}
RENAMED
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import '../assets/NcSettingsSelectGroup-
|
|
2
|
-
import { N as NcSelect } from "./NcSelect-
|
|
3
|
-
import { r as register, f as t47, a as t } from "./_l10n-
|
|
1
|
+
import '../assets/NcSettingsSelectGroup-BEjOwCJQ.css';
|
|
2
|
+
import { N as NcSelect } from "./NcSelect-DvGJHzaa.mjs";
|
|
3
|
+
import { r as register, f as t47, a as t } from "./_l10n-B-QPoWAJ.mjs";
|
|
4
4
|
import { G as GenRandomId } from "./GenRandomId-CMooMQt0.mjs";
|
|
5
|
+
import { u as useModelMigration } from "./useModelMigration-EhAWvqDD.mjs";
|
|
5
6
|
import axios from "@nextcloud/axios";
|
|
6
7
|
import debounce from "debounce";
|
|
7
8
|
import { generateOcsUrl } from "@nextcloud/router";
|
|
@@ -12,6 +13,10 @@ const _sfc_main = {
|
|
|
12
13
|
components: {
|
|
13
14
|
NcSelect
|
|
14
15
|
},
|
|
16
|
+
model: {
|
|
17
|
+
prop: "modelValue",
|
|
18
|
+
event: "update:modelValue"
|
|
19
|
+
},
|
|
15
20
|
props: {
|
|
16
21
|
/**
|
|
17
22
|
* The text of the label element of the select group input
|
|
@@ -36,11 +41,19 @@ const _sfc_main = {
|
|
|
36
41
|
default: () => "action-" + GenRandomId(),
|
|
37
42
|
validator: (id) => id.trim() !== ""
|
|
38
43
|
},
|
|
44
|
+
/**
|
|
45
|
+
* Removed in v9 - use `modelValue` (`v-model`) instead
|
|
46
|
+
* @deprecated
|
|
47
|
+
*/
|
|
48
|
+
value: {
|
|
49
|
+
type: Array,
|
|
50
|
+
default: void 0
|
|
51
|
+
},
|
|
39
52
|
/**
|
|
40
53
|
* value of the select group input
|
|
41
54
|
* A list of group IDs can be provided
|
|
42
55
|
*/
|
|
43
|
-
|
|
56
|
+
modelValue: {
|
|
44
57
|
type: Array,
|
|
45
58
|
default: () => []
|
|
46
59
|
},
|
|
@@ -53,9 +66,23 @@ const _sfc_main = {
|
|
|
53
66
|
}
|
|
54
67
|
},
|
|
55
68
|
emits: [
|
|
69
|
+
/**
|
|
70
|
+
* Removed in v9 - use `update:modelValue` (`v-model`) instead
|
|
71
|
+
* @deprecated
|
|
72
|
+
*/
|
|
56
73
|
"input",
|
|
74
|
+
/** Emitted when the groups selection changes<br />**Payload:** `value` (`Array`) - *Ids of selected groups */
|
|
75
|
+
"update:modelValue",
|
|
76
|
+
/** Same as update:modelValue for Vue 2 compatibility */
|
|
77
|
+
"update:model-value",
|
|
57
78
|
"error"
|
|
58
79
|
],
|
|
80
|
+
setup() {
|
|
81
|
+
const model = useModelMigration("value", "input");
|
|
82
|
+
return {
|
|
83
|
+
model
|
|
84
|
+
};
|
|
85
|
+
},
|
|
59
86
|
data() {
|
|
60
87
|
return {
|
|
61
88
|
/** Temporary store to cache groups */
|
|
@@ -77,7 +104,7 @@ const _sfc_main = {
|
|
|
77
104
|
* @return {string[]}
|
|
78
105
|
*/
|
|
79
106
|
filteredValue() {
|
|
80
|
-
return this.
|
|
107
|
+
return this.model.filter((group) => group !== "" && typeof group === "string");
|
|
81
108
|
},
|
|
82
109
|
/**
|
|
83
110
|
* value property converted to an array of group objects used as input for the NcSelect
|
|
@@ -102,7 +129,7 @@ const _sfc_main = {
|
|
|
102
129
|
* @return {object[]}
|
|
103
130
|
*/
|
|
104
131
|
groupsArray() {
|
|
105
|
-
return Object.values(this.groups).filter((g) => !this.
|
|
132
|
+
return Object.values(this.groups).filter((g) => !this.model.includes(g.id));
|
|
106
133
|
}
|
|
107
134
|
},
|
|
108
135
|
watch: {
|
|
@@ -125,7 +152,7 @@ const _sfc_main = {
|
|
|
125
152
|
* Load groups matching the empty query to reduce API calls
|
|
126
153
|
*/
|
|
127
154
|
async mounted() {
|
|
128
|
-
const storageName =
|
|
155
|
+
const storageName = `${appName}:${appVersion}/initialGroups`;
|
|
129
156
|
let savedGroups = window.sessionStorage.getItem(storageName);
|
|
130
157
|
if (savedGroups) {
|
|
131
158
|
savedGroups = Object.fromEntries(JSON.parse(savedGroups).map((group) => [group.id, group]));
|
|
@@ -144,7 +171,7 @@ const _sfc_main = {
|
|
|
144
171
|
*/
|
|
145
172
|
update(updatedValue) {
|
|
146
173
|
const value = updatedValue.map((element) => element.id);
|
|
147
|
-
this
|
|
174
|
+
this.model = value;
|
|
148
175
|
},
|
|
149
176
|
/**
|
|
150
177
|
* Use provisioning API to search for given group and save it in the groups object
|
|
@@ -155,7 +182,7 @@ const _sfc_main = {
|
|
|
155
182
|
async loadGroup(query) {
|
|
156
183
|
try {
|
|
157
184
|
query = typeof query === "string" ? encodeURI(query) : "";
|
|
158
|
-
const response = await axios.get(generateOcsUrl(
|
|
185
|
+
const response = await axios.get(generateOcsUrl(`cloud/groups/details?search=${query}&limit=10`, 2));
|
|
159
186
|
if (this.errorMessage !== "") {
|
|
160
187
|
window.setTimeout(() => {
|
|
161
188
|
this.errorMessage = "";
|
|
@@ -180,7 +207,7 @@ const _sfc_main = {
|
|
|
180
207
|
* @param {string} search The current search string
|
|
181
208
|
*/
|
|
182
209
|
filterGroups(option, label, search) {
|
|
183
|
-
return
|
|
210
|
+
return `${label || ""} ${option.id}`.toLocaleLowerCase().indexOf(search.toLocaleLowerCase()) > -1;
|
|
184
211
|
},
|
|
185
212
|
/**
|
|
186
213
|
* Debounce the group search (reduce API calls)
|
|
@@ -192,7 +219,7 @@ const _sfc_main = {
|
|
|
192
219
|
};
|
|
193
220
|
var _sfc_render = function render() {
|
|
194
221
|
var _vm = this, _c = _vm._self._c;
|
|
195
|
-
return _c("div", [_vm.label ? _c("label", { staticClass: "hidden-visually", attrs: { "for": _vm.id } }, [_vm._v(_vm._s(_vm.label))]) : _vm._e(), _c("NcSelect", { attrs: { "value": _vm.inputValue, "options": _vm.groupsArray, "placeholder": _vm.placeholder || _vm.label, "filter-by": _vm.filterGroups, "input-id": _vm.id, "limit": 5, "label": "displayname", "multiple": true, "close-on-select": false, "disabled": _vm.disabled }, on: { "
|
|
222
|
+
return _c("div", [_vm.label ? _c("label", { staticClass: "hidden-visually", attrs: { "for": _vm.id } }, [_vm._v(_vm._s(_vm.label))]) : _vm._e(), _c("NcSelect", { attrs: { "value": _vm.inputValue, "options": _vm.groupsArray, "placeholder": _vm.placeholder || _vm.label, "filter-by": _vm.filterGroups, "input-id": _vm.id, "limit": 5, "label": "displayname", "multiple": true, "close-on-select": false, "disabled": _vm.disabled }, on: { "update:model-value": _vm.update, "search": _vm.onSearch } }), _c("div", { directives: [{ name: "show", rawName: "v-show", value: _vm.hasError, expression: "hasError" }], staticClass: "select-group-error" }, [_vm._v(" " + _vm._s(_vm.errorMessage) + " ")])], 1);
|
|
196
223
|
};
|
|
197
224
|
var _sfc_staticRenderFns = [];
|
|
198
225
|
var __component__ = /* @__PURE__ */ normalizeComponent(
|
|
@@ -201,7 +228,7 @@ var __component__ = /* @__PURE__ */ normalizeComponent(
|
|
|
201
228
|
_sfc_staticRenderFns,
|
|
202
229
|
false,
|
|
203
230
|
null,
|
|
204
|
-
"
|
|
231
|
+
"a53a2bb4"
|
|
205
232
|
);
|
|
206
233
|
const NcSettingsSelectGroup = __component__.exports;
|
|
207
234
|
export {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NcSettingsSelectGroup-BAhG6V1R.mjs","sources":["../../src/components/NcSettingsSelectGroup/NcSettingsSelectGroup.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n```vue\n<template>\n\t<section>\n\t\t<NcSettingsSelectGroup v-model=\"groups\" placeholder=\"Select user groups\" label=\"The hidden label\" />\n\t\t<NcSettingsSelectGroup v-model=\"otherGroups\" :disabled=\"true\" label=\"Also a fallback for the placeholder\" />\n\t\t<div>You have selected: <code>{{ groups }}</code> and <code>{{ otherGroups }}</code></div>\n\t</section>\n</template>\n<script>\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\tgroups: [],\n\t\t\totherGroups: ['admin']\n\t\t}\n\t}\n}\n</script>\n<style scoped>\nsection * {\n\tpadding: 6px 0px;\n}\n</style>\n```\n</docs>\n\n<template>\n\t<div>\n\t\t<label v-if=\"label\" :for=\"id\" class=\"hidden-visually\">{{ label }}</label>\n\t\t<NcSelect :value=\"inputValue\"\n\t\t\t:options=\"groupsArray\"\n\t\t\t:placeholder=\"placeholder || label\"\n\t\t\t:filter-by=\"filterGroups\"\n\t\t\t:input-id=\"id\"\n\t\t\t:limit=\"5\"\n\t\t\tlabel=\"displayname\"\n\t\t\t:multiple=\"true\"\n\t\t\t:close-on-select=\"false\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t@update:model-value=\"update\"\n\t\t\t@search=\"onSearch\" />\n\t\t<div v-show=\"hasError\" class=\"select-group-error\">\n\t\t\t{{ errorMessage }}\n\t\t</div>\n\t</div>\n</template>\n\n<script>\nimport NcSelect from '../../components/NcSelect/index.js'\nimport { t } from '../../l10n.js'\nimport GenRandomId from '../../utils/GenRandomId.js'\nimport { useModelMigration } from '../../composables/useModelMigration.ts'\n\nimport axios from '@nextcloud/axios'\nimport debounce from 'debounce'\nimport { generateOcsUrl } from '@nextcloud/router'\n\nexport default {\n\tname: 'NcSettingsSelectGroup',\n\tcomponents: {\n\t\tNcSelect,\n\t},\n\n\tmodel: {\n\t\tprop: 'modelValue',\n\t\tevent: 'update:modelValue',\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * The text of the label element of the select group input\n\t\t */\n\t\tlabel: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * Placeholder for the input element\n\t\t * For backwards compatibility it falls back to the `label` value\n\t\t */\n\t\tplaceholder: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * id attribute of the select group element\n\t\t */\n\t\tid: {\n\t\t\ttype: String,\n\t\t\tdefault: () => 'action-' + GenRandomId(),\n\t\t\tvalidator: id => id.trim() !== '',\n\t\t},\n\n\t\t/**\n\t\t * Removed in v9 - use `modelValue` (`v-model`) instead\n\t\t * @deprecated\n\t\t */\n\t\tvalue: {\n\t\t\ttype: Array,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * value of the select group input\n\t\t * A list of group IDs can be provided\n\t\t */\n\t\tmodelValue: {\n\t\t\ttype: Array,\n\t\t\tdefault: () => [],\n\t\t},\n\n\t\t/**\n\t\t * disabled state of the settings select group input\n\t\t */\n\t\tdisabled: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t},\n\temits: [\n\t\t/**\n\t\t * Removed in v9 - use `update:modelValue` (`v-model`) instead\n\t\t * @deprecated\n\t\t */\n\t\t'input',\n\t\t/** Emitted when the groups selection changes<br />**Payload:** `value` (`Array`) - *Ids of selected groups */\n\t\t'update:modelValue',\n\t\t/** Same as update:modelValue for Vue 2 compatibility */\n\t\t'update:model-value',\n\t\t'error',\n\t],\n\tsetup() {\n\t\tconst model = useModelMigration('value', 'input')\n\t\treturn {\n\t\t\tmodel,\n\t\t}\n\t},\n\tdata() {\n\t\treturn {\n\t\t\t/** Temporary store to cache groups */\n\t\t\tgroups: {},\n\t\t\trandId: GenRandomId(),\n\t\t\terrorMessage: '',\n\t\t}\n\t},\n\tcomputed: {\n\t\t/**\n\t\t * If the error message should be shown\n\t\t */\n\t\thasError() {\n\t\t\treturn this.errorMessage !== ''\n\t\t},\n\n\t\t/**\n\t\t * Validate input value and only return valid strings (group IDs)\n\t\t *\n\t\t * @return {string[]}\n\t\t */\n\t\tfilteredValue() {\n\t\t\treturn this.model.filter((group) => group !== '' && typeof group === 'string')\n\t\t},\n\n\t\t/**\n\t\t * value property converted to an array of group objects used as input for the NcSelect\n\t\t */\n\t\tinputValue() {\n\t\t\treturn this.filteredValue.map(\n\t\t\t\t(id) => {\n\t\t\t\t\tif (typeof this.groups[id] === 'undefined') {\n\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\tid,\n\t\t\t\t\t\t\tdisplayname: id,\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\treturn this.groups[id]\n\t\t\t\t},\n\t\t\t)\n\t\t},\n\n\t\t/**\n\t\t * Convert groups object to array of groups required for NcSelect.options\n\t\t * Filter out currently selected values\n\t\t *\n\t\t * @return {object[]}\n\t\t */\n\t\tgroupsArray() {\n\t\t\treturn Object.values(this.groups).filter(g => !this.model.includes(g.id))\n\t\t},\n\t},\n\twatch: {\n\t\t/**\n\t\t * If the value is changed, check that all groups are loaded so we show the correct display name\n\t\t */\n\t\tvalue: {\n\t\t\thandler() {\n\t\t\t\tconst loadedGroupIds = Object.keys(this.groups)\n\t\t\t\tconst missing = this.filteredValue.filter(group => !loadedGroupIds.includes(group))\n\t\t\t\tmissing.forEach((groupId) => {\n\t\t\t\t\tthis.loadGroup(groupId)\n\t\t\t\t})\n\t\t\t},\n\t\t\t// Run the watch handler also when the component is initially mounted\n\t\t\timmediate: true,\n\t\t},\n\t},\n\t/**\n\t * Load groups matching the empty query to reduce API calls\n\t */\n\tasync mounted() {\n\t\t// version scoped to prevent issues with different library versions\n\t\tconst storageName = `${appName}:${appVersion}/initialGroups`\n\n\t\tlet savedGroups = window.sessionStorage.getItem(storageName)\n\t\tif (savedGroups) {\n\t\t\tsavedGroups = Object.fromEntries(JSON.parse(savedGroups).map(group => [group.id, group]))\n\t\t\tthis.groups = { ...this.groups, ...savedGroups }\n\t\t} else {\n\t\t\tawait this.loadGroup('')\n\t\t\twindow.sessionStorage.setItem(storageName, JSON.stringify(Object.values(this.groups)))\n\t\t}\n\t},\n\tmethods: {\n\t\tt,\n\n\t\t/**\n\t\t * Called when a new group is selected or previous group is deselected to emit the update event\n\t\t *\n\t\t * @param {object[]} updatedValue Array of selected groups\n\t\t */\n\t\tupdate(updatedValue) {\n\t\t\tconst value = updatedValue.map((element) => element.id)\n\t\t\tthis.model = value\n\t\t},\n\n\t\t/**\n\t\t * Use provisioning API to search for given group and save it in the groups object\n\t\t *\n\t\t * @param {string} query The query like parts of the id oder display name\n\t\t * @return {boolean}\n\t\t */\n\t\tasync loadGroup(query) {\n\t\t\ttry {\n\t\t\t\tquery = typeof query === 'string' ? encodeURI(query) : ''\n\t\t\t\tconst response = await axios.get(generateOcsUrl(`cloud/groups/details?search=${query}&limit=10`, 2))\n\n\t\t\t\t// No network error, so reset any error after 5 seconds\n\t\t\t\tif (this.errorMessage !== '') {\n\t\t\t\t\twindow.setTimeout(() => {\n\t\t\t\t\t\tthis.errorMessage = ''\n\t\t\t\t\t}, 5000)\n\t\t\t\t}\n\n\t\t\t\tif (Object.keys(response.data.ocs.data.groups).length > 0) {\n\t\t\t\t\tconst newGroups = Object.fromEntries(response.data.ocs.data.groups.map((element) => [element.id, element]))\n\t\t\t\t\tthis.groups = { ...this.groups, ...newGroups }\n\t\t\t\t\treturn true\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\t/** Emitted if groups could not be queried.<br />**Payload:** `error` (`object`) - The Axios error */\n\t\t\t\tthis.$emit('error', error)\n\t\t\t\tthis.errorMessage = t('Unable to search the group')\n\t\t\t}\n\t\t\treturn false\n\t\t},\n\n\t\t/**\n\t\t * Custom filter function for `NcSelect` to filter by ID *and* display name\n\t\t *\n\t\t * @param {object} option One of the groups\n\t\t * @param {string} label The label property of the group\n\t\t * @param {string} search The current search string\n\t\t */\n\t\tfilterGroups(option, label, search) {\n\t\t\treturn `${label || ''} ${option.id}`.toLocaleLowerCase().indexOf(search.toLocaleLowerCase()) > -1\n\t\t},\n\n\t\t/**\n\t\t * Debounce the group search (reduce API calls)\n\t\t */\n\t\tonSearch: debounce(function(query) {\n\t\t\tthis.loadGroup(query)\n\t\t}, 200),\n\t},\n}\n</script>\n\n<style scoped lang=\"scss\">\n.select-group-error {\n\tcolor: var(--color-error);\n\tfont-size: 13px;\n\tpadding-inline-start: var(--border-radius-large);\n}\n</style>\n"],"names":[],"mappings":"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"}
|
package/dist/chunks/{NcSettingsSelectGroup-8tK3uGkJ.cjs → NcSettingsSelectGroup-DypyXuEW.cjs}
RENAMED
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
require('../assets/NcSettingsSelectGroup-
|
|
1
|
+
require('../assets/NcSettingsSelectGroup-BEjOwCJQ.css');
|
|
2
2
|
"use strict";
|
|
3
|
-
const NcSelect = require("./NcSelect-
|
|
4
|
-
const _l10n = require("./_l10n-
|
|
3
|
+
const NcSelect = require("./NcSelect-Cp83bFsi.cjs");
|
|
4
|
+
const _l10n = require("./_l10n-Ch5mEdUH.cjs");
|
|
5
5
|
const GenRandomId = require("./GenRandomId-BQDud3d4.cjs");
|
|
6
|
+
const useModelMigration = require("./useModelMigration-D5zhrNXr.cjs");
|
|
6
7
|
const axios = require("@nextcloud/axios");
|
|
7
8
|
const debounce = require("debounce");
|
|
8
9
|
const router = require("@nextcloud/router");
|
|
@@ -16,6 +17,10 @@ const _sfc_main = {
|
|
|
16
17
|
components: {
|
|
17
18
|
NcSelect: NcSelect.NcSelect
|
|
18
19
|
},
|
|
20
|
+
model: {
|
|
21
|
+
prop: "modelValue",
|
|
22
|
+
event: "update:modelValue"
|
|
23
|
+
},
|
|
19
24
|
props: {
|
|
20
25
|
/**
|
|
21
26
|
* The text of the label element of the select group input
|
|
@@ -40,11 +45,19 @@ const _sfc_main = {
|
|
|
40
45
|
default: () => "action-" + GenRandomId.GenRandomId(),
|
|
41
46
|
validator: (id) => id.trim() !== ""
|
|
42
47
|
},
|
|
48
|
+
/**
|
|
49
|
+
* Removed in v9 - use `modelValue` (`v-model`) instead
|
|
50
|
+
* @deprecated
|
|
51
|
+
*/
|
|
52
|
+
value: {
|
|
53
|
+
type: Array,
|
|
54
|
+
default: void 0
|
|
55
|
+
},
|
|
43
56
|
/**
|
|
44
57
|
* value of the select group input
|
|
45
58
|
* A list of group IDs can be provided
|
|
46
59
|
*/
|
|
47
|
-
|
|
60
|
+
modelValue: {
|
|
48
61
|
type: Array,
|
|
49
62
|
default: () => []
|
|
50
63
|
},
|
|
@@ -57,9 +70,23 @@ const _sfc_main = {
|
|
|
57
70
|
}
|
|
58
71
|
},
|
|
59
72
|
emits: [
|
|
73
|
+
/**
|
|
74
|
+
* Removed in v9 - use `update:modelValue` (`v-model`) instead
|
|
75
|
+
* @deprecated
|
|
76
|
+
*/
|
|
60
77
|
"input",
|
|
78
|
+
/** Emitted when the groups selection changes<br />**Payload:** `value` (`Array`) - *Ids of selected groups */
|
|
79
|
+
"update:modelValue",
|
|
80
|
+
/** Same as update:modelValue for Vue 2 compatibility */
|
|
81
|
+
"update:model-value",
|
|
61
82
|
"error"
|
|
62
83
|
],
|
|
84
|
+
setup() {
|
|
85
|
+
const model = useModelMigration.useModelMigration("value", "input");
|
|
86
|
+
return {
|
|
87
|
+
model
|
|
88
|
+
};
|
|
89
|
+
},
|
|
63
90
|
data() {
|
|
64
91
|
return {
|
|
65
92
|
/** Temporary store to cache groups */
|
|
@@ -81,7 +108,7 @@ const _sfc_main = {
|
|
|
81
108
|
* @return {string[]}
|
|
82
109
|
*/
|
|
83
110
|
filteredValue() {
|
|
84
|
-
return this.
|
|
111
|
+
return this.model.filter((group) => group !== "" && typeof group === "string");
|
|
85
112
|
},
|
|
86
113
|
/**
|
|
87
114
|
* value property converted to an array of group objects used as input for the NcSelect
|
|
@@ -106,7 +133,7 @@ const _sfc_main = {
|
|
|
106
133
|
* @return {object[]}
|
|
107
134
|
*/
|
|
108
135
|
groupsArray() {
|
|
109
|
-
return Object.values(this.groups).filter((g) => !this.
|
|
136
|
+
return Object.values(this.groups).filter((g) => !this.model.includes(g.id));
|
|
110
137
|
}
|
|
111
138
|
},
|
|
112
139
|
watch: {
|
|
@@ -129,7 +156,7 @@ const _sfc_main = {
|
|
|
129
156
|
* Load groups matching the empty query to reduce API calls
|
|
130
157
|
*/
|
|
131
158
|
async mounted() {
|
|
132
|
-
const storageName =
|
|
159
|
+
const storageName = `${appName}:${appVersion}/initialGroups`;
|
|
133
160
|
let savedGroups = window.sessionStorage.getItem(storageName);
|
|
134
161
|
if (savedGroups) {
|
|
135
162
|
savedGroups = Object.fromEntries(JSON.parse(savedGroups).map((group) => [group.id, group]));
|
|
@@ -148,7 +175,7 @@ const _sfc_main = {
|
|
|
148
175
|
*/
|
|
149
176
|
update(updatedValue) {
|
|
150
177
|
const value = updatedValue.map((element) => element.id);
|
|
151
|
-
this
|
|
178
|
+
this.model = value;
|
|
152
179
|
},
|
|
153
180
|
/**
|
|
154
181
|
* Use provisioning API to search for given group and save it in the groups object
|
|
@@ -159,7 +186,7 @@ const _sfc_main = {
|
|
|
159
186
|
async loadGroup(query) {
|
|
160
187
|
try {
|
|
161
188
|
query = typeof query === "string" ? encodeURI(query) : "";
|
|
162
|
-
const response = await axios__default.default.get(router.generateOcsUrl(
|
|
189
|
+
const response = await axios__default.default.get(router.generateOcsUrl(`cloud/groups/details?search=${query}&limit=10`, 2));
|
|
163
190
|
if (this.errorMessage !== "") {
|
|
164
191
|
window.setTimeout(() => {
|
|
165
192
|
this.errorMessage = "";
|
|
@@ -184,7 +211,7 @@ const _sfc_main = {
|
|
|
184
211
|
* @param {string} search The current search string
|
|
185
212
|
*/
|
|
186
213
|
filterGroups(option, label, search) {
|
|
187
|
-
return
|
|
214
|
+
return `${label || ""} ${option.id}`.toLocaleLowerCase().indexOf(search.toLocaleLowerCase()) > -1;
|
|
188
215
|
},
|
|
189
216
|
/**
|
|
190
217
|
* Debounce the group search (reduce API calls)
|
|
@@ -196,7 +223,7 @@ const _sfc_main = {
|
|
|
196
223
|
};
|
|
197
224
|
var _sfc_render = function render() {
|
|
198
225
|
var _vm = this, _c = _vm._self._c;
|
|
199
|
-
return _c("div", [_vm.label ? _c("label", { staticClass: "hidden-visually", attrs: { "for": _vm.id } }, [_vm._v(_vm._s(_vm.label))]) : _vm._e(), _c("NcSelect", { attrs: { "value": _vm.inputValue, "options": _vm.groupsArray, "placeholder": _vm.placeholder || _vm.label, "filter-by": _vm.filterGroups, "input-id": _vm.id, "limit": 5, "label": "displayname", "multiple": true, "close-on-select": false, "disabled": _vm.disabled }, on: { "
|
|
226
|
+
return _c("div", [_vm.label ? _c("label", { staticClass: "hidden-visually", attrs: { "for": _vm.id } }, [_vm._v(_vm._s(_vm.label))]) : _vm._e(), _c("NcSelect", { attrs: { "value": _vm.inputValue, "options": _vm.groupsArray, "placeholder": _vm.placeholder || _vm.label, "filter-by": _vm.filterGroups, "input-id": _vm.id, "limit": 5, "label": "displayname", "multiple": true, "close-on-select": false, "disabled": _vm.disabled }, on: { "update:model-value": _vm.update, "search": _vm.onSearch } }), _c("div", { directives: [{ name: "show", rawName: "v-show", value: _vm.hasError, expression: "hasError" }], staticClass: "select-group-error" }, [_vm._v(" " + _vm._s(_vm.errorMessage) + " ")])], 1);
|
|
200
227
|
};
|
|
201
228
|
var _sfc_staticRenderFns = [];
|
|
202
229
|
var __component__ = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
|
|
@@ -205,7 +232,7 @@ var __component__ = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
|
|
|
205
232
|
_sfc_staticRenderFns,
|
|
206
233
|
false,
|
|
207
234
|
null,
|
|
208
|
-
"
|
|
235
|
+
"a53a2bb4"
|
|
209
236
|
);
|
|
210
237
|
const NcSettingsSelectGroup = __component__.exports;
|
|
211
238
|
exports.NcSettingsSelectGroup = NcSettingsSelectGroup;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NcSettingsSelectGroup-DypyXuEW.cjs","sources":["../../src/components/NcSettingsSelectGroup/NcSettingsSelectGroup.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n```vue\n<template>\n\t<section>\n\t\t<NcSettingsSelectGroup v-model=\"groups\" placeholder=\"Select user groups\" label=\"The hidden label\" />\n\t\t<NcSettingsSelectGroup v-model=\"otherGroups\" :disabled=\"true\" label=\"Also a fallback for the placeholder\" />\n\t\t<div>You have selected: <code>{{ groups }}</code> and <code>{{ otherGroups }}</code></div>\n\t</section>\n</template>\n<script>\nexport default {\n\tdata() {\n\t\treturn {\n\t\t\tgroups: [],\n\t\t\totherGroups: ['admin']\n\t\t}\n\t}\n}\n</script>\n<style scoped>\nsection * {\n\tpadding: 6px 0px;\n}\n</style>\n```\n</docs>\n\n<template>\n\t<div>\n\t\t<label v-if=\"label\" :for=\"id\" class=\"hidden-visually\">{{ label }}</label>\n\t\t<NcSelect :value=\"inputValue\"\n\t\t\t:options=\"groupsArray\"\n\t\t\t:placeholder=\"placeholder || label\"\n\t\t\t:filter-by=\"filterGroups\"\n\t\t\t:input-id=\"id\"\n\t\t\t:limit=\"5\"\n\t\t\tlabel=\"displayname\"\n\t\t\t:multiple=\"true\"\n\t\t\t:close-on-select=\"false\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t@update:model-value=\"update\"\n\t\t\t@search=\"onSearch\" />\n\t\t<div v-show=\"hasError\" class=\"select-group-error\">\n\t\t\t{{ errorMessage }}\n\t\t</div>\n\t</div>\n</template>\n\n<script>\nimport NcSelect from '../../components/NcSelect/index.js'\nimport { t } from '../../l10n.js'\nimport GenRandomId from '../../utils/GenRandomId.js'\nimport { useModelMigration } from '../../composables/useModelMigration.ts'\n\nimport axios from '@nextcloud/axios'\nimport debounce from 'debounce'\nimport { generateOcsUrl } from '@nextcloud/router'\n\nexport default {\n\tname: 'NcSettingsSelectGroup',\n\tcomponents: {\n\t\tNcSelect,\n\t},\n\n\tmodel: {\n\t\tprop: 'modelValue',\n\t\tevent: 'update:modelValue',\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * The text of the label element of the select group input\n\t\t */\n\t\tlabel: {\n\t\t\ttype: String,\n\t\t\trequired: true,\n\t\t},\n\n\t\t/**\n\t\t * Placeholder for the input element\n\t\t * For backwards compatibility it falls back to the `label` value\n\t\t */\n\t\tplaceholder: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * id attribute of the select group element\n\t\t */\n\t\tid: {\n\t\t\ttype: String,\n\t\t\tdefault: () => 'action-' + GenRandomId(),\n\t\t\tvalidator: id => id.trim() !== '',\n\t\t},\n\n\t\t/**\n\t\t * Removed in v9 - use `modelValue` (`v-model`) instead\n\t\t * @deprecated\n\t\t */\n\t\tvalue: {\n\t\t\ttype: Array,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * value of the select group input\n\t\t * A list of group IDs can be provided\n\t\t */\n\t\tmodelValue: {\n\t\t\ttype: Array,\n\t\t\tdefault: () => [],\n\t\t},\n\n\t\t/**\n\t\t * disabled state of the settings select group input\n\t\t */\n\t\tdisabled: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\t},\n\temits: [\n\t\t/**\n\t\t * Removed in v9 - use `update:modelValue` (`v-model`) instead\n\t\t * @deprecated\n\t\t */\n\t\t'input',\n\t\t/** Emitted when the groups selection changes<br />**Payload:** `value` (`Array`) - *Ids of selected groups */\n\t\t'update:modelValue',\n\t\t/** Same as update:modelValue for Vue 2 compatibility */\n\t\t'update:model-value',\n\t\t'error',\n\t],\n\tsetup() {\n\t\tconst model = useModelMigration('value', 'input')\n\t\treturn {\n\t\t\tmodel,\n\t\t}\n\t},\n\tdata() {\n\t\treturn {\n\t\t\t/** Temporary store to cache groups */\n\t\t\tgroups: {},\n\t\t\trandId: GenRandomId(),\n\t\t\terrorMessage: '',\n\t\t}\n\t},\n\tcomputed: {\n\t\t/**\n\t\t * If the error message should be shown\n\t\t */\n\t\thasError() {\n\t\t\treturn this.errorMessage !== ''\n\t\t},\n\n\t\t/**\n\t\t * Validate input value and only return valid strings (group IDs)\n\t\t *\n\t\t * @return {string[]}\n\t\t */\n\t\tfilteredValue() {\n\t\t\treturn this.model.filter((group) => group !== '' && typeof group === 'string')\n\t\t},\n\n\t\t/**\n\t\t * value property converted to an array of group objects used as input for the NcSelect\n\t\t */\n\t\tinputValue() {\n\t\t\treturn this.filteredValue.map(\n\t\t\t\t(id) => {\n\t\t\t\t\tif (typeof this.groups[id] === 'undefined') {\n\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\tid,\n\t\t\t\t\t\t\tdisplayname: id,\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\treturn this.groups[id]\n\t\t\t\t},\n\t\t\t)\n\t\t},\n\n\t\t/**\n\t\t * Convert groups object to array of groups required for NcSelect.options\n\t\t * Filter out currently selected values\n\t\t *\n\t\t * @return {object[]}\n\t\t */\n\t\tgroupsArray() {\n\t\t\treturn Object.values(this.groups).filter(g => !this.model.includes(g.id))\n\t\t},\n\t},\n\twatch: {\n\t\t/**\n\t\t * If the value is changed, check that all groups are loaded so we show the correct display name\n\t\t */\n\t\tvalue: {\n\t\t\thandler() {\n\t\t\t\tconst loadedGroupIds = Object.keys(this.groups)\n\t\t\t\tconst missing = this.filteredValue.filter(group => !loadedGroupIds.includes(group))\n\t\t\t\tmissing.forEach((groupId) => {\n\t\t\t\t\tthis.loadGroup(groupId)\n\t\t\t\t})\n\t\t\t},\n\t\t\t// Run the watch handler also when the component is initially mounted\n\t\t\timmediate: true,\n\t\t},\n\t},\n\t/**\n\t * Load groups matching the empty query to reduce API calls\n\t */\n\tasync mounted() {\n\t\t// version scoped to prevent issues with different library versions\n\t\tconst storageName = `${appName}:${appVersion}/initialGroups`\n\n\t\tlet savedGroups = window.sessionStorage.getItem(storageName)\n\t\tif (savedGroups) {\n\t\t\tsavedGroups = Object.fromEntries(JSON.parse(savedGroups).map(group => [group.id, group]))\n\t\t\tthis.groups = { ...this.groups, ...savedGroups }\n\t\t} else {\n\t\t\tawait this.loadGroup('')\n\t\t\twindow.sessionStorage.setItem(storageName, JSON.stringify(Object.values(this.groups)))\n\t\t}\n\t},\n\tmethods: {\n\t\tt,\n\n\t\t/**\n\t\t * Called when a new group is selected or previous group is deselected to emit the update event\n\t\t *\n\t\t * @param {object[]} updatedValue Array of selected groups\n\t\t */\n\t\tupdate(updatedValue) {\n\t\t\tconst value = updatedValue.map((element) => element.id)\n\t\t\tthis.model = value\n\t\t},\n\n\t\t/**\n\t\t * Use provisioning API to search for given group and save it in the groups object\n\t\t *\n\t\t * @param {string} query The query like parts of the id oder display name\n\t\t * @return {boolean}\n\t\t */\n\t\tasync loadGroup(query) {\n\t\t\ttry {\n\t\t\t\tquery = typeof query === 'string' ? encodeURI(query) : ''\n\t\t\t\tconst response = await axios.get(generateOcsUrl(`cloud/groups/details?search=${query}&limit=10`, 2))\n\n\t\t\t\t// No network error, so reset any error after 5 seconds\n\t\t\t\tif (this.errorMessage !== '') {\n\t\t\t\t\twindow.setTimeout(() => {\n\t\t\t\t\t\tthis.errorMessage = ''\n\t\t\t\t\t}, 5000)\n\t\t\t\t}\n\n\t\t\t\tif (Object.keys(response.data.ocs.data.groups).length > 0) {\n\t\t\t\t\tconst newGroups = Object.fromEntries(response.data.ocs.data.groups.map((element) => [element.id, element]))\n\t\t\t\t\tthis.groups = { ...this.groups, ...newGroups }\n\t\t\t\t\treturn true\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\t/** Emitted if groups could not be queried.<br />**Payload:** `error` (`object`) - The Axios error */\n\t\t\t\tthis.$emit('error', error)\n\t\t\t\tthis.errorMessage = t('Unable to search the group')\n\t\t\t}\n\t\t\treturn false\n\t\t},\n\n\t\t/**\n\t\t * Custom filter function for `NcSelect` to filter by ID *and* display name\n\t\t *\n\t\t * @param {object} option One of the groups\n\t\t * @param {string} label The label property of the group\n\t\t * @param {string} search The current search string\n\t\t */\n\t\tfilterGroups(option, label, search) {\n\t\t\treturn `${label || ''} ${option.id}`.toLocaleLowerCase().indexOf(search.toLocaleLowerCase()) > -1\n\t\t},\n\n\t\t/**\n\t\t * Debounce the group search (reduce API calls)\n\t\t */\n\t\tonSearch: debounce(function(query) {\n\t\t\tthis.loadGroup(query)\n\t\t}, 200),\n\t},\n}\n</script>\n\n<style scoped lang=\"scss\">\n.select-group-error {\n\tcolor: var(--color-error);\n\tfont-size: 13px;\n\tpadding-inline-start: var(--border-radius-large);\n}\n</style>\n"],"names":["NcSelect","GenRandomId","useModelMigration","t","axios","generateOcsUrl","debounce"],"mappings":"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"}
|
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
import '../assets/NcTextArea-fzbciv3V.css';
|
|
2
|
+
import { G as GenRandomId } from "./GenRandomId-CMooMQt0.mjs";
|
|
3
|
+
import { A as AlertCircle } from "./AlertCircleOutline-DBxbepLy.mjs";
|
|
4
|
+
import { C as Check } from "./Check-BkThHPH7.mjs";
|
|
5
|
+
import { u as useModelMigration } from "./useModelMigration-EhAWvqDD.mjs";
|
|
6
|
+
import { n as normalizeComponent } from "./_plugin-vue2_normalizer-DU4iP6Vu.mjs";
|
|
7
|
+
const _sfc_main = {
|
|
8
|
+
name: "NcTextArea",
|
|
9
|
+
components: {
|
|
10
|
+
AlertCircle,
|
|
11
|
+
Check
|
|
12
|
+
},
|
|
13
|
+
inheritAttrs: false,
|
|
14
|
+
model: {
|
|
15
|
+
prop: "modelValue",
|
|
16
|
+
event: "update:modelValue"
|
|
17
|
+
},
|
|
18
|
+
props: {
|
|
19
|
+
/**
|
|
20
|
+
* Removed in v9 - use `modelValue` (`v-model`) instead
|
|
21
|
+
* @deprecated
|
|
22
|
+
*/
|
|
23
|
+
value: {
|
|
24
|
+
type: String,
|
|
25
|
+
default: void 0
|
|
26
|
+
},
|
|
27
|
+
/**
|
|
28
|
+
* The value of the input field
|
|
29
|
+
*/
|
|
30
|
+
modelValue: {
|
|
31
|
+
type: String,
|
|
32
|
+
default: void 0
|
|
33
|
+
},
|
|
34
|
+
/**
|
|
35
|
+
* The input label, always provide one for accessibility purposes.
|
|
36
|
+
* This will also be used as a placeholder unless the placeholder
|
|
37
|
+
* prop is populated with a different string.
|
|
38
|
+
*/
|
|
39
|
+
label: {
|
|
40
|
+
type: String,
|
|
41
|
+
default: void 0
|
|
42
|
+
},
|
|
43
|
+
/**
|
|
44
|
+
* Pass in true if you want to use an external label. This is useful
|
|
45
|
+
* if you need a label that looks different from the one provided by
|
|
46
|
+
* this component
|
|
47
|
+
*/
|
|
48
|
+
labelOutside: {
|
|
49
|
+
type: Boolean,
|
|
50
|
+
default: false
|
|
51
|
+
},
|
|
52
|
+
/**
|
|
53
|
+
* The placeholder of the input. This defaults as the string that's
|
|
54
|
+
* passed into the label prop. In order to remove the placeholder,
|
|
55
|
+
* pass in an empty string.
|
|
56
|
+
*/
|
|
57
|
+
placeholder: {
|
|
58
|
+
type: String,
|
|
59
|
+
default: void 0
|
|
60
|
+
},
|
|
61
|
+
/**
|
|
62
|
+
* Toggles the success state of the component. Adds a checkmark icon.
|
|
63
|
+
* this cannot be used together with canClear.
|
|
64
|
+
*/
|
|
65
|
+
success: {
|
|
66
|
+
type: Boolean,
|
|
67
|
+
default: false
|
|
68
|
+
},
|
|
69
|
+
/**
|
|
70
|
+
* Toggles the error state of the component. Adds an error icon.
|
|
71
|
+
* this cannot be used together with canClear.
|
|
72
|
+
*/
|
|
73
|
+
error: {
|
|
74
|
+
type: Boolean,
|
|
75
|
+
default: false
|
|
76
|
+
},
|
|
77
|
+
/**
|
|
78
|
+
* Additional helper text message
|
|
79
|
+
*
|
|
80
|
+
* This will be displayed beneath the input field. In case the field is
|
|
81
|
+
* also marked as having an error, the text will be displayed in red.
|
|
82
|
+
*/
|
|
83
|
+
helperText: {
|
|
84
|
+
type: String,
|
|
85
|
+
default: ""
|
|
86
|
+
},
|
|
87
|
+
/**
|
|
88
|
+
* Disable the input field
|
|
89
|
+
*/
|
|
90
|
+
disabled: {
|
|
91
|
+
type: Boolean,
|
|
92
|
+
default: false
|
|
93
|
+
},
|
|
94
|
+
/**
|
|
95
|
+
* Class to add to the input field.
|
|
96
|
+
* Necessary to use NcInputField in the NcActionInput component.
|
|
97
|
+
*/
|
|
98
|
+
inputClass: {
|
|
99
|
+
type: [Object, String],
|
|
100
|
+
default: ""
|
|
101
|
+
},
|
|
102
|
+
/**
|
|
103
|
+
* The resize CSS property sets whether an element is resizable, and if
|
|
104
|
+
* so, in which directions.
|
|
105
|
+
*/
|
|
106
|
+
resize: {
|
|
107
|
+
type: String,
|
|
108
|
+
default: "both",
|
|
109
|
+
validator: (value) => ["both", "vertical", "horizontal", "none"].includes(value)
|
|
110
|
+
}
|
|
111
|
+
},
|
|
112
|
+
emits: [
|
|
113
|
+
/**
|
|
114
|
+
* Removed in v9 - use `update:modelValue` (`v-model`) instead
|
|
115
|
+
* @deprecated
|
|
116
|
+
*/
|
|
117
|
+
"update:value",
|
|
118
|
+
"update:modelValue",
|
|
119
|
+
/** Same as update:modelValue for Vue 2 compatibility */
|
|
120
|
+
"update:model-value"
|
|
121
|
+
],
|
|
122
|
+
setup() {
|
|
123
|
+
const model = useModelMigration("value", "update:value", true);
|
|
124
|
+
return {
|
|
125
|
+
model
|
|
126
|
+
};
|
|
127
|
+
},
|
|
128
|
+
computed: {
|
|
129
|
+
computedId() {
|
|
130
|
+
return this.$attrs.id && this.$attrs.id !== "" ? this.$attrs.id : this.inputName;
|
|
131
|
+
},
|
|
132
|
+
inputName() {
|
|
133
|
+
return "input" + GenRandomId();
|
|
134
|
+
},
|
|
135
|
+
hasPlaceholder() {
|
|
136
|
+
return this.placeholder !== "" && this.placeholder !== void 0;
|
|
137
|
+
},
|
|
138
|
+
computedPlaceholder() {
|
|
139
|
+
return this.hasPlaceholder ? this.placeholder : this.label;
|
|
140
|
+
},
|
|
141
|
+
isValidLabel() {
|
|
142
|
+
const isValidLabel = this.label || this.labelOutside;
|
|
143
|
+
if (!isValidLabel) {
|
|
144
|
+
console.warn("You need to add a label to the NcInputField component. Either use the prop label or use an external one, as per the example in the documentation.");
|
|
145
|
+
}
|
|
146
|
+
return isValidLabel;
|
|
147
|
+
},
|
|
148
|
+
ariaDescribedby() {
|
|
149
|
+
const ariaDescribedby = [];
|
|
150
|
+
if (this.helperText.length > 0) {
|
|
151
|
+
ariaDescribedby.push(`${this.inputName}-helper-text`);
|
|
152
|
+
}
|
|
153
|
+
if (this.$attrs["aria-describedby"]) {
|
|
154
|
+
ariaDescribedby.push(this.$attrs["aria-describedby"]);
|
|
155
|
+
}
|
|
156
|
+
return ariaDescribedby.join(" ") || null;
|
|
157
|
+
}
|
|
158
|
+
},
|
|
159
|
+
methods: {
|
|
160
|
+
/**
|
|
161
|
+
* Focus the input element
|
|
162
|
+
*
|
|
163
|
+
* @public
|
|
164
|
+
*/
|
|
165
|
+
focus() {
|
|
166
|
+
this.$refs.input.focus();
|
|
167
|
+
},
|
|
168
|
+
/**
|
|
169
|
+
* Select all the text in the input
|
|
170
|
+
*
|
|
171
|
+
* @public
|
|
172
|
+
*/
|
|
173
|
+
select() {
|
|
174
|
+
this.$refs.input.select();
|
|
175
|
+
},
|
|
176
|
+
handleInput(event) {
|
|
177
|
+
this.model = event.target.value;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
};
|
|
181
|
+
var _sfc_render = function render() {
|
|
182
|
+
var _vm = this, _c = _vm._self._c;
|
|
183
|
+
return _c("div", { staticClass: "textarea", class: { "textarea--disabled": _vm.disabled } }, [_c("div", { staticClass: "textarea__main-wrapper" }, [_c("textarea", _vm._g(_vm._b({ ref: "input", staticClass: "textarea__input", class: [
|
|
184
|
+
_vm.inputClass,
|
|
185
|
+
{
|
|
186
|
+
"textarea__input--label-outside": _vm.labelOutside,
|
|
187
|
+
"textarea__input--success": _vm.success,
|
|
188
|
+
"textarea__input--error": _vm.error
|
|
189
|
+
}
|
|
190
|
+
], style: { resize: _vm.resize }, attrs: { "id": _vm.computedId, "disabled": _vm.disabled, "placeholder": _vm.computedPlaceholder, "aria-describedby": _vm.ariaDescribedby, "aria-live": "polite" }, domProps: { "value": _vm.model }, on: { "input": _vm.handleInput } }, "textarea", _vm.$attrs, false), _vm.$listeners)), _vm._v(" "), !_vm.labelOutside && _vm.isValidLabel ? _c("label", { staticClass: "textarea__label", attrs: { "for": _vm.computedId } }, [_vm._v(" " + _vm._s(_vm.label) + " ")]) : _vm._e()]), _vm.helperText.length > 0 ? _c("p", { staticClass: "textarea__helper-text-message", class: {
|
|
191
|
+
"textarea__helper-text-message--error": _vm.error,
|
|
192
|
+
"textarea__helper-text-message--success": _vm.success
|
|
193
|
+
}, attrs: { "id": `${_vm.inputName}-helper-text` } }, [_vm.success ? _c("Check", { staticClass: "textarea__helper-text-message__icon", attrs: { "size": 18 } }) : _vm.error ? _c("AlertCircle", { staticClass: "textarea__helper-text-message__icon", attrs: { "size": 18 } }) : _vm._e(), _vm._v(" " + _vm._s(_vm.helperText) + " ")], 1) : _vm._e()]);
|
|
194
|
+
};
|
|
195
|
+
var _sfc_staticRenderFns = [];
|
|
196
|
+
var __component__ = /* @__PURE__ */ normalizeComponent(
|
|
197
|
+
_sfc_main,
|
|
198
|
+
_sfc_render,
|
|
199
|
+
_sfc_staticRenderFns,
|
|
200
|
+
false,
|
|
201
|
+
null,
|
|
202
|
+
"c89174d0"
|
|
203
|
+
);
|
|
204
|
+
const NcTextArea = __component__.exports;
|
|
205
|
+
export {
|
|
206
|
+
NcTextArea as N
|
|
207
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NcTextArea-BHERsE_g.mjs","sources":["../../src/components/NcTextArea/NcTextArea.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\n### Description\n\nThis component is a textarea field.\nIt extends and styles an HTMLTextAreaElement.\n\n```\n<template>\n\t<div class=\"wrapper\">\n\t\t<NcTextArea label=\"Text area\"\n\t\t\tv-model=\"text1\"\n\t\t\tplaceholder=\"Placeholders are possible\"\n\t\t\thelper-text=\"This is a regular helper text.\" >\n\t\t</NcTextArea>\n\t\t<NcTextArea label=\"Success state\"\n\t\t\tv-model=\"text2\"\n\t\t\t:success=\"true\">\n\t\t</NcTextArea>\n\t\t<NcTextArea label=\"Error state\"\n\t\t\tv-model=\"text3\"\n\t\t\tplaceholder=\"Enter something valid\"\n\t\t\thelper-text=\"Helper texts will be styled accordingly.\"\n\t\t\t:error=\"true\">\n\t\t</NcTextArea>\n\t\t<NcTextArea label=\"Disabled\"\n\t\t\tv-model=\"text4\"\n\t\t\t:disabled=\"true\" />\n\t\t<NcTextArea label=\"Disabled + Success\"\n\t\t\tv-model=\"text5\"\n\t\t\t:success=\"true\"\n\t\t\t:disabled=\"true\" />\n\t\t<div class=\"external-label\">\n\t\t\t<label for=\"textField\">External label</label>\n\t\t\t<NcTextArea id=\"textField\"\n\t\t\t\tv-model=\"text6\"\n\t\t\t\t:label-outside=\"true\"\n\t\t\t\tplaceholder=\"Text area with external label\" />\n\t\t</div>\n\t\t<NcTextArea label=\"Custom size and no resize\"\n\t\t\tv-model=\"text7\"\n\t\t\tresize=\"none\"\n\t\t\trows=\"5\" />\n\t\t</NcTextArea>\n\t</div>\n</template>\n\n<script>\n\texport default {\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\ttext1: '',\n\t\t\t\ttext2: '',\n\t\t\t\ttext3: '',\n\t\t\t\ttext4: '',\n\t\t\t\ttext5: '',\n\t\t\t\ttext6: '',\n\t\t\t\ttext7: '',\n\t\t\t}\n\t\t},\n\t}\n</script>\n\n<style lang=\"scss\" scoped>\n.wrapper {\n\tdisplay: flex;\n\tgap: 4px;\n\talign-items: flex-end;\n\tflex-wrap: wrap;\n}\n\n.external-label {\n\tdisplay: flex;\n\twidth: 100%;\n\talign-items: center;\n\tgap: 14px;\n\n\t> label {\n\t\tflex-shrink: 0;\n\t}\n}\n</style>\n```\n</docs>\n\n<template>\n\t<div class=\"textarea\" :class=\"{ 'textarea--disabled': disabled }\">\n\t\t<div class=\"textarea__main-wrapper\">\n\t\t\t<textarea v-bind=\"$attrs\"\n\t\t\t\t:id=\"computedId\"\n\t\t\t\tref=\"input\"\n\t\t\t\tclass=\"textarea__input\"\n\t\t\t\t:disabled=\"disabled\"\n\t\t\t\t:placeholder=\"computedPlaceholder\"\n\t\t\t\t:aria-describedby=\"ariaDescribedby\"\n\t\t\t\taria-live=\"polite\"\n\t\t\t\t:class=\"[inputClass,\n\t\t\t\t\t{\n\t\t\t\t\t\t'textarea__input--label-outside': labelOutside,\n\t\t\t\t\t\t'textarea__input--success': success,\n\t\t\t\t\t\t'textarea__input--error': error,\n\t\t\t\t\t}]\"\n\t\t\t\t:style=\"{ resize: resize }\"\n\t\t\t\t:value=\"model\"\n\t\t\t\tv-on=\"$listeners\"\n\t\t\t\t@input=\"handleInput\" />\n\t\t\t<!-- Label -->\n\t\t\t<label v-if=\"!labelOutside && isValidLabel\"\n\t\t\t\tclass=\"textarea__label\"\n\t\t\t\t:for=\"computedId\">\n\t\t\t\t{{ label }}\n\t\t\t</label>\n\t\t</div>\n\t\t<p v-if=\"helperText.length > 0\"\n\t\t\t:id=\"`${inputName}-helper-text`\"\n\t\t\tclass=\"textarea__helper-text-message\"\n\t\t\t:class=\"{\n\t\t\t\t'textarea__helper-text-message--error': error,\n\t\t\t\t'textarea__helper-text-message--success': success,\n\t\t\t}\">\n\t\t\t<Check v-if=\"success\" class=\"textarea__helper-text-message__icon\" :size=\"18\" />\n\t\t\t<AlertCircle v-else-if=\"error\" class=\"textarea__helper-text-message__icon\" :size=\"18\" />\n\t\t\t{{ helperText }}\n\t\t</p>\n\t</div>\n</template>\n\n<script>\nimport GenRandomId from '../../utils/GenRandomId.js'\n\nimport AlertCircle from 'vue-material-design-icons/AlertCircleOutline.vue'\nimport Check from 'vue-material-design-icons/Check.vue'\nimport { useModelMigration } from '../../composables/useModelMigration.ts'\n\nexport default {\n\tname: 'NcTextArea',\n\n\tcomponents: {\n\t\tAlertCircle,\n\t\tCheck,\n\t},\n\n\tinheritAttrs: false,\n\n\tmodel: {\n\t\tprop: 'modelValue',\n\t\tevent: 'update:modelValue',\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Removed in v9 - use `modelValue` (`v-model`) instead\n\t\t * @deprecated\n\t\t */\n\t\tvalue: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * The value of the input field\n\t\t */\n\t\tmodelValue: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * The input label, always provide one for accessibility purposes.\n\t\t * This will also be used as a placeholder unless the placeholder\n\t\t * prop is populated with a different string.\n\t\t */\n\t\tlabel: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Pass in true if you want to use an external label. This is useful\n\t\t * if you need a label that looks different from the one provided by\n\t\t * this component\n\t\t */\n\t\tlabelOutside: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * The placeholder of the input. This defaults as the string that's\n\t\t * passed into the label prop. In order to remove the placeholder,\n\t\t * pass in an empty string.\n\t\t */\n\t\tplaceholder: {\n\t\t\ttype: String,\n\t\t\tdefault: undefined,\n\t\t},\n\n\t\t/**\n\t\t * Toggles the success state of the component. Adds a checkmark icon.\n\t\t * this cannot be used together with canClear.\n\t\t */\n\t\tsuccess: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Toggles the error state of the component. Adds an error icon.\n\t\t * this cannot be used together with canClear.\n\t\t */\n\t\terror: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Additional helper text message\n\t\t *\n\t\t * This will be displayed beneath the input field. In case the field is\n\t\t * also marked as having an error, the text will be displayed in red.\n\t\t */\n\t\thelperText: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * Disable the input field\n\t\t */\n\t\tdisabled: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * Class to add to the input field.\n\t\t * Necessary to use NcInputField in the NcActionInput component.\n\t\t */\n\t\tinputClass: {\n\t\t\ttype: [Object, String],\n\t\t\tdefault: '',\n\t\t},\n\n\t\t/**\n\t\t * The resize CSS property sets whether an element is resizable, and if\n\t\t * so, in which directions.\n\t\t */\n\t\tresize: {\n\t\t\ttype: String,\n\t\t\tdefault: 'both',\n\t\t\tvalidator: (value) => ['both', 'vertical', 'horizontal', 'none'].includes(value),\n\t\t},\n\t},\n\n\temits: [\n\t\t/**\n\t\t * Removed in v9 - use `update:modelValue` (`v-model`) instead\n\t\t * @deprecated\n\t\t */\n\t\t'update:value',\n\t\t'update:modelValue',\n\t\t/** Same as update:modelValue for Vue 2 compatibility */\n\t\t'update:model-value',\n\t],\n\n\tsetup() {\n\t\tconst model = useModelMigration('value', 'update:value', true)\n\t\treturn {\n\t\t\tmodel,\n\t\t}\n\t},\n\n\tcomputed: {\n\t\tcomputedId() {\n\t\t\treturn this.$attrs.id && this.$attrs.id !== '' ? this.$attrs.id : this.inputName\n\t\t},\n\n\t\tinputName() {\n\t\t\treturn 'input' + GenRandomId()\n\t\t},\n\n\t\thasPlaceholder() {\n\t\t\treturn this.placeholder !== '' && this.placeholder !== undefined\n\t\t},\n\n\t\tcomputedPlaceholder() {\n\t\t\treturn this.hasPlaceholder ? this.placeholder : this.label\n\t\t},\n\n\t\tisValidLabel() {\n\t\t\tconst isValidLabel = this.label || this.labelOutside\n\t\t\tif (!isValidLabel) {\n\t\t\t\tconsole.warn('You need to add a label to the NcInputField component. Either use the prop label or use an external one, as per the example in the documentation.')\n\t\t\t}\n\t\t\treturn isValidLabel\n\t\t},\n\n\t\tariaDescribedby() {\n\t\t\tconst ariaDescribedby = []\n\t\t\tif (this.helperText.length > 0) {\n\t\t\t\tariaDescribedby.push(`${this.inputName}-helper-text`)\n\t\t\t}\n\t\t\tif (this.$attrs['aria-describedby']) {\n\t\t\t\tariaDescribedby.push(this.$attrs['aria-describedby'])\n\t\t\t}\n\t\t\treturn ariaDescribedby.join(' ') || null\n\t\t},\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Focus the input element\n\t\t *\n\t\t * @public\n\t\t */\n\t\tfocus() {\n\t\t\tthis.$refs.input.focus()\n\t\t},\n\n\t\t/**\n\t\t * Select all the text in the input\n\t\t *\n\t\t * @public\n\t\t */\n\t\tselect() {\n\t\t\tthis.$refs.input.select()\n\t\t},\n\n\t\thandleInput(event) {\n\t\t\tthis.model = event.target.value\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n\n.textarea {\n\tposition: relative;\n\twidth: 100%;\n\tborder-radius: var(--border-radius-large);\n\tmargin-block-start: 6px; // for the label in active state\n\tresize: vertical;\n\n\t&__main-wrapper {\n\t\tposition: relative;\n\t}\n\n\t&--disabled {\n\t\topacity: 0.7;\n\t\tfilter: saturate(0.7);\n\t}\n\n\t&__input {\n\t\tmargin: 0;\n\t\tpadding-inline: 10px 6px; // align with label 8px margin label + 4px padding label - 2px border input\n\t\twidth: 100%;\n\t\theight: calc(var(--default-clickable-area) * 2);\n\t\tfont-size: var(--default-font-size);\n\t\ttext-overflow: ellipsis;\n\n\t\tbackground-color: var(--color-main-background);\n\t\tcolor: var(--color-main-text);\n\t\tborder: var(--border-width-input, 2px) solid var(--color-border-maxcontrast);\n\t\tborder-radius: var(--border-radius-large);\n\n\t\tcursor: pointer;\n\n\t\t&:active:not([disabled]),\n\t\t&:hover:not([disabled]),\n\t\t&:focus:not([disabled]) {\n\t\t\tborder-width: var(--border-width-input-focused, 2px);\n\t\t\tborder-color: var(--color-main-text);\n\t\t\tbox-shadow: 0 0 0 2px var(--color-main-background) !important;\n\t\t}\n\n\t\t// Hide placeholder while not focussed -> show label instead (only if internal label is used)\n\t\t&:not(:focus,&--label-outside)::placeholder {\n\t\t\topacity: 0;\n\t\t}\n\n\t\t&:focus {\n\t\t\tcursor: text;\n\t\t}\n\n\t\t&:disabled {\n\t\t\tcursor: default;\n\t\t}\n\n\t\t&:focus-visible {\n\t\t\tbox-shadow: unset !important; // Override server rules\n\t\t}\n\n\t\t&--success {\n\t\t\tborder-color: var(--color-success) !important; //Override hover border color\n\t\t\t&:focus-visible {\n\t\t\t\tbox-shadow: rgb(248, 250, 252) 0px 0px 0px 2px, var(--color-primary-element) 0px 0px 0px 4px, rgba(0, 0, 0, 0.05) 0px 1px 2px 0px\n\t\t\t}\n\t\t}\n\n\t\t&--error {\n\t\t\tborder-color: var(--color-error) !important; //Override hover border color\n\t\t\t&:focus-visible {\n\t\t\t\tbox-shadow: rgb(248, 250, 252) 0px 0px 0px 2px, var(--color-primary-element) 0px 0px 0px 4px, rgba(0, 0, 0, 0.05) 0px 1px 2px 0px\n\t\t\t}\n\t\t}\n\t}\n\n\t&__label {\n\t\tposition: absolute;\n\t\tmargin-inline: 12px 0;\n\t\tmax-width: fit-content;\n\t\tinset-block-start: 11px;\n\t\tinset-inline: 0;\n\t\t// Fix color so that users do not think the input already has content\n\t\tcolor: var(--color-text-maxcontrast);\n\t\t// only one line labels are allowed\n\t\twhite-space: nowrap;\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\t// forward events to input\n\t\tpointer-events: none;\n\t\t// Position transition\n\t\ttransition: height var(--animation-quick), inset-block-start var(--animation-quick), font-size var(--animation-quick), color var(--animation-quick), background-color var(--animation-quick) var(--animation-slow);\n\t}\n\n\t&__input:focus + &__label,\n\t&__input:not(:placeholder-shown) + &__label {\n\t\tinset-block-start: -10px;\n\t\tline-height: 1.5; // minimum allowed line height for accessibility\n\t\tfont-size: 13px; // minimum allowed font size for accessibility\n\t\tfont-weight: 500;\n\t\tcolor: var(--color-main-text);\n\t\tbackground-color: var(--color-main-background);\n\t\tpadding-inline: 4px;\n\t\tmargin-inline-start: 8px;\n\n\t\ttransition: height var(--animation-quick), inset-block-start var(--animation-quick), font-size var(--animation-quick), color var(--animation-quick);\n\t}\n\n\t&__helper-text-message {\n\t\tpadding-block: 4px;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\n\t\t&__icon {\n\t\t\tmargin-inline-end: 8px;\n\t\t}\n\n\t\t&--error {\n\t\t\tcolor: var(--color-error-text);\n\t\t}\n\n\t\t&--success {\n\t\t\tcolor: var(--color-success-text);\n\t\t}\n\t}\n}\n</style>\n"],"names":[],"mappings":"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"}
|