UNPKG

@toreda/strong-types

Version:

Better TypeScript code in fewer lines.

1 lines 3.29 kB
{"version":3,"sources":["../src/is/date.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AAEH,OAAO,EAAC,IAAI,EAAC,MAAM,SAAS,CAAC;AAE7B,OAAO,EAAC,QAAQ,EAAC,MAAM,cAAc,CAAC;AAItC;;;;GAIG;AACH,oBAAY,MAAM,CAAC,OAAO,IAAI,MAAM,OAAO,CAAC;AAO5C;;;;;;;GAOG;AACH,wBAAgB,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAY7C;AAED;;;;;;;;;GASG;AACH,wBAAgB,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,CAWhG","file":"date.d.ts","sourcesContent":["/**\n *\tMIT License\n *\n *\tCopyright (c) 2019 - 2021 Toreda, Inc.\n *\n *\tPermission is hereby granted, free of charge, to any person obtaining a copy\n *\tof this software and associated documentation files (the \"Software\"), to deal\n *\tin the Software without restriction, including without limitation the rights\n *\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n *\tcopies of the Software, and to permit persons to whom the Software is\n *\tfurnished to do so, subject to the following conditions:\n\n * \tThe above copyright notice and this permission notice shall be included in all\n * \tcopies or substantial portions of the Software.\n *\n * \tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n *\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n *\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * \tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n *\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n *\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * \tSOFTWARE.\n *\n */\n\nimport {Rule} from '../rule';\nimport {RuleFn} from '../rule/fn';\nimport {RuleMods} from '../rule/mods';\nimport {RuleNode} from '../rule/node';\nimport {RuleNodeType} from '../rule/node/type';\n\n/**\n * Type signature for isDate validators used in rule chains.\n *\n * @category Validators\n */\nexport type IsDate<CallerT> = () => CallerT;\n\n// eslint-disable-next-line\nconst timeStr = 'T([01]?[0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9]';\nconst timeStr1 = 'T([01]?[0-9]|2[0-3]):[0-5][0-9]';\nconst timeStr2 = 'T([01]?[0-9]|2[0-3])';\n\n/**\n * Check if provided value is a valid Date string. Accepts most ISO\n * Date strings as valid.\n * @param value\n * @returns\n *\n * @category Validators\n */\nexport function isDate(value: string): boolean {\n\tif (typeof value !== 'string') {\n\t\treturn false;\n\t}\n\n\tconst result = Date.parse(value);\n\n\tif (isNaN(result) || value.match(timeStr) || value.match(timeStr1) || value.match(timeStr2)) {\n\t\treturn false;\n\t}\n\n\treturn true;\n}\n\n/**\n * Factory function to create isDate validator function. Once created, the validator function can\n * be invoked with a value.\n * @param caller\n * @param rule\n * @param mods\n * @returns\n *\n * @category Validator Factory Functions\n */\nexport function isDateMake<CallerT>(caller: CallerT, rule: Rule, mods: RuleMods): IsDate<CallerT> {\n\treturn (): CallerT => {\n\t\tconst fn: RuleFn<string> = (curr: string): boolean => {\n\t\t\treturn isDate(curr);\n\t\t};\n\n\t\tconst node = new RuleNode<string>('IS_DATE', RuleNodeType.CMP, fn, mods);\n\t\trule.add(node);\n\n\t\treturn caller;\n\t};\n}\n"]}