2015-06-05 15:53:57 -04:00
|
|
|
# Helper methods for per-User preferences
|
|
|
|
module PreferencesHelper
|
|
|
|
COLOR_SCHEMES = {
|
|
|
|
1 => 'white',
|
|
|
|
2 => 'dark',
|
|
|
|
3 => 'solarized-light',
|
|
|
|
4 => 'solarized-dark',
|
|
|
|
5 => 'monokai',
|
|
|
|
}
|
|
|
|
COLOR_SCHEMES.default = 'white'
|
|
|
|
|
|
|
|
# Helper method to access the COLOR_SCHEMES
|
|
|
|
#
|
|
|
|
# The keys are the `color_scheme_ids`
|
|
|
|
# The values are the `name` of the scheme.
|
|
|
|
#
|
|
|
|
# The preview images are `name-scheme-preview.png`
|
|
|
|
# The stylesheets should use the css class `.name`
|
|
|
|
def color_schemes
|
|
|
|
COLOR_SCHEMES.freeze
|
|
|
|
end
|
|
|
|
|
2015-06-12 20:39:48 -04:00
|
|
|
# Maps `dashboard` values to more user-friendly option text
|
|
|
|
DASHBOARD_CHOICES = {
|
|
|
|
projects: 'Your Projects (default)',
|
|
|
|
stars: 'Starred Projects'
|
|
|
|
}.with_indifferent_access.freeze
|
2015-06-10 04:42:02 -04:00
|
|
|
|
2015-06-12 20:39:48 -04:00
|
|
|
# Returns an Array usable by a select field for more user-friendly option text
|
|
|
|
def dashboard_choices
|
|
|
|
defined = User.dashboards
|
2015-06-10 04:42:02 -04:00
|
|
|
|
2015-06-12 20:39:48 -04:00
|
|
|
if defined.size != DASHBOARD_CHOICES.size
|
|
|
|
# Ensure that anyone adding new options updates this method too
|
|
|
|
raise RuntimeError, "`User` defines #{defined.size} dashboard choices," +
|
|
|
|
" but `DASHBOARD_CHOICES` defined #{DASHBOARD_CHOICES.size}."
|
2015-06-10 04:42:02 -04:00
|
|
|
else
|
2015-06-12 20:39:48 -04:00
|
|
|
defined.map do |key, _|
|
|
|
|
# Use `fetch` so `KeyError` gets raised when a key is missing
|
|
|
|
[DASHBOARD_CHOICES.fetch(key), key]
|
|
|
|
end
|
2015-06-10 04:42:02 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-07-13 12:24:15 -04:00
|
|
|
def project_view_choices
|
|
|
|
[
|
|
|
|
['Readme (default)', :readme],
|
|
|
|
['Activity view', :activity]
|
|
|
|
]
|
|
|
|
end
|
|
|
|
|
2015-06-05 15:53:57 -04:00
|
|
|
def user_application_theme
|
|
|
|
theme = Gitlab::Themes.by_id(current_user.try(:theme_id))
|
|
|
|
theme.css_class
|
|
|
|
end
|
|
|
|
|
|
|
|
def user_color_scheme_class
|
|
|
|
COLOR_SCHEMES[current_user.try(:color_scheme_id)] if defined?(current_user)
|
|
|
|
end
|
2015-07-13 12:24:15 -04:00
|
|
|
|
|
|
|
def prefer_readme?
|
|
|
|
!current_user ||
|
|
|
|
current_user.project_view == 'readme'
|
|
|
|
end
|
2015-06-05 15:53:57 -04:00
|
|
|
end
|