ISchemaManagerCreateSchema Method |
Namespace: Ingeniux.CMS
ISchema CreateSchema( string name, string friendlyName, int icon, bool isComponent, bool isViewPage, string viewNameorStylesheetName, IPagePresentationCollection presentations = null, string thumbnailPath = "" )
[Missing <param name="thumbnailPath"/> documentation for "M:Ingeniux.CMS.ISchemaManager.CreateSchema(System.String,System.String,System.Int32,System.Boolean,System.Boolean,System.String,Ingeniux.CMS.Presentation.IPagePresentationCollection,System.String)"]
Exception | Condition |
---|---|
ArgumentNullException | When the "name" parameter is null, empty, or contains whitespace. |
ArgumentException | When the "name" parameter is not a valid XML element name; there are already schemas with same root name or friendly name; or the view name or style sheet name is invalid. |
The schema returned is not yet saved to the content store.
The "name" paramter provided cannot be null, empty, or contain whitespace, and it must be a valid XML element name.
The friendly names and root element names are unique to the schema's collection. If any schemas with a matching friendly name or root element name already exist, an error is thrown.
The newly created schema will be in draft mode. It cannot be used to create pages until it is saved with a new version.
If the icon ID provided doesn't match any icon images, it defaults to a blank page icon.
The newly created schema doesn't have any fields yet. Fields must be added to the returned object before saving (for more information, see UserWriteSession disposal).
On a Dynamic Site Server (run-time) site, the rendering engine first searches for the view that matches either the value of ViewName, or the RootName of page document. If the view doesn't exist, it tries to fall back to the style sheet. isViewPage being true only means it is not needed to set the style sheet property; it doesn't mean you cannot set it.
Setting isViewPage to true doesn't mean that the ViewName property is required.
The purpose of this parameter is for visual presentation only in the CMS schema designer user interface.
using (IUserWriteSession session = _Store.OpenWriteSession(operatingUser)) { //Create a new View page with View Name "News", instead of the default "NewsDetails" schema = session.SchemasManager.CreateSchema("NewsDetails", "News Details", 2, False, True, "News"); ISchemaFieldType attributeType = session.SchemasManager.FieldDefinitions.ItemByID("1"); ISchemaField attribField = new SchemaField(attributeType, "Source", "Source Publication"); attribField.HelpText = "The Publication that first published the news"; attribField.DefaultValue = "Seattle Times"; ISchemaFieldType textElementType = session.SchemasManager.FieldDefinitions.ItemByID("2"); ISchemaField textField = new SchemaField(textElementType, "Title", "Title", true, false, false); schema.AddField(attribField); schema.AddField(textField); schema.Save(true); }