2025-07-10 12:41:09 +02:00

39 lines
640 B
Go

package diyhrt
import "slices"
type StoreFilter struct{
Limit int
IncludeIds []int
ExcludeIds []int
}
func (f StoreFilter) Filter (stores []Store) []Store {
result := make([]Store, 0)
for _, s := range stores {
if f.Limit > 0 && len(result) >= f.Limit {
break
}
if len(f.IncludeIds) > 0 {
if slices.Contains(f.IncludeIds, s.Id) {
result = append(result, s)
}
continue
}
if slices.Contains(f.ExcludeIds, s.Id) {
continue
}
result = append(result, s)
}
return result
}