114 lines
5.4 KiB
Ruby
114 lines
5.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
# rubocop:disable Metrics/AbcSize
|
|
|
|
module Gitlab
|
|
module GonHelper
|
|
include WebpackHelper
|
|
|
|
def add_gon_variables
|
|
gon.api_version = 'v4'
|
|
gon.default_avatar_url = default_avatar_url
|
|
gon.max_file_size = Gitlab::CurrentSettings.max_attachment_size
|
|
gon.asset_host = ActionController::Base.asset_host
|
|
gon.webpack_public_path = webpack_public_path
|
|
gon.relative_url_root = Gitlab.config.gitlab.relative_url_root
|
|
gon.user_color_scheme = Gitlab::ColorSchemes.for_user(current_user).css_class
|
|
gon.markdown_surround_selection = current_user&.markdown_surround_selection
|
|
gon.markdown_automatic_lists = current_user&.markdown_automatic_lists
|
|
|
|
if Gitlab.config.sentry.enabled
|
|
gon.sentry_dsn = Gitlab.config.sentry.clientside_dsn
|
|
gon.sentry_environment = Gitlab.config.sentry.environment
|
|
end
|
|
|
|
# Support for Sentry setup via configuration files will be removed in 16.0
|
|
# in favor of Gitlab::CurrentSettings.
|
|
if Feature.enabled?(:enable_new_sentry_clientside_integration,
|
|
current_user) && Gitlab::CurrentSettings.sentry_enabled
|
|
gon.sentry_dsn = Gitlab::CurrentSettings.sentry_clientside_dsn
|
|
gon.sentry_environment = Gitlab::CurrentSettings.sentry_environment
|
|
end
|
|
|
|
gon.recaptcha_api_server_url = ::Recaptcha.configuration.api_server_url
|
|
gon.recaptcha_sitekey = Gitlab::CurrentSettings.recaptcha_site_key
|
|
gon.gitlab_url = Gitlab.config.gitlab.url
|
|
gon.revision = Gitlab.revision
|
|
gon.feature_category = Gitlab::ApplicationContext.current_context_attribute(:feature_category).presence
|
|
gon.gitlab_logo = ActionController::Base.helpers.asset_path('gitlab_logo.png')
|
|
gon.secure = Gitlab.config.gitlab.https
|
|
gon.sprite_icons = IconsHelper.sprite_icon_path
|
|
gon.sprite_file_icons = IconsHelper.sprite_file_icons_path
|
|
gon.emoji_sprites_css_path = ActionController::Base.helpers.stylesheet_path('emoji_sprites')
|
|
gon.select2_css_path = ActionController::Base.helpers.stylesheet_path('lazy_bundles/select2.css')
|
|
gon.gridstack_css_path = ActionController::Base.helpers.stylesheet_path('lazy_bundles/gridstack.css')
|
|
gon.test_env = Rails.env.test?
|
|
gon.disable_animations = Gitlab.config.gitlab['disable_animations']
|
|
gon.suggested_label_colors = LabelsHelper.suggested_colors
|
|
gon.first_day_of_week = current_user&.first_day_of_week || Gitlab::CurrentSettings.first_day_of_week
|
|
gon.time_display_relative = true
|
|
gon.ee = Gitlab.ee?
|
|
gon.jh = Gitlab.jh?
|
|
gon.dot_com = Gitlab.com?
|
|
|
|
if current_user
|
|
gon.current_user_id = current_user.id
|
|
gon.current_username = current_user.username
|
|
gon.current_user_fullname = current_user.name
|
|
gon.current_user_avatar_url = current_user.avatar_url
|
|
gon.time_display_relative = current_user.time_display_relative
|
|
end
|
|
|
|
# Initialize gon.features with any flags that should be
|
|
# made globally available to the frontend
|
|
push_frontend_feature_flag(:usage_data_api, type: :ops)
|
|
push_frontend_feature_flag(:security_auto_fix)
|
|
push_frontend_feature_flag(:new_header_search)
|
|
push_frontend_feature_flag(:source_editor_toolbar)
|
|
push_frontend_feature_flag(:vscode_web_ide, current_user)
|
|
push_frontend_feature_flag(:integration_slack_app_notifications)
|
|
push_frontend_feature_flag(:vue_group_select)
|
|
push_frontend_feature_flag(:new_fonts, current_user)
|
|
end
|
|
|
|
# Exposes the state of a feature flag to the frontend code.
|
|
#
|
|
# name - The name of the feature flag, e.g. `my_feature`.
|
|
# args - Any additional arguments to pass to `Feature.enabled?`. This allows
|
|
# you to check if a flag is enabled for a particular user.
|
|
def push_frontend_feature_flag(name, *args, **kwargs)
|
|
enabled = Feature.enabled?(name, *args, **kwargs)
|
|
|
|
push_to_gon_attributes(:features, name, enabled)
|
|
end
|
|
|
|
# Exposes the state of a feature flag to the frontend code.
|
|
# Can be used for more complex feature flag checks.
|
|
#
|
|
# name - The name of the feature flag, e.g. `my_feature`.
|
|
# enabled - Boolean to be pushed directly to the frontend. Should be fetched by checking a feature flag.
|
|
def push_force_frontend_feature_flag(name, enabled)
|
|
push_to_gon_attributes(:features, name, !!enabled)
|
|
end
|
|
|
|
def push_to_gon_attributes(key, name, enabled)
|
|
var_name = name.to_s.camelize(:lower)
|
|
# Here the `true` argument signals gon that the value should be merged
|
|
# into any existing ones, instead of overwriting them. This allows you to
|
|
# use this method to push multiple feature flags.
|
|
gon.push({ key => { var_name => enabled } }, true)
|
|
end
|
|
|
|
def default_avatar_url
|
|
# We can't use ActionController::Base.helpers.image_url because it
|
|
# doesn't return an actual URL because request is nil for some reason.
|
|
#
|
|
# We also can't use Gitlab::Utils.append_path because the image path
|
|
# may be an absolute URL.
|
|
URI.join(Gitlab.config.gitlab.url,
|
|
ActionController::Base.helpers.image_path('no_avatar.png')).to_s
|
|
end
|
|
end
|
|
end
|
|
|
|
Gitlab::GonHelper.prepend_mod_with('Gitlab::GonHelper')
|