react-table-edit 1.5.28 → 1.5.30

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
  }
@@ -19912,7 +19948,7 @@ const calculateTableStructure = (columns, settingColumns) => {
19912
19948
  cell.numericSettings = { fraction: setting.fraction };
19913
19949
  }
19914
19950
  }
19915
- cell.headerDisplay = setting.headerText || cell.headerText;
19951
+ cell.headerDisplay = setting.headerText || (cell.headerDisplay ?? cell.headerText);
19916
19952
  }
19917
19953
  else {
19918
19954
  if (cell.columns?.length) {
@@ -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;
@@ -20501,19 +20538,6 @@ const ReactInput = (props) => {
20501
20538
  }), value: value, onChange: (val) => setValue(val.target.value) }), value ? jsx(SvgX, { className: 'input__clear-icon', onClick: handelClear, strokeWidth: 3, fontSize: 16 }) : ''] }));
20502
20539
  };
20503
20540
 
20504
- const RenderToolbarTop = ({ toolbarTopOption }) => {
20505
- return (jsx("div", { id: "table_custom_top_toolbar", className: "r-toolbar r-toolbar-top", "aria-orientation": "horizontal", children: jsxs("div", { className: "r-toolbar-items", children: [jsx("div", { className: "r-toolbar-left", children: toolbarTopOption?.map((item, index) => {
20506
- return item.align === 'left' ? jsx(ToolBarElement, { item: item, index: index }) : '';
20507
- }) }), jsx("div", { className: "r-toolbar-center", children: toolbarTopOption?.map((item, index) => {
20508
- return item.align === 'center' ? jsx(ToolBarElement, { item: item, index: index }) : '';
20509
- }) }), jsx("div", { className: "r-toolbar-right", children: toolbarTopOption?.map((item, index) => {
20510
- return item.align === 'right' ? jsx(ToolBarElement, { item: item, index: index }) : '';
20511
- }) })] }) }));
20512
- };
20513
- const ToolBarElement = ({ item, index }) => {
20514
- return (jsx("div", { className: "r-toolbar-item", "aria-disabled": "false", children: item.template?.() }, `toolbar-top-${index}`));
20515
- };
20516
-
20517
20541
  const handleAdd = (dataSource, containerRef, indexFirstEdit,
20518
20542
  /*eslint-disable*/
20519
20543
  changeDataSource, handleFocusCell,
@@ -31588,63 +31612,7 @@ class DateLib {
31588
31612
  formatNumber(value) {
31589
31613
  return this.replaceDigits(value.toString());
31590
31614
  }
31591
- /**
31592
- * Returns the preferred ordering for month and year labels for the current
31593
- * locale.
31594
- */
31595
- getMonthYearOrder() {
31596
- const code = this.options.locale?.code;
31597
- if (!code) {
31598
- return "month-first";
31599
- }
31600
- return DateLib.yearFirstLocales.has(code) ? "year-first" : "month-first";
31601
- }
31602
- /**
31603
- * Formats the month/year pair respecting locale conventions.
31604
- *
31605
- * @since 9.11.0
31606
- */
31607
- formatMonthYear(date) {
31608
- const { locale, timeZone, numerals } = this.options;
31609
- const localeCode = locale?.code;
31610
- if (localeCode && DateLib.yearFirstLocales.has(localeCode)) {
31611
- try {
31612
- const intl = new Intl.DateTimeFormat(localeCode, {
31613
- month: "long",
31614
- year: "numeric",
31615
- timeZone,
31616
- numberingSystem: numerals,
31617
- });
31618
- const formatted = intl.format(date);
31619
- return formatted;
31620
- }
31621
- catch {
31622
- // Fallback to date-fns formatting below.
31623
- }
31624
- }
31625
- const pattern = this.getMonthYearOrder() === "year-first" ? "y LLLL" : "LLLL y";
31626
- return this.format(date, pattern);
31627
- }
31628
- }
31629
- DateLib.yearFirstLocales = new Set([
31630
- "eu",
31631
- "hu",
31632
- "ja",
31633
- "ja-Hira",
31634
- "ja-JP",
31635
- "ko",
31636
- "ko-KR",
31637
- "lt",
31638
- "lt-LT",
31639
- "lv",
31640
- "lv-LV",
31641
- "mn",
31642
- "mn-MN",
31643
- "zh",
31644
- "zh-CN",
31645
- "zh-HK",
31646
- "zh-TW",
31647
- ]);
31615
+ }
31648
31616
  /**
31649
31617
  * The default date library with English locale.
31650
31618
  *
@@ -32540,7 +32508,7 @@ function getDefaultClassNames() {
32540
32508
  /**
32541
32509
  * Formats the caption of the month.
32542
32510
  *
32543
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32511
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32544
32512
  * @param month The date representing the month.
32545
32513
  * @param options Configuration options for the date library.
32546
32514
  * @param dateLib The date library to use for formatting. If not provided, a new
@@ -32550,8 +32518,7 @@ function getDefaultClassNames() {
32550
32518
  * @see https://daypicker.dev/docs/translation#custom-formatters
32551
32519
  */
32552
32520
  function formatCaption(month, options, dateLib) {
32553
- const lib = dateLib ?? new DateLib(options);
32554
- return lib.formatMonthYear(month);
32521
+ return (dateLib ?? new DateLib(options)).format(month, "LLLL y");
32555
32522
  }
32556
32523
  /**
32557
32524
  * @private
@@ -32845,7 +32812,7 @@ const labelDay = labelDayButton;
32845
32812
  * Generates the ARIA label for the month grid, which is announced when entering
32846
32813
  * the grid.
32847
32814
  *
32848
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32815
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32849
32816
  * @param date - The date representing the month.
32850
32817
  * @param options - Optional configuration for the date formatting library.
32851
32818
  * @param dateLib - An optional instance of the date formatting library.
@@ -32854,8 +32821,7 @@ const labelDay = labelDayButton;
32854
32821
  * @see https://daypicker.dev/docs/translation#aria-labels
32855
32822
  */
32856
32823
  function labelGrid(date, options, dateLib) {
32857
- const lib = dateLib ?? new DateLib(options);
32858
- return lib.formatMonthYear(date);
32824
+ return (dateLib ?? new DateLib(options)).format(date, "LLLL y");
32859
32825
  }
32860
32826
  /**
32861
32827
  * @ignore
@@ -34338,7 +34304,7 @@ function DayPicker(initialProps) {
34338
34304
  formatters,
34339
34305
  };
34340
34306
  return (React__default.createElement(dayPickerContext.Provider, { value: contextValue },
34341
- React__default.createElement(components.Root, { rootRef: props.animate ? rootElRef : undefined, className: className, style: style, dir: props.dir, id: props.id, lang: props.lang, nonce: props.nonce, title: props.title, role: props.role, "aria-label": props["aria-label"], "aria-labelledby": props["aria-labelledby"], ...dataAttributes },
34307
+ React__default.createElement(components.Root, { rootRef: props.animate ? rootElRef : undefined, className: className, style: style, dir: props.dir, id: props.id, lang: props.lang, nonce: props.nonce, title: props.title, role: props.role, "aria-label": props["aria-label"], ...dataAttributes },
34342
34308
  React__default.createElement(components.Months, { className: classNames[UI.Months], style: styles?.[UI.Months] },
34343
34309
  !props.hideNavigation && !navLayout && (React__default.createElement(components.Nav, { "data-animated-nav": props.animate ? "true" : undefined, className: classNames[UI.Nav], style: styles?.[UI.Nav], "aria-label": labelNav(), onPreviousClick: handlePreviousClick, onNextClick: handleNextClick, previousMonth: previousMonth, nextMonth: nextMonth })),
34344
34310
  months.map((calendarMonth, displayIndex) => {
@@ -34350,16 +34316,10 @@ function DayPicker(initialProps) {
34350
34316
  displayIndex === 0 && (React__default.createElement(components.PreviousMonthButton, { type: "button", className: classNames[UI.PreviousMonthButton], tabIndex: previousMonth ? undefined : -1, "aria-disabled": previousMonth ? undefined : true, "aria-label": labelPrevious(previousMonth), onClick: handlePreviousClick, "data-animated-button": props.animate ? "true" : undefined },
34351
34317
  React__default.createElement(components.Chevron, { disabled: previousMonth ? undefined : true, className: classNames[UI.Chevron], orientation: props.dir === "rtl" ? "right" : "left" }))),
34352
34318
  React__default.createElement(components.MonthCaption, { "data-animated-caption": props.animate ? "true" : undefined, className: classNames[UI.MonthCaption], style: styles?.[UI.MonthCaption], calendarMonth: calendarMonth, displayIndex: displayIndex }, captionLayout?.startsWith("dropdown") ? (React__default.createElement(components.DropdownNav, { className: classNames[UI.Dropdowns], style: styles?.[UI.Dropdowns] },
34353
- (() => {
34354
- const monthControl = captionLayout === "dropdown" ||
34355
- captionLayout === "dropdown-months" ? (React__default.createElement(components.MonthsDropdown, { key: "month", className: classNames[UI.MonthsDropdown], "aria-label": labelMonthDropdown(), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleMonthChange(calendarMonth.date), options: getMonthOptions(calendarMonth.date, navStart, navEnd, formatters, dateLib), style: styles?.[UI.Dropdown], value: dateLib.getMonth(calendarMonth.date) })) : (React__default.createElement("span", { key: "month" }, formatMonthDropdown(calendarMonth.date, dateLib)));
34356
- const yearControl = captionLayout === "dropdown" ||
34357
- captionLayout === "dropdown-years" ? (React__default.createElement(components.YearsDropdown, { key: "year", className: classNames[UI.YearsDropdown], "aria-label": labelYearDropdown(dateLib.options), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleYearChange(calendarMonth.date), options: getYearOptions(navStart, navEnd, formatters, dateLib, Boolean(props.reverseYears)), style: styles?.[UI.Dropdown], value: dateLib.getYear(calendarMonth.date) })) : (React__default.createElement("span", { key: "year" }, formatYearDropdown(calendarMonth.date, dateLib)));
34358
- const controls = dateLib.getMonthYearOrder() === "year-first"
34359
- ? [yearControl, monthControl]
34360
- : [monthControl, yearControl];
34361
- return controls;
34362
- })(),
34319
+ captionLayout === "dropdown" ||
34320
+ 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))),
34321
+ captionLayout === "dropdown" ||
34322
+ captionLayout === "dropdown-years" ? (React__default.createElement(components.YearsDropdown, { className: classNames[UI.YearsDropdown], "aria-label": labelYearDropdown(dateLib.options), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleYearChange(calendarMonth.date), options: getYearOptions(navStart, navEnd, formatters, dateLib, Boolean(props.reverseYears)), style: styles?.[UI.Dropdown], value: dateLib.getYear(calendarMonth.date) })) : (React__default.createElement("span", null, formatYearDropdown(calendarMonth.date, dateLib))),
34363
34323
  React__default.createElement("span", { role: "status", "aria-live": "polite", style: {
34364
34324
  border: 0,
34365
34325
  clip: "rect(0 0 0 0)",
@@ -36809,9 +36769,8 @@ const FooterCol = ({ col, indexCol, dataSource, objWidthFix, formatSetting }) =>
36809
36769
  }, children: jsx("div", { className: "r-footer-div", children: col.haveSum === true && col.type === "numeric" && (jsx(Fragment$1, { children: Number(sumValue) >= 0 ? (jsx(Fragment$1, { children: formartNumberic(sumValue, formatSetting?.decimalSeparator ?? ",", formatSetting?.thousandSeparator ?? ".", col.numericSettings?.fraction, true, false) })) : (jsx("div", { style: { color: formatSetting?.colorNegative ?? "red" }, children: `${formatSetting?.prefixNegative ?? "-"}${formartNumberic(sumValue, formatSetting?.decimalSeparator ?? ",", formatSetting?.thousandSeparator ?? ".", col.numericSettings?.fraction, true, false)}${formatSetting?.suffixNegative ?? ""}` })) })) }) })) }, `summarycell-${indexCol}`));
36810
36770
  };
36811
36771
 
36812
- const RenderColGroup = ({ contentColumns, groupSetting }) => (jsx("colgroup", { children: contentColumns.map((col, index) => {
36813
- return (col.visible !== false &&
36814
- (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (jsx("col", { style: {
36772
+ const RenderColGroup = ({ contentColumns }) => (jsx("colgroup", { children: contentColumns.map((col, index) => {
36773
+ return (col.visible !== false && col.isGroup !== true && (jsx("col", { style: {
36815
36774
  width: typeof col.width === 'number' ? `${col.width}px` : col.width || undefined,
36816
36775
  minWidth: typeof col.minWidth === 'number' ? `${col.minWidth}px` : col.minWidth || undefined,
36817
36776
  maxWidth: typeof col.maxWidth === 'number' ? `${col.maxWidth}px` : col.maxWidth || undefined
@@ -38703,7 +38662,7 @@ const DateRangePicker = forwardRef((props, ref) => {
38703
38662
  setViewDateTo(selectedTo || today);
38704
38663
  }
38705
38664
  else if (!newRange.from || (selected && selected < newRange.from)) {
38706
- newRange = { from: selected, to };
38665
+ newRange = { from: selected, to: undefined };
38707
38666
  setViewDateFrom(selected || today);
38708
38667
  }
38709
38668
  else if (newRange.from && selected && selected > newRange.from && (!newRange.to || selected < newRange.to)) {
@@ -38714,6 +38673,16 @@ const DateRangePicker = forwardRef((props, ref) => {
38714
38673
  newRange = { from, to: selected };
38715
38674
  setViewDateTo(selected || today);
38716
38675
  }
38676
+ else if (newRange.from && !selected) {
38677
+ if (newRange.to) {
38678
+ newRange = { from: newRange.to, to };
38679
+ setViewDateFrom(newRange.to || today);
38680
+ }
38681
+ else {
38682
+ newRange = { from, to: newRange.from };
38683
+ setViewDateTo(newRange.from || today);
38684
+ }
38685
+ }
38717
38686
  onChange(newRange);
38718
38687
  setInputValue(formatDisplay(newRange.from, newRange.to));
38719
38688
  };
@@ -38771,7 +38740,10 @@ const DateRangePicker = forwardRef((props, ref) => {
38771
38740
  const newDate = new Date(viewDateFrom);
38772
38741
  newDate.setFullYear(newYear);
38773
38742
  setViewDateFrom(newDate);
38774
- }, value: { value: viewDateFrom.getFullYear(), label: viewDateFrom.getFullYear() } }) })] }), jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38743
+ }, value: {
38744
+ value: viewDateFrom.getFullYear(),
38745
+ label: viewDateFrom.getFullYear()
38746
+ } }) })] }), jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38775
38747
  const newDate = new Date(viewDateFrom);
38776
38748
  newDate.setMonth(viewDateFrom.getMonth() + 1);
38777
38749
  setViewDateFrom(newDate);
@@ -38783,6 +38755,8 @@ const DateRangePicker = forwardRef((props, ref) => {
38783
38755
  inRange: 'rdp-in-range',
38784
38756
  rangeStart: 'rdp-selected',
38785
38757
  rangeEnd: 'rdp-selected'
38758
+ }, formatters: {
38759
+ formatWeekdayName: (day) => [t('Su'), t('Mo'), t('Tu'), t('We'), t('Th'), t('Fr'), t('Sa')][day.getDay() === 0 ? 6 : day.getDay() - 1]
38786
38760
  } })] }), jsxs("div", { children: [jsxs("div", { className: "select-month-year", children: [jsx(SvgChevronLeft, { cursor: 'pointer', fontSize: 22, onClick: () => {
38787
38761
  const newDate = new Date(viewDateTo);
38788
38762
  newDate.setMonth(viewDateTo.getMonth() - 1);
@@ -38797,7 +38771,10 @@ const DateRangePicker = forwardRef((props, ref) => {
38797
38771
  const newDate = new Date(viewDateTo);
38798
38772
  newDate.setFullYear(newYear);
38799
38773
  setViewDateTo(newDate);
38800
- }, value: { value: viewDateTo.getFullYear(), label: viewDateTo.getFullYear() } }) })] }), jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38774
+ }, value: {
38775
+ value: viewDateTo.getFullYear(),
38776
+ label: viewDateTo.getFullYear()
38777
+ } }) })] }), jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38801
38778
  const newDate = new Date(viewDateTo);
38802
38779
  newDate.setMonth(viewDateTo.getMonth() + 1);
38803
38780
  setViewDateTo(newDate);
@@ -38809,6 +38786,8 @@ const DateRangePicker = forwardRef((props, ref) => {
38809
38786
  inRange: 'rdp-in-range',
38810
38787
  rangeStart: 'rdp-selected',
38811
38788
  rangeEnd: 'rdp-selected'
38789
+ }, formatters: {
38790
+ formatWeekdayName: (day) => [t('Su'), t('Mo'), t('Tu'), t('We'), t('Th'), t('Fr'), t('Sa')][day.getDay() === 0 ? 6 : day.getDay() - 1]
38812
38791
  } })] })] }), jsxs("div", { className: "d-flex border-top ms-50", style: { gap: 20, paddingTop: 10 }, children: [jsx("div", { className: "btn-today", onClick: () => {
38813
38792
  handleSelect(today, today);
38814
38793
  setOpen(false);
@@ -38990,7 +38969,7 @@ const DateRangeFilterComponent = ({ fieldFilter, filterBy, handleSave }) => {
38990
38969
  };
38991
38970
 
38992
38971
  const HeaderTableCol = (props) => {
38993
- const { selectEnable, dataSource, setSelectedRows, col, indexCol, indexParent, objHeaderWidthFixLeft, objHeaderWidthFixRight, totalCount, selectedRows, columns, orderBy, changeFilter, filterBy, changeOrder, allowFiltering, allowSorting, container, fisrtObjWidthFixRight, lastObjWidthFixLeft, setContentColumns, formatSetting, optionsFilter, idTable, isMulti, groupSetting } = props;
38972
+ const { selectEnable, dataSource, setSelectedRows, col, indexCol, indexParent, objHeaderWidthFixLeft, objHeaderWidthFixRight, totalCount, selectedRows, columns, orderBy, changeFilter, filterBy, changeOrder, allowFiltering, allowSorting, container, fisrtObjWidthFixRight, lastObjWidthFixLeft, setContentColumns, formatSetting, optionsFilter, idTable, isMulti } = props;
38994
38973
  const { t } = useTranslation();
38995
38974
  const headerRef = useRef(null);
38996
38975
  const order = orderBy.find((item) => item.key === col.field);
@@ -39009,11 +38988,11 @@ const HeaderTableCol = (props) => {
39009
38988
  const checkOverflow = () => {
39010
38989
  return headerRef.current && headerRef.current.scrollHeight > headerRef.current.clientHeight;
39011
38990
  };
39012
- return (jsx(Fragment, { children: col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (jsx(Resizable, { className: "r-resize", width: typeof col.width === 'number' ? col.width : Number((col.width ?? '').replaceAll(new RegExp(`[^0-9]`, 'g'), '')), height: 0, onResize: handleResize, draggableOpts: { enableUserSelectHack: true }, children: jsx("th", { rowSpan: col.rowspan !== 1 ? col.rowspan : 1, colSpan: col.columns?.filter((x) => x.visible !== false)?.length ?? 1, className: classNames$1(`r-headercell fix-${col.fixedType}`, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'cell-fixed': col.fixedType }), style: {
38991
+ return (jsx(Fragment, { children: col.visible !== false && col.isGroup !== true && (jsx(Resizable, { className: "r-resize", width: typeof col.width === 'number' ? col.width : Number((col.width ?? '').replaceAll(new RegExp(`[^0-9]`, 'g'), '')), height: 0, onResize: handleResize, draggableOpts: { enableUserSelectHack: true }, children: jsx("th", { rowSpan: col.rowspan !== 1 ? col.rowspan : 1, colSpan: col.columns?.filter((x) => x.visible !== false)?.length ?? 1, className: classNames$1(`r-headercell fix-${col.fixedType}`, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'cell-fixed': col.fixedType }), style: {
39013
38992
  top: `${indexParent * 42}px`,
39014
38993
  left: col.fixedType === 'left' ? objHeaderWidthFixLeft[`${indexParent}-${indexCol ?? 0}`] : undefined,
39015
38994
  right: col.fixedType === 'right' ? objHeaderWidthFixRight[`${indexParent}-${indexCol ?? 0}`] : undefined
39016
- }, children: jsxs("div", { style: { justifyContent: 'space-between' }, onClick: () => {
38995
+ }, children: jsxs("div", { style: { justifyContent: col.textAlign === 'center' ? 'center' : 'space-between' }, onClick: () => {
39017
38996
  if (!allowSorting || col.columns?.length) {
39018
38997
  return;
39019
38998
  }
@@ -39820,6 +39799,19 @@ const ToolbarBottom = ({ handleAdd, handleDuplicate, handleInsertBefore, handleI
39820
39799
  }), jsx("div", { className: classNames$1('r-toolbar-item me-25'), "aria-disabled": "false", children: jsx(SvgSettings, { className: "text-primary cursor-pointer", onClick: () => setOpenPopupSetupColumn(true) }) }), jsx("div", { className: classNames$1('r-toolbar-item me-25', { 'd-none': editDisable || addDisable }), "aria-disabled": "false", children: jsxs(UncontrolledDropdown, { className: "dropdown-user nav-item", children: [jsx(DropdownToggle$1, { tag: "div", color: "primary", onClick: (e) => e.preventDefault(), children: jsx(SvgInfo, { className: "cursor-pointer text-primary" }) }), jsx(DropdownMenu$1, { className: "formula-dropdown icon-dropdown", children: jsxs("ul", { className: "mb-0 pe-50", children: [jsx("li", { style: { fontSize: 13 }, children: "Nh\u1EA5n v\u00E0o c\u1ED9t STT \u0111\u1EC3 ch\u1ECDn h\u00E0ng v\u00E0 nh\u1EA5n Ctrl + D \u0111\u1EC3 nh\u00E2n b\u1EA3n" }), jsx("li", { style: { fontSize: 13 }, children: "Ch\u1ECDn \u00F4 v\u00E0 Ctrl + V \u0111\u1EC3 d\u00E1n th\u00F4ng tin t\u1EEB excel" }), jsx("li", { style: { fontSize: 13 }, children: "Nh\u1EA5n v\u00E0o c\u1ED9t STT \u0111\u1EC3 ch\u1ECDn h\u00E0ng v\u00E0 nh\u1EA5n Ctrl + C \u0111\u1EC3 sao ch\u00E9p h\u00E0ng" }), jsx("li", { style: { fontSize: 13 }, children: "Nh\u1EA5n v\u00E0o c\u1ED9t STT \u0111\u1EC3 ch\u1ECDn h\u00E0ng v\u00E0 nh\u1EA5n Ctrl + V \u0111\u1EC3 d\u00E1n h\u00E0ng" }), jsx("li", { style: { fontSize: 13 }, children: "Nh\u1EA5n Ctrl ho\u1EB7c Alt + Shift + \u2193 \u0111\u1EC3 sao ch\u00E9p d\u1EEF li\u1EC7u \u00F4 cho c\u00E1c d\u00F2ng d\u01B0\u1EDBi" }), jsx("li", { style: { fontSize: 13 }, children: "Nh\u1EA5n Ctrl ho\u1EB7c Alt + Shift + \u2191 \u0111\u1EC3 sao ch\u00E9p d\u1EEF li\u1EC7u \u00F4 cho c\u00E1c d\u00F2ng tr\u00EAn" })] }) })] }) })] })] }) }));
39821
39800
  };
39822
39801
 
39802
+ const RenderToolbarTop = ({ toolbarTopOption }) => {
39803
+ return (jsx("div", { id: "table_custom_top_toolbar", className: "r-toolbar r-toolbar-top", "aria-orientation": "horizontal", children: jsxs("div", { className: "r-toolbar-items", children: [jsx("div", { className: "r-toolbar-left", children: toolbarTopOption?.map((item, index) => {
39804
+ return item.align === 'left' ? jsx(ToolBarElement, { item: item, index: index }) : '';
39805
+ }) }), jsx("div", { className: "r-toolbar-center", children: toolbarTopOption?.map((item, index) => {
39806
+ return item.align === 'center' ? jsx(ToolBarElement, { item: item, index: index }) : '';
39807
+ }) }), jsx("div", { className: "r-toolbar-right", children: toolbarTopOption?.map((item, index) => {
39808
+ return item.align === 'right' ? jsx(ToolBarElement, { item: item, index: index }) : '';
39809
+ }) })] }) }));
39810
+ };
39811
+ const ToolBarElement = ({ item, index }) => {
39812
+ return (jsx("div", { className: "r-toolbar-item", "aria-disabled": "false", children: item.template?.() }, `toolbar-top-${index}`));
39813
+ };
39814
+
39823
39815
  const TableEdit = forwardRef((props, ref) => {
39824
39816
  const { t } = useTranslation();
39825
39817
  const { idTable, dataSource, columns, setDataSource, height = 400, rowHeight = 31.3, defaultValue, toolbarSetting, searchSetting, selectedItem, selectEnable, editDisable, addDisable, buttonSetting, formatSetting, haveSum, isMulti, disableAutoKey, commandClick, dataSourceChange, rowChange, setSelectedItem, handleSelect, onDuplicate, saveSettingColumn, allowFiltering = true, allowSorting, settingColumns, optionsFilter, pagingSetting, resetDefaultColumns } = props;
@@ -68684,15 +68676,17 @@ const UnExpandAllIcon = ({ className, color = '#7F7F7F', size = 24, onClick, sty
68684
68676
  };
68685
68677
 
68686
68678
  const RenderContentCol = (props) => {
68687
- const { col, indexCol, indexRow, isSelected, row, zeroVisiable, groupSetting, formatSetting, idTable, fisrtObjWidthFixRight, lastObjWidthFixLeft, objWidthFixLeft, objWidthFixRight, selectedRows, selectEnable, setSelectedRows, fieldKey, isMulti } = props;
68679
+ const { col, indexCol, indexRow, isSelected, row, zeroVisiable, formatSetting, idTable, fisrtObjWidthFixRight, lastObjWidthFixLeft, objWidthFixLeft, objWidthFixRight, selectedRows, selectEnable, setSelectedRows, fieldKey, isMulti } = props;
68688
68680
  const cellId = `content-${idTable}-row${indexRow}col-${indexCol}`;
68689
68681
  const checkOverflow = () => {
68690
68682
  const element = document.getElementById(cellId);
68691
68683
  return element && element.scrollWidth > element.clientWidth;
68692
68684
  };
68693
68685
  const RenderElement = () => {
68694
- if (col.type === 'checkbox' && !col.field) {
68695
- return (jsx("div", { className: "r-rowcell-div cursor-pointer", style: { alignItems: 'center' }, onClick: (e) => {
68686
+ if (col.type === 'checkbox' || col.field === 'checkbox') {
68687
+ return (jsx("div", { className: "r-rowcell-div cursor-pointer", style: { display: 'flex', justifyContent: col.textAlign === 'center' ? 'center' : col.textAlign === 'right' ? 'flex-end' : 'flex-start', alignItems: 'center' }, onClick: (e) => {
68688
+ console.log(isMulti);
68689
+ console.log(selectEnable);
68696
68690
  if (selectEnable) {
68697
68691
  const index = selectedRows?.findIndex((x) => x[fieldKey] === row[fieldKey]);
68698
68692
  if (index > -1) {
@@ -68740,7 +68734,8 @@ const RenderContentCol = (props) => {
68740
68734
  const suffix = isNegative ? formatSetting?.suffixNegative ?? '' : '';
68741
68735
  const displayText = isNegative ? `${prefix}${value}${suffix}` : value ?? '';
68742
68736
  return (jsxs("div", { className: classNames$1('r-rowcell-div'), style: {
68743
- fontWeight: row.sortOrder < 0 || row.sortOrder > 100000 ? 600 : 400
68737
+ fontWeight: row.sortOrder < 0 || row.sortOrder > 100000 || row.haveBoldType ? 600 : 400,
68738
+ fontStyle: row.haveItalicType ? 'italic' : 'normal'
68744
68739
  }, children: [jsx("div", { className: "r-cell-text", style: {
68745
68740
  display: 'flex',
68746
68741
  justifyContent: col.textAlign === 'center' ? 'center' : col.textAlign === 'right' ? 'flex-end' : 'flex-start',
@@ -68754,7 +68749,7 @@ const RenderContentCol = (props) => {
68754
68749
  }, children: displayText }) }), checkOverflow() && (jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: cellId, placement: "top", children: jsx("div", { style: { color: textColor }, children: displayText }) }))] }));
68755
68750
  }
68756
68751
  };
68757
- return (jsx(Fragment$1, { children: col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (jsx("td", { className: classNames$1(`r-rowcell fix-${col.fixedType}`, { 'cell-fixed': col.fixedType }, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'r-active': isSelected }), style: {
68752
+ return (jsx(Fragment$1, { children: col.visible !== false && col.isGroup !== true && (jsx("td", { className: classNames$1(`r-rowcell fix-${col.fixedType}`, { 'cell-fixed': col.fixedType }, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'r-active': isSelected }), style: {
68758
68753
  left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
68759
68754
  right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined
68760
68755
  }, onClick: (e) => {
@@ -68812,17 +68807,16 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68812
68807
  setExpandsAll(true);
68813
68808
  }, [groupSetting?.groupColumns]);
68814
68809
  const { levels: headerColumns, objHeaderWidthFixLeft, objHeaderWidthFixRight, objWidthFixLeft, objWidthFixRight, lastObjWidthFixLeft, fisrtObjWidthFixRight } = useMemo(() => {
68815
- const rs = calculateTableStructure(columns, settingColumns?.value);
68810
+ const rs = calculateTableStructure(columns, settingColumns?.value, groupSetting?.groupColumns);
68816
68811
  setContentColumns(rs.flat);
68817
68812
  return rs;
68818
- }, [columns, settingColumns]);
68819
- const optionGroupColumns = useMemo(() => contentColumns.filter((x) => !groupSetting?.groupColumns.includes(x.field)).map((x) => ({ ...x, headerDisplay: t(x.columnGroupText ?? x.headerDisplay ?? x.headerText) })), [groupSetting?.groupColumns, contentColumns]);
68813
+ }, [columns, settingColumns, groupSetting?.groupColumns]);
68820
68814
  const firstColSpan = useMemo(() => {
68821
68815
  let count = 0;
68822
68816
  let index = 3;
68823
68817
  for (let i = 0; i < contentColumns.length; i++) {
68824
68818
  const col = contentColumns[i];
68825
- if (col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field))) {
68819
+ if (col.visible !== false && col.isGroup !== true) {
68826
68820
  count++;
68827
68821
  }
68828
68822
  if (count === 3) {
@@ -68831,7 +68825,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68831
68825
  }
68832
68826
  }
68833
68827
  return index;
68834
- }, [contentColumns, groupSetting?.groupColumns]);
68828
+ }, [contentColumns]);
68835
68829
  // Tính toán dữ liệu hiển thị dựa trên các điều kiện lọc, tìm kiếm và sắp xếp
68836
68830
  const viewData = useMemo(() => {
68837
68831
  if (!dataSource || dataSource.length === 0) {
@@ -68916,7 +68910,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68916
68910
  return (jsx("div", { className: "me-50 r-search", children: jsx(ReactInput, { style: { width: '230px' }, value: searchSetting?.searchTerm !== undefined ? searchSetting?.searchTerm : searchTerm, setSearchTerm: searchSetting?.setSearchTerm ? searchSetting?.setSearchTerm : setSearchTerm, placeholder: t('Search'), onKeyPress: handleKeyPress }) }));
68917
68911
  };
68918
68912
  const groupbtnTemplate = () => {
68919
- return (jsxs(UncontrolledDropdown, { children: [jsx(DropdownToggle$1, { tag: "div", id: "group-dropdown-toggle", style: { position: 'relative' }, onClick: (e) => e.preventDefault(), children: jsx(GroupIcon, { color: "#7F7F7F", size: 24 }) }), jsxs(DropdownMenu$1, { className: "formula-dropdown icon-dropdown p-1", children: [jsx("div", { className: "mb-1", style: { fontSize: 16, fontWeight: 500 }, children: "Nh\u00F3m d\u1EEF li\u1EC7u theo c\u1ED9t" }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-1`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 1" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options: optionGroupColumns, fieldLabel: 'headerDisplay', fieldValue: 'field', value: groupColumns[0] ? { headerDisplay: t(contentColumns.find((x) => x.field === groupColumns[0])?.headerDisplay ?? contentColumns.find((x) => x.field === groupColumns[0])?.headerText) } : undefined, onChange: (val) => {
68913
+ return (jsxs(UncontrolledDropdown, { children: [jsx(DropdownToggle$1, { tag: "div", id: "group-dropdown-toggle", style: { position: 'relative' }, onClick: (e) => e.preventDefault(), children: jsx(GroupIcon, { color: "#7F7F7F", size: 24 }) }), jsxs(DropdownMenu$1, { className: "formula-dropdown icon-dropdown p-1", children: [jsx("div", { className: "mb-1", style: { fontSize: 16, fontWeight: 500 }, children: "Nh\u00F3m d\u1EEF li\u1EC7u theo c\u1ED9t" }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-1`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 1" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options: contentColumns, fieldLabel: 'headerText', fieldValue: 'field', value: groupColumns[0] ? { headerText: t(contentColumns.find((x) => x.field === groupColumns[0])?.headerText ?? contentColumns.find((x) => x.field === groupColumns[0])?.headerText) } : undefined, onChange: (val) => {
68920
68914
  if (val) {
68921
68915
  groupColumns[0] = val.field;
68922
68916
  }
@@ -68924,7 +68918,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68924
68918
  groupColumns.pop();
68925
68919
  }
68926
68920
  setGroupColumns([...groupColumns]);
68927
- }, isClearable: groupColumns?.length === 1 }) })] }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-2`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 2" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options: optionGroupColumns, fieldLabel: 'headerDisplay', fieldValue: 'field', value: groupColumns[1] ? { headerDisplay: t(contentColumns.find((x) => x.field === groupColumns[1])?.headerDisplay ?? contentColumns.find((x) => x.field === groupColumns[1])?.headerText) } : undefined, onChange: (val) => {
68921
+ }, isClearable: groupColumns?.length === 1 }) })] }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-2`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 2" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options: contentColumns, fieldLabel: 'headerText', fieldValue: 'field', value: groupColumns[1] ? { headerText: t(contentColumns.find((x) => x.field === groupColumns[1])?.headerText ?? contentColumns.find((x) => x.field === groupColumns[1])?.headerText) } : undefined, onChange: (val) => {
68928
68922
  if (val) {
68929
68923
  groupColumns[1] = val.field;
68930
68924
  }
@@ -68932,7 +68926,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68932
68926
  groupColumns.pop();
68933
68927
  }
68934
68928
  setGroupColumns([...groupColumns]);
68935
- }, isClearable: groupColumns?.length === 2 }) })] }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-3`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 3" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options: optionGroupColumns, fieldLabel: 'headerDisplay', fieldValue: 'field', value: groupColumns[2] ? { headerDisplay: t(contentColumns.find((x) => x.field === groupColumns[2])?.headerDisplay ?? contentColumns.find((x) => x.field === groupColumns[2])?.headerText) } : undefined, onChange: (val) => {
68929
+ }, isClearable: groupColumns?.length === 2 }) })] }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-3`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 3" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options: contentColumns, fieldLabel: 'headerText', fieldValue: 'field', value: groupColumns[2] ? { headerText: t(contentColumns.find((x) => x.field === groupColumns[2])?.headerText ?? contentColumns.find((x) => x.field === groupColumns[2])?.headerText) } : undefined, onChange: (val) => {
68936
68930
  if (groupSetting) {
68937
68931
  if (val) {
68938
68932
  groupColumns[2] = val.field;
@@ -69069,7 +69063,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69069
69063
  setExpandsAll(undefined);
69070
69064
  row.expand = !expand;
69071
69065
  } }), t(col.headerDisplay ?? col.headerText), ": ", value, " (", row.children.length, ")"] }) }), contentColumns.map((colSum, indexCol) => {
69072
- if (indexCol <= firstColSpan || colSum.visible === false || (!groupSetting?.visibleGroupColumn && groupColumns?.includes(colSum.field))) {
69066
+ if (indexCol <= firstColSpan || colSum.visible === false || colSum.isGroup === true) {
69073
69067
  return;
69074
69068
  }
69075
69069
  let sumValue = row[colSum.field];
@@ -69085,7 +69079,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69085
69079
  sumValue = '';
69086
69080
  }
69087
69081
  }
69088
- return (jsx("td", { className: "r-rowcell r-cell-sum-group", children: jsx("div", { className: "r-rowcell-div", style: { justifyContent: colSum.textAlign ? colSum.textAlign : 'left' }, children: (haveSum || colSum.haveSum === true) && Number(sumValue) < 0 ? (jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] })) : (sumValue) }) }, `group-sum-cell-${level}-${indexRow}-${indexCol}`));
69082
+ return (jsx("td", { className: "r-rowcell r-cell-sum-group", children: jsx("div", { className: "r-rowcell-div", style: { justifyContent: colSum.textAlign ? colSum.textAlign : 'left' }, children: (haveSum || colSum.haveSum === true) && Number(sumValue) < 0 ? jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] }) : sumValue }) }, `group-sum-cell-${level}-${indexRow}-${indexCol}`));
69089
69083
  })] }), expand && jsx(RenderContent, { datas: row.children, level: level + 1 })] }, `row-${level}-${indexRow}`));
69090
69084
  }
69091
69085
  else {
@@ -69097,7 +69091,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69097
69091
  }, onContextMenu: (e) => {
69098
69092
  e.preventDefault();
69099
69093
  handleContextMenu(e, row);
69100
- }, children: contentColumns.map((column, indexCol) => (jsx(RenderContentCol, { idTable: idTable, col: column, fieldKey: fieldKey, objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, isMulti: isMutil ?? false, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, formatSetting: formatSetting, indexCol: indexCol, indexRow: indexRow, isSelected: isSelected, row: row, zeroVisiable: zeroVisiable, groupSetting: groupSetting }, indexCol))) }, `row-content-${indexRow}`));
69094
+ }, children: contentColumns.map((column, indexCol) => (jsx(RenderContentCol, { idTable: idTable, col: column, fieldKey: fieldKey, objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, isMulti: isMutil ?? false, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, formatSetting: formatSetting, indexCol: indexCol, indexRow: indexRow, isSelected: isSelected, row: row, zeroVisiable: zeroVisiable }, indexCol))) }, `row-content-${indexRow}`));
69101
69095
  }
69102
69096
  }) }));
69103
69097
  };
@@ -69124,7 +69118,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69124
69118
  virtualDivRef.current.style.height = '0px';
69125
69119
  }
69126
69120
  }, [context]);
69127
- return (jsxs("div", { className: "r-table-edit r-virtualized-table", children: [jsxs("div", { className: "r-grid", children: [toolbarSetting?.showTopToolbar && jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), headerComponent && headerComponent(), jsxs("div", { ref: gridRef, className: "r-gridtable", style: { height: `${height ? `${height}px` : 'auto'}`, position: 'relative' }, children: [jsxs("table", { role: "presentation", style: { width: '100%' }, children: [jsx(RenderColGroup, { contentColumns: contentColumns, groupSetting: groupSetting }), jsx("thead", { className: "r-gridheader", role: "rowgroup", children: headerColumns.map((rowColumn, indexParent) => {
69121
+ return (jsxs("div", { className: "r-table-edit r-virtualized-table", children: [jsxs("div", { className: "r-grid", children: [toolbarSetting?.showTopToolbar && jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), headerComponent && headerComponent(), jsxs("div", { ref: gridRef, className: "r-gridtable", style: { height: `${height ? `${height}px` : 'auto'}`, position: 'relative' }, children: [jsxs("table", { role: "presentation", style: { width: '100%' }, children: [jsx(RenderColGroup, { contentColumns: contentColumns }), jsx("thead", { className: "r-gridheader", role: "rowgroup", children: headerColumns.map((rowColumn, indexParent) => {
69128
69122
  return (jsx("tr", { className: "r-row", role: "row", children: rowColumn.map((col, index) => (jsx(HeaderTableCol, { col: col, idTable: idTable ?? '', dataSource: dataSource, indexCol: index, indexParent: indexParent, isMulti: isMulti ?? false, objHeaderWidthFixLeft: objHeaderWidthFixLeft, objHeaderWidthFixRight: objHeaderWidthFixRight, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, container: gridRef, filterBy: filterBy, orderBy: orderBy, optionsFilter: querySetting?.optionsFilter, allowFiltering: querySetting?.allowFiltering, allowSorting: querySetting?.allowSorting, formatSetting: formatSetting, changeFilter: (val) => {
69129
69123
  setFilterBy([...val]);
69130
69124
  if (querySetting?.changeFilter) {
@@ -69135,9 +69129,9 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69135
69129
  if (querySetting?.changeOrder) {
69136
69130
  querySetting.changeOrder(val);
69137
69131
  }
69138
- }, columns: contentColumns, groupSetting: groupSetting, setContentColumns: setContentColumns, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, totalCount: dataSource?.length ?? 0 }, `header-${indexParent}-${index}`))) }, `header-${-indexParent}`));
69132
+ }, columns: contentColumns, setContentColumns: setContentColumns, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, totalCount: dataSource?.length ?? 0 }, `header-${indexParent}-${index}`))) }, `header-${-indexParent}`));
69139
69133
  }) }), jsx("tbody", { className: "r-gridcontent", role: "rowgroup", children: jsx(RenderContent, { datas: viewData }) }), jsx("tfoot", { className: "r-gridfoot", children: (columnsAggregate?.length ?? 0) > 0 && (jsx("tr", { className: "r-row", children: contentColumns.map((col, indexCol) => {
69140
- if (col.visible === false || (!groupSetting?.visibleGroupColumn && groupSetting?.groupColumns.includes(col.field))) {
69134
+ if (col.visible === false || col.isGroup === true) {
69141
69135
  return;
69142
69136
  }
69143
69137
  const item = columnsAggregate?.find((x) => x.field === col.field);
@@ -69154,7 +69148,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69154
69148
  left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
69155
69149
  right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined,
69156
69150
  textAlign: col.textAlign ? col.textAlign : 'left'
69157
- }, children: jsx("div", { className: "r-footer-div", children: (item || col.haveSum === true) && Number(sumValue) < 0 ? (jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] })) : (sumValue) }) }, `summarycell-${indexCol}`));
69151
+ }, children: jsx("div", { className: "r-footer-div", children: (item || col.haveSum === true) && Number(sumValue) < 0 ? jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] }) : sumValue }) }, `summarycell-${indexCol}`));
69158
69152
  }) })) })] }), jsx("div", { ref: virtualDivRef }), context && (contextMenuItems?.length ?? 0) > 0 && handleContextMenuClick && (jsx(Popover$1, { className: "r-context-popover", placement: "right-start", isOpen: context.show, target: virtualDivRef.current, toggle: handleCloseContext, fade: false, children: jsx(PopoverBody$1, { children: contextMenuItems?.map((item, index) => {
69159
69153
  return (jsxs("div", { className: "r-context-item", onClick: () => {
69160
69154
  handleCloseContext();