Changing the default sorting order for a table column in the IBM Sales Center
In this sample you will change the sorting order for a table column in the IBM Sales Center. Changing the sorting order is useful for instance, if you do not want the default sorting sequence (ascending).
The following two attributes in the com.ibm.commerce.telesales.widgets.tableDefinitions widget
need to be customized to change the default sorting sequence for a
table column:
- initialSort
- The initial sort attribute indicates that this column is the column by which the table should initially be sorted. The default value is false. For a table definition, only one or the first column can be selected for initial sort.
- sortingOrder
- The sorting sequence for the column to be initially sorted. The argument must be either ASC (acsending) or DESC (descending). The default value is ASC for ascending order. This sorting preference is applicable only when the initialSort attribute is set to true for a particular column.
Create a new plugin in the IBM Sales Center development environment
In this section, you will create a new plugin in the IBM Sales Center development environment to contain your new code. Alternatively, you can download the completed plugin and import it into your IBM Sales Center development environment.
To
create a new plugin in the development environment:
- Open the IBM Sales Center development environment.
- Create a new plugin called changeSortingOrder.
- In the plugin, leave the default dependencies and add the com.ibm.commerce.telesales.config
as a new dependency. The plugin must contain the following dependencies:
- org.eclipse.ui
- org.eclipse.core.runtime
- com.ibm.commerce.telesales.config
- Add an extension to the com.ibm.commerce.telesales.configurator
plugin. You can use the plugin editor interface, or edit the plugin.xml
file directly. The resulting code should look similar to the following:
<extension point="com.ibm.commerce.telesales.configurator"> <configurator path="config" /> </extension>
- In the changeSortingOrder plugin project, navigate to the plugin.xml and open the file.
- Add an extension to com.ibm.commerce.telesales.widgets.tableDefinitions
and define a new table definition by referring to the existing one
as shown in the following example.
<extension point="com.ibm.commerce.telesales.widgets.tableDefinitions"> <tableDefinition id="mycustomerOrdersSearchResultsTableDefinition"> <column referenceId="com.ibm.commerce.telesales.ui.impl.findOrderIdTableColumn" initialSort="true" sortingOrder="DESC" /> <column referenceId="com.ibm.commerce.telesales.ui.impl.findOrderDatePlacedTableColumn" /> <column referenceId="com.ibm.commerce.telesales.ui.impl.findOrderStatusTableColumn" /> <column referenceId="com.ibm.commerce.telesales.ui.impl.findOrderTotalTableColumn" /> </tableDefinition > </extension >
- Define the following entry in the system configuration
file to replace the old table definition with the new one:
com.ibm.commerce.telesales.ui.impl.customerOrdersSearchResultsTableDefinition=test.mycustomerOrdersSearchResultsTableDefinition
Test your changes
To test your changes:
- Launch the IBM Sales Center; then connect to your WebSphere Commerce Server.
- Click .
- From the Configurations list, select Sales Center.
- In the Arguments tab, select Clear workspace data before launching.
- Click Run.
- When asked if you really want to clear the workspace data, click Yes.
- When the IBM Sales Center client opens, click .
- Click
- Select .
- Enter the search criteria and select one of the stores from the list.
- Select .
- Enter search criteria and select one of the customers. Note: You can choose either create customer or find customer. In both the cases, make sure there are orders created for that customer before performing the next steps.
- Go to the Orders tab of the Customer editor. Order entries are listed in table in descending sequence by the order ID.