Commit b6c30a6f authored by Doug Stull's avatar Doug Stull Committed by Bob Van Landuyt

Launch invite modal from invite CTA on project empty state

parent dd39fe1a
...@@ -3,6 +3,8 @@ import Activities from '~/activities'; ...@@ -3,6 +3,8 @@ import Activities from '~/activities';
import ShortcutsNavigation from '~/behaviors/shortcuts/shortcuts_navigation'; import ShortcutsNavigation from '~/behaviors/shortcuts/shortcuts_navigation';
import BlobViewer from '~/blob/viewer/index'; import BlobViewer from '~/blob/viewer/index';
import { initUploadForm } from '~/blob_edit/blob_bundle'; import { initUploadForm } from '~/blob_edit/blob_bundle';
import initInviteMembersModal from '~/invite_members/init_invite_members_modal';
import initInviteMembersTrigger from '~/invite_members/init_invite_members_trigger';
import leaveByUrl from '~/namespaces/leave_by_url'; import leaveByUrl from '~/namespaces/leave_by_url';
import initVueNotificationsDropdown from '~/notifications'; import initVueNotificationsDropdown from '~/notifications';
import { initUploadFileTrigger } from '~/projects/upload_file_experiment'; import { initUploadFileTrigger } from '~/projects/upload_file_experiment';
...@@ -44,3 +46,5 @@ initVueNotificationsDropdown(); ...@@ -44,3 +46,5 @@ initVueNotificationsDropdown();
new ShortcutsNavigation(); // eslint-disable-line no-new new ShortcutsNavigation(); // eslint-disable-line no-new
initUploadFileTrigger(); initUploadFileTrigger();
initInviteMembersModal();
initInviteMembersTrigger();
...@@ -3,6 +3,10 @@ ...@@ -3,6 +3,10 @@
track_event: 'render' } } track_event: 'render' } }
= s_('InviteMember|Invite your team') = s_('InviteMember|Invite your team')
%p= s_('InviteMember|Add members to this project and start collaborating with your team.') %p= s_('InviteMember|Add members to this project and start collaborating with your team.')
= link_to s_('InviteMember|Invite members'), project_project_members_path(@project, sort: :access_level_desc), .js-invite-members-trigger{ data: { variant: 'confirm',
class: 'gl-button btn btn-confirm gl-mb-8 gl-xs-w-full', classes: 'gl-mb-8 gl-xs-w-full',
data: { track_event: 'click_button', track_label: 'invite_members_empty_project' } display_text: s_('InviteMember|Invite members'),
event: 'click_button',
label: 'invite_members_empty_project' } }
= render 'shared/issuable/invite_members_trigger', project: @project
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe 'User views an empty project' do RSpec.describe 'User views an empty project' do
let(:project) { create(:project, :empty_repo) } let_it_be(:project) { create(:project, :empty_repo) }
let(:user) { create(:user) } let_it_be(:user) { create(:user) }
shared_examples 'allowing push to default branch' do shared_examples 'allowing push to default branch' do
it 'shows push-to-master instructions' do it 'shows push-to-master instructions' do
...@@ -14,17 +14,25 @@ RSpec.describe 'User views an empty project' do ...@@ -14,17 +14,25 @@ RSpec.describe 'User views an empty project' do
end end
end end
describe 'as a maintainer' do context 'when user is a maintainer' do
before do before do
project.add_maintainer(user) project.add_maintainer(user)
sign_in(user) sign_in(user)
end end
it_behaves_like 'allowing push to default branch' it_behaves_like 'allowing push to default branch'
it 'shows a link for inviting members and launches invite modal', :js do
visit project_path(project)
click_button 'Invite members'
expect(page).to have_content("You're inviting members to the")
end
end end
describe 'as an admin' do context 'when user is an admin' do
let(:user) { create(:user, :admin) } let_it_be(:user) { create(:user, :admin) }
context 'when admin mode is enabled' do context 'when admin mode is enabled' do
before do before do
...@@ -44,16 +52,17 @@ RSpec.describe 'User views an empty project' do ...@@ -44,16 +52,17 @@ RSpec.describe 'User views an empty project' do
end end
end end
describe 'as a developer' do context 'when user is a developer' do
before do before do
project.add_developer(user) project.add_developer(user)
sign_in(user) sign_in(user)
end end
it 'does not show push-to-master instructions' do it 'does not show push-to-master instructions nor invite members link', :aggregate_failures, :js do
visit project_path(project) visit project_path(project)
expect(page).not_to have_content('git push -u origin master') expect(page).not_to have_content('git push -u origin master')
expect(page).not_to have_button(text: 'Invite members')
end end
end end
end end
...@@ -57,20 +57,24 @@ RSpec.describe 'projects/empty' do ...@@ -57,20 +57,24 @@ RSpec.describe 'projects/empty' do
render render
expect(rendered).to have_selector('[data-track-event=render]') expect(rendered).to have_selector('[data-track-event=render]')
expect(rendered).to have_selector('[data-track-label=invite_members_empty_project]', count: 2) expect(rendered).to have_selector('[data-track-label=invite_members_empty_project]')
expect(rendered).to have_content('Invite your team') expect(rendered).to have_content('Invite your team')
expect(rendered).to have_content('Add members to this project and start collaborating with your team.') expect(rendered).to have_content('Add members to this project and start collaborating with your team.')
expect(rendered).to have_link('Invite members', href: project_project_members_path(project, sort: :access_level_desc)) expect(rendered).to have_selector('.js-invite-members-trigger')
expect(rendered).to have_selector('[data-track-event=click_button]') expect(rendered).to have_selector('.js-invite-members-modal')
expect(rendered).to have_selector('[data-label=invite_members_empty_project]')
expect(rendered).to have_selector('[data-event=click_button]')
end end
context 'when user does not have permissions to invite members' do context 'when user does not have permissions to invite members' do
let(:can_import_members) { false } let(:can_import_members) { false }
it 'does not show invite member info' do it 'does not show invite member info', :aggregate_failures do
render render
expect(rendered).not_to have_content('Invite your team') expect(rendered).not_to have_content('Invite your team')
expect(rendered).not_to have_selector('.js-invite-members-trigger')
expect(rendered).not_to have_selector('.js-invite-members-modal')
end end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment