@fileverse-dev/ddoc 3.1.7 → 3.1.8

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.
Files changed (47) hide show
  1. package/dist/index.es.js +32974 -28903
  2. package/dist/package/components/editor-bubble-menu/props.d.ts +2 -0
  3. package/dist/package/components/inline-comment/comment-card.d.ts +1 -1
  4. package/dist/package/components/inline-comment/comment-drawer.d.ts +1 -1
  5. package/dist/package/components/inline-comment/comment-dropdown.d.ts +1 -1
  6. package/dist/package/components/inline-comment/comment-floating-container.d.ts +1 -0
  7. package/dist/package/components/inline-comment/comment-floating-layout.d.ts +34 -0
  8. package/dist/package/components/inline-comment/comment-input-field.d.ts +4 -0
  9. package/dist/package/components/inline-comment/comment-reply-input.d.ts +8 -0
  10. package/dist/package/components/inline-comment/comment-section.d.ts +1 -1
  11. package/dist/package/components/inline-comment/comment-username.d.ts +1 -1
  12. package/dist/package/components/inline-comment/constants.d.ts +1 -0
  13. package/dist/package/components/inline-comment/context/types.d.ts +46 -89
  14. package/dist/package/components/inline-comment/delete-confirm-overlay.d.ts +10 -0
  15. package/dist/package/components/inline-comment/empty-comments.d.ts +4 -1
  16. package/dist/package/components/inline-comment/floating-comment/comment-floating-container.d.ts +3 -0
  17. package/dist/package/components/inline-comment/floating-comment/draft-floating-card.d.ts +3 -0
  18. package/dist/package/components/inline-comment/floating-comment/floating-auth-prompt.d.ts +1 -0
  19. package/dist/package/components/inline-comment/floating-comment/floating-card-shell.d.ts +3 -0
  20. package/dist/package/components/inline-comment/floating-comment/index.d.ts +1 -0
  21. package/dist/package/components/inline-comment/floating-comment/thread-floating-card.d.ts +3 -0
  22. package/dist/package/components/inline-comment/floating-comment/types.d.ts +34 -0
  23. package/dist/package/components/inline-comment/floating-comment-layout-utils.d.ts +78 -0
  24. package/dist/package/components/inline-comment/resize-inline-comment-textarea.d.ts +1 -0
  25. package/dist/package/components/inline-comment/types.d.ts +24 -0
  26. package/dist/package/components/inline-comment/use-anchor-registry.d.ts +34 -0
  27. package/dist/package/components/inline-comment/use-comment-card.d.ts +29 -0
  28. package/dist/package/components/inline-comment/use-comment-list-container.d.ts +17 -0
  29. package/dist/package/components/inline-comment/use-ens-status.d.ts +3 -0
  30. package/dist/package/components/inline-comment/use-floating-card-state.d.ts +36 -0
  31. package/dist/package/components/inline-comment/use-floating-comment-card-layout.d.ts +23 -0
  32. package/dist/package/components/inline-comment/use-floating-comment-card-state.d.ts +13 -0
  33. package/dist/package/components/inline-comment/use-floating-layout-engine.d.ts +26 -0
  34. package/dist/package/components/inline-comment/use-is-selected-content-deleted.d.ts +1 -0
  35. package/dist/package/components/tabs/document-tabs-sidebar.d.ts +2 -1
  36. package/dist/package/extensions/comment/comment-decoration-plugin.d.ts +70 -0
  37. package/dist/package/extensions/comment/comment.d.ts +33 -0
  38. package/dist/package/hooks/use-tab-editor.d.ts +6 -2
  39. package/dist/package/stores/comment-store-provider.d.ts +56 -0
  40. package/dist/package/stores/comment-store.d.ts +195 -0
  41. package/dist/package/types.d.ts +16 -2
  42. package/dist/package/use-ddoc-editor.d.ts +4 -1
  43. package/dist/package/utils/comment-anchor-serialization.d.ts +5 -0
  44. package/dist/package/utils/comment-scroll-into-view.d.ts +21 -0
  45. package/dist/style.css +1 -1
  46. package/package.json +3 -2
  47. package/dist/package/components/inline-comment/context/comment-context.d.ts +0 -4
@@ -1,5 +1,7 @@
1
1
  import { Editor } from '@tiptap/core';
2
2
 
3
+ export declare const isSelectionInsideEditor: (editor: Editor) => boolean;
3
4
  export declare const shouldShow: ({ editor }: {
4
5
  editor: Editor;
5
6
  }) => boolean;
7
+ export declare const shouldShowIgnoringFocus: (editor: Editor) => boolean;
@@ -1,4 +1,4 @@
1
1
  import { CommentCardProps } from './types';
2
2
 
3
- export declare const CommentCard: ({ username, selectedContent, comment, createdAt, replies, onResolve, onDelete, onUnresolve, isResolved, isDropdown, activeCommentId, id, isDisabled, isCommentOwner, version, emptyComment, }: CommentCardProps) => import("react/jsx-runtime").JSX.Element;
3
+ export declare const CommentCard: (props: CommentCardProps) => import("react/jsx-runtime").JSX.Element;
4
4
  export declare const UserDisplaySkeleton: () => import("react/jsx-runtime").JSX.Element;
@@ -1,3 +1,3 @@
1
1
  import { CommentDrawerProps } from './types';
2
2
 
3
- export declare const CommentDrawer: ({ isOpen, onClose, isNavbarVisible, isPresentationMode, activeCommentId, isPreviewMode, }: CommentDrawerProps) => import("react/jsx-runtime").JSX.Element;
3
+ export declare const CommentDrawer: ({ isOpen, onClose, isNavbarVisible, isPresentationMode, activeCommentId, activeTabId, onTabChange, isPreviewMode, tabs, isCollaborationEnabled, }: CommentDrawerProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,3 +1,3 @@
1
1
  import { CommentDropdownProps } from './types';
2
2
 
3
- export declare const CommentDropdown: ({ activeCommentId, initialComment, isBubbleMenu, selectedContent, isDisabled, isCommentOwner, }: CommentDropdownProps) => import("react/jsx-runtime").JSX.Element | null;
3
+ export declare const CommentDropdown: ({ activeCommentId, isBubbleMenu, isDisabled, isCommentOwner, }: CommentDropdownProps) => import("react/jsx-runtime").JSX.Element | null;
@@ -0,0 +1 @@
1
+ export { CommentFloatingContainer } from './floating-comment';
@@ -0,0 +1,34 @@
1
+ export declare const FLOATING_COMMENT_CARD_GAP = 8;
2
+ export declare const enum FloatingLayoutInvalidationFlag {
3
+ None = 0,
4
+ Anchor = 1,
5
+ Viewport = 2,
6
+ Height = 4,
7
+ Visibility = 8
8
+ }
9
+ export interface FloatingCardLayoutInput {
10
+ floatingCardId: string;
11
+ anchorTop: number | null;
12
+ height: number;
13
+ isVisible: boolean;
14
+ isMeasured: boolean;
15
+ lastCommittedTranslateY: number | null;
16
+ invalidationFlags: FloatingLayoutInvalidationFlag;
17
+ }
18
+ export interface FloatingLayoutResult {
19
+ placements: Map<string, {
20
+ translateY: number | null;
21
+ isVisible: boolean;
22
+ }>;
23
+ stopIndex: number;
24
+ usedFocusedLayout: boolean;
25
+ }
26
+ export declare const roundFloatingTranslateY: (translateY: number | null) => number | null;
27
+ export declare const computeFloatingCommentLayout: ({ floatingCards, recomputeStartIndex, firstInvalidatedIndex, lastInvalidatedIndex, gap, focusedFloatingCardId, }: {
28
+ floatingCards: FloatingCardLayoutInput[];
29
+ recomputeStartIndex: number;
30
+ firstInvalidatedIndex?: number;
31
+ lastInvalidatedIndex: number;
32
+ gap?: number;
33
+ focusedFloatingCardId?: string | null;
34
+ }) => FloatingLayoutResult;
@@ -0,0 +1,4 @@
1
+ export declare const CommentInputField: ({ tabId, isCollaborationEnabled, }: {
2
+ tabId?: string;
3
+ isCollaborationEnabled: boolean;
4
+ }) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,8 @@
1
+ interface CommentReplyInputProps {
2
+ commentId: string;
3
+ commentUsername?: string;
4
+ replyCount: number;
5
+ isCollaborationEnabled: boolean;
6
+ }
7
+ export declare const CommentReplyInput: ({ commentId, replyCount, isCollaborationEnabled, }: CommentReplyInputProps) => import("react/jsx-runtime").JSX.Element;
8
+ export {};
@@ -1,3 +1,3 @@
1
1
  import { CommentSectionProps } from './types';
2
2
 
3
- export declare const CommentSection: ({ activeCommentId, isNavbarVisible, isPresentationMode, }: CommentSectionProps) => import("react/jsx-runtime").JSX.Element;
3
+ export declare const CommentSection: ({ activeCommentId, isNavbarVisible, isPresentationMode, isMobile, comments: commentsProp, commentType, tabNameById, selectedTabLabel, newCommentTabId, showNewCommentInput, onCommentFocus, onReset, isCollaborationEnabled, }: CommentSectionProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,4 +1,4 @@
1
1
  import { CommentUsernameProps } from './context/types';
2
2
 
3
- declare const CommentUsername: ({ username, setUsername, isNavbarVisible, isConnected, connectViaUsername, connectViaWallet, isLoading, }: CommentUsernameProps) => import("react/jsx-runtime").JSX.Element;
3
+ declare const CommentUsername: ({ username, setUsername, isConnected, connectViaUsername, connectViaWallet, isLoading, }: CommentUsernameProps) => import("react/jsx-runtime").JSX.Element;
4
4
  export { CommentUsername };
@@ -0,0 +1 @@
1
+ export declare const FLOATING_CARD_WIDTH = 300;
@@ -1,100 +1,57 @@
1
- import { Editor } from '@tiptap/react';
1
+ import { Dispatch, RefObject, SetStateAction } from 'react';
2
2
  import { IComment } from '../../../extensions/comment';
3
- import { SetStateAction } from 'react';
4
- import { CommentAccountProps, CommentMutationMeta } from '../../../types';
5
- import { EnsStatus } from '../types';
3
+ import { CommentStoreState } from '../../../stores/comment-store';
4
+ import { CommentStoreProviderProps } from '../../../stores/comment-store-provider';
5
+ import { CommentAccountProps } from '../../../types';
6
6
 
7
- import * as Y from 'yjs';
8
- export interface CommentContextType extends CommentAccountProps {
9
- comments: IComment[];
10
- setComments: React.Dispatch<SetStateAction<IComment[]>>;
11
- editor: Editor;
12
- username?: string | null;
13
- setUsername?: React.Dispatch<SetStateAction<string>>;
14
- showResolved: boolean;
15
- setShowResolved: (show: boolean) => void;
16
- resolveComment: (commentId: string) => void;
17
- unresolveComment: (commentId: string) => void;
18
- deleteComment: (commentId: string) => void;
19
- handleAddReply: (activeCommentId: string, replyContent: string, onCommentReply: (activeCommentId: string, reply: IComment) => void) => void;
20
- focusCommentInEditor: (commentId: string) => void;
21
- handleReplyChange: (event: React.ChangeEvent<HTMLTextAreaElement>) => void;
22
- handleCommentChange: (event: React.ChangeEvent<HTMLTextAreaElement>) => void;
23
- handleCommentKeyDown: (event: React.KeyboardEvent<HTMLTextAreaElement>) => void;
24
- handleReplySubmit: () => void;
25
- toggleResolved: () => void;
26
- openReplyId: string | null;
27
- setOpenReplyId: (id: string | null) => void;
28
- handleReplyKeyDown: (event: React.KeyboardEvent<HTMLTextAreaElement>) => void;
29
- commentsSectionRef: React.RefObject<HTMLDivElement>;
30
- replySectionRef: React.RefObject<HTMLDivElement>;
31
- addComment: (content?: string) => void;
32
- handleCommentSubmit: () => void;
33
- reply: string;
34
- setReply: React.Dispatch<React.SetStateAction<string>>;
35
- comment: string;
36
- setComment: React.Dispatch<React.SetStateAction<string>>;
37
- onPrevComment: () => void;
38
- onNextComment: () => void;
39
- activeCommentIndex: number;
40
- activeComment: IComment | undefined;
7
+ export interface CommentFloatingBaseCard {
8
+ floatingCardId: string;
41
9
  selectedText: string;
42
- isCommentOpen: boolean;
43
- isBubbleMenuSuppressed: boolean;
44
- setIsBubbleMenuSuppressed: React.Dispatch<React.SetStateAction<boolean>>;
45
- handleInlineComment: () => void;
46
- portalRef: React.RefObject<HTMLDivElement>;
47
- buttonRef: React.RefObject<HTMLDivElement>;
48
- dropdownRef: React.RefObject<HTMLDivElement>;
49
- activeComments: IComment[];
50
- handleInput: (e: React.FormEvent<HTMLTextAreaElement>, content: string) => void;
51
- isCommentActive: boolean;
52
- isCommentResolved: boolean;
53
- ensResolutionUrl: string;
54
- activeTabId: string;
55
- onCommentReply?: (activeCommentId: string, reply: IComment) => void;
56
- onComment?: () => void;
57
- setCommentDrawerOpen?: React.Dispatch<React.SetStateAction<boolean>>;
58
- inlineCommentData: {
59
- inlineCommentText: string;
60
- handleClick: boolean;
61
- };
62
- setInlineCommentData: React.Dispatch<React.SetStateAction<{
63
- inlineCommentText: string;
64
- handleClick: boolean;
65
- }>>;
66
- getEnsStatus: (walletAddress: string, setEnsStatus: React.Dispatch<React.SetStateAction<EnsStatus>>) => void;
67
- ensCache: EnsCache;
10
+ isFocused: boolean;
68
11
  }
69
- export interface CommentProviderProps extends CommentAccountProps {
70
- children: React.ReactNode;
71
- editor: Editor;
72
- ydoc: Y.Doc;
73
- initialComments?: IComment[];
74
- setInitialComments?: React.Dispatch<SetStateAction<IComment[]>>;
75
- onCommentReply?: (activeCommentId: string, reply: IComment) => void;
76
- onNewComment?: (newComment: IComment, meta?: CommentMutationMeta) => void;
77
- onResolveComment?: (activeCommentId: string, meta?: CommentMutationMeta) => void;
78
- onUnresolveComment?: (activeCommentId: string, meta?: CommentMutationMeta) => void;
79
- onDeleteComment?: (activeCommentId: string, meta?: CommentMutationMeta) => void;
80
- username: string | null;
81
- setUsername?: React.Dispatch<SetStateAction<string>>;
82
- activeCommentId: string | null;
83
- setActiveCommentId: React.Dispatch<React.SetStateAction<string | null>>;
84
- activeTabId: string;
85
- focusCommentWithActiveId: (id: string) => void;
86
- ensResolutionUrl: string;
87
- onInlineComment?: () => void;
88
- onComment?: () => void;
89
- setCommentDrawerOpen?: React.Dispatch<React.SetStateAction<boolean>>;
12
+ export type InlineDraftLocation = 'drawer' | 'floating';
13
+ export interface InlineCommentDraft {
14
+ draftId: string;
15
+ tabId: string;
16
+ selectedText: string;
17
+ text: string;
18
+ location: InlineDraftLocation;
19
+ isAuthPending: boolean;
90
20
  }
91
- export interface CommentUsernameProps extends CommentAccountProps {
92
- username?: string | null;
93
- setUsername?: React.Dispatch<SetStateAction<string>>;
94
- isNavbarVisible?: boolean;
21
+ export interface CommentFloatingDraftCard extends CommentFloatingBaseCard {
22
+ type: 'draft';
23
+ draftId: string;
24
+ }
25
+ export interface CommentFloatingThreadCard extends CommentFloatingBaseCard {
26
+ type: 'thread';
27
+ commentId: string;
28
+ }
29
+ export type CommentFloatingCard = CommentFloatingDraftCard | CommentFloatingThreadCard;
30
+ export interface InlineCommentData {
31
+ highlightedTextContent?: string;
32
+ inlineCommentText: string;
33
+ handleClick: boolean;
95
34
  }
96
35
  export interface EnsEntry {
97
36
  name: string;
98
37
  isEns: boolean;
99
38
  }
100
39
  export type EnsCache = Record<string, EnsEntry>;
40
+ export type CommentProviderProps = CommentStoreProviderProps;
41
+ export type CommentContextType = Pick<CommentStoreState, 'activeComment' | 'activeCommentIndex' | 'activeComments' | 'activeTabId' | 'addComment' | 'blurFloatingCard' | 'cancelFloatingDraft' | 'closeFloatingCard' | 'comment' | 'connectViaUsername' | 'connectViaWallet' | 'createFloatingDraft' | 'deleteComment' | 'deleteReply' | 'ensCache' | 'floatingCards' | 'focusCommentInEditor' | 'focusFloatingCard' | 'getEnsStatus' | 'handleAddReply' | 'handleCommentChange' | 'handleCommentKeyDown' | 'handleCommentSubmit' | 'handleInlineComment' | 'handleInput' | 'handleReplyChange' | 'handleReplyKeyDown' | 'handleReplySubmit' | 'inlineCommentData' | 'isBubbleMenuSuppressed' | 'isCommentActive' | 'isCommentOpen' | 'isCommentResolved' | 'isConnected' | 'isDDocOwner' | 'isDesktopFloatingEnabled' | 'isLoading' | 'onComment' | 'onNextComment' | 'onPrevComment' | 'openFloatingThread' | 'openReplyId' | 'reply' | 'resolveComment' | 'setComment' | 'setCommentDrawerOpen' | 'setInlineCommentData' | 'setIsBubbleMenuSuppressed' | 'setOpenReplyId' | 'setReply' | 'setShowResolved' | 'setUsername' | 'selectedText' | 'showResolved' | 'submitFloatingDraft' | 'toggleResolved' | 'unresolveComment' | 'updateFloatingDraftText' | 'username'> & {
42
+ comments: IComment[];
43
+ commentsSectionRef: RefObject<HTMLDivElement>;
44
+ dropdownRef: RefObject<HTMLDivElement>;
45
+ buttonRef: RefObject<HTMLDivElement>;
46
+ portalRef: RefObject<HTMLDivElement>;
47
+ replySectionRef: RefObject<HTMLDivElement>;
48
+ editor: CommentStoreProviderProps['editor'];
49
+ ensResolutionUrl: string;
50
+ onCommentReply?: CommentStoreProviderProps['onCommentReply'];
51
+ setComments?: Dispatch<SetStateAction<IComment[]>>;
52
+ };
53
+ export interface CommentUsernameProps extends CommentAccountProps {
54
+ username?: string | null;
55
+ setUsername?: Dispatch<SetStateAction<string>>;
56
+ isNavbarVisible?: boolean;
57
+ }
@@ -0,0 +1,10 @@
1
+ export declare const DeleteConfirmOverlay: ({ isVisible, title, onCancel, onConfirm, className, heading, description, confirmLabel, }: {
2
+ isVisible: boolean;
3
+ title: string;
4
+ onCancel: () => void;
5
+ onConfirm: () => void;
6
+ className?: string;
7
+ heading?: string;
8
+ description?: string;
9
+ confirmLabel?: string;
10
+ }) => import("react/jsx-runtime").JSX.Element | null;
@@ -1,2 +1,5 @@
1
- declare const EmptyComments: () => import("react/jsx-runtime").JSX.Element;
1
+ declare const EmptyComments: ({ commentType, handleReset, }: {
2
+ commentType: string;
3
+ handleReset?: () => void;
4
+ }) => import("react/jsx-runtime").JSX.Element;
2
5
  export { EmptyComments };
@@ -0,0 +1,3 @@
1
+ import { CommentFloatingContainerProps } from './types';
2
+
3
+ export declare const CommentFloatingContainer: ({ editor, editorWrapperRef, scrollContainerRef, tabName, isHidden, isCollaborationEnabled, }: CommentFloatingContainerProps) => import("react/jsx-runtime").JSX.Element | null;
@@ -0,0 +1,3 @@
1
+ import { DraftFloatingCardProps } from './types';
2
+
3
+ export declare const DraftFloatingCard: ({ draft, isHidden, registerCardNode, }: DraftFloatingCardProps) => import("react/jsx-runtime").JSX.Element | null;
@@ -0,0 +1 @@
1
+ export declare const FloatingAuthPrompt: () => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,3 @@
1
+ import { FloatingCardShellProps } from './types';
2
+
3
+ export declare const FloatingCardShell: import('react').ForwardRefExoticComponent<FloatingCardShellProps & import('react').RefAttributes<HTMLDivElement>>;
@@ -0,0 +1 @@
1
+ export { CommentFloatingContainer } from './comment-floating-container';
@@ -0,0 +1,3 @@
1
+ import { ThreadFloatingCardProps } from './types';
2
+
3
+ export declare const ThreadFloatingCard: ({ thread, comment, tabName, isHidden, registerCardNode, isCollaborationEnabled, }: ThreadFloatingCardProps) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,34 @@
1
+ import { Editor } from '@tiptap/react';
2
+ import { ReactNode, RefObject } from 'react';
3
+ import { IComment } from '../../../extensions/comment';
4
+ import { CommentFloatingDraftCard, CommentFloatingThreadCard } from '../context/types';
5
+
6
+ export type RegisterCardNode = (floatingCardId: string, node: HTMLDivElement | null) => void;
7
+ export interface CommentFloatingContainerProps {
8
+ editor: Editor;
9
+ editorWrapperRef: RefObject<HTMLDivElement>;
10
+ scrollContainerRef: RefObject<HTMLDivElement>;
11
+ tabName: string;
12
+ isHidden: boolean;
13
+ isCollaborationEnabled?: boolean;
14
+ }
15
+ export interface FloatingCardShellProps {
16
+ floatingCardId: string;
17
+ isHidden: boolean;
18
+ isFocused: boolean;
19
+ onFocus: () => void;
20
+ children: ReactNode;
21
+ }
22
+ export interface DraftFloatingCardProps {
23
+ draft: CommentFloatingDraftCard;
24
+ isHidden: boolean;
25
+ registerCardNode: RegisterCardNode;
26
+ }
27
+ export interface ThreadFloatingCardProps {
28
+ thread: CommentFloatingThreadCard;
29
+ comment: IComment | undefined;
30
+ tabName: string;
31
+ isHidden: boolean;
32
+ registerCardNode: RegisterCardNode;
33
+ isCollaborationEnabled?: boolean;
34
+ }
@@ -0,0 +1,78 @@
1
+ import { Editor } from '@tiptap/react';
2
+ import { FloatingLayoutInvalidationFlag, FloatingCardLayoutInput } from './comment-floating-layout';
3
+ import { CommentFloatingCard } from './context/types';
4
+
5
+ export type AnchorType = 'draft' | 'thread';
6
+ export interface CachedAnchorRect {
7
+ top: number;
8
+ height: number;
9
+ scrollTop: number;
10
+ containerTop: number;
11
+ }
12
+ export interface AnchorRecord {
13
+ floatingCardId: string;
14
+ anchorId: string;
15
+ anchorType: AnchorType;
16
+ elements: HTMLElement[];
17
+ pmPos: number | null;
18
+ anchorVersion: number;
19
+ cachedRect: CachedAnchorRect | null;
20
+ lastSeenEditorRoot: HTMLElement | null;
21
+ missingSinceDocVersion: number | null;
22
+ missingSinceCycle: number | null;
23
+ }
24
+ export interface FloatingCardRuntimeState {
25
+ floatingCardId: string;
26
+ anchorPosition: number | null;
27
+ anchorVersion: number;
28
+ anchorTop: number | null;
29
+ anchorHeight: number;
30
+ height: number;
31
+ isMeasured: boolean;
32
+ isInViewport: boolean;
33
+ translateY: number | null;
34
+ lastCommittedTranslateY: number | null;
35
+ lastCommittedVisible: boolean;
36
+ needsTransformSync: boolean;
37
+ invalidationFlags: FloatingLayoutInvalidationFlag;
38
+ }
39
+ export declare const FLOATING_VIEWPORT_BUFFER_MULTIPLIER = 1;
40
+ export declare const getAnchorIdentity: (floatingCard: CommentFloatingCard) => {
41
+ anchorId: string;
42
+ anchorType: "draft";
43
+ } | {
44
+ anchorId: string;
45
+ anchorType: "thread";
46
+ };
47
+ export declare const getAnchorElements: ({ editorRoot, anchorId, anchorType, }: {
48
+ editorRoot: HTMLElement;
49
+ anchorId: string;
50
+ anchorType: AnchorType;
51
+ }) => HTMLElement[];
52
+ export declare const getAnchorStartPos: (editor: Editor, elements: HTMLElement[]) => null;
53
+ export declare const getEditorRoot: (editor: Editor) => HTMLElement | null;
54
+ export declare const areAnchorElementsEqual: (previousElements: HTMLElement[], nextElements: HTMLElement[]) => boolean;
55
+ export declare const isAnchorEntryValid: (entry: AnchorRecord, editorRoot: HTMLElement) => boolean;
56
+ export declare const getCachedAnchorRect: ({ cachedRect, scrollTop, containerTop, }: {
57
+ cachedRect: CachedAnchorRect;
58
+ scrollTop: number;
59
+ containerTop: number;
60
+ }) => {
61
+ top: number;
62
+ height: number;
63
+ };
64
+ export declare const getRect: ({ elements, viewportTop, viewportBottom, }: {
65
+ elements: HTMLElement[];
66
+ viewportTop: number;
67
+ viewportBottom: number;
68
+ }) => DOMRect | null;
69
+ export declare const reconcileOrderedFloatingCardIds: ({ previousOrderedFloatingCardIds, nextFloatingCards, getPos, }: {
70
+ previousOrderedFloatingCardIds: string[];
71
+ nextFloatingCards: CommentFloatingCard[];
72
+ getPos: (floatingCardId: string) => number | null;
73
+ }) => {
74
+ orderedFloatingCardIds: string[];
75
+ firstChangedIndex: number | null;
76
+ };
77
+ export declare const areFloatingCardIdListsEqual: (a: string[], b: string[]) => boolean;
78
+ export declare const toFloatingCardLayoutInput: (floatingCardState: FloatingCardRuntimeState) => FloatingCardLayoutInput;
@@ -0,0 +1 @@
1
+ export declare const resizeInlineCommentTextarea: (textarea: HTMLTextAreaElement, maxHeight?: number) => void;
@@ -2,6 +2,7 @@ import { BubbleMenuProps } from '@tiptap/react/menus';
2
2
  import { Editor } from '@tiptap/react';
3
3
  import { IComment } from '../../extensions/comment';
4
4
  import { SetStateAction } from 'react';
5
+ import { Tab } from '../tabs/utils/tab-utils';
5
6
 
6
7
  export interface UseCommentActionsProps {
7
8
  editor: Editor;
@@ -31,13 +32,19 @@ export interface CommentDrawerProps {
31
32
  isNavbarVisible: boolean;
32
33
  isPresentationMode: boolean;
33
34
  activeCommentId: string | null;
35
+ activeTabId: string;
36
+ onTabChange?: (tabId: string) => void;
34
37
  isPreviewMode: boolean;
38
+ tabs: Tab[];
39
+ isCollaborationEnabled: boolean;
35
40
  }
36
41
  export interface CommentCardProps extends IComment {
37
42
  comment?: string;
38
43
  onResolve?: (commentId: string) => void;
39
44
  onDelete?: (commentId: string) => void;
45
+ onRequestDelete?: (commentId: string) => void;
40
46
  onUnresolve?: (commentId: string) => void;
47
+ onFocusRequest?: () => void;
41
48
  isResolved?: boolean;
42
49
  isDropdown?: boolean;
43
50
  activeCommentId?: string;
@@ -45,15 +52,21 @@ export interface CommentCardProps extends IComment {
45
52
  isCommentOwner?: boolean;
46
53
  version?: string;
47
54
  emptyComment?: boolean;
55
+ isFocused?: boolean;
56
+ isCommentDrawerContext?: boolean;
48
57
  }
49
58
  export type CommentBubbleMenuProps = Omit<BubbleMenuProps, 'children'> & {
50
59
  zoomLevel: string;
51
60
  };
52
61
  export interface CommentReplyProps {
62
+ commentId: string;
63
+ replyId: string;
53
64
  reply: string;
54
65
  username: string;
55
66
  createdAt: Date;
56
67
  isLast: boolean;
68
+ isThreadResolved?: boolean;
69
+ isCommentDrawerContext?: boolean;
57
70
  }
58
71
  export interface EnsStatus {
59
72
  name: string;
@@ -63,6 +76,17 @@ export interface CommentSectionProps {
63
76
  activeCommentId: string | null;
64
77
  isNavbarVisible?: boolean;
65
78
  isPresentationMode?: boolean;
79
+ isMobile?: boolean;
80
+ comments?: IComment[];
81
+ commentType?: 'all' | 'active' | 'resolved';
82
+ sectionLabel?: string;
83
+ tabNameById?: Record<string, string>;
84
+ selectedTabLabel?: string;
85
+ newCommentTabId?: string;
86
+ showNewCommentInput?: boolean;
87
+ onCommentFocus?: (commentId: string, tabId?: string) => void;
88
+ onReset?: () => void;
89
+ isCollaborationEnabled: boolean;
66
90
  }
67
91
  export interface UserDisplayProps {
68
92
  username: string;
@@ -0,0 +1,34 @@
1
+ import { MutableRefObject } from 'react';
2
+ import { Editor } from '@tiptap/react';
3
+ import { FloatingLayoutInvalidationFlag } from './comment-floating-layout';
4
+ import { CommentFloatingCard } from './context/types';
5
+ import { AnchorRecord, FloatingCardRuntimeState } from './floating-comment-layout-utils';
6
+
7
+ interface SyncAnchorsArgs {
8
+ currentCycle: number;
9
+ currentDocVersion: number;
10
+ editor: Editor;
11
+ editorRoot: HTMLElement;
12
+ editorWrapperNode: HTMLDivElement | null;
13
+ floatingCards: CommentFloatingCard[];
14
+ getFloatingCardRuntimeState: (floatingCardId: string) => FloatingCardRuntimeState;
15
+ markFloatingCardInvalidated: (floatingCardId: string, flag: FloatingLayoutInvalidationFlag) => void;
16
+ markFloatingCardOrderDirty: () => void;
17
+ markRecomputeFromIndex: (recomputeFromIndex: number) => void;
18
+ getOrderedFloatingCardIndex: (floatingCardId: string) => number | null;
19
+ }
20
+ interface SyncAnchorsResult {
21
+ activeFloatingCards: CommentFloatingCard[];
22
+ activeFloatingCardMap: Map<string, CommentFloatingCard>;
23
+ floatingCardIdsToClose: Set<string>;
24
+ shouldScheduleFollowUp: boolean;
25
+ }
26
+ export interface UseAnchorRegistryResult {
27
+ anchorRegistryRef: MutableRefObject<Map<string, AnchorRecord>>;
28
+ queueAnchorRefresh: (floatingCardId: string) => void;
29
+ queueAnchorRefreshForCards: (floatingCards: CommentFloatingCard[]) => void;
30
+ resetAnchorRegistry: () => void;
31
+ syncAnchors: (args: SyncAnchorsArgs) => SyncAnchorsResult;
32
+ }
33
+ export declare const useAnchorRegistry: () => UseAnchorRegistryResult;
34
+ export {};
@@ -0,0 +1,29 @@
1
+ import { MouseEvent } from 'react';
2
+ import { IComment } from '../../extensions/comment';
3
+ import { CommentCardProps } from './types';
4
+
5
+ export declare const useCommentCard: ({ username, comment, replies, onResolve, onRequestDelete, onUnresolve, onFocusRequest, isResolved, isDropdown, isCommentDrawerContext, activeCommentId, id, isFocused, }: CommentCardProps) => {
6
+ commentsContainerRef: import('react').RefObject<HTMLDivElement>;
7
+ displayedComment: string | undefined;
8
+ displayedReplies: IComment[];
9
+ dropdownRef: import('react').RefObject<HTMLDivElement>;
10
+ ensStatus: import('./types').EnsStatus;
11
+ focusCardIfNeeded: () => void;
12
+ handleCommentExpandClick: (event: MouseEvent<HTMLButtonElement>) => void;
13
+ handleReplyToggleClick: (event: MouseEvent<HTMLElement>) => void;
14
+ handleRequestEditClick: () => void;
15
+ handleRequestDeleteClick: () => void;
16
+ handleResolveClick: (event: MouseEvent<HTMLButtonElement>) => void;
17
+ handleUnresolveClick: () => void;
18
+ isBelow1280px: boolean;
19
+ isCardActive: boolean;
20
+ isCommentExpanded: boolean;
21
+ isCommentMobileFocused: boolean;
22
+ isCommentTruncated: boolean;
23
+ replyToggleLabel: string;
24
+ shouldShowReplyThread: boolean;
25
+ shouldShowReplyToggle: boolean;
26
+ shouldShowResolvedMobileReplyCount: boolean;
27
+ showAllReplies: boolean;
28
+ visibleReplies: IComment[];
29
+ };
@@ -0,0 +1,17 @@
1
+ import { RefObject } from 'react';
2
+ import { Editor } from '@tiptap/react';
3
+ import { CommentFloatingCard } from './context/types';
4
+
5
+ export interface UseCommentListContainerProps {
6
+ editor: Editor;
7
+ editorWrapperRef: RefObject<HTMLDivElement>;
8
+ scrollContainerRef: RefObject<HTMLDivElement>;
9
+ isHidden: boolean;
10
+ }
11
+ export interface UseCommentListContainerResult {
12
+ floatingCardListContainerRef: RefObject<HTMLDivElement>;
13
+ mountedFloatingCards: CommentFloatingCard[];
14
+ registerCardNode: (floatingCardId: string, node: HTMLDivElement | null) => void;
15
+ shouldRender: boolean;
16
+ }
17
+ export declare const useCommentListContainer: ({ editor, editorWrapperRef, scrollContainerRef, isHidden, }: UseCommentListContainerProps) => UseCommentListContainerResult;
@@ -0,0 +1,3 @@
1
+ import { EnsStatus } from './types';
2
+
3
+ export declare const useEnsStatus: (walletAddressOrName?: string | null) => EnsStatus;
@@ -0,0 +1,36 @@
1
+ import { MutableRefObject } from 'react';
2
+ import { FloatingLayoutInvalidationFlag, FloatingCardLayoutInput } from './comment-floating-layout';
3
+ import { CommentFloatingCard } from './context/types';
4
+ import { FloatingCardRuntimeState } from './floating-comment-layout-utils';
5
+
6
+ interface SyncMountedFloatingCardIdsResult {
7
+ didChange: boolean;
8
+ previousMountedFloatingCardIds: Set<string>;
9
+ }
10
+ export interface UseFloatingCardStateResult {
11
+ floatingCardStateRef: MutableRefObject<Map<string, FloatingCardRuntimeState>>;
12
+ orderedFloatingCardIdsRef: MutableRefObject<string[]>;
13
+ orderDirtyRef: MutableRefObject<boolean>;
14
+ heightMeasurementQueueRef: MutableRefObject<Set<string>>;
15
+ layoutBoundaryRef: MutableRefObject<{
16
+ recomputeFromIndex: number;
17
+ }>;
18
+ mountedFloatingCardIdsRef: MutableRefObject<string[]>;
19
+ mountedFloatingCardIds: string[];
20
+ getFloatingCardRuntimeState: (floatingCardId: string) => FloatingCardRuntimeState;
21
+ getOrderedFloatingCardIndex: (floatingCardId: string) => number | null;
22
+ markRecomputeFromIndex: (recomputeFromIndex: number) => void;
23
+ markFloatingCardInvalidated: (floatingCardId: string, flag: FloatingLayoutInvalidationFlag) => void;
24
+ markFloatingCardOrderDirty: () => void;
25
+ reconcileFloatingCardOrder: (nextFloatingCards: CommentFloatingCard[]) => {
26
+ orderedFloatingCardIds: string[];
27
+ firstChangedIndex: number | null;
28
+ };
29
+ pruneFloatingCardRuntimeState: (activeFloatingCardIds: Set<string>) => void;
30
+ syncMountedFloatingCardIds: (nextMountedFloatingCardIds: string[]) => SyncMountedFloatingCardIdsResult;
31
+ clearInvalidationFlagsThroughIndex: (stopIndex: number) => void;
32
+ getFloatingCardLayoutInputs: () => FloatingCardLayoutInput[];
33
+ resetFloatingCardState: () => void;
34
+ }
35
+ export declare const useFloatingCardState: () => UseFloatingCardStateResult;
36
+ export {};
@@ -0,0 +1,23 @@
1
+ import { RefObject } from 'react';
2
+ import { Editor } from '@tiptap/react';
3
+ import { CommentFloatingCard } from './context/types';
4
+
5
+ interface UseFloatingCommentCardLayoutProps {
6
+ blurFloatingCard: (floatingCardId: string) => void;
7
+ closeFloatingCard: (floatingCardId: string) => void;
8
+ editor: Editor;
9
+ editorWrapperRef: RefObject<HTMLDivElement>;
10
+ floatingCardIdsKey: string;
11
+ floatingCards: CommentFloatingCard[];
12
+ focusedFloatingCardId: string | null;
13
+ isDesktopFloatingEnabled: boolean;
14
+ isHidden: boolean;
15
+ scrollContainerRef: RefObject<HTMLDivElement>;
16
+ }
17
+ interface UseFloatingCommentCardLayoutResult {
18
+ floatingCardListContainerRef: RefObject<HTMLDivElement>;
19
+ mountedFloatingCardIds: string[];
20
+ registerCardNode: (floatingCardId: string, node: HTMLDivElement | null) => void;
21
+ }
22
+ export declare const useFloatingCommentCardLayout: ({ blurFloatingCard, closeFloatingCard, editor, editorWrapperRef, floatingCardIdsKey, floatingCards, focusedFloatingCardId, isDesktopFloatingEnabled, isHidden, scrollContainerRef, }: UseFloatingCommentCardLayoutProps) => UseFloatingCommentCardLayoutResult;
23
+ export {};
@@ -0,0 +1,13 @@
1
+ import { CommentFloatingCard } from './context/types';
2
+
3
+ interface UseFloatingCommentCardStateResult {
4
+ blurFloatingCard: (floatingCardId: string) => void;
5
+ closeFloatingCard: (floatingCardId: string) => void;
6
+ floatingCardIdsKey: string;
7
+ floatingCardMap: Map<string, CommentFloatingCard>;
8
+ floatingCards: CommentFloatingCard[];
9
+ focusedFloatingCardId: string | null;
10
+ isDesktopFloatingEnabled: boolean;
11
+ }
12
+ export declare const useFloatingCommentCardState: () => UseFloatingCommentCardStateResult;
13
+ export {};