@abraca/nuxt 1.8.2 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +27 -2
- package/dist/module.d.mts +4 -3
- package/dist/module.json +1 -1
- package/dist/module.mjs +50 -4
- package/dist/runtime/components/ADocumentTree.vue +1 -1
- package/dist/runtime/components/AEditor.d.vue.ts +26 -1
- package/dist/runtime/components/AEditor.vue +153 -4
- package/dist/runtime/components/AEditor.vue.d.ts +26 -1
- package/dist/runtime/components/AIdentityModal.d.vue.ts +46 -0
- package/dist/runtime/components/AIdentityModal.vue +157 -0
- package/dist/runtime/components/AIdentityModal.vue.d.ts +46 -0
- package/dist/runtime/components/AMnemonicLoginModal.d.vue.ts +35 -0
- package/dist/runtime/components/AMnemonicLoginModal.vue +173 -0
- package/dist/runtime/components/AMnemonicLoginModal.vue.d.ts +35 -0
- package/dist/runtime/components/ANodePanel.d.vue.ts +29 -2
- package/dist/runtime/components/ANodePanel.vue +148 -27
- package/dist/runtime/components/ANodePanel.vue.d.ts +29 -2
- package/dist/runtime/components/ANodePanelHeader.d.vue.ts +64 -0
- package/dist/runtime/components/ANodePanelHeader.vue +105 -0
- package/dist/runtime/components/ANodePanelHeader.vue.d.ts +64 -0
- package/dist/runtime/components/ANodeSettingsPanel.d.vue.ts +49 -0
- package/dist/runtime/components/ANodeSettingsPanel.vue +59 -0
- package/dist/runtime/components/ANodeSettingsPanel.vue.d.ts +49 -0
- package/dist/runtime/components/ANotificationBell.d.vue.ts +26 -0
- package/dist/runtime/components/ANotificationBell.vue +55 -0
- package/dist/runtime/components/ANotificationBell.vue.d.ts +26 -0
- package/dist/runtime/components/AOfflineSync.d.vue.ts +11 -0
- package/dist/runtime/components/AOfflineSync.vue +217 -0
- package/dist/runtime/components/AOfflineSync.vue.d.ts +11 -0
- package/dist/runtime/components/ARecoveryPhraseDisplay.d.vue.ts +26 -0
- package/dist/runtime/components/ARecoveryPhraseDisplay.vue +94 -0
- package/dist/runtime/components/ARecoveryPhraseDisplay.vue.d.ts +26 -0
- package/dist/runtime/components/AServerInfoModal.d.vue.ts +43 -0
- package/dist/runtime/components/AServerInfoModal.vue +150 -0
- package/dist/runtime/components/AServerInfoModal.vue.d.ts +43 -0
- package/dist/runtime/components/ASpaceFormModal.vue +1 -1
- package/dist/runtime/components/aware/AAccordion.d.vue.ts +25 -0
- package/dist/runtime/components/aware/AAccordion.vue +107 -0
- package/dist/runtime/components/aware/AAccordion.vue.d.ts +25 -0
- package/dist/runtime/components/aware/AArea.vue +24 -11
- package/dist/runtime/components/aware/AAvatar.d.vue.ts +6 -0
- package/dist/runtime/components/aware/AAvatar.vue +33 -3
- package/dist/runtime/components/aware/AAvatar.vue.d.ts +6 -0
- package/dist/runtime/components/aware/AAvatarGroup.d.vue.ts +10 -0
- package/dist/runtime/components/aware/AAvatarGroup.vue +30 -0
- package/dist/runtime/components/aware/AAvatarGroup.vue.d.ts +10 -0
- package/dist/runtime/components/aware/AButton.d.vue.ts +4 -2
- package/dist/runtime/components/aware/AButton.vue +46 -14
- package/dist/runtime/components/aware/AButton.vue.d.ts +4 -2
- package/dist/runtime/components/aware/ACalendar.d.vue.ts +17 -0
- package/dist/runtime/components/aware/ACalendar.vue +145 -0
- package/dist/runtime/components/aware/ACalendar.vue.d.ts +17 -0
- package/dist/runtime/components/aware/ACarousel.d.vue.ts +25 -0
- package/dist/runtime/components/aware/ACarousel.vue +39 -0
- package/dist/runtime/components/aware/ACarousel.vue.d.ts +25 -0
- package/dist/runtime/components/aware/ACheckbox.d.vue.ts +11 -0
- package/dist/runtime/components/aware/ACheckbox.vue +74 -0
- package/dist/runtime/components/aware/ACheckbox.vue.d.ts +11 -0
- package/dist/runtime/components/aware/ACheckboxGroup.d.vue.ts +27 -0
- package/dist/runtime/components/aware/ACheckboxGroup.vue +79 -0
- package/dist/runtime/components/aware/ACheckboxGroup.vue.d.ts +27 -0
- package/dist/runtime/components/aware/ACollapsible.d.vue.ts +25 -0
- package/dist/runtime/components/aware/ACollapsible.vue +45 -0
- package/dist/runtime/components/aware/ACollapsible.vue.d.ts +25 -0
- package/dist/runtime/components/aware/AColorPicker.d.vue.ts +15 -0
- package/dist/runtime/components/aware/AColorPicker.vue +48 -0
- package/dist/runtime/components/aware/AColorPicker.vue.d.ts +15 -0
- package/dist/runtime/components/aware/ACommandPalette.d.vue.ts +33 -0
- package/dist/runtime/components/aware/ACommandPalette.vue +123 -0
- package/dist/runtime/components/aware/ACommandPalette.vue.d.ts +33 -0
- package/dist/runtime/components/aware/AContextMenu.d.vue.ts +25 -0
- package/dist/runtime/components/aware/AContextMenu.vue +63 -0
- package/dist/runtime/components/aware/AContextMenu.vue.d.ts +25 -0
- package/dist/runtime/components/aware/ADrawer.d.vue.ts +25 -0
- package/dist/runtime/components/aware/ADrawer.vue +57 -0
- package/dist/runtime/components/aware/ADrawer.vue.d.ts +25 -0
- package/dist/runtime/components/aware/ADropdownMenu.d.vue.ts +25 -0
- package/dist/runtime/components/aware/ADropdownMenu.vue +63 -0
- package/dist/runtime/components/aware/ADropdownMenu.vue.d.ts +25 -0
- package/dist/runtime/components/aware/AFileUpload.d.vue.ts +27 -0
- package/dist/runtime/components/aware/AFileUpload.vue +67 -0
- package/dist/runtime/components/aware/AFileUpload.vue.d.ts +27 -0
- package/dist/runtime/components/aware/AFollowBar.d.vue.ts +21 -0
- package/dist/runtime/components/aware/AFollowBar.vue +62 -0
- package/dist/runtime/components/aware/AFollowBar.vue.d.ts +21 -0
- package/dist/runtime/components/aware/AFollowScroll.d.vue.ts +7 -0
- package/dist/runtime/components/aware/AFollowScroll.vue +17 -0
- package/dist/runtime/components/aware/AFollowScroll.vue.d.ts +7 -0
- package/dist/runtime/components/aware/AFormSync.d.vue.ts +21 -0
- package/dist/runtime/components/aware/AFormSync.vue +52 -0
- package/dist/runtime/components/aware/AFormSync.vue.d.ts +21 -0
- package/dist/runtime/components/aware/AGlobalFocusLayer.d.vue.ts +3 -0
- package/dist/runtime/components/aware/AGlobalFocusLayer.vue +90 -0
- package/dist/runtime/components/aware/AGlobalFocusLayer.vue.d.ts +3 -0
- package/dist/runtime/components/aware/AHoverItem.d.vue.ts +27 -0
- package/dist/runtime/components/aware/AHoverItem.vue +124 -0
- package/dist/runtime/components/aware/AHoverItem.vue.d.ts +27 -0
- package/dist/runtime/components/aware/AInput.d.vue.ts +12 -2
- package/dist/runtime/components/aware/AInput.vue +72 -19
- package/dist/runtime/components/aware/AInput.vue.d.ts +12 -2
- package/dist/runtime/components/aware/AInputMenu.d.vue.ts +17 -0
- package/dist/runtime/components/aware/AInputMenu.vue +138 -0
- package/dist/runtime/components/aware/AInputMenu.vue.d.ts +17 -0
- package/dist/runtime/components/aware/AInputNumber.d.vue.ts +15 -0
- package/dist/runtime/components/aware/AInputNumber.vue +67 -0
- package/dist/runtime/components/aware/AInputNumber.vue.d.ts +15 -0
- package/dist/runtime/components/aware/AInputTags.d.vue.ts +15 -0
- package/dist/runtime/components/aware/AInputTags.vue +67 -0
- package/dist/runtime/components/aware/AInputTags.vue.d.ts +15 -0
- package/dist/runtime/components/aware/AKeyHint.d.vue.ts +3 -0
- package/dist/runtime/components/aware/AKeyHint.vue +23 -0
- package/dist/runtime/components/aware/AKeyHint.vue.d.ts +3 -0
- package/dist/runtime/components/aware/AMedia.d.vue.ts +19 -0
- package/dist/runtime/components/aware/AMedia.vue +85 -0
- package/dist/runtime/components/aware/AMedia.vue.d.ts +19 -0
- package/dist/runtime/components/aware/AModal.d.vue.ts +33 -0
- package/dist/runtime/components/aware/AModal.vue +110 -0
- package/dist/runtime/components/aware/AModal.vue.d.ts +33 -0
- package/dist/runtime/components/aware/ANavigationMenu.d.vue.ts +25 -0
- package/dist/runtime/components/aware/ANavigationMenu.vue +82 -0
- package/dist/runtime/components/aware/ANavigationMenu.vue.d.ts +25 -0
- package/dist/runtime/components/aware/APagination.d.vue.ts +13 -0
- package/dist/runtime/components/aware/APagination.vue +53 -0
- package/dist/runtime/components/aware/APagination.vue.d.ts +13 -0
- package/dist/runtime/components/aware/APeerCaretLayer.d.vue.ts +10 -0
- package/dist/runtime/components/aware/APeerCaretLayer.vue +133 -0
- package/dist/runtime/components/aware/APeerCaretLayer.vue.d.ts +10 -0
- package/dist/runtime/components/aware/APinInput.d.vue.ts +15 -0
- package/dist/runtime/components/aware/APinInput.vue +48 -0
- package/dist/runtime/components/aware/APinInput.vue.d.ts +15 -0
- package/dist/runtime/components/aware/APopover.d.vue.ts +25 -0
- package/dist/runtime/components/aware/APopover.vue +57 -0
- package/dist/runtime/components/aware/APopover.vue.d.ts +25 -0
- package/dist/runtime/components/aware/APresenceBlobs.d.vue.ts +3 -0
- package/dist/runtime/components/aware/APresenceBlobs.vue +69 -0
- package/dist/runtime/components/aware/APresenceBlobs.vue.d.ts +3 -0
- package/dist/runtime/components/aware/APresenceCursors.d.vue.ts +20 -0
- package/dist/runtime/components/aware/APresenceCursors.vue +47 -0
- package/dist/runtime/components/aware/APresenceCursors.vue.d.ts +20 -0
- package/dist/runtime/components/aware/ARadioGroup.d.vue.ts +27 -0
- package/dist/runtime/components/aware/ARadioGroup.vue +86 -0
- package/dist/runtime/components/aware/ARadioGroup.vue.d.ts +27 -0
- package/dist/runtime/components/aware/AScroll.d.vue.ts +25 -0
- package/dist/runtime/components/aware/AScroll.vue +87 -0
- package/dist/runtime/components/aware/AScroll.vue.d.ts +25 -0
- package/dist/runtime/components/aware/ASelect.d.vue.ts +12 -2
- package/dist/runtime/components/aware/ASelect.vue +146 -22
- package/dist/runtime/components/aware/ASelect.vue.d.ts +12 -2
- package/dist/runtime/components/aware/ASelectMenu.d.vue.ts +17 -0
- package/dist/runtime/components/aware/ASelectMenu.vue +139 -0
- package/dist/runtime/components/aware/ASelectMenu.vue.d.ts +17 -0
- package/dist/runtime/components/aware/ASlideover.d.vue.ts +33 -0
- package/dist/runtime/components/aware/ASlideover.vue +110 -0
- package/dist/runtime/components/aware/ASlideover.vue.d.ts +33 -0
- package/dist/runtime/components/aware/ASlider.d.vue.ts +19 -0
- package/dist/runtime/components/aware/ASlider.vue +77 -0
- package/dist/runtime/components/aware/ASlider.vue.d.ts +19 -0
- package/dist/runtime/components/aware/AStepper.d.vue.ts +25 -0
- package/dist/runtime/components/aware/AStepper.vue +82 -0
- package/dist/runtime/components/aware/AStepper.vue.d.ts +25 -0
- package/dist/runtime/components/aware/ASwitch.d.vue.ts +11 -0
- package/dist/runtime/components/aware/ASwitch.vue +75 -0
- package/dist/runtime/components/aware/ASwitch.vue.d.ts +11 -0
- package/dist/runtime/components/aware/ATable.d.vue.ts +23 -0
- package/dist/runtime/components/aware/ATable.vue +97 -0
- package/dist/runtime/components/aware/ATable.vue.d.ts +23 -0
- package/dist/runtime/components/aware/ATabs.d.vue.ts +27 -0
- package/dist/runtime/components/aware/ATabs.vue +128 -0
- package/dist/runtime/components/aware/ATabs.vue.d.ts +27 -0
- package/dist/runtime/components/aware/ATextarea.d.vue.ts +12 -2
- package/dist/runtime/components/aware/ATextarea.vue +72 -19
- package/dist/runtime/components/aware/ATextarea.vue.d.ts +12 -2
- package/dist/runtime/components/aware/AToggleGroup.d.vue.ts +27 -0
- package/dist/runtime/components/aware/AToggleGroup.vue +79 -0
- package/dist/runtime/components/aware/AToggleGroup.vue.d.ts +27 -0
- package/dist/runtime/components/aware/ATree.d.vue.ts +27 -0
- package/dist/runtime/components/aware/ATree.vue +111 -0
- package/dist/runtime/components/aware/ATree.vue.d.ts +27 -0
- package/dist/runtime/components/chat/AChatPanel.d.vue.ts +6 -6
- package/dist/runtime/components/chat/AChatPanel.vue.d.ts +6 -6
- package/dist/runtime/components/chat/ANodeChatPanel.d.vue.ts +42 -0
- package/dist/runtime/components/chat/ANodeChatPanel.vue +53 -0
- package/dist/runtime/components/chat/ANodeChatPanel.vue.d.ts +42 -0
- package/dist/runtime/components/docs/ADocsNavigation.d.vue.ts +155 -0
- package/dist/runtime/components/docs/ADocsNavigation.vue +154 -0
- package/dist/runtime/components/docs/ADocsNavigation.vue.d.ts +155 -0
- package/dist/runtime/components/docs/ADocsSearch.d.vue.ts +249 -0
- package/dist/runtime/components/docs/ADocsSearch.vue +187 -0
- package/dist/runtime/components/docs/ADocsSearch.vue.d.ts +249 -0
- package/dist/runtime/components/docs/ADocsSearchButton.d.vue.ts +253 -0
- package/dist/runtime/components/docs/ADocsSearchButton.vue +99 -0
- package/dist/runtime/components/docs/ADocsSearchButton.vue.d.ts +253 -0
- package/dist/runtime/components/docs/ADocsSurround.d.vue.ts +56 -0
- package/dist/runtime/components/docs/ADocsSurround.vue +68 -0
- package/dist/runtime/components/docs/ADocsSurround.vue.d.ts +56 -0
- package/dist/runtime/components/docs/ADocsToc.d.vue.ts +117 -0
- package/dist/runtime/components/docs/ADocsToc.vue +194 -0
- package/dist/runtime/components/docs/ADocsToc.vue.d.ts +117 -0
- package/dist/runtime/components/editor/ADocLinkPopover.vue +1 -5
- package/dist/runtime/components/editor/AEditorRedoButton.d.vue.ts +26 -0
- package/dist/runtime/components/editor/AEditorRedoButton.vue +38 -0
- package/dist/runtime/components/editor/AEditorRedoButton.vue.d.ts +26 -0
- package/dist/runtime/components/editor/AEditorUndoButton.d.vue.ts +26 -0
- package/dist/runtime/components/editor/AEditorUndoButton.vue +38 -0
- package/dist/runtime/components/editor/AEditorUndoButton.vue.d.ts +26 -0
- package/dist/runtime/components/editor/AIconPickerPopover.d.vue.ts +24 -0
- package/dist/runtime/components/editor/AIconPickerPopover.vue +113 -0
- package/dist/runtime/components/editor/AIconPickerPopover.vue.d.ts +24 -0
- package/dist/runtime/components/editor/ANodeInlineLabel.d.vue.ts +24 -0
- package/dist/runtime/components/editor/ANodeInlineLabel.vue +101 -0
- package/dist/runtime/components/editor/ANodeInlineLabel.vue.d.ts +24 -0
- package/dist/runtime/components/renderers/ADocLoadError.d.vue.ts +3 -0
- package/dist/runtime/components/renderers/ADocLoadError.vue +11 -0
- package/dist/runtime/components/renderers/ADocLoadError.vue.d.ts +3 -0
- package/dist/runtime/components/renderers/ADocLoadingSkeleton.d.vue.ts +3 -0
- package/dist/runtime/components/renderers/ADocLoadingSkeleton.vue +5 -0
- package/dist/runtime/components/renderers/ADocLoadingSkeleton.vue.d.ts +3 -0
- package/dist/runtime/components/renderers/AMediaRenderer.vue +1 -1
- package/dist/runtime/components/renderers/AOverviewRenderer.d.vue.ts +22 -0
- package/dist/runtime/components/renderers/AOverviewRenderer.vue +1041 -0
- package/dist/runtime/components/renderers/AOverviewRenderer.vue.d.ts +22 -0
- package/dist/runtime/components/renderers/AProseRenderer.d.vue.ts +23 -0
- package/dist/runtime/components/renderers/AProseRenderer.vue +31 -0
- package/dist/runtime/components/renderers/AProseRenderer.vue.d.ts +23 -0
- package/dist/runtime/components/renderers/ASheetsRenderer.client.d.vue.ts +19 -0
- package/dist/runtime/components/renderers/ASheetsRenderer.client.vue +865 -0
- package/dist/runtime/components/renderers/ASheetsRenderer.client.vue.d.ts +19 -0
- package/dist/runtime/components/renderers/calendar/ACalendarDayCell.d.vue.ts +14 -0
- package/dist/runtime/components/renderers/calendar/ACalendarDayCell.vue +45 -15
- package/dist/runtime/components/renderers/calendar/ACalendarDayCell.vue.d.ts +14 -0
- package/dist/runtime/components/renderers/calendar/ACalendarDayView.d.vue.ts +15 -0
- package/dist/runtime/components/renderers/calendar/ACalendarDayView.vue +93 -20
- package/dist/runtime/components/renderers/calendar/ACalendarDayView.vue.d.ts +15 -0
- package/dist/runtime/components/renderers/calendar/ACalendarEventChip.d.vue.ts +9 -0
- package/dist/runtime/components/renderers/calendar/ACalendarEventChip.vue +31 -2
- package/dist/runtime/components/renderers/calendar/ACalendarEventChip.vue.d.ts +9 -0
- package/dist/runtime/components/renderers/calendar/ACalendarToolbar.d.vue.ts +4 -4
- package/dist/runtime/components/renderers/calendar/ACalendarToolbar.vue.d.ts +4 -4
- package/dist/runtime/components/renderers/calendar/ACalendarWeekView.d.vue.ts +15 -0
- package/dist/runtime/components/renderers/calendar/ACalendarWeekView.vue +94 -21
- package/dist/runtime/components/renderers/calendar/ACalendarWeekView.vue.d.ts +15 -0
- package/dist/runtime/components/renderers/media/MediaTransportBar.d.vue.ts +2 -2
- package/dist/runtime/components/renderers/media/MediaTransportBar.vue.d.ts +2 -2
- package/dist/runtime/components/renderers/sheets/ASheetsCell.d.vue.ts +45 -0
- package/dist/runtime/components/renderers/sheets/ASheetsCell.vue +123 -0
- package/dist/runtime/components/renderers/sheets/ASheetsCell.vue.d.ts +45 -0
- package/dist/runtime/components/renderers/sheets/ASheetsGrid.d.vue.ts +111 -0
- package/dist/runtime/components/renderers/sheets/ASheetsGrid.vue +737 -0
- package/dist/runtime/components/renderers/sheets/ASheetsGrid.vue.d.ts +111 -0
- package/dist/runtime/components/renderers/sheets/ASheetsMobileActionBar.d.vue.ts +26 -0
- package/dist/runtime/components/renderers/sheets/ASheetsMobileActionBar.vue +100 -0
- package/dist/runtime/components/renderers/sheets/ASheetsMobileActionBar.vue.d.ts +26 -0
- package/dist/runtime/components/renderers/sheets/ASheetsToolbar.d.vue.ts +48 -0
- package/dist/runtime/components/renderers/sheets/ASheetsToolbar.vue +243 -0
- package/dist/runtime/components/renderers/sheets/ASheetsToolbar.vue.d.ts +48 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellColor.d.vue.ts +1 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellColor.vue +13 -32
- package/dist/runtime/components/renderers/table/cells/ATableCellColor.vue.d.ts +1 -0
- package/dist/runtime/components/renderers/timeline/ATimelineBar.d.vue.ts +6 -0
- package/dist/runtime/components/renderers/timeline/ATimelineBar.vue +34 -4
- package/dist/runtime/components/renderers/timeline/ATimelineBar.vue.d.ts +6 -0
- package/dist/runtime/components/renderers/timeline/ATimelineBarArea.d.vue.ts +16 -0
- package/dist/runtime/components/renderers/timeline/ATimelineBarArea.vue +14 -3
- package/dist/runtime/components/renderers/timeline/ATimelineBarArea.vue.d.ts +16 -0
- package/dist/runtime/components/renderers/timeline/ATimelineLabelPanel.d.vue.ts +13 -1
- package/dist/runtime/components/renderers/timeline/ATimelineLabelPanel.vue +114 -47
- package/dist/runtime/components/renderers/timeline/ATimelineLabelPanel.vue.d.ts +13 -1
- package/dist/runtime/components/renderers/timeline/ATimelineMilestone.d.vue.ts +4 -0
- package/dist/runtime/components/renderers/timeline/ATimelineMilestone.vue +21 -4
- package/dist/runtime/components/renderers/timeline/ATimelineMilestone.vue.d.ts +4 -0
- package/dist/runtime/components/renderers/timeline/ATimelineToolbar.d.vue.ts +2 -2
- package/dist/runtime/components/renderers/timeline/ATimelineToolbar.vue.d.ts +2 -2
- package/dist/runtime/components/settings/ASettingsSpacesPanel.vue +7 -25
- package/dist/runtime/components/shell/ADocPanelSettings.d.vue.ts +34 -4
- package/dist/runtime/components/shell/ADocPanelSettings.vue +289 -2
- package/dist/runtime/components/shell/ADocPanelSettings.vue.d.ts +34 -4
- package/dist/runtime/components/shell/ASyncStatus.d.vue.ts +1 -1
- package/dist/runtime/components/shell/ASyncStatus.vue.d.ts +1 -1
- package/dist/runtime/components/shell/AUserMenu.d.vue.ts +2 -2
- package/dist/runtime/components/shell/AUserMenu.vue.d.ts +2 -2
- package/dist/runtime/components/shell/AWelcomeScreen.d.vue.ts +1 -1
- package/dist/runtime/components/shell/AWelcomeScreen.vue.d.ts +1 -1
- package/dist/runtime/composables/useAACaret.d.ts +29 -0
- package/dist/runtime/composables/useAACaret.js +64 -0
- package/dist/runtime/composables/useAAEphemeral.d.ts +32 -0
- package/dist/runtime/composables/useAAEphemeral.js +33 -0
- package/dist/runtime/composables/useAAField.d.ts +10 -2
- package/dist/runtime/composables/useAAField.js +31 -2
- package/dist/runtime/composables/useAAFieldValue.d.ts +26 -0
- package/dist/runtime/composables/useAAFieldValue.js +32 -0
- package/dist/runtime/composables/useAAFocus.d.ts +68 -0
- package/dist/runtime/composables/useAAFocus.js +174 -0
- package/dist/runtime/composables/useAAFollowAnchor.d.ts +25 -0
- package/dist/runtime/composables/useAAFollowAnchor.js +69 -0
- package/dist/runtime/composables/useAAFollowPeer.d.ts +29 -0
- package/dist/runtime/composables/useAAFollowPeer.js +75 -0
- package/dist/runtime/composables/useAAKey.d.ts +22 -0
- package/dist/runtime/composables/useAAKey.js +24 -0
- package/dist/runtime/composables/useAAPointer.d.ts +30 -0
- package/dist/runtime/composables/useAAPointer.js +53 -0
- package/dist/runtime/composables/useAAUIState.d.ts +29 -0
- package/dist/runtime/composables/useAAUIState.js +28 -0
- package/dist/runtime/composables/useAAViewport.d.ts +22 -0
- package/dist/runtime/composables/useAAViewport.js +50 -0
- package/dist/runtime/composables/useAbraAdmin.d.ts +54 -0
- package/dist/runtime/composables/useAbraAdmin.js +115 -0
- package/dist/runtime/composables/useAbracadabraAuth.d.ts +8 -0
- package/dist/runtime/composables/useAbracadabraAuth.js +8 -0
- package/dist/runtime/composables/useAggregatedPresence.d.ts +23 -0
- package/dist/runtime/composables/useAggregatedPresence.js +140 -0
- package/dist/runtime/composables/useChat.d.ts +16 -2
- package/dist/runtime/composables/useChat.js +257 -66
- package/dist/runtime/composables/useChatUsers.d.ts +2 -0
- package/dist/runtime/composables/useChatUsers.js +2 -1
- package/dist/runtime/composables/useDocLookup.d.ts +4 -0
- package/dist/runtime/composables/useDocLookup.js +25 -0
- package/dist/runtime/composables/useDocSnapshots.d.ts +79 -0
- package/dist/runtime/composables/useDocSnapshots.js +234 -0
- package/dist/runtime/composables/useDocsSearch.d.ts +24 -0
- package/dist/runtime/composables/useDocsSearch.js +34 -0
- package/dist/runtime/composables/useEditorDragHandle.d.ts +7 -0
- package/dist/runtime/composables/useEditorDragHandle.js +19 -1
- package/dist/runtime/composables/useEditorSuggestions.js +26 -1
- package/dist/runtime/composables/useEditorToolbar.js +9 -1
- package/dist/runtime/composables/useEmailVerification.d.ts +33 -0
- package/dist/runtime/composables/useEmailVerification.js +58 -0
- package/dist/runtime/composables/useIdentityDoc.js +0 -3
- package/dist/runtime/composables/useItemPresence.d.ts +47 -0
- package/dist/runtime/composables/useItemPresence.js +73 -0
- package/dist/runtime/composables/useResizableWidth.d.ts +24 -0
- package/dist/runtime/composables/useResizableWidth.js +87 -0
- package/dist/runtime/composables/useServerInfo.d.ts +17 -2
- package/dist/runtime/composables/useServerInfo.js +30 -6
- package/dist/runtime/composables/useServerSearch.d.ts +36 -0
- package/dist/runtime/composables/useServerSearch.js +91 -0
- package/dist/runtime/composables/useServerTrash.d.ts +67 -0
- package/dist/runtime/composables/useServerTrash.js +128 -0
- package/dist/runtime/composables/useSheetsClipboard.d.ts +42 -0
- package/dist/runtime/composables/useSheetsClipboard.js +109 -0
- package/dist/runtime/composables/useSheetsFormulas.d.ts +38 -0
- package/dist/runtime/composables/useSheetsFormulas.js +725 -0
- package/dist/runtime/composables/useSheetsSelection.d.ts +68 -0
- package/dist/runtime/composables/useSheetsSelection.js +390 -0
- package/dist/runtime/composables/useSheetsView.d.ts +31 -0
- package/dist/runtime/composables/useSheetsView.js +77 -0
- package/dist/runtime/composables/useSpaceConnections.d.ts +43 -0
- package/dist/runtime/composables/useSpaceConnections.js +72 -0
- package/dist/runtime/composables/useSpaces.d.ts +1 -3
- package/dist/runtime/composables/useSpaces.js +2 -5
- package/dist/runtime/composables/useTiptapHistory.d.ts +22 -0
- package/dist/runtime/composables/useTiptapHistory.js +12 -0
- package/dist/runtime/composables/useTreeExpansion.d.ts +28 -0
- package/dist/runtime/composables/useTreeExpansion.js +94 -0
- package/dist/runtime/composables/useYDoc.js +12 -1
- package/dist/runtime/extensions/button.d.ts +3 -0
- package/dist/runtime/extensions/button.js +62 -0
- package/dist/runtime/extensions/color-swatch.d.ts +2 -0
- package/dist/runtime/extensions/color-swatch.js +34 -0
- package/dist/runtime/extensions/diff.d.ts +2 -0
- package/dist/runtime/extensions/diff.js +40 -0
- package/dist/runtime/extensions/divider.d.ts +2 -0
- package/dist/runtime/extensions/divider.js +33 -0
- package/dist/runtime/extensions/doc-embed.js +2 -1
- package/dist/runtime/extensions/doc-link-drop.js +4 -4
- package/dist/runtime/extensions/doc-link.d.ts +12 -0
- package/dist/runtime/extensions/doc-link.js +60 -0
- package/dist/runtime/extensions/embed.d.ts +2 -0
- package/dist/runtime/extensions/embed.js +40 -0
- package/dist/runtime/extensions/figure.d.ts +2 -0
- package/dist/runtime/extensions/figure.js +49 -0
- package/dist/runtime/extensions/math.d.ts +15 -0
- package/dist/runtime/extensions/math.js +66 -0
- package/dist/runtime/extensions/progress.d.ts +2 -0
- package/dist/runtime/extensions/progress.js +43 -0
- package/dist/runtime/extensions/quote.d.ts +2 -0
- package/dist/runtime/extensions/quote.js +39 -0
- package/dist/runtime/extensions/spoiler.d.ts +2 -0
- package/dist/runtime/extensions/spoiler.js +36 -0
- package/dist/runtime/extensions/stat.d.ts +3 -0
- package/dist/runtime/extensions/stat.js +58 -0
- package/dist/runtime/extensions/video.d.ts +2 -0
- package/dist/runtime/extensions/video.js +40 -0
- package/dist/runtime/extensions/views/ButtonGroupView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/ButtonGroupView.vue +25 -0
- package/dist/runtime/extensions/views/ButtonGroupView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/ButtonView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/ButtonView.vue +171 -0
- package/dist/runtime/extensions/views/ButtonView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/ColorSwatchView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/ColorSwatchView.vue +134 -0
- package/dist/runtime/extensions/views/ColorSwatchView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/DiffView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/DiffView.vue +163 -0
- package/dist/runtime/extensions/views/DiffView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/DividerView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/DividerView.vue +40 -0
- package/dist/runtime/extensions/views/DividerView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/DocEmbedView.vue +18 -3
- package/dist/runtime/extensions/views/DocLinkView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/DocLinkView.vue +71 -0
- package/dist/runtime/extensions/views/DocLinkView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/EmbedView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/EmbedView.vue +166 -0
- package/dist/runtime/extensions/views/EmbedView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/FigureView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/FigureView.vue +122 -0
- package/dist/runtime/extensions/views/FigureView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/FileNodeView.vue +21 -24
- package/dist/runtime/extensions/views/MathBlockView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/MathBlockView.vue +151 -0
- package/dist/runtime/extensions/views/MathBlockView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/MathInlineView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/MathInlineView.vue +149 -0
- package/dist/runtime/extensions/views/MathInlineView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/MetaFieldView.vue +1129 -550
- package/dist/runtime/extensions/views/ProgressView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/ProgressView.vue +156 -0
- package/dist/runtime/extensions/views/ProgressView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/QuoteView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/QuoteView.vue +128 -0
- package/dist/runtime/extensions/views/QuoteView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/SpoilerView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/SpoilerView.vue +62 -0
- package/dist/runtime/extensions/views/SpoilerView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/StatGroupView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/StatGroupView.vue +25 -0
- package/dist/runtime/extensions/views/StatGroupView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/StatView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/StatView.vue +89 -0
- package/dist/runtime/extensions/views/StatView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/VideoView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/VideoView.vue +190 -0
- package/dist/runtime/extensions/views/VideoView.vue.d.ts +4 -0
- package/dist/runtime/locale.d.ts +133 -0
- package/dist/runtime/locale.js +121 -2
- package/dist/runtime/plugin-abracadabra.client.js +251 -38
- package/dist/runtime/plugin-abracadabra.server.js +0 -1
- package/dist/runtime/plugins/core.plugin.js +76 -4
- package/dist/runtime/server/plugins/abracadabra-service.js +4 -2
- package/dist/runtime/server/utils/rpcHandler.d.ts +74 -0
- package/dist/runtime/server/utils/rpcHandler.js +74 -0
- package/dist/runtime/server/utils/spaceManager.js +10 -9
- package/dist/runtime/theme/content/_shared.d.ts +6 -0
- package/dist/runtime/theme/content/_shared.js +6 -0
- package/dist/runtime/theme/content/content-navigation.d.ts +120 -0
- package/dist/runtime/theme/content/content-navigation.js +155 -0
- package/dist/runtime/theme/content/content-search-button.d.ts +16 -0
- package/dist/runtime/theme/content/content-search-button.js +15 -0
- package/dist/runtime/theme/content/content-search.d.ts +24 -0
- package/dist/runtime/theme/content/content-search.js +23 -0
- package/dist/runtime/theme/content/content-surround.d.ts +22 -0
- package/dist/runtime/theme/content/content-surround.js +23 -0
- package/dist/runtime/theme/content/content-toc.d.ts +84 -0
- package/dist/runtime/theme/content/content-toc.js +94 -0
- package/dist/runtime/theme/content/index.d.ts +5 -0
- package/dist/runtime/theme/content/index.js +5 -0
- package/dist/runtime/types.d.ts +63 -10
- package/dist/runtime/utils/awareRingStyle.d.ts +22 -0
- package/dist/runtime/utils/awareRingStyle.js +16 -0
- package/dist/runtime/utils/caretCoordinates.d.ts +41 -0
- package/dist/runtime/utils/caretCoordinates.js +126 -0
- package/dist/runtime/utils/content.d.ts +19 -0
- package/dist/runtime/utils/content.js +23 -0
- package/dist/runtime/utils/docReferenceEdges.js +1 -1
- package/dist/runtime/utils/docTypes.js +44 -13
- package/dist/runtime/utils/domPath.d.ts +42 -0
- package/dist/runtime/utils/domPath.js +89 -0
- package/dist/runtime/utils/loadKatex.d.ts +1 -0
- package/dist/runtime/utils/loadKatex.js +29 -0
- package/dist/runtime/utils/lucideIcons.d.ts +16 -0
- package/dist/runtime/utils/lucideIcons.js +451 -0
- package/dist/runtime/utils/time.d.ts +15 -0
- package/dist/runtime/utils/time.js +5 -0
- package/dist/types.d.mts +4 -0
- package/package.json +38 -20
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { NodeViewProps } from '@tiptap/vue-3';
|
|
2
|
+
declare const __VLS_export: import("vue").DefineComponent<NodeViewProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<NodeViewProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
3
|
+
declare const _default: typeof __VLS_export;
|
|
4
|
+
export default _default;
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { ref, computed } from "vue";
|
|
3
|
+
import { NodeViewWrapper } from "@tiptap/vue-3";
|
|
4
|
+
import ANodeInlineLabel from "../../components/editor/ANodeInlineLabel.vue";
|
|
5
|
+
const props = defineProps({
|
|
6
|
+
decorations: { type: Array, required: true },
|
|
7
|
+
selected: { type: Boolean, required: true },
|
|
8
|
+
updateAttributes: { type: Function, required: true },
|
|
9
|
+
deleteNode: { type: Function, required: true },
|
|
10
|
+
node: { type: null, required: true },
|
|
11
|
+
view: { type: null, required: true },
|
|
12
|
+
getPos: { type: null, required: true },
|
|
13
|
+
innerDecorations: { type: null, required: true },
|
|
14
|
+
editor: { type: Object, required: true },
|
|
15
|
+
extension: { type: Object, required: true },
|
|
16
|
+
HTMLAttributes: { type: Object, required: true }
|
|
17
|
+
});
|
|
18
|
+
const before = computed(() => props.node.attrs.before || "");
|
|
19
|
+
const after = computed(() => props.node.attrs.after || "");
|
|
20
|
+
const language = computed(() => props.node.attrs.language || "text");
|
|
21
|
+
const editMode = ref(false);
|
|
22
|
+
function lineDiff(a, b) {
|
|
23
|
+
const aLines = a.split("\n");
|
|
24
|
+
const bLines = b.split("\n");
|
|
25
|
+
const m = aLines.length;
|
|
26
|
+
const n = bLines.length;
|
|
27
|
+
const dp = Array.from({ length: m + 1 }, () => Array(n + 1).fill(0));
|
|
28
|
+
for (let i2 = m - 1; i2 >= 0; i2--) {
|
|
29
|
+
for (let j2 = n - 1; j2 >= 0; j2--) {
|
|
30
|
+
if (aLines[i2] === bLines[j2]) dp[i2][j2] = (dp[i2 + 1][j2 + 1] ?? 0) + 1;
|
|
31
|
+
else dp[i2][j2] = Math.max(dp[i2 + 1][j2] ?? 0, dp[i2][j2 + 1] ?? 0);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
const result = [];
|
|
35
|
+
let i = 0;
|
|
36
|
+
let j = 0;
|
|
37
|
+
while (i < m && j < n) {
|
|
38
|
+
if (aLines[i] === bLines[j]) {
|
|
39
|
+
result.push({ op: "equal", line: aLines[i] });
|
|
40
|
+
i++;
|
|
41
|
+
j++;
|
|
42
|
+
} else if ((dp[i + 1][j] ?? 0) >= (dp[i][j + 1] ?? 0)) {
|
|
43
|
+
result.push({ op: "remove", line: aLines[i] });
|
|
44
|
+
i++;
|
|
45
|
+
} else {
|
|
46
|
+
result.push({ op: "add", line: bLines[j] });
|
|
47
|
+
j++;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
while (i < m) result.push({ op: "remove", line: aLines[i++] });
|
|
51
|
+
while (j < n) result.push({ op: "add", line: bLines[j++] });
|
|
52
|
+
return result;
|
|
53
|
+
}
|
|
54
|
+
const diffLines = computed(() => lineDiff(before.value, after.value));
|
|
55
|
+
const added = computed(() => diffLines.value.filter((d) => d.op === "add").length);
|
|
56
|
+
const removed = computed(() => diffLines.value.filter((d) => d.op === "remove").length);
|
|
57
|
+
function setBefore(v) {
|
|
58
|
+
props.updateAttributes({ before: v });
|
|
59
|
+
}
|
|
60
|
+
function setAfter(v) {
|
|
61
|
+
props.updateAttributes({ after: v });
|
|
62
|
+
}
|
|
63
|
+
function setLanguage(v) {
|
|
64
|
+
props.updateAttributes({ language: v.trim() || "text" });
|
|
65
|
+
}
|
|
66
|
+
</script>
|
|
67
|
+
|
|
68
|
+
<template>
|
|
69
|
+
<NodeViewWrapper
|
|
70
|
+
as="div"
|
|
71
|
+
class="my-5 border border-(--ui-border) rounded-md overflow-hidden"
|
|
72
|
+
contenteditable="false"
|
|
73
|
+
>
|
|
74
|
+
<div class="flex items-center justify-between px-3 py-1.5 border-b border-(--ui-border-muted) bg-(--ui-bg-elevated)/40 text-sm gap-2">
|
|
75
|
+
<div class="flex items-center gap-2 font-mono text-xs text-(--ui-text-muted)">
|
|
76
|
+
<UIcon
|
|
77
|
+
name="i-lucide-git-compare"
|
|
78
|
+
class="size-3.5"
|
|
79
|
+
/>
|
|
80
|
+
<ANodeInlineLabel
|
|
81
|
+
:model-value="language"
|
|
82
|
+
placeholder="text"
|
|
83
|
+
variant="label"
|
|
84
|
+
@update:model-value="setLanguage"
|
|
85
|
+
/>
|
|
86
|
+
</div>
|
|
87
|
+
<div class="flex items-center gap-2">
|
|
88
|
+
<span class="text-xs tabular-nums">
|
|
89
|
+
<span class="text-(--ui-success)">+{{ added }}</span>
|
|
90
|
+
<span class="mx-1 text-(--ui-text-muted)">/</span>
|
|
91
|
+
<span class="text-(--ui-error)">−{{ removed }}</span>
|
|
92
|
+
</span>
|
|
93
|
+
<UButton
|
|
94
|
+
size="xs"
|
|
95
|
+
color="neutral"
|
|
96
|
+
variant="ghost"
|
|
97
|
+
:icon="editMode ? 'i-lucide-check' : 'i-lucide-pencil'"
|
|
98
|
+
:label="editMode ? 'Done' : 'Edit'"
|
|
99
|
+
@click="editMode = !editMode"
|
|
100
|
+
/>
|
|
101
|
+
</div>
|
|
102
|
+
</div>
|
|
103
|
+
<div
|
|
104
|
+
v-if="editMode"
|
|
105
|
+
class="grid grid-cols-1 md:grid-cols-2 divide-y md:divide-y-0 md:divide-x divide-(--ui-border-muted)"
|
|
106
|
+
>
|
|
107
|
+
<div class="flex flex-col">
|
|
108
|
+
<div class="px-3 py-1 text-xs text-(--ui-text-muted) bg-(--ui-bg-elevated)/30 border-b border-(--ui-border-muted)">
|
|
109
|
+
Before
|
|
110
|
+
</div>
|
|
111
|
+
<textarea
|
|
112
|
+
:value="before"
|
|
113
|
+
class="flex-1 p-3 font-mono text-sm bg-transparent outline-none resize-none text-(--ui-text) min-h-[160px]"
|
|
114
|
+
placeholder="Original…"
|
|
115
|
+
spellcheck="false"
|
|
116
|
+
@input="(e) => setBefore(e.target.value)"
|
|
117
|
+
/>
|
|
118
|
+
</div>
|
|
119
|
+
<div class="flex flex-col">
|
|
120
|
+
<div class="px-3 py-1 text-xs text-(--ui-text-muted) bg-(--ui-bg-elevated)/30 border-b border-(--ui-border-muted)">
|
|
121
|
+
After
|
|
122
|
+
</div>
|
|
123
|
+
<textarea
|
|
124
|
+
:value="after"
|
|
125
|
+
class="flex-1 p-3 font-mono text-sm bg-transparent outline-none resize-none text-(--ui-text) min-h-[160px]"
|
|
126
|
+
placeholder="Changed…"
|
|
127
|
+
spellcheck="false"
|
|
128
|
+
@input="(e) => setAfter(e.target.value)"
|
|
129
|
+
/>
|
|
130
|
+
</div>
|
|
131
|
+
</div>
|
|
132
|
+
<div
|
|
133
|
+
v-else
|
|
134
|
+
class="font-mono text-sm overflow-x-auto"
|
|
135
|
+
>
|
|
136
|
+
<div
|
|
137
|
+
v-if="diffLines.length === 0"
|
|
138
|
+
class="px-3 py-4 text-(--ui-text-muted) text-center"
|
|
139
|
+
>
|
|
140
|
+
Empty — click Edit to add content
|
|
141
|
+
</div>
|
|
142
|
+
<div
|
|
143
|
+
v-for="(d, idx) in diffLines"
|
|
144
|
+
:key="idx"
|
|
145
|
+
class="flex items-start gap-2 px-3 py-0.5 whitespace-pre"
|
|
146
|
+
:class="{
|
|
147
|
+
'bg-green-500/10 text-(--ui-text-highlighted)': d.op === 'add',
|
|
148
|
+
'bg-red-500/10 text-(--ui-text-highlighted)': d.op === 'remove',
|
|
149
|
+
'text-(--ui-text)': d.op === 'equal'
|
|
150
|
+
}"
|
|
151
|
+
>
|
|
152
|
+
<span
|
|
153
|
+
class="w-4 shrink-0 text-(--ui-text-muted)"
|
|
154
|
+
:class="{
|
|
155
|
+
'text-(--ui-success)': d.op === 'add',
|
|
156
|
+
'text-(--ui-error)': d.op === 'remove'
|
|
157
|
+
}"
|
|
158
|
+
>{{ d.op === "add" ? "+" : d.op === "remove" ? "\u2212" : " " }}</span>
|
|
159
|
+
<span class="flex-1">{{ d.line || " " }}</span>
|
|
160
|
+
</div>
|
|
161
|
+
</div>
|
|
162
|
+
</NodeViewWrapper>
|
|
163
|
+
</template>
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { NodeViewProps } from '@tiptap/vue-3';
|
|
2
|
+
declare const __VLS_export: import("vue").DefineComponent<NodeViewProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<NodeViewProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
3
|
+
declare const _default: typeof __VLS_export;
|
|
4
|
+
export default _default;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { NodeViewProps } from '@tiptap/vue-3';
|
|
2
|
+
declare const __VLS_export: import("vue").DefineComponent<NodeViewProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<NodeViewProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
3
|
+
declare const _default: typeof __VLS_export;
|
|
4
|
+
export default _default;
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { computed } from "vue";
|
|
3
|
+
import { NodeViewWrapper } from "@tiptap/vue-3";
|
|
4
|
+
import ANodeInlineLabel from "../../components/editor/ANodeInlineLabel.vue";
|
|
5
|
+
const props = defineProps({
|
|
6
|
+
decorations: { type: Array, required: true },
|
|
7
|
+
selected: { type: Boolean, required: true },
|
|
8
|
+
updateAttributes: { type: Function, required: true },
|
|
9
|
+
deleteNode: { type: Function, required: true },
|
|
10
|
+
node: { type: null, required: true },
|
|
11
|
+
view: { type: null, required: true },
|
|
12
|
+
getPos: { type: null, required: true },
|
|
13
|
+
innerDecorations: { type: null, required: true },
|
|
14
|
+
editor: { type: Object, required: true },
|
|
15
|
+
extension: { type: Object, required: true },
|
|
16
|
+
HTMLAttributes: { type: Object, required: true }
|
|
17
|
+
});
|
|
18
|
+
const label = computed(() => props.node.attrs.label || "");
|
|
19
|
+
function setLabel(v) {
|
|
20
|
+
props.updateAttributes({ label: v });
|
|
21
|
+
}
|
|
22
|
+
</script>
|
|
23
|
+
|
|
24
|
+
<template>
|
|
25
|
+
<NodeViewWrapper
|
|
26
|
+
as="div"
|
|
27
|
+
class="my-6 flex items-center gap-3 text-(--ui-text-muted)"
|
|
28
|
+
contenteditable="false"
|
|
29
|
+
>
|
|
30
|
+
<div class="flex-1 h-px bg-(--ui-border)" />
|
|
31
|
+
<ANodeInlineLabel
|
|
32
|
+
:model-value="label"
|
|
33
|
+
placeholder="Add label"
|
|
34
|
+
variant="label"
|
|
35
|
+
class="text-xs uppercase tracking-wider"
|
|
36
|
+
@update:model-value="setLabel"
|
|
37
|
+
/>
|
|
38
|
+
<div class="flex-1 h-px bg-(--ui-border)" />
|
|
39
|
+
</NodeViewWrapper>
|
|
40
|
+
</template>
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { NodeViewProps } from '@tiptap/vue-3';
|
|
2
|
+
declare const __VLS_export: import("vue").DefineComponent<NodeViewProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<NodeViewProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
3
|
+
declare const _default: typeof __VLS_export;
|
|
4
|
+
export default _default;
|
|
@@ -57,12 +57,16 @@ function navigate() {
|
|
|
57
57
|
}
|
|
58
58
|
const collapsed = computed(() => props.node.attrs.collapsed);
|
|
59
59
|
const tall = computed(() => props.node.attrs.tall);
|
|
60
|
+
const seamless = computed(() => props.node.attrs.seamless);
|
|
60
61
|
function toggleCollapsed() {
|
|
61
62
|
props.updateAttributes({ collapsed: !collapsed.value });
|
|
62
63
|
}
|
|
63
64
|
function toggleHeight() {
|
|
64
65
|
props.updateAttributes({ tall: !tall.value });
|
|
65
66
|
}
|
|
67
|
+
function toggleSeamless() {
|
|
68
|
+
props.updateAttributes({ seamless: !seamless.value });
|
|
69
|
+
}
|
|
66
70
|
function removeEmbed() {
|
|
67
71
|
props.deleteNode();
|
|
68
72
|
}
|
|
@@ -73,6 +77,7 @@ function removeEmbed() {
|
|
|
73
77
|
<div
|
|
74
78
|
v-if="exists"
|
|
75
79
|
class="de-container"
|
|
80
|
+
:class="{ 'de-seamless': seamless }"
|
|
76
81
|
contenteditable="false"
|
|
77
82
|
>
|
|
78
83
|
<!-- Header -->
|
|
@@ -100,6 +105,7 @@ function removeEmbed() {
|
|
|
100
105
|
|
|
101
106
|
<div class="de-controls">
|
|
102
107
|
<button
|
|
108
|
+
v-if="!seamless"
|
|
103
109
|
class="de-ctrl-btn de-ctrl-toggle"
|
|
104
110
|
@click.stop="toggleCollapsed"
|
|
105
111
|
>
|
|
@@ -109,7 +115,7 @@ function removeEmbed() {
|
|
|
109
115
|
/>
|
|
110
116
|
</button>
|
|
111
117
|
<button
|
|
112
|
-
v-if="!collapsed"
|
|
118
|
+
v-if="!seamless && !collapsed"
|
|
113
119
|
class="de-ctrl-btn"
|
|
114
120
|
@click.stop="toggleHeight"
|
|
115
121
|
>
|
|
@@ -118,6 +124,15 @@ function removeEmbed() {
|
|
|
118
124
|
class="size-3"
|
|
119
125
|
/>
|
|
120
126
|
</button>
|
|
127
|
+
<button
|
|
128
|
+
class="de-ctrl-btn"
|
|
129
|
+
@click.stop="toggleSeamless"
|
|
130
|
+
>
|
|
131
|
+
<UIcon
|
|
132
|
+
:name="seamless ? 'i-lucide-frame' : 'i-lucide-square-dashed'"
|
|
133
|
+
class="size-3"
|
|
134
|
+
/>
|
|
135
|
+
</button>
|
|
121
136
|
<button
|
|
122
137
|
class="de-ctrl-btn de-ctrl-expand"
|
|
123
138
|
@click.stop="navigate"
|
|
@@ -142,7 +157,7 @@ function removeEmbed() {
|
|
|
142
157
|
<!-- Body -->
|
|
143
158
|
<div
|
|
144
159
|
class="de-body"
|
|
145
|
-
:class="{ 'de-body-tall': tall, 'de-body-collapsed': collapsed }"
|
|
160
|
+
:class="{ 'de-body-tall': tall && !seamless, 'de-body-collapsed': collapsed && !seamless, 'de-body-seamless': seamless }"
|
|
146
161
|
>
|
|
147
162
|
<div
|
|
148
163
|
v-if="isLoading"
|
|
@@ -194,5 +209,5 @@ function removeEmbed() {
|
|
|
194
209
|
</template>
|
|
195
210
|
|
|
196
211
|
<style scoped>
|
|
197
|
-
.de-container{background:var(--ui-bg);border:1px solid var(--ui-border);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.1),0 2px 8px rgba(0,0,0,.06);overflow:hidden;transition:box-shadow .28s ease}.de-container:has(.de-body-collapsed){box-shadow:0 2px 8px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.04)}.de-header{align-items:center;background:var(--ui-bg-elevated);border-bottom:1px solid var(--ui-border);cursor:grab;display:flex;flex-shrink:0;gap:6px;height:34px;padding:0 4px 0 10px;transition:border-color .28s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.de-header:active{cursor:grabbing}.de-header-collapsed{border-bottom-color:transparent}.de-body{display:flex;flex-direction:column;height:400px;overflow:hidden;transition:height .28s cubic-bezier(.4,0,.2,1),border-color .28s ease}.de-body-tall{height:700px}.de-body-collapsed{height:0}.de-title{align-items:center;display:flex;flex:1;gap:4px;min-width:0;overflow:hidden;pointer-events:none}.de-title button,.de-title-link{pointer-events:auto}.de-title-link{cursor:pointer}.de-title-link .de-title-text{color:var(--ui-primary);text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .12s}.de-title-link:hover .de-title-text{text-decoration-color:var(--ui-primary)}.de-title-text{color:var(--ui-text-muted);font-size:12px;font-weight:500;overflow:hidden;pointer-events:none;text-overflow:ellipsis;white-space:nowrap}.de-type-btn{align-items:center;border-radius:var(--ui-radius);color:var(--ui-text-muted);cursor:pointer;display:flex;flex-shrink:0;height:22px;justify-content:center;transition:background .1s,color .1s;width:22px}.de-type-btn:hover{background:var(--ui-bg-accented);color:var(--ui-text)}.de-controls{flex-shrink:0;gap:2px}.de-controls,.de-ctrl-btn{align-items:center;display:flex}.de-ctrl-btn{border-radius:50%;color:var(--ui-text-dimmed);cursor:pointer;height:22px;justify-content:center;transition:background .12s,color .12s;width:22px}.de-ctrl-btn:hover{background:var(--ui-bg-accented);color:var(--ui-text)}.de-ctrl-expand:hover{background:rgba(34,197,94,.15);color:#148f3e}.de-ctrl-close:hover{background:rgba(239,68,68,.15);color:#dc2626}
|
|
212
|
+
.de-container{background:var(--ui-bg);border:1px solid var(--ui-border);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.1),0 2px 8px rgba(0,0,0,.06);overflow:hidden;transition:box-shadow .28s ease}.de-container:has(.de-body-collapsed){box-shadow:0 2px 8px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.04)}.de-header{align-items:center;background:var(--ui-bg-elevated);border-bottom:1px solid var(--ui-border);cursor:grab;display:flex;flex-shrink:0;gap:6px;height:34px;padding:0 4px 0 10px;transition:border-color .28s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.de-header:active{cursor:grabbing}.de-header-collapsed{border-bottom-color:transparent}.de-body{display:flex;flex-direction:column;height:400px;overflow:hidden;transition:height .28s cubic-bezier(.4,0,.2,1),border-color .28s ease}.de-body-tall{height:700px}.de-body-collapsed{height:0}.de-seamless{background:transparent;border:none;box-shadow:none}.de-seamless .de-header{background:transparent;border-bottom:none;height:26px;opacity:0;pointer-events:none;transition:opacity .15s ease}.de-seamless:focus-within .de-header,.de-seamless:hover .de-header{opacity:1;pointer-events:auto}.de-body-seamless{height:auto;min-height:0}.de-title{align-items:center;display:flex;flex:1;gap:4px;min-width:0;overflow:hidden;pointer-events:none}.de-title button,.de-title-link{pointer-events:auto}.de-title-link{cursor:pointer}.de-title-link .de-title-text{color:var(--ui-primary);text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .12s}.de-title-link:hover .de-title-text{text-decoration-color:var(--ui-primary)}.de-title-text{color:var(--ui-text-muted);font-size:12px;font-weight:500;overflow:hidden;pointer-events:none;text-overflow:ellipsis;white-space:nowrap}.de-type-btn{align-items:center;border-radius:var(--ui-radius);color:var(--ui-text-muted);cursor:pointer;display:flex;flex-shrink:0;height:22px;justify-content:center;transition:background .1s,color .1s;width:22px}.de-type-btn:hover{background:var(--ui-bg-accented);color:var(--ui-text)}.de-controls{flex-shrink:0;gap:2px}.de-controls,.de-ctrl-btn{align-items:center;display:flex}.de-ctrl-btn{border-radius:50%;color:var(--ui-text-dimmed);cursor:pointer;height:22px;justify-content:center;transition:background .12s,color .12s;width:22px}.de-ctrl-btn:hover{background:var(--ui-bg-accented);color:var(--ui-text)}.de-ctrl-expand:hover{background:rgba(34,197,94,.15);color:#148f3e}.de-ctrl-close:hover{background:rgba(239,68,68,.15);color:#dc2626}
|
|
198
213
|
</style>
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { NodeViewProps } from '@tiptap/vue-3';
|
|
2
|
+
declare const __VLS_export: import("vue").DefineComponent<NodeViewProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<NodeViewProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
3
|
+
declare const _default: typeof __VLS_export;
|
|
4
|
+
export default _default;
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { NodeViewWrapper } from "@tiptap/vue-3";
|
|
3
|
+
import { computed } from "vue";
|
|
4
|
+
import { navigateTo } from "#imports";
|
|
5
|
+
import { useAbracadabra } from "../../composables/useAbracadabra";
|
|
6
|
+
import { useSyncedMap } from "../../composables/useYDoc";
|
|
7
|
+
import { resolveDocType } from "../../utils/docTypes";
|
|
8
|
+
const props = defineProps({
|
|
9
|
+
decorations: { type: Array, required: true },
|
|
10
|
+
selected: { type: Boolean, required: true },
|
|
11
|
+
updateAttributes: { type: Function, required: true },
|
|
12
|
+
deleteNode: { type: Function, required: true },
|
|
13
|
+
node: { type: null, required: true },
|
|
14
|
+
view: { type: null, required: true },
|
|
15
|
+
getPos: { type: null, required: true },
|
|
16
|
+
innerDecorations: { type: null, required: true },
|
|
17
|
+
editor: { type: Object, required: true },
|
|
18
|
+
extension: { type: Object, required: true },
|
|
19
|
+
HTMLAttributes: { type: Object, required: true }
|
|
20
|
+
});
|
|
21
|
+
const { doc: rootDoc } = useAbracadabra();
|
|
22
|
+
const treeMap = useSyncedMap(
|
|
23
|
+
rootDoc,
|
|
24
|
+
"doc-tree"
|
|
25
|
+
);
|
|
26
|
+
const docId = computed(() => props.node.attrs.docId);
|
|
27
|
+
const treeEntry = computed(() => treeMap.data[docId.value]);
|
|
28
|
+
const exists = computed(() => !!treeEntry.value);
|
|
29
|
+
const docType = computed(() => resolveDocType(treeEntry.value?.type));
|
|
30
|
+
const label = computed(() => treeEntry.value?.label || "Untitled");
|
|
31
|
+
function navigate(e) {
|
|
32
|
+
e.preventDefault();
|
|
33
|
+
e.stopPropagation();
|
|
34
|
+
if (!docId.value) return;
|
|
35
|
+
navigateTo(`/doc/${docId.value}`);
|
|
36
|
+
}
|
|
37
|
+
</script>
|
|
38
|
+
|
|
39
|
+
<template>
|
|
40
|
+
<NodeViewWrapper
|
|
41
|
+
as="span"
|
|
42
|
+
class="inline-flex align-baseline"
|
|
43
|
+
>
|
|
44
|
+
<UBadge
|
|
45
|
+
v-if="exists"
|
|
46
|
+
:icon="docType.icon"
|
|
47
|
+
color="neutral"
|
|
48
|
+
variant="subtle"
|
|
49
|
+
size="sm"
|
|
50
|
+
class="dl-badge rounded-full cursor-pointer"
|
|
51
|
+
:class="{ 'dl-badge-selected': props.selected }"
|
|
52
|
+
@click="navigate"
|
|
53
|
+
>
|
|
54
|
+
{{ label }}
|
|
55
|
+
</UBadge>
|
|
56
|
+
<UBadge
|
|
57
|
+
v-else
|
|
58
|
+
icon="i-lucide-file-x"
|
|
59
|
+
color="error"
|
|
60
|
+
variant="outline"
|
|
61
|
+
size="sm"
|
|
62
|
+
class="dl-badge rounded-full"
|
|
63
|
+
>
|
|
64
|
+
Missing document
|
|
65
|
+
</UBadge>
|
|
66
|
+
</NodeViewWrapper>
|
|
67
|
+
</template>
|
|
68
|
+
|
|
69
|
+
<style scoped>
|
|
70
|
+
.dl-badge{transition:background-color .12s ease,box-shadow .12s ease;vertical-align:baseline}.dl-badge:hover{background:var(--ui-bg-accented)}.dl-badge-selected,:deep(.ProseMirror-selectednode) .dl-badge{box-shadow:0 0 0 2px var(--ui-primary)}
|
|
71
|
+
</style>
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { NodeViewProps } from '@tiptap/vue-3';
|
|
2
|
+
declare const __VLS_export: import("vue").DefineComponent<NodeViewProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<NodeViewProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
3
|
+
declare const _default: typeof __VLS_export;
|
|
4
|
+
export default _default;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { NodeViewProps } from '@tiptap/vue-3';
|
|
2
|
+
declare const __VLS_export: import("vue").DefineComponent<NodeViewProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<NodeViewProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
3
|
+
declare const _default: typeof __VLS_export;
|
|
4
|
+
export default _default;
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { ref, computed, watch } from "vue";
|
|
3
|
+
import { NodeViewWrapper } from "@tiptap/vue-3";
|
|
4
|
+
const props = defineProps({
|
|
5
|
+
decorations: { type: Array, required: true },
|
|
6
|
+
selected: { type: Boolean, required: true },
|
|
7
|
+
updateAttributes: { type: Function, required: true },
|
|
8
|
+
deleteNode: { type: Function, required: true },
|
|
9
|
+
node: { type: null, required: true },
|
|
10
|
+
view: { type: null, required: true },
|
|
11
|
+
getPos: { type: null, required: true },
|
|
12
|
+
innerDecorations: { type: null, required: true },
|
|
13
|
+
editor: { type: Object, required: true },
|
|
14
|
+
extension: { type: Object, required: true },
|
|
15
|
+
HTMLAttributes: { type: Object, required: true }
|
|
16
|
+
});
|
|
17
|
+
const src = computed(() => props.node.attrs.src || "");
|
|
18
|
+
const title = computed(() => props.node.attrs.title || "");
|
|
19
|
+
const aspectRatio = computed(() => props.node.attrs.aspectRatio || "16/9");
|
|
20
|
+
const isSafe = computed(() => /^https?:\/\//.test(src.value));
|
|
21
|
+
const popoverOpen = ref(false);
|
|
22
|
+
const srcDraft = ref("");
|
|
23
|
+
const titleDraft = ref("");
|
|
24
|
+
watch(popoverOpen, (open) => {
|
|
25
|
+
if (open) {
|
|
26
|
+
srcDraft.value = src.value;
|
|
27
|
+
titleDraft.value = title.value;
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
const ASPECTS = [
|
|
31
|
+
{ key: "16/9", label: "16:9" },
|
|
32
|
+
{ key: "4/3", label: "4:3" },
|
|
33
|
+
{ key: "1/1", label: "1:1" },
|
|
34
|
+
{ key: "3/4", label: "3:4" },
|
|
35
|
+
{ key: "auto", label: "Auto" }
|
|
36
|
+
];
|
|
37
|
+
function saveSrc() {
|
|
38
|
+
const raw = srcDraft.value.trim();
|
|
39
|
+
const safe = /^https?:\/\//.test(raw) ? raw : "";
|
|
40
|
+
props.updateAttributes({
|
|
41
|
+
src: safe,
|
|
42
|
+
title: titleDraft.value.trim()
|
|
43
|
+
});
|
|
44
|
+
popoverOpen.value = false;
|
|
45
|
+
}
|
|
46
|
+
function setAspect(key) {
|
|
47
|
+
props.updateAttributes({ aspectRatio: key });
|
|
48
|
+
}
|
|
49
|
+
function onKeydown(e) {
|
|
50
|
+
if (e.key === "Enter") {
|
|
51
|
+
e.preventDefault();
|
|
52
|
+
saveSrc();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
const aspectStyle = computed(() => {
|
|
56
|
+
if (aspectRatio.value === "auto") return { aspectRatio: void 0, minHeight: "240px" };
|
|
57
|
+
return { aspectRatio: aspectRatio.value.replace("/", " / ") };
|
|
58
|
+
});
|
|
59
|
+
</script>
|
|
60
|
+
|
|
61
|
+
<template>
|
|
62
|
+
<NodeViewWrapper
|
|
63
|
+
as="div"
|
|
64
|
+
class="my-5"
|
|
65
|
+
contenteditable="false"
|
|
66
|
+
>
|
|
67
|
+
<div class="group/embed relative w-full">
|
|
68
|
+
<div
|
|
69
|
+
class="w-full rounded-md overflow-hidden bg-(--ui-bg-elevated) border border-(--ui-border)"
|
|
70
|
+
:style="aspectStyle"
|
|
71
|
+
>
|
|
72
|
+
<iframe
|
|
73
|
+
v-if="isSafe"
|
|
74
|
+
:src="src"
|
|
75
|
+
:title="title || 'Embed'"
|
|
76
|
+
class="size-full border-0"
|
|
77
|
+
sandbox="allow-scripts allow-same-origin allow-forms allow-popups allow-popups-to-escape-sandbox"
|
|
78
|
+
loading="lazy"
|
|
79
|
+
referrerpolicy="strict-origin-when-cross-origin"
|
|
80
|
+
/>
|
|
81
|
+
<UPopover
|
|
82
|
+
v-else
|
|
83
|
+
v-model:open="popoverOpen"
|
|
84
|
+
:content="{ align: 'center' }"
|
|
85
|
+
>
|
|
86
|
+
<button
|
|
87
|
+
class="size-full flex flex-col items-center justify-center gap-2 text-(--ui-text-muted) hover:text-(--ui-text) hover:bg-(--ui-bg-elevated)/60 transition-colors"
|
|
88
|
+
type="button"
|
|
89
|
+
>
|
|
90
|
+
<UIcon
|
|
91
|
+
name="i-lucide-code-xml"
|
|
92
|
+
class="size-10"
|
|
93
|
+
/>
|
|
94
|
+
<span class="text-sm">Click to add embed URL</span>
|
|
95
|
+
</button>
|
|
96
|
+
<template #content>
|
|
97
|
+
<div class="p-2 w-96 flex flex-col gap-2">
|
|
98
|
+
<UInput
|
|
99
|
+
v-model="srcDraft"
|
|
100
|
+
autofocus
|
|
101
|
+
size="sm"
|
|
102
|
+
placeholder="https://codepen.io/… or figma.com/…"
|
|
103
|
+
icon="i-lucide-link"
|
|
104
|
+
@keydown="onKeydown"
|
|
105
|
+
/>
|
|
106
|
+
<UInput
|
|
107
|
+
v-model="titleDraft"
|
|
108
|
+
size="sm"
|
|
109
|
+
placeholder="Title (for accessibility)"
|
|
110
|
+
icon="i-lucide-text"
|
|
111
|
+
@keydown="onKeydown"
|
|
112
|
+
/>
|
|
113
|
+
<div class="flex justify-end">
|
|
114
|
+
<UButton
|
|
115
|
+
size="sm"
|
|
116
|
+
@click="saveSrc"
|
|
117
|
+
>
|
|
118
|
+
Save
|
|
119
|
+
</UButton>
|
|
120
|
+
</div>
|
|
121
|
+
</div>
|
|
122
|
+
</template>
|
|
123
|
+
</UPopover>
|
|
124
|
+
</div>
|
|
125
|
+
<div
|
|
126
|
+
v-if="isSafe"
|
|
127
|
+
class="absolute top-2 right-2 flex items-center gap-1 opacity-0 group-hover/embed:opacity-100 transition-opacity"
|
|
128
|
+
>
|
|
129
|
+
<UButton
|
|
130
|
+
size="xs"
|
|
131
|
+
color="neutral"
|
|
132
|
+
variant="solid"
|
|
133
|
+
icon="i-lucide-pencil"
|
|
134
|
+
label="Replace"
|
|
135
|
+
@click="popoverOpen = true"
|
|
136
|
+
/>
|
|
137
|
+
<UPopover>
|
|
138
|
+
<UButton
|
|
139
|
+
size="xs"
|
|
140
|
+
color="neutral"
|
|
141
|
+
variant="solid"
|
|
142
|
+
icon="i-lucide-ratio"
|
|
143
|
+
:label="aspectRatio === 'auto' ? 'Auto' : aspectRatio.replace('/', ':')"
|
|
144
|
+
/>
|
|
145
|
+
<template #content>
|
|
146
|
+
<div class="p-1 flex flex-col gap-0.5 min-w-[100px]">
|
|
147
|
+
<button
|
|
148
|
+
v-for="a in ASPECTS"
|
|
149
|
+
:key="a.key"
|
|
150
|
+
class="px-2 py-1 text-sm rounded-sm hover:bg-(--ui-bg-elevated) transition-colors text-left flex items-center gap-2"
|
|
151
|
+
:class="aspectRatio === a.key ? 'text-(--ui-text-highlighted) bg-(--ui-bg-elevated)' : 'text-(--ui-text-muted)'"
|
|
152
|
+
@click="setAspect(a.key)"
|
|
153
|
+
>
|
|
154
|
+
<UIcon
|
|
155
|
+
:name="aspectRatio === a.key ? 'i-lucide-check' : 'i-lucide-ratio'"
|
|
156
|
+
class="size-3.5"
|
|
157
|
+
/>
|
|
158
|
+
{{ a.label }}
|
|
159
|
+
</button>
|
|
160
|
+
</div>
|
|
161
|
+
</template>
|
|
162
|
+
</UPopover>
|
|
163
|
+
</div>
|
|
164
|
+
</div>
|
|
165
|
+
</NodeViewWrapper>
|
|
166
|
+
</template>
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { NodeViewProps } from '@tiptap/vue-3';
|
|
2
|
+
declare const __VLS_export: import("vue").DefineComponent<NodeViewProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<NodeViewProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
3
|
+
declare const _default: typeof __VLS_export;
|
|
4
|
+
export default _default;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { NodeViewProps } from '@tiptap/vue-3';
|
|
2
|
+
declare const __VLS_export: import("vue").DefineComponent<NodeViewProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<NodeViewProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
3
|
+
declare const _default: typeof __VLS_export;
|
|
4
|
+
export default _default;
|