Master-detail pages can be quickly created in Code On Time web applications using drag and drop operations in the Project Designer.
Creating a Page
Start the Project Designer. In the Project Explorer toolbar, press New Page.
data:image/s3,"s3://crabby-images/6b5e9/6b5e9a5786ab313f266d01ecdcbc167c1e04048a" alt="New Page toolbar option in the Project Explorer of web application designer. New Page toolbar option in the Project Explorer of web application designer."
Assign the following properties, and press OK to save the page.
Property | Value |
Name | Master Detail Page |
The page will appear at the bottom of the page hierarchy in the Project Explorer. Drop it on the right side of Home node to place it in the second position in the navigation menu.
data:image/s3,"s3://crabby-images/9c9cc/9c9ccc35208e76a3334b001a74c3154cfd1eeba5" alt="Master Detail Page placed after Home page in the Project Explorer. Master Detail Page placed after Home page in the Project Explorer."
Adding Data Views
Switch to the Controllers tab. While holding down Ctrl key, click on the controllers in this order: Customers, Orders, OrderDetails. Right-click on OrderDetails node and select Copy.
data:image/s3,"s3://crabby-images/ef0b3/ef0b3427fac099c7fe7d3820f0a4292b6e6dcace" alt="Copy context menu option for three selected controllers in the Project Explorer. Copy context menu option for three selected controllers in the Project Explorer."
Switch back to the Pages tab. Right-click on Master Detail Page and press Paste. The three copied controllers will be pasted as data views each in their own container.
data:image/s3,"s3://crabby-images/5995f/5995ff01dad680b06f2b6f43710db96d6b5d849b" alt="Master Detail Page with three new data views in individual containers after pasting. Master Detail Page with three new data views in individual containers after pasting."
Configuring Master-Detail Relationships
The data views have been added to the page, but there are no relationships between them yet.
Expand to Master Detail Page / c102 / view2 / grid1 / CustomerID data field node. Drag CustomerID and drop on view1 node. The data view view2 will be configured to filter orders by the customer selected in view1 data view.
data:image/s3,"s3://crabby-images/39bff/39bffbf673fcdcdd4f4b22d7b91c19a19d0f343c" alt="Data view 'view2' is now configured with a master-detail relationship with 'view1'. Records will be filtered according to the selected record in 'view1'. Data view 'view2' is now configured with a master-detail relationship with 'view1'. Records will be filtered according to the selected record in 'view1'."
Expand to Master Detail Page / c103 / view3 / grid1 / OrderID data field node. Drag OrderID and drop on view2 node. Data view view3 will be configured to filter order details by the order selected in view2 data view.
data:image/s3,"s3://crabby-images/82ec0/82ec0020f5918d97d750c52b409b721bead55134" alt="Data view 'view3' is now configured with a master-detail relationship with 'view2'. Records will be filtered according to the selected record in 'view2'. Data view 'view3' is now configured with a master-detail relationship with 'view2'. Records will be filtered according to the selected record in 'view2'."
Testing the Three-level Master-Detail Page
In the Project Explorer, right-click on Master Detail Page node and press View in Browser.
data:image/s3,"s3://crabby-images/fa4a5/fa4a5a8e9dbc324cc6148d466e757df4cb94ea18" alt="View in Browser context menu option for a page node in the Project Explorer. View in Browser context menu option for a page node in the Project Explorer."
The web application will be generated and the page will open in your default browser. Select a customer, and a list of related orders will appear underneath. Select an order, and related order details will be displayed.
data:image/s3,"s3://crabby-images/f9c32/f9c32e8ff6236a3368b2384ca0783ebe1f4b4c46" alt="Master Detail Page configured with a three-level master-detail relationship. Master Detail Page configured with a three-level master-detail relationship."
Further Customization
The standard form views have their fields rendered top down. The screenshot shows form views of related customer and order.
data:image/s3,"s3://crabby-images/27667/27667e47e667497e1d91db67b159caf61b0ab62f" alt="The standard form views have their fields rendered top down. The standard form views have their fields rendered top down."
Let’s customize the presentation of both form views.
Switch back to the Project Designer. In the Project Explorer, double-click on Master Detail Page / c101 / editForm1 / c1 category node.
data:image/s3,"s3://crabby-images/0b9be/0b9bebf6c989d3aef7356d357dcce140d91fa8d6" alt="Category c1 in editForm1 of Customers controller. Category c1 in editForm1 of Customers controller."
Change the Floating property to “Yes”, and press OK to save the category.
Property | New Value |
Floating | Yes |
In the Project Explorer, right-click on Master Detail Page / c102 / view2 / editForm1 / c1 node and press New Category.
data:image/s3,"s3://crabby-images/cc8b0/cc8b032b82c47abcac0ef68ecd2a5790d23bc554" alt="New Category context menu option for the view 'editForm1'. New Category context menu option for the view 'editForm1'."
Assign the following properties.
Property | New Value |
Header Text | Shipping Info |
New Column | Yes |
Drag all the Ship- data fields from c1 – Orders category and drop them on c2 – Shipping Info category.
data:image/s3,"s3://crabby-images/86e4a/86e4a85b81ab48facfefd409b2a3ac25b915a5ff" alt="All shipping data fields have been moved into 'c2' category. All shipping data fields have been moved into 'c2' category."
Right-click on Master Detail Page node, and press View in Browser.
data:image/s3,"s3://crabby-images/1e4e5/1e4e51c53a8d3fd316b2e64f6c10897d40249fa5" alt="View in Browser context menu option for Master Detail Page in the Project Explorer. View in Browser context menu option for Master Detail Page in the Project Explorer."
When the page loads, select a customer from the list. The form view will be more compact as the fields are floating. Click on an order – the data fields will be split in two columns.
data:image/s3,"s3://crabby-images/db12c/db12c6dc31018611786229d819a7adb567c3da5e" alt="Master Detail Page with customized categories for Customers and Orders. Master Detail Page with customized categories for Customers and Orders."
If you select an order detail record, it will show up in a modal window. This behavior has been configured automatically when the master-detail relationship was established between view3 (Order Details) and view2 (Orders) data views.
data:image/s3,"s3://crabby-images/0117e/0117edd029062aa452ba9c801aa37ed51c7692a2" alt="If you select an order detail record, it will show up in a modal window. If you select an order detail record, it will show up in a modal window."