-
Notifications
You must be signed in to change notification settings - Fork 4.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Inline Commenting: Re-order the comments in sidebar in which blocks are listed #66927
Changes from 5 commits
1d42175
67441de
5574c5e
5a43c16
eb4e907
e47abac
b5c41f7
7da59a0
809ebc8
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -12,7 +12,7 @@ import { useState, useMemo } from '@wordpress/element'; | |
import { comment as commentIcon } from '@wordpress/icons'; | ||
import { addFilter } from '@wordpress/hooks'; | ||
import { store as noticesStore } from '@wordpress/notices'; | ||
import { store as coreStore } from '@wordpress/core-data'; | ||
import { store as coreStore, useEntityBlockEditor } from '@wordpress/core-data'; | ||
import { store as blockEditorStore } from '@wordpress/block-editor'; | ||
import { store as interfaceStore } from '@wordpress/interface'; | ||
|
||
|
@@ -220,8 +220,11 @@ export default function CollabSidebar() { | |
const { enableComplementaryArea } = useDispatch( interfaceStore ); | ||
const { getActiveComplementaryArea } = useSelect( interfaceStore ); | ||
|
||
const { postStatus } = useSelect( ( select ) => { | ||
const { postId, postType, postStatus } = useSelect( ( select ) => { | ||
const { getCurrentPostId, getCurrentPostType } = select( editorStore ); | ||
return { | ||
postId: getCurrentPostId(), | ||
postType: getCurrentPostType(), | ||
postStatus: | ||
select( editorStore ).getEditedPostAttribute( 'status' ), | ||
}; | ||
|
@@ -262,8 +265,37 @@ export default function CollabSidebar() { | |
}; | ||
}, [] ); | ||
|
||
const [ blocks ] = useEntityBlockEditor( 'postType', postType, { | ||
id: postId, | ||
} ); | ||
|
||
const getCommentIdsFromBlocks = () => { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Let's use named functions? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Also, can't this function be moved out of the component? It doesn't seem to depend on other variables. |
||
// Recursive function to extract comment IDs from blocks | ||
const extractCommentIds = ( items ) => { | ||
return items.reduce( ( commentIds, block ) => { | ||
// Check for comment IDs in the current block's attributes | ||
if ( block.attributes && block.attributes.blockCommentId ) { | ||
commentIds.push( block.attributes.blockCommentId ); | ||
} | ||
|
||
// Recursively check inner blocks | ||
if ( block.innerBlocks && block.innerBlocks.length > 0 ) { | ||
const innerCommentIds = extractCommentIds( | ||
block.innerBlocks | ||
); | ||
commentIds.push( ...innerCommentIds ); | ||
} | ||
|
||
return commentIds; | ||
}, [] ); | ||
}; | ||
|
||
// Extract all comment IDs recursively | ||
return extractCommentIds( blocks ); | ||
}; | ||
|
||
// Process comments to build the tree structure | ||
const resultComments = useMemo( () => { | ||
const { resultComments, sortedThreads } = useMemo( () => { | ||
// Create a compare to store the references to all objects by id | ||
const compare = {}; | ||
const result = []; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Isn't this always an array? Why guard with There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. yes, i'll update that. |
||
|
@@ -288,7 +320,18 @@ export default function CollabSidebar() { | |
} | ||
} ); | ||
|
||
return result; | ||
const blockCommentIds = getCommentIdsFromBlocks(); | ||
|
||
const uniqueIds = [ ...new Set( blockCommentIds.values() ) ]; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Is the values call really needed her? Set accepts the array? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Also, if you need unique IDs, maybe |
||
|
||
const threadIdMap = new Map( | ||
result?.map( ( thread ) => [ thread.id, thread ] ) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If it's possible for |
||
); | ||
const sortedComments = uniqueIds | ||
.map( ( id ) => threadIdMap.get( id ) ) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Btw, I see above that a thread can be There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't follow, we are re-arranging comments here so reply comments will go under the parent comment. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Sorry, I missed that this is within |
||
.filter( ( thread ) => thread !== undefined ); | ||
|
||
return { resultComments: result, sortedThreads: sortedComments }; | ||
}, [ threads ] ); | ||
|
||
// Get the global styles to set the background color of the sidebar. | ||
|
@@ -338,7 +381,7 @@ export default function CollabSidebar() { | |
headerClassName="editor-collab-sidebar__header" | ||
> | ||
<CollabSidebarContent | ||
comments={ resultComments } | ||
comments={ sortedThreads } | ||
showCommentBoard={ showCommentBoard } | ||
setShowCommentBoard={ setShowCommentBoard } | ||
styles={ { | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can there be a case where there is no current post ID?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it does, Ill put condition there to avoid errors.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
After some finding, Undefined postId is already being handled under
useEntityBlockEditor
for cases like templates and patterns.