react-table-edit 1.5.27 → 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;
@@ -20076,6 +20113,15 @@ const CheckRowMatch = (row, filters, keyword, searchKeys) => {
20076
20113
  });
20077
20114
  return isFilterMatch && isSearchMatch;
20078
20115
  };
20116
+ const getMaxExpandedLevel = (items, fieldChildren = 'children', level = 0) => {
20117
+ let max = level;
20118
+ items.forEach((item) => {
20119
+ if (item[fieldChildren]?.length > 0) {
20120
+ max = Math.max(max, getMaxExpandedLevel(item[fieldChildren], fieldChildren, level + 1));
20121
+ }
20122
+ });
20123
+ return max;
20124
+ };
20079
20125
 
20080
20126
  const defaultMaxHeight$1 = 250;
20081
20127
  const SelectTable = React$5.forwardRef((props, ref) => {
@@ -20412,7 +20458,7 @@ const SelectTable = React$5.forwardRef((props, ref) => {
20412
20458
  setIndexFocus(indexRow);
20413
20459
  }
20414
20460
  e.stopPropagation();
20415
- }, children: col.template ? (col.template(row, indexRow)) : col.type === 'numeric' && Number(row[col.field]) < 0 ? (jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] })) : (valueDisplay) }, `col-${indexRow}-${indexCol}`)), checkOverflow(indexRow, indexCol) && (jsxRuntime.jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: `select-${id}-${indexRow}-${indexCol}`, children: col.template ? col.template(row, indexRow) : valueDisplay }))] }, indexCol));
20461
+ }, children: col.template ? col.template(row, indexRow) : col.type === 'numeric' && Number(row[col.field]) < 0 ? jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] }) : valueDisplay }, `col-${indexRow}-${indexCol}`)), checkOverflow(indexRow, indexCol) && (jsxRuntime.jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: `select-${id}-${indexRow}-${indexCol}`, children: col.template ? col.template(row, indexRow) : valueDisplay }))] }, indexCol));
20416
20462
  })] }, `row-${indexRow}`));
20417
20463
  });
20418
20464
  const RenderTable = (props) => {
@@ -20469,7 +20515,7 @@ const SelectTable = React$5.forwardRef((props, ref) => {
20469
20515
  inputRef?.current.focus();
20470
20516
  e.preventDefault();
20471
20517
  }
20472
- }, children: jsxRuntime.jsxs("div", { className: "r-select-grid", children: [jsxRuntime.jsx("div", { className: classNames$1('r-select-gridtable', { 'no-header': noHeader || (columns?.length ?? 0) === 0 }), ref: selectMenuTableRef, style: { width: menuWidth, minWidth: selectTableRef?.current?.clientWidth, maxHeight: maxHeight ?? defaultMaxHeight$1 }, children: jsxRuntime.jsx(RenderTable, {}) }), jsxRuntime.jsxs("div", { className: classNames$1('r-select-footer', { 'd-none': !(showFooter === true || handleAdd) }), children: [jsxRuntime.jsxs(Button$1$1, { outline: true, color: "primary", onClick: () => handleAdd?.(), className: classNames$1('r-btn d-flex align-items-center', { 'd-none': !handleAdd }), children: [jsxRuntime.jsx(SvgPlus, { className: "me-50", fontSize: 16 }), t('AddNew'), " (F9)"] }), footerComponent ? footerComponent() : null] })] }) })) }) })] }) }) }));
20518
+ }, children: jsxRuntime.jsxs("div", { className: "r-select-grid", children: [jsxRuntime.jsx("div", { className: classNames$1('r-select-gridtable', { 'no-header': noHeader || (columns?.length ?? 0) === 0 }), ref: selectMenuTableRef, style: { width: menuWidth, minWidth: selectTableRef?.current?.clientWidth, maxHeight: maxHeight ?? defaultMaxHeight$1 }, children: jsxRuntime.jsx(RenderTable, {}) }), jsxRuntime.jsxs("div", { className: classNames$1('r-select-footer', { 'd-none': !(showFooter === true || handleAdd || isMulti) }), children: [jsxRuntime.jsxs(Button$1$1, { outline: true, color: "primary", onClick: () => handleAdd?.(), className: classNames$1('r-btn d-flex align-items-center', { 'd-none': !handleAdd }), children: [jsxRuntime.jsx(SvgPlus, { className: "me-50", fontSize: 16 }), t('AddNew'), " (F9)"] }), isMulti && jsxRuntime.jsx("div", { className: "ms-50 text-primary h-100 d-flex align-items-center", children: t('countSelected', { item: value?.length ?? 0 }) }), footerComponent ? footerComponent() : null] })] }) })) }) })] }) }) }));
20473
20519
  });
20474
20520
 
20475
20521
  const PagingComponent = ({ totalItem, gridRef, pageSize, currentPage, onChangePage, pageOptions, onChangePageSize }) => {
@@ -31608,63 +31654,7 @@ class DateLib {
31608
31654
  formatNumber(value) {
31609
31655
  return this.replaceDigits(value.toString());
31610
31656
  }
31611
- /**
31612
- * Returns the preferred ordering for month and year labels for the current
31613
- * locale.
31614
- */
31615
- getMonthYearOrder() {
31616
- const code = this.options.locale?.code;
31617
- if (!code) {
31618
- return "month-first";
31619
- }
31620
- return DateLib.yearFirstLocales.has(code) ? "year-first" : "month-first";
31621
- }
31622
- /**
31623
- * Formats the month/year pair respecting locale conventions.
31624
- *
31625
- * @since 9.11.0
31626
- */
31627
- formatMonthYear(date) {
31628
- const { locale, timeZone, numerals } = this.options;
31629
- const localeCode = locale?.code;
31630
- if (localeCode && DateLib.yearFirstLocales.has(localeCode)) {
31631
- try {
31632
- const intl = new Intl.DateTimeFormat(localeCode, {
31633
- month: "long",
31634
- year: "numeric",
31635
- timeZone,
31636
- numberingSystem: numerals,
31637
- });
31638
- const formatted = intl.format(date);
31639
- return formatted;
31640
- }
31641
- catch {
31642
- // Fallback to date-fns formatting below.
31643
- }
31644
- }
31645
- const pattern = this.getMonthYearOrder() === "year-first" ? "y LLLL" : "LLLL y";
31646
- return this.format(date, pattern);
31647
- }
31648
- }
31649
- DateLib.yearFirstLocales = new Set([
31650
- "eu",
31651
- "hu",
31652
- "ja",
31653
- "ja-Hira",
31654
- "ja-JP",
31655
- "ko",
31656
- "ko-KR",
31657
- "lt",
31658
- "lt-LT",
31659
- "lv",
31660
- "lv-LV",
31661
- "mn",
31662
- "mn-MN",
31663
- "zh",
31664
- "zh-CN",
31665
- "zh-HK",
31666
- "zh-TW",
31667
- ]);
31657
+ }
31668
31658
  /**
31669
31659
  * The default date library with English locale.
31670
31660
  *
@@ -32560,7 +32550,7 @@ function getDefaultClassNames() {
32560
32550
  /**
32561
32551
  * Formats the caption of the month.
32562
32552
  *
32563
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32553
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32564
32554
  * @param month The date representing the month.
32565
32555
  * @param options Configuration options for the date library.
32566
32556
  * @param dateLib The date library to use for formatting. If not provided, a new
@@ -32570,8 +32560,7 @@ function getDefaultClassNames() {
32570
32560
  * @see https://daypicker.dev/docs/translation#custom-formatters
32571
32561
  */
32572
32562
  function formatCaption(month, options, dateLib) {
32573
- const lib = dateLib ?? new DateLib(options);
32574
- return lib.formatMonthYear(month);
32563
+ return (dateLib ?? new DateLib(options)).format(month, "LLLL y");
32575
32564
  }
32576
32565
  /**
32577
32566
  * @private
@@ -32865,7 +32854,7 @@ const labelDay = labelDayButton;
32865
32854
  * Generates the ARIA label for the month grid, which is announced when entering
32866
32855
  * the grid.
32867
32856
  *
32868
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32857
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32869
32858
  * @param date - The date representing the month.
32870
32859
  * @param options - Optional configuration for the date formatting library.
32871
32860
  * @param dateLib - An optional instance of the date formatting library.
@@ -32874,8 +32863,7 @@ const labelDay = labelDayButton;
32874
32863
  * @see https://daypicker.dev/docs/translation#aria-labels
32875
32864
  */
32876
32865
  function labelGrid(date, options, dateLib) {
32877
- const lib = dateLib ?? new DateLib(options);
32878
- return lib.formatMonthYear(date);
32866
+ return (dateLib ?? new DateLib(options)).format(date, "LLLL y");
32879
32867
  }
32880
32868
  /**
32881
32869
  * @ignore
@@ -34358,7 +34346,7 @@ function DayPicker(initialProps) {
34358
34346
  formatters,
34359
34347
  };
34360
34348
  return (React__default["default"].createElement(dayPickerContext.Provider, { value: contextValue },
34361
- 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 },
34362
34350
  React__default["default"].createElement(components.Months, { className: classNames[UI.Months], style: styles?.[UI.Months] },
34363
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 })),
34364
34352
  months.map((calendarMonth, displayIndex) => {
@@ -34370,16 +34358,10 @@ function DayPicker(initialProps) {
34370
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 },
34371
34359
  React__default["default"].createElement(components.Chevron, { disabled: previousMonth ? undefined : true, className: classNames[UI.Chevron], orientation: props.dir === "rtl" ? "right" : "left" }))),
34372
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] },
34373
- (() => {
34374
- const monthControl = captionLayout === "dropdown" ||
34375
- 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)));
34376
- const yearControl = captionLayout === "dropdown" ||
34377
- 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)));
34378
- const controls = dateLib.getMonthYearOrder() === "year-first"
34379
- ? [yearControl, monthControl]
34380
- : [monthControl, yearControl];
34381
- return controls;
34382
- })(),
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))),
34383
34365
  React__default["default"].createElement("span", { role: "status", "aria-live": "polite", style: {
34384
34366
  border: 0,
34385
34367
  clip: "rect(0 0 0 0)",
@@ -35864,7 +35846,7 @@ const SelectTableTree = React$5.forwardRef((props, ref) => {
35864
35846
  let flag = false;
35865
35847
  if (!key) {
35866
35848
  if (e.code === 'F9') {
35867
- handleAdd();
35849
+ handleAdd?.(e);
35868
35850
  flag = true;
35869
35851
  }
35870
35852
  else if (e.code === 'Space') {
@@ -36050,7 +36032,7 @@ const SelectTableTree = React$5.forwardRef((props, ref) => {
36050
36032
  setExpanded(true);
36051
36033
  }
36052
36034
  e.stopPropagation();
36053
- }, fontSize: 18, className: classNames$1('me-50 r-icon-expand', { 'is-open': expanded }) })), col.template ? col.template(row, indexRow) : col.type === 'numeric' && Number(row[col.field]) < 0 ? jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] }) : valueDisplay] }, `col-${indexRow}-${indexCol}`)), checkOverflow(indexRow, indexCol) && (jsxRuntime.jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: `select-${id}-${indexRow}-${indexCol}`, children: col.template ? col.template(row, indexRow) : col.type === 'numeric' && Number(row[col.field]) < 0 ? jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] }) : valueDisplay }))] }, indexCol));
36035
+ }, fontSize: 18, className: classNames$1('me-50 r-icon-expand', { 'is-open': expanded }) })), col.template ? (col.template(row, indexRow)) : col.type === 'numeric' && Number(row[col.field]) < 0 ? (jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] })) : (valueDisplay)] }, `col-${indexRow}-${indexCol}`)), checkOverflow(indexRow, indexCol) && (jsxRuntime.jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: `select-${id}-${indexRow}-${indexCol}`, children: col.template ? (col.template(row, indexRow)) : col.type === 'numeric' && Number(row[col.field]) < 0 ? (jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] })) : (valueDisplay) }))] }, indexCol));
36054
36036
  })] }, `row-${indexRow}`), row[fieldChildren ?? 'children'] &&
36055
36037
  row.expanded &&
36056
36038
  row[fieldChildren ?? 'children'].map((child, indexChild) => {
@@ -36060,9 +36042,10 @@ const SelectTableTree = React$5.forwardRef((props, ref) => {
36060
36042
  }
36061
36043
  })] }));
36062
36044
  });
36045
+ const maxExpandedLevel = getMaxExpandedLevel(options, fieldChildren, 0);
36063
36046
  const RenderTable = (props) => {
36064
36047
  let countDisplay = 0;
36065
- return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsxs("table", { style: { width: '100%' }, children: [!(noHeader && (columns?.length ?? 0) > 0) && (jsxRuntime.jsx("thead", { className: "r-select-gridheader", children: jsxRuntime.jsxs("tr", { className: "r-select-row", role: "row", children: [isMulti && (jsxRuntime.jsx("th", { className: classNames$1(`r-select-headercell checkbox-column`), style: { width: 50, top: `0px` }, children: jsxRuntime.jsx("div", { style: { justifyContent: 'left' }, className: classNames$1('r-select-headercell-div'), children: jsxRuntime.jsx(Input$1, { checked: isSelectedAll, type: "checkbox", onClick: (e) => {
36048
+ return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsxs("table", { style: { width: '100%' }, children: [!(noHeader && (columns?.length ?? 0) > 0) && (jsxRuntime.jsx("thead", { className: "r-select-gridheader", children: jsxRuntime.jsxs("tr", { className: "r-select-row", role: "row", children: [isMulti && (jsxRuntime.jsx("th", { className: classNames$1(`r-select-headercell checkbox-column`), style: { width: 10 + maxExpandedLevel * 15, top: `0px` }, children: jsxRuntime.jsx("div", { style: { justifyContent: 'left' }, className: classNames$1('r-select-headercell-div'), children: jsxRuntime.jsx(Input$1, { checked: isSelectedAll, type: "checkbox", onClick: (e) => {
36066
36049
  if (isMulti) {
36067
36050
  if (isSelectedAll) {
36068
36051
  onChange([]);
@@ -36106,7 +36089,7 @@ const SelectTableTree = React$5.forwardRef((props, ref) => {
36106
36089
  e.preventDefault();
36107
36090
  }, tag: "div", style: { width: '100%' }, className: classNames$1('select-table-control', { 'r-select-is-disabled': isDisabled }, { 'r-select-is-open': dropdownOpen }, { 'r-select-is-focus': isFocus }, { 'r-select-is-invalid': invalid }), children: [jsxRuntime.jsxs("div", { className: "select-table-container", children: [isMulti ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: jsxRuntime.jsx("div", { className: classNames$1('select-value is-mutil', { 'd-none': searchTerm }), children: getSelectedRecords(options, value).map((ele, index) => {
36108
36091
  return (jsxRuntime.jsxs("span", { children: [index === 0 ? '' : ', ', ele[fieldLabel ?? 'label']] }, index));
36109
- }) }) })) : (jsxRuntime.jsx(jsxRuntime.Fragment, { children: jsxRuntime.jsxs("div", { className: classNames$1('select-value', { 'd-none': searchTerm }), children: [value ? (formatOptionLabel ? formatOptionLabel(value) : value[fieldLabel ?? 'label']) : '', " "] }) })), !((isMulti ? value?.length > 0 : value) || isDisabled || searchTerm) && jsxRuntime.jsx("div", { className: classNames$1('select-placeholder'), children: placeholder }), jsxRuntime.jsx("div", { className: "input-container", children: jsxRuntime.jsx("input", { style: { textAlign: textAlign ?? 'left' }, ref: inputRef, className: classNames$1('select-input'), readOnly: isDisabled, value: searchTerm, onPaste: (e) => onPaste && !dropdownOpen && onPaste(e), onChange: (val) => {
36092
+ }) }) })) : (jsxRuntime.jsxs("div", { className: classNames$1('select-value', { 'd-none': searchTerm }), children: [value ? (formatOptionLabel ? formatOptionLabel(value) : value[fieldLabel ?? 'label']) : '', " "] })), !((isMulti ? value?.length > 0 : value) || isDisabled || searchTerm) && jsxRuntime.jsx("div", { className: classNames$1('select-placeholder'), children: placeholder }), jsxRuntime.jsx("div", { className: "input-container", children: jsxRuntime.jsx("input", { style: { textAlign: textAlign ?? 'left' }, ref: inputRef, className: classNames$1('select-input'), readOnly: isDisabled, value: searchTerm, onPaste: (e) => onPaste && !dropdownOpen && onPaste(e), onChange: (val) => {
36110
36093
  setSearchTerm(val.target.value);
36111
36094
  }, onKeyDown: (e) => handleOnKeyDown(e) }) })] }), isClearable && value && !isDisabled && (jsxRuntime.jsx("div", { className: classNames$1('cursor-pointer icon-clear'), onClick: (e) => {
36112
36095
  onChange(isMulti ? [] : undefined);
@@ -36121,7 +36104,7 @@ const SelectTableTree = React$5.forwardRef((props, ref) => {
36121
36104
  inputRef?.current.focus();
36122
36105
  e.preventDefault();
36123
36106
  }
36124
- }, children: jsxRuntime.jsxs("div", { className: "r-select-grid r-select-tree-grid", children: [jsxRuntime.jsx("div", { className: "r-select-gridtable ", ref: selectMenuTableRef, style: { width: menuWidth, minWidth: selectTableRef?.current?.clientWidth, maxHeight: maxHeight ?? defaultMaxHeight }, children: jsxRuntime.jsx(RenderTable, {}) }), jsxRuntime.jsxs("div", { className: classNames$1('r-select-footer', { 'd-none': !(showFooter === true || handleAdd || isMulti) }), children: [jsxRuntime.jsxs(Button$1$1, { outline: true, color: "primary", onClick: handleAdd, className: classNames$1('r-btn d-flex align-items-center', { 'd-none': !handleAdd }), children: [jsxRuntime.jsx(SvgPlus, { className: "me-50", fontSize: 16 }), t('AddNew'), " (F9)"] }), isMulti && (jsxRuntime.jsx("div", { className: "ms-50 text-primary h-100 d-flex align-items-center", onClick: handleAdd, children: t('countSelected', { item: value?.length ?? 0 }) })), footerComponent ? footerComponent() : null] })] }) })) }) })] }) }) }));
36107
+ }, children: jsxRuntime.jsxs("div", { className: "r-select-grid r-select-tree-grid", children: [jsxRuntime.jsx("div", { className: "r-select-gridtable ", ref: selectMenuTableRef, style: { width: menuWidth, minWidth: selectTableRef?.current?.clientWidth, maxHeight: maxHeight ?? defaultMaxHeight }, children: jsxRuntime.jsx(RenderTable, {}) }), jsxRuntime.jsxs("div", { className: classNames$1('r-select-footer', { 'd-none': !(showFooter === true || handleAdd || isMulti) }), children: [jsxRuntime.jsxs(Button$1$1, { outline: true, color: "primary", onClick: handleAdd, className: classNames$1('r-btn d-flex align-items-center', { 'd-none': !handleAdd }), children: [jsxRuntime.jsx(SvgPlus, { className: "me-50", fontSize: 16 }), t('AddNew'), " (F9)"] }), isMulti && jsxRuntime.jsx("div", { className: "ms-50 text-primary h-100 d-flex align-items-center", children: t('countSelected', { item: value?.length ?? 0 }) }), footerComponent ? footerComponent() : null] })] }) })) }) })] }) }) }));
36125
36108
  });
36126
36109
 
36127
36110
  const RenderEditCellComponent = (props) => {
@@ -36245,7 +36228,7 @@ const RenderEditCellComponent = (props) => {
36245
36228
  col.callback(val, indexRow, row);
36246
36229
  }
36247
36230
  handleDataChange(row, col, indexRow);
36248
- }, fieldValue: col.selectSettings?.fieldValue, fieldLabel: col.selectSettings?.fieldLabel, component: gridRef, columns: col.selectSettings?.columns, isClearable: col.selectSettings?.isClearable ?? false, formatSetting: formatSetting, placeholder: t('Select'), loadOptions: col.selectSettings?.loadOptions, handleAdd: col.selectSettings?.handAddNew ? (e) => col.selectSettings?.handAddNew(e, indexRow, row) : undefined, fieldChildren: col.selectSettings?.fieldChild ?? 'children', selectChilds: col.selectSettings?.selectChilds, showFooter: col.selectSettings?.showFooter, formatOptionLabel: col.selectSettings?.formatOptionLabel, footerComponent: col.selectSettings?.footerComponent, width: col.selectSettings?.widthPopup ? Number(col.selectSettings?.widthPopup) : undefined, isMulti: col.selectSettings?.isMulti, noHeader: col.selectSettings?.noHeader, invalid: col.validate && col.validate(row[col.field], row), maxHeight: col.selectSettings?.heightPopup ? Number(col.selectSettings?.heightPopup) : undefined, menuWidth: col.selectSettings?.widthPopup ? Number(col.selectSettings?.widthPopup) : undefined, textAlign: col.textAlign ?? 'left', onOpenMenu: col.selectSettings?.onOpenMenu ? () => col.selectSettings?.onOpenMenu?.(row, col, indexRow) : undefined, onKeyDown: (e) => {
36231
+ }, fieldValue: col.selectSettings?.fieldValue, fieldLabel: col.selectSettings?.fieldLabel, component: gridRef, columns: col.selectSettings?.columns, isClearable: col.selectSettings?.isClearable ?? false, formatSetting: formatSetting, placeholder: t('Select'), handleAdd: col.selectSettings?.handAddNew ? (e) => col.selectSettings?.handAddNew(e, indexRow, row) : undefined, fieldChildren: col.selectSettings?.fieldChild ?? 'children', selectChilds: col.selectSettings?.selectChilds, showFooter: col.selectSettings?.showFooter, formatOptionLabel: col.selectSettings?.formatOptionLabel, footerComponent: col.selectSettings?.footerComponent, width: col.selectSettings?.widthPopup ? Number(col.selectSettings?.widthPopup) : undefined, isMulti: col.selectSettings?.isMulti, noHeader: col.selectSettings?.noHeader, invalid: col.validate && col.validate(row[col.field], row), maxHeight: col.selectSettings?.heightPopup ? Number(col.selectSettings?.heightPopup) : undefined, menuWidth: col.selectSettings?.widthPopup ? Number(col.selectSettings?.widthPopup) : undefined, textAlign: col.textAlign ?? 'left', onOpenMenu: col.selectSettings?.onOpenMenu ? () => col.selectSettings?.onOpenMenu?.(row, col, indexRow) : undefined, onKeyDown: (e) => {
36249
36232
  if (e.key === 'ArrowDown' || e.key === 'ArrowUp' || e.key === 'NumpadEnter' || e.key === 'Enter' || e.key === 'Tab') {
36250
36233
  handleKeyDown(e, row);
36251
36234
  }
@@ -36828,9 +36811,8 @@ const FooterCol = ({ col, indexCol, dataSource, objWidthFix, formatSetting }) =>
36828
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}`));
36829
36812
  };
36830
36813
 
36831
- const RenderColGroup = ({ contentColumns, groupSetting }) => (jsxRuntime.jsx("colgroup", { children: contentColumns.map((col, index) => {
36832
- return (col.visible !== false &&
36833
- (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: {
36834
36816
  width: typeof col.width === 'number' ? `${col.width}px` : col.width || undefined,
36835
36817
  minWidth: typeof col.minWidth === 'number' ? `${col.minWidth}px` : col.minWidth || undefined,
36836
36818
  maxWidth: typeof col.maxWidth === 'number' ? `${col.maxWidth}px` : col.maxWidth || undefined
@@ -38722,7 +38704,7 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38722
38704
  setViewDateTo(selectedTo || today);
38723
38705
  }
38724
38706
  else if (!newRange.from || (selected && selected < newRange.from)) {
38725
- newRange = { from: selected, to };
38707
+ newRange = { from: selected, to: undefined };
38726
38708
  setViewDateFrom(selected || today);
38727
38709
  }
38728
38710
  else if (newRange.from && selected && selected > newRange.from && (!newRange.to || selected < newRange.to)) {
@@ -38733,6 +38715,16 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38733
38715
  newRange = { from, to: selected };
38734
38716
  setViewDateTo(selected || today);
38735
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
+ }
38736
38728
  onChange(newRange);
38737
38729
  setInputValue(formatDisplay(newRange.from, newRange.to));
38738
38730
  };
@@ -39009,7 +39001,7 @@ const DateRangeFilterComponent = ({ fieldFilter, filterBy, handleSave }) => {
39009
39001
  };
39010
39002
 
39011
39003
  const HeaderTableCol = (props) => {
39012
- 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;
39013
39005
  const { t } = reactI18next.useTranslation();
39014
39006
  const headerRef = React$5.useRef(null);
39015
39007
  const order = orderBy.find((item) => item.key === col.field);
@@ -39028,7 +39020,7 @@ const HeaderTableCol = (props) => {
39028
39020
  const checkOverflow = () => {
39029
39021
  return headerRef.current && headerRef.current.scrollHeight > headerRef.current.clientHeight;
39030
39022
  };
39031
- 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: {
39032
39024
  top: `${indexParent * 42}px`,
39033
39025
  left: col.fixedType === 'left' ? objHeaderWidthFixLeft[`${indexParent}-${indexCol ?? 0}`] : undefined,
39034
39026
  right: col.fixedType === 'right' ? objHeaderWidthFixRight[`${indexParent}-${indexCol ?? 0}`] : undefined
@@ -68703,7 +68695,7 @@ const UnExpandAllIcon = ({ className, color = '#7F7F7F', size = 24, onClick, sty
68703
68695
  };
68704
68696
 
68705
68697
  const RenderContentCol = (props) => {
68706
- 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;
68707
68699
  const cellId = `content-${idTable}-row${indexRow}col-${indexCol}`;
68708
68700
  const checkOverflow = () => {
68709
68701
  const element = document.getElementById(cellId);
@@ -68773,7 +68765,7 @@ const RenderContentCol = (props) => {
68773
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 }) }))] }));
68774
68766
  }
68775
68767
  };
68776
- 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: {
68777
68769
  left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
68778
68770
  right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined
68779
68771
  }, onClick: (e) => {
@@ -68831,17 +68823,17 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68831
68823
  setExpandsAll(true);
68832
68824
  }, [groupSetting?.groupColumns]);
68833
68825
  const { levels: headerColumns, objHeaderWidthFixLeft, objHeaderWidthFixRight, objWidthFixLeft, objWidthFixRight, lastObjWidthFixLeft, fisrtObjWidthFixRight } = React$5.useMemo(() => {
68834
- const rs = calculateTableStructure(columns, settingColumns?.value);
68826
+ const rs = calculateTableStructure(columns, settingColumns?.value, groupSetting?.groupColumns);
68835
68827
  setContentColumns(rs.flat);
68836
68828
  return rs;
68837
- }, [columns, settingColumns]);
68838
- 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]);
68839
68831
  const firstColSpan = React$5.useMemo(() => {
68840
68832
  let count = 0;
68841
68833
  let index = 3;
68842
68834
  for (let i = 0; i < contentColumns.length; i++) {
68843
68835
  const col = contentColumns[i];
68844
- if (col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field))) {
68836
+ if (col.visible !== false && col.isGroup !== true) {
68845
68837
  count++;
68846
68838
  }
68847
68839
  if (count === 3) {
@@ -68850,7 +68842,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68850
68842
  }
68851
68843
  }
68852
68844
  return index;
68853
- }, [contentColumns, groupSetting?.groupColumns]);
68845
+ }, [contentColumns]);
68854
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
68855
68847
  const viewData = React$5.useMemo(() => {
68856
68848
  if (!dataSource || dataSource.length === 0) {
@@ -69088,7 +69080,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69088
69080
  setExpandsAll(undefined);
69089
69081
  row.expand = !expand;
69090
69082
  } }), t(col.headerDisplay ?? col.headerText), ": ", value, " (", row.children.length, ")"] }) }), contentColumns.map((colSum, indexCol) => {
69091
- if (indexCol <= firstColSpan || colSum.visible === false || (!groupSetting?.visibleGroupColumn && groupColumns?.includes(colSum.field))) {
69083
+ if (indexCol <= firstColSpan || colSum.visible === false || colSum.isGroup === true) {
69092
69084
  return;
69093
69085
  }
69094
69086
  let sumValue = row[colSum.field];
@@ -69116,7 +69108,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69116
69108
  }, onContextMenu: (e) => {
69117
69109
  e.preventDefault();
69118
69110
  handleContextMenu(e, row);
69119
- }, 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}`));
69120
69112
  }
69121
69113
  }) }));
69122
69114
  };
@@ -69143,7 +69135,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69143
69135
  virtualDivRef.current.style.height = '0px';
69144
69136
  }
69145
69137
  }, [context]);
69146
- 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) => {
69147
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) => {
69148
69140
  setFilterBy([...val]);
69149
69141
  if (querySetting?.changeFilter) {
@@ -69154,9 +69146,9 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69154
69146
  if (querySetting?.changeOrder) {
69155
69147
  querySetting.changeOrder(val);
69156
69148
  }
69157
- }, 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}`));
69158
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) => {
69159
- if (col.visible === false || (!groupSetting?.visibleGroupColumn && groupSetting?.groupColumns.includes(col.field))) {
69151
+ if (col.visible === false || col.isGroup === true) {
69160
69152
  return;
69161
69153
  }
69162
69154
  const item = columnsAggregate?.find((x) => x.field === col.field);
@@ -69205,6 +69197,7 @@ exports["default"] = TableEdit;
69205
69197
  exports.formartNumberic = formartNumberic;
69206
69198
  exports.formatDateTime = formatDateTime;
69207
69199
  exports.generateUUID = generateUUID;
69200
+ exports.getMaxExpandedLevel = getMaxExpandedLevel;
69208
69201
  exports.isNullOrUndefined = isNullOrUndefined$1;
69209
69202
  exports.messageBoxConfirm = messageBoxConfirm;
69210
69203
  exports.messageBoxConfirmAsync = messageBoxConfirmAsync;