Каков наилучший способ собрать динамическое предложение WHERE в оператор LINQ?
У меня есть несколько десятков флажков в форме и передаю их обратно: Словарь < string, List <string → > (Dictionary < fieldName, List < values  → ) в мой запрос LINQ.
public IOrderedQueryable<ProductDetail> GetProductList(string productGroupName, string productTypeName, Dictionary<string,List<string>> filterDictionary)
{
    var q = from c in db.ProductDetail
            where c.ProductGroupName == productGroupName && c.ProductTypeName == productTypeName
            // insert dynamic filter here
            orderby c.ProductTypeName
            select c;
    return q;
}

