Backend: Include categories when creating albums from labels
Signed-off-by: Michael Mayer <michael@liquidbytes.net>
This commit is contained in:
parent
7181adb360
commit
a88c499b70
1 changed files with 5 additions and 3 deletions
|
@ -17,12 +17,14 @@ func (q *Query) PhotoSelection(f form.Selection) (results []entity.Photo, err er
|
|||
|
||||
s = s.Table("photos").
|
||||
Select("photos.*").
|
||||
Joins("LEFT JOIN photos_labels ON photos_labels.photo_id = photos.id").
|
||||
Joins("LEFT JOIN labels ON photos_labels.label_id = labels.id AND labels.deleted_at IS NULL").
|
||||
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_uuid IN (?) OR labels.label_uuid IN (?)", f.Photos, f.Labels)
|
||||
s = s.Where("photos.photo_uuid IN (?) OR l.label_uuid IN (?) OR lc.label_uuid IN (?)", f.Photos, f.Labels, f.Labels)
|
||||
|
||||
if result := s.Scan(&results); result.Error != nil {
|
||||
return results, result.Error
|
||||
|
|
Loading…
Reference in a new issue