Support #710
Building a Simple Messenger Web Application with Ruby on Rails
Description
- Table of contents
- The Main Page
- The Message Page
- Create the New Message Function
- Create the Show Message Function
- Resources
NOTE: This guide was adapted from the Ruby on Rails tutorial on Codecademy
- Create the new Ruby on Rails web application:
rails new message_app
- Change into the message_app directory:
cd message_app
- Start the rails development web server locally:
bundle exec rails s
- NOTE: The development web server bind the IP address to the localhost by default, so accessing it over the network will not work. To allow network access to the development web server:
bundle exec rails s -b 0.0.0.0
- NOTE: The development web server bind the IP address to the localhost by default, so accessing it over the network will not work. To allow network access to the development web server:
The Main Page¶
Main Page Controller¶
- Create a controller for the Page class:
rails generate controller Page
- Edit the routes file:
vi config/routes.rb
- And add the route for the default landing page:
Rails.application.routes.draw do get '/' => "page#home" end
- And add the route for the default landing page:
- Edit the Page controller:
vi app/controllers/page_controller.rb
- And create the home method:
class PageController < ApplicationController def home end end
- And create the home method:
Main Page View¶
- Edit the home page view:
vi app/views/page/home.html.erb
- And add the following bare html page:
<div class="main"> <div class="container"> <h1>Hello World!</h1> </div> </div>
- And add the following bare html page:
The Message Page¶
Create the Message Model¶
- Start by creating a Message model:
rails generate model Message
- Edit the database migrate file:
vi db/migrate/20151209164020_create_messages.rb
- And add the
*t.text :content*
to create the content row to the messages table:class CreateMessages < ActiveRecord::Migration def change create_table :messages do |t| t.text :content t.timestamps end end end
- And add the
- Run the database migration:
rake db:migrate
Create the Message Controller¶
- Create the Messages controller:
rails generate controller Messages
Index Method¶
- Next edit the routes file:
vi config/routes.rb
- Then map the URL /messages to the Messages controller index action:
Rails.application.routes.draw do get '/' => "page#home" get '/messages' => "messages#index" end
- Then map the URL /messages to the Messages controller index action:
- Edit the Messages controller:
vi app/controllers/messages_controller.rb
- And define an index method with a class array named @messages that contains all the messages in the database table:
class MessagesController < ApplicationController def index @messages = Message.all end end
- And define an index method with a class array named @messages that contains all the messages in the database table:
Create the Message View¶
- Edit the messages index Ruby HTML view:
vi app/views/messages/index.html.erb
- Then create a for loop to loop through the contents of the @messages array:
<div class="header"> <div class="container"> <h1>Messenger</h1> </div> </div> <div class="messages"> <div class="container"> <% @messages.each do |message| %> <div class="message"> <p class="content"><%= message.content %></p> <p class="time"><%= message.created_at %></p> </div> <% end %> </div> </div>
- Then create a for loop to loop through the contents of the @messages array:
Create the New Message Function¶
New Method¶
- Edit the routes file
vi config/routes.rb
- Then create a route that maps requests to messages/new to the Message controller's new action:
Rails.application.routes.draw do get '/' => "page#home" get '/messages' => 'messages#index' get 'messages/new' => 'messages#new' end
- Then create a route that maps requests to messages/new to the Message controller's new action:
- Edit the Messages controller:
vi app/controllers/messages_controller.rb
- And define the new method that adds new messages to the database table:
class MessagesController < ApplicationController def index @messages = Message.all end def new @message = Message.new end end
- And define the new method that adds new messages to the database table:
Create Method¶
- Edit the routes file again
vi config/routes.rb
- And map requests to the Message controller's create action:
Rails.application.routes.draw do get '/' => "page#home" get '/messages' => 'messages#index' get 'messages/new' => 'messages#new' post 'messages' => 'messages#create' end
- And map requests to the Message controller's create action:
- Edit the Messages controller again:
vi app/controllers/messages_controller.rb
- And create the create method and the private message_params method below the new method:
class MessagesController < ApplicationController def index @messages = Message.all end def new @message = Message.new end def create @message = Message.new(message_params) if @message.save redirect_to messages_path else render 'new' end end private def message_params params.require(:message).permit(:content) end end
- And create the create method and the private message_params method below the new method:
Create the New Message View¶
- Edit the new message Ruby HTML view:
vi app/views/messages/new.html.erb
- And add the following:
<div class="header"> <div class="container"> <h1>Messenger</h1> </div> </div> <div class="create"> <div class="container"> <%= form_for(@message) do |f| %> <div class="field"> <%= f.label :message %><br> <%= f.text_area :content %> </div> <div class="actions"> <%= f.submit "Create" %> </div> <% end %> </div> </div>
- And add the following:
- Edit the messages index Ruby HTML view:
vi app/views/messages/index.html.erb
- And add the link_to function:
<div class="header"> <div class="container"> <h1>Messenger</h1> </div> </div> <div class="messages"> <div class="container"> <% @messages.each do |message| %> <%= link_to 'New Message', messages_new_path %> <div class="message"> <p class="content"><%= message.content %></p> <p class="time"><%= message.created_at %></p> </div> <% end %> </div> </div>
- And add the link_to function:
Create the Show Message Function¶
- Edit the routes file again
vi config/routes.rb
- And map requests to the Message controller's create action:
Rails.application.routes.draw do get '/' => "page#home" get '/messages' => 'messages#index' get 'messages/new' => 'messages#new' post 'messages' => 'messages#create' get '/messages/:id', to: 'messages#show, as: 'message' end
- And map requests to the Message controller's create action:
Show Method¶
- Edit the Messages controller again:
vi app/controllers/messages_controller.rb
- And create the create method and the private message_params method below the new method:
class MessagesController < ApplicationController def index @messages = Message.all end def new @message = Message.new end def create @message = Message.new(message_params) if @message.save redirect_to messages_path else render 'new' end end private def message_params params.require(:message).permit(:content) end def show @message = Message.find(params[:id]) end end
- And create the create method and the private message_params method below the new method:
Create the Show Message View¶
- Edit the show message Ruby HTML view:
vi app/views/messages/show.html.erb
- And add the following:
<div class="header"> <div class="container"> <h1>Messenger</h1> </div> </div> <div class="show"> <div class="container"> <div class="message"> <%= @message.content %> </div> </div> </div>
- And add the following: