mirror of
https://github.com/Retrospring/retrospring.git
synced 2025-01-18 14:05:59 +01:00
added inbox ajax thing
This commit is contained in:
parent
0226cff3e4
commit
1702c2fca4
6 changed files with 81 additions and 1 deletions
|
@ -33,7 +33,41 @@ $(document).on "click", "button[name=qb-ask]", ->
|
|||
$("div#question-box").hide()
|
||||
$("div#question-box-promote").show()
|
||||
$.snackbar # allahu snackbar
|
||||
content: "Successfully asked question"
|
||||
content: data.message
|
||||
style: "snackbar"
|
||||
timeout: 5000
|
||||
else
|
||||
console.log data, status, jqxhr
|
||||
$.snackbar # allahu snackbar
|
||||
content: "An error occurred, a developer should check the console for details"
|
||||
style: "snackbar"
|
||||
timeout: 5000
|
||||
error: (jqxhr, status, error) ->
|
||||
console.log jqxhr, status, error
|
||||
$.snackbar # allahu snackbar
|
||||
content: "An error occurred, a developer should check the console for details"
|
||||
style: "snackbar"
|
||||
timeout: 5000
|
||||
complete: (jqxhr, status) ->
|
||||
btn.button "reset"
|
||||
$("textarea[name=qb-question]").removeAttr "readonly"
|
||||
|
||||
$(document).on "click", "button[name=ib-answer]", ->
|
||||
btn = $(this)
|
||||
btn.button "loading"
|
||||
iid = $("input[name=ib-id]").val()
|
||||
$.ajax
|
||||
url: '/ajax/inbox' # TODO: find a way to use rake routes instead of hardcoding them here
|
||||
type: 'POST'
|
||||
data:
|
||||
id: iid
|
||||
answer: $("textarea[name=ib-answer]").val()
|
||||
success: (data, status, jqxhr) ->
|
||||
if data.success
|
||||
$("div#inbox-box[data-id=#{iid}]").val ''
|
||||
$("div#inbox-box").slideUp()
|
||||
$.snackbar # allahu snackbar
|
||||
content: data.message
|
||||
style: "snackbar"
|
||||
timeout: 5000
|
||||
else
|
||||
|
|
33
app/controllers/ajax/inbox_controller.rb
Normal file
33
app/controllers/ajax/inbox_controller.rb
Normal file
|
@ -0,0 +1,33 @@
|
|||
class Ajax::InboxController < ApplicationController
|
||||
def destroy
|
||||
params.require :id
|
||||
params.require :answer
|
||||
|
||||
question = Question.create!(content: params[:question],
|
||||
author_is_anonymous: params[:anonymousQuestion],
|
||||
user: current_user)
|
||||
|
||||
unless current_user.nil?
|
||||
current_user.increment! :answered_count
|
||||
end
|
||||
|
||||
inbox = Inbox.find(params[:id]).first
|
||||
|
||||
unless current_user.id == Inbox.user_id
|
||||
@status = :fail
|
||||
@message = "question not in your inbox"
|
||||
@success = false
|
||||
return
|
||||
end
|
||||
|
||||
answer = Answer.create(content: params[:answer],
|
||||
user: current_user,
|
||||
question: inbox.question)
|
||||
|
||||
Inbox.destroy inbox.id
|
||||
|
||||
@status = :okay
|
||||
@message = "Successfully answered question."
|
||||
@success = true
|
||||
end
|
||||
end
|
1
app/views/ajax/inbox/destroy.json.jbuilder
Normal file
1
app/views/ajax/inbox/destroy.json.jbuilder
Normal file
|
@ -0,0 +1 @@
|
|||
json.partial! 'ajax/shared/status'
|
|
@ -25,6 +25,7 @@ Rails.application.routes.draw do
|
|||
|
||||
namespace :ajax do
|
||||
match '/ask', to: 'question#create', via: :post, as: :ask
|
||||
match '/answer', to: 'inbox#destroy', via: :post, as: :answer
|
||||
end
|
||||
|
||||
match '/inbox', to: 'inbox#show', via: 'get'
|
||||
|
|
7
test/controllers/ajax/inbox_controller_test.rb
Normal file
7
test/controllers/ajax/inbox_controller_test.rb
Normal file
|
@ -0,0 +1,7 @@
|
|||
require 'test_helper'
|
||||
|
||||
class Ajax::InboxControllerTest < ActionController::TestCase
|
||||
# test "the truth" do
|
||||
# assert true
|
||||
# end
|
||||
end
|
4
test/helpers/ajax/inbox_helper_test.rb
Normal file
4
test/helpers/ajax/inbox_helper_test.rb
Normal file
|
@ -0,0 +1,4 @@
|
|||
require 'test_helper'
|
||||
|
||||
class Ajax::InboxHelperTest < ActionView::TestCase
|
||||
end
|
Loading…
Reference in a new issue