A cross-platform UI framework for .NET
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

81 lines
2.9 KiB

// Copyright (c) The Perspex Project. All rights reserved.
// Licensed under the MIT license. See licence.md file in the project root for full license information.
using System;
using System.Reflection;
namespace Perspex.Controls.Templates
{
/// <summary>
/// Builds a control for a piece of data.
/// </summary>
public class FuncDataTemplate : FuncTemplate<object, IControl>, IDataTemplate
{
/// <summary>
/// The default data template used in the case where not matching data template is found.
/// </summary>
public static readonly FuncDataTemplate Default =
new FuncDataTemplate(typeof(object), o => (o != null) ? new TextBlock { Text = o.ToString() } : null);
/// <summary>
/// The implementation of the <see cref="Match"/> method.
/// </summary>
private readonly Func<object, bool> _match;
/// <summary>
/// Initializes a new instance of the <see cref="FuncDataTemplate"/> class.
/// </summary>
/// <param name="type">The type of data which the data template matches.</param>
/// <param name="build">
/// A function which when passed an object of <paramref name="type"/> returns a control.
/// </param>
public FuncDataTemplate(Type type, Func<object, IControl> build)
: this(o => IsInstance(o, type), build)
{
}
/// <summary>
/// Initializes a new instance of the <see cref="FuncDataTemplate"/> class.
/// </summary>
/// <param name="match">
/// A function which determines whether the data template matches the specified data.
/// </param>
/// <param name="build">
/// A function which returns a control for matching data.
/// </param>
public FuncDataTemplate(Func<object, bool> match, Func<object, IControl> build)
: base(build)
{
Contract.Requires<ArgumentNullException>(match != null);
_match = match;
}
/// <summary>
/// Checks to see if this data template matches the specified data.
/// </summary>
/// <param name="data">The data.</param>
/// <returns>
/// True if the data template can build a control for the data, otherwise false.
/// </returns>
public bool Match(object data)
{
return _match(data);
}
/// <summary>
/// Determines of an object is of the specified type.
/// </summary>
/// <param name="o">The object.</param>
/// <param name="t">The type.</param>
/// <returns>
/// True if <paramref name="o"/> is of type <paramref name="t"/>, otherwise false.
/// </returns>
private static bool IsInstance(object o, Type t)
{
return (o != null) ?
t.GetTypeInfo().IsAssignableFrom(o.GetType().GetTypeInfo()) :
false;
}
}
}