wms-be/modules/warehouse/query/warehouse_query.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
}