X-Git-Url: https://irasnyder.com/gitweb/?a=blobdiff_plain;f=app%2Fmodels%2Fvideo.rb;h=b20602af2c1a366d963dfc78b34d9fb91bd9ab9d;hb=b12881a928516bca02b2bd8ce1bbe9288840c76f;hp=411c978eedcf33dbe4b767aea4066fe5ac20fc7d;hpb=42bfb060c3d3d661486f94ce7a8f8c12cf452399;p=cs356-p2-videostore.git diff --git a/app/models/video.rb b/app/models/video.rb index 411c978..b20602a 100644 --- a/app/models/video.rb +++ b/app/models/video.rb @@ -6,6 +6,36 @@ class Video < Rentable validates_presence_of :video_genre validates_presence_of :media + def genre + return Videogenre.find(video_genre).name + end + + def media_name + return Media.find(media).name + end + + def calculated_price + # FIXME: generate this based on day of week, newrelease + day_of_week = Time.now.to_date.wday + base_fee = VideoPolicy.find_by_day(day_of_week).fee + + # Check for newrelease + newrelease_fee = newrelease ? VideoPolicy.find_by_day(8).fee : 0.00 + + return base_fee + newrelease_fee + end + + def due_date + # FIXME: generate this based on the day of week, newrelease + # NOTE: a Date.wday will tell you the day of week (0-6, meaning Sunday-Saturday) + day_of_week = Time.now.to_date.wday + base_period = VideoPolicy.find_by_day(day_of_week).period + newrelease_period = newrelease ? VideoPolicy.find_by_day(8).period : 0 + + period = base_period + newrelease_period + return Time.now.advance(:days => period).to_date + end + protected def validate errors.add(:video_genre, "does not exist in the database") if video_genre.nil?