5
0
Fork 0
mirror of https://0xacab.org/sutty/sutty synced 2024-11-22 17:26:21 +00:00
panel/app/helpers/application_helper.rb

143 lines
3.4 KiB
Ruby
Raw Normal View History

2019-03-26 15:32:20 +00:00
# frozen_string_literal: true
2019-07-31 20:55:34 +00:00
# Helpers
2018-01-02 17:19:25 +00:00
module ApplicationHelper
# Devuelve el atributo name de un campo anidado en el formato que
# esperan los helpers *_field
#
# [ 'post', :image, :description ]
# [ 'post[image]', :description ]
# 'post[image][description]'
def field_name_for(*names)
name = names.pop
root = names.shift
names.each do |n|
2024-05-02 19:05:35 +00:00
root += "[#{n}]"
end
[root, name]
end
2020-06-28 00:42:15 +00:00
def plain_field_name_for(*names)
root, name = field_name_for(*names)
2024-05-02 19:05:35 +00:00
"#{root}[#{name}]"
2020-06-28 00:42:15 +00:00
end
2019-08-02 00:20:42 +00:00
def distance_of_time_in_words_if_more_than_a_minute(seconds)
if seconds > 60
distance_of_time_in_words seconds
else
I18n.t('seconds', seconds: seconds)
end
end
2024-03-04 16:09:36 +00:00
# Sanitizador que elimina todo
#
# @param html [String]
# @return [String]
def text_plain(html)
sanitize(html, tags: [], attributes: [])
end
# Sanitizador con etiquetas y atributos por defecto
#
# @param html [String]
# @param options [Hash]
# @return [String]
def sanitize(html, options = {})
options[:tags] ||= Sutty::ALLOWED_TAGS
options[:attributes] ||= Sutty::ALLOWED_ATTRIBUTES
super(html, options)
end
# Genera HTML y limpia etiquetas innecesarias
#
# @param [String]
# @param [Hash]
# @return [String]
def sanitize_markdown(text, options = {})
options.merge!(attributes: %w[id href alt class])
document = CommonMarker
.render_doc(text,
%i[FOOTNOTES SMART],
%i[table strikethrough autolink])
sanitize(document.to_html, options)
end
2019-07-31 20:55:34 +00:00
def invalid?(model, field)
model.errors.messages[field].present?
end
def form_control(model, field)
if invalid? model, field
'form-control is-invalid'
else
'form-control'
end
end
def form_class(model)
model.errors.messages.empty? ? 'needs-validation' : 'was-validated'
end
# Opciones por defecto para el campo de un formulario
2020-05-26 21:32:46 +00:00
def field_options(attribute, metadata, **extra)
required = extra.key?(:required) ? extra[:required] : metadata.required
2020-06-28 00:42:15 +00:00
{
2020-05-26 21:32:46 +00:00
class: "form-control #{invalid(metadata.post, attribute)} #{extra[:class]}",
2020-06-28 00:42:15 +00:00
required: required,
disabled: metadata.disabled?,
2019-09-12 18:11:39 +00:00
autofocus: (metadata.post.attributes.first == attribute),
aria: {
describedby: id_for_help(attribute),
2020-06-28 00:42:15 +00:00
required: required
}
}
end
# Devuelve la clase is-invalid si el campo tiene un error
def invalid(post, attribute)
'is-invalid' if post.errors[attribute].present?
end
# Busca la traducción de una etiqueta en los metadatos de un post
def post_label_t(*attribute, post:, **extra)
required = extra.key?(:required) ? extra[:required] : post[attribute.first].required
label = post_t(*attribute, post: post, type: :label)
label += I18n.t('posts.attributes.required.label') if required
label
end
def post_help_t(*attribute, post:)
post_t(*attribute, post: post, type: :help)
end
def id_for_help(*attribute)
"#{attribute.join('-')}-help"
end
def id_for_feedback(*attribute)
"#{attribute.join('-')}-feedback"
end
2019-08-16 23:25:07 +00:00
def id_for_datalist(*attribute)
"#{attribute.join('-')}-datalist"
end
private
def post_t(*attribute, post:, type:)
post.layout.metadata.dig(*attribute, type.to_s, I18n.locale.to_s) ||
post.layout.metadata.dig(*attribute, type.to_s, I18n.default_locale.to_s) ||
I18n.t("posts.attributes.#{attribute.join('.')}.#{type}")
end
2018-01-02 17:19:25 +00:00
end