photoprism/internal/query/selection.go
Michael Mayer 03ec4b586d Initial commit for folders and moments #154 #260 #331
Signed-off-by: Michael Mayer <michael@liquidbytes.net>
2020-05-23 20:58:58 +02:00

35 lines
989 B
Go

package query
import (
"errors"
"github.com/photoprism/photoprism/internal/entity"
"github.com/photoprism/photoprism/internal/form"
)
// PhotoSelection returns all selected photos.
func PhotoSelection(f form.Selection) (results []entity.Photo, err error) {
if f.Empty() {
return results, errors.New("no photos selected")
}
s := Db().NewScope(nil).DB()
s = s.Table("photos").
Select("photos.*").
Joins("LEFT JOIN photos_labels pl ON pl.photo_id = photos.id").
Joins("LEFT JOIN labels l ON pl.label_id = l.id AND l.deleted_at IS NULL").
Joins("LEFT JOIN categories c ON c.label_id = pl.label_id").
Joins("LEFT JOIN labels lc ON lc.id = c.category_id AND lc.deleted_at IS NULL").
Where("photos.deleted_at IS NULL").
Group("photos.id")
s = s.Where("photos.photo_uid IN (?) OR l.label_uid IN (?) OR lc.label_uid IN (?)", f.Photos, f.Labels, f.Labels)
if result := s.Scan(&results); result.Error != nil {
return results, result.Error
}
return results, nil
}