1
0
mirror of https://gitlab.com/JKANetwork/CheckServer.git synced 2026-03-02 17:03:45 +01:00

Start again

This commit is contained in:
2020-10-04 17:14:00 +02:00
parent c0d3912413
commit 091f119048
4382 changed files with 1762543 additions and 9606 deletions

View File

@@ -0,0 +1,48 @@
{
"name": "datatables.net-keytable",
"description": "KeyTable for DataTables ",
"main": [
"js/dataTables.keyTable.js"
],
"keywords": [
"spreadsheet",
"excel",
"keyboard",
"DataTables",
"jQuery",
"table",
"DataTables"
],
"dependencies": {
"jquery": ">=1.7",
"datatables.net": ">=1.10.9"
},
"moduleType": [
"globals",
"amd",
"node"
],
"ignore": [
"composer.json",
"datatables.json",
"package.json"
],
"authors": [
{
"name": "SpryMedia Ltd",
"homepage": "https://datatables.net"
}
],
"homepage": "https://datatables.net",
"license": "MIT",
"version": "2.1.2",
"_release": "2.1.2",
"_resolution": {
"type": "version",
"tag": "2.1.2",
"commit": "2debcfe4f7e4b0e73d5f5c9daec429e8788d2921"
},
"_source": "https://github.com/DataTables/Dist-DataTables-KeyTable.git",
"_target": "^2.1.1",
"_originalSource": "datatables.net-keytable"
}

View File

@@ -0,0 +1,20 @@
Copyright SpryMedia Limited and other contributors
http://datatables.net
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.

View File

@@ -0,0 +1,50 @@
# KeyTable for DataTables
This package contains distribution files for the [KeyTable extension](https://datatables.net/extensions/keytable) for [DataTables](https://datatables.net/). Only the core software for this library is contained in this package - to be correctly styled, a styling package for KeyTable must also be included. Styling options include DataTable's native styling, [Bootstrap](http://getboostrap.com) and [Foundation](http://foundation.zurb.com/).
KeyTable allows you to use keyboard navigation on a DataTables enhanced table, like an Excel spreadsheet - a cell shows a focus outline which can be moved using the keyboard or mouse operations. This can be particularly useful in an editable table that uses Editor allowing end users to update data very quickly.
## Installation
### Browser
For inclusion of this library using a standard `<script>` tag, rather than using this package, it is recommended that you use the [DataTables download builder](//datatables.net/download) which can create CDN or locally hosted packages for you, will all dependencies satisfied.
### npm
```
npm install datatables.net-keytable
```
```
var $ = require( 'jquery' );
require( 'datatables.net-keytable' )( window, $ );
```
### bower
```
bower install --save datatables.net-keytable
```
## Documentation
Full documentation of the DataTables options, API and plug-in interface are available on the DOCS_LINK. The site also contains information on the wide variety of plug-ins that are available for DataTables, which can be used to enhance and customise your table even further.
## Bug / Support
Support for DataTables is available through the [DataTables forums](//datatables.net/forums) and [commercial support options](//datatables.net/support) are available.
### Contributing
If you are thinking of contributing code to DataTables, first of all, thank you! All fixes, patches and enhancements to DataTables are very warmly welcomed. This repository is a distribution repo, so patches and issues sent to this repo will not be accepted. Instead, please direct pull requests to the [DataTables/KeyTable](http://github.com/DataTables/KeyTable). For issues / bugs, please direct your questions to the [DataTables forums](//datatables.net/forums).
## License
This software is released under the [MIT license](//datatables.net/license). You are free to use, modify and distribute this software, but all copyright information must remain.

View File

@@ -0,0 +1,38 @@
{
"name": "datatables.net-keytable",
"description": "KeyTable for DataTables ",
"main": [
"js/dataTables.keyTable.js"
],
"keywords": [
"spreadsheet",
"excel",
"keyboard",
"DataTables",
"jQuery",
"table",
"DataTables"
],
"dependencies": {
"jquery": ">=1.7",
"datatables.net": ">=1.10.9"
},
"moduleType": [
"globals",
"amd",
"node"
],
"ignore": [
"composer.json",
"datatables.json",
"package.json"
],
"authors": [
{
"name": "SpryMedia Ltd",
"homepage": "https://datatables.net"
}
],
"homepage": "https://datatables.net",
"license": "MIT"
}

View File

@@ -0,0 +1,883 @@
/*! KeyTable 2.1.2
* ©2009-2016 SpryMedia Ltd - datatables.net/license
*/
/**
* @summary KeyTable
* @description Spreadsheet like keyboard navigation for DataTables
* @version 2.1.2
* @file dataTables.keyTable.js
* @author SpryMedia Ltd (www.sprymedia.co.uk)
* @contact www.sprymedia.co.uk/contact
* @copyright Copyright 2009-2016 SpryMedia Ltd.
*
* This source file is free software, available under the following license:
* MIT license - http://datatables.net/license/mit
*
* This source file 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 license files for details.
*
* For details please refer to: http://www.datatables.net
*/
(function( factory ){
if ( typeof define === 'function' && define.amd ) {
// AMD
define( ['jquery', 'datatables.net'], function ( $ ) {
return factory( $, window, document );
} );
}
else if ( typeof exports === 'object' ) {
// CommonJS
module.exports = function (root, $) {
if ( ! root ) {
root = window;
}
if ( ! $ || ! $.fn.dataTable ) {
$ = require('datatables.net')(root, $).$;
}
return factory( $, root, root.document );
};
}
else {
// Browser
factory( jQuery, window, document );
}
}(function( $, window, document, undefined ) {
'use strict';
var DataTable = $.fn.dataTable;
var KeyTable = function ( dt, opts ) {
// Sanity check that we are using DataTables 1.10 or newer
if ( ! DataTable.versionCheck || ! DataTable.versionCheck( '1.10.8' ) ) {
throw 'KeyTable requires DataTables 1.10.8 or newer';
}
// User and defaults configuration object
this.c = $.extend( true, {},
DataTable.defaults.keyTable,
KeyTable.defaults,
opts
);
// Internal settings
this.s = {
/** @type {DataTable.Api} DataTables' API instance */
dt: new DataTable.Api( dt ),
enable: true,
/** @type {bool} Flag for if a draw is triggered by focus */
focusDraw: false
};
// DOM items
this.dom = {
};
// Check if row reorder has already been initialised on this table
var settings = this.s.dt.settings()[0];
var exisiting = settings.keytable;
if ( exisiting ) {
return exisiting;
}
settings.keytable = this;
this._constructor();
};
$.extend( KeyTable.prototype, {
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* API methods for DataTables API interface
*/
/**
* Blur the table's cell focus
*/
blur: function ()
{
this._blur();
},
/**
* Enable cell focus for the table
*
* @param {string} state Can be `true`, `false` or `-string navigation-only`
*/
enable: function ( state )
{
this.s.enable = state;
},
/**
* Focus on a cell
* @param {integer} row Row index
* @param {integer} column Column index
*/
focus: function ( row, column )
{
this._focus( this.s.dt.cell( row, column ) );
},
/**
* Is the cell focused
* @param {object} cell Cell index to check
* @returns {boolean} true if focused, false otherwise
*/
focused: function ( cell )
{
var lastFocus = this.s.lastFocus;
if ( ! lastFocus ) {
return false;
}
var lastIdx = this.s.lastFocus.index();
return cell.row === lastIdx.row && cell.column === lastIdx.column;
},
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Constructor
*/
/**
* Initialise the KeyTable instance
*
* @private
*/
_constructor: function ()
{
this._tabInput();
var that = this;
var dt = this.s.dt;
var table = $( dt.table().node() );
// Need to be able to calculate the cell positions relative to the table
if ( table.css('position') === 'static' ) {
table.css( 'position', 'relative' );
}
// Click to focus
$( dt.table().body() ).on( 'click.keyTable', 'th, td', function () {
if ( that.s.enable === false ) {
return;
}
var cell = dt.cell( this );
if ( ! cell.any() ) {
return;
}
that._focus( cell, null, false );
} );
// Key events
$( document ).on( 'keydown.keyTable', function (e) {
that._key( e );
} );
// Click blur
if ( this.c.blurable ) {
$( document ).on( 'click.keyTable', function ( e ) {
// Click on the search input will blur focus
if ( $(e.target).parents( '.dataTables_filter' ).length ) {
that._blur();
}
// If the click was inside the DataTables container, don't blur
if ( $(e.target).parents().filter( dt.table().container() ).length ) {
return;
}
// Don't blur in Editor form
if ( $(e.target).parents('div.DTE').length ) {
return;
}
that._blur();
} );
}
if ( this.c.editor ) {
dt.on( 'key.keyTable', function ( e, dt, key, cell, orig ) {
that._editor( key, orig );
} );
}
// Stave saving
if ( dt.settings()[0].oFeatures.bStateSave ) {
dt.on( 'stateSaveParams.keyTable', function (e, s, d) {
d.keyTable = that.s.lastFocus ?
that.s.lastFocus.index() :
null;
} );
}
// Reload - re-focus on the currently selected item. In SSP mode this
// has the effect of keeping the focus in position when changing page as
// well (which is different from how client-side processing works).
dt.on( 'xhr.keyTable', function ( e ) {
if ( that.s.focusDraw ) {
// Triggered by server-side processing, and thus `_focus` will
// do the refocus on the next draw event
return;
}
var lastFocus = that.s.lastFocus;
if ( lastFocus ) {
that.s.lastFocus = null;
dt.one( 'draw', function () {
that._focus( lastFocus );
} );
}
} );
dt.on( 'destroy.keyTable', function () {
dt.off( '.keyTable' );
$( dt.table().body() ).off( 'click.keyTable', 'th, td' );
$( document.body )
.off( 'keydown.keyTable' )
.off( 'click.keyTable' );
} );
// Initial focus comes from state or options
var state = dt.state.loaded();
if ( state && state.keyTable ) {
// Wait until init is done
dt.one( 'init', function () {
var cell = dt.cell( state.keyTable );
// Ensure that the saved cell still exists
if ( cell.any() ) {
cell.focus();
}
} );
}
else if ( this.c.focus ) {
dt.cell( this.c.focus ).focus();
}
},
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Private methods
*/
/**
* Blur the control
*
* @private
*/
_blur: function ()
{
if ( ! this.s.enable || ! this.s.lastFocus ) {
return;
}
var cell = this.s.lastFocus;
$( cell.node() ).removeClass( this.c.className );
this.s.lastFocus = null;
this._emitEvent( 'key-blur', [ this.s.dt, cell ] );
},
/**
* Get an array of the column indexes that KeyTable can operate on. This
* is a merge of the user supplied columns and the visible columns.
*
* @private
*/
_columns: function ()
{
var dt = this.s.dt;
var user = dt.columns( this.c.columns ).indexes();
var out = [];
dt.columns( ':visible' ).every( function (i) {
if ( user.indexOf( i ) !== -1 ) {
out.push( i );
}
} );
return out;
},
/**
* Perform excel like navigation for Editor by triggering an edit on key
* press
*
* @param {integer} key Key code for the pressed key
* @param {object} orig Original event
* @private
*/
_editor: function ( key, orig )
{
var dt = this.s.dt;
var editor = this.c.editor;
orig.stopPropagation();
// Return key should do nothing - for textareas's it would empty the
// contents
if ( key === 13 ) {
orig.preventDefault();
}
editor.inline( this.s.lastFocus.index() );
// Excel style - select all text
var input = $('div.DTE input, div.DTE textarea');
if ( input.length ) {
input[0].select();
}
// Reduce the keys the Keys listens for
dt.keys.enable( 'navigation-only' );
// On blur of the navigation submit
dt.one( 'key-blur.editor', function () {
if ( editor.displayed() ) {
editor.submit();
}
} );
// Restore full key navigation on close
editor.one( 'close', function () {
dt.keys.enable( true );
dt.off( 'key-blur.editor' );
} );
},
/**
* Emit an event on the DataTable for listeners
*
* @param {string} name Event name
* @param {array} args Event arguments
* @private
*/
_emitEvent: function ( name, args )
{
this.s.dt.iterator( 'table', function ( ctx, i ) {
$(ctx.nTable).triggerHandler( name, args );
} );
},
/**
* Focus on a particular cell, shifting the table's paging if required
*
* @param {DataTables.Api|integer} row Can be given as an API instance that
* contains the cell to focus or as an integer. As the latter it is the
* visible row index - NOT the data index
* @param {integer} [column] Not required if a cell is given as the first
* parameter. Otherwise this is the column data index for the cell to
* focus on
* @param {boolean} [shift=true] Should the viewport be moved to show cell
* @private
*/
_focus: function ( row, column, shift )
{
var that = this;
var dt = this.s.dt;
var pageInfo = dt.page.info();
var lastFocus = this.s.lastFocus;
if ( ! this.s.enable ) {
return;
}
if ( typeof row !== 'number' ) {
// Convert the cell to a row and column
var index = row.index();
column = index.column;
row = dt
.rows( { filter: 'applied', order: 'applied' } )
.indexes()
.indexOf( index.row );
// For server-side processing normalise the row by adding the start
// point, since `rows().indexes()` includes only rows that are
// available at the client-side
if ( pageInfo.serverSide ) {
row += pageInfo.start;
}
}
// Is the row on the current page? If not, we need to redraw to show the
// page
if ( pageInfo.length !== -1 && (row < pageInfo.start || row >= pageInfo.start+pageInfo.length) ) {
this.s.focusDraw = true;
dt
.one( 'draw', function () {
that.s.focusDraw = false;
that._focus( row, column );
} )
.page( Math.floor( row / pageInfo.length ) )
.draw( false );
return;
}
// In the available columns?
if ( $.inArray( column, this._columns() ) === -1 ) {
return;
}
// De-normalise the server-side processing row, so we select the row
// in its displayed position
if ( pageInfo.serverSide ) {
row -= pageInfo.start;
}
var cell = dt.cell( ':eq('+row+')', column, {search: 'applied'} );
if ( lastFocus ) {
// Don't trigger a refocus on the same cell
if ( lastFocus.node() === cell.node() ) {
return;
}
// Otherwise blur the old focus
this._blur();
}
var node = $( cell.node() );
node.addClass( this.c.className );
// Shift viewpoint and page to make cell visible
if ( shift === undefined || shift === true ) {
this._scroll( $(window), $(document.body), node, 'offset' );
var bodyParent = dt.table().body().parentNode;
if ( bodyParent !== dt.table().header().parentNode ) {
var parent = $(bodyParent.parentNode);
this._scroll( parent, parent, node, 'position' );
}
}
// Event and finish
this.s.lastFocus = cell;
this._emitEvent( 'key-focus', [ this.s.dt, cell ] );
dt.state.save();
},
/**
* Handle key press
*
* @param {object} e Event
* @private
*/
_key: function ( e )
{
if ( ! this.s.enable ) {
return;
}
if ( e.keyCode === 0 || e.ctrlKey || e.metaKey || e.altKey ) {
return;
}
// If not focused, then there is no key action to take
var cell = this.s.lastFocus;
if ( ! cell ) {
return;
}
var that = this;
var dt = this.s.dt;
// If we are not listening for this key, do nothing
if ( this.c.keys && $.inArray( e.keyCode, this.c.keys ) === -1 ) {
return;
}
switch( e.keyCode ) {
case 9: // tab
this._shift( e, e.shiftKey ? 'left' : 'right', true );
break;
case 27: // esc
if ( this.s.blurable && this.s.enable === true ) {
this._blur();
}
break;
case 33: // page up (previous page)
case 34: // page down (next page)
e.preventDefault();
var index = dt.cells( {page: 'current'} ).nodes().indexOf( cell.node() );
dt
.one( 'draw', function () {
var nodes = dt.cells( {page: 'current'} ).nodes();
that._focus( dt.cell( index < nodes.length ?
nodes[ index ] :
nodes[ nodes.length-1 ]
) );
} )
.page( e.keyCode === 33 ? 'previous' : 'next' )
.draw( false );
break;
case 35: // end (end of current page)
case 36: // home (start of current page)
e.preventDefault();
var indexes = dt.cells( {page: 'current'} ).indexes();
this._focus( dt.cell(
indexes[ e.keyCode === 35 ? indexes.length-1 : 0 ]
) );
break;
case 37: // left arrow
this._shift( e, 'left' );
break;
case 38: // up arrow
this._shift( e, 'up' );
break;
case 39: // right arrow
this._shift( e, 'right' );
break;
case 40: // down arrow
this._shift( e, 'down' );
break;
default:
// Everything else - pass through only when fully enabled
if ( this.s.enable === true ) {
this._emitEvent( 'key', [ dt, e.keyCode, this.s.lastFocus, e ] );
}
break;
}
},
/**
* Scroll a container to make a cell visible in it. This can be used for
* both DataTables scrolling and native window scrolling.
*
* @param {jQuery} container Scrolling container
* @param {jQuery} scroller Item being scrolled
* @param {jQuery} cell Cell in the scroller
* @param {string} posOff `position` or `offset` - which to use for the
* calculation. `offset` for the document, otherwise `position`
* @private
*/
_scroll: function ( container, scroller, cell, posOff )
{
var offset = cell[posOff]();
var height = cell.outerHeight();
var width = cell.outerWidth();
var scrollTop = scroller.scrollTop();
var scrollLeft = scroller.scrollLeft();
var containerHeight = container.height();
var containerWidth = container.width();
// Top correction
if ( offset.top < scrollTop ) {
scroller.scrollTop( offset.top );
}
// Left correction
if ( offset.left < scrollLeft ) {
scroller.scrollLeft( offset.left );
}
// Bottom correction
if ( offset.top + height > scrollTop + containerHeight && height < containerHeight ) {
scroller.scrollTop( offset.top + height - containerHeight );
}
// Right correction
if ( offset.left + width > scrollLeft + containerWidth && width < containerWidth ) {
scroller.scrollLeft( offset.left + width - containerWidth );
}
},
/**
* Calculate a single offset movement in the table - up, down, left and
* right and then perform the focus if possible
*
* @param {object} e Event object
* @param {string} direction Movement direction
* @param {boolean} keyBlurable `true` if the key press can result in the
* table being blurred. This is so arrow keys won't blur the table, but
* tab will.
* @private
*/
_shift: function ( e, direction, keyBlurable )
{
var that = this;
var dt = this.s.dt;
var pageInfo = dt.page.info();
var rows = pageInfo.recordsDisplay;
var currentCell = this.s.lastFocus;
var columns = this._columns();
if ( ! currentCell ) {
return;
}
var currRow = dt
.rows( { filter: 'applied', order: 'applied' } )
.indexes()
.indexOf( currentCell.index().row );
// When server-side processing, `rows().indexes()` only gives the rows
// that are available at the client-side, so we need to normalise the
// row's current position by the display start point
if ( pageInfo.serverSide ) {
currRow += pageInfo.start;
}
var currCol = dt
.columns( columns )
.indexes()
.indexOf( currentCell.index().column );
var
row = currRow,
column = columns[ currCol ]; // row is the display, column is an index
if ( direction === 'right' ) {
if ( currCol >= columns.length - 1 ) {
row++;
column = columns[0];
}
else {
column = columns[ currCol+1 ];
}
}
else if ( direction === 'left' ) {
if ( currCol === 0 ) {
row--;
column = columns[ columns.length - 1 ];
}
else {
column = columns[ currCol-1 ];
}
}
else if ( direction === 'up' ) {
row--;
}
else if ( direction === 'down' ) {
row++;
}
if ( row >= 0 && row < rows && $.inArray( column, columns ) !== -1
) {
e.preventDefault();
this._focus( row, column );
}
else if ( ! keyBlurable || ! this.c.blurable ) {
// No new focus, but if the table isn't blurable, then don't loose
// focus
e.preventDefault();
}
else {
this._blur();
}
},
/**
* Create a hidden input element that can receive focus on behalf of the
* table
*
* @private
*/
_tabInput: function ()
{
var that = this;
var dt = this.s.dt;
var tabIndex = this.c.tabIndex !== null ?
this.c.tabIndex :
dt.settings()[0].iTabIndex;
if ( tabIndex == -1 ) {
return;
}
var div = $('<div><input type="text" tabindex="'+tabIndex+'"/></div>')
.css( {
position: 'absolute',
height: 1,
width: 0,
overflow: 'hidden'
} )
.insertBefore( dt.table().node() );
div.children().on( 'focus', function () {
that._focus( dt.cell(':eq(0)', '0:visible', {page: 'current'}) );
} );
}
} );
/**
* KeyTable default settings for initialisation
*
* @namespace
* @name KeyTable.defaults
* @static
*/
KeyTable.defaults = {
/**
* Can focus be removed from the table
* @type {Boolean}
*/
blurable: true,
/**
* Class to give to the focused cell
* @type {String}
*/
className: 'focus',
/**
* Columns that can be focused. This is automatically merged with the
* visible columns as only visible columns can gain focus.
* @type {String}
*/
columns: '', // all
/**
* Editor instance to automatically perform Excel like navigation
* @type {Editor}
*/
editor: null,
/**
* Select a cell to automatically select on start up. `null` for no
* automatic selection
* @type {cell-selector}
*/
focus: null,
/**
* Array of keys to listen for
* @type {null|array}
*/
keys: null,
/**
* Tab index for where the table should sit in the document's tab flow
* @type {integer|null}
*/
tabIndex: null
};
KeyTable.version = "2.1.2";
$.fn.dataTable.KeyTable = KeyTable;
$.fn.DataTable.KeyTable = KeyTable;
DataTable.Api.register( 'cell.blur()', function () {
return this.iterator( 'table', function (ctx) {
if ( ctx.keytable ) {
ctx.keytable.blur();
}
} );
} );
DataTable.Api.register( 'cell().focus()', function () {
return this.iterator( 'cell', function (ctx, row, column) {
if ( ctx.keytable ) {
ctx.keytable.focus( row, column );
}
} );
} );
DataTable.Api.register( 'keys.disable()', function () {
return this.iterator( 'table', function (ctx) {
if ( ctx.keytable ) {
ctx.keytable.enable( false );
}
} );
} );
DataTable.Api.register( 'keys.enable()', function ( opts ) {
return this.iterator( 'table', function (ctx) {
if ( ctx.keytable ) {
ctx.keytable.enable( opts === undefined ? true : opts );
}
} );
} );
// Cell selector
DataTable.ext.selector.cell.push( function ( settings, opts, cells ) {
var focused = opts.focused;
var kt = settings.keytable;
var out = [];
if ( ! kt || focused === undefined ) {
return cells;
}
for ( var i=0, ien=cells.length ; i<ien ; i++ ) {
if ( (focused === true && kt.focused( cells[i] ) ) ||
(focused === false && ! kt.focused( cells[i] ) )
) {
out.push( cells[i] );
}
}
return out;
} );
// Attach a listener to the document which listens for DataTables initialisation
// events so we can automatically initialise
$(document).on( 'preInit.dt.dtk', function (e, settings, json) {
if ( e.namespace !== 'dt' ) {
return;
}
var init = settings.oInit.keys;
var defaults = DataTable.defaults.keys;
if ( init || defaults ) {
var opts = $.extend( {}, init, defaults );
if ( init !== false ) {
new KeyTable( settings, opts );
}
}
} );
return KeyTable;
}));

View File

@@ -0,0 +1,18 @@
/*!
KeyTable 2.1.2
©2009-2016 SpryMedia Ltd - datatables.net/license
*/
(function(e){"function"===typeof define&&define.amd?define(["jquery","datatables.net"],function(k){return e(k,window,document)}):"object"===typeof exports?module.exports=function(k,g){k||(k=window);if(!g||!g.fn.dataTable)g=require("datatables.net")(k,g).$;return e(g,k,k.document)}:e(jQuery,window,document)})(function(e,k,g,n){var h=e.fn.dataTable,l=function(a,b){if(!h.versionCheck||!h.versionCheck("1.10.8"))throw"KeyTable requires DataTables 1.10.8 or newer";this.c=e.extend(!0,{},h.defaults.keyTable,
l.defaults,b);this.s={dt:new h.Api(a),enable:!0,focusDraw:!1};this.dom={};var d=this.s.dt.settings()[0],c=d.keytable;if(c)return c;d.keytable=this;this._constructor()};e.extend(l.prototype,{blur:function(){this._blur()},enable:function(a){this.s.enable=a},focus:function(a,b){this._focus(this.s.dt.cell(a,b))},focused:function(a){if(!this.s.lastFocus)return!1;var b=this.s.lastFocus.index();return a.row===b.row&&a.column===b.column},_constructor:function(){this._tabInput();var a=this,b=this.s.dt,d=e(b.table().node());
"static"===d.css("position")&&d.css("position","relative");e(b.table().body()).on("click.keyTable","th, td",function(){if(!1!==a.s.enable){var c=b.cell(this);c.any()&&a._focus(c,null,!1)}});e(g).on("keydown.keyTable",function(b){a._key(b)});if(this.c.blurable)e(g).on("click.keyTable",function(c){e(c.target).parents(".dataTables_filter").length&&a._blur();e(c.target).parents().filter(b.table().container()).length||e(c.target).parents("div.DTE").length||a._blur()});if(this.c.editor)b.on("key.keyTable",
function(b,c,d,e,g){a._editor(d,g)});if(b.settings()[0].oFeatures.bStateSave)b.on("stateSaveParams.keyTable",function(b,c,d){d.keyTable=a.s.lastFocus?a.s.lastFocus.index():null});b.on("xhr.keyTable",function(){if(!a.s.focusDraw){var c=a.s.lastFocus;c&&(a.s.lastFocus=null,b.one("draw",function(){a._focus(c)}))}});b.on("destroy.keyTable",function(){b.off(".keyTable");e(b.table().body()).off("click.keyTable","th, td");e(g.body).off("keydown.keyTable").off("click.keyTable")});var c=b.state.loaded();if(c&&
c.keyTable)b.one("init",function(){var a=b.cell(c.keyTable);a.any()&&a.focus()});else this.c.focus&&b.cell(this.c.focus).focus()},_blur:function(){if(this.s.enable&&this.s.lastFocus){var a=this.s.lastFocus;e(a.node()).removeClass(this.c.className);this.s.lastFocus=null;this._emitEvent("key-blur",[this.s.dt,a])}},_columns:function(){var a=this.s.dt,b=a.columns(this.c.columns).indexes(),d=[];a.columns(":visible").every(function(a){-1!==b.indexOf(a)&&d.push(a)});return d},_editor:function(a,b){var d=
this.s.dt,c=this.c.editor;b.stopPropagation();13===a&&b.preventDefault();c.inline(this.s.lastFocus.index());var f=e("div.DTE input, div.DTE textarea");f.length&&f[0].select();d.keys.enable("navigation-only");d.one("key-blur.editor",function(){c.displayed()&&c.submit()});c.one("close",function(){d.keys.enable(!0);d.off("key-blur.editor")})},_emitEvent:function(a,b){this.s.dt.iterator("table",function(d){e(d.nTable).triggerHandler(a,b)})},_focus:function(a,b,d){var c=this,f=this.s.dt,i=f.page.info(),
m=this.s.lastFocus;if(this.s.enable){if("number"!==typeof a){var j=a.index(),b=j.column,a=f.rows({filter:"applied",order:"applied"}).indexes().indexOf(j.row);i.serverSide&&(a+=i.start)}if(-1!==i.length&&(a<i.start||a>=i.start+i.length))this.s.focusDraw=!0,f.one("draw",function(){c.s.focusDraw=!1;c._focus(a,b)}).page(Math.floor(a/i.length)).draw(!1);else if(-1!==e.inArray(b,this._columns())){i.serverSide&&(a-=i.start);i=f.cell(":eq("+a+")",b,{search:"applied"});if(m){if(m.node()===i.node())return;
this._blur()}m=e(i.node());m.addClass(this.c.className);if(d===n||!0===d)this._scroll(e(k),e(g.body),m,"offset"),d=f.table().body().parentNode,d!==f.table().header().parentNode&&(d=e(d.parentNode),this._scroll(d,d,m,"position"));this.s.lastFocus=i;this._emitEvent("key-focus",[this.s.dt,i]);f.state.save()}}},_key:function(a){if(this.s.enable&&!(0===a.keyCode||a.ctrlKey||a.metaKey||a.altKey)){var b=this.s.lastFocus;if(b){var d=this,c=this.s.dt;if(!(this.c.keys&&-1===e.inArray(a.keyCode,this.c.keys)))switch(a.keyCode){case 9:this._shift(a,
a.shiftKey?"left":"right",!0);break;case 27:this.s.blurable&&!0===this.s.enable&&this._blur();break;case 33:case 34:a.preventDefault();var f=c.cells({page:"current"}).nodes().indexOf(b.node());c.one("draw",function(){var a=c.cells({page:"current"}).nodes();d._focus(c.cell(f<a.length?a[f]:a[a.length-1]))}).page(33===a.keyCode?"previous":"next").draw(!1);break;case 35:case 36:a.preventDefault();b=c.cells({page:"current"}).indexes();this._focus(c.cell(b[35===a.keyCode?b.length-1:0]));break;case 37:this._shift(a,
"left");break;case 38:this._shift(a,"up");break;case 39:this._shift(a,"right");break;case 40:this._shift(a,"down");break;default:!0===this.s.enable&&this._emitEvent("key",[c,a.keyCode,this.s.lastFocus,a])}}}},_scroll:function(a,b,d,c){var c=d[c](),f=d.outerHeight(),d=d.outerWidth(),e=b.scrollTop(),g=b.scrollLeft(),j=a.height(),a=a.width();c.top<e&&b.scrollTop(c.top);c.left<g&&b.scrollLeft(c.left);c.top+f>e+j&&f<j&&b.scrollTop(c.top+f-j);c.left+d>g+a&&d<a&&b.scrollLeft(c.left+d-a)},_shift:function(a,
b,d){var c=this.s.dt,f=c.page.info(),i=f.recordsDisplay,g=this.s.lastFocus,j=this._columns();if(g){var h=c.rows({filter:"applied",order:"applied"}).indexes().indexOf(g.index().row);f.serverSide&&(h+=f.start);c=c.columns(j).indexes().indexOf(g.index().column);f=j[c];"right"===b?c>=j.length-1?(h++,f=j[0]):f=j[c+1]:"left"===b?0===c?(h--,f=j[j.length-1]):f=j[c-1]:"up"===b?h--:"down"===b&&h++;0<=h&&h<i&&-1!==e.inArray(f,j)?(a.preventDefault(),this._focus(h,f)):!d||!this.c.blurable?a.preventDefault():this._blur()}},
_tabInput:function(){var a=this,b=this.s.dt,d=null!==this.c.tabIndex?this.c.tabIndex:b.settings()[0].iTabIndex;if(-1!=d)e('<div><input type="text" tabindex="'+d+'"/></div>').css({position:"absolute",height:1,width:0,overflow:"hidden"}).insertBefore(b.table().node()).children().on("focus",function(){a._focus(b.cell(":eq(0)","0:visible",{page:"current"}))})}});l.defaults={blurable:!0,className:"focus",columns:"",editor:null,focus:null,keys:null,tabIndex:null};l.version="2.1.2";e.fn.dataTable.KeyTable=
l;e.fn.DataTable.KeyTable=l;h.Api.register("cell.blur()",function(){return this.iterator("table",function(a){a.keytable&&a.keytable.blur()})});h.Api.register("cell().focus()",function(){return this.iterator("cell",function(a,b,d){a.keytable&&a.keytable.focus(b,d)})});h.Api.register("keys.disable()",function(){return this.iterator("table",function(a){a.keytable&&a.keytable.enable(!1)})});h.Api.register("keys.enable()",function(a){return this.iterator("table",function(b){b.keytable&&b.keytable.enable(a===
n?!0:a)})});h.ext.selector.cell.push(function(a,b,d){var b=b.focused,a=a.keytable,c=[];if(!a||b===n)return d;for(var e=0,g=d.length;e<g;e++)(!0===b&&a.focused(d[e])||!1===b&&!a.focused(d[e]))&&c.push(d[e]);return c});e(g).on("preInit.dt.dtk",function(a,b){if("dt"===a.namespace){var d=b.oInit.keys,c=h.defaults.keys;if(d||c)c=e.extend({},d,c),!1!==d&&new l(b,c)}});return l});