Skip to content
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

Add trailing visuals to the text field #3237

Conversation

bsatarnejad
Copy link
Contributor

@bsatarnejad bsatarnejad commented Dec 10, 2024

What are you trying to accomplish?

Like leading visuals in a text-field, add trailing visuals to it. As explained here.

Screenshots

Screenshot 2024-12-10 at 07 43 30

Closes #3218

Risk Assessment

  • Low risk the change is small, highly observable, and easily rolled back.
  • Medium risk changes that are isolated, reduced in scope or could impact few users. The change will not impact library availability.
  • High risk changes are those that could impact customers and SLOs, low or no test coverage, low observability, or slow to rollback.

What approach did you choose and why?

Like leading visuals in text field, we add a section for trailing visuals:

  • Icon
  • Text
  • Label
  • Counter

Merge checklist

  • Added/updated tests
  • Added/updated documentation
  • Added/updated previews (Lookbook)
  • Tested in Chrome
  • Tested in Firefox
  • Tested in Safari
  • Tested in Edge

Take a look at the What we look for in reviews section of the contributing guidelines for more information on how we review PRs.

@bsatarnejad bsatarnejad requested review from a team as code owners December 10, 2024 08:45
@bsatarnejad bsatarnejad requested review from langermank and removed request for a team December 10, 2024 08:45
Copy link

changeset-bot bot commented Dec 10, 2024

🦋 Changeset detected

Latest commit: 472b01b

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 1 package
Name Type
@primer/view-components Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@bsatarnejad bsatarnejad force-pushed the 59860-add-trailing-unit-for-input-fields-in-datepicker-and-lag-field branch from d650220 to 5396bf2 Compare December 17, 2024 06:49
@camertron
Copy link
Contributor

Hey @bsatarnejad, were you planning on implementing the other kinds of trailing visuals we talked about in #3218 (comment) ?

@bsatarnejad
Copy link
Contributor Author

Hey @bsatarnejad, were you planning on implementing the other kinds of trailing visuals we talked about in #3218 (comment) ?

Hi @camertron Yes of course.
The trailing icon has been successfully implemented, and the trailing text is currently being worked on. The remaining items will be addressed in due course.

@bsatarnejad
Copy link
Contributor Author

bsatarnejad commented Dec 19, 2024

Hi @camertron
As you mentioned here, four possible forms of trailing visual for an input text field are implemented: icon, label, text, and counter.
Screenshot of four possible trailing visuals in input text field

In the React implementation of this component, I noticed an issue: when there’s a long trailing text, it takes up all the available space, leaving no room for the input field itself.
https://github.com/user-attachments/assets/b33917c8-053c-404d-9bcb-374dc4b97cd4

The solution I’ve implemented for a long trailing text is to handle it by truncating it with ellipsis.
Therefore, I set the trailing text width to 25% of the parent container’s width, ensuring that the input field still has enough space. If the trailing text exceeds this width, it gets truncated with ellipsis.

Screenshot of a long tailing text

I’d love to hear your thoughts on this solution!

Copy link
Contributor

Uh oh! @bsatarnejad, the image you shared is missing helpful alt text. Check #3237 (comment).

Alt text is an invisible description that helps screen readers describe images to blind or low-vision users. If you are using markdown to display images, add your alt text inside the brackets of the markdown image.

Learn more about alt text at Basic writing and formatting syntax: images on GitHub Docs.

🤖 Beep boop! This comment was added automatically by github/accessibility-alt-text-bot.

Copy link
Contributor

@camertron camertron left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looking good 😄

app/lib/primer/forms/text_field.rb Outdated Show resolved Hide resolved
app/lib/primer/forms/text_field.html.erb Outdated Show resolved Hide resolved
@bsatarnejad bsatarnejad requested a review from camertron January 6, 2025 14:26
@bsatarnejad
Copy link
Contributor Author

Looking good 😄

Hi @camertron Thanks for your review, I applied the changes that you mentioned, could you please have another look?
Regards.

@camertron
Copy link
Contributor

Hey @bsatarnejad, just took another look and created this parallel PR so all our CI jobs would run: #3267

I noticed some unusual overflow in the label preview:

A screenshot of a Lookbook preview showing that the text entered in the text field overflows and covers part of the label on the right-hand side.

Any idea what's causing this?

@bsatarnejad
Copy link
Contributor Author

Hey @bsatarnejad, just took another look and created this parallel PR so all our CI jobs would run: #3267

I noticed some unusual overflow in the label preview:

A screenshot of a Lookbook preview showing that the text entered in the text field overflows and covers part of the label on the right-hand side. Any idea what's causing this?

Hi @camertron thanks for the review.
This issue is because padding-inline-end of the input is smaller than the width of the label. The solution I suggest for this problem is similar to the one we used for long text. We can set padding-inline-end of the input to 25% and the max-width of the label to 25% as well. This way, we prevent the input content from overlapping with the label. I will commit this solution, let me know if it works for you or not.
Regards

@camertron
Copy link
Contributor

Awesome, thanks @bsatarnejad, everything looks great now 🎉

Copy link
Contributor

@langermank langermank left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for putting so much care into this CSS change! 🚀

@camertron
Copy link
Contributor

camertron commented Jan 14, 2025

Merged in #3267

@camertron camertron closed this Jan 14, 2025
@bsatarnejad
Copy link
Contributor Author

Thank you! @camertron @langermank I’m so happy you’re pleased with the changes. Your feedback really helped refine things!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

TextFields are missing the option for a trailing visual icon or text
3 participants