31 lines
676 B
Go
31 lines
676 B
Go
package query
|
|
|
|
import (
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
type WarehouseFilter struct {
|
|
Name string `form:"name"`
|
|
Code string `form:"code"`
|
|
Status string `form:"status"`
|
|
ClientID string `form:"client_id"`
|
|
PerPage int `form:"per_page"`
|
|
Page int `form:"page"`
|
|
}
|
|
|
|
func ApplyWarehouseFilters(db *gorm.DB, filter WarehouseFilter) *gorm.DB {
|
|
if filter.Name != "" {
|
|
db = db.Where("name ILIKE ?", "%"+filter.Name+"%")
|
|
}
|
|
if filter.Code != "" {
|
|
db = db.Where("code ILIKE ?", "%"+filter.Code+"%")
|
|
}
|
|
if filter.ClientID != "" {
|
|
db = db.Where("client_id = ?", filter.ClientID)
|
|
}
|
|
if filter.Status != "" {
|
|
db = db.Where("status = ?", filter.Status)
|
|
}
|
|
return db
|
|
}
|