Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / xsp / System / Extensions / UI / WebControls / Expressions / SearchExpression.cs / 1305376 / SearchExpression.cs
#if ORYX_VNEXT namespace Microsoft.Web.Data.UI.WebControls.Expressions { #else namespace System.Web.UI.WebControls.Expressions { #endif using System; using System.Collections; using System.Collections.Generic; using System.Globalization; using System.Linq; using System.Linq.Expressions; using System.Web.Resources; using System.Web.UI; using System.Web.UI.WebControls; public class SearchExpression : ParameterDataSourceExpression { public string DataFields { get { return (string)ViewState["DataFields"] ?? String.Empty; } set { ViewState["DataFields"] = value; } } public SearchType SearchType { get { object o = ViewState["SearchType"]; return o != null ? (SearchType)o : SearchType.StartsWith; } set { ViewState["SearchType"] = value; } } public StringComparison ComparisonType { get { object o = ViewState["ComparisonType"]; return o != null ? (StringComparison)o : StringComparison.OrdinalIgnoreCase; } set { ViewState["ComparisonType"] = value; } } public override IQueryable GetQueryable(IQueryable source) { if (source == null) { return null; } if ((DataFields == null) || String.IsNullOrEmpty(DataFields.Trim())) { throw new InvalidOperationException(AtlasWeb.Expressions_DataFieldRequired); } IDictionaryvalues = GetValues(); if (values.Count == 0) { throw new InvalidOperationException(AtlasWeb.SearchExpression_ParameterRequired); } string query = Convert.ToString(values.First().Value, CultureInfo.CurrentCulture); if (String.IsNullOrEmpty(query)) { return null; } string[] properties = DataFields.Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries); // Use the or expression to or the fields together List searchExpressions = new List (); ParameterExpression parameterExpression = Expression.Parameter(source.ElementType, String.Empty); foreach (string p in properties) { Expression property = ExpressionHelper.CreatePropertyExpression(parameterExpression, p.Trim()); searchExpressions.Add(CreateCallExpression(property, query)); } return ExpressionHelper.Where(source, Expression.Lambda(ExpressionHelper.Or(searchExpressions), parameterExpression)); } private Expression CreateCallExpression(Expression property, string query) { // LINQ to SQL does not support the overloads StartsWith(string, StringComparer) or EndsWith(string, StringComparer) // and Contains has not overload that takes a StringComparer if (SearchType == SearchType.Contains || (ViewState["ComparisonType"] == null)) { return Expression.Call(property, SearchType.ToString(), Type.EmptyTypes, Expression.Constant(query, property.Type)); } return Expression.Call(property, SearchType.ToString(), Type.EmptyTypes, Expression.Constant(query, property.Type), Expression.Constant(ComparisonType)); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. #if ORYX_VNEXT namespace Microsoft.Web.Data.UI.WebControls.Expressions { #else namespace System.Web.UI.WebControls.Expressions { #endif using System; using System.Collections; using System.Collections.Generic; using System.Globalization; using System.Linq; using System.Linq.Expressions; using System.Web.Resources; using System.Web.UI; using System.Web.UI.WebControls; public class SearchExpression : ParameterDataSourceExpression { public string DataFields { get { return (string)ViewState["DataFields"] ?? String.Empty; } set { ViewState["DataFields"] = value; } } public SearchType SearchType { get { object o = ViewState["SearchType"]; return o != null ? (SearchType)o : SearchType.StartsWith; } set { ViewState["SearchType"] = value; } } public StringComparison ComparisonType { get { object o = ViewState["ComparisonType"]; return o != null ? (StringComparison)o : StringComparison.OrdinalIgnoreCase; } set { ViewState["ComparisonType"] = value; } } public override IQueryable GetQueryable(IQueryable source) { if (source == null) { return null; } if ((DataFields == null) || String.IsNullOrEmpty(DataFields.Trim())) { throw new InvalidOperationException(AtlasWeb.Expressions_DataFieldRequired); } IDictionary values = GetValues(); if (values.Count == 0) { throw new InvalidOperationException(AtlasWeb.SearchExpression_ParameterRequired); } string query = Convert.ToString(values.First().Value, CultureInfo.CurrentCulture); if (String.IsNullOrEmpty(query)) { return null; } string[] properties = DataFields.Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries); // Use the or expression to or the fields together List searchExpressions = new List (); ParameterExpression parameterExpression = Expression.Parameter(source.ElementType, String.Empty); foreach (string p in properties) { Expression property = ExpressionHelper.CreatePropertyExpression(parameterExpression, p.Trim()); searchExpressions.Add(CreateCallExpression(property, query)); } return ExpressionHelper.Where(source, Expression.Lambda(ExpressionHelper.Or(searchExpressions), parameterExpression)); } private Expression CreateCallExpression(Expression property, string query) { // LINQ to SQL does not support the overloads StartsWith(string, StringComparer) or EndsWith(string, StringComparer) // and Contains has not overload that takes a StringComparer if (SearchType == SearchType.Contains || (ViewState["ComparisonType"] == null)) { return Expression.Call(property, SearchType.ToString(), Type.EmptyTypes, Expression.Constant(query, property.Type)); } return Expression.Call(property, SearchType.ToString(), Type.EmptyTypes, Expression.Constant(query, property.Type), Expression.Constant(ComparisonType)); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- InkCanvasFeedbackAdorner.cs
- AttachmentCollection.cs
- HttpException.cs
- SerializationException.cs
- MsmqIntegrationElement.cs
- PerformanceCounterCategory.cs
- WindowsStartMenu.cs
- MembershipSection.cs
- MissingSatelliteAssemblyException.cs
- NonBatchDirectoryCompiler.cs
- DataBindingHandlerAttribute.cs
- CatalogPartCollection.cs
- XmlSchemaType.cs
- HttpCapabilitiesEvaluator.cs
- SpellerInterop.cs
- SslStream.cs
- HostingEnvironment.cs
- DataGridViewColumn.cs
- MethodRental.cs
- WebResourceAttribute.cs
- WebRequestModulesSection.cs
- BamlTreeMap.cs
- AppModelKnownContentFactory.cs
- DataGridItemEventArgs.cs
- WindowsPrincipal.cs
- __Error.cs
- SHA384Cng.cs
- StaticSiteMapProvider.cs
- GradientStop.cs
- ControlAdapter.cs
- ValidationEventArgs.cs
- _DisconnectOverlappedAsyncResult.cs
- FormatterServices.cs
- StreamGeometryContext.cs
- XmlArrayItemAttributes.cs
- FactoryGenerator.cs
- CodeBinaryOperatorExpression.cs
- ToolStripMenuItemCodeDomSerializer.cs
- CreateParams.cs
- FontWeights.cs
- PropertyCondition.cs
- RootDesignerSerializerAttribute.cs
- ListViewCancelEventArgs.cs
- Stylus.cs
- EmptyEnumerable.cs
- GradientSpreadMethodValidation.cs
- OLEDB_Util.cs
- BulletChrome.cs
- XmlDataSourceNodeDescriptor.cs
- SQLMoneyStorage.cs
- nulltextnavigator.cs
- WebPartMenuStyle.cs
- EllipticalNodeOperations.cs
- ArrayConverter.cs
- PocoPropertyAccessorStrategy.cs
- HitTestFilterBehavior.cs
- TemplatePartAttribute.cs
- AggregateNode.cs
- validationstate.cs
- IChannel.cs
- Command.cs
- DesignTable.cs
- SqlCacheDependency.cs
- XmlDataSource.cs
- EventHandlerList.cs
- SettingsProperty.cs
- ExpandoObject.cs
- GridLength.cs
- ReachDocumentSequenceSerializer.cs
- PermissionListSet.cs
- Context.cs
- BmpBitmapDecoder.cs
- CheckBoxList.cs
- safelink.cs
- DbBuffer.cs
- GestureRecognizer.cs
- ColumnWidthChangedEvent.cs
- WCFBuildProvider.cs
- ListBindingConverter.cs
- CodeBlockBuilder.cs
- DeferredRunTextReference.cs
- AsyncOperationManager.cs
- HandlerFactoryCache.cs
- SoundPlayer.cs
- SafeCryptoHandles.cs
- SoapAttributes.cs
- TryCatchDesigner.xaml.cs
- TextParagraphProperties.cs
- ScanQueryOperator.cs
- DbConnectionPoolIdentity.cs
- CDSsyncETWBCLProvider.cs
- ActivationServices.cs
- FilterableAttribute.cs
- ManagedFilter.cs
- SqlBulkCopy.cs
- DBBindings.cs
- QueryResults.cs
- SHA1.cs
- ProjectedSlot.cs
- CurrentChangingEventManager.cs