@react-querybuilder/core 8.11.1 → 8.11.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. package/dist/{basic-B4vXboTG.d.mts → basic-CLG_Bmom.d.mts} +1 -1
  2. package/dist/cjs/react-querybuilder_core.cjs.development.d.ts +14 -2
  3. package/dist/cjs/react-querybuilder_core.cjs.development.js +23 -11
  4. package/dist/cjs/react-querybuilder_core.cjs.development.js.map +1 -1
  5. package/dist/cjs/react-querybuilder_core.cjs.production.d.ts +14 -2
  6. package/dist/cjs/react-querybuilder_core.cjs.production.js +1 -1
  7. package/dist/cjs/react-querybuilder_core.cjs.production.js.map +1 -1
  8. package/dist/{convertQuery-DAqoID3O.js → convertQuery-C7NvB0XA.js} +1 -1
  9. package/dist/{convertQuery-DAqoID3O.js.map → convertQuery-C7NvB0XA.js.map} +1 -1
  10. package/dist/{convertQuery-CqX3rPvj.mjs → convertQuery-Cj4t-LT4.mjs} +2 -2
  11. package/dist/{convertQuery-CqX3rPvj.mjs.map → convertQuery-Cj4t-LT4.mjs.map} +1 -1
  12. package/dist/{export-BjRt-qrK.d.mts → export-B2Yw5gak.d.mts} +2 -2
  13. package/dist/formatQuery.d.mts +15 -3
  14. package/dist/formatQuery.d.ts +13 -1
  15. package/dist/formatQuery.js +170 -423
  16. package/dist/formatQuery.js.map +1 -1
  17. package/dist/formatQuery.mjs +4 -257
  18. package/dist/formatQuery.mjs.map +1 -1
  19. package/dist/{import-Bc_p8ls9.d.mts → import-BtpySRSy.d.mts} +2 -2
  20. package/dist/{isRuleGroup-CYcfPgbg.mjs → isRuleGroup-BcfwGaIN.mjs} +1 -1
  21. package/dist/{isRuleGroup-CYcfPgbg.mjs.map → isRuleGroup-BcfwGaIN.mjs.map} +1 -1
  22. package/dist/parseCEL.d.mts +32 -7
  23. package/dist/parseCEL.d.ts +30 -5
  24. package/dist/parseCEL.js +168 -9
  25. package/dist/parseCEL.js.map +1 -1
  26. package/dist/parseCEL.mjs +163 -8
  27. package/dist/parseCEL.mjs.map +1 -1
  28. package/dist/parseJSONata.d.mts +2 -2
  29. package/dist/parseJSONata.js +2 -2
  30. package/dist/parseJSONata.mjs +3 -3
  31. package/dist/parseJsonLogic.d.mts +3 -3
  32. package/dist/parseJsonLogic.js +9 -10
  33. package/dist/parseJsonLogic.js.map +1 -1
  34. package/dist/parseJsonLogic.mjs +4 -5
  35. package/dist/parseJsonLogic.mjs.map +1 -1
  36. package/dist/parseMongoDB.d.mts +2 -2
  37. package/dist/parseMongoDB.js +19 -20
  38. package/dist/parseMongoDB.js.map +1 -1
  39. package/dist/parseMongoDB.mjs +4 -5
  40. package/dist/parseMongoDB.mjs.map +1 -1
  41. package/dist/parseSQL.d.mts +2 -2
  42. package/dist/parseSQL.js +8 -10
  43. package/dist/parseSQL.js.map +1 -1
  44. package/dist/parseSQL.mjs +3 -5
  45. package/dist/parseSQL.mjs.map +1 -1
  46. package/dist/parseSpEL.d.mts +2 -2
  47. package/dist/parseSpEL.js +3 -4
  48. package/dist/parseSpEL.js.map +1 -1
  49. package/dist/parseSpEL.mjs +3 -4
  50. package/dist/parseSpEL.mjs.map +1 -1
  51. package/dist/{prepareQueryObjects-DPCC-iHp.mjs → prepareQueryObjects-BfnyRV5t.mjs} +4 -3
  52. package/dist/{prepareQueryObjects-DPCC-iHp.mjs.map → prepareQueryObjects-BfnyRV5t.mjs.map} +1 -1
  53. package/dist/{prepareQueryObjects-BOUWfel5.js → prepareQueryObjects-Cz_28zYz.js} +12 -11
  54. package/dist/prepareQueryObjects-Cz_28zYz.js.map +1 -0
  55. package/dist/react-querybuilder_core.d.mts +14 -2
  56. package/dist/react-querybuilder_core.legacy-esm.d.ts +14 -2
  57. package/dist/react-querybuilder_core.legacy-esm.js +23 -11
  58. package/dist/react-querybuilder_core.legacy-esm.js.map +1 -1
  59. package/dist/react-querybuilder_core.mjs +23 -11
  60. package/dist/react-querybuilder_core.mjs.map +1 -1
  61. package/dist/react-querybuilder_core.production.d.mts +14 -2
  62. package/dist/react-querybuilder_core.production.mjs +1 -1
  63. package/dist/react-querybuilder_core.production.mjs.map +1 -1
  64. package/dist/{transformQuery-CWDPogO5.js → transformQuery-B4SaTTO-.js} +1 -1
  65. package/dist/{transformQuery-CWDPogO5.js.map → transformQuery-B4SaTTO-.js.map} +1 -1
  66. package/dist/{transformQuery-DCCpjtyq.mjs → transformQuery-C85j__7e.mjs} +2 -2
  67. package/dist/{transformQuery-DCCpjtyq.mjs.map → transformQuery-C85j__7e.mjs.map} +1 -1
  68. package/dist/transformQuery.d.mts +1 -1
  69. package/dist/transformQuery.js +1 -1
  70. package/dist/transformQuery.mjs +2 -2
  71. package/dist/utils-Dkz3Xn2D.js +707 -0
  72. package/dist/utils-Dkz3Xn2D.js.map +1 -0
  73. package/dist/utils-DxH23QtE.mjs +514 -0
  74. package/dist/utils-DxH23QtE.mjs.map +1 -0
  75. package/package.json +8 -8
  76. package/dist/arrayUtils-A_OXU9W1.mjs +0 -50
  77. package/dist/arrayUtils-A_OXU9W1.mjs.map +0 -1
  78. package/dist/arrayUtils-QxZOZTf6.js +0 -73
  79. package/dist/arrayUtils-QxZOZTf6.js.map +0 -1
  80. package/dist/optGroupUtils-B0hTpodo.js +0 -251
  81. package/dist/optGroupUtils-B0hTpodo.js.map +0 -1
  82. package/dist/optGroupUtils-VeZ3k7-1.mjs +0 -185
  83. package/dist/optGroupUtils-VeZ3k7-1.mjs.map +0 -1
  84. package/dist/parseNumber-CXdMVNFx.mjs +0 -24
  85. package/dist/parseNumber-CXdMVNFx.mjs.map +0 -1
  86. package/dist/parseNumber-D4iQDxK-.js +0 -31
  87. package/dist/parseNumber-D4iQDxK-.js.map +0 -1
  88. package/dist/prepareQueryObjects-BOUWfel5.js.map +0 -1
@@ -1003,7 +1003,7 @@ const prepareOptionList = (props) => {
1003
1003
  label: placeholderLabel
1004
1004
  };
1005
1005
  const optionsProp = optionListPropOriginal ?? [defaultOption];
1006
- let optionList = [];
1006
+ let optionList;
1007
1007
  const opts = Array.isArray(optionsProp) ? toFullOptionList(optionsProp, baseOption, labelMap) : objectKeys(toFullOptionMap(optionsProp, baseOption)).map((opt) => ({
1008
1008
  ...optionsProp[opt],
1009
1009
  name: opt,
@@ -1364,18 +1364,29 @@ const translationMatchFilter = (key, keyToTest, conditions) => keyToTest.startsW
1364
1364
  * @group Export
1365
1365
  */
1366
1366
  const getNLTranslataion = (key, translations, conditions = []) => conditions.length === 0 ? translations[key] ?? defaultNLTranslations[key] ?? "" : Object.entries(translations).find(([keyToTest]) => translationMatchFilter(key, keyToTest, conditions))?.[1] ?? Object.entries(defaultNLTranslations).find(([keyToTest]) => translationMatchFilter(key, keyToTest, conditions))?.[1] ?? defaultNLTranslations[key] ?? "";
1367
+ /**
1368
+ * Transforms
1369
+ * - `match: { mode: "atLeast", threshold: 1 }` to `match: { mode: "some" }`
1370
+ * - `match: { mode: "atMost", threshold: 0 }` to `match: { mode: "none" }`.
1371
+ *
1372
+ * Returns:
1373
+ * - Processed `{ mode, threshold }` object for valid subqueries
1374
+ * - `null` if match mode is not applicable for the rule
1375
+ * - `false` if match mode is valid, but either
1376
+ * 1. `threshold` is required and invalid, or
1377
+ * 2. `value` is not a valid rule group.
1378
+ */
1367
1379
  const processMatchMode = (rule) => {
1368
1380
  const { mode, threshold } = rule.match ?? {};
1369
- if (mode) {
1370
- if (!isRuleGroup(rule.value)) return false;
1371
- const matchModeLC = lc(mode);
1372
- const matchModeCoerced = matchModeLC === "atleast" && threshold === 1 ? "some" : matchModeLC === "atmost" && threshold === 0 ? "none" : matchModeLC;
1373
- if ((matchModeCoerced === "atleast" || matchModeCoerced === "atmost" || matchModeCoerced === "exactly") && (typeof threshold !== "number" || threshold < 0)) return false;
1374
- return {
1375
- mode: matchModeCoerced,
1376
- threshold
1377
- };
1378
- }
1381
+ if (!mode) return null;
1382
+ if (!isRuleGroup(rule.value)) return false;
1383
+ const matchModeLC = lc(mode);
1384
+ const matchModeCoerced = matchModeLC === "atleast" && threshold === 1 ? "some" : matchModeLC === "atmost" && threshold === 0 ? "none" : matchModeLC;
1385
+ if ((matchModeCoerced === "atleast" || matchModeCoerced === "atmost" || matchModeCoerced === "exactly") && (typeof threshold !== "number" || threshold < 0)) return false;
1386
+ return {
1387
+ mode: matchModeCoerced,
1388
+ threshold
1389
+ };
1379
1390
  };
1380
1391
  /**
1381
1392
  * "Replacer" method for JSON.stringify's second argument. Converts `bigint` values to
@@ -3910,6 +3921,7 @@ const preferFlagProps = (props = {}, contextVals = {}, finalize) => objectEntrie
3910
3921
  */
3911
3922
  const prepareRule = (rule, { idGenerator = generateID } = {}) => produce(rule, (draft) => {
3912
3923
  if (!draft.id) draft.id = idGenerator();
3924
+ if (processMatchMode(draft)) draft.value = prepareRuleGroup(draft.value, { idGenerator });
3913
3925
  });
3914
3926
  /**
3915
3927
  * Ensures that a rule group is valid by recursively adding an `id` property to the group itself