@abraca/nuxt 1.9.1 → 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/dist/module.d.mts +4 -3
- package/dist/module.json +1 -1
- package/dist/module.mjs +9 -1
- 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/ADocsSearch.d.vue.ts +2 -2
- package/dist/runtime/components/docs/ADocsSearch.vue.d.ts +2 -2
- package/dist/runtime/components/docs/ADocsSearchButton.d.vue.ts +3 -3
- package/dist/runtime/components/docs/ADocsSearchButton.vue.d.ts +3 -3
- 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/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 +3 -3
- package/dist/runtime/components/shell/ADocPanelSettings.vue.d.ts +3 -3
- 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/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/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/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 +233 -36
- package/dist/runtime/plugin-abracadabra.server.js +0 -1
- package/dist/runtime/plugins/core.plugin.js +73 -4
- package/dist/runtime/server/plugins/abracadabra-service.js +1 -1
- 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/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 +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 +27 -16
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { computed, useAttrs } from "vue";
|
|
3
|
+
import { useAAField } from "../../composables/useAAField";
|
|
4
|
+
import { useAAFieldValue } from "../../composables/useAAFieldValue";
|
|
5
|
+
import { awareRingStyle } from "../../utils/awareRingStyle";
|
|
6
|
+
defineOptions({ inheritAttrs: false });
|
|
7
|
+
const props = defineProps({
|
|
8
|
+
fieldKey: { type: String, required: true },
|
|
9
|
+
sync: { type: Boolean, required: false, default: false },
|
|
10
|
+
max: { type: Number, required: false, default: 3 }
|
|
11
|
+
});
|
|
12
|
+
const attrs = useAttrs();
|
|
13
|
+
const { hoverers, focusers, pressers, isPressed, handlers } = useAAField(() => props.fieldKey);
|
|
14
|
+
const synced = useAAFieldValue(() => props.fieldKey);
|
|
15
|
+
const hasExternalModel = computed(
|
|
16
|
+
() => "modelValue" in attrs || "onUpdate:modelValue" in attrs
|
|
17
|
+
);
|
|
18
|
+
const ringStyle = computed(() => awareRingStyle({
|
|
19
|
+
hover: hoverers.value[0]?.user?.color,
|
|
20
|
+
focus: focusers.value[0]?.user?.color,
|
|
21
|
+
press: pressers.value[0]?.user?.color,
|
|
22
|
+
radius: "9999px"
|
|
23
|
+
}));
|
|
24
|
+
const overlayPeers = computed(() => {
|
|
25
|
+
const seen = /* @__PURE__ */ new Set();
|
|
26
|
+
const out = [];
|
|
27
|
+
for (const p of focusers.value) if (!seen.has(p.clientId)) {
|
|
28
|
+
seen.add(p.clientId);
|
|
29
|
+
out.push(p);
|
|
30
|
+
}
|
|
31
|
+
for (const p of hoverers.value) if (!seen.has(p.clientId)) {
|
|
32
|
+
seen.add(p.clientId);
|
|
33
|
+
out.push(p);
|
|
34
|
+
}
|
|
35
|
+
return out;
|
|
36
|
+
});
|
|
37
|
+
</script>
|
|
38
|
+
|
|
39
|
+
<template>
|
|
40
|
+
<span
|
|
41
|
+
class="aa-host aa-host--inline"
|
|
42
|
+
:class="{ 'aa-host--pressed': isPressed }"
|
|
43
|
+
:style="ringStyle"
|
|
44
|
+
v-on="handlers"
|
|
45
|
+
>
|
|
46
|
+
<USwitch
|
|
47
|
+
v-if="props.sync && !hasExternalModel"
|
|
48
|
+
v-model="synced"
|
|
49
|
+
v-bind="attrs"
|
|
50
|
+
/>
|
|
51
|
+
<USwitch
|
|
52
|
+
v-else
|
|
53
|
+
v-bind="attrs"
|
|
54
|
+
/>
|
|
55
|
+
<Transition name="aa-peer">
|
|
56
|
+
<span
|
|
57
|
+
v-if="overlayPeers.length"
|
|
58
|
+
class="aa-overlay"
|
|
59
|
+
>
|
|
60
|
+
<AAvatar
|
|
61
|
+
v-for="p in overlayPeers.slice(0, max)"
|
|
62
|
+
:key="p.clientId"
|
|
63
|
+
:user="p"
|
|
64
|
+
size="2xs"
|
|
65
|
+
:show-status="false"
|
|
66
|
+
:show-tooltip="true"
|
|
67
|
+
/>
|
|
68
|
+
</span>
|
|
69
|
+
</Transition>
|
|
70
|
+
</span>
|
|
71
|
+
</template>
|
|
72
|
+
|
|
73
|
+
<style scoped>
|
|
74
|
+
.aa-host{border-radius:9999px;position:relative;transition:filter .12s ease}.aa-host--inline{align-items:center;display:inline-flex}.aa-host--pressed{filter:brightness(.85)}.aa-overlay{display:flex;gap:0;pointer-events:none;position:absolute;right:0;top:-.625rem;z-index:10}.aa-overlay>*+*{margin-left:-.25rem}.aa-peer-enter-active,.aa-peer-leave-active{transition:opacity .15s ease}.aa-peer-enter-from,.aa-peer-leave-to{opacity:0}
|
|
75
|
+
</style>
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
type __VLS_Props = {
|
|
2
|
+
fieldKey: string;
|
|
3
|
+
sync?: boolean;
|
|
4
|
+
max?: number;
|
|
5
|
+
};
|
|
6
|
+
declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
7
|
+
sync: boolean;
|
|
8
|
+
max: number;
|
|
9
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
10
|
+
declare const _default: typeof __VLS_export;
|
|
11
|
+
export default _default;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
type __VLS_Props = {
|
|
2
|
+
fieldKey: string;
|
|
3
|
+
awareness?: boolean;
|
|
4
|
+
peers?: boolean;
|
|
5
|
+
total?: boolean;
|
|
6
|
+
};
|
|
7
|
+
declare var __VLS_9: string, __VLS_10: any;
|
|
8
|
+
type __VLS_Slots = {} & {
|
|
9
|
+
[K in NonNullable<typeof __VLS_9>]?: (props: typeof __VLS_10) => any;
|
|
10
|
+
};
|
|
11
|
+
declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
12
|
+
peers: boolean;
|
|
13
|
+
awareness: boolean;
|
|
14
|
+
total: boolean;
|
|
15
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
16
|
+
declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
|
|
17
|
+
declare const _default: typeof __VLS_export;
|
|
18
|
+
export default _default;
|
|
19
|
+
type __VLS_WithSlots<T, S> = T & {
|
|
20
|
+
new (): {
|
|
21
|
+
$slots: S;
|
|
22
|
+
};
|
|
23
|
+
};
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { computed, ref, useAttrs, watch } from "vue";
|
|
3
|
+
import { useAAField } from "../../composables/useAAField";
|
|
4
|
+
import { useAAEphemeral } from "../../composables/useAAEphemeral";
|
|
5
|
+
import { awareRingStyle } from "../../utils/awareRingStyle";
|
|
6
|
+
defineOptions({ inheritAttrs: false });
|
|
7
|
+
const props = defineProps({
|
|
8
|
+
fieldKey: { type: String, required: true },
|
|
9
|
+
awareness: { type: Boolean, required: false, default: true },
|
|
10
|
+
peers: { type: Boolean, required: false, default: false },
|
|
11
|
+
total: { type: Boolean, required: false, default: false }
|
|
12
|
+
});
|
|
13
|
+
const enableAwareness = computed(() => props.awareness || props.total);
|
|
14
|
+
const enablePeers = computed(() => props.peers || props.total);
|
|
15
|
+
const attrs = useAttrs();
|
|
16
|
+
const { hoverers, focusers, pressers, isPressed, hoverHandlers } = useAAField(() => props.fieldKey);
|
|
17
|
+
const ringStyle = computed(
|
|
18
|
+
() => enableAwareness.value ? awareRingStyle({
|
|
19
|
+
hover: hoverers.value[0]?.user?.color,
|
|
20
|
+
focus: focusers.value[0]?.user?.color,
|
|
21
|
+
press: pressers.value[0]?.user?.color
|
|
22
|
+
}) : void 0
|
|
23
|
+
);
|
|
24
|
+
const { peers: hoveredRowPeers, setLocal: setHoveredRow } = useAAEphemeral(() => `${props.fieldKey}:hoveredRow`);
|
|
25
|
+
const hostRef = ref(null);
|
|
26
|
+
function onRowOver(e) {
|
|
27
|
+
if (!enablePeers.value) return;
|
|
28
|
+
const tr = e.target?.closest("tr");
|
|
29
|
+
const id = tr?.getAttribute("data-row-id") || tr?.dataset.rowKey || tr?.getAttribute("aria-rowindex");
|
|
30
|
+
if (id) setHoveredRow(id);
|
|
31
|
+
}
|
|
32
|
+
function onRowOut() {
|
|
33
|
+
if (!enablePeers.value) return;
|
|
34
|
+
setHoveredRow(null);
|
|
35
|
+
}
|
|
36
|
+
watch([hoveredRowPeers, hostRef], () => {
|
|
37
|
+
const host = hostRef.value;
|
|
38
|
+
if (!host) return;
|
|
39
|
+
for (const tr of host.querySelectorAll("tr[data-aa-peer]")) {
|
|
40
|
+
tr.style.backgroundColor = "";
|
|
41
|
+
tr.style.boxShadow = "";
|
|
42
|
+
tr.removeAttribute("data-aa-peer");
|
|
43
|
+
}
|
|
44
|
+
if (!enablePeers.value) return;
|
|
45
|
+
for (const p of hoveredRowPeers.value) {
|
|
46
|
+
const id = String(p.value);
|
|
47
|
+
const tr = host.querySelector(`tr[data-row-id="${id}"], tr[data-row-key="${id}"], tr[aria-rowindex="${id}"]`);
|
|
48
|
+
if (!tr) continue;
|
|
49
|
+
const color = p.user?.color ?? "currentColor";
|
|
50
|
+
tr.style.backgroundColor = colorMix(color, 0.15);
|
|
51
|
+
tr.style.boxShadow = `inset 3px 0 0 0 ${color}`;
|
|
52
|
+
tr.setAttribute("data-aa-peer", String(p.clientId));
|
|
53
|
+
}
|
|
54
|
+
}, { deep: true, flush: "post" });
|
|
55
|
+
function colorMix(color, alpha) {
|
|
56
|
+
if (color.startsWith("#") && color.length === 7) {
|
|
57
|
+
const a = Math.round(alpha * 255).toString(16).padStart(2, "0");
|
|
58
|
+
return `${color}${a}`;
|
|
59
|
+
}
|
|
60
|
+
if (color.startsWith("rgb(")) return color.replace("rgb(", "rgba(").replace(")", `, ${alpha})`);
|
|
61
|
+
if (color.startsWith("hsl(")) return color.replace("hsl(", "hsla(").replace(")", `, ${alpha})`);
|
|
62
|
+
return color;
|
|
63
|
+
}
|
|
64
|
+
</script>
|
|
65
|
+
|
|
66
|
+
<template>
|
|
67
|
+
<div
|
|
68
|
+
ref="hostRef"
|
|
69
|
+
class="aa-table-host aa-host"
|
|
70
|
+
:class="{ 'aa-host--pressed': isPressed }"
|
|
71
|
+
:style="ringStyle"
|
|
72
|
+
v-on="enableAwareness ? hoverHandlers : {}"
|
|
73
|
+
@mouseover="onRowOver"
|
|
74
|
+
@mouseleave="onRowOut"
|
|
75
|
+
>
|
|
76
|
+
<UTable v-bind="attrs">
|
|
77
|
+
<template v-for="(_, name) in $slots" #[name]="slotData">
|
|
78
|
+
<slot :name="name" v-bind="slotData ?? {}" />
|
|
79
|
+
</template>
|
|
80
|
+
</UTable>
|
|
81
|
+
<div v-if="enablePeers && hoveredRowPeers.length" class="aa-table-peers">
|
|
82
|
+
<span
|
|
83
|
+
v-for="p in hoveredRowPeers"
|
|
84
|
+
:key="p.clientId"
|
|
85
|
+
class="aa-table-peer-chip"
|
|
86
|
+
:style="{ borderColor: p.user?.color ?? 'var(--ui-border)' }"
|
|
87
|
+
>
|
|
88
|
+
<span class="aa-table-peer-dot" :style="{ background: p.user?.color ?? 'var(--ui-text-muted)' }" />
|
|
89
|
+
{{ p.user?.name || "Anonymous" }} on row #{{ p.value }}
|
|
90
|
+
</span>
|
|
91
|
+
</div>
|
|
92
|
+
</div>
|
|
93
|
+
</template>
|
|
94
|
+
|
|
95
|
+
<style scoped>
|
|
96
|
+
.aa-table-host{position:relative;transition:filter .12s ease,box-shadow .1s ease}.aa-host--pressed{filter:brightness(.94)}.aa-table-peers{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.aa-table-peer-chip{align-items:center;border:1px solid var(--ui-border);border-radius:999px;color:var(--ui-text-highlighted);display:inline-flex;font-size:.6875rem;font-weight:500;gap:.35rem;padding:.15rem .55rem}.aa-table-peer-dot{border-radius:999px;height:.5rem;width:.5rem}
|
|
97
|
+
</style>
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
type __VLS_Props = {
|
|
2
|
+
fieldKey: string;
|
|
3
|
+
awareness?: boolean;
|
|
4
|
+
peers?: boolean;
|
|
5
|
+
total?: boolean;
|
|
6
|
+
};
|
|
7
|
+
declare var __VLS_9: string, __VLS_10: any;
|
|
8
|
+
type __VLS_Slots = {} & {
|
|
9
|
+
[K in NonNullable<typeof __VLS_9>]?: (props: typeof __VLS_10) => any;
|
|
10
|
+
};
|
|
11
|
+
declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
12
|
+
peers: boolean;
|
|
13
|
+
awareness: boolean;
|
|
14
|
+
total: boolean;
|
|
15
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
16
|
+
declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
|
|
17
|
+
declare const _default: typeof __VLS_export;
|
|
18
|
+
export default _default;
|
|
19
|
+
type __VLS_WithSlots<T, S> = T & {
|
|
20
|
+
new (): {
|
|
21
|
+
$slots: S;
|
|
22
|
+
};
|
|
23
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
type __VLS_Props = {
|
|
2
|
+
fieldKey: string;
|
|
3
|
+
awareness?: boolean;
|
|
4
|
+
live?: boolean;
|
|
5
|
+
peers?: boolean;
|
|
6
|
+
total?: boolean;
|
|
7
|
+
};
|
|
8
|
+
declare var __VLS_9: string, __VLS_10: any, __VLS_27: string, __VLS_28: any;
|
|
9
|
+
type __VLS_Slots = {} & {
|
|
10
|
+
[K in NonNullable<typeof __VLS_9>]?: (props: typeof __VLS_10) => any;
|
|
11
|
+
} & {
|
|
12
|
+
[K in NonNullable<typeof __VLS_27>]?: (props: typeof __VLS_28) => any;
|
|
13
|
+
};
|
|
14
|
+
declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
15
|
+
peers: boolean;
|
|
16
|
+
awareness: boolean;
|
|
17
|
+
live: boolean;
|
|
18
|
+
total: boolean;
|
|
19
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
20
|
+
declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
|
|
21
|
+
declare const _default: typeof __VLS_export;
|
|
22
|
+
export default _default;
|
|
23
|
+
type __VLS_WithSlots<T, S> = T & {
|
|
24
|
+
new (): {
|
|
25
|
+
$slots: S;
|
|
26
|
+
};
|
|
27
|
+
};
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { computed, ref, useAttrs, watch } from "vue";
|
|
3
|
+
import { useAAField } from "../../composables/useAAField";
|
|
4
|
+
import { useAAUIState } from "../../composables/useAAUIState";
|
|
5
|
+
import { useAAEphemeral } from "../../composables/useAAEphemeral";
|
|
6
|
+
import AHoverItem from "./AHoverItem.vue";
|
|
7
|
+
function tabId(item) {
|
|
8
|
+
if (item == null) return "";
|
|
9
|
+
if (typeof item === "string") return item;
|
|
10
|
+
return String(item.value ?? item.id ?? item.label ?? "");
|
|
11
|
+
}
|
|
12
|
+
function tabLabel(item) {
|
|
13
|
+
if (item == null) return "";
|
|
14
|
+
if (typeof item === "string") return item;
|
|
15
|
+
return String(item.label ?? item.value ?? item.id ?? "");
|
|
16
|
+
}
|
|
17
|
+
defineOptions({ inheritAttrs: false });
|
|
18
|
+
const props = defineProps({
|
|
19
|
+
fieldKey: { type: String, required: true },
|
|
20
|
+
awareness: { type: Boolean, required: false, default: true },
|
|
21
|
+
live: { type: Boolean, required: false, default: false },
|
|
22
|
+
peers: { type: Boolean, required: false, default: false },
|
|
23
|
+
total: { type: Boolean, required: false, default: false }
|
|
24
|
+
});
|
|
25
|
+
const enableAwareness = computed(() => props.awareness || props.total);
|
|
26
|
+
const enableLive = computed(() => props.live || props.total);
|
|
27
|
+
const enablePeers = computed(() => props.peers || props.total);
|
|
28
|
+
const attrs = useAttrs();
|
|
29
|
+
const { hoverers, focusers, hoverHandlers } = useAAField(() => props.fieldKey);
|
|
30
|
+
const liveActive = useAAUIState(() => `${props.fieldKey}:active`, { defaultValue: "" });
|
|
31
|
+
const { peers: peerActives, setLocal } = useAAEphemeral(() => `${props.fieldKey}:active`);
|
|
32
|
+
const hasExternalModel = computed(
|
|
33
|
+
() => "modelValue" in attrs || "onUpdate:modelValue" in attrs
|
|
34
|
+
);
|
|
35
|
+
const local = ref(enableLive.value ? liveActive.value || "" : "");
|
|
36
|
+
watch(liveActive, (val) => {
|
|
37
|
+
if (!enableLive.value) return;
|
|
38
|
+
const next = val || "";
|
|
39
|
+
if (local.value !== next) local.value = next;
|
|
40
|
+
});
|
|
41
|
+
watch(local, (val) => {
|
|
42
|
+
if (enableLive.value && (liveActive.value || "") !== val) liveActive.value = val;
|
|
43
|
+
if (enablePeers.value) setLocal(val || null);
|
|
44
|
+
});
|
|
45
|
+
const ringStyle = computed(() => {
|
|
46
|
+
if (!enableAwareness.value) return void 0;
|
|
47
|
+
const focusColor = focusers.value[0]?.user?.color;
|
|
48
|
+
const hoverColor = hoverers.value[0]?.user?.color;
|
|
49
|
+
if (!focusColor && !hoverColor) return void 0;
|
|
50
|
+
const layers = [];
|
|
51
|
+
if (hoverColor) layers.push(`0 0 0 1px ${hoverColor}40`);
|
|
52
|
+
if (focusColor) layers.push(`0 0 0 2px ${focusColor}`);
|
|
53
|
+
return {
|
|
54
|
+
boxShadow: layers.join(", "),
|
|
55
|
+
borderRadius: "var(--ui-radius, 0.375rem)",
|
|
56
|
+
transition: "box-shadow 150ms ease"
|
|
57
|
+
};
|
|
58
|
+
});
|
|
59
|
+
const eventHandlers = computed(() => enableAwareness.value ? hoverHandlers : {});
|
|
60
|
+
</script>
|
|
61
|
+
|
|
62
|
+
<template>
|
|
63
|
+
<div
|
|
64
|
+
class="aa-host aa-host--block"
|
|
65
|
+
:style="ringStyle"
|
|
66
|
+
v-on="eventHandlers"
|
|
67
|
+
>
|
|
68
|
+
<UTabs
|
|
69
|
+
v-if="enableLive && !hasExternalModel"
|
|
70
|
+
v-model="local"
|
|
71
|
+
v-bind="attrs"
|
|
72
|
+
>
|
|
73
|
+
<template
|
|
74
|
+
v-for="(_, name) in $slots"
|
|
75
|
+
#[name]="slotData"
|
|
76
|
+
>
|
|
77
|
+
<slot
|
|
78
|
+
:name="name"
|
|
79
|
+
v-bind="slotData ?? {}"
|
|
80
|
+
/>
|
|
81
|
+
</template>
|
|
82
|
+
<template #trigger="{ item }">
|
|
83
|
+
<AHoverItem :field-key="`${fieldKey}:item:${tabId(item)}`" variant="block" :show-flag="false">
|
|
84
|
+
{{ tabLabel(item) }}
|
|
85
|
+
</AHoverItem>
|
|
86
|
+
</template>
|
|
87
|
+
</UTabs>
|
|
88
|
+
<UTabs
|
|
89
|
+
v-else
|
|
90
|
+
v-bind="attrs"
|
|
91
|
+
>
|
|
92
|
+
<template
|
|
93
|
+
v-for="(_, name) in $slots"
|
|
94
|
+
#[name]="slotData"
|
|
95
|
+
>
|
|
96
|
+
<slot
|
|
97
|
+
:name="name"
|
|
98
|
+
v-bind="slotData ?? {}"
|
|
99
|
+
/>
|
|
100
|
+
</template>
|
|
101
|
+
<template #trigger="{ item }">
|
|
102
|
+
<AHoverItem :field-key="`${fieldKey}:item:${tabId(item)}`" variant="block" :show-flag="false">
|
|
103
|
+
{{ tabLabel(item) }}
|
|
104
|
+
</AHoverItem>
|
|
105
|
+
</template>
|
|
106
|
+
</UTabs>
|
|
107
|
+
|
|
108
|
+
<Transition name="aa-peer">
|
|
109
|
+
<span
|
|
110
|
+
v-if="enablePeers && peerActives.length"
|
|
111
|
+
class="aa-overlay"
|
|
112
|
+
>
|
|
113
|
+
<AAvatar
|
|
114
|
+
v-for="p in peerActives.slice(0, 5)"
|
|
115
|
+
:key="p.clientId"
|
|
116
|
+
:user="{ clientId: p.clientId, user: p.user, docId: p.value }"
|
|
117
|
+
size="2xs"
|
|
118
|
+
:show-status="false"
|
|
119
|
+
:show-tooltip="true"
|
|
120
|
+
/>
|
|
121
|
+
</span>
|
|
122
|
+
</Transition>
|
|
123
|
+
</div>
|
|
124
|
+
</template>
|
|
125
|
+
|
|
126
|
+
<style scoped>
|
|
127
|
+
.aa-host{border-radius:var(--ui-radius,.375rem);position:relative}.aa-host--block{display:block}.aa-overlay{display:flex;gap:0;pointer-events:none;position:absolute;right:0;top:-.625rem;z-index:10}.aa-overlay>*+*{margin-left:-.25rem}.aa-peer-enter-active,.aa-peer-leave-active{transition:opacity .15s ease}.aa-peer-enter-from,.aa-peer-leave-to{opacity:0}
|
|
128
|
+
</style>
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
type __VLS_Props = {
|
|
2
|
+
fieldKey: string;
|
|
3
|
+
awareness?: boolean;
|
|
4
|
+
live?: boolean;
|
|
5
|
+
peers?: boolean;
|
|
6
|
+
total?: boolean;
|
|
7
|
+
};
|
|
8
|
+
declare var __VLS_9: string, __VLS_10: any, __VLS_27: string, __VLS_28: any;
|
|
9
|
+
type __VLS_Slots = {} & {
|
|
10
|
+
[K in NonNullable<typeof __VLS_9>]?: (props: typeof __VLS_10) => any;
|
|
11
|
+
} & {
|
|
12
|
+
[K in NonNullable<typeof __VLS_27>]?: (props: typeof __VLS_28) => any;
|
|
13
|
+
};
|
|
14
|
+
declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
15
|
+
peers: boolean;
|
|
16
|
+
awareness: boolean;
|
|
17
|
+
live: boolean;
|
|
18
|
+
total: boolean;
|
|
19
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
20
|
+
declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
|
|
21
|
+
declare const _default: typeof __VLS_export;
|
|
22
|
+
export default _default;
|
|
23
|
+
type __VLS_WithSlots<T, S> = T & {
|
|
24
|
+
new (): {
|
|
25
|
+
$slots: S;
|
|
26
|
+
};
|
|
27
|
+
};
|
|
@@ -1,7 +1,17 @@
|
|
|
1
1
|
type __VLS_Props = {
|
|
2
|
-
/** Unique field key for awareness broadcasting. Convention: "{scope}:{id}" */
|
|
3
2
|
fieldKey: string;
|
|
3
|
+
awareness?: boolean;
|
|
4
|
+
sync?: boolean;
|
|
5
|
+
peers?: boolean;
|
|
6
|
+
total?: boolean;
|
|
7
|
+
max?: number;
|
|
4
8
|
};
|
|
5
|
-
declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
9
|
+
declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
10
|
+
sync: boolean;
|
|
11
|
+
peers: boolean;
|
|
12
|
+
awareness: boolean;
|
|
13
|
+
max: number;
|
|
14
|
+
total: boolean;
|
|
15
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
6
16
|
declare const _default: typeof __VLS_export;
|
|
7
17
|
export default _default;
|
|
@@ -1,38 +1,91 @@
|
|
|
1
1
|
<script setup>
|
|
2
|
-
import { computed } from "vue";
|
|
2
|
+
import { computed, onMounted, ref, useAttrs, watch } from "vue";
|
|
3
3
|
import { useAAField } from "../../composables/useAAField";
|
|
4
|
+
import { useAAFieldValue } from "../../composables/useAAFieldValue";
|
|
5
|
+
import { useAACaret } from "../../composables/useAACaret";
|
|
6
|
+
import { awareRingStyle } from "../../utils/awareRingStyle";
|
|
7
|
+
import APeerCaretLayer from "./APeerCaretLayer.vue";
|
|
4
8
|
defineOptions({ inheritAttrs: false });
|
|
5
9
|
const props = defineProps({
|
|
6
|
-
fieldKey: { type: String, required: true }
|
|
10
|
+
fieldKey: { type: String, required: true },
|
|
11
|
+
awareness: { type: Boolean, required: false, default: true },
|
|
12
|
+
sync: { type: Boolean, required: false, default: false },
|
|
13
|
+
peers: { type: Boolean, required: false, default: false },
|
|
14
|
+
total: { type: Boolean, required: false, default: false },
|
|
15
|
+
max: { type: Number, required: false, default: 3 }
|
|
7
16
|
});
|
|
8
|
-
const
|
|
9
|
-
const
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
17
|
+
const enableAwareness = computed(() => props.awareness || props.total);
|
|
18
|
+
const enableSync = computed(() => props.sync || props.total);
|
|
19
|
+
const enablePeers = computed(() => props.peers || props.total);
|
|
20
|
+
const attrs = useAttrs();
|
|
21
|
+
const { hoverers, focusers, pressers, isPressed, handlers } = useAAField(() => props.fieldKey);
|
|
22
|
+
const synced = useAAFieldValue(() => props.fieldKey);
|
|
23
|
+
const hasExternalModel = computed(
|
|
24
|
+
() => "modelValue" in attrs || "onUpdate:modelValue" in attrs
|
|
25
|
+
);
|
|
26
|
+
const hostRef = ref(null);
|
|
27
|
+
const textareaEl = ref(null);
|
|
28
|
+
function resolveTextarea() {
|
|
29
|
+
textareaEl.value = hostRef.value?.querySelector("textarea") ?? null;
|
|
30
|
+
}
|
|
31
|
+
onMounted(resolveTextarea);
|
|
32
|
+
watch(() => props.fieldKey, resolveTextarea);
|
|
33
|
+
const { carets } = useAACaret(() => props.fieldKey, textareaEl);
|
|
34
|
+
const ringStyle = computed(
|
|
35
|
+
() => enableAwareness.value ? awareRingStyle({
|
|
36
|
+
hover: hoverers.value[0]?.user?.color,
|
|
37
|
+
focus: focusers.value[0]?.user?.color,
|
|
38
|
+
press: pressers.value[0]?.user?.color
|
|
39
|
+
}) : void 0
|
|
40
|
+
);
|
|
41
|
+
const overlayPeers = computed(() => {
|
|
42
|
+
if (!enableAwareness.value) return [];
|
|
43
|
+
const seen = /* @__PURE__ */ new Set();
|
|
44
|
+
const out = [];
|
|
45
|
+
for (const p of focusers.value) if (!seen.has(p.clientId)) {
|
|
46
|
+
seen.add(p.clientId);
|
|
47
|
+
out.push(p);
|
|
13
48
|
}
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
49
|
+
for (const p of hoverers.value) if (!seen.has(p.clientId)) {
|
|
50
|
+
seen.add(p.clientId);
|
|
51
|
+
out.push(p);
|
|
17
52
|
}
|
|
18
|
-
return
|
|
53
|
+
return out;
|
|
19
54
|
});
|
|
55
|
+
const eventHandlers = computed(() => enableAwareness.value ? handlers : {});
|
|
20
56
|
</script>
|
|
21
57
|
|
|
22
58
|
<template>
|
|
23
59
|
<div
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
60
|
+
ref="hostRef"
|
|
61
|
+
class="aa-host aa-host--block"
|
|
62
|
+
:class="{ 'aa-host--pressed': isPressed }"
|
|
63
|
+
:style="ringStyle"
|
|
64
|
+
v-on="eventHandlers"
|
|
27
65
|
>
|
|
28
|
-
<UTextarea
|
|
66
|
+
<UTextarea
|
|
67
|
+
v-if="enableSync && !hasExternalModel"
|
|
68
|
+
v-model="synced"
|
|
69
|
+
v-bind="attrs"
|
|
70
|
+
/>
|
|
71
|
+
<UTextarea
|
|
72
|
+
v-else
|
|
73
|
+
v-bind="attrs"
|
|
74
|
+
/>
|
|
75
|
+
|
|
76
|
+
<APeerCaretLayer
|
|
77
|
+
v-if="enablePeers"
|
|
78
|
+
:target="textareaEl"
|
|
79
|
+
:carets="carets"
|
|
80
|
+
/>
|
|
81
|
+
|
|
29
82
|
<Transition name="aa-peer">
|
|
30
83
|
<span
|
|
31
|
-
v-if="
|
|
32
|
-
class="
|
|
84
|
+
v-if="overlayPeers.length"
|
|
85
|
+
class="aa-overlay"
|
|
33
86
|
>
|
|
34
87
|
<AAvatar
|
|
35
|
-
v-for="p in
|
|
88
|
+
v-for="p in overlayPeers.slice(0, max)"
|
|
36
89
|
:key="p.clientId"
|
|
37
90
|
:user="p"
|
|
38
91
|
size="2xs"
|
|
@@ -45,5 +98,5 @@ const focusRingStyle = computed(() => {
|
|
|
45
98
|
</template>
|
|
46
99
|
|
|
47
100
|
<style scoped>
|
|
48
|
-
.aa-peer-enter-active,.aa-peer-leave-active{transition:opacity .15s ease}.aa-peer-enter-from,.aa-peer-leave-to{opacity:0}
|
|
101
|
+
.aa-host{border-radius:var(--ui-radius,.375rem);position:relative;transition:filter .12s ease}.aa-host--block{display:block}.aa-host--pressed{filter:brightness(.9)}.aa-overlay{display:flex;gap:0;pointer-events:none;position:absolute;right:0;top:-.625rem;z-index:10}.aa-overlay>*+*{margin-left:-.25rem}.aa-peer-enter-active,.aa-peer-leave-active{transition:opacity .15s ease}.aa-peer-enter-from,.aa-peer-leave-to{opacity:0}
|
|
49
102
|
</style>
|
|
@@ -1,7 +1,17 @@
|
|
|
1
1
|
type __VLS_Props = {
|
|
2
|
-
/** Unique field key for awareness broadcasting. Convention: "{scope}:{id}" */
|
|
3
2
|
fieldKey: string;
|
|
3
|
+
awareness?: boolean;
|
|
4
|
+
sync?: boolean;
|
|
5
|
+
peers?: boolean;
|
|
6
|
+
total?: boolean;
|
|
7
|
+
max?: number;
|
|
4
8
|
};
|
|
5
|
-
declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
9
|
+
declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
10
|
+
sync: boolean;
|
|
11
|
+
peers: boolean;
|
|
12
|
+
awareness: boolean;
|
|
13
|
+
max: number;
|
|
14
|
+
total: boolean;
|
|
15
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
6
16
|
declare const _default: typeof __VLS_export;
|
|
7
17
|
export default _default;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
type __VLS_Props = {
|
|
2
|
+
fieldKey: string;
|
|
3
|
+
awareness?: boolean;
|
|
4
|
+
sync?: boolean;
|
|
5
|
+
total?: boolean;
|
|
6
|
+
max?: number;
|
|
7
|
+
};
|
|
8
|
+
declare var __VLS_9: string, __VLS_10: any, __VLS_20: string, __VLS_21: any;
|
|
9
|
+
type __VLS_Slots = {} & {
|
|
10
|
+
[K in NonNullable<typeof __VLS_9>]?: (props: typeof __VLS_10) => any;
|
|
11
|
+
} & {
|
|
12
|
+
[K in NonNullable<typeof __VLS_20>]?: (props: typeof __VLS_21) => any;
|
|
13
|
+
};
|
|
14
|
+
declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
15
|
+
sync: boolean;
|
|
16
|
+
awareness: boolean;
|
|
17
|
+
max: number;
|
|
18
|
+
total: boolean;
|
|
19
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
20
|
+
declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
|
|
21
|
+
declare const _default: typeof __VLS_export;
|
|
22
|
+
export default _default;
|
|
23
|
+
type __VLS_WithSlots<T, S> = T & {
|
|
24
|
+
new (): {
|
|
25
|
+
$slots: S;
|
|
26
|
+
};
|
|
27
|
+
};
|