From c3add155d625a0ca2d7e48b7c9f0f08bf884b3d5 Mon Sep 17 00:00:00 2001 From: Adam Silverstein Date: Thu, 22 Oct 2020 08:48:14 -0600 Subject: [PATCH 1/3] Ensure the parent post is among the available options. --- packages/editor/src/components/page-attributes/parent.js | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/packages/editor/src/components/page-attributes/parent.js b/packages/editor/src/components/page-attributes/parent.js index 147b7d5a51fae9..f4f35dd31c665d 100644 --- a/packages/editor/src/components/page-attributes/parent.js +++ b/packages/editor/src/components/page-attributes/parent.js @@ -7,6 +7,7 @@ import { debounce, flatMap, repeat, + find, } from 'lodash'; /** @@ -92,7 +93,14 @@ export function PageAttributesParent() { } ) ) ); const opts = getOptionsFromTree( tree ); + const itemsHaveParent = find( opts, item => item.value === parentPostId ); + if ( parentPost && ! itemsHaveParent ) { + opts.unshift( { + value: parentPostId, + label: getTitle( parentPost ), + } ); + } return opts; }, [ pageItems ] ); From 4a27a9b4372f10c55d9c546d9d4d19650e3e16bf Mon Sep 17 00:00:00 2001 From: Adam Silverstein Date: Thu, 22 Oct 2020 11:07:52 -0600 Subject: [PATCH 2/3] Fix search & only build a hierarchical tree when not searching. --- .../src/components/page-attributes/parent.js | 35 ++++++++++++------- 1 file changed, 23 insertions(+), 12 deletions(-) diff --git a/packages/editor/src/components/page-attributes/parent.js b/packages/editor/src/components/page-attributes/parent.js index f4f35dd31c665d..b6cea94bc1fc79 100644 --- a/packages/editor/src/components/page-attributes/parent.js +++ b/packages/editor/src/components/page-attributes/parent.js @@ -32,6 +32,7 @@ function getTitle( post ) { export function PageAttributesParent() { const { editPost } = useDispatch( 'core/editor' ); const [ fieldValue, setFieldValue ] = useState( false ); + const isSearching = fieldValue && '' !== fieldValue; const { parentPost, parentPostId, items, postType } = useSelect( ( select ) => { const { getPostType, getEntityRecords, getEntityRecord } = select( @@ -53,7 +54,9 @@ export function PageAttributesParent() { order: 'asc', _fields: 'id,title,parent', }; - if ( parentPost && fieldValue && '' !== fieldValue ) { + + // Perform a search when the field is changed. + if ( isSearching ) { query.search = fieldValue; } @@ -85,21 +88,29 @@ export function PageAttributesParent() { }; const parentOptions = useMemo( () => { - const tree = buildTermsTree( - pageItems.map( ( item ) => ( { - id: item.id, - parent: item.parent, - name: getTitle( item ), - } ) ) - ); + let tree = pageItems.map( ( item ) => ( { + id: item.id, + parent: item.parent, + name: getTitle( item ), + } ) ); + + // Only build a hierarchical tree when not searching. + if ( ! isSearching ) { + tree = buildTermsTree( tree ); + } + const opts = getOptionsFromTree( tree ); - const itemsHaveParent = find( opts, item => item.value === parentPostId ); - if ( parentPost && ! itemsHaveParent ) { + + // Ensure the current parent is in the options list. + const optsHasParent = find( + opts, + ( item ) => item.value === parentPostId + ); + if ( parentPost && ! optsHasParent ) { opts.unshift( { value: parentPostId, label: getTitle( parentPost ), - } ); - + } ); } return opts; }, [ pageItems ] ); From 63e28dca4dd0ff8713cbd589253e04d209dada50 Mon Sep 17 00:00:00 2001 From: Adam Silverstein Date: Fri, 23 Oct 2020 07:41:59 -0600 Subject: [PATCH 3/3] Update packages/editor/src/components/page-attributes/parent.js Co-authored-by: Nik Tsekouras --- packages/editor/src/components/page-attributes/parent.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/editor/src/components/page-attributes/parent.js b/packages/editor/src/components/page-attributes/parent.js index b6cea94bc1fc79..b18cc4badf30a9 100644 --- a/packages/editor/src/components/page-attributes/parent.js +++ b/packages/editor/src/components/page-attributes/parent.js @@ -32,7 +32,7 @@ function getTitle( post ) { export function PageAttributesParent() { const { editPost } = useDispatch( 'core/editor' ); const [ fieldValue, setFieldValue ] = useState( false ); - const isSearching = fieldValue && '' !== fieldValue; + const isSearching = fieldValue; const { parentPost, parentPostId, items, postType } = useSelect( ( select ) => { const { getPostType, getEntityRecords, getEntityRecord } = select(