-
Notifications
You must be signed in to change notification settings - Fork 4.1k
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
Simplify the design of Chosen, and organize the CSS #2479
Conversation
…focus styles when on mac, remove unused and old css
coffee/chosen.jquery.coffee
Outdated
@@ -44,7 +44,7 @@ class Chosen extends AbstractChosen | |||
if @is_multiple | |||
@container.html '<ul class="chosen-choices"><li class="search-field"><input type="text" value="' + @default_text + '" class="default" autocomplete="off" style="width:25px;" /></li></ul><div class="chosen-drop"><ul class="chosen-results"></ul></div>' | |||
else | |||
@container.html '<a class="chosen-single chosen-default"><span>' + @default_text + '</span><div><b></b></div></a><div class="chosen-drop"><div class="chosen-search"><input type="text" autocomplete="off" /></div><ul class="chosen-results"></ul></div>' | |||
@container.html '<a class="chosen-single chosen-default"><span>' + @default_text + '</span><div></div></a><div class="chosen-drop"><div class="chosen-search"><input type="text" autocomplete="off" placeholder="Filter" /></div><ul class="chosen-results"></ul></div>' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
- The
<b> </b>
was unnecessary, as I've moved the sprite image right onto that parent<div> </div>
. - I've added a placeholder of "Filter" to this input. Watching people use Chosen in Harvest we've seen them skip right over the input. We should probably make this customizable, but maybe in another PR.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The placeholder needs to be configurable through an option, to allow people to translate it (all other texts are configurable)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This change should be applied to the prototype version too
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👍 I'm going to remove the placeholder for now. I think this is a feature/option we should add to Chosen, but I'll keep this PR focused on the design changes.
I took a quick look and think this is a step in the right direction. For now I only wonder why sort properties alphabetical? Because it doesn't define or visualize the relation between them. |
Thanks @koenpunt - I'll add that Why we should alphabetize CSS: The main reason is that this is an order that anyone can understand, read, and contribute to. There is no set "proper" way to write CSS in today's landscape, which means designers/developers all make their own. As you mention, you have a preferred sorting method by category. Another developer using this repo and reading the code might have a different preferred sorting method, using similar categories but a different order of them. And both of you could write your properties in different order per category... like you could keep your When I read the current Chosen code, I feel like I had to read the entire property list on a class to understand how it behaved. It was hard for me to find if this class had a By writing CSS in alphabetical order—especially for an open-source library that will be read by many people—it should help developers reading the CSS find what they are looking for with less hassle. And it keeps property order consistent across the whole file, thus making the library easier to work with. |
I agree that if this goes in, it should be for a 2.0 release. That said, we should definitely release a final 1.x series release before this goes in -- there are a lot of commits on master that haven't been rolled into a release version yet. (See the current draft notes on the releases page). |
@mlettini I'm with @koenpunt regarding the property sorting: with alphabetical order, you still have to read the entire list to understand what it does, because alphabetical order is unrelated to the effect of properties. |
@mlettini I remember you being opposed to use a tool like CSSComb for sensible sorting? My main concern with alphabetical is that properties like |
In comparison: |
Personally, I find that code on the right to be hard to read. While yes, properties that are semi-related to each other are closer to each other, it doesn't promote ease of reading. If I wanted to update the At Harvest, we've been using alphabetical order for all CSS for a few years now, and it's done a good job of keeping our CSS (across all repos and many files) easy to use, easy to maintain, and consistent when many people are in the code. I'm curious how you would feel towards alphabetically ordered CSS properties if you were to try it for a bit. Either way, this conversation gets to the root of the problem: different developers have a different pre-conceived notion of how property order should be set, and bring that notion with them when reading other CSS files. That makes me prefer "ease of reading" over anything else when I know other people will be reading my code, and I have to read their code. (plus, aside from height/width, most related properties are quite near each other in alphabetical order already: background/border, font-stuffs, margin/padding) Now, all that said, I'd be fine with Chosen using CSSComb. Chosen is just one file, and by using a tool to set the property orders, we'd at least still be maintaining consistency across the file. We should, though, ensure this stays the same with all future changes, by making the combing happen automatically. Aside: @tjschuck noted to me that this change will (unfortunately) mess with the CSS file's history, rendering Blame almost unusable. Adding/using CSSComb would do the same. I think this design step forward is still worth that loss. |
About the sprite, do we need 2 of them? Can't we just use the retina version on low dpi screens as well? |
@koenpunt I began working on Chosen with only 1 image, the retina one, but the issue with that is the 2x sprite requires |
Hm yeah good point, then the question is; for how long do we want to support IE8? Because we're probably not going to drop IE8 support because of the sprite. |
Probably a conversation for another time 😄
Agreed. I'll have a new version available soon. There was a small conversation outside of this PR that the single chosen doesn't look clickable / doesn't stand out / doesn't look like a select box (compared to the current Chosen). So I'm toying with the design a bit for a nice middleground. |
…remove left/right padding from chosen-drop
…op style for single chosen
@koenpunt I've improved a few things you see in my latest commits, including difference between disabled and selected in multi (note current Chosen just makes these look the same). I pulled Bootstrap in and Chosen still looks the same, so successfully not allowing any of the design to be over-written. This PR only lands a foundation for theming (with variables and some other improvements), but thats still a goal for a future PR. It probably involves more than just colors, as Chosen should work well with different font-sizing and padding. So in order for this PR to move forward, we need:
Do I have that correct? |
What I meant with my bootstrap comment is –because lots of people use Chosen within a bootstrap styled website– that it would be a pro if it does fit in with the bootstrap style. |
I agree! I think this Chosen design works well with Bootstrap as it is, even if it's not perfectly Bootstrappy (the padding's aren't the same for inputs, single chosen has a gradient while Bootstrap is fairly flat, etc). This design works better than current Chosen. What I was saying is that Chosen could fit in more with Bootstrap, but I think that should be left to a bootstrap-chosen theme (once we work on better theming). This lays the groundwork for that at least. Do you have other design suggestions that could work for default Chosen to help it fit more into the Bootstrap style while also being a good default for anyone? All ears.
A default multi-select is different than multi-chosen. Multi-selects need to highlight what you've selected because otherwise there's no other indication for you to know! Chosen, however, highlights what you've already selected both with the selections at the top, and the checkmark in the dropdown. This dropdown is also only shown when you go to select more options, so during this interaction I think we should not be highlighting what you've already selected more, because that grabs your attention away from what you haven't selected. |
Yes, for the same (but opposite) reason we are just talking about. When you are typing and get down to "nothing found", we want the user to realize this. The background helps it stand out, otherwise it just looks like an option. However, now that I'm looking at it, it makes the "nothing found" look like it's selected. Might re-think that... |
@koenpunt Removed the background-color on |
+1 to @mlettini the normal multiple select has bad ui, so we don't need to copy its behavior if it was good we didn't need chosen( @microsoft ) |
I haven't looked at this in awhile and getting back on it. @koenpunt I simplified the design by removing the gradient and box-shadow I had on there. This makes it look better in the Bootstrap styling, and also allows someone grabbing and using Chosen to more-easily customize it to fit their needs (an effort also started with the variables). It will need a bit more effort for real theming (so we can have an actual Bootstrap theme), but I don't think that will be too difficult later on. I've also made a couple more adjustments, improving disabled support, and removing unnecessary compass includes. The only one left is the box-sizing include, and I suspect that can go away too (but wish to do so in another PR). The next steps for this PR, I believe:
|
It was suggested I mention here that relative units would be better than pixel values. When we incorporated Chosen into our recent project, the controls and text all seemed relatively small, and scaling it up, while not awkward, could have been avoided if Chosen's sizing were based on its container's. The doubling of the PNG certainly helps to alleviate the other problem, which was that I ended up styling the controls to use FontAwesome so it scaled up beyond the native size of the PNG. |
@Altreus I think that's a 👍 idea. Although to not make this specific PR any larger than it is, I suggest that work be done separately after this (eventually) gets merged. I think the best course for Chosen specifically is to use em's throughout, with one pixel-based font-size on the parent element. Using rem's could have unintended consequences depending on the the font-size applied to the HTML element in any project Chosen is added to (could be too big or too small). Using em's gives more flexibility. |
It's been on my list (for quite awhile) to do something with this PR. Obviously it's grown quite old, and I'm closing it, since in Chosen's latest release we announce that we're done with new features until further notice. To preserve the work I did (if anyone's interested), I've forked the repository: https://github.com/mlettini/chosen/releases/tag/v2.0 👏 |
@pfiller @tjschuck @koenpunt
This is a very large and significant design/css change. It most definitely breaks currently open PRs that touch CSS. It's probably the biggest since the last time we updated the design of Chosen.
Background
The design of Chosen is currently quite dated. Single Chosen's gradient (also used on Multi Chosen search-choices) is based off of OS X select boxes, but those have been redesigned as of Mavericks. The design of both Single and Multi are not terribly consistent, which causes extra and unnecessary CSS to accommodate. At the same time, the repo's Sass has been growing cruft. Properties are out of order and inconsistent across the Sass file.
This has been bugging me for quite awhile. When I come across Chosen in the wild, it sticks out like a sore thumb, since it doesn't fit in with the design around it. Or the developer had to override a ton of properties just to have it fit into their app/website. It'd be nice to work Chosen towards a possible "theme-able" future.
Doing something about it was a slightly overwhelming task, considering how much Chosen is used, and how many open PRs would most likely break. We had a hackweek at Harvest last week, and I decided to give it a shot. This might be shot down because of it's size and the number of open PRs, but I do believe it is a positive step forward for Chosen. It could be considered a 2.0 (from a design-only perspective, anyway).
What's Changed
outline
property so Chosen's focus design fits into the standard OS X protocol (we could make this an option, but that requires JS)I will comment directly in the code below pointing out anything helpful. Because of the alphabetizing of properties, I imagine the diff will be a little hard to read. Rather than post a bunch of screenshots, you should pull and look at this version side-by-side with the current version.