module Agilibox::TextHelper
include ::ActionView::Helpers::NumberHelper
include ::ActionView::Helpers::SanitizeHelper
include ::ActionView::Helpers::TextHelper
def nbsp(text = :no_argument)
if text == :no_argument
" "
else
text.to_s.gsub(" ", nbsp)
end
end
def euros(n)
currency(n, "€")
end
def currency(n, u)
return if n.nil?
I18n.t("number.currency.format.format")
.gsub("%n", number(n))
.gsub("%u", u)
.tr(" ", "\u00A0")
end
def percentage(n)
return if n.nil?
(number(n) + " %").tr(" ", "\u00A0")
end
def number(n)
return if n.nil?
opts = {}
if n.class.to_s.match?(/Float|Decimal/i)
opts[:precision] = 2
else
opts[:precision] = 0
end
opts[:delimiter] = I18n.t("number.format.delimiter")
opts[:separator] = I18n.t("number.format.separator")
number_with_precision(n, opts).tr(" ", "\u00A0")
end
def date(d, *args)
I18n.l(d, *args) unless d.nil?
end
def boolean_icon(bool)
return if bool.nil?
return icon(:check, style: "color: green") if bool == true
return icon(:times, style: "color: red") if bool == false
raise "#{bool} is not a boolean"
end
def hours(n)
return if n.nil?
number = number_with_precision(n, precision: 2)
text = I18n.t("datetime.prompts.hour").downcase
text = text.pluralize if n > 1
"#{number} #{text}"
end
def text2html(str)
return if str.to_s.blank?
str = str.delete("\r").strip
strip_tags(str).gsub("\n", "
").html_safe
end
def lf2br(str)
return if str.to_s.blank?
str.delete("\r").gsub("\n", "
").html_safe
end
# rubocop:disable Metrics/MethodLength
def info(object, attribute, value_or_options = nil, options = {})
if value_or_options.nil?
value = object.public_send(attribute)
elsif value_or_options.is_a?(Hash)
value = object.public_send(attribute)
options = value_or_options
else
value = value_or_options
end
if value.blank?
value = options[:default]
return if value == :hide
end
label = options[:label] || object.t(attribute)
tag = options[:tag] || :div
separator = options[:separator] || " : "
helper = options[:helper]
i18n_key = "#{object.class.to_s.tableize.singularize}/#{attribute}"
nested = I18n.t("activerecord.attributes.#{i18n_key}", default: "").is_a?(Hash)
klass = object.is_a?(Module) ? object : object.class
object_type = klass.to_s.split("::").last.underscore
value = t("yes") if value == true
value = t("no") if value == false
value = object.t("#{attribute}.#{value}") if nested
value = send(helper, value) if helper
value = number(value) if value.is_a?(Numeric)
value = l(value) if value.is_a?(Time)
value = l(value) if value.is_a?(Date)
value = value.to_s
html_label = content_tag(:strong, class: "info-label") { label }
span_css_class = "info-value #{object_type}-#{attribute}"
html_value = content_tag(:span, class: span_css_class) { value }
separator_html = content_tag(:span, class: "info-separator") { separator }
if value.blank?
container_css_class = "info blank"
else
container_css_class = "info"
end
content_tag(tag, class: container_css_class) do
[html_label, separator_html, html_value].join.html_safe
end
end # def info
# rubocop:enable Metrics/MethodLength
def tags(object)
return "" if object.tag_list.empty?
object.tag_list.map { |tag|
content_tag(:span, class: "tag label label-primary") {
"#{icon :tag} #{tag}".html_safe
}
}.join(" ").html_safe
end
end