From b5f616a9d91629114c034b92afeb4e24fdc97bf8 Mon Sep 17 00:00:00 2001 From: Gregory Eremin Date: Mon, 27 Aug 2012 03:53:30 +0400 Subject: [PATCH] Artist import, page --- .gitignore | 1 + Gemfile | 7 + Gemfile.lock | 74 ++- app/assets/javascripts/application.js | 7 + .../javascripts/backbone/beat_haven.js.coffee | 18 + .../backbone/models/artist.js.coffee | 2 + .../backbone/routers/artist_router.js.coffee | 9 + .../backbone/templates/artists/show.mustache | 39 ++ .../views/artist/artist_show.js.coffee | 10 + app/assets/stylesheets/application.css | 13 - app/assets/stylesheets/application.css.scss | 20 + app/assets/stylesheets/artist.css.scss | 132 ++++ app/controllers/api/albums_controller.rb | 8 + app/controllers/api/artists_controller.rb | 10 + app/controllers/application_controller.rb | 4 + app/models/album.rb | 24 + app/models/artist.rb | 88 +++ app/models/artist_genre.rb | 3 + app/models/genre.rb | 3 + app/models/performer.rb | 6 + app/models/track.rb | 14 + app/views/application/main.html | 0 app/views/layouts/application.html.erb | 11 +- config/api_keys.example.yml | 7 + config/initializers/beatparser.rb | 13 + config/initializers/hogan_templates.rb | 3 + config/routes.rb | 62 +- db/migrate/20120826170848_create_genres.rb | 10 + .../20120826171119_create_artist_genres.rb | 10 + db/migrate/20120826171313_create_artists.rb | 13 + db/migrate/20120826171911_create_albums.rb | 13 + db/migrate/20120826172032_create_tracks.rb | 14 + .../20120826172120_create_performers.rb | 10 + db/schema.rb | 68 ++ public/index.html | 241 ------- vendor/assets/javascripts/mustache.js | 613 ++++++++++++++++++ 36 files changed, 1268 insertions(+), 312 deletions(-) create mode 100644 app/assets/javascripts/backbone/beat_haven.js.coffee create mode 100644 app/assets/javascripts/backbone/models/artist.js.coffee create mode 100644 app/assets/javascripts/backbone/routers/artist_router.js.coffee create mode 100644 app/assets/javascripts/backbone/templates/artists/show.mustache create mode 100644 app/assets/javascripts/backbone/views/artist/artist_show.js.coffee delete mode 100644 app/assets/stylesheets/application.css create mode 100644 app/assets/stylesheets/application.css.scss create mode 100644 app/assets/stylesheets/artist.css.scss create mode 100644 app/controllers/api/albums_controller.rb create mode 100644 app/controllers/api/artists_controller.rb create mode 100644 app/models/album.rb create mode 100644 app/models/artist.rb create mode 100644 app/models/artist_genre.rb create mode 100644 app/models/genre.rb create mode 100644 app/models/performer.rb create mode 100644 app/models/track.rb create mode 100644 app/views/application/main.html create mode 100644 config/api_keys.example.yml create mode 100644 config/initializers/beatparser.rb create mode 100644 config/initializers/hogan_templates.rb create mode 100644 db/migrate/20120826170848_create_genres.rb create mode 100644 db/migrate/20120826171119_create_artist_genres.rb create mode 100644 db/migrate/20120826171313_create_artists.rb create mode 100644 db/migrate/20120826171911_create_albums.rb create mode 100644 db/migrate/20120826172032_create_tracks.rb create mode 100644 db/migrate/20120826172120_create_performers.rb create mode 100644 db/schema.rb delete mode 100644 public/index.html create mode 100644 vendor/assets/javascripts/mustache.js diff --git a/.gitignore b/.gitignore index b2dae98..b836692 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ /config/database.yml +/config/api_keys.yml /log/*.log /tmp diff --git a/Gemfile b/Gemfile index 15f132e..3d3b661 100644 --- a/Gemfile +++ b/Gemfile @@ -8,6 +8,7 @@ group :assets do gem "coffee-rails", "~> 3.2.1" gem "therubyracer", platforms: :ruby + gem "hogan_assets" gem "uglifier", ">= 1.0.3" end @@ -21,3 +22,9 @@ gem "thin" # Deploy with Capistrano gem "capistrano" + +gem "robbie", path: "../robbie" +gem "beatparser", path: "../beatparser" +gem "rails-backbone" +gem "eco" +gem 'bootstrap-sass', '~> 2.0.4.0' diff --git a/Gemfile.lock b/Gemfile.lock index af41caa..ccf9f06 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -1,5 +1,20 @@ +PATH + remote: ../beatparser + specs: + beatparser (0.0.1) + lastfm-client + musicbrainz + robbie + +PATH + remote: ../robbie + specs: + robbie (0.0.1) + httparty + oj + GEM - remote: https://rubygems.org/ + remote: http://rubygems.org/ specs: actionmailer (3.2.8) actionpack (= 3.2.8) @@ -29,7 +44,14 @@ GEM i18n (~> 0.6) multi_json (~> 1.0) arel (3.0.2) + bootstrap-sass (2.0.4.0) builder (3.0.0) + capistrano (2.12.0) + highline + net-scp (>= 1.0.0) + net-sftp (>= 2.0.0) + net-ssh (>= 2.0.14) + net-ssh-gateway (>= 1.1.0) coffee-rails (3.2.2) coffee-script (>= 2.2.0) railties (~> 3.2.0) @@ -37,22 +59,53 @@ GEM coffee-script-source execjs coffee-script-source (1.3.3) + daemons (1.1.9) + eco (1.0.0) + coffee-script + eco-source + execjs + eco-source (1.1.0.rc.1) + ejs (1.0.0) erubis (2.7.0) + eventmachine (0.12.10) execjs (1.4.0) multi_json (~> 1.0) + highline (1.6.13) hike (1.2.1) + hogan_assets (1.3.2) + execjs (>= 1.2.9) + sprockets (>= 2.0.3) + tilt (>= 1.3.3) + httparty (0.8.3) + multi_json (~> 1.0) + multi_xml i18n (0.6.0) journey (1.0.4) jquery-rails (2.1.1) railties (>= 3.1.0, < 5.0) thor (~> 0.14) json (1.7.5) + lastfm-client (0.0.3) + json (>= 1.4.6) + libv8 (3.3.10.4) mail (2.4.4) i18n (>= 0.4.0) mime-types (~> 1.16) treetop (~> 1.4.8) mime-types (1.19) multi_json (1.3.6) + multi_xml (0.5.1) + musicbrainz (0.7.0) + nokogiri + net-scp (1.0.4) + net-ssh (>= 1.99.1) + net-sftp (2.0.5) + net-ssh (>= 2.0.9) + net-ssh (2.5.2) + net-ssh-gateway (1.1.0) + net-ssh (>= 1.99.1) + nokogiri (1.5.5) + oj (1.3.4) pg (0.14.0) polyglot (0.3.3) rack (1.4.1) @@ -70,6 +123,10 @@ GEM activesupport (= 3.2.8) bundler (~> 1.0) railties (= 3.2.8) + rails-backbone (0.7.2) + coffee-script (~> 2.2.0) + ejs (~> 1.0.0) + railties (>= 3.1.0) railties (3.2.8) actionpack (= 3.2.8) activesupport (= 3.2.8) @@ -89,6 +146,12 @@ GEM hike (~> 1.2) rack (~> 1.0) tilt (~> 1.1, != 1.3.0) + therubyracer (0.10.2) + libv8 (~> 3.3.10) + thin (1.4.1) + daemons (>= 1.0.9) + eventmachine (>= 0.12.6) + rack (>= 1.0.0) thor (0.16.0) tilt (1.3.3) treetop (1.4.10) @@ -103,9 +166,18 @@ PLATFORMS ruby DEPENDENCIES + beatparser! + bootstrap-sass (~> 2.0.4.0) + capistrano coffee-rails (~> 3.2.1) + eco + hogan_assets jquery-rails pg rails (= 3.2.8) + rails-backbone + robbie! sass-rails (~> 3.2.3) + therubyracer + thin uglifier (>= 1.0.3) diff --git a/app/assets/javascripts/application.js b/app/assets/javascripts/application.js index 9097d83..8428731 100644 --- a/app/assets/javascripts/application.js +++ b/app/assets/javascripts/application.js @@ -12,4 +12,11 @@ // //= require jquery //= require jquery_ujs +//= require mustache +//= require hogan +//= require underscore +//= require backbone +//= require backbone_rails_sync +//= require backbone_datalink +//= require backbone/beat_haven //= require_tree . diff --git a/app/assets/javascripts/backbone/beat_haven.js.coffee b/app/assets/javascripts/backbone/beat_haven.js.coffee new file mode 100644 index 0000000..c88d4f2 --- /dev/null +++ b/app/assets/javascripts/backbone/beat_haven.js.coffee @@ -0,0 +1,18 @@ +#= require_self +#= require_tree ./templates +#= require_tree ./models +#= require_tree ./views +#= require_tree ./routers + +window.BeatHaven = + Models: {} + Collections: {} + Routers: {} + Views: {} + + init: -> + new BeatHaven.Routers.Artist() + Backbone.history.start(); + +$ -> + BeatHaven.init() diff --git a/app/assets/javascripts/backbone/models/artist.js.coffee b/app/assets/javascripts/backbone/models/artist.js.coffee new file mode 100644 index 0000000..ecdf6f8 --- /dev/null +++ b/app/assets/javascripts/backbone/models/artist.js.coffee @@ -0,0 +1,2 @@ +class BeatHaven.Models.Artist extends Backbone.Model + urlRoot: "/api/artists" diff --git a/app/assets/javascripts/backbone/routers/artist_router.js.coffee b/app/assets/javascripts/backbone/routers/artist_router.js.coffee new file mode 100644 index 0000000..d7f2f8d --- /dev/null +++ b/app/assets/javascripts/backbone/routers/artist_router.js.coffee @@ -0,0 +1,9 @@ +class BeatHaven.Routers.Artist extends Backbone.Router + routes: + "artist/:name": "show" + + show: (name) -> + artist = new BeatHaven.Models.Artist(id: name) + artist.fetch() + view = new BeatHaven.Views.ArtistShow(model: artist) + $("#main").html(view.render().el) diff --git a/app/assets/javascripts/backbone/templates/artists/show.mustache b/app/assets/javascripts/backbone/templates/artists/show.mustache new file mode 100644 index 0000000..cc2da89 --- /dev/null +++ b/app/assets/javascripts/backbone/templates/artists/show.mustache @@ -0,0 +1,39 @@ +
+

{{name}}

+
+
+ {{name}} +
+
{{bio}}
+
+
+ {{#albums}} +
+ +

{{title}} ({{year}})

+
+ + + {{#tracks}} + + + + + {{/tracks}} + +
+ + {{title}} + + {{length}} + +
+
+
+ {{/albums}} +
+
diff --git a/app/assets/javascripts/backbone/views/artist/artist_show.js.coffee b/app/assets/javascripts/backbone/views/artist/artist_show.js.coffee new file mode 100644 index 0000000..f895978 --- /dev/null +++ b/app/assets/javascripts/backbone/views/artist/artist_show.js.coffee @@ -0,0 +1,10 @@ +class BeatHaven.Views.ArtistShow extends Backbone.View + template: HoganTemplates["backbone/templates/artists/show"] + + initialize: -> + @model.on("change", @render, this) + + render: -> + return this if typeof @model.attributes.id is "string" + $(@el).html(@template.render(@model.toJSON())) + this diff --git a/app/assets/stylesheets/application.css b/app/assets/stylesheets/application.css deleted file mode 100644 index 3192ec8..0000000 --- a/app/assets/stylesheets/application.css +++ /dev/null @@ -1,13 +0,0 @@ -/* - * This is a manifest file that'll be compiled into application.css, which will include all the files - * listed below. - * - * Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets, - * or vendor/assets/stylesheets of plugins, if any, can be referenced here using a relative path. - * - * You're free to add application-wide styles to this file and they'll appear at the top of the - * compiled file, but it's generally better to create a new file per style scope. - * - *= require_self - *= require_tree . - */ diff --git a/app/assets/stylesheets/application.css.scss b/app/assets/stylesheets/application.css.scss new file mode 100644 index 0000000..c1f6c3f --- /dev/null +++ b/app/assets/stylesheets/application.css.scss @@ -0,0 +1,20 @@ +@import "bootstrap"; +@import "artist"; +@import url(http://fonts.googleapis.com/css?family=Lobster); +@import url(http://fonts.googleapis.com/css?family=Source+Sans+Pro); + +body { + background: url() +} + +#main { + margin-top: 50px; +} + +.navbar a.brand { + font-family: Lobster, Georgia, Serif; + font-size: 24px; + color: #fafafa; + letter-spacing: 1px; + text-shadow: 1px 1px 0 rgba(255, 255, 255, .2); +} diff --git a/app/assets/stylesheets/artist.css.scss b/app/assets/stylesheets/artist.css.scss new file mode 100644 index 0000000..82d41c1 --- /dev/null +++ b/app/assets/stylesheets/artist.css.scss @@ -0,0 +1,132 @@ +.artist-page { + h1 { + font-family: Lobster, Georgia, serif; + font-size: 42px; + line-height: 64px; + letter-spacing: 1px; + text-shadow: 1px 1px 0 rgba(0, 0, 0, .2); + } + + .artist-info { + min-height: 250px; + margin-bottom: 50px; + + .pic { + float: left; + + img { + width: 250px; + height: 250px; + border-size: 1px; + border-style: solid; + border-color: rgba(255, 255, 255, .2); + border-radius: 5px; + box-shadow: 1px 1px 5px rgba(0, 0, 0, .2); + } + } + .bio { + margin-left: 270px; + font-family: "Source Sans Pro", Helvetica, sans-serif; + font-size: 22px; + line-height: 26px; + text-shadow: 1px 1px 0 rgba(0, 0, 0, .1); + } + } + + .album { + min-height: 250px; + margin-bottom: 30px; + + h2 { + font-family: Lobster, Georgia, Serif; + font-size: 26px; + text-shadow: 1px 1px 0 rgba(0, 0, 0, .2); + } + .pic { + float: left; + height: 300px; + text-align: center; + + img { + background-color: #a0a0a0; + width: 250px; + height: 250px; + border-size: 1px; + border-style: solid; + border-color: rgba(255, 255, 255, .2); + border-radius: 5px; + box-shadow: 1px 1px 5px rgba(0, 0, 0, .2); + margin-bottom: 10px; + } + } + .title { + margin-left: 270px; + margin-bottom: 10px; + } + .tracks { + margin-left: 270px; + + tr:hover { + td { + background-color: rgba(200, 200, 200, .3); + + .track-play i { + opacity: 1; + } + &.length { + .track-add { + display: block; + } + .length { + display: none; + } + } + } + } + + td { + position: relative; + font-family: "Source Sans Pro", Helvetica, sans-serif; + font-size: 20px; + line-height: 28px; + text-shadow: 1px 1px 0 rgba(0, 0, 0, .1); + + .btn-round { + width: 10px; + height: 22px; + border-radius: 50px; + + i { + margin: 3px 0 0 -1px; + } + } + } + + td.title { + padding-left: 40px; + .track-play { + position: absolute; + margin: -2px 0 0 -40px; + + i { + opacity: .3; + } + } + .track-link { + color: #303030; + } + } + + td.length { + text-align: right; + + .track-add { + position: absolute; + right: 8px; + margin: -2px 0 0 0; + display: none; + } + } + } + } +} diff --git a/app/controllers/api/albums_controller.rb b/app/controllers/api/albums_controller.rb new file mode 100644 index 0000000..dbab9a9 --- /dev/null +++ b/app/controllers/api/albums_controller.rb @@ -0,0 +1,8 @@ +module Api + class AlbumsController < ::ApplicationController + def picture + album = Album.find(params[:id]) + redirect_to album.load_pic + end + end +end diff --git a/app/controllers/api/artists_controller.rb b/app/controllers/api/artists_controller.rb new file mode 100644 index 0000000..463406c --- /dev/null +++ b/app/controllers/api/artists_controller.rb @@ -0,0 +1,10 @@ +module Api + class ArtistsController < ::ApplicationController + def show + artist = Artist.with_name(params[:id].gsub("+", " ")) + return render json: { fail: true } if artist.nil? + + render json: artist.dump_json + end + end +end diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb index e8065d9..676ede8 100644 --- a/app/controllers/application_controller.rb +++ b/app/controllers/application_controller.rb @@ -1,3 +1,7 @@ class ApplicationController < ActionController::Base protect_from_forgery + + def main + + end end diff --git a/app/models/album.rb b/app/models/album.rb new file mode 100644 index 0000000..a7a8947 --- /dev/null +++ b/app/models/album.rb @@ -0,0 +1,24 @@ +class Album < ActiveRecord::Base + belongs_to :artist + has_many :tracks + + attr_accessible :artist_id, :pic, :rovi_id, :title, :year + + def pic_safe + unless pic.nil? + pic + else + "/api/albums/#{id}/picture" + end + end + + def load_pic + info = BeatParser::Sources::Lastfm.album_info(artist.name, title) + unless info[:pic].nil? + update_attributes(pic: info[:pic]) + info[:pic] + else + "/assets/images/album-dummy.png" + end + end +end diff --git a/app/models/artist.rb b/app/models/artist.rb new file mode 100644 index 0000000..447a50b --- /dev/null +++ b/app/models/artist.rb @@ -0,0 +1,88 @@ +class Artist < ActiveRecord::Base + has_many :albums + has_many :performers + has_many :tracks, through: :performers + has_many :genres, through: :artist_genres + + attr_accessible :bio, :is_group, :name, :pic, :rovi_id + + def loaded? + pic? && bio? + end + + def dump_json + serialized = to_json( + include: { + albums: { + include: { + tracks: { + methods: [:length], + except: [:created_at, :updated_at, :rovi_id, :album_id] + } + }, + except: [:created_at, :updated_at, :rovi_id, :pic], + methods: [:pic_safe] + } + }, + except: [:created_at, :updated_at, :rovi_id], + ) + end + + class << self + def with_name(name) + # DB lookup + artist = find_by_name(name) + return artist unless artist.nil? + + # Rovi correction + rovi_artist = Robbie::Artist.find_by_name(name) + return artist if rovi_artist && artist = find_by_rovi_id(rovi_artist.id) + + # Parsing artist if ok + import(rovi_artist) if rovi_artist + end + + def import(rovi_artist) + data = BeatParser::Aggregator.new.combine(rovi_artist.id) + artist = Artist.find_or_create_by_rovi_id(data[:id]) + artist.update_attributes( + name: data[:name], + is_group: data[:is_group], + pic: data[:pic], + bio: data[:bio] + ) + data[:albums].each do |album_meta| + album = Album.find_or_create_by_rovi_id(album_meta[:id]) + album.update_attributes( + artist_id: artist.id, + title: album_meta[:title], + year: album_meta[:year].to_i + ) + album_meta[:tracks].each do |track_meta| + track = Track.find_or_create_by_rovi_id(track_meta[:id]) + track.update_attributes( + album_id: album.id, + disc_id: track_meta[:disc_id], + position: track_meta[:position], + title: track_meta[:title], + duration: track_meta[:duration] + ) + track_meta[:artists].each do |performer| + performer_artist = Artist.find_or_create_by_rovi_id(performer[:id]) + performer_artist.update_attributes( + name: performer[:name] + ) + Performer.find_or_create_by_artist_id_and_track_id(performer_artist.id, track.id) + end + end + end + data[:genres].each do |genre_meta| + genre = Genre.find_or_create_by_rovi_id(genre_meta[:id]) + genre.update_attributes( + name: genre_meta[:name] + ) + ArtistGenre.find_or_create_by_artist_id_and_genre_id(artist.id, genre.id) + end + end + end +end diff --git a/app/models/artist_genre.rb b/app/models/artist_genre.rb new file mode 100644 index 0000000..e7a4271 --- /dev/null +++ b/app/models/artist_genre.rb @@ -0,0 +1,3 @@ +class ArtistGenre < ActiveRecord::Base + attr_accessible :artist_id, :genre_id +end diff --git a/app/models/genre.rb b/app/models/genre.rb new file mode 100644 index 0000000..25b9626 --- /dev/null +++ b/app/models/genre.rb @@ -0,0 +1,3 @@ +class Genre < ActiveRecord::Base + attr_accessible :name, :rovi_id +end diff --git a/app/models/performer.rb b/app/models/performer.rb new file mode 100644 index 0000000..6958b10 --- /dev/null +++ b/app/models/performer.rb @@ -0,0 +1,6 @@ +class Performer < ActiveRecord::Base + belongs_to :artist + belongs_to :track + + attr_accessible :artist_id, :track_id +end diff --git a/app/models/track.rb b/app/models/track.rb new file mode 100644 index 0000000..17515e0 --- /dev/null +++ b/app/models/track.rb @@ -0,0 +1,14 @@ +class Track < ActiveRecord::Base + belongs_to :album + has_many :performers + has_many :artists, through: :performers + + attr_accessible :album_id, :disc_id, :duration, :position, :rovi_id, :title + + def length + return if duration.nil? + length = duration.divmod(60).map(&:to_s) + length[1] = "0" << length[1] if length[1].length == 1 + length.join(":") + end +end diff --git a/app/views/application/main.html b/app/views/application/main.html new file mode 100644 index 0000000..e69de29 diff --git a/app/views/layouts/application.html.erb b/app/views/layouts/application.html.erb index 2bdac2b..a6bb5af 100644 --- a/app/views/layouts/application.html.erb +++ b/app/views/layouts/application.html.erb @@ -2,13 +2,20 @@ BeatHaven - <%= stylesheet_link_tag "application", :media => "all" %> + <%= stylesheet_link_tag "application", media: "all" %> <%= javascript_include_tag "application" %> <%= csrf_meta_tags %> -<%= yield %> + +
Loading...
diff --git a/config/api_keys.example.yml b/config/api_keys.example.yml new file mode 100644 index 0000000..784b272 --- /dev/null +++ b/config/api_keys.example.yml @@ -0,0 +1,7 @@ +lastfm: + api_key: secret + api_secret: secret + client_name: BeatHaven +rovi: + api_key: secret + api_secret: secret diff --git a/config/initializers/beatparser.rb b/config/initializers/beatparser.rb new file mode 100644 index 0000000..f15911a --- /dev/null +++ b/config/initializers/beatparser.rb @@ -0,0 +1,13 @@ +File.open("#{Rails.root}/config/api_keys.yml") do |file| + config = YAML.load(file.read) + + LastFM.api_key = config["lastfm"]["api_key"] + LastFM.secret = config["lastfm"]["api_secret"] + LastFM.client_name = config["lastfm"]["client_name"] + + Robbie.setup( + api_key: config["rovi"]["api_key"], + api_secret: config["rovi"]["api_secret"] + ) + Robbie.enable_cache +end diff --git a/config/initializers/hogan_templates.rb b/config/initializers/hogan_templates.rb new file mode 100644 index 0000000..122204f --- /dev/null +++ b/config/initializers/hogan_templates.rb @@ -0,0 +1,3 @@ +HoganAssets::Config.configure do |config| + config.path_prefix = "backbone/templates/" +end diff --git a/config/routes.rb b/config/routes.rb index d06904e..5bb6d03 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -1,58 +1,10 @@ BeatHaven::Application.routes.draw do - # The priority is based upon order of creation: - # first created -> highest priority. + namespace :api do + resources :artists, only: [:show], constraints: { id: /.+/ } + resources :albums, only: [:picture] do + member { get :picture } + end + end - # Sample of regular route: - # match 'products/:id' => 'catalog#view' - # Keep in mind you can assign values other than :controller and :action - - # Sample of named route: - # match 'products/:id/purchase' => 'catalog#purchase', :as => :purchase - # This route can be invoked with purchase_url(:id => product.id) - - # Sample resource route (maps HTTP verbs to controller actions automatically): - # resources :products - - # Sample resource route with options: - # resources :products do - # member do - # get 'short' - # post 'toggle' - # end - # - # collection do - # get 'sold' - # end - # end - - # Sample resource route with sub-resources: - # resources :products do - # resources :comments, :sales - # resource :seller - # end - - # Sample resource route with more complex sub-resources - # resources :products do - # resources :comments - # resources :sales do - # get 'recent', :on => :collection - # end - # end - - # Sample resource route within a namespace: - # namespace :admin do - # # Directs /admin/products/* to Admin::ProductsController - # # (app/controllers/admin/products_controller.rb) - # resources :products - # end - - # You can have the root of your site routed with "root" - # just remember to delete public/index.html. - # root :to => 'welcome#index' - - # See how all your routes lay out with "rake routes" - - # This is a legacy wild controller route that's not recommended for RESTful applications. - # Note: This route will make all actions in every controller accessible via GET requests. - # match ':controller(/:action(/:id))(.:format)' + root to: "application#main" end diff --git a/db/migrate/20120826170848_create_genres.rb b/db/migrate/20120826170848_create_genres.rb new file mode 100644 index 0000000..c380cdd --- /dev/null +++ b/db/migrate/20120826170848_create_genres.rb @@ -0,0 +1,10 @@ +class CreateGenres < ActiveRecord::Migration + def change + create_table :genres do |t| + t.string :rovi_id + t.string :name + + t.timestamps + end + end +end diff --git a/db/migrate/20120826171119_create_artist_genres.rb b/db/migrate/20120826171119_create_artist_genres.rb new file mode 100644 index 0000000..f1b0cde --- /dev/null +++ b/db/migrate/20120826171119_create_artist_genres.rb @@ -0,0 +1,10 @@ +class CreateArtistGenres < ActiveRecord::Migration + def change + create_table :artist_genres do |t| + t.integer :artist_id + t.integer :genre_id + + t.timestamps + end + end +end diff --git a/db/migrate/20120826171313_create_artists.rb b/db/migrate/20120826171313_create_artists.rb new file mode 100644 index 0000000..c8652f5 --- /dev/null +++ b/db/migrate/20120826171313_create_artists.rb @@ -0,0 +1,13 @@ +class CreateArtists < ActiveRecord::Migration + def change + create_table :artists do |t| + t.string :rovi_id + t.string :name + t.boolean :is_group + t.text :bio + t.string :pic + + t.timestamps + end + end +end diff --git a/db/migrate/20120826171911_create_albums.rb b/db/migrate/20120826171911_create_albums.rb new file mode 100644 index 0000000..1afb99a --- /dev/null +++ b/db/migrate/20120826171911_create_albums.rb @@ -0,0 +1,13 @@ +class CreateAlbums < ActiveRecord::Migration + def change + create_table :albums do |t| + t.integer :artist_id + t.string :rovi_id + t.string :title + t.integer :year + t.string :pic + + t.timestamps + end + end +end diff --git a/db/migrate/20120826172032_create_tracks.rb b/db/migrate/20120826172032_create_tracks.rb new file mode 100644 index 0000000..d32d390 --- /dev/null +++ b/db/migrate/20120826172032_create_tracks.rb @@ -0,0 +1,14 @@ +class CreateTracks < ActiveRecord::Migration + def change + create_table :tracks do |t| + t.integer :album_id + t.string :rovi_id + t.integer :disc_id + t.integer :position + t.string :title + t.integer :duration + + t.timestamps + end + end +end diff --git a/db/migrate/20120826172120_create_performers.rb b/db/migrate/20120826172120_create_performers.rb new file mode 100644 index 0000000..2d72405 --- /dev/null +++ b/db/migrate/20120826172120_create_performers.rb @@ -0,0 +1,10 @@ +class CreatePerformers < ActiveRecord::Migration + def change + create_table :performers do |t| + t.integer :track_id + t.integer :artist_id + + t.timestamps + end + end +end diff --git a/db/schema.rb b/db/schema.rb new file mode 100644 index 0000000..3ac82e1 --- /dev/null +++ b/db/schema.rb @@ -0,0 +1,68 @@ +# encoding: UTF-8 +# This file is auto-generated from the current state of the database. Instead +# of editing this file, please use the migrations feature of Active Record to +# incrementally modify your database, and then regenerate this schema definition. +# +# Note that this schema.rb definition is the authoritative source for your +# database schema. If you need to create the application database on another +# system, you should be using db:schema:load, not running all the migrations +# from scratch. The latter is a flawed and unsustainable approach (the more migrations +# you'll amass, the slower it'll run and the greater likelihood for issues). +# +# It's strongly recommended to check this file into your version control system. + +ActiveRecord::Schema.define(:version => 20120826172120) do + + create_table "albums", :force => true do |t| + t.integer "artist_id" + t.string "rovi_id" + t.string "title" + t.integer "year" + t.string "pic" + t.datetime "created_at", :null => false + t.datetime "updated_at", :null => false + end + + create_table "artist_genres", :force => true do |t| + t.integer "artist_id" + t.integer "genre_id" + t.datetime "created_at", :null => false + t.datetime "updated_at", :null => false + end + + create_table "artists", :force => true do |t| + t.string "rovi_id" + t.string "name" + t.boolean "is_group" + t.text "bio" + t.string "pic" + t.datetime "created_at", :null => false + t.datetime "updated_at", :null => false + end + + create_table "genres", :force => true do |t| + t.string "rovi_id" + t.string "name" + t.datetime "created_at", :null => false + t.datetime "updated_at", :null => false + end + + create_table "performers", :force => true do |t| + t.integer "track_id" + t.integer "artist_id" + t.datetime "created_at", :null => false + t.datetime "updated_at", :null => false + end + + create_table "tracks", :force => true do |t| + t.integer "album_id" + t.string "rovi_id" + t.integer "disc_id" + t.integer "position" + t.string "title" + t.integer "duration" + t.datetime "created_at", :null => false + t.datetime "updated_at", :null => false + end + +end diff --git a/public/index.html b/public/index.html deleted file mode 100644 index a1d5099..0000000 --- a/public/index.html +++ /dev/null @@ -1,241 +0,0 @@ - - - - Ruby on Rails: Welcome aboard - - - - -
- - -
- - - - -
-

Getting started

-

Here’s how to get rolling:

- -
    -
  1. -

    Use rails generate to create your models and controllers

    -

    To see all available options, run it without parameters.

    -
  2. - -
  3. -

    Set up a default route and remove public/index.html

    -

    Routes are set up in config/routes.rb.

    -
  4. - -
  5. -

    Create your database

    -

    Run rake db:create to create your database. If you're not using SQLite (the default), edit config/database.yml with your username and password.

    -
  6. -
-
-
- - -
- - diff --git a/vendor/assets/javascripts/mustache.js b/vendor/assets/javascripts/mustache.js new file mode 100644 index 0000000..9e20b87 --- /dev/null +++ b/vendor/assets/javascripts/mustache.js @@ -0,0 +1,613 @@ +/*! + * mustache.js - Logic-less {{mustache}} templates with JavaScript + * http://github.com/janl/mustache.js + */ + +/*global define: false*/ + +var Mustache; + +(function (exports) { + if (typeof module !== "undefined" && typeof module.exports !== "undefined") { + module.exports = exports; // CommonJS + } else if (typeof define === "function") { + define(exports); // AMD + } else { + Mustache = exports; //