120 lines
3.2 KiB
Ruby
120 lines
3.2 KiB
Ruby
module ApplicationHelper
|
|
include SanitizeUrl
|
|
|
|
def sanitize_url(url)
|
|
if !url.nil?
|
|
super(url, schemes: ['http', 'https'], replace_evil_with: root_url)
|
|
end
|
|
end
|
|
|
|
def flash_class(level, sticky: false, fixed: false)
|
|
class_names = case level
|
|
when 'notice'
|
|
['alert-success']
|
|
when 'alert'
|
|
['alert-danger']
|
|
end
|
|
if sticky
|
|
class_names << 'sticky'
|
|
end
|
|
if fixed
|
|
class_names << 'alert-fixed'
|
|
end
|
|
class_names.join(' ')
|
|
end
|
|
|
|
def render_to_element(selector, partial:, outer: false, locals: {})
|
|
method = outer ? 'outerHTML' : 'innerHTML'
|
|
html = escape_javascript(render partial: partial, locals: locals)
|
|
# rubocop:disable Rails/OutputSafety
|
|
raw("document.querySelector('#{selector}').#{method} = \"#{html}\";")
|
|
# rubocop:enable Rails/OutputSafety
|
|
end
|
|
|
|
def render_flash(timeout: false, sticky: false, fixed: false)
|
|
if flash.any?
|
|
html = render_to_element('#flash_messages', partial: 'layouts/flash_messages', locals: { sticky: sticky, fixed: fixed }, outer: true)
|
|
flash.clear
|
|
if timeout
|
|
html += remove_element('#flash_messages', timeout: timeout, inner: true)
|
|
end
|
|
html
|
|
end
|
|
end
|
|
|
|
def remove_element(selector, timeout: 0, inner: false)
|
|
script = "(function() {";
|
|
script << "var el = document.querySelector('#{selector}');"
|
|
method = (inner ? "el.innerHTML = ''" : "el.parentNode.removeChild(el)")
|
|
script << "setTimeout(function() { #{method}; }, #{timeout});";
|
|
script << "})();"
|
|
# rubocop:disable Rails/OutputSafety
|
|
raw(script);
|
|
# rubocop:enable Rails/OutputSafety
|
|
end
|
|
|
|
def disable_element(selector)
|
|
# rubocop:disable Rails/OutputSafety
|
|
raw("document.querySelector('#{selector}').disabled = true;")
|
|
# rubocop:enable Rails/OutputSafety
|
|
end
|
|
|
|
def enable_element(selector)
|
|
# rubocop:disable Rails/OutputSafety
|
|
raw("document.querySelector('#{selector}').disabled = false;")
|
|
# rubocop:enable Rails/OutputSafety
|
|
end
|
|
|
|
def fire_event(event_name, data)
|
|
# rubocop:disable Rails/OutputSafety
|
|
raw("DS.fire('#{event_name}', #{raw(data)});")
|
|
# rubocop:enable Rails/OutputSafety
|
|
end
|
|
|
|
def current_email
|
|
current_user&.email ||
|
|
current_gestionnaire&.email ||
|
|
current_administrateur&.email
|
|
end
|
|
|
|
def staging?
|
|
ENV['APP_NAME'] == 'tps_dev'
|
|
end
|
|
|
|
def contact_link(title, options = {})
|
|
tags, type, dossier_id = options.values_at(:tags, :type, :dossier_id)
|
|
options.except!(:tags, :type, :dossier_id)
|
|
|
|
if Flipflop.support_form?
|
|
params = { tags: tags, type: type, dossier_id: dossier_id }.compact
|
|
link_to title, contact_url(params), options
|
|
else
|
|
mail_to CONTACT_EMAIL, title,
|
|
options.merge(subject: "Question à propos de demarches-simplifiees.fr")
|
|
end
|
|
end
|
|
|
|
def root_path_for_profile(nav_bar_profile)
|
|
case nav_bar_profile
|
|
when :gestionnaire
|
|
gestionnaire_procedures_path
|
|
when :user
|
|
dossiers_path
|
|
else
|
|
root_path
|
|
end
|
|
end
|
|
|
|
def sentry_config
|
|
sentry = Rails.application.secrets.sentry
|
|
if sentry
|
|
{
|
|
dsn: sentry[:browser],
|
|
id: current_user&.id,
|
|
email: current_email
|
|
}.to_json
|
|
else
|
|
{}
|
|
end
|
|
end
|
|
end
|