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 }