Switching away from regex to use custom formats.
This commit is contained in:
parent
bdac304551
commit
bd37698055
|
@ -4,7 +4,9 @@ import { generateMetadataID } from "../db/utils"
|
||||||
import { Document } from "@budibase/types"
|
import { Document } from "@budibase/types"
|
||||||
import stream from "stream"
|
import stream from "stream"
|
||||||
import dayjs from "dayjs"
|
import dayjs from "dayjs"
|
||||||
|
import customParseFormat from "dayjs/plugin/customParseFormat"
|
||||||
|
|
||||||
|
dayjs.extend(customParseFormat)
|
||||||
const Readable = stream.Readable
|
const Readable = stream.Readable
|
||||||
|
|
||||||
export function wait(ms: number) {
|
export function wait(ms: number) {
|
||||||
|
@ -14,16 +16,27 @@ export function wait(ms: number) {
|
||||||
export const isDev = env.isDev
|
export const isDev = env.isDev
|
||||||
|
|
||||||
export const NUMBER_REGEX = /^[+-]?([0-9]*[.])?[0-9]+$/g
|
export const NUMBER_REGEX = /^[+-]?([0-9]*[.])?[0-9]+$/g
|
||||||
|
const ACCEPTED_DATE_FORMATS = [
|
||||||
|
"MM/DD/YYYY",
|
||||||
|
"MM/DD/YY",
|
||||||
|
"DD/MM/YYYY",
|
||||||
|
"DD/MM/YY",
|
||||||
|
"YYYY/MM/DD",
|
||||||
|
"YYYY-MM-DD",
|
||||||
|
"YYYY-MM-DDTHH:mm",
|
||||||
|
"YYYY-MM-DDTHH:mm:ss",
|
||||||
|
"YYYY-MM-DDTHH:mm:ss[Z]",
|
||||||
|
"YYYY-MM-DDTHH:mm:ss.SSS[Z]",
|
||||||
|
]
|
||||||
|
|
||||||
export function isDate(str: string) {
|
export function isDate(str: string) {
|
||||||
// checks for xx/xx/xx or ISO date timestamp formats
|
// checks for xx/xx/xx or ISO date timestamp formats
|
||||||
return (
|
for (const format of ACCEPTED_DATE_FORMATS) {
|
||||||
/^\d{2}\/\d{2}\/\d{2,4}$|^\d{4}-\d{2}-\d{2}(T\d{2}:\d{2}(:\d{2})?)?$/.test(
|
if (dayjs(str, format, true).isValid()) {
|
||||||
str
|
return true
|
||||||
) &&
|
}
|
||||||
dayjs(str).isValid() &&
|
}
|
||||||
!str.includes(",")
|
return false
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function removeFromArray(array: any[], element: any) {
|
export function removeFromArray(array: any[], element: any) {
|
||||||
|
|
|
@ -21,6 +21,10 @@ describe("isDate", () => {
|
||||||
expect(isDate("2001-01-01T12:30:45")).toEqual(true)
|
expect(isDate("2001-01-01T12:30:45")).toEqual(true)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it("should handle complete ISO format", () => {
|
||||||
|
expect(isDate("2001-01-01T12:30:00.000Z")).toEqual(true)
|
||||||
|
})
|
||||||
|
|
||||||
it("should return false for invalid formats", () => {
|
it("should return false for invalid formats", () => {
|
||||||
expect(isDate("")).toEqual(false)
|
expect(isDate("")).toEqual(false)
|
||||||
expect(isDate("1/10")).toEqual(false)
|
expect(isDate("1/10")).toEqual(false)
|
||||||
|
|
Loading…
Reference in New Issue