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

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

package com.jwebmp.plugins.datatable.options;

import com.jwebmp.core.htmlbuilder.javascript.JavaScriptPart;

import javax.validation.constraints.NotNull;

/**
 * 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 */ public class DataTablesScrollerOptions> extends JavaScriptPart { /** * scroller.boundaryScale * Set the point at which new data will be loaded and drawn. Please note - this property requires the Scroller extension for * DataTables. *

* Description * Scroller uses the boundary scaling factor to decide when to redraw the table - which it typically does before you reach the end of * the currently loaded data set (in order to allow the data to look continuous to a user scrolling through the data). If given as 0 * then the table will be redrawn whenever the viewport is scrolled, while 1 would not redraw the table until the currently loaded * data has all been shown. You will want something in the middle - the default factor of 0.5 is usually suitable. */ private Double boundaryScale; /** * scroller.displayBuffer * The amount of data that Scroller should pre-buffer to ensure smooth scrolling. Please note - this property requires the Scroller * extension for DataTables. *

* Description * To display a smooth scrolling table, Scroller will load more data than it actually needs to display in the viewport. This allows * the end user to scroll by small increments without the table needing to redraw. *

* The value given here determines how many rows of data Scroller will pre-fetch and draw. It is a multiplier that will be multiplied * by the number of rows that Scroller determines can fit into a viewport. For example if a viewport of 400px is used with 20px height * rows and the default of 9 is used for the display buffer, 180 rows will be loaded. The range of records will be split equally * between records before and after the instantaneous display start point. *

* Setting this value gives the ability to customise the balance between the performance enhancements offered by Scroller through its * ability to draw only a sub-set of the rows in the table, and the fact that a data redraw can be an expensive operation, * particularly if server-side processing is used and data must be loaded via Ajax. */ private Integer displayBuffer; /** * scroller.loadingIndicator * Display a loading message while Scroller is loading additional data. Please note - this property requires the Scroller extension * for DataTables. *

* Description * While scrolling quickly through a table it is quite possible that Scroller will not be able to display the data to shown in the * table as quickly as the user is scrolling (particularly if server-side processing is used - serverSide). *

* To indicate to the end user that something is happening while new data is being loaded, this option can be used to display a * loading message. The text shown is taken from the language.loadingRecords option. */ private Boolean loadingIndicator; /** * scroller.rowHeight * Set the row height, or how the row height is calculated. Please note - this property requires the Scroller extension for DataTables. *

* Description * It is important for Scroller to know the height of the rows in the DataTable so it can perform its virtual display calculations. * All rows must be of the same height, and Scroller will attempt to automatically calculate the height of rows itself. *

* However, the value that is used can be overridden using this parameter. Generally it is not recommended that this be used - it * offers little in the way of performance enhancements, although it can be useful if styling that alters the height of the rows is * applied to the table after initialisation. */ private Integer rowHeight; /** * scroller.serverWait * Time delay before new data is requested when server-side processing is enabled. Please note - this property requires the Scroller * extension for DataTables. *

* Description * When using server-side processing (serverSide), Scroller will wait a small amount of time to allow the scrolling to finish before * requesting more data from the server. This can be useful to help prevent you from DDoSing your own server with frequent Ajax * requests as the user scrolls through a table! *

* The wait time can be configured by this parameter. */ private Integer serverWait; /** * 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. */ public DataTablesScrollerOptions() { //No config required } /** * scroller.boundaryScale * Set the point at which new data will be loaded and drawn. Please note - this property requires the Scroller extension for * DataTables. *

* Description * Scroller uses the boundary scaling factor to decide when to redraw the table - which it typically does before you reach the end of * the currently loaded data set (in order to allow the data to look continuous to a user scrolling through the data). If given as 0 * then the table will be redrawn whenever the viewport is scrolled, while 1 would not redraw the table until the currently loaded * data has all been shown. You will want something in the middle - the default factor of 0.5 is usually suitable. * * @return */ public Double getBoundaryScale() { return boundaryScale; } /** * scroller.boundaryScale * Set the point at which new data will be loaded and drawn. Please note - this property requires the Scroller extension for * DataTables. *

* Description * Scroller uses the boundary scaling factor to decide when to redraw the table - which it typically does before you reach the end of * the currently loaded data set (in order to allow the data to look continuous to a user scrolling through the data). If given as 0 * then the table will be redrawn whenever the viewport is scrolled, while 1 would not redraw the table until the currently loaded * data has all been shown. You will want something in the middle - the default factor of 0.5 is usually suitable. * * @param boundaryScale * * @return */ @SuppressWarnings("unchecked") @NotNull public J setBoundaryScale(Double boundaryScale) { this.boundaryScale = boundaryScale; return (J) this; } /** * scroller.displayBuffer * The amount of data that Scroller should pre-buffer to ensure smooth scrolling. Please note - this property requires the Scroller * extension for DataTables. *

* Description * To display a smooth scrolling table, Scroller will load more data than it actually needs to display in the viewport. This allows * the end user to scroll by small increments without the table needing to redraw. *

* The value given here determines how many rows of data Scroller will pre-fetch and draw. It is a multiplier that will be multiplied * by the number of rows that Scroller determines can fit into a viewport. For example if a viewport of 400px is used with 20px height * rows and the default of 9 is used for the display buffer, 180 rows will be loaded. The range of records will be split equally * between records before and after the instantaneous display start point. *

* Setting this value gives the ability to customise the balance between the performance enhancements offered by Scroller through its * ability to draw only a sub-set of the rows in the table, and the fact that a data redraw can be an expensive operation, * particularly if server-side processing is used and data must be loaded via Ajax. * * @return */ public Integer getDisplayBuffer() { return displayBuffer; } /** * scroller.displayBuffer * The amount of data that Scroller should pre-buffer to ensure smooth scrolling. Please note - this property requires the Scroller * extension for DataTables. *

* Description * To display a smooth scrolling table, Scroller will load more data than it actually needs to display in the viewport. This allows * the end user to scroll by small increments without the table needing to redraw. *

* The value given here determines how many rows of data Scroller will pre-fetch and draw. It is a multiplier that will be multiplied * by the number of rows that Scroller determines can fit into a viewport. For example if a viewport of 400px is used with 20px height * rows and the default of 9 is used for the display buffer, 180 rows will be loaded. The range of records will be split equally * between records before and after the instantaneous display start point. *

* Setting this value gives the ability to customise the balance between the performance enhancements offered by Scroller through its * ability to draw only a sub-set of the rows in the table, and the fact that a data redraw can be an expensive operation, * particularly if server-side processing is used and data must be loaded via Ajax. * * @param displayBuffer * * @return */ @SuppressWarnings("unchecked") @NotNull public J setDisplayBuffer(Integer displayBuffer) { this.displayBuffer = displayBuffer; return (J) this; } /** * scroller.loadingIndicator * Display a loading message while Scroller is loading additional data. Please note - this property requires the Scroller extension * for DataTables. *

* Description * While scrolling quickly through a table it is quite possible that Scroller will not be able to display the data to shown in the * table as quickly as the user is scrolling (particularly if server-side processing is used - serverSide). *

* To indicate to the end user that something is happening while new data is being loaded, this option can be used to display a * loading message. The text shown is taken from the language.loadingRecords option. * * @return */ public Boolean getLoadingIndicator() { return loadingIndicator; } /** * scroller.loadingIndicator * Display a loading message while Scroller is loading additional data. Please note - this property requires the Scroller extension * for DataTables. *

* Description * While scrolling quickly through a table it is quite possible that Scroller will not be able to display the data to shown in the * table as quickly as the user is scrolling (particularly if server-side processing is used - serverSide). *

* To indicate to the end user that something is happening while new data is being loaded, this option can be used to display a * loading message. The text shown is taken from the language.loadingRecords option. * * @param loadingIndicator * * @return */ @SuppressWarnings("unchecked") @NotNull public J setLoadingIndicator(Boolean loadingIndicator) { this.loadingIndicator = loadingIndicator; return (J) this; } /** * scroller.rowHeight * Set the row height, or how the row height is calculated. Please note - this property requires the Scroller extension for DataTables. *

* Description * It is important for Scroller to know the height of the rows in the DataTable so it can perform its virtual display calculations. * All rows must be of the same height, and Scroller will attempt to automatically calculate the height of rows itself. *

* However, the value that is used can be overridden using this parameter. Generally it is not recommended that this be used - it * offers little in the way of performance enhancements, although it can be useful if styling that alters the height of the rows is * applied to the table after initialisation. * * @return */ public Integer getRowHeight() { return rowHeight; } /** * scroller.rowHeight * Set the row height, or how the row height is calculated. Please note - this property requires the Scroller extension for DataTables. *

* Description * It is important for Scroller to know the height of the rows in the DataTable so it can perform its virtual display calculations. * All rows must be of the same height, and Scroller will attempt to automatically calculate the height of rows itself. *

* However, the value that is used can be overridden using this parameter. Generally it is not recommended that this be used - it * offers little in the way of performance enhancements, although it can be useful if styling that alters the height of the rows is * applied to the table after initialisation. * * @param rowHeight * * @return */ @SuppressWarnings("unchecked") @NotNull public J setRowHeight(Integer rowHeight) { this.rowHeight = rowHeight; return (J) this; } /** * scroller.serverWait * Time delay before new data is requested when server-side processing is enabled. Please note - this property requires the Scroller * extension for DataTables. *

* Description * When using server-side processing (serverSide), Scroller will wait a small amount of time to allow the scrolling to finish before * requesting more data from the server. This can be useful to help prevent you from DDoSing your own server with frequent Ajax * requests as the user scrolls through a table! *

* The wait time can be configured by this parameter. * * @return */ public Integer getServerWait() { return serverWait; } /** * scroller.serverWait * Time delay before new data is requested when server-side processing is enabled. Please note - this property requires the Scroller * extension for DataTables. *

* Description * When using server-side processing (serverSide), Scroller will wait a small amount of time to allow the scrolling to finish before * requesting more data from the server. This can be useful to help prevent you from DDoSing your own server with frequent Ajax * requests as the user scrolls through a table! *

* The wait time can be configured by this parameter. * * @param serverWait * * @return */ @SuppressWarnings("unchecked") @NotNull public J setServerWait(Integer serverWait) { this.serverWait = serverWait; return (J) this; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy