Browse Source
			
			
			
			
				
		* [CLDC-2202] Allow coordinators to set created_by * Scope user selection when data coordinator * Remove managing_for_other_user_enabled * Move sales created_by page and question out of common * Address comments - only select required users - remove not needed CYA checkspull/1601/head
				 15 changed files with 256 additions and 247 deletions
			
			
		| @ -1,16 +0,0 @@ | ||||
| class Form::Common::Pages::CreatedBy < ::Form::Page | ||||
|   def initialize(id, hsh, subsection) | ||||
|     super | ||||
|     @id = "created_by" | ||||
|   end | ||||
| 
 | ||||
|   def questions | ||||
|     @questions ||= [ | ||||
|       Form::Common::Questions::CreatedById.new(nil, nil, self), | ||||
|     ] | ||||
|   end | ||||
| 
 | ||||
|   def routed_to?(_log, current_user) | ||||
|     !!current_user&.support? | ||||
|   end | ||||
| end | ||||
| @ -1,46 +0,0 @@ | ||||
| class Form::Common::Questions::CreatedById < ::Form::Question | ||||
|   def initialize(id, hsh, page) | ||||
|     super | ||||
|     @id = "created_by_id" | ||||
|     @check_answer_label = "User" | ||||
|     @header = "Which user are you creating this log for?" | ||||
|     @type = "select" | ||||
|   end | ||||
| 
 | ||||
|   def answer_options | ||||
|     answer_opts = { "" => "Select an option" } | ||||
|     return answer_opts unless ActiveRecord::Base.connected? | ||||
| 
 | ||||
|     User.select(:id, :name).each_with_object(answer_opts) do |user, hsh| | ||||
|       hsh[user.id] = user.name | ||||
|       hsh | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def displayed_answer_options(log, _user = nil) | ||||
|     return answer_options unless log.owning_organisation | ||||
| 
 | ||||
|     user_ids = log.owning_organisation.users.pluck(:id) + [""] | ||||
|     answer_options.select { |k, _v| user_ids.include?(k) } | ||||
|   end | ||||
| 
 | ||||
|   def label_from_value(value, _log = nil, _user = nil) | ||||
|     return unless value | ||||
| 
 | ||||
|     answer_options[value] | ||||
|   end | ||||
| 
 | ||||
|   def hidden_in_check_answers?(_log, current_user) | ||||
|     !current_user.support? | ||||
|   end | ||||
| 
 | ||||
|   def derived? | ||||
|     true | ||||
|   end | ||||
| 
 | ||||
| private | ||||
| 
 | ||||
|   def selected_answer_option_is_derived?(_log) | ||||
|     false | ||||
|   end | ||||
| end | ||||
| @ -0,0 +1,19 @@ | ||||
| class Form::Sales::Pages::CreatedBy < ::Form::Page | ||||
|   def initialize(id, hsh, subsection) | ||||
|     super | ||||
|     @id = "created_by" | ||||
|   end | ||||
| 
 | ||||
|   def questions | ||||
|     @questions ||= [ | ||||
|       Form::Sales::Questions::CreatedById.new(nil, nil, self), | ||||
|     ] | ||||
|   end | ||||
| 
 | ||||
|   def routed_to?(_log, current_user) | ||||
|     return true if current_user&.support? | ||||
|     return true if current_user&.data_coordinator? | ||||
| 
 | ||||
|     false | ||||
|   end | ||||
| end | ||||
| @ -0,0 +1,54 @@ | ||||
| class Form::Sales::Questions::CreatedById < ::Form::Question | ||||
|   ANSWER_OPTS = { "" => "Select an option" }.freeze | ||||
| 
 | ||||
|   def initialize(id, hsh, page) | ||||
|     super | ||||
|     @id = "created_by_id" | ||||
|     @check_answer_label = "User" | ||||
|     @header = "Which user are you creating this log for?" | ||||
|     @type = "select" | ||||
|   end | ||||
| 
 | ||||
|   def answer_options | ||||
|     ANSWER_OPTS | ||||
|   end | ||||
| 
 | ||||
|   def displayed_answer_options(log, current_user = nil) | ||||
|     return ANSWER_OPTS unless log.owning_organisation | ||||
|     return ANSWER_OPTS unless current_user | ||||
| 
 | ||||
|     users = current_user.support? ? log.owning_organisation.users : current_user.organisation.users | ||||
| 
 | ||||
|     users.each_with_object(ANSWER_OPTS.dup) do |user, hsh| | ||||
|       hsh[user.id] = present_user(user) | ||||
|       hsh | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def label_from_value(value, _log = nil, _user = nil) | ||||
|     return unless value | ||||
| 
 | ||||
|     present_user(User.find(value)) | ||||
|   end | ||||
| 
 | ||||
|   def hidden_in_check_answers?(_log, current_user) | ||||
|     return false if current_user.support? | ||||
|     return false if current_user.data_coordinator? | ||||
| 
 | ||||
|     true | ||||
|   end | ||||
| 
 | ||||
|   def derived? | ||||
|     true | ||||
|   end | ||||
| 
 | ||||
| private | ||||
| 
 | ||||
|   def present_user(user) | ||||
|     "#{user.name} (#{user.email})" | ||||
|   end | ||||
| 
 | ||||
|   def selected_answer_option_is_derived?(_log) | ||||
|     false | ||||
|   end | ||||
| end | ||||
| @ -1,82 +0,0 @@ | ||||
| require "rails_helper" | ||||
| 
 | ||||
| RSpec.describe Form::Common::Questions::CreatedById, type: :model do | ||||
|   subject(:question) { described_class.new(question_id, question_definition, page) } | ||||
| 
 | ||||
|   let(:question_id) { nil } | ||||
|   let(:question_definition) { nil } | ||||
|   let(:page) { instance_double(Form::Page) } | ||||
|   let(:subsection) { instance_double(Form::Subsection) } | ||||
|   let(:form) { instance_double(Form) } | ||||
|   let(:user_1) { FactoryBot.create(:user, name: "first user") } | ||||
|   let(:user_2) { FactoryBot.create(:user, name: "second user") } | ||||
|   let!(:expected_answer_options) do | ||||
|     { | ||||
|       "" => "Select an option", | ||||
|       user_1.id => user_1.name, | ||||
|       user_2.id => user_2.name, | ||||
|     } | ||||
|   end | ||||
| 
 | ||||
|   it "has correct page" do | ||||
|     expect(question.page).to eq(page) | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct id" do | ||||
|     expect(question.id).to eq("created_by_id") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct header" do | ||||
|     expect(question.header).to eq("Which user are you creating this log for?") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct check_answer_label" do | ||||
|     expect(question.check_answer_label).to eq("User") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct type" do | ||||
|     expect(question.type).to eq("select") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct hint_text" do | ||||
|     expect(question.hint_text).to be_nil | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct answer options" do | ||||
|     expect(question.answer_options).to eq(expected_answer_options) | ||||
|   end | ||||
| 
 | ||||
|   it "is marked as derived" do | ||||
|     expect(question.derived?).to be true | ||||
|   end | ||||
| 
 | ||||
|   context "when the current user is support" do | ||||
|     let(:support_user) { FactoryBot.build(:user, :support) } | ||||
| 
 | ||||
|     it "is shown in check answers" do | ||||
|       expect(question.hidden_in_check_answers?(nil, support_user)).to be false | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   context "when the current user is not support" do | ||||
|     let(:user) { FactoryBot.build(:user) } | ||||
| 
 | ||||
|     it "is not shown in check answers" do | ||||
|       expect(question.hidden_in_check_answers?(nil, user)).to be true | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   context "when the owning organisation is already set" do | ||||
|     let(:lettings_log) { FactoryBot.create(:lettings_log, owning_organisation: user_2.organisation) } | ||||
|     let(:expected_answer_options) do | ||||
|       { | ||||
|         "" => "Select an option", | ||||
|         user_2.id => user_2.name, | ||||
|       } | ||||
|     end | ||||
| 
 | ||||
|     it "only displays users that belong to that organisation" do | ||||
|       expect(question.displayed_answer_options(lettings_log)).to eq(expected_answer_options) | ||||
|     end | ||||
|   end | ||||
| end | ||||
| @ -0,0 +1,88 @@ | ||||
| require "rails_helper" | ||||
| 
 | ||||
| RSpec.describe Form::Sales::Questions::CreatedById, type: :model do | ||||
|   subject(:question) { described_class.new(question_id, question_definition, page) } | ||||
| 
 | ||||
|   let(:question_id) { nil } | ||||
|   let(:question_definition) { nil } | ||||
|   let(:page) { instance_double(Form::Page) } | ||||
|   let(:subsection) { instance_double(Form::Subsection) } | ||||
|   let(:form) { instance_double(Form) } | ||||
| 
 | ||||
|   it "has correct page" do | ||||
|     expect(question.page).to eq(page) | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct id" do | ||||
|     expect(question.id).to eq("created_by_id") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct header" do | ||||
|     expect(question.header).to eq("Which user are you creating this log for?") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct check_answer_label" do | ||||
|     expect(question.check_answer_label).to eq("User") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct type" do | ||||
|     expect(question.type).to eq("select") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct hint_text" do | ||||
|     expect(question.hint_text).to be_nil | ||||
|   end | ||||
| 
 | ||||
|   it "is marked as derived" do | ||||
|     expect(question.derived?).to be true | ||||
|   end | ||||
| 
 | ||||
|   context "when the current user is support" do | ||||
|     let(:support_user) { build(:user, :support) } | ||||
| 
 | ||||
|     it "is shown in check answers" do | ||||
|       expect(question.hidden_in_check_answers?(nil, support_user)).to be false | ||||
|     end | ||||
| 
 | ||||
|     describe "#displayed_answer_options" do | ||||
|       let(:owning_org_user) { create(:user) } | ||||
|       let(:sales_log) { create(:sales_log, owning_organisation: owning_org_user.organisation) } | ||||
|       let(:expected_answer_options) do | ||||
|         { | ||||
|           "" => "Select an option", | ||||
|           owning_org_user.id => "#{owning_org_user.name} (#{owning_org_user.email})", | ||||
|         } | ||||
|       end | ||||
| 
 | ||||
|       it "only displays users that belong to the owning organisation" do | ||||
|         expect(question.displayed_answer_options(sales_log, support_user)).to eq(expected_answer_options) | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   context "when the current user is data_coordinator" do | ||||
|     let(:data_coordinator) { create(:user, :data_coordinator) } | ||||
| 
 | ||||
|     it "is shown in check answers" do | ||||
|       expect(question.hidden_in_check_answers?(nil, data_coordinator)).to be false | ||||
|     end | ||||
| 
 | ||||
|     describe "#displayed_answer_options" do | ||||
|       let(:owning_org_user) { create(:user) } | ||||
|       let(:sales_log) { create(:sales_log, owning_organisation: owning_org_user.organisation) } | ||||
|       let!(:user_in_same_org) { create(:user, organisation: data_coordinator.organisation) } | ||||
| 
 | ||||
|       let(:expected_answer_options) do | ||||
|         { | ||||
|           "" => "Select an option", | ||||
|           user_in_same_org.id => "#{user_in_same_org.name} (#{user_in_same_org.email})", | ||||
|           data_coordinator.id => "#{data_coordinator.name} (#{data_coordinator.email})", | ||||
|         } | ||||
|       end | ||||
| 
 | ||||
|       it "only displays users that belong user's org" do | ||||
|         expect(question.displayed_answer_options(sales_log, data_coordinator)).to eq(expected_answer_options) | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| end | ||||
					Loading…
					
					
				
		Reference in new issue