react-table-edit 1.5.28 → 1.5.29

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.
package/dist/index.js CHANGED
@@ -5967,13 +5967,6 @@ var SvgBecoxyHandshake = function (_a) {
5967
5967
  React__namespace.createElement("image", { id: "becoxy-handshake_svg__b", width: 512, height: 512, xlinkHref: "" }))));
5968
5968
  };
5969
5969
 
5970
- var SvgBecoxyHome2 = function (_a) {
5971
- var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
5972
- return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
5973
- title ? React__namespace.createElement("title", { id: titleId }, title) : null,
5974
- React__namespace.createElement("path", { d: "M19.734 9.105V2.629h-4.218v2.274L12 1.403 0 13.352v1.463h2.86v7.782h8.421v-3.75h1.406v3.75h8.454v-7.781H24v-1.465l-4.266-4.247Zm-2.812-5.07h1.406v3.67l-1.406-1.401V4.035Zm2.812 9.375v7.782h-5.64v-3.75H9.875v3.75h-5.61V13.41h-2.33L12 3.387 22.065 13.41h-2.33Z", fill: props.color || "currentColor" })));
5975
- };
5976
-
5977
5970
  var SvgBecoxyHome = function (_a) {
5978
5971
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
5979
5972
  return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
@@ -9017,6 +9010,13 @@ var SvgPieChart = function (_a) {
9017
9010
  React__namespace.createElement("path", { d: "M22 12A10 10 0 0 0 12 2v10z" })));
9018
9011
  };
9019
9012
 
9013
+ var SvgPin = function (_a) {
9014
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9015
+ return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
9016
+ title ? React__namespace.createElement("title", { id: titleId }, title) : null,
9017
+ React__namespace.createElement("path", { d: "M14.743 1.083a.75.75 0 0 1 .53.219L22.7 8.727a.75.75 0 0 1 0 1.06c-.72.72-1.608.882-2.255.882-.265 0-.502-.027-.69-.058l-4.7 4.701c.123.499.203 1.007.24 1.52.068 1.052-.049 2.53-1.08 3.562a.75.75 0 0 1-1.061 0l-4.244-4.242-4.773 4.773c-.292.293-1.828 1.353-2.12 1.06-.293-.292.767-1.83 1.06-2.12l4.773-4.773-4.242-4.244a.75.75 0 0 1 0-1.06c1.032-1.032 2.51-1.151 3.562-1.08a9 9 0 0 1 1.52.24l4.7-4.7a4.488 4.488 0 0 1-.06-.691c0-.645.163-1.533.884-2.255a.75.75 0 0 1 .53-.219Zm.183 3.165v.003a.75.75 0 0 1-.183.765L9.44 10.317a.75.75 0 0 1-.766.18H8.67l-.021-.006a7.485 7.485 0 0 0-1.58-.288c-.633-.042-1.254.012-1.762.225l8.265 8.264c.211-.51.265-1.13.223-1.763a7.503 7.503 0 0 0-.288-1.581l-.006-.02a.755.755 0 0 1 .18-.769l5.304-5.302a.75.75 0 0 1 .798-.173l.144.033c.13.026.312.051.516.051a2.05 2.05 0 0 0 .515-.06L14.89 3.042a2.06 2.06 0 0 0-.06.515c.002.233.033.464.093.69l.002.001Z", fill: props.color || "currentColor", stroke: props.color || "currentColor", strokeWidth: 0.25 })));
9018
+ };
9019
+
9020
9020
  var SvgPlayCircle = function (_a) {
9021
9021
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9022
9022
  return (React__namespace.createElement("svg", __assign({ xmlns: "http://www.w3.org/2000/svg", width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: props.strokeWidth || 1.5, strokeLinecap: "round", strokeLinejoin: "round", className: "play-circle_svg__feather play-circle_svg__feather-play-circle", "aria-labelledby": titleId }, props),
@@ -9263,6 +9263,32 @@ var SvgShare2 = function (_a) {
9263
9263
  React__namespace.createElement("path", { d: "m8.59 13.51 6.83 3.98M15.41 6.51l-6.82 3.98" })));
9264
9264
  };
9265
9265
 
9266
+ var SvgShare3 = function (_a) {
9267
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9268
+ return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
9269
+ title ? React__namespace.createElement("title", { id: titleId }, title) : null,
9270
+ React__namespace.createElement("g", { clipPath: "url(#share-3_svg__a)" },
9271
+ React__namespace.createElement("path", { d: "M9.643 2.693c.208 0 .408.09.555.248a.88.88 0 0 1 .23.599.88.88 0 0 1-.23.598.758.758 0 0 1-.555.248H4.928c-.625 0-1.224.267-1.666.743a2.64 2.64 0 0 0-.69 1.795V18.77c0 .673.248 1.318.69 1.794a2.275 2.275 0 0 0 1.666.744h11c.625 0 1.225-.268 1.667-.744a2.64 2.64 0 0 0 .69-1.794v-3.385a.88.88 0 0 1 .23-.598.758.758 0 0 1 .556-.248c.208 0 .408.09.555.248a.88.88 0 0 1 .23.598v3.385a4.4 4.4 0 0 1-1.15 2.99c-.737.794-1.736 1.24-2.778 1.24h-11c-1.041 0-2.04-.446-2.777-1.24A4.401 4.401 0 0 1 1 18.77V6.924c0-1.122.414-2.198 1.15-2.991.737-.794 1.737-1.24 2.778-1.24h4.715Zm5.154-1.607a.737.737 0 0 1 .828.093l7.071 5.923c.095.079.171.18.224.296a.9.9 0 0 1 0 .744.836.836 0 0 1-.224.297l-7.071 5.922a.738.738 0 0 1-.828.092.81.81 0 0 1-.321-.312.894.894 0 0 1-.12-.448v-2.496c-3.507.389-5.694 3.339-6.907 5.752l-.247.507a.816.816 0 0 1-.37.388c-.16.08-.34.1-.513.057a.782.782 0 0 1-.435-.299.888.888 0 0 1-.17-.525c0-3.513.814-6.669 2.415-8.968 1.474-2.116 3.593-3.464 6.228-3.688V1.847c0-.158.04-.314.118-.448a.81.81 0 0 1 .322-.313Zm1.131 4.146a.88.88 0 0 1-.23.598.758.758 0 0 1-.556.248c-2.498 0-4.426 1.139-5.754 3.046-.844 1.211-1.458 2.751-1.798 4.535 1.616-2.17 4.056-4.197 7.552-4.197.209 0 .409.09.556.248a.88.88 0 0 1 .23.598v1.655l5.005-4.193-5.005-4.195v1.657Z", fill: props.color || "currentColor", stroke: props.color || "currentColor", strokeWidth: 0.45 })),
9272
+ React__namespace.createElement("defs", null,
9273
+ React__namespace.createElement("clipPath", { id: "share-3_svg__a" },
9274
+ React__namespace.createElement("path", { fill: "#fff", d: "M0 0h24v24H0z" })))));
9275
+ };
9276
+
9277
+ var SvgShareBoxed = function (_a) {
9278
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9279
+ return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
9280
+ title ? React__namespace.createElement("title", { id: titleId }, title) : null,
9281
+ React__namespace.createElement("path", { d: "M2.25 0C1.02 0 0 1.02 0 2.25v16.5C0 19.98 1.02 21 2.25 21h13.5c1.23 0 2.25-1.02 2.25-2.25V15h-2v4H2V2h7V0H2.25ZM18 0v3C11.85 3 6.9 7.62 6.18 13.59A5.958 5.958 0 0 1 12 9h6v3l6-6-6-6Z", fill: props.color || "currentColor" })));
9282
+ };
9283
+
9284
+ var SvgShareFilled = function (_a) {
9285
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9286
+ return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
9287
+ title ? React__namespace.createElement("title", { id: titleId }, title) : null,
9288
+ React__namespace.createElement("path", { d: "M10.25 2c.199 0 .39.088.53.244.141.156.22.368.22.59a.882.882 0 0 1-.22.589.714.714 0 0 1-.53.244h-4.5c-.597 0-1.169.263-1.591.732A2.648 2.648 0 0 0 3.5 6.167v11.666c0 .663.237 1.3.659 1.768.422.469.994.732 1.591.732h10.5c.597 0 1.169-.263 1.591-.732a2.648 2.648 0 0 0 .659-1.768V14.5c0-.221.079-.433.22-.59a.714.714 0 0 1 .53-.243c.199 0 .39.088.53.244.141.156.22.368.22.589v3.333c0 1.105-.395 2.165-1.098 2.947-.704.781-1.657 1.22-2.652 1.22H5.75c-.995 0-1.948-.439-2.652-1.22C2.395 19.998 2 18.938 2 17.833V6.167c0-1.105.395-2.165 1.098-2.947C3.802 2.44 4.755 2 5.75 2h4.5Z", fill: props.color || "currentColor", stroke: props.color || "currentColor", strokeWidth: 0.5 }),
9289
+ React__namespace.createElement("path", { d: "M14.67 2.325a.75.75 0 0 1 .79.083l6.75 5.25a.75.75 0 0 1 0 1.185l-6.75 5.25a.75.75 0 0 1-1.21-.593v-2.212c-3.348.345-5.436 2.96-6.594 5.098l-.236.45A.75.75 0 0 1 6 16.5c0-3.114.777-5.911 2.306-7.95 1.407-1.875 3.429-3.07 5.944-3.268V3a.75.75 0 0 1 .42-.675Z", fill: props.color || "currentColor" })));
9290
+ };
9291
+
9266
9292
  var SvgShare = function (_a) {
9267
9293
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9268
9294
  return (React__namespace.createElement("svg", __assign({ xmlns: "http://www.w3.org/2000/svg", width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: props.strokeWidth || 1.5, strokeLinecap: "round", strokeLinejoin: "round", className: "share_svg__feather share_svg__feather-share", "aria-labelledby": titleId }, props),
@@ -9439,6 +9465,14 @@ var SvgSortDecending = function (_a) {
9439
9465
  React__namespace.createElement("path", { d: "M15 5v17h2V8h4l-6-6v3Z", fill: props.color || "currentColor" })));
9440
9466
  };
9441
9467
 
9468
+ var SvgSpeakerPhone = function (_a) {
9469
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9470
+ return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
9471
+ title ? React__namespace.createElement("title", { id: titleId }, title) : null,
9472
+ React__namespace.createElement("path", { d: "M19.334 6.863a3.666 3.666 0 0 1 0 7.333M9.557 6.863v13.444a1.222 1.222 0 0 1-1.222 1.222H7.113a1.222 1.222 0 0 1-1.222-1.222v-6.111", stroke: props.color || "currentColor", strokeWidth: 1.6, strokeLinecap: "round", strokeLinejoin: "round" }),
9473
+ React__namespace.createElement("path", { d: "m12 6.863 5.528-4.608a1.1 1.1 0 0 1 1.804.846v14.857a1.1 1.1 0 0 1-1.804.846L12 14.196H2.222A1.222 1.222 0 0 1 1 12.974v-4.89a1.222 1.222 0 0 1 1.222-1.221H12Z", stroke: props.color || "currentColor", strokeWidth: 1.6, strokeLinecap: "round", strokeLinejoin: "round" })));
9474
+ };
9475
+
9442
9476
  var SvgSpeaker = function (_a) {
9443
9477
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9444
9478
  return (React__namespace.createElement("svg", __assign({ xmlns: "http://www.w3.org/2000/svg", width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: props.strokeWidth || 1.5, strokeLinecap: "round", strokeLinejoin: "round", className: "speaker_svg__feather speaker_svg__feather-speaker", "aria-labelledby": titleId }, props),
@@ -10109,7 +10143,6 @@ var Icon = /*#__PURE__*/Object.freeze({
10109
10143
  BecoxyGrowth: SvgBecoxyGrowth,
10110
10144
  BecoxyHandshake: SvgBecoxyHandshake,
10111
10145
  BecoxyHome: SvgBecoxyHome,
10112
- BecoxyHome2: SvgBecoxyHome2,
10113
10146
  BecoxyHospital: SvgBecoxyHospital,
10114
10147
  BecoxyHrm: SvgBecoxyHrm,
10115
10148
  BecoxyImportWarehouse: SvgBecoxyImportWarehouse,
@@ -10437,6 +10470,7 @@ var Icon = /*#__PURE__*/Object.freeze({
10437
10470
  PhoneOff: SvgPhoneOff,
10438
10471
  PhoneOutgoing: SvgPhoneOutgoing,
10439
10472
  PieChart: SvgPieChart,
10473
+ Pin: SvgPin,
10440
10474
  Play: SvgPlay,
10441
10475
  PlayCircle: SvgPlayCircle,
10442
10476
  Plus: SvgPlus,
@@ -10467,6 +10501,9 @@ var Icon = /*#__PURE__*/Object.freeze({
10467
10501
  Settings: SvgSettings,
10468
10502
  Share: SvgShare,
10469
10503
  Share2: SvgShare2,
10504
+ Share3: SvgShare3,
10505
+ ShareBoxed: SvgShareBoxed,
10506
+ ShareFilled: SvgShareFilled,
10470
10507
  Shield: SvgShield,
10471
10508
  ShieldOff: SvgShieldOff,
10472
10509
  ShoppingBag: SvgShoppingBag,
@@ -10488,6 +10525,7 @@ var Icon = /*#__PURE__*/Object.freeze({
10488
10525
  SortCancel: SvgSortCancel,
10489
10526
  SortDecending: SvgSortDecending,
10490
10527
  Speaker: SvgSpeaker,
10528
+ SpeakerPhone: SvgSpeakerPhone,
10491
10529
  Square: SvgSquare,
10492
10530
  Star: SvgStar,
10493
10531
  StarFill: SvgStarFill,
@@ -19893,7 +19931,7 @@ const FindNodeByPath = (tree, path) => {
19893
19931
  * fisrtObjWidthFixRight: number // Chỉ số cột đầu tiên fixed right
19894
19932
  * }
19895
19933
  */
19896
- const calculateTableStructure = (columns, settingColumns) => {
19934
+ const calculateTableStructure = (columns, settingColumns, groupColumns) => {
19897
19935
  const levels = [];
19898
19936
  const flat = [];
19899
19937
  const objWidthFixLeft = {};
@@ -19927,9 +19965,7 @@ const calculateTableStructure = (columns, settingColumns) => {
19927
19965
  if (!cell.visibleLocked) {
19928
19966
  cell.visible = setting.visible ?? true;
19929
19967
  }
19930
- if (setting.fixedType !== undefined) {
19931
- cell.fixedType = setting.fixedType;
19932
- }
19968
+ cell.fixedType = setting.fixedType;
19933
19969
  if (setting.width !== undefined && setting.width !== null) {
19934
19970
  cell.width = setting.width;
19935
19971
  }
@@ -19960,6 +19996,7 @@ const calculateTableStructure = (columns, settingColumns) => {
19960
19996
  }
19961
19997
  }
19962
19998
  }
19999
+ cell.isGroup = groupColumns?.includes(cell.field);
19963
20000
  return cell;
19964
20001
  });
19965
20002
  };
@@ -19980,7 +20017,7 @@ const calculateTableStructure = (columns, settingColumns) => {
19980
20017
  };
19981
20018
  levels[level].push(cell);
19982
20019
  const headerKey = `${level}-${indexCol}`;
19983
- if (cell.fixedType === 'left' && cell.visible !== false) {
20020
+ if (cell.fixedType === 'left' && cell.visible !== false && cell.isGroup !== true) {
19984
20021
  objHeaderWidthFixLeft[headerKey] = leftTotal;
19985
20022
  }
19986
20023
  if (!hasChildren) {
@@ -19988,16 +20025,16 @@ const calculateTableStructure = (columns, settingColumns) => {
19988
20025
  const width = cell.width ?? 40;
19989
20026
  cell.index = index;
19990
20027
  flat.push(cell);
19991
- if (cell.fixedType === 'left' && cell.visible !== false) {
20028
+ if (cell.fixedType === 'left' && cell.visible !== false && cell.isGroup !== true) {
19992
20029
  objWidthFixLeft[index] = leftTotal;
19993
20030
  leftTotal += width;
19994
20031
  }
19995
- if (cell.fixedType === 'right' && cell.visible !== false) {
20032
+ if (cell.fixedType === 'right' && cell.visible !== false && cell.isGroup !== true) {
19996
20033
  rightTotal -= width;
19997
20034
  objWidthFixRight[index] = rightTotal;
19998
20035
  }
19999
20036
  }
20000
- if (cell.fixedType === 'right' && cell.visible !== false) {
20037
+ if (cell.fixedType === 'right' && cell.visible !== false && cell.isGroup !== true) {
20001
20038
  objHeaderWidthFixRight[headerKey] = rightTotal;
20002
20039
  }
20003
20040
  return colspanSum + colspan;
@@ -31617,63 +31654,7 @@ class DateLib {
31617
31654
  formatNumber(value) {
31618
31655
  return this.replaceDigits(value.toString());
31619
31656
  }
31620
- /**
31621
- * Returns the preferred ordering for month and year labels for the current
31622
- * locale.
31623
- */
31624
- getMonthYearOrder() {
31625
- const code = this.options.locale?.code;
31626
- if (!code) {
31627
- return "month-first";
31628
- }
31629
- return DateLib.yearFirstLocales.has(code) ? "year-first" : "month-first";
31630
- }
31631
- /**
31632
- * Formats the month/year pair respecting locale conventions.
31633
- *
31634
- * @since 9.11.0
31635
- */
31636
- formatMonthYear(date) {
31637
- const { locale, timeZone, numerals } = this.options;
31638
- const localeCode = locale?.code;
31639
- if (localeCode && DateLib.yearFirstLocales.has(localeCode)) {
31640
- try {
31641
- const intl = new Intl.DateTimeFormat(localeCode, {
31642
- month: "long",
31643
- year: "numeric",
31644
- timeZone,
31645
- numberingSystem: numerals,
31646
- });
31647
- const formatted = intl.format(date);
31648
- return formatted;
31649
- }
31650
- catch {
31651
- // Fallback to date-fns formatting below.
31652
- }
31653
- }
31654
- const pattern = this.getMonthYearOrder() === "year-first" ? "y LLLL" : "LLLL y";
31655
- return this.format(date, pattern);
31656
- }
31657
- }
31658
- DateLib.yearFirstLocales = new Set([
31659
- "eu",
31660
- "hu",
31661
- "ja",
31662
- "ja-Hira",
31663
- "ja-JP",
31664
- "ko",
31665
- "ko-KR",
31666
- "lt",
31667
- "lt-LT",
31668
- "lv",
31669
- "lv-LV",
31670
- "mn",
31671
- "mn-MN",
31672
- "zh",
31673
- "zh-CN",
31674
- "zh-HK",
31675
- "zh-TW",
31676
- ]);
31657
+ }
31677
31658
  /**
31678
31659
  * The default date library with English locale.
31679
31660
  *
@@ -32569,7 +32550,7 @@ function getDefaultClassNames() {
32569
32550
  /**
32570
32551
  * Formats the caption of the month.
32571
32552
  *
32572
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32553
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32573
32554
  * @param month The date representing the month.
32574
32555
  * @param options Configuration options for the date library.
32575
32556
  * @param dateLib The date library to use for formatting. If not provided, a new
@@ -32579,8 +32560,7 @@ function getDefaultClassNames() {
32579
32560
  * @see https://daypicker.dev/docs/translation#custom-formatters
32580
32561
  */
32581
32562
  function formatCaption(month, options, dateLib) {
32582
- const lib = dateLib ?? new DateLib(options);
32583
- return lib.formatMonthYear(month);
32563
+ return (dateLib ?? new DateLib(options)).format(month, "LLLL y");
32584
32564
  }
32585
32565
  /**
32586
32566
  * @private
@@ -32874,7 +32854,7 @@ const labelDay = labelDayButton;
32874
32854
  * Generates the ARIA label for the month grid, which is announced when entering
32875
32855
  * the grid.
32876
32856
  *
32877
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32857
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32878
32858
  * @param date - The date representing the month.
32879
32859
  * @param options - Optional configuration for the date formatting library.
32880
32860
  * @param dateLib - An optional instance of the date formatting library.
@@ -32883,8 +32863,7 @@ const labelDay = labelDayButton;
32883
32863
  * @see https://daypicker.dev/docs/translation#aria-labels
32884
32864
  */
32885
32865
  function labelGrid(date, options, dateLib) {
32886
- const lib = dateLib ?? new DateLib(options);
32887
- return lib.formatMonthYear(date);
32866
+ return (dateLib ?? new DateLib(options)).format(date, "LLLL y");
32888
32867
  }
32889
32868
  /**
32890
32869
  * @ignore
@@ -34367,7 +34346,7 @@ function DayPicker(initialProps) {
34367
34346
  formatters,
34368
34347
  };
34369
34348
  return (React__default["default"].createElement(dayPickerContext.Provider, { value: contextValue },
34370
- React__default["default"].createElement(components.Root, { rootRef: props.animate ? rootElRef : undefined, className: className, style: style, dir: props.dir, id: props.id, lang: props.lang, nonce: props.nonce, title: props.title, role: props.role, "aria-label": props["aria-label"], "aria-labelledby": props["aria-labelledby"], ...dataAttributes },
34349
+ React__default["default"].createElement(components.Root, { rootRef: props.animate ? rootElRef : undefined, className: className, style: style, dir: props.dir, id: props.id, lang: props.lang, nonce: props.nonce, title: props.title, role: props.role, "aria-label": props["aria-label"], ...dataAttributes },
34371
34350
  React__default["default"].createElement(components.Months, { className: classNames[UI.Months], style: styles?.[UI.Months] },
34372
34351
  !props.hideNavigation && !navLayout && (React__default["default"].createElement(components.Nav, { "data-animated-nav": props.animate ? "true" : undefined, className: classNames[UI.Nav], style: styles?.[UI.Nav], "aria-label": labelNav(), onPreviousClick: handlePreviousClick, onNextClick: handleNextClick, previousMonth: previousMonth, nextMonth: nextMonth })),
34373
34352
  months.map((calendarMonth, displayIndex) => {
@@ -34379,16 +34358,10 @@ function DayPicker(initialProps) {
34379
34358
  displayIndex === 0 && (React__default["default"].createElement(components.PreviousMonthButton, { type: "button", className: classNames[UI.PreviousMonthButton], tabIndex: previousMonth ? undefined : -1, "aria-disabled": previousMonth ? undefined : true, "aria-label": labelPrevious(previousMonth), onClick: handlePreviousClick, "data-animated-button": props.animate ? "true" : undefined },
34380
34359
  React__default["default"].createElement(components.Chevron, { disabled: previousMonth ? undefined : true, className: classNames[UI.Chevron], orientation: props.dir === "rtl" ? "right" : "left" }))),
34381
34360
  React__default["default"].createElement(components.MonthCaption, { "data-animated-caption": props.animate ? "true" : undefined, className: classNames[UI.MonthCaption], style: styles?.[UI.MonthCaption], calendarMonth: calendarMonth, displayIndex: displayIndex }, captionLayout?.startsWith("dropdown") ? (React__default["default"].createElement(components.DropdownNav, { className: classNames[UI.Dropdowns], style: styles?.[UI.Dropdowns] },
34382
- (() => {
34383
- const monthControl = captionLayout === "dropdown" ||
34384
- captionLayout === "dropdown-months" ? (React__default["default"].createElement(components.MonthsDropdown, { key: "month", className: classNames[UI.MonthsDropdown], "aria-label": labelMonthDropdown(), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleMonthChange(calendarMonth.date), options: getMonthOptions(calendarMonth.date, navStart, navEnd, formatters, dateLib), style: styles?.[UI.Dropdown], value: dateLib.getMonth(calendarMonth.date) })) : (React__default["default"].createElement("span", { key: "month" }, formatMonthDropdown(calendarMonth.date, dateLib)));
34385
- const yearControl = captionLayout === "dropdown" ||
34386
- captionLayout === "dropdown-years" ? (React__default["default"].createElement(components.YearsDropdown, { key: "year", className: classNames[UI.YearsDropdown], "aria-label": labelYearDropdown(dateLib.options), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleYearChange(calendarMonth.date), options: getYearOptions(navStart, navEnd, formatters, dateLib, Boolean(props.reverseYears)), style: styles?.[UI.Dropdown], value: dateLib.getYear(calendarMonth.date) })) : (React__default["default"].createElement("span", { key: "year" }, formatYearDropdown(calendarMonth.date, dateLib)));
34387
- const controls = dateLib.getMonthYearOrder() === "year-first"
34388
- ? [yearControl, monthControl]
34389
- : [monthControl, yearControl];
34390
- return controls;
34391
- })(),
34361
+ captionLayout === "dropdown" ||
34362
+ captionLayout === "dropdown-months" ? (React__default["default"].createElement(components.MonthsDropdown, { className: classNames[UI.MonthsDropdown], "aria-label": labelMonthDropdown(), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleMonthChange(calendarMonth.date), options: getMonthOptions(calendarMonth.date, navStart, navEnd, formatters, dateLib), style: styles?.[UI.Dropdown], value: dateLib.getMonth(calendarMonth.date) })) : (React__default["default"].createElement("span", null, formatMonthDropdown(calendarMonth.date, dateLib))),
34363
+ captionLayout === "dropdown" ||
34364
+ captionLayout === "dropdown-years" ? (React__default["default"].createElement(components.YearsDropdown, { className: classNames[UI.YearsDropdown], "aria-label": labelYearDropdown(dateLib.options), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleYearChange(calendarMonth.date), options: getYearOptions(navStart, navEnd, formatters, dateLib, Boolean(props.reverseYears)), style: styles?.[UI.Dropdown], value: dateLib.getYear(calendarMonth.date) })) : (React__default["default"].createElement("span", null, formatYearDropdown(calendarMonth.date, dateLib))),
34392
34365
  React__default["default"].createElement("span", { role: "status", "aria-live": "polite", style: {
34393
34366
  border: 0,
34394
34367
  clip: "rect(0 0 0 0)",
@@ -36838,9 +36811,8 @@ const FooterCol = ({ col, indexCol, dataSource, objWidthFix, formatSetting }) =>
36838
36811
  }, children: jsxRuntime.jsx("div", { className: "r-footer-div", children: col.haveSum === true && col.type === "numeric" && (jsxRuntime.jsx(jsxRuntime.Fragment, { children: Number(sumValue) >= 0 ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: formartNumberic(sumValue, formatSetting?.decimalSeparator ?? ",", formatSetting?.thousandSeparator ?? ".", col.numericSettings?.fraction, true, false) })) : (jsxRuntime.jsx("div", { style: { color: formatSetting?.colorNegative ?? "red" }, children: `${formatSetting?.prefixNegative ?? "-"}${formartNumberic(sumValue, formatSetting?.decimalSeparator ?? ",", formatSetting?.thousandSeparator ?? ".", col.numericSettings?.fraction, true, false)}${formatSetting?.suffixNegative ?? ""}` })) })) }) })) }, `summarycell-${indexCol}`));
36839
36812
  };
36840
36813
 
36841
- const RenderColGroup = ({ contentColumns, groupSetting }) => (jsxRuntime.jsx("colgroup", { children: contentColumns.map((col, index) => {
36842
- return (col.visible !== false &&
36843
- (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (jsxRuntime.jsx("col", { style: {
36814
+ const RenderColGroup = ({ contentColumns }) => (jsxRuntime.jsx("colgroup", { children: contentColumns.map((col, index) => {
36815
+ return (col.visible !== false && col.isGroup !== true && (jsxRuntime.jsx("col", { style: {
36844
36816
  width: typeof col.width === 'number' ? `${col.width}px` : col.width || undefined,
36845
36817
  minWidth: typeof col.minWidth === 'number' ? `${col.minWidth}px` : col.minWidth || undefined,
36846
36818
  maxWidth: typeof col.maxWidth === 'number' ? `${col.maxWidth}px` : col.maxWidth || undefined
@@ -38732,7 +38704,7 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38732
38704
  setViewDateTo(selectedTo || today);
38733
38705
  }
38734
38706
  else if (!newRange.from || (selected && selected < newRange.from)) {
38735
- newRange = { from: selected, to };
38707
+ newRange = { from: selected, to: undefined };
38736
38708
  setViewDateFrom(selected || today);
38737
38709
  }
38738
38710
  else if (newRange.from && selected && selected > newRange.from && (!newRange.to || selected < newRange.to)) {
@@ -38743,6 +38715,16 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38743
38715
  newRange = { from, to: selected };
38744
38716
  setViewDateTo(selected || today);
38745
38717
  }
38718
+ else if (newRange.from && !selected) {
38719
+ if (newRange.to) {
38720
+ newRange = { from: newRange.to, to };
38721
+ setViewDateFrom(newRange.to || today);
38722
+ }
38723
+ else {
38724
+ newRange = { from, to: newRange.from };
38725
+ setViewDateTo(newRange.from || today);
38726
+ }
38727
+ }
38746
38728
  onChange(newRange);
38747
38729
  setInputValue(formatDisplay(newRange.from, newRange.to));
38748
38730
  };
@@ -39019,7 +39001,7 @@ const DateRangeFilterComponent = ({ fieldFilter, filterBy, handleSave }) => {
39019
39001
  };
39020
39002
 
39021
39003
  const HeaderTableCol = (props) => {
39022
- const { selectEnable, dataSource, setSelectedRows, col, indexCol, indexParent, objHeaderWidthFixLeft, objHeaderWidthFixRight, totalCount, selectedRows, columns, orderBy, changeFilter, filterBy, changeOrder, allowFiltering, allowSorting, container, fisrtObjWidthFixRight, lastObjWidthFixLeft, setContentColumns, formatSetting, optionsFilter, idTable, isMulti, groupSetting } = props;
39004
+ const { selectEnable, dataSource, setSelectedRows, col, indexCol, indexParent, objHeaderWidthFixLeft, objHeaderWidthFixRight, totalCount, selectedRows, columns, orderBy, changeFilter, filterBy, changeOrder, allowFiltering, allowSorting, container, fisrtObjWidthFixRight, lastObjWidthFixLeft, setContentColumns, formatSetting, optionsFilter, idTable, isMulti } = props;
39023
39005
  const { t } = reactI18next.useTranslation();
39024
39006
  const headerRef = React$5.useRef(null);
39025
39007
  const order = orderBy.find((item) => item.key === col.field);
@@ -39038,7 +39020,7 @@ const HeaderTableCol = (props) => {
39038
39020
  const checkOverflow = () => {
39039
39021
  return headerRef.current && headerRef.current.scrollHeight > headerRef.current.clientHeight;
39040
39022
  };
39041
- return (jsxRuntime.jsx(React$5.Fragment, { children: col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (jsxRuntime.jsx(Resizable, { className: "r-resize", width: typeof col.width === 'number' ? col.width : Number((col.width ?? '').replaceAll(new RegExp(`[^0-9]`, 'g'), '')), height: 0, onResize: handleResize, draggableOpts: { enableUserSelectHack: true }, children: jsxRuntime.jsx("th", { rowSpan: col.rowspan !== 1 ? col.rowspan : 1, colSpan: col.columns?.filter((x) => x.visible !== false)?.length ?? 1, className: classNames$1(`r-headercell fix-${col.fixedType}`, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'cell-fixed': col.fixedType }), style: {
39023
+ return (jsxRuntime.jsx(React$5.Fragment, { children: col.visible !== false && col.isGroup !== true && (jsxRuntime.jsx(Resizable, { className: "r-resize", width: typeof col.width === 'number' ? col.width : Number((col.width ?? '').replaceAll(new RegExp(`[^0-9]`, 'g'), '')), height: 0, onResize: handleResize, draggableOpts: { enableUserSelectHack: true }, children: jsxRuntime.jsx("th", { rowSpan: col.rowspan !== 1 ? col.rowspan : 1, colSpan: col.columns?.filter((x) => x.visible !== false)?.length ?? 1, className: classNames$1(`r-headercell fix-${col.fixedType}`, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'cell-fixed': col.fixedType }), style: {
39042
39024
  top: `${indexParent * 42}px`,
39043
39025
  left: col.fixedType === 'left' ? objHeaderWidthFixLeft[`${indexParent}-${indexCol ?? 0}`] : undefined,
39044
39026
  right: col.fixedType === 'right' ? objHeaderWidthFixRight[`${indexParent}-${indexCol ?? 0}`] : undefined
@@ -68713,7 +68695,7 @@ const UnExpandAllIcon = ({ className, color = '#7F7F7F', size = 24, onClick, sty
68713
68695
  };
68714
68696
 
68715
68697
  const RenderContentCol = (props) => {
68716
- const { col, indexCol, indexRow, isSelected, row, zeroVisiable, groupSetting, formatSetting, idTable, fisrtObjWidthFixRight, lastObjWidthFixLeft, objWidthFixLeft, objWidthFixRight, selectedRows, selectEnable, setSelectedRows, fieldKey, isMulti } = props;
68698
+ const { col, indexCol, indexRow, isSelected, row, zeroVisiable, formatSetting, idTable, fisrtObjWidthFixRight, lastObjWidthFixLeft, objWidthFixLeft, objWidthFixRight, selectedRows, selectEnable, setSelectedRows, fieldKey, isMulti } = props;
68717
68699
  const cellId = `content-${idTable}-row${indexRow}col-${indexCol}`;
68718
68700
  const checkOverflow = () => {
68719
68701
  const element = document.getElementById(cellId);
@@ -68783,7 +68765,7 @@ const RenderContentCol = (props) => {
68783
68765
  }, children: displayText }) }), checkOverflow() && (jsxRuntime.jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: cellId, placement: "top", children: jsxRuntime.jsx("div", { style: { color: textColor }, children: displayText }) }))] }));
68784
68766
  }
68785
68767
  };
68786
- return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (jsxRuntime.jsx("td", { className: classNames$1(`r-rowcell fix-${col.fixedType}`, { 'cell-fixed': col.fixedType }, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'r-active': isSelected }), style: {
68768
+ return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: col.visible !== false && col.isGroup !== true && (jsxRuntime.jsx("td", { className: classNames$1(`r-rowcell fix-${col.fixedType}`, { 'cell-fixed': col.fixedType }, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'r-active': isSelected }), style: {
68787
68769
  left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
68788
68770
  right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined
68789
68771
  }, onClick: (e) => {
@@ -68841,17 +68823,17 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68841
68823
  setExpandsAll(true);
68842
68824
  }, [groupSetting?.groupColumns]);
68843
68825
  const { levels: headerColumns, objHeaderWidthFixLeft, objHeaderWidthFixRight, objWidthFixLeft, objWidthFixRight, lastObjWidthFixLeft, fisrtObjWidthFixRight } = React$5.useMemo(() => {
68844
- const rs = calculateTableStructure(columns, settingColumns?.value);
68826
+ const rs = calculateTableStructure(columns, settingColumns?.value, groupSetting?.groupColumns);
68845
68827
  setContentColumns(rs.flat);
68846
68828
  return rs;
68847
- }, [columns, settingColumns]);
68848
- const optionGroupColumns = React$5.useMemo(() => contentColumns.filter((x) => !groupSetting?.groupColumns.includes(x.field)).map((x) => ({ ...x, headerDisplay: t(x.columnGroupText ?? x.headerDisplay ?? x.headerText) })), [groupSetting?.groupColumns, contentColumns]);
68829
+ }, [columns, settingColumns, groupSetting?.groupColumns]);
68830
+ const optionGroupColumns = React$5.useMemo(() => contentColumns.map((x) => ({ ...x, headerDisplay: t(x.headerText) })), [contentColumns]);
68849
68831
  const firstColSpan = React$5.useMemo(() => {
68850
68832
  let count = 0;
68851
68833
  let index = 3;
68852
68834
  for (let i = 0; i < contentColumns.length; i++) {
68853
68835
  const col = contentColumns[i];
68854
- if (col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field))) {
68836
+ if (col.visible !== false && col.isGroup !== true) {
68855
68837
  count++;
68856
68838
  }
68857
68839
  if (count === 3) {
@@ -68860,7 +68842,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68860
68842
  }
68861
68843
  }
68862
68844
  return index;
68863
- }, [contentColumns, groupSetting?.groupColumns]);
68845
+ }, [contentColumns]);
68864
68846
  // Tính toán dữ liệu hiển thị dựa trên các điều kiện lọc, tìm kiếm và sắp xếp
68865
68847
  const viewData = React$5.useMemo(() => {
68866
68848
  if (!dataSource || dataSource.length === 0) {
@@ -69098,7 +69080,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69098
69080
  setExpandsAll(undefined);
69099
69081
  row.expand = !expand;
69100
69082
  } }), t(col.headerDisplay ?? col.headerText), ": ", value, " (", row.children.length, ")"] }) }), contentColumns.map((colSum, indexCol) => {
69101
- if (indexCol <= firstColSpan || colSum.visible === false || (!groupSetting?.visibleGroupColumn && groupColumns?.includes(colSum.field))) {
69083
+ if (indexCol <= firstColSpan || colSum.visible === false || colSum.isGroup === true) {
69102
69084
  return;
69103
69085
  }
69104
69086
  let sumValue = row[colSum.field];
@@ -69126,7 +69108,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69126
69108
  }, onContextMenu: (e) => {
69127
69109
  e.preventDefault();
69128
69110
  handleContextMenu(e, row);
69129
- }, children: contentColumns.map((column, indexCol) => (jsxRuntime.jsx(RenderContentCol, { idTable: idTable, col: column, fieldKey: fieldKey, objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, isMulti: isMutil ?? false, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, formatSetting: formatSetting, indexCol: indexCol, indexRow: indexRow, isSelected: isSelected, row: row, zeroVisiable: zeroVisiable, groupSetting: groupSetting }, indexCol))) }, `row-content-${indexRow}`));
69111
+ }, children: contentColumns.map((column, indexCol) => (jsxRuntime.jsx(RenderContentCol, { idTable: idTable, col: column, fieldKey: fieldKey, objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, isMulti: isMutil ?? false, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, formatSetting: formatSetting, indexCol: indexCol, indexRow: indexRow, isSelected: isSelected, row: row, zeroVisiable: zeroVisiable }, indexCol))) }, `row-content-${indexRow}`));
69130
69112
  }
69131
69113
  }) }));
69132
69114
  };
@@ -69153,7 +69135,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69153
69135
  virtualDivRef.current.style.height = '0px';
69154
69136
  }
69155
69137
  }, [context]);
69156
- return (jsxRuntime.jsxs("div", { className: "r-table-edit r-virtualized-table", children: [jsxRuntime.jsxs("div", { className: "r-grid", children: [toolbarSetting?.showTopToolbar && jsxRuntime.jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), headerComponent && headerComponent(), jsxRuntime.jsxs("div", { ref: gridRef, className: "r-gridtable", style: { height: `${height ? `${height}px` : 'auto'}`, position: 'relative' }, children: [jsxRuntime.jsxs("table", { role: "presentation", style: { width: '100%' }, children: [jsxRuntime.jsx(RenderColGroup, { contentColumns: contentColumns, groupSetting: groupSetting }), jsxRuntime.jsx("thead", { className: "r-gridheader", role: "rowgroup", children: headerColumns.map((rowColumn, indexParent) => {
69138
+ return (jsxRuntime.jsxs("div", { className: "r-table-edit r-virtualized-table", children: [jsxRuntime.jsxs("div", { className: "r-grid", children: [toolbarSetting?.showTopToolbar && jsxRuntime.jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), headerComponent && headerComponent(), jsxRuntime.jsxs("div", { ref: gridRef, className: "r-gridtable", style: { height: `${height ? `${height}px` : 'auto'}`, position: 'relative' }, children: [jsxRuntime.jsxs("table", { role: "presentation", style: { width: '100%' }, children: [jsxRuntime.jsx(RenderColGroup, { contentColumns: contentColumns }), jsxRuntime.jsx("thead", { className: "r-gridheader", role: "rowgroup", children: headerColumns.map((rowColumn, indexParent) => {
69157
69139
  return (jsxRuntime.jsx("tr", { className: "r-row", role: "row", children: rowColumn.map((col, index) => (jsxRuntime.jsx(HeaderTableCol, { col: col, idTable: idTable ?? '', dataSource: dataSource, indexCol: index, indexParent: indexParent, isMulti: isMulti ?? false, objHeaderWidthFixLeft: objHeaderWidthFixLeft, objHeaderWidthFixRight: objHeaderWidthFixRight, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, container: gridRef, filterBy: filterBy, orderBy: orderBy, optionsFilter: querySetting?.optionsFilter, allowFiltering: querySetting?.allowFiltering, allowSorting: querySetting?.allowSorting, formatSetting: formatSetting, changeFilter: (val) => {
69158
69140
  setFilterBy([...val]);
69159
69141
  if (querySetting?.changeFilter) {
@@ -69164,9 +69146,9 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69164
69146
  if (querySetting?.changeOrder) {
69165
69147
  querySetting.changeOrder(val);
69166
69148
  }
69167
- }, columns: contentColumns, groupSetting: groupSetting, setContentColumns: setContentColumns, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, totalCount: dataSource?.length ?? 0 }, `header-${indexParent}-${index}`))) }, `header-${-indexParent}`));
69149
+ }, columns: contentColumns, setContentColumns: setContentColumns, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, totalCount: dataSource?.length ?? 0 }, `header-${indexParent}-${index}`))) }, `header-${-indexParent}`));
69168
69150
  }) }), jsxRuntime.jsx("tbody", { className: "r-gridcontent", role: "rowgroup", children: jsxRuntime.jsx(RenderContent, { datas: viewData }) }), jsxRuntime.jsx("tfoot", { className: "r-gridfoot", children: (columnsAggregate?.length ?? 0) > 0 && (jsxRuntime.jsx("tr", { className: "r-row", children: contentColumns.map((col, indexCol) => {
69169
- if (col.visible === false || (!groupSetting?.visibleGroupColumn && groupSetting?.groupColumns.includes(col.field))) {
69151
+ if (col.visible === false || col.isGroup === true) {
69170
69152
  return;
69171
69153
  }
69172
69154
  const item = columnsAggregate?.find((x) => x.field === col.field);