Opened 13 years ago
Last modified 12 months ago
#18035 reopened enhancement
ignore_sticky_posts fails to remove sticky class
Reported by: | mikkelbreum | Owned by: | johneckman |
---|---|---|---|
Milestone: | Future Release | Priority: | normal |
Severity: | normal | Version: | 3.2 |
Component: | Query | Keywords: | has-patch dev-feedback |
Focuses: | template | Cc: |
Description
When setting the query_posts parameter:
ignore_sticky_posts = 1
all sticky posts are returned as normal posts and placed accordingly in the flow. However the sticky posts keep their sticky class, which means that an additional filtering of post_class is necessary to avoid any css rules defined for the .sticky selector taking effect.
is this intended, or could it be considered an enhancement if it was patched?
Attachments (3)
Change History (34)
#2
@
13 years ago
Judging by the syntax of the get_post_class() function, it does look like it shouldn't apply in this case:
345 // sticky for Sticky Posts 346 if ( is_sticky($post->ID) && is_home() && !is_paged() ) 347 $classes[] = 'sticky';
#3
@
13 years ago
- Keywords has-patch added; needs-patch removed
is_sticky doesn't check for ignore_sticky_posts ;) patch attached
#6
@
13 years ago
When uploading a new version of a patch, don't overwrite the old one, so that context is preserved.
#8
@
12 years ago
- Cc mikkel@… added
Theres a patch provided here (18035), but it hasn't been implemented as of WP 3.3. Any reason?
#10
@
10 years ago
- Keywords needs-refresh added; has-patch commit removed
- Severity changed from minor to normal
Needs a refresh
#17
follow-up:
↓ 18
@
10 years ago
- Resolution fixed deleted
- Status changed from closed to reopened
I don't remember where (Twitter?) but I've seen a bug report related to the sticky class no longer appearing in 4.1.
I am trying to think how this could break things, but I bet it does, despite it looking harmless. Secondary loops, queries that deliberately splice sticky_posts and put it into post__in
because the client stuck a few thousand posts (classic markjaquith rant), etc.
#18
in reply to:
↑ 17
@
10 years ago
Replying to nacin:
I don't remember where (Twitter?) but I've seen a bug report related to the sticky class no longer appearing in 4.1.
I am trying to think how this could break things, but I bet it does, despite it looking harmless. Secondary loops, queries that deliberately splice sticky_posts and put it into
post__in
because the client stuck a few thousand posts (classic markjaquith rant), etc.
We have to determine that if current query is main query or query for secondary loop. We can add class sticky in following couple of situations.
- If query is main query and ignore_sticky_posts parameter is not set in the query.
- If query is for secondary loop only.
Still, I am wondering when there is a check for is_home(), how could it break the things !
This ticket was mentioned in Slack in #core by nacin. View the logs.
10 years ago
#20
@
10 years ago
I think if we are dealing with secondary loop, then we can remove is_home() condition from that line. Otherwise on homepage secondary loop does not seem effective.
#21
follow-up:
↓ 22
@
10 years ago
- Keywords revert added
Even though we already rely on the state of the $wp_query
global in the other parts of the conditional, looking at a query var that might not be from that particular loop seems extra wrong. I also don't think a post stops being marked as sticky based on the query that's being run. The global is_main_query()
function is deprecated (see #23329) so the following patch is a no-go.
This definitely breaks things visually on the front for anybody who was previously styling sticky posts whether or not they were floated to the top in the query, which to me is a separate concern from an HTML/CSS class. I'm also sure there are people out there who use stickies to indicate some kind of importance without necessarily always chucking them to the front and rely on the class being there, no matter what that query var says.
Suggest revert and wontfix - not only do I think that we are mixing concerns here, but even if we weren't, there's no way this doesn't at least cause visual breakage in themes.
#22
in reply to:
↑ 21
;
follow-up:
↓ 23
@
10 years ago
Replying to helen:
The global
is_main_query()
function is deprecated (see #23329) so the following patch is a no-go.
is_main_query()
only issues a notice when being called from pre_get_posts
. It still has a valid use case otherwise ("is $wp_query
the main query?"), see comment:3:ticket:23329, which is exactly the use case here.
I don't disagree with a wontfix, but checking is_main_query()
seems like a correct thing to do here, so perhaps revert and fix in a future release would be a better way.
#23
in reply to:
↑ 22
@
10 years ago
Replying to SergeyBiryukov:
Replying to helen:
The global
is_main_query()
function is deprecated (see #23329) so the following patch is a no-go.
is_main_query()
only issues a notice when being called frompre_get_posts
. It still have a valid use case otherwise ("is$wp_query
the main query?"), see comment:3:ticket:23329, which is exactly the use case here.
Came back here to say oops, because you are correct and I am asleep at the wheel. :) Also, upon further thought, by default this class seems rather unreliable (sometimes applied to secondary queries because of global state) outside of the good old first-page-of-home-main-query context. If we add is_main_query(), I guess the default behavior overall would become more correct, though I'd still be concerned about how (custom) themes are potentially affected. But in any case, let's revert and try again later.
This ticket was mentioned in Slack in #core by mark. View the logs.
10 years ago
#31
@
12 months ago
- Keywords changed from has-patch, dev-feedback to has-patch dev-feedback
Another contributor asked me to take a look at this.
As the sticky
class on posts has worked in roughly the same way for approximately fifteen years, I think it would be too risky to change it now.
Possibly we could add a hoisted
class for sticky posts that have been raised to the top with the block of code looking something like this (possibly with an is_main_query()
thrown in for good measure):
<?php global $wp_query; // ... // Sticky for Sticky Posts. if ( is_sticky( $post->ID ) ) { if ( is_home() && ! is_paged() ) { $classes[] = 'sticky'; if ( true !== (bool) $wp_query->get( 'ignore_sticky_posts' ) ) { $classes[] = 'hoisted'; } } elseif ( is_admin() ) { $classes[] = 'status-sticky'; } }
As far as I can tell, the sticky class is the only thing that allows you to style a sticky post.
Therefore, posts that are displayed normally shouldn't have the sticky class.