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

com.jwebmp.plugins.datatable.options.DataTableKeyTableOptions 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.jwebmp.core.htmlbuilder.javascript.JavaScriptPart;
import com.jwebmp.plugins.datatable.enumerations.DataTableKeyTableEditorKeys;

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

/**
 * Spreadsheet navigation of a DataTable can make not only for an attractive and rapid data input interface, but also for a very familiar
 * one well suited for those used to Excel, OpenOffice or similar and now transitioning to web based apps.
 * 

* KeyTable adds keyboard navigation to DataTables, operating in exactly the same way as a traditional spreadsheet application. Combined * with AutoFill and Editor's inline editing a true spreadsheet like environment can be created. Furthermore, using the keyboard * accessibility features of Buttons allows a fully editable DataTable to be accessed using the keyboard only. * * @param */ public class DataTableKeyTableOptions> extends JavaScriptPart { /** * keys.blurableSince: KeyTable KeyTable 2.0.0 * Allow KeyTable's focus to be blurred (removed) from a table. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * By default KeyTable will make the table act like a normal input element in an HTML page and the tab key can be used to move focus * between fields. Tabbing when focused on the last cell in the table will then move the focus on to the next form element in the * document - thus blurring the table. *

* This ability to loose focus (blurring) can be disabled in KeyTable by setting this option to false. That means that once the table * has been focused (which it can be automatically using keys.focus) focus cannot be removed (although interaction can be disabled * using keys.disable()). */ private Boolean blurable; /** * keys.classNameSince: KeyTable KeyTable 2.0.0 * Set the class name used for the focused cell. Please note - this property requires the KeyTable extension for DataTables. *

* Description * Allowing the end user to visually identify which cell has focus is obviously fundamentally important to KeyTable's abilities, and * this is done by added a class to the focused cell. This class can then be styled using CSS to visually highlight the cell. The CSS * outline property is useful for this, and is the styling option used by the KeyTable default stylesheet. *

* This property can be used to alter the class name used to show cell focus. */ private String className; /** * keys.columnsSince: KeyTable 2.0.0 * Select the columns that can gain focus. Please note - this property requires the KeyTable extension for DataTables. *

* Description * When working with complex tables it is not uncommon to have certain columns that you might not wish to allow spreadsheet like * navigation on (for example a checkbox column for row selection or a column with editing action buttons). This option can be used to * define which columns can receive focus. If a column cannot receive focus KeyTable will skip over it as if it was not present. *

* Please note that only visible cells can receive focus, so the columns defined by this option are automatically merged with the * visible columns in the table. Non-visible columns will not receive focus */ private Set columns; /** * keys.editAutoSelectSince: KeyTable KeyTable 2.3.0 * Set if Editor should automatically select the text in the input. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * When KeyTable is used to navigate a table and activate inline editing, it will, by default, automatically select the text in the * input element. This provides an editing interface which acts very much like Excel - start typing and it will replace the existing * values with the new text. */ private Boolean editAutoSelect; /** * keys.editOnFocusSince: KeyTable KeyTable 2.3.0 * Control if editing should be activated immediately upon focus. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * When used with Editor (keys.editor), inline editing will not be triggered by KeyTable until a key value is pressed when a cell is * focused (similar to Excel). However, you may wish to immediately place the cell into edit mode when the focus happens. This option * provides that ability. */ private Boolean editOnFocus; /** * When using KeyTable with Editor to provide an Excel like inline editing experience for the end user, you may wish to control the * behaviour of the arrow keys. There are currently two options KeyTable supports: *

* navigation-only - like Excel the current cell will be blurred and the focus moved per the arrow keys. * tab-only - more like what might be expected on the web - the arrow keys move the cursor through the text box. Tab can be used to * move between cells. * The behaviour you might wish to use can be configured through this option. For applications where end users are used to Excel's * behaviour you might wish to use the default, while for more general use the tab-only option might be appropriate. */ private DataTableKeyTableEditorKeys editorKeys; /** * keys.focusSince: KeyTable KeyTable 2.0.0 * Cell to receive initial focus in the table. Please note - this property requires the KeyTable extension for DataTables. *

* Description * This option can be used to define what cell in the table (if any) will automatically receive focus when the table is initialised * with KeyTable enabled. *

* The value of this option will be over-ridden if state saving is enabled in DataTables (stateSave) and there is a saved focused cell * - i.e. the state saved focused cell will instead receive the focus. *

* Type * cell-selector * Description: * The cell that will receive focus when the table is initialised. This accepts all of the options of cell-selector such as class name * selector, jQuery pseudo selects and cell index selectors. *

* Default * Value: null * The table will not automatically receive focus when initialised *

* Example * Automatically focus on the first cell in the table: *

* Javascript * 1 * 2 * 3 * 4 * 5 * $('#myTable').DataTable( { * keys: { * focus: ':eq(0)' * } * } ); */ private String focus; /** * eys.keysSince: KeyTable KeyTable 2.0.0 * Limit the keys that KeyTable will listen for and take action on. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * This option can be used to gain fine control over which keys that KeyTable will listen for. The keys.enable() and keys.disable() * methods can be used to enable and disable KeyTable completely, but this option provides the ability to specify the character codes * that KeyTable will take action on when enabled. *

* This can be used, for example, to listen only for arrow and return keys (effectively disabling the tab key), or only the tab key. *

* You can hard code the character code values if you wish, but a more flexible and potentially understandable option is to use the * String.charCodeAt() method to obtain a character code - for example to get the tab key use "\t".charCodeAt(0). *

* Type * array|null * Description: * As null KeyTable will listen for all key presses, regardless of what key is pressed. As an array you can limit the keys that * KeyTable will take action on to just the key codes given in the array. *

* Default * Value: null * Listen for all keys *

* Example * Listen for the tab key only: *

* Javascript * 1 * 2 * 3 * 4 * 5 * $('#myTable').DataTable( { * keys: { * keys: [ "\t".charCodeAt(0) ] * } * } ); */ private Set keys; /** * keys.tabIndexSince: KeyTable KeyTable 2.0.0 * Set the table's tab index for when it will receive focus. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * Browser's have complex built in algorithms that define which element will receive focus when the tab key is pressed by the end user * . The tab index attribute for HTML elements can be used to control this behaviour, focusing focus to follow a route defined by the * developer rather than the end user. This option can be used to define the tab index of the KeyTable enhanced DataTable in the * documents tab flow. *

* Type * integer * Description: * The tab index for the table. Like all other tab indexes, this can be -1 to disallow tabbing into the table. */ private Integer tabIndex; /** * Spreadsheet navigation of a DataTable can make not only for an attractive and rapid data input interface, but also for a very * familiar one well suited for those used to Excel, OpenOffice or similar and now transitioning to web based apps. *

* KeyTable adds keyboard navigation to DataTables, operating in exactly the same way as a traditional spreadsheet application. * Combined with AutoFill and Editor's inline editing a true spreadsheet like environment can be created. Furthermore, using the * keyboard accessibility features of Buttons allows a fully editable DataTable to be accessed using the keyboard only. */ public DataTableKeyTableOptions() { //No Config Needed } /** * keys.blurableSince: KeyTable KeyTable 2.0.0 * Allow KeyTable's focus to be blurred (removed) from a table. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * By default KeyTable will make the table act like a normal input element in an HTML page and the tab key can be used to move focus * between fields. Tabbing when focused on the last cell in the table will then move the focus on to the next form element in the * document - thus blurring the table. *

* This ability to loose focus (blurring) can be disabled in KeyTable by setting this option to false. That means that once the table * has been focused (which it can be automatically using keys.focus) focus cannot be removed (although interaction can be disabled * using keys.disable()). * * @return */ public Boolean getBlurable() { return blurable; } /** * keys.blurableSince: KeyTable KeyTable 2.0.0 * Allow KeyTable's focus to be blurred (removed) from a table. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * By default KeyTable will make the table act like a normal input element in an HTML page and the tab key can be used to move focus * between fields. Tabbing when focused on the last cell in the table will then move the focus on to the next form element in the * document - thus blurring the table. *

* This ability to loose focus (blurring) can be disabled in KeyTable by setting this option to false. That means that once the table * has been focused (which it can be automatically using keys.focus) focus cannot be removed (although interaction can be disabled * using keys.disable()). * * @param blurable * * @return */ @SuppressWarnings("unchecked") @NotNull public J setBlurable(Boolean blurable) { this.blurable = blurable; return (J) this; } /** * keys.classNameSince: KeyTable KeyTable 2.0.0 * Set the class name used for the focused cell. Please note - this property requires the KeyTable extension for DataTables. *

* Description * Allowing the end user to visually identify which cell has focus is obviously fundamentally important to KeyTable's abilities, and * this is done by added a class to the focused cell. This class can then be styled using CSS to visually highlight the cell. The CSS * outline property is useful for this, and is the styling option used by the KeyTable default stylesheet. *

* This property can be used to alter the class name used to show cell focus. * * @return */ public String getClassName() { return className; } /** * keys.classNameSince: KeyTable KeyTable 2.0.0 * Set the class name used for the focused cell. Please note - this property requires the KeyTable extension for DataTables. *

* Description * Allowing the end user to visually identify which cell has focus is obviously fundamentally important to KeyTable's abilities, and * this is done by added a class to the focused cell. This class can then be styled using CSS to visually highlight the cell. The CSS * outline property is useful for this, and is the styling option used by the KeyTable default stylesheet. *

* This property can be used to alter the class name used to show cell focus. * * @param className * * @return */ @SuppressWarnings("unchecked") @NotNull public J setClassName(String className) { this.className = className; return (J) this; } /** * keys.columnsSince: KeyTable 2.0.0 * Select the columns that can gain focus. Please note - this property requires the KeyTable extension for DataTables. *

* Description * When working with complex tables it is not uncommon to have certain columns that you might not wish to allow spreadsheet like * navigation on (for example a checkbox column for row selection or a column with editing action buttons). This option can be used to * define which columns can receive focus. If a column cannot receive focus KeyTable will skip over it as if it was not present. *

* Please note that only visible cells can receive focus, so the columns defined by this option are automatically merged with the * visible columns in the table. Non-visible columns will not receive focus * * @return */ public Set getColumns() { if (columns == null) { columns = new HashSet<>(); } return columns; } /** * keys.columnsSince: KeyTable 2.0.0 * Select the columns that can gain focus. Please note - this property requires the KeyTable extension for DataTables. *

* Description * When working with complex tables it is not uncommon to have certain columns that you might not wish to allow spreadsheet like * navigation on (for example a checkbox column for row selection or a column with editing action buttons). This option can be used to * define which columns can receive focus. If a column cannot receive focus KeyTable will skip over it as if it was not present. *

* Please note that only visible cells can receive focus, so the columns defined by this option are automatically merged with the * visible columns in the table. Non-visible columns will not receive focus * * @param columns * * @return */ @SuppressWarnings("unchecked") @NotNull public J setColumns(Set columns) { this.columns = columns; return (J) this; } /** * keys.editAutoSelectSince: KeyTable KeyTable 2.3.0 * Set if Editor should automatically select the text in the input. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * When KeyTable is used to navigate a table and activate inline editing, it will, by default, automatically select the text in the * input element. This provides an editing interface which acts very much like Excel - start typing and it will replace the existing * values with the new text. * * @return */ public Boolean getEditAutoSelect() { return editAutoSelect; } /** * keys.editAutoSelectSince: KeyTable KeyTable 2.3.0 * Set if Editor should automatically select the text in the input. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * When KeyTable is used to navigate a table and activate inline editing, it will, by default, automatically select the text in the * input element. This provides an editing interface which acts very much like Excel - start typing and it will replace the existing * values with the new text. * * @param editAutoSelect * * @return */ @SuppressWarnings("unchecked") @NotNull public J setEditAutoSelect(Boolean editAutoSelect) { this.editAutoSelect = editAutoSelect; return (J) this; } /** * keys.editOnFocusSince: KeyTable KeyTable 2.3.0 * Control if editing should be activated immediately upon focus. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * When used with Editor (keys.editor), inline editing will not be triggered by KeyTable until a key value is pressed when a cell is * focused (similar to Excel). However, you may wish to immediately place the cell into edit mode when the focus happens. This option * provides that ability. * * @return */ public Boolean getEditOnFocus() { return editOnFocus; } /** * keys.editOnFocusSince: KeyTable KeyTable 2.3.0 * Control if editing should be activated immediately upon focus. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * When used with Editor (keys.editor), inline editing will not be triggered by KeyTable until a key value is pressed when a cell is * focused (similar to Excel). However, you may wish to immediately place the cell into edit mode when the focus happens. This option * provides that ability. * * @param editOnFocus * * @return */ @SuppressWarnings("unchecked") @NotNull public J setEditOnFocus(Boolean editOnFocus) { this.editOnFocus = editOnFocus; return (J) this; } /** * When using KeyTable with Editor to provide an Excel like inline editing experience for the end user, you may wish to control the * behaviour of the arrow keys. There are currently two options KeyTable supports: *

* navigation-only - like Excel the current cell will be blurred and the focus moved per the arrow keys. * tab-only - more like what might be expected on the web - the arrow keys move the cursor through the text box. Tab can be used to * move between cells. * The behaviour you might wish to use can be configured through this option. For applications where end users are used to Excel's * behaviour you might wish to use the default, while for more general use the tab-only option might be appropriate. * * @return */ public DataTableKeyTableEditorKeys getEditorKeys() { return editorKeys; } /** * When using KeyTable with Editor to provide an Excel like inline editing experience for the end user, you may wish to control the * behaviour of the arrow keys. There are currently two options KeyTable supports: *

* navigation-only - like Excel the current cell will be blurred and the focus moved per the arrow keys. * tab-only - more like what might be expected on the web - the arrow keys move the cursor through the text box. Tab can be used to * move between cells. * The behaviour you might wish to use can be configured through this option. For applications where end users are used to Excel's * behaviour you might wish to use the default, while for more general use the tab-only option might be appropriate. * * @param editorKeys * * @return */ @SuppressWarnings("unchecked") @NotNull public J setEditorKeys(DataTableKeyTableEditorKeys editorKeys) { this.editorKeys = editorKeys; return (J) this; } /** * keys.focusSince: KeyTable KeyTable 2.0.0 * Cell to receive initial focus in the table. Please note - this property requires the KeyTable extension for DataTables. *

* Description * This option can be used to define what cell in the table (if any) will automatically receive focus when the table is initialised * with KeyTable enabled. *

* The value of this option will be over-ridden if state saving is enabled in DataTables (stateSave) and there is a saved focused cell * - i.e. the state saved focused cell will instead receive the focus. *

* Type * cell-selector * Description: * The cell that will receive focus when the table is initialised. This accepts all of the options of cell-selector such as class name * selector, jQuery pseudo selects and cell index selectors. *

* Default * Value: null * The table will not automatically receive focus when initialised *

* Example * Automatically focus on the first cell in the table: *

* Javascript * 1 * 2 * 3 * 4 * 5 * $('#myTable').DataTable( { * keys: { * focus: ':eq(0)' * } * } ); * * @return */ public String getFocus() { return focus; } /** * keys.focusSince: KeyTable KeyTable 2.0.0 * Cell to receive initial focus in the table. Please note - this property requires the KeyTable extension for DataTables. *

* Description * This option can be used to define what cell in the table (if any) will automatically receive focus when the table is initialised * with KeyTable enabled. *

* The value of this option will be over-ridden if state saving is enabled in DataTables (stateSave) and there is a saved focused cell * - i.e. the state saved focused cell will instead receive the focus. *

* Type * cell-selector * Description: * The cell that will receive focus when the table is initialised. This accepts all of the options of cell-selector such as class name * selector, jQuery pseudo selects and cell index selectors. *

* Default * Value: null * The table will not automatically receive focus when initialised *

* Example * Automatically focus on the first cell in the table: *

* Javascript * 1 * 2 * 3 * 4 * 5 * $('#myTable').DataTable( { * keys: { * focus: ':eq(0)' * } * } ); * * @param focus * * @return */ @SuppressWarnings("unchecked") @NotNull public J setFocus(String focus) { this.focus = focus; return (J) this; } /** * eys.keysSince: KeyTable KeyTable 2.0.0 * Limit the keys that KeyTable will listen for and take action on. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * This option can be used to gain fine control over which keys that KeyTable will listen for. The keys.enable() and keys.disable() * methods can be used to enable and disable KeyTable completely, but this option provides the ability to specify the character codes * that KeyTable will take action on when enabled. *

* This can be used, for example, to listen only for arrow and return keys (effectively disabling the tab key), or only the tab key. *

* You can hard code the character code values if you wish, but a more flexible and potentially understandable option is to use the * String.charCodeAt() method to obtain a character code - for example to get the tab key use "\t".charCodeAt(0). *

* Type * array|null * Description: * As null KeyTable will listen for all key presses, regardless of what key is pressed. As an array you can limit the keys that * KeyTable will take action on to just the key codes given in the array. *

* Default * Value: null * Listen for all keys *

* Example * Listen for the tab key only: *

* Javascript * 1 * 2 * 3 * 4 * 5 * $('#myTable').DataTable( { * keys: { * keys: [ "\t".charCodeAt(0) ] * } * } ); * * @return */ public Set getKeys() { if (keys == null) { keys = new LinkedHashSet<>(); } return keys; } /** * eys.keysSince: KeyTable KeyTable 2.0.0 * Limit the keys that KeyTable will listen for and take action on. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * This option can be used to gain fine control over which keys that KeyTable will listen for. The keys.enable() and keys.disable() * methods can be used to enable and disable KeyTable completely, but this option provides the ability to specify the character codes * that KeyTable will take action on when enabled. *

* This can be used, for example, to listen only for arrow and return keys (effectively disabling the tab key), or only the tab key. *

* You can hard code the character code values if you wish, but a more flexible and potentially understandable option is to use the * String.charCodeAt() method to obtain a character code - for example to get the tab key use "\t".charCodeAt(0). *

* Type * array|null * Description: * As null KeyTable will listen for all key presses, regardless of what key is pressed. As an array you can limit the keys that * KeyTable will take action on to just the key codes given in the array. *

* Default * Value: null * Listen for all keys *

* Example * Listen for the tab key only: *

* Javascript * 1 * 2 * 3 * 4 * 5 * $('#myTable').DataTable( { * keys: { * keys: [ "\t".charCodeAt(0) ] * } * } ); * * @param keys * * @return */ @SuppressWarnings("unchecked") @NotNull public J setKeys(Set keys) { this.keys = keys; return (J) this; } /** * keys.tabIndexSince: KeyTable KeyTable 2.0.0 * Set the table's tab index for when it will receive focus. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * Browser's have complex built in algorithms that define which element will receive focus when the tab key is pressed by the end user * . The tab index attribute for HTML elements can be used to control this behaviour, focusing focus to follow a route defined by the * developer rather than the end user. This option can be used to define the tab index of the KeyTable enhanced DataTable in the * documents tab flow. *

* Type * integer * Description: * The tab index for the table. Like all other tab indexes, this can be -1 to disallow tabbing into the table. * * @return */ public Integer getTabIndex() { return tabIndex; } /** * keys.tabIndexSince: KeyTable KeyTable 2.0.0 * Set the table's tab index for when it will receive focus. Please note - this property requires the KeyTable extension for * DataTables. *

* Description * Browser's have complex built in algorithms that define which element will receive focus when the tab key is pressed by the end user * . The tab index attribute for HTML elements can be used to control this behaviour, focusing focus to follow a route defined by the * developer rather than the end user. This option can be used to define the tab index of the KeyTable enhanced DataTable in the * documents tab flow. *

* Type * integer * Description: * The tab index for the table. Like all other tab indexes, this can be -1 to disallow tabbing into the table. * * @param tabIndex * * @return */ @SuppressWarnings("unchecked") @NotNull public J setTabIndex(Integer tabIndex) { this.tabIndex = tabIndex; return (J) this; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy