@toreda/strong-types
Version:
Better TypeScript code in fewer lines.
1 lines • 3.16 kB
Source Map (JSON)
{"version":3,"sources":["../src/rule/must.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AAEH,OAAO,EAAC,OAAO,EAAc,MAAM,aAAa,CAAC;AAEjD,OAAO,EAAC,IAAI,EAAC,MAAM,SAAS,CAAC;AAC7B,OAAO,EAAC,MAAM,EAAC,MAAM,MAAM,CAAC;AAC5B,OAAO,EAAC,YAAY,EAAC,MAAM,YAAY,CAAC;AACxC,OAAO,EAAC,QAAQ,EAAC,MAAM,QAAQ,CAAC;AAChC,OAAO,EAAC,SAAS,EAAC,MAAM,SAAS,CAAC;AAElC,OAAO,EAAC,OAAO,EAAC,MAAM,OAAO,CAAC;AAE9B;;;;GAIG;AACH,qBAAa,QAAQ;IACpB,SAAgB,EAAE,EAAE,MAAM,CAAC;IAC3B,SAAgB,IAAI,EAAE,QAAQ,CAAC;IAC/B,SAAgB,GAAG,EAAE,OAAO,CAAC;IAC7B,SAAgB,KAAK,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;IACzC,SAAgB,KAAK,EAAE,SAAS,CAAC;IACjC,SAAgB,OAAO,EAAE,YAAY,CAAC;gBAE1B,KAAK,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,IAAI,GAAG,IAAI;CAmBlD","file":"must.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 {IsEqual, isEqualMake} from '../is/equal';\n\nimport {Rule} from '../rule';\nimport {RuleBe} from './be';\nimport {RuleContains} from './contains';\nimport {RuleHave} from './have';\nimport {RuleMatch} from './match';\nimport {RuleMods} from './mods';\nimport {RuleNot} from './not';\n\n/**\n * Begins a new statement within a rule.\n *\n * @category Rules\n */\nexport class RuleMust {\n\tpublic readonly be: RuleBe;\n\tpublic readonly have: RuleHave;\n\tpublic readonly not: RuleNot;\n\tpublic readonly equal: IsEqual<RuleMust>;\n\tpublic readonly match: RuleMatch;\n\tpublic readonly contain: RuleContains;\n\n\tconstructor(rules: Rule[], parentRule: Rule | null) {\n\t\tconst rule = parentRule ? parentRule : new Rule();\n\t\tif (!parentRule) {\n\t\t\trules.push(rule);\n\t\t}\n\n\t\t// Each must begins a new rule and resets all preceding mods.\n\t\tconst mods: RuleMods = {\n\t\t\tinvert: false,\n\t\t\ttarget: 'value'\n\t\t};\n\n\t\tthis.be = new RuleBe(rule, mods);\n\t\tthis.have = new RuleHave(rule, mods);\n\t\tthis.not = new RuleNot(rule, mods);\n\t\tthis.equal = isEqualMake<RuleMust>(this, rule, mods);\n\t\tthis.match = new RuleMatch(rule, mods);\n\t\tthis.contain = new RuleContains(rule, mods);\n\t}\n}\n"]}