##// END OF EJS Templates
Makes zoom buttons on gantt looks like the others....
Jean-Philippe Lang -
r4169:a29c35e08f23
parent child
Show More
@@ -1,51 +1,49
1 # redMine - project management software
1 # redMine - project management software
2 # Copyright (C) 2006 Jean-Philippe Lang
2 # Copyright (C) 2006 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 module GanttHelper
18 module GanttHelper
19
19
20 def gantt_zoom_link(gantt, in_or_out)
20 def gantt_zoom_link(gantt, in_or_out)
21 img_attributes = {:style => 'height:1.4em; width:1.4em; margin-left: 3px;'} # em for accessibility
22
23 case in_or_out
21 case in_or_out
24 when :in
22 when :in
25 if gantt.zoom < 4
23 if gantt.zoom < 4
26 link_to_remote(l(:text_zoom_in) + image_tag('zoom_in.png', img_attributes.merge(:alt => l(:text_zoom_in))),
24 link_to_remote(l(:text_zoom_in),
27 {:url => gantt.params.merge(:zoom => (gantt.zoom+1)), :method => :get, :update => 'content'},
25 {:url => gantt.params.merge(:zoom => (gantt.zoom+1)), :method => :get, :update => 'content'},
28 {:href => url_for(gantt.params.merge(:zoom => (gantt.zoom+1)))})
26 {:href => url_for(gantt.params.merge(:zoom => (gantt.zoom+1))),
27 :class => 'icon icon-zoom-in'})
29 else
28 else
30 l(:text_zoom_in) +
29 content_tag('span', l(:text_zoom_in), :class => 'icon icon-zoom-in')
31 image_tag('zoom_in_g.png', img_attributes.merge(:alt => l(:text_zoom_in)))
32 end
30 end
33
31
34 when :out
32 when :out
35 if gantt.zoom > 1
33 if gantt.zoom > 1
36 link_to_remote(l(:text_zoom_out) + image_tag('zoom_out.png', img_attributes.merge(:alt => l(:text_zoom_out))),
34 link_to_remote(l(:text_zoom_out),
37 {:url => gantt.params.merge(:zoom => (gantt.zoom-1)), :method => :get, :update => 'content'},
35 {:url => gantt.params.merge(:zoom => (gantt.zoom-1)), :method => :get, :update => 'content'},
38 {:href => url_for(gantt.params.merge(:zoom => (gantt.zoom-1)))})
36 {:href => url_for(gantt.params.merge(:zoom => (gantt.zoom-1))),
37 :class => 'icon icon-zoom-out'})
39 else
38 else
40 l(:text_zoom_out) +
39 content_tag('span', l(:text_zoom_out), :class => 'icon icon-zoom-out')
41 image_tag('zoom_out_g.png', img_attributes.merge(:alt => l(:text_zoom_out)))
42 end
40 end
43 end
41 end
44 end
42 end
45
43
46 def number_of_issues_on_versions(gantt)
44 def number_of_issues_on_versions(gantt)
47 versions = gantt.events.collect {|event| (event.is_a? Version) ? event : nil}.compact
45 versions = gantt.events.collect {|event| (event.is_a? Version) ? event : nil}.compact
48
46
49 versions.sum {|v| v.fixed_issues.for_gantt.with_query(@query).count}
47 versions.sum {|v| v.fixed_issues.for_gantt.with_query(@query).count}
50 end
48 end
51 end
49 end
@@ -1,188 +1,188
1 <% @gantt.view = self %>
1 <% @gantt.view = self %>
2 <h2><%= l(:label_gantt) %></h2>
2 <h2><%= l(:label_gantt) %></h2>
3
3
4 <% form_tag(gantt_path(:month => params[:month], :year => params[:year], :months => params[:months]), :method => :put, :id => 'query_form') do %>
4 <% form_tag(gantt_path(:month => params[:month], :year => params[:year], :months => params[:months]), :method => :put, :id => 'query_form') do %>
5 <%= hidden_field_tag('project_id', @project.to_param) if @project%>
5 <%= hidden_field_tag('project_id', @project.to_param) if @project%>
6 <fieldset id="filters" class="collapsible">
6 <fieldset id="filters" class="collapsible">
7 <legend onclick="toggleFieldset(this);"><%= l(:label_filter_plural) %></legend>
7 <legend onclick="toggleFieldset(this);"><%= l(:label_filter_plural) %></legend>
8 <div>
8 <div>
9 <%= render :partial => 'queries/filters', :locals => {:query => @query} %>
9 <%= render :partial => 'queries/filters', :locals => {:query => @query} %>
10 </div>
10 </div>
11 </fieldset>
11 </fieldset>
12
12
13 <p style="float:right;">
13 <p class="contextual">
14 <%= gantt_zoom_link(@gantt, :in) %>
14 <%= gantt_zoom_link(@gantt, :in) %>
15 <%= gantt_zoom_link(@gantt, :out) %>
15 <%= gantt_zoom_link(@gantt, :out) %>
16 </p>
16 </p>
17
17
18 <p class="buttons">
18 <p class="buttons">
19 <%= text_field_tag 'months', @gantt.months, :size => 2 %>
19 <%= text_field_tag 'months', @gantt.months, :size => 2 %>
20 <%= l(:label_months_from) %>
20 <%= l(:label_months_from) %>
21 <%= select_month(@gantt.month_from, :prefix => "month", :discard_type => true) %>
21 <%= select_month(@gantt.month_from, :prefix => "month", :discard_type => true) %>
22 <%= select_year(@gantt.year_from, :prefix => "year", :discard_type => true) %>
22 <%= select_year(@gantt.year_from, :prefix => "year", :discard_type => true) %>
23 <%= hidden_field_tag 'zoom', @gantt.zoom %>
23 <%= hidden_field_tag 'zoom', @gantt.zoom %>
24
24
25 <%= link_to_remote l(:button_apply),
25 <%= link_to_remote l(:button_apply),
26 { :url => { :set_filter => (@query.new_record? ? 1 : nil) },
26 { :url => { :set_filter => (@query.new_record? ? 1 : nil) },
27 :update => "content",
27 :update => "content",
28 :with => "Form.serialize('query_form')"
28 :with => "Form.serialize('query_form')"
29 }, :class => 'icon icon-checked' %>
29 }, :class => 'icon icon-checked' %>
30
30
31 <%= link_to_remote l(:button_clear),
31 <%= link_to_remote l(:button_clear),
32 { :url => { :project_id => @project, :set_filter => (@query.new_record? ? 1 : nil) },
32 { :url => { :project_id => @project, :set_filter => (@query.new_record? ? 1 : nil) },
33 :method => :put,
33 :method => :put,
34 :update => "content",
34 :update => "content",
35 }, :class => 'icon icon-reload' if @query.new_record? %>
35 }, :class => 'icon icon-reload' if @query.new_record? %>
36 </p>
36 </p>
37 <% end %>
37 <% end %>
38
38
39 <%= error_messages_for 'query' %>
39 <%= error_messages_for 'query' %>
40 <% if @query.valid? %>
40 <% if @query.valid? %>
41 <% zoom = 1
41 <% zoom = 1
42 @gantt.zoom.times { zoom = zoom * 2 }
42 @gantt.zoom.times { zoom = zoom * 2 }
43
43
44 subject_width = 330
44 subject_width = 330
45 header_heigth = 18
45 header_heigth = 18
46
46
47 headers_height = header_heigth
47 headers_height = header_heigth
48 show_weeks = false
48 show_weeks = false
49 show_days = false
49 show_days = false
50
50
51 if @gantt.zoom >1
51 if @gantt.zoom >1
52 show_weeks = true
52 show_weeks = true
53 headers_height = 2*header_heigth
53 headers_height = 2*header_heigth
54 if @gantt.zoom > 2
54 if @gantt.zoom > 2
55 show_days = true
55 show_days = true
56 headers_height = 3*header_heigth
56 headers_height = 3*header_heigth
57 end
57 end
58 end
58 end
59
59
60 # Width of the entire chart
60 # Width of the entire chart
61 g_width = (@gantt.date_to - @gantt.date_from + 1)*zoom
61 g_width = (@gantt.date_to - @gantt.date_from + 1)*zoom
62 # Collect the number of issues on Versions
62 # Collect the number of issues on Versions
63 g_height = [(20 * (@gantt.number_of_rows + 6))+150, 206].max
63 g_height = [(20 * (@gantt.number_of_rows + 6))+150, 206].max
64 t_height = g_height + headers_height
64 t_height = g_height + headers_height
65 %>
65 %>
66 <table width="100%" style="border:0; border-collapse: collapse;">
66 <table width="100%" style="border:0; border-collapse: collapse;">
67 <tr>
67 <tr>
68 <td style="width:<%= subject_width %>px; padding:0px;">
68 <td style="width:<%= subject_width %>px; padding:0px;">
69
69
70 <div style="position:relative;height:<%= t_height + 24 %>px;width:<%= subject_width + 1 %>px;">
70 <div style="position:relative;height:<%= t_height + 24 %>px;width:<%= subject_width + 1 %>px;">
71 <div style="right:-2px;width:<%= subject_width %>px;height:<%= headers_height %>px;background: #eee;" class="gantt_hdr"></div>
71 <div style="right:-2px;width:<%= subject_width %>px;height:<%= headers_height %>px;background: #eee;" class="gantt_hdr"></div>
72 <div style="right:-2px;width:<%= subject_width %>px;height:<%= t_height %>px;border-left: 1px solid #c0c0c0;overflow:hidden;" class="gantt_hdr"></div>
72 <div style="right:-2px;width:<%= subject_width %>px;height:<%= t_height %>px;border-left: 1px solid #c0c0c0;overflow:hidden;" class="gantt_hdr"></div>
73 <% top = headers_height + 8 %>
73 <% top = headers_height + 8 %>
74
74
75 <%= @gantt.subjects(:headers_height => headers_height, :top => top, :g_width => g_width) %>
75 <%= @gantt.subjects(:headers_height => headers_height, :top => top, :g_width => g_width) %>
76
76
77 </div>
77 </div>
78 </td>
78 </td>
79 <td>
79 <td>
80
80
81 <div style="position:relative;height:<%= t_height + 24 %>px;overflow:auto;">
81 <div style="position:relative;height:<%= t_height + 24 %>px;overflow:auto;">
82 <div style="width:<%= g_width-1 %>px;height:<%= headers_height %>px;background: #eee;" class="gantt_hdr">&nbsp;</div>
82 <div style="width:<%= g_width-1 %>px;height:<%= headers_height %>px;background: #eee;" class="gantt_hdr">&nbsp;</div>
83 <%
83 <%
84 #
84 #
85 # Months headers
85 # Months headers
86 #
86 #
87 month_f = @gantt.date_from
87 month_f = @gantt.date_from
88 left = 0
88 left = 0
89 height = (show_weeks ? header_heigth : header_heigth + g_height)
89 height = (show_weeks ? header_heigth : header_heigth + g_height)
90 @gantt.months.times do
90 @gantt.months.times do
91 width = ((month_f >> 1) - month_f) * zoom - 1
91 width = ((month_f >> 1) - month_f) * zoom - 1
92 %>
92 %>
93 <div style="left:<%= left %>px;width:<%= width %>px;height:<%= height %>px;" class="gantt_hdr">
93 <div style="left:<%= left %>px;width:<%= width %>px;height:<%= height %>px;" class="gantt_hdr">
94 <%= link_to "#{month_f.year}-#{month_f.month}", @gantt.params.merge(:year => month_f.year, :month => month_f.month), :title => "#{month_name(month_f.month)} #{month_f.year}"%>
94 <%= link_to "#{month_f.year}-#{month_f.month}", @gantt.params.merge(:year => month_f.year, :month => month_f.month), :title => "#{month_name(month_f.month)} #{month_f.year}"%>
95 </div>
95 </div>
96 <%
96 <%
97 left = left + width + 1
97 left = left + width + 1
98 month_f = month_f >> 1
98 month_f = month_f >> 1
99 end %>
99 end %>
100
100
101 <%
101 <%
102 #
102 #
103 # Weeks headers
103 # Weeks headers
104 #
104 #
105 if show_weeks
105 if show_weeks
106 left = 0
106 left = 0
107 height = (show_days ? header_heigth-1 : header_heigth-1 + g_height)
107 height = (show_days ? header_heigth-1 : header_heigth-1 + g_height)
108 if @gantt.date_from.cwday == 1
108 if @gantt.date_from.cwday == 1
109 # @date_from is monday
109 # @date_from is monday
110 week_f = @gantt.date_from
110 week_f = @gantt.date_from
111 else
111 else
112 # find next monday after @date_from
112 # find next monday after @date_from
113 week_f = @gantt.date_from + (7 - @gantt.date_from.cwday + 1)
113 week_f = @gantt.date_from + (7 - @gantt.date_from.cwday + 1)
114 width = (7 - @gantt.date_from.cwday + 1) * zoom-1
114 width = (7 - @gantt.date_from.cwday + 1) * zoom-1
115 %>
115 %>
116 <div style="left:<%= left %>px;top:19px;width:<%= width %>px;height:<%= height %>px;" class="gantt_hdr">&nbsp;</div>
116 <div style="left:<%= left %>px;top:19px;width:<%= width %>px;height:<%= height %>px;" class="gantt_hdr">&nbsp;</div>
117 <%
117 <%
118 left = left + width+1
118 left = left + width+1
119 end %>
119 end %>
120 <%
120 <%
121 while week_f <= @gantt.date_to
121 while week_f <= @gantt.date_to
122 width = (week_f + 6 <= @gantt.date_to) ? 7 * zoom -1 : (@gantt.date_to - week_f + 1) * zoom-1
122 width = (week_f + 6 <= @gantt.date_to) ? 7 * zoom -1 : (@gantt.date_to - week_f + 1) * zoom-1
123 %>
123 %>
124 <div style="left:<%= left %>px;top:19px;width:<%= width %>px;height:<%= height %>px;" class="gantt_hdr">
124 <div style="left:<%= left %>px;top:19px;width:<%= width %>px;height:<%= height %>px;" class="gantt_hdr">
125 <small><%= week_f.cweek if width >= 16 %></small>
125 <small><%= week_f.cweek if width >= 16 %></small>
126 </div>
126 </div>
127 <%
127 <%
128 left = left + width+1
128 left = left + width+1
129 week_f = week_f+7
129 week_f = week_f+7
130 end
130 end
131 end %>
131 end %>
132
132
133 <%
133 <%
134 #
134 #
135 # Days headers
135 # Days headers
136 #
136 #
137 if show_days
137 if show_days
138 left = 0
138 left = 0
139 height = g_height + header_heigth - 1
139 height = g_height + header_heigth - 1
140 wday = @gantt.date_from.cwday
140 wday = @gantt.date_from.cwday
141 (@gantt.date_to - @gantt.date_from + 1).to_i.times do
141 (@gantt.date_to - @gantt.date_from + 1).to_i.times do
142 width = zoom - 1
142 width = zoom - 1
143 %>
143 %>
144 <div style="left:<%= left %>px;top:37px;width:<%= width %>px;height:<%= height %>px;font-size:0.7em;<%= "background:#f1f1f1;" if wday > 5 %>" class="gantt_hdr">
144 <div style="left:<%= left %>px;top:37px;width:<%= width %>px;height:<%= height %>px;font-size:0.7em;<%= "background:#f1f1f1;" if wday > 5 %>" class="gantt_hdr">
145 <%= day_name(wday).first %>
145 <%= day_name(wday).first %>
146 </div>
146 </div>
147 <%
147 <%
148 left = left + width+1
148 left = left + width+1
149 wday = wday + 1
149 wday = wday + 1
150 wday = 1 if wday > 7
150 wday = 1 if wday > 7
151 end
151 end
152 end %>
152 end %>
153
153
154 <% top = headers_height + 10 %>
154 <% top = headers_height + 10 %>
155
155
156 <%= @gantt.lines(:top => top, :zoom => zoom, :g_width => g_width ) %>
156 <%= @gantt.lines(:top => top, :zoom => zoom, :g_width => g_width ) %>
157
157
158 <%
158 <%
159 #
159 #
160 # Today red line (excluded from cache)
160 # Today red line (excluded from cache)
161 #
161 #
162 if Date.today >= @gantt.date_from and Date.today <= @gantt.date_to %>
162 if Date.today >= @gantt.date_from and Date.today <= @gantt.date_to %>
163 <div style="position: absolute;height:<%= g_height %>px;top:<%= headers_height + 1 %>px;left:<%= ((Date.today-@gantt.date_from+1)*zoom).floor()-1 %>px;width:10px;border-left: 1px dashed red;">&nbsp;</div>
163 <div style="position: absolute;height:<%= g_height %>px;top:<%= headers_height + 1 %>px;left:<%= ((Date.today-@gantt.date_from+1)*zoom).floor()-1 %>px;width:10px;border-left: 1px dashed red;">&nbsp;</div>
164 <% end %>
164 <% end %>
165
165
166 </div>
166 </div>
167 </td>
167 </td>
168 </tr>
168 </tr>
169 </table>
169 </table>
170
170
171 <table width="100%">
171 <table width="100%">
172 <tr>
172 <tr>
173 <td align="left"><%= link_to_remote ('&#171; ' + l(:label_previous)), {:url => @gantt.params_previous, :method => :get, :update => 'content', :complete => 'window.scrollTo(0,0)'}, {:href => url_for(@gantt.params_previous)} %></td>
173 <td align="left"><%= link_to_remote ('&#171; ' + l(:label_previous)), {:url => @gantt.params_previous, :method => :get, :update => 'content', :complete => 'window.scrollTo(0,0)'}, {:href => url_for(@gantt.params_previous)} %></td>
174 <td align="right"><%= link_to_remote (l(:label_next) + ' &#187;'), {:url => @gantt.params_next, :method => :get, :update => 'content', :complete => 'window.scrollTo(0,0)'}, {:href => url_for(@gantt.params_next)} %></td>
174 <td align="right"><%= link_to_remote (l(:label_next) + ' &#187;'), {:url => @gantt.params_next, :method => :get, :update => 'content', :complete => 'window.scrollTo(0,0)'}, {:href => url_for(@gantt.params_next)} %></td>
175 </tr>
175 </tr>
176 </table>
176 </table>
177
177
178 <% other_formats_links do |f| %>
178 <% other_formats_links do |f| %>
179 <%= f.link_to 'PDF', :url => @gantt.params %>
179 <%= f.link_to 'PDF', :url => @gantt.params %>
180 <%= f.link_to('PNG', :url => @gantt.params) if @gantt.respond_to?('to_image') %>
180 <%= f.link_to('PNG', :url => @gantt.params) if @gantt.respond_to?('to_image') %>
181 <% end %>
181 <% end %>
182 <% end # query.valid? %>
182 <% end # query.valid? %>
183
183
184 <% content_for :sidebar do %>
184 <% content_for :sidebar do %>
185 <%= render :partial => 'issues/sidebar' %>
185 <%= render :partial => 'issues/sidebar' %>
186 <% end %>
186 <% end %>
187
187
188 <% html_title(l(:label_gantt)) -%>
188 <% html_title(l(:label_gantt)) -%>
@@ -1,941 +1,943
1 body { font-family: Verdana, sans-serif; font-size: 12px; color:#484848; margin: 0; padding: 0; min-width: 900px; }
1 body { font-family: Verdana, sans-serif; font-size: 12px; color:#484848; margin: 0; padding: 0; min-width: 900px; }
2
2
3 h1, h2, h3, h4 { font-family: "Trebuchet MS", Verdana, sans-serif;}
3 h1, h2, h3, h4 { font-family: "Trebuchet MS", Verdana, sans-serif;}
4 h1 {margin:0; padding:0; font-size: 24px;}
4 h1 {margin:0; padding:0; font-size: 24px;}
5 h2, .wiki h1 {font-size: 20px;padding: 2px 10px 1px 0px;margin: 0 0 10px 0; border-bottom: 1px solid #bbbbbb; color: #444;}
5 h2, .wiki h1 {font-size: 20px;padding: 2px 10px 1px 0px;margin: 0 0 10px 0; border-bottom: 1px solid #bbbbbb; color: #444;}
6 h3, .wiki h2 {font-size: 16px;padding: 2px 10px 1px 0px;margin: 0 0 10px 0; border-bottom: 1px solid #bbbbbb; color: #444;}
6 h3, .wiki h2 {font-size: 16px;padding: 2px 10px 1px 0px;margin: 0 0 10px 0; border-bottom: 1px solid #bbbbbb; color: #444;}
7 h4, .wiki h3 {font-size: 13px;padding: 2px 10px 1px 0px;margin-bottom: 5px; border-bottom: 1px dotted #bbbbbb; color: #444;}
7 h4, .wiki h3 {font-size: 13px;padding: 2px 10px 1px 0px;margin-bottom: 5px; border-bottom: 1px dotted #bbbbbb; color: #444;}
8
8
9 /***** Layout *****/
9 /***** Layout *****/
10 #wrapper {background: white;}
10 #wrapper {background: white;}
11
11
12 #top-menu {background: #2C4056; color: #fff; height:1.8em; font-size: 0.8em; padding: 2px 2px 0px 6px;}
12 #top-menu {background: #2C4056; color: #fff; height:1.8em; font-size: 0.8em; padding: 2px 2px 0px 6px;}
13 #top-menu ul {margin: 0; padding: 0;}
13 #top-menu ul {margin: 0; padding: 0;}
14 #top-menu li {
14 #top-menu li {
15 float:left;
15 float:left;
16 list-style-type:none;
16 list-style-type:none;
17 margin: 0px 0px 0px 0px;
17 margin: 0px 0px 0px 0px;
18 padding: 0px 0px 0px 0px;
18 padding: 0px 0px 0px 0px;
19 white-space:nowrap;
19 white-space:nowrap;
20 }
20 }
21 #top-menu a {color: #fff; margin-right: 8px; font-weight: bold;}
21 #top-menu a {color: #fff; margin-right: 8px; font-weight: bold;}
22 #top-menu #loggedas { float: right; margin-right: 0.5em; color: #fff; }
22 #top-menu #loggedas { float: right; margin-right: 0.5em; color: #fff; }
23
23
24 #account {float:right;}
24 #account {float:right;}
25
25
26 #header {height:5.3em;margin:0;background-color:#507AAA;color:#f8f8f8; padding: 4px 8px 0px 6px; position:relative;}
26 #header {height:5.3em;margin:0;background-color:#507AAA;color:#f8f8f8; padding: 4px 8px 0px 6px; position:relative;}
27 #header a {color:#f8f8f8;}
27 #header a {color:#f8f8f8;}
28 #header h1 a.ancestor { font-size: 80%; }
28 #header h1 a.ancestor { font-size: 80%; }
29 #quick-search {float:right;}
29 #quick-search {float:right;}
30
30
31 #main-menu {position: absolute; bottom: 0px; left:6px; margin-right: -500px;}
31 #main-menu {position: absolute; bottom: 0px; left:6px; margin-right: -500px;}
32 #main-menu ul {margin: 0; padding: 0;}
32 #main-menu ul {margin: 0; padding: 0;}
33 #main-menu li {
33 #main-menu li {
34 float:left;
34 float:left;
35 list-style-type:none;
35 list-style-type:none;
36 margin: 0px 2px 0px 0px;
36 margin: 0px 2px 0px 0px;
37 padding: 0px 0px 0px 0px;
37 padding: 0px 0px 0px 0px;
38 white-space:nowrap;
38 white-space:nowrap;
39 }
39 }
40 #main-menu li a {
40 #main-menu li a {
41 display: block;
41 display: block;
42 color: #fff;
42 color: #fff;
43 text-decoration: none;
43 text-decoration: none;
44 font-weight: bold;
44 font-weight: bold;
45 margin: 0;
45 margin: 0;
46 padding: 4px 10px 4px 10px;
46 padding: 4px 10px 4px 10px;
47 }
47 }
48 #main-menu li a:hover {background:#759FCF; color:#fff;}
48 #main-menu li a:hover {background:#759FCF; color:#fff;}
49 #main-menu li a.selected, #main-menu li a.selected:hover {background:#fff; color:#555;}
49 #main-menu li a.selected, #main-menu li a.selected:hover {background:#fff; color:#555;}
50
50
51 #admin-menu ul {margin: 0; padding: 0;}
51 #admin-menu ul {margin: 0; padding: 0;}
52 #admin-menu li {margin: 0; padding: 0 0 12px 0; list-style-type:none;}
52 #admin-menu li {margin: 0; padding: 0 0 12px 0; list-style-type:none;}
53
53
54 #admin-menu a { background-position: 0% 40%; background-repeat: no-repeat; padding-left: 20px; padding-top: 2px; padding-bottom: 3px;}
54 #admin-menu a { background-position: 0% 40%; background-repeat: no-repeat; padding-left: 20px; padding-top: 2px; padding-bottom: 3px;}
55 #admin-menu a.projects { background-image: url(../images/projects.png); }
55 #admin-menu a.projects { background-image: url(../images/projects.png); }
56 #admin-menu a.users { background-image: url(../images/user.png); }
56 #admin-menu a.users { background-image: url(../images/user.png); }
57 #admin-menu a.groups { background-image: url(../images/group.png); }
57 #admin-menu a.groups { background-image: url(../images/group.png); }
58 #admin-menu a.roles { background-image: url(../images/database_key.png); }
58 #admin-menu a.roles { background-image: url(../images/database_key.png); }
59 #admin-menu a.trackers { background-image: url(../images/ticket.png); }
59 #admin-menu a.trackers { background-image: url(../images/ticket.png); }
60 #admin-menu a.issue_statuses { background-image: url(../images/ticket_edit.png); }
60 #admin-menu a.issue_statuses { background-image: url(../images/ticket_edit.png); }
61 #admin-menu a.workflows { background-image: url(../images/ticket_go.png); }
61 #admin-menu a.workflows { background-image: url(../images/ticket_go.png); }
62 #admin-menu a.custom_fields { background-image: url(../images/textfield.png); }
62 #admin-menu a.custom_fields { background-image: url(../images/textfield.png); }
63 #admin-menu a.enumerations { background-image: url(../images/text_list_bullets.png); }
63 #admin-menu a.enumerations { background-image: url(../images/text_list_bullets.png); }
64 #admin-menu a.settings { background-image: url(../images/changeset.png); }
64 #admin-menu a.settings { background-image: url(../images/changeset.png); }
65 #admin-menu a.plugins { background-image: url(../images/plugin.png); }
65 #admin-menu a.plugins { background-image: url(../images/plugin.png); }
66 #admin-menu a.info { background-image: url(../images/help.png); }
66 #admin-menu a.info { background-image: url(../images/help.png); }
67 #admin-menu a.server_authentication { background-image: url(../images/server_key.png); }
67 #admin-menu a.server_authentication { background-image: url(../images/server_key.png); }
68
68
69 #main {background-color:#EEEEEE;}
69 #main {background-color:#EEEEEE;}
70
70
71 #sidebar{ float: right; width: 22%; position: relative; z-index: 9; padding: 0; margin: 0;}
71 #sidebar{ float: right; width: 22%; position: relative; z-index: 9; padding: 0; margin: 0;}
72 * html #sidebar{ width: 22%; }
72 * html #sidebar{ width: 22%; }
73 #sidebar h3{ font-size: 14px; margin-top:14px; color: #666; }
73 #sidebar h3{ font-size: 14px; margin-top:14px; color: #666; }
74 #sidebar hr{ width: 100%; margin: 0 auto; height: 1px; background: #ccc; border: 0; }
74 #sidebar hr{ width: 100%; margin: 0 auto; height: 1px; background: #ccc; border: 0; }
75 * html #sidebar hr{ width: 95%; position: relative; left: -6px; color: #ccc; }
75 * html #sidebar hr{ width: 95%; position: relative; left: -6px; color: #ccc; }
76 #sidebar .contextual { margin-right: 1em; }
76 #sidebar .contextual { margin-right: 1em; }
77
77
78 #content { width: 75%; background-color: #fff; margin: 0px; border-right: 1px solid #ddd; padding: 6px 10px 10px 10px; z-index: 10; }
78 #content { width: 75%; background-color: #fff; margin: 0px; border-right: 1px solid #ddd; padding: 6px 10px 10px 10px; z-index: 10; }
79 * html #content{ width: 75%; padding-left: 0; margin-top: 0px; padding: 6px 10px 10px 10px;}
79 * html #content{ width: 75%; padding-left: 0; margin-top: 0px; padding: 6px 10px 10px 10px;}
80 html>body #content { min-height: 600px; }
80 html>body #content { min-height: 600px; }
81 * html body #content { height: 600px; } /* IE */
81 * html body #content { height: 600px; } /* IE */
82
82
83 #main.nosidebar #sidebar{ display: none; }
83 #main.nosidebar #sidebar{ display: none; }
84 #main.nosidebar #content{ width: auto; border-right: 0; }
84 #main.nosidebar #content{ width: auto; border-right: 0; }
85
85
86 #footer {clear: both; border-top: 1px solid #bbb; font-size: 0.9em; color: #aaa; padding: 5px; text-align:center; background:#fff;}
86 #footer {clear: both; border-top: 1px solid #bbb; font-size: 0.9em; color: #aaa; padding: 5px; text-align:center; background:#fff;}
87
87
88 #login-form table {margin-top:5em; padding:1em; margin-left: auto; margin-right: auto; border: 2px solid #FDBF3B; background-color:#FFEBC1; }
88 #login-form table {margin-top:5em; padding:1em; margin-left: auto; margin-right: auto; border: 2px solid #FDBF3B; background-color:#FFEBC1; }
89 #login-form table td {padding: 6px;}
89 #login-form table td {padding: 6px;}
90 #login-form label {font-weight: bold;}
90 #login-form label {font-weight: bold;}
91 #login-form input#username, #login-form input#password { width: 300px; }
91 #login-form input#username, #login-form input#password { width: 300px; }
92
92
93 input#openid_url { background: url(../images/openid-bg.gif) no-repeat; background-color: #fff; background-position: 0 50%; padding-left: 18px; }
93 input#openid_url { background: url(../images/openid-bg.gif) no-repeat; background-color: #fff; background-position: 0 50%; padding-left: 18px; }
94
94
95 .clear:after{ content: "."; display: block; height: 0; clear: both; visibility: hidden; }
95 .clear:after{ content: "."; display: block; height: 0; clear: both; visibility: hidden; }
96
96
97 /***** Links *****/
97 /***** Links *****/
98 a, a:link, a:visited{ color: #2A5685; text-decoration: none; }
98 a, a:link, a:visited{ color: #2A5685; text-decoration: none; }
99 a:hover, a:active{ color: #c61a1a; text-decoration: underline;}
99 a:hover, a:active{ color: #c61a1a; text-decoration: underline;}
100 a img{ border: 0; }
100 a img{ border: 0; }
101
101
102 a.issue.closed, a.issue.closed:link, a.issue.closed:visited { color: #999; text-decoration: line-through; }
102 a.issue.closed, a.issue.closed:link, a.issue.closed:visited { color: #999; text-decoration: line-through; }
103
103
104 /***** Tables *****/
104 /***** Tables *****/
105 table.list { border: 1px solid #e4e4e4; border-collapse: collapse; width: 100%; margin-bottom: 4px; }
105 table.list { border: 1px solid #e4e4e4; border-collapse: collapse; width: 100%; margin-bottom: 4px; }
106 table.list th { background-color:#EEEEEE; padding: 4px; white-space:nowrap; }
106 table.list th { background-color:#EEEEEE; padding: 4px; white-space:nowrap; }
107 table.list td { vertical-align: top; }
107 table.list td { vertical-align: top; }
108 table.list td.id { width: 2%; text-align: center;}
108 table.list td.id { width: 2%; text-align: center;}
109 table.list td.checkbox { width: 15px; padding: 0px;}
109 table.list td.checkbox { width: 15px; padding: 0px;}
110 table.list td.buttons { width: 15%; white-space:nowrap; text-align: right; }
110 table.list td.buttons { width: 15%; white-space:nowrap; text-align: right; }
111 table.list td.buttons a { padding-right: 0.6em; }
111 table.list td.buttons a { padding-right: 0.6em; }
112 table.list caption { text-align: left; padding: 0.5em 0.5em 0.5em 0; }
112 table.list caption { text-align: left; padding: 0.5em 0.5em 0.5em 0; }
113
113
114 tr.project td.name a { white-space:nowrap; }
114 tr.project td.name a { white-space:nowrap; }
115
115
116 tr.project.idnt td.name span {background: url(../images/bullet_arrow_right.png) no-repeat 0 50%; padding-left: 16px;}
116 tr.project.idnt td.name span {background: url(../images/bullet_arrow_right.png) no-repeat 0 50%; padding-left: 16px;}
117 tr.project.idnt-1 td.name {padding-left: 0.5em;}
117 tr.project.idnt-1 td.name {padding-left: 0.5em;}
118 tr.project.idnt-2 td.name {padding-left: 2em;}
118 tr.project.idnt-2 td.name {padding-left: 2em;}
119 tr.project.idnt-3 td.name {padding-left: 3.5em;}
119 tr.project.idnt-3 td.name {padding-left: 3.5em;}
120 tr.project.idnt-4 td.name {padding-left: 5em;}
120 tr.project.idnt-4 td.name {padding-left: 5em;}
121 tr.project.idnt-5 td.name {padding-left: 6.5em;}
121 tr.project.idnt-5 td.name {padding-left: 6.5em;}
122 tr.project.idnt-6 td.name {padding-left: 8em;}
122 tr.project.idnt-6 td.name {padding-left: 8em;}
123 tr.project.idnt-7 td.name {padding-left: 9.5em;}
123 tr.project.idnt-7 td.name {padding-left: 9.5em;}
124 tr.project.idnt-8 td.name {padding-left: 11em;}
124 tr.project.idnt-8 td.name {padding-left: 11em;}
125 tr.project.idnt-9 td.name {padding-left: 12.5em;}
125 tr.project.idnt-9 td.name {padding-left: 12.5em;}
126
126
127 tr.issue { text-align: center; white-space: nowrap; }
127 tr.issue { text-align: center; white-space: nowrap; }
128 tr.issue td.subject, tr.issue td.category, td.assigned_to { white-space: normal; }
128 tr.issue td.subject, tr.issue td.category, td.assigned_to { white-space: normal; }
129 tr.issue td.subject { text-align: left; }
129 tr.issue td.subject { text-align: left; }
130 tr.issue td.done_ratio table.progress { margin-left:auto; margin-right: auto;}
130 tr.issue td.done_ratio table.progress { margin-left:auto; margin-right: auto;}
131
131
132 tr.issue.idnt td.subject a {background: url(../images/bullet_arrow_right.png) no-repeat 0 50%; padding-left: 16px;}
132 tr.issue.idnt td.subject a {background: url(../images/bullet_arrow_right.png) no-repeat 0 50%; padding-left: 16px;}
133 tr.issue.idnt-1 td.subject {padding-left: 0.5em;}
133 tr.issue.idnt-1 td.subject {padding-left: 0.5em;}
134 tr.issue.idnt-2 td.subject {padding-left: 2em;}
134 tr.issue.idnt-2 td.subject {padding-left: 2em;}
135 tr.issue.idnt-3 td.subject {padding-left: 3.5em;}
135 tr.issue.idnt-3 td.subject {padding-left: 3.5em;}
136 tr.issue.idnt-4 td.subject {padding-left: 5em;}
136 tr.issue.idnt-4 td.subject {padding-left: 5em;}
137 tr.issue.idnt-5 td.subject {padding-left: 6.5em;}
137 tr.issue.idnt-5 td.subject {padding-left: 6.5em;}
138 tr.issue.idnt-6 td.subject {padding-left: 8em;}
138 tr.issue.idnt-6 td.subject {padding-left: 8em;}
139 tr.issue.idnt-7 td.subject {padding-left: 9.5em;}
139 tr.issue.idnt-7 td.subject {padding-left: 9.5em;}
140 tr.issue.idnt-8 td.subject {padding-left: 11em;}
140 tr.issue.idnt-8 td.subject {padding-left: 11em;}
141 tr.issue.idnt-9 td.subject {padding-left: 12.5em;}
141 tr.issue.idnt-9 td.subject {padding-left: 12.5em;}
142
142
143 tr.entry { border: 1px solid #f8f8f8; }
143 tr.entry { border: 1px solid #f8f8f8; }
144 tr.entry td { white-space: nowrap; }
144 tr.entry td { white-space: nowrap; }
145 tr.entry td.filename { width: 30%; }
145 tr.entry td.filename { width: 30%; }
146 tr.entry td.size { text-align: right; font-size: 90%; }
146 tr.entry td.size { text-align: right; font-size: 90%; }
147 tr.entry td.revision, tr.entry td.author { text-align: center; }
147 tr.entry td.revision, tr.entry td.author { text-align: center; }
148 tr.entry td.age { text-align: right; }
148 tr.entry td.age { text-align: right; }
149 tr.entry.file td.filename a { margin-left: 16px; }
149 tr.entry.file td.filename a { margin-left: 16px; }
150
150
151 tr span.expander {background-image: url(../images/bullet_toggle_plus.png); padding-left: 8px; margin-left: 0; cursor: pointer;}
151 tr span.expander {background-image: url(../images/bullet_toggle_plus.png); padding-left: 8px; margin-left: 0; cursor: pointer;}
152 tr.open span.expander {background-image: url(../images/bullet_toggle_minus.png);}
152 tr.open span.expander {background-image: url(../images/bullet_toggle_minus.png);}
153
153
154 tr.changeset td.author { text-align: center; width: 15%; }
154 tr.changeset td.author { text-align: center; width: 15%; }
155 tr.changeset td.committed_on { text-align: center; width: 15%; }
155 tr.changeset td.committed_on { text-align: center; width: 15%; }
156
156
157 table.files tr.file td { text-align: center; }
157 table.files tr.file td { text-align: center; }
158 table.files tr.file td.filename { text-align: left; padding-left: 24px; }
158 table.files tr.file td.filename { text-align: left; padding-left: 24px; }
159 table.files tr.file td.digest { font-size: 80%; }
159 table.files tr.file td.digest { font-size: 80%; }
160
160
161 table.members td.roles, table.memberships td.roles { width: 45%; }
161 table.members td.roles, table.memberships td.roles { width: 45%; }
162
162
163 tr.message { height: 2.6em; }
163 tr.message { height: 2.6em; }
164 tr.message td.subject { padding-left: 20px; }
164 tr.message td.subject { padding-left: 20px; }
165 tr.message td.created_on { white-space: nowrap; }
165 tr.message td.created_on { white-space: nowrap; }
166 tr.message td.last_message { font-size: 80%; white-space: nowrap; }
166 tr.message td.last_message { font-size: 80%; white-space: nowrap; }
167 tr.message.locked td.subject { background: url(../images/locked.png) no-repeat 0 1px; }
167 tr.message.locked td.subject { background: url(../images/locked.png) no-repeat 0 1px; }
168 tr.message.sticky td.subject { background: url(../images/bullet_go.png) no-repeat 0 1px; font-weight: bold; }
168 tr.message.sticky td.subject { background: url(../images/bullet_go.png) no-repeat 0 1px; font-weight: bold; }
169
169
170 tr.version.closed, tr.version.closed a { color: #999; }
170 tr.version.closed, tr.version.closed a { color: #999; }
171 tr.version td.name { padding-left: 20px; }
171 tr.version td.name { padding-left: 20px; }
172 tr.version.shared td.name { background: url(../images/link.png) no-repeat 0% 70%; }
172 tr.version.shared td.name { background: url(../images/link.png) no-repeat 0% 70%; }
173 tr.version td.date, tr.version td.status, tr.version td.sharing { text-align: center; }
173 tr.version td.date, tr.version td.status, tr.version td.sharing { text-align: center; }
174
174
175 tr.user td { width:13%; }
175 tr.user td { width:13%; }
176 tr.user td.email { width:18%; }
176 tr.user td.email { width:18%; }
177 tr.user td { white-space: nowrap; }
177 tr.user td { white-space: nowrap; }
178 tr.user.locked, tr.user.registered { color: #aaa; }
178 tr.user.locked, tr.user.registered { color: #aaa; }
179 tr.user.locked a, tr.user.registered a { color: #aaa; }
179 tr.user.locked a, tr.user.registered a { color: #aaa; }
180
180
181 tr.time-entry { text-align: center; white-space: nowrap; }
181 tr.time-entry { text-align: center; white-space: nowrap; }
182 tr.time-entry td.subject, tr.time-entry td.comments { text-align: left; white-space: normal; }
182 tr.time-entry td.subject, tr.time-entry td.comments { text-align: left; white-space: normal; }
183 td.hours { text-align: right; font-weight: bold; padding-right: 0.5em; }
183 td.hours { text-align: right; font-weight: bold; padding-right: 0.5em; }
184 td.hours .hours-dec { font-size: 0.9em; }
184 td.hours .hours-dec { font-size: 0.9em; }
185
185
186 table.plugins td { vertical-align: middle; }
186 table.plugins td { vertical-align: middle; }
187 table.plugins td.configure { text-align: right; padding-right: 1em; }
187 table.plugins td.configure { text-align: right; padding-right: 1em; }
188 table.plugins span.name { font-weight: bold; display: block; margin-bottom: 6px; }
188 table.plugins span.name { font-weight: bold; display: block; margin-bottom: 6px; }
189 table.plugins span.description { display: block; font-size: 0.9em; }
189 table.plugins span.description { display: block; font-size: 0.9em; }
190 table.plugins span.url { display: block; font-size: 0.9em; }
190 table.plugins span.url { display: block; font-size: 0.9em; }
191
191
192 table.list tbody tr.group td { padding: 0.8em 0 0.5em 0.3em; font-weight: bold; border-bottom: 1px solid #ccc; }
192 table.list tbody tr.group td { padding: 0.8em 0 0.5em 0.3em; font-weight: bold; border-bottom: 1px solid #ccc; }
193 table.list tbody tr.group span.count { color: #aaa; font-size: 80%; }
193 table.list tbody tr.group span.count { color: #aaa; font-size: 80%; }
194
194
195 table.list tbody tr:hover { background-color:#ffffdd; }
195 table.list tbody tr:hover { background-color:#ffffdd; }
196 table.list tbody tr.group:hover { background-color:inherit; }
196 table.list tbody tr.group:hover { background-color:inherit; }
197 table td {padding:2px;}
197 table td {padding:2px;}
198 table p {margin:0;}
198 table p {margin:0;}
199 .odd {background-color:#f6f7f8;}
199 .odd {background-color:#f6f7f8;}
200 .even {background-color: #fff;}
200 .even {background-color: #fff;}
201
201
202 a.sort { padding-right: 16px; background-position: 100% 50%; background-repeat: no-repeat; }
202 a.sort { padding-right: 16px; background-position: 100% 50%; background-repeat: no-repeat; }
203 a.sort.asc { background-image: url(../images/sort_asc.png); }
203 a.sort.asc { background-image: url(../images/sort_asc.png); }
204 a.sort.desc { background-image: url(../images/sort_desc.png); }
204 a.sort.desc { background-image: url(../images/sort_desc.png); }
205
205
206 table.attributes { width: 100% }
206 table.attributes { width: 100% }
207 table.attributes th { vertical-align: top; text-align: left; }
207 table.attributes th { vertical-align: top; text-align: left; }
208 table.attributes td { vertical-align: top; }
208 table.attributes td { vertical-align: top; }
209
209
210 table.boards a.board, h3.comments { background: url(../images/comment.png) no-repeat 0% 50%; padding-left: 20px; }
210 table.boards a.board, h3.comments { background: url(../images/comment.png) no-repeat 0% 50%; padding-left: 20px; }
211
211
212 td.center {text-align:center;}
212 td.center {text-align:center;}
213
213
214 h3.version { background: url(../images/package.png) no-repeat 0% 50%; padding-left: 20px; }
214 h3.version { background: url(../images/package.png) no-repeat 0% 50%; padding-left: 20px; }
215
215
216 div.issues h3 { background: url(../images/ticket.png) no-repeat 0% 50%; padding-left: 20px; }
216 div.issues h3 { background: url(../images/ticket.png) no-repeat 0% 50%; padding-left: 20px; }
217 div.members h3 { background: url(../images/group.png) no-repeat 0% 50%; padding-left: 20px; }
217 div.members h3 { background: url(../images/group.png) no-repeat 0% 50%; padding-left: 20px; }
218 div.news h3 { background: url(../images/news.png) no-repeat 0% 50%; padding-left: 20px; }
218 div.news h3 { background: url(../images/news.png) no-repeat 0% 50%; padding-left: 20px; }
219 div.projects h3 { background: url(../images/projects.png) no-repeat 0% 50%; padding-left: 20px; }
219 div.projects h3 { background: url(../images/projects.png) no-repeat 0% 50%; padding-left: 20px; }
220
220
221 #watchers ul {margin: 0; padding: 0;}
221 #watchers ul {margin: 0; padding: 0;}
222 #watchers li {list-style-type:none;margin: 0px 2px 0px 0px; padding: 0px 0px 0px 0px;}
222 #watchers li {list-style-type:none;margin: 0px 2px 0px 0px; padding: 0px 0px 0px 0px;}
223 #watchers select {width: 95%; display: block;}
223 #watchers select {width: 95%; display: block;}
224 #watchers a.delete {opacity: 0.4;}
224 #watchers a.delete {opacity: 0.4;}
225 #watchers a.delete:hover {opacity: 1;}
225 #watchers a.delete:hover {opacity: 1;}
226 #watchers img.gravatar {vertical-align: middle;margin: 0 4px 2px 0;}
226 #watchers img.gravatar {vertical-align: middle;margin: 0 4px 2px 0;}
227
227
228 .highlight { background-color: #FCFD8D;}
228 .highlight { background-color: #FCFD8D;}
229 .highlight.token-1 { background-color: #faa;}
229 .highlight.token-1 { background-color: #faa;}
230 .highlight.token-2 { background-color: #afa;}
230 .highlight.token-2 { background-color: #afa;}
231 .highlight.token-3 { background-color: #aaf;}
231 .highlight.token-3 { background-color: #aaf;}
232
232
233 .box{
233 .box{
234 padding:6px;
234 padding:6px;
235 margin-bottom: 10px;
235 margin-bottom: 10px;
236 background-color:#f6f6f6;
236 background-color:#f6f6f6;
237 color:#505050;
237 color:#505050;
238 line-height:1.5em;
238 line-height:1.5em;
239 border: 1px solid #e4e4e4;
239 border: 1px solid #e4e4e4;
240 }
240 }
241
241
242 div.square {
242 div.square {
243 border: 1px solid #999;
243 border: 1px solid #999;
244 float: left;
244 float: left;
245 margin: .3em .4em 0 .4em;
245 margin: .3em .4em 0 .4em;
246 overflow: hidden;
246 overflow: hidden;
247 width: .6em; height: .6em;
247 width: .6em; height: .6em;
248 }
248 }
249 .contextual {float:right; white-space: nowrap; line-height:1.4em;margin-top:5px; padding-left: 10px; font-size:0.9em;}
249 .contextual {float:right; white-space: nowrap; line-height:1.4em;margin-top:5px; padding-left: 10px; font-size:0.9em;}
250 .contextual input, .contextual select {font-size:0.9em;}
250 .contextual input, .contextual select {font-size:0.9em;}
251 .message .contextual { margin-top: 0; }
251 .message .contextual { margin-top: 0; }
252
252
253 .splitcontentleft{float:left; width:49%;}
253 .splitcontentleft{float:left; width:49%;}
254 .splitcontentright{float:right; width:49%;}
254 .splitcontentright{float:right; width:49%;}
255 form {display: inline;}
255 form {display: inline;}
256 input, select {vertical-align: middle; margin-top: 1px; margin-bottom: 1px;}
256 input, select {vertical-align: middle; margin-top: 1px; margin-bottom: 1px;}
257 fieldset {border: 1px solid #e4e4e4; margin:0;}
257 fieldset {border: 1px solid #e4e4e4; margin:0;}
258 legend {color: #484848;}
258 legend {color: #484848;}
259 hr { width: 100%; height: 1px; background: #ccc; border: 0;}
259 hr { width: 100%; height: 1px; background: #ccc; border: 0;}
260 blockquote { font-style: italic; border-left: 3px solid #e0e0e0; padding-left: 0.6em; margin-left: 2.4em;}
260 blockquote { font-style: italic; border-left: 3px solid #e0e0e0; padding-left: 0.6em; margin-left: 2.4em;}
261 blockquote blockquote { margin-left: 0;}
261 blockquote blockquote { margin-left: 0;}
262 acronym { border-bottom: 1px dotted; cursor: help; }
262 acronym { border-bottom: 1px dotted; cursor: help; }
263 textarea.wiki-edit { width: 99%; }
263 textarea.wiki-edit { width: 99%; }
264 li p {margin-top: 0;}
264 li p {margin-top: 0;}
265 div.issue {background:#ffffdd; padding:6px; margin-bottom:6px;border: 1px solid #d7d7d7;}
265 div.issue {background:#ffffdd; padding:6px; margin-bottom:6px;border: 1px solid #d7d7d7;}
266 p.breadcrumb { font-size: 0.9em; margin: 4px 0 4px 0;}
266 p.breadcrumb { font-size: 0.9em; margin: 4px 0 4px 0;}
267 p.subtitle { font-size: 0.9em; margin: -6px 0 12px 0; font-style: italic; }
267 p.subtitle { font-size: 0.9em; margin: -6px 0 12px 0; font-style: italic; }
268 p.footnote { font-size: 0.9em; margin-top: 0px; margin-bottom: 0px; }
268 p.footnote { font-size: 0.9em; margin-top: 0px; margin-bottom: 0px; }
269
269
270 div.issue div.subject div div { padding-left: 16px; }
270 div.issue div.subject div div { padding-left: 16px; }
271 div.issue div.subject p {margin: 0; margin-bottom: 0.1em; font-size: 90%; color: #999;}
271 div.issue div.subject p {margin: 0; margin-bottom: 0.1em; font-size: 90%; color: #999;}
272 div.issue div.subject>div>p { margin-top: 0.5em; }
272 div.issue div.subject>div>p { margin-top: 0.5em; }
273 div.issue div.subject h3 {margin: 0; margin-bottom: 0.1em;}
273 div.issue div.subject h3 {margin: 0; margin-bottom: 0.1em;}
274
274
275 #issue_tree table.issues { border: 0; }
275 #issue_tree table.issues { border: 0; }
276 #issue_tree td.checkbox {display:none;}
276 #issue_tree td.checkbox {display:none;}
277
277
278 fieldset.collapsible { border-width: 1px 0 0 0; font-size: 0.9em; }
278 fieldset.collapsible { border-width: 1px 0 0 0; font-size: 0.9em; }
279 fieldset.collapsible legend { padding-left: 16px; background: url(../images/arrow_expanded.png) no-repeat 0% 40%; cursor:pointer; }
279 fieldset.collapsible legend { padding-left: 16px; background: url(../images/arrow_expanded.png) no-repeat 0% 40%; cursor:pointer; }
280 fieldset.collapsible.collapsed legend { background-image: url(../images/arrow_collapsed.png); }
280 fieldset.collapsible.collapsed legend { background-image: url(../images/arrow_collapsed.png); }
281
281
282 fieldset#date-range p { margin: 2px 0 2px 0; }
282 fieldset#date-range p { margin: 2px 0 2px 0; }
283 fieldset#filters table { border-collapse: collapse; }
283 fieldset#filters table { border-collapse: collapse; }
284 fieldset#filters table td { padding: 0; vertical-align: middle; }
284 fieldset#filters table td { padding: 0; vertical-align: middle; }
285 fieldset#filters tr.filter { height: 2em; }
285 fieldset#filters tr.filter { height: 2em; }
286 fieldset#filters td.add-filter { text-align: right; vertical-align: top; }
286 fieldset#filters td.add-filter { text-align: right; vertical-align: top; }
287 .buttons { font-size: 0.9em; margin-bottom: 1.4em; margin-top: 1em; }
287 .buttons { font-size: 0.9em; margin-bottom: 1.4em; margin-top: 1em; }
288
288
289 div#issue-changesets {float:right; width:45%; margin-left: 1em; margin-bottom: 1em; background: #fff; padding-left: 1em; font-size: 90%;}
289 div#issue-changesets {float:right; width:45%; margin-left: 1em; margin-bottom: 1em; background: #fff; padding-left: 1em; font-size: 90%;}
290 div#issue-changesets div.changeset { padding: 4px;}
290 div#issue-changesets div.changeset { padding: 4px;}
291 div#issue-changesets div.changeset { border-bottom: 1px solid #ddd; }
291 div#issue-changesets div.changeset { border-bottom: 1px solid #ddd; }
292 div#issue-changesets p { margin-top: 0; margin-bottom: 1em;}
292 div#issue-changesets p { margin-top: 0; margin-bottom: 1em;}
293
293
294 div#activity dl, #search-results { margin-left: 2em; }
294 div#activity dl, #search-results { margin-left: 2em; }
295 div#activity dd, #search-results dd { margin-bottom: 1em; padding-left: 18px; font-size: 0.9em; }
295 div#activity dd, #search-results dd { margin-bottom: 1em; padding-left: 18px; font-size: 0.9em; }
296 div#activity dt, #search-results dt { margin-bottom: 0px; padding-left: 20px; line-height: 18px; background-position: 0 50%; background-repeat: no-repeat; }
296 div#activity dt, #search-results dt { margin-bottom: 0px; padding-left: 20px; line-height: 18px; background-position: 0 50%; background-repeat: no-repeat; }
297 div#activity dt.me .time { border-bottom: 1px solid #999; }
297 div#activity dt.me .time { border-bottom: 1px solid #999; }
298 div#activity dt .time { color: #777; font-size: 80%; }
298 div#activity dt .time { color: #777; font-size: 80%; }
299 div#activity dd .description, #search-results dd .description { font-style: italic; }
299 div#activity dd .description, #search-results dd .description { font-style: italic; }
300 div#activity span.project:after, #search-results span.project:after { content: " -"; }
300 div#activity span.project:after, #search-results span.project:after { content: " -"; }
301 div#activity dd span.description, #search-results dd span.description { display:block; color: #808080; }
301 div#activity dd span.description, #search-results dd span.description { display:block; color: #808080; }
302
302
303 #search-results dd { margin-bottom: 1em; padding-left: 20px; margin-left:0px; }
303 #search-results dd { margin-bottom: 1em; padding-left: 20px; margin-left:0px; }
304
304
305 div#search-results-counts {float:right;}
305 div#search-results-counts {float:right;}
306 div#search-results-counts ul { margin-top: 0.5em; }
306 div#search-results-counts ul { margin-top: 0.5em; }
307 div#search-results-counts li { list-style-type:none; float: left; margin-left: 1em; }
307 div#search-results-counts li { list-style-type:none; float: left; margin-left: 1em; }
308
308
309 dt.issue { background-image: url(../images/ticket.png); }
309 dt.issue { background-image: url(../images/ticket.png); }
310 dt.issue-edit { background-image: url(../images/ticket_edit.png); }
310 dt.issue-edit { background-image: url(../images/ticket_edit.png); }
311 dt.issue-closed { background-image: url(../images/ticket_checked.png); }
311 dt.issue-closed { background-image: url(../images/ticket_checked.png); }
312 dt.issue-note { background-image: url(../images/ticket_note.png); }
312 dt.issue-note { background-image: url(../images/ticket_note.png); }
313 dt.changeset { background-image: url(../images/changeset.png); }
313 dt.changeset { background-image: url(../images/changeset.png); }
314 dt.news { background-image: url(../images/news.png); }
314 dt.news { background-image: url(../images/news.png); }
315 dt.message { background-image: url(../images/message.png); }
315 dt.message { background-image: url(../images/message.png); }
316 dt.reply { background-image: url(../images/comments.png); }
316 dt.reply { background-image: url(../images/comments.png); }
317 dt.wiki-page { background-image: url(../images/wiki_edit.png); }
317 dt.wiki-page { background-image: url(../images/wiki_edit.png); }
318 dt.attachment { background-image: url(../images/attachment.png); }
318 dt.attachment { background-image: url(../images/attachment.png); }
319 dt.document { background-image: url(../images/document.png); }
319 dt.document { background-image: url(../images/document.png); }
320 dt.project { background-image: url(../images/projects.png); }
320 dt.project { background-image: url(../images/projects.png); }
321 dt.time-entry { background-image: url(../images/time.png); }
321 dt.time-entry { background-image: url(../images/time.png); }
322
322
323 #search-results dt.issue.closed { background-image: url(../images/ticket_checked.png); }
323 #search-results dt.issue.closed { background-image: url(../images/ticket_checked.png); }
324
324
325 div#roadmap .related-issues { margin-bottom: 1em; }
325 div#roadmap .related-issues { margin-bottom: 1em; }
326 div#roadmap .related-issues td.checkbox { display: none; }
326 div#roadmap .related-issues td.checkbox { display: none; }
327 div#roadmap .wiki h1:first-child { display: none; }
327 div#roadmap .wiki h1:first-child { display: none; }
328 div#roadmap .wiki h1 { font-size: 120%; }
328 div#roadmap .wiki h1 { font-size: 120%; }
329 div#roadmap .wiki h2 { font-size: 110%; }
329 div#roadmap .wiki h2 { font-size: 110%; }
330
330
331 div#version-summary { float:right; width:380px; margin-left: 16px; margin-bottom: 16px; background-color: #fff; }
331 div#version-summary { float:right; width:380px; margin-left: 16px; margin-bottom: 16px; background-color: #fff; }
332 div#version-summary fieldset { margin-bottom: 1em; }
332 div#version-summary fieldset { margin-bottom: 1em; }
333 div#version-summary .total-hours { text-align: right; }
333 div#version-summary .total-hours { text-align: right; }
334
334
335 table#time-report td.hours, table#time-report th.period, table#time-report th.total { text-align: right; padding-right: 0.5em; }
335 table#time-report td.hours, table#time-report th.period, table#time-report th.total { text-align: right; padding-right: 0.5em; }
336 table#time-report tbody tr { font-style: italic; color: #777; }
336 table#time-report tbody tr { font-style: italic; color: #777; }
337 table#time-report tbody tr.last-level { font-style: normal; color: #555; }
337 table#time-report tbody tr.last-level { font-style: normal; color: #555; }
338 table#time-report tbody tr.total { font-style: normal; font-weight: bold; color: #555; background-color:#EEEEEE; }
338 table#time-report tbody tr.total { font-style: normal; font-weight: bold; color: #555; background-color:#EEEEEE; }
339 table#time-report .hours-dec { font-size: 0.9em; }
339 table#time-report .hours-dec { font-size: 0.9em; }
340
340
341 form .attributes { margin-bottom: 8px; }
341 form .attributes { margin-bottom: 8px; }
342 form .attributes p { padding-top: 1px; padding-bottom: 2px; }
342 form .attributes p { padding-top: 1px; padding-bottom: 2px; }
343 form .attributes select { min-width: 50%; }
343 form .attributes select { min-width: 50%; }
344
344
345 ul.projects { margin: 0; padding-left: 1em; }
345 ul.projects { margin: 0; padding-left: 1em; }
346 ul.projects.root { margin: 0; padding: 0; }
346 ul.projects.root { margin: 0; padding: 0; }
347 ul.projects ul.projects { border-left: 3px solid #e0e0e0; }
347 ul.projects ul.projects { border-left: 3px solid #e0e0e0; }
348 ul.projects li.root { list-style-type:none; margin-bottom: 1em; }
348 ul.projects li.root { list-style-type:none; margin-bottom: 1em; }
349 ul.projects li.child { list-style-type:none; margin-top: 1em;}
349 ul.projects li.child { list-style-type:none; margin-top: 1em;}
350 ul.projects div.root a.project { font-family: "Trebuchet MS", Verdana, sans-serif; font-weight: bold; font-size: 16px; margin: 0 0 10px 0; }
350 ul.projects div.root a.project { font-family: "Trebuchet MS", Verdana, sans-serif; font-weight: bold; font-size: 16px; margin: 0 0 10px 0; }
351 .my-project { padding-left: 18px; background: url(../images/fav.png) no-repeat 0 50%; }
351 .my-project { padding-left: 18px; background: url(../images/fav.png) no-repeat 0 50%; }
352
352
353 #tracker_project_ids ul { margin: 0; padding-left: 1em; }
353 #tracker_project_ids ul { margin: 0; padding-left: 1em; }
354 #tracker_project_ids li { list-style-type:none; }
354 #tracker_project_ids li { list-style-type:none; }
355
355
356 ul.properties {padding:0; font-size: 0.9em; color: #777;}
356 ul.properties {padding:0; font-size: 0.9em; color: #777;}
357 ul.properties li {list-style-type:none;}
357 ul.properties li {list-style-type:none;}
358 ul.properties li span {font-style:italic;}
358 ul.properties li span {font-style:italic;}
359
359
360 .total-hours { font-size: 110%; font-weight: bold; }
360 .total-hours { font-size: 110%; font-weight: bold; }
361 .total-hours span.hours-int { font-size: 120%; }
361 .total-hours span.hours-int { font-size: 120%; }
362
362
363 .autoscroll {overflow-x: auto; padding:1px; margin-bottom: 1.2em;}
363 .autoscroll {overflow-x: auto; padding:1px; margin-bottom: 1.2em;}
364 #user_firstname, #user_lastname, #user_mail, #my_account_form select { width: 90%; }
364 #user_firstname, #user_lastname, #user_mail, #my_account_form select { width: 90%; }
365
365
366 #workflow_copy_form select { width: 200px; }
366 #workflow_copy_form select { width: 200px; }
367
367
368 .pagination {font-size: 90%}
368 .pagination {font-size: 90%}
369 p.pagination {margin-top:8px;}
369 p.pagination {margin-top:8px;}
370
370
371 /***** Tabular forms ******/
371 /***** Tabular forms ******/
372 .tabular p{
372 .tabular p{
373 margin: 0;
373 margin: 0;
374 padding: 5px 0 8px 0;
374 padding: 5px 0 8px 0;
375 padding-left: 180px; /*width of left column containing the label elements*/
375 padding-left: 180px; /*width of left column containing the label elements*/
376 height: 1%;
376 height: 1%;
377 clear:left;
377 clear:left;
378 }
378 }
379
379
380 html>body .tabular p {overflow:hidden;}
380 html>body .tabular p {overflow:hidden;}
381
381
382 .tabular label{
382 .tabular label{
383 font-weight: bold;
383 font-weight: bold;
384 float: left;
384 float: left;
385 text-align: right;
385 text-align: right;
386 margin-left: -180px; /*width of left column*/
386 margin-left: -180px; /*width of left column*/
387 width: 175px; /*width of labels. Should be smaller than left column to create some right
387 width: 175px; /*width of labels. Should be smaller than left column to create some right
388 margin*/
388 margin*/
389 }
389 }
390
390
391 .tabular label.floating{
391 .tabular label.floating{
392 font-weight: normal;
392 font-weight: normal;
393 margin-left: 0px;
393 margin-left: 0px;
394 text-align: left;
394 text-align: left;
395 width: 270px;
395 width: 270px;
396 }
396 }
397
397
398 .tabular label.block{
398 .tabular label.block{
399 font-weight: normal;
399 font-weight: normal;
400 margin-left: 0px !important;
400 margin-left: 0px !important;
401 text-align: left;
401 text-align: left;
402 float: none;
402 float: none;
403 display: block;
403 display: block;
404 width: auto;
404 width: auto;
405 }
405 }
406
406
407 .tabular label.inline{
407 .tabular label.inline{
408 float:none;
408 float:none;
409 margin-left: 5px !important;
409 margin-left: 5px !important;
410 width: auto;
410 width: auto;
411 }
411 }
412
412
413 input#time_entry_comments { width: 90%;}
413 input#time_entry_comments { width: 90%;}
414
414
415 #preview fieldset {margin-top: 1em; background: url(../images/draft.png)}
415 #preview fieldset {margin-top: 1em; background: url(../images/draft.png)}
416
416
417 .tabular.settings p{ padding-left: 300px; }
417 .tabular.settings p{ padding-left: 300px; }
418 .tabular.settings label{ margin-left: -300px; width: 295px; }
418 .tabular.settings label{ margin-left: -300px; width: 295px; }
419 .tabular.settings textarea { width: 99%; }
419 .tabular.settings textarea { width: 99%; }
420
420
421 fieldset.settings label { display: block; }
421 fieldset.settings label { display: block; }
422 .parent { padding-left: 20px; }
422 .parent { padding-left: 20px; }
423
423
424 .required {color: #bb0000;}
424 .required {color: #bb0000;}
425 .summary {font-style: italic;}
425 .summary {font-style: italic;}
426
426
427 #attachments_fields input[type=text] {margin-left: 8px; }
427 #attachments_fields input[type=text] {margin-left: 8px; }
428
428
429 div.attachments { margin-top: 12px; }
429 div.attachments { margin-top: 12px; }
430 div.attachments p { margin:4px 0 2px 0; }
430 div.attachments p { margin:4px 0 2px 0; }
431 div.attachments img { vertical-align: middle; }
431 div.attachments img { vertical-align: middle; }
432 div.attachments span.author { font-size: 0.9em; color: #888; }
432 div.attachments span.author { font-size: 0.9em; color: #888; }
433
433
434 p.other-formats { text-align: right; font-size:0.9em; color: #666; }
434 p.other-formats { text-align: right; font-size:0.9em; color: #666; }
435 .other-formats span + span:before { content: "| "; }
435 .other-formats span + span:before { content: "| "; }
436
436
437 a.atom { background: url(../images/feed.png) no-repeat 1px 50%; padding: 2px 0px 3px 16px; }
437 a.atom { background: url(../images/feed.png) no-repeat 1px 50%; padding: 2px 0px 3px 16px; }
438
438
439 /* Project members tab */
439 /* Project members tab */
440 div#tab-content-members .splitcontentleft, div#tab-content-memberships .splitcontentleft, div#tab-content-users .splitcontentleft { width: 64% }
440 div#tab-content-members .splitcontentleft, div#tab-content-memberships .splitcontentleft, div#tab-content-users .splitcontentleft { width: 64% }
441 div#tab-content-members .splitcontentright, div#tab-content-memberships .splitcontentright, div#tab-content-users .splitcontentright { width: 34% }
441 div#tab-content-members .splitcontentright, div#tab-content-memberships .splitcontentright, div#tab-content-users .splitcontentright { width: 34% }
442 div#tab-content-members fieldset, div#tab-content-memberships fieldset, div#tab-content-users fieldset { padding:1em; margin-bottom: 1em; }
442 div#tab-content-members fieldset, div#tab-content-memberships fieldset, div#tab-content-users fieldset { padding:1em; margin-bottom: 1em; }
443 div#tab-content-members fieldset legend, div#tab-content-memberships fieldset legend, div#tab-content-users fieldset legend { font-weight: bold; }
443 div#tab-content-members fieldset legend, div#tab-content-memberships fieldset legend, div#tab-content-users fieldset legend { font-weight: bold; }
444 div#tab-content-members fieldset label, div#tab-content-memberships fieldset label, div#tab-content-users fieldset label { display: block; }
444 div#tab-content-members fieldset label, div#tab-content-memberships fieldset label, div#tab-content-users fieldset label { display: block; }
445 div#tab-content-members fieldset div, div#tab-content-users fieldset div { max-height: 400px; overflow:auto; }
445 div#tab-content-members fieldset div, div#tab-content-users fieldset div { max-height: 400px; overflow:auto; }
446
446
447 table.members td.group { padding-left: 20px; background: url(../images/group.png) no-repeat 0% 50%; }
447 table.members td.group { padding-left: 20px; background: url(../images/group.png) no-repeat 0% 50%; }
448
448
449 input#principal_search, input#user_search {width:100%}
449 input#principal_search, input#user_search {width:100%}
450
450
451 * html div#tab-content-members fieldset div { height: 450px; }
451 * html div#tab-content-members fieldset div { height: 450px; }
452
452
453 /***** Flash & error messages ****/
453 /***** Flash & error messages ****/
454 #errorExplanation, div.flash, .nodata, .warning {
454 #errorExplanation, div.flash, .nodata, .warning {
455 padding: 4px 4px 4px 30px;
455 padding: 4px 4px 4px 30px;
456 margin-bottom: 12px;
456 margin-bottom: 12px;
457 font-size: 1.1em;
457 font-size: 1.1em;
458 border: 2px solid;
458 border: 2px solid;
459 }
459 }
460
460
461 div.flash {margin-top: 8px;}
461 div.flash {margin-top: 8px;}
462
462
463 div.flash.error, #errorExplanation {
463 div.flash.error, #errorExplanation {
464 background: url(../images/exclamation.png) 8px 50% no-repeat;
464 background: url(../images/exclamation.png) 8px 50% no-repeat;
465 background-color: #ffe3e3;
465 background-color: #ffe3e3;
466 border-color: #dd0000;
466 border-color: #dd0000;
467 color: #880000;
467 color: #880000;
468 }
468 }
469
469
470 div.flash.notice {
470 div.flash.notice {
471 background: url(../images/true.png) 8px 5px no-repeat;
471 background: url(../images/true.png) 8px 5px no-repeat;
472 background-color: #dfffdf;
472 background-color: #dfffdf;
473 border-color: #9fcf9f;
473 border-color: #9fcf9f;
474 color: #005f00;
474 color: #005f00;
475 }
475 }
476
476
477 div.flash.warning {
477 div.flash.warning {
478 background: url(../images/warning.png) 8px 5px no-repeat;
478 background: url(../images/warning.png) 8px 5px no-repeat;
479 background-color: #FFEBC1;
479 background-color: #FFEBC1;
480 border-color: #FDBF3B;
480 border-color: #FDBF3B;
481 color: #A6750C;
481 color: #A6750C;
482 text-align: left;
482 text-align: left;
483 }
483 }
484
484
485 .nodata, .warning {
485 .nodata, .warning {
486 text-align: center;
486 text-align: center;
487 background-color: #FFEBC1;
487 background-color: #FFEBC1;
488 border-color: #FDBF3B;
488 border-color: #FDBF3B;
489 color: #A6750C;
489 color: #A6750C;
490 }
490 }
491
491
492 #errorExplanation ul { font-size: 0.9em;}
492 #errorExplanation ul { font-size: 0.9em;}
493 #errorExplanation h2, #errorExplanation p { display: none; }
493 #errorExplanation h2, #errorExplanation p { display: none; }
494
494
495 /***** Ajax indicator ******/
495 /***** Ajax indicator ******/
496 #ajax-indicator {
496 #ajax-indicator {
497 position: absolute; /* fixed not supported by IE */
497 position: absolute; /* fixed not supported by IE */
498 background-color:#eee;
498 background-color:#eee;
499 border: 1px solid #bbb;
499 border: 1px solid #bbb;
500 top:35%;
500 top:35%;
501 left:40%;
501 left:40%;
502 width:20%;
502 width:20%;
503 font-weight:bold;
503 font-weight:bold;
504 text-align:center;
504 text-align:center;
505 padding:0.6em;
505 padding:0.6em;
506 z-index:100;
506 z-index:100;
507 filter:alpha(opacity=50);
507 filter:alpha(opacity=50);
508 opacity: 0.5;
508 opacity: 0.5;
509 }
509 }
510
510
511 html>body #ajax-indicator { position: fixed; }
511 html>body #ajax-indicator { position: fixed; }
512
512
513 #ajax-indicator span {
513 #ajax-indicator span {
514 background-position: 0% 40%;
514 background-position: 0% 40%;
515 background-repeat: no-repeat;
515 background-repeat: no-repeat;
516 background-image: url(../images/loading.gif);
516 background-image: url(../images/loading.gif);
517 padding-left: 26px;
517 padding-left: 26px;
518 vertical-align: bottom;
518 vertical-align: bottom;
519 }
519 }
520
520
521 /***** Calendar *****/
521 /***** Calendar *****/
522 table.cal {border-collapse: collapse; width: 100%; margin: 0px 0 6px 0;border: 1px solid #d7d7d7;}
522 table.cal {border-collapse: collapse; width: 100%; margin: 0px 0 6px 0;border: 1px solid #d7d7d7;}
523 table.cal thead th {width: 14%; background-color:#EEEEEE; padding: 4px; }
523 table.cal thead th {width: 14%; background-color:#EEEEEE; padding: 4px; }
524 table.cal thead th.week-number {width: auto;}
524 table.cal thead th.week-number {width: auto;}
525 table.cal tbody tr {height: 100px;}
525 table.cal tbody tr {height: 100px;}
526 table.cal td {border: 1px solid #d7d7d7; vertical-align: top; font-size: 0.9em;}
526 table.cal td {border: 1px solid #d7d7d7; vertical-align: top; font-size: 0.9em;}
527 table.cal td.week-number { background-color:#EEEEEE; padding: 4px; border:none; font-size: 1em;}
527 table.cal td.week-number { background-color:#EEEEEE; padding: 4px; border:none; font-size: 1em;}
528 table.cal td p.day-num {font-size: 1.1em; text-align:right;}
528 table.cal td p.day-num {font-size: 1.1em; text-align:right;}
529 table.cal td.odd p.day-num {color: #bbb;}
529 table.cal td.odd p.day-num {color: #bbb;}
530 table.cal td.today {background:#ffffdd;}
530 table.cal td.today {background:#ffffdd;}
531 table.cal td.today p.day-num {font-weight: bold;}
531 table.cal td.today p.day-num {font-weight: bold;}
532 table.cal .starting a, p.cal.legend .starting {background: url(../images/bullet_go.png) no-repeat -1px -2px; padding-left:16px;}
532 table.cal .starting a, p.cal.legend .starting {background: url(../images/bullet_go.png) no-repeat -1px -2px; padding-left:16px;}
533 table.cal .ending a, p.cal.legend .ending {background: url(../images/bullet_end.png) no-repeat -1px -2px; padding-left:16px;}
533 table.cal .ending a, p.cal.legend .ending {background: url(../images/bullet_end.png) no-repeat -1px -2px; padding-left:16px;}
534 table.cal .starting.ending a, p.cal.legend .starting.ending {background: url(../images/bullet_diamond.png) no-repeat -1px -2px; padding-left:16px;}
534 table.cal .starting.ending a, p.cal.legend .starting.ending {background: url(../images/bullet_diamond.png) no-repeat -1px -2px; padding-left:16px;}
535 p.cal.legend span {display:block;}
535 p.cal.legend span {display:block;}
536
536
537 /***** Tooltips ******/
537 /***** Tooltips ******/
538 .tooltip{position:relative;z-index:24;}
538 .tooltip{position:relative;z-index:24;}
539 .tooltip:hover{z-index:25;color:#000;}
539 .tooltip:hover{z-index:25;color:#000;}
540 .tooltip span.tip{display: none; text-align:left;}
540 .tooltip span.tip{display: none; text-align:left;}
541
541
542 div.tooltip:hover span.tip{
542 div.tooltip:hover span.tip{
543 display:block;
543 display:block;
544 position:absolute;
544 position:absolute;
545 top:12px; left:24px; width:270px;
545 top:12px; left:24px; width:270px;
546 border:1px solid #555;
546 border:1px solid #555;
547 background-color:#fff;
547 background-color:#fff;
548 padding: 4px;
548 padding: 4px;
549 font-size: 0.8em;
549 font-size: 0.8em;
550 color:#505050;
550 color:#505050;
551 }
551 }
552
552
553 /***** Progress bar *****/
553 /***** Progress bar *****/
554 table.progress {
554 table.progress {
555 border: 1px solid #D7D7D7;
555 border: 1px solid #D7D7D7;
556 border-collapse: collapse;
556 border-collapse: collapse;
557 border-spacing: 0pt;
557 border-spacing: 0pt;
558 empty-cells: show;
558 empty-cells: show;
559 text-align: center;
559 text-align: center;
560 float:left;
560 float:left;
561 margin: 1px 6px 1px 0px;
561 margin: 1px 6px 1px 0px;
562 }
562 }
563
563
564 table.progress td { height: 0.9em; }
564 table.progress td { height: 0.9em; }
565 table.progress td.closed { background: #BAE0BA none repeat scroll 0%; }
565 table.progress td.closed { background: #BAE0BA none repeat scroll 0%; }
566 table.progress td.done { background: #DEF0DE none repeat scroll 0%; }
566 table.progress td.done { background: #DEF0DE none repeat scroll 0%; }
567 table.progress td.open { background: #FFF none repeat scroll 0%; }
567 table.progress td.open { background: #FFF none repeat scroll 0%; }
568 p.pourcent {font-size: 80%;}
568 p.pourcent {font-size: 80%;}
569 p.progress-info {clear: left; font-style: italic; font-size: 80%;}
569 p.progress-info {clear: left; font-style: italic; font-size: 80%;}
570
570
571 /***** Tabs *****/
571 /***** Tabs *****/
572 #content .tabs {height: 2.6em; margin-bottom:1.2em; position:relative; overflow:hidden;}
572 #content .tabs {height: 2.6em; margin-bottom:1.2em; position:relative; overflow:hidden;}
573 #content .tabs ul {margin:0; position:absolute; bottom:0; padding-left:1em; width: 2000px; border-bottom: 1px solid #bbbbbb;}
573 #content .tabs ul {margin:0; position:absolute; bottom:0; padding-left:1em; width: 2000px; border-bottom: 1px solid #bbbbbb;}
574 #content .tabs ul li {
574 #content .tabs ul li {
575 float:left;
575 float:left;
576 list-style-type:none;
576 list-style-type:none;
577 white-space:nowrap;
577 white-space:nowrap;
578 margin-right:8px;
578 margin-right:8px;
579 background:#fff;
579 background:#fff;
580 position:relative;
580 position:relative;
581 margin-bottom:-1px;
581 margin-bottom:-1px;
582 }
582 }
583 #content .tabs ul li a{
583 #content .tabs ul li a{
584 display:block;
584 display:block;
585 font-size: 0.9em;
585 font-size: 0.9em;
586 text-decoration:none;
586 text-decoration:none;
587 line-height:1.3em;
587 line-height:1.3em;
588 padding:4px 6px 4px 6px;
588 padding:4px 6px 4px 6px;
589 border: 1px solid #ccc;
589 border: 1px solid #ccc;
590 border-bottom: 1px solid #bbbbbb;
590 border-bottom: 1px solid #bbbbbb;
591 background-color: #eeeeee;
591 background-color: #eeeeee;
592 color:#777;
592 color:#777;
593 font-weight:bold;
593 font-weight:bold;
594 }
594 }
595
595
596 #content .tabs ul li a:hover {
596 #content .tabs ul li a:hover {
597 background-color: #ffffdd;
597 background-color: #ffffdd;
598 text-decoration:none;
598 text-decoration:none;
599 }
599 }
600
600
601 #content .tabs ul li a.selected {
601 #content .tabs ul li a.selected {
602 background-color: #fff;
602 background-color: #fff;
603 border: 1px solid #bbbbbb;
603 border: 1px solid #bbbbbb;
604 border-bottom: 1px solid #fff;
604 border-bottom: 1px solid #fff;
605 }
605 }
606
606
607 #content .tabs ul li a.selected:hover {
607 #content .tabs ul li a.selected:hover {
608 background-color: #fff;
608 background-color: #fff;
609 }
609 }
610
610
611 div.tabs-buttons { position:absolute; right: 0; width: 48px; height: 24px; background: white; bottom: 0; border-bottom: 1px solid #bbbbbb; }
611 div.tabs-buttons { position:absolute; right: 0; width: 48px; height: 24px; background: white; bottom: 0; border-bottom: 1px solid #bbbbbb; }
612
612
613 button.tab-left, button.tab-right {
613 button.tab-left, button.tab-right {
614 font-size: 0.9em;
614 font-size: 0.9em;
615 cursor: pointer;
615 cursor: pointer;
616 height:24px;
616 height:24px;
617 border: 1px solid #ccc;
617 border: 1px solid #ccc;
618 border-bottom: 1px solid #bbbbbb;
618 border-bottom: 1px solid #bbbbbb;
619 position:absolute;
619 position:absolute;
620 padding:4px;
620 padding:4px;
621 width: 20px;
621 width: 20px;
622 bottom: -1px;
622 bottom: -1px;
623 }
623 }
624
624
625 button.tab-left {
625 button.tab-left {
626 right: 20px;
626 right: 20px;
627 background: #eeeeee url(../images/bullet_arrow_left.png) no-repeat 50% 50%;
627 background: #eeeeee url(../images/bullet_arrow_left.png) no-repeat 50% 50%;
628 }
628 }
629
629
630 button.tab-right {
630 button.tab-right {
631 right: 0;
631 right: 0;
632 background: #eeeeee url(../images/bullet_arrow_right.png) no-repeat 50% 50%;
632 background: #eeeeee url(../images/bullet_arrow_right.png) no-repeat 50% 50%;
633 }
633 }
634
634
635 /***** Auto-complete *****/
635 /***** Auto-complete *****/
636 div.autocomplete {
636 div.autocomplete {
637 position:absolute;
637 position:absolute;
638 width:400px;
638 width:400px;
639 margin:0;
639 margin:0;
640 padding:0;
640 padding:0;
641 }
641 }
642 div.autocomplete ul {
642 div.autocomplete ul {
643 list-style-type:none;
643 list-style-type:none;
644 margin:0;
644 margin:0;
645 padding:0;
645 padding:0;
646 }
646 }
647 div.autocomplete ul li {
647 div.autocomplete ul li {
648 list-style-type:none;
648 list-style-type:none;
649 display:block;
649 display:block;
650 margin:-1px 0 0 0;
650 margin:-1px 0 0 0;
651 padding:2px;
651 padding:2px;
652 cursor:pointer;
652 cursor:pointer;
653 font-size: 90%;
653 font-size: 90%;
654 border: 1px solid #ccc;
654 border: 1px solid #ccc;
655 border-left: 1px solid #ccc;
655 border-left: 1px solid #ccc;
656 border-right: 1px solid #ccc;
656 border-right: 1px solid #ccc;
657 background-color:white;
657 background-color:white;
658 }
658 }
659 div.autocomplete ul li.selected { background-color: #ffb;}
659 div.autocomplete ul li.selected { background-color: #ffb;}
660 div.autocomplete ul li span.informal {
660 div.autocomplete ul li span.informal {
661 font-size: 80%;
661 font-size: 80%;
662 color: #aaa;
662 color: #aaa;
663 }
663 }
664
664
665 #parent_issue_candidates ul li {width: 500px;}
665 #parent_issue_candidates ul li {width: 500px;}
666
666
667 /***** Diff *****/
667 /***** Diff *****/
668 .diff_out { background: #fcc; }
668 .diff_out { background: #fcc; }
669 .diff_in { background: #cfc; }
669 .diff_in { background: #cfc; }
670
670
671 /***** Wiki *****/
671 /***** Wiki *****/
672 div.wiki table {
672 div.wiki table {
673 border: 1px solid #505050;
673 border: 1px solid #505050;
674 border-collapse: collapse;
674 border-collapse: collapse;
675 margin-bottom: 1em;
675 margin-bottom: 1em;
676 }
676 }
677
677
678 div.wiki table, div.wiki td, div.wiki th {
678 div.wiki table, div.wiki td, div.wiki th {
679 border: 1px solid #bbb;
679 border: 1px solid #bbb;
680 padding: 4px;
680 padding: 4px;
681 }
681 }
682
682
683 div.wiki .external {
683 div.wiki .external {
684 background-position: 0% 60%;
684 background-position: 0% 60%;
685 background-repeat: no-repeat;
685 background-repeat: no-repeat;
686 padding-left: 12px;
686 padding-left: 12px;
687 background-image: url(../images/external.png);
687 background-image: url(../images/external.png);
688 }
688 }
689
689
690 div.wiki a.new {
690 div.wiki a.new {
691 color: #b73535;
691 color: #b73535;
692 }
692 }
693
693
694 div.wiki pre {
694 div.wiki pre {
695 margin: 1em 1em 1em 1.6em;
695 margin: 1em 1em 1em 1.6em;
696 padding: 2px 2px 2px 0;
696 padding: 2px 2px 2px 0;
697 background-color: #fafafa;
697 background-color: #fafafa;
698 border: 1px solid #dadada;
698 border: 1px solid #dadada;
699 width:auto;
699 width:auto;
700 overflow-x: auto;
700 overflow-x: auto;
701 overflow-y: hidden;
701 overflow-y: hidden;
702 }
702 }
703
703
704 div.wiki ul.toc {
704 div.wiki ul.toc {
705 background-color: #ffffdd;
705 background-color: #ffffdd;
706 border: 1px solid #e4e4e4;
706 border: 1px solid #e4e4e4;
707 padding: 4px;
707 padding: 4px;
708 line-height: 1.2em;
708 line-height: 1.2em;
709 margin-bottom: 12px;
709 margin-bottom: 12px;
710 margin-right: 12px;
710 margin-right: 12px;
711 margin-left: 0;
711 margin-left: 0;
712 display: table
712 display: table
713 }
713 }
714 * html div.wiki ul.toc { width: 50%; } /* IE6 doesn't autosize div */
714 * html div.wiki ul.toc { width: 50%; } /* IE6 doesn't autosize div */
715
715
716 div.wiki ul.toc.right { float: right; margin-left: 12px; margin-right: 0; width: auto; }
716 div.wiki ul.toc.right { float: right; margin-left: 12px; margin-right: 0; width: auto; }
717 div.wiki ul.toc.left { float: left; margin-right: 12px; margin-left: 0; width: auto; }
717 div.wiki ul.toc.left { float: left; margin-right: 12px; margin-left: 0; width: auto; }
718 div.wiki ul.toc li { list-style-type:none;}
718 div.wiki ul.toc li { list-style-type:none;}
719 div.wiki ul.toc li.heading2 { margin-left: 6px; }
719 div.wiki ul.toc li.heading2 { margin-left: 6px; }
720 div.wiki ul.toc li.heading3 { margin-left: 12px; font-size: 0.8em; }
720 div.wiki ul.toc li.heading3 { margin-left: 12px; font-size: 0.8em; }
721
721
722 div.wiki ul.toc a {
722 div.wiki ul.toc a {
723 font-size: 0.9em;
723 font-size: 0.9em;
724 font-weight: normal;
724 font-weight: normal;
725 text-decoration: none;
725 text-decoration: none;
726 color: #606060;
726 color: #606060;
727 }
727 }
728 div.wiki ul.toc a:hover { color: #c61a1a; text-decoration: underline;}
728 div.wiki ul.toc a:hover { color: #c61a1a; text-decoration: underline;}
729
729
730 a.wiki-anchor { display: none; margin-left: 6px; text-decoration: none; }
730 a.wiki-anchor { display: none; margin-left: 6px; text-decoration: none; }
731 a.wiki-anchor:hover { color: #aaa !important; text-decoration: none; }
731 a.wiki-anchor:hover { color: #aaa !important; text-decoration: none; }
732 h1:hover a.wiki-anchor, h2:hover a.wiki-anchor, h3:hover a.wiki-anchor { display: inline; color: #ddd; }
732 h1:hover a.wiki-anchor, h2:hover a.wiki-anchor, h3:hover a.wiki-anchor { display: inline; color: #ddd; }
733
733
734 div.wiki img { vertical-align: middle; }
734 div.wiki img { vertical-align: middle; }
735
735
736 /***** My page layout *****/
736 /***** My page layout *****/
737 .block-receiver {
737 .block-receiver {
738 border:1px dashed #c0c0c0;
738 border:1px dashed #c0c0c0;
739 margin-bottom: 20px;
739 margin-bottom: 20px;
740 padding: 15px 0 15px 0;
740 padding: 15px 0 15px 0;
741 }
741 }
742
742
743 .mypage-box {
743 .mypage-box {
744 margin:0 0 20px 0;
744 margin:0 0 20px 0;
745 color:#505050;
745 color:#505050;
746 line-height:1.5em;
746 line-height:1.5em;
747 }
747 }
748
748
749 .handle {
749 .handle {
750 cursor: move;
750 cursor: move;
751 }
751 }
752
752
753 a.close-icon {
753 a.close-icon {
754 display:block;
754 display:block;
755 margin-top:3px;
755 margin-top:3px;
756 overflow:hidden;
756 overflow:hidden;
757 width:12px;
757 width:12px;
758 height:12px;
758 height:12px;
759 background-repeat: no-repeat;
759 background-repeat: no-repeat;
760 cursor:pointer;
760 cursor:pointer;
761 background-image:url('../images/close.png');
761 background-image:url('../images/close.png');
762 }
762 }
763
763
764 a.close-icon:hover {
764 a.close-icon:hover {
765 background-image:url('../images/close_hl.png');
765 background-image:url('../images/close_hl.png');
766 }
766 }
767
767
768 /***** Gantt chart *****/
768 /***** Gantt chart *****/
769 .gantt_hdr {
769 .gantt_hdr {
770 position:absolute;
770 position:absolute;
771 top:0;
771 top:0;
772 height:16px;
772 height:16px;
773 border-top: 1px solid #c0c0c0;
773 border-top: 1px solid #c0c0c0;
774 border-bottom: 1px solid #c0c0c0;
774 border-bottom: 1px solid #c0c0c0;
775 border-right: 1px solid #c0c0c0;
775 border-right: 1px solid #c0c0c0;
776 text-align: center;
776 text-align: center;
777 overflow: hidden;
777 overflow: hidden;
778 }
778 }
779
779
780 .task {
780 .task {
781 position: absolute;
781 position: absolute;
782 height:8px;
782 height:8px;
783 font-size:0.8em;
783 font-size:0.8em;
784 color:#888;
784 color:#888;
785 padding:0;
785 padding:0;
786 margin:0;
786 margin:0;
787 line-height:0.8em;
787 line-height:0.8em;
788 white-space:nowrap;
788 white-space:nowrap;
789 }
789 }
790
790
791 .task.label {width:100%;}
791 .task.label {width:100%;}
792
792
793 .task_late { background:#f66 url(../images/task_late.png); border: 1px solid #f66; }
793 .task_late { background:#f66 url(../images/task_late.png); border: 1px solid #f66; }
794 .task_done { background:#00c600 url(../images/task_done.png); border: 1px solid #00c600; }
794 .task_done { background:#00c600 url(../images/task_done.png); border: 1px solid #00c600; }
795 .task_todo { background:#aaa url(../images/task_todo.png); border: 1px solid #aaa; }
795 .task_todo { background:#aaa url(../images/task_todo.png); border: 1px solid #aaa; }
796
796
797 .task_todo.parent { background: #888; border: 1px solid #888; height: 6px;}
797 .task_todo.parent { background: #888; border: 1px solid #888; height: 6px;}
798 .task_late.parent, .task_done.parent { height: 3px;}
798 .task_late.parent, .task_done.parent { height: 3px;}
799 .task_todo.parent .left { position: absolute; background: url(../images/task_parent_end.png) no-repeat 0 0; width: 8px; height: 16px; margin-left: -5px; left: 0px; top: -1px;}
799 .task_todo.parent .left { position: absolute; background: url(../images/task_parent_end.png) no-repeat 0 0; width: 8px; height: 16px; margin-left: -5px; left: 0px; top: -1px;}
800 .task_todo.parent .right { position: absolute; background: url(../images/task_parent_end.png) no-repeat 0 0; width: 8px; height: 16px; margin-right: -5px; right: 0px; top: -1px;}
800 .task_todo.parent .right { position: absolute; background: url(../images/task_parent_end.png) no-repeat 0 0; width: 8px; height: 16px; margin-right: -5px; right: 0px; top: -1px;}
801
801
802 .milestone { background-image:url(../images/version_marker.png); background-repeat: no-repeat; border: 0; }
802 .milestone { background-image:url(../images/version_marker.png); background-repeat: no-repeat; border: 0; }
803 .milestone_late { background:#f66 url(../images/milestone_late.png); border: 1px solid #f66; height: 2px; margin-top: 3px;}
803 .milestone_late { background:#f66 url(../images/milestone_late.png); border: 1px solid #f66; height: 2px; margin-top: 3px;}
804 .milestone_done { background:#00c600 url(../images/milestone_done.png); border: 1px solid #00c600; height: 2px; margin-top: 3px;}
804 .milestone_done { background:#00c600 url(../images/milestone_done.png); border: 1px solid #00c600; height: 2px; margin-top: 3px;}
805 .milestone_todo { background:#fff url(../images/milestone_todo.png); border: 1px solid #fff; height: 2px; margin-top: 3px;}
805 .milestone_todo { background:#fff url(../images/milestone_todo.png); border: 1px solid #fff; height: 2px; margin-top: 3px;}
806 .project-line { background-image:url(../images/project_marker.png); background-repeat: no-repeat; border: 0; }
806 .project-line { background-image:url(../images/project_marker.png); background-repeat: no-repeat; border: 0; }
807 .project_late { background:#f66 url(../images/milestone_late.png); border: 1px solid #f66; height: 2px; margin-top: 3px;}
807 .project_late { background:#f66 url(../images/milestone_late.png); border: 1px solid #f66; height: 2px; margin-top: 3px;}
808 .project_done { background:#00c600 url(../images/milestone_done.png); border: 1px solid #00c600; height: 2px; margin-top: 3px;}
808 .project_done { background:#00c600 url(../images/milestone_done.png); border: 1px solid #00c600; height: 2px; margin-top: 3px;}
809 .project_todo { background:#fff url(../images/milestone_todo.png); border: 1px solid #fff; height: 2px; margin-top: 3px;}
809 .project_todo { background:#fff url(../images/milestone_todo.png); border: 1px solid #fff; height: 2px; margin-top: 3px;}
810
810
811 .version-behind-schedule a, .issue-behind-schedule a {color: #f66914;}
811 .version-behind-schedule a, .issue-behind-schedule a {color: #f66914;}
812 .version-overdue a, .issue-overdue a, .project-overdue a {color: #f00;}
812 .version-overdue a, .issue-overdue a, .project-overdue a {color: #f00;}
813
813
814 /***** Icons *****/
814 /***** Icons *****/
815 .icon {
815 .icon {
816 background-position: 0% 50%;
816 background-position: 0% 50%;
817 background-repeat: no-repeat;
817 background-repeat: no-repeat;
818 padding-left: 20px;
818 padding-left: 20px;
819 padding-top: 2px;
819 padding-top: 2px;
820 padding-bottom: 3px;
820 padding-bottom: 3px;
821 }
821 }
822
822
823 .icon-add { background-image: url(../images/add.png); }
823 .icon-add { background-image: url(../images/add.png); }
824 .icon-edit { background-image: url(../images/edit.png); }
824 .icon-edit { background-image: url(../images/edit.png); }
825 .icon-copy { background-image: url(../images/copy.png); }
825 .icon-copy { background-image: url(../images/copy.png); }
826 .icon-duplicate { background-image: url(../images/duplicate.png); }
826 .icon-duplicate { background-image: url(../images/duplicate.png); }
827 .icon-del { background-image: url(../images/delete.png); }
827 .icon-del { background-image: url(../images/delete.png); }
828 .icon-move { background-image: url(../images/move.png); }
828 .icon-move { background-image: url(../images/move.png); }
829 .icon-save { background-image: url(../images/save.png); }
829 .icon-save { background-image: url(../images/save.png); }
830 .icon-cancel { background-image: url(../images/cancel.png); }
830 .icon-cancel { background-image: url(../images/cancel.png); }
831 .icon-multiple { background-image: url(../images/table_multiple.png); }
831 .icon-multiple { background-image: url(../images/table_multiple.png); }
832 .icon-folder { background-image: url(../images/folder.png); }
832 .icon-folder { background-image: url(../images/folder.png); }
833 .open .icon-folder { background-image: url(../images/folder_open.png); }
833 .open .icon-folder { background-image: url(../images/folder_open.png); }
834 .icon-package { background-image: url(../images/package.png); }
834 .icon-package { background-image: url(../images/package.png); }
835 .icon-home { background-image: url(../images/home.png); }
835 .icon-home { background-image: url(../images/home.png); }
836 .icon-user { background-image: url(../images/user.png); }
836 .icon-user { background-image: url(../images/user.png); }
837 .icon-projects { background-image: url(../images/projects.png); }
837 .icon-projects { background-image: url(../images/projects.png); }
838 .icon-help { background-image: url(../images/help.png); }
838 .icon-help { background-image: url(../images/help.png); }
839 .icon-attachment { background-image: url(../images/attachment.png); }
839 .icon-attachment { background-image: url(../images/attachment.png); }
840 .icon-history { background-image: url(../images/history.png); }
840 .icon-history { background-image: url(../images/history.png); }
841 .icon-time { background-image: url(../images/time.png); }
841 .icon-time { background-image: url(../images/time.png); }
842 .icon-time-add { background-image: url(../images/time_add.png); }
842 .icon-time-add { background-image: url(../images/time_add.png); }
843 .icon-stats { background-image: url(../images/stats.png); }
843 .icon-stats { background-image: url(../images/stats.png); }
844 .icon-warning { background-image: url(../images/warning.png); }
844 .icon-warning { background-image: url(../images/warning.png); }
845 .icon-fav { background-image: url(../images/fav.png); }
845 .icon-fav { background-image: url(../images/fav.png); }
846 .icon-fav-off { background-image: url(../images/fav_off.png); }
846 .icon-fav-off { background-image: url(../images/fav_off.png); }
847 .icon-reload { background-image: url(../images/reload.png); }
847 .icon-reload { background-image: url(../images/reload.png); }
848 .icon-lock { background-image: url(../images/locked.png); }
848 .icon-lock { background-image: url(../images/locked.png); }
849 .icon-unlock { background-image: url(../images/unlock.png); }
849 .icon-unlock { background-image: url(../images/unlock.png); }
850 .icon-checked { background-image: url(../images/true.png); }
850 .icon-checked { background-image: url(../images/true.png); }
851 .icon-details { background-image: url(../images/zoom_in.png); }
851 .icon-details { background-image: url(../images/zoom_in.png); }
852 .icon-report { background-image: url(../images/report.png); }
852 .icon-report { background-image: url(../images/report.png); }
853 .icon-comment { background-image: url(../images/comment.png); }
853 .icon-comment { background-image: url(../images/comment.png); }
854 .icon-summary { background-image: url(../images/lightning.png); }
854 .icon-summary { background-image: url(../images/lightning.png); }
855 .icon-server-authentication { background-image: url(../images/server_key.png); }
855 .icon-server-authentication { background-image: url(../images/server_key.png); }
856 .icon-issue { background-image: url(../images/ticket.png); }
856 .icon-issue { background-image: url(../images/ticket.png); }
857 .icon-zoom-in { background-image: url(../images/zoom_in.png); }
858 .icon-zoom-out { background-image: url(../images/zoom_out.png); }
857
859
858 .icon-file { background-image: url(../images/files/default.png); }
860 .icon-file { background-image: url(../images/files/default.png); }
859 .icon-file.text-plain { background-image: url(../images/files/text.png); }
861 .icon-file.text-plain { background-image: url(../images/files/text.png); }
860 .icon-file.text-x-c { background-image: url(../images/files/c.png); }
862 .icon-file.text-x-c { background-image: url(../images/files/c.png); }
861 .icon-file.text-x-csharp { background-image: url(../images/files/csharp.png); }
863 .icon-file.text-x-csharp { background-image: url(../images/files/csharp.png); }
862 .icon-file.text-x-php { background-image: url(../images/files/php.png); }
864 .icon-file.text-x-php { background-image: url(../images/files/php.png); }
863 .icon-file.text-x-ruby { background-image: url(../images/files/ruby.png); }
865 .icon-file.text-x-ruby { background-image: url(../images/files/ruby.png); }
864 .icon-file.text-xml { background-image: url(../images/files/xml.png); }
866 .icon-file.text-xml { background-image: url(../images/files/xml.png); }
865 .icon-file.image-gif { background-image: url(../images/files/image.png); }
867 .icon-file.image-gif { background-image: url(../images/files/image.png); }
866 .icon-file.image-jpeg { background-image: url(../images/files/image.png); }
868 .icon-file.image-jpeg { background-image: url(../images/files/image.png); }
867 .icon-file.image-png { background-image: url(../images/files/image.png); }
869 .icon-file.image-png { background-image: url(../images/files/image.png); }
868 .icon-file.image-tiff { background-image: url(../images/files/image.png); }
870 .icon-file.image-tiff { background-image: url(../images/files/image.png); }
869 .icon-file.application-pdf { background-image: url(../images/files/pdf.png); }
871 .icon-file.application-pdf { background-image: url(../images/files/pdf.png); }
870 .icon-file.application-zip { background-image: url(../images/files/zip.png); }
872 .icon-file.application-zip { background-image: url(../images/files/zip.png); }
871 .icon-file.application-x-gzip { background-image: url(../images/files/zip.png); }
873 .icon-file.application-x-gzip { background-image: url(../images/files/zip.png); }
872
874
873 img.gravatar {
875 img.gravatar {
874 padding: 2px;
876 padding: 2px;
875 border: solid 1px #d5d5d5;
877 border: solid 1px #d5d5d5;
876 background: #fff;
878 background: #fff;
877 }
879 }
878
880
879 div.issue img.gravatar {
881 div.issue img.gravatar {
880 float: right;
882 float: right;
881 margin: 0 0 0 1em;
883 margin: 0 0 0 1em;
882 padding: 5px;
884 padding: 5px;
883 }
885 }
884
886
885 div.issue table img.gravatar {
887 div.issue table img.gravatar {
886 height: 14px;
888 height: 14px;
887 width: 14px;
889 width: 14px;
888 padding: 2px;
890 padding: 2px;
889 float: left;
891 float: left;
890 margin: 0 0.5em 0 0;
892 margin: 0 0.5em 0 0;
891 }
893 }
892
894
893 h2 img.gravatar {
895 h2 img.gravatar {
894 padding: 3px;
896 padding: 3px;
895 margin: -2px 4px -4px 0;
897 margin: -2px 4px -4px 0;
896 vertical-align: top;
898 vertical-align: top;
897 }
899 }
898
900
899 h4 img.gravatar {
901 h4 img.gravatar {
900 padding: 3px;
902 padding: 3px;
901 margin: -6px 0 -4px 0;
903 margin: -6px 0 -4px 0;
902 vertical-align: top;
904 vertical-align: top;
903 }
905 }
904
906
905 td.username img.gravatar {
907 td.username img.gravatar {
906 float: left;
908 float: left;
907 margin: 0 1em 0 0;
909 margin: 0 1em 0 0;
908 }
910 }
909
911
910 #activity dt img.gravatar {
912 #activity dt img.gravatar {
911 float: left;
913 float: left;
912 margin: 0 1em 1em 0;
914 margin: 0 1em 1em 0;
913 }
915 }
914
916
915 /* Used on 12px Gravatar img tags without the icon background */
917 /* Used on 12px Gravatar img tags without the icon background */
916 .icon-gravatar {
918 .icon-gravatar {
917 float: left;
919 float: left;
918 margin-right: 4px;
920 margin-right: 4px;
919 }
921 }
920
922
921 #activity dt,
923 #activity dt,
922 .journal {
924 .journal {
923 clear: left;
925 clear: left;
924 }
926 }
925
927
926 .journal-link {
928 .journal-link {
927 float: right;
929 float: right;
928 }
930 }
929
931
930 h2 img { vertical-align:middle; }
932 h2 img { vertical-align:middle; }
931
933
932 .hascontextmenu { cursor: context-menu; }
934 .hascontextmenu { cursor: context-menu; }
933
935
934 /***** Media print specific styles *****/
936 /***** Media print specific styles *****/
935 @media print {
937 @media print {
936 #top-menu, #header, #main-menu, #sidebar, #footer, .contextual, .other-formats { display:none; }
938 #top-menu, #header, #main-menu, #sidebar, #footer, .contextual, .other-formats { display:none; }
937 #main { background: #fff; }
939 #main { background: #fff; }
938 #content { width: 99%; margin: 0; padding: 0; border: 0; background: #fff; overflow: visible !important;}
940 #content { width: 99%; margin: 0; padding: 0; border: 0; background: #fff; overflow: visible !important;}
939 #wiki_add_attachment { display:none; }
941 #wiki_add_attachment { display:none; }
940 .hide-when-print { display: none; }
942 .hide-when-print { display: none; }
941 }
943 }
General Comments 0
You need to be logged in to leave comments. Login now