photomix/app/controllers/albums_controller.rb

93 lines
3.4 KiB
Ruby
Raw Permalink Normal View History

2009-05-22 14:13:46 +02:00
class AlbumsController < ApplicationController
2009-08-03 16:39:33 +02:00
before_filter :check_public_access
2009-06-09 00:30:22 +02:00
before_filter :require_role_admin, :only => [:untouched, :new, :create, :edit, :update, :destroy]
2009-05-22 14:13:46 +02:00
def index
if params[:tag_id]
2009-08-03 16:23:51 +02:00
@albums = Album.find(:all, :conditions => [ "id IN ( SELECT DISTINCT photos.album_id FROM photos WHERE photos.id IN ( SELECT photo_id FROM photo_tags WHERE photo_tags.tag_id = :q) )", { :q => Tag.find( params[:tag_id] ).id } ], :order => 'title')
elsif params[:q]
#search = params[:q]
#search = search.split("AND").map{|q|q.strip}
#@albums = Album.find(:all, :select => 'DISTINCT albums.id, albums.title', :limit => 20, :conditions => { :tags => {:title => search}}, :joins => 'LEFT OUTER JOIN photos ON albums.id = photos.album_id LEFT OUTER JOIN photo_tags ON photos.id = photo_tags.photo_id LEFT OUTER JOIN tags ON photo_tags.tag_id = tags.id', :order => "albums.title ASC" )
2009-08-12 15:42:18 +02:00
#@albums = Album.find(:all, :select => 'DISTINCT album_id', :conditions => [ "title LIKE :q OR description LIKE :q OR id IN ( SELECT DISTINCT photos.album_id FROM photos WHERE photos.description LIKE :q OR photos.title LIKE :q OR photos.id IN ( SELECT photo_id FROM photo_tags LEFT OUTER JOIN tags ON photo_tags.tag_id = tags.id WHERE tags.title LIKE :q) )", { :q => '%' + params[:q] + '%' } ], :order => 'title')
params[:q].split(" AND ").each {|q|
qphotos = Photo.find(:all, :select => 'DISTINCT album_id', :conditions => [ "description LIKE :q OR title LIKE :q OR id IN ( SELECT photo_id FROM photo_tags LEFT OUTER JOIN tags ON photo_tags.tag_id = tags.id WHERE tags.title LIKE :q)", { :q => '%' + q + '%' } ])
qalbums = Album.find(:all, :conditions => ['title LIKE :q OR description LIKE :q OR id IN (:ids)', { :ids => qphotos.map{|p|p.album_id}, :q => '%' + q + '%' }], :order => 'title' )
if @albums
@albums = @albums & qalbums
else
@albums = qalbums
end
}
else
2009-08-03 16:23:51 +02:00
@albums = Album.find(:all, :order => 'title')
end
2009-05-22 14:13:46 +02:00
respond_to do |format|
format.html
format.json { render :json => @albums }
format.xml { render :xml => @albums }
end
end
2009-06-03 01:33:39 +02:00
def untouched
@albums = Album.untouched()
respond_to do |format|
format.html
format.json { render :json => @albums }
format.xml { render :xml => @albums }
end
end
2009-05-22 14:13:46 +02:00
def show
2009-06-16 01:18:42 +02:00
@album = Album.find( params[:id])
2009-05-22 14:13:46 +02:00
respond_to do |format|
format.html
format.json { render :json => @album }
format.xml { render :xml => @album }
2009-05-25 21:39:43 +02:00
format.pdf { render :pdf => @album.title }
2009-05-22 14:13:46 +02:00
end
end
2009-05-22 21:04:41 +02:00
def new
@album = Album.new
end
def create
@album = Album.new(params[:album])
2009-08-12 15:42:18 +02:00
2009-05-22 21:04:41 +02:00
if @album.save
2009-08-01 19:53:20 +02:00
unless params[:collection_id].empty?
2009-06-30 22:41:27 +02:00
@album.collections << Collection.find( params[:collection_id] )
end
2009-05-22 21:04:41 +02:00
flash[:notice] = "Album created!"
redirect_to @album
else
render :action => :new
end
end
2009-05-22 21:04:41 +02:00
def edit
@album = Album.find( params[:id])
end
def update
@album = Album.find( params[:id])
if @album.update_attributes(params[:album])
2009-06-09 00:30:22 +02:00
flash[:notice] = "Album updated!"
2009-05-22 21:04:41 +02:00
redirect_to @album
else
render :action => :edit
end
end
2009-06-02 00:08:57 +02:00
def destroy
2009-05-22 21:04:41 +02:00
@album = Album.find( params[:id])
2009-06-02 00:08:57 +02:00
if @album.destroy
redirect_to albums_path
2009-05-22 21:04:41 +02:00
else
redirect_to @album
end
end
2009-05-22 14:13:46 +02:00
end