2020-02-04 05:18:22 +01:00
|
|
|
package query
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
|
|
|
|
"github.com/photoprism/photoprism/internal/entity"
|
|
|
|
"github.com/photoprism/photoprism/internal/form"
|
|
|
|
)
|
|
|
|
|
|
|
|
// PhotoSelection returns all selected photos.
|
2020-03-28 17:17:41 +01:00
|
|
|
func (q *Query) PhotoSelection(f form.Selection) (results []entity.Photo, err error) {
|
2020-02-04 05:18:22 +01:00
|
|
|
if f.Empty() {
|
|
|
|
return results, errors.New("no photos selected")
|
|
|
|
}
|
|
|
|
|
2020-03-28 17:17:41 +01:00
|
|
|
s := q.db.NewScope(nil).DB()
|
2020-02-04 05:18:22 +01:00
|
|
|
|
2020-03-28 17:17:41 +01:00
|
|
|
s = s.Table("photos").
|
2020-02-04 05:18:22 +01:00
|
|
|
Select("photos.*").
|
2020-04-23 19:22:41 +02:00
|
|
|
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").
|
2020-02-04 05:18:22 +01:00
|
|
|
Where("photos.deleted_at IS NULL").
|
|
|
|
Group("photos.id")
|
|
|
|
|
2020-04-23 19:22:41 +02:00
|
|
|
s = s.Where("photos.photo_uuid IN (?) OR l.label_uuid IN (?) OR lc.label_uuid IN (?)", f.Photos, f.Labels, f.Labels)
|
2020-02-04 05:18:22 +01:00
|
|
|
|
2020-03-28 17:17:41 +01:00
|
|
|
if result := s.Scan(&results); result.Error != nil {
|
2020-02-04 05:18:22 +01:00
|
|
|
return results, result.Error
|
|
|
|
}
|
|
|
|
|
|
|
|
return results, nil
|
|
|
|
}
|