Quickstart building a web application (desktop style)
Lesson 5: Creating the Media View
In this last lesson the Media View will be created.
- Define the Media Table. A relation between the Media and Person Table will be created. The Person Table is the Parent of the Media Table.
- Define the business rules on top of the Media Table. These are defined in the Data Dictionary. We’re going to add a validation table that allows you to select the media type from a list of specific types.
- Create the Media View, by using a template.
- Test the Media View.
- Create the lookup, the dialog that helps to easily select records.
Define the Media Table
- Click the Create New Table.
- Enter the Table Name: Media
- Add the following fields:
- MediaId, Numeric, 8,0
- PersonId, Numeric, 8,0
- Title, ASCII, 100,0
- Author, ASCII, 60,0
- Type, ASCII, 8,0
- PurchaseDate, Date, 6,0
- Price, Numeric, 4,2
data:image/s3,"s3://crabby-images/02700/02700e8d7d419dc6606d777c7b759a3603baad39" alt=""
- Define the Relationships by clicking the Relationships tab.
- Click on Add Relationship.
data:image/s3,"s3://crabby-images/a08fb/a08fbfd6967056914ba5a348ce9b894b474d1f76" alt=""
- Choose the table we want to relate to, in this case the Person table.
- Select the fields on both tables that will define the relation. The first is creating a relationship between the PersonId in Media and in Person.
data:image/s3,"s3://crabby-images/60168/601688c002de7e9c606e8092f40e47a2cec851ae" alt=""
- Define the Index.
- Got to Indexes and click Add Index.
- Create a unique index for MediaId.
data:image/s3,"s3://crabby-images/caec8/caec89eb9b8f7a468db4059b7d928dedcc3d6c34" alt=""
- The second Index will be used for the relationship. Select PersonId and MediaId.
data:image/s3,"s3://crabby-images/14ac7/14ac74d8c98482313ae3b95c75c74f7bdf814530" alt=""
- Create some Indexes to sort on, in this case:
- Title
- PersonId
- MediaId
data:image/s3,"s3://crabby-images/ceadb/ceadbb5fdd28d03e7a60deed71993708b4b76f88" alt=""
- The fourth Index contains also indexes to sort on:
- Author
- Title
- PersonId
- MediaId
data:image/s3,"s3://crabby-images/b8af5/b8af5510b1ccee08b57a03adaaea1ecfa1b3915d" alt=""
Create Data Dictionary
- The Studio already generated an empty Data Dictionary:
data:image/s3,"s3://crabby-images/1cd28/1cd28783b9d45590297192adc82eec7045cb2950" alt=""
- Select Auto Increment and choose Sysfile, MediaId:
data:image/s3,"s3://crabby-images/9d051/9d051edc9272fa08ab29147d74026eb8807c0de1" alt=""
- Set Protect Vavlue to True by double clicking it:
data:image/s3,"s3://crabby-images/2f78b/2f78b21d8a7d0d057c5f27f04f5dff18fe218680" alt=""
- In the left column select Title:
data:image/s3,"s3://crabby-images/27c0c/27c0c24eb6c6c4d80d9fbd557f30ef635cae1ee6" alt=""
- Mark as required:
data:image/s3,"s3://crabby-images/4f20c/4f20cf4ade79343e95b5665ec98885014f7aa3b8" alt=""
- Do the same for Author.
- Select Price:
data:image/s3,"s3://crabby-images/f089f/f089f42b69ab29a2d4ab2d7f9d3099953ef91eb8" alt=""
- For the Price select Mask Type and choose Mask_Currency_Window:
data:image/s3,"s3://crabby-images/17622/176228f705f87f0afe520af329d34a6044c96750" alt=""
- Next step is setting up Validation Objects. First select Type in the left column. Then select Validation Objects. Click on Add Validation Object:
data:image/s3,"s3://crabby-images/485ce/485ce77f9f0502779c5160a0916f35a7ae1a6639" alt=""
- Set the name to oMediaType and apply it to the Type column.
data:image/s3,"s3://crabby-images/39b97/39b9706111c6ea1616ed6462f7ac00c84eba1178" alt=""
- Enter the options that will be available for this field. In this Quickstart:
- CD
- DVD
- Book
- Mp3
- Other
data:image/s3,"s3://crabby-images/51007/51007928e5bea6860de80691ca66b2909f714201" alt=""
- We will make this Combo field as a pull down. Go back to the tab Columns.
data:image/s3,"s3://crabby-images/9565a/9565a898bbad47c1be00dad5b51413c5bf754d6f" alt=""
- Make sure the Type column is still selected. Go to Visual Control and select Combo.
data:image/s3,"s3://crabby-images/fe424/fe424685dd38a9dbf97895e4fa41f817b2b15bb2" alt=""
- Save the Data Dictionary.
Define the View
- Go to Create New and select the Web View.
data:image/s3,"s3://crabby-images/31b48/31b4877fbfebd816eea326a76f00b3271f905265" alt=""
- Note: we don’t choose the Web View Wizard in this case, but the Web View Template. This is a bit simpler.
- Give the Object Name oMediaView and the caption Media.
data:image/s3,"s3://crabby-images/167cb/167cb479ac473924247b722ad2ad2b03604d7102" alt=""
- It immediately generates a basic structure for the view.
- Previewing this, there is one example field.
data:image/s3,"s3://crabby-images/e8e69/e8e691abce70a5edf3e0dd1ddf2bd03558622a2a" alt=""
- Delete this example by right click and choosing Delete.
- To add a field again choose DDO Explorer and click on Add DDO.
data:image/s3,"s3://crabby-images/54a45/54a45f87395404dd5e1810d5c6d96837dcc2aec6" alt=""
- Now the Data Dictionary needs to be chosen. In this case the Media data dictionary.
data:image/s3,"s3://crabby-images/f556a/f556a0c887d6c2d6400bff9c4da39d971724e0e5" alt=""
- It immediately also adds the Person Data Dictionary because it’s the parent. Based on the relationship that’s defined earlier.
data:image/s3,"s3://crabby-images/bb011/bb011b196a3cdbbfe7ea54f26573d7a6823142d9" alt=""
- Selecting the DDO Column Selector we can select the fields we want on our view. In this case:
- MediaId
- PersonId
- Title
- Author
- Type
data:image/s3,"s3://crabby-images/88071/88071e2ad16d0a66ad106bedece61d16ed50c23c" alt=""
- Select the fields and drag them to the View.
- Note that Type automatically became a Combo form.
data:image/s3,"s3://crabby-images/aabc1/aabc10b6aa4d6a88c6f14410a0fb6ee4462b2d09" alt=""
- In the previous list we didn’t select the PurchaseDate. To add the date go to Class Palette.
data:image/s3,"s3://crabby-images/e5bb6/e5bb6bc74d545e7a569882048be159d8ed950635" alt=""
- Select the cWebDataForm.
data:image/s3,"s3://crabby-images/860a3/860a3c2387a7c212f07ed5effd97e1bc4b6956a4" alt=""
- Drag the DateForm and drag it after the Type field.
data:image/s3,"s3://crabby-images/a0358/a0358c723b4dedd3e5cdb1d10e6c92a8510755af" alt=""
- Because it’s dragged from the Class Palette it needs to bind to the database field manually.
- Go to Properties, Binding.
data:image/s3,"s3://crabby-images/b1929/b19293520464d5edd6c267bac7c78c0dd1b9530d" alt=""
- Select the Data Source and select oMedia_DD, PurchaseDate.
data:image/s3,"s3://crabby-images/a4cc7/a4cc77ce488a26b3f5fe2b00eb2e0e7237dfe81e" alt=""
- In the Properties panel the Label can be changed. In this Quickstart we change it from dateform to Purchase date.
data:image/s3,"s3://crabby-images/cf6d7/cf6d73d5350b2f84ed4eaac86cc6fbd1c30419bf" alt=""
- Go back to the View. The PersonId isn’t needed in this case. Right click it and choose Delete.
data:image/s3,"s3://crabby-images/3f8f1/3f8f135f93db5b58bd1dfad5d2936c1e3be39c7f" alt=""
- Now change the sizes and the order of the fields in the View. For this Quickstart we do it this way:
data:image/s3,"s3://crabby-images/5c29d/5c29dc0d0fbe025101ab295f2968ad5545198407" alt=""
- Note that we didn’t add any fields from our parent table. We’re going to add that later.
- Now we will add a Group.
- Select Web Containers, cWebGroup, from the Class Palette.
data:image/s3,"s3://crabby-images/7bba7/7bba7c0af6c1bda9f1111d8b3cfe37bdab7f9337" alt=""
- Drag it after the Price field.
data:image/s3,"s3://crabby-images/25bac/25bacb66482c1c981c34e0f4c44d5287252602ef" alt=""