You've already forked baupm-core
Compare commits
17 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| addeeee529 | |||
| 873a7e5227 | |||
| 555a1ceae2 | |||
| 2c41a29947 | |||
| 090b017863 | |||
| 6f99277ebe | |||
| baa32f709f | |||
| ae1e67d73e | |||
| d2f56ad7c6 | |||
| 250bdc6740 | |||
| abe0407086 | |||
| 8c21f5164d | |||
| a2766c70cd | |||
| 286c29ce44 | |||
| 4cd0396c95 | |||
| 1c4ebe2d22 | |||
| 6452e561ef |
14
.dbdiff
14
.dbdiff
@@ -1,14 +0,0 @@
|
|||||||
server1:
|
|
||||||
user: user
|
|
||||||
password: password
|
|
||||||
port: 3306
|
|
||||||
host: 127.0.0.1
|
|
||||||
server2:
|
|
||||||
user: user
|
|
||||||
password: password
|
|
||||||
port: 3306
|
|
||||||
host: 127.0.0.1
|
|
||||||
template: ./.migrate.tmpl
|
|
||||||
type: all
|
|
||||||
include: all
|
|
||||||
nocomments: true
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
SQL_UP = u"""
|
|
||||||
{{ $up }}
|
|
||||||
"""
|
|
||||||
|
|
||||||
SQL_DOWN = u"""
|
|
||||||
{{ $down }}
|
|
||||||
"""
|
|
||||||
|
|
||||||
9
app/controllers/healthcheck_controller.rb
Normal file
9
app/controllers/healthcheck_controller.rb
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
class HealthcheckController < ApplicationController
|
||||||
|
unloadable
|
||||||
|
|
||||||
|
skip_before_action :check_if_login_required
|
||||||
|
|
||||||
|
def index
|
||||||
|
render :layout => false, :action => 'index'
|
||||||
|
end
|
||||||
|
end
|
||||||
2
app/helpers/healthcheck_helper.rb
Normal file
2
app/helpers/healthcheck_helper.rb
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
module HealthcheckHelper
|
||||||
|
end
|
||||||
8
app/views/admin/index.html.erb
Normal file
8
app/views/admin/index.html.erb
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
<h2><%=l(:label_administration)%></h2>
|
||||||
|
|
||||||
|
<div id="admin-index">
|
||||||
|
<%= render :partial => 'no_data' if @no_configuration_data %>
|
||||||
|
<%= render :partial => 'menu' %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<% html_title(l(:label_administration)) -%>
|
||||||
66
app/views/calendars/show.html.erb
Normal file
66
app/views/calendars/show.html.erb
Normal file
@@ -0,0 +1,66 @@
|
|||||||
|
<h2><%= @query.new_record? ? l(:label_calendar) : @query.name %></h2>
|
||||||
|
|
||||||
|
<%= form_tag({:controller => 'calendars', :action => 'show', :project_id => @project},
|
||||||
|
:method => :get, :id => 'query_form') do %>
|
||||||
|
<%= hidden_field_tag 'set_filter', '1' %>
|
||||||
|
<%= hidden_field_tag 'calendar', '1' %>
|
||||||
|
|
||||||
|
<div id="query_form_with_buttons" class="hide-when-print">
|
||||||
|
<div id="query_form_content">
|
||||||
|
<fieldset id="filters" class="collapsible <%= @query.new_record? ? "" : "collapsed" %>">
|
||||||
|
<legend onclick="toggleFieldset(this);" class="icon icon-<%= @query.new_record? ? "expanded" : "collapsed" %>"><%= l(:label_filter_plural) %></legend>
|
||||||
|
<div style="<%= @query.new_record? ? "" : "display: none;" %>">
|
||||||
|
<%= render :partial => 'queries/filters', :locals => {:query => @query} %>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<span class="contextual pagination">
|
||||||
|
<ul class="pages">
|
||||||
|
<li class="previous page">
|
||||||
|
<%= link_to_previous_month(@year, @month, :accesskey => accesskey(:previous)) %>
|
||||||
|
</li><li class="next page">
|
||||||
|
<%= link_to_next_month(@year, @month, :accesskey => accesskey(:next)) %>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</span>
|
||||||
|
|
||||||
|
<p class="buttons">
|
||||||
|
<%= label_tag('month', l(:label_month)) %>
|
||||||
|
<%= select_month(@month, :prefix => "month", :discard_type => true) %>
|
||||||
|
<%= label_tag('year', l(:label_year)) %>
|
||||||
|
<%= select_year(@year, :prefix => "year", :discard_type => true) %>
|
||||||
|
|
||||||
|
<%= link_to_function l(:button_apply), '$("#query_form").submit()', :class => 'icon icon-checked' %>
|
||||||
|
<%= link_to l(:button_clear), { :project_id => @project, :set_filter => 1 }, :class => 'icon icon-reload' %>
|
||||||
|
<% if @query.new_record? && User.current.allowed_to?(:save_queries, @project, :global => true) %>
|
||||||
|
<%= link_to_function l(:button_save_object, object_name: l(:label_query)),
|
||||||
|
"$('#query_form').attr('action', '#{ @project ? new_project_query_path(@project) : new_query_path }').submit();",
|
||||||
|
:class => 'icon icon-save' %>
|
||||||
|
<% end %>
|
||||||
|
<% if !@query.new_record? && @query.editable_by?(User.current) %>
|
||||||
|
<%= link_to l(:button_edit_object, object_name: l(:label_query)), edit_query_path(@query, :calendar => 1), :class => 'icon icon-edit' %>
|
||||||
|
<%= delete_link query_path(@query, :calendar => 1), {}, l(:button_delete_object, object_name: l(:label_query)) %>
|
||||||
|
<% end %>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<%= error_messages_for 'query' %>
|
||||||
|
<% if @query.valid? %>
|
||||||
|
<%= render :partial => 'common/calendar', :locals => {:calendar => @calendar} %>
|
||||||
|
|
||||||
|
<%= call_hook(:view_calendars_show_bottom, :year => @year, :month => @month, :project => @project, :query => @query) %>
|
||||||
|
|
||||||
|
<p class="legend cal">
|
||||||
|
<span class="starting"><%= l(:text_tip_issue_begin_day) %></span>
|
||||||
|
<span class="ending"><%= l(:text_tip_issue_end_day) %></span>
|
||||||
|
<span class="starting ending"><%= l(:text_tip_issue_begin_end_day) %></span>
|
||||||
|
</p>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% content_for :sidebar do %>
|
||||||
|
<%= render :partial => 'issues/sidebar' %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% html_title(l(:label_calendar)) -%>
|
||||||
430
app/views/gantts/show.html.erb
Normal file
430
app/views/gantts/show.html.erb
Normal file
@@ -0,0 +1,430 @@
|
|||||||
|
<% @gantt.view = self %>
|
||||||
|
<div class="contextual">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<h2><%= @query.new_record? ? l(:label_gantt) : @query.name %></h2>
|
||||||
|
|
||||||
|
<%= form_tag({:controller => 'gantts', :action => 'show',
|
||||||
|
:project_id => @project, :month => params[:month],
|
||||||
|
:year => params[:year], :months => params[:months]},
|
||||||
|
:method => :get, :id => 'query_form') do %>
|
||||||
|
<%= hidden_field_tag 'set_filter', '1' %>
|
||||||
|
<%= hidden_field_tag 'gantt', '1' %>
|
||||||
|
|
||||||
|
<div id="query_form_with_buttons" class="hide-when-print">
|
||||||
|
<div id="query_form_content">
|
||||||
|
<fieldset id="filters" class="collapsible <%= @query.new_record? ? "" : "collapsed" %>">
|
||||||
|
<legend onclick="toggleFieldset(this);" class="icon icon-<%= @query.new_record? ? "expanded" : "collapsed" %>"><%= l(:label_filter_plural) %></legend>
|
||||||
|
<div style="<%= @query.new_record? ? "" : "display: none;" %>">
|
||||||
|
<%= render :partial => 'queries/filters', :locals => {:query => @query} %>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
|
||||||
|
<fieldset id="options" class="collapsible collapsed">
|
||||||
|
<legend onclick="toggleFieldset(this);" class="icon icon-collapsed"><%= l(:label_options) %></legend>
|
||||||
|
<div style="display: none;">
|
||||||
|
<table>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<fieldset>
|
||||||
|
<legend>
|
||||||
|
<%= l(:field_column_names) %>
|
||||||
|
</legend>
|
||||||
|
<label for="draw_selected_columns">
|
||||||
|
<%= check_box 'query', 'draw_selected_columns', :id => 'draw_selected_columns', 'data-enables' => 'span.query-columns select, span.query-columns input' %>
|
||||||
|
<%= l(:label_display) %>
|
||||||
|
</label>
|
||||||
|
<%= render_query_columns_selection(@query) %>
|
||||||
|
</fieldset>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<fieldset>
|
||||||
|
<legend><%= l(:label_related_issues) %></legend>
|
||||||
|
<label for="draw_relations">
|
||||||
|
<%= check_box 'query', 'draw_relations', :id => 'draw_relations' %>
|
||||||
|
<% rels = [IssueRelation::TYPE_BLOCKS, IssueRelation::TYPE_PRECEDES] %>
|
||||||
|
<% rels.each do |rel| %>
|
||||||
|
<% color = Redmine::Helpers::Gantt::DRAW_TYPES[rel][:color] %>
|
||||||
|
<%= content_tag(:span, ' '.html_safe,
|
||||||
|
:style => "background-color: #{color}") %>
|
||||||
|
<%= l(IssueRelation::TYPES[rel][:name]) %>
|
||||||
|
<% end %>
|
||||||
|
</label>
|
||||||
|
</fieldset>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<fieldset>
|
||||||
|
<legend><%= l(:label_gantt_progress_line) %></legend>
|
||||||
|
<label for="draw_progress_line">
|
||||||
|
<%= check_box 'query', 'draw_progress_line', :id => 'draw_progress_line' %>
|
||||||
|
<%= l(:label_display) %>
|
||||||
|
</label>
|
||||||
|
</fieldset>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<p class="contextual">
|
||||||
|
<span>
|
||||||
|
<%= gantt_zoom_link(@gantt, :in) %>
|
||||||
|
<%= gantt_zoom_link(@gantt, :out) %>
|
||||||
|
</span>
|
||||||
|
<span>
|
||||||
|
<%= link_to_previous_month(@gantt.year_from, @gantt.month_from, :accesskey => accesskey(:previous)) %> | <%= link_to_next_month(@gantt.year_from, @gantt.month_from, :accesskey => accesskey(:next)) %>
|
||||||
|
</span>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<p class="buttons">
|
||||||
|
<%= number_field_tag 'months', @gantt.months, :min => 1, :max => Setting.gantt_months_limit.to_i, :autocomplete => false %>
|
||||||
|
<%= l(:label_months_from) %>
|
||||||
|
<%= select_month(@gantt.month_from, :prefix => "month", :discard_type => true) %>
|
||||||
|
<%= select_year(@gantt.year_from, :prefix => "year", :discard_type => true) %>
|
||||||
|
<%= hidden_field_tag 'zoom', @gantt.zoom %>
|
||||||
|
|
||||||
|
<%= link_to_function l(:button_apply), '$("#query_form").submit()',
|
||||||
|
:class => 'icon icon-checked' %>
|
||||||
|
<%= link_to l(:button_clear), { :project_id => @project, :set_filter => 1 },
|
||||||
|
:class => 'icon icon-reload' %>
|
||||||
|
<% if @query.new_record? && User.current.allowed_to?(:save_queries, @project, :global => true) %>
|
||||||
|
<%= link_to_function l(:button_save_object, object_name: l(:label_query)),
|
||||||
|
"$('#query_form').attr('action', '#{ @project ? new_project_query_path(@project) : new_query_path }').submit();",
|
||||||
|
:class => 'icon icon-save' %>
|
||||||
|
<% end %>
|
||||||
|
<% if !@query.new_record? && @query.editable_by?(User.current) %>
|
||||||
|
<%= link_to l(:button_edit_object, object_name: l(:label_query)), edit_query_path(@query, :gantt => 1), :class => 'icon icon-edit' %>
|
||||||
|
<%= delete_link query_path(@query, :gantt => 1), {}, l(:button_delete_object, object_name: l(:label_query)) %>
|
||||||
|
<% end %>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<%= error_messages_for 'query' %>
|
||||||
|
<% if @query.valid? %>
|
||||||
|
<%
|
||||||
|
zoom = 1
|
||||||
|
@gantt.zoom.times { zoom = zoom * 2 }
|
||||||
|
|
||||||
|
subject_width = 330
|
||||||
|
header_height = 18
|
||||||
|
|
||||||
|
headers_height = header_height
|
||||||
|
show_weeks = false
|
||||||
|
show_days = false
|
||||||
|
show_day_num = false
|
||||||
|
|
||||||
|
if @gantt.zoom > 1
|
||||||
|
show_weeks = true
|
||||||
|
headers_height = 2 * header_height
|
||||||
|
if @gantt.zoom > 2
|
||||||
|
show_days = true
|
||||||
|
headers_height = 3 * header_height
|
||||||
|
if @gantt.zoom > 3
|
||||||
|
show_day_num = true
|
||||||
|
headers_height = 4 * header_height
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# Width of the entire chart
|
||||||
|
g_width = ((@gantt.date_to - @gantt.date_from + 1) * zoom).to_i
|
||||||
|
@gantt.render(:top => headers_height + 8,
|
||||||
|
:zoom => zoom,
|
||||||
|
:g_width => g_width,
|
||||||
|
:subject_width => subject_width)
|
||||||
|
g_height = [(20 * (@gantt.number_of_rows + 6)) + 150, 206].max
|
||||||
|
t_height = g_height + headers_height
|
||||||
|
%>
|
||||||
|
|
||||||
|
<% if @gantt.truncated %>
|
||||||
|
<p class="warning"><%= l(:notice_gantt_chart_truncated, :max => @gantt.max_rows) %></p>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<table class='gantt-table'>
|
||||||
|
<tr>
|
||||||
|
<td style="width:<%= @query.draw_selected_columns ? subject_width + 1 : subject_width + 2 %>px;" class="gantt_subjects_column">
|
||||||
|
<%
|
||||||
|
style = ""
|
||||||
|
style += "position:relative;"
|
||||||
|
style += "height: #{t_height + 24}px;"
|
||||||
|
style += "width: #{subject_width + 1}px;"
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, :style => style, :class => "gantt_subjects_container #{'draw_selected_columns' if @query.draw_selected_columns}") do %>
|
||||||
|
<%
|
||||||
|
style = ""
|
||||||
|
style += "width: #{subject_width + 1}px;"
|
||||||
|
style += "height: #{headers_height}px;"
|
||||||
|
style += 'background: #eee;'
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, "", :style => style, :class => "gantt_hdr") %>
|
||||||
|
<%
|
||||||
|
style = ""
|
||||||
|
style += "z-index: 1;"
|
||||||
|
style += "width: #{subject_width + 1}px;"
|
||||||
|
style += "height: #{t_height}px;"
|
||||||
|
style += 'overflow: hidden;'
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, "", :style => style, :class => "gantt_hdr") %>
|
||||||
|
<%= content_tag(:div, :class => "gantt_subjects") do %>
|
||||||
|
<%= form_tag({}, :data => {:cm_url => issues_context_menu_path}) do -%>
|
||||||
|
<%= hidden_field_tag 'back_url', url_for(:params => request.query_parameters), :id => nil %>
|
||||||
|
<%= @gantt.subjects.html_safe %>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
</td>
|
||||||
|
<%
|
||||||
|
@query.columns.each do |column|
|
||||||
|
next if Redmine::Helpers::Gantt::UNAVAILABLE_COLUMNS.include?(column.name)
|
||||||
|
column_name = column.name.to_s.tr('.', '_')
|
||||||
|
%>
|
||||||
|
<td class="gantt_<%= column_name %>_column gantt_selected_column <%= 'last_gantt_selected_column' if @query.columns.last == column %>" id="<%= column_name %>">
|
||||||
|
<%
|
||||||
|
style = "position: relative;"
|
||||||
|
style += "height: #{t_height + 24}px;"
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, :style => style, :class => "gantt_#{column_name}_container gantt_selected_column_container") do %>
|
||||||
|
<%
|
||||||
|
style = "height: #{t_height}px;"
|
||||||
|
style += 'overflow: hidden;'
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, '', :style => style, :class => "gantt_hdr") %>
|
||||||
|
<%
|
||||||
|
style = "height: #{headers_height}px;"
|
||||||
|
style += 'background: #eee;'
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, content_tag(:p, column.caption, :class => 'gantt_hdr_selected_column_name'), :style => style, :class => "gantt_hdr") %>
|
||||||
|
<%= content_tag(:div, :class => "gantt_#{column_name} gantt_selected_column_content") do %>
|
||||||
|
<%= @gantt.selected_column_content({:column => column, :top => headers_height + 8, :zoom => zoom, :g_width => g_width}).html_safe %>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
</td>
|
||||||
|
<% end %>
|
||||||
|
<td>
|
||||||
|
<div style="position:relative;height:<%= t_height + 24 %>px;overflow:auto;" id="gantt_area">
|
||||||
|
<%
|
||||||
|
style = ""
|
||||||
|
style += "width: #{g_width - 1}px;"
|
||||||
|
style += "height: #{headers_height}px;"
|
||||||
|
style += 'background: #eee;'
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, ' '.html_safe, :style => style, :class => "gantt_hdr") %>
|
||||||
|
|
||||||
|
<% ###### Months headers ###### %>
|
||||||
|
<%
|
||||||
|
month_f = @gantt.date_from
|
||||||
|
left = 0
|
||||||
|
height = (show_weeks ? header_height : header_height + g_height)
|
||||||
|
%>
|
||||||
|
<% @gantt.months.times do %>
|
||||||
|
<%
|
||||||
|
width = (((month_f >> 1) - month_f) * zoom - 1).to_i
|
||||||
|
style = ""
|
||||||
|
style += "left: #{left}px;"
|
||||||
|
style += "width: #{width}px;"
|
||||||
|
style += "height: #{height}px;"
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, :style => style, :class => "gantt_hdr") do %>
|
||||||
|
<%= 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}" %>
|
||||||
|
<% end %>
|
||||||
|
<%
|
||||||
|
left = left + width + 1
|
||||||
|
month_f = month_f >> 1
|
||||||
|
%>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% ###### Weeks headers ###### %>
|
||||||
|
<% if show_weeks %>
|
||||||
|
<%
|
||||||
|
left = 0
|
||||||
|
height = (show_days ? header_height - 1 : header_height - 1 + g_height)
|
||||||
|
%>
|
||||||
|
<% if @gantt.date_from.cwday == 1 %>
|
||||||
|
<%
|
||||||
|
# @date_from is monday
|
||||||
|
week_f = @gantt.date_from
|
||||||
|
%>
|
||||||
|
<% else %>
|
||||||
|
<%
|
||||||
|
# find next monday after @date_from
|
||||||
|
week_f = @gantt.date_from + (7 - @gantt.date_from.cwday + 1)
|
||||||
|
width = (7 - @gantt.date_from.cwday + 1) * zoom - 1
|
||||||
|
style = ""
|
||||||
|
style += "left: #{left}px;"
|
||||||
|
style += "top: 19px;"
|
||||||
|
style += "width: #{width}px;"
|
||||||
|
style += "height: #{height}px;"
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, ' '.html_safe,
|
||||||
|
:style => style, :class => "gantt_hdr") %>
|
||||||
|
<% left = left + width + 1 %>
|
||||||
|
<% end %>
|
||||||
|
<% while week_f <= @gantt.date_to %>
|
||||||
|
<%
|
||||||
|
width = ((week_f + 6 <= @gantt.date_to) ?
|
||||||
|
7 * zoom - 1 :
|
||||||
|
(@gantt.date_to - week_f + 1) * zoom - 1).to_i
|
||||||
|
style = ""
|
||||||
|
style += "left: #{left}px;"
|
||||||
|
style += "top: 19px;"
|
||||||
|
style += "width: #{width}px;"
|
||||||
|
style += "height: #{height}px;"
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, :style => style, :class => "gantt_hdr") do %>
|
||||||
|
<%= content_tag(:small) do %>
|
||||||
|
<%= week_f.cweek if width >= 16 %>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
<%
|
||||||
|
left = left + width + 1
|
||||||
|
week_f = week_f + 7
|
||||||
|
%>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% ###### Day numbers headers ###### %>
|
||||||
|
<% if show_day_num %>
|
||||||
|
<%
|
||||||
|
left = 0
|
||||||
|
height = g_height + header_height*2 - 1
|
||||||
|
wday = @gantt.date_from.cwday
|
||||||
|
day_num = @gantt.date_from
|
||||||
|
%>
|
||||||
|
<% (@gantt.date_to - @gantt.date_from + 1).to_i.times do %>
|
||||||
|
<%
|
||||||
|
width = zoom - 1
|
||||||
|
style = ""
|
||||||
|
style += "left:#{left}px;"
|
||||||
|
style += "top:37px;"
|
||||||
|
style += "width:#{width}px;"
|
||||||
|
style += "height:#{height}px;"
|
||||||
|
style += "font-size:0.7em;"
|
||||||
|
clss = "gantt_hdr"
|
||||||
|
clss << " nwday" if @gantt.non_working_week_days.include?(wday)
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, :style => style, :class => clss) do %>
|
||||||
|
<%= day_num.day %>
|
||||||
|
<% end %>
|
||||||
|
<%
|
||||||
|
left = left + width+1
|
||||||
|
day_num = day_num + 1
|
||||||
|
wday = wday + 1
|
||||||
|
wday = 1 if wday > 7
|
||||||
|
%>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% ###### Days headers ####### %>
|
||||||
|
<% if show_days %>
|
||||||
|
<%
|
||||||
|
left = 0
|
||||||
|
height = g_height + header_height - 1
|
||||||
|
top = (show_day_num ? 55 : 37)
|
||||||
|
%>
|
||||||
|
<% (@gantt.date_from..@gantt.date_to).each do |g_date| %>
|
||||||
|
<%
|
||||||
|
width = zoom - 1
|
||||||
|
style = ""
|
||||||
|
style += "left: #{left}px;"
|
||||||
|
style += "top: #{top}px;"
|
||||||
|
style += "width: #{width}px;"
|
||||||
|
style += "height: #{height}px;"
|
||||||
|
style += "font-size:0.7em;"
|
||||||
|
clss = "gantt_hdr"
|
||||||
|
clss << " nwday" if @gantt.non_working_week_days.include?(g_date.cwday)
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, :style => style, :class => clss) do %>
|
||||||
|
<%= day_letter(g_date.cwday) %>
|
||||||
|
<% end %>
|
||||||
|
<%
|
||||||
|
left = left + width + 1
|
||||||
|
%>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<%= form_tag({}, :data => {:cm_url => issues_context_menu_path}) do -%>
|
||||||
|
<%= hidden_field_tag 'back_url', url_for(:params => request.query_parameters), :id => nil %>
|
||||||
|
<%= @gantt.lines.html_safe %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% ###### Today red line (excluded from cache) ###### %>
|
||||||
|
<% if User.current.today >= @gantt.date_from and User.current.today <= @gantt.date_to %>
|
||||||
|
<%
|
||||||
|
today_left = (((User.current.today - @gantt.date_from + 1) * zoom).floor() - 1).to_i
|
||||||
|
style = ""
|
||||||
|
style += "position: absolute;"
|
||||||
|
style += "height: #{g_height}px;"
|
||||||
|
style += "top: #{headers_height + 1}px;"
|
||||||
|
style += "left: #{today_left}px;"
|
||||||
|
style += "width:10px;"
|
||||||
|
style += "border-left: 1px dashed red;"
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, ' '.html_safe, :style => style, :id => 'today_line') %>
|
||||||
|
<% end %>
|
||||||
|
<%
|
||||||
|
style = ""
|
||||||
|
style += "position: absolute;"
|
||||||
|
style += "height: #{g_height}px;"
|
||||||
|
style += "top: #{headers_height + 1}px;"
|
||||||
|
style += "left: 0px;"
|
||||||
|
style += "width: #{g_width - 1}px;"
|
||||||
|
%>
|
||||||
|
<%= content_tag(:div, '', :style => style, :id => "gantt_draw_area") %>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<span class="pagination">
|
||||||
|
<ul class="pages">
|
||||||
|
<li class="previous page">
|
||||||
|
<%= link_to("\xc2\xab " + l(:label_previous),
|
||||||
|
{:params => request.query_parameters.merge(@gantt.params_previous)},
|
||||||
|
:accesskey => accesskey(:previous)) %>
|
||||||
|
</li><li class="next page">
|
||||||
|
<%= link_to(l(:label_next) + " \xc2\xbb",
|
||||||
|
{:params => request.query_parameters.merge(@gantt.params_next)},
|
||||||
|
:accesskey => accesskey(:next)) %>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</span>
|
||||||
|
|
||||||
|
<% other_formats_links do |f| %>
|
||||||
|
<%= f.link_to_with_query_parameters 'PDF', @gantt.params %>
|
||||||
|
<%= f.link_to_with_query_parameters('PNG', @gantt.params) if @gantt.respond_to?('to_image') %>
|
||||||
|
<% end %>
|
||||||
|
<% end # query.valid? %>
|
||||||
|
|
||||||
|
<% content_for :sidebar do %>
|
||||||
|
<%= render :partial => 'issues/sidebar' %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% html_title(l(:label_gantt)) -%>
|
||||||
|
|
||||||
|
<% content_for :header_tags do %>
|
||||||
|
<%= javascript_include_tag 'raphael' %>
|
||||||
|
<%= javascript_include_tag 'gantt' %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<%= javascript_tag do %>
|
||||||
|
var issue_relation_type = <%= raw Redmine::Helpers::Gantt::DRAW_TYPES.to_json %>;
|
||||||
|
$(function() {
|
||||||
|
disable_unavailable_columns('<%= Redmine::Helpers::Gantt::UNAVAILABLE_COLUMNS.map(&:to_s).join(',') %>'.split(','));
|
||||||
|
drawGanttHandler();
|
||||||
|
resizableSubjectColumn();
|
||||||
|
drawSelectedColumns();
|
||||||
|
$("#draw_relations, #draw_progress_line, #draw_selected_columns").change(drawGanttHandler);
|
||||||
|
$('div.gantt_subjects .expander').on('click', ganttEntryClick);
|
||||||
|
});
|
||||||
|
$(window).resize(function() {
|
||||||
|
drawGanttHandler();
|
||||||
|
resizableSubjectColumn();
|
||||||
|
});
|
||||||
|
<% end %>
|
||||||
|
<%= context_menu %>
|
||||||
1
app/views/healthcheck/index.html.erb
Normal file
1
app/views/healthcheck/index.html.erb
Normal file
@@ -0,0 +1 @@
|
|||||||
|
OK
|
||||||
88
app/views/queries/_query_form.html.erb
Normal file
88
app/views/queries/_query_form.html.erb
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
<%= hidden_field_tag 'set_filter', '1' %>
|
||||||
|
<%= hidden_field_tag 'type', @query.type, :disabled => true, :id => 'query_type' %>
|
||||||
|
<%= query_hidden_sort_tag(@query) %>
|
||||||
|
|
||||||
|
<div id="query_form_with_buttons" class="hide-when-print">
|
||||||
|
<div id="query_form_content">
|
||||||
|
<fieldset id="filters" class="collapsible <%= @query.new_record? ? "" : "collapsed" %>">
|
||||||
|
<legend onclick="toggleFieldset(this);" class="icon icon-<%= @query.new_record? ? "expanded" : "collapsed" %>"><%= l(:label_filter_plural) %></legend>
|
||||||
|
<div style="<%= @query.new_record? ? "" : "display: none;" %>">
|
||||||
|
<%= render :partial => 'queries/filters', :locals => {:query => @query} %>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
|
||||||
|
<% if @query.available_columns.any? %>
|
||||||
|
<fieldset id="options" class="collapsible collapsed">
|
||||||
|
<legend onclick="toggleFieldset(this);" class="icon icon-collapsed"><%= l(:label_options) %></legend>
|
||||||
|
<div class="hidden">
|
||||||
|
<% if @query.available_display_types.size > 1 %>
|
||||||
|
<div>
|
||||||
|
<span class="field"><label for='display_type'><%= l(:label_display_type) %></label></span>
|
||||||
|
<%= available_display_types_tags(@query) %>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
<table id="list-definition" class="<%= 'hidden' if (@query.display_type != 'list') %>">
|
||||||
|
<% if @query.available_columns.any? %>
|
||||||
|
<tr>
|
||||||
|
<td class="field"><%= l(:field_column_names) %></td>
|
||||||
|
<td><%= render_query_columns_selection(@query) %></td>
|
||||||
|
</tr>
|
||||||
|
<% end %>
|
||||||
|
<% if @query.groupable_columns.any? %>
|
||||||
|
<tr>
|
||||||
|
<td class="field"><label for='group_by'><%= l(:field_group_by) %></label></td>
|
||||||
|
<td><%= group_by_column_select_tag(@query) %></td>
|
||||||
|
</tr>
|
||||||
|
<% end %>
|
||||||
|
<% if @query.available_block_columns.any? %>
|
||||||
|
<tr>
|
||||||
|
<td class="field"><%= l(:button_show) %></td>
|
||||||
|
<td><%= available_block_columns_tags(@query) %></td>
|
||||||
|
</tr>
|
||||||
|
<% end %>
|
||||||
|
<% if @query.available_totalable_columns.any? %>
|
||||||
|
<tr>
|
||||||
|
<td><%= l(:label_total_plural) %></td>
|
||||||
|
<td><%= available_totalable_columns_tags(@query) %></td>
|
||||||
|
</tr>
|
||||||
|
<% end %>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<p class="buttons">
|
||||||
|
<%= link_to_function l(:button_apply), '$("#query_form").submit()', :class => 'icon icon-checked' %>
|
||||||
|
<%= link_to l(:button_clear), { :set_filter => 1, :sort => '', :project_id => @project }, :class => 'icon icon-reload' %>
|
||||||
|
<% if @query.new_record? %>
|
||||||
|
<% if User.current.allowed_to?(:save_queries, @project, :global => true) %>
|
||||||
|
<%= link_to_function l(:button_save_object, object_name: l(:label_query)),
|
||||||
|
"$('#query_type').prop('disabled',false);$('#query_form').attr('action', '#{ @project ? new_project_query_path(@project) : new_query_path }').submit()",
|
||||||
|
:class => 'icon icon-save' %>
|
||||||
|
<% end %>
|
||||||
|
<% else %>
|
||||||
|
<% if @query.editable_by?(User.current) %>
|
||||||
|
<% redirect_params = (controller_name == 'admin' && action_name == 'projects') ? {:admin_projects => 1} : {} %>
|
||||||
|
<%= link_to l(:button_edit_object, object_name: l(:label_query)), edit_query_path(@query, redirect_params), :class => 'icon icon-edit' %>
|
||||||
|
<%= delete_link query_path(@query, redirect_params), {}, l(:button_delete_object, object_name: l(:label_query)) %>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<%= error_messages_for @query %>
|
||||||
|
|
||||||
|
<%= javascript_tag do %>
|
||||||
|
$(function ($) {
|
||||||
|
$('input[name=display_type]').change(function (e) {
|
||||||
|
if ($("#display_type_list").is(':checked')) {
|
||||||
|
$('table#list-definition').show();
|
||||||
|
} else {
|
||||||
|
$('table#list-definition').hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
<% end %>
|
||||||
@@ -44,7 +44,7 @@
|
|||||||
color:#ffffff;
|
color:#ffffff;
|
||||||
font-size: 19px;
|
font-size: 19px;
|
||||||
box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
|
box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
|
||||||
transition:.3s;
|
transition:.3s;
|
||||||
pointer-events:all;
|
pointer-events:all;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
@@ -68,7 +68,7 @@ button.jfab_main_btn{
|
|||||||
color:#ffffff;
|
color:#ffffff;
|
||||||
font-size:24px;
|
font-size:24px;
|
||||||
box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
|
box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
|
||||||
transition:.3s;
|
transition:.3s;
|
||||||
-webkit-tap-highlight-color: rgba(0,0,0,0);
|
-webkit-tap-highlight-color: rgba(0,0,0,0);
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
pointer-events:all;
|
pointer-events:all;
|
||||||
@@ -81,6 +81,4 @@ button:hover.jfab_main_btn{
|
|||||||
}
|
}
|
||||||
.jfab_main_btn.rotate {
|
.jfab_main_btn.rotate {
|
||||||
transform:rotate(45deg);
|
transform:rotate(45deg);
|
||||||
-ms-transform: rotate(45deg);
|
}
|
||||||
-webkit-transform: rotate(45deg);
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -197,3 +197,21 @@ de:
|
|||||||
label_fieldset_default_state: Fieldset Default Status
|
label_fieldset_default_state: Fieldset Default Status
|
||||||
label_fieldset_state_all_expended: Alle ausklappen
|
label_fieldset_state_all_expended: Alle ausklappen
|
||||||
label_fieldset_state_all_collapsed: Alle einklappen
|
label_fieldset_state_all_collapsed: Alle einklappen
|
||||||
|
|
||||||
|
# Plugin EasyGantt
|
||||||
|
button_project_menu_easy_gantt: Gantt-Plan
|
||||||
|
easy_gantt_toolbar:
|
||||||
|
day: Tage
|
||||||
|
month: Monate
|
||||||
|
week: Wochen
|
||||||
|
quarter: Quartal
|
||||||
|
year: Jahre
|
||||||
|
easy_gantt:
|
||||||
|
buton_create_baseline: Basispläne
|
||||||
|
button_critical_path: Kritischer Weg
|
||||||
|
button:
|
||||||
|
quarter_zoom: Quartale
|
||||||
|
year_zoom: Jahre
|
||||||
|
easy_printable_templates_categories:
|
||||||
|
easy_gantt: Gantt-Plan
|
||||||
|
label_easy_gantt: Gantt-Plan
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
if Redmine::Plugin.installed? :baupm_core
|
if Redmine::Plugin.installed? :baupm_core
|
||||||
RedmineApp::Application.routes.draw do
|
RedmineApp::Application.routes.draw do
|
||||||
get '/manifest.json', :controller => 'manifest', :action => 'index', :as => 'manifest_json'
|
get '/manifest.json', :controller => 'manifest', :action => 'index', :as => 'manifest_json'
|
||||||
|
get '/_healthcheck', :controller => 'healthcheck', :action => 'index', :as => 'healthcheck'
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
42
init.rb
42
init.rb
@@ -10,7 +10,7 @@ Redmine::Plugin.register :baupm_core do
|
|||||||
author 'Marco Grätsch'
|
author 'Marco Grätsch'
|
||||||
author_url 'https://src.bundespruefstelle.ch/magdev'
|
author_url 'https://src.bundespruefstelle.ch/magdev'
|
||||||
description "Common modifications for BauPM"
|
description "Common modifications for BauPM"
|
||||||
version '0.2.1'
|
version '0.2.3'
|
||||||
|
|
||||||
requires_redmine :version_or_higher => '4.1.0'
|
requires_redmine :version_or_higher => '4.1.0'
|
||||||
|
|
||||||
@@ -26,3 +26,43 @@ Redmine::Plugin.register :baupm_core do
|
|||||||
'baupm_enable_webapp' => '1'
|
'baupm_enable_webapp' => '1'
|
||||||
}, :partial => 'settings/baupm_settings'
|
}, :partial => 'settings/baupm_settings'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Redmine::WikiFormatting::Macros.register do
|
||||||
|
desc <<-DESCRIPTION
|
||||||
|
Embed video attachments
|
||||||
|
|
||||||
|
{{video(attachment.mp4)}} show video with default size 640x360
|
||||||
|
{{video(attachment.mp4, width=480, height=320)}} show video with size 480x320
|
||||||
|
DESCRIPTION
|
||||||
|
|
||||||
|
macro :video do |obj, args|
|
||||||
|
@width = args[1].gsub(/\D/,'') if args[1]
|
||||||
|
@height = args[2].gsub(/\D/,'') if args[2]
|
||||||
|
@width ||= 640
|
||||||
|
@height ||= 360
|
||||||
|
attachment = obj.attachments.find_by_filename(args[0]) if obj.respond_to?('attachments')
|
||||||
|
|
||||||
|
if attachment
|
||||||
|
file_url = url_for(
|
||||||
|
:only_path => false,
|
||||||
|
:controller => 'attachments',
|
||||||
|
:action => 'download',
|
||||||
|
:id => attachment,
|
||||||
|
:filename => attachment.filename
|
||||||
|
)
|
||||||
|
out = <<END
|
||||||
|
<video width="#{@width}" height="#{@height}" controls class="embedded-video">
|
||||||
|
<source src="#{file_url}">
|
||||||
|
Your browser does not support the video tag.
|
||||||
|
</video>
|
||||||
|
END
|
||||||
|
else
|
||||||
|
file_url = args[0].gsub(/<.*?>/, '').gsub(/<.*>/,'')
|
||||||
|
out = <<END
|
||||||
|
<iframe width="#{@width}" height="#{@height}" src="#{file_url}" class="embedded-video"></iframe>
|
||||||
|
END
|
||||||
|
end
|
||||||
|
|
||||||
|
out.html_safe
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|||||||
@@ -1,7 +0,0 @@
|
|||||||
|
|
||||||
# Fetch emails
|
|
||||||
*/5 * * * * /opt/bitnami/redmine/fetch-mails >/dev/null 2>&1
|
|
||||||
|
|
||||||
# Update Letsencrypt Certificate
|
|
||||||
#### Don't forget to set the --email and --domain arguments! ####
|
|
||||||
# 0 0 * * * sudo /opt/bitnami/letsencrypt/lego --path /opt/bitnami/letsencrypt --email="" --http --http-timeout 30 --http.webroot /opt/bitnami/apps/letsencrypt --domains="" renew && sudo /opt/bitnami/apache2/bin/httpd -f /opt/bitnami/apache2/conf/httpd.conf -k graceful
|
|
||||||
@@ -1,43 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Email-address of the system
|
|
||||||
mail_address="${REDMINE_IMAP_USER}"
|
|
||||||
|
|
||||||
# Email-Account username and password
|
|
||||||
mail_username="${REDMINE_IMAP_USERNAME:-"$mail_address"}"
|
|
||||||
mail_password="${REDMINE_IMAP_PASSWORD}"
|
|
||||||
|
|
||||||
# IMAP-Server address and port
|
|
||||||
mail_host="${REDMINE_IMAP_HOST}"
|
|
||||||
mail_port=${REDMINE_IMAP_PORT:-993}
|
|
||||||
mail_ssl=${REDMINE_IMAP_SSL:-true}
|
|
||||||
|
|
||||||
# IMAP-INBOX-Folder
|
|
||||||
mail_folder="INBOX"
|
|
||||||
|
|
||||||
# Default project and tracker
|
|
||||||
project="${REDMINE_IMAP_DEFAULT_PROJECT:-"meta"}"
|
|
||||||
tracker="${REDMINE_IMAP_DEFAULT_TRACKER:-"Support"}"
|
|
||||||
|
|
||||||
# Redmine Settings
|
|
||||||
unknown_user_action="ignore"
|
|
||||||
allow_override="all"
|
|
||||||
no_permission_check=true
|
|
||||||
app_root="/opt/bitnami/redmine"
|
|
||||||
|
|
||||||
if [[ -n "$mail_address" ]] && [[ -n "$mail_username" ]] && [[ -n "$mail_password" ]] && [[ -n "$mail_host" ]]; then
|
|
||||||
sudo /opt/bitnami/ruby/bin/rake -f $app_root/Rakefile --silent redmine:email:receive_imap RAILS_ENV="production" \
|
|
||||||
host="$mail_host" \
|
|
||||||
port=$mail_port \
|
|
||||||
username="$mail_username" \
|
|
||||||
password="$mail_password" \
|
|
||||||
ssl=$mail_ssl \
|
|
||||||
move_on_success="$mail_folder.success" \
|
|
||||||
move_on_failure="$mail_folder.failed" \
|
|
||||||
unknown_user="$unknown_user_action" \
|
|
||||||
tracker="$tracker" \
|
|
||||||
allow_override="$allow_override" \
|
|
||||||
folder="$mail_folder" \
|
|
||||||
project="$project" \
|
|
||||||
no_permission_check=$no_permission_check
|
|
||||||
fi
|
|
||||||
Reference in New Issue
Block a user