OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
openproject/config/initializers/10-patches.rb

153 lines
5.3 KiB

#-- encoding: UTF-8
Fix/bump representable (#5465) * bump reform and roar -> bumps representer * adapt to changed validation interface * disable initializer patch for now * adapt to changed representable attr interface * can no longer have private methods inside a representer * private no longer possible for representer * bump reform * wip - restyle validation * remove commented out patch * apply injection as prescribed * reactivate reform error symbols patch * remove patch to Hash superfluous wit ruby 2.3 * remove outdated human_attribute_name patch * whitespace fixes * adapt filter name after removal of human_attribute_name patch * adapt filter specs to no longer rely on human_attribute_name patch * fix version filter name * remove reliance on no longer existing human_attribute_name patch * use correct key in journal formatter * remove private from representer * adapt to altered setter interface * reenable i18n for error messages in contracts * no private methods in representer * defined model for contracts * fix validaton * instantiate correct Object * define model for contract * circumvent now existing render method on reform * replace deprecated constant * patch correct reform class - not the module - via prepend * refactor too complex method * replace deprations * remove remnants of parentId * prevent error symbols from existing twice * adapt user representer to altered setter interface * adapt watcher representer to altered setter interface * remove now unnessary patch * adapt setter to altered interface * adapt spec * fix custom field setters * remove parentId from wp representer As the parent is a wp resource, clients should use the parent link instead * adapt spec to changed valid? interface * remove parentId from wp schema * replace references of parentId in frontend * remove TODO [ci skip]
8 years ago
#-- copyright
# OpenProject is an open source project management software.
# Copyright (C) 2012-2020 the OpenProject GmbH
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License version 3.
#
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
# Copyright (C) 2006-2017 Jean-Philippe Lang
# Copyright (C) 2010-2013 the ChiliProject Team
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
# See docs/COPYRIGHT.rdoc for more details.
#++
require 'active_record'
module ActiveRecord
class Base
include Redmine::I18n
def self.human_attribute_name(attr, options = {})
attr = attr.to_s.gsub(/_id\z/, '')
Fix/bump representable (#5465) * bump reform and roar -> bumps representer * adapt to changed validation interface * disable initializer patch for now * adapt to changed representable attr interface * can no longer have private methods inside a representer * private no longer possible for representer * bump reform * wip - restyle validation * remove commented out patch * apply injection as prescribed * reactivate reform error symbols patch * remove patch to Hash superfluous wit ruby 2.3 * remove outdated human_attribute_name patch * whitespace fixes * adapt filter name after removal of human_attribute_name patch * adapt filter specs to no longer rely on human_attribute_name patch * fix version filter name * remove reliance on no longer existing human_attribute_name patch * use correct key in journal formatter * remove private from representer * adapt to altered setter interface * reenable i18n for error messages in contracts * no private methods in representer * defined model for contracts * fix validaton * instantiate correct Object * define model for contract * circumvent now existing render method on reform * replace deprecated constant * patch correct reform class - not the module - via prepend * refactor too complex method * replace deprations * remove remnants of parentId * prevent error symbols from existing twice * adapt user representer to altered setter interface * adapt watcher representer to altered setter interface * remove now unnessary patch * adapt setter to altered interface * adapt spec * fix custom field setters * remove parentId from wp representer As the parent is a wp resource, clients should use the parent link instead * adapt spec to changed valid? interface * remove parentId from wp schema * replace references of parentId in frontend * remove TODO [ci skip]
8 years ago
super
end
end
end
module ActionView
module Helpers
module Tags
Base.class_eval do
attr_reader :method_name
end
end
module AccessibleErrors
def self.included(base)
base.send(:include, InstanceMethods)
base.extend(ClassMethods)
end
module ClassMethods
def wrap_with_error_span(html_tag, object, method)
object_identifier = erroneous_object_identifier(object.object_id.to_s, method)
"<span id='#{object_identifier}' class=\"errorSpan\"><a name=\"#{object_identifier}\"></a>#{html_tag}</span>".html_safe
end
def erroneous_object_identifier(id, method)
# select boxes use name_id whereas the validation uses name
# we have to cut the '_id' of in order for the field to match
id + '_' + method.gsub('_id', '') + '_error'
end
end
module InstanceMethods
def error_message_list(objects)
objects.map do |object|
error_messages = []
object.errors.each_error do |attr, error|
unless attr == 'custom_values'
# Generating unique identifier in order to jump directly to the field with the error
object_identifier = erroneous_object_identifier(object.object_id.to_s, attr)
error_messages << [object.class.human_attribute_name(attr) + ' ' + error.message, object_identifier]
end
end
# excluding custom_values from the errors.each loop before
# as more than one error can be assigned to custom_values
# which would add to many error messages
if object.errors[:custom_values].any?
object.custom_values.each do |value|
value.errors.map do |attr, msg|
# Generating unique identifier in order to jump directly to the field with the error
object_identifier = erroneous_object_identifier(value.object_id.to_s, attr)
error_messages << [value.custom_field.name + ' ' + msg, object_identifier]
end
end
end
error_message_list_elements(error_messages)
end
end
private
def erroneous_object_identifier(id, method)
self.class.erroneous_object_identifier(id, method)
end
def error_message_list_elements(array)
array.map do |msg, identifier|
content_tag :li do
content_tag :a,
ERB::Util.html_escape(msg),
href: '#' + identifier,
class: 'afocus'
end
end
end
end
end
module DateHelper
# distance_of_time_in_words breaks when difference is greater than 30 years
def distance_of_date_in_words(from_date, to_date = 0, options = {})
from_date = from_date.to_date if from_date.respond_to?(:to_date)
to_date = to_date.to_date if to_date.respond_to?(:to_date)
distance_in_days = (to_date - from_date).abs
I18n.with_options locale: options[:locale], scope: :'datetime.distance_in_words' do |locale|
case distance_in_days
when 0..60 then locale.t :x_days, count: distance_in_days.round
when 61..720 then locale.t :about_x_months, count: (distance_in_days / 30).round
else locale.t :over_x_years, count: (distance_in_days / 365).floor
end
end
end
end
end
end
ActionView::Base.send :include, ActionView::Helpers::AccessibleErrors
ActionView::Base.field_error_proc = Proc.new do |html_tag, instance|
if html_tag.include?('<label')
html_tag.to_s
else
ActionView::Base.wrap_with_error_span(html_tag, instance.object, instance.method_name)
end
end
# Patch acts_as_list before any class includes the module
require 'open_project/patches/acts_as_list'