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.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;
@@ -20047,6 +20084,15 @@ const CheckRowMatch = (row, filters, keyword, searchKeys) => {
20047
20084
  });
20048
20085
  return isFilterMatch && isSearchMatch;
20049
20086
  };
20087
+ const getMaxExpandedLevel = (items, fieldChildren = 'children', level = 0) => {
20088
+ let max = level;
20089
+ items.forEach((item) => {
20090
+ if (item[fieldChildren]?.length > 0) {
20091
+ max = Math.max(max, getMaxExpandedLevel(item[fieldChildren], fieldChildren, level + 1));
20092
+ }
20093
+ });
20094
+ return max;
20095
+ };
20050
20096
 
20051
20097
  const defaultMaxHeight$1 = 250;
20052
20098
  const SelectTable = forwardRef((props, ref) => {
@@ -20383,7 +20429,7 @@ const SelectTable = forwardRef((props, ref) => {
20383
20429
  setIndexFocus(indexRow);
20384
20430
  }
20385
20431
  e.stopPropagation();
20386
- }, children: col.template ? (col.template(row, indexRow)) : col.type === 'numeric' && Number(row[col.field]) < 0 ? (jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] })) : (valueDisplay) }, `col-${indexRow}-${indexCol}`)), checkOverflow(indexRow, indexCol) && (jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: `select-${id}-${indexRow}-${indexCol}`, children: col.template ? col.template(row, indexRow) : valueDisplay }))] }, indexCol));
20432
+ }, children: col.template ? col.template(row, indexRow) : col.type === 'numeric' && Number(row[col.field]) < 0 ? jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] }) : valueDisplay }, `col-${indexRow}-${indexCol}`)), checkOverflow(indexRow, indexCol) && (jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: `select-${id}-${indexRow}-${indexCol}`, children: col.template ? col.template(row, indexRow) : valueDisplay }))] }, indexCol));
20387
20433
  })] }, `row-${indexRow}`));
20388
20434
  });
20389
20435
  const RenderTable = (props) => {
@@ -20440,7 +20486,7 @@ const SelectTable = forwardRef((props, ref) => {
20440
20486
  inputRef?.current.focus();
20441
20487
  e.preventDefault();
20442
20488
  }
20443
- }, children: jsxs("div", { className: "r-select-grid", children: [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: jsx(RenderTable, {}) }), jsxs("div", { className: classNames$1('r-select-footer', { 'd-none': !(showFooter === true || handleAdd) }), children: [jsxs(Button$1$1, { outline: true, color: "primary", onClick: () => handleAdd?.(), className: classNames$1('r-btn d-flex align-items-center', { 'd-none': !handleAdd }), children: [jsx(SvgPlus, { className: "me-50", fontSize: 16 }), t('AddNew'), " (F9)"] }), footerComponent ? footerComponent() : null] })] }) })) }) })] }) }) }));
20489
+ }, children: jsxs("div", { className: "r-select-grid", children: [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: jsx(RenderTable, {}) }), jsxs("div", { className: classNames$1('r-select-footer', { 'd-none': !(showFooter === true || handleAdd || isMulti) }), children: [jsxs(Button$1$1, { outline: true, color: "primary", onClick: () => handleAdd?.(), className: classNames$1('r-btn d-flex align-items-center', { 'd-none': !handleAdd }), children: [jsx(SvgPlus, { className: "me-50", fontSize: 16 }), t('AddNew'), " (F9)"] }), isMulti && jsx("div", { className: "ms-50 text-primary h-100 d-flex align-items-center", children: t('countSelected', { item: value?.length ?? 0 }) }), footerComponent ? footerComponent() : null] })] }) })) }) })] }) }) }));
20444
20490
  });
20445
20491
 
20446
20492
  const PagingComponent = ({ totalItem, gridRef, pageSize, currentPage, onChangePage, pageOptions, onChangePageSize }) => {
@@ -31579,63 +31625,7 @@ class DateLib {
31579
31625
  formatNumber(value) {
31580
31626
  return this.replaceDigits(value.toString());
31581
31627
  }
31582
- /**
31583
- * Returns the preferred ordering for month and year labels for the current
31584
- * locale.
31585
- */
31586
- getMonthYearOrder() {
31587
- const code = this.options.locale?.code;
31588
- if (!code) {
31589
- return "month-first";
31590
- }
31591
- return DateLib.yearFirstLocales.has(code) ? "year-first" : "month-first";
31592
- }
31593
- /**
31594
- * Formats the month/year pair respecting locale conventions.
31595
- *
31596
- * @since 9.11.0
31597
- */
31598
- formatMonthYear(date) {
31599
- const { locale, timeZone, numerals } = this.options;
31600
- const localeCode = locale?.code;
31601
- if (localeCode && DateLib.yearFirstLocales.has(localeCode)) {
31602
- try {
31603
- const intl = new Intl.DateTimeFormat(localeCode, {
31604
- month: "long",
31605
- year: "numeric",
31606
- timeZone,
31607
- numberingSystem: numerals,
31608
- });
31609
- const formatted = intl.format(date);
31610
- return formatted;
31611
- }
31612
- catch {
31613
- // Fallback to date-fns formatting below.
31614
- }
31615
- }
31616
- const pattern = this.getMonthYearOrder() === "year-first" ? "y LLLL" : "LLLL y";
31617
- return this.format(date, pattern);
31618
- }
31619
- }
31620
- DateLib.yearFirstLocales = new Set([
31621
- "eu",
31622
- "hu",
31623
- "ja",
31624
- "ja-Hira",
31625
- "ja-JP",
31626
- "ko",
31627
- "ko-KR",
31628
- "lt",
31629
- "lt-LT",
31630
- "lv",
31631
- "lv-LV",
31632
- "mn",
31633
- "mn-MN",
31634
- "zh",
31635
- "zh-CN",
31636
- "zh-HK",
31637
- "zh-TW",
31638
- ]);
31628
+ }
31639
31629
  /**
31640
31630
  * The default date library with English locale.
31641
31631
  *
@@ -32531,7 +32521,7 @@ function getDefaultClassNames() {
32531
32521
  /**
32532
32522
  * Formats the caption of the month.
32533
32523
  *
32534
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32524
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32535
32525
  * @param month The date representing the month.
32536
32526
  * @param options Configuration options for the date library.
32537
32527
  * @param dateLib The date library to use for formatting. If not provided, a new
@@ -32541,8 +32531,7 @@ function getDefaultClassNames() {
32541
32531
  * @see https://daypicker.dev/docs/translation#custom-formatters
32542
32532
  */
32543
32533
  function formatCaption(month, options, dateLib) {
32544
- const lib = dateLib ?? new DateLib(options);
32545
- return lib.formatMonthYear(month);
32534
+ return (dateLib ?? new DateLib(options)).format(month, "LLLL y");
32546
32535
  }
32547
32536
  /**
32548
32537
  * @private
@@ -32836,7 +32825,7 @@ const labelDay = labelDayButton;
32836
32825
  * Generates the ARIA label for the month grid, which is announced when entering
32837
32826
  * the grid.
32838
32827
  *
32839
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32828
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32840
32829
  * @param date - The date representing the month.
32841
32830
  * @param options - Optional configuration for the date formatting library.
32842
32831
  * @param dateLib - An optional instance of the date formatting library.
@@ -32845,8 +32834,7 @@ const labelDay = labelDayButton;
32845
32834
  * @see https://daypicker.dev/docs/translation#aria-labels
32846
32835
  */
32847
32836
  function labelGrid(date, options, dateLib) {
32848
- const lib = dateLib ?? new DateLib(options);
32849
- return lib.formatMonthYear(date);
32837
+ return (dateLib ?? new DateLib(options)).format(date, "LLLL y");
32850
32838
  }
32851
32839
  /**
32852
32840
  * @ignore
@@ -34329,7 +34317,7 @@ function DayPicker(initialProps) {
34329
34317
  formatters,
34330
34318
  };
34331
34319
  return (React__default.createElement(dayPickerContext.Provider, { value: contextValue },
34332
- 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 },
34333
34321
  React__default.createElement(components.Months, { className: classNames[UI.Months], style: styles?.[UI.Months] },
34334
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 })),
34335
34323
  months.map((calendarMonth, displayIndex) => {
@@ -34341,16 +34329,10 @@ function DayPicker(initialProps) {
34341
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 },
34342
34330
  React__default.createElement(components.Chevron, { disabled: previousMonth ? undefined : true, className: classNames[UI.Chevron], orientation: props.dir === "rtl" ? "right" : "left" }))),
34343
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] },
34344
- (() => {
34345
- const monthControl = captionLayout === "dropdown" ||
34346
- 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)));
34347
- const yearControl = captionLayout === "dropdown" ||
34348
- 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)));
34349
- const controls = dateLib.getMonthYearOrder() === "year-first"
34350
- ? [yearControl, monthControl]
34351
- : [monthControl, yearControl];
34352
- return controls;
34353
- })(),
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))),
34354
34336
  React__default.createElement("span", { role: "status", "aria-live": "polite", style: {
34355
34337
  border: 0,
34356
34338
  clip: "rect(0 0 0 0)",
@@ -35835,7 +35817,7 @@ const SelectTableTree = forwardRef((props, ref) => {
35835
35817
  let flag = false;
35836
35818
  if (!key) {
35837
35819
  if (e.code === 'F9') {
35838
- handleAdd();
35820
+ handleAdd?.(e);
35839
35821
  flag = true;
35840
35822
  }
35841
35823
  else if (e.code === 'Space') {
@@ -36021,7 +36003,7 @@ const SelectTableTree = forwardRef((props, ref) => {
36021
36003
  setExpanded(true);
36022
36004
  }
36023
36005
  e.stopPropagation();
36024
- }, 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 ? jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] }) : valueDisplay] }, `col-${indexRow}-${indexCol}`)), checkOverflow(indexRow, indexCol) && (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 ? jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] }) : valueDisplay }))] }, indexCol));
36006
+ }, 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 ? (jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] })) : (valueDisplay)] }, `col-${indexRow}-${indexCol}`)), checkOverflow(indexRow, indexCol) && (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 ? (jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] })) : (valueDisplay) }))] }, indexCol));
36025
36007
  })] }, `row-${indexRow}`), row[fieldChildren ?? 'children'] &&
36026
36008
  row.expanded &&
36027
36009
  row[fieldChildren ?? 'children'].map((child, indexChild) => {
@@ -36031,9 +36013,10 @@ const SelectTableTree = forwardRef((props, ref) => {
36031
36013
  }
36032
36014
  })] }));
36033
36015
  });
36016
+ const maxExpandedLevel = getMaxExpandedLevel(options, fieldChildren, 0);
36034
36017
  const RenderTable = (props) => {
36035
36018
  let countDisplay = 0;
36036
- return (jsxs(Fragment$1, { children: [jsxs("table", { style: { width: '100%' }, children: [!(noHeader && (columns?.length ?? 0) > 0) && (jsx("thead", { className: "r-select-gridheader", children: jsxs("tr", { className: "r-select-row", role: "row", children: [isMulti && (jsx("th", { className: classNames$1(`r-select-headercell checkbox-column`), style: { width: 50, top: `0px` }, children: jsx("div", { style: { justifyContent: 'left' }, className: classNames$1('r-select-headercell-div'), children: jsx(Input$1, { checked: isSelectedAll, type: "checkbox", onClick: (e) => {
36019
+ return (jsxs(Fragment$1, { children: [jsxs("table", { style: { width: '100%' }, children: [!(noHeader && (columns?.length ?? 0) > 0) && (jsx("thead", { className: "r-select-gridheader", children: jsxs("tr", { className: "r-select-row", role: "row", children: [isMulti && (jsx("th", { className: classNames$1(`r-select-headercell checkbox-column`), style: { width: 10 + maxExpandedLevel * 15, top: `0px` }, children: jsx("div", { style: { justifyContent: 'left' }, className: classNames$1('r-select-headercell-div'), children: jsx(Input$1, { checked: isSelectedAll, type: "checkbox", onClick: (e) => {
36037
36020
  if (isMulti) {
36038
36021
  if (isSelectedAll) {
36039
36022
  onChange([]);
@@ -36077,7 +36060,7 @@ const SelectTableTree = forwardRef((props, ref) => {
36077
36060
  e.preventDefault();
36078
36061
  }, 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: [jsxs("div", { className: "select-table-container", children: [isMulti ? (jsx(Fragment$1, { children: jsx("div", { className: classNames$1('select-value is-mutil', { 'd-none': searchTerm }), children: getSelectedRecords(options, value).map((ele, index) => {
36079
36062
  return (jsxs("span", { children: [index === 0 ? '' : ', ', ele[fieldLabel ?? 'label']] }, index));
36080
- }) }) })) : (jsx(Fragment$1, { children: 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) && jsx("div", { className: classNames$1('select-placeholder'), children: placeholder }), jsx("div", { className: "input-container", children: 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) => {
36063
+ }) }) })) : (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) && jsx("div", { className: classNames$1('select-placeholder'), children: placeholder }), jsx("div", { className: "input-container", children: 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) => {
36081
36064
  setSearchTerm(val.target.value);
36082
36065
  }, onKeyDown: (e) => handleOnKeyDown(e) }) })] }), isClearable && value && !isDisabled && (jsx("div", { className: classNames$1('cursor-pointer icon-clear'), onClick: (e) => {
36083
36066
  onChange(isMulti ? [] : undefined);
@@ -36092,7 +36075,7 @@ const SelectTableTree = forwardRef((props, ref) => {
36092
36075
  inputRef?.current.focus();
36093
36076
  e.preventDefault();
36094
36077
  }
36095
- }, children: jsxs("div", { className: "r-select-grid r-select-tree-grid", children: [jsx("div", { className: "r-select-gridtable ", ref: selectMenuTableRef, style: { width: menuWidth, minWidth: selectTableRef?.current?.clientWidth, maxHeight: maxHeight ?? defaultMaxHeight }, children: jsx(RenderTable, {}) }), jsxs("div", { className: classNames$1('r-select-footer', { 'd-none': !(showFooter === true || handleAdd || isMulti) }), children: [jsxs(Button$1$1, { outline: true, color: "primary", onClick: handleAdd, className: classNames$1('r-btn d-flex align-items-center', { 'd-none': !handleAdd }), children: [jsx(SvgPlus, { className: "me-50", fontSize: 16 }), t('AddNew'), " (F9)"] }), isMulti && (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] })] }) })) }) })] }) }) }));
36078
+ }, children: jsxs("div", { className: "r-select-grid r-select-tree-grid", children: [jsx("div", { className: "r-select-gridtable ", ref: selectMenuTableRef, style: { width: menuWidth, minWidth: selectTableRef?.current?.clientWidth, maxHeight: maxHeight ?? defaultMaxHeight }, children: jsx(RenderTable, {}) }), jsxs("div", { className: classNames$1('r-select-footer', { 'd-none': !(showFooter === true || handleAdd || isMulti) }), children: [jsxs(Button$1$1, { outline: true, color: "primary", onClick: handleAdd, className: classNames$1('r-btn d-flex align-items-center', { 'd-none': !handleAdd }), children: [jsx(SvgPlus, { className: "me-50", fontSize: 16 }), t('AddNew'), " (F9)"] }), isMulti && jsx("div", { className: "ms-50 text-primary h-100 d-flex align-items-center", children: t('countSelected', { item: value?.length ?? 0 }) }), footerComponent ? footerComponent() : null] })] }) })) }) })] }) }) }));
36096
36079
  });
36097
36080
 
36098
36081
  const RenderEditCellComponent = (props) => {
@@ -36216,7 +36199,7 @@ const RenderEditCellComponent = (props) => {
36216
36199
  col.callback(val, indexRow, row);
36217
36200
  }
36218
36201
  handleDataChange(row, col, indexRow);
36219
- }, 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) => {
36202
+ }, 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) => {
36220
36203
  if (e.key === 'ArrowDown' || e.key === 'ArrowUp' || e.key === 'NumpadEnter' || e.key === 'Enter' || e.key === 'Tab') {
36221
36204
  handleKeyDown(e, row);
36222
36205
  }
@@ -36799,9 +36782,8 @@ const FooterCol = ({ col, indexCol, dataSource, objWidthFix, formatSetting }) =>
36799
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}`));
36800
36783
  };
36801
36784
 
36802
- const RenderColGroup = ({ contentColumns, groupSetting }) => (jsx("colgroup", { children: contentColumns.map((col, index) => {
36803
- return (col.visible !== false &&
36804
- (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: {
36805
36787
  width: typeof col.width === 'number' ? `${col.width}px` : col.width || undefined,
36806
36788
  minWidth: typeof col.minWidth === 'number' ? `${col.minWidth}px` : col.minWidth || undefined,
36807
36789
  maxWidth: typeof col.maxWidth === 'number' ? `${col.maxWidth}px` : col.maxWidth || undefined
@@ -38693,7 +38675,7 @@ const DateRangePicker = forwardRef((props, ref) => {
38693
38675
  setViewDateTo(selectedTo || today);
38694
38676
  }
38695
38677
  else if (!newRange.from || (selected && selected < newRange.from)) {
38696
- newRange = { from: selected, to };
38678
+ newRange = { from: selected, to: undefined };
38697
38679
  setViewDateFrom(selected || today);
38698
38680
  }
38699
38681
  else if (newRange.from && selected && selected > newRange.from && (!newRange.to || selected < newRange.to)) {
@@ -38704,6 +38686,16 @@ const DateRangePicker = forwardRef((props, ref) => {
38704
38686
  newRange = { from, to: selected };
38705
38687
  setViewDateTo(selected || today);
38706
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
+ }
38707
38699
  onChange(newRange);
38708
38700
  setInputValue(formatDisplay(newRange.from, newRange.to));
38709
38701
  };
@@ -38980,7 +38972,7 @@ const DateRangeFilterComponent = ({ fieldFilter, filterBy, handleSave }) => {
38980
38972
  };
38981
38973
 
38982
38974
  const HeaderTableCol = (props) => {
38983
- 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;
38984
38976
  const { t } = useTranslation();
38985
38977
  const headerRef = useRef(null);
38986
38978
  const order = orderBy.find((item) => item.key === col.field);
@@ -38999,7 +38991,7 @@ const HeaderTableCol = (props) => {
38999
38991
  const checkOverflow = () => {
39000
38992
  return headerRef.current && headerRef.current.scrollHeight > headerRef.current.clientHeight;
39001
38993
  };
39002
- 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: {
39003
38995
  top: `${indexParent * 42}px`,
39004
38996
  left: col.fixedType === 'left' ? objHeaderWidthFixLeft[`${indexParent}-${indexCol ?? 0}`] : undefined,
39005
38997
  right: col.fixedType === 'right' ? objHeaderWidthFixRight[`${indexParent}-${indexCol ?? 0}`] : undefined
@@ -68674,7 +68666,7 @@ const UnExpandAllIcon = ({ className, color = '#7F7F7F', size = 24, onClick, sty
68674
68666
  };
68675
68667
 
68676
68668
  const RenderContentCol = (props) => {
68677
- 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;
68678
68670
  const cellId = `content-${idTable}-row${indexRow}col-${indexCol}`;
68679
68671
  const checkOverflow = () => {
68680
68672
  const element = document.getElementById(cellId);
@@ -68744,7 +68736,7 @@ const RenderContentCol = (props) => {
68744
68736
  }, children: displayText }) }), checkOverflow() && (jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: cellId, placement: "top", children: jsx("div", { style: { color: textColor }, children: displayText }) }))] }));
68745
68737
  }
68746
68738
  };
68747
- 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: {
68748
68740
  left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
68749
68741
  right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined
68750
68742
  }, onClick: (e) => {
@@ -68802,17 +68794,17 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68802
68794
  setExpandsAll(true);
68803
68795
  }, [groupSetting?.groupColumns]);
68804
68796
  const { levels: headerColumns, objHeaderWidthFixLeft, objHeaderWidthFixRight, objWidthFixLeft, objWidthFixRight, lastObjWidthFixLeft, fisrtObjWidthFixRight } = useMemo(() => {
68805
- const rs = calculateTableStructure(columns, settingColumns?.value);
68797
+ const rs = calculateTableStructure(columns, settingColumns?.value, groupSetting?.groupColumns);
68806
68798
  setContentColumns(rs.flat);
68807
68799
  return rs;
68808
- }, [columns, settingColumns]);
68809
- 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]);
68810
68802
  const firstColSpan = useMemo(() => {
68811
68803
  let count = 0;
68812
68804
  let index = 3;
68813
68805
  for (let i = 0; i < contentColumns.length; i++) {
68814
68806
  const col = contentColumns[i];
68815
- if (col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field))) {
68807
+ if (col.visible !== false && col.isGroup !== true) {
68816
68808
  count++;
68817
68809
  }
68818
68810
  if (count === 3) {
@@ -68821,7 +68813,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68821
68813
  }
68822
68814
  }
68823
68815
  return index;
68824
- }, [contentColumns, groupSetting?.groupColumns]);
68816
+ }, [contentColumns]);
68825
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
68826
68818
  const viewData = useMemo(() => {
68827
68819
  if (!dataSource || dataSource.length === 0) {
@@ -69059,7 +69051,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69059
69051
  setExpandsAll(undefined);
69060
69052
  row.expand = !expand;
69061
69053
  } }), t(col.headerDisplay ?? col.headerText), ": ", value, " (", row.children.length, ")"] }) }), contentColumns.map((colSum, indexCol) => {
69062
- if (indexCol <= firstColSpan || colSum.visible === false || (!groupSetting?.visibleGroupColumn && groupColumns?.includes(colSum.field))) {
69054
+ if (indexCol <= firstColSpan || colSum.visible === false || colSum.isGroup === true) {
69063
69055
  return;
69064
69056
  }
69065
69057
  let sumValue = row[colSum.field];
@@ -69087,7 +69079,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69087
69079
  }, onContextMenu: (e) => {
69088
69080
  e.preventDefault();
69089
69081
  handleContextMenu(e, row);
69090
- }, 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}`));
69091
69083
  }
69092
69084
  }) }));
69093
69085
  };
@@ -69114,7 +69106,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69114
69106
  virtualDivRef.current.style.height = '0px';
69115
69107
  }
69116
69108
  }, [context]);
69117
- 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) => {
69118
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) => {
69119
69111
  setFilterBy([...val]);
69120
69112
  if (querySetting?.changeFilter) {
@@ -69125,9 +69117,9 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69125
69117
  if (querySetting?.changeOrder) {
69126
69118
  querySetting.changeOrder(val);
69127
69119
  }
69128
- }, 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}`));
69129
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) => {
69130
- if (col.visible === false || (!groupSetting?.visibleGroupColumn && groupSetting?.groupColumns.includes(col.field))) {
69122
+ if (col.visible === false || col.isGroup === true) {
69131
69123
  return;
69132
69124
  }
69133
69125
  const item = columnsAggregate?.find((x) => x.field === col.field);
@@ -69159,5 +69151,5 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69159
69151
  } })] }));
69160
69152
  };
69161
69153
 
69162
- export { CheckRowMatch, ExportExcelComponent, FindNodeByPath, InputStyleComponent, ModalImportComponent, SelectTable, SelectTableTree, TableView, TabsMenuComponent, Wizard, calculateTableStructure, checkDecimalSeparator, checkThousandSeparator, TableEdit as default, formartNumberic, formatDateTime, generateUUID, isNullOrUndefined$1 as isNullOrUndefined, messageBoxConfirm, messageBoxConfirmAsync, messageBoxConfirmDelete, messageBoxError, messageHtmlBoxConfirm, messageHtmlBoxConfirmAsync, messageHtmlBoxError, notificationError, notificationSuccess, roundNumber, useOnClickOutside };
69154
+ export { CheckRowMatch, ExportExcelComponent, FindNodeByPath, InputStyleComponent, ModalImportComponent, SelectTable, SelectTableTree, TableView, TabsMenuComponent, Wizard, calculateTableStructure, checkDecimalSeparator, checkThousandSeparator, TableEdit as default, formartNumberic, formatDateTime, generateUUID, getMaxExpandedLevel, isNullOrUndefined$1 as isNullOrUndefined, messageBoxConfirm, messageBoxConfirmAsync, messageBoxConfirmDelete, messageBoxError, messageHtmlBoxConfirm, messageHtmlBoxConfirmAsync, messageHtmlBoxError, notificationError, notificationSuccess, roundNumber, useOnClickOutside };
69163
69155
  //# sourceMappingURL=index.mjs.map