mirror of
https://github.com/directus/directus.git
synced 2026-04-25 03:00:53 -04:00
Allow for + in $NOW (#8286)
* allow for + before number and simplify regex * fix regex
This commit is contained in:
@@ -1,21 +1,4 @@
|
||||
import {
|
||||
addYears,
|
||||
subWeeks,
|
||||
subYears,
|
||||
addWeeks,
|
||||
subMonths,
|
||||
addMonths,
|
||||
subDays,
|
||||
addDays,
|
||||
subHours,
|
||||
addHours,
|
||||
subMinutes,
|
||||
addMinutes,
|
||||
subSeconds,
|
||||
addSeconds,
|
||||
addMilliseconds,
|
||||
subMilliseconds,
|
||||
} from 'date-fns';
|
||||
import { addYears, addWeeks, addMonths, addDays, addHours, addMinutes, addSeconds, addMilliseconds } from 'date-fns';
|
||||
import { clone } from 'lodash';
|
||||
|
||||
/**
|
||||
@@ -27,23 +10,15 @@ import { clone } from 'lodash';
|
||||
export function adjustDate(date: Date, adjustment: string): Date | undefined {
|
||||
date = clone(date);
|
||||
|
||||
const subtract = adjustment.startsWith('-');
|
||||
|
||||
if (subtract || adjustment.startsWith('+')) {
|
||||
adjustment = adjustment.substring(1);
|
||||
}
|
||||
|
||||
const match =
|
||||
/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|months?|mth|mo|years?|yrs?|y)?$/i.exec(
|
||||
adjustment
|
||||
/^((?:-|\+)?\d*?\.?\d+?) *?(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|months?|mth|mo|years?|yrs?|y)?$/i.exec(
|
||||
adjustment.trim()
|
||||
);
|
||||
|
||||
if (!match || !match[1]) {
|
||||
return;
|
||||
}
|
||||
if (!match || !match[1]) return;
|
||||
|
||||
const amount = parseFloat(match[1]);
|
||||
const type = (match[2] || 'days').toLowerCase();
|
||||
const type = (match[2] ?? 'days').toLowerCase();
|
||||
|
||||
switch (type) {
|
||||
case 'years':
|
||||
@@ -51,44 +26,44 @@ export function adjustDate(date: Date, adjustment: string): Date | undefined {
|
||||
case 'yrs':
|
||||
case 'yr':
|
||||
case 'y':
|
||||
return subtract ? subYears(date, amount) : addYears(date, amount);
|
||||
return addYears(date, amount);
|
||||
case 'months':
|
||||
case 'month':
|
||||
case 'mth':
|
||||
case 'mo':
|
||||
return subtract ? subMonths(date, amount) : addMonths(date, amount);
|
||||
return addMonths(date, amount);
|
||||
case 'weeks':
|
||||
case 'week':
|
||||
case 'w':
|
||||
return subtract ? subWeeks(date, amount) : addWeeks(date, amount);
|
||||
return addWeeks(date, amount);
|
||||
case 'days':
|
||||
case 'day':
|
||||
case 'd':
|
||||
return subtract ? subDays(date, amount) : addDays(date, amount);
|
||||
return addDays(date, amount);
|
||||
case 'hours':
|
||||
case 'hour':
|
||||
case 'hrs':
|
||||
case 'hr':
|
||||
case 'h':
|
||||
return subtract ? subHours(date, amount) : addHours(date, amount);
|
||||
return addHours(date, amount);
|
||||
case 'minutes':
|
||||
case 'minute':
|
||||
case 'mins':
|
||||
case 'min':
|
||||
case 'm':
|
||||
return subtract ? subMinutes(date, amount) : addMinutes(date, amount);
|
||||
return addMinutes(date, amount);
|
||||
case 'seconds':
|
||||
case 'second':
|
||||
case 'secs':
|
||||
case 'sec':
|
||||
case 's':
|
||||
return subtract ? subSeconds(date, amount) : addSeconds(date, amount);
|
||||
return addSeconds(date, amount);
|
||||
case 'milliseconds':
|
||||
case 'millisecond':
|
||||
case 'msecs':
|
||||
case 'msec':
|
||||
case 'ms':
|
||||
return subtract ? subMilliseconds(date, amount) : addMilliseconds(date, amount);
|
||||
return addMilliseconds(date, amount);
|
||||
default:
|
||||
return undefined;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user