Opened 18 years ago
Closed 17 years ago
#4394 closed (wontfix)
Common fractions in humanize
Reported by: | Owned by: | nobody | |
---|---|---|---|
Component: | Contrib apps | Version: | dev |
Severity: | Keywords: | humanize fractions | |
Cc: | Triage Stage: | Design decision needed | |
Has patch: | yes | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
The "humanize" tags are very useful for making a site friendly, but one thing that is missing are common/vulgar fractions, which are much more human than decimal fractions in many contexts. This patch adds text_fraction (which produces fractions like "1 1/4") and html_fraction (which generates HTML using sup and sub tags to position the numerator and denomenator).
Attachments (3)
Change History (15)
by , 18 years ago
Attachment: | fraction.diff added |
---|
comment:1 by , 18 years ago
Component: | Uncategorized → Contrib apps |
---|---|
Owner: | changed from | to
Triage Stage: | Unreviewed → Ready for checkin |
Hmm.. I like this. Tests, docs and all.
comment:3 by , 18 years ago
Could you please use the actual entities for the common fractions? Screen readers, search engines, etc, benefit from the actual entities. Plus, they look a lot nicer!
1/4, 1/2, 3/4 are covered by ¼ ½ and ¾ respectively, or with their Unicode equiv: http://www.unicode.org/charts/PDF/U0080.pdf
1/3, 2/3, 1/5, 2/5, 3/5, 4/5, 1/6, 5/6, 1/8, 3/8, 5/8 and 7/8 are the vulgar fractions and are covered by Unicode under the "Number Forms" chart: http://www.unicode.org/charts/PDF/U2150.pdf
comment:4 by , 18 years ago
I will change it to use unicode fractions where available. Should I also change it to use U+2044 (FRACTION SLASH) instead of U+002F (SOLIDUS)? I don't have IE, so I can't do serious testing of the generated HTML.
by , 18 years ago
Attachment: | fraction2.diff added |
---|
Fractions for humanize, using Unicode characters where possible
comment:5 by , 18 years ago
Triage Stage: | Ready for checkin → Unreviewed |
---|
fraction2.diff now uses Unicode fractions where these are available. I'm changing this to "Unreviewed" - not sure if that's right, but since the behaviour is somewhat different I thought it was best.
comment:6 by , 18 years ago
Triage Stage: | Unreviewed → Ready for checkin |
---|
comment:7 by , 18 years ago
Triage Stage: | Ready for checkin → Design decision needed |
---|
This is not something that can be moved straight to ready for checkin. There are a large number of assumptions being made here that require some thinking.
One obvious technical question is what is the common font support like in different browsers on different platforms for these particular Unicode codepoints? There's a good argument for including conversions for 1/2, 1/3, 1/4, 3/4, say, since they have good font coverage. Anything beyond that is going to need more supporting evidence to suggest it's a good idea. If we don't have solid coverage in all common fonts, we are basically saying "don't use this, because most of your users won't be able to see some of the results".
I'm also not in favour of the sup/sub changes for other fractions at the moment. It's not particularly semantic.
This requires a design decision and before we can make that (for the first point), cross-browser, cross-platform data is needed.
comment:8 by , 18 years ago
Good points. Browser-wise: the fifths and sixths appear as "<" in IE 6 (on Wine/Ubuntu); it's all good on Firefox (2.0, Ubuntu) and Konqueror (3.5.6, Ubuntu).
Perhaps <sup> and <sub> should be replaced with <span class="numerator"> and <span class="denominator">?
The best solution may be to remove the entities which IE doesn't support, and simply render them the other way.
by , 18 years ago
Attachment: | fraction3.diff added |
---|
only uses unicode fractions which are supported by IE 5, and doesn't use sup and sub
comment:9 by , 18 years ago
Thanks. The sup/sub thing doesn't play well, so thanks for not using it. Screen readers can tend to skip over sup elements (thinking they are footnotes or useless text), and read sub inline. So "Out of the group, <sup>1</sup>/<sub>2</sub> were blond" can get read as "Out of the group, 2 were blond". Whereas "Out of the group, 1/2 were blond" would be read as "Out of the group, 1-slash-2 were blond" (not pretty, but the better than <sup>). Just the common fractions are a huge improvement.
comment:10 by , 18 years ago
What's happening with this ticket? Is the necessary design decision going to be made?
comment:11 by , 18 years ago
If you have a question of that nature, please post to the django-developers list about it; design discussions usually take place there rather than in Trac because it's much easier to keep track of them via email.
comment:12 by , 17 years ago
Resolution: | → wontfix |
---|---|
Status: | new → closed |
This feels a bit too special-purpose for addition to Django, and since no other core devs have weighed in I'm going to assume that this is better put into a third-party app.
Adds fractions to humanize