From ace89739c98e4fcb482a75bb3444eacd85eb4b08 Mon Sep 17 00:00:00 2001 From: Roger Date: Tue, 29 Jun 2021 11:05:58 +0200 Subject: [PATCH] fix: export filter with time part ('date:"MM-dd-YYYY HH:mm'). --- packages/exporter/src/js/exporter.js | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/packages/exporter/src/js/exporter.js b/packages/exporter/src/js/exporter.js index cb5679a220..64b19c0523 100755 --- a/packages/exporter/src/js/exporter.js +++ b/packages/exporter/src/js/exporter.js @@ -1653,14 +1653,15 @@ } function defaultExporterFieldCallback(grid, row, col, value) { - // fix to handle cases with 'number : 1' or 'date:MM-dd-YYYY', etc.. We needed to split the string + // fix to handle cases with 'number : 1' or 'date:"MM-dd-YYYY HH:mm"', etc.. We needed to split the string if (col.cellFilter) { - var args, filter, arg1, arg2; - // remove space, single/double to mantein retro-compatibility - args = col.cellFilter.replace(/[\'\"\s]/g, "").split(':'); - filter = args[0] ? args[0] : null; - arg1 = args[1] ? args[1] : null; - arg2 = args[2] ? args[2] : null; + var args, filter, arg1, arg2; + // Split on ':' except when in double quotes. + args = col.cellFilter.match(/(?:[^:"]+|"[^"]*")+/g); + // remove space, single/double to maintain retro-compatibility, but keep spaces in second argument (arg[1]) + filter = args[0] ? args[0].replace(/[\'\"\s]/g, "") : null; + arg1 = args[1] ? args[1].replace(/[\'\"]/g, "").trim() : null; + arg2 = args[2] ? args[2].replace(/[\'\"\s]/g, "") : null; return $filter(filter)(value, arg1, arg2); } else { return value;