This section describes how to use Application Builder to build an application and application components. It includes instructions for creating an application and adding pages as well as adding components (reports, charts, or forms), page controls (buttons, items, list of values), or a shared components (menus, lists, or tabs).
This section contains the following topics:
You create a new application in Oracle HTML DB using the Create Application Wizard. You delete an application from the Application Builder home page.
Topics in this section include:
You can use the Create Application Wizard to create a new application having up to nine pages.
To create an application using the Create Application Wizard:
Navigate to the Workspace home page.
Click the Create Application button.
Choose the method by which you want to create your application:
From Scratch. Enables you to define tabs, select a user interface (UI), and many other options.
Based on an Existing Application. Creates a copy of another application, including any authentication settings, but without any the pages. Select this option to create an application using the same user interface templates as an existing application.
Based on an Existing Table. Creates a complete application based on an existing table in your workspace. The resulting application includes a standard report, an insert form, an update form, a success form (indicates when a record is successfully inserted), an analysis menu page, analysis reports, analysis charts, and a login page.
Demonstration Application. Installs a demonstration application included with Oracle HTML DB.
Based on Spreadsheet. Creates an easily deployable application from a spreadsheet.
From an Application Export File. Uploads an application export file.
Follow the on-screen instruction.
Once you create an application the next step is to specify application attributes.
You can delete an application from the Application Builder home page, or while editing application attributes. If you delete an application you also delete all defined components (reports, charts, or forms), page controls (buttons, items, list of values), or a shared components (menus, lists, or tabs).
To delete an application from Application Builder home page:
Navigate to the Workspace home page.
From the Applications list, select an application.
When Application Builder appears, verify the application name and the application ID at the top of the page.
From the Tasks list, select Delete this Application.
Follow the on-screen instructions.
To delete an application while editing application attributes:
Navigate to the Workspace home page.
From the Applications list, select an application.
When Application Builder appears, verify the application name and the application ID at the top of the page.
Click the Edit Attributes icon.
The Edit Application Attributes page appears.
Verify the application ID and name.
Click Delete at the top of the page.
You can add a new page or add a component to an existing page by running the Create Page Wizard. You can access this wizard on the Application Builder home page, the Page Definition, or by selecting the New... link on the Developer toolbar.
When you run the Create Page Wizard, you choose whether to create a blank page or a page with a component. Select Page with Component to create a page containing a report, a chart, a form, a wizard, a calendar, or a tree.
| Note:You can add a component (that is, a report, chart, form, wizard, a calendar, or tree) to an existing page using the Create Page Wizard. When prompted, specify an existing page number. | 
Topics in this section include:
| See Also:"Creating Reports", "Creating Charts", "Creating Forms", "Creating Calendars", and "Creating Trees" | 
To create a new page from the Application Builder home page:
Navigate to Workspace home page.
From the Applications list, select an application.
On the Application Builder home page, click Create Page.
Select the type of page you wish to create:
Blank Page
Page with Component
Select Page with Component to create a page containing a report, a chart, a form, a wizard, a calendar, or a tree. Selecting this option creates complete pages containing multiple attributes. For example, the Report wizard generates one page containing one region and multiple buttons.
Follow the on-screen instructions.
To create a new page while viewing a Page Definition:
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
From the navigation bar at the top of the page, click the Create button.
Select the type of page you wish to create:
Blank Page
Page with Component
Select Page with Component to create a page containing a report, a chart, a form, a wizard, a calendar, or a tree. Selecting this option creates complete pages containing multiple attributes. For example, the Report wizard generates one page containing one region and multiple buttons.
Follow the on-screen instructions.
Users who log in to Oracle HTML DB having developer privileges have access to the Developer toolbar. The Developer toolbar displays at the bottom every page and offers a quick way create a new page.
To create a new page from the Developer toolbar:
On the Developer toolbar, select New.
Select the type of page you want to create:
Page (Blank Page)
Component (Report, Form, Chart)
Page Control (Region, Item, Button)
Shared Control (Menu, List, Tab)
Follow the on-screen instructions.
The HTML DB engine dynamically renders and process pages based on data stored in database tables. To view a rendered version of your application, you run or submit it to the HTML DB engine. As you create new pages you can run them individually, or run an entire application. You can run a page from numerous locations within Application Builder by clicking the Run icon. (See Figure 8-1.)
To run a specific page from the Pages list:
Navigate to the Workspace home page.
From the Applications list, select an application.
Application Builder appears. The list of pages for the selected application appears at the bottom of the page.
From the Pages list, locate the page you wish to run and click the Run button in the far right column.
To run a specific page from the Page Definition:
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
Click the Run button in the upper right corner of the page.
To run an entire application:
Navigate to the Workspace home page.
Locate the application in the Applications list.
Click the Run button in the far right column.
You can make the pages within your application easier to access by organizing them into page groups.
Topics in this section include:
To create a page group:
Navigate to the Workspace home page.
From the Applications list, select an application.
From the Tasks List on the right side of the page, select Manage Page Groups.
On the Page Groups page, click Create.
Enter a name, a description (optional), and click Create.
To assign pages to page group:
Navigate to the Workspace home page.
From the Applications list, select the application.
From the Tasks List on the right side of the page, select Manage Page Groups.
From the Tasks list, select Report Unassigned Pages.
The Unassigned Pages page appears.
From Page Group, select a group to assign pages to.
Select the pages to be assigned.
Click Assigned Checked.
Selecting the page number takes you to the Page Attributes page. Selecting the Page Name links to the Page Definition.
The Page Group Report offers a comprehensive list of which pages in an application are assigned to a group and which pages are unassigned.
To view the Page Group Report:
Navigate to the Workspace home page.
From the Applications list, select the application.
From the Tasks List on the right side of the page, select Manage Page Groups.
On the Page Groups page, click Report Page Groups.
You can prevent conflicts during application development by locking pages of your application. By locking a page, you prevent other developers from editing it.
To lock a page of your application:
Navigate to the Workspace home page.
From the Applications list, select the application.
To lock pages from the Locked Pages page:
From the Tasks List on the right side of the page, select Manage Page Locks.
Select the appropriate pages and click Lock.
Enter a comment in the Comment field.
Click Lock Pages.
To lock pages from the Pages list:
Click the Lock icon in the Pages list.
Enter a comment in the Comment field.
Click Lock Pages.
To lock pages from the Page Definition:
Navigate to the Page Definition. (See "Viewing a Page Definition".)
Click the Lock icon in the upper right corner above Shared Components.
The Locked Pages page appears.
Select the appropriate pages and click Lock.
Enter a comment in the Comment field.
Click Lock Pages.
Only the user who locked a page can unlock it.
To unlock a page of your application:
Navigate to the Workspace home page.
From the Applications list, select the application.
To unlock pages from the Locked Pages page:
From the Tasks List on the right side of the page, select Manage Page Locks.
Select the appropriate pages.
Click UnLock.
To unlock pages from the Pages list:
Click the Lock icon in the Pages list.
The Edit Page Lock page appears.
Click UnLock.
To unlock pages from the Page Definition:
Navigate to the Page Definition. (See "Viewing a Page Definition".)
Click the Lock icon in the upper right corner above Shared Components.
The Locked Pages page appears.
Select the appropriate pages.
Click UnLock.
Note the Lock icon changes to reflect the lock status of a given page.
You can access a number of different views of Locked Pages on the Locked Pages page.
To access different views of locked pages:
Navigate to the Workspace home page.
From the Applications list, select the application.
From the Tasks List on the right side of the page, select Manage Page Locks.
From the Tasks list, select one of the following:
Show Locked Pages displays only locked pages within the current application
Show All Pages displays all pages within the current application
Show Unlocked Pages display only unlocked pages within the current application
Administer Locks enables workspace administrators to unlock any pages locked by a developer
You can delete a page from the Page Definition or while editing page attributes.
To delete a page from the Page Definition:
Navigate to the Page Definition. (See "Viewing a Page Definition".)
Verify the page name.
From the navigation bar at the top of the page, click Delete.
Follow the on-screen instructions.
To delete a page while editing page attributes:
Navigate to the Page Definition. (See "Viewing a Page Definition".)
From the navigation bar at the top of the page, click Edit Attributes.
Verify the application ID and page name.
Click Delete.
Follow the on-screen instructions.
In Oracle HTML DB a report is the formatted result of a SQL query. You can generate reports by selecting and running a built-in query, or by defining a report region based on a SQL query.
Topics in this section include:
Oracle HTML DB includes the number of built-in wizards for generating reports.
To create a report using a wizard:
Navigate to the Workspace home page.
From the Applications list, select the application.
Application Builder appears.
Click Create Page.
Select Page with Component.
Select Report.
Select one of the following report types:
Easy Report - Does not require any SQL knowledge. Simply select the appropriate schema, table, columns, and result set display.
Report with Form - Builds a two page report and form combination. The first page enables users to specify the row to be updated. The second page includes a form for updating the selected table or view.
SQL Report - Creates a report based on a custom SQL SELECT statement or a PL/SQL function returning a SQL SELECT statement that you provide.
Follow the on-screen instructions.
You can use the Report Attributes and Column Attributes pages to precisely control the look and feel of report pages. For example, you can use these attributes to alter column heading text, change column positioning, hide a column, create a sum of a column, or select a sort sequence.
On the Page Definition, you can access the Report Attributes page by clicking either Q or RPT adjacent to the report region you want to edit. Q indicates the report is a regular report and RPT indicates the report is an easy report. You can also navigate to the Report Attributes page by clicking the region name then selecting the Report Attributes tab.
To access the Report Attributes page:
Navigate to the Workspace home page.
From the Applications list, select the application.
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
Under Regions, click Q next to the name of the report region you want to edit.
The Report Attributes page appears.
Heading Type identifies how the heading was generated for the report. Use the Report Column Attributes section to control report column appearance and functionality. The Link column indicates whether a column link is currently defined. The Edit column indicates whether or not a column is currently updatable. The Edit column.
Table 8-1 describes common report column edits.
Table 8-1 Common Report Column Edits
| Description | Developer Action | 
|---|---|
| Alter column display sequence. | Click the up and down arrows. | 
| Alter heading alignment. | Under Column Alignment, select a new column alignment. | 
| Change column heading text. | Under Heading, enter a different heading text. | 
| Control which columns display. | Click Show to indicate a column should display. | 
| Enable an unique sort sequence. | Click Sort and select a sequence number from Sort Sequence. | 
| Enable the sum of a column. | Click Sum to enable the sum of a column. | 
You can further refine the attributes of a specific column on the Column Attributes page.
To access the Column Attributes page, click the Edit icon adjacent to the appropriate column name.
See online help for more information on a specific attribute.
You control report pagination by:
Including a pagination substitution string in the report template
Making selections from Layout and Pagination on the Report Attributes page
You control how pagination displays by making selections from the Layout and Pagination attributes on the Report Attributes page.
To access the Layout and Pagination section of the Report Attributes page:
Create a report. (See "Creating a Report Using a Wizard".)
Under Regions, click the appropriate report attributes link (Q or RPT).
The Report Attributes page appears.
Scroll down to Layout and Pagination.
You use the Layout and Pagination attributes to select a pagination style, determine where pagination displays, and specify the number of rows that display on each page. Table 8-2 describes the most commonly used Layout and Pagination attributes.
Table 8-2 Layout and Pagination Attributes
| Attribute | Description | 
|---|---|
| Report Template | Specifies a template to be applied to this report. Report templates provide control over the results of a row from your SQL query. You can choose from a number of default templates, or pick a custom build template. | 
| Pagination Scheme | Specifies a pagination scheme for this report. Pagination provides the user with information about the number of rows and the current position within the result set. Pagination also defines the style of links or buttons used to navigate to the next or previous page. For more information, see the help for this item. | 
| Display Position | Defines where pagination displays. If you choose to display pagination above a report, the selected report template needs to support that type of display. | 
| Number of Rows | Defines the maximum number of rows to display on each page. | 
| Strip HTML | Specifies whether or not to remove HTML tags from the original column values for HTML expressions and column links. If you select values from the database that already contain HTML tags, then those tags can cause conflicts with the HTML generated for your columns links or HTML expressions. When this option is enabled, only the actual data portion of your column value is used. | 
To include pagination after the rows in a report:
Create a report. (See "Creating a Report Using a Wizard".)
Next, select the appropriate Layout and Pagination attributes.
Navigate to the Report Attributes page:
Navigate to the Page Definition.
Under Regions, click the appropriate report attributes link (Q or RPT)
The Report Attributes page appears.
Under Layout and Pagination, select the following:
Report Template - Select a report template (optional).
Pagination Scheme - Select a pagination scheme.
Display Position - Select a display position.
Number of Rows - Specify how many rows display on each page.
Click Apply Changes.
Edit the report template.
Navigate to the Page Definition.
Under Templates, select the report template name.
Include the #PAGINATION# substitution string in the After Rows attribute.
Click Apply Changes.
Run the page.
To include pagination after the rows in a report:
Create a report. (See "Creating a Report Using a Wizard".)
Next, select the appropriate Layout and Pagination attributes.
Navigate to the Report Attributes page:
Navigate to the Page Definition.
Under Regions, click the appropriate report attributes link (Q or RPT).
The Report Attributes page appears.
Under Layout and Pagination:
Report Template - Select a report template (optional).
Pagination Scheme - Select a pagination scheme.
Display Position - Select a position that contains the word "top."
Number of Rows - Specify how many rows display on each page.
Click Apply Changes.
Edit the report template.
Navigate to the Page Definition.
Under Templates, select the report template name.
Include the #TOP_PAGINATION# substitution string in the Before Rows attribute.
Click Apply Changes.
Run the page.
You enable column sorting on the Report Attributes page.
To enable column sorting:
Navigate to the Report Attributes page. (See "Editing Report Attributes".)
Under Report Column Attributes, select the Sort check box adjacent to the columns to be sorted.
From Sort Sequence, select a sequence number.
Sort Sequence is optional. However, if there are one or more sort enabled columns, then at least one column needs a defined Sort Sequence.
Scroll down to Sorting.
Specify ascending and descending image attributes or click set defaults.
You can create a link within a report that enables users to export the report as either a comma delimited file (.csv) or XML file. You specify an export format by selecting a report template.
To specify an export report template:
Navigate to the appropriate Report Attributes page. (See "Editing Report Attributes".)
Scroll down to Layout and Pagination.
From the Report Template list, select one of the following:
export: CSV exports the report as a CSV file
export: XML exports the report as a XML file
Selecting either option prevents the HTML DB engine from rendering the page and dumps the content to either a CSV or XML file.
You can use the options under CSV Output to create a link that downloads the content of the report.
Scroll down Report Export.
From Enable SCV output, select Yes.
(Optional) In the Separator and Enclosed By fields, define the separator and delimiter characters.
The default Enclosed By by characters are a double quotes (" "). The default delimiter character is either a comma or a semicolon depending upon your current NLS settings.
In the Link Label field, enter link text. This text will display in your report and enable users to invoke a download.
(Optional) To specify a default export filename, enter a name in the Filename field.
By default, the HTML DB engine creates an export filename by taking the region name and adding the appropriate filename extension (.csv or .xml).
Click Apply Changes.
Use the Column Link attributes to create a link from a report to another page in your application or to a URL.
To create a column link to another page:
Navigate to the appropriate Report Attributes page. (See "Editing Report Attributes".)
Under Report Column Attributes, locate the column to contain the link.
Click the Edit icon adjacent to the column name.
The Column Attributes page appears.
Scroll down to Column Link.
To create a Column Link to another page:
From Target, select Page in this Application.
(Optional) In Link Attributes, specify additional column link attributes that will be included in the <a href= > tag (for example, a link target, classes, or styles).
In Link Text, enter text to be displayed as a link, specify an image tag, or pick from the list of default images.
In Page, specify the target page number. To reset pagination for this page, select Reset Pagination.
In Request, specify the request to be used.
In Clear Cache, specify the pages (that is, the page numbers) on which to clear cache. You can specify multiple pages by listing the page numbers in a comma delimited list.
Use the Name and Value fields to specify session state for a specific item.
Click Apply Changes.
To create a column link to a URL:
Navigate to the appropriate Report Attributes page. (See "Editing Report Attributes".)
Access the Column Attributes page by clicking the Edit icon adjacent to the appropriate column.
The Column Attributes page appears.
Scroll down to Column Link.
Under Column Link, make the following selections
From Target Type, select URL.
In Link Text, enter text to be displayed as a link, select a substitution string.
(Optional) In Link Attributes, specify additional column link attributes that will be included in the <a href= > tag (for example, a link target, classes, or styles).
In URL, enter the appropriate address.
Click Apply Changes.
You can make a column updatable by editing Tabular Form Element attributes on the Column Attributes page. Note that the HTML DB engine can only perform updates if a multi row update is defined, or PL/SQL process is implemented to process updated data.
To define updatable column attributes:
Navigate to the appropriate Report Attributes page. (See "Editing Report Attributes".)
Access the Column Attributes page by clicking the Edit icon adjacent to the appropriate column.
The Column Attributes page appears.
Scroll down to Tabular Form Element.
Under Tabular Form Element, make the following selections:
From Display As, select a type of updatable column.
Use this option to make a column updatable. Updates can only be performed if a multi row update is defined, or PL/SQL process is implemented to process updated data.
From Date Picker Format Mask, make a selection if you selected the Display As type of Date Picker.
In Element Width, specify the width of the form item.
In Number of Rows, specify the height of a form item (applicable to text areas).
In Element Attributes, define a style or standard form element attribute.
In Element Option Attributes, specify form element attributes for items in a radio group or check box.
From Default Type, identify the default type.
In Default, identify the default source.
Use Default Type and Default Source to add new rows to a tabular form. The HTML DB engine uses this setting to determine the default value for the column. Otherwise, the column is defined as NULL.
From Reference Table Owner, identify the owner of the referenced table. Use this attribute to build User Interface Defaults for reports.
In Reference Table Name, identify the table or view that contains the current report column.
In Reference Column Name, identify the column name that this report column references
Click Apply Changes.
Report columns may be rendered as lists of values. For example, a column can be rendered using a select list or a popup list of values. Or, a column can also be rendered as read-only text based on a list of values.
This last approach is an effective strategy when creating display lookup values and is particularly useful in regular, non-updatable reports. This approach enables you to display the value of a column without having to write a SQL JOIN.
To render a report column as a list of values:
Navigate to the appropriate Report Attributes page. (See "Editing Report Attributes".)
Access the Column Attributes page by clicking the Edit icon adjacent to the appropriate column.
The Column Attributes page appears.
Scroll down to List of Values.
From Named LOV, make a selection from the Named List of Values repository.
To include a null value in a list of values:
In Display Null, select Yes.
In Null Text, specify the value that displays.
A column may also have a value that does not display in its list of values.
To define a value that does not display in the list of values:
From Display Extra Value, select Yes.
The extra value is used if the actual column value is not part of the LOV. In that situation, the actual value is shown. If you do not display extra values, you may end up with the wrong value and unintentionally and update your data incorrectly.
In Null Value, specify the value that displays.
If you have not selected a Named LOV, enter the query used to display a select list in the LOV Query field.
If you have not selected a Named LOV, enter the query used to display a select list in LOV Query.
Click Apply Changes.
You can use the Authorization and Conditional Display column attributes to control when a column displays.
Authorization enables you to control access to resources (such as a report column) based on predefined user privileges. For example, you could create an authorization scheme in which only managers can view a specific report column. Before you can select an authorization scheme, you must first create it.
A condition is a small unit of logic that enables you to control the display of a column based on a predefined condition type. The condition evaluates to true or false based on the values you enter in the Expressions fields.
To specify Authorization and Conditional Display attributes:
Navigate to the appropriate Report Attributes page. (See "Editing Report Attributes".)
Access the Column Attributes page by clicking the Edit icon adjacent to the appropriate column.
The Column Attributes page appears.
Under Authorization, make a selection from the Authorization Scheme list.
Under Conditional Display, make a selection from the Condition Type list and depending upon your selection, enter an expression or value in the appropriate Expression fields.
If the authorization is successful and the condition type display evaluates to true, the column displays.
You can control whether a specific column repeats and how column breaks appear when printed using Break Formatting attributes. For example, suppose your report displays employee information by department number. If multiple employees are members of the same department, you can increase the readability by specifying the department number only appears once.
To create this type of column break:
Navigate to the appropriate Report Attributes page. (See "Editing Report Attributes".)
Scroll down to Break Formatting.
Make a selection from the Breaks list.
You can include a variety of different types of forms in your applications. You can include forms that enable users to update just a single row in a table or multiple rows at once. Oracle HTML DB includes a number of wizards you can use to create forms automatically, or you can create forms manually.
Topics in this section include:
The easiest way to create a form is to use a wizard. For example, the Form on Table or View Wizard creates one item for each column in a table. It also includes the necessary buttons and processes required to insert, update, and delete rows from the table using a primary key. Each region has a defined name and display position all other attributes are items, buttons, processes, and branches.
To create a form using a wizard:
Navigate to the Workspace home page.
From the Applications list, select an application.
Application Builder appears.
Click Create Page.
Select Page with Component.
Select Form.
Under Forms, select a wizard described in Table 8-3.
| Wizard | Description | 
|---|---|
| Form on a Procedure | Builds a form based on stored procedure arguments. Use this approach when you have implemented logic or DML (Data Manipulation Language) in a stored procedure or package. | 
| Form on a SQL Query | Creates a form based on the columns returned by a SQL query such as an equijoin. | 
| Form on a Table or View | Creates a form that enables users to update a single row in a database table. | 
| Form on a Table with Report. 2 pages | Creates two pages. One page displays a report. Each row provides a link to the second page to enable users to update each record. Note: This wizard does not support tables having more than 127 columns. Selecting more than 127 columns will generate an error. | 
| Form on Web Service | Creates a page with items based on a Web service definition. This wizard creates a user input form, a process to call the Web service, and a submit button. See Also: "Creating a Form on a Web Service" | 
| Form and Report on Web Service | Creates a page with items based on a Web service definition. This wizard creates a user input form, a process to call the Web service, a submit button, and displays the results returned in a report. See Also: "Creating an Input Form and Report on a Web Service" | 
| Master Detail Form | Creates a form which displays a master row and multiple detail rows within a single HTML form. With this form, users can query, insert, update, and delete values from two tables or views. See Also: "Building a Master Detail Form" | 
| Summary Page | Creates a read-only version of a form. Typically used to provide a confirmation page at the end of a wizard. | 
| Tabular Form | Creates a form in which users can update multiple rows in a database. See Also: "Creating a Tabular Form" | 
Follow the on-screen instructions.
A tabular form enables users to update multiple rows in a table. The Tabular Form Wizard creates a form to perform update, insert, and delete operations on multiple rows in a database table.
To create a tabular form:
From the Workspace home page, select the appropriate application.
Click Create Page.
Select Page with Component.
Select Form.
Select Tabular Form.
The Tabular Form Wizard appears.
On Identify Table/View Owner:
Specify the table or view owner on which you want to base your tabular form.
Select the type of tabular form you want to create.
Select a table.
On Identify Table/View Name, select a table.
On Identify Columns to Display:
Specify whether to use user interface defaults.
User interface defaults enable you to assign default user interface properties to a table, column, or view within a specified schema.
Select the columns (updatable and nonupdatable) to include in the form.
You can modify the column order or your SQL query after you have created the page.
On Identify Primary Key, select the Primary Key column and a foreign key column (if applicable).
On Defaults for Primary and Foreign Keys, select a source type for the primary key column. Valid options include:
Existing trigger - Select this option if a trigger is already defined for the table. You do not need to define a primary key column source for existing columns. Existing columns already have a primary key.
Custom PL/SQL function - Select this option if the source is a PL/SQL function returning the key value.
Existing sequence - Select this option if an existing sequence is defined for the table. If that is the case, the sequence next value would be used.
On Updatable Columns, select which columns should be updatable.
On Identify Page and Region Attributes.
Specify page and region information.
Select a region template.
Select a report template.
On Identify Tab, specify a tab implementation for this page.
On Button Labels, enter the display text to appear on the Cancel, Submit, Delete, and Add Row buttons.
On Identify Branching, specify the pages to branch to after the user clicks the Submit and Cancel buttons.
Click Finish.
| Note:Do not modify the select list of a SQL statement of a tabular form after it has been generated. Doing so can result in a checksum error when you alter data in the form. | 
A master detail form reflects a one-to-many relationship between two tables in a database. Typically a master detail form displays a master row and multiple detail rows within a single HTML form. With this form, users can insert, update, and delete values from two tables or views.
To create a master detail form:
From the Workspace home page, select the appropriate application.
Click Create Page.
Select Page with Component.
Select Form.
Select Master Detail Form.
The Master Detail Wizard appears.
On Define Master Table:
Select a table or view owner
Select a table or view name
Select the columns to display
On Define Detail Table:
Specify to show only related tables
Select the table or view owner
Select the table or view name
Select the columns to display
On Define Primary Key, select the primary key column for the master table and then the primary key column for the detail table.
On Define Master and Detail, define the relationships between master and detail tables.
Specify the source for the master table and detail table primary key columns.
On Define Master Options, specify whether to include master row navigation.
If you include master row navigation, define navigation order columns. If a navigation order column is not defined, the master update form will navigate by the primary key column.
On Choose Layout, specify the layout of the master detail pages.
You can include the master detail as a tabular form on the same page, or add the master detail on a separate page.
On Page Attributes, review and edit the master page and detail page information.
On Identify Tabs, specify whether to include an optional tab set.
Click Create.
You can also create a form manually by performing the following steps:
Create an HTML region (to serve as a container for your page items)
Create items to display in the region
Create processes and branches
To create a form manually:
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
Create an HTML region:
Under Regions, click Create
Select the region type HTML
Follow the on-screen instructions
Start adding items to the page:
Under Items, click Create
Follow the on-screen instructions
Once you create a form, the next step is to process the data a user types by inserting into or updating the underlying database tables or views. There are three ways to process a form:
One common way to implement a form is to manually create an Automatic Row Processing (DML) process. This approach offers three advantages. First, you are not required to provide any SQL coding. Second, Oracle HTML DB performs DML processing for you. Third, this process automatically performs lost update detection. Lost update detection ensures data integrity in applications where data can be accessed concurrently.
In order to implement this approach you need to:
Add items and define the Item Source Type as Database Column and specify a case-sensitive column name
Select the option Always overrides the cache value
To create an Automatic Row Processing (DML) process:
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
Under Processes, click the Create icon.
Select the process type Data Manipulation.
Select the process category Automatic Row Processing (DML).
Specify the following process attributes:
In the Name field, type a name to identify the process.
In the Sequence field, specify a sequence number.
From the Point list, select the appropriate processing point. In most instances, select Onload - After Header.
From the Type list, select Automated Row Processing (DML).
Follow the on-screen instructions.
In this approach to form handling, you create one or more processes to handle insert, update and delete actions. Instead of having the HTML DB engine handling everything transparently, you are in complete control.
For example, suppose you have a form with three items:
P1_ID - A hidden item to store the primary key of the currently displayed row in a table.
P1_FIRST_NAME - A text field for user input.
P1_LAST_NAME - A text field for user input.
Assume also there are three buttons labeled Insert, Update, and Delete. Also assume you have a table T which contains the columns id, first_name, and last_name. The table has a trigger which automatically populates the ID column when there is no value supplied.
To process the insert of a new row, you create a conditional process of type PL/SQL that executes when the user clicks the Insert button. For example:
BEGIN
  INSERT INTO T ( first_name, last_name )
     VALUES  (:P1_FIRST_NAME, :P1_LAST_NAME);
END; 
To process the update of a row, you create another conditional process of type PL/SQL. For example:
BEGIN
    UPDATE T
       SET first_name = :P1_FIRST_NAME,
           last_name = :P1_LAST_NAME
    WHERE ID = :P1_ID;
END; 
To process the deletion of a row, you create a conditional process that executes when the user clicks the Delete button. For example:
BEGIN
    DELETE FROM T
    WHERE ID = :P1_ID;
END;
For certain types of applications it is appropriate to centralize all access to tables in a single or few PL/SQL packages. If you have created a package to handle DML operations, you can call procedures and functions within this package from a After Submit PL/SQL process to process insert, update and delete requests.
Oracle HTML DB populates a form on load, or when the HTML DB engine renders the page. You can populate a form in the following ways:
Create a process and define the type as Automated Row Fetch
Populate the form manually by referencing a hidden session state item
To create an Automated Row Fetch process:
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
Under Processes, click Create.
Select the process type Data Manipulation.
Select the process category Automatic Row Fetch.
Specify the following process attributes:
In the Name field, type a name to identify the process.
In the Sequence field, specify a sequence number.
From the Point list, select the appropriate processing point.
From the Type list, select Automated Row Fetch.
Follow the on-screen instructions.
You can also populate a form manually by referencing a hidden session state item. For example, the following code in an Oracle HTML DB process of type PL/SQL would set the values of ename and sal. The example also demonstrates how to manually populate a form by referencing a hidden session state item named P2_ID.
FOR C1 in (SELECT ename, sal
FROM emp WHERE ID=:P2_ID)
LOOP     
     :P2_ENAME := C1.ename;
     :P2_SAL := C1.sal;
END LOOP;
In this example:
C1 is an implicit cursor
The value of P2_ID has already been set
The process point for this process would be set to execute (or fire) on or before Onload - Before Regions
You can use validations to check data a user types prior to processing. Once you create a validation and the associated error message, you can associate it with a specific item. You can choose to have validation error messages display inline (that is, on the page where the validation is performed) or on a separate error page.
Creating an inline error message involves these steps:
Create a new validation and specify error message text
Associate the validation with a specific item
To create a new validation:
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
Under Validations, click the Create icon.
When the Create Validations Wizard appears, follow the on-screen instructions.
Validations Types are divided into two categories:
Item. These validations start with the phrase "Item" and provide common checks you may want to perform on the item that the validation is associated with.
Code. These validations require you provide either a piece of PL/SQL code or SQL query that defines the validation logic. Use this type of validation to perform custom validations that require verifying values of more than one item or accessing additional database tables.
Follow the on-screen instructions.
| Note:Validations may not contain more than 3,950 characters. | 
To associate an item with a validation and specify error message text:
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
Under Validations, select the validation item you want to associate.
The attributes page for the validation appears.
Scroll down to Error Messaging:
In Error message display location, verify the display location
In Associated Item, select the item you want to associate with this validation
Click Apply Changes.
Error message display location identifies where a validation error message displays. Validation error messages can display on an error page or inline within the existing page. Inline error messages can display in a notification area (defined as part of the page template) or within the field label.
If you want to create a hard error that stops processing of any remaining validations, you must display the error on an error page.
Oracle HTML DB includes built-in wizards for generating HTML and Scalable Vector Graphics (SVG) charts. Oracle HTML DB supports two types of graphical charts:
HTML
SVG
SVG is an XML-based language for Web graphics from the World Wide Web Consortium (W3C). SVG charts are defined using an embed tag. When evaluating whether a SVG chart is the appropriate chart type for your application remember that:
Some Web browsers do not support SVG charts
Most Web browsers that support SVG charts require users download an SVG plug-in
Topics in this section include:
The Adobe SVG plug-in can properly handle data encoded in UTF-8, UTF-16, ISO-8859-1, and US-ASCII. Encoding of an SVG chart is determined by the database access descriptor (DAD) database character set. If the DAD character set is not UTF8, AL32UTF8, AL16UTF16, WE8ISO8859P1, or US7ASCII, SVG charts may not render properly in the Adobe SVG plug-in.
You define a chart in Oracle HTML DB using a wizard. For most chart wizards, you select a chart type and provide a SQL query using the following syntax:
SELECT link, label, value FROM ...
Where:
link is a URL
label is the text that displays in the bar
value is the numeric column that defines the bar size
For example:
SELECT null, ename, sal FROM scott.emp WHERE deptno = :P101_DEPTNO
To create a dial chart, select a dial chart type and provide a SQL query using the following syntax:
SELECT value , maximum_value [ ,low_value [ ,high_value] ] FROM ...
Where:
value is the starting point on the dial
maximum_value is the possible highest point on the dial
low_value and high_value are the historical low and high values
For example:
select dbms_random.value(500, 1200), 1300, dbms_random.value(100, 200) FROM DUAL
Table 8-4 describes the chart types available in Oracle HTML DB.
Table 8-4 Available Chart Types
| Chart Type | Description | 
|---|---|
| Bar (HTML) | Bar chart showing one data series with each data point represented by a bar. HTML-based. Does not require a plug-in. | 
| Bar, Horizontal | Single series based bar chart oriented horizontally with each data point in series represented by a bar. SVG-based. Requires a SVG plug-in. | 
| Bar, Vertical | Single series based bar chart oriented vertically with each data point in series represented by a bar. SVG-based. Requires a SVG plug-in. | 
| Cluster Bar, Horizontal | Multiple series based bar chart oriented horizontally and clustered by a common variable with each data point in series represented by a bar (for example, Department sales total clustered by month of year). SVG-based. Requires a SVG plug-in. | 
| Cluster Bar, Vertical | Multiple series based bar chart oriented vertically clustered by a common variable with each data point in series represented by a bar (for example, Department sales total clustered by month of year). SVG-based. Requires a SVG plug-in. | 
| Dial - Sweep | Also known as an angular gauge, this chart shows either percentage of maximum value or absolute value compared to a maximum value represented as a solid area. SVG-based. Requires a SVG plug-in. | 
| Dial | Also known as angular gauge, this chart shows either percentage of maximum value or absolute value compared to maximum value represented as a line. SVG-based. Requires a SVG plug-in. | 
| Line | Multiple series based line chart oriented with each line representing all data points in the series. SVG-based. Requires a SVG plug-in. | 
| Pie | Single series based pie chart with each slice representing a data point in the series. SVG-based. Requires a SVG plug-in. | 
| Stacked Bar, Horizontal | Multiple series based bar chart oriented horizontally with each data point being an absolute value in series representing a segment of a single bar. SVG-based. Requires a SVG plug-in. | 
| Stacked Bar, Vertical | Multiple series based bar chart oriented vertically with each data point being an absolute value in series representing a segment of a single bar. SVG-based. Requires a SVG plug-in. | 
| Stacked Percentage Bar, Horizontal | Multiple series based bar chart oriented horizontally with each data point being an percentage of 100% of the series represented by a segment of a single bar. SVG-based. Requires a SVG plug-in. | 
| Stacked Percentage Bar, Vertical | Multiple series based bar chart oriented vertically with each data point being an percentage of 100% of the series represented by a segment of a single bar SVG-based. Requires a SVG plug-in. | 
| Note:Do not change the Type of an existing chart. Instead, delete the existing chart and then re-create it. | 
How you create a chart depends upon whether you are adding the chart to an existing page, or adding a chart on a new page.
To add a chart to an existing page:
Navigate to the Page Definition.
Under Regions, click the Create icon.
The Create Region Wizard appears.
Select Chart.
Select the type of chart you wish to create. (See Table 8-4.)
Follow the on-screen instructions.
To create a chart on a new page:
Navigate to the Workspace home page.
From the Applications list, select an application.
Click Create Page.
When prompted for the type of page to create, select Page with Component.
Select the component type Chart.
Select the type of chart you wish to create. (See Table 8-4.)
Follow the on-screen instructions.
Once you have created a chart you can alter its display by editing chart attributes on the chart attributes page.
To access the Chart Attributes page:
Navigate to the Page Definition.
Under Regions, click Chart next to the name of the chart region you wish to edit.
The Chart Attributes page appears.
Note that removing the chart title (that is, the Chart Title attribute) may negatively impact the location and display of the chart legend.
When you create a new chart, Oracle HTML DB renders it based on cascading style sheet (CSS) classes associated with the current theme. You can change the appearance of a chart by referencing another CSS or by overriding individual classes in the CSS section of the Edit Attributes page
The following sample contains the CSS classes for the dial chart in Sample Application. This example contains all the available CSS classes. Class names appear in boldface.
text{font-family:Verdana, Geneva, Arial, Helvetica, sans-serif;fill:#000000;} tspan{font-family:Verdana, Geneva, Arial, Helvetica, sans-serif;fill:#000000;} text.title{font-weight:bold;font-size:14;fill:#000000;} text.moredatafound{font-size:12;} rect.legend{fill:#EEEEEE;stroke:#000000;stroke-width:1;} text.legend{font-size:10;} #background{fill:#FFFFFF;stroke:none;} rect.chartholderbackground{fill:#ffffff;stroke:#000000;stroke-width:1;} #timestamp{text-anchor:start;font-size:9;} text.tic{stroke:none;fill:#000000;font-size:12} line.tic{stroke:#000000;stroke-width:1px;fill:none;} #dial{stroke:#336699;stroke-width:2px;fill:#336699;fill-opacity:.5;} #dial.alert{fill:#FF0000;fill-opacity:.5;} #dialbackground{stroke:#000000;stroke-width:none;fill:none;filter:url(#MyFilter);} #dialcenter{stroke:none;fill:#111111;filter:url(#MyFilter);} #dialbackground-border{stroke:#DDDDDD;stroke-width:2px;fill:none;filter:url (#MyFilter);}#low{stroke-width:3;stroke:#336699;} #high{stroke-width:3;stroke:#FF0000;} #XAxisTitle{letter-spacing:2;kerning:auto;font-size:14;fill:#000000;text-anchor:middle;} #YAxisTitle{letter-spacing:2;kerning:auto;font-size:14;fill:#000000;text-anchor:middle;writing-mode:tb;} .XAxisValue{font-size:8;fill:#000000;} .YAxisValue{font-size:8;fill:#000000;text-anchor:end;} .nodatafound{stroke:#000000;stroke-width:1;font-size:12;} .AxisLine{stroke:#000000;stroke-width:2;fill:#FFFFFF;} .GridLine{stroke:#000000;stroke-width:0.3;stroke-dasharray:2,4;fill:none;} g.dataholder rect{stroke:#000000;stroke-width:0.5;} .legenditem rect{stroke:#000000;stroke-width:0.5;}
Table 8-5 describes all supported CSS class. Note that certain classes only apply to specific chart types.
Table 8-5 Available Chart CSS Classes
| Class | Description | 
|---|---|
| text | Defines the appearance of text that displays in a chart. | 
| tspan | Defines the appearance of text that displays in a chart. tspanshould match the definition oftext. | 
| text.title | Overrides the default chart text. Use this class for title text. | 
| text.moredatafound | Defines the appearance of more datafound text. | 
| rect.legend | Creates the rectangular box that holds the chart legend. For a remove the legend border, change  
rect.legend{fill:#CCCC99;stroke:none;} 
 | 
| text.legend | Defines the text that appears in the chart legend. | 
| #background | Creates the entire background for the SVG plug-in. For a solid white background with no border, change  
#background{fill:#FFFFFF;stroke:#FFFFFF;stroke-width:2;}
 | 
| rect.chartholderbackground | (Not applicable to pie and dial charts.) Creates the background of the rectangle that holds the chart data. For a clear background, change  rect.chartholderbackground(display:none;) | 
| #timestamp | Only applicable if the Asynchronous Update chart attribute is set to Yes. Controls the appearance of the update timestamp test. To disable the display of the timestamp, use defines  
"#timestamp{display:none;}" 
See Also: "Enabling Asynchronous Updates" | 
| text.tic | (Dial charts only.) Defines the numbers on a dial chart. | 
| line.tic | (Dial charts only.) Defines the graduation mark that displays directly beneath the number on a dial chart. | 
| #dial | (Dial charts only.) Defines the value that displays on the dial chart. | 
| #dial.alert | (Dial charts only.) Defines a value (called an alert value) that renders on in a dial chart using a different display. | 
| #dialbackground | (Dial charts only.) Creates the background of a dial chart. | 
| #dialcenter | (Dial charts only.) Creates the center of the dial on a dial chart. | 
| #dialbackground-border | (Dial charts only.) Works in conjunction with #dialbackgroundto create specific graphic effect. | 
| #low | (Dial charts only.) Defines a historical low watermark of the data being displayed on a chart. | 
| #high | (Dial charts only.) Defines historical high watermark of the data being displayed on a chart. | 
| #XAxisTitle | Defines the title that appears on the X axis | 
| #YAxisTitle | Defines the title that appears on the Y axis. | 
| .XAxisValue | Defines the value that appears on the X axis. | 
| .YAxisValue | Defines the value that appears on the Y axis. | 
| .AxisLabel | Similar to axis value. | 
| .nodatafound | Defines the text element that displays if no information is available. | 
| .AxisLine | Indicates zero on charts that have negative values. | 
| . GridLine | Creates the horizontal and vertical lines on the chart. | 
| g.dataholder rect | Applies a blanket style to all data that displays in the chart. | 
| .legenditem rect | Applies a blanket style to all rectangular items in the legend. | 
You can reference a custom cascading style sheet for a chart using the CSS section of the Chart Attributes page. When you reference an external CSS, you can reference it entirely or simply override specific styles.
To reference a custom chart CSS:
Upload the CSS to Oracle HTML DB. (See "Uploading Cascading Style Sheets").
Create a chart. (See "Creating a New Chart".)
Navigate to the Page Definition.
Under Regions, click Chart next to the region name.
The Chart Attributes page appears.
Scroll down to the CSS section.
From Use Custom CSS, select Yes.
To reference an external CSS exclusively:
In Custom CSS, Link enter a link to a custom CSS. For example:
#IMAGE_PREFIX#themes/theme_4/svg.css
Specify that the CSS should be used exclusively. In Custom CSS, Inline enter the following:
/**/
To reference a custom CSS and override specific styles:
In Custom CSS, Link enter a link to a custom style sheet. For example:
#IMAGE_PREFIX#themes/theme_4/svg.css
In Custom CSS, Inline, enter the custom CSS styles you want to override.
You can override specific styles within the default CSS, using the Custom CSS, Inline attribute on the Chart Attributes page.
To override specific styles within the default CSS:
Create a chart. (See "Creating a New Chart".)
Navigate to the Page Definition.
Under Regions, click Chart next to the region name.
The Chart Attributes page appears.
Scroll down to CSS.
From Use Custom CSS, select Yes.
In Custom CSS, Inline, enter the custom CSS styles you want to override.
You can create charts that monitor information by enabling the Asynchronous Update attribute on the Chart attributes page. Enabling this attribute updates the chart to reflect changes in the underlying data within a specified time interval.
To enable asynchronous updates:
Create a chart. (See Creating a New Chart.)
Navigate to the Page Definition.
Under Regions, click Chart next to the region name.
The Chart Attributes page appears.
Scroll down to Refresh.
From Asynchronous Update, select Yes.
In Update Interval (Seconds), enter the interval in seconds between chart updates. For optimal performance, select an interval that is greater than 2 seconds.
When Asynchronous Update is enabled, a timestamp displays on the chart indicating that last update.
To disable the Asynchronous Update timestamp:
Navigate to the Chart Attributes page.
Locate the CSS section.
From Use Custom CSS, select Yes.
In Custom CSS, Inline edit #timestamp as follows:
#timestamp{display:none;}
To display a chart in another language, you edit the text and tspan classes to reflect the correct language.
To display a chart in another language:
Navigate to the Chart Attributes page. (See Editing Chart Attributes.)
Scroll down to CSS.
From Use Custom CSS, select Yes.
In Custom CSS, Inline, edit the text and tspan classes to reflect the correct language. The following example demonstrates how to change a chart to Korean:
text{font-family:Batang;fill:#000000;}
tspan{font-family:Batang;fill:#000000;}
As you design your application you can use buttons to direct users to a specific page or URL, or to post or process information (for example, by creating Create, Cancel, Next, Previous, or Delete buttons).
Buttons can perform two different types of actions. A button can submit the page and then redirect to a URL. Alternately, a button can simply branch to a URL without submitting the page.
Topics in this section include:
You create a button by running the Create Button Wizard from the Page Definition. Each button resides in a region. A region is a area on a page that serves as a container for content.
To create a new button:
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
If necessary, create an HTML region. (See "Customizing Regions".)
Under Buttons, click the Create icon.
The Create Button Wizard appears.
Select a region to contain the button.
Select a position for the button:
Create a button displayed among this region's items
Create a button in a region position
Select Create a button displayed among this region's items to add a button to a region as if it was an item (for example, to add a button directly to the right of a form field).
If you select Create a button in a region position:
Specify the Button Name and Label.
Select a Button Type: HTML Button (Default), Image, or Template Driven
Select Button is Reset to create an Undo button. When enabled, this type of button resets the page values to the state they were in when the page was initially rendered.
Select an Action.
Selecting Submit page and redirect to URL submits the current page to the HTML DB engine whenever a user clicks the button.
Selecting Redirect to URL without submitting page avoids submitting the page. Choose this action when submitting the page for processing is not necessary (for example, a Cancel button). This action avoids processing in the database and therefore reduces the load.
If you select Create a button displayed among this region's items:
Specify the Button Name and Sequence.
Specify whether the button displays at the beginning of a new line or new field.
Specify a Label.
Enter the value of Request.
Select the Button Style.
Follow the on-screen instructions
Buttons can be placed in predefined region template position or among items in a form. To create an HTML button, select one of the following while running the Create Button Wizard:
Under Task, select Create a button in a region position
Under Button Type, select a button type and then HTML Button (default)
You can create multiple buttons within the same region at once using the Create Multiple Buttons Wizard.
To create multiple buttons at once:
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
If necessary, create an HTML region. (See "Customizing Regions".)
Under Buttons, click the Create icon.
The Create Button Wizard appears.
From the Tasks list, select Create Multiple Buttons.
The Create Multiple Button Wizard appears.
From Place Buttons in Region, select the region to contain the buttons.
From Template, select a template.
In HTML Attributes, Specify HTML attributes for these buttons. This text will be added to the HTML element definition. For example, you could set the class of a text button as follows:
class="myclass"
To quickly populate the remaining fields, select make a selection from the Quick Button list on the right side of the page.
Click Create Buttons.
The name you give a button determines the value of the built-in attribute REQUEST. You can reference the value of REQUEST from within PL/SQL using the bind variable :REQUEST. By using this bind variable, you can conditionally process, validate, or branch based on which button the user clicks. You can also create processes that execute when the user clicks a button. You can also use a more complex condition as demonstrated in the following examples:
If :REQUEST in ('EDIT','DELETE') then ...
If :REQUEST != 'DELETE' then ...
These examples assume the existence of buttons named EDIT and DELETE. You can also use this syntax in PL/SQL Expression conditions. Be aware, however, that the button name case is preserved. In other words, if you name a button "LOGIN" then a request looking for the name "Login" will fail. For example:
<input type="BUTTON" value="Finish" onClick="javascript:doSubmit('Finish');">
Note that in this example Finish is the name of the REQUEST and this example is case-sensitive.
Each page can include any number of branches. A branch links to another page in your application or to a URL. The HTML DB engine considers branching at different times during page processing. You can choose to branch before processing, before computation, before validation, and after processing. Like any other control in Application Builder, branching can be conditional. For example, you can branch when a user clicks a button. When you create a branch, you associate it with a specific button. The branch will only be considered if a user clicks the button.
You can choose to have a button display conditionally by editing attributes on the Edit Pages Button page.
To have a button display conditionally:
Create the button. (See "Creating a Button Using a Wizard".)
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
Under Buttons, select the button name.
The attributes page for the button appears.
Scroll down to Conditional Button Display.
Make a selection from the Condition Type list.
Enter an expression in the fields provided.
Click Apply Changes.
An item is part of an HTML form. An item can be a text field, text area, password, combobox, check box, and so on. Item attributes affect the display of items on a page. For example, these attributes can impact where a label displays, how large an item will be, and whether the item will display next to or below the previous item.
There are two types of items, page items and application items. Page items are placed on a page and have associated user interface properties, such as Display As, Label and Label Template. Application items are not associated with a page and therefore have no user interface properties. You can use an application item as a global variable.
Topics in this section include:
You create a page level item by running the Create Item Wizard from the Page Definition.
To create a new page level item:
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
If necessary, create an HTML region. (See "Customizing Regions".)
Under Items, click the Create icon.
Select an item type. (See "About Item Types".)
Follow the on-screen instructions
When specifying an item name, remember the following rules. Item names must:
Not use quotes
Begin with a letter or a numeral, and subsequent characters can be letters, numerals, or underscore characters
Be case insensitive
Should not exceed 30 characters
Cannot contain letters outside the base ASCII character set
When you create an item, you specify an item type. Once you create an item, these types appear on the Display As list on the Edit Page Item page. Table 8-6 describes available item types.
Table 8-6 Available Item Types
| Item Type | Description | 
|---|---|
| Button | Used to build forms in Oracle HTML DB. Use an Item Button when you want to place a button among other fields (or items) in a form. When clicked, this type of button will automatically switch the HTML DB engine to processing mode, enabling you to perform validations, execute processes, or branch the user to another page. | 
| Display Only | Oracle HTML DB uses HTML tables to render items. Use this item to control the layout of items in forms by closing a table and starting a new one. | 
| Check box | Displayed using a list of values. A list of values is required for items displayed as check boxes. The value corresponding to a checked box is returned in a single colon (:) delimited string. The following example demonstrates how to create a single check box that returns  SELECT NULL display_text, 'YES' return_value FROM DUAL; This example includes the additional text "Click to select." SELECT 'Click to select' display_text, 'YES' return_value FROM DUAL; See Also: "HTMLDB_UTIL" for information on breaking up returned values | 
| Date Picker | Displays a text field with a Calendar icon next to it. When clicked, this icon displays a small calendar from which the user can select a date and a time (optional). If the format you need is not included in the Display As list, select Date Picker (use application format mask). When using a format mask, your application looks for the format in an item called  | 
| File Browse | Displays a text field with a "Browse..." button. This enables the user to locate a file on a local file system and upload it. Oracle HTML DB provides a table for these files to be uploaded to as well as an API to retrieve the files. | 
| Hidden | Renders an HTML hidden form element. Session state can be assigned and referenced just like a text field. | 
| List Managers | Based on a list of values. This item enables you to manage a list of items by selecting and adding to a list. The list of values display as a popup. | 
| Multiple Select | Renders as a multiselect HTML form element. When submitted, selected values are returned in a single colon delimited string. You can break up the values using the HTMLDB_UTIL API.See Also: "HTMLDB_UTIL" | 
| Password | Renders as an HTML password form element. | 
| Popup List of Values | Renders as a text field with an icon next to it from which a user can select a value from a popup window. The list in the popup window is driven by a list of values. There are two types of Popup LOVs, one that fetches a set of rows when the window pops up and one that does not. Popup LOV values must select two columns. For example: SELECT ename, empno FROM emp If one of the columns is an expression, remember to use an alias. For example: SELECT ename||' '||job display_value, empno FROM emp | 
| Radio | Renders as an HTML radio group form element, based on a list of values. Choose Radiogroup with Submit to have the page submitted when the radio button is selected. The following example displays employee names ( SELECT ename, empno FROM emp | 
| Select List | Displays using a list of values. A list of values is required for items displayed as a select list. Select lists are rendered using the HTML form element <select>. The values in a select list are determined using a named list of values or a list of values defined at the item level. You may specify the NULL display value and NULL return value.The following example would return employee names ( SELECT ename display_text, empno return_value FROM emp Oracle HTML DB provides additional enhancements to a standard HTML select list: 
 | 
| Text | Displays as an HTML text field containing a maximum of 30,000 bytes of text. You control the maximum length and display width by editing the Height and Width item attribute. | 
| Text Area | Renders as an HTML text area. This is no maximum length for an item displayed as a text area. You control the height and width by editing the Height and Width item attribute. Additional available Text Area Display As options include: 
 | 
| Text | Available Text Control display options include: 
 | 
You can reference item values stored in session state in regions, computations, processes, validation, and branches. Table 8-7 describes the supported syntax for referencing item values.
Table 8-7 Syntax for Referencing Item Values
| Type | Syntax | Description | 
|---|---|---|
| SQL | :MY_ITEM | Standard bind variable syntax for items no longer than 30 bytes. Use this syntax for references within a SQL query and within PL/SQL. | 
| PL/SQL | V('MY_ITEM') | PL/SQL syntax referencing the item value using the Vfunction.See Also: "Oracle HTML DB APIs" | 
| PL/SQL | NV('MY_NUMERIC_ITEM') | Standard PL/SQL syntax referencing the numeric item value using the NVfunction.See Also: "Oracle HTML DB APIs" | 
| Static Text | &MY_ITEM | Static text. | 
| Static Text (exact) | &MY_ITEM. | Static text. Exact Substitution. | 
You can set the value of an item in your application using any of the following methods:
For page items, use the Source Attribute to set the item value.
From the Page Definition, select the item name to view the Edit Page Item page. Scroll down to Source and edit the appropriate fields.
You can also set the value of an item in any region based on PL/SQL or a process using the following syntax:
BEGIN :MY_ITEM := 'new value'; END;
Pass the value on a URL reference using f?p syntax. For example:
f?p=100:101:10636547268728380919::NO::MY_ITEM:ABC
Set the value using a computation. Computations are designed to set item values. For example:
TO_CHAR(SYSDATE,'Day DD Month, YYYY');
Use the PL/SQL API to set an item value within a PL/SQL context. For example:
HTMLDB_UTIL.SET_SESSION_STATE('MY_ITEM',SYSDATE);
You can choose to have an item display conditionally or as read-only by editing attributes on the Edit Pages Item page.
To display a conditional or read-only item:
Create the item. (See "Creating a Page Level Item".)
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
Under Items, select the item name.
The attributes page for the item appears.
To display an item conditionally:
Scroll down to Conditional Display.
Make a selection from the Condition Type list.
Enter an expression in the fields provided.
To make an item read-only:
Scroll down to Read Only Display Settings.
Make a selection from the Read Only Condition Type list.
Enter an expression in the fields provided.
Click Apply Changes.
Application level items do not display, but are used as global variables to the application. To reference an application level item you must set a value by using an ON_NEW_INSTANCE computation.
To create a new application level item:
Navigate to the Workspace home page.
From the Applications list, select an application name.
When Application Builder appears, click Shared Components.
Under Logic, select Items.
The Application Items page appears.
To create a new application item, click the Create icon.
Follow the on-screen instructions.
If you need to create a Date Picker item, but the format you need does not appear in the Display As list, you should select Date Picker (use application format mask). When an application uses this type of date picker, the HTML DB engine derives the date format from an item named PICK_DATE_FORMAT_MASK. You can populate this item in two ways:
By defining an application substitution string named PICK_DATE_FORMAT_MASK
By creating an application level item named PICK_DATE_FORMAT_MASK
One approach to populating PICK_DATE_FORMAT_MASK is to create an application substitution string. You define application level substitution strings on the Edit Application Attributes page. Remember that an application level substitution string is a static value and cannot be altered at runtime.
To define a new application substitution string named PICK_DATE_FORMAT_MASK:
Navigate to the Workspace home page.
From the Applications list, select an application.
Application Builder appears.
Click the Edit Attributes icon.
Scroll down to Static Substitution Strings.
Create a new static substitution string named PICK_DATE_FORMAT_MASK:
In Substitution String, enter the name PICK_DATE_FORMAT_MASK.
In Substitution Value, enter a value for your for your date format (for example, Month DD, YYYY).
Another approach to populating PICK_DATE_FORMAT_MASK is to create an application level item named PICK_DATE_FORMAT_MASK. This approach enables you to control any items rendered as Date Picker (use application format mask) by simply setting the value of this item. Plus, you can set the value of PICK_DATE_FORMAT_MASK using a computation from anywhere within your application.
If you wish to provide the user with a list of date formats as preferences, you will need to create an application level item named PICK_DATE_FORMAT_MASK and then use a computation to set the value of this item based upon the user's selection.
A list of values (LOV) is a static or dynamic definition used to display a specific type of page item, such as popup lists of values, a select list, a check box, a radio group, or multiple select lists.
Topics in this section include:
You define named (or shared) LOVs at the application level by running the Create LOV Wizard and adding them to the Named List of Values repository. All LOVs can be defined as static or dynamic. Static lists are based on predefined pairs of display and return values. Dynamic lists are based on a SQL query you write that selects values from a table.
To create a named LOV:
Navigate to the Workspace home page.
From the Applications list, select an application name.
When Application Builder appears, click Shared Components.
Under User Interface, select Lists of Values.
To create a new LOV, click the Create icon.
Follow the on-screen instructions.
New named LOVs are added to the Named List of Values repository.
Static LOVs are based on a static list of display and return values you specify when you run the Create LOV Wizard. To create a static LOV you run the Create LOV Wizard and select the LOV type Static. Oracle HTML DB stores the display values, return values, and sort sequence you specify in the Named List of Values repository. Once you add a static LOV to the repository you can create an item and display it as a check box, radio group, select list, or popup list based on this definition.
Using a popup LOV is a good choice for lists of values that are too large to return on a single page. Popup LOVs create an icon to the right of a standard text field. When the user clicks this icon, a popup window appears with a list of values represented as a series of links. When the user selects from this searchable list, the selected value will be placed in the text field. You control popup LOVs through templates. You can only specify one popup LOV template for each application.
Popup LOVs must be based on a query that selects two columns with different column aliases. For example:
SELECT ename name, empno id FROM emp
You can reference session state by using bind variables. In the following example, this LOV only works if the item called my_deptno contains a valid department number.
SELECT ename, empno FROM emp WHERE deptno = :my_deptno
Application Builder includes a number of reports designed to help you better manage LOVs, including:
To access LOV reports:
Navigate to the Workspace home page.
From the Applications list, select an application name.
When Application Builder appears, click Shared Components.
Under User Interface, select Lists of Values.
Select one of the following buttons at the top of the page:
Edit all lists of values entries
Subscription
Utilization
History
Follow the on-screen instructions.
Click Edit all lists of values entries to display the Bulk Update LOV Data Values page. Use this page to edit the display values of all static LOVs at once. To save your changes, click Apply Changes. To search for a specific name, enter keywords at the top of the page and click Go.
Click Subscription to display the Subscribed LOVs page. This page displays all subscribed LOVs in your application.
Click Utilization to display the LOV Utilization page. This page displays LOVs used in the current application. To edit an LOV, click the LOV name.
Oracle HTML DB includes a built-in wizard for generating a calendar. Once you specify the table on which the calendar is based you can create drill down links to information stored in specific columns.
Topics in this section include:
Oracle HTML DB supports two calendar types:
Easy Calendar creates a calendar based on schema, table, and columns you specify. The wizard prompts you to select a date column and display column.
SQL Calendar creates a calendar based on a SQL query you provide. The SQL SELECT statement you provide must include at least two columns, a date column and display column.
The date column determines which days on the calendar will contain entries. The display column defines a specific row that will display a calendar date.
Oracle HTML DB supports a number of date format substitution strings. You can view a complete list of supported substitution strings on the Calendar Templates page.
To view a list of supported substitution strings for calendars:
Navigate to the appropriate calendar template.
Expand the Substitution Stings list on the right side of the page.
How you create a calendar depends upon whether you are adding a calendar to an existing page, or adding a calendar on a new page.
To add a calendar to an existing page:
Navigate to the Page Definition.
Under Regions, click the Create icon.
Select Calendar.
Select the type of calendar you wish to create:
Easy Calendar creates a calendar based on the date column and display column you specify.
SQL Calendar creates a calendar based on a SQL query you provide.
Follow the on-screen instructions.
To create a calendar on a new page:
Navigate to the Workspace home page.
From the Applications list, select an application.
Click Create Page.
When prompted for the type of page to create, select Page with Component.
Select the component type Calendar.
Select the type of calendar you wish to create:
Easy Calendar creates a calendar based on the date column and display column you specify.
SQL Calendar creates a calendar based on a SQL query you provide.
Follow the on-screen instructions.
Creating an Easy Calendar is the simplest way to create a calendar in Oracle HTML DB. However, if you find the resulting calendar does not meet your needs, you can quickly convert it to SQL Calendar.
To convert an Easy Calendar to a SQL Calendar:
Navigate to the Page Definition.
Under Regions, click CAL next to the region name.
The Calendar Attributes page appears.
From the Tasks list, select Convert to SQL Based calendar.
Converting an Easy Calendar to a SQL Calendar, adds a Region Source section to the Region Definition. The Region Source contains the original SQL query that creates the calendar. By having accessing the Region Source, you can easily edit the query to meet your needs.
The title that appears at the top of calendar corresponds to the region title.
To alter the region title:
Navigate to the Page Definition.
Under Regions, select the region name.
The Region Definition appears.
Under Region, enter a new title.
Click Apply Changes.
Once you have created a calendar you can alter how it appears by editing its attributes.
Topics in this section include:
To access the Calendar Attributes page:
Navigate to the appropriate Page Definition. (See "Viewing a Page Definition".)
Under Regions, click CAL next to the region name.
The Calendar Attributes page appears. The topics that follow describe the specific sections of the Calendar Attributes page.
Use Calendar Display to specify a calendar template, date columns, and general calendar formatting.
Calendar Template determines what template is used when the HTML DB engine renders a calendar. Date Column defines the column from the table or query containing the dates to be placed on the calendar. Display Column defines a specific row that displays on a calendar date.
To select another Display Column:
Navigate to the appropriate Calendar Attributes page.
Locate the Calendar Display section.
To specify another display column, make a selection from the Display Column list.
Click Apply Changes.
To specify a custom Display Column:
Navigate to the appropriate Calendar Attributes page.
Locate the Calendar Display section.
From Display Type, select Custom.
In Column Format enter a custom column format. You can use an HTML expression and supported substitution strings.
Click Apply Changes.
Use Calendar Interval to define the dates which are included in the calendar.
Begin At Start Of Interval determines when the calendar should start. Selecting this option creates a calendar that spans an entire interval (for example, a month). For example:
If Begin at start of interval is selected, the date is June 15th, and the display is monthly, the resulting calendar spans from June 1st to June 30th.
If Begin at start of interval is not selected, the date is June 15th, and the display is monthly, the resulting calendar spans from June 15th to June 30th.
Date Item holds the date on which the calendar is based.
The next two attributes define which items hold the calendar start date and end date. You can use these attributes to create calendars that span multiple months at a time. Item Containing Start Date points to an item that holds the start date of the calendar. Item Containing End Date points to an item that holds the end date of calendar. Note that format of the date of either item must be YYYMMDD.
Start of Week determines the day of the week on which the calendar starts.
Use Column link to create a link on the column in the calendar.
To create a column link to another page:
Navigate to the appropriate Calendar Attributes page.
Scroll down to Column Link.
From Target is a, select Page in this Application.
In Page, specify the target page number. To reset pagination for this page, select reset pagination for this page.
In Request, specify the request to be used.
In Clear Cache, specify the pages (that is, the page numbers) on which to clear cache. Specify multiple pages by listing the page numbers in a comma delimited list.
You can set session state (that is, give a listed item a value) using the next two attributes:
To set session state:
Set these items - Enter a comma delimited list of item names for which you would like to set session state.
With these values - Enter a comma delimited list of values for the items specified in the previous step.
You can specify static values or substitution syntax (for example, &APP_ITEM_NAME.). Note that item values passed to f?p= in the URL may not contain a colon (:). Additionally, item values may not contain commas unless you enclose the entire value in backslash characters (for example, \1234,56\).
Click Apply Changes.
To create a column link to a URL:
Navigate to the appropriate Calendar Attributes page.
Scroll down to Column Link.
From Target is a, select URL.
In URL, enter the appropriate address.
Click Apply Changes.
Use Day link to create link on a day in the calendar. This attribute creates a link on an actual numeral (or day) on the calendar.
To create a day link to another page:
Navigate to the appropriate Calendar Attributes page.
Scroll down to Day Link.
From Target is a, select Page in this Application.
In Page, specify the target page number.
To reset pagination for this page, select reset pagination for this page.
In Request, specify the request to be used.
In Clear Cache, specify the pages (that is, the page numbers) on which to clear cache. Specify multiple pages by listing the page numbers in a comma delimited list.
You can set session state (that is, give a listed item a value) using the next two attributes:
To set session state:
Set these items - Enter a comma delimited list of item names for which you would like to set session state.
With these values - Enter a comma delimited list of values for the items specified in the previous step.
You can specify static values or substitution syntax (for example, &APP_ITEM_NAME.). Note that item values passed to f?p= in the URL may not contain a colon (:). Additionally, item values may not contain commas unless you enclose the entire value in backslash characters (for example, \1234,56\).
Click Apply Changes.
To create a day link to a URL:
Navigate to the appropriate Calendar Attributes page.
Scroll down to Day Link.
From Target is a, select URL.
In URL, enter the appropriate address.
Click Apply Changes.
By using shortcuts you can avoid repetitive coding of HTML or PL/SQL functions. You can use a shortcut to define a page control such as a button, HTML text, a PL/SQL procedure, or HTML. Once defined, you can invoke a shortcut using specific syntax unique to the location in which the shortcut is used. Shortcuts can be referenced many times, thus reducing code redundancy.
This section contains the following topics:
When you create a new shortcut, you must specify the type of shortcut you wish to create. Oracle HTML DB supports the following shortcut types:
Use this type of shortcut to reference a shortcut inside of a JavaScript literal string. This shortcut defines a text string. When the shortcut is referenced, it escapes the single quotes required for JavaScript.
Use this type of shortcut to reference a translatable message at runtime. Note that since this shortcut does not have a shortcut body, the name of the shortcut must match the corresponding message name. At runtime, the name of the shortcut expands to the text of the translatable message for the current language.
Before you can incorporate a shortcut in your application, you must define it and add it to the Shortcuts repository. You reference new shortcuts using the following syntax:
"MY_SHORTCUT"
Note that the shortcut name must be capitalized and enclosed in quotes.
To define a new shortcut:
Navigate to the Workspace home page.
From the Applications list, select an application name.
When Application Builder appears, click Shared Components.
Under User Interface, select Shortcuts.
Click Create.
Select one of the following creation methods:
From Scratch
As a Copy of an Existing Shortcut
Follow the on-screen instructions.
New shortcuts are added to the Shortcut repository and are available for use within the following locations:
The Region Source attribute of regions defined as HTML Text (with shortcuts). (See "Customizing Regions".)
Region Header and Footer Text attribute (See "Specifying a Region Header and Footer".)
Item Label attributes and Item Default Value attribute. (See "Items".)
Region Templates attributes. (See "Editing Templates".)
Application Builder includes a number of reports designed to help you better manage LOVs, including:
To access of report detailing recent shortcut changes:
Navigate to the Workspace home page.
From the Applications list, select an application name.
When Application Builder appears, click Shared Components.
Under User Interface, select Shortcuts.
Click Create.
Follow the on-screen instructions.
Click Subscription to display the Subscribed Shortcuts page. This page displays all subscribed shortcuts in your application.
Adding JavaScript to a Web applications is a great way to add features that mimic those found client/server applications without sacrificing all of the benefits of Web deployment. Oracle HTML DB includes multiple built-in interfaces (or "hooks") especially designed for adding JavaScript.
Remember that JavaScript is not appropriate for data intensive validations. For example, to verify that a name is contained within a large database table, you would need to pull down every record to the client, creating a huge HTML document. In general, complex operations are much better suited for server-side HTML DB validations instead of JavaScript.
This section contains the following topics:
When you reference an item, the best approach is to reference by ID. If you view the HTML source of an Oracle HTML DB page in a Web browser, you would notice that all items have an ID attribute. This ID corresponds to name of the item, not the item label. For example, if you create an item with the name P1_FIRST_NAME and a label of First Name, the ID will be P1_FIRST_NAME.
Knowing the item ID enables you to use the JavaScript function getElementById to get and set item attributes and values. The following example demonstrates how to reference an item by ID and display its value in an alert box.
<script language="JavaScript1.1" type="text/javascript">
  function firstName(){    
    alert('First Name is ' + document.getElementById('P1_FIRST_NAME').value );
  }
 // or a more generic version would be
  function displayValue(id){    
    alert('The Value is ' + document.getElementById(id).value );
  }
</script>
 
  // Then add the following to the "Form Element Attributes" Attribute of the item:
  onChange="javascript:displayValue('P1_FIRST_NAME');"
While it is possible to reference items using the HTML form element attribute name (represented in the previous example as form p_t01), this is strongly discouraged. Remember that the name attribute is dynamic and is determined at when a page is rendered. For example, suppose the first element rendered on a page is p_t01 and the second is p_t02. If you write a function that references p_t01 and then create a new item on the page that appears first, the item that was p_t01 will now be p_t02 and your function will break.
There are two primary places to include JavaScript functions:
In the HTML Header attribute of the page
In a .js file in the page template.
| See Also:"Text with JavaScript Escaped Single Quotes" for information on referencing a shortcut inside of a JavaScript literal string | 
One way to include JavaScript into your application is add it to the HTML Header attribute of the page. This is good approach for functions that are very specific to a page as well as a convenient way to test a function before you include it in the .js file.
You can add JavaScript functions to a page by simply entering the code into the HTML Header attribute of the Page Attributes page. For example, adding following would test function accessible from anywhere on the current page.
<script language="JavaScript1.1" type="text/javascript>
  function test(){
    alert('This is a test.');
  }
</script>
In a .js file in the page template. This is the most efficient approach since a .js file loads on the first page view of your application and is then cached by the browser.
The following demonstrates how to include a .js file in the header section of a page template.
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
    <title>#TITLE#</title>
    #HEAD#
    <script src="#APP_IMAGES#custom.js" type="text/javascript"></script>
</head>
<body #ONLOAD#>#FORM_OPEN#
Calling a JavaScript from a button is a great way to confirm a request. Oracle HTML DB actually uses this technique for the delete operation of most objects. For example, when you delete a button, a JavaScript Alert Box appears asking you to confirm your request. Consider the following example:
<script language="JavaScript1.1" type="text/javascript">
  function deleteConfirm(msg)
  {
var confDel = msg;
if(confDel ==null)
  confDel= confirm("Would you like to perform this delete action?");
else
  confDel= confirm(msg);
  
if (confDel== true)
  doSubmit('Delete');
  }
</script>
This example creates a function to confirm a delete action and then calls that function from a button. Note that the function optionally submits the page and sets the value of the internal variable :REQUEST to Delete, thus performing the delete using a process that conditionally executes based on the value of request.
Note that when you create the button you would need to select Action Redirect to URL without submitting page. Then, you would specify a URL target such as the following:
javascript:confirmDelete('Would you like to perform this delete action?');
You may use a select list to determine the range of values of another select list on the same page. You can achieve this functionality by having a driving select list submit values to a subsequent select list. You incorporate these values in the subsequent select list as a bind variable in the WHERE clause of its query.
You can have one LOV drive another LOV by:
Creating a basic form.
Defining two list of values. Note that the driving LOV must submit the page after a value is chosen.
Defining a branch that branches back to the current page.
Consider the following example. The first LOV enables the user to pick a state.
SELECT state_name d, state_id v FROM states
The second LOV selects the country name and country ID based on the state selected in the first LOV.
SELECT county_name d, county_id v FROM counties WHERE state_id = :Px_STATE_ID
Oracle HTML DB includes built-in attributes to make creating help for your application quick and easy. Creating help for your application involves the following steps:
Create a dedicated help page and help region
Define page help text
Define item help text
Create a navigation bar icon to link to your help page
Help created in Oracle HTML DB displays on a dedicated help page. To access help, users click a link that takes them to a dedicated help page. This help page displays page and item help topics specific to the page they are viewing.
Topics in this section include:
The first step in creating a help for your application it to create a dedicated page and Help Text region.
To create a new Help Text region:
Create new page for your help. (See "Adding Additional Pages".)
Navigate to the Page Definition of your help page. (See "Viewing a Page".)
Under Regions, the Create icon.
When prompted to select a region type, select Help Text.
Follow the on-screen instructions.
You define help text for a page or single item by editing attributes. Ideally, you would define these attributes as you create your application. For simplicity, however, the following procedures describe how to define this text after the fact.
To define page help text:
Navigate to the Page Definition for the page for which you want to add page help. (See "Viewing a Page".)
Click Edit Attributes to view the existing page attributes.
Scroll down to Page Help Text.
Enter your help text in the field provided.
Click Apply Changes.
Repeat the previous procedure for each page requiring page help text.
To define item help text:
Navigate to the Page Definition for the page for which you want to add item help.
Under Items, click name of the item you want to edit.
Scroll down to Help Text.
Enter your help text in the field provided.
Click Apply Change.
Repeat the previous procedure for each item requiring help text.
If you are including item help in your application, you can edit multiple item help topics at once using the Bulk Edit Item Help report.
To view the Bulk Edit Item Help report:
Navigate to the Workspace home page.
Select an application name from the Applications list.
From the Tasks list, select View Application Reports.
Application Reports page appears.
Select Item Help Text.
Under Item Help Text column, make the appropriate edits.
Click Apply Changes.
Once you have created your help, the next step is to create a navigation bar icon so users can link to it.
To create a navigation bar icon:
Navigate to the Page Definition. (See "Viewing a Page".)
Under Navigation Bar, click the Create icon.
Specify the appropriate NavBar entry attributes:
Sequence
Alt Tag Text
Icon Image Name
Image Height and Image Width
Text
Specify the target location.
To specify the target location:
From Target type, select Page in this application.
In Page, specify the page number.
In Request, type:
&APP_PAGE_ID.
By specifying substitution string &APP_PAGE_ID as the Request, you are instructing the HTML DB engine to display help text for the current page when the user clicks this icon.