StellarAdmin is still in development. We'd love for you to try it out and get your feedback, but please be advised that your may run into bugs. Changes to public APIs may also occur.

Automatically generated fields

StellarAdmin will automatically define fields representing all the simple properties of the underlying resource model. StellarAdmin uses data annotations to determine fields attributes such as the field Label, Description etc.

Manually define fields

If you would like more control over the field definitions, you can manually define fields for your resource definition. To do this, override the CreateFields() method in your resource definition and return an IEnumerable<IField> that contains the list of fields. You can define each of the individual fields by calling the CreateField() method, passing a lambda expression representing the field as the expression parameter.

Let's assume you have the following resource.

public class Contact
    public int Id { get; set; }

    public string FirstName { get; set; }

    public string LastName { get; set; }

    public string Email { get; set; }

    public string PhoneNumber { get; set; }

Create a resource definition called ContactDefinition and define each of the fields in the CreateFields() method as follows:

public class ContactDefinition : ResourceDefinition<Contact>
    protected override IEnumerable<IField> CreateFields()
        return new IField[]
            CreateField(c => c.Id, f => f.IsKey = true),
            CreateField(c => c.FirstName),
            CreateField(c => c.LastName),
            CreateField(c => c.EmailAddress),
            CreateField(c => c.PhoneNumber, f => f.HideOnList())

Specifying field attributes

Note in the example above that the field definition for the Id property has extra parameters defined. The optional configureField parameter of the CreateField method is a callback that allows you to specify extra attributes for the field.

Specifying a key field

If the example above, we define the Id property as the key field for the resource. It is essential to specify a key field for a resource. If no key field is specified, you cannot view, edit, create or delete resource for that particular resource definition - you can only see a list view.

You can also specify the key field with data annotations by adding a [Key] attribute to property of your model that represents the key field:

public class Contact
    public int Id { get; set; }

    // ...

When defining an EF Core resource definition, StellarAdmin will rely on EF Core to infer the key field. So in other words, for our Contact entity, that will be the property named Id or ContactId, or the property defined as a key using the HasKey method of the EF Core Fluent API.

Specifying display attributes

The configureField callback allows you to control various aspects of the field. You can, for example, specify the Label and HelpText.

Specifying field visibility

You can also control the visibility of a field by calling the various Hide* methods. Hide() hides a field in all views. This is useful, for example, for key fields that you never want to display to the user. Or maybe you want the key field to only be visible in the list and detail views, in which case you can call the HideOnForms() method that hides the field in the edit and create views.

Specifying the name of the field

The second optional parameter for the CreateField method is the name parameter. By default, the Name of the field is determined by the underlying property name, but there may be cases where specifying the name field is required. For example, if your field does not reference a property, but is a complex expression like the following:

CreateField(c => $"{c.FirstName} {c.LastName}");

In this case StellarAdmin will be unable to determine the name and you will have to explicitly define a name:

CreateField(c => $"{c.FirstName} {c.LastName}", name: "Fullname");