Commit c091bfbf35937bdd629423e06c9515e806362c8e
Committed by
Antonio Terceiro
1 parent
f3f04a53
Exists in
master
and in
23 other branches
ActionItem791: send copy of message to requester
Showing
4 changed files
with
25 additions
and
1 deletions
Show diff stats
app/models/contact.rb
| ... | ... | @@ -5,7 +5,8 @@ class Contact < ActiveRecord::Base #WithoutTable |
| 5 | 5 | [:message, :string], |
| 6 | 6 | [:email, :string], |
| 7 | 7 | [:state, :string], |
| 8 | - [:city, :string] | |
| 8 | + [:city, :string], | |
| 9 | + [:receive_a_copy, :boolean] | |
| 9 | 10 | ] |
| 10 | 11 | attr_accessor :dest |
| 11 | 12 | |
| ... | ... | @@ -23,6 +24,9 @@ class Contact < ActiveRecord::Base #WithoutTable |
| 23 | 24 | emails = [contact.dest.contact_email] + contact.dest.admins.map{|i| i.email} |
| 24 | 25 | recipients emails |
| 25 | 26 | from "#{contact.name} <#{contact.email}>" |
| 27 | + if contact.receive_a_copy | |
| 28 | + cc "#{contact.name} <#{contact.email}>" | |
| 29 | + end | |
| 26 | 30 | subject contact.subject |
| 27 | 31 | body :name => contact.name, |
| 28 | 32 | :email => contact.email, | ... | ... |
app/views/contact/new.rhtml
| ... | ... | @@ -9,6 +9,7 @@ |
| 9 | 9 | <%= labelled_form_field _('City and state'), select_city(true) %> |
| 10 | 10 | <%= f.text_field :subject %> |
| 11 | 11 | <%= f.text_area :message, :rows => 10, :cols => 60 %> |
| 12 | + <%= labelled_form_field check_box(:contact, :receive_a_copy) + _('Want to receive a copy of your message in your mailbox?'), '' %> | |
| 12 | 13 | |
| 13 | 14 | <%= submit_button(:send, _('Send')) %> |
| 14 | 15 | ... | ... |
test/functional/contact_controller_test.rb
| ... | ... | @@ -69,4 +69,9 @@ class ContactControllerTest < Test::Unit::TestCase |
| 69 | 69 | assert_equal 'Bahia', assigns(:contact).state |
| 70 | 70 | end |
| 71 | 71 | |
| 72 | + should 'display checkbox for receive copy of email' do | |
| 73 | + get :new, :profile => enterprise.identifier | |
| 74 | + assert_tag :tag => 'input', :attributes => {:name => 'contact[receive_a_copy]'} | |
| 75 | + end | |
| 76 | + | |
| 72 | 77 | end | ... | ... |
test/unit/contact_sender_test.rb
| ... | ... | @@ -41,6 +41,20 @@ class ContactSenderTest < Test::Unit::TestCase |
| 41 | 41 | assert_includes response.to, admin.email |
| 42 | 42 | end |
| 43 | 43 | |
| 44 | + should 'deliver a copy of email if requester wants' do | |
| 45 | + ent = Enterprise.new(:name => 'my enterprise', :identifier => 'myent', :environment => Environment.default) | |
| 46 | + c = Contact.new(:dest => ent, :email => 'requester@invalid.com', :receive_a_copy => true) | |
| 47 | + response = Contact::Sender.deliver_mail(c) | |
| 48 | + assert_includes response.cc, c.email | |
| 49 | + end | |
| 50 | + | |
| 51 | + should 'not deliver a copy of email if requester dont wants' do | |
| 52 | + ent = Enterprise.new(:name => 'my enterprise', :identifier => 'myent', :environment => Environment.default) | |
| 53 | + c = Contact.new(:dest => ent, :email => 'requester@invalid.com', :receive_a_copy => false) | |
| 54 | + response = Contact::Sender.deliver_mail(c) | |
| 55 | + assert_nil response.cc | |
| 56 | + end | |
| 57 | + | |
| 44 | 58 | private |
| 45 | 59 | |
| 46 | 60 | def read_fixture(action) | ... | ... |