Добавление пользовательских фильтров для веб-сайта с динамическими данными (VS2010, EF4) - PullRequest
5 голосов
/ 09 апреля 2010

Попытка добавить несколько разных фильтров (в дополнение к фильтру ForeignKey) на веб-сайт динамических данных в VS2010 с использованием EF4. Я могу добавить новые шаблоны фильтров, но как мне указать, какой шаблон будет отображаться для каждого свойства в моей модели?

Спасибо

1 Ответ

9 голосов
/ 28 мая 2010

Вот как это сделать:

1) Создайте новый UserControl для нужного фильтра в DynamicData \ Filters. Я создал TextFilter.ascx:

<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="TextFilter.ascx.cs" Inherits="Test.Prototype.Web.DynamicData.DynamicData.Filters.TextFilter" %>
<asp:TextBox runat="server" ID="TextBox1" AutoPostBack="true"  OnTextChanged="TextBox1_OnTextChanged" CssClass="DDFilter">
</asp:TextBox>

и код:

using System;
using System.Collections;
using System.Collections.Generic;
using System.Collections.Specialized;

using System.ComponentModel.DataAnnotations;
using System.Linq;

using System.Linq.Expressions;
using System.Web.DynamicData;
using System.Web.UI;
using System.Web.UI.WebControls;


namespace Test.Prototype.Web.DynamicData.DynamicData.Filters
{
    public partial class TextFilter : System.Web.DynamicData.QueryableFilterUserControl
    {

        private const string NullValueString = "[null]";

        protected void Page_Load(object sender, EventArgs e)
        {

        }

        public override Control FilterControl
        {
            get
            {
                return TextBox1;
            }
        }


        protected void TextBox1_OnTextChanged(object sender, EventArgs e)
        {
            OnFilterChanged();
        }

        public override IQueryable GetQueryable(IQueryable source)
        {
            string selectedValue = TextBox1.Text;
            if (String.IsNullOrEmpty(selectedValue))
            {
                return source;
            }

            object value = selectedValue;
            if (selectedValue == NullValueString)
            {
                value = null;
            }
            if (DefaultValues != null)
            {
                DefaultValues[Column.Name] = value;
            }

            return ApplyEqualityFilter(source, Column.Name, value);

        }

    }
}

Затем в вашей модели просто аннотируйте свои свойства атрибутом FilterUIHint, указывающим на следующий фильтр, и все готово:

с использованием системы; использование System.Collections; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Collections.Specialized;

с использованием System.ComponentModel.DataAnnotations;

namespace Test.Model { публичный частичный класс Asset { #region Примитивные свойства

    public virtual int Id
    {
        get;
        set;
    }

    [FilterUIHint("TextFilter")]
    public virtual string Name
    {
        get;
        set;
    }

...

...