#11106 closed enhancement (fixed)
Inputs and Text areas should have the same number of columns on the Report Edit page
Reported by: | Owned by: | Jun Omae | |
---|---|---|---|
Priority: | normal | Milestone: | 1.0.2 |
Component: | report system | Version: | 1.0-stable |
Severity: | normal | Keywords: | |
Cc: | Branch: | ||
Release Notes: |
|
||
API Changes: | |||
Internal Changes: |
Attachments (4)
Change History (26)
by , 12 years ago
Attachment: | ReportEdit.png added |
---|
comment:1 by , 12 years ago
by , 12 years ago
Attachment: | ReportEdit2.png added |
---|
comment:2 by , 12 years ago
Milestone: | → 1.0.2 |
---|---|
Owner: | set to |
Status: | new → assigned |
Looks much better indeed, thanks!
by , 12 years ago
Attachment: | ReportEdit3.png added |
---|
by , 12 years ago
Attachment: | ReportEdit4.png added |
---|
comment:3 by , 12 years ago
This isn't working as well as I had hoped because apparently a certain number of cols
for an input
element is not the same width as the same number of cols
for a textarea
across all browsers.
The patch in 238ca84a makes the following changes:
- Centers the
#content
div
(like on the ticket page). - Sets the width of the
#content
div
to be 645px. This value was chosen because it was the width of thetextarea
in Chromium 25 when the number ofcols
was set to 78. - Sets the width of the
input
andtextarea
elements to be100%
. - Removes the
cols
attribute from theinput
andtextarea
elements.
Now it looks quite a bit better I think!:
comment:4 by , 12 years ago
If this change looks good, then it might make sense to do similarly (i.e. center and limit width) for the Milestone Edit page.
comment:5 by , 12 years ago
There is a problem with my patch. It causes the content of the Available Reports page to also be centered and have a max width of 645px. This can mostly be fixed by changing the selector from #content.report
to its child #edit_report
, however when that is done the h1
is not centered, and there is no way to uniquely select this h1
without adding a class or id to it or an enclosing element.
I can think of several fairly equivalent ways to fix this issue.
- Add an
edit
class to the#content
div
so that we can select the div on the edit page without selecting thediv
on the view page. - Add a
centered
class to the#content
div
, which effectively does the same thing as theedit
class, but we also refactor the ticket page to use this class. - Wrap the
h1
andform#edit_report
in adiv
.
(1) seems like the better solution to me.
comment:6 by , 12 years ago
(1) is fine with me.
The problem with a centered
class is that if people don't like / can't use a centered style, they'll have to create CSS rules for .centered
which will be anything but centered…
comment:7 by , 12 years ago
In 3ef54a8d: Add an edit
class to the enclosing div
on the report edit page and modify the CSS rules for centering the div
on the report edit page so that the report view page isn't also centered. Make the report edit div
to be the same width (58 em) as the ticket edit div
follow-up: 9 comment:8 by , 12 years ago
Looks good! However it has three failures in functional tests. In XHTML, the cols
attribute of textarea
is not optional.
... TwillAssertionError: # Element textarea does not carry attribute cols # URL: http://127.0.0.1:8410/report?action=new # Line 77, column 3 ... ------- Ran 127 tests in 592.780s FAILED (failures=3) make: *** [functional-test] Error 1
comment:9 by , 12 years ago
Replying to jomae:
Looks good! However it has three failures in functional tests.
Thanks, I'll fix those issues and submit a post a new branch with a cleaner commit history.
comment:10 by , 12 years ago
follow-up: 14 comment:11 by , 11 years ago
I no longer feel that these are the right CSS changes to make. It looks like width: 100%
for input
and textarea
isn't effective for making the elements the same width since we need to take into account all of the dimensions of the bounding box.
comment:12 by , 11 years ago
Milestone: | 1.0.2 → next-stable-1.0.x |
---|---|
Owner: | changed from | to
comment:13 by , 11 years ago
Milestone: | next-stable-1.0.x → 1.0.3 |
---|
comment:14 by , 11 years ago
I no longer feel that these are the right CSS changes to make. It looks like
width: 100%
forinput
andtextarea
isn't effective for making the elements the same width since we need to take into account all of the dimensions of the bounding box.
I think that using box-sizing: border-box
would be simple to make the elements the same width. See log:jomae.git:t11106.3.
comment:15 by , 11 years ago
The element width looks good. Tested:
- Windows 7
- IE 11
- Chrome 32
- Firefox 24 (Waterfox)
- Opera 18
- Ubuntu 13.04
- Chromium 31
- Firefox 26
- Opera 12.16
I do think we should consider limiting the width though (similar to the ticket form),
-
trac/htdocs/css/report.css
diff --git a/trac/htdocs/css/report.css b/trac/htdocs/css/report.css index 0e1471b..a75e906 100644
a b h2.report-result { 82 82 #report-descr { margin: 0 2em; font-size: 90% } 83 83 #report-notfound { margin: 2em; font-size: 110% } 84 84 85 #content.report.edit { 86 margin-left: auto; 87 margin-right: auto; 88 max-width: 58em; 89 } 85 90 #content.report input#title, #content.report textarea.trac-resizable { 86 91 -moz-box-sizing: border-box; 87 92 box-sizing: border-box; -
trac/ticket/templates/report_edit.html
diff --git a/trac/ticket/templates/report_edit.html b/trac/ticket/templates/report_edit.html index 3d85e45..87f2cf6 100644
a b 11 11 </head> 12 12 13 13 <body> 14 <div id="content" class="report ">14 <div id="content" class="report edit"> 15 15 16 16 <h1>${_('New Report') if action == 'new' else report.title}</h1> 17 17 <form action="${href.report(report.id)}" method="post" id="edit_report">
comment:16 by , 11 years ago
I don't think the edit form of report needs the narrow width and center-aligned. The view and edit form of ticket have the narrow width and center-aligned, that is consistent. However, the view of report is left aligned. When come and go between the view and edit form, my eyes would be moved between left side and center of the screen.
comment:17 by , 11 years ago
Owner: | changed from | to
---|
comment:18 by , 11 years ago
Since we don't have agreement on the width and alignment and there have been no other inputs, we could:
- Apply the changes to 1.0-stable that keep the form left aligned but don't change the width: log:rjollos.git:t11106.4
- Apply your other changes on the trunk, which would allow time for more user feedback before a major release (i.e. don't apply log:rjollos.git:1b587eace on the trunk).
comment:19 by , 11 years ago
Milestone: | 1.0.3 → 1.0.2 |
---|---|
Release Notes: | modified (diff) |
Resolution: | → fixed |
Status: | assigned → closed |
follow-up: 21 comment:20 by , 10 years ago
It looks like we can simplify the CSS in [12796] a little bit:
-
trac/htdocs/css/report.css
diff --git a/trac/htdocs/css/report.css b/trac/htdocs/css/report.css index 0155f76..8ae4772 100644
a b h2.report-result { 82 82 #report-descr { margin: 0 2em; font-size: 90% } 83 83 #report-notfound { margin: 2em; font-size: 110% } 84 84 85 #content.report input#title, #content.report textarea.trac-resizable {85 #content.report input#title, #content.report .trac-resizable { 86 86 -moz-box-sizing: border-box; 87 87 box-sizing: border-box; 88 }89 #content.report input#title, #content.report div.trac-resizable,90 #content.report textarea.trac-resizable {91 88 width: 100%; 92 89 } 93 90 #content.report.edit form {
This results in box-sizing: border-box
being applied to div.trac-resizable
, but it doesn't change the layout at all as far as I can tell.
comment:21 by , 10 years ago
comment:22 by , 10 years ago
Component: | general → report system |
---|
Simple patch in 114561bf results in the following: