Creating page types
In this example, you will learn how to define a new custom page type.
- Open the Page types application.
- Click New page type. A New page type wizard opens.
Step 1
- Fill in the following values:
Page type display name: Computer (the system displays this name to users in the administration interface)
Namespace: custom (namespace to distinguish your page types from the default system types that use the cms namespace)
Name:computer (the identifier of the page type)
- Click Next.
Step 2
Enter a Table name for the database table that stores the page type data.
Enter a Primary key name for the table.
(Optional) Select if you want the page to to Inherit fields from page type.
Click Next.
The wizard creates the database table.
Step 3
Now, you need to define fields of the page type (columns of the table).
Click New field.
For each field, enter the values, click Save and repeat the procedure until you have defined all the listed fields.
Field name: ComputerName
Data type: Text
Size: 200
Required: yes (checked)
Field caption: Computer name
Form control: Text box
Field name: ComputerProcessorType
Data type: Text
Size: 200
Field caption: Processor type
Form control: Drop-down list
Editing control settings -> Data source: select List of options and enter the following items into the text area, one per line:
Athlon;Athlon Pentium XEON;Pentium XEON Pentium Core 2 Duo;Pentium Core 2 Duo
Field name: ComputerRamSize
Data type: Integer number
Field caption: RAM (MB)
Form control: Text box
Field name: ComputerHDDSize
Data type: Integer number
Field caption: HDD (GB)
Form control: Text box
Field name: ComputerImage
Data type: File
Field caption: Image
Form control: Upload file
Click Next.
You can also define system fields that will be displayed when editing pages of this type on the Form tab. You can do this using the Field type drop-down list when creating a new field. Select Page field and you can then choose from the following two groups of system fields:
- Page fields - offers system fields of pages
- Node fields - offers system fields of content tree nodes.
Page or node system fields will then be offered in the Field name drop-down list. If you leave the Display field in the editing form check-box turned on, the field will be visible on the page’s Form tab.
Step 4
Now you need to choose the field that will be used as the name for page’s of this type.
Choose the ComputerName option from the drop-down list.
This ensures that computer pages will use the value of the ComputerName field as the name displayed in site navigation and in the Page application’s content tree. The field is available in the drop-down list because you set it as Required in the previous step and it’s a text field.Click Next.
Step 5
Select the page types that will be supported as parents for computer pages in the Page application’s content tree.
If necessary, click Add page types and select the Page (menu item) page type.
Click OK.
Users are now only allowed to place computer pages under pages of the Page (menu item), not under articles, news items or other page types.Click Next.
Step 6
Assign the page type to all websites on which you want to use it.
Click Add sites.
Check the appropriate websites in the selection dialog.
Click OK.
Click Next.
Step 7
The wizard has finished the configuration of the new page type. It has automatically created not only the database table, but also the SQL queries for SELECT, INSERT, UPDATE and DELETE operations and the default transformations.
Click Finish. You have created a new page type.
Now, you may want to:
- Extend the page type’s listing filter – editors use page listing to perform multiple page (batch) operations in the Pages application.
- Limit the pages users can create – this way you can control where on the site users create new pages.
How the content is stored
The new page type Computer has its own database table for its specific fields. Each page is stored in three tables: CMS_TREE (tree structure), CMS_Document (page properties, metadata and content defined on the Page tab) and the custom table - in the case of this example, CUSTOM_Computer.
The system automatically ensures all operations are performed correctly on these tables. The advantage of this storage is that it is very fast and you can easily write standard SQL SELECT queries to retrieve data from the Microsoft SQL Server database.