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

com.jwebmp.plugins.datatable.options.buttons.DataTablesButtonButtonsOptions 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.buttons;

import com.fasterxml.jackson.annotation.JsonProperty;
import com.jwebmp.core.htmlbuilder.javascript.JavaScriptPart;
import com.jwebmp.plugins.datatable.enumerations.DataTableButtons;
import com.jwebmp.plugins.datatable.enumerations.DataTablesButtonKeys;

import javax.validation.constraints.NotNull;
import java.util.LinkedHashMap;
import java.util.Map;

/**
 * buttons.buttonsSince: Buttons 1.0.0
 * List of buttons to be created. Please note - this property requires the Buttons extension for DataTables.
 * 

* Description * The buttons array defines the buttons that will appear in the document to the end user. Each element in the array can be one of: *

* string - The name of a built-in button type or plug-in button type. This is the equivalent of using { extend: ... }. * object - A custom button or a customisation of an existing button type. The extend property (see buttons.buttons.extend) can be * defined to tell Buttons which button type to base the button on, and any of the configuration options you wish to customise. * Alternatively, if the extend option is not given, use the text and action options to define a button. Buttons has only a few built in * configuration options for each button, but the various button types may provide additional options. Please refer to the documentation * for each button type for information on the further options they provide. * * @param */ public class DataTablesButtonButtonsOptions> extends JavaScriptPart implements Comparable> { /** * buttons.buttons.attrSince: Buttons 1.5.0 * Collection of attribute key / values to set for a button. Please note - this property requires the Buttons extension for DataTables. *

* Description * This option provides the ability to set any arbitrary attribute on the button's HTML element in the document. This can be useful * for customisation of attributes such as ARIA assistive attributes, setting a custom id for selection / styling, custom data * parameters, etc. */ @JsonProperty("attr") private Map buttonAttributes; /** * buttons.buttons.classNameSince: Buttons 1.0.0 * Set the class name for the button. Please note - this property requires the Buttons extension for DataTables. *

* Description * The ability to set a class name for a button can be useful both for styling the button and also for selection and manipulation via * the API (buttons() for example). This option provides exactly that ability. *

* The class name defined here is added to the class name defined by buttons.buttons.className, so the button will likely have two or * more class names assigned to it. *

* Please note that most buttons will define their own class name so they will be style-able without being required to add a custom * class name using you are extending an existing button. Please refer to the documentation for each button type for their default * class name. *

* Additionally, if you extend a button that has its own class name defined, any classes you set will automatically be appended to the * extended button's class. It will not overwrite the original class. */ private String className; /** * buttons.buttons.enabledSince: Buttons 1.0.0 * Set a button's initial enabled state. Please note - this property requires the Buttons extension for DataTables. *

* Description * This option provides the ability to set the initial enabled state of a button using a boolean value. It is most likely to be of use * when using the API methods that can control the button's enabled state after initialisation: *

* buttons().enab */ private Boolean enabled; /** * buttons.buttons.keySince: Buttons 1.0.0 * Define an activation key for a button. Please note - this property requires the Buttons extension for DataTables. *

* Description * Buttons has the built in ability to activate buttons through keyboard key presses and key combinations. This is to aid * accessibility and provide complete keyboard navigation of your table. For example, with using Editor, records can be added, edited * and deleted without touching the mouse! *

* Key presses are only processed when the document has no element that is actively focused. This means that typing into an input * element will not accidentally trigger a button's action! *

* Please note that for Adobe Flash based buttons, key activation simply will not work! This is a security feature implemented by * Adobe - such buttons must be clicked on to activate them. */ private DataTablesButtonKeys key; /** * buttons.buttons.nameSince: Buttons 1.0.0 * Set a name for each selection. Please note - this property requires the Buttons extension for DataTables. *

* Description * The buttons() and button() API methods provide the ability to use a button-selector to be able to select one or more buttons in one * or more Buttons instances. In turn the button selector provides an option to easily select a button by using a predefined name * (thus removing any complexities that might occur if using index selection). This option provides the ability to set that name. *

* Multiple buttons can share the same name, they need not be unique, but please be aware that they will always be selected together * if using a name selector. */ private String name; /** * buttons.buttons.textSince: Buttons 1.0.0 * The text to show in the button. Please note - this property requires the Buttons extension for DataTables. *

* Description * Being able to let your users know what will happen when they activate a button is obviously fundamentally important to the Buttons * extension and this option provides exactly that ability */ private String text; @JsonProperty("titleAttr") private String titleAttribute; /** * A predefined button to extend */ private DataTableButtons extend; /** * buttons.buttonsSince: Buttons 1.0.0 * List of buttons to be created. Please note - this property requires the Buttons extension for DataTables. *

* Description * The buttons array defines the buttons that will appear in the document to the end user. Each element in the array can be one of: *

* string - The name of a built-in button type or plug-in button type. This is the equivalent of using { extend: ... }. * object - A custom button or a customisation of an existing button type. The extend property (see buttons.buttons.extend) can be * defined to tell Buttons which button type to base the button on, and any of the configuration options you wish to customise. * Alternatively, if the extend option is not given, use the text and action options to define a button. Buttons has only a few built * in configuration options for each button, but the various button types may provide additional options. Please refer to the * documentation for each button type for information on the further options they provide. */ public DataTablesButtonButtonsOptions() { //No config required } /** * buttons.buttons.attrSince: Buttons 1.5.0 * Collection of attribute key / values to set for a button. Please note - this property requires the Buttons extension for DataTables. *

* Description * This option provides the ability to set any arbitrary attribute on the button's HTML element in the document. This can be useful * for customisation of attributes such as ARIA assistive attributes, setting a custom id for selection / styling, custom data * parameters, etc. * * @return */ public Map getButtonAttributes() { if (buttonAttributes == null) { buttonAttributes = new LinkedHashMap<>(); } return buttonAttributes; } /** * buttons.buttons.attrSince: Buttons 1.5.0 * Collection of attribute key / values to set for a button. Please note - this property requires the Buttons extension for DataTables. *

* Description * This option provides the ability to set any arbitrary attribute on the button's HTML element in the document. This can be useful * for customisation of attributes such as ARIA assistive attributes, setting a custom id for selection / styling, custom data * parameters, etc. * * @param buttonAttributes * * @return */ @SuppressWarnings("unchecked") @NotNull public J setButtonAttributes(Map buttonAttributes) { this.buttonAttributes = buttonAttributes; return (J) this; } /** * buttons.buttons.classNameSince: Buttons 1.0.0 * Set the class name for the button. Please note - this property requires the Buttons extension for DataTables. *

* Description * The ability to set a class name for a button can be useful both for styling the button and also for selection and manipulation via * the API (buttons() for example). This option provides exactly that ability. *

* The class name defined here is added to the class name defined by buttons.buttons.className, so the button will likely have two or * more class names assigned to it. *

* Please note that most buttons will define their own class name so they will be style-able without being required to add a custom * class name using you are extending an existing button. Please refer to the documentation for each button type for their default * class name. *

* Additionally, if you extend a button that has its own class name defined, any classes you set will automatically be appended to the * extended button's class. It will not overwrite the original class. * * @return */ public String getClassName() { return className; } /** * buttons.buttons.classNameSince: Buttons 1.0.0 * Set the class name for the button. Please note - this property requires the Buttons extension for DataTables. *

* Description * The ability to set a class name for a button can be useful both for styling the button and also for selection and manipulation via * the API (buttons() for example). This option provides exactly that ability. *

* The class name defined here is added to the class name defined by buttons.buttons.className, so the button will likely have two or * more class names assigned to it. *

* Please note that most buttons will define their own class name so they will be style-able without being required to add a custom * class name using you are extending an existing button. Please refer to the documentation for each button type for their default * class name. *

* Additionally, if you extend a button that has its own class name defined, any classes you set will automatically be appended to the * extended button's class. It will not overwrite the original class. * * @param className * * @return */ @SuppressWarnings("unchecked") @NotNull public J setClassName(String className) { this.className = className; return (J) this; } /** * buttons.buttons.enabledSince: Buttons 1.0.0 * Set a button's initial enabled state. Please note - this property requires the Buttons extension for DataTables. *

* Description * This option provides the ability to set the initial enabled state of a button using a boolean value. It is most likely to be of use * when using the API methods that can control the button's enabled state after initialisation: *

* buttons().enab * * @return */ public Boolean getEnabled() { return enabled; } /** * buttons.buttons.enabledSince: Buttons 1.0.0 * Set a button's initial enabled state. Please note - this property requires the Buttons extension for DataTables. *

* Description * This option provides the ability to set the initial enabled state of a button using a boolean value. It is most likely to be of use * when using the API methods that can control the button's enabled state after initialisation: *

* buttons().enab * * @param enabled * * @return */ @SuppressWarnings("unchecked") @NotNull public J setEnabled(Boolean enabled) { this.enabled = enabled; return (J) this; } /** * buttons.buttons.keySince: Buttons 1.0.0 * Define an activation key for a button. Please note - this property requires the Buttons extension for DataTables. *

* Description * Buttons has the built in ability to activate buttons through keyboard key presses and key combinations. This is to aid * accessibility and provide complete keyboard navigation of your table. For example, with using Editor, records can be added, edited * and deleted without touching the mouse! *

* Key presses are only processed when the document has no element that is actively focused. This means that typing into an input * element will not accidentally trigger a button's action! *

* Please note that for Adobe Flash based buttons, key activation simply will not work! This is a security feature implemented by * Adobe - such buttons must be clicked on to activate them. * * @return */ public DataTablesButtonKeys getKey() { return key; } /** * buttons.buttons.keySince: Buttons 1.0.0 * Define an activation key for a button. Please note - this property requires the Buttons extension for DataTables. *

* Description * Buttons has the built in ability to activate buttons through keyboard key presses and key combinations. This is to aid * accessibility and provide complete keyboard navigation of your table. For example, with using Editor, records can be added, edited * and deleted without touching the mouse! *

* Key presses are only processed when the document has no element that is actively focused. This means that typing into an input * element will not accidentally trigger a button's action! *

* Please note that for Adobe Flash based buttons, key activation simply will not work! This is a security feature implemented by * Adobe - such buttons must be clicked on to activate them. * * @param key * * @return */ @SuppressWarnings("unchecked") @NotNull public J setKey(DataTablesButtonKeys key) { this.key = key; return (J) this; } /** * buttons.buttons.nameSince: Buttons 1.0.0 * Set a name for each selection. Please note - this property requires the Buttons extension for DataTables. *

* Description * The buttons() and button() API methods provide the ability to use a button-selector to be able to select one or more buttons in one * or more Buttons instances. In turn the button selector provides an option to easily select a button by using a predefined name * (thus removing any complexities that might occur if using index selection). This option provides the ability to set that name. *

* Multiple buttons can share the same name, they need not be unique, but please be aware that they will always be selected together * if using a name selector. * * @return */ public String getName() { return name; } /** * buttons.buttons.nameSince: Buttons 1.0.0 * Set a name for each selection. Please note - this property requires the Buttons extension for DataTables. *

* Description * The buttons() and button() API methods provide the ability to use a button-selector to be able to select one or more buttons in one * or more Buttons instances. In turn the button selector provides an option to easily select a button by using a predefined name * (thus removing any complexities that might occur if using index selection). This option provides the ability to set that name. *

* Multiple buttons can share the same name, they need not be unique, but please be aware that they will always be selected together * if using a name selector. * * @param name * * @return */ @SuppressWarnings("unchecked") @NotNull public J setName(String name) { this.name = name; return (J) this; } /** * buttons.buttons.textSince: Buttons 1.0.0 * The text to show in the button. Please note - this property requires the Buttons extension for DataTables. *

* Description * Being able to let your users know what will happen when they activate a button is obviously fundamentally important to the Buttons * extension and this option provides exactly that ability * * @return */ public String getText() { return text; } /** * buttons.buttons.textSince: Buttons 1.0.0 * The text to show in the button. Please note - this property requires the Buttons extension for DataTables. *

* Description * Being able to let your users know what will happen when they activate a button is obviously fundamentally important to the Buttons * extension and this option provides exactly that ability * * @param text * * @return */ @SuppressWarnings("unchecked") @NotNull public J setText(String text) { this.text = text; return (J) this; } /** * buttons.buttons.textSince: Buttons 1.0.0 * The text to show in the button. Please note - this property requires the Buttons extension for DataTables. *

* Description * Being able to let your users know what will happen when they activate a button is obviously fundamentally important to the Buttons * extension and this option provides exactly that ability * * @return */ public String getTitleAttribute() { return titleAttribute; } /** * buttons.buttons.textSince: Buttons 1.0.0 * The text to show in the button. Please note - this property requires the Buttons extension for DataTables. *

* Description * Being able to let your users know what will happen when they activate a button is obviously fundamentally important to the Buttons * extension and this option provides exactly that ability * * @param titleAttribute * * @return */ @SuppressWarnings("unchecked") @NotNull public J setTitleAttribute(String titleAttribute) { this.titleAttribute = titleAttribute; return (J) this; } /** * Returns the current button extending if specified * * @return */ public DataTableButtons getExtend() { return extend; } /** * Sets the predefined button to extend * * @param extend * * @return */ @SuppressWarnings("unchecked") @NotNull public J setExtend(DataTableButtons extend) { this.extend = extend; return (J) this; } @Override public int compareTo(DataTablesButtonButtonsOptions o) { if (o == null) { return -1; } return 1; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy