summaryrefslogtreecommitdiff
path: root/app/helpers/broadcast_messages_helper.rb
blob: bc3527565a6773081a3530a11f9d0e424f7e0e31 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
# frozen_string_literal: true

module BroadcastMessagesHelper
  include Gitlab::Utils::StrongMemoize

  def current_broadcast_banner_messages
    BroadcastMessage.current_banner_messages(
      current_path: request.path,
      user_access_level: current_user_access_level_for_project_or_group
    ).select do |message|
      cookies["hide_broadcast_message_#{message.id}"].blank?
    end
  end

  def current_broadcast_notification_message
    not_hidden_messages = BroadcastMessage.current_notification_messages(
      current_path: request.path,
      user_access_level: current_user_access_level_for_project_or_group
    ).select do |message|
      cookies["hide_broadcast_message_#{message.id}"].blank?
    end
    not_hidden_messages.last
  end

  def broadcast_message(message, opts = {})
    return unless message.present?

    render "shared/broadcast_message", { message: message, **opts }
  end

  def broadcast_message_status(broadcast_message)
    if broadcast_message.active?
      'Active'
    elsif broadcast_message.ended?
      'Expired'
    else
      'Pending'
    end
  end

  def render_broadcast_message(broadcast_message)
    if broadcast_message.notification?
      Banzai.render_field_and_post_process(broadcast_message, :message, {
        current_user: current_user,
        skip_project_check: true,
        broadcast_message_placeholders: true
      }).html_safe
    else
      Banzai.render_field(broadcast_message, :message).html_safe
    end
  end

  def target_access_level_options
    BroadcastMessage::ALLOWED_TARGET_ACCESS_LEVELS.map do |access_level|
      [Gitlab::Access.human_access(access_level), access_level]
    end
  end

  def target_access_levels_display(access_levels)
    access_levels.map do |access_level|
      Gitlab::Access.human_access(access_level)
    end.join(', ')
  end

  def admin_broadcast_messages_data(broadcast_messages)
    broadcast_messages.map do |message|
      {
        id: message.id,
        status: broadcast_message_status(message),
        preview: broadcast_message(message, preview: true),
        starts_at: message.starts_at.iso8601,
        ends_at: message.ends_at.iso8601,
        target_roles: target_access_levels_display(message.target_access_levels),
        target_path: message.target_path,
        type: message.broadcast_type.capitalize,
        edit_path: edit_admin_broadcast_message_path(message),
        delete_path: "#{admin_broadcast_message_path(message)}.js"
      }
    end.to_json
  end

  def broadcast_message_data(broadcast_message)
    {
      id: broadcast_message.id,
      message: broadcast_message.message,
      broadcast_type: broadcast_message.broadcast_type,
      theme: broadcast_message.theme,
      dismissable: broadcast_message.dismissable.to_s,
      target_access_levels: broadcast_message.target_access_levels,
      messages_path: admin_broadcast_messages_path,
      preview_path: preview_admin_broadcast_messages_path,
      target_path: broadcast_message.target_path,
      starts_at: broadcast_message.starts_at.iso8601,
      ends_at: broadcast_message.ends_at.iso8601,
      target_access_level_options: target_access_level_options.to_json
    }
  end

  private

  def current_user_access_level_for_project_or_group
    return if Feature.disabled?(:role_targeted_broadcast_messages)
    return unless current_user.present?

    strong_memoize(:current_user_access_level_for_project_or_group) do
      case controller
      when Projects::ApplicationController
        next unless @project

        @project.team.max_member_access(current_user.id)
      when Groups::ApplicationController
        next unless @group

        @group.max_member_access_for_user(current_user)
      end
    end
  end
end