From 0ab43ae83a39aabc0b3e1ebd8fb33dff2a9d7660 Mon Sep 17 00:00:00 2001 From: SandyDatatables Date: Fri, 5 Feb 2021 16:41:19 +0000 Subject: [PATCH] new: Luxon version of the Ultimate Date Sorting Plugin Jira Issue DD-1841 --- sorting/datetime-luxon.js | 74 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 sorting/datetime-luxon.js diff --git a/sorting/datetime-luxon.js b/sorting/datetime-luxon.js new file mode 100644 index 0000000..9baf91f --- /dev/null +++ b/sorting/datetime-luxon.js @@ -0,0 +1,74 @@ +/** + * This plug-in for DataTables represents the ultimate option in extensibility + * for sorting date / time strings correctly. It uses + * [luxon](https://moment.github.io/luxon/) to create automatic type detection and + * sorting plug-ins for DataTables based on a given format. This way, DataTables + * will automatically detect your temporal information and sort it correctly. + * + * For usage instructions, please see the DataTables blog + * post that [introduces it](//datatables.net/blog/2014-12-18). + * + * @name Ultimate Date / Time sorting + * @summary Sort date and time in any format using luxon + * @author [Allan Jardine](//datatables.net) + * @depends DataTables 1.10+, luxon.js 1.0+ + * + * @example + * $.fn.dataTable.luxon( 'HH:mm MMM d, yy' ); + * $.fn.dataTable.luxon( 'EEE, MMMM Do, yyyy' ); + * + * $('#example').DataTable(); + */ + +(function (factory) { + if (typeof define === "function" && define.amd) { + define(["jquery", "luxon", "datatables.net"], factory); + } else { + factory(jQuery, luxon); + } +}(function ($, luxon) { + +function strip (d) { + if ( typeof d === 'string' ) { + // Strip HTML tags and newline characters if possible + d = d.replace(/(<.*?>)|(\r?\n|\r)/g, ''); + + // Strip out surrounding white space + d = d.trim(); + } + + return d; +} + +$.fn.dataTable.luxon = function ( format, locale, reverseEmpties ) { + var types = $.fn.dataTable.ext.type; + + // Add type detection + types.detect.unshift( function ( d ) { + d = strip(d); + + // Null and empty values are acceptable + if ( d === '' || d === null ) { + return 'luxon-'+format; + } + + if(!luxon.DateTime.fromFormat( d, format).isValid) { + console.log("pause") + } + + return luxon.DateTime.fromFormat( d, format).isValid ? + 'luxon-'+format : + null; + } ); + + // Add sorting method - use an integer for the sorting + types.order[ 'luxon-'+format+'-pre' ] = function ( d ) { + d = strip(d); + + return !luxon.DateTime.fromFormat(d, format).isValid ? + (reverseEmpties ? -Infinity : Infinity) : + parseInt( luxon.DateTime.fromFormat( d, format).ts, 10 ); + }; +}; + +})); \ No newline at end of file