Использование DataAnnotations (DisplayColumn) в службах RIA WCF - PullRequest
0 голосов
/ 14 июня 2011

Я создал модель Entity Framework 4.0 (DB-First), добавил свои частичные классы и использовал DataAnnotations для них, чтобы иметь идеальный пользовательский интерфейс на клиенте.

У меня есть некоторые отношения между моими таблицами и я использовал DisplayColumn поверх моих классов.например, у меня есть класс User, который имеет атрибут [DataColumn("UserName")] поверх класса.И класс Message, который имеет "public User Sender" с атрибутом [Include] поверх свойства.

Кроме того, я использовал .Include("User") в своем DomainService, чтобы загрузить пользователя, который связан с сообщением.

Но в моей таблице данных вместо UserName, который я указал, я вижу User : (UserID) (UserID = свойство ключа сущности пользователя).Я посмотрел на сгенерированный код в моем проекте SL, и он правильно украсил мой класс User атрибутом DisplayColumn.Но все же я не вижу UserName в своей сетке.

Любая помощь будет принята с благодарностью.
Обновление: Вот мой вопрос в коде:

Как я уже говорил, Owner, UserName, MessageId, UserId были определены в моей автоматически сгенерированной модели.UserMeta класс не имеет ничего особенного.

[MetadataType(typeof(MessageMeta))]
public partial class Message
{
}  

public class MessageMeta
{
 [Include()]
 [Display(Name = "Belongs to", Order = 4)]
 [Association("Message_User","MessageId","UserId",IsForeignKey =  true)]
 public virtual User Owner { get; set; }
}

[MetadataType(typeof(UserMeta))]
[DisplayColumn("UserName")]
public partial class User
{
}  

В моем DomainService:

public IQueryable<Message> GetMessages()
{
    return this.ObjectContext.Messages.Include("Owner");
}

1 Ответ

0 голосов
/ 23 июня 2011

Наконец-то мне пришлось использовать Reflection. Для DataGrid:

private void OnAutoGenerateColumn(object sender, DataGridAutoGeneratingColumnEventArgs e)
    {
        //Need to get an array, but should always just have a single DisplayColumnAttribute
        var atts = e.PropertyType.GetCustomAttributes(typeof(DisplayColumnAttribute),true);

        foreach (DisplayColumnAttribute d in atts)
        {
            DataGridTextColumn col = (DataGridTextColumn)e.Column;

            //Make sure that we always have the base path
            if(col.Binding.Path.Path!="")
            {
                col.Binding = new Binding()
                {
                    Path = new PropertyPath(col.Binding.Path.Path + "." + d.DisplayColumn)
                };
            }

            //Only do the first one, just in case we have more than one in metadata
            break;
        }

    } 

А для Telerik RadGridView:

var column = e.Column as GridViewDataColumn;
if (column == null)
{
    return;
}

// Need to get an array, but should always just have a single DisplayColumnAttribute  
var atts = column.DataType.GetCustomAttributes(typeof(DisplayColumnAttribute), true);

foreach (DisplayColumnAttribute d in atts)
{
    // Make sure that we always have the base path
    if (column.DataMemberBinding.Path.Path != "")
    {
        column.DataMemberBinding = new Binding()
        {
            Path = new PropertyPath(column.DataMemberBinding.Path.Path + "." + d.DisplayColumn)
        };
     }
     // Only do the first one, just in case we have more than one in metadata
     break;
 }
...