Feature: Ability to switch between multiple accounts (#881)

* Feature: Ability to switch between multiple accounts

* Fix rubocop

* Fix assigned inboxes

* fix auth json

* Add account switcher in UI

* fix ordering on administrate

* Add switch accounts to sidebar

* add account id

* Fix schema.rb timestamp

* Revert "add account id"

This reverts commit 27570f50ef584cb9a5f69454f43f630b318c8807.

* Add a check for account

Co-authored-by: Pranav Raj Sreepuram <pranavrajs@gmail.com>
This commit is contained in:
Sojan Jose
2020-05-26 22:38:48 +05:30
committed by GitHub
parent b1aab228ae
commit b7a583b2c4
64 changed files with 441 additions and 212 deletions

View File

@@ -11,23 +11,26 @@ RSpec.describe ContactPolicy, type: :policy do
let(:agent) { create(:user, account: account) }
let(:contact) { create(:contact) }
let(:administrator_context) { { user: administrator, account: account, account_user: account.account_users.first } }
let(:agent_context) { { user: agent, account: account, account_user: account.account_users.first } }
permissions :index?, :show?, :update? do
context 'when administrator' do
it { expect(contact_policy).to permit(administrator, contact) }
it { expect(contact_policy).to permit(administrator_context, contact) }
end
context 'when agent' do
it { expect(contact_policy).not_to permit(agent, contact) }
it { expect(contact_policy).to permit(agent_context, contact) }
end
end
permissions :create? do
context 'when administrator' do
it { expect(contact_policy).to permit(administrator, contact) }
it { expect(contact_policy).to permit(administrator_context, contact) }
end
context 'when agent' do
it { expect(contact_policy).to permit(agent, contact) }
it { expect(contact_policy).to permit(agent_context, contact) }
end
end
end

View File

@@ -10,24 +10,26 @@ RSpec.describe InboxPolicy, type: :policy do
let(:administrator) { create(:user, :administrator, account: account) }
let(:agent) { create(:user, account: account) }
let(:inbox) { create(:inbox) }
let(:administrator_context) { { user: administrator, account: account, account_user: account.account_users.first } }
let(:agent_context) { { user: agent, account: account, account_user: account.account_users.first } }
permissions :create?, :destroy?, :update?, :set_agent_bot? do
context 'when administrator' do
it { expect(inbox_policy).to permit(administrator, inbox) }
it { expect(inbox_policy).to permit(administrator_context, inbox) }
end
context 'when agent' do
it { expect(inbox_policy).not_to permit(agent, inbox) }
it { expect(inbox_policy).not_to permit(agent_context, inbox) }
end
end
permissions :index? do
context 'when administrator' do
it { expect(inbox_policy).to permit(administrator, inbox) }
it { expect(inbox_policy).to permit(administrator_context, inbox) }
end
context 'when agent' do
it { expect(inbox_policy).to permit(agent, inbox) }
it { expect(inbox_policy).to permit(agent_context, inbox) }
end
end
end

View File

@@ -10,24 +10,26 @@ RSpec.describe UserPolicy, type: :policy do
let(:administrator) { create(:user, :administrator, account: account) }
let(:agent) { create(:user, account: account) }
let(:user) { create(:user, account: account) }
let(:administrator_context) { { user: administrator, account: account, account_user: account.account_users.first } }
let(:agent_context) { { user: agent, account: account, account_user: account.account_users.first } }
permissions :create?, :update?, :destroy? do
context 'when administrator' do
it { expect(user_policy).to permit(administrator, user) }
it { expect(user_policy).to permit(administrator_context, user) }
end
context 'when agent' do
it { expect(user_policy).not_to permit(agent, user) }
it { expect(user_policy).not_to permit(agent_context, user) }
end
end
permissions :index? do
context 'when administrator' do
it { expect(user_policy).to permit(administrator, user) }
it { expect(user_policy).to permit(administrator_context, user) }
end
context 'when agent' do
it { expect(user_policy).to permit(agent, user) }
it { expect(user_policy).to permit(agent_context, user) }
end
end
end