Merge branch 'group-activity-separate-tab' into 'master'
Move group activity feed to separate page for consistency with dashboard and project pages Fixes #14161. Part of #13480 See merge request !3157
This commit is contained in:
commit
ee14ac68a5
10 changed files with 44 additions and 19 deletions
|
@ -27,6 +27,7 @@ v 8.6.0 (unreleased)
|
|||
- Show labels in dashboard and group milestone views
|
||||
- Add main language of a project in the list of projects (Tiago Botelho)
|
||||
- Add ability to show archived projects on dashboard, explore and group pages
|
||||
- Move group activity to separate page
|
||||
|
||||
v 8.5.5
|
||||
- Ensure removing a project removes associated Todo entries
|
||||
|
|
|
@ -74,8 +74,9 @@ class Dispatcher
|
|||
shortcut_handler = new ShortcutsNavigation()
|
||||
|
||||
new TreeView() if $('#tree-slider').length
|
||||
when 'groups:show'
|
||||
when 'groups:activity'
|
||||
new Activities()
|
||||
when 'groups:show'
|
||||
shortcut_handler = new ShortcutsNavigation()
|
||||
when 'groups:group_members:index'
|
||||
new GroupMembers()
|
||||
|
|
|
@ -15,7 +15,7 @@ class GroupsController < Groups::ApplicationController
|
|||
|
||||
# Load group projects
|
||||
before_action :load_projects, except: [:index, :new, :create, :projects, :edit, :update, :autocomplete]
|
||||
before_action :event_filter, only: [:show, :events]
|
||||
before_action :event_filter, only: [:activity]
|
||||
|
||||
layout :determine_layout
|
||||
|
||||
|
@ -62,8 +62,10 @@ class GroupsController < Groups::ApplicationController
|
|||
end
|
||||
end
|
||||
|
||||
def events
|
||||
def activity
|
||||
respond_to do |format|
|
||||
format.html
|
||||
|
||||
format.json do
|
||||
load_events
|
||||
pager_json("events/_events", @events.count)
|
||||
|
|
12
app/views/groups/_activities.html.haml
Normal file
12
app/views/groups/_activities.html.haml
Normal file
|
@ -0,0 +1,12 @@
|
|||
.hidden-xs
|
||||
= render "events/event_last_push", event: @last_push
|
||||
|
||||
.nav-block
|
||||
- if current_user
|
||||
.controls
|
||||
= link_to dashboard_projects_path(:atom, { private_token: current_user.private_token }), class: 'btn rss-btn' do
|
||||
%i.fa.fa-rss
|
||||
= render 'shared/event_filter'
|
||||
|
||||
.content_list
|
||||
= spinner
|
9
app/views/groups/activity.html.haml
Normal file
9
app/views/groups/activity.html.haml
Normal file
|
@ -0,0 +1,9 @@
|
|||
= content_for :meta_tags do
|
||||
- if current_user
|
||||
= auto_discovery_link_tag(:atom, group_url(@group, format: :atom, private_token: current_user.private_token), title: "#{@group.name} activity")
|
||||
|
||||
- page_title "Activity"
|
||||
- header_title group_title(@group, "Activity", activity_group_path(@group))
|
||||
|
||||
%section.activities
|
||||
= render 'activities'
|
|
@ -30,26 +30,13 @@
|
|||
|
||||
%ul.nav-links
|
||||
%li.active
|
||||
= link_to "#activity", 'data-toggle' => 'tab' do
|
||||
Activity
|
||||
%li
|
||||
= link_to "#projects", 'data-toggle' => 'tab' do
|
||||
Projects
|
||||
|
||||
- if can?(current_user, :read_group, @group)
|
||||
%div{ class: container_class }
|
||||
.tab-content
|
||||
.tab-pane.active#activity
|
||||
.activity-filter-block
|
||||
- if current_user
|
||||
= render "events/event_last_push", event: @last_push
|
||||
|
||||
= render 'shared/event_filter'
|
||||
|
||||
.content_list{data: {href: events_group_path}}
|
||||
= spinner
|
||||
|
||||
.tab-pane#projects
|
||||
.tab-pane.active#projects
|
||||
= render "projects", projects: @projects
|
||||
|
||||
- else
|
||||
|
|
|
@ -9,10 +9,15 @@
|
|||
|
||||
= nav_link(path: 'groups#show', html_options: {class: 'home'}) do
|
||||
= link_to group_path(@group), title: 'Home' do
|
||||
= icon('dashboard fw')
|
||||
= icon('group fw')
|
||||
%span
|
||||
Group
|
||||
- if can?(current_user, :read_group, @group)
|
||||
= nav_link(path: 'groups#activity') do
|
||||
= link_to activity_group_path(@group), title: 'Activity' do
|
||||
= icon('dashboard fw')
|
||||
%span
|
||||
Activity
|
||||
- if current_user
|
||||
= nav_link(controller: [:group, :milestones]) do
|
||||
= link_to group_milestones_path(@group), title: 'Milestones' do
|
||||
|
|
|
@ -382,7 +382,7 @@ Rails.application.routes.draw do
|
|||
get :issues
|
||||
get :merge_requests
|
||||
get :projects
|
||||
get :events
|
||||
get :activity
|
||||
end
|
||||
|
||||
scope module: :groups do
|
||||
|
|
|
@ -15,6 +15,10 @@ Feature: Groups
|
|||
Scenario: I should see group "Owned" dashboard list
|
||||
When I visit group "Owned" page
|
||||
Then I should see group "Owned" projects list
|
||||
|
||||
@javascript
|
||||
Scenario: I should see group "Owned" activity feed
|
||||
When I visit group "Owned" activity page
|
||||
And I should see projects activity feed
|
||||
|
||||
Scenario: I should see group "Owned" issues list
|
||||
|
|
|
@ -27,6 +27,10 @@ module SharedPaths
|
|||
visit group_path(Group.find_by(name: "Owned"))
|
||||
end
|
||||
|
||||
step 'I visit group "Owned" activity page' do
|
||||
visit activity_group_path(Group.find_by(name: "Owned"))
|
||||
end
|
||||
|
||||
step 'I visit group "Owned" issues page' do
|
||||
visit issues_group_path(Group.find_by(name: "Owned"))
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue