examples.js 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354
  1. /*
  2. |--------------------------------------------------------------------------
  3. | This file contains examples of how to use this plugin
  4. |--------------------------------------------------------------------------
  5. |
  6. | To see what the pdfs generated by these examples looks like you can open
  7. | ´examples.html´ or go to http://simonbengtsson.github.io/jsPDF-AutoTable.
  8. |
  9. | To make it possible to view each example in examples.html some extra code
  10. | are added to the examples below. For example they return their jspdf
  11. | doc instance and gets generated data from the library faker.js. However you
  12. | can of course use this plugin how you wish and the simplest first example
  13. | below would look like this without any extras:
  14. |
  15. | var columns = ["ID", "Name", "Age", "City"];
  16. |
  17. | var data = [
  18. | [1, "Jonatan", 25, "Gothenburg"],
  19. | [2, "Simon", 23, "Gothenburg"],
  20. | [3, "Hanna", 21, "Stockholm"]
  21. | ];
  22. |
  23. | var doc = new jsPDF('p', 'pt');
  24. | doc.autoTable(columns, data);
  25. | doc.save("table.pdf");
  26. |
  27. */
  28. var examples = {};
  29. // Default - shows what a default table looks like
  30. examples.auto = function () {
  31. var doc = new jsPDF('p', 'pt');
  32. doc.autoTable(getColumns(), getData());
  33. return doc;
  34. };
  35. // Minimal - shows how compact tables can be drawn
  36. examples.minimal = function () {
  37. var doc = new jsPDF('p', 'pt');
  38. doc.autoTable(getColumns(), getData(), {
  39. tableWidth: 'wrap',
  40. styles: {cellPadding: 2},
  41. headerStyles: {rowHeight: 15, fontSize: 8},
  42. bodyStyles: {rowHeight: 12, fontSize: 8, valign: 'middle'}
  43. });
  44. return doc;
  45. };
  46. // Long data - shows how the overflow features looks and can be used
  47. examples.long = function () {
  48. var doc = new jsPDF('l', 'pt');
  49. var columnsLong = getColumns().concat([
  50. {title: shuffleSentence(), dataKey: "text"},
  51. {title: "Text with a\nlinebreak", dataKey: "text2"}
  52. ]);
  53. doc.text("Overflow 'ellipsize' (default)", 10, 40);
  54. doc.autoTable(columnsLong, getData(), {
  55. startY: 55,
  56. margin: {horizontal: 10},
  57. columnStyles: {text: {columnWidth: 250}}
  58. });
  59. doc.text("Overflow 'hidden'", 10, doc.autoTableEndPosY() + 30);
  60. doc.autoTable(columnsLong, getData(), {
  61. startY: doc.autoTableEndPosY() + 45,
  62. margin: {horizontal: 10},
  63. styles: {overflow: 'hidden'},
  64. columnStyles: {email: {columnWidth: 160}}
  65. });
  66. doc.text("Overflow 'linebreak'", 10, doc.autoTableEndPosY() + 30);
  67. doc.autoTable(columnsLong, getData(3), {
  68. startY: doc.autoTableEndPosY() + 45,
  69. margin: {horizontal: 10},
  70. styles: {overflow: 'linebreak'},
  71. bodyStyles: {valign: 'top'},
  72. columnStyles: {email: {columnWidth: 'wrap'}},
  73. });
  74. return doc;
  75. };
  76. // Content - shows how tables can be integrated with any other pdf content
  77. examples.content = function () {
  78. var doc = new jsPDF({unit: 'pt', lineHeight: 1.5, orientation: 'p'});
  79. doc.setFontSize(18);
  80. doc.text('A story about Miusov', 40, 60);
  81. doc.setFontSize(11);
  82. doc.setTextColor(100);
  83. var text = doc.splitTextToSize(shuffleSentence(faker.lorem.words(55)) + '.', doc.internal.pageSize.width - 80, {});
  84. doc.text(text, 40, 80);
  85. var cols = getColumns();
  86. cols.splice(0, 2);
  87. doc.autoTable(cols, getData(40), {startY: 150});
  88. doc.text(text, 40, doc.autoTableEndPosY() + 30);
  89. return doc;
  90. };
  91. // Multiple - shows how multiple tables can be drawn both horizontally and vertically
  92. examples.multiple = function () {
  93. var doc = new jsPDF('p', 'pt');
  94. doc.setFontSize(22);
  95. doc.text("Multiple tables", 40, 60);
  96. doc.setFontSize(12);
  97. doc.autoTable(getColumns().slice(0, 3), getData(), {
  98. startY: 90,
  99. pageBreak: 'avoid',
  100. margin: {right: 305}
  101. });
  102. doc.autoTable(getColumns().slice(0, 3), getData(), {
  103. startY: 90,
  104. pageBreak: 'avoid',
  105. margin: {left: 305}
  106. });
  107. for (var j = 0; j < 6; j++) {
  108. doc.autoTable(getColumns(), getData(9), {
  109. startY: doc.autoTableEndPosY() + 30,
  110. pageBreak: 'avoid',
  111. });
  112. }
  113. return doc;
  114. };
  115. // From html - shows how pdf tables can be be drawn from html tables
  116. examples.html = function () {
  117. var doc = new jsPDF('p', 'pt');
  118. doc.text("From HTML", 40, 50);
  119. var res = doc.autoTableHtmlToJson(document.getElementById("basic-table"));
  120. doc.autoTable(res.columns, res.data, {startY: 60});
  121. return doc;
  122. };
  123. // Header and footers - shows how header and footers can be drawn
  124. examples['header-footer'] = function () {
  125. var doc = new jsPDF('p', 'pt');
  126. var header = function (data) {
  127. doc.setFontSize(20);
  128. doc.setTextColor(40);
  129. doc.setFontStyle('normal');
  130. doc.addImage(headerImgData, 'JPEG', data.settings.margin.left, 40, 25, 25);
  131. doc.text("Report", data.settings.margin.left + 35, 60);
  132. };
  133. var totalPagesExp = "{total_pages_count_string}";
  134. var footer = function (data) {
  135. var str = "Page " + data.pageCount;
  136. // Total page number plugin only available in jspdf v1.0+
  137. if (typeof doc.putTotalPages === 'function') {
  138. str = str + " of " + totalPagesExp;
  139. }
  140. doc.text(str, data.settings.margin.left, doc.internal.pageSize.height - 30);
  141. };
  142. var options = {
  143. beforePageContent: header,
  144. afterPageContent: footer,
  145. margin: {top: 80}
  146. };
  147. doc.autoTable(getColumns(), getData(40), options);
  148. // Total page number plugin only available in jspdf v1.0+
  149. if (typeof doc.putTotalPages === 'function') {
  150. doc.putTotalPages(totalPagesExp);
  151. }
  152. return doc;
  153. };
  154. // Themes - shows how the different themes looks
  155. examples.themes = function () {
  156. var doc = new jsPDF('p', 'pt');
  157. doc.setFontSize(12);
  158. doc.setFontStyle('bold');
  159. doc.text('Theme "striped"', 40, 50);
  160. doc.autoTable(getColumns(), getData(), {startY: 60});
  161. doc.text('Theme "grid"', 40, doc.autoTableEndPosY() + 30);
  162. doc.autoTable(getColumns(), getData(), {startY: doc.autoTableEndPosY() + 40, theme: 'grid'});
  163. doc.text('Theme "plain"', 40, doc.autoTableEndPosY() + 30);
  164. doc.autoTable(getColumns(), getData(), {startY: doc.autoTableEndPosY() + 40, theme: 'plain'});
  165. return doc;
  166. };
  167. // Horizontal - shows how tables can be drawn with horizontal headers
  168. examples.horizontal = function () {
  169. var doc = new jsPDF('p', 'pt');
  170. doc.autoTable(getColumns().splice(1,4), getData(), {
  171. drawHeaderRow: function() {
  172. // Don't draw header row
  173. return false;
  174. },
  175. columnStyles: {
  176. first_name: {fillColor: [41, 128, 185], textColor: 255, fontStyle: 'bold'}
  177. }
  178. });
  179. return doc;
  180. };
  181. // Custom style - shows how custom styles can be applied to tables
  182. examples.custom = function () {
  183. var doc = new jsPDF('p', 'pt');
  184. doc.autoTable(getColumns().slice(2, 6), getData(20), {
  185. styles: {
  186. font: 'courier',
  187. fillStyle: 'DF',
  188. lineColor: [44, 62, 80],
  189. lineWidth: 2
  190. },
  191. headerStyles: {
  192. fillColor: [44, 62, 80],
  193. fontSize: 15,
  194. rowHeight: 30
  195. },
  196. bodyStyles: {
  197. fillColor: [52, 73, 94],
  198. textColor: 240
  199. },
  200. alternateRowStyles: {
  201. fillColor: [74, 96, 117]
  202. },
  203. columnStyles: {
  204. email: {
  205. fontStyle: 'bold'
  206. }
  207. },
  208. createdCell: function (cell, data) {
  209. if (data.column.dataKey === 'expenses') {
  210. cell.styles.halign = 'right';
  211. if (cell.raw > 600) {
  212. cell.styles.textColor = [255, 100, 100];
  213. cell.styles.fontStyle = 'bolditalic';
  214. }
  215. cell.text = '$' + cell.text;
  216. } else if (data.column.dataKey === 'country') {
  217. cell.text = cell.raw.split(' ')[0];
  218. }
  219. }
  220. });
  221. return doc;
  222. };
  223. // Custom style - shows how custom styles can be applied to tables
  224. examples.spans = function () {
  225. var doc = new jsPDF('p', 'pt');
  226. doc.setFontSize(12);
  227. doc.setTextColor(0);
  228. doc.setFontStyle('bold');
  229. doc.text('Col and row span', 40, 50);
  230. var data = getData(20);
  231. data.sort(function (a, b) {
  232. return parseFloat(b.expenses) - parseFloat(a.expenses);
  233. });
  234. doc.autoTable(getColumns(), data, {
  235. theme: 'grid',
  236. startY: 60,
  237. drawRow: function (row, data) {
  238. // Colspan
  239. doc.setFontStyle('bold');
  240. doc.setFontSize(10);
  241. if (row.index === 0) {
  242. doc.setTextColor(200, 0, 0);
  243. doc.rect(data.settings.margin.left, row.y, data.table.width, 20, 'S');
  244. doc.autoTableText("Priority Group", data.settings.margin.left + data.table.width / 2, row.y + row.height / 2, {
  245. halign: 'center',
  246. valign: 'middle'
  247. });
  248. data.cursor.y += 20;
  249. } else if (row.index === 5) {
  250. doc.rect(data.settings.margin.left, row.y, data.table.width, 20, 'S');
  251. doc.autoTableText("Other Groups", data.settings.margin.left + data.table.width / 2, row.y + row.height / 2, {
  252. halign: 'center',
  253. valign: 'middle'
  254. });
  255. data.cursor.y += 20;
  256. }
  257. },
  258. drawCell: function (cell, data) {
  259. // Rowspan
  260. if (data.column.dataKey === 'id') {
  261. if (data.row.index % 5 === 0) {
  262. doc.rect(cell.x, cell.y, data.table.width, cell.height * 5, 'S');
  263. doc.autoTableText(data.row.index / 5 + 1 + '', cell.x + cell.width / 2, cell.y + cell.height * 5 / 2, {
  264. halign: 'center',
  265. valign: 'middle'
  266. });
  267. }
  268. return false;
  269. }
  270. }
  271. });
  272. return doc;
  273. };
  274. /*
  275. |--------------------------------------------------------------------------
  276. | Below is some helper functions for the examples
  277. |--------------------------------------------------------------------------
  278. */
  279. // Returns a new array each time to avoid pointer issues
  280. var getColumns = function () {
  281. return [
  282. {title: "ID", dataKey: "id"},
  283. {title: "Name", dataKey: "first_name"},
  284. {title: "Email", dataKey: "email"},
  285. {title: "City", dataKey: "city"},
  286. {title: "Country", dataKey: "country"},
  287. {title: "Expenses", dataKey: "expenses"}
  288. ];
  289. };
  290. // Uses the faker.js library to get random data.
  291. function getData(rowCount) {
  292. rowCount = rowCount || 4;
  293. var sentence = faker.lorem.words(12);
  294. var data = [];
  295. for (var j = 1; j <= rowCount; j++) {
  296. data.push({
  297. id: j,
  298. first_name: faker.name.findName(),
  299. email: faker.internet.email(),
  300. country: faker.address.country(),
  301. city: faker.address.city(),
  302. expenses: faker.finance.amount(),
  303. text: shuffleSentence(sentence),
  304. text2: shuffleSentence(sentence)
  305. });
  306. }
  307. return data;
  308. }
  309. function shuffleSentence(words) {
  310. words = words || faker.lorem.words(8);
  311. var str = faker.helpers.shuffle(words).join(' ').trim();
  312. return str.charAt(0).toUpperCase() + str.slice(1);
  313. }
  314. // Use http://dopiaza.org/tools/datauri or similar service to convert an image into image data
  315. var headerImgData = '';