J'ai mis à jour la mise en œuvre doit être aussi proche que possible du RESTE de la spécification.
La configuration de base
Vous pouvez utiliser le mail_form gem. Après l'installation il suffit de créer un modèle nommé Message
similaires, comme il est décrit dans la documentation.
# app/models/message.rb
class Message < MailForm::Base
attribute :name, :validate => true
attribute :email, :validate => /\A([\w\.%\+\-]+)@([\w\-]+\.)+([\w]{2,})\z/i
attribute :message_title, :validate => true
attribute :message_body, :validate => true
def headers
{
:subject => "A message",
:to => "contact@domain.com",
:from => %("#{name}" <#{email}>)
}
end
end
Cela va déjà vous permettre de tester l'envoi d'e-mails via la console.
Page de Contact
Afin de créer une page de contact, procédez comme suit.
# app/controllers/messages_controller.rb
class MessagesController < ApplicationController
respond_to :html
def index
end
def create
message = Message.new(params[:contact_form])
if message.deliver
redirect_to root_path, :notice => 'Email has been sent.'
else
redirect_to root_path, :notice => 'Email could not be sent.'
end
end
end
Configuration du routage ..
# config/routes.rb
MyApp::Application.routes.draw do
# Other resources
resources :messages, only: [:index, :create]
match "contact" => "messages#index"
end
Préparer une forme partielle ..
// app/views/pages/_form.html.haml
= simple_form_for :contact_form, url: messages_path, method: :post do |f|
= f.error_notification
.form-inputs
= f.input :name
= f.input :email, label: 'Email address'
= f.input :message_title, label: 'Title'
= f.input :message_body, label: 'Your message', as: :text
.form-actions
= f.submit 'Submit'
Et de rendre le formulaire dans la vue ..
// app/views/messages/index.html.haml
#contactform.row
= render 'form'