www.leapfm.com にアクセスすると、各曲の右側の括弧内に YouTube の URL が表示されます。フィードバックを評価した後、代わりに括弧内にジャンル タグを表示することにしました。
これをやろうとすると、
次のエラーが表示されます。
Couldn't find Genre without an ID
Extracted source:
def genre_name
@genre = Genre.find(params[:id])
end
def get_last_song
song_controller スニピット
def index
if params[:query].present?
@songs = Song.search(params)
get_last_song
genre_name
elsif params[:genre]
@songs = Song.tagged_with(params[:genre]).paginate(:page => params[:page], :per_page => 15)
get_last_song
genre_name
else
@songs = Song.order('id').order('plusminus desc nulls last').paginate(:page => params[:page], :per_page => 15)
#@songs = Song.tally.paginate(:page => params[:page], :per_page => 15)
get_last_song
genre_name
end
end
def genre_name
@genre = Genre.find(params[:id])
end
index.html.erb (_song 部分) スニピット
<div class="title">
<%=link_to image_tag('arrow.gif'), vote_for_song_path(song), :remote => true, :method => :put if controller.action_name == "index" %>
<%= link_to song.title, song %><span class="subtext"> (<%= song.genre_name %>)</span>
</div>
song.rb の抜粋:
class Song < ActiveRecord::Base
acts_as_voteable
belongs_to :user
has_many :comments, :dependent => :destroy
has_many :genre_songs
has_many :genres, through: :genre_songs
ジャンル.rb
class Genre < ActiveRecord::Base
has_many :genre_songs, :dependent => :destroy
has_many :songs, through: :genre_songs
end
スキーマ スニピット
create_table "genre_songs", force: true do |t|
t.integer "genre_id"
t.integer "song_id"
t.datetime "created_at"
t.datetime "updated_at"
end
add_index "genre_songs", ["genre_id"], name: "index_genre_songs_on_genre_id", using: :btree
add_index "genre_songs", ["song_id"], name: "index_genre_songs_on_song_id", using: :btree
create_table "genres", force: true do |t|
t.string "name"
t.datetime "created_at"
t.datetime "updated_at"
end
create_table "songs", force: true do |t|
t.string "title"
t.string "artist"
t.text "url"
t.string "track_file_name"
t.string "track_content_type"
t.integer "track_file_size"
t.datetime "track_updated_at"
t.integer "user_id"
t.datetime "created_at"
t.datetime "updated_at"
t.integer "plusminus"
end