×

Welcome to TagMyCode

Please login or create account to add a snippet.
0
0
 
0
Language: Javascript
Posted by: karguvel kalisekar
Added: Jun 15, 2017 4:32 AM
Views: 5
Tags: pdf word exel csc
  1. /*The MIT License (MIT)
  2.  Copyright (c) 2014 https://github.com/kayalshri/
  3.  Permission is hereby granted, free of charge, to any person obtaining a copy
  4.  of this software and associated documentation files (the "Software"), to deal
  5.  in the Software without restriction, including without limitation the rights
  6.  to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  7.  copies of the Software, and to permit persons to whom the Software is
  8.  furnished to do so, subject to the following conditions:
  9.  The above copyright notice and this permission notice shall be included in
  10.  all copies or substantial portions of the Software.
  11.  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  12.  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  13.  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  14.  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  15.  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  16.  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  17.  THE SOFTWARE.*/
  18.  
  19. (function ($) {
  20.     $.fn.extend({
  21.         tableExport: function (options) {
  22.             var defaults = {
  23.                 separator: ',',
  24.                 ignoreColumn: [],
  25.                 tableName: 'MyOwnFileName',
  26.                 type: 'csv',
  27.                 pdfFontSize: 12,
  28.                 pdfLeftMargin: 20,
  29.                 escape: 'true',
  30.                 htmlContent: 'false',
  31.                 consoleLog: 'false'
  32.             };
  33.  
  34.             var options = $.extend(defaults, options);
  35.  
  36.             var el = this;
  37.             if (defaults.type == 'csv' || defaults.type == 'txt') {
  38.  
  39.                 // Header
  40.                 var tdData = "";
  41.                 $(el).find('thead').find('tr').each(function () {
  42.                     tdData += "\n";
  43.                     $(this).filter(':visible').find('th').each(function (index, data) {
  44.                         if ($(this).css('display') != 'none') {
  45.                             if (defaults.ignoreColumn.indexOf(index) == -1) {
  46.                                 tdData += '"' + parseString($(this)) + '"' + defaults.separator;
  47.                             }
  48.                         }
  49.                     });
  50.                     tdData = $.trim(tdData);
  51.                     tdData = $.trim(tdData).substring(0, tdData.length - 1);
  52.                 });
  53.  
  54.                 // Row vs Column
  55.                 $(el).find('tbody').find('tr').each(function () {
  56.                     tdData += "\n";
  57.                     $(this).filter(':visible').find('td').each(function (index, data) {
  58.                         if ($(this).css('display') != 'none') {
  59.                             if (defaults.ignoreColumn.indexOf(index) == -1) {
  60.                                 tdData += '"' + parseString($(this)) + '"' + defaults.separator;
  61.                             }
  62.                         }
  63.                     });
  64.                     //tdData = $.trim(tdData);
  65.                     tdData = $.trim(tdData).substring(0, tdData.length - 1);
  66.                 });
  67.  
  68.                 //output
  69.                 if (defaults.consoleLog == 'true') {
  70.                     console.log(tdData);
  71.                 }
  72.                 var base64data = "base64," + $.base64.encode(tdData);
  73.                 window.open('data:application/' + defaults.type + ';filename=exportData;' + base64data);
  74.             } else if (defaults.type == 'sql') {
  75.  
  76.                 // Header
  77.                 var tdData = "INSERT INTO `" + defaults.tableName + "` (";
  78.                 $(el).find('thead').find('tr').each(function () {
  79.  
  80.                     $(this).filter(':visible').find('th').each(function (index, data) {
  81.                         if ($(this).css('display') != 'none') {
  82.                             if (defaults.ignoreColumn.indexOf(index) == -1) {
  83.                                 tdData += '`' + parseString($(this)) + '`,';
  84.                             }
  85.                         }
  86.  
  87.                     });
  88.                     tdData = $.trim(tdData);
  89.                     tdData = $.trim(tdData).substring(0, tdData.length - 1);
  90.                 });
  91.                 tdData += ") VALUES ";
  92.                 // Row vs Column
  93.                 $(el).find('tbody').find('tr').each(function () {
  94.                     tdData += "(";
  95.                     $(this).filter(':visible').find('td').each(function (index, data) {
  96.                         if ($(this).css('display') != 'none') {
  97.                             if (defaults.ignoreColumn.indexOf(index) == -1) {
  98.                                 tdData += '"' + parseString($(this)) + '",';
  99.                             }
  100.                         }
  101.                     });
  102.  
  103.                     tdData = $.trim(tdData).substring(0, tdData.length - 1);
  104.                     tdData += "),";
  105.                 });
  106.                 tdData = $.trim(tdData).substring(0, tdData.length - 1);
  107.                 tdData += ";";
  108.  
  109.                 //output
  110.                 //console.log(tdData);
  111.  
  112.                 if (defaults.consoleLog == 'true') {
  113.                     console.log(tdData);
  114.                 }
  115.  
  116.                 var base64data = "base64," + $.base64.encode(tdData);
  117.                 window.open('data:application/sql;filename=exportData;' + base64data);
  118.  
  119.  
  120.             } else if (defaults.type == 'json') {
  121.  
  122.                 var jsonHeaderArray = [];
  123.                 $(el).find('thead').find('tr').each(function () {
  124.                     var tdData = "";
  125.                     var jsonArrayTd = [];
  126.  
  127.                     $(this).filter(':visible').find('th').each(function (index, data) {
  128.                         if ($(this).css('display') != 'none') {
  129.                             if (defaults.ignoreColumn.indexOf(index) == -1) {
  130.                                 jsonArrayTd.push(parseString($(this)));
  131.                             }
  132.                         }
  133.                     });
  134.                     jsonHeaderArray.push(jsonArrayTd);
  135.  
  136.                 });
  137.  
  138.                 var jsonArray = [];
  139.                 $(el).find('tbody').find('tr').each(function () {
  140.                     var tdData = "";
  141.                     var jsonArrayTd = [];
  142.  
  143.                     $(this).filter(':visible').find('td').each(function (index, data) {
  144.                         if ($(this).css('display') != 'none') {
  145.                             if (defaults.ignoreColumn.indexOf(index) == -1) {
  146.                                 jsonArrayTd.push(parseString($(this)));
  147.                             }
  148.                         }
  149.                     });
  150.                     jsonArray.push(jsonArrayTd);
  151.  
  152.                 });
  153.  
  154.                 var jsonExportArray = [];
  155.                 jsonExportArray.push({header: jsonHeaderArray, data: jsonArray});
  156.  
  157.                 //Return as JSON
  158.                 //console.log(JSON.stringify(jsonExportArray));
  159.  
  160.                 //Return as Array
  161.                 //console.log(jsonExportArray);
  162.                 if (defaults.consoleLog == 'true') {
  163.                     console.log(JSON.stringify(jsonExportArray));
  164.                 }
  165.                 var base64data = "base64," + $.base64.encode(JSON.stringify(jsonExportArray));
  166.                 window.open('data:application/json;filename=exportData;' + base64data);
  167.             } else if (defaults.type == 'xml') {
  168.  
  169.                 var xml = '<?xml version="1.0" encoding="utf-8"?>';
  170.                 xml += '<tabledata><fields>';
  171.  
  172.                 // Header
  173.                 $(el).find('thead').find('tr').each(function () {
  174.                     $(this).filter(':visible').find('th').each(function (index, data) {
  175.                         if ($(this).css('display') != 'none') {
  176.                             if (defaults.ignoreColumn.indexOf(index) == -1) {
  177.                                 xml += "<field>" + parseString($(this)) + "</field>";
  178.                             }
  179.                         }
  180.                     });
  181.                 });
  182.                 xml += '</fields><data>';
  183.  
  184.                 // Row Vs Column
  185.  
  186.                 var rowCount = 1;
  187.                 $(el).find('tbody').find('tr').each(function () {
  188.                     xml += '<row id="' + rowCount + '">';
  189.                     var colCount = 0;
  190.                     $(this).filter(':visible').find('td').each(function (index, data) {
  191.                         if ($(this).css('display') != 'none') {
  192.                             if (defaults.ignoreColumn.indexOf(index) == -1) {
  193.                                 xml += "<column-" + colCount + ">" + parseString($(this)) + "</column-" + colCount + ">";
  194.                             }
  195.                         }
  196.                         colCount++;
  197.                     });
  198.                     rowCount++;
  199.                     xml += '</row>';
  200.                 });
  201.                 xml += '</data></tabledata>'
  202.  
  203.                 if (defaults.consoleLog == 'true') {
  204.                     console.log(xml);
  205.                 }
  206.  
  207.                 var base64data = "base64," + $.base64.encode(xml);
  208.                 window.open('data:application/xml;filename=exportData;' + base64data);
  209.  
  210.             } else if (defaults.type == 'excel' || defaults.type == 'doc' || defaults.type == 'powerpoint') {
  211.                 //console.log($(this).html());
  212.                 var excel = "<table border='1'>";
  213.                 // Header
  214.                 $(el).find('thead').find('tr').each(function (index, data) {
  215.                     if (data.id !== 'hide') {
  216.                         if ($(el).find('thead').find('tr').id !== 'hide') {
  217.                             excel += "<tr>";
  218.                             $(this).find('th').each(function (index, data) {
  219.                                 if (data.colSpan > 1 && (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')) {
  220.                                     if (data.id !== 'hide') {
  221.                                         return excel += "<th colspan=" + data.colSpan + " align=" + data.align + ">" + parseString($(this)) + "</th>";
  222.                                     }
  223.                                 } else if (data.rowSpan > 1 && (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')) {
  224.                                     if (data.id !== 'hide') {
  225.                                         return excel += "<th rowSpan=" + data.colSpan + " align=" + data.align + ">" + parseString($(this)) + "</th>";
  226.                                     }
  227.                                 } else if (data.colSpan > 1) {
  228.                                     if ($(this).find('th').length > 0) {
  229.                                         excel += "<th colspan=" + data.colSpan + ">" + (data.firstChild.data).trim();
  230.                                         excel += "<table>";
  231.                                         $(data).find('table').find('tr').each(function (index, data1) {
  232.                                             excel += "<tr>";
  233.                                             if ($(data1).find('th').length > 0) {
  234.                                                 $(data1).find('th').each(function (index, data2) {
  235.                                                     excel += "<th>" + data2.textContent + "</th>";
  236.                                                 });
  237.                                             }
  238.                                             excel += "</tr>";
  239.                                         });
  240.                                         excel += "</table>";
  241.                                         excel += "</th>";
  242.                                     } else {
  243.                                         if (data.id !== 'hide') {
  244.                                             return  excel += "<th colspan=" + data.colSpan + ">" + parseString($(this)) + "</th>";
  245.                                         }
  246.                                     }
  247.                                 } else if (data.rowSpan > 1) {
  248.                                     if (data.id !== 'hide') {
  249.                                         return  excel += "<th rowSpan=" + data.rowSpan + ">" + parseString($(this)) + "</th>";
  250.                                     }
  251.                                 } else if (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify') {
  252.                                     if (data.id !== 'hide') {
  253.                                         return  excel += "<th align=" + data.align + ">" + parseString($(this)) + "</th>";
  254.                                     }
  255.                                 } else if (defaults.ignoreColumn.indexOf(index) == -1) {
  256.                                     if (data.id !== 'hide') {
  257.                                         return  excel += "<th>" + parseString($(this)) + "</th>";
  258.                                     }
  259.                                 }
  260.                             });
  261.                             $(this).find('td').each(function (index, data) {
  262.                                
  263.                                if (data.colSpan > 1 && data.bgColor !=="" && (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')) {
  264.                                     excel += "<td colspan=" + data.colSpan + " align=" + data.align + " bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  265.                                } else if (data.rowSpan > 1 && data.bgColor !=="" (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')) {
  266.                                     excel += "<td rowSpan=" + data.colSpan + " align=" + data.align + " bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  267.                                 }else if (data.colSpan > 1 && (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')) {
  268.                                     excel += "<td colspan=" + data.colSpan + " align=" + data.align + ">" + parseString($(this)) + "</td>";
  269.                                 } else if (data.rowSpan > 1 && (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')) {
  270.                                     excel += "<td rowSpan=" + data.colSpan + " align=" + data.align + ">" + parseString($(this)) + "</td>";
  271.                                 } else if (data.colSpan > 1 && data.bgColor !=="") {
  272.                                     excel += "<td colspan=" + data.colSpan + " bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  273.                                 } else if (data.rowSpan > 1 && data.bgColor !=="") {
  274.                                     excel += "<td rowSpan=" + data.colSpan + "  bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  275.                                 }else if (data.colSpan > 1) {
  276.                                     excel += "<td colspan=" + data.colSpan + ">" + parseString($(this)) + "</td>";
  277.                                 } else if (data.rowSpan > 1) {
  278.                                     excel += "<td rowSpan=" + data.colSpan + ">" + parseString($(this)) + "</td>";
  279.                                 } else if ((data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')&& data.bgColor !=="") {
  280.                                     excel += "<td align=" + data.align + " bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  281.                                 } else if (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify') {
  282.                                     excel += "<td align=" + data.align + ">" + parseString($(this)) + "</td>";
  283.                                 } else if(data.bgColor !==""){
  284.                                      excel += "<td bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  285.                                 }  else if (defaults.ignoreColumn.indexOf(index) == -1) {
  286.                                     excel += "<td>" + parseString($(this)) + "</td>";
  287.                                 }
  288.                             });
  289.  
  290.                             excel += '</tr>';
  291.                         }
  292.                     }
  293.                 });
  294.  
  295.                 // Row Vs Column
  296.                 if (defaults.data.name === 'undefined' || defaults.data.name === undefined) {
  297.                     var rowCount = 1;
  298.                     $(el).find('tbody').find('tr').each(function (index, data) {
  299.                         if (data.id !== 'hide') {
  300.                             excel += "<tr>";
  301.                             var colCount = 0;
  302.                             $(this).find('td').each(function (index, data) {
  303.                                 if (data.id !== 'hide') {
  304.                                 if (data.colSpan > 1 && data.bgColor !=="" && (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')) {
  305.                                     excel += "<td colspan=" + data.colSpan + " align=" + data.align + " bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  306.                                 } else if (data.rowSpan > 1 && data.bgColor !=="" (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')) {
  307.                                     excel += "<td rowSpan=" + data.colSpan + " align=" + data.align + " bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  308.                                 }else if (data.colSpan > 1 && (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')) {
  309.                                     excel += "<td colspan=" + data.colSpan + " align=" + data.align + ">" + parseString($(this)) + "</td>";
  310.                                 } else if (data.rowSpan > 1 && (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')) {
  311.                                     excel += "<td rowSpan=" + data.colSpan + " align=" + data.align + ">" + parseString($(this)) + "</td>";
  312.                                 } else if (data.colSpan > 1 && data.bgColor !=="") {
  313.                                     excel += "<td colspan=" + data.colSpan + " bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  314.                                 } else if (data.rowSpan > 1 && data.bgColor !=="") {
  315.                                     excel += "<td rowSpan=" + data.colSpan + "  bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  316.                                 }else if (data.colSpan > 1) {
  317.                                     excel += "<td colspan=" + data.colSpan + ">" + parseString($(this)) + "</td>";
  318.                                 } else if (data.rowSpan > 1) {
  319.                                     excel += "<td rowSpan=" + data.colSpan + ">" + parseString($(this)) + "</td>";
  320.                                 } else if ((data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify')&& data.bgColor !=="") {
  321.                                     excel += "<td align=" + data.align + " bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  322.                                 } else if (data.align === 'left' || data.align === 'right' || data.align === 'center' || data.align === 'justify') {
  323.                                     excel += "<td align=" + data.align + ">" + parseString($(this)) + "</td>";
  324.                                 } else if(data.bgColor !==""){
  325.                                      excel += "<td bgcolor="+ data.bgColor + ">" + parseString($(this)) + "</td>";
  326.                                 } else if (defaults.ignoreColumn.indexOf(index) == -1) {
  327.                                     var data1 = data.textContent.trim();
  328.                                     var removeAllSpecialCharactors = data1.replace(/[^\w\s]/gi, '');
  329.                                     var checkNumberOnly = /^\d+$/;
  330.  
  331.                                     if (removeAllSpecialCharactors.match(checkNumberOnly)) {
  332.                                         if (data.id === "invalidNo") {
  333.                                             var data = data.textContent + ":00"
  334.                                             excel += "<td align=right>" + data + "</td>";
  335.                                         } else {
  336.                                             excel += "<td align=right>" + parseString($(this)) + "</td>";
  337.                                         }
  338.                                     } else {
  339.                                         excel += "<td align=left>" + parseString($(this)) + "</td>";
  340.                                     }
  341.                                 }
  342. //                        if (defaults.ignoreColumn.indexOf(index) == -1) {
  343. //                            excel += "<td>" + parseString($(this)) + "</td>";
  344. //                        }
  345.                                 colCount++;
  346.                                 }
  347.                             });
  348.                             rowCount++;
  349.                             excel += '</tr>';
  350.                         }
  351.                     });
  352.                 } else {
  353.                     var rowCount = 1;
  354.                     $(el).find('tbody').find('tr').each(function () {
  355.                         if ($(this).find('td').length > 2) {
  356.                             excel += "<tr>";
  357.                             var colCount = 0;
  358.                             $(this).find('td').each(function (index, data) {
  359.                                 if (data.colSpan > 1 || data.id === 'show' || data.id === 'shown') {
  360.                                     if (data.colSpan > 1) {
  361.                                         excel += "<td colspan=" + data.colSpan + ">";
  362.                                         excel += "<table>";
  363.                                         excel += "<tr>";
  364.                                     } else if (data.id === 'show') {
  365.                                         excel += "<td align='center'> " + data.textContent + "</td>";
  366.                                     } else if (data.id === 'shown') {
  367.                                         excel += "<td align='center'>" + data.textContent + "</td>";
  368.                                         excel += "</tr>";
  369.                                         excel += "</table>";
  370.                                         excel += "</td>";
  371.                                     }
  372.                                 } else {
  373.                                     var data = data.textContent.trim();
  374.                                     var removeAllSpecialCharactors = data.replace(/[^\w\s]/gi, '');
  375.                                     var checkNumberOnly = /^\d+$/;
  376.                                     if (removeAllSpecialCharactors.match(checkNumberOnly)) {
  377.                                         excel += "<td align=right>" + parseString($(this)) + "</td>";
  378.                                     } else {
  379.                                         excel += "<td align=left>" + parseString($(this)) + "</td>";
  380.                                     }
  381.                                 }
  382.                                 colCount++;
  383.                             });
  384.  
  385.                             rowCount++;
  386.                             excel += '</tr>';
  387.                         }
  388.                     });
  389.                 }
  390.  
  391.                 excel += '</table>';
  392.                 if (defaults.consoleLog === 'true') {
  393.  
  394.                 }
  395.                
  396.                 var excelFile = "<html xmlns:o='urn:schemas-microsoft-com:office:office' xmlns:x='urn:schemas-microsoft-com:office:" + defaults.type + "' xmlns='http://www.w3.org/TR/REC-html40'>";
  397.                 excelFile += "<head>";
  398.                 excelFile += "<!--[if gte mso 9]>";
  399.                 excelFile += "<xml>";
  400.                 excelFile += "<x:ExcelWorkbook>";
  401.                 excelFile += "<x:ExcelWorksheets>";
  402.                 excelFile += "<x:ExcelWorksheet>";
  403.                 excelFile += "<x:Name>";
  404.                 excelFile += "{worksheet}";
  405.                 excelFile += "</x:Name>";
  406.                 excelFile += "<x:WorksheetOptions>";
  407.                 excelFile += "<x:DisplayGridlines/>";
  408.                 excelFile += "</x:WorksheetOptions>";
  409.                 excelFile += "</x:ExcelWorksheet>";
  410.                 excelFile += "</x:ExcelWorksheets>";
  411.                 excelFile += "</x:ExcelWorkbook>";
  412.                 excelFile += "</xml>";
  413.                 excelFile += "<![endif]-->";
  414.                 excelFile += "</head>";
  415.                 excelFile += "<body>";
  416.                 excelFile += excel;
  417.                 excelFile += "</body>";
  418.                 excelFile += "</html>";
  419.                 var Base64 = {_keyStr: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=", encode: function (e) {
  420.                         var t = "";
  421.                         var n, r, i, s, o, u, a;
  422.                         var f = 0;
  423.                         e = Base64._utf8_encode(e);
  424.                         while (f < e.length) {
  425.                             n = e.charCodeAt(f++);
  426.                             r = e.charCodeAt(f++);
  427.                             i = e.charCodeAt(f++);
  428.                             s = n >> 2;
  429.                             o = (n & 3) << 4 | r >> 4;
  430.                             u = (r & 15) << 2 | i >> 6;
  431.                             a = i & 63;
  432.                             if (isNaN(r)) {
  433.                                 u = a = 64;
  434.                             } else if (isNaN(i)) {
  435.                                 a = 64;
  436.                             }
  437.                             t = t + this._keyStr.charAt(s) + this._keyStr.charAt(o) + this._keyStr.charAt(u) + this._keyStr.charAt(a)
  438.                         }
  439.                         return t;
  440.                     }, decode: function (e) {
  441.                         var t = "";
  442.                         var n, r, i;
  443.                         var s, o, u, a;
  444.                         var f = 0;
  445.                         e = e.replace(/[^A-Za-z0-9+/=]/g, "");
  446.                         while (f < e.length) {
  447.                             s = this._keyStr.indexOf(e.charAt(f++));
  448.                             o = this._keyStr.indexOf(e.charAt(f++));
  449.                             u = this._keyStr.indexOf(e.charAt(f++));
  450.                             a = this._keyStr.indexOf(e.charAt(f++));
  451.                             n = s << 2 | o >> 4;
  452.                             r = (o & 15) << 4 | u >> 2;
  453.                             i = (u & 3) << 6 | a;
  454.                             t = t + String.fromCharCode(n);
  455.                             if (u != 64) {
  456.                                 t = t + String.fromCharCode(r)
  457.                             }
  458.                             if (a != 64) {
  459.                                 t = t + String.fromCharCode(i)
  460.                             }
  461.                         }
  462.                         t = Base64._utf8_decode(t);
  463.                         return t
  464.                     }, _utf8_encode: function (e) {
  465.                         e = e.replace(/rn/g, "n");
  466.                         var t = "";
  467.                         for (var n = 0; n < e.length; n++) {
  468.                             var r = e.charCodeAt(n);
  469.                             if (r < 128) {
  470.                                 t += String.fromCharCode(r)
  471.                             } else if (r > 127 && r < 2048) {
  472.                                 t += String.fromCharCode(r >> 6 | 192);
  473.                                 t += String.fromCharCode(r & 63 | 128)
  474.                             } else {
  475.                                 t += String.fromCharCode(r >> 12 | 224);
  476.                                 t += String.fromCharCode(r >> 6 & 63 | 128);
  477.                                 t += String.fromCharCode(r & 63 | 128)
  478.                             }
  479.                         }
  480.                         return t
  481.                     }, _utf8_decode: function (e) {
  482.                         var t = "";
  483.                         var n = 0;
  484.                         var r = c1 = c2 = 0;
  485.                         while (n < e.length) {
  486.                             r = e.charCodeAt(n);
  487.                             if (r < 128) {
  488.                                 t += String.fromCharCode(r);
  489.                                 n++
  490.                             } else if (r > 191 && r < 224) {
  491.                                 c2 = e.charCodeAt(n + 1);
  492.                                 t += String.fromCharCode((r & 31) << 6 | c2 & 63);
  493.                                 n += 2
  494.                             } else {
  495.                                 c2 = e.charCodeAt(n + 1);
  496.                                 c3 = e.charCodeAt(n + 2);
  497.                                 t += String.fromCharCode((r & 15) << 12 | (c2 & 63) << 6 | c3 & 63);
  498.                                 n += 3
  499.                             }
  500.                         }
  501.                         return t
  502.                     }}
  503.                 var base64data = "base64," + Base64.encode(excelFile);
  504.  
  505. //                document.getElementById("dlink").href = 'data:application/vnd.ms-' + defaults.type + ';filename=exportData.doc;' + base64data;
  506. //                document.getElementById("dlink").download = defaults.tableName.toString() + '.xls';
  507. //                document.getElementById("dlink").click();
  508. //               // window.open('data:application/vnd.ms-' + defaults.type + ';filename=exportData.doc;' + base64data);
  509.                 $('<a style="display:none" href="data:application/vnd.ms-' + defaults.type + ';filename=exportData.doc;' + base64data + '" download="' + defaults.data.filename.toString() + '.xls"><span></span></a>').appendTo(document.body).find('span').trigger("click").parent().remove();
  510.             } else if (defaults.type == 'png') {
  511.                 html2canvas($(el), {
  512.                     onrendered: function (canvas) {
  513.                         var img = canvas.toDataURL("image/png");
  514.                         window.open(img);
  515.  
  516.  
  517.                     }
  518.                 });
  519.             } else
  520.             if (defaults.type == 'pdf') {
  521.                 var mValue;
  522.                 if(options.data.Header5){
  523.                     mValue=105;
  524.                 }else{
  525.                     mValue=85;
  526.                 }
  527.                 if (options.data.heading === 'Consolidate Payroll Report') {
  528.                     var doc = new jsPDF('l', 'pt', 'a4', true);
  529.                 } else {
  530.                     var doc = new jsPDF('p', 'pt', 'a4', true);
  531.                 }
  532.                 var totalPagesExp = "{total_pages_count_string}";
  533.                 var val = [];
  534.                 doc.setFontSize(defaults.pdfFontSize);
  535.                 var res = doc.autoTableHtmlToJson(document.getElementById("testTablePDF"), false);
  536.  
  537.                 var base64data;
  538.  
  539.                 //var imgData = '';
  540.  
  541.                 var pageContent = function (data) {
  542.                     // HEADER
  543.                     doc.setFontSize(18);
  544.                     doc.setTextColor(40);
  545.                     doc.setFontStyle('normal');
  546.                     if (options.data.datas.loadedImg) {
  547.                         //doc.addImage(options.data.datas.loadedImg, options.data.datas.logo.fileType, data.settings.margin.left, 10, 75, 25);
  548.  
  549.                     }
  550.                     if (options.data.Header1) {
  551.                         var Header = options.data.Header1;
  552.                         var Semicolon = " : ";
  553.                         var Content = options.data.Content1;
  554.                         doc.setFontSize(9);
  555.                         doc.setTextColor(40);
  556.                         var xOffset = (doc.internal.pageSize.width / 2) - (doc.getStringUnitWidth(Semicolon) * doc.internal.getFontSize() / 2);
  557.                         doc.text(Header, data.settings.margin.left, 50);
  558.                         doc.text(Semicolon, xOffset - 175, 50);
  559.                         doc.text(Content, xOffset - 110, 50);
  560.                     }
  561.                     if (options.data.Header2) {
  562.                         var Header = options.data.Header2;
  563.                         var Semicolon = " : ";
  564.                         var Content = options.data.Content2;
  565.                         doc.setFontSize(9);
  566.                         doc.setTextColor(40);
  567.                         var xOffset = (doc.internal.pageSize.width / 2) - (doc.getStringUnitWidth(Semicolon) * doc.internal.getFontSize() / 2);
  568.                         doc.text(Header, data.settings.margin.left, 60);
  569.                         doc.text(Semicolon, xOffset - 175, 60);
  570.                         doc.text(Content, xOffset - 110, 60);
  571.                     }
  572.                     if (options.data.Header3) {
  573.  
  574.                         var Header = options.data.Header3;
  575.                         var Semicolon = " : ";
  576.                         var Content = options.data.Content3.toString();
  577.                         doc.setFontSize(9);
  578.                         doc.setTextColor(40);
  579.                         var xOffset = (doc.internal.pageSize.width / 2) - (doc.getStringUnitWidth(Semicolon) * doc.internal.getFontSize() / 2);
  580.                         doc.text(Header, data.settings.margin.left, 70);
  581.