All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.jwebmp.plugins.datatable.options.DataTableOptions Maven / Gradle / Ivy

There is a newer version: 0.66.0.1
Show newest version
/*
 * Copyright (C) 2017 Marc Magon
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see .
 */
package com.jwebmp.plugins.datatable.options;

import com.fasterxml.jackson.annotation.*;
import com.jwebmp.core.htmlbuilder.css.measurement.MeasurementCSSImpl;
import com.jwebmp.core.htmlbuilder.javascript.JavaScriptPart;
import com.jwebmp.plugins.datatable.DataTablePageConfigurator;
import com.jwebmp.plugins.datatable.DataTableReferencePool;
import com.jwebmp.plugins.datatable.enumerations.DataTablePlugins;
import com.jwebmp.plugins.datatable.enumerations.DataTableThemes;
import com.jwebmp.plugins.datatable.enumerations.DataTablesPagingTypes;
import com.jwebmp.plugins.datatable.options.buttons.DataTablesButtonButtonsOptions;
import com.jwebmp.plugins.datatable.options.responsive.DataTablesResponsiveOptions;

import javax.validation.constraints.NotNull;
import java.util.*;

import static com.fasterxml.jackson.annotation.JsonAutoDetect.Visibility.*;
import static com.fasterxml.jackson.annotation.JsonInclude.Include.*;
import static com.jwebmp.plugins.datatable.enumerations.DataTablePlugins.*;

/**
 * The Options for the Data Table
 * 

* * @author GedMarc * @since 09 May 2015 */ @JsonAutoDetect(fieldVisibility = ANY, getterVisibility = NONE, setterVisibility = NONE) @JsonInclude(NON_NULL) @JsonIgnoreProperties(ignoreUnknown = true) public class DataTableOptions> extends JavaScriptPart { /** * the document object model layout */ @JsonIgnore private List dom; /** * ajaxSince: DataTables 1.10 * Load data for the table's content from an Ajax source. *

* Description * DataTables can obtain the data that it is to display in the table body from a number of sources, including from an Ajax data * source, using this initialisation parameter. As with other dynamic data sources, arrays or objects can be used for the data source * for each row, with columns.data employed to read from specific object properties. *

* The ajax property has three different modes of operation, depending on how it is defined. These are: *

* string - Set the URL from where the data should be loaded from. * object - Define properties for jQuery.ajax. * function - Custom data get function */ private DataTablesAjaxOptions ajax; /** * Data to use as the display data for the table. */ private String data; /** * Feature control DataTables' smart column width handling */ private Boolean autoWidth; /** * Feature control deferred rendering for additional speed of initialization. */ private Boolean deferRender; /** * Feature control table information display field */ private Boolean info; /** * Use markup and classes for the table to be themed by jQuery UI ThemeRoller. *

* In addition to the above control options, there are two constants DataTables understands (note that these two options are * deprecated in 1.10 and will be removed in 1.11 along side the separation of the jQueryUI option into its own theme file): */ private Boolean jQueryUI; /** * Feature control the end user's ability to change the paging display length of the table. */ private Boolean lengthChange; /** * Description * This parameter allows you to readily specify the entries in the length drop down select list that DataTables shows when pagination * is enabled. It can be either: *

* 1D array of integer values which will be used for both the displayed option and the value to use for the display length, or *

* 2D array which will use the first inner array as the page length values and the second inner array as the displayed options. This * is useful for language strings such as 'All'). *

* The page length values must always be integer values>0, with the sole exception of -1. When -1 is used as a value this tells * DataTables to disable pagination (i.e. display all rows). *

* Note that the pageLength property will be automatically set to the first value given in this array, unless pageLength is also * provided. *

* Type * This option can be given in the following type(s): *

* array * Default * [ 10, 25, 50, 100 ] */ private Set lengthMenu; /** * Description * Allows control over whether DataTables should use the top (true) unique cell that is found for a single column, or the bottom * (false - default) to attach the default order listener. This is useful when using complex headers. */ private Boolean orderCellsTop; /** * Description * DataTables highlight the columns which are used to order the content in the table's body by adding a class to the cells in that * column, which in turn has CSS applied to those classes to highlight those cells. *

* This is done by the addition of the classes sorting_1, sorting_2 and sorting_3 to the columns which are currently being ordered on. * The integer value indicates the level of sorting when mutli-column sorting. If more than 3 columns are being ordered upon, the * sorting_3 class is repeated. *

* Please note that this feature can affect performance, particularly in old browsers and when there are a lot of rows to be displayed * as it is manipulating a large number of DOM elements. As such, this option is available as a feature switch to allow this feature * to be disabled with working with old browsers or large data sets. */ private Boolean orderClasses; /** * orderFixedSince: DataTables 1.10 * Ordering to always be applied to the table. *

* Description * The option works in tandem with the order option which provides an initial ordering state for the table which can then be modified * by the user clicking on column headings, while the ordering specified by this option will always be applied to the table, * regardless of user interaction. *

* This fixed ordering can be applied before (pre) or after (post) the user's own ordering criteria using the two different forms of * this option (array or object) described below. *

* The values that are used to describe the ordering conditions for the table are given as two element arrays: *

* Column index to order upon * Direction so order to apply (asc for ascending order or desc for descending order). * It is also possible to give a set of nested arrays (i.e. arrays in arrays) to allow multi-column ordering to be assigned. *

* This option can be useful if you a column (visible or hidden) which must always be sorted upon first - a priority order or index * column for example, or for grouping similar rows together. */ private Boolean orderFixed; /** * orderMultiSince: DataTables 1.10 * Multiple column ordering ability control. *

* Description * When ordering is enabled (ordering), by default DataTables allows users to sort multiple columns by shift clicking upon the header * cell for each column. Although this can be quite useful for users, it can also increase the complexity of the order, potentiality * increasing the processing time of ordering the data. Therefore, this option is provided to allow this shift-click multiple column * ability. *

* Note that disabling this ability does not impede your ability as a developer to do multiple column ordering using columns * .orderData, order or order(), it just disallows the user from performing their own multi-column order. *

* Type * This option can be given in the following type(s): *

* boolean * Default * true */ private Boolean orderMulti; /** * Feature control ordering (sorting) abilities in DataTables. */ private Boolean ordering; /** * pageLengthSince: DataTables 1.10 * Change the initial page length (number of rows per page). *

* Description * Number of rows to display on a single page when using pagination. *

* If lengthChange is feature enabled (it is by default) then the end user will be able to override the value set here to a custom * setting using a pop-up menu (see lengthMenu). *

* Type * This option can be given in the following type(s): *

* integer * Default * Value: 10 */ private Integer pageLength; /** * pagingTypeSince: DataTables 1.10 * Pagination button display options. *

* Description * The pagination option of DataTables will display a pagination control below the table (by default, its position can be changed using * dom and CSS) with buttons that the end user can use to navigate the pages of the table. Which buttons are shown in the pagination * control are defined by the option given here. *

* DataTables has six built-in paging button arrangements: *

* numbers - Page number buttons only (1.10.8) * simple - 'Previous' and 'Next' buttons only * simple_numbers - 'Previous' and 'Next' buttons, plus page numbers * full - 'First', 'Previous', 'Next' and 'Last' buttons * full_numbers - 'First', 'Previous', 'Next' and 'Last' buttons, plus page numbers * first_last_numbers - 'First' and 'Last' buttons, plus page numbers * Further methods can be added using plug-ins. *

* Type * This option can be given in the following type(s): *

* string */ private DataTablesPagingTypes pagingType; /** * Enable or disable table pagination. */ private Boolean paging; /** * Feature control the processing indicator. */ private Boolean processing; /** * rendererSince: DataTables 1.10 * Display component renderer types. *

* Description * DataTables adds some complex components to your HTML page, such as the pagination control. The business logic used to calculate * information should be displayed (what buttons in the case of the pagination buttons) is core to DataTables and generally doesn't * vary how the buttons are actually displayed does based on the styling requirements of the page. For example the pagination buttons * might be displayed as li elements in a ul list, or simply as a collection of a buttons. *

* This ability to use different renderers, while maintaining the same core business logic, is fundamental to how DataTables provides * integration options for CSS frameworks such as Bootstrap, Foundation and jQuery UI, customising the HTML it uses to fit the * requirements of each framework. *

* This parameter controls which renderers will be used. The value given will be used is such a renderer exists, otherwise the default * renderer will be used. Additional renderers can be added by plug-ins. *

* DataTables currently supports two different types of renderers: *

* header - header cell renderer * pageButton - pagination buttons * This list will likely expand significantly in future versions of DataTables! *

* Types * string * Description: * Attempt to use renderers of this name for all available renderers. If a renderer is not found matching this name for the renderer * type requested, the default renderer will be used. *

* object * Description: * Specify specific renderers for the different renderer types. For a list of the available renderer types, please see the * documentation below. *

* Examples * Using the Bootstrap plug-in renderer: *

* Javascript * 1 * 2 * 3 * $('#example').dataTable( { * renderer: "bootstrap" * } ); */ private DataTableThemes renderer; /** * retrieveSince: DataTables 1.10 * Retrieve an existing DataTables instance. *

* Description * Retrieve the DataTables object for the given selector. Note that if the table has already been initialised, this parameter will * cause DataTables to simply return the object that has already been set up - it will not take account of any changes you might have * made to the initialisation object passed to DataTables (setting this parameter to true is an acknowledgement that you understand * this!). *

* The destroy option can be used to reinitialise a table with different options if required. *

* Type * This option can be given in the following type(s): *

* boolean * Default * Value: false */ private Boolean retrieve = true; /** * rowIdSince: DataTables 1.10.8 * Data property name that DataTables will use to set tr element DOM IDs. *

* Description * It can often be useful to have a id attribute on each tr element in a DataTable for row selection and data source identification, * particularly when using events. *

* DataTables will attempt to automatically read an id value from the data source for each row using the property defined by this * option. By default it is DT_RowId but can be set to any other name. As with columns.data it can also read from a nested JSON data * source by using Javascript dotted object notation (e.g. DT_RowId: 'image.id'). *

* If no id value for the row is found, the id property will not be automatically set. *

* Any row id values that are given in the data source should match the HTML specification for what values it can take: *

* The value must be unique amongst all the IDs in the element's home subtree and must contain at least one character. The value must * not contain any space characters. *

* You may also wish to consider the CSS 2.1 specification of an identifier which is more restrictive than HTML5's and will provide * maximum compatibility with jQuery: *

* identifiers (including element names, classes, and IDs in selectors) can contain only the characters [a-zA-Z0-9] and ISO 10646 * characters U+00A0 and higher, plus the hyphen (-) and the underscore (_); they cannot start with a digit, two hyphens, or a hyphen * followed by a digit. Identifiers can also contain escaped characters and any ISO 10646 character as a numeric code. *

* Type * This option can be given in the following type(s): *

* string */ private String rowId; /** * scrollCollapseSince: DataTables 1.10 * Allow the table to reduce in height when a limited number of rows are shown. *

* Description * When vertical (y) scrolling is enabled through the use of the scrollY option, DataTables will force the height of the table's * viewport to the given height at all times (useful for layout). However, this can look odd when filtering data down to a small data * set, and the footer is left "floating" further down. This parameter (when enabled) will cause DataTables to collapse the table's * viewport down when the result set will fit within the given Y height. *

* Type * This option can be given in the following type(s): *

* boolean */ private Boolean scrollCollapse; /** * Horizontal scrolling */ private Boolean scrollX; /** * Horizontal scrolling */ private Integer scrollXNum; /** * Vertical scrolling */ private MeasurementCSSImpl scrollY; /** * searchSince: DataTables 1.10 * Set an initial filter in DataTables and / or filtering options. *

* Description * The search option allows the way DataTables performs filtering to be set during the initialisation, and to set an initial global * filter. *

* The options that control how the filtering is performs are: *

* search.caseInsensitive - Indicate is case-insensitive sorting should be performed. * search.regex - Treat the search as a regular expression or not * search.smart - Use DataTables' smart filtering or not * Additionally, to set an initial filter: *

* search.search - Set an initial global filter. */ private DataTablesSearchOptions search; /** * searchColsSince: DataTables 1.10 * Define an initial search for individual columns. *

* Description * Basically the same as the search option, but in this case for individual columns, rather than the global filter, this option * defined the filtering to apply to the table during initialisation. *

* The array must be of the same size as the number of columns, and each element be an object with the parameters search and * escapeRegex (the latter is optional). 'null' is also accepted and the default will be used. *

* Type * This option can be given in the following type(s): *

* array */ private List> searchCols; /** * searchDelaySince: DataTables 1.10.3 * Set a throttle frequency for searching. *

* Description * The built in DataTables global search (by default at the top right of every DataTable)will instantly search the table on every * keypress when in client-side processing mode and reduce the search call frequency automatically to 400mS when in server-side * processing mode. This call frequency (throttling) can be controlled using the searchDelay parameter for both client-side and * server-side processing. *

* Being able to control the call frequency has a number of uses: *

* Older browsers and slower computers can have their processing load reduced by reducing the search frequency * Fewer table redraws while search can be less distracting for the user * Reduce the load on the server when using server-side processing by making fewer calls * Conversely, you can speed up the search when using server-side processing by reducing the default of 400mS to instant (0). * As with many other parts of DataTables, it is up to yourself how you configure it to suit your needs! *

* The value given for searchDelay is in milliseconds (mS). *

* Please note that this option effects only the built in global search box that DataTables provides. It does not effect the search() * or column().search() methods at all. If you wish to be able to throttle calls to those API methods use the utility method $.fn * .dataTable.util.throttle(). *

* Type * This option can be given in the following type(s): */ private Integer searchDelay; /** * stateDurationSince: DataTables 1.10 * Saved state validity duration. *

* Description * Duration for which the saved state information is considered valid. After this period has elapsed the state will be returned to the * default. *

* This option is also used to indicate to DataTables if localStorage or sessionStorage should be used for storing the table's state. * When set to -1 sessionStorage will be used, while for 0 or greater localStorage will be used. *

* The difference between the two storage APIs is that sessionStorage retains data only for the current session (i..e the current * browser window). For more information on these two HTML APIs please refer to the Mozilla Storage documentation. *

* Please note that the value is given in seconds. The value 0 is a special value as it indicates that the state can be stored and * retrieved indefinitely with no time limit. *

* Type * This option can be given in the following type(s): *

* integer */ private Integer stateDuration; /** * stripeClassesSince: DataTables 1.10 * Set the zebra stripe class names for the rows in the table. *

* Description * An array of CSS classes that should be applied to displayed rows, in sequence. This array may be of any length, and DataTables will * apply each class sequentially, looping when required. *

* Note that by default this option will take the values determined by the $.fn.dataTable.ext.classes.stripe* options (these are odd * and even by default). *

* Type * This option can be given in the following type(s): *

* array * Example * Use three stripe classes: *

* Javascript * 1 * 2 * 3 * $('#example').dataTable( { * "stripeClasses": [ 'strip1', 'strip2', 'strip3' ] * } ); */ private Set stripeClasses; /** * Feature control search (filtering) abilities */ private Boolean searching; /** * Feature control DataTables' server-side processing mode. */ private Boolean serverSide; /** * State saving - restore table state on page reload */ private Boolean stateSave; /** * tabIndexSince: DataTables 1.10 * Tab index control for keyboard navigation. *

* Description * By default DataTables allows keyboard navigation of the table (sorting, paging, and filtering) by adding a tabindex attribute to * the required elements. This allows the end user to tab through the controls and press the enter key to activate them, allowing the * table controls to be accessible without a mouse. *

* The default tabindex is 0, meaning that the tab follows the flow of the document. You can overrule this using this parameter if you * wish. Use a value of -1 to disable built-in keyboard navigation, although this is not recommended for accessibility reasons. *

* Type * This option can be given in the following type(s): *

* integer * Default * Value: 0 */ private Integer tabIndex; /** * If the data table should be destroyed */ private Boolean destroy; /** * The list of columns */ @JsonProperty("columnDefs") @JsonInclude(JsonInclude.Include.NON_EMPTY) private List> columns; /** * autoFillSince: AutoFill 2.0.0 * Enable and configure the AutoFill extension for DataTables. Please note - this property requires the AutoFill extension for * DataTables. *

* Description * This option provides the ability to enable and configure AutoFill for DataTables. In its simplest form as the boolean true it will * enable AutoFill with the default configuration options (as defined by $.fn.dataTable.AutoFill.defaults). It can also be used as an * object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for AutoFill, this option is an extension to the default set of DataTables * options. This property should be set in the DataTables initialisation object. */ private DataTableAutoFillOptions autoFill; /** * Buttons * A common UI paradigm to use with interactive tables is to present buttons that will trigger some action - that may be to alter the * table's state, modify the data in the table, gather the data from the table or even to activate some external process. Showing such * buttons is an interface that end users are comfortable with, making them feel at home with the table. *

* The Buttons library for DataTables provides a framework with common options and API that can be used with DataTables, but is also * very extensible, recognising that you will likely want to use buttons which perform an action unique to your applications. *

* Buttons has four sets of plug-ins that are part of the core software - they are not built into the core, but rather than be * included as and when you need them, selecting only the software you require. Other extensions such as Editor and Select also * provide buttons for use with this library, with actions unique to their own behaviours. This ensures a consistent interface for the * interactions performed with your tables. */ private Set> buttons; /** * ColReorder adds the ability for the end user to be able to reorder columns in a DataTable through a click and drag operation. This * can be useful when presenting data in a table, letting the user move columns that they wish to compare next to each other for * easier comparison. *

* It is worth noting that the underlying column data structure of the DataTable is modified as part of this process - this is * important if you are interacting with the table using the API. */ private DataTableColReOrderOptions colReorder; /** * FixedColumns * When making use of DataTables' x-axis scrolling feature (scrollX), you may wish to fix the left or right most columns in place. * This extension for DataTables provides exactly this option (for non-scrolling tables, please use the FixedHeader extension, which * will create sticky headers and footers for tables). *

* Additional complexity * It is important to state up front that utilising FixedColumns in your DataTable can significantly increase the complexity of the * table and its use should not be undertaken lightly, particularly for complex tables. The reason for this is in how FixedColumns * operates - the fixed columns are actually separate tables from the original DataTable (i.e. they are separate table elements) which * are styled to look like they are visually part of the original table. These fixed tables are then positioned over the original * DataTable. *

* This means that any events attached to the DataTable need to also take into account the fixed tables. Equally, any updates that are * made to the original DataTable needs to also update the fixed tables! *

* If you refer to the DataTables compatibility chart you will be able to see that most incompatibilities are between FixedColumns and * the other extensions for exactly this reason. *

* This is not to say that FixedColumns is not useful - it absolutely can be. But you need to be aware of the additional complexity * that it will introduce into your software. */ private DataTableFixedColumnsOptions fixedColumns; /** * When displaying tables with a particularly large amount of data shown on each page, it can be useful to have the table's header and * / or footer fixed to the top or bottom of the scrolling window. This lets your users quickly determine what each column refers to * rather than needing to scroll back to the top of the table. *

* FixedHeader provides the ability to perform this action with DataTables tables. It operates by detaching the header and footer * elements from the host table and attaching them to the top or bottom of the screen as required by the scrolling position of the * window. This ensures that FixedColumns is fully compatible with DataTables and you can add complex interactions such as search * elements in the table footer, just as you would with any other table. *

* Please note that FixedHeader is not currently compatible with tables that have the scrolling features of DataTables enabled * (scrollX / scrollY). Please refer to the compatibility table for full compatibility details. */ private DataTableFixedHeaderOptions fixedHeader; /** * keysSince: KeyTable KeyTable 2.0.0 * Enable and configure the KeyTable extension for DataTables. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * KeyTable is an extension for DataTables that provides spreadsheet like keyboard navigation in a table, with the focused cell being * movable with arrow keys, tab, home, end and page up / down. KeyTable will automatically adjust the table's paging and other * parameters to show the focused cell as the user navigates around the table. Combined with Editor it makes it super easy to create * an Excel like user interface in the browser. *

* This option provides the ability to enable and configure KeyTable for DataTables. In its simplest form as the boolean true it will * enable KeyTable with the default configuration options (as defined by $.fn.dataTable.KeyTable.defaults). It can also be used as an * object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for KeyTable, this option is an extension to the default set of DataTables * options. This property should be set in the DataTables initialisation object. */ private DataTableKeyTableOptions keys; /** * responsiveSince: Responsive Responsive 1.0.0 * Enable and configure the Responsive extension for DataTables. Please note - this property requires the Responsive extension for * DataTables. *

* Description * This option provides the ability to enable and configure Responsive for DataTables. In its simplest form as the boolean true it * will enable Responsive with the default configuration options (as defined by $.fn.dataTable.Responsive.defaults). It can also be * used as an object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for Responsive, this option is an extension to the default set of * DataTables options. This property should be set in the DataTables initialisation object. */ private DataTablesResponsiveOptions responsive; /** * rowGroupSince: RowGroup RowGroup 1.0.0 * Enable and configure the RowGroup extension for DataTables. Please note - this property requires the RowGroup extension for * DataTables. *

* Description * RowGroup is an extension for DataTables that provides grouping capabilities (like all other DataTables extensions, the clue is in * the name!). A data point in the table's data is used to group information and then display grouping rows before and / or after the * group, with options to customise the display of those rows. *

* This option provides the ability to enable and configure RowGroup for DataTables. In its simplest form as the boolean true it will * enable RowGroup with the default configuration options (as defined by $.fn.dataTable.RowGroup.defaults). However, it is more likely * that you will wish to use it as an object to provide custom configuration options, particularly for the data parameter to use for * the grouping (rowGroup.dataSrc). *

* Please note that as with all other configuration options for RowGroup, this option is an extension to the default set of DataTables * options. This property should be set in the DataTables initialisation object. */ private DataTablesRowGroupOptions rowGroup; /** * rowReorder * Enable and configure the RowReorder extension for DataTables. Please note - this property requires the RowReorder extension for * DataTables. *

* Description * This option provides the ability to enable and configure RowReorder for DataTables. In its simplest form as the boolean true it * will enable RowReorder with the default configuration options (as defined by $.fn.dataTable.RowReorder.defaults). It can also be * used as an object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for RowReorder, this option is an extension to the default set of * DataTables options. This property should be set in the DataTables initialisation object. */ private DataTablesRowReorder rowReorder; /** * scroller * Enable and configure the Scroller extension for DataTables. Please note - this property requires the Scroller extension for * DataTables. *

* Description * Scroller is an extension for DataTables that provides virtual rendering support - i.e. it will draw only the small visible section * of the table (plus a small overlap for smooth scrolling), even although in the scrolling viewport it will appear visually to the * end user that the whole table is available. This can significantly improve performance for large data sets where you don't wish to * display paging controls. *

* There are two important requirements to consider when using Scroller: *

* Paging must be enabled in DataTables (paging - it is by default) * All rows must be of equal height. This is to allow row height calculations for rows which have not yet been rendered. * This option provides the ability to enable and configure Scroller for DataTables. In its simplest form as the boolean true it will * enable Scroller with the default configuration options (as defined by $.fn.dataTable.Scroller.defaults). It can also be used as an * object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for Scroller, this option is an extension to the default set of DataTables * options. This property should be set in the DataTables initialisation object. */ private DataTablesScrollerOptions scroller; /** * selectSince: Select 1.0.0 * Select configuration object. Please note - this property requires the Select extension for DataTables. *

* Description * This option can be used to configure the Select extension for DataTables during the initialisation of a DataTable. *

* When Select has been loaded on a page, all DataTables on that page have the ability to have items selected, but by default this can * only be done through the API - i.e. the end user will have no ability to select items in a table by default. To enable end user * selection, this option should be used (the select.style() method can also be used after initialisation). *

* Exactly what selection the user can make and how depends upon the options selected. */ private DataTablesSelectOptions select; /** * The list of data table options */ public DataTableOptions() { //Nothing Needed } /** * autoWidthSince: DataTables 1.10 * Feature control DataTables' smart column width handling. *

* Description * Enable or disable automatic column width calculation. This can be disabled as an optimisation (it takes a finite amount of time to * calculate the widths) if the tables widths are passed in using columns.width. *

* Type * This option can be given in the following type(s): *

* boolean * * @return */ public Boolean getAutoWidth() { return autoWidth; } /** * autoWidthSince: DataTables 1.10 * Feature control DataTables' smart column width handling. *

* Description * Enable or disable automatic column width calculation. This can be disabled as an optimisation (it takes a finite amount of time to * calculate the widths) if the tables widths are passed in using columns.width. *

* Type * This option can be given in the following type(s): *

* boolean * * @param autoWidth * * @return */ @SuppressWarnings("unchecked") @NotNull public J setAutoWidth(Boolean autoWidth) { this.autoWidth = autoWidth; return (J) this; } /** * deferLoadingSince: DataTables 1.10 * Delay the loading of server-side data until second draw. *

* Description * When using server-side processing, the default mode of operation for DataTables is to simply throw away any data that currently * exists in the table and make a request to the server to get the first page of data to display. This is fine for an empty table, but * if you already have the first page of data displayed in the plain HTML, it is a waste of resources. As such, this option exists to * allow you to instruct DataTables to not make that initial request, rather it will use the data already on the page (no sorting etc * will be applied to it). *

* deferLoading is used to indicate that deferred loading is required, but it is also used to tell DataTables how many records there * are in the full table (allowing the information element and pagination to be displayed correctly). In the case where a filtering is * applied to the table on initial load, this can be indicated by giving the parameter as an array, where the first element is the * number of records available after filtering and the second element is the number of records without filtering (allowing the table * information element to be shown correctly). *

* Note that this option only has effect when serverSide is enabled. It does not have any effect when using client-side processing. * * @return */ public Boolean getDeferRender() { return deferRender; } /** * deferLoadingSince: DataTables 1.10 * Delay the loading of server-side data until second draw. *

* Description * When using server-side processing, the default mode of operation for DataTables is to simply throw away any data that currently * exists in the table and make a request to the server to get the first page of data to display. This is fine for an empty table, but * if you already have the first page of data displayed in the plain HTML, it is a waste of resources. As such, this option exists to * allow you to instruct DataTables to not make that initial request, rather it will use the data already on the page (no sorting etc * will be applied to it). *

* deferLoading is used to indicate that deferred loading is required, but it is also used to tell DataTables how many records there * are in the full table (allowing the information element and pagination to be displayed correctly). In the case where a filtering is * applied to the table on initial load, this can be indicated by giving the parameter as an array, where the first element is the * number of records available after filtering and the second element is the number of records without filtering (allowing the table * information element to be shown correctly). *

* Note that this option only has effect when serverSide is enabled. It does not have any effect when using client-side processing. * * @param deferRender * * @return */ @SuppressWarnings("unchecked") @NotNull public J setDeferRender(Boolean deferRender) { this.deferRender = deferRender; return (J) this; } /** * nfoSince: DataTables 1.10 * Feature control table information display field. *

* Description * When this option is enabled, Datatables will show information about the table including information about filtered data if that * action is being performed. This option allows that feature to be enabled or disabled. *

* Note that by default the information display is shown below the table on the left, but this can be controlled using dom and CSS). *

* Type * This option can be given in the following type(s): *

* boolean * Default * Value: true * * @return */ public Boolean getInfo() { return info; } /** * nfoSince: DataTables 1.10 * Feature control table information display field. *

* Description * When this option is enabled, Datatables will show information about the table including information about filtered data if that * action is being performed. This option allows that feature to be enabled or disabled. *

* Note that by default the information display is shown below the table on the left, but this can be controlled using dom and CSS). *

* Type * This option can be given in the following type(s): *

* boolean * Default * Value: true * * @param info * * @return */ @SuppressWarnings("unchecked") @NotNull public J setInfo(Boolean info) { this.info = info; return (J) this; } /** * Enables JQuery UI Theming within the data table *

* In addition to the above control options, there are two constants DataTables understands (note that these two options are * deprecated in 1.10 and will be removed in 1.11 along side the separation of the jQueryUI option into its own theme file): * * @return */ public Boolean getjQueryUI() { return jQueryUI; } /** * Enables JQuery UI Theming within the data table *

* In addition to the above control options, there are two constants DataTables understands (note that these two options are * deprecated in 1.10 and will be removed in 1.11 along side the separation of the jQueryUI option into its own theme file): * * @param jQueryUI */ @SuppressWarnings("unchecked") @NotNull public J setjQueryUI(Boolean jQueryUI) { this.jQueryUI = jQueryUI; return (J) this; } /** * lengthChangeSince: DataTables 1.10 * Feature control the end user's ability to change the paging display length of the table. *

* Description * When pagination is enabled, this option will control the display of an option for the end user to change number of records to be * shown per page. The options shown in the list are controlled by the lengthMenu configuration option. *

* Note that by default the control is shown at the top left of the table. That can be controlled using dom and CSS. *

* If this option is disabled (false) the length change input control is removed - although the page.len() method can still be used if * you wish to programmatically change the page size and pageLength can be used to specify the initial page length. Paging itself is * not effected. *

* Additionally, if pagination is disabled using the paging option, this option is automatically disabled since it has no relevance * when the is no pagination. * * @return */ public Boolean getLengthChange() { return lengthChange; } /** * lengthChangeSince: DataTables 1.10 * Feature control the end user's ability to change the paging display length of the table. *

* Description * When pagination is enabled, this option will control the display of an option for the end user to change number of records to be * shown per page. The options shown in the list are controlled by the lengthMenu configuration option. *

* Note that by default the control is shown at the top left of the table. That can be controlled using dom and CSS. *

* If this option is disabled (false) the length change input control is removed - although the page.len() method can still be used if * you wish to programmatically change the page size and pageLength can be used to specify the initial page length. Paging itself is * not effected. *

* Additionally, if pagination is disabled using the paging option, this option is automatically disabled since it has no relevance * when the is no pagination. * * @param lengthChange * * @return */ @SuppressWarnings("unchecked") @NotNull public J setLengthChange(Boolean lengthChange) { this.lengthChange = lengthChange; return (J) this; } /** * Description * This parameter allows you to readily specify the entries in the length drop down select list that DataTables shows when pagination * is enabled. It can be either: *

* 1D array of integer values which will be used for both the displayed option and the value to use for the display length, or *

* 2D array which will use the first inner array as the page length values and the second inner array as the displayed options. This * is useful for language strings such as 'All'). *

* The page length values must always be integer values>0, with the sole exception of -1. When -1 is used as a value this tells * DataTables to disable pagination (i.e. display all rows). *

* Note that the pageLength property will be automatically set to the first value given in this array, unless pageLength is also * provided. *

* Type * This option can be given in the following type(s): *

* array * Default * [ 10, 25, 50, 100 ] * * @return */ public Set getLengthMenu() { return lengthMenu; } /** * Description * This parameter allows you to readily specify the entries in the length drop down select list that DataTables shows when pagination * is enabled. It can be either: *

* 1D array of integer values which will be used for both the displayed option and the value to use for the display length, or *

* 2D array which will use the first inner array as the page length values and the second inner array as the displayed options. This * is useful for language strings such as 'All'). *

* The page length values must always be integer values>0, with the sole exception of -1. When -1 is used as a value this tells * DataTables to disable pagination (i.e. display all rows). *

* Note that the pageLength property will be automatically set to the first value given in this array, unless pageLength is also * provided. *

* Type * This option can be given in the following type(s): *

* array * Default * [ 10, 25, 50, 100 ] * * @param lengthMenu */ @SuppressWarnings("unchecked") @NotNull public J setLengthMenu(Set lengthMenu) { if (lengthMenu == null) { lengthMenu = new LinkedHashSet<>(); } this.lengthMenu = lengthMenu; return (J) this; } /** * Description * Allows control over whether DataTables should use the top (true) unique cell that is found for a single column, or the bottom * (false - default) to attach the default order listener. This is useful when using complex headers. * * @return */ public Boolean getOrderCellsTop() { return orderCellsTop; } /** * Description * Allows control over whether DataTables should use the top (true) unique cell that is found for a single column, or the bottom * (false - default) to attach the default order listener. This is useful when using complex headers. * * @param orderCellsTop * * @return */ @SuppressWarnings("unchecked") @NotNull public J setOrderCellsTop(Boolean orderCellsTop) { this.orderCellsTop = orderCellsTop; return (J) this; } /** * Description * DataTables highlight the columns which are used to order the content in the table's body by adding a class to the cells in that * column, which in turn has CSS applied to those classes to highlight those cells. *

* This is done by the addition of the classes sorting_1, sorting_2 and sorting_3 to the columns which are currently being ordered on. * The integer value indicates the level of sorting when mutli-column sorting. If more than 3 columns are being ordered upon, the * sorting_3 class is repeated. *

* Please note that this feature can affect performance, particularly in old browsers and when there are a lot of rows to be displayed * as it is manipulating a large number of DOM elements. As such, this option is available as a feature switch to allow this feature * to be disabled with working with old browsers or large data sets. * * @return */ public Boolean getOrderClasses() { return orderClasses; } /** * Description * DataTables highlight the columns which are used to order the content in the table's body by adding a class to the cells in that * column, which in turn has CSS applied to those classes to highlight those cells. *

* This is done by the addition of the classes sorting_1, sorting_2 and sorting_3 to the columns which are currently being ordered on. * The integer value indicates the level of sorting when mutli-column sorting. If more than 3 columns are being ordered upon, the * sorting_3 class is repeated. *

* Please note that this feature can affect performance, particularly in old browsers and when there are a lot of rows to be displayed * as it is manipulating a large number of DOM elements. As such, this option is available as a feature switch to allow this feature * to be disabled with working with old browsers or large data sets. * * @param orderClasses * * @return */ @SuppressWarnings("unchecked") @NotNull public J setOrderClasses(Boolean orderClasses) { this.orderClasses = orderClasses; return (J) this; } /** * orderFixedSince: DataTables 1.10 * Ordering to always be applied to the table. *

* Description * The option works in tandem with the order option which provides an initial ordering state for the table which can then be modified * by the user clicking on column headings, while the ordering specified by this option will always be applied to the table, * regardless of user interaction. *

* This fixed ordering can be applied before (pre) or after (post) the user's own ordering criteria using the two different forms of * this option (array or object) described below. *

* The values that are used to describe the ordering conditions for the table are given as two element arrays: *

* Column index to order upon * Direction so order to apply (asc for ascending order or desc for descending order). * It is also possible to give a set of nested arrays (i.e. arrays in arrays) to allow multi-column ordering to be assigned. *

* This option can be useful if you a column (visible or hidden) which must always be sorted upon first - a priority order or index * column for example, or for grouping similar rows together. * * @return */ public Boolean getOrderFixed() { return orderFixed; } /** * orderFixedSince: DataTables 1.10 * Ordering to always be applied to the table. *

* Description * The option works in tandem with the order option which provides an initial ordering state for the table which can then be modified * by the user clicking on column headings, while the ordering specified by this option will always be applied to the table, * regardless of user interaction. *

* This fixed ordering can be applied before (pre) or after (post) the user's own ordering criteria using the two different forms of * this option (array or object) described below. *

* The values that are used to describe the ordering conditions for the table are given as two element arrays: *

* Column index to order upon * Direction so order to apply (asc for ascending order or desc for descending order). * It is also possible to give a set of nested arrays (i.e. arrays in arrays) to allow multi-column ordering to be assigned. *

* This option can be useful if you a column (visible or hidden) which must always be sorted upon first - a priority order or index * column for example, or for grouping similar rows together. * * @param orderFixed * * @return */ @SuppressWarnings("unchecked") @NotNull public J setOrderFixed(Boolean orderFixed) { this.orderFixed = orderFixed; return (J) this; } /** * orderMultiSince: DataTables 1.10 * Multiple column ordering ability control. *

* Description * When ordering is enabled (ordering), by default DataTables allows users to sort multiple columns by shift clicking upon the header * cell for each column. Although this can be quite useful for users, it can also increase the complexity of the order, potentiality * increasing the processing time of ordering the data. Therefore, this option is provided to allow this shift-click multiple column * ability. *

* Note that disabling this ability does not impede your ability as a developer to do multiple column ordering using columns * .orderData, order or order(), it just disallows the user from performing their own multi-column order. *

* Type * This option can be given in the following type(s): *

* boolean * Default * true * * @return */ public Boolean getOrderMulti() { return orderMulti; } /** * orderMultiSince: DataTables 1.10 * Multiple column ordering ability control. *

* Description * When ordering is enabled (ordering), by default DataTables allows users to sort multiple columns by shift clicking upon the header * cell for each column. Although this can be quite useful for users, it can also increase the complexity of the order, potentiality * increasing the processing time of ordering the data. Therefore, this option is provided to allow this shift-click multiple column * ability. *

* Note that disabling this ability does not impede your ability as a developer to do multiple column ordering using columns * .orderData, order or order(), it just disallows the user from performing their own multi-column order. *

* Type * This option can be given in the following type(s): *

* boolean * Default * true * * @param orderMulti * * @return */ @SuppressWarnings("unchecked") @NotNull public J setOrderMulti(Boolean orderMulti) { this.orderMulti = orderMulti; return (J) this; } /** * orderingSince: DataTables 1.10 * Feature control ordering (sorting) abilities in DataTables. *

* Description * Enable or disable ordering of columns - it is as simple as that! DataTables, by default, allows end users to click on the header * cell for each column, ordering the table by the data in that column. The ability to order data can be disabled using this option. *

* Note that the ability to add or remove sorting of individual columns can be disabled by the columns.orderable option for each * column. This parameter is a global option - when disabled, there are no sorting actions applied by DataTables at all. * * @return */ public Boolean getOrdering() { return ordering; } /** * orderingSince: DataTables 1.10 * Feature control ordering (sorting) abilities in DataTables. *

* Description * Enable or disable ordering of columns - it is as simple as that! DataTables, by default, allows end users to click on the header * cell for each column, ordering the table by the data in that column. The ability to order data can be disabled using this option. *

* Note that the ability to add or remove sorting of individual columns can be disabled by the columns.orderable option for each * column. This parameter is a global option - when disabled, there are no sorting actions applied by DataTables at all. * * @param ordering * * @return */ @SuppressWarnings("unchecked") @NotNull public J setOrdering(Boolean ordering) { this.ordering = ordering; return (J) this; } /** * pageLengthSince: DataTables 1.10 * Change the initial page length (number of rows per page). *

* Description * Number of rows to display on a single page when using pagination. *

* If lengthChange is feature enabled (it is by default) then the end user will be able to override the value set here to a custom * setting using a pop-up menu (see lengthMenu). *

* Type * This option can be given in the following type(s): *

* integer * Default * Value: 10 * * @return */ public Integer getPageLength() { return pageLength; } /** * pageLengthSince: DataTables 1.10 * Change the initial page length (number of rows per page). *

* Description * Number of rows to display on a single page when using pagination. *

* If lengthChange is feature enabled (it is by default) then the end user will be able to override the value set here to a custom * setting using a pop-up menu (see lengthMenu). *

* Type * This option can be given in the following type(s): *

* integer * Default * Value: 10 * * @param pageLength * * @return */ @SuppressWarnings("unchecked") @NotNull public J setPageLength(Integer pageLength) { this.pageLength = pageLength; return (J) this; } /** * pagingTypeSince: DataTables 1.10 * Pagination button display options. *

* Description * The pagination option of DataTables will display a pagination control below the table (by default, its position can be changed using * dom and CSS) with buttons that the end user can use to navigate the pages of the table. Which buttons are shown in the pagination * control are defined by the option given here. *

* DataTables has six built-in paging button arrangements: *

* numbers - Page number buttons only (1.10.8) * simple - 'Previous' and 'Next' buttons only * simple_numbers - 'Previous' and 'Next' buttons, plus page numbers * full - 'First', 'Previous', 'Next' and 'Last' buttons * full_numbers - 'First', 'Previous', 'Next' and 'Last' buttons, plus page numbers * first_last_numbers - 'First' and 'Last' buttons, plus page numbers * Further methods can be added using plug-ins. *

* Type * This option can be given in the following type(s): *

* string * * @return */ public DataTablesPagingTypes getPagingType() { return pagingType; } /** * pagingTypeSince: DataTables 1.10 * Pagination button display options. *

* Description * The pagination option of DataTables will display a pagination control below the table (by default, its position can be changed using * dom and CSS) with buttons that the end user can use to navigate the pages of the table. Which buttons are shown in the pagination * control are defined by the option given here. *

* DataTables has six built-in paging button arrangements: *

* numbers - Page number buttons only (1.10.8) * simple - 'Previous' and 'Next' buttons only * simple_numbers - 'Previous' and 'Next' buttons, plus page numbers * full - 'First', 'Previous', 'Next' and 'Last' buttons * full_numbers - 'First', 'Previous', 'Next' and 'Last' buttons, plus page numbers * first_last_numbers - 'First' and 'Last' buttons, plus page numbers * Further methods can be added using plug-ins. *

* Type * This option can be given in the following type(s): *

* string * * @param pagingType * * @return */ @SuppressWarnings("unchecked") @NotNull public J setPagingType(DataTablesPagingTypes pagingType) { this.pagingType = pagingType; return (J) this; } /** * pagingSince: DataTables 1.10 * Enable or disable table pagination. *

* Description * DataTables can split the rows in tables into individual pages, which is an efficient method of showing a large number of records in * a small space. The end user is provided with controls to request the display of different data as the navigate through the data. * This feature is enabled by default, but if you wish to disable it, you may do so with this parameter. *

* Type * This option can be given in the following type(s): *

* boolean * Default * true * * @return */ public Boolean getPaging() { return paging; } /** * pagingSince: DataTables 1.10 * Enable or disable table pagination. *

* Description * DataTables can split the rows in tables into individual pages, which is an efficient method of showing a large number of records in * a small space. The end user is provided with controls to request the display of different data as the navigate through the data. * This feature is enabled by default, but if you wish to disable it, you may do so with this parameter. *

* Type * This option can be given in the following type(s): *

* boolean * Default * true * * @param paging * * @return */ @SuppressWarnings("unchecked") @NotNull public J setPaging(Boolean paging) { this.paging = paging; return (J) this; } /** * processingSince: DataTables 1.10 * Feature control the processing indicator. *

* Description * Enable or disable the display of a 'processing' indicator when the table is being processed (e.g. a sort). This is particularly * useful for tables with large amounts of data where it can take a noticeable amount of time to sort the entries. *

* Type * This option can be given in the following type(s): *

* boolean * Default * false * * @return */ public Boolean getProcessing() { return processing; } /** * processingSince: DataTables 1.10 * Feature control the processing indicator. *

* Description * Enable or disable the display of a 'processing' indicator when the table is being processed (e.g. a sort). This is particularly * useful for tables with large amounts of data where it can take a noticeable amount of time to sort the entries. *

* Type * This option can be given in the following type(s): *

* boolean * Default * false * * @param processing * * @return */ @SuppressWarnings("unchecked") @NotNull public J setProcessing(Boolean processing) { this.processing = processing; return (J) this; } /** * rendererSince: DataTables 1.10 * Display component renderer types. *

* Description * DataTables adds some complex components to your HTML page, such as the pagination control. The business logic used to calculate * information should be displayed (what buttons in the case of the pagination buttons) is core to DataTables and generally doesn't * vary how the buttons are actually displayed does based on the styling requirements of the page. For example the pagination buttons * might be displayed as li elements in a ul list, or simply as a collection of a buttons. *

* This ability to use different renderers, while maintaining the same core business logic, is fundamental to how DataTables provides * integration options for CSS frameworks such as Bootstrap, Foundation and jQuery UI, customising the HTML it uses to fit the * requirements of each framework. *

* This parameter controls which renderers will be used. The value given will be used is such a renderer exists, otherwise the default * renderer will be used. Additional renderers can be added by plug-ins. *

* DataTables currently supports two different types of renderers: *

* header - header cell renderer * pageButton - pagination buttons * This list will likely expand significantly in future versions of DataTables! *

* Types * string * Description: * Attempt to use renderers of this name for all available renderers. If a renderer is not found matching this name for the renderer * type requested, the default renderer will be used. *

* object * Description: * Specify specific renderers for the different renderer types. For a list of the available renderer types, please see the * documentation below. *

* Examples * Using the Bootstrap plug-in renderer: *

* Javascript * 1 * 2 * 3 * $('#example').dataTable( { * renderer: "bootstrap" * } ); * * @return */ public DataTableThemes getRenderer() { return renderer; } /** * rendererSince: DataTables 1.10 * Display component renderer types. *

* Description * DataTables adds some complex components to your HTML page, such as the pagination control. The business logic used to calculate * information should be displayed (what buttons in the case of the pagination buttons) is core to DataTables and generally doesn't * vary how the buttons are actually displayed does based on the styling requirements of the page. For example the pagination buttons * might be displayed as li elements in a ul list, or simply as a collection of a buttons. *

* This ability to use different renderers, while maintaining the same core business logic, is fundamental to how DataTables provides * integration options for CSS frameworks such as Bootstrap, Foundation and jQuery UI, customising the HTML it uses to fit the * requirements of each framework. *

* This parameter controls which renderers will be used. The value given will be used is such a renderer exists, otherwise the default * renderer will be used. Additional renderers can be added by plug-ins. *

* DataTables currently supports two different types of renderers: *

* header - header cell renderer * pageButton - pagination buttons * This list will likely expand significantly in future versions of DataTables! *

* Types * string * Description: * Attempt to use renderers of this name for all available renderers. If a renderer is not found matching this name for the renderer * type requested, the default renderer will be used. *

* object * Description: * Specify specific renderers for the different renderer types. For a list of the available renderer types, please see the * documentation below. *

* Examples * Using the Bootstrap plug-in renderer: *

* Javascript * 1 * 2 * 3 * $('#example').dataTable( { * renderer: "bootstrap" * } ); * * @param renderer * * @return */ @SuppressWarnings("unchecked") @NotNull public J setRenderer(DataTableThemes renderer) { this.renderer = renderer; return (J) this; } /** * retrieveSince: DataTables 1.10 * Retrieve an existing DataTables instance. *

* Description * Retrieve the DataTables object for the given selector. Note that if the table has already been initialised, this parameter will * cause DataTables to simply return the object that has already been set up - it will not take account of any changes you might have * made to the initialisation object passed to DataTables (setting this parameter to true is an acknowledgement that you understand * this!). *

* The destroy option can be used to reinitialise a table with different options if required. *

* Type * This option can be given in the following type(s): *

* boolean * Default * Value: false * * @return */ public Boolean getRetrieve() { return retrieve; } /** * retrieveSince: DataTables 1.10 * Retrieve an existing DataTables instance. *

* Description * Retrieve the DataTables object for the given selector. Note that if the table has already been initialised, this parameter will * cause DataTables to simply return the object that has already been set up - it will not take account of any changes you might have * made to the initialisation object passed to DataTables (setting this parameter to true is an acknowledgement that you understand * this!). *

* The destroy option can be used to reinitialise a table with different options if required. *

* Type * This option can be given in the following type(s): *

* boolean * Default * Value: true * * @param retrieve * * @return */ @SuppressWarnings("unchecked") @NotNull public J setRetrieve(Boolean retrieve) { this.retrieve = retrieve; return (J) this; } public String getRowId() { return rowId; } /** * rowIdSince: DataTables 1.10.8 * Data property name that DataTables will use to set tr element DOM IDs. *

* Description * It can often be useful to have a id attribute on each tr element in a DataTable for row selection and data source identification, * particularly when using events. *

* DataTables will attempt to automatically read an id value from the data source for each row using the property defined by this * option. By default it is DT_RowId but can be set to any other name. As with columns.data it can also read from a nested JSON data * source by using Javascript dotted object notation (e.g. DT_RowId: 'image.id'). *

* If no id value for the row is found, the id property will not be automatically set. *

* Any row id values that are given in the data source should match the HTML specification for what values it can take: *

* The value must be unique amongst all the IDs in the element's home subtree and must contain at least one character. The value must * not contain any space characters. *

* You may also wish to consider the CSS 2.1 specification of an identifier which is more restrictive than HTML5's and will provide * maximum compatibility with jQuery: *

* identifiers (including element names, classes, and IDs in selectors) can contain only the characters [a-zA-Z0-9] and ISO 10646 * characters U+00A0 and higher, plus the hyphen (-) and the underscore (_); they cannot start with a digit, two hyphens, or a hyphen * followed by a digit. Identifiers can also contain escaped characters and any ISO 10646 character as a numeric code. *

* Type * This option can be given in the following type(s): *

* string * * @param rowId * * @return */ @SuppressWarnings("unchecked") @NotNull public J setRowId(String rowId) { this.rowId = rowId; return (J) this; } /** * scrollCollapseSince: DataTables 1.10 * Allow the table to reduce in height when a limited number of rows are shown. *

* Description * When vertical (y) scrolling is enabled through the use of the scrollY option, DataTables will force the height of the table's * viewport to the given height at all times (useful for layout). However, this can look odd when filtering data down to a small data * set, and the footer is left "floating" further down. This parameter (when enabled) will cause DataTables to collapse the table's * viewport down when the result set will fit within the given Y height. *

* Type * This option can be given in the following type(s): *

* boolean * * @return */ public Boolean getScrollCollapse() { return scrollCollapse; } /** * scrollCollapseSince: DataTables 1.10 * Allow the table to reduce in height when a limited number of rows are shown. *

* Description * When vertical (y) scrolling is enabled through the use of the scrollY option, DataTables will force the height of the table's * viewport to the given height at all times (useful for layout). However, this can look odd when filtering data down to a small data * set, and the footer is left "floating" further down. This parameter (when enabled) will cause DataTables to collapse the table's * viewport down when the result set will fit within the given Y height. *

* Type * This option can be given in the following type(s): *

* boolean * * @param scrollCollapse * * @return */ @SuppressWarnings("unchecked") @NotNull public J setScrollCollapse(Boolean scrollCollapse) { this.scrollCollapse = scrollCollapse; return (J) this; } /** * scrollXSince: DataTables 1.10 * Horizontal scrolling. *

* Description * Enable horizontal scrolling. When a table is too wide to fit into a certain layout, or you have a large number of columns in the * table, you can enable horizontal (x) scrolling to show the table in a viewport, which can be scrolled. *

* This property can be true which will allow the table to scroll horizontally when needed (recommended), or any CSS unit, or a number * (in which case it will be treated as a pixel measurement). * * @return */ public Boolean getScrollX() { return scrollX; } /** * scrollXSince: DataTables 1.10 * Horizontal scrolling. *

* Description * Enable horizontal scrolling. When a table is too wide to fit into a certain layout, or you have a large number of columns in the * table, you can enable horizontal (x) scrolling to show the table in a viewport, which can be scrolled. *

* This property can be true which will allow the table to scroll horizontally when needed (recommended), or any CSS unit, or a number * (in which case it will be treated as a pixel measurement). * * @param scrollX * * @return */ @SuppressWarnings("unchecked") @NotNull public J setScrollX(Boolean scrollX) { this.scrollX = scrollX; return (J) this; } /** * scrollXSince: DataTables 1.10 * Horizontal scrolling. *

* Description * Enable horizontal scrolling. When a table is too wide to fit into a certain layout, or you have a large number of columns in the * table, you can enable horizontal (x) scrolling to show the table in a viewport, which can be scrolled. *

* This property can be true which will allow the table to scroll horizontally when needed (recommended), or any CSS unit, or a number * (in which case it will be treated as a pixel measurement). * * @return */ public Integer getScrollXNum() { return scrollXNum; } /** * scrollXSince: DataTables 1.10 * Horizontal scrolling. *

* Description * Enable horizontal scrolling. When a table is too wide to fit into a certain layout, or you have a large number of columns in the * table, you can enable horizontal (x) scrolling to show the table in a viewport, which can be scrolled. *

* This property can be true which will allow the table to scroll horizontally when needed (recommended), or any CSS unit, or a number * (in which case it will be treated as a pixel measurement). * * @param scrollXNum * * @return */ @SuppressWarnings("unchecked") @NotNull public J setScrollXNum(Integer scrollXNum) { this.scrollXNum = scrollXNum; return (J) this; } /** * scrollYSince: DataTables 1.10 * Vertical scrolling. *

* Description * Enable vertical scrolling. Vertical scrolling will constrain the DataTable to the given height, and enable scrolling for any data * which overflows the current viewport. This can be used as an alternative to paging to display a lot of data in a small area * (although paging and scrolling can both be enabled at the same time if desired). *

* The value given here can be any CSS unit, or a number (in which case it will be treated as a pixel measurement) and is applied to * the table body (i.e. it does not take into account the header or footer height directly). *

* Type * This option can be given in the following type(s): *

* string * * @return */ public MeasurementCSSImpl getScrollY() { return scrollY; } /** * scrollYSince: DataTables 1.10 * Vertical scrolling. *

* Description * Enable vertical scrolling. Vertical scrolling will constrain the DataTable to the given height, and enable scrolling for any data * which overflows the current viewport. This can be used as an alternative to paging to display a lot of data in a small area * (although paging and scrolling can both be enabled at the same time if desired). *

* The value given here can be any CSS unit, or a number (in which case it will be treated as a pixel measurement) and is applied to * the table body (i.e. it does not take into account the header or footer height directly). *

* Type * This option can be given in the following type(s): *

* string * * @param scrollY * * @return */ @SuppressWarnings("unchecked") @NotNull public J setScrollY(MeasurementCSSImpl scrollY) { this.scrollY = scrollY; return (J) this; } /** * searchDelaySince: DataTables 1.10.3 * Set a throttle frequency for searching. *

* Description * The built in DataTables global search (by default at the top right of every DataTable)will instantly search the table on every * keypress when in client-side processing mode and reduce the search call frequency automatically to 400mS when in server-side * processing mode. This call frequency (throttling) can be controlled using the searchDelay parameter for both client-side and * server-side processing. *

* Being able to control the call frequency has a number of uses: *

* Older browsers and slower computers can have their processing load reduced by reducing the search frequency * Fewer table redraws while search can be less distracting for the user * Reduce the load on the server when using server-side processing by making fewer calls * Conversely, you can speed up the search when using server-side processing by reducing the default of 400mS to instant (0). * As with many other parts of DataTables, it is up to yourself how you configure it to suit your needs! *

* The value given for searchDelay is in milliseconds (mS). *

* Please note that this option effects only the built in global search box that DataTables provides. It does not effect the search() * or column().search() methods at all. If you wish to be able to throttle calls to those API methods use the utility method $.fn * .dataTable.util.throttle(). *

* Type * This option can be given in the following type(s): * * @return */ public Integer getSearchDelay() { return searchDelay; } /** * searchDelaySince: DataTables 1.10.3 * Set a throttle frequency for searching. *

* Description * The built in DataTables global search (by default at the top right of every DataTable)will instantly search the table on every * keypress when in client-side processing mode and reduce the search call frequency automatically to 400mS when in server-side * processing mode. This call frequency (throttling) can be controlled using the searchDelay parameter for both client-side and * server-side processing. *

* Being able to control the call frequency has a number of uses: *

* Older browsers and slower computers can have their processing load reduced by reducing the search frequency * Fewer table redraws while search can be less distracting for the user * Reduce the load on the server when using server-side processing by making fewer calls * Conversely, you can speed up the search when using server-side processing by reducing the default of 400mS to instant (0). * As with many other parts of DataTables, it is up to yourself how you configure it to suit your needs! *

* The value given for searchDelay is in milliseconds (mS). *

* Please note that this option effects only the built in global search box that DataTables provides. It does not effect the search() * or column().search() methods at all. If you wish to be able to throttle calls to those API methods use the utility method $.fn * .dataTable.util.throttle(). *

* Type * This option can be given in the following type(s): * * @param searchDelay * * @return */ @SuppressWarnings("unchecked") @NotNull public J setSearchDelay(Integer searchDelay) { this.searchDelay = searchDelay; return (J) this; } /** * stateDurationSince: DataTables 1.10 * Saved state validity duration. *

* Description * Duration for which the saved state information is considered valid. After this period has elapsed the state will be returned to the * default. *

* This option is also used to indicate to DataTables if localStorage or sessionStorage should be used for storing the table's state. * When set to -1 sessionStorage will be used, while for 0 or greater localStorage will be used. *

* The difference between the two storage APIs is that sessionStorage retains data only for the current session (i..e the current * browser window). For more information on these two HTML APIs please refer to the Mozilla Storage documentation. *

* Please note that the value is given in seconds. The value 0 is a special value as it indicates that the state can be stored and * retrieved indefinitely with no time limit. *

* Type * This option can be given in the following type(s): *

* integer * * @return */ public Integer getStateDuration() { return stateDuration; } /** * stateDurationSince: DataTables 1.10 * Saved state validity duration. *

* Description * Duration for which the saved state information is considered valid. After this period has elapsed the state will be returned to the * default. *

* This option is also used to indicate to DataTables if localStorage or sessionStorage should be used for storing the table's state. * When set to -1 sessionStorage will be used, while for 0 or greater localStorage will be used. *

* The difference between the two storage APIs is that sessionStorage retains data only for the current session (i..e the current * browser window). For more information on these two HTML APIs please refer to the Mozilla Storage documentation. *

* Please note that the value is given in seconds. The value 0 is a special value as it indicates that the state can be stored and * retrieved indefinitely with no time limit. *

* Type * This option can be given in the following type(s): *

* integer * * @param stateDuration * * @return */ @SuppressWarnings("unchecked") @NotNull public J setStateDuration(Integer stateDuration) { this.stateDuration = stateDuration; return (J) this; } /** * stripeClassesSince: DataTables 1.10 * Set the zebra stripe class names for the rows in the table. *

* Description * An array of CSS classes that should be applied to displayed rows, in sequence. This array may be of any length, and DataTables will * apply each class sequentially, looping when required. *

* Note that by default this option will take the values determined by the $.fn.dataTable.ext.classes.stripe* options (these are odd * and even by default). *

* Type * This option can be given in the following type(s): *

* array * Example * Use three stripe classes: *

* Javascript * 1 * 2 * 3 * $('#example').dataTable( { * "stripeClasses": [ 'strip1', 'strip2', 'strip3' ] * } ); * * @return */ public Set getStripeClasses() { if (stripeClasses == null) { stripeClasses = new LinkedHashSet<>(); } return stripeClasses; } /** * stripeClassesSince: DataTables 1.10 * Set the zebra stripe class names for the rows in the table. *

* Description * An array of CSS classes that should be applied to displayed rows, in sequence. This array may be of any length, and DataTables will * apply each class sequentially, looping when required. *

* Note that by default this option will take the values determined by the $.fn.dataTable.ext.classes.stripe* options (these are odd * and even by default). *

* Type * This option can be given in the following type(s): *

* array * Example * Use three stripe classes: *

* Javascript * 1 * 2 * 3 * $('#example').dataTable( { * "stripeClasses": [ 'strip1', 'strip2', 'strip3' ] * } ); * * @param stripeClasses * * @return */ @SuppressWarnings("unchecked") @NotNull public J setStripeClasses(Set stripeClasses) { this.stripeClasses = stripeClasses; return (J) this; } /** * searchingSince: DataTables 1.10 * Feature control search (filtering) abilities. *

* Description * This option allows the search abilities of DataTables to be enabled or disabled. Searching in DataTables is "smart" in that it * allows the end user to input multiple words (space separated) and will match a row containing those words, even if not in the order * that was specified (this allow matching across multiple columns). *

* Please be aware that technically the search in DataTables is actually a filter, since it is subtractive, removing data from the * data set as the input becomes more complex. It is named "search" here, and else where in the DataTables API for consistency and to * ensure there are no conflicts with other methods of a similar name (specific the filter() API method). *

* Note that if you wish to use the search abilities of DataTables this must remain true - to remove the default search input box * whilst retaining searching abilities (for example you might use the search() method), use the dom option. *

* Type * This option can be given in the following type(s): *

* boolean * Default * Value: true * * @return */ public Boolean getSearching() { return searching; } /** * searchingSince: DataTables 1.10 * Feature control search (filtering) abilities. *

* Description * This option allows the search abilities of DataTables to be enabled or disabled. Searching in DataTables is "smart" in that it * allows the end user to input multiple words (space separated) and will match a row containing those words, even if not in the order * that was specified (this allow matching across multiple columns). *

* Please be aware that technically the search in DataTables is actually a filter, since it is subtractive, removing data from the * data set as the input becomes more complex. It is named "search" here, and else where in the DataTables API for consistency and to * ensure there are no conflicts with other methods of a similar name (specific the filter() API method). *

* Note that if you wish to use the search abilities of DataTables this must remain true - to remove the default search input box * whilst retaining searching abilities (for example you might use the search() method), use the dom option. *

* Type * This option can be given in the following type(s): *

* boolean * Default * Value: true * * @param searching * * @return */ @SuppressWarnings("unchecked") @NotNull public J setSearching(Boolean searching) { this.searching = searching; return (J) this; } /** * serverSideSince: DataTables 1.10 * Feature control DataTables' server-side processing mode. *

* Description * DataTables has two fundamental modes of operation: *

* Client-side processing - where filtering, paging and sorting calculations are all performed in the web-browser. *

* Server-side processing - where filtering, paging and sorting calculations are all performed by a server. *

* By default DataTables operates in client-side processing mode, but can be switched to server-side processing mode using this option * . Server-side processing is useful when working with large data sets (typically > 50'000 records) as it means a database engine * can * be used to perform the sorting etc calculations - operations that modern database engines are highly optimised for, allowing use of * DataTables with massive data sets (millions of rows). *

* When operating in server-side processing mode, DataTables will send parameters to the server indicating what data it needs (what * page, what filters are applied etc), and also expects certain parameters back in order that it has all the information required to * display the table. The client-server communication protocol DataTables uses is detailed in the DataTables documentation. *

* Type * This option can be given in the following type(s): *

* boolean * Default * false * * @return */ public Boolean getServerSide() { return serverSide; } /** * serverSideSince: DataTables 1.10 * Feature control DataTables' server-side processing mode. *

* Description * DataTables has two fundamental modes of operation: *

* Client-side processing - where filtering, paging and sorting calculations are all performed in the web-browser. *

* Server-side processing - where filtering, paging and sorting calculations are all performed by a server. *

* By default DataTables operates in client-side processing mode, but can be switched to server-side processing mode using this option * . Server-side processing is useful when working with large data sets (typically >50'000 records) as it means a database engine * can * be used to perform the sorting etc calculations - operations that modern database engines are highly optimised for, allowing use of * DataTables with massive data sets (millions of rows). *

* When operating in server-side processing mode, DataTables will send parameters to the server indicating what data it needs (what * page, what filters are applied etc), and also expects certain parameters back in order that it has all the information required to * display the table. The client-server communication protocol DataTables uses is detailed in the DataTables documentation. *

* Type * This option can be given in the following type(s): *

* boolean * Default * false * * @param serverSide * * @return */ @SuppressWarnings("unchecked") @NotNull public J setServerSide(Boolean serverSide) { this.serverSide = serverSide; return (J) this; } /** * stateSaveSince: DataTables 1.10 * State saving - restore table state on page reload. *

* Description * Enable or disable state saving. When enabled aDataTables will store state information such as pagination position, display length, * filtering and sorting. When the end user reloads the page the table's state will be altered to match what they had previously set * up. *

* Data storage for the state information in the browser is performed by use of the localStorage or sessionStorage HTML5 APIs. The * stateDuration indicated to DataTables which API should be used (localStorage: 0 or greater, or sessionStorage: -1). *

* To be able to uniquely identify each table's state data, information is stored using a combination of the table's DOM id and the * current page's pathname. If the table's id changes, or the page URL changes, the state information will be lost. *

* Please note that the use of the HTML5 APIs for data storage means that the built in state saving option will not work with IE6/7 as * these browsers do not support these APIs. Alternative options of using cookies or saving the state on the server through Ajax can * be used through the stateSaveCallback and stateLoadCallback options. *

* Type * This option can be given in the following type(s): *

* boolean * Default * Value: false * * @return */ public Boolean getStateSave() { return stateSave; } /** * stateSaveSince: DataTables 1.10 * State saving - restore table state on page reload. *

* Description * Enable or disable state saving. When enabled aDataTables will store state information such as pagination position, display length, * filtering and sorting. When the end user reloads the page the table's state will be altered to match what they had previously set * up. *

* Data storage for the state information in the browser is performed by use of the localStorage or sessionStorage HTML5 APIs. The * stateDuration indicated to DataTables which API should be used (localStorage: 0 or greater, or sessionStorage: -1). *

* To be able to uniquely identify each table's state data, information is stored using a combination of the table's DOM id and the * current page's pathname. If the table's id changes, or the page URL changes, the state information will be lost. *

* Please note that the use of the HTML5 APIs for data storage means that the built in state saving option will not work with IE6/7 as * these browsers do not support these APIs. Alternative options of using cookies or saving the state on the server through Ajax can * be used through the stateSaveCallback and stateLoadCallback options. *

* Type * This option can be given in the following type(s): *

* boolean * Default * Value: false * * @param stateSave * * @return */ @SuppressWarnings("unchecked") @NotNull public J setStateSave(Boolean stateSave) { this.stateSave = stateSave; return (J) this; } /** * tabIndexSince: DataTables 1.10 * Tab index control for keyboard navigation. *

* Description * By default DataTables allows keyboard navigation of the table (sorting, paging, and filtering) by adding a tabindex attribute to * the required elements. This allows the end user to tab through the controls and press the enter key to activate them, allowing the * table controls to be accessible without a mouse. *

* The default tabindex is 0, meaning that the tab follows the flow of the document. You can overrule this using this parameter if you * wish. Use a value of -1 to disable built-in keyboard navigation, although this is not recommended for accessibility reasons. *

* Type * This option can be given in the following type(s): *

* integer * Default * Value: 0 * * @return */ public Integer getTabIndex() { return tabIndex; } /** * tabIndexSince: DataTables 1.10 * Tab index control for keyboard navigation. *

* Description * By default DataTables allows keyboard navigation of the table (sorting, paging, and filtering) by adding a tabindex attribute to * the required elements. This allows the end user to tab through the controls and press the enter key to activate them, allowing the * table controls to be accessible without a mouse. *

* The default tabindex is 0, meaning that the tab follows the flow of the document. You can overrule this using this parameter if you * wish. Use a value of -1 to disable built-in keyboard navigation, although this is not recommended for accessibility reasons. *

* Type * This option can be given in the following type(s): *

* integer * Default * Value: 0 * * @param tabIndex * * @return */ @SuppressWarnings("unchecked") @NotNull public J setTabIndex(Integer tabIndex) { this.tabIndex = tabIndex; return (J) this; } /** * ajaxSince: DataTables 1.10 * Load data for the table's content from an Ajax source. *

* Description * DataTables can obtain the data that it is to display in the table body from a number of sources, including from an Ajax data * source, using this initialisation parameter. As with other dynamic data sources, arrays or objects can be used for the data source * for each row, with columns.data employed to read from specific object properties. *

* The ajax property has three different modes of operation, depending on how it is defined. These are: *

* string - Set the URL from where the data should be loaded from. * object - Define properties for jQuery.ajax. * function - Custom data get function * * @return */ @NotNull @SuppressWarnings("unchecked") public DataTablesAjaxOptions getAjax() { if (ajax == null) { setAjax(new DataTablesAjaxOptions()); } return ajax; } /** * ajaxSince: DataTables 1.10 * Load data for the table's content from an Ajax source. *

* Description * DataTables can obtain the data that it is to display in the table body from a number of sources, including from an Ajax data * source, using this initialisation parameter. As with other dynamic data sources, arrays or objects can be used for the data source * for each row, with columns.data employed to read from specific object properties. *

* The ajax property has three different modes of operation, depending on how it is defined. These are: *

* string - Set the URL from where the data should be loaded from. * object - Define properties for jQuery.ajax. * function - Custom data get function * * @param ajax * * @return */ @SuppressWarnings("unchecked") @NotNull public J setAjax(DataTablesAjaxOptions ajax) { this.ajax = ajax; return (J) this; } public String getData() { return data; } @NotNull @SuppressWarnings("unchecked") public J setData(String data) { this.data = data; return (J) this; } /** * If the data table should be destroyed * * @return */ public Boolean getDestroy() { return destroy; } /** * If the data table should be destroyed * * @param destroy * * @return */ @NotNull @SuppressWarnings("unchecked") public J setDestroy(Boolean destroy) { this.destroy = destroy; return (J) this; } /** *

* As is described by the basic DOM positioning example you can use the dom initialisation parameter to move DataTables features * around the table to where you want them. *

* In addition to this, you can also use dom to create multiple instances of these table controls. Simply include the feature's * identification letter where you want it to appear, as many times as * you wish, and the controls will all sync up (note that obviously the table (t) should be included only once). *

* This is shown in the demo below where for four key build-in features are duplicated above and below the table. * * @return */ @SuppressWarnings("all") @NotNull public List getDom() { if (dom == null) { dom = new ArrayList<>(); } return dom; } /** * ColReorder adds the ability for the end user to be able to reorder columns in a DataTable through a click and drag operation. This * can be useful when presenting data in a table, letting the user move columns that they wish to compare next to each other for * easier comparison. *

* It is worth noting that the underlying column data structure of the DataTable is modified as part of this process - this is * important if you are interacting with the table using the API. * * @param dom * * @return */ @SuppressWarnings("all") @NotNull public J setDom(List dom) { this.dom = dom; return (J) this; } @JsonFormat(shape = JsonFormat.Shape.STRING) @JsonProperty("dom") private String jsonDom() { StringBuilder sb = new StringBuilder(); if (dom != null) { dom.forEach(a -> sb.append(a.toString())); } else { return null; } return sb.toString(); } /** * Returns the list of columns * * @return */ @NotNull public List> getColumns() { if (columns == null) { setColumns(new ArrayList<>()); } return columns; } /** * Sets the list of columns * * @param columns * * @return */ @NotNull @SuppressWarnings("unchecked") public J setColumns(List> columns) { this.columns = columns; return (J) this; } /** * Spreadsheets such as Excel and Google Docs have a very handy data duplication option of an auto fill tool. The AutoFill library for * DataTables provides a similar interface for DataTables and extends upon this interface paradigm to provide complex data * interaction options that the user can select between. *

* Download * The easiest way to get and use AutoFill is to use the DataTables download builder where you can select the software that you wish * to use on your page and have a single Javascript and CSS file created and hosted for you. * * @return */ @NotNull public DataTableAutoFillOptions getAutoFill() { if (autoFill == null) { setAutoFill(new DataTableAutoFillOptions()); DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.AutoFill); } return autoFill; } /** * Spreadsheets such as Excel and Google Docs have a very handy data duplication option of an auto fill tool. The AutoFill library for * DataTables provides a similar interface for DataTables and extends upon this interface paradigm to provide complex data * interaction options that the user can select between. *

* Download * The easiest way to get and use AutoFill is to use the DataTables download builder where you can select the software that you wish * to use on your page and have a single Javascript and CSS file created and hosted for you. * * @param autoFill * * @return */ @NotNull @SuppressWarnings("unchecked") public J setAutoFill(DataTableAutoFillOptions autoFill) { this.autoFill = autoFill; if (autoFill == null) { DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.AutoFill); } return (J) this; } /** * Buttons * A common UI paradigm to use with interactive tables is to present buttons that will trigger some action - that may be to alter the * table's state, modify the data in the table, gather the data from the table or even to activate some external process. Showing such * buttons is an interface that end users are comfortable with, making them feel at home with the table. *

* The Buttons library for DataTables provides a framework with common options and API that can be used with DataTables, but is also * very extensible, recognising that you will likely want to use buttons which perform an action unique to your applications. *

* Buttons has four sets of plug-ins that are part of the core software - they are not built into the core, but rather than be * included as and when you need them, selecting only the software you require. Other extensions such as Editor and Select also * provide buttons for use with this library, with actions unique to their own behaviours. This ensures a consistent interface for the * interactions performed with your tables. * * @return */ @NotNull public Set> getButtons() { if (buttons == null) { setButtons(new TreeSet<>()); DataTablePageConfigurator.configureButtons(); } return buttons; } /** * Buttons * A common UI paradigm to use with interactive tables is to present buttons that will trigger some action - that may be to alter the * table's state, modify the data in the table, gather the data from the table or even to activate some external process. Showing such * buttons is an interface that end users are comfortable with, making them feel at home with the table. *

* The Buttons library for DataTables provides a framework with common options and API that can be used with DataTables, but is also * very extensible, recognising that you will likely want to use buttons which perform an action unique to your applications. *

* Buttons has four sets of plug-ins that are part of the core software - they are not built into the core, but rather than be * included as and when you need them, selecting only the software you require. Other extensions such as Editor and Select also * provide buttons for use with this library, with actions unique to their own behaviours. This ensures a consistent interface for the * interactions performed with your tables. * * @param buttons * * @return */ @NotNull @SuppressWarnings("unchecked") public J setButtons(Set> buttons) { this.buttons = buttons; if (buttons != null) { DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.Buttons); DataTablePageConfigurator.configureButtons(); } return (J) this; } /** * ColReorder adds the ability for the end user to be able to reorder columns in a DataTable through a click and drag operation. This * can be useful when presenting data in a table, letting the user move columns that they wish to compare next to each other for * easier comparison. *

* It is worth noting that the underlying column data structure of the DataTable is modified as part of this process - this is * important if you are interacting with the table using the API. * * @return */ @NotNull public DataTableColReOrderOptions getColReorder() { if (colReorder == null) { setColReorder(new DataTableColReOrderOptions()); } return colReorder; } /** * ColReorder adds the ability for the end user to be able to reorder columns in a DataTable through a click and drag operation. This * can be useful when presenting data in a table, letting the user move columns that they wish to compare next to each other for * easier comparison. *

* It is worth noting that the underlying column data structure of the DataTable is modified as part of this process - this is * important if you are interacting with the table using the API. * * @param colReorder * * @return */ @NotNull @SuppressWarnings("unchecked") public J setColReorder(DataTableColReOrderOptions colReorder) { this.colReorder = colReorder; if (colReorder != null) { DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.ColReorder); DataTablePageConfigurator.getExtensions() .add(DataTableReferencePool.ColReorder.getJavaScriptReference()); } return (J) this; } /** * FixedColumns * When making use of DataTables' x-axis scrolling feature (scrollX), you may wish to fix the left or right most columns in place. * This extension for DataTables provides exactly this option (for non-scrolling tables, please use the FixedHeader extension, which * will create sticky headers and footers for tables). *

* Additional complexity * It is important to state up front that utilising FixedColumns in your DataTable can significantly increase the complexity of the * table and its use should not be undertaken lightly, particularly for complex tables. The reason for this is in how FixedColumns * operates - the fixed columns are actually separate tables from the original DataTable (i.e. they are separate table elements) which * are styled to look like they are visually part of the original table. These fixed tables are then positioned over the original * DataTable. *

* This means that any events attached to the DataTable need to also take into account the fixed tables. Equally, any updates that are * made to the original DataTable needs to also update the fixed tables! *

* If you refer to the DataTables compatibility chart you will be able to see that most incompatibilities are between FixedColumns and * the other extensions for exactly this reason. *

* This is not to say that FixedColumns is not useful - it absolutely can be. But you need to be aware of the additional complexity * that it will introduce into your software. * * @return */ @NotNull @SuppressWarnings("unchecked") public DataTableFixedColumnsOptions getFixedColumns() { if (fixedColumns == null) { setFixedColumns(new DataTableFixedColumnsOptions()); } return fixedColumns; } /** * FixedColumns * When making use of DataTables' x-axis scrolling feature (scrollX), you may wish to fix the left or right most columns in place. * This extension for DataTables provides exactly this option (for non-scrolling tables, please use the FixedHeader extension, which * will create sticky headers and footers for tables). *

* Additional complexity * It is important to state up front that utilising FixedColumns in your DataTable can significantly increase the complexity of the * table and its use should not be undertaken lightly, particularly for complex tables. The reason for this is in how FixedColumns * operates - the fixed columns are actually separate tables from the original DataTable (i.e. they are separate table elements) which * are styled to look like they are visually part of the original table. These fixed tables are then positioned over the original * DataTable. *

* This means that any events attached to the DataTable need to also take into account the fixed tables. Equally, any updates that are * made to the original DataTable needs to also update the fixed tables! *

* If you refer to the DataTables compatibility chart you will be able to see that most incompatibilities are between FixedColumns and * the other extensions for exactly this reason. *

* This is not to say that FixedColumns is not useful - it absolutely can be. But you need to be aware of the additional complexity * that it will introduce into your software. * * @param fixedColumns * * @return */ @NotNull @SuppressWarnings("unchecked") public J setFixedColumns(DataTableFixedColumnsOptions fixedColumns) { this.fixedColumns = fixedColumns; if (fixedColumns != null) { DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.FixedColumns); DataTablePageConfigurator.getExtensions() .add(DataTableReferencePool.FixedColumns.getJavaScriptReference()); } return (J) this; } /** * When displaying tables with a particularly large amount of data shown on each page, it can be useful to have the table's header and * / or footer fixed to the top or bottom of the scrolling window. This lets your users quickly determine what each column refers to * rather than needing to scroll back to the top of the table. *

* FixedHeader provides the ability to perform this action with DataTables tables. It operates by detaching the header and footer * elements from the host table and attaching them to the top or bottom of the screen as required by the scrolling position of the * window. This ensures that FixedColumns is fully compatible with DataTables and you can add complex interactions such as search * elements in the table footer, just as you would with any other table. *

* Please note that FixedHeader is not currently compatible with tables that have the scrolling features of DataTables enabled * (scrollX / scrollY). Please refer to the compatibility table for full compatibility details. * * @return */ @NotNull @SuppressWarnings("unchecked") public DataTableFixedHeaderOptions getFixedHeader() { if (fixedHeader == null) { setFixedHeader(new DataTableFixedHeaderOptions()); } return fixedHeader; } /** * When displaying tables with a particularly large amount of data shown on each page, it can be useful to have the table's header and * / or footer fixed to the top or bottom of the scrolling window. This lets your users quickly determine what each column refers to * rather than needing to scroll back to the top of the table. *

* FixedHeader provides the ability to perform this action with DataTables tables. It operates by detaching the header and footer * elements from the host table and attaching them to the top or bottom of the screen as required by the scrolling position of the * window. This ensures that FixedColumns is fully compatible with DataTables and you can add complex interactions such as search * elements in the table footer, just as you would with any other table. *

* Please note that FixedHeader is not currently compatible with tables that have the scrolling features of DataTables enabled * (scrollX / scrollY). Please refer to the compatibility table for full compatibility details. * * @param fixedHeader * * @return */ @NotNull @SuppressWarnings("unchecked") public J setFixedHeader(DataTableFixedHeaderOptions fixedHeader) { this.fixedHeader = fixedHeader; if (fixedHeader != null) { DataTablePageConfigurator.getPlugins() .add(FixedHeader); DataTablePageConfigurator.getExtensions() .add(DataTableReferencePool.FixedHeaders.getJavaScriptReference()); } return (J) this; } /** * keysSince: KeyTable KeyTable 2.0.0 * Enable and configure the KeyTable extension for DataTables. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * KeyTable is an extension for DataTables that provides spreadsheet like keyboard navigation in a table, with the focused cell being * movable with arrow keys, tab, home, end and page up / down. KeyTable will automatically adjust the table's paging and other * parameters to show the focused cell as the user navigates around the table. Combined with Editor it makes it super easy to create * an Excel like user interface in the browser. *

* This option provides the ability to enable and configure KeyTable for DataTables. In its simplest form as the boolean true it will * enable KeyTable with the default configuration options (as defined by $.fn.dataTable.KeyTable.defaults). It can also be used as an * object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for KeyTable, this option is an extension to the default set of DataTables * options. This property should be set in the DataTables initialisation object. * * @return */ @NotNull public DataTableKeyTableOptions getKeys() { if (keys == null) { setKeys(new DataTableKeyTableOptions()); } return keys; } /** * keysSince: KeyTable KeyTable 2.0.0 * Enable and configure the KeyTable extension for DataTables. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * KeyTable is an extension for DataTables that provides spreadsheet like keyboard navigation in a table, with the focused cell being * movable with arrow keys, tab, home, end and page up / down. KeyTable will automatically adjust the table's paging and other * parameters to show the focused cell as the user navigates around the table. Combined with Editor it makes it super easy to create * an Excel like user interface in the browser. *

* This option provides the ability to enable and configure KeyTable for DataTables. In its simplest form as the boolean true it will * enable KeyTable with the default configuration options (as defined by $.fn.dataTable.KeyTable.defaults). It can also be used as an * object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for KeyTable, this option is an extension to the default set of DataTables * options. This property should be set in the DataTables initialisation object. * * @param keys * * @return */ @SuppressWarnings("unchecked") public J setKeys(DataTableKeyTableOptions keys) { this.keys = keys; if (keys != null) { DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.KeyTable); DataTablePageConfigurator.getExtensions() .add(DataTableReferencePool.KeyTable.getJavaScriptReference()); } return (J) this; } /** * responsiveSince: Responsive Responsive 1.0.0 * Enable and configure the Responsive extension for DataTables. Please note - this property requires the Responsive extension for * DataTables. *

* Description * This option provides the ability to enable and configure Responsive for DataTables. In its simplest form as the boolean true it * will enable Responsive with the default configuration options (as defined by $.fn.dataTable.Responsive.defaults). It can also be * used as an object to provide custom configuration options as described below. *

*

* Please note that as with all other configuration options for Responsive, this option is an extension to the default set of * DataTables options. This property should be set in the DataTables initialisation object. * * @return */ @NotNull public DataTablesResponsiveOptions getResponsive() { if (responsive == null) { setResponsive(new DataTablesResponsiveOptions()); } return responsive; } /** * responsiveSince: Responsive Responsive 1.0.0 * Enable and configure the Responsive extension for DataTables. Please note - this property requires the Responsive extension for * DataTables. *

* Description * This option provides the ability to enable and configure Responsive for DataTables. In its simplest form as the boolean true it * will enable Responsive with the default configuration options (as defined by $.fn.dataTable.Responsive.defaults). It can also be * used as an object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for Responsive, this option is an extension to the default set of * DataTables options. This property should be set in the DataTables initialisation object. * * @param responsive * * @return */ @SuppressWarnings("unchecked") public J setResponsive(DataTablesResponsiveOptions responsive) { this.responsive = responsive; if (responsive != null) { DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.Responsive); DataTablePageConfigurator.getExtensions() .add(DataTableReferencePool.KeyTable.getJavaScriptReference()); } return (J) this; } /** * searchSince: DataTables 1.10 * Set an initial filter in DataTables and / or filtering options. *

* Description * The search option allows the way DataTables performs filtering to be set during the initialisation, and to set an initial global * filter. *

* The options that control how the filtering is performs are: *

* search.caseInsensitive - Indicate is case-insensitive sorting should be performed. * search.regex - Treat the search as a regular expression or not * search.smart - Use DataTables' smart filtering or not * Additionally, to set an initial filter: *

* search.search - Set an initial global filter. * * @return */ @NotNull public DataTablesSearchOptions getSearch() { if (search == null) { setSearch(new DataTablesSearchOptions()); } return search; } /** * searchSince: DataTables 1.10 * Set an initial filter in DataTables and / or filtering options. *

* Description * The search option allows the way DataTables performs filtering to be set during the initialisation, and to set an initial global * filter. *

* The options that control how the filtering is performs are: *

* search.caseInsensitive - Indicate is case-insensitive sorting should be performed. * search.regex - Treat the search as a regular expression or not * search.smart - Use DataTables' smart filtering or not * Additionally, to set an initial filter: *

* search.search - Set an initial global filter. * * @param search * * @return */ @SuppressWarnings("unchecked") @NotNull public J setSearch(DataTablesSearchOptions search) { this.search = search; return (J) this; } /** * searchColsSince: DataTables 1.10 * Define an initial search for individual columns. *

* Description * Basically the same as the search option, but in this case for individual columns, rather than the global filter, this option * defined the filtering to apply to the table during initialisation. *

* The array must be of the same size as the number of columns, and each element be an object with the parameters search and * escapeRegex (the latter is optional). 'null' is also accepted and the default will be used. *

* Type * This option can be given in the following type(s): *

* array * * @return */ @NotNull public List> getSearchCols() { if (searchCols == null) { setSearchCols(new ArrayList<>()); } return searchCols; } /** * searchColsSince: DataTables 1.10 * Define an initial search for individual columns. *

* Description * Basically the same as the search option, but in this case for individual columns, rather than the global filter, this option * defined the filtering to apply to the table during initialisation. *

* The array must be of the same size as the number of columns, and each element be an object with the parameters search and * escapeRegex (the latter is optional). 'null' is also accepted and the default will be used. *

* Type * This option can be given in the following type(s): *

* array * * @param searchCols * * @return */ @SuppressWarnings("unchecked") @NotNull public J setSearchCols(List> searchCols) { this.searchCols = searchCols; return (J) this; } /** * rowGroupSince: RowGroup RowGroup 1.0.0 * Enable and configure the RowGroup extension for DataTables. Please note - this property requires the RowGroup extension for * DataTables. *

* Description * RowGroup is an extension for DataTables that provides grouping capabilities (like all other DataTables extensions, the clue is in * the name!). A data point in the table's data is used to group information and then display grouping rows before and / or after the * group, with options to customise the display of those rows. *

* This option provides the ability to enable and configure RowGroup for DataTables. In its simplest form as the boolean true it will * enable RowGroup with the default configuration options (as defined by $.fn.dataTable.RowGroup.defaults). However, it is more likely * that you will wish to use it as an object to provide custom configuration options, particularly for the data parameter to use for * the grouping (rowGroup.dataSrc). *

* Please note that as with all other configuration options for RowGroup, this option is an extension to the default set of DataTables * options. This property should be set in the DataTables initialisation object. * * @return */ @NotNull public DataTablesRowGroupOptions getRowGroup() { if (rowGroup == null) { setRowGroup(new DataTablesRowGroupOptions<>()); } return rowGroup; } /** * rowGroupSince: RowGroup RowGroup 1.0.0 * Enable and configure the RowGroup extension for DataTables. Please note - this property requires the RowGroup extension for * DataTables. *

* Description * RowGroup is an extension for DataTables that provides grouping capabilities (like all other DataTables extensions, the clue is in * the name!). A data point in the table's data is used to group information and then display grouping rows before and / or after the * group, with options to customise the display of those rows. *

* This option provides the ability to enable and configure RowGroup for DataTables. In its simplest form as the boolean true it will * enable RowGroup with the default configuration options (as defined by $.fn.dataTable.RowGroup.defaults). However, it is more likely * that you will wish to use it as an object to provide custom configuration options, particularly for the data parameter to use for * the grouping (rowGroup.dataSrc). *

* Please note that as with all other configuration options for RowGroup, this option is an extension to the default set of DataTables * options. This property should be set in the DataTables initialisation object. * * @param rowGroup * * @return */ @NotNull @SuppressWarnings("unchecked") public J setRowGroup(DataTablesRowGroupOptions rowGroup) { this.rowGroup = rowGroup; if (rowGroup != null) { DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.RowGroup); } return (J) this; } /** * rowReorder * Enable and configure the RowReorder extension for DataTables. Please note - this property requires the RowReorder extension for * DataTables. *

* Description * This option provides the ability to enable and configure RowReorder for DataTables. In its simplest form as the boolean true it * will enable RowReorder with the default configuration options (as defined by $.fn.dataTable.RowReorder.defaults). It can also be * used as an object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for RowReorder, this option is an extension to the default set of * DataTables options. This property should be set in the DataTables initialisation object. * * @return */ @NotNull public DataTablesRowReorder getRowReorder() { if (rowReorder == null) { setRowReorder(new DataTablesRowReorder<>()); } return rowReorder; } /** * rowReorder * Enable and configure the RowReorder extension for DataTables. Please note - this property requires the RowReorder extension for * DataTables. *

* Description * This option provides the ability to enable and configure RowReorder for DataTables. In its simplest form as the boolean true it * will enable RowReorder with the default configuration options (as defined by $.fn.dataTable.RowReorder.defaults). It can also be * used as an object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for RowReorder, this option is an extension to the default set of * DataTables options. This property should be set in the DataTables initialisation object. * * @param rowReorder * * @return */ @NotNull @SuppressWarnings("unchecked") public J setRowReorder(DataTablesRowReorder rowReorder) { this.rowReorder = rowReorder; if (rowReorder != null) { DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.RowReorder); } return (J) this; } /** * scroller * Enable and configure the Scroller extension for DataTables. Please note - this property requires the Scroller extension for * DataTables. *

* Description * Scroller is an extension for DataTables that provides virtual rendering support - i.e. it will draw only the small visible section * of the table (plus a small overlap for smooth scrolling), even although in the scrolling viewport it will appear visually to the * end user that the whole table is available. This can significantly improve performance for large data sets where you don't wish to * display paging controls. *

* There are two important requirements to consider when using Scroller: *

* Paging must be enabled in DataTables (paging - it is by default) * All rows must be of equal height. This is to allow row height calculations for rows which have not yet been rendered. * This option provides the ability to enable and configure Scroller for DataTables. In its simplest form as the boolean true it will * enable Scroller with the default configuration options (as defined by $.fn.dataTable.Scroller.defaults). It can also be used as an * object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for Scroller, this option is an extension to the default set of DataTables * options. This property should be set in the DataTables initialisation object. * * @return */ @NotNull public DataTablesScrollerOptions getScroller() { if (scroller == null) { setScroller(new DataTablesScrollerOptions<>()); } return scroller; } /** * scroller * Enable and configure the Scroller extension for DataTables. Please note - this property requires the Scroller extension for * DataTables. *

* Description * Scroller is an extension for DataTables that provides virtual rendering support - i.e. it will draw only the small visible section * of the table (plus a small overlap for smooth scrolling), even although in the scrolling viewport it will appear visually to the * end user that the whole table is available. This can significantly improve performance for large data sets where you don't wish to * display paging controls. *

* There are two important requirements to consider when using Scroller: *

* Paging must be enabled in DataTables (paging - it is by default) * All rows must be of equal height. This is to allow row height calculations for rows which have not yet been rendered. * This option provides the ability to enable and configure Scroller for DataTables. In its simplest form as the boolean true it will * enable Scroller with the default configuration options (as defined by $.fn.dataTable.Scroller.defaults). It can also be used as an * object to provide custom configuration options as described below. *

* Please note that as with all other configuration options for Scroller, this option is an extension to the default set of DataTables * options. This property should be set in the DataTables initialisation object. * * @param scroller * * @return */ @NotNull @SuppressWarnings("unchecked") public J setScroller(DataTablesScrollerOptions scroller) { this.scroller = scroller; if (scroller != null) { DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.Scroller); } return (J) this; } /** * selectSince: Select 1.0.0 * Select configuration object. Please note - this property requires the Select extension for DataTables. *

* Description * This option can be used to configure the Select extension for DataTables during the initialisation of a DataTable. *

* When Select has been loaded on a page, all DataTables on that page have the ability to have items selected, but by default this can * only be done through the API - i.e. the end user will have no ability to select items in a table by default. To enable end user * selection, this option should be used (the select.style() method can also be used after initialisation). *

* Exactly what selection the user can make and how depends upon the options selected. * * @return */ @NotNull public DataTablesSelectOptions getSelect() { if (select == null) { setSelect(new DataTablesSelectOptions<>()); } return select; } /** * selectSince: Select 1.0.0 * Select configuration object. Please note - this property requires the Select extension for DataTables. *

* Description * This option can be used to configure the Select extension for DataTables during the initialisation of a DataTable. *

* When Select has been loaded on a page, all DataTables on that page have the ability to have items selected, but by default this can * only be done through the API - i.e. the end user will have no ability to select items in a table by default. To enable end user * selection, this option should be used (the select.style() method can also be used after initialisation). *

* Exactly what selection the user can make and how depends upon the options selected. * * @param select * * @return */ @NotNull @SuppressWarnings("unchecked") public J setSelect(DataTablesSelectOptions select) { this.select = select; if (select != null) { DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.Select); } return (J) this; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy