Sortir_menurut dalam Hash - mundur atau tidak mundur - bagaimana caranya?

Saya memiliki hash, di bawah ini:

library = {"1"=>{"title"=>"bbb", "money"=>10}, "2"=>{"title"=>"aaa", "money"=>12}}

dan application_helper.rb saya:

  def sortable_columns
    %w[title money]
  end

  def sort_column
    sortable_columns.include?(params[:column]) ? params[:column] : "title"
  end

  def sort_direction
    %w[asc desc].include?(params[:direction]) ? params[:direction] : "asc"
  end

  def sort_link(column, title)
    direction = column == sort_column && sort_direction == "asc" ? "desc" : "asc"
    icon = sort_direction == "asc" ? "fa fa-arrow-down" : "fa fa-arrow-up"
    icon = column == sort_column ? icon : ""
    link_to "#{title} <i class='#{icon}'></i>".html_safe, {column: column, direction: direction}
  end

Tabel saya di table.html.erb:

          <table class="table table-striped">
            <thead>
            <tr>
                <th>#</th>
                <% sortable_columns.each do |column| %>
                  <th><%= sort_link column, column %></th>
                <% end %>
            </tr>
            </thead>
            <tbody>
              <% library.sort_by {|k| k[1][sort_column]}.each_with_index do |data, i| %>
               ...

              <% end %>
            </tbody>
          </table>

dan sekarang - setelah klik di header "judul" atau "uang" - ASC penyortiran tabel. Saya ingin DESC ditampilkan ketika diklik lagi (dengan ikon panah ke bawah). Bagaimana hal ini dapat dilakukan? Saya berpikir tentang "membalikkan", setelah library.sort_by {|k| k[1][sort_column]}, tetapi tidak berhasil.


person Kamil Pikula    schedule 21.05.2019    source sumber
comment
Karena seluruh perpustakaan dirender di sisi klien – sudahkah Anda mempertimbangkan untuk menggunakan salah satu dari berbagai solusi penyortiran tabel JavaScript yang ada?   -  person Stefan    schedule 21.05.2019
comment
Tidak, saya belum mempertimbangkannya. Apakah Anda punya ide?   -  person Kamil Pikula    schedule 21.05.2019
comment
tablesorter mungkin? Anda juga dapat menulis sendiri, lihat Menyortir tabel HTML dengan JavaScript   -  person Stefan    schedule 21.05.2019
comment
BTW, mengapa Anda memasukkan data ke dalam hash daripada tabel database? Bukankah lebih masuk akal menggunakan ActiveRecord, mengingat ini adalah pertanyaan Rails?   -  person Stefan    schedule 21.05.2019
comment
@Stefan karena saya mendapatkan data dari api di json dan saya tidak perlu menyimpannya di database. Cara Anda berhasil, tetapi saya menggunakan metode tap di Ruby. Terima kasih. :)   -  person Kamil Pikula    schedule 22.05.2019


Jawaban (2)


berhasil terbalik:

library = {"1"=>{"title"=>"bbb", "money"=>10}, "2"=>{"title"=>"aaa", "money"=>12}}

sort_column = "money"

sort_direction = "asc"
library
  .sort_by {|k| k[1][sort_column]}
  .tap { |l| l.reverse! if sort_direction == "desc" }
# => [["1", {"title"=>"bbb", "money"=>10}], ["2", {"title"=>"aaa", "money"=>12}]]

sort_direction = "desc"
library
  .sort_by {|k| k[1][sort_column]}
  .tap { |l| l.reverse! if sort_direction == "desc" }
# => [["2", {"title"=>"aaa", "money"=>12}], ["1", {"title"=>"bbb", "money"=>10}]]
person fphilipe    schedule 21.05.2019
comment
Sayangnya - tidak, library bukan relasi AR, melainkan ActiveSupport::HashWithIndifferentAccess - person Kamil Pikula; 21.05.2019
comment
@KamilPikula apa kunci dan nilainya? Apakah Anda mengatakan ini adalah array ActiveSupport::HashWithIndifferentAccess yang setiap elemennya berupa baris dan kolom yang ingin Anda urutkan adalah kunci di setiap hash? - person fphilipe; 21.05.2019
comment
@KamilPikula, maaf, saya melewatkan library dalam pertanyaan Anda. Memperbarui jawaban saya. - person fphilipe; 21.05.2019
comment
Sial, saya benar-benar lupa tentang metode tap di Ruby. Berhasil, terima kasih banyak @fphilipe! - person Kamil Pikula; 22.05.2019

Anda dapat meminta maaf seperti di bawah ini

jika diurutkan berdasarkan judul saja

library.values.sort_by{|h| h["title"] }

atau Anda ingin mengurutkan berdasarkan judul pertama dan uang kedua lalu gunakan

library.values.sort_by{|h| [h["title"], h["money"]] }
person NensiMakawana    schedule 21.05.2019