module Decidim::Meetings::ApplicationHelper

def activity_filter_values

Options to filter meetings by activity.
def activity_filter_values
  [
    ["all", t("decidim.meetings.meetings.filters.all")],
    ["my_meetings", t("decidim.meetings.meetings.filters.my_meetings")]
  ]
end

def filter_date_values

def filter_date_values
  [
    ["all", t("decidim.meetings.meetings.filters.date_values.all")],
    ["upcoming", t("decidim.meetings.meetings.filters.date_values.upcoming")],
    ["past", t("decidim.meetings.meetings.filters.date_values.past")]
  ]
end

def filter_origin_values

def filter_origin_values
  origin_values = []
  origin_values << TreePoint.new("official", t("decidim.meetings.meetings.filters.origin_values.official"))
  origin_values << TreePoint.new("participants", t("decidim.meetings.meetings.filters.origin_values.participants")) # todo
  if current_organization.user_groups_enabled?
    origin_values << TreePoint.new("user_group", t("decidim.meetings.meetings.filters.origin_values.user_groups")) # todo
  end
  # if current_organization.user_groups_enabled? and component_settings enabled enabled
  TreeNode.new(
    TreePoint.new("", t("decidim.meetings.meetings.filters.origin_values.all")),
    origin_values
  )
end

def filter_type_values

def filter_type_values
  type_values = []
  Decidim::Meetings::Meeting::TYPE_OF_MEETING.each do |type|
    type_values << TreePoint.new(type, t("decidim.meetings.meetings.filters.type_values.#{type}"))
  end
  TreeNode.new(
    TreePoint.new("", t("decidim.meetings.meetings.filters.type_values.all")),
    type_values
  )
end

def iframe_embed_or_live_event_page?(meeting)

def iframe_embed_or_live_event_page?(meeting)
  %w(embed_in_meeting_page open_in_live_event_page).include? meeting.iframe_embed_type
end

def online_or_hybrid_meeting?(meeting)

def online_or_hybrid_meeting?(meeting)
  meeting.online_meeting? || meeting.hybrid_meeting?
end

def prevent_timeout_seconds

def prevent_timeout_seconds
  return 0 unless respond_to?(:meeting)
  return 0 if !current_user || !meeting || !meeting.live?
  return 0 unless online_or_hybrid_meeting?(meeting)
  return 0 unless iframe_embed_or_live_event_page?(meeting)
  return 0 unless meeting.iframe_access_level_allowed_for_user?(current_user)
  (meeting.end_time - Time.current).to_i
end

def render_meeting_body(meeting)

If the content is safe, HTML tags are sanitized, otherwise, they are stripped.
def render_meeting_body(meeting)
  sanitized = render_sanitized_content(meeting, :description)
  if safe_content?
    Decidim::ContentProcessor.render_without_format(sanitized).html_safe
  else
    Decidim::ContentProcessor.render(sanitized, "div")
  end
end

def safe_content?

the meeting comes from a collaborative_draft or a participatory_text.
frontend, the meeting body is considered as safe content; that's unless
If the meeting is official or the rich text editor is enabled on the
def safe_content?
  rich_text_editor_in_public_views? || @meeting.official?
end