-
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
Unable to remove underline from Post Title links #46180
Comments
I have this issue too. I am on WP 6.1.1 using Firefox Browser on Windows. I believe my issue is the same as this one. Here's how I described it elsewhere: If you have the "Make Title A Link" option turned OFF, you can change the typography all you want, including setting the typography decorations. But if you turn the "Make Title A Link" ON, text decorations do not work. Size, Line Height, Appearance, and Letter case all work just fine. But Decoration does not work. I ran across this because I have a somewhat brutalist approach to web pages. In my world, if text is clickable, it must be visibly underlined at all times. Ideally, I would like to see two complete sets of typography options. One set of typography options for when it's just displayed and another set of typography options for :hover. So for example, I would like to have the text underlined at all times but if a mouse is hovering over it, I'd like change the text to bold. And then have it go back to normal when the mouse is no longer hovering over it. I see no way to do this with the current behavior. |
Thanks for writing up this issue @terra-incognita 👍 Testing with the latest version of the TwentyTwentyThree theme, it appears that the Post Title block has the text decoration removed for its link element. If I edit this link element style, to something else e.g. The Post Title block's "make title a link" option semantically changes the markup to include an anchor tag. This link is then subject to the Global Styles element settings. Please correct me if I'm wrong but the issue as I see it, is that setting typography styles at the block level are not inherited by the block's link element when the "make title a link" option is enabled due to theme.json and global styles for links. This is a problem for more than just text decoration, if the link elements are styled with say a custom font size, that will take precedence over the block's style applied to the wrapper as well. It might be possible for us to force styles set at the block level for the Post Title block, to be inherited by any inner link. It would involve adding some default block styles that hook onto the addition of inline styles or preset CSS classes on the block wrapper and styling the inner link to then inherit values. This is a bit of a hack and not a very clean option. Something like the following would allow an individual block's text decoration to override the link element's if set: .wp-block-post-title[style*="text-decoration"] a {
text-decoration: inherit;
} An alternative solution would be to update the post title block to apply all typography styles on the inner anchor tag when set. As Post Title is a dynamic block we might be able to achieve this without the need for a block deprecation. I'll be AFK for a few weeks, so happy for someone else to explore solutions here. If not, it might be something I can pick up in the new year. |
→I was looking for a solution to this and discovered that a similar approach had already been taken in some blocks:
If this approach is the best we currently have, I would like to test it and submit a PR. |
I believe we need the same for the site title: |
It would be nice if we had an option to customize the way links appear in general. Different sites choose different methods of making links stand out, such as changing text color, adding a background highlight, etc. Currently there is no way to do this inside Gutenberg or Here I'm talking about changing the appearance of specific links, or links within a section, as opposed to changing the appearance of links globally. |
HI @aadilayub 👋 There's is actually some ongoing work at the moment that will help address this. You can follow along or gain some extra context via #57537. In essence, block style variations are being extended to allow support for element styles. This would open up the possibility to create a block style variation for the container block being used for a section of your page and style the links there differently to the global link styles. |
Ran into this yesterday while creating a block theme. Reproduced the issue with the Emptytheme theme. Definitely frustrating. Kapture.2024-06-04.at.15.08.00.mp4 |
@aaronrobertshaw thanks for the recommendation! This is a potential solution, but I don't know if it is a good idea to create a whole separate style variation for styling links differently on a section of a page. I was hoping there could be some solution like going in and setting typography/color styles for links directly, similar to how we currently do for paragraph, heading blocks. |
This issue creates a bad experience as it seems like the editor does not follow what we defined.
Into this one:
It is not a perfect solution it goes a little against the convention that wp-block-* class is the wrapper of a block, but I think the results people get would be better. Any thoughts on this solution? |
@jorgefilipecosta What about this: #64911? I'm still working on the description, but I think this is a good solution to handle both |
@rafaelgallani: Did #64911 fix this issue? |
Hey, @noisysocks! Yes, I haven't been able to reproduce any of the linked issues in #64911, but I wanted a second opinion before closing them... Or should I just close them and have someone reopen them if they still persist? |
Yes you can close them if your PR fixed those issues! We can always re-open as you say. |
Cosing as the issue is now fixed. |
Description
Post Title blocks have an option to turn the title into a link, as you'd want on a homepage. But you can't set
text-decoration
on such links from the editor. It's always just underlined.Even if you edit
theme.json
, the WP-generated#wp-block-post-title-inline-css
embedded stylesheet seems to ignore what you set fortextDecoration
on Post Title links even though:fontWeight
andfontSize
textDecoration
for:hover
,:active
and:focus
for Post Title linksI also tried adding
:link
or:any-link
selectors as an attempted workaround, but WP just ignored them.Step-by-step reproduction instructions
Twenty Twenty-Three
theme.Home
template.Post Title
block.Make title a link
is enabled in the settings for that block.Decoration
typography option in the block settings.-
(none).Tools > Theme File Editor
and select theTwenty Twenty-Three
theme.Theme Styles & Block Settings (theme.json)
from the file selector.core/post-title
block understyles > blocks
, and try to set the Post Title block's"link"
element'stextDecoration
to"none"
:Update File
.#wp-block-post-title-inline-css
<style>
element and notice that the.wp-block-navigation a:where(:not(.wp-element-button))
selector still hastext-decoration: underline
.fontSize
orfontWeight
attribute on Post Title links in the exact same place as above intheme.json
. Notice that the embedded stylesheet changes to reflect those values, and your Post Title links can have a custom size or weight, just not text-decoration.Screenshots, screen recording, code snippet
The
text-decoration
attribute on the.wp-block-post-title a:where(:not(.wp-element-button))
selector will always be set tounderline
no matter what you do.You can add
font-weight
orfont-size
to that selector. But WP won't let you change thetext-decoration
attribute:The above
data:image/s3,"s3://crabby-images/ffc82/ffc82108a31c1c2aa49d5599af1c0d165bad36da" alt="204721994-4cb77a4b-24f8-4577-b3db-95de26530828"
theme.json
produces the following embedded stylesheet:Environment info
Please confirm that you have searched existing issues in the repo.
Yes
Please confirm that you have tested with all plugins deactivated except Gutenberg.
Yes
The text was updated successfully, but these errors were encountered: