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

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

/*
 * Copyright (C) 2017 GedMarc
 *
 * 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.base.ComponentHierarchyBase;
import com.jwebmp.core.base.servlets.enumarations.ComponentTypes;
import com.jwebmp.core.htmlbuilder.javascript.JavaScriptPart;
import com.jwebmp.plugins.datatable.DataTablePageConfigurator;
import com.jwebmp.plugins.datatable.enumerations.DataTablePlugins;
import com.jwebmp.plugins.datatable.enumerations.DataTableSorts;
import com.jwebmp.plugins.datatable.enumerations.DataTablesSortables;

import javax.validation.constraints.NotNull;
import java.util.ArrayList;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Set;

import static com.fasterxml.jackson.annotation.JsonAutoDetect.Visibility.*;
import static com.fasterxml.jackson.annotation.JsonInclude.Include.*;

/**
 * The options allowed for a data table columns
 * This columnDefs.targets option provides the information required by DataTables for which columns in the table the column definition
 * object should be applied.
 * 

* It can be: *

* 0 or a positive integer - column index counting from the left * A negative integer - column index counting from the right * A string - class name will be matched on the TH for the column (without a leading .) * The string "_all" - all columns (i.e. assign a default) * Additionally, targets can be either a single option from the list above, or an array of options (the different types can be mixed in * the array if required). For example targets: [ -1, -2 ] would target the last and second last columns in the table. * * @param */ @JsonAutoDetect(fieldVisibility = ANY, getterVisibility = NONE, setterVisibility = NONE) @JsonInclude(NON_NULL) @JsonIgnoreProperties(ignoreUnknown = true) public class DataTableColumnOptions> extends JavaScriptPart { private String name; /** * This columnDefs.targets option provides the information required by DataTables for which columns in the table the column definition * object should be applied. *

* It can be: *

* 0 or a positive integer - column index counting from the left * A negative integer - column index counting from the right * A string - class name will be matched on the TH for the column (without a leading .) * The string "_all" - all columns (i.e. assign a default) * Additionally, targets can be either a single option from the list above, or an array of options (the different types can be mixed * in the array if required). For example targets: [ -1, -2 ] would target the last and second last columns in the table. */ private Integer targets; /** * Change the cell type created for the column - either TD cells or TH cells. *

* This can be useful as TH cells have semantic meaning in the table body, allowing them to act as a header for a row (you may wish to * add scope='row' to the TH elements using columns.createdCell option). *

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

* string * Default */ private ComponentTypes cellType; /** * Description * Quite simply this option adds a class to each cell in a column, regardless of if the table source is from DOM, Javascript or Ajax. * This can be useful for styling columns. *

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

* string */ private String className; /** * Description * The first thing to say about this property is that generally you shouldn't need this! *

* Having said that, it can be useful on rare occasions. When DataTables calculates the column widths to assign to each column, it * finds the longest string in each column and then constructs a temporary table and reads the widths from that. The problem with this * is that "mmm" is much wider then "iiii", but the latter is a longer string - thus the calculation can go wrong (doing it properly * and putting it into an DOM object and measuring that is horribly slow!). Thus as a "work around" we provide this option. It will * append its value to the text that is found to be the longest string for the column - i.e. padding. */ private String contentPadding; /** * Description * Often you may wish to have static content in a column, for example simple edit and / or delete buttons, which have events assigned * to them. This option is available for those use cases - creating static content for a column. If you wish to create dynamic content * (i.e. based on other data in the row), the columns.render option should be used. *

* Additionally, this option can be useful when loading JSON data, as the value set here will be used if the cell value from the JSON * is found to be null (for example, you might set a default string of Not available. *

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

* string */ @JsonIgnore private ComponentHierarchyBase defaultContent; /** * Description * Using this parameter, you can remove the end user's ability to order upon a column. This might be useful for generated content * columns, for example if you have 'Edit' or 'Delete' buttons in the table. *

* Note that this option only effects the end user's ability to order a column. Developers are still able to order a column using the * order option or the order() method if required. *

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

* boolean */ private Boolean orderable; /** * Description * Allows a column's sorting to take either the data from a different (often hidden) column as the data to sort, or data from multiple * columns. *

* A common example of this is a table which contains first and last name columns next to each other, it is intuitive that they would * be linked together to multi-column sort. Another example, with a single column, is the case where the data shown to the end user is * not directly sortable itself (a column with images in it), but there is some meta data than can be sorted (e.g. file name) - note * that orthogonal data is an alternative method that can be used for this. */ private Set orderData; /** * Description * DataTables' primary order method (the ordering feature) makes use of data that has been cached in memory rather than reading the * data directly from the DOM every time an order is performed for performance reasons (reading from the DOM is inherently slow). * However, there are times when you do actually want to read directly from the DOM, acknowledging that there will be a performance * hit, for example when you have form elements in the table and the end user can alter the values. This configuration option is * provided to allow plug-ins to provide this capability in DataTables. *

* Please note that there are no columns.orderDataType plug-ins built into DataTables, they must be added separately. See the * DataTables sorting plug-ins page for further information. */ private Set orderDataType; /** * Description * You can control the default ordering direction, and even alter the behaviour of the order handler (i.e. only allow ascending * sorting etc) using this parameter. *

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

* array * Default * Value: [ 'asc', 'desc' ] */ private List orderSequence; /** * Allows this column to be searchable */ private Boolean searchable; /** * Description * The titles of columns are typically read directly from the DOM (from the cells in the THEAD element), but it can often be useful to * either override existing values, or have DataTables actually construct a header with column titles for you (for example if there is * not THEAD element in the table before DataTables is constructed). This option is available to provide that ability. *

* Please note that when constructing a header, DataTables can only construct a simple header with a single cell for each column. * Complex headers with colspan and rowspan attributes must either already be defined in the document, or be constructed using * standard DOM / jQuery methods. */ private String title; /** * escription * DataTables and show and hide columns dynamically through use of this option and the column().visible() / columns().visible() * methods. This option can be used to get the initial visibility state of the column, with the API methods used to alter that state * at a later time. *

* This can be particularly useful if your table holds a large number of columns and you wish the user to have the ability to control * which columns they can see, or you have data in the table that the end user shouldn't see (for example a database ID column). *

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

* boolean */ private Boolean visible; /** * Description * This parameter can be used to define the width of a column, and may take any CSS value (3em, 20px etc). *

* Please note that pixel perfect column width is virtually impossible to achieve in tables with dynamic content, so do not be * surprised if the width of the column if off by a few pixels from what you assign using this property. Column width in tables * depends upon many properties such as cell borders, table borders, the border-collapse property, the content of the table and many * other properties. Both DataTables and the browsers attempt to lay the table out in an optimal manner taking this options all into * account. *

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

* string * Default * Auto-detected from the table's content. */ private Integer width; /** * columns.responsivePrioritySince: Responsive Responsive 2.0.0 * Set column's visibility priority. Please note - this property requires the Responsive extension for DataTables. *

* Description * Responsive will automatically remove columns from the right-hand-side of the table when it needs to hide columns when a table is * too wide for a given display. Although this is a useful default, this behaviour might not always suit your needs and you want to * control the order in which columns are hidden. This parameter provides that ability by setting a visibility priority order. *

* The value given will set the column's visibility priority with a lower number representing a higher priority in terms of staying * visible in the table. For example a column with a priority of 2 will be removed from the display before a column with priority 1, * regardless of the order that they appear in the table. *

* This can be particularly useful for cases where you wish to keep the right hand column(s) visible if they contain action buttons or * other important information. *

* The column priority can also be defined by a data-priority attribute on the column's header cell (for example>th * data-priority="1"<First name>/th<). If both a data-priority attribute and a columns.responsivePriority value has been set * for a * single column, the columns.responsivePriority value will always be used. */ private Integer responsivePriority; /** * This columnDefs.targets option provides the information required by DataTables for which columns in the table the column definition * object should be applied. *

* It can be: *

* 0 or a positive integer - column index counting from the left * A negative integer - column index counting from the right * A string - class name will be matched on the TH for the column (without a leading .) * The string "_all" - all columns (i.e. assign a default) * Additionally, targets can be either a single option from the list above, or an array of options (the different types can be mixed * in the array if required). For example targets: [ -1, -2 ] would target the last and second last columns in the table. * * @param name */ public DataTableColumnOptions(@NotNull String name) { this.name = name; } /** * @return */ @NotNull public String getName() { return name; } @SuppressWarnings({"unchecked"}) @NotNull public J setName(String name) { this.name = name; return (J) this; } /** * This columnDefs.targets option provides the information required by DataTables for which columns in the table the column definition * object should be applied. *

* It can be: *

* 0 or a positive integer - column index counting from the left * A negative integer - column index counting from the right * A string - class name will be matched on the TH for the column (without a leading .) * The string "_all" - all columns (i.e. assign a default) * Additionally, targets can be either a single option from the list above, or an array of options (the different types can be mixed * in the array if required). For example targets: [ -1, -2 ] would target the last and second last columns in the table. * * @return */ public Integer getTargets() { return targets; } /** * This columnDefs.targets option provides the information required by DataTables for which columns in the table the column definition * object should be applied. *

* It can be: *

* 0 or a positive integer - column index counting from the left * A negative integer - column index counting from the right * A string - class name will be matched on the TH for the column (without a leading .) * The string "_all" - all columns (i.e. assign a default) * Additionally, targets can be either a single option from the list above, or an array of options (the different types can be mixed * in the array if required). For example targets: [ -1, -2 ] would target the last and second last columns in the table. * * @param targets * * @return */ @NotNull @SuppressWarnings("unchecked") public J setTargets(Integer targets) { this.targets = targets; return (J) this; } /** * Change the cell type created for the column - either TD cells or TH cells. *

* This can be useful as TH cells have semantic meaning in the table body, allowing them to act as a header for a row (you may wish to * add scope='row' to the TH elements using columns.createdCell option). *

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

* string * Default * * @return */ public ComponentTypes getCellType() { return cellType; } /** * Change the cell type created for the column - either TD cells or TH cells. *

* This can be useful as TH cells have semantic meaning in the table body, allowing them to act as a header for a row (you may wish to * add scope='row' to the TH elements using columns.createdCell option). *

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

* string * Default * * @param cellType * * @return */ @NotNull @SuppressWarnings("unchecked") public J setCellType(ComponentTypes cellType) { this.cellType = cellType; return (J) this; } /** * Description * Quite simply this option adds a class to each cell in a column, regardless of if the table source is from DOM, Javascript or Ajax. * This can be useful for styling columns. *

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

* string * * @return */ public String getClassName() { return className; } /** * Description * Quite simply this option adds a class to each cell in a column, regardless of if the table source is from DOM, Javascript or Ajax. * This can be useful for styling columns. *

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

* string * * @param className * * @return */ @NotNull @SuppressWarnings("unchecked") public J setClassName(String className) { this.className = className; return (J) this; } /** * Use mmm or iii * Description * The first thing to say about this property is that generally you shouldn't need this! *

* Having said that, it can be useful on rare occasions. When DataTables calculates the column widths to assign to each column, it * finds the longest string in each column and then constructs a temporary table and reads the widths from that. The problem with this * is that "mmm" is much wider then "iiii", but the latter is a longer string - thus the calculation can go wrong (doing it properly * and putting it into an DOM object and measuring that is horribly slow!). Thus as a "work around" we provide this option. It will * append its value to the text that is found to be the longest string for the column - i.e. padding. * * @return */ public String getContentPadding() { return contentPadding; } /** * Use mmm or iii *

* Description * The first thing to say about this property is that generally you shouldn't need this! *

* Having said that, it can be useful on rare occasions. When DataTables calculates the column widths to assign to each column, it * finds the longest string in each column and then constructs a temporary table and reads the widths from that. The problem with this * is that "mmm" is much wider then "iiii", but the latter is a longer string - thus the calculation can go wrong (doing it properly * and putting it into an DOM object and measuring that is horribly slow!). Thus as a "work around" we provide this option. It will * append its value to the text that is found to be the longest string for the column - i.e. padding. * * @param contentPadding * * @return */ @NotNull @SuppressWarnings("unchecked") public J setContentPadding(String contentPadding) { this.contentPadding = contentPadding; return (J) this; } @JsonProperty("defaultContent") @SuppressWarnings("unused") private String getDefaultContentJson() { if (defaultContent == null) { return null; } defaultContent.setTiny(true); return defaultContent.toString(0); } /** * Description * Often you may wish to have static content in a column, for example simple edit and / or delete buttons, which have events assigned * to them. This option is available for those use cases - creating static content for a column. If you wish to create dynamic content * (i.e. based on other data in the row), the columns.render option should be used. *

* Additionally, this option can be useful when loading JSON data, as the value set here will be used if the cell value from the JSON * is found to be null (for example, you might set a default string of Not available. *

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

* string * * @return */ public ComponentHierarchyBase getDefaultContent() { return defaultContent; } /** * Description * Often you may wish to have static content in a column, for example simple edit and / or delete buttons, which have events assigned * to them. This option is available for those use cases - creating static content for a column. If you wish to create dynamic content * (i.e. based on other data in the row), the columns.render option should be used. *

* Additionally, this option can be useful when loading JSON data, as the value set here will be used if the cell value from the JSON * is found to be null (for example, you might set a default string of Not available. *

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

* string * * @param defaultContent * * @return */ @NotNull @SuppressWarnings("unchecked") public J setDefaultContent(ComponentHierarchyBase defaultContent) { this.defaultContent = defaultContent; return (J) this; } /** * Description * Using this parameter, you can remove the end user's ability to order upon a column. This might be useful for generated content * columns, for example if you have 'Edit' or 'Delete' buttons in the table. *

* Note that this option only effects the end user's ability to order a column. Developers are still able to order a column using the * order option or the order() method if required. *

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

* boolean * * @return */ public Boolean getOrderable() { return orderable; } /** * Description * Using this parameter, you can remove the end user's ability to order upon a column. This might be useful for generated content * columns, for example if you have 'Edit' or 'Delete' buttons in the table. *

* Note that this option only effects the end user's ability to order a column. Developers are still able to order a column using the * order option or the order() method if required. *

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

* boolean * * @param orderable * * @return */ @NotNull @SuppressWarnings("unchecked") public J setOrderable(Boolean orderable) { this.orderable = orderable; return (J) this; } /** * Description * Allows a column's sorting to take either the data from a different (often hidden) column as the data to sort, or data from multiple * columns. *

* A common example of this is a table which contains first and last name columns next to each other, it is intuitive that they would * be linked together to multi-column sort. Another example, with a single column, is the case where the data shown to the end user is * not directly sortable itself (a column with images in it), but there is some meta data than can be sorted (e.g. file name) - note * that orthogonal data is an alternative method that can be used for this. * * @return */ public Set getOrderData() { if (orderData == null) { orderData = new LinkedHashSet<>(); } return orderData; } /** * Description * Allows a column's sorting to take either the data from a different (often hidden) column as the data to sort, or data from multiple * columns. *

* A common example of this is a table which contains first and last name columns next to each other, it is intuitive that they would * be linked together to multi-column sort. Another example, with a single column, is the case where the data shown to the end user is * not directly sortable itself (a column with images in it), but there is some meta data than can be sorted (e.g. file name) - note * that orthogonal data is an alternative method that can be used for this. * * @param orderData * * @return */ @NotNull @SuppressWarnings("unchecked") public J setOrderData(Set orderData) { this.orderData = orderData; return (J) this; } /** * Description * DataTables' primary order method (the ordering feature) makes use of data that has been cached in memory rather than reading the * data directly from the DOM every time an order is performed for performance reasons (reading from the DOM is inherently slow). * However, there are times when you do actually want to read directly from the DOM, acknowledging that there will be a performance * hit, for example when you have form elements in the table and the end user can alter the values. This configuration option is * provided to allow plug-ins to provide this capability in DataTables. *

* Please note that there are no columns.orderDataType plug-ins built into DataTables, they must be added separately. See the * DataTables sorting plug-ins page for further information. * * @return */ public Set getOrderDataType() { if (orderDataType == null) { orderDataType = new LinkedHashSet<>(); } return orderDataType; } /** * Description * DataTables' primary order method (the ordering feature) makes use of data that has been cached in memory rather than reading the * data directly from the DOM every time an order is performed for performance reasons (reading from the DOM is inherently slow). * However, there are times when you do actually want to read directly from the DOM, acknowledging that there will be a performance * hit, for example when you have form elements in the table and the end user can alter the values. This configuration option is * provided to allow plug-ins to provide this capability in DataTables. *

* Please note that there are no columns.orderDataType plug-ins built into DataTables, they must be added separately. See the * DataTables sorting plug-ins page for further information. * * @param orderDataType * * @return */ @NotNull @SuppressWarnings("unchecked") public J setOrderDataType(Set orderDataType) { this.orderDataType = orderDataType; return (J) this; } /** * Description * You can control the default ordering direction, and even alter the behaviour of the order handler (i.e. only allow ascending * sorting etc) using this parameter. *

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

* array * Default * Value: [ 'asc', 'desc' ] * * @return */ @NotNull @SuppressWarnings("unchecked") public List getOrderSequence() { if (orderSequence == null) { orderSequence = new ArrayList<>(); } return orderSequence; } /** * Description * You can control the default ordering direction, and even alter the behaviour of the order handler (i.e. only allow ascending * sorting etc) using this parameter. *

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

* array * Default * Value: [ 'asc', 'desc' ] * * @param orderSequence * * @return */ @NotNull @SuppressWarnings("unchecked") public J setOrderSequence(List orderSequence) { this.orderSequence = orderSequence; return (J) this; } /** * Description * Using this parameter, you can defined if DataTables should include this column in the filterable data in the table. You may want * use this option to display filtering on generated columns such as 'Edit' and 'Delete' buttons for example. *

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

* boolean * * @return */ public Boolean getSearchable() { return searchable; } /** * Description * Using this parameter, you can defined if DataTables should include this column in the filterable data in the table. You may want * use this option to display filtering on generated columns such as 'Edit' and 'Delete' buttons for example. *

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

* boolean * * @param searchable * * @return */ @NotNull @SuppressWarnings("unchecked") public J setSearchable(Boolean searchable) { this.searchable = searchable; return (J) this; } /** * Description * The titles of columns are typically read directly from the DOM (from the cells in the THEAD element), but it can often be useful to * either override existing values, or have DataTables actually construct a header with column titles for you (for example if there is * not THEAD element in the table before DataTables is constructed). This option is available to provide that ability. *

* Please note that when constructing a header, DataTables can only construct a simple header with a single cell for each column. * Complex headers with colspan and rowspan attributes must either already be defined in the document, or be constructed using * standard DOM / jQuery methods. * * @return */ public String getTitle() { return title; } /** * Description * The titles of columns are typically read directly from the DOM (from the cells in the THEAD element), but it can often be useful to * either override existing values, or have DataTables actually construct a header with column titles for you (for example if there is * not THEAD element in the table before DataTables is constructed). This option is available to provide that ability. *

* Please note that when constructing a header, DataTables can only construct a simple header with a single cell for each column. * Complex headers with colspan and rowspan attributes must either already be defined in the document, or be constructed using * standard DOM / jQuery methods. * * @param title * * @return */ @NotNull @SuppressWarnings("unchecked") public J setTitle(String title) { this.title = title; return (J) this; } /** * Description * DataTables and show and hide columns dynamically through use of this option and the column().visible() / columns().visible() * methods. This option can be used to get the initial visibility state of the column, with the API methods used to alter that state * at a later time. *

* This can be particularly useful if your table holds a large number of columns and you wish the user to have the ability to control * which columns they can see, or you have data in the table that the end user shouldn't see (for example a database ID column). *

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

* boolean * * @return */ public Boolean getVisible() { return visible; } /** * Description * DataTables and show and hide columns dynamically through use of this option and the column().visible() / columns().visible() * methods. This option can be used to get the initial visibility state of the column, with the API methods used to alter that state * at a later time. *

* This can be particularly useful if your table holds a large number of columns and you wish the user to have the ability to control * which columns they can see, or you have data in the table that the end user shouldn't see (for example a database ID column). *

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

* boolean * * @param visible * * @return */ @NotNull @SuppressWarnings("unchecked") public J setVisible(Boolean visible) { this.visible = visible; return (J) this; } /** * Description * This parameter can be used to define the width of a column, and may take any CSS value (3em, 20px etc). *

* Please note that pixel perfect column width is virtually impossible to achieve in tables with dynamic content, so do not be * surprised if the width of the column if off by a few pixels from what you assign using this property. Column width in tables * depends upon many properties such as cell borders, table borders, the border-collapse property, the content of the table and many * other properties. Both DataTables and the browsers attempt to lay the table out in an optimal manner taking this options all into * account. *

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

* string * Default * Auto-detected from the table's content. * * @return */ public Integer getWidth() { return width; } /** * Description * This parameter can be used to define the width of a column, and may take any CSS value (3em, 20px etc). *

* Please note that pixel perfect column width is virtually impossible to achieve in tables with dynamic content, so do not be * surprised if the width of the column if off by a few pixels from what you assign using this property. Column width in tables * depends upon many properties such as cell borders, table borders, the border-collapse property, the content of the table and many * other properties. Both DataTables and the browsers attempt to lay the table out in an optimal manner taking this options all into * account. *

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

* string * Default * Auto-detected from the table's content. * * @param width */ @NotNull @SuppressWarnings("unchecked") public J setWidth(Integer width) { this.width = width; return (J) this; } /** * columns.responsivePrioritySince: Responsive Responsive 2.0.0 * Set column's visibility priority. Please note - this property requires the Responsive extension for DataTables. *

* Description * Responsive will automatically remove columns from the right-hand-side of the table when it needs to hide columns when a table is * too wide for a given display. Although this is a useful default, this behaviour might not always suit your needs and you want to * control the order in which columns are hidden. This parameter provides that ability by setting a visibility priority order. *

* The value given will set the column's visibility priority with a lower number representing a higher priority in terms of staying * visible in the table. For example a column with a priority of 2 will be removed from the display before a column with priority 1, * regardless of the order that they appear in the table. *

* This can be particularly useful for cases where you wish to keep the right hand column(s) visible if they contain action buttons or * other important information. *

* The column priority can also be defined by a data-priority attribute on the column's header cell (for example th * data-priority="1"First name"th). If both a data-priority attribute and a columns.responsivePriority value has been set for a * single column, the columns.responsivePriority value will always be used. * * @return */ public Integer getResponsivePriority() { return responsivePriority; } /** * columns.responsivePrioritySince: Responsive Responsive 2.0.0 * Set column's visibility priority. Please note - this property requires the Responsive extension for DataTables. *

* Description * Responsive will automatically remove columns from the right-hand-side of the table when it needs to hide columns when a table is * too wide for a given display. Although this is a useful default, this behaviour might not always suit your needs and you want to * control the order in which columns are hidden. This parameter provides that ability by setting a visibility priority order. *

* The value given will set the column's visibility priority with a lower number representing a higher priority in terms of staying * visible in the table. For example a column with a priority of 2 will be removed from the display before a column with priority 1, * regardless of the order that they appear in the table. *

* This can be particularly useful for cases where you wish to keep the right hand column(s) visible if they contain action buttons or * other important information. *

* The column priority can also be defined by a data-priority attribute on the column's header cell (for example>th * data-priority="1"<First name>/th<). If both a data-priority attribute and a columns.responsivePriority value has been set for a * single column, the columns.responsivePriority value will always be used. * * @param responsivePriority * * @return */ @SuppressWarnings("unchecked") @NotNull public J setResponsivePriority(Integer responsivePriority) { this.responsivePriority = responsivePriority; if (this.responsivePriority != null) { DataTablePageConfigurator.getPlugins() .add(DataTablePlugins.Responsive); } return (J) this; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy