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

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

import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.jwebmp.core.htmlbuilder.javascript.JavaScriptPart;

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

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

/**
 * buttonsSince: Buttons 1.0.0
 * Buttons configuration object. Please note - this property requires the Buttons extension for DataTables.
 * 

* Description * This option provides the ability to have a Buttons instance created automatically when a new DataTable is created. The button * collection can then be inserted into the DataTables controlled DOM by using the B option in the dom parameter, or through the buttons * ().container() API method. * * @param */ @JsonAutoDetect(fieldVisibility = ANY, getterVisibility = NONE, setterVisibility = NONE) @JsonInclude(NON_NULL) @JsonIgnoreProperties(ignoreUnknown = true) @JsonFormat(shape = JsonFormat.Shape.OBJECT) public class DataTablesButtonsOptions> extends JavaScriptPart { /** * buttons.nameSince: Buttons 1.0.0 * Set a name for the instance for the group selector. Please note - this property requires the Buttons extension for DataTables. *

* Description * As multiple Buttons instances can be attached to a single DataTable, it can be useful to be able to select each instance * individually. This option provides the ability to set a name for the instance so it can later be selected using the * button-group-selector option of the buttons() and button() API methods. *

* The instance name does not need to be unique. If a group selector is given that matches multiple instances, all matching instances * will be selected. */ private String name; /** * buttons.domSince: Buttons 1.0.0 * Options to control the DOM structure Buttons creates. Please note - this property requires the Buttons extension for DataTables. *

* Description * The markup that is created by Buttons is quite flexible in that you can control the tags used and the class names. You can also * optionally control the structure of the markup for the buttons. */ private DataTablesButtonsDomOptions dom; /** * 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. */ private Set> buttons; /** * buttonsSince: Buttons 1.0.0 * Buttons configuration object. Please note - this property requires the Buttons extension for DataTables. *

* Description * This option provides the ability to have a Buttons instance created automatically when a new DataTable is created. The button * collection can then be inserted into the DataTables controlled DOM by using the B option in the dom parameter, or through the * buttons().container() API method. */ public DataTablesButtonsOptions() { //No config required } /** * buttons.nameSince: Buttons 1.0.0 * Set a name for the instance for the group selector. Please note - this property requires the Buttons extension for DataTables. *

* Description * As multiple Buttons instances can be attached to a single DataTable, it can be useful to be able to select each instance * individually. This option provides the ability to set a name for the instance so it can later be selected using the * button-group-selector option of the buttons() and button() API methods. *

* The instance name does not need to be unique. If a group selector is given that matches multiple instances, all matching instances * will be selected. * * @return */ public String getName() { return name; } /** * buttons.nameSince: Buttons 1.0.0 * Set a name for the instance for the group selector. Please note - this property requires the Buttons extension for DataTables. *

* Description * As multiple Buttons instances can be attached to a single DataTable, it can be useful to be able to select each instance * individually. This option provides the ability to set a name for the instance so it can later be selected using the * button-group-selector option of the buttons() and button() API methods. *

* The instance name does not need to be unique. If a group selector is given that matches multiple instances, all matching instances * will be selected. * * @param name * * @return */ @SuppressWarnings("unchecked") @NotNull public J setName(String name) { this.name = name; return (J) this; } /** * buttons.domSince: Buttons 1.0.0 * Options to control the DOM structure Buttons creates. Please note - this property requires the Buttons extension for DataTables. *

* Description * The markup that is created by Buttons is quite flexible in that you can control the tags used and the class names. You can also * optionally control the structure of the markup for the buttons. * * @return */ public DataTablesButtonsDomOptions getDom() { if (dom == null) { dom = new DataTablesButtonsDomOptions(); } return dom; } /** * buttons.domSince: Buttons 1.0.0 * Options to control the DOM structure Buttons creates. Please note - this property requires the Buttons extension for DataTables. *

* Description * The markup that is created by Buttons is quite flexible in that you can control the tags used and the class names. You can also * optionally control the structure of the markup for the buttons. * * @param dom * * @return */ @SuppressWarnings("unchecked") @NotNull public J setDom(DataTablesButtonsDomOptions dom) { this.dom = dom; return (J) this; } /** * 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. * * @return */ @NotNull public Set> getButtons() { if (buttons == null) { buttons = new LinkedHashSet<>(); } return buttons; } /** * 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 buttons * * @return */ @SuppressWarnings("unchecked") @NotNull public J setButtons(Set> buttons) { this.buttons = buttons; return (J) this; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy