org.wicketstuff.datatables.media.js.TableTools.js Maven / Gradle / Ivy
/*
* File: TableTools.js
* Version: 1.1.4
* CVS: $Id$
* Description: Copy, save and print functions for DataTables
* Author: Allan Jardine (www.sprymedia.co.uk)
* Created: Wed 1 Apr 2009 08:41:58 BST
* Modified: $Date$ by $Author$
* Language: Javascript
* License: LGPL
* Project: Just a little bit of fun :-)
* Contact: www.sprymedia.co.uk/contact
*
* Copyright 2009-2010 Allan Jardine, all rights reserved.
*
*/
/*
* Variable: TableToolsInit
* Purpose: Parameters for TableTools customisation
* Scope: global
*/
var TableToolsInit = {
"oFeatures": {
"bCsv": true,
"bXls": true,
"bCopy": true,
"bPrint": true
},
"oBom": {
"bCsv": true,
"bXls": true
},
"bIncFooter": true,
"bIncHiddenColumns": false,
"sPrintMessage": "", /* Message with will print with the table */
"sPrintInfo": "Print view
Please use your browser's print function to "+
"print this table. Press escape when finished.", /* The 'fading' message */
"sTitle": "",
"sSwfPath": "media/swf/ZeroClipboard.swf",
"iButtonHeight": 30,
"iButtonWidth": 30,
"sCsvBoundary": "'",
"_iNextId": 1 /* Internal useage - but needs to be global */
};
(function($) {
/*
* Function: TableTools
* Purpose: TableTools "class"
* Returns: same as _fnInit
* Inputs: same as _fnInit
*/
function TableTools ( oInit )
{
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Private parameters
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
var _oSettings;
var nTools = null;
var _nTableWrapper;
var _aoPrintHidden = [];
var _iPrintScroll = 0;
var _nPrintMessage = null;
var _DTSettings;
var _sLastData;
var _iId;
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Initialisation
*/
/*
* Function: _fnInit
* Purpose: Initialise the table tools
* Returns: node: - The created node for the table tools wrapping
* Inputs: object:oInit - object with:
* oDTSettings - DataTables settings
*/
function _fnInit( oInit )
{
_nTools = document.createElement('div');
_nTools.className = "TableTools";
_iId = TableToolsInit._iNextId++;
/* Copy the init object */
_oSettings = $.extend( true, {}, TableToolsInit );
_DTSettings = oInit.oDTSettings;
_nTableWrapper = fnFindParentClass( _DTSettings.nTable, "dataTables_wrapper" );
ZeroClipboard.moviePath = _oSettings.sSwfPath;
if ( _oSettings.oFeatures.bCopy ) {
fnFeatureClipboard();
}
if ( _oSettings.oFeatures.bCsv ) {
fnFeatureSaveCSV();
}
if ( _oSettings.oFeatures.bXls ) {
fnFeatureSaveXLS();
}
if ( _oSettings.oFeatures.bPrint ) {
fnFeaturePrint();
}
return _nTools;
}
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Feature buttons
*/
/*
* Function: fnFeatureSaveCSV
* Purpose: Add a button for saving a CSV file
* Returns: -
* Inputs: -
*/
function fnFeatureSaveCSV ()
{
var sBaseClass = "TableTools_button TableTools_csv";
var nButton = document.createElement( 'div' );
nButton.id = "ToolTables_CSV_"+_iId;
nButton.style.height = _oSettings.iButtonHeight+'px';
nButton.style.width = _oSettings.iButtonWidth+'px';
nButton.className = sBaseClass;
_nTools.appendChild( nButton );
var clip = new ZeroClipboard.Client();
clip.setHandCursor( true );
clip.setAction( 'save' );
clip.setCharSet( 'UTF8' );
clip.setBomInc( _oSettings.oBom.bCsv );
clip.setFileName( fnGetTitle()+'.csv' );
clip.addEventListener('mouseOver', function(client) {
nButton.className = sBaseClass+'_hover';
} );
clip.addEventListener('mouseOut', function(client) {
nButton.className = sBaseClass;
} );
clip.addEventListener('mouseDown', function(client) {
fnFlashSetText( clip, fnGetDataTablesData(",", TableToolsInit.sCsvBoundary) );
} );
fnGlue( clip, nButton, "ToolTables_CSV_"+_iId, "Save as CSV" );
}
/*
* Function: fnFeatureSaveXLS
* Purpose: Add a button for saving an XLS file
* Returns: -
* Inputs: -
*/
function fnFeatureSaveXLS ()
{
var sBaseClass = "TableTools_button TableTools_xls";
var nButton = document.createElement( 'div' );
nButton.id = "ToolTables_XLS_"+_iId;
nButton.style.height = _oSettings.iButtonHeight+'px';
nButton.style.width = _oSettings.iButtonWidth+'px';
nButton.className = sBaseClass;
_nTools.appendChild( nButton );
var clip = new ZeroClipboard.Client();
clip.setHandCursor( true );
clip.setAction( 'save' );
clip.setCharSet( 'UTF16LE' );
clip.setBomInc( _oSettings.oBom.bXls );
clip.setFileName( fnGetTitle()+'.xls' );
clip.addEventListener('mouseOver', function(client) {
nButton.className = sBaseClass+'_hover';
} );
clip.addEventListener('mouseOut', function(client) {
nButton.className = sBaseClass;
} );
clip.addEventListener('mouseDown', function(client) {
fnFlashSetText( clip, fnGetDataTablesData("\t") );
} );
fnGlue( clip, nButton, "ToolTables_XLS_"+_iId, "Save for Excel" );
}
/*
* Function: fnFeatureClipboard
* Purpose: Add a button for copying data to clipboard
* Returns: -
* Inputs: -
*/
function fnFeatureClipboard ()
{
var sBaseClass = "TableTools_button TableTools_clipboard";
var nButton = document.createElement( 'div' );
nButton.id = "ToolTables_Copy_"+_iId;
nButton.style.height = _oSettings.iButtonHeight+'px';
nButton.style.width = _oSettings.iButtonWidth+'px';
nButton.className = sBaseClass;
_nTools.appendChild( nButton );
var clip = new ZeroClipboard.Client();
clip.setHandCursor( true );
clip.setAction( 'copy' );
clip.addEventListener('mouseOver', function(client) {
nButton.className = sBaseClass+'_hover';
} );
clip.addEventListener('mouseOut', function(client) {
nButton.className = sBaseClass;
} );
clip.addEventListener('mouseDown', function(client) {
fnFlashSetText( clip, fnGetDataTablesData("\t") );
} );
clip.addEventListener('complete', function (client, text) {
var aData = _sLastData.split('\n');
alert( 'Copied '+(aData.length-1)+' rows to the clipboard' );
} );
fnGlue( clip, nButton, "ToolTables_Copy_"+_iId, "Copy to clipboard" );
}
/*
* Function: fnFeaturePrint
* Purpose: Add a button for printing data
* Returns: -
* Inputs: -
* Notes: Fun one this function. In order to print the table, we want the table to retain
* it's position in the DOM, so all styles still apply, but we don't want to print all the
* other nonesense. So we hide that nonesese and add an event handler for 'esc' which will
* restore a normal view.
*/
function fnFeaturePrint ()
{
var sBaseClass = "TableTools_button TableTools_print";
var nButton = document.createElement( 'div' );
nButton.style.height = _oSettings.iButtonHeight+'px';
nButton.style.width = _oSettings.iButtonWidth+'px';
nButton.className = sBaseClass;
nButton.title = "Print table";
_nTools.appendChild( nButton );
/* Could do this in CSS - but might as well be consistent with the flash buttons */
$(nButton).hover( function(client) {
nButton.className = sBaseClass+'_hover';
}, function(client) {
nButton.className = sBaseClass;
} );
$(nButton).click( function() {
/* Parse through the DOM hiding everything that isn't needed for the table */
fnPrintHideNodes( _DTSettings.nTable );
/* Show the whole table */
_iPrintSaveStart = _DTSettings._iDisplayStart;
_iPrintSaveLength = _DTSettings._iDisplayLength;
_DTSettings._iDisplayStart = 0;
_DTSettings._iDisplayLength = -1;
_DTSettings.oApi._fnCalculateEnd( _DTSettings );
_DTSettings.oApi._fnDraw( _DTSettings );
/* Remove the other DataTables feature nodes - but leave the table! and info div */
var anFeature = _DTSettings.anFeatures;
for ( var cFeature in anFeature )
{
if ( cFeature != 'i' && cFeature != 't' )
{
_aoPrintHidden.push( {
"node": anFeature[cFeature],
"display": "block"
} );
anFeature[cFeature].style.display = "none";
}
}
/* Add a node telling the user what is going on */
var nInfo = document.createElement( "div" );
nInfo.className = "TableTools_PrintInfo";
nInfo.innerHTML = _oSettings.sPrintInfo;
document.body.appendChild( nInfo );
/* Add a message at the top of the page */
if ( _oSettings.sPrintMessage !== "" )
{
_nPrintMessage = document.createElement( "p" );
_nPrintMessage.className = "TableTools_PrintMessage";
_nPrintMessage.innerHTML = _oSettings.sPrintMessage;
document.body.insertBefore( _nPrintMessage, document.body.childNodes[0] );
}
/* Cache the scrolling and the jump to the top of the t=page */
_iPrintScroll = $(window).scrollTop();
window.scrollTo( 0, 0 );
$(document).bind( "keyup", null, fnPrintEnd );
setTimeout( function() {
$(nInfo).fadeOut( "normal", function() {
document.body.removeChild( nInfo );
} );
}, 2000 );
} );
}
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Printing functions
*/
/*
* Function: fnPrintEnd
* Purpose: Printing is finished, resume normal display
* Returns: -
* Inputs: event
*/
function fnPrintEnd ( e )
{
/* Only interested in the escape key */
if ( e.keyCode == 27 )
{
/* Show all hidden nodes */
fnPrintShowNodes();
/* Restore the scroll */
window.scrollTo( 0, _iPrintScroll );
/* Drop the print message */
if ( _nPrintMessage )
{
document.body.removeChild( _nPrintMessage );
_nPrintMessage = null;
}
/* Restore the table length */
_DTSettings._iDisplayStart = _iPrintSaveStart;
_DTSettings._iDisplayLength = _iPrintSaveLength;
_DTSettings.oApi._fnCalculateEnd( _DTSettings );
_DTSettings.oApi._fnDraw( _DTSettings );
$(document).unbind( "keydown", fnPrintEnd );
}
}
/*
* Function: fnPrintShowNodes
* Purpose: Resume the display of all TableTools hidden nodes
* Returns: -
* Inputs: -
*/
function fnPrintShowNodes( )
{
for ( var i=0, iLen=_aoPrintHidden.length ; i= 8 && iIndex > aData[i].length - 8 )
{
sInner = aData[i].substr( iIndex );
aData[i] = aData[i].substr( 0, iIndex );
}
n.innerHTML = aData[i];
sReturn += n.childNodes[0].nodeValue;
}
return sReturn;
}
//function fnHtmlDecode( sData )
//{
// var n = document.createElement('div');
// n.innerHTML = sData;
// return n.childNodes[0].nodeValue;
//}
/*
* Function: fnChunkData
* Purpose: Break a string up into an array of smaller strings
* Returns: array strings: - string array
* Inputs: string:sData - data to be broken up
* int:iSize - chunk size
*/
function fnChunkData( sData, iSize )
{
var asReturn = [];
var iStrlen = sData.length;
for ( var i=0 ; i/g, "" );
if ( sLoopData.indexOf( '&' ) != -1 )
{
sLoopData = fnHtmlDecode( sLoopData );
}
sData += fnBoundData( sLoopData, sBoundary, regex ) + sSeperator;
}
}
sData = sData.slice( 0, sSeperator.length*-1 );
sData += sNewline;
/* Rows */
for ( j=0, jLen=_DTSettings.aiDisplay.length ; j]+)).*?>/gi, '$1$2$3')
sLoopData = sLoopData.replace( /<.*?>/g, "" );
}
else
{
sLoopData = mTypeData+"";
}
/* Trim and clean the data */
sLoopData = sLoopData.replace(/^\s+/, '').replace(/\s+$/, '');
if ( sLoopData.indexOf( '&' ) != -1 )
{
sLoopData = fnHtmlDecode( sLoopData );
}
/* Bound it and add it to the total data */
sData += fnBoundData( sLoopData, sBoundary, regex ) + sSeperator;
}
}
sData = sData.slice( 0, sSeperator.length*-1 );
sData += sNewline;
}
/* Remove the last new line */
sData.slice( 0, -1 );
/* Add the footer */
if ( _oSettings.bIncFooter )
{
for ( i=0, iLen=_DTSettings.aoColumns.length ; i/g, "" );
if ( sLoopData.indexOf( '&' ) != -1 )
{
sLoopData = fnHtmlDecode( sLoopData );
}
sData += fnBoundData( sLoopData, sBoundary, regex ) + sSeperator;
}
}
sData = sData.slice( 0, sSeperator.length*-1 );
}
/* No pointers here - this is a string copy :-) */
_sLastData = sData;
return sData;
}
/* Initialise our new object */
return _fnInit( oInit );
}
/*
* Register a new feature with DataTables
*/
if ( typeof $.fn.dataTable == "function" && typeof $.fn.dataTableExt.sVersion != "undefined" )
{
$.fn.dataTableExt.aoFeatures.push( {
"fnInit": function( oSettings ) {
return new TableTools( { "oDTSettings": oSettings } );
},
"cFeature": "T",
"sFeature": "TableTools"
} );
}
else
{
alert( "Warning: TableTools requires DataTables 1.5 or greater - "+
"www.datatables.net/download");
}
})(jQuery);