Usage
With a db table and a petapoco poco in place you'll have a couple of steps to follow. Important: your table must have a primary key column (and your poco must mark it with the PrimaryKeyColumn attribute)

Decorate your class with the UIOMatic attribute

In order for UI-O-Matic to pick up your poco you'll have to mark it with the UIOMatic attribute
[UIOMatic("people","People","Person")]
The UIOMatic attribute has a contructor with 3 parameters
  • Alias gives the type an easily referenceable name for lookups by UI-O-Matic
  • Folder name is displayed in the content tree and list view title (should be plural form)
  • Item name is displayed in the editor view titles (should be singular form)
You can also specify additional parameters
  • FolderIcon used for the main tree node
  • ItemIcon used for the tree item nodes
  • ParentAlias, if you wish this type to appear inside a folder then this should be set to the folders alias
  • ConnectionStringName, if you wish to use a different db then the current Umbraco one
  • RenderType, if you wish to render the items in a listview or in the tree
  • SortColumn, the default sort column
  • SortOrder, the order of the sord (asc or desc)
  • ReadOnly, setting this to true will remove create/update/delete options
  • Order, sets the order in which this item should appear in the tree
  • ShowOnSummaryDashboard, if you wish to show the count of items on the summary dashboard
  • ListViewActions, actions that will be available on the list view

Decorate properties with the UIOMaticField attribute

All fields you wish to be editable by UI-O-Matic must be decorated with the UIOMaticField attribute like so.
[UIOMaticField]
You can also specify additional parameters
  • Name, name of the field (will be shown as the label for the field)
  • Description, description of the field
  • IsNameField, sets whether the given field should be treated as the name field and be displayed in the header section
  • Tab, sets which tab this property should appear on
  • TabOrder, sets the order of the tab in the tabs collection
  • Order, sets the order in which this field will be displayed
Optionally it's also possible to specify a view
[UIOMaticField(View = UIOMatic.Constants.FieldEditors.File)]
There are a couple out of the box views you can use
  • checkbox
  • checkboxlist (needs config)
  • date
  • datetime
  • datetimeoffset
  • dropdown (needs config)
  • file
  • list (needs config)
  • label
  • map (needs config)
  • number
  • password
  • pickers.content
  • pickers.media
  • pickers.member
  • pickers.user
  • pickers.users
  • radiobuttonlist (needs config)
  • rte
  • textarea
  • textfield
Besides the out of the box ones you can also use a completely custom one
[UIOMaticField(View = "~/App_Plugins/Example/picker.person.html")]

Validation

UIOMatic will validate using the standard .net [data annotation](https://msdn.microsoft.com/en-us/library/system.componentmodel.dataannotations(v=vs.110).aspx), so you can just decorate your properties with those.
[Required]
public string FirstName { get; set; }

Override the ToString method

UI-O-Matic will call the ToString method when it tries to fetch the tree item names, so make sure to override that one.
public override string ToString()
{
return FirstName + " " + LastName;
}

Complete example

Here is a complete example that puts the different bits together.
[UIOMatic("people", "People", "Person", FolderIcon = "icon-users", ItemIcon = "icon-user")]
[TableName("People")]
public class Person
{
[PrimaryKeyColumn(AutoIncrement = true)]
public int Id { get; set; }
​
[Required]
[UIOMaticField(Name="First name", Description="Enter your firstname")]
public string FirstName { get; set; }
​
[Required]
[UIOMaticField(Name="Last name", Description="Enter your lastname")]
public string LastName { get; set; }
​
[UIOMaticField(Name = "Picture", Description="Please select a picture",View = UIOMatic.Constants.FieldEditors.File)]
public string Picture { get; set; }
​
public override string ToString()
{
return FirstName + " " + LastName;
}
}

Result