@nextcloud/vue 8.35.0 → 8.35.2
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 +26 -2
- package/dist/Components/NcActionButton.cjs +1 -1
- package/dist/Components/NcActionButton.mjs +1 -1
- package/dist/Components/NcActionButtonGroup.cjs +1 -1
- package/dist/Components/NcActionButtonGroup.mjs +1 -1
- package/dist/Components/NcActionInput.cjs +1 -1
- package/dist/Components/NcActionInput.mjs +1 -1
- package/dist/Components/NcActionTextEditable.cjs +1 -1
- package/dist/Components/NcActionTextEditable.mjs +1 -1
- package/dist/Components/NcActions.cjs +1 -1
- package/dist/Components/NcActions.mjs +1 -1
- package/dist/Components/NcAppContent.cjs +1 -1
- package/dist/Components/NcAppContent.mjs +1 -1
- package/dist/Components/NcAppNavigation.cjs +1 -1
- package/dist/Components/NcAppNavigation.mjs +1 -1
- package/dist/Components/NcAppNavigationCaption.cjs +1 -1
- package/dist/Components/NcAppNavigationCaption.mjs +1 -1
- package/dist/Components/NcAppNavigationItem.cjs +1 -1
- package/dist/Components/NcAppNavigationItem.mjs +1 -1
- package/dist/Components/NcAppNavigationNewItem.cjs +1 -1
- package/dist/Components/NcAppNavigationNewItem.mjs +1 -1
- package/dist/Components/NcAppNavigationSearch.cjs +1 -1
- package/dist/Components/NcAppNavigationSearch.mjs +1 -1
- package/dist/Components/NcAppNavigationSettings.cjs +1 -1
- package/dist/Components/NcAppNavigationSettings.mjs +1 -1
- package/dist/Components/NcAppNavigationToggle.cjs +1 -1
- package/dist/Components/NcAppNavigationToggle.mjs +1 -1
- package/dist/Components/NcAppSettingsDialog.cjs +1 -1
- package/dist/Components/NcAppSettingsDialog.mjs +1 -1
- package/dist/Components/NcAppSettingsSection.cjs +1 -1
- package/dist/Components/NcAppSettingsSection.mjs +1 -1
- package/dist/Components/NcAppSettingsSectionShortcuts.cjs +1 -1
- package/dist/Components/NcAppSettingsSectionShortcuts.mjs +1 -1
- package/dist/Components/NcAppSettingsShortcutsSection.cjs +1 -1
- package/dist/Components/NcAppSettingsShortcutsSection.mjs +1 -1
- package/dist/Components/NcAppSidebar.cjs +1 -1
- package/dist/Components/NcAppSidebar.mjs +1 -1
- package/dist/Components/NcAssistantButton.cjs +1 -1
- package/dist/Components/NcAssistantButton.mjs +1 -1
- package/dist/Components/NcAssistantIcon.cjs +1 -1
- package/dist/Components/NcAssistantIcon.mjs +1 -1
- package/dist/Components/NcAvatar.cjs +1 -1
- package/dist/Components/NcAvatar.mjs +1 -1
- package/dist/Components/NcBreadcrumb.cjs +1 -1
- package/dist/Components/NcBreadcrumb.mjs +1 -1
- package/dist/Components/NcBreadcrumbs.cjs +1 -1
- package/dist/Components/NcBreadcrumbs.mjs +1 -1
- package/dist/Components/NcCheckboxRadioSwitch.cjs +1 -1
- package/dist/Components/NcCheckboxRadioSwitch.mjs +1 -1
- package/dist/Components/NcChip.cjs +4 -4
- package/dist/Components/NcChip.mjs +4 -4
- 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/NcDashboardWidget.cjs +1 -1
- package/dist/Components/NcDashboardWidget.mjs +1 -1
- package/dist/Components/NcDashboardWidgetItem.cjs +1 -1
- package/dist/Components/NcDashboardWidgetItem.mjs +1 -1
- package/dist/Components/NcDateTimePicker.cjs +5 -5
- package/dist/Components/NcDateTimePicker.mjs +5 -5
- package/dist/Components/NcDateTimePickerNative.cjs +1 -1
- package/dist/Components/NcDateTimePickerNative.mjs +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/NcEmojiPicker.cjs +1 -1
- package/dist/Components/NcEmojiPicker.mjs +1 -1
- package/dist/Components/NcFormBox.cjs +1 -1
- package/dist/Components/NcFormBox.mjs +1 -1
- package/dist/Components/NcFormBoxButton.cjs +1 -1
- package/dist/Components/NcFormBoxButton.mjs +1 -1
- package/dist/Components/NcFormBoxCopyButton.cjs +1 -1
- package/dist/Components/NcFormBoxCopyButton.mjs +1 -1
- package/dist/Components/NcFormBoxSwitch.cjs +1 -1
- package/dist/Components/NcFormBoxSwitch.mjs +1 -1
- package/dist/Components/NcHotkey.cjs +1 -1
- package/dist/Components/NcHotkey.mjs +1 -1
- package/dist/Components/NcHotkeyList.cjs +1 -1
- package/dist/Components/NcHotkeyList.mjs +1 -1
- package/dist/Components/NcKbd.cjs +1 -1
- package/dist/Components/NcKbd.mjs +1 -1
- package/dist/Components/NcListItem.cjs +1 -1
- package/dist/Components/NcListItem.mjs +1 -1
- package/dist/Components/NcListItemIcon.cjs +1 -1
- package/dist/Components/NcListItemIcon.mjs +1 -1
- package/dist/Components/NcModal.cjs +7 -7
- package/dist/Components/NcModal.cjs.map +1 -1
- package/dist/Components/NcModal.mjs +7 -7
- package/dist/Components/NcModal.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/NcRadioGroup.cjs +1 -1
- package/dist/Components/NcRadioGroup.mjs +1 -1
- package/dist/Components/NcRadioGroupButton.cjs +1 -1
- package/dist/Components/NcRadioGroupButton.mjs +1 -1
- package/dist/Components/NcRelatedResourcesPanel.cjs +1 -1
- package/dist/Components/NcRelatedResourcesPanel.mjs +1 -1
- package/dist/Components/NcRichContenteditable.cjs +1 -1
- package/dist/Components/NcRichContenteditable.mjs +1 -1
- package/dist/Components/NcRichText.cjs +2 -2
- package/dist/Components/NcRichText.mjs +3 -3
- package/dist/Components/NcSelect.cjs +1 -1
- package/dist/Components/NcSelect.mjs +1 -1
- package/dist/Components/NcSelectTags.cjs +1 -1
- package/dist/Components/NcSelectTags.mjs +1 -1
- package/dist/Components/NcSelectUsers.cjs +1 -1
- package/dist/Components/NcSelectUsers.mjs +1 -1
- package/dist/Components/NcSettingsInputText.cjs +1 -1
- package/dist/Components/NcSettingsInputText.mjs +1 -1
- package/dist/Components/NcSettingsSection.cjs +1 -1
- package/dist/Components/NcSettingsSection.mjs +1 -1
- package/dist/Components/NcSettingsSelectGroup.cjs +1 -1
- package/dist/Components/NcSettingsSelectGroup.mjs +1 -1
- package/dist/Components/NcTextField.cjs +1 -1
- package/dist/Components/NcTextField.mjs +1 -1
- package/dist/Components/NcThemeProvider.cjs +1 -1
- package/dist/Components/NcThemeProvider.mjs +1 -1
- package/dist/Components/NcTimezonePicker.cjs +1 -1
- package/dist/Components/NcTimezonePicker.mjs +1 -1
- package/dist/Components/NcUserBubble.cjs +1 -1
- package/dist/Components/NcUserBubble.mjs +1 -1
- package/dist/Components/NcUserStatusIcon.cjs +1 -1
- package/dist/Components/NcUserStatusIcon.mjs +1 -1
- package/dist/Composables/useFormatDateTime.cjs +1 -1
- package/dist/Composables/useFormatDateTime.mjs +1 -1
- package/dist/Composables/useIsDarkTheme.cjs +1 -1
- package/dist/Composables/useIsDarkTheme.mjs +1 -1
- package/dist/Functions/reference.cjs +1 -1
- package/dist/Functions/reference.mjs +1 -1
- package/dist/Functions/usernameToColor.cjs +1 -1
- package/dist/Functions/usernameToColor.mjs +1 -1
- package/dist/assets/{NcActionInput-BvPYSqDP.css → NcActionInput-B-c5cOfM.css} +65 -65
- package/dist/assets/{NcCheckboxRadioSwitch-BcHKt-lf.css → NcCheckboxRadioSwitch-BACLOhMO.css} +13 -12
- package/dist/assets/{NcDateTimePicker-DzPH7x0i.css → NcDateTimePicker-DyG-TczL.css} +8 -8
- package/dist/assets/{NcFormBoxSwitch-BmyNQCbA.css → NcFormBoxSwitch-DScgbxtv.css} +2 -8
- package/dist/assets/NcIconToggleSwitch-Dr-tC5Ic.css +30 -0
- package/dist/assets/{NcModal-4ZPVUmG2.css → NcModal-CfHpabcF.css} +65 -65
- package/dist/chunks/{NcActionButton-BS9Mv3XD.cjs → NcActionButton-jtEEPXw2.cjs} +2 -2
- package/dist/chunks/{NcActionButton-BS9Mv3XD.cjs.map → NcActionButton-jtEEPXw2.cjs.map} +1 -1
- package/dist/chunks/{NcActionButton-CECxOkhK.mjs → NcActionButton-w5F9kCHW.mjs} +2 -2
- package/dist/chunks/{NcActionButton-CECxOkhK.mjs.map → NcActionButton-w5F9kCHW.mjs.map} +1 -1
- package/dist/chunks/{NcActionButtonGroup-D_ldp8Lw.mjs → NcActionButtonGroup-Dl_0bIqn.mjs} +2 -2
- package/dist/chunks/{NcActionButtonGroup-D_ldp8Lw.mjs.map → NcActionButtonGroup-Dl_0bIqn.mjs.map} +1 -1
- package/dist/chunks/{NcActionButtonGroup-CbKrDPie.cjs → NcActionButtonGroup-E-6SoAHx.cjs} +2 -2
- package/dist/chunks/{NcActionButtonGroup-CbKrDPie.cjs.map → NcActionButtonGroup-E-6SoAHx.cjs.map} +1 -1
- package/dist/chunks/{NcActionInput-Cd7bhV5-.cjs → NcActionInput-CvTePip6.cjs} +7 -7
- package/dist/chunks/NcActionInput-CvTePip6.cjs.map +1 -0
- package/dist/chunks/{NcActionInput-CB9jcc0_.mjs → NcActionInput-JVtIXzyo.mjs} +7 -7
- package/dist/chunks/NcActionInput-JVtIXzyo.mjs.map +1 -0
- package/dist/chunks/{NcActionTextEditable-D-peY-RA.cjs → NcActionTextEditable-CDkdl0jj.cjs} +2 -2
- package/dist/chunks/{NcActionTextEditable-D-peY-RA.cjs.map → NcActionTextEditable-CDkdl0jj.cjs.map} +1 -1
- package/dist/chunks/{NcActionTextEditable-CNEW3Fav.mjs → NcActionTextEditable-CfhlP5-E.mjs} +2 -2
- package/dist/chunks/{NcActionTextEditable-CNEW3Fav.mjs.map → NcActionTextEditable-CfhlP5-E.mjs.map} +1 -1
- package/dist/chunks/{NcActions-C-CwY6XQ.mjs → NcActions-DXfOYf3w.mjs} +3 -3
- package/dist/chunks/{NcActions-C-CwY6XQ.mjs.map → NcActions-DXfOYf3w.mjs.map} +1 -1
- package/dist/chunks/{NcActions-S-0Ec5lH.cjs → NcActions-DhEGso92.cjs} +3 -3
- package/dist/chunks/{NcActions-S-0Ec5lH.cjs.map → NcActions-DhEGso92.cjs.map} +1 -1
- package/dist/chunks/{NcAppContent-BvgsOP0K.mjs → NcAppContent-D-MzdCDi.mjs} +2 -2
- package/dist/chunks/{NcAppContent-BvgsOP0K.mjs.map → NcAppContent-D-MzdCDi.mjs.map} +1 -1
- package/dist/chunks/{NcAppContent-CMntmSFj.cjs → NcAppContent-cKOp687H.cjs} +2 -2
- package/dist/chunks/{NcAppContent-CMntmSFj.cjs.map → NcAppContent-cKOp687H.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigation-DgekTp_z.mjs → NcAppNavigation-BGc7ks7G.mjs} +2 -2
- package/dist/chunks/{NcAppNavigation-DgekTp_z.mjs.map → NcAppNavigation-BGc7ks7G.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigation-BcFTYsgM.cjs → NcAppNavigation-Ce5BoTSG.cjs} +2 -2
- package/dist/chunks/{NcAppNavigation-BcFTYsgM.cjs.map → NcAppNavigation-Ce5BoTSG.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationCaption-1-KiRt-N.cjs → NcAppNavigationCaption-C8SUVqGR.cjs} +2 -2
- package/dist/chunks/{NcAppNavigationCaption-1-KiRt-N.cjs.map → NcAppNavigationCaption-C8SUVqGR.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationCaption-D7mH8K7B.mjs → NcAppNavigationCaption-oRJEZSTQ.mjs} +2 -2
- package/dist/chunks/{NcAppNavigationCaption-D7mH8K7B.mjs.map → NcAppNavigationCaption-oRJEZSTQ.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationItem-CkAgsU6p.cjs → NcAppNavigationItem-DyMBscJd.cjs} +5 -5
- package/dist/chunks/{NcAppNavigationItem-CkAgsU6p.cjs.map → NcAppNavigationItem-DyMBscJd.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationItem-B6YKr1n2.mjs → NcAppNavigationItem-zOxlduFj.mjs} +5 -5
- package/dist/chunks/{NcAppNavigationItem-B6YKr1n2.mjs.map → NcAppNavigationItem-zOxlduFj.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationNewItem-D7dxbu-1.cjs → NcAppNavigationNewItem-BSsLh8nj.cjs} +2 -2
- package/dist/chunks/{NcAppNavigationNewItem-D7dxbu-1.cjs.map → NcAppNavigationNewItem-BSsLh8nj.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationNewItem-C96AER1b.mjs → NcAppNavigationNewItem-D7Pn6vob.mjs} +2 -2
- package/dist/chunks/{NcAppNavigationNewItem-C96AER1b.mjs.map → NcAppNavigationNewItem-D7Pn6vob.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationSearch-CuqE2exX.mjs → NcAppNavigationSearch-BgivVWlR.mjs} +2 -2
- package/dist/chunks/{NcAppNavigationSearch-CuqE2exX.mjs.map → NcAppNavigationSearch-BgivVWlR.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationSearch-C9dLgU2t.cjs → NcAppNavigationSearch-DC2ybadu.cjs} +2 -2
- package/dist/chunks/{NcAppNavigationSearch-C9dLgU2t.cjs.map → NcAppNavigationSearch-DC2ybadu.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationSettings-Ba8OcJxl.mjs → NcAppNavigationSettings-D5-V4TIs.mjs} +3 -3
- package/dist/chunks/{NcAppNavigationSettings-Ba8OcJxl.mjs.map → NcAppNavigationSettings-D5-V4TIs.mjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationSettings-C7d5dhkD.cjs → NcAppNavigationSettings-J1GIZ9QS.cjs} +3 -3
- package/dist/chunks/{NcAppNavigationSettings-C7d5dhkD.cjs.map → NcAppNavigationSettings-J1GIZ9QS.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationToggle-Ck-d5mHe.cjs → NcAppNavigationToggle-C0Kc4R9v.cjs} +2 -2
- package/dist/chunks/{NcAppNavigationToggle-Ck-d5mHe.cjs.map → NcAppNavigationToggle-C0Kc4R9v.cjs.map} +1 -1
- package/dist/chunks/{NcAppNavigationToggle-B0N05AxP.mjs → NcAppNavigationToggle-phm-tyID.mjs} +2 -2
- package/dist/chunks/{NcAppNavigationToggle-B0N05AxP.mjs.map → NcAppNavigationToggle-phm-tyID.mjs.map} +1 -1
- package/dist/chunks/{NcAppSettingsDialog-fOCnfyD-.cjs → NcAppSettingsDialog-BSxqwcZ4.cjs} +5 -5
- package/dist/chunks/{NcAppSettingsDialog-fOCnfyD-.cjs.map → NcAppSettingsDialog-BSxqwcZ4.cjs.map} +1 -1
- package/dist/chunks/{NcAppSettingsDialog-PRGGDKCy.mjs → NcAppSettingsDialog-CjnPlzCs.mjs} +5 -5
- package/dist/chunks/{NcAppSettingsDialog-PRGGDKCy.mjs.map → NcAppSettingsDialog-CjnPlzCs.mjs.map} +1 -1
- package/dist/chunks/{NcAppSettingsSection-Cq1VIzMR.mjs → NcAppSettingsSection-BjQllLEA.mjs} +2 -2
- package/dist/chunks/{NcAppSettingsSection-Cq1VIzMR.mjs.map → NcAppSettingsSection-BjQllLEA.mjs.map} +1 -1
- package/dist/chunks/{NcAppSettingsSection-Q5PB51ht.cjs → NcAppSettingsSection-CDLQ-AjK.cjs} +2 -2
- package/dist/chunks/{NcAppSettingsSection-Q5PB51ht.cjs.map → NcAppSettingsSection-CDLQ-AjK.cjs.map} +1 -1
- package/dist/chunks/{NcAppSettingsShortcutsSection-DI5YBdYf.cjs → NcAppSettingsShortcutsSection-B0WBkOo9.cjs} +4 -4
- package/dist/chunks/NcAppSettingsShortcutsSection-B0WBkOo9.cjs.map +1 -0
- package/dist/chunks/{NcAppSettingsShortcutsSection-BGMDhIXI.mjs → NcAppSettingsShortcutsSection-DzjowBeE.mjs} +4 -4
- package/dist/chunks/NcAppSettingsShortcutsSection-DzjowBeE.mjs.map +1 -0
- package/dist/chunks/{NcAppSidebar-BA8rmpOk.cjs → NcAppSidebar-BDz7d7NJ.cjs} +5 -5
- package/dist/chunks/{NcAppSidebar-BA8rmpOk.cjs.map → NcAppSidebar-BDz7d7NJ.cjs.map} +1 -1
- package/dist/chunks/{NcAppSidebar-1Q4AznUI.mjs → NcAppSidebar-CdSeLJD4.mjs} +5 -5
- package/dist/chunks/{NcAppSidebar-1Q4AznUI.mjs.map → NcAppSidebar-CdSeLJD4.mjs.map} +1 -1
- package/dist/chunks/{NcAssistantButton-BPXX2mz6.mjs → NcAssistantButton-CjP2aanh.mjs} +3 -3
- package/dist/chunks/{NcAssistantButton-BPXX2mz6.mjs.map → NcAssistantButton-CjP2aanh.mjs.map} +1 -1
- package/dist/chunks/{NcAssistantButton-CAJQBxgk.cjs → NcAssistantButton-DQSwGT_7.cjs} +3 -3
- package/dist/chunks/{NcAssistantButton-CAJQBxgk.cjs.map → NcAssistantButton-DQSwGT_7.cjs.map} +1 -1
- package/dist/chunks/{NcAssistantIcon-jHDGZ_Bd.cjs → NcAssistantIcon-Dn_unLGj.cjs} +2 -2
- package/dist/chunks/{NcAssistantIcon-jHDGZ_Bd.cjs.map → NcAssistantIcon-Dn_unLGj.cjs.map} +1 -1
- package/dist/chunks/{NcAssistantIcon-CKWZRzXg.mjs → NcAssistantIcon-wlxNsdd7.mjs} +2 -2
- package/dist/chunks/{NcAssistantIcon-CKWZRzXg.mjs.map → NcAssistantIcon-wlxNsdd7.mjs.map} +1 -1
- package/dist/chunks/{NcAvatar-4h0wo9uv.mjs → NcAvatar-Cn98JTqK.mjs} +5 -5
- package/dist/chunks/{NcAvatar-4h0wo9uv.mjs.map → NcAvatar-Cn98JTqK.mjs.map} +1 -1
- package/dist/chunks/{NcAvatar-BrDByW-X.cjs → NcAvatar-DTYINOTI.cjs} +5 -5
- package/dist/chunks/{NcAvatar-BrDByW-X.cjs.map → NcAvatar-DTYINOTI.cjs.map} +1 -1
- package/dist/chunks/{NcBreadcrumb-BUsCwbnF.cjs → NcBreadcrumb-CkmzyLa_.cjs} +2 -2
- package/dist/chunks/{NcBreadcrumb-BUsCwbnF.cjs.map → NcBreadcrumb-CkmzyLa_.cjs.map} +1 -1
- package/dist/chunks/{NcBreadcrumb-CcKJsew_.mjs → NcBreadcrumb-DB0OuwsV.mjs} +2 -2
- package/dist/chunks/{NcBreadcrumb-CcKJsew_.mjs.map → NcBreadcrumb-DB0OuwsV.mjs.map} +1 -1
- package/dist/chunks/{NcBreadcrumbs-bDlnNcz1.mjs → NcBreadcrumbs-BizyuyGI.mjs} +4 -4
- package/dist/chunks/{NcBreadcrumbs-bDlnNcz1.mjs.map → NcBreadcrumbs-BizyuyGI.mjs.map} +1 -1
- package/dist/chunks/{NcBreadcrumbs-W9wcvU4n.cjs → NcBreadcrumbs-C4T9-I6M.cjs} +4 -4
- package/dist/chunks/{NcBreadcrumbs-W9wcvU4n.cjs.map → NcBreadcrumbs-C4T9-I6M.cjs.map} +1 -1
- package/dist/chunks/{NcCheckboxRadioSwitch-CX3HXCEk.mjs → NcCheckboxRadioSwitch-CgbTELjq.mjs} +37 -104
- package/dist/chunks/NcCheckboxRadioSwitch-CgbTELjq.mjs.map +1 -0
- package/dist/chunks/{NcCheckboxRadioSwitch-CG2BbMsv.cjs → NcCheckboxRadioSwitch-USANpRLI.cjs} +37 -104
- package/dist/chunks/NcCheckboxRadioSwitch-USANpRLI.cjs.map +1 -0
- package/dist/chunks/{NcCollectionList-DSk0m1Ap.cjs → NcCollectionList-BjYItjGi.cjs} +6 -6
- package/dist/chunks/{NcCollectionList-DSk0m1Ap.cjs.map → NcCollectionList-BjYItjGi.cjs.map} +1 -1
- package/dist/chunks/{NcCollectionList-CejmntlL.mjs → NcCollectionList-C7QmpJW9.mjs} +6 -6
- package/dist/chunks/{NcCollectionList-CejmntlL.mjs.map → NcCollectionList-C7QmpJW9.mjs.map} +1 -1
- package/dist/chunks/{NcColorPicker-BPVlMiBg.cjs → NcColorPicker-Chsy5lX_.cjs} +6 -6
- package/dist/chunks/{NcColorPicker-BPVlMiBg.cjs.map → NcColorPicker-Chsy5lX_.cjs.map} +1 -1
- package/dist/chunks/{NcColorPicker-BERjJHgc.mjs → NcColorPicker-DnWT8i3g.mjs} +6 -6
- package/dist/chunks/{NcColorPicker-BERjJHgc.mjs.map → NcColorPicker-DnWT8i3g.mjs.map} +1 -1
- package/dist/chunks/{NcContent-DWLtsXHf.cjs → NcContent-B0MLEwwX.cjs} +2 -2
- package/dist/chunks/{NcContent-DWLtsXHf.cjs.map → NcContent-B0MLEwwX.cjs.map} +1 -1
- package/dist/chunks/{NcContent-yW5m-Mj5.mjs → NcContent-RSHRX9Ei.mjs} +2 -2
- package/dist/chunks/{NcContent-yW5m-Mj5.mjs.map → NcContent-RSHRX9Ei.mjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidget-Bk6i__T-.mjs → NcDashboardWidget-By1MRGQM.mjs} +4 -4
- package/dist/chunks/{NcDashboardWidget-Bk6i__T-.mjs.map → NcDashboardWidget-By1MRGQM.mjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidget-Dc0fUaGv.cjs → NcDashboardWidget-tPBonsAz.cjs} +4 -4
- package/dist/chunks/{NcDashboardWidget-Dc0fUaGv.cjs.map → NcDashboardWidget-tPBonsAz.cjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidgetItem--NyYqf1-.mjs → NcDashboardWidgetItem-D2CwvHeu.mjs} +4 -4
- package/dist/chunks/{NcDashboardWidgetItem--NyYqf1-.mjs.map → NcDashboardWidgetItem-D2CwvHeu.mjs.map} +1 -1
- package/dist/chunks/{NcDashboardWidgetItem-DiSoDid-.cjs → NcDashboardWidgetItem-Zb-33B99.cjs} +4 -4
- package/dist/chunks/{NcDashboardWidgetItem-DiSoDid-.cjs.map → NcDashboardWidgetItem-Zb-33B99.cjs.map} +1 -1
- package/dist/chunks/{NcDialog-WN4eYniZ.cjs → NcDialog-ChYi3mdd.cjs} +2 -2
- package/dist/chunks/{NcDialog-WN4eYniZ.cjs.map → NcDialog-ChYi3mdd.cjs.map} +1 -1
- package/dist/chunks/{NcDialog-8ipQ69_t.mjs → NcDialog-DDWiv6ap.mjs} +2 -2
- package/dist/chunks/{NcDialog-8ipQ69_t.mjs.map → NcDialog-DDWiv6ap.mjs.map} +1 -1
- package/dist/chunks/{NcDialogButton-BFV6qd7F.cjs → NcDialogButton-DljI3tNu.cjs} +2 -2
- package/dist/chunks/{NcDialogButton-BFV6qd7F.cjs.map → NcDialogButton-DljI3tNu.cjs.map} +1 -1
- package/dist/chunks/{NcDialogButton-CSC8PAz-.mjs → NcDialogButton-lR5aJG_-.mjs} +2 -2
- package/dist/chunks/{NcDialogButton-CSC8PAz-.mjs.map → NcDialogButton-lR5aJG_-.mjs.map} +1 -1
- package/dist/chunks/{NcEmojiPicker-BENbptkx.cjs → NcEmojiPicker-C0AfqJC9.cjs} +6 -6
- package/dist/chunks/{NcEmojiPicker-BENbptkx.cjs.map → NcEmojiPicker-C0AfqJC9.cjs.map} +1 -1
- package/dist/chunks/{NcEmojiPicker-DlizXqla.mjs → NcEmojiPicker-DclGvRU_.mjs} +6 -6
- package/dist/chunks/{NcEmojiPicker-DlizXqla.mjs.map → NcEmojiPicker-DclGvRU_.mjs.map} +1 -1
- package/dist/chunks/{NcFormBox-DL435pbV.mjs → NcFormBox-C4wu4RJ_.mjs} +2 -2
- package/dist/chunks/{NcFormBox-DL435pbV.mjs.map → NcFormBox-C4wu4RJ_.mjs.map} +1 -1
- package/dist/chunks/{NcFormBox-_JqkU_xn.cjs → NcFormBox-DjrN-K4Q.cjs} +2 -2
- package/dist/chunks/{NcFormBox-_JqkU_xn.cjs.map → NcFormBox-DjrN-K4Q.cjs.map} +1 -1
- package/dist/chunks/{NcFormBoxButton-DR_OMvmB.mjs → NcFormBoxButton-4xiKHRJH.mjs} +3 -3
- package/dist/chunks/{NcFormBoxButton-DR_OMvmB.mjs.map → NcFormBoxButton-4xiKHRJH.mjs.map} +1 -1
- package/dist/chunks/{NcFormBoxButton-B4STyrn7.cjs → NcFormBoxButton-WatYqw6i.cjs} +3 -3
- package/dist/chunks/{NcFormBoxButton-B4STyrn7.cjs.map → NcFormBoxButton-WatYqw6i.cjs.map} +1 -1
- package/dist/chunks/{NcFormBoxCopyButton-BQt4cqDo.mjs → NcFormBoxCopyButton-AeYq9iKM.mjs} +3 -3
- package/dist/chunks/{NcFormBoxCopyButton-BQt4cqDo.mjs.map → NcFormBoxCopyButton-AeYq9iKM.mjs.map} +1 -1
- package/dist/chunks/{NcFormBoxCopyButton-CthOiHuc.cjs → NcFormBoxCopyButton-VM720MPU.cjs} +3 -3
- package/dist/chunks/{NcFormBoxCopyButton-CthOiHuc.cjs.map → NcFormBoxCopyButton-VM720MPU.cjs.map} +1 -1
- package/dist/chunks/{NcFormBoxItem-BfXaRfkc.cjs → NcFormBoxItem-CK0Zakr1.cjs} +2 -2
- package/dist/chunks/{NcFormBoxItem-BfXaRfkc.cjs.map → NcFormBoxItem-CK0Zakr1.cjs.map} +1 -1
- package/dist/chunks/{NcFormBoxItem-BcNIAmpc.mjs → NcFormBoxItem-DJZrmlTP.mjs} +2 -2
- package/dist/chunks/{NcFormBoxItem-BcNIAmpc.mjs.map → NcFormBoxItem-DJZrmlTP.mjs.map} +1 -1
- package/dist/chunks/{NcFormBoxSwitch-BUBD5jli.cjs → NcFormBoxSwitch-DGAjBKdo.cjs} +9 -12
- package/dist/chunks/NcFormBoxSwitch-DGAjBKdo.cjs.map +1 -0
- package/dist/chunks/{NcFormBoxSwitch-BqbGsapa.mjs → NcFormBoxSwitch-Dq5JvIem.mjs} +9 -12
- package/dist/chunks/NcFormBoxSwitch-Dq5JvIem.mjs.map +1 -0
- package/dist/chunks/{NcHotkey-CuAapY_f.cjs → NcHotkey-B9IBly2F.cjs} +2 -2
- package/dist/chunks/{NcHotkey-CuAapY_f.cjs.map → NcHotkey-B9IBly2F.cjs.map} +1 -1
- package/dist/chunks/{NcHotkey-DcpG5Pla.mjs → NcHotkey-COqzksbg.mjs} +2 -2
- package/dist/chunks/{NcHotkey-DcpG5Pla.mjs.map → NcHotkey-COqzksbg.mjs.map} +1 -1
- package/dist/chunks/{NcHotkeyList-CyJKMulK.cjs → NcHotkeyList-D5QS6zXI.cjs} +3 -3
- package/dist/chunks/{NcHotkeyList-CyJKMulK.cjs.map → NcHotkeyList-D5QS6zXI.cjs.map} +1 -1
- package/dist/chunks/{NcHotkeyList-CV_FJXF8.mjs → NcHotkeyList-D9tKXM-e.mjs} +3 -3
- package/dist/chunks/{NcHotkeyList-CV_FJXF8.mjs.map → NcHotkeyList-D9tKXM-e.mjs.map} +1 -1
- package/dist/chunks/NcIconToggleSwitch-C2VDKTSP.mjs +62 -0
- package/dist/chunks/NcIconToggleSwitch-C2VDKTSP.mjs.map +1 -0
- package/dist/chunks/NcIconToggleSwitch-Cnov67_2.cjs +61 -0
- package/dist/chunks/NcIconToggleSwitch-Cnov67_2.cjs.map +1 -0
- package/dist/chunks/{NcInputConfirmCancel-lLiyPQvo.cjs → NcInputConfirmCancel-BAM7SUH2.cjs} +2 -2
- package/dist/chunks/{NcInputConfirmCancel-lLiyPQvo.cjs.map → NcInputConfirmCancel-BAM7SUH2.cjs.map} +1 -1
- package/dist/chunks/{NcInputConfirmCancel-D7omQqvB.mjs → NcInputConfirmCancel-CrZiDaEw.mjs} +2 -2
- package/dist/chunks/{NcInputConfirmCancel-D7omQqvB.mjs.map → NcInputConfirmCancel-CrZiDaEw.mjs.map} +1 -1
- package/dist/chunks/{NcKbd-ChdGXvZR.mjs → NcKbd-CapL6_v1.mjs} +3 -3
- package/dist/chunks/{NcKbd-ChdGXvZR.mjs.map → NcKbd-CapL6_v1.mjs.map} +1 -1
- package/dist/chunks/{NcKbd-CyyEm6BD.cjs → NcKbd-DiOuj-R9.cjs} +3 -3
- package/dist/chunks/{NcKbd-CyyEm6BD.cjs.map → NcKbd-DiOuj-R9.cjs.map} +1 -1
- package/dist/chunks/{NcListItem-DP0kl2g5.mjs → NcListItem-BCsfLnyO.mjs} +2 -2
- package/dist/chunks/{NcListItem-DP0kl2g5.mjs.map → NcListItem-BCsfLnyO.mjs.map} +1 -1
- package/dist/chunks/{NcListItem-DB6prfmf.cjs → NcListItem-DO5dSzuL.cjs} +2 -2
- package/dist/chunks/{NcListItem-DB6prfmf.cjs.map → NcListItem-DO5dSzuL.cjs.map} +1 -1
- package/dist/chunks/{NcListItemIcon-D41xabRp.mjs → NcListItemIcon-D--9lMWR.mjs} +2 -2
- package/dist/chunks/{NcListItemIcon-D41xabRp.mjs.map → NcListItemIcon-D--9lMWR.mjs.map} +1 -1
- package/dist/chunks/{NcListItemIcon-BM5iJwye.cjs → NcListItemIcon-DShtuUOU.cjs} +2 -2
- package/dist/chunks/{NcListItemIcon-BM5iJwye.cjs.map → NcListItemIcon-DShtuUOU.cjs.map} +1 -1
- package/dist/chunks/{NcPasswordField-D2xXHnvI.mjs → NcPasswordField-Df0X4U3c.mjs} +2 -2
- package/dist/chunks/{NcPasswordField-D2xXHnvI.mjs.map → NcPasswordField-Df0X4U3c.mjs.map} +1 -1
- package/dist/chunks/{NcPasswordField-Cq8yg7NE.cjs → NcPasswordField-btocqVR7.cjs} +2 -2
- package/dist/chunks/{NcPasswordField-Cq8yg7NE.cjs.map → NcPasswordField-btocqVR7.cjs.map} +1 -1
- package/dist/chunks/{NcPopover-BgUZkmjk.cjs → NcPopover-CD8IwZd2.cjs} +4 -4
- package/dist/chunks/NcPopover-CD8IwZd2.cjs.map +1 -0
- package/dist/chunks/{NcPopover-gxcAqoEb.mjs → NcPopover-DmPH_emH.mjs} +4 -4
- package/dist/chunks/NcPopover-DmPH_emH.mjs.map +1 -0
- package/dist/chunks/{NcRadioGroup-D0rC63G8.mjs → NcRadioGroup-C2Nibs7w.mjs} +3 -3
- package/dist/chunks/{NcRadioGroup-D0rC63G8.mjs.map → NcRadioGroup-C2Nibs7w.mjs.map} +1 -1
- package/dist/chunks/{NcRadioGroup-D59En1O3.cjs → NcRadioGroup-zZIcG3FY.cjs} +3 -3
- package/dist/chunks/{NcRadioGroup-D59En1O3.cjs.map → NcRadioGroup-zZIcG3FY.cjs.map} +1 -1
- package/dist/chunks/{NcRadioGroupButton-3Pu4Iqdf.mjs → NcRadioGroupButton-Bzd7AZ5F.mjs} +3 -3
- package/dist/chunks/{NcRadioGroupButton-3Pu4Iqdf.mjs.map → NcRadioGroupButton-Bzd7AZ5F.mjs.map} +1 -1
- package/dist/chunks/{NcRadioGroupButton-DoOf7cE1.cjs → NcRadioGroupButton-C_T_e6DC.cjs} +3 -3
- package/dist/chunks/{NcRadioGroupButton-DoOf7cE1.cjs.map → NcRadioGroupButton-C_T_e6DC.cjs.map} +1 -1
- package/dist/chunks/{NcRelatedResourcesPanel-BbjG2Qvg.mjs → NcRelatedResourcesPanel-CZgZsBil.mjs} +2 -2
- package/dist/chunks/{NcRelatedResourcesPanel-BbjG2Qvg.mjs.map → NcRelatedResourcesPanel-CZgZsBil.mjs.map} +1 -1
- package/dist/chunks/{NcRelatedResourcesPanel-DUxV4_Bt.cjs → NcRelatedResourcesPanel-DDEAaN_S.cjs} +2 -2
- package/dist/chunks/{NcRelatedResourcesPanel-DUxV4_Bt.cjs.map → NcRelatedResourcesPanel-DDEAaN_S.cjs.map} +1 -1
- package/dist/chunks/{NcRichContenteditable-S7ASR6NI.mjs → NcRichContenteditable-BitJ9Dpc.mjs} +7 -7
- package/dist/chunks/{NcRichContenteditable-S7ASR6NI.mjs.map → NcRichContenteditable-BitJ9Dpc.mjs.map} +1 -1
- package/dist/chunks/{NcRichContenteditable-C_PlLt-H.cjs → NcRichContenteditable-Y5XIH11o.cjs} +7 -7
- package/dist/chunks/{NcRichContenteditable-C_PlLt-H.cjs.map → NcRichContenteditable-Y5XIH11o.cjs.map} +1 -1
- package/dist/chunks/{NcRichText-C7k_8zuH.mjs → NcRichText-BoBTuJn0.mjs} +6 -6
- package/dist/chunks/{NcRichText-C7k_8zuH.mjs.map → NcRichText-BoBTuJn0.mjs.map} +1 -1
- package/dist/chunks/{NcRichText-kd0NZSP_.cjs → NcRichText-C-Sj_7GQ.cjs} +6 -6
- package/dist/chunks/{NcRichText-kd0NZSP_.cjs.map → NcRichText-C-Sj_7GQ.cjs.map} +1 -1
- package/dist/chunks/{NcSelect-DfosTlgF.cjs → NcSelect-B04XrVzV.cjs} +3 -3
- package/dist/chunks/{NcSelect-DfosTlgF.cjs.map → NcSelect-B04XrVzV.cjs.map} +1 -1
- package/dist/chunks/{NcSelect-CkB50N9T.mjs → NcSelect-vNUKMdvr.mjs} +3 -3
- package/dist/chunks/{NcSelect-CkB50N9T.mjs.map → NcSelect-vNUKMdvr.mjs.map} +1 -1
- package/dist/chunks/{NcSelectTags-DrDrZUA6.mjs → NcSelectTags-BHfgOy9u.mjs} +3 -3
- package/dist/chunks/{NcSelectTags-DrDrZUA6.mjs.map → NcSelectTags-BHfgOy9u.mjs.map} +1 -1
- package/dist/chunks/{NcSelectTags-deek6JXy.cjs → NcSelectTags-DeVGcDZr.cjs} +3 -3
- package/dist/chunks/{NcSelectTags-deek6JXy.cjs.map → NcSelectTags-DeVGcDZr.cjs.map} +1 -1
- package/dist/chunks/{NcSelectUsers-HmMuAP19.mjs → NcSelectUsers--GvJjma1.mjs} +4 -4
- package/dist/chunks/{NcSelectUsers-HmMuAP19.mjs.map → NcSelectUsers--GvJjma1.mjs.map} +1 -1
- package/dist/chunks/{NcSelectUsers-Cu5KZCxC.cjs → NcSelectUsers-BSi-wQFH.cjs} +4 -4
- package/dist/chunks/{NcSelectUsers-Cu5KZCxC.cjs.map → NcSelectUsers-BSi-wQFH.cjs.map} +1 -1
- package/dist/chunks/{NcSettingsInputText-ynxiTO4n.cjs → NcSettingsInputText-BmZijZoF.cjs} +2 -2
- package/dist/chunks/{NcSettingsInputText-ynxiTO4n.cjs.map → NcSettingsInputText-BmZijZoF.cjs.map} +1 -1
- package/dist/chunks/{NcSettingsInputText-wFKkjw2t.mjs → NcSettingsInputText-DRgdOe4X.mjs} +2 -2
- package/dist/chunks/{NcSettingsInputText-wFKkjw2t.mjs.map → NcSettingsInputText-DRgdOe4X.mjs.map} +1 -1
- package/dist/chunks/{NcSettingsSection-ZV3KIsxm.mjs → NcSettingsSection-10O9VU1F.mjs} +2 -2
- package/dist/chunks/{NcSettingsSection-ZV3KIsxm.mjs.map → NcSettingsSection-10O9VU1F.mjs.map} +1 -1
- package/dist/chunks/{NcSettingsSection-Bvo098h3.cjs → NcSettingsSection-Ck1k_G_E.cjs} +2 -2
- package/dist/chunks/{NcSettingsSection-Bvo098h3.cjs.map → NcSettingsSection-Ck1k_G_E.cjs.map} +1 -1
- package/dist/chunks/{NcSettingsSelectGroup-DmHVvBng.cjs → NcSettingsSelectGroup-Chz3fOJq.cjs} +3 -3
- package/dist/chunks/{NcSettingsSelectGroup-DmHVvBng.cjs.map → NcSettingsSelectGroup-Chz3fOJq.cjs.map} +1 -1
- package/dist/chunks/{NcSettingsSelectGroup-CXGxufce.mjs → NcSettingsSelectGroup-Dqh2jQi_.mjs} +3 -3
- package/dist/chunks/{NcSettingsSelectGroup-CXGxufce.mjs.map → NcSettingsSelectGroup-Dqh2jQi_.mjs.map} +1 -1
- package/dist/chunks/{NcTextField-CYbpyxC1.cjs → NcTextField-DiFoJmdM.cjs} +3 -3
- package/dist/chunks/{NcTextField-CYbpyxC1.cjs.map → NcTextField-DiFoJmdM.cjs.map} +1 -1
- package/dist/chunks/{NcTextField-CijJWC3h.mjs → NcTextField-DyPJI6lW.mjs} +3 -3
- package/dist/chunks/{NcTextField-CijJWC3h.mjs.map → NcTextField-DyPJI6lW.mjs.map} +1 -1
- package/dist/chunks/{NcThemeProvider-25ResoIv.mjs → NcThemeProvider-BA_zMjAf.mjs} +2 -2
- package/dist/chunks/{NcThemeProvider-25ResoIv.mjs.map → NcThemeProvider-BA_zMjAf.mjs.map} +1 -1
- package/dist/chunks/{NcThemeProvider-BqGPTeWg.cjs → NcThemeProvider-BOKkNukO.cjs} +2 -2
- package/dist/chunks/{NcThemeProvider-BqGPTeWg.cjs.map → NcThemeProvider-BOKkNukO.cjs.map} +1 -1
- package/dist/chunks/{NcTimezonePicker-8z2Jxzq-.cjs → NcTimezonePicker-2dMBEhRN.cjs} +3 -3
- package/dist/chunks/{NcTimezonePicker-8z2Jxzq-.cjs.map → NcTimezonePicker-2dMBEhRN.cjs.map} +1 -1
- package/dist/chunks/{NcTimezonePicker-DOSucwRx.mjs → NcTimezonePicker-Cirerde6.mjs} +3 -3
- package/dist/chunks/{NcTimezonePicker-DOSucwRx.mjs.map → NcTimezonePicker-Cirerde6.mjs.map} +1 -1
- package/dist/chunks/{NcUserBubble-CSGX6IdN.mjs → NcUserBubble-DT9YWw5v.mjs} +3 -3
- package/dist/chunks/{NcUserBubble-CSGX6IdN.mjs.map → NcUserBubble-DT9YWw5v.mjs.map} +1 -1
- package/dist/chunks/{NcUserBubble-Bzng2YLf.cjs → NcUserBubble-OTn2y2Qh.cjs} +3 -3
- package/dist/chunks/{NcUserBubble-Bzng2YLf.cjs.map → NcUserBubble-OTn2y2Qh.cjs.map} +1 -1
- package/dist/chunks/{NcUserStatusIcon-Dfd_lPCI.mjs → NcUserStatusIcon-BNyLZCP1.mjs} +2 -2
- package/dist/chunks/{NcUserStatusIcon-Dfd_lPCI.mjs.map → NcUserStatusIcon-BNyLZCP1.mjs.map} +1 -1
- package/dist/chunks/{NcUserStatusIcon-DYU-ubF3.cjs → NcUserStatusIcon-CeS_I2cx.cjs} +2 -2
- package/dist/chunks/{NcUserStatusIcon-DYU-ubF3.cjs.map → NcUserStatusIcon-CeS_I2cx.cjs.map} +1 -1
- package/dist/chunks/{ScopeComponent-CycICbeB.cjs → ScopeComponent-DIh9MG7S.cjs} +2 -2
- package/dist/chunks/{ScopeComponent-CycICbeB.cjs.map → ScopeComponent-DIh9MG7S.cjs.map} +1 -1
- package/dist/chunks/{ScopeComponent-CTeSJqUJ.mjs → ScopeComponent-DzNYMeEs.mjs} +2 -2
- package/dist/chunks/{ScopeComponent-CTeSJqUJ.mjs.map → ScopeComponent-DzNYMeEs.mjs.map} +1 -1
- package/dist/chunks/_l10n-BcrsamRV.mjs +149 -0
- package/dist/chunks/_l10n-BcrsamRV.mjs.map +1 -0
- package/dist/chunks/_l10n-IBFNlYqh.cjs +148 -0
- package/dist/chunks/{_l10n-DWMcjgRh.cjs.map → _l10n-IBFNlYqh.cjs.map} +1 -1
- package/dist/chunks/{colors-RIMKc3tN.cjs → colors-DSOGBWbF.cjs} +2 -2
- package/dist/chunks/{colors-RIMKc3tN.cjs.map → colors-DSOGBWbF.cjs.map} +1 -1
- package/dist/chunks/{colors-DYuPlOca.mjs → colors-DqvwWwoq.mjs} +2 -2
- package/dist/chunks/{colors-DYuPlOca.mjs.map → colors-DqvwWwoq.mjs.map} +1 -1
- package/dist/chunks/{constants-C_lA-vcp.cjs → constants-D-Hp78ng.cjs} +2 -2
- package/dist/chunks/{constants-C_lA-vcp.cjs.map → constants-D-Hp78ng.cjs.map} +1 -1
- package/dist/chunks/{constants-Bls5liKo.mjs → constants-wIEKSp2G.mjs} +2 -2
- package/dist/chunks/{constants-Bls5liKo.mjs.map → constants-wIEKSp2G.mjs.map} +1 -1
- package/dist/chunks/{mdi-CVXTs58m.cjs → mdi-BLgCcHlv.cjs} +1 -5
- package/dist/chunks/{mdi-CVXTs58m.cjs.map → mdi-BLgCcHlv.cjs.map} +1 -1
- package/dist/chunks/{mdi-CgetWrFc.mjs → mdi-CNJ_YP0l.mjs} +9 -13
- package/dist/chunks/{mdi-CgetWrFc.mjs.map → mdi-CNJ_YP0l.mjs.map} +1 -1
- package/dist/chunks/{referencePickerModal-eu8fU-gn.mjs → referencePickerModal-B8AfZsD_.mjs} +5 -5
- package/dist/chunks/{referencePickerModal-eu8fU-gn.mjs.map → referencePickerModal-B8AfZsD_.mjs.map} +1 -1
- package/dist/chunks/{referencePickerModal-BPowR5yI.cjs → referencePickerModal-BfGuwv98.cjs} +5 -5
- package/dist/chunks/{referencePickerModal-BPowR5yI.cjs.map → referencePickerModal-BfGuwv98.cjs.map} +1 -1
- package/dist/chunks/useAppSettingsDialog-C73Wx6iQ.mjs +12 -0
- package/dist/chunks/{useAppSettingsDialog-DbtEkXa4.mjs.map → useAppSettingsDialog-C73Wx6iQ.mjs.map} +1 -1
- package/dist/chunks/{useAppSettingsDialog-BfnyikIV.cjs → useAppSettingsDialog-DKwz-cwX.cjs} +3 -3
- package/dist/chunks/{useAppSettingsDialog-BfnyikIV.cjs.map → useAppSettingsDialog-DKwz-cwX.cjs.map} +1 -1
- package/dist/chunks/{useCopy-BrkuO6SD.cjs → useCopy-B8YTkOhE.cjs} +3 -3
- package/dist/chunks/{useCopy-BrkuO6SD.cjs.map → useCopy-B8YTkOhE.cjs.map} +1 -1
- package/dist/chunks/{useCopy-J3zJ3s94.mjs → useCopy-BWnr0WjK.mjs} +3 -3
- package/dist/chunks/{useCopy-J3zJ3s94.mjs.map → useCopy-BWnr0WjK.mjs.map} +1 -1
- package/dist/chunks/{useNcFormBox-DA9iwXWY.mjs → useNcFormBox-Djlh582y.mjs} +2 -2
- package/dist/chunks/{useNcFormBox-DA9iwXWY.mjs.map → useNcFormBox-Djlh582y.mjs.map} +1 -1
- package/dist/chunks/{useNcFormBox-DQeOEuQp.cjs → useNcFormBox-XowgPxpI.cjs} +2 -2
- package/dist/chunks/{useNcFormBox-DQeOEuQp.cjs.map → useNcFormBox-XowgPxpI.cjs.map} +1 -1
- package/dist/chunks/{useNcRadioGroup-DaZbEKbf.mjs → useNcRadioGroup-D6llQmAl.mjs} +2 -2
- package/dist/chunks/{useNcRadioGroup-DaZbEKbf.mjs.map → useNcRadioGroup-D6llQmAl.mjs.map} +1 -1
- package/dist/chunks/{useNcRadioGroup-Djvu7bo0.cjs → useNcRadioGroup-rLYISWKB.cjs} +2 -2
- package/dist/chunks/{useNcRadioGroup-Djvu7bo0.cjs.map → useNcRadioGroup-rLYISWKB.cjs.map} +1 -1
- package/dist/index.cjs +57 -57
- package/dist/index.mjs +58 -58
- package/package.json +9 -9
- package/dist/chunks/NcActionInput-CB9jcc0_.mjs.map +0 -1
- package/dist/chunks/NcActionInput-Cd7bhV5-.cjs.map +0 -1
- package/dist/chunks/NcAppSettingsShortcutsSection-BGMDhIXI.mjs.map +0 -1
- package/dist/chunks/NcAppSettingsShortcutsSection-DI5YBdYf.cjs.map +0 -1
- package/dist/chunks/NcCheckboxRadioSwitch-CG2BbMsv.cjs.map +0 -1
- package/dist/chunks/NcCheckboxRadioSwitch-CX3HXCEk.mjs.map +0 -1
- package/dist/chunks/NcFormBoxSwitch-BUBD5jli.cjs.map +0 -1
- package/dist/chunks/NcFormBoxSwitch-BqbGsapa.mjs.map +0 -1
- package/dist/chunks/NcPopover-BgUZkmjk.cjs.map +0 -1
- package/dist/chunks/NcPopover-gxcAqoEb.mjs.map +0 -1
- package/dist/chunks/_l10n-D3tJt_gL.mjs +0 -141
- package/dist/chunks/_l10n-D3tJt_gL.mjs.map +0 -1
- package/dist/chunks/_l10n-DWMcjgRh.cjs +0 -140
- package/dist/chunks/useAppSettingsDialog-DbtEkXa4.mjs +0 -12
|
@@ -9,17 +9,17 @@
|
|
|
9
9
|
/*
|
|
10
10
|
* Ensure proper alignment of the vue material icons
|
|
11
11
|
*/
|
|
12
|
-
.material-design-icon[data-v-
|
|
12
|
+
.material-design-icon[data-v-525de6c5] {
|
|
13
13
|
display: flex;
|
|
14
14
|
align-self: center;
|
|
15
15
|
justify-self: center;
|
|
16
16
|
align-items: center;
|
|
17
17
|
justify-content: center;
|
|
18
18
|
}
|
|
19
|
-
.modal-mask[data-v-
|
|
19
|
+
.modal-mask[data-v-525de6c5] {
|
|
20
20
|
--backdrop-color: 0, 0, 0;
|
|
21
21
|
--icon-size: 20px;
|
|
22
|
-
--slideshow-duration: var(--
|
|
22
|
+
--slideshow-duration: var(--44ba6a1a);
|
|
23
23
|
position: fixed;
|
|
24
24
|
z-index: 9998;
|
|
25
25
|
top: 0;
|
|
@@ -29,13 +29,13 @@
|
|
|
29
29
|
height: 100%;
|
|
30
30
|
background-color: rgba(var(--backdrop-color), 0.5);
|
|
31
31
|
}
|
|
32
|
-
.modal-mask--opaque[data-v-
|
|
32
|
+
.modal-mask--opaque[data-v-525de6c5] {
|
|
33
33
|
background-color: rgba(var(--backdrop-color), 0.92);
|
|
34
34
|
}
|
|
35
|
-
.modal-mask--light[data-v-
|
|
35
|
+
.modal-mask--light[data-v-525de6c5] {
|
|
36
36
|
--backdrop-color: 255, 255, 255;
|
|
37
37
|
}
|
|
38
|
-
.modal-header[data-v-
|
|
38
|
+
.modal-header[data-v-525de6c5] {
|
|
39
39
|
position: absolute;
|
|
40
40
|
z-index: 10001;
|
|
41
41
|
top: 0;
|
|
@@ -48,7 +48,7 @@
|
|
|
48
48
|
overflow: hidden;
|
|
49
49
|
transition: opacity 250ms, visibility 250ms;
|
|
50
50
|
}
|
|
51
|
-
.modal-header__name[data-v-
|
|
51
|
+
.modal-header__name[data-v-525de6c5] {
|
|
52
52
|
overflow-x: hidden;
|
|
53
53
|
box-sizing: border-box;
|
|
54
54
|
width: 100%;
|
|
@@ -60,19 +60,19 @@
|
|
|
60
60
|
margin-block: 0;
|
|
61
61
|
}
|
|
62
62
|
@media only screen and (min-width: 1024px) {
|
|
63
|
-
.modal-header__name[data-v-
|
|
63
|
+
.modal-header__name[data-v-525de6c5] {
|
|
64
64
|
padding-inline-start: calc(var(--default-clickable-area) * 3);
|
|
65
65
|
text-align: center;
|
|
66
66
|
}
|
|
67
67
|
}
|
|
68
|
-
.modal-header .icons-menu[data-v-
|
|
68
|
+
.modal-header .icons-menu[data-v-525de6c5] {
|
|
69
69
|
position: absolute;
|
|
70
70
|
inset-inline-end: 0;
|
|
71
71
|
display: flex;
|
|
72
72
|
align-items: center;
|
|
73
73
|
justify-content: flex-end;
|
|
74
74
|
}
|
|
75
|
-
.modal-header .icons-menu .header-close[data-v-
|
|
75
|
+
.modal-header .icons-menu .header-close[data-v-525de6c5] {
|
|
76
76
|
display: flex;
|
|
77
77
|
align-items: center;
|
|
78
78
|
justify-content: center;
|
|
@@ -80,7 +80,7 @@
|
|
|
80
80
|
margin: calc((var(--header-height) - var(--default-clickable-area)) / 2);
|
|
81
81
|
padding: 0;
|
|
82
82
|
}
|
|
83
|
-
.modal-header .icons-menu .play-pause-icons[data-v-
|
|
83
|
+
.modal-header .icons-menu .play-pause-icons[data-v-525de6c5] {
|
|
84
84
|
position: relative;
|
|
85
85
|
width: var(--header-height);
|
|
86
86
|
height: var(--header-height);
|
|
@@ -90,14 +90,14 @@
|
|
|
90
90
|
border: none;
|
|
91
91
|
background-color: transparent;
|
|
92
92
|
}
|
|
93
|
-
.modal-header .icons-menu .play-pause-icons:hover .play-pause-icons__play[data-v-
|
|
94
|
-
.modal-header .icons-menu .play-pause-icons:hover .play-pause-icons__pause[data-v-
|
|
95
|
-
.modal-header .icons-menu .play-pause-icons:focus .play-pause-icons__pause[data-v-
|
|
93
|
+
.modal-header .icons-menu .play-pause-icons:hover .play-pause-icons__play[data-v-525de6c5],
|
|
94
|
+
.modal-header .icons-menu .play-pause-icons:hover .play-pause-icons__pause[data-v-525de6c5], .modal-header .icons-menu .play-pause-icons:focus .play-pause-icons__play[data-v-525de6c5],
|
|
95
|
+
.modal-header .icons-menu .play-pause-icons:focus .play-pause-icons__pause[data-v-525de6c5] {
|
|
96
96
|
opacity: 1;
|
|
97
97
|
border-radius: calc(var(--default-clickable-area) / 2);
|
|
98
98
|
background-color: rgba(127, 127, 127, 0.25);
|
|
99
99
|
}
|
|
100
|
-
.modal-header .icons-menu .play-pause-icons__play[data-v-
|
|
100
|
+
.modal-header .icons-menu .play-pause-icons__play[data-v-525de6c5], .modal-header .icons-menu .play-pause-icons__pause[data-v-525de6c5] {
|
|
101
101
|
box-sizing: border-box;
|
|
102
102
|
width: var(--default-clickable-area);
|
|
103
103
|
height: var(--default-clickable-area);
|
|
@@ -105,10 +105,10 @@
|
|
|
105
105
|
cursor: pointer;
|
|
106
106
|
opacity: 0.7;
|
|
107
107
|
}
|
|
108
|
-
.modal-header .icons-menu[data-v-
|
|
108
|
+
.modal-header .icons-menu[data-v-525de6c5] .action-item {
|
|
109
109
|
margin: calc((var(--header-height) - var(--default-clickable-area)) / 2);
|
|
110
110
|
}
|
|
111
|
-
.modal-header .icons-menu[data-v-
|
|
111
|
+
.modal-header .icons-menu[data-v-525de6c5] .action-item--single {
|
|
112
112
|
box-sizing: border-box;
|
|
113
113
|
width: var(--default-clickable-area);
|
|
114
114
|
height: var(--default-clickable-area);
|
|
@@ -116,18 +116,18 @@
|
|
|
116
116
|
background-position: center;
|
|
117
117
|
background-size: 22px;
|
|
118
118
|
}
|
|
119
|
-
.modal-header .icons-menu .header-actions[data-v-
|
|
119
|
+
.modal-header .icons-menu .header-actions[data-v-525de6c5] button:focus-visible {
|
|
120
120
|
box-shadow: none !important;
|
|
121
121
|
outline: 2px solid #fff !important;
|
|
122
122
|
}
|
|
123
|
-
.modal-header .icons-menu[data-v-
|
|
123
|
+
.modal-header .icons-menu[data-v-525de6c5] .action-item__menutoggle {
|
|
124
124
|
padding: 0;
|
|
125
125
|
}
|
|
126
|
-
.modal-header .icons-menu[data-v-
|
|
126
|
+
.modal-header .icons-menu[data-v-525de6c5] .action-item__menutoggle span, .modal-header .icons-menu[data-v-525de6c5] .action-item__menutoggle svg {
|
|
127
127
|
width: var(--icon-size);
|
|
128
128
|
height: var(--icon-size);
|
|
129
129
|
}
|
|
130
|
-
.modal-wrapper[data-v-
|
|
130
|
+
.modal-wrapper[data-v-525de6c5] {
|
|
131
131
|
display: flex;
|
|
132
132
|
align-items: center;
|
|
133
133
|
justify-content: center;
|
|
@@ -136,8 +136,8 @@
|
|
|
136
136
|
height: 100%;
|
|
137
137
|
/* Navigation buttons */
|
|
138
138
|
}
|
|
139
|
-
.modal-wrapper .prev[data-v-
|
|
140
|
-
.modal-wrapper .next[data-v-
|
|
139
|
+
.modal-wrapper .prev[data-v-525de6c5],
|
|
140
|
+
.modal-wrapper .next[data-v-525de6c5] {
|
|
141
141
|
z-index: 10000;
|
|
142
142
|
height: 35vh;
|
|
143
143
|
min-height: 300px;
|
|
@@ -145,21 +145,21 @@
|
|
|
145
145
|
transition: opacity 250ms;
|
|
146
146
|
color: white;
|
|
147
147
|
}
|
|
148
|
-
.modal-wrapper .prev[data-v-
|
|
149
|
-
.modal-wrapper .next[data-v-
|
|
148
|
+
.modal-wrapper .prev[data-v-525de6c5]:focus-visible,
|
|
149
|
+
.modal-wrapper .next[data-v-525de6c5]:focus-visible {
|
|
150
150
|
box-shadow: 0 0 0 2px var(--color-primary-element-text);
|
|
151
151
|
background-color: var(--color-box-shadow);
|
|
152
152
|
}
|
|
153
|
-
.modal-wrapper .prev[data-v-
|
|
153
|
+
.modal-wrapper .prev[data-v-525de6c5] {
|
|
154
154
|
inset-inline-start: 2px;
|
|
155
155
|
}
|
|
156
|
-
.modal-wrapper .next[data-v-
|
|
156
|
+
.modal-wrapper .next[data-v-525de6c5] {
|
|
157
157
|
inset-inline-end: 2px;
|
|
158
158
|
}
|
|
159
|
-
.modal-wrapper[data-v-
|
|
159
|
+
.modal-wrapper[data-v-525de6c5] {
|
|
160
160
|
/* Content */
|
|
161
161
|
}
|
|
162
|
-
.modal-wrapper .modal-container[data-v-
|
|
162
|
+
.modal-wrapper .modal-container[data-v-525de6c5] {
|
|
163
163
|
position: relative;
|
|
164
164
|
display: flex;
|
|
165
165
|
padding: 0;
|
|
@@ -169,33 +169,33 @@
|
|
|
169
169
|
color: var(--color-main-text);
|
|
170
170
|
box-shadow: 0 0 40px rgba(0, 0, 0, 0.2);
|
|
171
171
|
}
|
|
172
|
-
.modal-wrapper .modal-container__close[data-v-
|
|
172
|
+
.modal-wrapper .modal-container__close[data-v-525de6c5] {
|
|
173
173
|
z-index: 1;
|
|
174
174
|
position: absolute;
|
|
175
175
|
top: 4px;
|
|
176
176
|
inset-inline-end: var(--default-grid-baseline);
|
|
177
177
|
}
|
|
178
|
-
.modal-wrapper .modal-container__content[data-v-
|
|
178
|
+
.modal-wrapper .modal-container__content[data-v-525de6c5] {
|
|
179
179
|
width: 100%;
|
|
180
180
|
min-height: 52px;
|
|
181
181
|
overflow: auto;
|
|
182
182
|
}
|
|
183
|
-
.modal-wrapper--small > .modal-container[data-v-
|
|
183
|
+
.modal-wrapper--small > .modal-container[data-v-525de6c5] {
|
|
184
184
|
width: 400px;
|
|
185
185
|
max-width: 90%;
|
|
186
|
-
max-height: min(90%, 100% - 2 * var(--header-height));
|
|
186
|
+
max-height: min(90%, 100% - 2 * var(--header-height) - 2 * var(--body-container-margin));
|
|
187
187
|
}
|
|
188
|
-
.modal-wrapper--normal > .modal-container[data-v-
|
|
188
|
+
.modal-wrapper--normal > .modal-container[data-v-525de6c5] {
|
|
189
189
|
max-width: 90%;
|
|
190
190
|
width: 600px;
|
|
191
|
-
max-height: min(90%, 100% - 2 * var(--header-height));
|
|
191
|
+
max-height: min(90%, 100% - 2 * var(--header-height) - 2 * var(--body-container-margin));
|
|
192
192
|
}
|
|
193
|
-
.modal-wrapper--large > .modal-container[data-v-
|
|
193
|
+
.modal-wrapper--large > .modal-container[data-v-525de6c5] {
|
|
194
194
|
max-width: 90%;
|
|
195
195
|
width: 900px;
|
|
196
|
-
max-height: min(90%, 100% - 2 * var(--header-height));
|
|
196
|
+
max-height: min(90%, 100% - 2 * var(--header-height) - 2 * var(--body-container-margin));
|
|
197
197
|
}
|
|
198
|
-
.modal-wrapper--full > .modal-container[data-v-
|
|
198
|
+
.modal-wrapper--full > .modal-container[data-v-525de6c5] {
|
|
199
199
|
width: 100%;
|
|
200
200
|
height: calc(100% - var(--header-height));
|
|
201
201
|
position: absolute;
|
|
@@ -203,7 +203,7 @@
|
|
|
203
203
|
border-radius: 0;
|
|
204
204
|
}
|
|
205
205
|
@media only screen and ((max-width: 512px) or (max-height: 400px)) {
|
|
206
|
-
.modal-wrapper .modal-container[data-v-
|
|
206
|
+
.modal-wrapper .modal-container[data-v-525de6c5] {
|
|
207
207
|
max-width: initial;
|
|
208
208
|
width: 100%;
|
|
209
209
|
max-height: initial;
|
|
@@ -215,60 +215,60 @@
|
|
|
215
215
|
}
|
|
216
216
|
|
|
217
217
|
/* TRANSITIONS */
|
|
218
|
-
.fade-enter-active[data-v-
|
|
219
|
-
.fade-leave-active[data-v-
|
|
218
|
+
.fade-enter-active[data-v-525de6c5],
|
|
219
|
+
.fade-leave-active[data-v-525de6c5] {
|
|
220
220
|
transition: opacity 250ms;
|
|
221
221
|
}
|
|
222
|
-
.fade-enter[data-v-
|
|
223
|
-
.fade-leave-to[data-v-
|
|
222
|
+
.fade-enter[data-v-525de6c5],
|
|
223
|
+
.fade-leave-to[data-v-525de6c5] {
|
|
224
224
|
opacity: 0;
|
|
225
225
|
}
|
|
226
|
-
.fade-visibility-enter[data-v-
|
|
227
|
-
.fade-visibility-leave-to[data-v-
|
|
226
|
+
.fade-visibility-enter[data-v-525de6c5],
|
|
227
|
+
.fade-visibility-leave-to[data-v-525de6c5] {
|
|
228
228
|
visibility: hidden;
|
|
229
229
|
opacity: 0;
|
|
230
230
|
}
|
|
231
|
-
.modal-in-enter-active[data-v-
|
|
232
|
-
.modal-in-leave-active[data-v-
|
|
233
|
-
.modal-out-enter-active[data-v-
|
|
234
|
-
.modal-out-leave-active[data-v-
|
|
231
|
+
.modal-in-enter-active[data-v-525de6c5],
|
|
232
|
+
.modal-in-leave-active[data-v-525de6c5],
|
|
233
|
+
.modal-out-enter-active[data-v-525de6c5],
|
|
234
|
+
.modal-out-leave-active[data-v-525de6c5] {
|
|
235
235
|
transition: opacity 250ms;
|
|
236
236
|
}
|
|
237
|
-
.modal-in-enter[data-v-
|
|
238
|
-
.modal-in-leave-to[data-v-
|
|
239
|
-
.modal-out-enter[data-v-
|
|
240
|
-
.modal-out-leave-to[data-v-
|
|
237
|
+
.modal-in-enter[data-v-525de6c5],
|
|
238
|
+
.modal-in-leave-to[data-v-525de6c5],
|
|
239
|
+
.modal-out-enter[data-v-525de6c5],
|
|
240
|
+
.modal-out-leave-to[data-v-525de6c5] {
|
|
241
241
|
opacity: 0;
|
|
242
242
|
}
|
|
243
|
-
.modal-in-enter .modal-container[data-v-
|
|
244
|
-
.modal-in-leave-to .modal-container[data-v-
|
|
243
|
+
.modal-in-enter .modal-container[data-v-525de6c5],
|
|
244
|
+
.modal-in-leave-to .modal-container[data-v-525de6c5] {
|
|
245
245
|
transform: scale(0.9);
|
|
246
246
|
}
|
|
247
|
-
.modal-out-enter .modal-container[data-v-
|
|
248
|
-
.modal-out-leave-to .modal-container[data-v-
|
|
247
|
+
.modal-out-enter .modal-container[data-v-525de6c5],
|
|
248
|
+
.modal-out-leave-to .modal-container[data-v-525de6c5] {
|
|
249
249
|
transform: scale(1.1);
|
|
250
250
|
}
|
|
251
|
-
.modal-mask .play-pause-icons .progress-ring[data-v-
|
|
251
|
+
.modal-mask .play-pause-icons .progress-ring[data-v-525de6c5] {
|
|
252
252
|
position: absolute;
|
|
253
253
|
top: 0;
|
|
254
254
|
inset-inline-start: 0;
|
|
255
255
|
transform: rotate(-90deg);
|
|
256
256
|
}
|
|
257
|
-
.modal-mask .play-pause-icons .progress-ring .progress-ring__circle[data-v-
|
|
257
|
+
.modal-mask .play-pause-icons .progress-ring .progress-ring__circle[data-v-525de6c5] {
|
|
258
258
|
transition: 100ms stroke-dashoffset;
|
|
259
259
|
transform-origin: 50% 50%;
|
|
260
|
-
animation: progressring-
|
|
260
|
+
animation: progressring-525de6c5 linear var(--slideshow-duration) infinite;
|
|
261
261
|
stroke-linecap: round;
|
|
262
262
|
stroke-dashoffset: 94.2477796077;
|
|
263
263
|
stroke-dasharray: 94.2477796077;
|
|
264
264
|
}
|
|
265
|
-
.modal-mask .play-pause-icons--paused .icon-pause[data-v-
|
|
266
|
-
animation: breath-
|
|
265
|
+
.modal-mask .play-pause-icons--paused .icon-pause[data-v-525de6c5] {
|
|
266
|
+
animation: breath-525de6c5 2s cubic-bezier(0.4, 0, 0.2, 1) infinite;
|
|
267
267
|
}
|
|
268
|
-
.modal-mask .play-pause-icons--paused .progress-ring__circle[data-v-
|
|
268
|
+
.modal-mask .play-pause-icons--paused .progress-ring__circle[data-v-525de6c5] {
|
|
269
269
|
animation-play-state: paused !important;
|
|
270
270
|
}
|
|
271
|
-
@keyframes progressring-
|
|
271
|
+
@keyframes progressring-525de6c5 {
|
|
272
272
|
from {
|
|
273
273
|
stroke-dashoffset: 94.2477796077;
|
|
274
274
|
}
|
|
@@ -276,7 +276,7 @@ to {
|
|
|
276
276
|
stroke-dashoffset: 0;
|
|
277
277
|
}
|
|
278
278
|
}
|
|
279
|
-
@keyframes breath-
|
|
279
|
+
@keyframes breath-525de6c5 {
|
|
280
280
|
0% {
|
|
281
281
|
opacity: 1;
|
|
282
282
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
require('../assets/NcActionButton-CG4V9b5b.css');
|
|
2
2
|
"use strict";
|
|
3
|
-
const mdi = require("./mdi-
|
|
3
|
+
const mdi = require("./mdi-BLgCcHlv.cjs");
|
|
4
4
|
const NcIconSvgWrapper = require("./NcIconSvgWrapper-Bbl4kXZI.cjs");
|
|
5
5
|
const actionText = require("./actionText-D2-z0ud3.cjs");
|
|
6
6
|
const _pluginVue2_normalizer = require("./_plugin-vue2_normalizer-V0q-tHlQ.cjs");
|
|
@@ -180,4 +180,4 @@ var __component__ = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
|
|
|
180
180
|
);
|
|
181
181
|
const NcActionButton = __component__.exports;
|
|
182
182
|
exports.NcActionButton = NcActionButton;
|
|
183
|
-
//# sourceMappingURL=NcActionButton-
|
|
183
|
+
//# sourceMappingURL=NcActionButton-jtEEPXw2.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NcActionButton-BS9Mv3XD.cjs","sources":["../../src/components/NcActionButton/NcActionButton.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nThis component is made to be used inside of the [NcActions](#NcActions) component slots.\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Delete')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDelete\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :close-after-click=\"true\" @click=\"showMessage('Delete and close menu')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDelete and close\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :is-menu=\"true\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tCreate\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :disabled=\"true\" @click=\"showMessage('Disabled')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDisabled button\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Delete from 'vue-material-design-icons/Delete.vue'\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tDelete,\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n```\n\nIf you're using a long text, you can specify a `name` prop.\n\nFor the same purpose, but in a more compact way, `description` prop can be used.\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Add')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tAdd new\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton name=\"Long button\" @click=\"showMessage('Delete')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tThis button is associated with a very long text.\\nAnd with new lines too.\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton description=\"Subline description for the button\" @click=\"showMessage('Edit')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Pencil :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tEdit\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Delete from 'vue-material-design-icons/Delete.vue'\n\timport Pencil from 'vue-material-design-icons/Pencil.vue'\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tDelete,\n\t\t\tPencil,\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n\n```\n\nAction icon attribute with a single action\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Add')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tAdd new\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n\n```\n\nYou can also use a custom icon, for example from the vue-material-design-icons library:\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton>\n\t\t\t<template #icon>\n\t\t\t\t<HandBackLeft :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise left hand\n\t\t</NcActionButton>\n\t\t<NcActionButton>\n\t\t\t<template #icon>\n\t\t\t\t<HandBackRight :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise right hand\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport HandBackLeft from 'vue-material-design-icons/HandBackLeft.vue'\nimport HandBackRight from 'vue-material-design-icons/HandBackRight.vue'\n\nexport default {\n\tcomponents: {\n\t\tHandBackLeft,\n\t\tHandBackRight,\n\t},\n}\n</script>\n```\n\n### With different model behavior\nBy default the button will act like a normal button, but it is also possible to change the behavior to a toggle button, checkbox button or radio button.\n\nFor example to have the button act like a toggle button just set the `modelValue` property to the toggle state:\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton :model-value.sync=\"fullscreen\">\n\t\t\t<template #icon>\n\t\t\t\t<Fullscreen :size=\"20\" />\n\t\t\t</template>\n\t\t\tFullscreen\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport Fullscreen from 'vue-material-design-icons/Fullscreen.vue'\n\nexport default {\n\tcomponents: {\n\t\tFullscreen,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tfullscreen: true,\n\t\t}\n\t},\n}\n</script>\n```\n\nAnother example would be using it with checkbox semantics, to enable or disable features.\nThis also allows tri-state behavior (`true`, `false`, `null`) in which case `aria-checked` will be either `true`, `false` or `mixed`.\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton :model-value.sync=\"handRaised\" type=\"checkbox\">\n\t\t\t<template #icon>\n\t\t\t\t<HandBackLeft :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise hand\n\t\t</NcActionButton>\n\t\t<NcActionButton :model-value.sync=\"fullscreen\" type=\"checkbox\">\n\t\t\t<template #icon>\n\t\t\t\t<Fullscreen :size=\"20\" />\n\t\t\t</template>\n\t\t\tFullscreen\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport HandBackLeft from 'vue-material-design-icons/HandBackLeft.vue'\nimport Fullscreen from 'vue-material-design-icons/Fullscreen.vue'\n\nexport default {\n\tcomponents: {\n\t\tHandBackLeft,\n\t\tFullscreen,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tfullscreen: true,\n\t\t\thandRaised: false,\n\t\t}\n\t},\n}\n</script>\n```\n\nIt is also possible to use the button with radio semantics, this is only possible in menus and not for inline actions!\n\nWith a string `modelValue`, checked state is determined by the `value` property and updates `modelValue` with the new `value` string.\n\nWith a boolean `modelValue`, checked state is determined by `modelValue` and updates to `true` on check.\n\nNote: unlike native radio buttons, `NcActionButton` are not grouped by name, so you need to connect them by bind correct `modelValue``.\n\n```vue\n<template>\n\t<div>\n\t\t<NcActions>\n\t\t\t<NcActionButton :model-value.sync=\"payment\" type=\"radio\" value=\"cash\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Cash :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tPay with cash\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :model-value.sync=\"payment\" type=\"radio\" value=\"card\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<CreditCard :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tPay by card\n\t\t\t</NcActionButton>\n\t\t\t<NcActionSeparator />\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isLeft\" @update:modelValue=\"setAlign('Left', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignLeft :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tLeft\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isCenter\" @update:modelValue=\"setAlign('Center', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignCenter :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tCenter\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isRight\" @update:modelValue=\"setAlign('Right', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignRight :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tRight\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t\t<p>payment = \"{{ payment }}\"</p>\n\t\t<p>align.isLeft = {{ align.isLeft }}</p>\n\t\t<p>align.isCenter = {{ align.isCenter }}</p>\n\t\t<p>align.isRight = {{ align.isRight }}</p>\n\t</div>\n</template>\n<script>\nimport Cash from 'vue-material-design-icons/Cash.vue'\nimport CreditCard from 'vue-material-design-icons/CreditCard.vue'\nimport FormatAlignLeft from 'vue-material-design-icons/FormatAlignLeft.vue'\nimport FormatAlignCenter from 'vue-material-design-icons/FormatAlignCenter.vue'\nimport FormatAlignRight from 'vue-material-design-icons/FormatAlignRight.vue'\n\nexport default {\n\tcomponents: {\n\t\tCash,\n\t\tCreditCard,\n\t\tFormatAlignLeft,\n\t\tFormatAlignCenter,\n\t\tFormatAlignRight,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tpayment: 'card',\n\t\t\talign: {\n\t\t\t\tisLeft: false,\n\t\t\t\tisCenter: true,\n\t\t\t\tisRight: false,\n\t\t\t},\n\t\t}\n\t},\n\tmethods: {\n\t\tsetAlign(direction, value) {\n\t\t\tthis.align.isLeft = false\n\t\t\tthis.align.isCenter = false\n\t\t\tthis.align.isRight = false\n\t\t\tthis.align[`is${direction}`] = value\n\t\t},\n\t}\n}\n</script>\n```\n</docs>\n\n<template>\n\t<li class=\"action\" :class=\"{ 'action--disabled': disabled }\" :role=\"isInSemanticMenu && 'presentation'\">\n\t\t<button\n\t\t\t:aria-label=\"ariaLabel\"\n\t\t\tclass=\"action-button button-vue\"\n\t\t\t:class=\"{\n\t\t\t\t'action-button--active': isChecked,\n\t\t\t\tfocusable: isFocusable,\n\t\t\t}\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:title=\"title\"\n\t\t\t:type=\"nativeType\"\n\t\t\tv-bind=\"buttonAttributes\"\n\t\t\t@click=\"handleClick\">\n\t\t\t<!-- @slot Manually provide icon -->\n\t\t\t<slot name=\"icon\">\n\t\t\t\t<span\n\t\t\t\t\t:class=\"[isIconUrl ? 'action-button__icon--url' : icon]\"\n\t\t\t\t\t:style=\"{ backgroundImage: isIconUrl ? `url(${icon})` : null }\"\n\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\tclass=\"action-button__icon\" />\n\t\t\t</slot>\n\n\t\t\t<!-- long text with name -->\n\t\t\t<span class=\"action-button__longtext-wrapper\">\n\t\t\t\t<strong\n\t\t\t\t\tv-if=\"name\"\n\t\t\t\t\tclass=\"action-button__name\">\n\t\t\t\t\t{{ name }}\n\t\t\t\t</strong>\n\t\t\t\t<!-- white space is shown on longtext, so we can't\n\t\t\t\t\tput {{ text }} on a new line for code readability -->\n\t\t\t\t<span\n\t\t\t\t\tv-if=\"isLongText\"\n\t\t\t\t\tclass=\"action-button__longtext\"\n\t\t\t\t\tv-text=\"text\" />\n\t\t\t\t<!-- default text display -->\n\t\t\t\t<span\n\t\t\t\t\tv-else\n\t\t\t\t\tclass=\"action-button__text\">\n\t\t\t\t\t{{ text }}\n\t\t\t\t</span>\n\t\t\t\t<span\n\t\t\t\t\tv-if=\"description\"\n\t\t\t\t\tclass=\"action-button__description\"\n\t\t\t\t\tv-text=\"description\" />\n\t\t\t</span>\n\n\t\t\t<!-- right(in LTR) or left(in RTL) arrow icon when there is a sub-menu -->\n\t\t\t<NcIconSvgWrapper\n\t\t\t\tv-if=\"isMenu\"\n\t\t\t\tclass=\"action-button__menu-icon\"\n\t\t\t\tdirectional\n\t\t\t\t:path=\"mdiChevronRight\" />\n\t\t\t<NcIconSvgWrapper v-else-if=\"isChecked\" :path=\"mdiCheck\" class=\"action-button__pressed-icon\" />\n\n\t\t\t<span v-else-if=\"isChecked === false\" class=\"action-button__pressed-icon material-design-icon\" />\n\n\t\t\t<!-- fake slot to gather inner text -->\n\t\t\t<slot v-if=\"false\" />\n\t\t</button>\n\t</li>\n</template>\n\n<script>\nimport { mdiCheck, mdiChevronRight } from '@mdi/js'\nimport NcIconSvgWrapper from '../NcIconSvgWrapper/NcIconSvgWrapper.vue'\nimport ActionTextMixin from '../../mixins/actionText.js'\n\n/**\n * Button component to be used in Actions\n */\nexport default {\n\tname: 'NcActionButton',\n\n\tcomponents: {\n\t\tNcIconSvgWrapper,\n\t},\n\n\tmixins: [ActionTextMixin],\n\n\tinject: {\n\t\tisInSemanticMenu: {\n\t\t\tfrom: 'NcActions:isSemanticMenu',\n\t\t\tdefault: false,\n\t\t},\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * @deprecated To be removed in @nextcloud/vue 9. Migration guide: remove ariaHidden prop from NcAction* components.\n\t\t * @todo Add a check in @nextcloud/vue 9 that this prop is not provided,\n\t\t * otherwise root element will inherit incorrect aria-hidden.\n\t\t */\n\t\tariaHidden: {\n\t\t\ttype: Boolean,\n\t\t\t// eslint-disable-next-line vue/no-boolean-default\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * disabled state of the action button\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 * If this is a menu, a chevron icon will\n\t\t * be added at the end of the line\n\t\t */\n\t\tisMenu: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * The button's behavior, by default the button acts like a normal button with optional toggle button behavior if `modelValue` is `true` or `false`.\n\t\t * But you can also set to checkbox button behavior with tri-state or radio button like behavior.\n\t\t * This extends the native HTML button type attribute.\n\t\t */\n\t\ttype: {\n\t\t\ttype: String,\n\t\t\tdefault: 'button',\n\t\t\tvalidator: (behavior) => ['button', 'checkbox', 'radio', 'reset', 'submit'].includes(behavior),\n\t\t},\n\n\t\t/**\n\t\t * The buttons state if `type` is 'checkbox' or 'radio' (meaning if it is pressed / selected).\n\t\t * For checkbox and toggle button behavior - boolean value.\n\t\t * For radio button behavior - could be a boolean checked or a string with the value of the button.\n\t\t * Note: Unlike native radio buttons, NcActionButton are not grouped by name, so you need to connect them by bind correct modelValue.\n\t\t *\n\t\t * **This is not availabe for `type='submit'` or `type='reset'`**\n\t\t *\n\t\t * If using `type='checkbox'` a `model-value` of `true` means checked, `false` means unchecked and `null` means indeterminate (tri-state)\n\t\t * For `type='radio'` `null` is equal to `false`\n\t\t */\n\t\tmodelValue: {\n\t\t\ttype: [Boolean, String],\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * The value used for the `modelValue` when this component is used with radio behavior\n\t\t * Similar to the `value` attribute of `<input type=\"radio\">`\n\t\t */\n\t\tvalue: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Small underlying text content of the entry\n\t\t */\n\t\tdescription: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t},\n\n\tsetup() {\n\t\treturn {\n\t\t\tmdiCheck,\n\t\t\tmdiChevronRight,\n\t\t}\n\t},\n\n\tcomputed: {\n\t\t/**\n\t\t * determines if the action is focusable\n\t\t *\n\t\t * @return {boolean} is the action focusable ?\n\t\t */\n\t\tisFocusable() {\n\t\t\treturn !this.disabled\n\t\t},\n\n\t\t/**\n\t\t * The current \"checked\" or \"pressed\" state for the model behavior\n\t\t */\n\t\tisChecked() {\n\t\t\tif (this.type === 'radio' && typeof this.modelValue !== 'boolean') {\n\t\t\t\treturn this.modelValue === this.value\n\t\t\t}\n\t\t\treturn this.modelValue\n\t\t},\n\n\t\t/**\n\t\t * The native HTML type to set on the button\n\t\t */\n\t\tnativeType() {\n\t\t\tif (this.type === 'submit' || this.type === 'reset') {\n\t\t\t\treturn this.type\n\t\t\t}\n\t\t\treturn 'button'\n\t\t},\n\n\t\t/**\n\t\t * HTML attributes to bind to the <button>\n\t\t */\n\t\tbuttonAttributes() {\n\t\t\tconst attributes = {}\n\n\t\t\tif (this.isInSemanticMenu) {\n\t\t\t\t// By default it needs to be a menu item in semantic menus\n\t\t\t\tattributes.role = 'menuitem'\n\n\t\t\t\tif (this.type === 'radio') {\n\t\t\t\t\tattributes.role = 'menuitemradio'\n\t\t\t\t\tattributes['aria-checked'] = this.isChecked ? 'true' : 'false'\n\t\t\t\t} else if (this.type === 'checkbox' || (this.nativeType === 'button' && this.modelValue !== null)) {\n\t\t\t\t\t// either if checkbox behavior was set or the model value is not unset\n\t\t\t\t\tattributes.role = 'menuitemcheckbox'\n\t\t\t\t\tattributes['aria-checked'] = this.modelValue === null ? 'mixed' : (this.modelValue ? 'true' : 'false')\n\t\t\t\t}\n\t\t\t} else if (this.modelValue !== null && this.nativeType === 'button') {\n\t\t\t\t// In case this has a modelValue it is considered a toggle button, so we need to set the aria-pressed\n\t\t\t\tattributes['aria-pressed'] = this.modelValue ? 'true' : 'false'\n\t\t\t}\n\n\t\t\treturn attributes\n\t\t},\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Forward click event, let mixin handle the close-after-click and emit new modelValue if needed\n\t\t *\n\t\t * @param {MouseEvent} event The click event\n\t\t */\n\t\thandleClick(event) {\n\t\t\tthis.onClick(event)\n\t\t\t// If modelValue or type is set (so modelValue might be null for tri-state) we need to update it\n\t\t\tif (this.modelValue !== null || this.type !== 'button') {\n\t\t\t\tif (this.type === 'radio') {\n\t\t\t\t\tif (typeof this.modelValue !== 'boolean') {\n\t\t\t\t\t\t// String-value radios behavior is similar to native - click on checked radio does nothing\n\t\t\t\t\t\tif (!this.isChecked) {\n\t\t\t\t\t\t\tthis.$emit('update:modelValue', this.value)\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Boolean radio allows to uncheck\n\t\t\t\t\t\tthis.$emit('update:modelValue', !this.isChecked)\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// Checkbox toggles value\n\t\t\t\t\tthis.$emit('update:modelValue', !this.isChecked)\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n@use '../../assets/action.scss' as *;\n@include action-active;\n@include action--disabled;\n@include action-item('button');\n\n.action-button {\n\t&__pressed-icon {\n\t\tmargin-inline: auto calc($icon-margin * -1);\n\t}\n\n\t* {\n\t\tcursor: pointer;\n\t}\n}\n</style>\n"],"names":["NcIconSvgWrapper","ActionTextMixin","mdiCheck","mdiChevronRight"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"NcActionButton-jtEEPXw2.cjs","sources":["../../src/components/NcActionButton/NcActionButton.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nThis component is made to be used inside of the [NcActions](#NcActions) component slots.\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Delete')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDelete\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :close-after-click=\"true\" @click=\"showMessage('Delete and close menu')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDelete and close\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :is-menu=\"true\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tCreate\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :disabled=\"true\" @click=\"showMessage('Disabled')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDisabled button\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Delete from 'vue-material-design-icons/Delete.vue'\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tDelete,\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n```\n\nIf you're using a long text, you can specify a `name` prop.\n\nFor the same purpose, but in a more compact way, `description` prop can be used.\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Add')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tAdd new\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton name=\"Long button\" @click=\"showMessage('Delete')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tThis button is associated with a very long text.\\nAnd with new lines too.\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton description=\"Subline description for the button\" @click=\"showMessage('Edit')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Pencil :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tEdit\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Delete from 'vue-material-design-icons/Delete.vue'\n\timport Pencil from 'vue-material-design-icons/Pencil.vue'\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tDelete,\n\t\t\tPencil,\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n\n```\n\nAction icon attribute with a single action\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Add')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tAdd new\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n\n```\n\nYou can also use a custom icon, for example from the vue-material-design-icons library:\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton>\n\t\t\t<template #icon>\n\t\t\t\t<HandBackLeft :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise left hand\n\t\t</NcActionButton>\n\t\t<NcActionButton>\n\t\t\t<template #icon>\n\t\t\t\t<HandBackRight :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise right hand\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport HandBackLeft from 'vue-material-design-icons/HandBackLeft.vue'\nimport HandBackRight from 'vue-material-design-icons/HandBackRight.vue'\n\nexport default {\n\tcomponents: {\n\t\tHandBackLeft,\n\t\tHandBackRight,\n\t},\n}\n</script>\n```\n\n### With different model behavior\nBy default the button will act like a normal button, but it is also possible to change the behavior to a toggle button, checkbox button or radio button.\n\nFor example to have the button act like a toggle button just set the `modelValue` property to the toggle state:\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton :model-value.sync=\"fullscreen\">\n\t\t\t<template #icon>\n\t\t\t\t<Fullscreen :size=\"20\" />\n\t\t\t</template>\n\t\t\tFullscreen\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport Fullscreen from 'vue-material-design-icons/Fullscreen.vue'\n\nexport default {\n\tcomponents: {\n\t\tFullscreen,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tfullscreen: true,\n\t\t}\n\t},\n}\n</script>\n```\n\nAnother example would be using it with checkbox semantics, to enable or disable features.\nThis also allows tri-state behavior (`true`, `false`, `null`) in which case `aria-checked` will be either `true`, `false` or `mixed`.\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton :model-value.sync=\"handRaised\" type=\"checkbox\">\n\t\t\t<template #icon>\n\t\t\t\t<HandBackLeft :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise hand\n\t\t</NcActionButton>\n\t\t<NcActionButton :model-value.sync=\"fullscreen\" type=\"checkbox\">\n\t\t\t<template #icon>\n\t\t\t\t<Fullscreen :size=\"20\" />\n\t\t\t</template>\n\t\t\tFullscreen\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport HandBackLeft from 'vue-material-design-icons/HandBackLeft.vue'\nimport Fullscreen from 'vue-material-design-icons/Fullscreen.vue'\n\nexport default {\n\tcomponents: {\n\t\tHandBackLeft,\n\t\tFullscreen,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tfullscreen: true,\n\t\t\thandRaised: false,\n\t\t}\n\t},\n}\n</script>\n```\n\nIt is also possible to use the button with radio semantics, this is only possible in menus and not for inline actions!\n\nWith a string `modelValue`, checked state is determined by the `value` property and updates `modelValue` with the new `value` string.\n\nWith a boolean `modelValue`, checked state is determined by `modelValue` and updates to `true` on check.\n\nNote: unlike native radio buttons, `NcActionButton` are not grouped by name, so you need to connect them by bind correct `modelValue``.\n\n```vue\n<template>\n\t<div>\n\t\t<NcActions>\n\t\t\t<NcActionButton :model-value.sync=\"payment\" type=\"radio\" value=\"cash\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Cash :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tPay with cash\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :model-value.sync=\"payment\" type=\"radio\" value=\"card\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<CreditCard :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tPay by card\n\t\t\t</NcActionButton>\n\t\t\t<NcActionSeparator />\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isLeft\" @update:modelValue=\"setAlign('Left', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignLeft :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tLeft\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isCenter\" @update:modelValue=\"setAlign('Center', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignCenter :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tCenter\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isRight\" @update:modelValue=\"setAlign('Right', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignRight :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tRight\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t\t<p>payment = \"{{ payment }}\"</p>\n\t\t<p>align.isLeft = {{ align.isLeft }}</p>\n\t\t<p>align.isCenter = {{ align.isCenter }}</p>\n\t\t<p>align.isRight = {{ align.isRight }}</p>\n\t</div>\n</template>\n<script>\nimport Cash from 'vue-material-design-icons/Cash.vue'\nimport CreditCard from 'vue-material-design-icons/CreditCard.vue'\nimport FormatAlignLeft from 'vue-material-design-icons/FormatAlignLeft.vue'\nimport FormatAlignCenter from 'vue-material-design-icons/FormatAlignCenter.vue'\nimport FormatAlignRight from 'vue-material-design-icons/FormatAlignRight.vue'\n\nexport default {\n\tcomponents: {\n\t\tCash,\n\t\tCreditCard,\n\t\tFormatAlignLeft,\n\t\tFormatAlignCenter,\n\t\tFormatAlignRight,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tpayment: 'card',\n\t\t\talign: {\n\t\t\t\tisLeft: false,\n\t\t\t\tisCenter: true,\n\t\t\t\tisRight: false,\n\t\t\t},\n\t\t}\n\t},\n\tmethods: {\n\t\tsetAlign(direction, value) {\n\t\t\tthis.align.isLeft = false\n\t\t\tthis.align.isCenter = false\n\t\t\tthis.align.isRight = false\n\t\t\tthis.align[`is${direction}`] = value\n\t\t},\n\t}\n}\n</script>\n```\n</docs>\n\n<template>\n\t<li class=\"action\" :class=\"{ 'action--disabled': disabled }\" :role=\"isInSemanticMenu && 'presentation'\">\n\t\t<button\n\t\t\t:aria-label=\"ariaLabel\"\n\t\t\tclass=\"action-button button-vue\"\n\t\t\t:class=\"{\n\t\t\t\t'action-button--active': isChecked,\n\t\t\t\tfocusable: isFocusable,\n\t\t\t}\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:title=\"title\"\n\t\t\t:type=\"nativeType\"\n\t\t\tv-bind=\"buttonAttributes\"\n\t\t\t@click=\"handleClick\">\n\t\t\t<!-- @slot Manually provide icon -->\n\t\t\t<slot name=\"icon\">\n\t\t\t\t<span\n\t\t\t\t\t:class=\"[isIconUrl ? 'action-button__icon--url' : icon]\"\n\t\t\t\t\t:style=\"{ backgroundImage: isIconUrl ? `url(${icon})` : null }\"\n\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\tclass=\"action-button__icon\" />\n\t\t\t</slot>\n\n\t\t\t<!-- long text with name -->\n\t\t\t<span class=\"action-button__longtext-wrapper\">\n\t\t\t\t<strong\n\t\t\t\t\tv-if=\"name\"\n\t\t\t\t\tclass=\"action-button__name\">\n\t\t\t\t\t{{ name }}\n\t\t\t\t</strong>\n\t\t\t\t<!-- white space is shown on longtext, so we can't\n\t\t\t\t\tput {{ text }} on a new line for code readability -->\n\t\t\t\t<span\n\t\t\t\t\tv-if=\"isLongText\"\n\t\t\t\t\tclass=\"action-button__longtext\"\n\t\t\t\t\tv-text=\"text\" />\n\t\t\t\t<!-- default text display -->\n\t\t\t\t<span\n\t\t\t\t\tv-else\n\t\t\t\t\tclass=\"action-button__text\">\n\t\t\t\t\t{{ text }}\n\t\t\t\t</span>\n\t\t\t\t<span\n\t\t\t\t\tv-if=\"description\"\n\t\t\t\t\tclass=\"action-button__description\"\n\t\t\t\t\tv-text=\"description\" />\n\t\t\t</span>\n\n\t\t\t<!-- right(in LTR) or left(in RTL) arrow icon when there is a sub-menu -->\n\t\t\t<NcIconSvgWrapper\n\t\t\t\tv-if=\"isMenu\"\n\t\t\t\tclass=\"action-button__menu-icon\"\n\t\t\t\tdirectional\n\t\t\t\t:path=\"mdiChevronRight\" />\n\t\t\t<NcIconSvgWrapper v-else-if=\"isChecked\" :path=\"mdiCheck\" class=\"action-button__pressed-icon\" />\n\n\t\t\t<span v-else-if=\"isChecked === false\" class=\"action-button__pressed-icon material-design-icon\" />\n\n\t\t\t<!-- fake slot to gather inner text -->\n\t\t\t<slot v-if=\"false\" />\n\t\t</button>\n\t</li>\n</template>\n\n<script>\nimport { mdiCheck, mdiChevronRight } from '@mdi/js'\nimport NcIconSvgWrapper from '../NcIconSvgWrapper/NcIconSvgWrapper.vue'\nimport ActionTextMixin from '../../mixins/actionText.js'\n\n/**\n * Button component to be used in Actions\n */\nexport default {\n\tname: 'NcActionButton',\n\n\tcomponents: {\n\t\tNcIconSvgWrapper,\n\t},\n\n\tmixins: [ActionTextMixin],\n\n\tinject: {\n\t\tisInSemanticMenu: {\n\t\t\tfrom: 'NcActions:isSemanticMenu',\n\t\t\tdefault: false,\n\t\t},\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * @deprecated To be removed in @nextcloud/vue 9. Migration guide: remove ariaHidden prop from NcAction* components.\n\t\t * @todo Add a check in @nextcloud/vue 9 that this prop is not provided,\n\t\t * otherwise root element will inherit incorrect aria-hidden.\n\t\t */\n\t\tariaHidden: {\n\t\t\ttype: Boolean,\n\t\t\t// eslint-disable-next-line vue/no-boolean-default\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * disabled state of the action button\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 * If this is a menu, a chevron icon will\n\t\t * be added at the end of the line\n\t\t */\n\t\tisMenu: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * The button's behavior, by default the button acts like a normal button with optional toggle button behavior if `modelValue` is `true` or `false`.\n\t\t * But you can also set to checkbox button behavior with tri-state or radio button like behavior.\n\t\t * This extends the native HTML button type attribute.\n\t\t */\n\t\ttype: {\n\t\t\ttype: String,\n\t\t\tdefault: 'button',\n\t\t\tvalidator: (behavior) => ['button', 'checkbox', 'radio', 'reset', 'submit'].includes(behavior),\n\t\t},\n\n\t\t/**\n\t\t * The buttons state if `type` is 'checkbox' or 'radio' (meaning if it is pressed / selected).\n\t\t * For checkbox and toggle button behavior - boolean value.\n\t\t * For radio button behavior - could be a boolean checked or a string with the value of the button.\n\t\t * Note: Unlike native radio buttons, NcActionButton are not grouped by name, so you need to connect them by bind correct modelValue.\n\t\t *\n\t\t * **This is not availabe for `type='submit'` or `type='reset'`**\n\t\t *\n\t\t * If using `type='checkbox'` a `model-value` of `true` means checked, `false` means unchecked and `null` means indeterminate (tri-state)\n\t\t * For `type='radio'` `null` is equal to `false`\n\t\t */\n\t\tmodelValue: {\n\t\t\ttype: [Boolean, String],\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * The value used for the `modelValue` when this component is used with radio behavior\n\t\t * Similar to the `value` attribute of `<input type=\"radio\">`\n\t\t */\n\t\tvalue: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Small underlying text content of the entry\n\t\t */\n\t\tdescription: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t},\n\n\tsetup() {\n\t\treturn {\n\t\t\tmdiCheck,\n\t\t\tmdiChevronRight,\n\t\t}\n\t},\n\n\tcomputed: {\n\t\t/**\n\t\t * determines if the action is focusable\n\t\t *\n\t\t * @return {boolean} is the action focusable ?\n\t\t */\n\t\tisFocusable() {\n\t\t\treturn !this.disabled\n\t\t},\n\n\t\t/**\n\t\t * The current \"checked\" or \"pressed\" state for the model behavior\n\t\t */\n\t\tisChecked() {\n\t\t\tif (this.type === 'radio' && typeof this.modelValue !== 'boolean') {\n\t\t\t\treturn this.modelValue === this.value\n\t\t\t}\n\t\t\treturn this.modelValue\n\t\t},\n\n\t\t/**\n\t\t * The native HTML type to set on the button\n\t\t */\n\t\tnativeType() {\n\t\t\tif (this.type === 'submit' || this.type === 'reset') {\n\t\t\t\treturn this.type\n\t\t\t}\n\t\t\treturn 'button'\n\t\t},\n\n\t\t/**\n\t\t * HTML attributes to bind to the <button>\n\t\t */\n\t\tbuttonAttributes() {\n\t\t\tconst attributes = {}\n\n\t\t\tif (this.isInSemanticMenu) {\n\t\t\t\t// By default it needs to be a menu item in semantic menus\n\t\t\t\tattributes.role = 'menuitem'\n\n\t\t\t\tif (this.type === 'radio') {\n\t\t\t\t\tattributes.role = 'menuitemradio'\n\t\t\t\t\tattributes['aria-checked'] = this.isChecked ? 'true' : 'false'\n\t\t\t\t} else if (this.type === 'checkbox' || (this.nativeType === 'button' && this.modelValue !== null)) {\n\t\t\t\t\t// either if checkbox behavior was set or the model value is not unset\n\t\t\t\t\tattributes.role = 'menuitemcheckbox'\n\t\t\t\t\tattributes['aria-checked'] = this.modelValue === null ? 'mixed' : (this.modelValue ? 'true' : 'false')\n\t\t\t\t}\n\t\t\t} else if (this.modelValue !== null && this.nativeType === 'button') {\n\t\t\t\t// In case this has a modelValue it is considered a toggle button, so we need to set the aria-pressed\n\t\t\t\tattributes['aria-pressed'] = this.modelValue ? 'true' : 'false'\n\t\t\t}\n\n\t\t\treturn attributes\n\t\t},\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Forward click event, let mixin handle the close-after-click and emit new modelValue if needed\n\t\t *\n\t\t * @param {MouseEvent} event The click event\n\t\t */\n\t\thandleClick(event) {\n\t\t\tthis.onClick(event)\n\t\t\t// If modelValue or type is set (so modelValue might be null for tri-state) we need to update it\n\t\t\tif (this.modelValue !== null || this.type !== 'button') {\n\t\t\t\tif (this.type === 'radio') {\n\t\t\t\t\tif (typeof this.modelValue !== 'boolean') {\n\t\t\t\t\t\t// String-value radios behavior is similar to native - click on checked radio does nothing\n\t\t\t\t\t\tif (!this.isChecked) {\n\t\t\t\t\t\t\tthis.$emit('update:modelValue', this.value)\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Boolean radio allows to uncheck\n\t\t\t\t\t\tthis.$emit('update:modelValue', !this.isChecked)\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// Checkbox toggles value\n\t\t\t\t\tthis.$emit('update:modelValue', !this.isChecked)\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n@use '../../assets/action.scss' as *;\n@include action-active;\n@include action--disabled;\n@include action-item('button');\n\n.action-button {\n\t&__pressed-icon {\n\t\tmargin-inline: auto calc($icon-margin * -1);\n\t}\n\n\t* {\n\t\tcursor: pointer;\n\t}\n}\n</style>\n"],"names":["NcIconSvgWrapper","ActionTextMixin","mdiCheck","mdiChevronRight"],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import '../assets/NcActionButton-CG4V9b5b.css';
|
|
2
|
-
import { m as mdiChevronRight, a as mdiCheck } from "./mdi-
|
|
2
|
+
import { m as mdiChevronRight, a as mdiCheck } from "./mdi-CNJ_YP0l.mjs";
|
|
3
3
|
import { N as NcIconSvgWrapper } from "./NcIconSvgWrapper-Bui9PhAS.mjs";
|
|
4
4
|
import { A as ActionTextMixin } from "./actionText-BMig9Egt.mjs";
|
|
5
5
|
import { n as normalizeComponent } from "./_plugin-vue2_normalizer-DU4iP6Vu.mjs";
|
|
@@ -181,4 +181,4 @@ const NcActionButton = __component__.exports;
|
|
|
181
181
|
export {
|
|
182
182
|
NcActionButton as N
|
|
183
183
|
};
|
|
184
|
-
//# sourceMappingURL=NcActionButton-
|
|
184
|
+
//# sourceMappingURL=NcActionButton-w5F9kCHW.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NcActionButton-CECxOkhK.mjs","sources":["../../src/components/NcActionButton/NcActionButton.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nThis component is made to be used inside of the [NcActions](#NcActions) component slots.\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Delete')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDelete\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :close-after-click=\"true\" @click=\"showMessage('Delete and close menu')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDelete and close\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :is-menu=\"true\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tCreate\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :disabled=\"true\" @click=\"showMessage('Disabled')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDisabled button\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Delete from 'vue-material-design-icons/Delete.vue'\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tDelete,\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n```\n\nIf you're using a long text, you can specify a `name` prop.\n\nFor the same purpose, but in a more compact way, `description` prop can be used.\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Add')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tAdd new\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton name=\"Long button\" @click=\"showMessage('Delete')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tThis button is associated with a very long text.\\nAnd with new lines too.\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton description=\"Subline description for the button\" @click=\"showMessage('Edit')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Pencil :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tEdit\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Delete from 'vue-material-design-icons/Delete.vue'\n\timport Pencil from 'vue-material-design-icons/Pencil.vue'\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tDelete,\n\t\t\tPencil,\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n\n```\n\nAction icon attribute with a single action\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Add')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tAdd new\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n\n```\n\nYou can also use a custom icon, for example from the vue-material-design-icons library:\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton>\n\t\t\t<template #icon>\n\t\t\t\t<HandBackLeft :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise left hand\n\t\t</NcActionButton>\n\t\t<NcActionButton>\n\t\t\t<template #icon>\n\t\t\t\t<HandBackRight :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise right hand\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport HandBackLeft from 'vue-material-design-icons/HandBackLeft.vue'\nimport HandBackRight from 'vue-material-design-icons/HandBackRight.vue'\n\nexport default {\n\tcomponents: {\n\t\tHandBackLeft,\n\t\tHandBackRight,\n\t},\n}\n</script>\n```\n\n### With different model behavior\nBy default the button will act like a normal button, but it is also possible to change the behavior to a toggle button, checkbox button or radio button.\n\nFor example to have the button act like a toggle button just set the `modelValue` property to the toggle state:\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton :model-value.sync=\"fullscreen\">\n\t\t\t<template #icon>\n\t\t\t\t<Fullscreen :size=\"20\" />\n\t\t\t</template>\n\t\t\tFullscreen\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport Fullscreen from 'vue-material-design-icons/Fullscreen.vue'\n\nexport default {\n\tcomponents: {\n\t\tFullscreen,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tfullscreen: true,\n\t\t}\n\t},\n}\n</script>\n```\n\nAnother example would be using it with checkbox semantics, to enable or disable features.\nThis also allows tri-state behavior (`true`, `false`, `null`) in which case `aria-checked` will be either `true`, `false` or `mixed`.\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton :model-value.sync=\"handRaised\" type=\"checkbox\">\n\t\t\t<template #icon>\n\t\t\t\t<HandBackLeft :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise hand\n\t\t</NcActionButton>\n\t\t<NcActionButton :model-value.sync=\"fullscreen\" type=\"checkbox\">\n\t\t\t<template #icon>\n\t\t\t\t<Fullscreen :size=\"20\" />\n\t\t\t</template>\n\t\t\tFullscreen\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport HandBackLeft from 'vue-material-design-icons/HandBackLeft.vue'\nimport Fullscreen from 'vue-material-design-icons/Fullscreen.vue'\n\nexport default {\n\tcomponents: {\n\t\tHandBackLeft,\n\t\tFullscreen,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tfullscreen: true,\n\t\t\thandRaised: false,\n\t\t}\n\t},\n}\n</script>\n```\n\nIt is also possible to use the button with radio semantics, this is only possible in menus and not for inline actions!\n\nWith a string `modelValue`, checked state is determined by the `value` property and updates `modelValue` with the new `value` string.\n\nWith a boolean `modelValue`, checked state is determined by `modelValue` and updates to `true` on check.\n\nNote: unlike native radio buttons, `NcActionButton` are not grouped by name, so you need to connect them by bind correct `modelValue``.\n\n```vue\n<template>\n\t<div>\n\t\t<NcActions>\n\t\t\t<NcActionButton :model-value.sync=\"payment\" type=\"radio\" value=\"cash\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Cash :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tPay with cash\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :model-value.sync=\"payment\" type=\"radio\" value=\"card\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<CreditCard :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tPay by card\n\t\t\t</NcActionButton>\n\t\t\t<NcActionSeparator />\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isLeft\" @update:modelValue=\"setAlign('Left', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignLeft :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tLeft\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isCenter\" @update:modelValue=\"setAlign('Center', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignCenter :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tCenter\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isRight\" @update:modelValue=\"setAlign('Right', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignRight :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tRight\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t\t<p>payment = \"{{ payment }}\"</p>\n\t\t<p>align.isLeft = {{ align.isLeft }}</p>\n\t\t<p>align.isCenter = {{ align.isCenter }}</p>\n\t\t<p>align.isRight = {{ align.isRight }}</p>\n\t</div>\n</template>\n<script>\nimport Cash from 'vue-material-design-icons/Cash.vue'\nimport CreditCard from 'vue-material-design-icons/CreditCard.vue'\nimport FormatAlignLeft from 'vue-material-design-icons/FormatAlignLeft.vue'\nimport FormatAlignCenter from 'vue-material-design-icons/FormatAlignCenter.vue'\nimport FormatAlignRight from 'vue-material-design-icons/FormatAlignRight.vue'\n\nexport default {\n\tcomponents: {\n\t\tCash,\n\t\tCreditCard,\n\t\tFormatAlignLeft,\n\t\tFormatAlignCenter,\n\t\tFormatAlignRight,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tpayment: 'card',\n\t\t\talign: {\n\t\t\t\tisLeft: false,\n\t\t\t\tisCenter: true,\n\t\t\t\tisRight: false,\n\t\t\t},\n\t\t}\n\t},\n\tmethods: {\n\t\tsetAlign(direction, value) {\n\t\t\tthis.align.isLeft = false\n\t\t\tthis.align.isCenter = false\n\t\t\tthis.align.isRight = false\n\t\t\tthis.align[`is${direction}`] = value\n\t\t},\n\t}\n}\n</script>\n```\n</docs>\n\n<template>\n\t<li class=\"action\" :class=\"{ 'action--disabled': disabled }\" :role=\"isInSemanticMenu && 'presentation'\">\n\t\t<button\n\t\t\t:aria-label=\"ariaLabel\"\n\t\t\tclass=\"action-button button-vue\"\n\t\t\t:class=\"{\n\t\t\t\t'action-button--active': isChecked,\n\t\t\t\tfocusable: isFocusable,\n\t\t\t}\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:title=\"title\"\n\t\t\t:type=\"nativeType\"\n\t\t\tv-bind=\"buttonAttributes\"\n\t\t\t@click=\"handleClick\">\n\t\t\t<!-- @slot Manually provide icon -->\n\t\t\t<slot name=\"icon\">\n\t\t\t\t<span\n\t\t\t\t\t:class=\"[isIconUrl ? 'action-button__icon--url' : icon]\"\n\t\t\t\t\t:style=\"{ backgroundImage: isIconUrl ? `url(${icon})` : null }\"\n\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\tclass=\"action-button__icon\" />\n\t\t\t</slot>\n\n\t\t\t<!-- long text with name -->\n\t\t\t<span class=\"action-button__longtext-wrapper\">\n\t\t\t\t<strong\n\t\t\t\t\tv-if=\"name\"\n\t\t\t\t\tclass=\"action-button__name\">\n\t\t\t\t\t{{ name }}\n\t\t\t\t</strong>\n\t\t\t\t<!-- white space is shown on longtext, so we can't\n\t\t\t\t\tput {{ text }} on a new line for code readability -->\n\t\t\t\t<span\n\t\t\t\t\tv-if=\"isLongText\"\n\t\t\t\t\tclass=\"action-button__longtext\"\n\t\t\t\t\tv-text=\"text\" />\n\t\t\t\t<!-- default text display -->\n\t\t\t\t<span\n\t\t\t\t\tv-else\n\t\t\t\t\tclass=\"action-button__text\">\n\t\t\t\t\t{{ text }}\n\t\t\t\t</span>\n\t\t\t\t<span\n\t\t\t\t\tv-if=\"description\"\n\t\t\t\t\tclass=\"action-button__description\"\n\t\t\t\t\tv-text=\"description\" />\n\t\t\t</span>\n\n\t\t\t<!-- right(in LTR) or left(in RTL) arrow icon when there is a sub-menu -->\n\t\t\t<NcIconSvgWrapper\n\t\t\t\tv-if=\"isMenu\"\n\t\t\t\tclass=\"action-button__menu-icon\"\n\t\t\t\tdirectional\n\t\t\t\t:path=\"mdiChevronRight\" />\n\t\t\t<NcIconSvgWrapper v-else-if=\"isChecked\" :path=\"mdiCheck\" class=\"action-button__pressed-icon\" />\n\n\t\t\t<span v-else-if=\"isChecked === false\" class=\"action-button__pressed-icon material-design-icon\" />\n\n\t\t\t<!-- fake slot to gather inner text -->\n\t\t\t<slot v-if=\"false\" />\n\t\t</button>\n\t</li>\n</template>\n\n<script>\nimport { mdiCheck, mdiChevronRight } from '@mdi/js'\nimport NcIconSvgWrapper from '../NcIconSvgWrapper/NcIconSvgWrapper.vue'\nimport ActionTextMixin from '../../mixins/actionText.js'\n\n/**\n * Button component to be used in Actions\n */\nexport default {\n\tname: 'NcActionButton',\n\n\tcomponents: {\n\t\tNcIconSvgWrapper,\n\t},\n\n\tmixins: [ActionTextMixin],\n\n\tinject: {\n\t\tisInSemanticMenu: {\n\t\t\tfrom: 'NcActions:isSemanticMenu',\n\t\t\tdefault: false,\n\t\t},\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * @deprecated To be removed in @nextcloud/vue 9. Migration guide: remove ariaHidden prop from NcAction* components.\n\t\t * @todo Add a check in @nextcloud/vue 9 that this prop is not provided,\n\t\t * otherwise root element will inherit incorrect aria-hidden.\n\t\t */\n\t\tariaHidden: {\n\t\t\ttype: Boolean,\n\t\t\t// eslint-disable-next-line vue/no-boolean-default\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * disabled state of the action button\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 * If this is a menu, a chevron icon will\n\t\t * be added at the end of the line\n\t\t */\n\t\tisMenu: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * The button's behavior, by default the button acts like a normal button with optional toggle button behavior if `modelValue` is `true` or `false`.\n\t\t * But you can also set to checkbox button behavior with tri-state or radio button like behavior.\n\t\t * This extends the native HTML button type attribute.\n\t\t */\n\t\ttype: {\n\t\t\ttype: String,\n\t\t\tdefault: 'button',\n\t\t\tvalidator: (behavior) => ['button', 'checkbox', 'radio', 'reset', 'submit'].includes(behavior),\n\t\t},\n\n\t\t/**\n\t\t * The buttons state if `type` is 'checkbox' or 'radio' (meaning if it is pressed / selected).\n\t\t * For checkbox and toggle button behavior - boolean value.\n\t\t * For radio button behavior - could be a boolean checked or a string with the value of the button.\n\t\t * Note: Unlike native radio buttons, NcActionButton are not grouped by name, so you need to connect them by bind correct modelValue.\n\t\t *\n\t\t * **This is not availabe for `type='submit'` or `type='reset'`**\n\t\t *\n\t\t * If using `type='checkbox'` a `model-value` of `true` means checked, `false` means unchecked and `null` means indeterminate (tri-state)\n\t\t * For `type='radio'` `null` is equal to `false`\n\t\t */\n\t\tmodelValue: {\n\t\t\ttype: [Boolean, String],\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * The value used for the `modelValue` when this component is used with radio behavior\n\t\t * Similar to the `value` attribute of `<input type=\"radio\">`\n\t\t */\n\t\tvalue: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Small underlying text content of the entry\n\t\t */\n\t\tdescription: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t},\n\n\tsetup() {\n\t\treturn {\n\t\t\tmdiCheck,\n\t\t\tmdiChevronRight,\n\t\t}\n\t},\n\n\tcomputed: {\n\t\t/**\n\t\t * determines if the action is focusable\n\t\t *\n\t\t * @return {boolean} is the action focusable ?\n\t\t */\n\t\tisFocusable() {\n\t\t\treturn !this.disabled\n\t\t},\n\n\t\t/**\n\t\t * The current \"checked\" or \"pressed\" state for the model behavior\n\t\t */\n\t\tisChecked() {\n\t\t\tif (this.type === 'radio' && typeof this.modelValue !== 'boolean') {\n\t\t\t\treturn this.modelValue === this.value\n\t\t\t}\n\t\t\treturn this.modelValue\n\t\t},\n\n\t\t/**\n\t\t * The native HTML type to set on the button\n\t\t */\n\t\tnativeType() {\n\t\t\tif (this.type === 'submit' || this.type === 'reset') {\n\t\t\t\treturn this.type\n\t\t\t}\n\t\t\treturn 'button'\n\t\t},\n\n\t\t/**\n\t\t * HTML attributes to bind to the <button>\n\t\t */\n\t\tbuttonAttributes() {\n\t\t\tconst attributes = {}\n\n\t\t\tif (this.isInSemanticMenu) {\n\t\t\t\t// By default it needs to be a menu item in semantic menus\n\t\t\t\tattributes.role = 'menuitem'\n\n\t\t\t\tif (this.type === 'radio') {\n\t\t\t\t\tattributes.role = 'menuitemradio'\n\t\t\t\t\tattributes['aria-checked'] = this.isChecked ? 'true' : 'false'\n\t\t\t\t} else if (this.type === 'checkbox' || (this.nativeType === 'button' && this.modelValue !== null)) {\n\t\t\t\t\t// either if checkbox behavior was set or the model value is not unset\n\t\t\t\t\tattributes.role = 'menuitemcheckbox'\n\t\t\t\t\tattributes['aria-checked'] = this.modelValue === null ? 'mixed' : (this.modelValue ? 'true' : 'false')\n\t\t\t\t}\n\t\t\t} else if (this.modelValue !== null && this.nativeType === 'button') {\n\t\t\t\t// In case this has a modelValue it is considered a toggle button, so we need to set the aria-pressed\n\t\t\t\tattributes['aria-pressed'] = this.modelValue ? 'true' : 'false'\n\t\t\t}\n\n\t\t\treturn attributes\n\t\t},\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Forward click event, let mixin handle the close-after-click and emit new modelValue if needed\n\t\t *\n\t\t * @param {MouseEvent} event The click event\n\t\t */\n\t\thandleClick(event) {\n\t\t\tthis.onClick(event)\n\t\t\t// If modelValue or type is set (so modelValue might be null for tri-state) we need to update it\n\t\t\tif (this.modelValue !== null || this.type !== 'button') {\n\t\t\t\tif (this.type === 'radio') {\n\t\t\t\t\tif (typeof this.modelValue !== 'boolean') {\n\t\t\t\t\t\t// String-value radios behavior is similar to native - click on checked radio does nothing\n\t\t\t\t\t\tif (!this.isChecked) {\n\t\t\t\t\t\t\tthis.$emit('update:modelValue', this.value)\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Boolean radio allows to uncheck\n\t\t\t\t\t\tthis.$emit('update:modelValue', !this.isChecked)\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// Checkbox toggles value\n\t\t\t\t\tthis.$emit('update:modelValue', !this.isChecked)\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n@use '../../assets/action.scss' as *;\n@include action-active;\n@include action--disabled;\n@include action-item('button');\n\n.action-button {\n\t&__pressed-icon {\n\t\tmargin-inline: auto calc($icon-margin * -1);\n\t}\n\n\t* {\n\t\tcursor: pointer;\n\t}\n}\n</style>\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"NcActionButton-w5F9kCHW.mjs","sources":["../../src/components/NcActionButton/NcActionButton.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nThis component is made to be used inside of the [NcActions](#NcActions) component slots.\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Delete')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDelete\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :close-after-click=\"true\" @click=\"showMessage('Delete and close menu')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDelete and close\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :is-menu=\"true\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tCreate\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :disabled=\"true\" @click=\"showMessage('Disabled')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tDisabled button\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Delete from 'vue-material-design-icons/Delete.vue'\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tDelete,\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n```\n\nIf you're using a long text, you can specify a `name` prop.\n\nFor the same purpose, but in a more compact way, `description` prop can be used.\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Add')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tAdd new\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton name=\"Long button\" @click=\"showMessage('Delete')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Delete :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tThis button is associated with a very long text.\\nAnd with new lines too.\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton description=\"Subline description for the button\" @click=\"showMessage('Edit')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Pencil :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tEdit\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Delete from 'vue-material-design-icons/Delete.vue'\n\timport Pencil from 'vue-material-design-icons/Pencil.vue'\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tDelete,\n\t\t\tPencil,\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n\n```\n\nAction icon attribute with a single action\n\n```vue\n\t<template>\n\t\t<NcActions>\n\t\t\t<NcActionButton @click=\"showMessage('Add')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tAdd new\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</template>\n\t<script>\n\timport Plus from 'vue-material-design-icons/Plus.vue'\n\n\texport default {\n\t\tcomponents: {\n\t\t\tPlus,\n\t\t},\n\t\tmethods: {\n\t\t\tshowMessage(msg) {\n\t\t\t\talert(msg)\n\t\t\t},\n\t\t},\n\t}\n\t</script>\n\n```\n\nYou can also use a custom icon, for example from the vue-material-design-icons library:\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton>\n\t\t\t<template #icon>\n\t\t\t\t<HandBackLeft :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise left hand\n\t\t</NcActionButton>\n\t\t<NcActionButton>\n\t\t\t<template #icon>\n\t\t\t\t<HandBackRight :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise right hand\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport HandBackLeft from 'vue-material-design-icons/HandBackLeft.vue'\nimport HandBackRight from 'vue-material-design-icons/HandBackRight.vue'\n\nexport default {\n\tcomponents: {\n\t\tHandBackLeft,\n\t\tHandBackRight,\n\t},\n}\n</script>\n```\n\n### With different model behavior\nBy default the button will act like a normal button, but it is also possible to change the behavior to a toggle button, checkbox button or radio button.\n\nFor example to have the button act like a toggle button just set the `modelValue` property to the toggle state:\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton :model-value.sync=\"fullscreen\">\n\t\t\t<template #icon>\n\t\t\t\t<Fullscreen :size=\"20\" />\n\t\t\t</template>\n\t\t\tFullscreen\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport Fullscreen from 'vue-material-design-icons/Fullscreen.vue'\n\nexport default {\n\tcomponents: {\n\t\tFullscreen,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tfullscreen: true,\n\t\t}\n\t},\n}\n</script>\n```\n\nAnother example would be using it with checkbox semantics, to enable or disable features.\nThis also allows tri-state behavior (`true`, `false`, `null`) in which case `aria-checked` will be either `true`, `false` or `mixed`.\n\n```vue\n<template>\n\t<NcActions>\n\t\t<NcActionButton :model-value.sync=\"handRaised\" type=\"checkbox\">\n\t\t\t<template #icon>\n\t\t\t\t<HandBackLeft :size=\"20\" />\n\t\t\t</template>\n\t\t\tRaise hand\n\t\t</NcActionButton>\n\t\t<NcActionButton :model-value.sync=\"fullscreen\" type=\"checkbox\">\n\t\t\t<template #icon>\n\t\t\t\t<Fullscreen :size=\"20\" />\n\t\t\t</template>\n\t\t\tFullscreen\n\t\t</NcActionButton>\n\t</NcActions>\n</template>\n<script>\nimport HandBackLeft from 'vue-material-design-icons/HandBackLeft.vue'\nimport Fullscreen from 'vue-material-design-icons/Fullscreen.vue'\n\nexport default {\n\tcomponents: {\n\t\tHandBackLeft,\n\t\tFullscreen,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tfullscreen: true,\n\t\t\thandRaised: false,\n\t\t}\n\t},\n}\n</script>\n```\n\nIt is also possible to use the button with radio semantics, this is only possible in menus and not for inline actions!\n\nWith a string `modelValue`, checked state is determined by the `value` property and updates `modelValue` with the new `value` string.\n\nWith a boolean `modelValue`, checked state is determined by `modelValue` and updates to `true` on check.\n\nNote: unlike native radio buttons, `NcActionButton` are not grouped by name, so you need to connect them by bind correct `modelValue``.\n\n```vue\n<template>\n\t<div>\n\t\t<NcActions>\n\t\t\t<NcActionButton :model-value.sync=\"payment\" type=\"radio\" value=\"cash\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Cash :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tPay with cash\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton :model-value.sync=\"payment\" type=\"radio\" value=\"card\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<CreditCard :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tPay by card\n\t\t\t</NcActionButton>\n\t\t\t<NcActionSeparator />\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isLeft\" @update:modelValue=\"setAlign('Left', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignLeft :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tLeft\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isCenter\" @update:modelValue=\"setAlign('Center', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignCenter :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tCenter\n\t\t\t</NcActionButton>\n\t\t\t<NcActionButton type=\"radio\" :model-value=\"align.isRight\" @update:modelValue=\"setAlign('Right', $event)\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<FormatAlignRight :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tRight\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t\t<p>payment = \"{{ payment }}\"</p>\n\t\t<p>align.isLeft = {{ align.isLeft }}</p>\n\t\t<p>align.isCenter = {{ align.isCenter }}</p>\n\t\t<p>align.isRight = {{ align.isRight }}</p>\n\t</div>\n</template>\n<script>\nimport Cash from 'vue-material-design-icons/Cash.vue'\nimport CreditCard from 'vue-material-design-icons/CreditCard.vue'\nimport FormatAlignLeft from 'vue-material-design-icons/FormatAlignLeft.vue'\nimport FormatAlignCenter from 'vue-material-design-icons/FormatAlignCenter.vue'\nimport FormatAlignRight from 'vue-material-design-icons/FormatAlignRight.vue'\n\nexport default {\n\tcomponents: {\n\t\tCash,\n\t\tCreditCard,\n\t\tFormatAlignLeft,\n\t\tFormatAlignCenter,\n\t\tFormatAlignRight,\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tpayment: 'card',\n\t\t\talign: {\n\t\t\t\tisLeft: false,\n\t\t\t\tisCenter: true,\n\t\t\t\tisRight: false,\n\t\t\t},\n\t\t}\n\t},\n\tmethods: {\n\t\tsetAlign(direction, value) {\n\t\t\tthis.align.isLeft = false\n\t\t\tthis.align.isCenter = false\n\t\t\tthis.align.isRight = false\n\t\t\tthis.align[`is${direction}`] = value\n\t\t},\n\t}\n}\n</script>\n```\n</docs>\n\n<template>\n\t<li class=\"action\" :class=\"{ 'action--disabled': disabled }\" :role=\"isInSemanticMenu && 'presentation'\">\n\t\t<button\n\t\t\t:aria-label=\"ariaLabel\"\n\t\t\tclass=\"action-button button-vue\"\n\t\t\t:class=\"{\n\t\t\t\t'action-button--active': isChecked,\n\t\t\t\tfocusable: isFocusable,\n\t\t\t}\"\n\t\t\t:disabled=\"disabled\"\n\t\t\t:title=\"title\"\n\t\t\t:type=\"nativeType\"\n\t\t\tv-bind=\"buttonAttributes\"\n\t\t\t@click=\"handleClick\">\n\t\t\t<!-- @slot Manually provide icon -->\n\t\t\t<slot name=\"icon\">\n\t\t\t\t<span\n\t\t\t\t\t:class=\"[isIconUrl ? 'action-button__icon--url' : icon]\"\n\t\t\t\t\t:style=\"{ backgroundImage: isIconUrl ? `url(${icon})` : null }\"\n\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\tclass=\"action-button__icon\" />\n\t\t\t</slot>\n\n\t\t\t<!-- long text with name -->\n\t\t\t<span class=\"action-button__longtext-wrapper\">\n\t\t\t\t<strong\n\t\t\t\t\tv-if=\"name\"\n\t\t\t\t\tclass=\"action-button__name\">\n\t\t\t\t\t{{ name }}\n\t\t\t\t</strong>\n\t\t\t\t<!-- white space is shown on longtext, so we can't\n\t\t\t\t\tput {{ text }} on a new line for code readability -->\n\t\t\t\t<span\n\t\t\t\t\tv-if=\"isLongText\"\n\t\t\t\t\tclass=\"action-button__longtext\"\n\t\t\t\t\tv-text=\"text\" />\n\t\t\t\t<!-- default text display -->\n\t\t\t\t<span\n\t\t\t\t\tv-else\n\t\t\t\t\tclass=\"action-button__text\">\n\t\t\t\t\t{{ text }}\n\t\t\t\t</span>\n\t\t\t\t<span\n\t\t\t\t\tv-if=\"description\"\n\t\t\t\t\tclass=\"action-button__description\"\n\t\t\t\t\tv-text=\"description\" />\n\t\t\t</span>\n\n\t\t\t<!-- right(in LTR) or left(in RTL) arrow icon when there is a sub-menu -->\n\t\t\t<NcIconSvgWrapper\n\t\t\t\tv-if=\"isMenu\"\n\t\t\t\tclass=\"action-button__menu-icon\"\n\t\t\t\tdirectional\n\t\t\t\t:path=\"mdiChevronRight\" />\n\t\t\t<NcIconSvgWrapper v-else-if=\"isChecked\" :path=\"mdiCheck\" class=\"action-button__pressed-icon\" />\n\n\t\t\t<span v-else-if=\"isChecked === false\" class=\"action-button__pressed-icon material-design-icon\" />\n\n\t\t\t<!-- fake slot to gather inner text -->\n\t\t\t<slot v-if=\"false\" />\n\t\t</button>\n\t</li>\n</template>\n\n<script>\nimport { mdiCheck, mdiChevronRight } from '@mdi/js'\nimport NcIconSvgWrapper from '../NcIconSvgWrapper/NcIconSvgWrapper.vue'\nimport ActionTextMixin from '../../mixins/actionText.js'\n\n/**\n * Button component to be used in Actions\n */\nexport default {\n\tname: 'NcActionButton',\n\n\tcomponents: {\n\t\tNcIconSvgWrapper,\n\t},\n\n\tmixins: [ActionTextMixin],\n\n\tinject: {\n\t\tisInSemanticMenu: {\n\t\t\tfrom: 'NcActions:isSemanticMenu',\n\t\t\tdefault: false,\n\t\t},\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * @deprecated To be removed in @nextcloud/vue 9. Migration guide: remove ariaHidden prop from NcAction* components.\n\t\t * @todo Add a check in @nextcloud/vue 9 that this prop is not provided,\n\t\t * otherwise root element will inherit incorrect aria-hidden.\n\t\t */\n\t\tariaHidden: {\n\t\t\ttype: Boolean,\n\t\t\t// eslint-disable-next-line vue/no-boolean-default\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * disabled state of the action button\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 * If this is a menu, a chevron icon will\n\t\t * be added at the end of the line\n\t\t */\n\t\tisMenu: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false,\n\t\t},\n\n\t\t/**\n\t\t * The button's behavior, by default the button acts like a normal button with optional toggle button behavior if `modelValue` is `true` or `false`.\n\t\t * But you can also set to checkbox button behavior with tri-state or radio button like behavior.\n\t\t * This extends the native HTML button type attribute.\n\t\t */\n\t\ttype: {\n\t\t\ttype: String,\n\t\t\tdefault: 'button',\n\t\t\tvalidator: (behavior) => ['button', 'checkbox', 'radio', 'reset', 'submit'].includes(behavior),\n\t\t},\n\n\t\t/**\n\t\t * The buttons state if `type` is 'checkbox' or 'radio' (meaning if it is pressed / selected).\n\t\t * For checkbox and toggle button behavior - boolean value.\n\t\t * For radio button behavior - could be a boolean checked or a string with the value of the button.\n\t\t * Note: Unlike native radio buttons, NcActionButton are not grouped by name, so you need to connect them by bind correct modelValue.\n\t\t *\n\t\t * **This is not availabe for `type='submit'` or `type='reset'`**\n\t\t *\n\t\t * If using `type='checkbox'` a `model-value` of `true` means checked, `false` means unchecked and `null` means indeterminate (tri-state)\n\t\t * For `type='radio'` `null` is equal to `false`\n\t\t */\n\t\tmodelValue: {\n\t\t\ttype: [Boolean, String],\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * The value used for the `modelValue` when this component is used with radio behavior\n\t\t * Similar to the `value` attribute of `<input type=\"radio\">`\n\t\t */\n\t\tvalue: {\n\t\t\ttype: String,\n\t\t\tdefault: null,\n\t\t},\n\n\t\t/**\n\t\t * Small underlying text content of the entry\n\t\t */\n\t\tdescription: {\n\t\t\ttype: String,\n\t\t\tdefault: '',\n\t\t},\n\t},\n\n\tsetup() {\n\t\treturn {\n\t\t\tmdiCheck,\n\t\t\tmdiChevronRight,\n\t\t}\n\t},\n\n\tcomputed: {\n\t\t/**\n\t\t * determines if the action is focusable\n\t\t *\n\t\t * @return {boolean} is the action focusable ?\n\t\t */\n\t\tisFocusable() {\n\t\t\treturn !this.disabled\n\t\t},\n\n\t\t/**\n\t\t * The current \"checked\" or \"pressed\" state for the model behavior\n\t\t */\n\t\tisChecked() {\n\t\t\tif (this.type === 'radio' && typeof this.modelValue !== 'boolean') {\n\t\t\t\treturn this.modelValue === this.value\n\t\t\t}\n\t\t\treturn this.modelValue\n\t\t},\n\n\t\t/**\n\t\t * The native HTML type to set on the button\n\t\t */\n\t\tnativeType() {\n\t\t\tif (this.type === 'submit' || this.type === 'reset') {\n\t\t\t\treturn this.type\n\t\t\t}\n\t\t\treturn 'button'\n\t\t},\n\n\t\t/**\n\t\t * HTML attributes to bind to the <button>\n\t\t */\n\t\tbuttonAttributes() {\n\t\t\tconst attributes = {}\n\n\t\t\tif (this.isInSemanticMenu) {\n\t\t\t\t// By default it needs to be a menu item in semantic menus\n\t\t\t\tattributes.role = 'menuitem'\n\n\t\t\t\tif (this.type === 'radio') {\n\t\t\t\t\tattributes.role = 'menuitemradio'\n\t\t\t\t\tattributes['aria-checked'] = this.isChecked ? 'true' : 'false'\n\t\t\t\t} else if (this.type === 'checkbox' || (this.nativeType === 'button' && this.modelValue !== null)) {\n\t\t\t\t\t// either if checkbox behavior was set or the model value is not unset\n\t\t\t\t\tattributes.role = 'menuitemcheckbox'\n\t\t\t\t\tattributes['aria-checked'] = this.modelValue === null ? 'mixed' : (this.modelValue ? 'true' : 'false')\n\t\t\t\t}\n\t\t\t} else if (this.modelValue !== null && this.nativeType === 'button') {\n\t\t\t\t// In case this has a modelValue it is considered a toggle button, so we need to set the aria-pressed\n\t\t\t\tattributes['aria-pressed'] = this.modelValue ? 'true' : 'false'\n\t\t\t}\n\n\t\t\treturn attributes\n\t\t},\n\t},\n\n\tmethods: {\n\t\t/**\n\t\t * Forward click event, let mixin handle the close-after-click and emit new modelValue if needed\n\t\t *\n\t\t * @param {MouseEvent} event The click event\n\t\t */\n\t\thandleClick(event) {\n\t\t\tthis.onClick(event)\n\t\t\t// If modelValue or type is set (so modelValue might be null for tri-state) we need to update it\n\t\t\tif (this.modelValue !== null || this.type !== 'button') {\n\t\t\t\tif (this.type === 'radio') {\n\t\t\t\t\tif (typeof this.modelValue !== 'boolean') {\n\t\t\t\t\t\t// String-value radios behavior is similar to native - click on checked radio does nothing\n\t\t\t\t\t\tif (!this.isChecked) {\n\t\t\t\t\t\t\tthis.$emit('update:modelValue', this.value)\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Boolean radio allows to uncheck\n\t\t\t\t\t\tthis.$emit('update:modelValue', !this.isChecked)\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// Checkbox toggles value\n\t\t\t\t\tthis.$emit('update:modelValue', !this.isChecked)\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t},\n}\n</script>\n\n<style lang=\"scss\" scoped>\n@use '../../assets/action.scss' as *;\n@include action-active;\n@include action--disabled;\n@include action-item('button');\n\n.action-button {\n\t&__pressed-icon {\n\t\tmargin-inline: auto calc($icon-margin * -1);\n\t}\n\n\t* {\n\t\tcursor: pointer;\n\t}\n}\n</style>\n"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import '../assets/NcActionButtonGroup-CRXLyFpx.css';
|
|
2
2
|
import { defineComponent } from "vue";
|
|
3
|
-
import { r as register, a as t } from "./_l10n-
|
|
3
|
+
import { r as register, a as t } from "./_l10n-BcrsamRV.mjs";
|
|
4
4
|
import { G as GenRandomId } from "./GenRandomId-F5ebeBB_.mjs";
|
|
5
5
|
import { n as normalizeComponent } from "./_plugin-vue2_normalizer-DU4iP6Vu.mjs";
|
|
6
6
|
register();
|
|
@@ -49,4 +49,4 @@ const NcActionButtonGroup = __component__.exports;
|
|
|
49
49
|
export {
|
|
50
50
|
NcActionButtonGroup as N
|
|
51
51
|
};
|
|
52
|
-
//# sourceMappingURL=NcActionButtonGroup-
|
|
52
|
+
//# sourceMappingURL=NcActionButtonGroup-Dl_0bIqn.mjs.map
|
package/dist/chunks/{NcActionButtonGroup-D_ldp8Lw.mjs.map → NcActionButtonGroup-Dl_0bIqn.mjs.map}
RENAMED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NcActionButtonGroup-
|
|
1
|
+
{"version":3,"file":"NcActionButtonGroup-Dl_0bIqn.mjs","sources":["../../src/components/NcActionButtonGroup/NcActionButtonGroup.vue"],"sourcesContent":["<!--\n - SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n-->\n\n<docs>\nThis component is made to be used inside of the [NcActions](#NcActions) component slots,\nto group buttons as one visual action, like for text alignment.\nThis should be used sparingly for accessibility.\n\n```vue\n<template>\n\t<div style=\"display: flex; align-items: center;\">\n\t\t<NcActions>\n\t\t\t<NcActionButtonGroup name=\"Text alignment\">\n\t\t\t\t<NcActionButton aria-label=\"Align left\"\n\t\t\t\t\t:model-value.sync=\"alignment\"\n\t\t\t\t\ttype=\"radio\"\n\t\t\t\t\tvalue=\"l\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<AlignLeft :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton aria-label=\"Align center\"\n\t\t\t\t\t:model-value.sync=\"alignment\"\n\t\t\t\t\ttype=\"radio\"\n\t\t\t\t\tvalue=\"c\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<AlignCenter :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t</NcActionButton>\n\t\t\t\t<NcActionButton aria-label=\"Align right\"\n\t\t\t\t\t:model-value.sync=\"alignment\"\n\t\t\t\t\ttype=\"radio\"\n\t\t\t\t\tvalue=\"r\">\n\t\t\t\t\t<template #icon>\n\t\t\t\t\t\t<AlignRight :size=\"20\" />\n\t\t\t\t\t</template>\n\t\t\t\t</NcActionButton>\n\t\t\t</NcActionButtonGroup>\n\t\t\t<NcActionButton :close-after-click=\"true\"\n\t\t\t\t@click=\"showMessage('Some other action')\">\n\t\t\t\t<template #icon>\n\t\t\t\t\t<Plus :size=\"20\" />\n\t\t\t\t</template>\n\t\t\t\tSome other action\n\t\t\t</NcActionButton>\n\t\t</NcActions>\n\t</div>\n</template>\n<script>\nimport AlignLeft from 'vue-material-design-icons/AlignHorizontalLeft'\nimport AlignRight from 'vue-material-design-icons/AlignHorizontalRight'\nimport AlignCenter from 'vue-material-design-icons/AlignHorizontalCenter'\nimport Plus from 'vue-material-design-icons/Plus'\n\nexport default {\n\tcomponents: {\n\t\tAlignLeft,\n\t\tAlignRight,\n\t\tAlignCenter,\n\t\tPlus,\n\t},\n\tdata() {\n\t\treturn { alignment: 'l' }\n\t},\n\tmethods: {\n\t\tshowMessage(msg) {\n\t\t\talert(msg)\n\t\t},\n\t},\n}\n</script>\n```\n</docs>\n\n<template>\n\t<li class=\"nc-button-group-base\" :role=\"isInSemanticMenu && 'presentation'\">\n\t\t<div v-if=\"name\" :id=\"labelId\">\n\t\t\t{{ name }}\n\t\t</div>\n\t\t<ul class=\"nc-button-group-content\" role=\"group\" :aria-labelledby=\"name ? labelId : undefined\">\n\t\t\t<slot />\n\t\t</ul>\n\t</li>\n</template>\n\n<script>\nimport { defineComponent } from 'vue'\nimport { t } from '../../l10n.js'\nimport GenRandomId from '../../utils/GenRandomId.js'\n\n/**\n * A wrapper for allowing inlining NcAction components within the action menu\n */\nexport default defineComponent({\n\tname: 'NcActionButtonGroup',\n\n\tinject: {\n\t\tisInSemanticMenu: {\n\t\t\tfrom: 'NcActions:isSemanticMenu',\n\t\t\tdefault: false,\n\t\t},\n\t},\n\n\tprops: {\n\t\t/**\n\t\t * Optional text shown below the button group\n\t\t */\n\t\tname: {\n\t\t\trequired: false,\n\t\t\tdefault: undefined,\n\t\t\ttype: String,\n\t\t},\n\t},\n\n\tsetup() {\n\t\treturn {\n\t\t\tlabelId: `nc-action-button-group-${GenRandomId()}`,\n\t\t}\n\t},\n\n\tmethods: {\n\t\tt,\n\t},\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nc-button-group-base {\n\t>div {\n\t\ttext-align: center;\n\t\tcolor: var(--color-text-maxcontrast);\n\t}\n\n\tul.nc-button-group-content {\n\t\tdisplay: flex;\n\t\tgap: 4px; // required for the focus-visible outline\n\t\tjustify-content: space-between;\n\n\t\t:deep(li) {\n\t\t\tflex: 1 1;\n\t\t}\n\n\t\t:deep(.action-button) {\n\t\t\t// Fix action buttons beeing shifted to the left (right padding)\n\t\t\tpadding: 0 !important;\n\t\t\twidth: 100%;\n\t\t\tdisplay: flex;\n\t\t\tjustify-content: center;\n\n\t\t\t&.action-button--active {\n\t\t\t\tbackground-color: var(--color-primary-element);\n\t\t\t\tborder-radius: var(--border-radius-large);\n\t\t\t\tcolor: var(--color-primary-element-text);\n\n\t\t\t\t&:hover, &:focus, &:focus-within {\n\t\t\t\t\tbackground-color: var(--color-primary-element-hover);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t.action-button__pressed-icon {\n\t\t\t\tdisplay: none;\n\t\t\t}\n\t\t}\n\t}\n}\n</style>\n"],"names":[],"mappings":";;;;;AA+FA,MAAA,YAAA,gBAAA;AAAA,EACA,MAAA;AAAA,EAEA,QAAA;AAAA,IACA,kBAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,OAAA;AAAA;AAAA;AAAA;AAAA,IAIA,MAAA;AAAA,MACA,UAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,QAAA;AACA,WAAA;AAAA,MACA,SAAA,0BAAA,YAAA,CAAA;AAAA,IACA;AAAA,EACA;AAAA,EAEA,SAAA;AAAA,IACA;AAAA,EACA;AACA,CAAA;;;;;;;;;;;;;;;;"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
require('../assets/NcActionButtonGroup-CRXLyFpx.css');
|
|
2
2
|
"use strict";
|
|
3
3
|
const Vue = require("vue");
|
|
4
|
-
const _l10n = require("./_l10n-
|
|
4
|
+
const _l10n = require("./_l10n-IBFNlYqh.cjs");
|
|
5
5
|
const GenRandomId = require("./GenRandomId-D7iOvpZS.cjs");
|
|
6
6
|
const _pluginVue2_normalizer = require("./_plugin-vue2_normalizer-V0q-tHlQ.cjs");
|
|
7
7
|
_l10n.register();
|
|
@@ -48,4 +48,4 @@ var __component__ = /* @__PURE__ */ _pluginVue2_normalizer.normalizeComponent(
|
|
|
48
48
|
);
|
|
49
49
|
const NcActionButtonGroup = __component__.exports;
|
|
50
50
|
exports.NcActionButtonGroup = NcActionButtonGroup;
|
|
51
|
-
//# sourceMappingURL=NcActionButtonGroup-
|
|
51
|
+
//# sourceMappingURL=NcActionButtonGroup-E-6SoAHx.cjs.map
|