Add New Comment on your post notifications

This notification is sent only to the post owner, unless this person turned off the notifications.
A simple first step into the notifications by mail world :)

The mail contains a link to user profile
The link to the user profile is required to give an easy access to
notifications disabling.

Also having a preview for the notify_post_owner method

We can `Comment.first` because it is part of the db:seeds method. So
there should, in development, always be one.
This commit is contained in:
Kevin Vinhas
2021-01-29 00:49:27 +01:00
committed by Riccardo Graziosi
parent 9dfb13eff6
commit 007d08a051
10 changed files with 110 additions and 12 deletions

View File

@@ -30,6 +30,7 @@ It has been heavely inspired by [Canny.io](https://canny.io/) ("astuto", indeed,
* Boards, to divide different types of feedback
* Roadmap, to let your users know what you're working on
* Comments, to discuss with your customers
* Notifications, to inform post owner of comments
* Feedback labels, to inform about the state of a certain feedback
* Feedback updates, to notify your users with news regarding a certain feedback
* Completely customizable (i.e. you can add/edit/remove as many boards, feedback statuses as you want; you can configure the roadmap the way you want; etc.)

View File

@@ -1,6 +1,6 @@
class CommentsController < ApplicationController
before_action :authenticate_user!, only: [:create, :update]
def index
comments = Comment
.select(
@@ -23,6 +23,8 @@ class CommentsController < ApplicationController
comment = Comment.new(comment_params)
if comment.save
send_notifications(comment)
render json: comment.attributes.merge(
{ user_full_name: current_user.full_name, user_email: current_user.email}
), status: :created
@@ -55,14 +57,19 @@ class CommentsController < ApplicationController
end
private
def comment_params
params
.require(:comment)
.permit(:body, :parent_id, :is_post_update)
.merge(
user_id: current_user.id,
post_id: params[:post_id]
)
end
def comment_params
params
.require(:comment)
.permit(:body, :parent_id, :is_post_update)
.merge(
user_id: current_user.id,
post_id: params[:post_id]
)
def send_notifications(comment)
if comment.post.user.notifications_enabled?
UserMailer.notify_post_owner(comment: comment).deliver_later
end
end
end

View File

@@ -0,0 +1,10 @@
class UserMailer < ApplicationMailer
default from: "notifications@example.com"
def notify_post_owner(comment:)
@comment = comment
@user = comment.post.user
mail(to: @user.email, subject: "[#{ENV.fetch('APP_NAME')}] - New comment on #{comment.post.title}")
end
end

View File

@@ -0,0 +1,17 @@
<!DOCTYPE html>
<html>
<head>
<meta content='text/html; charset=UTF-8' http-equiv='Content-Type' />
</head>
<body>
<h1>Hello, <%= @user.full_name %></h1>
<p>
There is a new comment by <%= @comment.user.full_name %> on your post <b><%= @comment.post.title %></b>
</p>
<p> To see this comment, <%= link_to "Click here", post_url(@comment.post) %> </p>
<p>Have a great day!</p>
</body>
<footer>
Annoyed ? You can <%= link_to("turn off notifications here", edit_user_registration_url) %>
</footer>
</html>

View File

@@ -9,7 +9,6 @@ ENV["POSTS_PER_PAGE"] = "15"
Rails.application.configure do
# Settings specified here will take precedence over those in config/application.rb.
# For Devise
config.action_mailer.default_url_options = { host: 'localhost:3000' }
@@ -46,6 +45,7 @@ Rails.application.configure do
# The :test delivery method accumulates sent emails in the
# ActionMailer::Base.deliveries array.
config.action_mailer.delivery_method = :test
config.active_job.queue_adapter = :test
# Print deprecation notices to the stderr.
config.active_support.deprecation = :stderr

View File

@@ -0,0 +1,6 @@
# Preview all emails at http://localhost:3000/rails/mailers/user_mailer
class UserMailerPreview < ActionMailer::Preview
def notify_post_owner
UserMailer.notify_post_owner(comment: Comment.first)
end
end

View File

@@ -0,0 +1,22 @@
require "rails_helper"
RSpec.describe UserMailer, type: :mailer do
describe "notify_comment" do
let(:user) { FactoryBot.create(:user, email: "notified@example.com", notifications_enabled: true) }
let(:post) { FactoryBot.create(:post, user: user)}
let(:comment) { FactoryBot.create(:comment, post: post) }
let(:mail) { UserMailer.notify_post_owner(comment: comment) }
it "renders the headers" do
expect(mail.subject).to eq("[#{ENV.fetch('APP_NAME')}] - New comment on #{post.title}")
expect(mail.to).to eq(["notified@example.com"])
expect(mail.from).to eq(["notifications@example.com"])
end
it "renders the body" do
expect(mail.body.encoded).to include("Hello, #{user.full_name}")
expect(mail.body.encoded).to include("There is a new comment by")
expect(mail.body.encoded).to include('Annoyed ? You can <a href="http://localhost:3000/users/edit">turn off notifications here</a>')
end
end
end

View File

@@ -0,0 +1,5 @@
RSpec.configure do |config|
config.before(:each) do
ActionMailer::Base.deliveries.clear
end
end

View File

@@ -108,4 +108,34 @@ feature 'comments', type: :system, js: true do
expect(Comment.where(post_id: post.id).count).to eq(comments_count + 1)
end
end
it 'notifies post owner when comment is posted' do
log_in_as user
visit post_path(post)
allow(UserMailer).to receive_message_chain(:notify_post_owner, :deliver_later)
comment_body = 'this is a comment!'
find(newCommentBodySelector).fill_in with: comment_body
click_button 'Submit'
visit post_path(post)
expect(UserMailer).to have_received(:notify_post_owner)
end
it 'does not notify the post owner if he refused notifications' do
post_owner = FactoryBot.create(:user, notifications_enabled: false)
post = FactoryBot.create(:post, user: post_owner)
log_in_as user
visit post_path(post)
allow(UserMailer).to receive_message_chain(:notify_post_owner, :deliver_later)
comment_body = 'this is a comment!'
find(newCommentBodySelector).fill_in with: comment_body
click_button 'Submit'
visit post_path(post)
expect(UserMailer).not_to have_received(:notify_post_owner)
end
end

View File

@@ -77,7 +77,7 @@ feature 'sign up', type: :system do
expect(page).to have_css('.alert')
end
scenario 'and disables notifications' do
scenario 'with disabled notifications' do
visit new_user_registration_path
fill_in 'Full name', with: user.full_name
fill_in 'Email', with: user.email