APEX 24.1 Selectable Template Components

APEX 24.1 Selectable Template Components

ยท

4 min read

Introduction

A common pattern in application development is allowing users to select one or more records and then perform some action based on the selection. I previously wrote how to do this with Interactive Grids: APEX Interactive Grid - Processing Selected Records. The solution in that post had a drawback: it involved quite a bit of custom JavaScript.

In APEX 24.1, the APEX development team has made our lives easier by enhancing Template Components to support declarative row selection.

๐Ÿ‘‰
This post will describe this new APEX 24.1 Template Component Row Selection feature.

Example

In this example, users can search for and select one or more customers to send a payment reminder. I have a simple table of customers (CNQB_CUSTOMERS) that have been integrated into APEX from Quickbooks.

Oracle APEX Selectable Template Components

Configuration

Template Component

I created a simple Content Row Template Component based on a table of customers.

Oracle APEX Selectable Template Component 1

Oracle APEX Selectable Template Component 2

Note: For this feature to work, the Display Attribute under Appearance must be set to Multiple (Report).

Identify the Primary Key

We must identify the Primary Key column. APEX will maintain a ':' limited list of Primary Key values for the row(s) the user selects. In this case, the ID column uniquely identifies a record in the result set.

Create Required Page Items

The next step is to create two new page items. The first item is a hidden item used by APEX to store the ':' delimited list of primary key values.

The second item is optional. If included, it must be a 'Checkbox' item type. APEX will use this item to control the Select All / Un-Select All functionality.

Configure Row Selection

  • Type

    • Focus only: This option enables setting the focus to a selected row. No page items are required or populated. It is used to improve accessibility or keyboard navigation.

    • Single-Selection: Enables single-row selection.

    • Multiple Selection: Enables multiple row selection.

  • Current Selection Page Item

    • Reference the page item used to store the selected Primary Key values.
  • Select All Page Item

    • Reference the page item Checkbox to enable the Select / De-Select All functionality.

Using the Selected Primary Keys

As we know, the page item P32_SELECTED_CUSTOMER_ID is being used to capture the selected Primary Key values. If we select several rows and then inspect the page, we can view the ':' delimited list of Primary Key values:

Oracle APEX Template Component Select Records Inspect Page

We can reference the list of Primary Keys using the below SQL:

SELECT * 
FROM   cnqb_customers 
WHERE  id MEMBER OF (SELECT apex_string.split_numbers 
                             (p_str => :P32_SELECTED_CUSTOMER_ID,
                              p_sep => ':') 
                     FROM dual);

Template Component Configuration

A new setting, Has Row Selection Support, controls whether row selection is available when building your own template components (or customizing the out-of-the-box templates).

Oracle APEX Template Component Row Selection

Other Standard Template Components

Medial List

The Media List template component offers a more compact view when selecting from lots of records.

Oracle APEX Media List Template Component Select

Comments

Oracle APEX Comment Template Component Select

Timeline

Oracle APEX Timeline Template Component Select

The standard Badge and Avatar Template Components do not support row selection out of the box. You can add row selection to the badge Template Component by copying the standard Badge Component and including the following DIV in the Partial attribute.

{if ?APEX$SELECTOR%assigned/}<div class="t-ContentRow-selection">#APEX$SELECTOR#</div>{endif/}

Oracle APEX Add Row Selection to a Badge

This results in a very compact selection widget:

Oracle APEX Add Row Selection to Badge Component

My Thoughts

  • This new functionality brings a clean, low-code method for selecting records from a Template Component.

  • When you provide a 'Select All Page Item', APEX displays a 'Load All' link. Clicking this link will fetch all of the records in the query.

  • The new feature maintains selections across pages.

  • Because this feature has been incorporated into Template Components, you have almost complete control over the appearance of your report.

Room for Improvement

While testing this new feature, I found that the Row Selection feature does not maintain selections across pages if:

  • You use an Order By Item and change the sort order of the query.

  • You combine the template component with a Faceted Search or Smart Filter and aff/remove filter criteria.

This prevents you from using this feature for multi-row selects when you have a large data set.

Conclusion

I think this is a nice addition to Template Components. It provides developers with an easy method for allowing users to select one or multiple records from a report that they have complete control over styling.

ย