summaryrefslogtreecommitdiff
path: root/lib/sidebars/your_work/menus
diff options
context:
space:
mode:
Diffstat (limited to 'lib/sidebars/your_work/menus')
-rw-r--r--lib/sidebars/your_work/menus/activity_menu.rb34
-rw-r--r--lib/sidebars/your_work/menus/groups_menu.rb34
-rw-r--r--lib/sidebars/your_work/menus/issues_menu.rb47
-rw-r--r--lib/sidebars/your_work/menus/merge_requests_menu.rb47
-rw-r--r--lib/sidebars/your_work/menus/milestones_menu.rb34
-rw-r--r--lib/sidebars/your_work/menus/projects_menu.rb34
-rw-r--r--lib/sidebars/your_work/menus/snippets_menu.rb34
-rw-r--r--lib/sidebars/your_work/menus/todos_menu.rb47
8 files changed, 311 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