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.mjs CHANGED
@@ -5938,13 +5938,6 @@ var SvgBecoxyHandshake = function (_a) {
5938
5938
  React$5.createElement("image", { id: "becoxy-handshake_svg__b", width: 512, height: 512, xlinkHref: "" }))));
5939
5939
  };
5940
5940
 
5941
- var SvgBecoxyHome2 = function (_a) {
5942
- var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
5943
- return (React$5.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),
5944
- title ? React$5.createElement("title", { id: titleId }, title) : null,
5945
- React$5.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" })));
5946
- };
5947
-
5948
5941
  var SvgBecoxyHome = function (_a) {
5949
5942
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
5950
5943
  return (React$5.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),
@@ -8988,6 +8981,13 @@ var SvgPieChart = function (_a) {
8988
8981
  React$5.createElement("path", { d: "M22 12A10 10 0 0 0 12 2v10z" })));
8989
8982
  };
8990
8983
 
8984
+ var SvgPin = function (_a) {
8985
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
8986
+ return (React$5.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),
8987
+ title ? React$5.createElement("title", { id: titleId }, title) : null,
8988
+ React$5.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 })));
8989
+ };
8990
+
8991
8991
  var SvgPlayCircle = function (_a) {
8992
8992
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
8993
8993
  return (React$5.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),
@@ -9234,6 +9234,32 @@ var SvgShare2 = function (_a) {
9234
9234
  React$5.createElement("path", { d: "m8.59 13.51 6.83 3.98M15.41 6.51l-6.82 3.98" })));
9235
9235
  };
9236
9236
 
9237
+ var SvgShare3 = function (_a) {
9238
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9239
+ return (React$5.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),
9240
+ title ? React$5.createElement("title", { id: titleId }, title) : null,
9241
+ React$5.createElement("g", { clipPath: "url(#share-3_svg__a)" },
9242
+ React$5.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 })),
9243
+ React$5.createElement("defs", null,
9244
+ React$5.createElement("clipPath", { id: "share-3_svg__a" },
9245
+ React$5.createElement("path", { fill: "#fff", d: "M0 0h24v24H0z" })))));
9246
+ };
9247
+
9248
+ var SvgShareBoxed = function (_a) {
9249
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9250
+ return (React$5.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),
9251
+ title ? React$5.createElement("title", { id: titleId }, title) : null,
9252
+ React$5.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" })));
9253
+ };
9254
+
9255
+ var SvgShareFilled = function (_a) {
9256
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9257
+ return (React$5.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),
9258
+ title ? React$5.createElement("title", { id: titleId }, title) : null,
9259
+ React$5.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 }),
9260
+ React$5.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" })));
9261
+ };
9262
+
9237
9263
  var SvgShare = function (_a) {
9238
9264
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9239
9265
  return (React$5.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),
@@ -9410,6 +9436,14 @@ var SvgSortDecending = function (_a) {
9410
9436
  React$5.createElement("path", { d: "M15 5v17h2V8h4l-6-6v3Z", fill: props.color || "currentColor" })));
9411
9437
  };
9412
9438
 
9439
+ var SvgSpeakerPhone = function (_a) {
9440
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9441
+ return (React$5.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),
9442
+ title ? React$5.createElement("title", { id: titleId }, title) : null,
9443
+ React$5.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" }),
9444
+ React$5.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" })));
9445
+ };
9446
+
9413
9447
  var SvgSpeaker = function (_a) {
9414
9448
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9415
9449
  return (React$5.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),
@@ -10080,7 +10114,6 @@ var Icon = /*#__PURE__*/Object.freeze({
10080
10114
  BecoxyGrowth: SvgBecoxyGrowth,
10081
10115
  BecoxyHandshake: SvgBecoxyHandshake,
10082
10116
  BecoxyHome: SvgBecoxyHome,
10083
- BecoxyHome2: SvgBecoxyHome2,
10084
10117
  BecoxyHospital: SvgBecoxyHospital,
10085
10118
  BecoxyHrm: SvgBecoxyHrm,
10086
10119
  BecoxyImportWarehouse: SvgBecoxyImportWarehouse,
@@ -10408,6 +10441,7 @@ var Icon = /*#__PURE__*/Object.freeze({
10408
10441
  PhoneOff: SvgPhoneOff,
10409
10442
  PhoneOutgoing: SvgPhoneOutgoing,
10410
10443
  PieChart: SvgPieChart,
10444
+ Pin: SvgPin,
10411
10445
  Play: SvgPlay,
10412
10446
  PlayCircle: SvgPlayCircle,
10413
10447
  Plus: SvgPlus,
@@ -10438,6 +10472,9 @@ var Icon = /*#__PURE__*/Object.freeze({
10438
10472
  Settings: SvgSettings,
10439
10473
  Share: SvgShare,
10440
10474
  Share2: SvgShare2,
10475
+ Share3: SvgShare3,
10476
+ ShareBoxed: SvgShareBoxed,
10477
+ ShareFilled: SvgShareFilled,
10441
10478
  Shield: SvgShield,
10442
10479
  ShieldOff: SvgShieldOff,
10443
10480
  ShoppingBag: SvgShoppingBag,
@@ -10459,6 +10496,7 @@ var Icon = /*#__PURE__*/Object.freeze({
10459
10496
  SortCancel: SvgSortCancel,
10460
10497
  SortDecending: SvgSortDecending,
10461
10498
  Speaker: SvgSpeaker,
10499
+ SpeakerPhone: SvgSpeakerPhone,
10462
10500
  Square: SvgSquare,
10463
10501
  Star: SvgStar,
10464
10502
  StarFill: SvgStarFill,
@@ -19864,7 +19902,7 @@ const FindNodeByPath = (tree, path) => {
19864
19902
  * fisrtObjWidthFixRight: number // Chỉ số cột đầu tiên fixed right
19865
19903
  * }
19866
19904
  */
19867
- const calculateTableStructure = (columns, settingColumns) => {
19905
+ const calculateTableStructure = (columns, settingColumns, groupColumns) => {
19868
19906
  const levels = [];
19869
19907
  const flat = [];
19870
19908
  const objWidthFixLeft = {};
@@ -19898,9 +19936,7 @@ const calculateTableStructure = (columns, settingColumns) => {
19898
19936
  if (!cell.visibleLocked) {
19899
19937
  cell.visible = setting.visible ?? true;
19900
19938
  }
19901
- if (setting.fixedType !== undefined) {
19902
- cell.fixedType = setting.fixedType;
19903
- }
19939
+ cell.fixedType = setting.fixedType;
19904
19940
  if (setting.width !== undefined && setting.width !== null) {
19905
19941
  cell.width = setting.width;
19906
19942
  }
@@ -19931,6 +19967,7 @@ const calculateTableStructure = (columns, settingColumns) => {
19931
19967
  }
19932
19968
  }
19933
19969
  }
19970
+ cell.isGroup = groupColumns?.includes(cell.field);
19934
19971
  return cell;
19935
19972
  });
19936
19973
  };
@@ -19951,7 +19988,7 @@ const calculateTableStructure = (columns, settingColumns) => {
19951
19988
  };
19952
19989
  levels[level].push(cell);
19953
19990
  const headerKey = `${level}-${indexCol}`;
19954
- if (cell.fixedType === 'left' && cell.visible !== false) {
19991
+ if (cell.fixedType === 'left' && cell.visible !== false && cell.isGroup !== true) {
19955
19992
  objHeaderWidthFixLeft[headerKey] = leftTotal;
19956
19993
  }
19957
19994
  if (!hasChildren) {
@@ -19959,16 +19996,16 @@ const calculateTableStructure = (columns, settingColumns) => {
19959
19996
  const width = cell.width ?? 40;
19960
19997
  cell.index = index;
19961
19998
  flat.push(cell);
19962
- if (cell.fixedType === 'left' && cell.visible !== false) {
19999
+ if (cell.fixedType === 'left' && cell.visible !== false && cell.isGroup !== true) {
19963
20000
  objWidthFixLeft[index] = leftTotal;
19964
20001
  leftTotal += width;
19965
20002
  }
19966
- if (cell.fixedType === 'right' && cell.visible !== false) {
20003
+ if (cell.fixedType === 'right' && cell.visible !== false && cell.isGroup !== true) {
19967
20004
  rightTotal -= width;
19968
20005
  objWidthFixRight[index] = rightTotal;
19969
20006
  }
19970
20007
  }
19971
- if (cell.fixedType === 'right' && cell.visible !== false) {
20008
+ if (cell.fixedType === 'right' && cell.visible !== false && cell.isGroup !== true) {
19972
20009
  objHeaderWidthFixRight[headerKey] = rightTotal;
19973
20010
  }
19974
20011
  return colspanSum + colspan;
@@ -31588,63 +31625,7 @@ class DateLib {
31588
31625
  formatNumber(value) {
31589
31626
  return this.replaceDigits(value.toString());
31590
31627
  }
31591
- /**
31592
- * Returns the preferred ordering for month and year labels for the current
31593
- * locale.
31594
- */
31595
- getMonthYearOrder() {
31596
- const code = this.options.locale?.code;
31597
- if (!code) {
31598
- return "month-first";
31599
- }
31600
- return DateLib.yearFirstLocales.has(code) ? "year-first" : "month-first";
31601
- }
31602
- /**
31603
- * Formats the month/year pair respecting locale conventions.
31604
- *
31605
- * @since 9.11.0
31606
- */
31607
- formatMonthYear(date) {
31608
- const { locale, timeZone, numerals } = this.options;
31609
- const localeCode = locale?.code;
31610
- if (localeCode && DateLib.yearFirstLocales.has(localeCode)) {
31611
- try {
31612
- const intl = new Intl.DateTimeFormat(localeCode, {
31613
- month: "long",
31614
- year: "numeric",
31615
- timeZone,
31616
- numberingSystem: numerals,
31617
- });
31618
- const formatted = intl.format(date);
31619
- return formatted;
31620
- }
31621
- catch {
31622
- // Fallback to date-fns formatting below.
31623
- }
31624
- }
31625
- const pattern = this.getMonthYearOrder() === "year-first" ? "y LLLL" : "LLLL y";
31626
- return this.format(date, pattern);
31627
- }
31628
- }
31629
- DateLib.yearFirstLocales = new Set([
31630
- "eu",
31631
- "hu",
31632
- "ja",
31633
- "ja-Hira",
31634
- "ja-JP",
31635
- "ko",
31636
- "ko-KR",
31637
- "lt",
31638
- "lt-LT",
31639
- "lv",
31640
- "lv-LV",
31641
- "mn",
31642
- "mn-MN",
31643
- "zh",
31644
- "zh-CN",
31645
- "zh-HK",
31646
- "zh-TW",
31647
- ]);
31628
+ }
31648
31629
  /**
31649
31630
  * The default date library with English locale.
31650
31631
  *
@@ -32540,7 +32521,7 @@ function getDefaultClassNames() {
32540
32521
  /**
32541
32522
  * Formats the caption of the month.
32542
32523
  *
32543
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32524
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32544
32525
  * @param month The date representing the month.
32545
32526
  * @param options Configuration options for the date library.
32546
32527
  * @param dateLib The date library to use for formatting. If not provided, a new
@@ -32550,8 +32531,7 @@ function getDefaultClassNames() {
32550
32531
  * @see https://daypicker.dev/docs/translation#custom-formatters
32551
32532
  */
32552
32533
  function formatCaption(month, options, dateLib) {
32553
- const lib = dateLib ?? new DateLib(options);
32554
- return lib.formatMonthYear(month);
32534
+ return (dateLib ?? new DateLib(options)).format(month, "LLLL y");
32555
32535
  }
32556
32536
  /**
32557
32537
  * @private
@@ -32845,7 +32825,7 @@ const labelDay = labelDayButton;
32845
32825
  * Generates the ARIA label for the month grid, which is announced when entering
32846
32826
  * the grid.
32847
32827
  *
32848
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32828
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32849
32829
  * @param date - The date representing the month.
32850
32830
  * @param options - Optional configuration for the date formatting library.
32851
32831
  * @param dateLib - An optional instance of the date formatting library.
@@ -32854,8 +32834,7 @@ const labelDay = labelDayButton;
32854
32834
  * @see https://daypicker.dev/docs/translation#aria-labels
32855
32835
  */
32856
32836
  function labelGrid(date, options, dateLib) {
32857
- const lib = dateLib ?? new DateLib(options);
32858
- return lib.formatMonthYear(date);
32837
+ return (dateLib ?? new DateLib(options)).format(date, "LLLL y");
32859
32838
  }
32860
32839
  /**
32861
32840
  * @ignore
@@ -34338,7 +34317,7 @@ function DayPicker(initialProps) {
34338
34317
  formatters,
34339
34318
  };
34340
34319
  return (React__default.createElement(dayPickerContext.Provider, { value: contextValue },
34341
- React__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 },
34320
+ React__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 },
34342
34321
  React__default.createElement(components.Months, { className: classNames[UI.Months], style: styles?.[UI.Months] },
34343
34322
  !props.hideNavigation && !navLayout && (React__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 })),
34344
34323
  months.map((calendarMonth, displayIndex) => {
@@ -34350,16 +34329,10 @@ function DayPicker(initialProps) {
34350
34329
  displayIndex === 0 && (React__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 },
34351
34330
  React__default.createElement(components.Chevron, { disabled: previousMonth ? undefined : true, className: classNames[UI.Chevron], orientation: props.dir === "rtl" ? "right" : "left" }))),
34352
34331
  React__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.createElement(components.DropdownNav, { className: classNames[UI.Dropdowns], style: styles?.[UI.Dropdowns] },
34353
- (() => {
34354
- const monthControl = captionLayout === "dropdown" ||
34355
- captionLayout === "dropdown-months" ? (React__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.createElement("span", { key: "month" }, formatMonthDropdown(calendarMonth.date, dateLib)));
34356
- const yearControl = captionLayout === "dropdown" ||
34357
- captionLayout === "dropdown-years" ? (React__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.createElement("span", { key: "year" }, formatYearDropdown(calendarMonth.date, dateLib)));
34358
- const controls = dateLib.getMonthYearOrder() === "year-first"
34359
- ? [yearControl, monthControl]
34360
- : [monthControl, yearControl];
34361
- return controls;
34362
- })(),
34332
+ captionLayout === "dropdown" ||
34333
+ captionLayout === "dropdown-months" ? (React__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.createElement("span", null, formatMonthDropdown(calendarMonth.date, dateLib))),
34334
+ captionLayout === "dropdown" ||
34335
+ captionLayout === "dropdown-years" ? (React__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.createElement("span", null, formatYearDropdown(calendarMonth.date, dateLib))),
34363
34336
  React__default.createElement("span", { role: "status", "aria-live": "polite", style: {
34364
34337
  border: 0,
34365
34338
  clip: "rect(0 0 0 0)",
@@ -36809,9 +36782,8 @@ const FooterCol = ({ col, indexCol, dataSource, objWidthFix, formatSetting }) =>
36809
36782
  }, children: jsx("div", { className: "r-footer-div", children: col.haveSum === true && col.type === "numeric" && (jsx(Fragment$1, { children: Number(sumValue) >= 0 ? (jsx(Fragment$1, { children: formartNumberic(sumValue, formatSetting?.decimalSeparator ?? ",", formatSetting?.thousandSeparator ?? ".", col.numericSettings?.fraction, true, false) })) : (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}`));
36810
36783
  };
36811
36784
 
36812
- const RenderColGroup = ({ contentColumns, groupSetting }) => (jsx("colgroup", { children: contentColumns.map((col, index) => {
36813
- return (col.visible !== false &&
36814
- (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (jsx("col", { style: {
36785
+ const RenderColGroup = ({ contentColumns }) => (jsx("colgroup", { children: contentColumns.map((col, index) => {
36786
+ return (col.visible !== false && col.isGroup !== true && (jsx("col", { style: {
36815
36787
  width: typeof col.width === 'number' ? `${col.width}px` : col.width || undefined,
36816
36788
  minWidth: typeof col.minWidth === 'number' ? `${col.minWidth}px` : col.minWidth || undefined,
36817
36789
  maxWidth: typeof col.maxWidth === 'number' ? `${col.maxWidth}px` : col.maxWidth || undefined
@@ -38703,7 +38675,7 @@ const DateRangePicker = forwardRef((props, ref) => {
38703
38675
  setViewDateTo(selectedTo || today);
38704
38676
  }
38705
38677
  else if (!newRange.from || (selected && selected < newRange.from)) {
38706
- newRange = { from: selected, to };
38678
+ newRange = { from: selected, to: undefined };
38707
38679
  setViewDateFrom(selected || today);
38708
38680
  }
38709
38681
  else if (newRange.from && selected && selected > newRange.from && (!newRange.to || selected < newRange.to)) {
@@ -38714,6 +38686,16 @@ const DateRangePicker = forwardRef((props, ref) => {
38714
38686
  newRange = { from, to: selected };
38715
38687
  setViewDateTo(selected || today);
38716
38688
  }
38689
+ else if (newRange.from && !selected) {
38690
+ if (newRange.to) {
38691
+ newRange = { from: newRange.to, to };
38692
+ setViewDateFrom(newRange.to || today);
38693
+ }
38694
+ else {
38695
+ newRange = { from, to: newRange.from };
38696
+ setViewDateTo(newRange.from || today);
38697
+ }
38698
+ }
38717
38699
  onChange(newRange);
38718
38700
  setInputValue(formatDisplay(newRange.from, newRange.to));
38719
38701
  };
@@ -38990,7 +38972,7 @@ const DateRangeFilterComponent = ({ fieldFilter, filterBy, handleSave }) => {
38990
38972
  };
38991
38973
 
38992
38974
  const HeaderTableCol = (props) => {
38993
- 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;
38975
+ 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;
38994
38976
  const { t } = useTranslation();
38995
38977
  const headerRef = useRef(null);
38996
38978
  const order = orderBy.find((item) => item.key === col.field);
@@ -39009,7 +38991,7 @@ const HeaderTableCol = (props) => {
39009
38991
  const checkOverflow = () => {
39010
38992
  return headerRef.current && headerRef.current.scrollHeight > headerRef.current.clientHeight;
39011
38993
  };
39012
- return (jsx(Fragment, { children: col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (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: 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: {
38994
+ return (jsx(Fragment, { children: col.visible !== false && col.isGroup !== true && (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: 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: {
39013
38995
  top: `${indexParent * 42}px`,
39014
38996
  left: col.fixedType === 'left' ? objHeaderWidthFixLeft[`${indexParent}-${indexCol ?? 0}`] : undefined,
39015
38997
  right: col.fixedType === 'right' ? objHeaderWidthFixRight[`${indexParent}-${indexCol ?? 0}`] : undefined
@@ -68684,7 +68666,7 @@ const UnExpandAllIcon = ({ className, color = '#7F7F7F', size = 24, onClick, sty
68684
68666
  };
68685
68667
 
68686
68668
  const RenderContentCol = (props) => {
68687
- const { col, indexCol, indexRow, isSelected, row, zeroVisiable, groupSetting, formatSetting, idTable, fisrtObjWidthFixRight, lastObjWidthFixLeft, objWidthFixLeft, objWidthFixRight, selectedRows, selectEnable, setSelectedRows, fieldKey, isMulti } = props;
68669
+ const { col, indexCol, indexRow, isSelected, row, zeroVisiable, formatSetting, idTable, fisrtObjWidthFixRight, lastObjWidthFixLeft, objWidthFixLeft, objWidthFixRight, selectedRows, selectEnable, setSelectedRows, fieldKey, isMulti } = props;
68688
68670
  const cellId = `content-${idTable}-row${indexRow}col-${indexCol}`;
68689
68671
  const checkOverflow = () => {
68690
68672
  const element = document.getElementById(cellId);
@@ -68754,7 +68736,7 @@ const RenderContentCol = (props) => {
68754
68736
  }, children: displayText }) }), checkOverflow() && (jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: cellId, placement: "top", children: jsx("div", { style: { color: textColor }, children: displayText }) }))] }));
68755
68737
  }
68756
68738
  };
68757
- return (jsx(Fragment$1, { children: col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (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: {
68739
+ return (jsx(Fragment$1, { children: col.visible !== false && col.isGroup !== true && (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: {
68758
68740
  left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
68759
68741
  right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined
68760
68742
  }, onClick: (e) => {
@@ -68812,17 +68794,17 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68812
68794
  setExpandsAll(true);
68813
68795
  }, [groupSetting?.groupColumns]);
68814
68796
  const { levels: headerColumns, objHeaderWidthFixLeft, objHeaderWidthFixRight, objWidthFixLeft, objWidthFixRight, lastObjWidthFixLeft, fisrtObjWidthFixRight } = useMemo(() => {
68815
- const rs = calculateTableStructure(columns, settingColumns?.value);
68797
+ const rs = calculateTableStructure(columns, settingColumns?.value, groupSetting?.groupColumns);
68816
68798
  setContentColumns(rs.flat);
68817
68799
  return rs;
68818
- }, [columns, settingColumns]);
68819
- const optionGroupColumns = useMemo(() => contentColumns.filter((x) => !groupSetting?.groupColumns.includes(x.field)).map((x) => ({ ...x, headerDisplay: t(x.columnGroupText ?? x.headerDisplay ?? x.headerText) })), [groupSetting?.groupColumns, contentColumns]);
68800
+ }, [columns, settingColumns, groupSetting?.groupColumns]);
68801
+ const optionGroupColumns = useMemo(() => contentColumns.map((x) => ({ ...x, headerDisplay: t(x.headerText) })), [contentColumns]);
68820
68802
  const firstColSpan = useMemo(() => {
68821
68803
  let count = 0;
68822
68804
  let index = 3;
68823
68805
  for (let i = 0; i < contentColumns.length; i++) {
68824
68806
  const col = contentColumns[i];
68825
- if (col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field))) {
68807
+ if (col.visible !== false && col.isGroup !== true) {
68826
68808
  count++;
68827
68809
  }
68828
68810
  if (count === 3) {
@@ -68831,7 +68813,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68831
68813
  }
68832
68814
  }
68833
68815
  return index;
68834
- }, [contentColumns, groupSetting?.groupColumns]);
68816
+ }, [contentColumns]);
68835
68817
  // 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
68836
68818
  const viewData = useMemo(() => {
68837
68819
  if (!dataSource || dataSource.length === 0) {
@@ -69069,7 +69051,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69069
69051
  setExpandsAll(undefined);
69070
69052
  row.expand = !expand;
69071
69053
  } }), t(col.headerDisplay ?? col.headerText), ": ", value, " (", row.children.length, ")"] }) }), contentColumns.map((colSum, indexCol) => {
69072
- if (indexCol <= firstColSpan || colSum.visible === false || (!groupSetting?.visibleGroupColumn && groupColumns?.includes(colSum.field))) {
69054
+ if (indexCol <= firstColSpan || colSum.visible === false || colSum.isGroup === true) {
69073
69055
  return;
69074
69056
  }
69075
69057
  let sumValue = row[colSum.field];
@@ -69097,7 +69079,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69097
69079
  }, onContextMenu: (e) => {
69098
69080
  e.preventDefault();
69099
69081
  handleContextMenu(e, row);
69100
- }, children: contentColumns.map((column, indexCol) => (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}`));
69082
+ }, children: contentColumns.map((column, indexCol) => (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}`));
69101
69083
  }
69102
69084
  }) }));
69103
69085
  };
@@ -69124,7 +69106,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69124
69106
  virtualDivRef.current.style.height = '0px';
69125
69107
  }
69126
69108
  }, [context]);
69127
- return (jsxs("div", { className: "r-table-edit r-virtualized-table", children: [jsxs("div", { className: "r-grid", children: [toolbarSetting?.showTopToolbar && jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), headerComponent && headerComponent(), jsxs("div", { ref: gridRef, className: "r-gridtable", style: { height: `${height ? `${height}px` : 'auto'}`, position: 'relative' }, children: [jsxs("table", { role: "presentation", style: { width: '100%' }, children: [jsx(RenderColGroup, { contentColumns: contentColumns, groupSetting: groupSetting }), jsx("thead", { className: "r-gridheader", role: "rowgroup", children: headerColumns.map((rowColumn, indexParent) => {
69109
+ return (jsxs("div", { className: "r-table-edit r-virtualized-table", children: [jsxs("div", { className: "r-grid", children: [toolbarSetting?.showTopToolbar && jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), headerComponent && headerComponent(), jsxs("div", { ref: gridRef, className: "r-gridtable", style: { height: `${height ? `${height}px` : 'auto'}`, position: 'relative' }, children: [jsxs("table", { role: "presentation", style: { width: '100%' }, children: [jsx(RenderColGroup, { contentColumns: contentColumns }), jsx("thead", { className: "r-gridheader", role: "rowgroup", children: headerColumns.map((rowColumn, indexParent) => {
69128
69110
  return (jsx("tr", { className: "r-row", role: "row", children: rowColumn.map((col, index) => (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) => {
69129
69111
  setFilterBy([...val]);
69130
69112
  if (querySetting?.changeFilter) {
@@ -69135,9 +69117,9 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69135
69117
  if (querySetting?.changeOrder) {
69136
69118
  querySetting.changeOrder(val);
69137
69119
  }
69138
- }, columns: contentColumns, groupSetting: groupSetting, setContentColumns: setContentColumns, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, totalCount: dataSource?.length ?? 0 }, `header-${indexParent}-${index}`))) }, `header-${-indexParent}`));
69120
+ }, columns: contentColumns, setContentColumns: setContentColumns, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, totalCount: dataSource?.length ?? 0 }, `header-${indexParent}-${index}`))) }, `header-${-indexParent}`));
69139
69121
  }) }), jsx("tbody", { className: "r-gridcontent", role: "rowgroup", children: jsx(RenderContent, { datas: viewData }) }), jsx("tfoot", { className: "r-gridfoot", children: (columnsAggregate?.length ?? 0) > 0 && (jsx("tr", { className: "r-row", children: contentColumns.map((col, indexCol) => {
69140
- if (col.visible === false || (!groupSetting?.visibleGroupColumn && groupSetting?.groupColumns.includes(col.field))) {
69122
+ if (col.visible === false || col.isGroup === true) {
69141
69123
  return;
69142
69124
  }
69143
69125
  const item = columnsAggregate?.find((x) => x.field === col.field);