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.js CHANGED
@@ -5967,13 +5967,6 @@ var SvgBecoxyHandshake = function (_a) {
5967
5967
  React__namespace.createElement("image", { id: "becoxy-handshake_svg__b", width: 512, height: 512, xlinkHref: "" }))));
5968
5968
  };
5969
5969
 
5970
- var SvgBecoxyHome2 = function (_a) {
5971
- var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
5972
- return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
5973
- title ? React__namespace.createElement("title", { id: titleId }, title) : null,
5974
- React__namespace.createElement("path", { d: "M19.734 9.105V2.629h-4.218v2.274L12 1.403 0 13.352v1.463h2.86v7.782h8.421v-3.75h1.406v3.75h8.454v-7.781H24v-1.465l-4.266-4.247Zm-2.812-5.07h1.406v3.67l-1.406-1.401V4.035Zm2.812 9.375v7.782h-5.64v-3.75H9.875v3.75h-5.61V13.41h-2.33L12 3.387 22.065 13.41h-2.33Z", fill: props.color || "currentColor" })));
5975
- };
5976
-
5977
5970
  var SvgBecoxyHome = function (_a) {
5978
5971
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
5979
5972
  return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
@@ -9017,6 +9010,13 @@ var SvgPieChart = function (_a) {
9017
9010
  React__namespace.createElement("path", { d: "M22 12A10 10 0 0 0 12 2v10z" })));
9018
9011
  };
9019
9012
 
9013
+ var SvgPin = function (_a) {
9014
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9015
+ return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
9016
+ title ? React__namespace.createElement("title", { id: titleId }, title) : null,
9017
+ React__namespace.createElement("path", { d: "M14.743 1.083a.75.75 0 0 1 .53.219L22.7 8.727a.75.75 0 0 1 0 1.06c-.72.72-1.608.882-2.255.882-.265 0-.502-.027-.69-.058l-4.7 4.701c.123.499.203 1.007.24 1.52.068 1.052-.049 2.53-1.08 3.562a.75.75 0 0 1-1.061 0l-4.244-4.242-4.773 4.773c-.292.293-1.828 1.353-2.12 1.06-.293-.292.767-1.83 1.06-2.12l4.773-4.773-4.242-4.244a.75.75 0 0 1 0-1.06c1.032-1.032 2.51-1.151 3.562-1.08a9 9 0 0 1 1.52.24l4.7-4.7a4.488 4.488 0 0 1-.06-.691c0-.645.163-1.533.884-2.255a.75.75 0 0 1 .53-.219Zm.183 3.165v.003a.75.75 0 0 1-.183.765L9.44 10.317a.75.75 0 0 1-.766.18H8.67l-.021-.006a7.485 7.485 0 0 0-1.58-.288c-.633-.042-1.254.012-1.762.225l8.265 8.264c.211-.51.265-1.13.223-1.763a7.503 7.503 0 0 0-.288-1.581l-.006-.02a.755.755 0 0 1 .18-.769l5.304-5.302a.75.75 0 0 1 .798-.173l.144.033c.13.026.312.051.516.051a2.05 2.05 0 0 0 .515-.06L14.89 3.042a2.06 2.06 0 0 0-.06.515c.002.233.033.464.093.69l.002.001Z", fill: props.color || "currentColor", stroke: props.color || "currentColor", strokeWidth: 0.25 })));
9018
+ };
9019
+
9020
9020
  var SvgPlayCircle = function (_a) {
9021
9021
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9022
9022
  return (React__namespace.createElement("svg", __assign({ xmlns: "http://www.w3.org/2000/svg", width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: props.strokeWidth || 1.5, strokeLinecap: "round", strokeLinejoin: "round", className: "play-circle_svg__feather play-circle_svg__feather-play-circle", "aria-labelledby": titleId }, props),
@@ -9263,6 +9263,32 @@ var SvgShare2 = function (_a) {
9263
9263
  React__namespace.createElement("path", { d: "m8.59 13.51 6.83 3.98M15.41 6.51l-6.82 3.98" })));
9264
9264
  };
9265
9265
 
9266
+ var SvgShare3 = function (_a) {
9267
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9268
+ return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
9269
+ title ? React__namespace.createElement("title", { id: titleId }, title) : null,
9270
+ React__namespace.createElement("g", { clipPath: "url(#share-3_svg__a)" },
9271
+ React__namespace.createElement("path", { d: "M9.643 2.693c.208 0 .408.09.555.248a.88.88 0 0 1 .23.599.88.88 0 0 1-.23.598.758.758 0 0 1-.555.248H4.928c-.625 0-1.224.267-1.666.743a2.64 2.64 0 0 0-.69 1.795V18.77c0 .673.248 1.318.69 1.794a2.275 2.275 0 0 0 1.666.744h11c.625 0 1.225-.268 1.667-.744a2.64 2.64 0 0 0 .69-1.794v-3.385a.88.88 0 0 1 .23-.598.758.758 0 0 1 .556-.248c.208 0 .408.09.555.248a.88.88 0 0 1 .23.598v3.385a4.4 4.4 0 0 1-1.15 2.99c-.737.794-1.736 1.24-2.778 1.24h-11c-1.041 0-2.04-.446-2.777-1.24A4.401 4.401 0 0 1 1 18.77V6.924c0-1.122.414-2.198 1.15-2.991.737-.794 1.737-1.24 2.778-1.24h4.715Zm5.154-1.607a.737.737 0 0 1 .828.093l7.071 5.923c.095.079.171.18.224.296a.9.9 0 0 1 0 .744.836.836 0 0 1-.224.297l-7.071 5.922a.738.738 0 0 1-.828.092.81.81 0 0 1-.321-.312.894.894 0 0 1-.12-.448v-2.496c-3.507.389-5.694 3.339-6.907 5.752l-.247.507a.816.816 0 0 1-.37.388c-.16.08-.34.1-.513.057a.782.782 0 0 1-.435-.299.888.888 0 0 1-.17-.525c0-3.513.814-6.669 2.415-8.968 1.474-2.116 3.593-3.464 6.228-3.688V1.847c0-.158.04-.314.118-.448a.81.81 0 0 1 .322-.313Zm1.131 4.146a.88.88 0 0 1-.23.598.758.758 0 0 1-.556.248c-2.498 0-4.426 1.139-5.754 3.046-.844 1.211-1.458 2.751-1.798 4.535 1.616-2.17 4.056-4.197 7.552-4.197.209 0 .409.09.556.248a.88.88 0 0 1 .23.598v1.655l5.005-4.193-5.005-4.195v1.657Z", fill: props.color || "currentColor", stroke: props.color || "currentColor", strokeWidth: 0.45 })),
9272
+ React__namespace.createElement("defs", null,
9273
+ React__namespace.createElement("clipPath", { id: "share-3_svg__a" },
9274
+ React__namespace.createElement("path", { fill: "#fff", d: "M0 0h24v24H0z" })))));
9275
+ };
9276
+
9277
+ var SvgShareBoxed = function (_a) {
9278
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9279
+ return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
9280
+ title ? React__namespace.createElement("title", { id: titleId }, title) : null,
9281
+ React__namespace.createElement("path", { d: "M2.25 0C1.02 0 0 1.02 0 2.25v16.5C0 19.98 1.02 21 2.25 21h13.5c1.23 0 2.25-1.02 2.25-2.25V15h-2v4H2V2h7V0H2.25ZM18 0v3C11.85 3 6.9 7.62 6.18 13.59A5.958 5.958 0 0 1 12 9h6v3l6-6-6-6Z", fill: props.color || "currentColor" })));
9282
+ };
9283
+
9284
+ var SvgShareFilled = function (_a) {
9285
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9286
+ return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
9287
+ title ? React__namespace.createElement("title", { id: titleId }, title) : null,
9288
+ React__namespace.createElement("path", { d: "M10.25 2c.199 0 .39.088.53.244.141.156.22.368.22.59a.882.882 0 0 1-.22.589.714.714 0 0 1-.53.244h-4.5c-.597 0-1.169.263-1.591.732A2.648 2.648 0 0 0 3.5 6.167v11.666c0 .663.237 1.3.659 1.768.422.469.994.732 1.591.732h10.5c.597 0 1.169-.263 1.591-.732a2.648 2.648 0 0 0 .659-1.768V14.5c0-.221.079-.433.22-.59a.714.714 0 0 1 .53-.243c.199 0 .39.088.53.244.141.156.22.368.22.589v3.333c0 1.105-.395 2.165-1.098 2.947-.704.781-1.657 1.22-2.652 1.22H5.75c-.995 0-1.948-.439-2.652-1.22C2.395 19.998 2 18.938 2 17.833V6.167c0-1.105.395-2.165 1.098-2.947C3.802 2.44 4.755 2 5.75 2h4.5Z", fill: props.color || "currentColor", stroke: props.color || "currentColor", strokeWidth: 0.5 }),
9289
+ React__namespace.createElement("path", { d: "M14.67 2.325a.75.75 0 0 1 .79.083l6.75 5.25a.75.75 0 0 1 0 1.185l-6.75 5.25a.75.75 0 0 1-1.21-.593v-2.212c-3.348.345-5.436 2.96-6.594 5.098l-.236.45A.75.75 0 0 1 6 16.5c0-3.114.777-5.911 2.306-7.95 1.407-1.875 3.429-3.07 5.944-3.268V3a.75.75 0 0 1 .42-.675Z", fill: props.color || "currentColor" })));
9290
+ };
9291
+
9266
9292
  var SvgShare = function (_a) {
9267
9293
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9268
9294
  return (React__namespace.createElement("svg", __assign({ xmlns: "http://www.w3.org/2000/svg", width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: props.strokeWidth || 1.5, strokeLinecap: "round", strokeLinejoin: "round", className: "share_svg__feather share_svg__feather-share", "aria-labelledby": titleId }, props),
@@ -9439,6 +9465,14 @@ var SvgSortDecending = function (_a) {
9439
9465
  React__namespace.createElement("path", { d: "M15 5v17h2V8h4l-6-6v3Z", fill: props.color || "currentColor" })));
9440
9466
  };
9441
9467
 
9468
+ var SvgSpeakerPhone = function (_a) {
9469
+ var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9470
+ return (React__namespace.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
9471
+ title ? React__namespace.createElement("title", { id: titleId }, title) : null,
9472
+ React__namespace.createElement("path", { d: "M19.334 6.863a3.666 3.666 0 0 1 0 7.333M9.557 6.863v13.444a1.222 1.222 0 0 1-1.222 1.222H7.113a1.222 1.222 0 0 1-1.222-1.222v-6.111", stroke: props.color || "currentColor", strokeWidth: 1.6, strokeLinecap: "round", strokeLinejoin: "round" }),
9473
+ React__namespace.createElement("path", { d: "m12 6.863 5.528-4.608a1.1 1.1 0 0 1 1.804.846v14.857a1.1 1.1 0 0 1-1.804.846L12 14.196H2.222A1.222 1.222 0 0 1 1 12.974v-4.89a1.222 1.222 0 0 1 1.222-1.221H12Z", stroke: props.color || "currentColor", strokeWidth: 1.6, strokeLinecap: "round", strokeLinejoin: "round" })));
9474
+ };
9475
+
9442
9476
  var SvgSpeaker = function (_a) {
9443
9477
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9444
9478
  return (React__namespace.createElement("svg", __assign({ xmlns: "http://www.w3.org/2000/svg", width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: props.strokeWidth || 1.5, strokeLinecap: "round", strokeLinejoin: "round", className: "speaker_svg__feather speaker_svg__feather-speaker", "aria-labelledby": titleId }, props),
@@ -10109,7 +10143,6 @@ var Icon = /*#__PURE__*/Object.freeze({
10109
10143
  BecoxyGrowth: SvgBecoxyGrowth,
10110
10144
  BecoxyHandshake: SvgBecoxyHandshake,
10111
10145
  BecoxyHome: SvgBecoxyHome,
10112
- BecoxyHome2: SvgBecoxyHome2,
10113
10146
  BecoxyHospital: SvgBecoxyHospital,
10114
10147
  BecoxyHrm: SvgBecoxyHrm,
10115
10148
  BecoxyImportWarehouse: SvgBecoxyImportWarehouse,
@@ -10437,6 +10470,7 @@ var Icon = /*#__PURE__*/Object.freeze({
10437
10470
  PhoneOff: SvgPhoneOff,
10438
10471
  PhoneOutgoing: SvgPhoneOutgoing,
10439
10472
  PieChart: SvgPieChart,
10473
+ Pin: SvgPin,
10440
10474
  Play: SvgPlay,
10441
10475
  PlayCircle: SvgPlayCircle,
10442
10476
  Plus: SvgPlus,
@@ -10467,6 +10501,9 @@ var Icon = /*#__PURE__*/Object.freeze({
10467
10501
  Settings: SvgSettings,
10468
10502
  Share: SvgShare,
10469
10503
  Share2: SvgShare2,
10504
+ Share3: SvgShare3,
10505
+ ShareBoxed: SvgShareBoxed,
10506
+ ShareFilled: SvgShareFilled,
10470
10507
  Shield: SvgShield,
10471
10508
  ShieldOff: SvgShieldOff,
10472
10509
  ShoppingBag: SvgShoppingBag,
@@ -10488,6 +10525,7 @@ var Icon = /*#__PURE__*/Object.freeze({
10488
10525
  SortCancel: SvgSortCancel,
10489
10526
  SortDecending: SvgSortDecending,
10490
10527
  Speaker: SvgSpeaker,
10528
+ SpeakerPhone: SvgSpeakerPhone,
10491
10529
  Square: SvgSquare,
10492
10530
  Star: SvgStar,
10493
10531
  StarFill: SvgStarFill,
@@ -19893,7 +19931,7 @@ const FindNodeByPath = (tree, path) => {
19893
19931
  * fisrtObjWidthFixRight: number // Chỉ số cột đầu tiên fixed right
19894
19932
  * }
19895
19933
  */
19896
- const calculateTableStructure = (columns, settingColumns) => {
19934
+ const calculateTableStructure = (columns, settingColumns, groupColumns) => {
19897
19935
  const levels = [];
19898
19936
  const flat = [];
19899
19937
  const objWidthFixLeft = {};
@@ -19927,9 +19965,7 @@ const calculateTableStructure = (columns, settingColumns) => {
19927
19965
  if (!cell.visibleLocked) {
19928
19966
  cell.visible = setting.visible ?? true;
19929
19967
  }
19930
- if (setting.fixedType !== undefined) {
19931
- cell.fixedType = setting.fixedType;
19932
- }
19968
+ cell.fixedType = setting.fixedType;
19933
19969
  if (setting.width !== undefined && setting.width !== null) {
19934
19970
  cell.width = setting.width;
19935
19971
  }
@@ -19941,7 +19977,7 @@ const calculateTableStructure = (columns, settingColumns) => {
19941
19977
  cell.numericSettings = { fraction: setting.fraction };
19942
19978
  }
19943
19979
  }
19944
- cell.headerDisplay = setting.headerText || cell.headerText;
19980
+ cell.headerDisplay = setting.headerText || (cell.headerDisplay ?? cell.headerText);
19945
19981
  }
19946
19982
  else {
19947
19983
  if (cell.columns?.length) {
@@ -19960,6 +19996,7 @@ const calculateTableStructure = (columns, settingColumns) => {
19960
19996
  }
19961
19997
  }
19962
19998
  }
19999
+ cell.isGroup = groupColumns?.includes(cell.field);
19963
20000
  return cell;
19964
20001
  });
19965
20002
  };
@@ -19980,7 +20017,7 @@ const calculateTableStructure = (columns, settingColumns) => {
19980
20017
  };
19981
20018
  levels[level].push(cell);
19982
20019
  const headerKey = `${level}-${indexCol}`;
19983
- if (cell.fixedType === 'left' && cell.visible !== false) {
20020
+ if (cell.fixedType === 'left' && cell.visible !== false && cell.isGroup !== true) {
19984
20021
  objHeaderWidthFixLeft[headerKey] = leftTotal;
19985
20022
  }
19986
20023
  if (!hasChildren) {
@@ -19988,16 +20025,16 @@ const calculateTableStructure = (columns, settingColumns) => {
19988
20025
  const width = cell.width ?? 40;
19989
20026
  cell.index = index;
19990
20027
  flat.push(cell);
19991
- if (cell.fixedType === 'left' && cell.visible !== false) {
20028
+ if (cell.fixedType === 'left' && cell.visible !== false && cell.isGroup !== true) {
19992
20029
  objWidthFixLeft[index] = leftTotal;
19993
20030
  leftTotal += width;
19994
20031
  }
19995
- if (cell.fixedType === 'right' && cell.visible !== false) {
20032
+ if (cell.fixedType === 'right' && cell.visible !== false && cell.isGroup !== true) {
19996
20033
  rightTotal -= width;
19997
20034
  objWidthFixRight[index] = rightTotal;
19998
20035
  }
19999
20036
  }
20000
- if (cell.fixedType === 'right' && cell.visible !== false) {
20037
+ if (cell.fixedType === 'right' && cell.visible !== false && cell.isGroup !== true) {
20001
20038
  objHeaderWidthFixRight[headerKey] = rightTotal;
20002
20039
  }
20003
20040
  return colspanSum + colspan;
@@ -20530,19 +20567,6 @@ const ReactInput = (props) => {
20530
20567
  }), value: value, onChange: (val) => setValue(val.target.value) }), value ? jsxRuntime.jsx(SvgX, { className: 'input__clear-icon', onClick: handelClear, strokeWidth: 3, fontSize: 16 }) : ''] }));
20531
20568
  };
20532
20569
 
20533
- const RenderToolbarTop = ({ toolbarTopOption }) => {
20534
- return (jsxRuntime.jsx("div", { id: "table_custom_top_toolbar", className: "r-toolbar r-toolbar-top", "aria-orientation": "horizontal", children: jsxRuntime.jsxs("div", { className: "r-toolbar-items", children: [jsxRuntime.jsx("div", { className: "r-toolbar-left", children: toolbarTopOption?.map((item, index) => {
20535
- return item.align === 'left' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
20536
- }) }), jsxRuntime.jsx("div", { className: "r-toolbar-center", children: toolbarTopOption?.map((item, index) => {
20537
- return item.align === 'center' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
20538
- }) }), jsxRuntime.jsx("div", { className: "r-toolbar-right", children: toolbarTopOption?.map((item, index) => {
20539
- return item.align === 'right' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
20540
- }) })] }) }));
20541
- };
20542
- const ToolBarElement = ({ item, index }) => {
20543
- return (jsxRuntime.jsx("div", { className: "r-toolbar-item", "aria-disabled": "false", children: item.template?.() }, `toolbar-top-${index}`));
20544
- };
20545
-
20546
20570
  const handleAdd = (dataSource, containerRef, indexFirstEdit,
20547
20571
  /*eslint-disable*/
20548
20572
  changeDataSource, handleFocusCell,
@@ -31617,63 +31641,7 @@ class DateLib {
31617
31641
  formatNumber(value) {
31618
31642
  return this.replaceDigits(value.toString());
31619
31643
  }
31620
- /**
31621
- * Returns the preferred ordering for month and year labels for the current
31622
- * locale.
31623
- */
31624
- getMonthYearOrder() {
31625
- const code = this.options.locale?.code;
31626
- if (!code) {
31627
- return "month-first";
31628
- }
31629
- return DateLib.yearFirstLocales.has(code) ? "year-first" : "month-first";
31630
- }
31631
- /**
31632
- * Formats the month/year pair respecting locale conventions.
31633
- *
31634
- * @since 9.11.0
31635
- */
31636
- formatMonthYear(date) {
31637
- const { locale, timeZone, numerals } = this.options;
31638
- const localeCode = locale?.code;
31639
- if (localeCode && DateLib.yearFirstLocales.has(localeCode)) {
31640
- try {
31641
- const intl = new Intl.DateTimeFormat(localeCode, {
31642
- month: "long",
31643
- year: "numeric",
31644
- timeZone,
31645
- numberingSystem: numerals,
31646
- });
31647
- const formatted = intl.format(date);
31648
- return formatted;
31649
- }
31650
- catch {
31651
- // Fallback to date-fns formatting below.
31652
- }
31653
- }
31654
- const pattern = this.getMonthYearOrder() === "year-first" ? "y LLLL" : "LLLL y";
31655
- return this.format(date, pattern);
31656
- }
31657
- }
31658
- DateLib.yearFirstLocales = new Set([
31659
- "eu",
31660
- "hu",
31661
- "ja",
31662
- "ja-Hira",
31663
- "ja-JP",
31664
- "ko",
31665
- "ko-KR",
31666
- "lt",
31667
- "lt-LT",
31668
- "lv",
31669
- "lv-LV",
31670
- "mn",
31671
- "mn-MN",
31672
- "zh",
31673
- "zh-CN",
31674
- "zh-HK",
31675
- "zh-TW",
31676
- ]);
31644
+ }
31677
31645
  /**
31678
31646
  * The default date library with English locale.
31679
31647
  *
@@ -32569,7 +32537,7 @@ function getDefaultClassNames() {
32569
32537
  /**
32570
32538
  * Formats the caption of the month.
32571
32539
  *
32572
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32540
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32573
32541
  * @param month The date representing the month.
32574
32542
  * @param options Configuration options for the date library.
32575
32543
  * @param dateLib The date library to use for formatting. If not provided, a new
@@ -32579,8 +32547,7 @@ function getDefaultClassNames() {
32579
32547
  * @see https://daypicker.dev/docs/translation#custom-formatters
32580
32548
  */
32581
32549
  function formatCaption(month, options, dateLib) {
32582
- const lib = dateLib ?? new DateLib(options);
32583
- return lib.formatMonthYear(month);
32550
+ return (dateLib ?? new DateLib(options)).format(month, "LLLL y");
32584
32551
  }
32585
32552
  /**
32586
32553
  * @private
@@ -32874,7 +32841,7 @@ const labelDay = labelDayButton;
32874
32841
  * Generates the ARIA label for the month grid, which is announced when entering
32875
32842
  * the grid.
32876
32843
  *
32877
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32844
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32878
32845
  * @param date - The date representing the month.
32879
32846
  * @param options - Optional configuration for the date formatting library.
32880
32847
  * @param dateLib - An optional instance of the date formatting library.
@@ -32883,8 +32850,7 @@ const labelDay = labelDayButton;
32883
32850
  * @see https://daypicker.dev/docs/translation#aria-labels
32884
32851
  */
32885
32852
  function labelGrid(date, options, dateLib) {
32886
- const lib = dateLib ?? new DateLib(options);
32887
- return lib.formatMonthYear(date);
32853
+ return (dateLib ?? new DateLib(options)).format(date, "LLLL y");
32888
32854
  }
32889
32855
  /**
32890
32856
  * @ignore
@@ -34367,7 +34333,7 @@ function DayPicker(initialProps) {
34367
34333
  formatters,
34368
34334
  };
34369
34335
  return (React__default["default"].createElement(dayPickerContext.Provider, { value: contextValue },
34370
- React__default["default"].createElement(components.Root, { rootRef: props.animate ? rootElRef : undefined, className: className, style: style, dir: props.dir, id: props.id, lang: props.lang, nonce: props.nonce, title: props.title, role: props.role, "aria-label": props["aria-label"], "aria-labelledby": props["aria-labelledby"], ...dataAttributes },
34336
+ React__default["default"].createElement(components.Root, { rootRef: props.animate ? rootElRef : undefined, className: className, style: style, dir: props.dir, id: props.id, lang: props.lang, nonce: props.nonce, title: props.title, role: props.role, "aria-label": props["aria-label"], ...dataAttributes },
34371
34337
  React__default["default"].createElement(components.Months, { className: classNames[UI.Months], style: styles?.[UI.Months] },
34372
34338
  !props.hideNavigation && !navLayout && (React__default["default"].createElement(components.Nav, { "data-animated-nav": props.animate ? "true" : undefined, className: classNames[UI.Nav], style: styles?.[UI.Nav], "aria-label": labelNav(), onPreviousClick: handlePreviousClick, onNextClick: handleNextClick, previousMonth: previousMonth, nextMonth: nextMonth })),
34373
34339
  months.map((calendarMonth, displayIndex) => {
@@ -34379,16 +34345,10 @@ function DayPicker(initialProps) {
34379
34345
  displayIndex === 0 && (React__default["default"].createElement(components.PreviousMonthButton, { type: "button", className: classNames[UI.PreviousMonthButton], tabIndex: previousMonth ? undefined : -1, "aria-disabled": previousMonth ? undefined : true, "aria-label": labelPrevious(previousMonth), onClick: handlePreviousClick, "data-animated-button": props.animate ? "true" : undefined },
34380
34346
  React__default["default"].createElement(components.Chevron, { disabled: previousMonth ? undefined : true, className: classNames[UI.Chevron], orientation: props.dir === "rtl" ? "right" : "left" }))),
34381
34347
  React__default["default"].createElement(components.MonthCaption, { "data-animated-caption": props.animate ? "true" : undefined, className: classNames[UI.MonthCaption], style: styles?.[UI.MonthCaption], calendarMonth: calendarMonth, displayIndex: displayIndex }, captionLayout?.startsWith("dropdown") ? (React__default["default"].createElement(components.DropdownNav, { className: classNames[UI.Dropdowns], style: styles?.[UI.Dropdowns] },
34382
- (() => {
34383
- const monthControl = captionLayout === "dropdown" ||
34384
- captionLayout === "dropdown-months" ? (React__default["default"].createElement(components.MonthsDropdown, { key: "month", className: classNames[UI.MonthsDropdown], "aria-label": labelMonthDropdown(), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleMonthChange(calendarMonth.date), options: getMonthOptions(calendarMonth.date, navStart, navEnd, formatters, dateLib), style: styles?.[UI.Dropdown], value: dateLib.getMonth(calendarMonth.date) })) : (React__default["default"].createElement("span", { key: "month" }, formatMonthDropdown(calendarMonth.date, dateLib)));
34385
- const yearControl = captionLayout === "dropdown" ||
34386
- captionLayout === "dropdown-years" ? (React__default["default"].createElement(components.YearsDropdown, { key: "year", className: classNames[UI.YearsDropdown], "aria-label": labelYearDropdown(dateLib.options), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleYearChange(calendarMonth.date), options: getYearOptions(navStart, navEnd, formatters, dateLib, Boolean(props.reverseYears)), style: styles?.[UI.Dropdown], value: dateLib.getYear(calendarMonth.date) })) : (React__default["default"].createElement("span", { key: "year" }, formatYearDropdown(calendarMonth.date, dateLib)));
34387
- const controls = dateLib.getMonthYearOrder() === "year-first"
34388
- ? [yearControl, monthControl]
34389
- : [monthControl, yearControl];
34390
- return controls;
34391
- })(),
34348
+ captionLayout === "dropdown" ||
34349
+ captionLayout === "dropdown-months" ? (React__default["default"].createElement(components.MonthsDropdown, { className: classNames[UI.MonthsDropdown], "aria-label": labelMonthDropdown(), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleMonthChange(calendarMonth.date), options: getMonthOptions(calendarMonth.date, navStart, navEnd, formatters, dateLib), style: styles?.[UI.Dropdown], value: dateLib.getMonth(calendarMonth.date) })) : (React__default["default"].createElement("span", null, formatMonthDropdown(calendarMonth.date, dateLib))),
34350
+ captionLayout === "dropdown" ||
34351
+ captionLayout === "dropdown-years" ? (React__default["default"].createElement(components.YearsDropdown, { className: classNames[UI.YearsDropdown], "aria-label": labelYearDropdown(dateLib.options), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleYearChange(calendarMonth.date), options: getYearOptions(navStart, navEnd, formatters, dateLib, Boolean(props.reverseYears)), style: styles?.[UI.Dropdown], value: dateLib.getYear(calendarMonth.date) })) : (React__default["default"].createElement("span", null, formatYearDropdown(calendarMonth.date, dateLib))),
34392
34352
  React__default["default"].createElement("span", { role: "status", "aria-live": "polite", style: {
34393
34353
  border: 0,
34394
34354
  clip: "rect(0 0 0 0)",
@@ -36838,9 +36798,8 @@ const FooterCol = ({ col, indexCol, dataSource, objWidthFix, formatSetting }) =>
36838
36798
  }, children: jsxRuntime.jsx("div", { className: "r-footer-div", children: col.haveSum === true && col.type === "numeric" && (jsxRuntime.jsx(jsxRuntime.Fragment, { children: Number(sumValue) >= 0 ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: formartNumberic(sumValue, formatSetting?.decimalSeparator ?? ",", formatSetting?.thousandSeparator ?? ".", col.numericSettings?.fraction, true, false) })) : (jsxRuntime.jsx("div", { style: { color: formatSetting?.colorNegative ?? "red" }, children: `${formatSetting?.prefixNegative ?? "-"}${formartNumberic(sumValue, formatSetting?.decimalSeparator ?? ",", formatSetting?.thousandSeparator ?? ".", col.numericSettings?.fraction, true, false)}${formatSetting?.suffixNegative ?? ""}` })) })) }) })) }, `summarycell-${indexCol}`));
36839
36799
  };
36840
36800
 
36841
- const RenderColGroup = ({ contentColumns, groupSetting }) => (jsxRuntime.jsx("colgroup", { children: contentColumns.map((col, index) => {
36842
- return (col.visible !== false &&
36843
- (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (jsxRuntime.jsx("col", { style: {
36801
+ const RenderColGroup = ({ contentColumns }) => (jsxRuntime.jsx("colgroup", { children: contentColumns.map((col, index) => {
36802
+ return (col.visible !== false && col.isGroup !== true && (jsxRuntime.jsx("col", { style: {
36844
36803
  width: typeof col.width === 'number' ? `${col.width}px` : col.width || undefined,
36845
36804
  minWidth: typeof col.minWidth === 'number' ? `${col.minWidth}px` : col.minWidth || undefined,
36846
36805
  maxWidth: typeof col.maxWidth === 'number' ? `${col.maxWidth}px` : col.maxWidth || undefined
@@ -38732,7 +38691,7 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38732
38691
  setViewDateTo(selectedTo || today);
38733
38692
  }
38734
38693
  else if (!newRange.from || (selected && selected < newRange.from)) {
38735
- newRange = { from: selected, to };
38694
+ newRange = { from: selected, to: undefined };
38736
38695
  setViewDateFrom(selected || today);
38737
38696
  }
38738
38697
  else if (newRange.from && selected && selected > newRange.from && (!newRange.to || selected < newRange.to)) {
@@ -38743,6 +38702,16 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38743
38702
  newRange = { from, to: selected };
38744
38703
  setViewDateTo(selected || today);
38745
38704
  }
38705
+ else if (newRange.from && !selected) {
38706
+ if (newRange.to) {
38707
+ newRange = { from: newRange.to, to };
38708
+ setViewDateFrom(newRange.to || today);
38709
+ }
38710
+ else {
38711
+ newRange = { from, to: newRange.from };
38712
+ setViewDateTo(newRange.from || today);
38713
+ }
38714
+ }
38746
38715
  onChange(newRange);
38747
38716
  setInputValue(formatDisplay(newRange.from, newRange.to));
38748
38717
  };
@@ -38800,7 +38769,10 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38800
38769
  const newDate = new Date(viewDateFrom);
38801
38770
  newDate.setFullYear(newYear);
38802
38771
  setViewDateFrom(newDate);
38803
- }, value: { value: viewDateFrom.getFullYear(), label: viewDateFrom.getFullYear() } }) })] }), jsxRuntime.jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38772
+ }, value: {
38773
+ value: viewDateFrom.getFullYear(),
38774
+ label: viewDateFrom.getFullYear()
38775
+ } }) })] }), jsxRuntime.jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38804
38776
  const newDate = new Date(viewDateFrom);
38805
38777
  newDate.setMonth(viewDateFrom.getMonth() + 1);
38806
38778
  setViewDateFrom(newDate);
@@ -38812,6 +38784,8 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38812
38784
  inRange: 'rdp-in-range',
38813
38785
  rangeStart: 'rdp-selected',
38814
38786
  rangeEnd: 'rdp-selected'
38787
+ }, formatters: {
38788
+ formatWeekdayName: (day) => [t('Su'), t('Mo'), t('Tu'), t('We'), t('Th'), t('Fr'), t('Sa')][day.getDay() === 0 ? 6 : day.getDay() - 1]
38815
38789
  } })] }), jsxRuntime.jsxs("div", { children: [jsxRuntime.jsxs("div", { className: "select-month-year", children: [jsxRuntime.jsx(SvgChevronLeft, { cursor: 'pointer', fontSize: 22, onClick: () => {
38816
38790
  const newDate = new Date(viewDateTo);
38817
38791
  newDate.setMonth(viewDateTo.getMonth() - 1);
@@ -38826,7 +38800,10 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38826
38800
  const newDate = new Date(viewDateTo);
38827
38801
  newDate.setFullYear(newYear);
38828
38802
  setViewDateTo(newDate);
38829
- }, value: { value: viewDateTo.getFullYear(), label: viewDateTo.getFullYear() } }) })] }), jsxRuntime.jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38803
+ }, value: {
38804
+ value: viewDateTo.getFullYear(),
38805
+ label: viewDateTo.getFullYear()
38806
+ } }) })] }), jsxRuntime.jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38830
38807
  const newDate = new Date(viewDateTo);
38831
38808
  newDate.setMonth(viewDateTo.getMonth() + 1);
38832
38809
  setViewDateTo(newDate);
@@ -38838,6 +38815,8 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38838
38815
  inRange: 'rdp-in-range',
38839
38816
  rangeStart: 'rdp-selected',
38840
38817
  rangeEnd: 'rdp-selected'
38818
+ }, formatters: {
38819
+ formatWeekdayName: (day) => [t('Su'), t('Mo'), t('Tu'), t('We'), t('Th'), t('Fr'), t('Sa')][day.getDay() === 0 ? 6 : day.getDay() - 1]
38841
38820
  } })] })] }), jsxRuntime.jsxs("div", { className: "d-flex border-top ms-50", style: { gap: 20, paddingTop: 10 }, children: [jsxRuntime.jsx("div", { className: "btn-today", onClick: () => {
38842
38821
  handleSelect(today, today);
38843
38822
  setOpen(false);
@@ -39019,7 +38998,7 @@ const DateRangeFilterComponent = ({ fieldFilter, filterBy, handleSave }) => {
39019
38998
  };
39020
38999
 
39021
39000
  const HeaderTableCol = (props) => {
39022
- const { selectEnable, dataSource, setSelectedRows, col, indexCol, indexParent, objHeaderWidthFixLeft, objHeaderWidthFixRight, totalCount, selectedRows, columns, orderBy, changeFilter, filterBy, changeOrder, allowFiltering, allowSorting, container, fisrtObjWidthFixRight, lastObjWidthFixLeft, setContentColumns, formatSetting, optionsFilter, idTable, isMulti, groupSetting } = props;
39001
+ const { selectEnable, dataSource, setSelectedRows, col, indexCol, indexParent, objHeaderWidthFixLeft, objHeaderWidthFixRight, totalCount, selectedRows, columns, orderBy, changeFilter, filterBy, changeOrder, allowFiltering, allowSorting, container, fisrtObjWidthFixRight, lastObjWidthFixLeft, setContentColumns, formatSetting, optionsFilter, idTable, isMulti } = props;
39023
39002
  const { t } = reactI18next.useTranslation();
39024
39003
  const headerRef = React$5.useRef(null);
39025
39004
  const order = orderBy.find((item) => item.key === col.field);
@@ -39038,11 +39017,11 @@ const HeaderTableCol = (props) => {
39038
39017
  const checkOverflow = () => {
39039
39018
  return headerRef.current && headerRef.current.scrollHeight > headerRef.current.clientHeight;
39040
39019
  };
39041
- return (jsxRuntime.jsx(React$5.Fragment, { children: col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (jsxRuntime.jsx(Resizable, { className: "r-resize", width: typeof col.width === 'number' ? col.width : Number((col.width ?? '').replaceAll(new RegExp(`[^0-9]`, 'g'), '')), height: 0, onResize: handleResize, draggableOpts: { enableUserSelectHack: true }, children: jsxRuntime.jsx("th", { rowSpan: col.rowspan !== 1 ? col.rowspan : 1, colSpan: col.columns?.filter((x) => x.visible !== false)?.length ?? 1, className: classNames$1(`r-headercell fix-${col.fixedType}`, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'cell-fixed': col.fixedType }), style: {
39020
+ return (jsxRuntime.jsx(React$5.Fragment, { children: col.visible !== false && col.isGroup !== true && (jsxRuntime.jsx(Resizable, { className: "r-resize", width: typeof col.width === 'number' ? col.width : Number((col.width ?? '').replaceAll(new RegExp(`[^0-9]`, 'g'), '')), height: 0, onResize: handleResize, draggableOpts: { enableUserSelectHack: true }, children: jsxRuntime.jsx("th", { rowSpan: col.rowspan !== 1 ? col.rowspan : 1, colSpan: col.columns?.filter((x) => x.visible !== false)?.length ?? 1, className: classNames$1(`r-headercell fix-${col.fixedType}`, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'cell-fixed': col.fixedType }), style: {
39042
39021
  top: `${indexParent * 42}px`,
39043
39022
  left: col.fixedType === 'left' ? objHeaderWidthFixLeft[`${indexParent}-${indexCol ?? 0}`] : undefined,
39044
39023
  right: col.fixedType === 'right' ? objHeaderWidthFixRight[`${indexParent}-${indexCol ?? 0}`] : undefined
39045
- }, children: jsxRuntime.jsxs("div", { style: { justifyContent: 'space-between' }, onClick: () => {
39024
+ }, children: jsxRuntime.jsxs("div", { style: { justifyContent: col.textAlign === 'center' ? 'center' : 'space-between' }, onClick: () => {
39046
39025
  if (!allowSorting || col.columns?.length) {
39047
39026
  return;
39048
39027
  }
@@ -39849,6 +39828,19 @@ const ToolbarBottom = ({ handleAdd, handleDuplicate, handleInsertBefore, handleI
39849
39828
  }), jsxRuntime.jsx("div", { className: classNames$1('r-toolbar-item me-25'), "aria-disabled": "false", children: jsxRuntime.jsx(SvgSettings, { className: "text-primary cursor-pointer", onClick: () => setOpenPopupSetupColumn(true) }) }), jsxRuntime.jsx("div", { className: classNames$1('r-toolbar-item me-25', { 'd-none': editDisable || addDisable }), "aria-disabled": "false", children: jsxRuntime.jsxs(UncontrolledDropdown, { className: "dropdown-user nav-item", children: [jsxRuntime.jsx(DropdownToggle$1, { tag: "div", color: "primary", onClick: (e) => e.preventDefault(), children: jsxRuntime.jsx(SvgInfo, { className: "cursor-pointer text-primary" }) }), jsxRuntime.jsx(DropdownMenu$1, { className: "formula-dropdown icon-dropdown", children: jsxRuntime.jsxs("ul", { className: "mb-0 pe-50", children: [jsxRuntime.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" }), jsxRuntime.jsx("li", { style: { fontSize: 13 }, children: "Ch\u1ECDn \u00F4 v\u00E0 Ctrl + V \u0111\u1EC3 d\u00E1n th\u00F4ng tin t\u1EEB excel" }), jsxRuntime.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" }), jsxRuntime.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" }), jsxRuntime.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" }), jsxRuntime.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" })] }) })] }) })] })] }) }));
39850
39829
  };
39851
39830
 
39831
+ const RenderToolbarTop = ({ toolbarTopOption }) => {
39832
+ return (jsxRuntime.jsx("div", { id: "table_custom_top_toolbar", className: "r-toolbar r-toolbar-top", "aria-orientation": "horizontal", children: jsxRuntime.jsxs("div", { className: "r-toolbar-items", children: [jsxRuntime.jsx("div", { className: "r-toolbar-left", children: toolbarTopOption?.map((item, index) => {
39833
+ return item.align === 'left' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
39834
+ }) }), jsxRuntime.jsx("div", { className: "r-toolbar-center", children: toolbarTopOption?.map((item, index) => {
39835
+ return item.align === 'center' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
39836
+ }) }), jsxRuntime.jsx("div", { className: "r-toolbar-right", children: toolbarTopOption?.map((item, index) => {
39837
+ return item.align === 'right' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
39838
+ }) })] }) }));
39839
+ };
39840
+ const ToolBarElement = ({ item, index }) => {
39841
+ return (jsxRuntime.jsx("div", { className: "r-toolbar-item", "aria-disabled": "false", children: item.template?.() }, `toolbar-top-${index}`));
39842
+ };
39843
+
39852
39844
  const TableEdit = React$5.forwardRef((props, ref) => {
39853
39845
  const { t } = reactI18next.useTranslation();
39854
39846
  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;
@@ -68713,15 +68705,17 @@ const UnExpandAllIcon = ({ className, color = '#7F7F7F', size = 24, onClick, sty
68713
68705
  };
68714
68706
 
68715
68707
  const RenderContentCol = (props) => {
68716
- const { col, indexCol, indexRow, isSelected, row, zeroVisiable, groupSetting, formatSetting, idTable, fisrtObjWidthFixRight, lastObjWidthFixLeft, objWidthFixLeft, objWidthFixRight, selectedRows, selectEnable, setSelectedRows, fieldKey, isMulti } = props;
68708
+ const { col, indexCol, indexRow, isSelected, row, zeroVisiable, formatSetting, idTable, fisrtObjWidthFixRight, lastObjWidthFixLeft, objWidthFixLeft, objWidthFixRight, selectedRows, selectEnable, setSelectedRows, fieldKey, isMulti } = props;
68717
68709
  const cellId = `content-${idTable}-row${indexRow}col-${indexCol}`;
68718
68710
  const checkOverflow = () => {
68719
68711
  const element = document.getElementById(cellId);
68720
68712
  return element && element.scrollWidth > element.clientWidth;
68721
68713
  };
68722
68714
  const RenderElement = () => {
68723
- if (col.type === 'checkbox' && !col.field) {
68724
- return (jsxRuntime.jsx("div", { className: "r-rowcell-div cursor-pointer", style: { alignItems: 'center' }, onClick: (e) => {
68715
+ if (col.type === 'checkbox' || col.field === 'checkbox') {
68716
+ return (jsxRuntime.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) => {
68717
+ console.log(isMulti);
68718
+ console.log(selectEnable);
68725
68719
  if (selectEnable) {
68726
68720
  const index = selectedRows?.findIndex((x) => x[fieldKey] === row[fieldKey]);
68727
68721
  if (index > -1) {
@@ -68769,7 +68763,8 @@ const RenderContentCol = (props) => {
68769
68763
  const suffix = isNegative ? formatSetting?.suffixNegative ?? '' : '';
68770
68764
  const displayText = isNegative ? `${prefix}${value}${suffix}` : value ?? '';
68771
68765
  return (jsxRuntime.jsxs("div", { className: classNames$1('r-rowcell-div'), style: {
68772
- fontWeight: row.sortOrder < 0 || row.sortOrder > 100000 ? 600 : 400
68766
+ fontWeight: row.sortOrder < 0 || row.sortOrder > 100000 || row.haveBoldType ? 600 : 400,
68767
+ fontStyle: row.haveItalicType ? 'italic' : 'normal'
68773
68768
  }, children: [jsxRuntime.jsx("div", { className: "r-cell-text", style: {
68774
68769
  display: 'flex',
68775
68770
  justifyContent: col.textAlign === 'center' ? 'center' : col.textAlign === 'right' ? 'flex-end' : 'flex-start',
@@ -68783,7 +68778,7 @@ const RenderContentCol = (props) => {
68783
68778
  }, children: displayText }) }), checkOverflow() && (jsxRuntime.jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: cellId, placement: "top", children: jsxRuntime.jsx("div", { style: { color: textColor }, children: displayText }) }))] }));
68784
68779
  }
68785
68780
  };
68786
- return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (jsxRuntime.jsx("td", { className: classNames$1(`r-rowcell fix-${col.fixedType}`, { 'cell-fixed': col.fixedType }, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'r-active': isSelected }), style: {
68781
+ return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: col.visible !== false && col.isGroup !== true && (jsxRuntime.jsx("td", { className: classNames$1(`r-rowcell fix-${col.fixedType}`, { 'cell-fixed': col.fixedType }, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'r-active': isSelected }), style: {
68787
68782
  left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
68788
68783
  right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined
68789
68784
  }, onClick: (e) => {
@@ -68841,17 +68836,16 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68841
68836
  setExpandsAll(true);
68842
68837
  }, [groupSetting?.groupColumns]);
68843
68838
  const { levels: headerColumns, objHeaderWidthFixLeft, objHeaderWidthFixRight, objWidthFixLeft, objWidthFixRight, lastObjWidthFixLeft, fisrtObjWidthFixRight } = React$5.useMemo(() => {
68844
- const rs = calculateTableStructure(columns, settingColumns?.value);
68839
+ const rs = calculateTableStructure(columns, settingColumns?.value, groupSetting?.groupColumns);
68845
68840
  setContentColumns(rs.flat);
68846
68841
  return rs;
68847
- }, [columns, settingColumns]);
68848
- const optionGroupColumns = React$5.useMemo(() => contentColumns.filter((x) => !groupSetting?.groupColumns.includes(x.field)).map((x) => ({ ...x, headerDisplay: t(x.columnGroupText ?? x.headerDisplay ?? x.headerText) })), [groupSetting?.groupColumns, contentColumns]);
68842
+ }, [columns, settingColumns, groupSetting?.groupColumns]);
68849
68843
  const firstColSpan = React$5.useMemo(() => {
68850
68844
  let count = 0;
68851
68845
  let index = 3;
68852
68846
  for (let i = 0; i < contentColumns.length; i++) {
68853
68847
  const col = contentColumns[i];
68854
- if (col.visible !== false && (groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field))) {
68848
+ if (col.visible !== false && col.isGroup !== true) {
68855
68849
  count++;
68856
68850
  }
68857
68851
  if (count === 3) {
@@ -68860,7 +68854,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68860
68854
  }
68861
68855
  }
68862
68856
  return index;
68863
- }, [contentColumns, groupSetting?.groupColumns]);
68857
+ }, [contentColumns]);
68864
68858
  // Tính toán dữ liệu hiển thị dựa trên các điều kiện lọc, tìm kiếm và sắp xếp
68865
68859
  const viewData = React$5.useMemo(() => {
68866
68860
  if (!dataSource || dataSource.length === 0) {
@@ -68945,7 +68939,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68945
68939
  return (jsxRuntime.jsx("div", { className: "me-50 r-search", children: jsxRuntime.jsx(ReactInput, { style: { width: '230px' }, value: searchSetting?.searchTerm !== undefined ? searchSetting?.searchTerm : searchTerm, setSearchTerm: searchSetting?.setSearchTerm ? searchSetting?.setSearchTerm : setSearchTerm, placeholder: t('Search'), onKeyPress: handleKeyPress }) }));
68946
68940
  };
68947
68941
  const groupbtnTemplate = () => {
68948
- return (jsxRuntime.jsxs(UncontrolledDropdown, { children: [jsxRuntime.jsx(DropdownToggle$1, { tag: "div", id: "group-dropdown-toggle", style: { position: 'relative' }, onClick: (e) => e.preventDefault(), children: jsxRuntime.jsx(GroupIcon, { color: "#7F7F7F", size: 24 }) }), jsxRuntime.jsxs(DropdownMenu$1, { className: "formula-dropdown icon-dropdown p-1", children: [jsxRuntime.jsx("div", { className: "mb-1", style: { fontSize: 16, fontWeight: 500 }, children: "Nh\u00F3m d\u1EEF li\u1EC7u theo c\u1ED9t" }), jsxRuntime.jsxs("div", { className: 'form-group', children: [jsxRuntime.jsx(Label$1, { id: `label-group-1`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 1" }), jsxRuntime.jsx("div", { className: "form-input", children: jsxRuntime.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) => {
68942
+ return (jsxRuntime.jsxs(UncontrolledDropdown, { children: [jsxRuntime.jsx(DropdownToggle$1, { tag: "div", id: "group-dropdown-toggle", style: { position: 'relative' }, onClick: (e) => e.preventDefault(), children: jsxRuntime.jsx(GroupIcon, { color: "#7F7F7F", size: 24 }) }), jsxRuntime.jsxs(DropdownMenu$1, { className: "formula-dropdown icon-dropdown p-1", children: [jsxRuntime.jsx("div", { className: "mb-1", style: { fontSize: 16, fontWeight: 500 }, children: "Nh\u00F3m d\u1EEF li\u1EC7u theo c\u1ED9t" }), jsxRuntime.jsxs("div", { className: 'form-group', children: [jsxRuntime.jsx(Label$1, { id: `label-group-1`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 1" }), jsxRuntime.jsx("div", { className: "form-input", children: jsxRuntime.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) => {
68949
68943
  if (val) {
68950
68944
  groupColumns[0] = val.field;
68951
68945
  }
@@ -68953,7 +68947,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68953
68947
  groupColumns.pop();
68954
68948
  }
68955
68949
  setGroupColumns([...groupColumns]);
68956
- }, isClearable: groupColumns?.length === 1 }) })] }), jsxRuntime.jsxs("div", { className: 'form-group', children: [jsxRuntime.jsx(Label$1, { id: `label-group-2`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 2" }), jsxRuntime.jsx("div", { className: "form-input", children: jsxRuntime.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) => {
68950
+ }, isClearable: groupColumns?.length === 1 }) })] }), jsxRuntime.jsxs("div", { className: 'form-group', children: [jsxRuntime.jsx(Label$1, { id: `label-group-2`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 2" }), jsxRuntime.jsx("div", { className: "form-input", children: jsxRuntime.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) => {
68957
68951
  if (val) {
68958
68952
  groupColumns[1] = val.field;
68959
68953
  }
@@ -68961,7 +68955,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68961
68955
  groupColumns.pop();
68962
68956
  }
68963
68957
  setGroupColumns([...groupColumns]);
68964
- }, isClearable: groupColumns?.length === 2 }) })] }), jsxRuntime.jsxs("div", { className: 'form-group', children: [jsxRuntime.jsx(Label$1, { id: `label-group-3`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 3" }), jsxRuntime.jsx("div", { className: "form-input", children: jsxRuntime.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) => {
68958
+ }, isClearable: groupColumns?.length === 2 }) })] }), jsxRuntime.jsxs("div", { className: 'form-group', children: [jsxRuntime.jsx(Label$1, { id: `label-group-3`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 3" }), jsxRuntime.jsx("div", { className: "form-input", children: jsxRuntime.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) => {
68965
68959
  if (groupSetting) {
68966
68960
  if (val) {
68967
68961
  groupColumns[2] = val.field;
@@ -69098,7 +69092,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69098
69092
  setExpandsAll(undefined);
69099
69093
  row.expand = !expand;
69100
69094
  } }), t(col.headerDisplay ?? col.headerText), ": ", value, " (", row.children.length, ")"] }) }), contentColumns.map((colSum, indexCol) => {
69101
- if (indexCol <= firstColSpan || colSum.visible === false || (!groupSetting?.visibleGroupColumn && groupColumns?.includes(colSum.field))) {
69095
+ if (indexCol <= firstColSpan || colSum.visible === false || colSum.isGroup === true) {
69102
69096
  return;
69103
69097
  }
69104
69098
  let sumValue = row[colSum.field];
@@ -69114,7 +69108,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69114
69108
  sumValue = '';
69115
69109
  }
69116
69110
  }
69117
- return (jsxRuntime.jsx("td", { className: "r-rowcell r-cell-sum-group", children: jsxRuntime.jsx("div", { className: "r-rowcell-div", style: { justifyContent: colSum.textAlign ? colSum.textAlign : 'left' }, children: (haveSum || colSum.haveSum === true) && Number(sumValue) < 0 ? (jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] })) : (sumValue) }) }, `group-sum-cell-${level}-${indexRow}-${indexCol}`));
69111
+ return (jsxRuntime.jsx("td", { className: "r-rowcell r-cell-sum-group", children: jsxRuntime.jsx("div", { className: "r-rowcell-div", style: { justifyContent: colSum.textAlign ? colSum.textAlign : 'left' }, children: (haveSum || colSum.haveSum === true) && Number(sumValue) < 0 ? jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] }) : sumValue }) }, `group-sum-cell-${level}-${indexRow}-${indexCol}`));
69118
69112
  })] }), expand && jsxRuntime.jsx(RenderContent, { datas: row.children, level: level + 1 })] }, `row-${level}-${indexRow}`));
69119
69113
  }
69120
69114
  else {
@@ -69126,7 +69120,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69126
69120
  }, onContextMenu: (e) => {
69127
69121
  e.preventDefault();
69128
69122
  handleContextMenu(e, row);
69129
- }, children: contentColumns.map((column, indexCol) => (jsxRuntime.jsx(RenderContentCol, { idTable: idTable, col: column, fieldKey: fieldKey, objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, isMulti: isMutil ?? false, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, formatSetting: formatSetting, indexCol: indexCol, indexRow: indexRow, isSelected: isSelected, row: row, zeroVisiable: zeroVisiable, groupSetting: groupSetting }, indexCol))) }, `row-content-${indexRow}`));
69123
+ }, children: contentColumns.map((column, indexCol) => (jsxRuntime.jsx(RenderContentCol, { idTable: idTable, col: column, fieldKey: fieldKey, objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, isMulti: isMutil ?? false, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, formatSetting: formatSetting, indexCol: indexCol, indexRow: indexRow, isSelected: isSelected, row: row, zeroVisiable: zeroVisiable }, indexCol))) }, `row-content-${indexRow}`));
69130
69124
  }
69131
69125
  }) }));
69132
69126
  };
@@ -69153,7 +69147,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69153
69147
  virtualDivRef.current.style.height = '0px';
69154
69148
  }
69155
69149
  }, [context]);
69156
- return (jsxRuntime.jsxs("div", { className: "r-table-edit r-virtualized-table", children: [jsxRuntime.jsxs("div", { className: "r-grid", children: [toolbarSetting?.showTopToolbar && jsxRuntime.jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), headerComponent && headerComponent(), jsxRuntime.jsxs("div", { ref: gridRef, className: "r-gridtable", style: { height: `${height ? `${height}px` : 'auto'}`, position: 'relative' }, children: [jsxRuntime.jsxs("table", { role: "presentation", style: { width: '100%' }, children: [jsxRuntime.jsx(RenderColGroup, { contentColumns: contentColumns, groupSetting: groupSetting }), jsxRuntime.jsx("thead", { className: "r-gridheader", role: "rowgroup", children: headerColumns.map((rowColumn, indexParent) => {
69150
+ return (jsxRuntime.jsxs("div", { className: "r-table-edit r-virtualized-table", children: [jsxRuntime.jsxs("div", { className: "r-grid", children: [toolbarSetting?.showTopToolbar && jsxRuntime.jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), headerComponent && headerComponent(), jsxRuntime.jsxs("div", { ref: gridRef, className: "r-gridtable", style: { height: `${height ? `${height}px` : 'auto'}`, position: 'relative' }, children: [jsxRuntime.jsxs("table", { role: "presentation", style: { width: '100%' }, children: [jsxRuntime.jsx(RenderColGroup, { contentColumns: contentColumns }), jsxRuntime.jsx("thead", { className: "r-gridheader", role: "rowgroup", children: headerColumns.map((rowColumn, indexParent) => {
69157
69151
  return (jsxRuntime.jsx("tr", { className: "r-row", role: "row", children: rowColumn.map((col, index) => (jsxRuntime.jsx(HeaderTableCol, { col: col, idTable: idTable ?? '', dataSource: dataSource, indexCol: index, indexParent: indexParent, isMulti: isMulti ?? false, objHeaderWidthFixLeft: objHeaderWidthFixLeft, objHeaderWidthFixRight: objHeaderWidthFixRight, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, container: gridRef, filterBy: filterBy, orderBy: orderBy, optionsFilter: querySetting?.optionsFilter, allowFiltering: querySetting?.allowFiltering, allowSorting: querySetting?.allowSorting, formatSetting: formatSetting, changeFilter: (val) => {
69158
69152
  setFilterBy([...val]);
69159
69153
  if (querySetting?.changeFilter) {
@@ -69164,9 +69158,9 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69164
69158
  if (querySetting?.changeOrder) {
69165
69159
  querySetting.changeOrder(val);
69166
69160
  }
69167
- }, columns: contentColumns, groupSetting: groupSetting, setContentColumns: setContentColumns, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, totalCount: dataSource?.length ?? 0 }, `header-${indexParent}-${index}`))) }, `header-${-indexParent}`));
69161
+ }, columns: contentColumns, setContentColumns: setContentColumns, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, totalCount: dataSource?.length ?? 0 }, `header-${indexParent}-${index}`))) }, `header-${-indexParent}`));
69168
69162
  }) }), jsxRuntime.jsx("tbody", { className: "r-gridcontent", role: "rowgroup", children: jsxRuntime.jsx(RenderContent, { datas: viewData }) }), jsxRuntime.jsx("tfoot", { className: "r-gridfoot", children: (columnsAggregate?.length ?? 0) > 0 && (jsxRuntime.jsx("tr", { className: "r-row", children: contentColumns.map((col, indexCol) => {
69169
- if (col.visible === false || (!groupSetting?.visibleGroupColumn && groupSetting?.groupColumns.includes(col.field))) {
69163
+ if (col.visible === false || col.isGroup === true) {
69170
69164
  return;
69171
69165
  }
69172
69166
  const item = columnsAggregate?.find((x) => x.field === col.field);
@@ -69183,7 +69177,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69183
69177
  left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
69184
69178
  right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined,
69185
69179
  textAlign: col.textAlign ? col.textAlign : 'left'
69186
- }, children: jsxRuntime.jsx("div", { className: "r-footer-div", children: (item || col.haveSum === true) && Number(sumValue) < 0 ? (jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] })) : (sumValue) }) }, `summarycell-${indexCol}`));
69180
+ }, children: jsxRuntime.jsx("div", { className: "r-footer-div", children: (item || col.haveSum === true) && Number(sumValue) < 0 ? jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] }) : sumValue }) }, `summarycell-${indexCol}`));
69187
69181
  }) })) })] }), jsxRuntime.jsx("div", { ref: virtualDivRef }), context && (contextMenuItems?.length ?? 0) > 0 && handleContextMenuClick && (jsxRuntime.jsx(Popover$1, { className: "r-context-popover", placement: "right-start", isOpen: context.show, target: virtualDivRef.current, toggle: handleCloseContext, fade: false, children: jsxRuntime.jsx(PopoverBody$1, { children: contextMenuItems?.map((item, index) => {
69188
69182
  return (jsxRuntime.jsxs("div", { className: "r-context-item", onClick: () => {
69189
69183
  handleCloseContext();