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 }