@abraca/nuxt 0.2.0 → 1.5.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 +72 -0
- package/dist/module.json +1 -1
- package/dist/module.mjs +139 -3
- package/dist/runtime/assets/editor.css +1 -0
- package/dist/runtime/components/AAccountSwitcherModal.d.vue.ts +10 -0
- package/dist/runtime/components/AAccountSwitcherModal.vue +158 -0
- package/dist/runtime/components/AAccountSwitcherModal.vue.d.ts +10 -0
- package/dist/runtime/components/AClaimAccountModal.d.vue.ts +10 -0
- package/dist/runtime/components/AClaimAccountModal.vue +230 -0
- package/dist/runtime/components/AClaimAccountModal.vue.d.ts +10 -0
- package/dist/runtime/components/ACollaborationUsers.vue +1 -0
- package/dist/runtime/components/AColorPicker.vue +4 -2
- package/dist/runtime/components/ACommandPalette.vue +8 -3
- package/dist/runtime/components/AConnectServerModal.d.vue.ts +12 -0
- package/dist/runtime/components/AConnectServerModal.vue +200 -0
- package/dist/runtime/components/AConnectServerModal.vue.d.ts +12 -0
- package/dist/runtime/components/AConnectionStatus.vue +1 -0
- package/dist/runtime/components/ADocPickModal.d.vue.ts +13 -0
- package/dist/runtime/components/ADocPickModal.vue +71 -0
- package/dist/runtime/components/ADocPickModal.vue.d.ts +13 -0
- package/dist/runtime/components/ADocRenderer.d.vue.ts +29 -0
- package/dist/runtime/components/ADocRenderer.vue +105 -0
- package/dist/runtime/components/ADocRenderer.vue.d.ts +29 -0
- package/dist/runtime/components/ADocTypeSelect.vue +8 -4
- package/dist/runtime/components/ADocumentTree.d.vue.ts +3 -3
- package/dist/runtime/components/ADocumentTree.vue +196 -29
- package/dist/runtime/components/ADocumentTree.vue.d.ts +3 -3
- package/dist/runtime/components/AEditor.d.vue.ts +9 -4
- package/dist/runtime/components/AEditor.vue +118 -8
- package/dist/runtime/components/AEditor.vue.d.ts +9 -4
- package/dist/runtime/components/AFloatingWindow.d.vue.ts +54 -2
- package/dist/runtime/components/AFloatingWindow.vue +15 -14
- package/dist/runtime/components/AFloatingWindow.vue.d.ts +54 -2
- package/dist/runtime/components/AIconPicker.vue +10 -2
- package/dist/runtime/components/AInviteRedeemModal.d.vue.ts +10 -0
- package/dist/runtime/components/AInviteRedeemModal.vue +122 -0
- package/dist/runtime/components/AInviteRedeemModal.vue.d.ts +10 -0
- package/dist/runtime/components/ANodePanel.vue +109 -62
- package/dist/runtime/components/ANotifications.vue +37 -8
- package/dist/runtime/components/APermissionGuard.vue +4 -1
- package/dist/runtime/components/APresence.vue +15 -3
- package/dist/runtime/components/AProvider.d.vue.ts +0 -1
- package/dist/runtime/components/AProvider.vue +24 -5
- package/dist/runtime/components/AProvider.vue.d.ts +0 -1
- package/dist/runtime/components/ARoleBadge.vue +1 -0
- package/dist/runtime/components/ASpaceFormModal.d.vue.ts +16 -0
- package/dist/runtime/components/ASpaceFormModal.vue +182 -0
- package/dist/runtime/components/ASpaceFormModal.vue.d.ts +16 -0
- package/dist/runtime/components/AVoiceBar.vue +60 -16
- package/dist/runtime/components/AVoiceTile.vue +5 -1
- package/dist/runtime/components/AWindowLayer.vue +1 -0
- package/dist/runtime/components/aware/AArea.d.vue.ts +1 -1
- package/dist/runtime/components/aware/AArea.vue +3 -2
- package/dist/runtime/components/aware/AArea.vue.d.ts +1 -1
- package/dist/runtime/components/aware/AAvatar.vue +87 -16
- package/dist/runtime/components/aware/AButton.vue +7 -2
- package/dist/runtime/components/aware/ACursorLabel.vue +6 -1
- package/dist/runtime/components/aware/ADocBadge.vue +6 -1
- package/dist/runtime/components/aware/AFacepile.vue +15 -3
- package/dist/runtime/components/aware/AInput.vue +8 -3
- package/dist/runtime/components/aware/ASelect.vue +3 -2
- package/dist/runtime/components/aware/ATextarea.vue +8 -3
- package/dist/runtime/components/aware/AUserList.vue +10 -2
- package/dist/runtime/components/chat/AChatAgentStatus.d.vue.ts +15 -0
- package/dist/runtime/components/chat/AChatAgentStatus.vue +95 -0
- package/dist/runtime/components/chat/AChatAgentStatus.vue.d.ts +15 -0
- package/dist/runtime/components/chat/AChatDocLink.d.vue.ts +18 -0
- package/dist/runtime/components/chat/AChatDocLink.vue +29 -0
- package/dist/runtime/components/chat/AChatDocLink.vue.d.ts +18 -0
- package/dist/runtime/components/chat/AChatDocQuote.d.vue.ts +26 -0
- package/dist/runtime/components/chat/AChatDocQuote.vue +47 -0
- package/dist/runtime/components/chat/AChatDocQuote.vue.d.ts +26 -0
- package/dist/runtime/components/chat/AChatInput.d.vue.ts +45 -0
- package/dist/runtime/components/chat/AChatInput.vue +219 -0
- package/dist/runtime/components/chat/AChatInput.vue.d.ts +45 -0
- package/dist/runtime/components/chat/AChatList.d.vue.ts +59 -0
- package/dist/runtime/components/chat/AChatList.vue +184 -0
- package/dist/runtime/components/chat/AChatList.vue.d.ts +59 -0
- package/dist/runtime/components/chat/AChatMemberList.d.vue.ts +24 -0
- package/dist/runtime/components/chat/AChatMemberList.vue +97 -0
- package/dist/runtime/components/chat/AChatMemberList.vue.d.ts +24 -0
- package/dist/runtime/components/chat/AChatMessages.d.vue.ts +31 -0
- package/dist/runtime/components/chat/AChatMessages.vue +161 -0
- package/dist/runtime/components/chat/AChatMessages.vue.d.ts +31 -0
- package/dist/runtime/components/chat/AChatPanel.d.vue.ts +84 -0
- package/dist/runtime/components/chat/AChatPanel.vue +89 -0
- package/dist/runtime/components/chat/AChatPanel.vue.d.ts +84 -0
- package/dist/runtime/components/chat/AChatTypingIndicator.d.vue.ts +11 -0
- package/dist/runtime/components/chat/AChatTypingIndicator.vue +58 -0
- package/dist/runtime/components/chat/AChatTypingIndicator.vue.d.ts +11 -0
- package/dist/runtime/components/editor/AColorPalettePopover.d.vue.ts +23 -0
- package/dist/runtime/components/editor/AColorPalettePopover.vue +71 -0
- package/dist/runtime/components/editor/AColorPalettePopover.vue.d.ts +23 -0
- package/dist/runtime/components/editor/ADocLinkPopover.d.vue.ts +7 -0
- package/dist/runtime/components/editor/ADocLinkPopover.vue +74 -0
- package/dist/runtime/components/editor/ADocLinkPopover.vue.d.ts +7 -0
- package/dist/runtime/components/editor/AFileAudioPlayer.d.vue.ts +10 -0
- package/dist/runtime/components/editor/AFileAudioPlayer.vue +353 -0
- package/dist/runtime/components/editor/AFileAudioPlayer.vue.d.ts +10 -0
- package/dist/runtime/components/editor/AFileGlbViewer.d.vue.ts +13 -0
- package/dist/runtime/components/editor/AFileGlbViewer.vue +187 -0
- package/dist/runtime/components/editor/AFileGlbViewer.vue.d.ts +13 -0
- package/dist/runtime/components/editor/AFileVideoPlayer.d.vue.ts +7 -0
- package/dist/runtime/components/editor/AFileVideoPlayer.vue +62 -0
- package/dist/runtime/components/editor/AFileVideoPlayer.vue.d.ts +7 -0
- package/dist/runtime/components/editor/ALinkPopover.d.vue.ts +8 -0
- package/dist/runtime/components/editor/ALinkPopover.vue +149 -0
- package/dist/runtime/components/editor/ALinkPopover.vue.d.ts +8 -0
- package/dist/runtime/components/editor/ALocationPickerPopover.d.vue.ts +28 -0
- package/dist/runtime/components/editor/ALocationPickerPopover.vue +232 -0
- package/dist/runtime/components/editor/ALocationPickerPopover.vue.d.ts +28 -0
- package/dist/runtime/components/renderers/ACalendarRenderer.d.vue.ts +14 -1
- package/dist/runtime/components/renderers/ACalendarRenderer.vue +279 -125
- package/dist/runtime/components/renderers/ACalendarRenderer.vue.d.ts +14 -1
- package/dist/runtime/components/renderers/ACallRenderer.d.vue.ts +13 -0
- package/dist/runtime/components/renderers/ACallRenderer.vue +172 -0
- package/dist/runtime/components/renderers/ACallRenderer.vue.d.ts +13 -0
- package/dist/runtime/components/renderers/AChecklistRenderer.d.vue.ts +19 -0
- package/dist/runtime/components/renderers/AChecklistRenderer.vue +582 -0
- package/dist/runtime/components/renderers/AChecklistRenderer.vue.d.ts +19 -0
- package/dist/runtime/components/renderers/ADashboardRenderer.d.vue.ts +19 -0
- package/dist/runtime/components/renderers/ADashboardRenderer.vue +1374 -0
- package/dist/runtime/components/renderers/ADashboardRenderer.vue.d.ts +19 -0
- package/dist/runtime/components/renderers/AGalleryCoverImage.d.vue.ts +8 -0
- package/dist/runtime/components/renderers/AGalleryCoverImage.vue +60 -0
- package/dist/runtime/components/renderers/AGalleryCoverImage.vue.d.ts +8 -0
- package/dist/runtime/components/renderers/AGalleryRenderer.d.vue.ts +12 -1
- package/dist/runtime/components/renderers/AGalleryRenderer.vue +327 -53
- package/dist/runtime/components/renderers/AGalleryRenderer.vue.d.ts +12 -1
- package/dist/runtime/components/renderers/AGraphRenderer.d.vue.ts +19 -0
- package/dist/runtime/components/renderers/AGraphRenderer.vue +1030 -0
- package/dist/runtime/components/renderers/AGraphRenderer.vue.d.ts +19 -0
- package/dist/runtime/components/renderers/AKanbanRenderer.d.vue.ts +13 -1
- package/dist/runtime/components/renderers/AKanbanRenderer.vue +490 -140
- package/dist/runtime/components/renderers/AKanbanRenderer.vue.d.ts +13 -1
- package/dist/runtime/components/renderers/AMapRenderer.d.vue.ts +19 -0
- package/dist/runtime/components/renderers/AMapRenderer.vue +1624 -0
- package/dist/runtime/components/renderers/AMapRenderer.vue.d.ts +19 -0
- package/dist/runtime/components/renderers/AMediaRenderer.d.vue.ts +19 -0
- package/dist/runtime/components/renderers/AMediaRenderer.vue +224 -0
- package/dist/runtime/components/renderers/AMediaRenderer.vue.d.ts +19 -0
- package/dist/runtime/components/renderers/AOutlineRenderer.d.vue.ts +12 -1
- package/dist/runtime/components/renderers/AOutlineRenderer.vue +295 -134
- package/dist/runtime/components/renderers/AOutlineRenderer.vue.d.ts +12 -1
- package/dist/runtime/components/renderers/ASpatialRenderer.d.vue.ts +19 -0
- package/dist/runtime/components/renderers/ASpatialRenderer.vue +436 -0
- package/dist/runtime/components/renderers/ASpatialRenderer.vue.d.ts +19 -0
- package/dist/runtime/components/renderers/ATableRenderer.d.vue.ts +12 -1
- package/dist/runtime/components/renderers/ATableRenderer.vue +459 -147
- package/dist/runtime/components/renderers/ATableRenderer.vue.d.ts +12 -1
- package/dist/runtime/components/renderers/ATimelineRenderer.d.vue.ts +19 -0
- package/dist/runtime/components/renderers/ATimelineRenderer.vue +468 -0
- package/dist/runtime/components/renderers/ATimelineRenderer.vue.d.ts +19 -0
- package/dist/runtime/components/renderers/calendar/ACalendarDayCell.d.vue.ts +41 -0
- package/dist/runtime/components/renderers/calendar/ACalendarDayCell.vue +109 -0
- package/dist/runtime/components/renderers/calendar/ACalendarDayCell.vue.d.ts +41 -0
- package/dist/runtime/components/renderers/calendar/ACalendarDayView.d.vue.ts +49 -0
- package/dist/runtime/components/renderers/calendar/ACalendarDayView.vue +152 -0
- package/dist/runtime/components/renderers/calendar/ACalendarDayView.vue.d.ts +49 -0
- package/dist/runtime/components/renderers/calendar/ACalendarEventChip.d.vue.ts +39 -0
- package/dist/runtime/components/renderers/calendar/ACalendarEventChip.vue +101 -0
- package/dist/runtime/components/renderers/calendar/ACalendarEventChip.vue.d.ts +39 -0
- package/dist/runtime/components/renderers/calendar/ACalendarMonthView.d.vue.ts +43 -0
- package/dist/runtime/components/renderers/calendar/ACalendarMonthView.vue +87 -0
- package/dist/runtime/components/renderers/calendar/ACalendarMonthView.vue.d.ts +43 -0
- package/dist/runtime/components/renderers/calendar/ACalendarToolbar.d.vue.ts +38 -0
- package/dist/runtime/components/renderers/calendar/ACalendarToolbar.vue +206 -0
- package/dist/runtime/components/renderers/calendar/ACalendarToolbar.vue.d.ts +38 -0
- package/dist/runtime/components/renderers/calendar/ACalendarUnscheduled.d.vue.ts +28 -0
- package/dist/runtime/components/renderers/calendar/ACalendarUnscheduled.vue +33 -0
- package/dist/runtime/components/renderers/calendar/ACalendarUnscheduled.vue.d.ts +28 -0
- package/dist/runtime/components/renderers/calendar/ACalendarWeekView.d.vue.ts +50 -0
- package/dist/runtime/components/renderers/calendar/ACalendarWeekView.vue +188 -0
- package/dist/runtime/components/renderers/calendar/ACalendarWeekView.vue.d.ts +50 -0
- package/dist/runtime/components/renderers/media/MediaPlaylist.d.vue.ts +25 -0
- package/dist/runtime/components/renderers/media/MediaPlaylist.vue +115 -0
- package/dist/runtime/components/renderers/media/MediaPlaylist.vue.d.ts +25 -0
- package/dist/runtime/components/renderers/media/MediaSyncBar.d.vue.ts +21 -0
- package/dist/runtime/components/renderers/media/MediaSyncBar.vue +61 -0
- package/dist/runtime/components/renderers/media/MediaSyncBar.vue.d.ts +21 -0
- package/dist/runtime/components/renderers/media/MediaTransportBar.d.vue.ts +22 -0
- package/dist/runtime/components/renderers/media/MediaTransportBar.vue +98 -0
- package/dist/runtime/components/renderers/media/MediaTransportBar.vue.d.ts +22 -0
- package/dist/runtime/components/renderers/spatial/SpatialGround.d.vue.ts +20 -0
- package/dist/runtime/components/renderers/spatial/SpatialGround.vue +26 -0
- package/dist/runtime/components/renderers/spatial/SpatialGround.vue.d.ts +20 -0
- package/dist/runtime/components/renderers/spatial/SpatialObject.d.vue.ts +17 -0
- package/dist/runtime/components/renderers/spatial/SpatialObject.vue +257 -0
- package/dist/runtime/components/renderers/spatial/SpatialObject.vue.d.ts +17 -0
- package/dist/runtime/components/renderers/spatial/SpatialSceneBridge.d.vue.ts +15 -0
- package/dist/runtime/components/renderers/spatial/SpatialSceneBridge.vue +18 -0
- package/dist/runtime/components/renderers/spatial/SpatialSceneBridge.vue.d.ts +15 -0
- package/dist/runtime/components/renderers/spatial/SpatialUserAvatar.d.vue.ts +8 -0
- package/dist/runtime/components/renderers/spatial/SpatialUserAvatar.vue +53 -0
- package/dist/runtime/components/renderers/spatial/SpatialUserAvatar.vue.d.ts +8 -0
- package/dist/runtime/components/renderers/table/ATableColumnHeader.d.vue.ts +25 -0
- package/dist/runtime/components/renderers/table/ATableColumnHeader.vue +129 -0
- package/dist/runtime/components/renderers/table/ATableColumnHeader.vue.d.ts +25 -0
- package/dist/runtime/components/renderers/table/ATableFlatMode.d.vue.ts +21 -0
- package/dist/runtime/components/renderers/table/ATableFlatMode.vue +370 -0
- package/dist/runtime/components/renderers/table/ATableFlatMode.vue.d.ts +21 -0
- package/dist/runtime/components/renderers/table/ATableToolbar.d.vue.ts +22 -0
- package/dist/runtime/components/renderers/table/ATableToolbar.vue +106 -0
- package/dist/runtime/components/renderers/table/ATableToolbar.vue.d.ts +22 -0
- package/dist/runtime/components/renderers/table/cells/ATableCell.d.vue.ts +18 -0
- package/dist/runtime/components/renderers/table/cells/ATableCell.vue +54 -0
- package/dist/runtime/components/renderers/table/cells/ATableCell.vue.d.ts +18 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellColor.d.vue.ts +14 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellColor.vue +67 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellColor.vue.d.ts +14 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellDate.d.vue.ts +16 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellDate.vue +91 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellDate.vue.d.ts +16 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellMembers.d.vue.ts +6 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellMembers.vue +30 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellMembers.vue.d.ts +6 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellMultiSelect.d.vue.ts +17 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellMultiSelect.vue +76 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellMultiSelect.vue.d.ts +17 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellNumber.d.vue.ts +17 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellNumber.vue +54 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellNumber.vue.d.ts +17 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellRating.d.vue.ts +16 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellRating.vue +35 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellRating.vue.d.ts +16 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellSelect.d.vue.ts +18 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellSelect.vue +111 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellSelect.vue.d.ts +18 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellSlider.d.vue.ts +16 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellSlider.vue +35 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellSlider.vue.d.ts +16 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellTags.d.vue.ts +15 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellTags.vue +92 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellTags.vue.d.ts +15 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellText.d.vue.ts +15 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellText.vue +44 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellText.vue.d.ts +15 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellToggle.d.vue.ts +14 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellToggle.vue +31 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellToggle.vue.d.ts +14 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellUrl.d.vue.ts +15 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellUrl.vue +63 -0
- package/dist/runtime/components/renderers/table/cells/ATableCellUrl.vue.d.ts +15 -0
- package/dist/runtime/components/renderers/timeline/ATimelineAxis.d.vue.ts +9 -0
- package/dist/runtime/components/renderers/timeline/ATimelineAxis.vue +53 -0
- package/dist/runtime/components/renderers/timeline/ATimelineAxis.vue.d.ts +9 -0
- package/dist/runtime/components/renderers/timeline/ATimelineBar.d.vue.ts +26 -0
- package/dist/runtime/components/renderers/timeline/ATimelineBar.vue +59 -0
- package/dist/runtime/components/renderers/timeline/ATimelineBar.vue.d.ts +26 -0
- package/dist/runtime/components/renderers/timeline/ATimelineBarArea.d.vue.ts +28 -0
- package/dist/runtime/components/renderers/timeline/ATimelineBarArea.vue +109 -0
- package/dist/runtime/components/renderers/timeline/ATimelineBarArea.vue.d.ts +28 -0
- package/dist/runtime/components/renderers/timeline/ATimelineLabelPanel.d.vue.ts +43 -0
- package/dist/runtime/components/renderers/timeline/ATimelineLabelPanel.vue +168 -0
- package/dist/runtime/components/renderers/timeline/ATimelineLabelPanel.vue.d.ts +43 -0
- package/dist/runtime/components/renderers/timeline/ATimelineMilestone.d.vue.ts +24 -0
- package/dist/runtime/components/renderers/timeline/ATimelineMilestone.vue +46 -0
- package/dist/runtime/components/renderers/timeline/ATimelineMilestone.vue.d.ts +24 -0
- package/dist/runtime/components/renderers/timeline/ATimelineToolbar.d.vue.ts +34 -0
- package/dist/runtime/components/renderers/timeline/ATimelineToolbar.vue +193 -0
- package/dist/runtime/components/renderers/timeline/ATimelineToolbar.vue.d.ts +34 -0
- package/dist/runtime/components/settings/ASettingsAdminPanel.d.vue.ts +3 -0
- package/dist/runtime/components/settings/ASettingsAdminPanel.vue +159 -0
- package/dist/runtime/components/settings/ASettingsAdminPanel.vue.d.ts +3 -0
- package/dist/runtime/components/settings/ASettingsConnectionPanel.d.vue.ts +3 -0
- package/dist/runtime/components/settings/ASettingsConnectionPanel.vue +146 -0
- package/dist/runtime/components/settings/ASettingsConnectionPanel.vue.d.ts +3 -0
- package/dist/runtime/components/settings/ASettingsInvitesPanel.d.vue.ts +3 -0
- package/dist/runtime/components/settings/ASettingsInvitesPanel.vue +157 -0
- package/dist/runtime/components/settings/ASettingsInvitesPanel.vue.d.ts +3 -0
- package/dist/runtime/components/settings/ASettingsMembersPanel.d.vue.ts +3 -0
- package/dist/runtime/components/settings/ASettingsMembersPanel.vue +134 -0
- package/dist/runtime/components/settings/ASettingsMembersPanel.vue.d.ts +3 -0
- package/dist/runtime/components/settings/ASettingsModal.d.vue.ts +3 -0
- package/dist/runtime/components/settings/ASettingsModal.vue +176 -0
- package/dist/runtime/components/settings/ASettingsModal.vue.d.ts +3 -0
- package/dist/runtime/components/settings/ASettingsOfflinePanel.d.vue.ts +3 -0
- package/dist/runtime/components/settings/ASettingsOfflinePanel.vue +170 -0
- package/dist/runtime/components/settings/ASettingsOfflinePanel.vue.d.ts +3 -0
- package/dist/runtime/components/settings/ASettingsPluginsPanel.d.vue.ts +3 -0
- package/dist/runtime/components/settings/ASettingsPluginsPanel.vue +96 -0
- package/dist/runtime/components/settings/ASettingsPluginsPanel.vue.d.ts +3 -0
- package/dist/runtime/components/settings/ASettingsProfilePanel.d.vue.ts +3 -0
- package/dist/runtime/components/settings/ASettingsProfilePanel.vue +223 -0
- package/dist/runtime/components/settings/ASettingsProfilePanel.vue.d.ts +3 -0
- package/dist/runtime/components/settings/ASettingsSecurityPanel.d.vue.ts +3 -0
- package/dist/runtime/components/settings/ASettingsSecurityPanel.vue +312 -0
- package/dist/runtime/components/settings/ASettingsSecurityPanel.vue.d.ts +3 -0
- package/dist/runtime/components/settings/ASettingsSpacesPanel.d.vue.ts +3 -0
- package/dist/runtime/components/settings/ASettingsSpacesPanel.vue +195 -0
- package/dist/runtime/components/settings/ASettingsSpacesPanel.vue.d.ts +3 -0
- package/dist/runtime/components/settings/ASettingsTrashPanel.d.vue.ts +3 -0
- package/dist/runtime/components/settings/ASettingsTrashPanel.vue +135 -0
- package/dist/runtime/components/settings/ASettingsTrashPanel.vue.d.ts +3 -0
- package/dist/runtime/components/shell/AChildContextMenu.d.vue.ts +30 -0
- package/dist/runtime/components/shell/AChildContextMenu.vue +48 -0
- package/dist/runtime/components/shell/AChildContextMenu.vue.d.ts +30 -0
- package/dist/runtime/components/shell/ACursorOverlay.d.vue.ts +11 -0
- package/dist/runtime/components/shell/ACursorOverlay.vue +55 -0
- package/dist/runtime/components/shell/ACursorOverlay.vue.d.ts +11 -0
- package/dist/runtime/components/shell/ADocDragGhost.d.vue.ts +3 -0
- package/dist/runtime/components/shell/ADocDragGhost.vue +58 -0
- package/dist/runtime/components/shell/ADocDragGhost.vue.d.ts +3 -0
- package/dist/runtime/components/shell/ADocPanelSettings.d.vue.ts +111 -0
- package/dist/runtime/components/shell/ADocPanelSettings.vue +621 -0
- package/dist/runtime/components/shell/ADocPanelSettings.vue.d.ts +111 -0
- package/dist/runtime/components/shell/AFavoritesList.d.vue.ts +27 -0
- package/dist/runtime/components/shell/AFavoritesList.vue +83 -0
- package/dist/runtime/components/shell/AFavoritesList.vue.d.ts +27 -0
- package/dist/runtime/components/shell/ANodeContextMenu.d.vue.ts +17 -0
- package/dist/runtime/components/shell/ANodeContextMenu.vue +14 -0
- package/dist/runtime/components/shell/ANodeContextMenu.vue.d.ts +17 -0
- package/dist/runtime/components/shell/ASidebar.d.vue.ts +54 -0
- package/dist/runtime/components/shell/ASidebar.vue +92 -0
- package/dist/runtime/components/shell/ASidebar.vue.d.ts +54 -0
- package/dist/runtime/components/shell/ASidebarToggle.d.vue.ts +7 -0
- package/dist/runtime/components/shell/ASidebarToggle.vue +23 -0
- package/dist/runtime/components/shell/ASidebarToggle.vue.d.ts +7 -0
- package/dist/runtime/components/shell/ASpaceSwitcher.d.vue.ts +32 -0
- package/dist/runtime/components/shell/ASpaceSwitcher.vue +63 -0
- package/dist/runtime/components/shell/ASpaceSwitcher.vue.d.ts +32 -0
- package/dist/runtime/components/shell/ASyncStatus.d.vue.ts +25 -0
- package/dist/runtime/components/shell/ASyncStatus.vue +96 -0
- package/dist/runtime/components/shell/ASyncStatus.vue.d.ts +25 -0
- package/dist/runtime/components/shell/AUserMenu.d.vue.ts +28 -0
- package/dist/runtime/components/shell/AUserMenu.vue +79 -0
- package/dist/runtime/components/shell/AUserMenu.vue.d.ts +28 -0
- package/dist/runtime/components/shell/AUserProfilePopover.d.vue.ts +54 -0
- package/dist/runtime/components/shell/AUserProfilePopover.vue +176 -0
- package/dist/runtime/components/shell/AUserProfilePopover.vue.d.ts +54 -0
- package/dist/runtime/components/shell/AWelcomeScreen.d.vue.ts +96 -0
- package/dist/runtime/components/shell/AWelcomeScreen.vue +422 -0
- package/dist/runtime/components/shell/AWelcomeScreen.vue.d.ts +96 -0
- package/dist/runtime/composables/useAAField.js +2 -0
- package/dist/runtime/composables/useAbraLocale.js +1 -0
- package/dist/runtime/composables/useAbracadabra.js +1 -0
- package/dist/runtime/composables/useAbracadabraAuth.d.ts +3 -4
- package/dist/runtime/composables/useAbracadabraAuth.js +4 -0
- package/dist/runtime/composables/useAwareness.js +6 -0
- package/dist/runtime/composables/useAwarenessPeers.js +1 -0
- package/dist/runtime/composables/useBackgroundSync.d.ts +5 -0
- package/dist/runtime/composables/useBackgroundSync.js +24 -3
- package/dist/runtime/composables/useBroadcastSync.d.ts +18 -0
- package/dist/runtime/composables/useBroadcastSync.js +26 -0
- package/dist/runtime/composables/useCalendarView.d.ts +86 -0
- package/dist/runtime/composables/useCalendarView.js +316 -0
- package/dist/runtime/composables/useChat.d.ts +2 -1
- package/dist/runtime/composables/useChat.js +21 -12
- package/dist/runtime/composables/useChatUsers.js +3 -1
- package/dist/runtime/composables/useChildTree.d.ts +4 -2
- package/dist/runtime/composables/useChildTree.js +31 -21
- package/dist/runtime/composables/useCommandPalette.js +77 -19
- package/dist/runtime/composables/useConnectionStatus.d.ts +1 -1
- package/dist/runtime/composables/useConnectionStatus.js +8 -1
- package/dist/runtime/composables/useCrossWindowSync.d.ts +11 -0
- package/dist/runtime/composables/useCrossWindowSync.js +38 -0
- package/dist/runtime/composables/useDashboard.js +17 -9
- package/dist/runtime/composables/useDevicePairing.d.ts +58 -0
- package/dist/runtime/composables/useDevicePairing.js +110 -0
- package/dist/runtime/composables/useDocDragBus.d.ts +28 -0
- package/dist/runtime/composables/useDocDragBus.js +22 -0
- package/dist/runtime/composables/useDocDropZone.d.ts +51 -0
- package/dist/runtime/composables/useDocDropZone.js +84 -0
- package/dist/runtime/composables/useDocExport.d.ts +5 -0
- package/dist/runtime/composables/useDocExport.js +4 -2
- package/dist/runtime/composables/useDocImport.js +5 -3
- package/dist/runtime/composables/useDocLabels.d.ts +22 -0
- package/dist/runtime/composables/useDocLabels.js +11 -0
- package/dist/runtime/composables/useDocLinkPick.d.ts +18 -0
- package/dist/runtime/composables/useDocLinkPick.js +22 -0
- package/dist/runtime/composables/useDocSeo.d.ts +20 -0
- package/dist/runtime/composables/useDocSeo.js +45 -0
- package/dist/runtime/composables/useDocSlugs.d.ts +7 -0
- package/dist/runtime/composables/useDocSlugs.js +23 -0
- package/dist/runtime/composables/useDocTree.d.ts +35 -0
- package/dist/runtime/composables/useDocTree.js +39 -0
- package/dist/runtime/composables/useEditor.js +1 -0
- package/dist/runtime/composables/useEditorDragHandle.js +4 -1
- package/dist/runtime/composables/useEditorEmojis.d.ts +22 -0
- package/dist/runtime/composables/useEditorEmojis.js +57 -0
- package/dist/runtime/composables/useEditorMentions.d.ts +10 -3
- package/dist/runtime/composables/useEditorMentions.js +35 -5
- package/dist/runtime/composables/useEditorSuggestions.d.ts +2 -1
- package/dist/runtime/composables/useEditorSuggestions.js +36 -21
- package/dist/runtime/composables/useEditorToolbar.d.ts +1 -1
- package/dist/runtime/composables/useEditorToolbar.js +5 -1
- package/dist/runtime/composables/useFavorites.d.ts +13 -0
- package/dist/runtime/composables/useFavorites.js +42 -0
- package/dist/runtime/composables/useFileIndex.js +4 -1
- package/dist/runtime/composables/useFileTransfer.d.ts +112 -0
- package/dist/runtime/composables/useFileTransfer.js +183 -0
- package/dist/runtime/composables/useFollowUser.js +4 -1
- package/dist/runtime/composables/useIdentityDoc.d.ts +89 -0
- package/dist/runtime/composables/useIdentityDoc.js +349 -0
- package/dist/runtime/composables/useInstalledPlugins.d.ts +31 -0
- package/dist/runtime/composables/useInstalledPlugins.js +58 -0
- package/dist/runtime/composables/useInvites.d.ts +56 -0
- package/dist/runtime/composables/useInvites.js +78 -0
- package/dist/runtime/composables/useJoinLink.d.ts +25 -0
- package/dist/runtime/composables/useJoinLink.js +58 -0
- package/dist/runtime/composables/useMediaExtractor.d.ts +31 -0
- package/dist/runtime/composables/useMediaExtractor.js +46 -0
- package/dist/runtime/composables/useMediaPlayback.d.ts +43 -0
- package/dist/runtime/composables/useMediaPlayback.js +465 -0
- package/dist/runtime/composables/useNodeContextMenu.d.ts +26 -0
- package/dist/runtime/composables/useNodeContextMenu.js +99 -0
- package/dist/runtime/composables/useNodePanel.d.ts +20 -0
- package/dist/runtime/composables/useNodePanel.js +89 -0
- package/dist/runtime/composables/useNodePanelFollow.d.ts +2 -0
- package/dist/runtime/composables/useNodePanelFollow.js +37 -0
- package/dist/runtime/composables/useNotifications.d.ts +1 -0
- package/dist/runtime/composables/useNotifications.js +9 -2
- package/dist/runtime/composables/usePasskeyAccounts.js +4 -2
- package/dist/runtime/composables/usePluginRegistry.js +1 -0
- package/dist/runtime/composables/useRendererBase.d.ts +16 -1
- package/dist/runtime/composables/useRendererBase.js +10 -1
- package/dist/runtime/composables/useSearchIndex.d.ts +1 -0
- package/dist/runtime/composables/useSearchIndex.js +15 -5
- package/dist/runtime/composables/useServerInfo.d.ts +31 -0
- package/dist/runtime/composables/useServerInfo.js +80 -0
- package/dist/runtime/composables/useSettingsModal.d.ts +18 -0
- package/dist/runtime/composables/useSettingsModal.js +30 -0
- package/dist/runtime/composables/useSlideoverSwipe.d.ts +39 -0
- package/dist/runtime/composables/useSlideoverSwipe.js +48 -0
- package/dist/runtime/composables/useSlugRoute.d.ts +6 -0
- package/dist/runtime/composables/useSlugRoute.js +21 -0
- package/dist/runtime/composables/useSpaces.d.ts +37 -0
- package/dist/runtime/composables/useSpaces.js +85 -0
- package/dist/runtime/composables/useSpatialCamera.d.ts +16 -0
- package/dist/runtime/composables/useSpatialCamera.js +175 -0
- package/dist/runtime/composables/useSpatialDrag.d.ts +14 -0
- package/dist/runtime/composables/useSpatialDrag.js +137 -0
- package/dist/runtime/composables/useTableView.d.ts +29 -0
- package/dist/runtime/composables/useTableView.js +184 -0
- package/dist/runtime/composables/useTimelineView.d.ts +55 -0
- package/dist/runtime/composables/useTimelineView.js +434 -0
- package/dist/runtime/composables/useTiptapDragState.d.ts +8 -0
- package/dist/runtime/composables/useTiptapDragState.js +5 -0
- package/dist/runtime/composables/useTouchDrag.d.ts +36 -0
- package/dist/runtime/composables/useTouchDrag.js +194 -0
- package/dist/runtime/composables/useTrash.d.ts +5 -1
- package/dist/runtime/composables/useTrash.js +12 -6
- package/dist/runtime/composables/useTreeUndoManager.d.ts +22 -0
- package/dist/runtime/composables/useTreeUndoManager.js +45 -0
- package/dist/runtime/composables/useUndoRedo.d.ts +37 -0
- package/dist/runtime/composables/useUndoRedo.js +115 -0
- package/dist/runtime/composables/useVoice.js +2 -0
- package/dist/runtime/composables/useWebRTC.d.ts +50 -0
- package/dist/runtime/composables/useWebRTC.js +179 -0
- package/dist/runtime/composables/useWindowManager.d.ts +2 -0
- package/dist/runtime/composables/useWindowManager.js +63 -1
- package/dist/runtime/extensions/code-preview.d.ts +2 -0
- package/dist/runtime/extensions/code-preview.js +17 -0
- package/dist/runtime/extensions/code-tree.d.ts +2 -0
- package/dist/runtime/extensions/code-tree.js +33 -0
- package/dist/runtime/extensions/doc-embed.d.ts +12 -0
- package/dist/runtime/extensions/doc-embed.js +63 -0
- package/dist/runtime/extensions/doc-link-drop.d.ts +3 -0
- package/dist/runtime/extensions/doc-link-drop.js +63 -0
- package/dist/runtime/extensions/document-header.js +1 -1
- package/dist/runtime/extensions/field.d.ts +3 -0
- package/dist/runtime/extensions/field.js +53 -0
- package/dist/runtime/extensions/mention-drop.d.ts +8 -0
- package/dist/runtime/extensions/mention-drop.js +47 -0
- package/dist/runtime/extensions/meta-field.d.ts +4 -1
- package/dist/runtime/extensions/meta-field.js +2 -0
- package/dist/runtime/extensions/selection-drag.d.ts +13 -0
- package/dist/runtime/extensions/selection-drag.js +126 -0
- package/dist/runtime/extensions/steps.js +1 -1
- package/dist/runtime/extensions/views/AccordionItemView.vue +14 -3
- package/dist/runtime/extensions/views/AccordionView.vue +4 -1
- package/dist/runtime/extensions/views/BadgeView.vue +12 -2
- package/dist/runtime/extensions/views/CalloutView.vue +4 -1
- package/dist/runtime/extensions/views/CardGroupView.vue +4 -1
- package/dist/runtime/extensions/views/CardView.vue +18 -3
- package/dist/runtime/extensions/views/CodeCollapseView.vue +1 -0
- package/dist/runtime/extensions/views/CodeGroupView.vue +5 -1
- package/dist/runtime/extensions/views/CodePreviewView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/CodePreviewView.vue +48 -0
- package/dist/runtime/extensions/views/CodePreviewView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/CodeTreeView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/CodeTreeView.vue +88 -0
- package/dist/runtime/extensions/views/CodeTreeView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/CollapsibleView.vue +9 -2
- package/dist/runtime/extensions/views/DocEmbedView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/DocEmbedView.vue +198 -0
- package/dist/runtime/extensions/views/DocEmbedView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/FieldGroupView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/FieldGroupView.vue +25 -0
- package/dist/runtime/extensions/views/FieldGroupView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/FieldView.d.vue.ts +4 -0
- package/dist/runtime/extensions/views/FieldView.vue +53 -0
- package/dist/runtime/extensions/views/FieldView.vue.d.ts +4 -0
- package/dist/runtime/extensions/views/FileNodeView.vue +34 -8
- package/dist/runtime/extensions/views/KbdView.vue +9 -2
- package/dist/runtime/extensions/views/MetaFieldView.vue +276 -48
- package/dist/runtime/extensions/views/ProseIconView.vue +9 -2
- package/dist/runtime/extensions/views/StepsView.vue +1 -0
- package/dist/runtime/extensions/views/TabsView.vue +18 -4
- package/dist/runtime/locale.d.ts +136 -0
- package/dist/runtime/locale.js +137 -1
- package/dist/runtime/middleware/abracadabra-auth.d.ts +1 -10
- package/dist/runtime/middleware/abracadabra-auth.js +2 -0
- package/dist/runtime/plugin-abracadabra.client.d.ts +1 -1
- package/dist/runtime/plugin-abracadabra.client.js +127 -55
- package/dist/runtime/plugin-abracadabra.server.d.ts +1 -1
- package/dist/runtime/plugin-abracadabra.server.js +4 -0
- package/dist/runtime/plugin-shared-globals.client.d.ts +1 -1
- package/dist/runtime/plugin-shared-globals.client.js +1 -0
- package/dist/runtime/plugins/core.plugin.js +40 -4
- package/dist/runtime/server/api/_abracadabra/render/[docId].get.d.ts +19 -17
- package/dist/runtime/server/api/_abracadabra/render/[docId].get.js +33 -4
- package/dist/runtime/server/api/_abracadabra/resolve/[...slug].get.d.ts +12 -0
- package/dist/runtime/server/api/_abracadabra/resolve/[...slug].get.js +44 -0
- package/dist/runtime/server/api/_abracadabra/slugs.get.d.ts +2 -0
- package/dist/runtime/server/api/_abracadabra/slugs.get.js +8 -0
- package/dist/runtime/server/api/_abracadabra/spaces.get.d.ts +1 -10
- package/dist/runtime/server/api/_abracadabra/spaces.get.js +3 -0
- package/dist/runtime/server/plugins/abracadabra-service.js +29 -12
- package/dist/runtime/server/runners/doc-tree-cache.js +4 -0
- package/dist/runtime/server/utils/docCache.d.ts +8 -6
- package/dist/runtime/server/utils/docCache.js +3 -3
- package/dist/runtime/server/utils/serverPluginLoader.d.ts +20 -0
- package/dist/runtime/server/utils/serverPluginLoader.js +42 -0
- package/dist/runtime/server/utils/serverRunner.d.ts +11 -2
- package/dist/runtime/server/utils/serverRunner.js +21 -10
- package/dist/runtime/server/utils/slugMap.d.ts +32 -0
- package/dist/runtime/server/utils/slugMap.js +58 -0
- package/dist/runtime/server/utils/spaceManager.d.ts +25 -0
- package/dist/runtime/server/utils/spaceManager.js +188 -0
- package/dist/runtime/types.d.ts +129 -30
- package/dist/runtime/types.js +17 -17
- package/dist/runtime/utils/chatContent.d.ts +41 -0
- package/dist/runtime/utils/chatContent.js +65 -0
- package/dist/runtime/utils/colorPalettes.js +12 -6
- package/dist/runtime/utils/coverCache.d.ts +12 -0
- package/dist/runtime/utils/coverCache.js +14 -0
- package/dist/runtime/utils/docReferenceEdges.d.ts +26 -0
- package/dist/runtime/utils/docReferenceEdges.js +122 -0
- package/dist/runtime/utils/docTypes.d.ts +34 -1
- package/dist/runtime/utils/docTypes.js +129 -1
- package/dist/runtime/utils/duplicateDocContent.d.ts +19 -0
- package/dist/runtime/utils/duplicateDocContent.js +68 -0
- package/dist/runtime/utils/extractFileMetadata.d.ts +13 -0
- package/dist/runtime/utils/extractFileMetadata.js +94 -0
- package/dist/runtime/utils/getMetaColor.d.ts +6 -0
- package/dist/runtime/utils/getMetaColor.js +12 -0
- package/dist/runtime/utils/htmlToYjs.d.ts +19 -0
- package/dist/runtime/utils/htmlToYjs.js +235 -0
- package/dist/runtime/utils/markdownToYjs.js +5 -5
- package/dist/runtime/utils/metaFieldDefinitions.js +9 -0
- package/dist/runtime/utils/notificationRenderers.d.ts +13 -0
- package/dist/runtime/utils/notificationRenderers.js +41 -0
- package/dist/runtime/utils/sdkRef.d.ts +12 -0
- package/dist/runtime/utils/sdkRef.js +7 -0
- package/dist/runtime/utils/slugify.d.ts +40 -0
- package/dist/runtime/utils/slugify.js +36 -0
- package/dist/types.d.mts +18 -0
- package/package.json +44 -32
|
@@ -1,13 +1,25 @@
|
|
|
1
1
|
<script setup>
|
|
2
|
-
import { ref, computed } from "vue";
|
|
2
|
+
import { ref, computed, watch, onBeforeUnmount } from "vue";
|
|
3
|
+
import { useRuntimeConfig, defineShortcuts } from "#imports";
|
|
3
4
|
import { useRendererBase } from "../../composables/useRendererBase";
|
|
5
|
+
import { useTouchDrag } from "../../composables/useTouchDrag";
|
|
6
|
+
import { useNodePanel } from "../../composables/useNodePanel";
|
|
7
|
+
import { useCalendarView } from "../../composables/useCalendarView";
|
|
4
8
|
import { DEFAULT_LOCALE } from "../../locale";
|
|
9
|
+
import ACalendarToolbar from "./calendar/ACalendarToolbar.vue";
|
|
10
|
+
import ACalendarMonthView from "./calendar/ACalendarMonthView.vue";
|
|
11
|
+
import ACalendarWeekView from "./calendar/ACalendarWeekView.vue";
|
|
12
|
+
import ACalendarDayView from "./calendar/ACalendarDayView.vue";
|
|
13
|
+
import ACalendarUnscheduled from "./calendar/ACalendarUnscheduled.vue";
|
|
5
14
|
const props = defineProps({
|
|
6
15
|
docId: { type: String, required: true },
|
|
7
16
|
childProvider: { type: null, required: true },
|
|
8
17
|
docLabel: { type: String, required: true },
|
|
9
18
|
pageTypes: { type: Array, required: false },
|
|
10
|
-
labels: { type: Object, required: false }
|
|
19
|
+
labels: { type: Object, required: false },
|
|
20
|
+
editable: { type: Boolean, required: false, default: true },
|
|
21
|
+
weekStartDay: { type: String, required: false },
|
|
22
|
+
showWeekNumbers: { type: Boolean, required: false }
|
|
11
23
|
});
|
|
12
24
|
const config = useRuntimeConfig();
|
|
13
25
|
const locale = computed(() => ({
|
|
@@ -15,140 +27,282 @@ const locale = computed(() => ({
|
|
|
15
27
|
...config.public?.abracadabra?.locale?.renderers?.calendar ?? {},
|
|
16
28
|
...props.labels ?? {}
|
|
17
29
|
}));
|
|
18
|
-
const { tree } = useRendererBase(props);
|
|
19
|
-
const
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
+
const { tree, childProviderRef, childDoc, states, setLocalState, connectedUsers } = useRendererBase(props);
|
|
31
|
+
const {
|
|
32
|
+
openNodeId,
|
|
33
|
+
openNodeLabel,
|
|
34
|
+
openNodeProvider,
|
|
35
|
+
openNode,
|
|
36
|
+
closePanel
|
|
37
|
+
} = useNodePanel(childProviderRef);
|
|
38
|
+
const myClientId = computed(() => props.childProvider?.awareness?.clientID ?? 0);
|
|
39
|
+
const weekStartDayRef = computed(() => props.weekStartDay ?? "sun");
|
|
40
|
+
const showWeekNumbersRef = computed(() => props.showWeekNumbers ?? false);
|
|
41
|
+
const cal = useCalendarView({
|
|
42
|
+
tree,
|
|
43
|
+
weekStartDay: weekStartDayRef,
|
|
44
|
+
showWeekNumbers: showWeekNumbersRef
|
|
45
|
+
});
|
|
46
|
+
watch(cal.viewMode, (mode) => {
|
|
47
|
+
setLocalState({ "calendar:viewMode": mode });
|
|
48
|
+
});
|
|
49
|
+
watch(cal.periodLabel, (label) => {
|
|
50
|
+
setLocalState({ "calendar:viewing": label });
|
|
51
|
+
}, { immediate: true });
|
|
52
|
+
function createEvent(date, hour) {
|
|
53
|
+
if (!props.editable) return;
|
|
54
|
+
const d = date ?? /* @__PURE__ */ new Date();
|
|
55
|
+
const dateStr = d.toISOString().slice(0, 10);
|
|
56
|
+
const id = tree.createChild(null, locale.value.newEvent);
|
|
57
|
+
if (hour !== void 0) {
|
|
58
|
+
const startHour = String(hour).padStart(2, "0");
|
|
59
|
+
const endHour = String(Math.min(hour + 1, 23)).padStart(2, "0");
|
|
60
|
+
tree.updateMeta(id, {
|
|
61
|
+
datetimeStart: `${dateStr}T${startHour}:00:00.000Z`,
|
|
62
|
+
datetimeEnd: `${dateStr}T${endHour}:00:00.000Z`,
|
|
63
|
+
color: "#6366f1"
|
|
64
|
+
});
|
|
65
|
+
} else {
|
|
66
|
+
tree.updateMeta(id, {
|
|
67
|
+
datetimeStart: `${dateStr}T00:00:00.000Z`,
|
|
68
|
+
datetimeEnd: `${dateStr}T01:00:00.000Z`,
|
|
69
|
+
allDay: true,
|
|
70
|
+
color: "#6366f1"
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
openNode(id, locale.value.newEvent);
|
|
30
74
|
}
|
|
31
|
-
function
|
|
32
|
-
if (
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
75
|
+
function onCreateEvent(payload) {
|
|
76
|
+
if (payload instanceof Date) {
|
|
77
|
+
createEvent(payload);
|
|
78
|
+
} else {
|
|
79
|
+
createEvent(payload.date, payload.hour);
|
|
80
|
+
}
|
|
36
81
|
}
|
|
37
|
-
const
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
const
|
|
42
|
-
if (
|
|
43
|
-
|
|
44
|
-
|
|
82
|
+
const dragPreviewTime = ref(null);
|
|
83
|
+
const { dragId, dragOverContainer, handlePointerDown } = useTouchDrag({
|
|
84
|
+
onMoveToContainer: (eventId, dateStr) => {
|
|
85
|
+
if (!props.editable) return;
|
|
86
|
+
const entry = tree.entries.value.find((e) => e.id === eventId);
|
|
87
|
+
if (cal.viewMode.value !== "month" && dragPreviewTime.value) {
|
|
88
|
+
const minutes = dragPreviewTime.value.minutes;
|
|
89
|
+
const snapped = Math.round(minutes / 10) * 10;
|
|
90
|
+
const h = String(dragPreviewTime.value.hours).padStart(2, "0");
|
|
91
|
+
const m = String(snapped % 60).padStart(2, "0");
|
|
92
|
+
let duration = 36e5;
|
|
93
|
+
if (entry?.meta?.datetimeStart && entry?.meta?.datetimeEnd) {
|
|
94
|
+
duration = new Date(entry.meta.datetimeEnd).getTime() - new Date(entry.meta.datetimeStart).getTime();
|
|
95
|
+
}
|
|
96
|
+
const startTime = (/* @__PURE__ */ new Date(`${dateStr}T${h}:${m}:00.000Z`)).getTime();
|
|
97
|
+
tree.updateMeta(eventId, {
|
|
98
|
+
datetimeStart: new Date(startTime).toISOString(),
|
|
99
|
+
datetimeEnd: new Date(startTime + duration).toISOString(),
|
|
100
|
+
allDay: false,
|
|
101
|
+
color: entry?.meta?.color ?? "#6366f1"
|
|
102
|
+
});
|
|
103
|
+
} else {
|
|
104
|
+
let newEnd = `${dateStr}T01:00:00.000Z`;
|
|
105
|
+
if (entry?.meta?.datetimeStart && entry?.meta?.datetimeEnd) {
|
|
106
|
+
const duration = new Date(entry.meta.datetimeEnd).getTime() - new Date(entry.meta.datetimeStart).getTime();
|
|
107
|
+
newEnd = new Date((/* @__PURE__ */ new Date(`${dateStr}T00:00:00.000Z`)).getTime() + duration).toISOString();
|
|
108
|
+
}
|
|
109
|
+
tree.updateMeta(eventId, {
|
|
110
|
+
datetimeStart: `${dateStr}T00:00:00.000Z`,
|
|
111
|
+
datetimeEnd: newEnd,
|
|
112
|
+
allDay: entry?.meta?.allDay ?? true,
|
|
113
|
+
color: entry?.meta?.color ?? "#6366f1"
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
dragPreviewTime.value = null;
|
|
117
|
+
},
|
|
118
|
+
onMoveOverContainer: (_eventId, _containerId, pointerEvent) => {
|
|
119
|
+
if (cal.viewMode.value === "month") return;
|
|
120
|
+
const target = pointerEvent.target?.closest("[data-hour-grid]");
|
|
121
|
+
if (!target) return;
|
|
122
|
+
const gridHeight = Number(target.getAttribute("data-hour-grid")) || 48;
|
|
123
|
+
const rect = target.getBoundingClientRect();
|
|
124
|
+
const y = pointerEvent.clientY - rect.top + target.scrollTop;
|
|
125
|
+
const totalMinutes = Math.max(0, Math.min(1439, y / gridHeight * 60));
|
|
126
|
+
const snapped = Math.round(totalMinutes / 10) * 10;
|
|
127
|
+
dragPreviewTime.value = {
|
|
128
|
+
hours: Math.floor(snapped / 60),
|
|
129
|
+
minutes: snapped % 60
|
|
130
|
+
};
|
|
131
|
+
},
|
|
132
|
+
containerAttr: "data-drop-container"
|
|
133
|
+
});
|
|
134
|
+
function onDragStart(payload) {
|
|
135
|
+
if (!props.editable) return;
|
|
136
|
+
handlePointerDown(payload.event, payload.id);
|
|
45
137
|
}
|
|
46
|
-
const
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
for (let i = 0; i < firstDay; i++) days.push({ day: null });
|
|
52
|
-
for (let d = 1; d <= daysInMonth; d++) days.push({ day: d });
|
|
53
|
-
return days;
|
|
54
|
-
}
|
|
55
|
-
);
|
|
56
|
-
function isToday(day) {
|
|
57
|
-
return day === today.getDate() && viewMonth.value === today.getMonth() && viewYear.value === today.getFullYear();
|
|
138
|
+
const renameId = ref(null);
|
|
139
|
+
const renameValue = ref("");
|
|
140
|
+
function _startRename(id, _label) {
|
|
141
|
+
renameId.value = id;
|
|
142
|
+
renameValue.value = _label;
|
|
58
143
|
}
|
|
59
|
-
function
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
const entry = tree.treeMap.get(id);
|
|
63
|
-
if (entry) {
|
|
64
|
-
tree.treeMap.set(id, {
|
|
65
|
-
...entry,
|
|
66
|
-
meta: { datetimeStart: dateStr, datetimeEnd: dateStr },
|
|
67
|
-
updatedAt: Date.now()
|
|
68
|
-
});
|
|
144
|
+
function commitRename() {
|
|
145
|
+
if (renameId.value && renameValue.value.trim()) {
|
|
146
|
+
tree.renameEntry(renameId.value, renameValue.value.trim());
|
|
69
147
|
}
|
|
148
|
+
renameId.value = null;
|
|
70
149
|
}
|
|
71
|
-
|
|
150
|
+
function cancelRename() {
|
|
151
|
+
renameId.value = null;
|
|
152
|
+
}
|
|
153
|
+
function onOpenEvent(event) {
|
|
154
|
+
openNode(event.id, event.label);
|
|
155
|
+
}
|
|
156
|
+
function focusEvent(eventId) {
|
|
157
|
+
setLocalState({ "calendar:focused": eventId });
|
|
158
|
+
}
|
|
159
|
+
function unfocusEvent() {
|
|
160
|
+
setLocalState({ "calendar:focused": null });
|
|
161
|
+
}
|
|
162
|
+
function eventFocusers(eventId) {
|
|
163
|
+
return states.value.filter((s) => s.clientId !== myClientId.value && s["calendar:focused"] === eventId).map((s) => ({
|
|
164
|
+
name: s.user?.name ?? "",
|
|
165
|
+
color: s.user?.color ?? "#888"
|
|
166
|
+
}));
|
|
167
|
+
}
|
|
168
|
+
const remoteViewers = computed(
|
|
169
|
+
() => states.value.filter((s) => s.clientId !== myClientId.value && s["calendar:viewing"]).map((s) => ({
|
|
170
|
+
clientId: s.clientId,
|
|
171
|
+
name: s.user?.name ?? "",
|
|
172
|
+
color: s.user?.color ?? "#888",
|
|
173
|
+
viewing: s["calendar:viewing"]
|
|
174
|
+
}))
|
|
175
|
+
);
|
|
176
|
+
watch(childDoc, (doc) => {
|
|
177
|
+
if (!doc) return;
|
|
178
|
+
const legacyMap = doc.getMap("event-dates");
|
|
179
|
+
if (legacyMap.size === 0) return;
|
|
180
|
+
legacyMap.forEach((val, id) => {
|
|
181
|
+
if (!tree.treeMap.get(id)?.meta?.datetimeStart) {
|
|
182
|
+
tree.updateMeta(id, {
|
|
183
|
+
datetimeStart: val.start,
|
|
184
|
+
datetimeEnd: val.end,
|
|
185
|
+
allDay: val.allDay,
|
|
186
|
+
color: val.color
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
});
|
|
190
|
+
doc.transact(() => {
|
|
191
|
+
for (const key of [...legacyMap.keys()]) legacyMap.delete(key);
|
|
192
|
+
});
|
|
193
|
+
}, { immediate: true });
|
|
194
|
+
defineShortcuts({
|
|
195
|
+
arrowleft: () => cal.prevPeriod(),
|
|
196
|
+
arrowright: () => cal.nextPeriod(),
|
|
197
|
+
t: () => cal.goToday()
|
|
198
|
+
});
|
|
199
|
+
onBeforeUnmount(() => {
|
|
200
|
+
setLocalState({ "calendar:focused": null, "calendar:viewing": null });
|
|
201
|
+
cal.cleanup();
|
|
202
|
+
});
|
|
203
|
+
defineExpose({ connectedUsers });
|
|
72
204
|
</script>
|
|
73
205
|
|
|
74
206
|
<template>
|
|
75
|
-
<div class="
|
|
76
|
-
<!--
|
|
77
|
-
<
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
icon="i-lucide-chevron-right"
|
|
87
|
-
variant="ghost"
|
|
88
|
-
color="neutral"
|
|
89
|
-
@click="nextMonth"
|
|
90
|
-
/>
|
|
91
|
-
<UButton
|
|
92
|
-
icon="i-lucide-today"
|
|
93
|
-
variant="soft"
|
|
94
|
-
color="neutral"
|
|
95
|
-
size="sm"
|
|
96
|
-
:label="locale.today"
|
|
97
|
-
@click="() => {
|
|
98
|
-
viewYear = today.getFullYear();
|
|
99
|
-
viewMonth = today.getMonth();
|
|
207
|
+
<div class="flex-1 min-h-0 flex flex-col relative">
|
|
208
|
+
<!-- Toolbar -->
|
|
209
|
+
<ACalendarToolbar
|
|
210
|
+
:view-mode="cal.viewMode.value"
|
|
211
|
+
:period-label="cal.periodLabel.value"
|
|
212
|
+
:current-year="cal.year.value"
|
|
213
|
+
:current-month="cal.month.value"
|
|
214
|
+
:remote-viewers="remoteViewers"
|
|
215
|
+
:editable="editable"
|
|
216
|
+
:labels="{
|
|
217
|
+
newEvent: locale.newEvent
|
|
100
218
|
}"
|
|
101
|
-
|
|
102
|
-
|
|
219
|
+
@update:view-mode="cal.viewMode.value = $event"
|
|
220
|
+
@prev="cal.prevPeriod()"
|
|
221
|
+
@next="cal.nextPeriod()"
|
|
222
|
+
@today="cal.goToday()"
|
|
223
|
+
@add-event="createEvent()"
|
|
224
|
+
@navigate-to-month="(year, month) => cal.goToMonth(year, month)"
|
|
225
|
+
/>
|
|
226
|
+
|
|
227
|
+
<!-- Month view -->
|
|
228
|
+
<ACalendarMonthView
|
|
229
|
+
v-if="cal.viewMode.value === 'month'"
|
|
230
|
+
:weeks="cal.weeks.value"
|
|
231
|
+
:week-day-headers="cal.weekDayHeaders.value"
|
|
232
|
+
:week-numbers="cal.weekNumbers.value"
|
|
233
|
+
:show-week-numbers="showWeekNumbers"
|
|
234
|
+
:drag-id="dragId"
|
|
235
|
+
:drag-over-container="dragOverContainer"
|
|
236
|
+
:event-focusers="eventFocusers"
|
|
237
|
+
:rename-id="renameId"
|
|
238
|
+
:rename-value="renameValue"
|
|
239
|
+
:editable="editable"
|
|
240
|
+
@create-event="onCreateEvent"
|
|
241
|
+
@open-event="onOpenEvent"
|
|
242
|
+
@drag-start="onDragStart"
|
|
243
|
+
@focus-event="focusEvent"
|
|
244
|
+
@unfocus-event="unfocusEvent"
|
|
245
|
+
@rename-input="renameValue = $event"
|
|
246
|
+
@rename-commit="commitRename"
|
|
247
|
+
@rename-cancel="cancelRename"
|
|
248
|
+
/>
|
|
249
|
+
|
|
250
|
+
<!-- Week view -->
|
|
251
|
+
<ACalendarWeekView
|
|
252
|
+
v-else-if="cal.viewMode.value === 'week'"
|
|
253
|
+
:columns="cal.weekColumns.value"
|
|
254
|
+
:event-focusers="eventFocusers"
|
|
255
|
+
:drag-id="dragId"
|
|
256
|
+
:drag-over-container="dragOverContainer"
|
|
257
|
+
:drag-preview-time="dragPreviewTime"
|
|
258
|
+
:rename-id="renameId"
|
|
259
|
+
:rename-value="renameValue"
|
|
260
|
+
:editable="editable"
|
|
261
|
+
@create-event="onCreateEvent"
|
|
262
|
+
@open-event="onOpenEvent"
|
|
263
|
+
@drag-start="onDragStart"
|
|
264
|
+
@focus-event="focusEvent"
|
|
265
|
+
@unfocus-event="unfocusEvent"
|
|
266
|
+
@rename-input="renameValue = $event"
|
|
267
|
+
@rename-commit="commitRename"
|
|
268
|
+
@rename-cancel="cancelRename"
|
|
269
|
+
/>
|
|
270
|
+
|
|
271
|
+
<!-- Day view -->
|
|
272
|
+
<ACalendarDayView
|
|
273
|
+
v-else
|
|
274
|
+
:column="cal.dayColumn.value"
|
|
275
|
+
:event-focusers="eventFocusers"
|
|
276
|
+
:drag-id="dragId"
|
|
277
|
+
:drag-preview-time="dragPreviewTime"
|
|
278
|
+
:rename-id="renameId"
|
|
279
|
+
:rename-value="renameValue"
|
|
280
|
+
:editable="editable"
|
|
281
|
+
@create-event="onCreateEvent"
|
|
282
|
+
@open-event="onOpenEvent"
|
|
283
|
+
@drag-start="onDragStart"
|
|
284
|
+
@focus-event="focusEvent"
|
|
285
|
+
@unfocus-event="unfocusEvent"
|
|
286
|
+
@rename-input="renameValue = $event"
|
|
287
|
+
@rename-commit="commitRename"
|
|
288
|
+
@rename-cancel="cancelRename"
|
|
289
|
+
/>
|
|
103
290
|
|
|
104
|
-
<!--
|
|
105
|
-
<
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
</div>
|
|
113
|
-
</div>
|
|
291
|
+
<!-- Unscheduled events -->
|
|
292
|
+
<ACalendarUnscheduled
|
|
293
|
+
:entries="cal.unscheduledEntries.value"
|
|
294
|
+
:drag-id="dragId"
|
|
295
|
+
:editable="editable"
|
|
296
|
+
@open-entry="openNode($event.id, $event.label)"
|
|
297
|
+
@drag-start="onDragStart"
|
|
298
|
+
/>
|
|
114
299
|
|
|
115
|
-
<!--
|
|
116
|
-
<
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
>
|
|
123
|
-
<template v-if="cell.day !== null">
|
|
124
|
-
<div
|
|
125
|
-
class="flex items-center justify-between"
|
|
126
|
-
>
|
|
127
|
-
<span
|
|
128
|
-
class="text-xs font-medium"
|
|
129
|
-
:class="isToday(cell.day) ? 'text-primary font-bold' : 'text-muted'"
|
|
130
|
-
>{{ cell.day }}</span>
|
|
131
|
-
<UButton
|
|
132
|
-
icon="i-lucide-plus"
|
|
133
|
-
variant="ghost"
|
|
134
|
-
color="neutral"
|
|
135
|
-
size="xs"
|
|
136
|
-
class="opacity-0 hover:opacity-100 h-4 w-4"
|
|
137
|
-
@click="addEvent(cell.day)"
|
|
138
|
-
/>
|
|
139
|
-
</div>
|
|
140
|
-
<div class="space-y-0.5 mt-0.5">
|
|
141
|
-
<div
|
|
142
|
-
v-for="ev in eventsOnDay(viewYear, viewMonth, cell.day)"
|
|
143
|
-
:key="ev.id"
|
|
144
|
-
class="text-xs px-1 py-0.5 rounded truncate"
|
|
145
|
-
:style="ev.meta?.color ? { backgroundColor: ev.meta.color + '33', color: ev.meta.color } : { backgroundColor: 'var(--color-primary-100)', color: 'var(--color-primary-700)' }"
|
|
146
|
-
>
|
|
147
|
-
{{ ev.label }}
|
|
148
|
-
</div>
|
|
149
|
-
</div>
|
|
150
|
-
</template>
|
|
151
|
-
</div>
|
|
152
|
-
</div>
|
|
300
|
+
<!-- Node panel -->
|
|
301
|
+
<ANodePanel
|
|
302
|
+
:node-id="openNodeId"
|
|
303
|
+
:node-label="openNodeLabel"
|
|
304
|
+
:child-provider="openNodeProvider"
|
|
305
|
+
@close="closePanel"
|
|
306
|
+
/>
|
|
153
307
|
</div>
|
|
154
308
|
</template>
|
|
@@ -2,7 +2,20 @@ import { type RendererBaseProps } from '../../composables/useRendererBase.js';
|
|
|
2
2
|
import type { AbracadabraLocale } from '../../locale.js';
|
|
3
3
|
type __VLS_Props = RendererBaseProps & {
|
|
4
4
|
labels?: Partial<AbracadabraLocale['renderers']['calendar']>;
|
|
5
|
+
editable?: boolean;
|
|
6
|
+
weekStartDay?: string;
|
|
7
|
+
showWeekNumbers?: boolean;
|
|
5
8
|
};
|
|
6
|
-
declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {
|
|
9
|
+
declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {
|
|
10
|
+
connectedUsers: import("vue").ComputedRef<{
|
|
11
|
+
clientId: number;
|
|
12
|
+
name: string;
|
|
13
|
+
color: string;
|
|
14
|
+
avatar: string | undefined;
|
|
15
|
+
publicKey: any;
|
|
16
|
+
}[]>;
|
|
17
|
+
}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
18
|
+
editable: boolean;
|
|
19
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
7
20
|
declare const _default: typeof __VLS_export;
|
|
8
21
|
export default _default;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { AbracadabraLocale } from '../../locale.js';
|
|
2
|
+
type __VLS_Props = {
|
|
3
|
+
docId: string;
|
|
4
|
+
childProvider?: any;
|
|
5
|
+
docLabel: string;
|
|
6
|
+
labels?: Partial<AbracadabraLocale['renderers']['call']>;
|
|
7
|
+
editable?: boolean;
|
|
8
|
+
};
|
|
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
|
+
editable: boolean;
|
|
11
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
12
|
+
declare const _default: typeof __VLS_export;
|
|
13
|
+
export default _default;
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { computed, onMounted } from "vue";
|
|
3
|
+
import { useRuntimeConfig } from "#imports";
|
|
4
|
+
import { useAbracadabra } from "../../composables/useAbracadabra";
|
|
5
|
+
import { useVoice } from "../../composables/useVoice";
|
|
6
|
+
import { DEFAULT_LOCALE } from "../../locale";
|
|
7
|
+
const props = defineProps({
|
|
8
|
+
docId: { type: String, required: true },
|
|
9
|
+
childProvider: { type: null, required: false },
|
|
10
|
+
docLabel: { type: String, required: true },
|
|
11
|
+
labels: { type: Object, required: false },
|
|
12
|
+
editable: { type: Boolean, required: false, default: true }
|
|
13
|
+
});
|
|
14
|
+
const config = useRuntimeConfig();
|
|
15
|
+
const locale = computed(() => ({
|
|
16
|
+
...DEFAULT_LOCALE.renderers.call,
|
|
17
|
+
...config.public?.abracadabra?.locale?.renderers?.call ?? {},
|
|
18
|
+
...props.labels ?? {}
|
|
19
|
+
}));
|
|
20
|
+
const { userName, userColor } = useAbracadabra();
|
|
21
|
+
const {
|
|
22
|
+
voiceStatus,
|
|
23
|
+
isMuted,
|
|
24
|
+
isVideoEnabled,
|
|
25
|
+
isScreenEnabled,
|
|
26
|
+
canScreenShare,
|
|
27
|
+
localVideoStream,
|
|
28
|
+
localScreenStream,
|
|
29
|
+
peerVideoStreams,
|
|
30
|
+
peerList,
|
|
31
|
+
joinRoom,
|
|
32
|
+
leaveRoom,
|
|
33
|
+
toggleMute,
|
|
34
|
+
toggleVideo,
|
|
35
|
+
toggleScreen
|
|
36
|
+
} = useVoice();
|
|
37
|
+
const isConnected = computed(() => voiceStatus.value === "connected");
|
|
38
|
+
onMounted(async () => {
|
|
39
|
+
if (!props.editable) return;
|
|
40
|
+
if (voiceStatus.value !== "connected" && voiceStatus.value !== "connecting") {
|
|
41
|
+
await joinRoom(props.docId);
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
const streams = computed(() => {
|
|
45
|
+
const result = [];
|
|
46
|
+
if (localVideoStream.value) {
|
|
47
|
+
result.push({
|
|
48
|
+
key: "self-camera",
|
|
49
|
+
stream: localVideoStream.value,
|
|
50
|
+
name: `${userName.value} (You)`,
|
|
51
|
+
color: userColor.value,
|
|
52
|
+
kind: "camera"
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
if (localScreenStream.value) {
|
|
56
|
+
result.push({
|
|
57
|
+
key: "self-screen",
|
|
58
|
+
stream: localScreenStream.value,
|
|
59
|
+
name: `${userName.value} (You)`,
|
|
60
|
+
color: userColor.value,
|
|
61
|
+
kind: "screen"
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
for (const peer of peerList.value) {
|
|
65
|
+
const vs = peerVideoStreams.value.get(peer.id);
|
|
66
|
+
if (vs?.camera) {
|
|
67
|
+
result.push({
|
|
68
|
+
key: `${peer.id}-camera`,
|
|
69
|
+
stream: vs.camera,
|
|
70
|
+
name: peer.displayName || peer.userId.slice(0, 6),
|
|
71
|
+
color: peer.color,
|
|
72
|
+
kind: "camera"
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
if (vs?.screen) {
|
|
76
|
+
result.push({
|
|
77
|
+
key: `${peer.id}-screen`,
|
|
78
|
+
stream: vs.screen,
|
|
79
|
+
name: peer.displayName || peer.userId.slice(0, 6),
|
|
80
|
+
color: peer.color,
|
|
81
|
+
kind: "screen"
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return result;
|
|
86
|
+
});
|
|
87
|
+
const gridCols = computed(() => {
|
|
88
|
+
const n = streams.value.length;
|
|
89
|
+
if (n <= 1) return "grid-cols-1";
|
|
90
|
+
if (n <= 4) return "grid-cols-2";
|
|
91
|
+
return "grid-cols-3";
|
|
92
|
+
});
|
|
93
|
+
</script>
|
|
94
|
+
|
|
95
|
+
<template>
|
|
96
|
+
<div class="flex flex-col flex-1 min-h-0">
|
|
97
|
+
<!-- Stream grid -->
|
|
98
|
+
<div class="flex-1 p-4 overflow-auto">
|
|
99
|
+
<div
|
|
100
|
+
v-if="streams.length"
|
|
101
|
+
class="grid gap-4 h-full auto-rows-fr"
|
|
102
|
+
:class="gridCols"
|
|
103
|
+
>
|
|
104
|
+
<AVoiceTile
|
|
105
|
+
v-for="entry in streams"
|
|
106
|
+
:key="entry.key"
|
|
107
|
+
:stream="entry.stream"
|
|
108
|
+
:name="entry.name"
|
|
109
|
+
:color="entry.color"
|
|
110
|
+
:kind="entry.kind"
|
|
111
|
+
/>
|
|
112
|
+
</div>
|
|
113
|
+
<div
|
|
114
|
+
v-else
|
|
115
|
+
class="flex items-center justify-center h-full"
|
|
116
|
+
>
|
|
117
|
+
<div class="text-center">
|
|
118
|
+
<UIcon
|
|
119
|
+
name="i-lucide-video-off"
|
|
120
|
+
class="size-12 mb-3 text-(--ui-text-dimmed)"
|
|
121
|
+
/>
|
|
122
|
+
<p class="text-sm text-(--ui-text-muted)">
|
|
123
|
+
{{ locale.noStreams }}
|
|
124
|
+
</p>
|
|
125
|
+
<p class="text-xs mt-1 text-(--ui-text-dimmed)">
|
|
126
|
+
{{ locale.turnOnCamera }}
|
|
127
|
+
</p>
|
|
128
|
+
</div>
|
|
129
|
+
</div>
|
|
130
|
+
</div>
|
|
131
|
+
|
|
132
|
+
<!-- Bottom controls bar -->
|
|
133
|
+
<div
|
|
134
|
+
v-if="isConnected && editable"
|
|
135
|
+
class="flex items-center justify-center gap-3 p-4 border-t border-(--ui-border) bg-(--ui-bg-elevated)/50"
|
|
136
|
+
>
|
|
137
|
+
<UButton
|
|
138
|
+
:icon="isMuted ? 'i-lucide-mic-off' : 'i-lucide-mic'"
|
|
139
|
+
size="lg"
|
|
140
|
+
:color="isMuted ? 'error' : 'neutral'"
|
|
141
|
+
:variant="isMuted ? 'subtle' : 'outline'"
|
|
142
|
+
class="rounded-full"
|
|
143
|
+
@click="toggleMute"
|
|
144
|
+
/>
|
|
145
|
+
<UButton
|
|
146
|
+
:icon="isVideoEnabled ? 'i-lucide-video' : 'i-lucide-video-off'"
|
|
147
|
+
size="lg"
|
|
148
|
+
:color="isVideoEnabled ? 'primary' : 'neutral'"
|
|
149
|
+
:variant="isVideoEnabled ? 'subtle' : 'outline'"
|
|
150
|
+
class="rounded-full"
|
|
151
|
+
@click="toggleVideo"
|
|
152
|
+
/>
|
|
153
|
+
<UButton
|
|
154
|
+
v-if="canScreenShare"
|
|
155
|
+
:icon="isScreenEnabled ? 'i-lucide-monitor-up' : 'i-lucide-monitor'"
|
|
156
|
+
size="lg"
|
|
157
|
+
:color="isScreenEnabled ? 'primary' : 'neutral'"
|
|
158
|
+
:variant="isScreenEnabled ? 'subtle' : 'outline'"
|
|
159
|
+
class="rounded-full"
|
|
160
|
+
@click="toggleScreen"
|
|
161
|
+
/>
|
|
162
|
+
<UButton
|
|
163
|
+
icon="i-lucide-phone-off"
|
|
164
|
+
size="lg"
|
|
165
|
+
color="error"
|
|
166
|
+
variant="solid"
|
|
167
|
+
class="rounded-full"
|
|
168
|
+
@click="leaveRoom"
|
|
169
|
+
/>
|
|
170
|
+
</div>
|
|
171
|
+
</div>
|
|
172
|
+
</template>
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { AbracadabraLocale } from '../../locale.js';
|
|
2
|
+
type __VLS_Props = {
|
|
3
|
+
docId: string;
|
|
4
|
+
childProvider?: any;
|
|
5
|
+
docLabel: string;
|
|
6
|
+
labels?: Partial<AbracadabraLocale['renderers']['call']>;
|
|
7
|
+
editable?: boolean;
|
|
8
|
+
};
|
|
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
|
+
editable: boolean;
|
|
11
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
12
|
+
declare const _default: typeof __VLS_export;
|
|
13
|
+
export default _default;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { type RendererBaseProps } from '../../composables/useRendererBase.js';
|
|
2
|
+
import type { AbracadabraLocale } from '../../locale.js';
|
|
3
|
+
type __VLS_Props = RendererBaseProps & {
|
|
4
|
+
labels?: Partial<AbracadabraLocale['renderers']['checklist']>;
|
|
5
|
+
editable?: boolean;
|
|
6
|
+
};
|
|
7
|
+
declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {
|
|
8
|
+
connectedUsers: import("vue").ComputedRef<{
|
|
9
|
+
clientId: number;
|
|
10
|
+
name: string;
|
|
11
|
+
color: string;
|
|
12
|
+
avatar: string | undefined;
|
|
13
|
+
publicKey: any;
|
|
14
|
+
}[]>;
|
|
15
|
+
}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {
|
|
16
|
+
editable: boolean;
|
|
17
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
18
|
+
declare const _default: typeof __VLS_export;
|
|
19
|
+
export default _default;
|