Opened 9 months ago
Closed 9 months ago
#9052 closed defect (bug) (fixed)
Duplicate "page on front" option values when BP Classic Add-on is activated
Reported by: | emaralive | Owned by: | imath |
---|---|---|---|
Milestone: | 12.1.0 | Priority: | normal |
Severity: | normal | Version: | 12.0.0 |
Component: | Core | Keywords: | has-patch has-screenshots commit |
Cc: |
Description
Environment
WordPress:
Version: 6.5-alpha-57235
Parent Theme:
Name : Twenty Eleven (twentyeleven)
Version: 4.5
Server:
PHP version: 7.4.33 (Supports 64bit values)
BuddyPress:
Version : 14.0.0-alpha
Active components : Community Members, Extended Profiles, Account Settings, Friend Connections, Private Messaging, Activity Streams, Notifications, User Groups, Site Tracking
Active template pack: BuddyPress Nouveau 14.0.0-alpha
URL Parser : Legacy Parser (used to illustrate issue [2nd result], to test patch and illustrate final (3rd) result)
URL Parser : BP Rewrites API (used to illustrate 1st result and to test patch)
The issue can be seen by having the BP Classic Add-on activated and viewing either the "Reading Settings" screen (Dashboard > Settings > Reading) or the "Homepage Settings" panel in Customizer (Dashboard > Appearance > Customize > Homepage Settings) and then click the "static page" radio button and then click the "Hompage" dropdown box. However, the following is the option values with the BP Classic Add-on deactivated (see screenshot w/o patch BP Classic deactivated):
wp_dropdown_pages(array('name' => 'page_on_front','echo' => 0,'show_option_none' => __( '— Select —' ),'option_none_value' => '0','selected' => get_option( 'page_on_front' ),)) => string(375) "<select name='page_on_front' id='page_on_front'> <option value="0">— Select —</option> <option class="level-0" value="45">Activity</option> <option class="level-0" value="55">Blog</option> <option class="level-0" value="49">Groups</option> <option class="level-0" value="47">Members</option> <option class="level-0" value="2">Sample Page</option> </select>
The following is when the BP Classic Add-on is activated, notice that Activity, Groups and Members option values are duplicated (see screenshot w/o patch BP Classic activated):
wp_dropdown_pages(array('name' => 'page_on_front','echo' => 0,'show_option_none' => __( '— Select —' ),'option_none_value' => '0','selected' => get_option( 'page_on_front' ),)) => string(642) "<select name='page_on_front' id='page_on_front'> <option value="0">— Select —</option> <option class="level-0" value="51">Activate</option> <option class="level-0" value="45">Activity</option> <option class="level-0" value="45">Activity</option> <option class="level-0" value="55">Blog</option> <option class="level-0" value="49">Groups</option> <option class="level-0" value="49">Groups</option> <option class="level-0" value="47">Members</option> <option class="level-0" value="47">Members</option> <option class="level-0" value="53">Register</option> <option class="level-0" value="2">Sample Page</option> </select>
Finally, with patch applied and the BP Classic Add-on activated, the option values are what should have been initially expected (see screenshot w/ patch BP Classic activated)):
wp_dropdown_pages(array('name' => 'page_on_front','echo' => 0,'show_option_none' => __( '— Select —' ),'option_none_value' => '0','selected' => get_option( 'page_on_front' ),)) => string(483) "<select name='page_on_front' id='page_on_front'> <option value="0">— Select —</option> <option class="level-0" value="51">Activate</option> <option class="level-0" value="45">Activity</option> <option class="level-0" value="55">Blog</option> <option class="level-0" value="49">Groups</option> <option class="level-0" value="47">Members</option> <option class="level-0" value="53">Register</option> <option class="level-0" value="2">Sample Page</option> </select>
The concept of the patch is to remove the filter for 'get_pages
' with the callback to the function bp_core_include_directory_on_front
, when the 'legacy' BuddyPress URL Parser is in use thus, preventing the duplication of the Activity, Groups & Members 'page on front' option values.
Attachments (5)
Change History (12)
#1
follow-up:
↓ 2
@
9 months ago
- Milestone changed from Awaiting Review to 12.1.0
Great catch @emaralive 👍.
My first feedbacks are:
- I wonder if this filter should be removed from the BP Classic plugin instead.
- If we need to do it from BuddyPress Core, I would only filter
get_pages
if the URL Parser is set torewrites
instead of adding a new filter to remove another one.
I'd prolly go with option 2.
#2
in reply to:
↑ 1
@
9 months ago
@imath
- I wonder if this filter should be removed from the BP Classic plugin instead.
I'm chuckling (at myself) because this was my initial thought, I had modified the function bp_classic_use_legacy_parser
(bp-classic/inc/core/filters.php) to remove the filter but then opted not to do that because it would cause a new release of the BP Classic plugin and since there is going to be a 12.1.0 release of BuddyPress, try and to it there/here instead. Although, you would probably do it at some other place in the BP Classic plugin.
- If we need to do it from BuddyPress Core, I would only filter
get_pages
if the URL Parser is set torewrites
instead of adding a new filter to remove another one.
I'm struggling with this option, not sure how I would do this since the 'get_pages' filter is added before the function bp_core_get_query_parser
is defined, e.g., add_filter( 'get_pages', 'bp_core_include_directory_on_front', 10, 2 );
is found on line 1017 of bp-core/bp-core-filters.php. But then, I'm most likely, not seeing what you are seeing; IOW, it's not that obvious to me (not grasping what you have conveyed).
Now as a counter-offer, I can see how I could modify the conditional (checks if the "legacy' parser is in use) to remove the "get_pages" filter within the function bp_core_setup_query_parser
found on line 89 of bp-core/bp-core-actions.php.
Other than that, you will have to enlighten me as to your 2nd option or if need be I'm OK with you applying a remedy of your own discretion because this is still a learning experience for me.
#3
@
9 months ago
Thanks for looking into each option and for your detailed explanation. I think that when the bp_core_include_directory_on_front()
will be used by our filter, bp_core_get_query_parser()
should be available.
@emaralive Could you test adding this kind of check at the very beginning of the bp_core_include_directory_on_front()
function's code?
function bp_core_include_directory_on_front( $pages = array(), $args = array() ) { if ( 'rewrites' !== bp_core_get_query_parser() ) { return $pages; }
I believe it's the fix we should include into 12.1.0.
Thanks in advance.
#4
@
9 months ago
@imath Now option 2 makes a whole lot of sense (laughing at myself, once again), thanks for the enlightenment!! And, yes, your code works like a charm. I've attached a new patch for your review (9052.01.patch).
screenshot w/o patch BP Classic deactivated