wms-be/modules/mvendor/query/vendor_query.go

25 lines
563 B
Go

package query
import "gorm.io/gorm"
type VendorFilter struct {
Name string `form:"name"`
IsActive *bool `form:"is_active"`
ClientID string `form:"client_id"`
PerPage int `form:"per_page"`
Page int `form:"page"`
}
func ApplyVendorFilters(db *gorm.DB, filter VendorFilter) *gorm.DB {
if filter.Name != "" {
db = db.Where("name ILIKE ?", "%"+filter.Name+"%")
}
if filter.ClientID != "" {
db = db.Where("client_id = ?", filter.ClientID)
}
if filter.IsActive != nil {
db = db.Where("is_active = ?", *filter.IsActive)
}
return db
}