diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2023-01-18 19:00:14 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2023-01-18 19:00:14 +0000 |
commit | 05f0ebba3a2c8ddf39e436f412dc2ab5bf1353b2 (patch) | |
tree | 11d0f2a6ec31c7793c184106cedc2ded3d9a2cc5 /lib/sidebars/your_work | |
parent | ec73467c23693d0db63a797d10194da9e72a74af (diff) | |
download | gitlab-ce-05f0ebba3a2c8ddf39e436f412dc2ab5bf1353b2.tar.gz |
Add latest changes from gitlab-org/gitlab@15-8-stable-eev15.8.0-rc42
Diffstat (limited to 'lib/sidebars/your_work')
-rw-r--r-- | lib/sidebars/your_work/menus/activity_menu.rb | 34 | ||||
-rw-r--r-- | lib/sidebars/your_work/menus/groups_menu.rb | 34 | ||||
-rw-r--r-- | lib/sidebars/your_work/menus/issues_menu.rb | 47 | ||||
-rw-r--r-- | lib/sidebars/your_work/menus/merge_requests_menu.rb | 47 | ||||
-rw-r--r-- | lib/sidebars/your_work/menus/milestones_menu.rb | 34 | ||||
-rw-r--r-- | lib/sidebars/your_work/menus/projects_menu.rb | 34 | ||||
-rw-r--r-- | lib/sidebars/your_work/menus/snippets_menu.rb | 34 | ||||
-rw-r--r-- | lib/sidebars/your_work/menus/todos_menu.rb | 47 | ||||
-rw-r--r-- | lib/sidebars/your_work/panel.rb | 35 |
9 files changed, 346 insertions, 0 deletions
diff --git a/lib/sidebars/your_work/menus/activity_menu.rb b/lib/sidebars/your_work/menus/activity_menu.rb new file mode 100644 index 00000000000..d39c9bfda9c --- /dev/null +++ b/lib/sidebars/your_work/menus/activity_menu.rb @@ -0,0 +1,34 @@ +# frozen_string_literal: true + +module Sidebars + module YourWork + module Menus + class ActivityMenu < ::Sidebars::Menu + override :link + def link + activity_dashboard_path + end + + override :title + def title + _('Activity') + end + + override :sprite_icon + def sprite_icon + 'history' + end + + override :render? + def render? + !!context.current_user + end + + override :active_routes + def active_routes + { path: 'dashboard#activity' } + end + end + end + end +end diff --git a/lib/sidebars/your_work/menus/groups_menu.rb b/lib/sidebars/your_work/menus/groups_menu.rb new file mode 100644 index 00000000000..fd50b9b4b50 --- /dev/null +++ b/lib/sidebars/your_work/menus/groups_menu.rb @@ -0,0 +1,34 @@ +# frozen_string_literal: true + +module Sidebars + module YourWork + module Menus + class GroupsMenu < ::Sidebars::Menu + override :link + def link + dashboard_groups_path + end + + override :title + def title + _('Groups') + end + + override :sprite_icon + def sprite_icon + 'group' + end + + override :render? + def render? + !!context.current_user + end + + override :active_routes + def active_routes + { controller: ['groups', 'dashboard/groups'] } + end + end + end + end +end diff --git a/lib/sidebars/your_work/menus/issues_menu.rb b/lib/sidebars/your_work/menus/issues_menu.rb new file mode 100644 index 00000000000..6046b78e54e --- /dev/null +++ b/lib/sidebars/your_work/menus/issues_menu.rb @@ -0,0 +1,47 @@ +# frozen_string_literal: true + +module Sidebars + module YourWork + module Menus + class IssuesMenu < ::Sidebars::Menu + include Gitlab::Utils::StrongMemoize + + override :link + def link + issues_dashboard_path(assignee_username: @context.current_user.username) + end + + override :title + def title + _('Issues') + end + + override :sprite_icon + def sprite_icon + 'issues' + end + + override :render? + def render? + !!context.current_user + end + + override :active_routes + def active_routes + { path: 'dashboard#issues' } + end + + override :has_pill? + def has_pill? + pill_count > 0 + end + + override :pill_count + def pill_count + context.current_user.assigned_open_issues_count + end + strong_memoize_attr :pill_count + end + end + end +end diff --git a/lib/sidebars/your_work/menus/merge_requests_menu.rb b/lib/sidebars/your_work/menus/merge_requests_menu.rb new file mode 100644 index 00000000000..695c2ffdf46 --- /dev/null +++ b/lib/sidebars/your_work/menus/merge_requests_menu.rb @@ -0,0 +1,47 @@ +# frozen_string_literal: true + +module Sidebars + module YourWork + module Menus + class MergeRequestsMenu < ::Sidebars::Menu + include Gitlab::Utils::StrongMemoize + + override :link + def link + merge_requests_dashboard_path(assignee_username: @context.current_user.username) + end + + override :title + def title + _('Merge requests') + end + + override :sprite_icon + def sprite_icon + 'merge-request' + end + + override :render? + def render? + !!context.current_user + end + + override :active_routes + def active_routes + { path: 'dashboard#merge_requests' } + end + + override :has_pill? + def has_pill? + pill_count > 0 + end + + override :pill_count + def pill_count + context.current_user.assigned_open_merge_requests_count + end + strong_memoize_attr :pill_count + end + end + end +end diff --git a/lib/sidebars/your_work/menus/milestones_menu.rb b/lib/sidebars/your_work/menus/milestones_menu.rb new file mode 100644 index 00000000000..9b643afeec5 --- /dev/null +++ b/lib/sidebars/your_work/menus/milestones_menu.rb @@ -0,0 +1,34 @@ +# frozen_string_literal: true + +module Sidebars + module YourWork + module Menus + class MilestonesMenu < ::Sidebars::Menu + override :link + def link + dashboard_milestones_path + end + + override :title + def title + _('Milestones') + end + + override :sprite_icon + def sprite_icon + 'clock' + end + + override :render? + def render? + !!context.current_user + end + + override :active_routes + def active_routes + { controller: 'dashboard/milestones' } + end + end + end + end +end diff --git a/lib/sidebars/your_work/menus/projects_menu.rb b/lib/sidebars/your_work/menus/projects_menu.rb new file mode 100644 index 00000000000..e8b2a1d7869 --- /dev/null +++ b/lib/sidebars/your_work/menus/projects_menu.rb @@ -0,0 +1,34 @@ +# frozen_string_literal: true + +module Sidebars + module YourWork + module Menus + class ProjectsMenu < ::Sidebars::Menu + override :link + def link + dashboard_projects_path + end + + override :title + def title + _('Projects') + end + + override :sprite_icon + def sprite_icon + 'project' + end + + override :render? + def render? + !!context.current_user + end + + override :active_routes + def active_routes + { controller: ['root', 'projects', 'dashboard/projects'] } + end + end + end + end +end diff --git a/lib/sidebars/your_work/menus/snippets_menu.rb b/lib/sidebars/your_work/menus/snippets_menu.rb new file mode 100644 index 00000000000..c7c591f03cd --- /dev/null +++ b/lib/sidebars/your_work/menus/snippets_menu.rb @@ -0,0 +1,34 @@ +# frozen_string_literal: true + +module Sidebars + module YourWork + module Menus + class SnippetsMenu < ::Sidebars::Menu + override :link + def link + dashboard_snippets_path + end + + override :title + def title + _('Snippets') + end + + override :sprite_icon + def sprite_icon + 'snippet' + end + + override :render? + def render? + !!context.current_user + end + + override :active_routes + def active_routes + { controller: :snippets } + end + end + end + end +end diff --git a/lib/sidebars/your_work/menus/todos_menu.rb b/lib/sidebars/your_work/menus/todos_menu.rb new file mode 100644 index 00000000000..d37ffadb579 --- /dev/null +++ b/lib/sidebars/your_work/menus/todos_menu.rb @@ -0,0 +1,47 @@ +# frozen_string_literal: true + +module Sidebars + module YourWork + module Menus + class TodosMenu < ::Sidebars::Menu + include Gitlab::Utils::StrongMemoize + + override :link + def link + dashboard_todos_path + end + + override :title + def title + _('To-Do List') + end + + override :sprite_icon + def sprite_icon + 'todo-done' + end + + override :render? + def render? + !!context.current_user + end + + override :active_routes + def active_routes + { path: 'dashboard/todos#index' } + end + + override :has_pill? + def has_pill? + pill_count > 0 + end + + override :pill_count + def pill_count + context.current_user.todos_pending_count + end + strong_memoize_attr :pill_count + end + end + end +end diff --git a/lib/sidebars/your_work/panel.rb b/lib/sidebars/your_work/panel.rb new file mode 100644 index 00000000000..215a2a2da09 --- /dev/null +++ b/lib/sidebars/your_work/panel.rb @@ -0,0 +1,35 @@ +# frozen_string_literal: true + +module Sidebars + module YourWork + class Panel < ::Sidebars::Panel + override :configure_menus + def configure_menus + add_menus + end + + override :aria_label + def aria_label + _('Your work') + end + + override :render_raw_scope_menu_partial + def render_raw_scope_menu_partial + "shared/nav/your_work_scope_header" + end + + private + + def add_menus + add_menu(Sidebars::YourWork::Menus::ProjectsMenu.new(context)) + add_menu(Sidebars::YourWork::Menus::GroupsMenu.new(context)) + add_menu(Sidebars::YourWork::Menus::IssuesMenu.new(context)) + add_menu(Sidebars::YourWork::Menus::MergeRequestsMenu.new(context)) + add_menu(Sidebars::YourWork::Menus::TodosMenu.new(context)) + add_menu(Sidebars::YourWork::Menus::MilestonesMenu.new(context)) + add_menu(Sidebars::YourWork::Menus::SnippetsMenu.new(context)) + add_menu(Sidebars::YourWork::Menus::ActivityMenu.new(context)) + end + end + end +end |