筛选后如何更新页面上的图表(Chartkick)?

问题描述 投票:0回答:1

我有一个问题。我使用ransack做了一些过滤器,它们工作得很好,但我不知道如何更新我在过滤的表格下实现的饼图。这个图表是用Chartkick做的。我对ror和一般的编程相当陌生。这是我的索引文件。

<h1>Lista Przychodów</h1>

<h2><%= link_to 'Nowy Przychód', new_income_path %></h2>

<%= search_form_for @q do |f| %>

 <div class="field">
 <%= f.label :title_cont, "Tytuł zawiera" %>
 <%= f.search_field :title_cont %>
 </div>

 <div class="field">
 <%= f.label :text_cont, "Opis zawiera" %>
 <%= f.search_field :text_cont %>
 </div>

 <div class="field">
 <%= f.label :category_name_cont, "Kategoria zawiera" %>
 <%= f.search_field :category_name_cont %>
 </div>

 <div class="field">
 <%= f.label :amount_gteq, "Kwota pomiędzy" %>
 <%= f.search_field :amount_gteq %>
 <%= f.label :amount_lteq, "a" %>
 <%= f.search_field :amount_lteq %>
 </div>

 <%= f.submit "Szukaj" %>

 <div class="button">
 <%= link_to 'Wyczyść filtry', request.path, class:"cancel-button" %>
 </div>

<% end %>

<div style="overflow-x:auto;">


<table class="center">
 <tr>
   <th><%= sort_link(@q, :title, 'Tytuł', default_order: :desc) %></th>
   <th><%= sort_link(@q, :text, 'Opis') %></th>
   <th><%= sort_link(@q, :amount, 'Kwota') %></th>
   <th><%= sort_link(@q, :category_id, 'Kategoria') %></th>
   <th colspan="3"></th>
 </tr>

 <% @incomes.each do |income| %>
   <tr>
     <td><%= income.title %></td>
     <td><%= income.text %></td>
     <td><%= number_to_currency(income.amount, :unit => "zł", :format => "%n %u") %></td>
     <td><%= Category.find(income.category_id).name %></td>
     <td><%= link_to 'Pokaż', income_path(income) %></td>
     <td><%= link_to 'Edytuj', edit_income_path(income) %></td>
     <td><%= link_to 'Usuń', income_path(income),
             method: :delete,
             data: { confirm: 'Czy na pewno chcesz usunąć ten wpis?' } %></td>
   </tr>
 <% end %>
</table>

</div>

<%= pie_chart Income.joins(:category).group(:name).sum(:amount),suffix: " zł", thousands: ",", messages: {empty: "Nie ma wpisów"}, download: {filename: "wykres"}, title: "Podział przychodów na kategorie" %>

<footer><%= link_to 'Strona główna', controller: 'welcome' %></footer>

还有我的控制器文件,如果需要的话

class IncomesController < ApplicationController
  helper_method :sort_column, :sort_direction

  http_basic_authenticate_with name: "admin", password: "admin", except: [:index, :show]

  def index
    @q = Income.search(params[:q])
    @incomes = @q.result.includes(:category)
  end

  def show
    @income = Income.find(params[:id])
  end

  def new
    @income = Income.new
    @categories = Category.all.map { |c| [c.name, c.id]}
  end

  def edit
    @income = Income.find(params[:id])
    @categories = Category.all.map { |c| [c.name, c.id]}
  end

  def create
    @income = Income.new(income_params)
    @categories = Category.all.map { |c| [c.name, c.id]}

    if @income.save
      redirect_to @income
    else
      render 'new'
    end
  end

  def update
    @income = Income.find(params[:id])

    if @income.update(income_params)
      redirect_to @income
    else
      render 'edit'
    end
  end

  def destroy
    @income = Income.find(params[:id])
    @income.destroy

    redirect_to incomes_path
  end

  private
    def income_params
      params.require(:income).permit(:title, :text, :amount, :category_id)
    end

    def sort_column
        params[:sort] || "title"
    end

    def sort_direction
        params[:direction] || "asc"
    end
end

我已经在互联网上找过类似的问题 但没有找到任何答案 我希望能得到一些帮助,或者至少能得到一些指导。我真的迷上了ror,想了解更多关于它的信息,这就是为什么我来到这里寻求帮助。先谢谢你的回答。

html ruby-on-rails ruby chartkick
1个回答
1
投票

如果你的意思是在表上应用了过滤器,但没有在图表上应用,这是因为你在这一行中,只对图表做了另一个查询。

<%= pie_chart Income.joins(:category).group(:name).sum(:amount),suffix: " zł", thousands: ",", messages: {empty: "Nie ma wpisów"}, download: {filename: "wykres"}, title: "Podział przychodów na kategorie" %>

你应该使用相同的实例变量来处理过滤后的数据。

@incomes

所以应该是这样的:

<%= pie_chart @incomes.sum(:amount), suffix: " zł", thousands: ",", messages: { empty: "Nie ma wpisów" }, download: { filename: "wykres" }, title: "Podział przychodów na kategorie" %>
© www.soinside.com 2019 - 2024. All rights reserved.