在Rails中更改数据库值的按钮

时间:2016-05-04 15:38:24

标签: javascript jquery mysql ruby-on-rails button

组show.html.erb的一部分看起来像:

  <% if !@pending.empty? %>
<div class="panel panel-default">
  <div class="panel-heading"> <h4>Pending Approvals for Group</h4></div>
    <table class="table", style="border-collapse: separate; border-spacing: 5px 1px;">
      <thead>
        <tr>
          <th>User Email</th>
          <th>Accept/Reject</th>
        </tr>
      </thead>
    <% @pending.each do |individual| %>
      <tbody>
        <tr>
          <td><%= individual.user.email %></td>
          <td>Accept/Reject (BUTTONS HERE)</td>
        </tr>
      </tbody>
    <% end %>
    </table>
  </div>
</div>
  <% end %>

我需要有两个按钮来更改数据库列成员资格中的值,而不是Accept / Reject。接受会产生&#34;成员&#34;的价值。拒绝将拒绝&#34;拒绝&#34;。但是,此更改位于GroupUser而非Group,它是Groups和Users的联合表。

换句话说,接受按钮基本上会<% individual.update(membership: "member")%>,拒绝会<% individual.update(membership: "denied")%>

然后该按钮将更改为“已批准”或“已拒绝”。我尝试了各种选项,但它们似乎都没有用。我不确定是否/如何使用javascript或jQuery实现它。

这是我尝试创建一个&#34;加入小组&#34;请求功能,允许其他用户请求加入私人组并获得会员资格。

1 个答案:

答案 0 :(得分:0)

我需要的只是一个链接(按钮),它将参数传递给控制器​​,根据这些参数进行更改,如下所示:

分组show.html.erb

        <td><%= link_to 'Accept', {:controller => "group",
                                   :action => "decision",
                                   :id => individual.group_id,
                                   :user_id => individual.user.id,
                                   :decision => "true"}, method: 'post', class: "btn btn-sm btn-success" %>

组控制器

  def decision
    @groupUser = GroupUser.where(group_id: params[:id], user_id: params[:user_id])
    if params[:decision] == "true"
      @groupUser.update(membership: "member")
      Homework.where(group_id: params[:id]).find_each do |hw|
        UserHomework.create(user_id: params[:user_id], homework_id: hw.id, admin: true, status: 'No attempt')
      end
    else
      @groupUser.update(membership: "denied")
    end
    redirect_to groupshow_path(:id => params[:id])
  end