react-table-edit 1.5.29 → 1.5.31

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.
@@ -0,0 +1,21 @@
1
+ import React, { ClipboardEvent } from 'react';
2
+ import 'react-day-picker/dist/style.css';
3
+ interface IFDateRange {
4
+ id?: string;
5
+ dateFormat?: 'dd/MM/yyyy' | 'dd/MM/yyyy HH:mm' | 'MM/yyyy';
6
+ className?: string;
7
+ invalid?: boolean;
8
+ value?: {
9
+ from?: Date;
10
+ to?: Date;
11
+ };
12
+ container?: any;
13
+ onChange: (value: {
14
+ from?: Date | string;
15
+ to?: Date | string;
16
+ }) => void;
17
+ onKeyDown?: (e: React.KeyboardEvent<any>) => void | any;
18
+ onPaste?: (e: ClipboardEvent<HTMLElement>) => void;
19
+ }
20
+ declare const DateRangePicker: React.ForwardRefExoticComponent<IFDateRange & React.RefAttributes<unknown>>;
21
+ export default DateRangePicker;
@@ -4,8 +4,6 @@ export interface IFPropsDetail {
4
4
  setColumn: any;
5
5
  openSidebar: boolean;
6
6
  handleSidebar: any;
7
- resetDefaultColumns?: () => void;
8
- formatSetting?: any;
9
7
  }
10
8
  declare const SidebarSetColumn: (props: IFPropsDetail) => import("react/jsx-runtime").JSX.Element;
11
9
  export default SidebarSetColumn;
@@ -0,0 +1,10 @@
1
+ import { IColumnTable } from '../type';
2
+ type IFProps = {
3
+ contentColumns: IColumnTable[];
4
+ groupSetting?: {
5
+ visibleGroupColumn?: boolean;
6
+ groupColumns: string[];
7
+ };
8
+ };
9
+ export declare const RenderColGroup: ({ contentColumns, groupSetting }: IFProps) => import("react/jsx-runtime").JSX.Element;
10
+ export {};
@@ -1,6 +1,6 @@
1
1
  import { Dispatch, SetStateAction } from 'react';
2
2
  import 'react-resizable/css/styles.css';
3
- import { IColumnTable, IFFilterTable, IFOrderTable, IFTableEditFormat } from "../type";
3
+ import { IColumnTable, IFFilterTable, IFOrderTable, IFTableEditFormat } from '../type';
4
4
  type IFDataProps = {
5
5
  idTable: string;
6
6
  selectEnable: boolean;
@@ -12,7 +12,7 @@ export interface KeyHandlerParams {
12
12
  pagingClient?: boolean;
13
13
  totalCount: number;
14
14
  columnLastEdit: number;
15
- moveIndexRowToNewPage: () => void;
15
+ addMoveNewCell: () => void;
16
16
  editDisable?: boolean;
17
17
  addDisable?: boolean;
18
18
  handleDuplicate: () => void;
@@ -22,10 +22,10 @@ export interface KeyHandlerParams {
22
22
  getNewParents: (parent: string, index: number) => string;
23
23
  fieldChildren?: string;
24
24
  }
25
- export declare const handleArrowRight: (e: KeyboardEvent<any>, params: KeyHandlerParams) => string | undefined;
26
- export declare const handleArrowLeft: (e: KeyboardEvent<any>, params: KeyHandlerParams) => string | undefined;
27
- export declare const handleArrowUp: (e: KeyboardEvent<any>, params: KeyHandlerParams) => string | undefined;
28
- export declare const handleArrowDown: (e: KeyboardEvent<any>, params: KeyHandlerParams) => string | undefined;
29
- export declare const handleTab: (e: KeyboardEvent<any>, params: KeyHandlerParams) => string | undefined;
30
- export declare const handleEnter: (e: KeyboardEvent<any>, params: KeyHandlerParams) => string | undefined;
31
- export declare const handleCtrlD: (e: KeyboardEvent<any>, params: KeyHandlerParams) => string | undefined;
25
+ export declare const handleArrowRight: (e: KeyboardEvent<any>, params: KeyHandlerParams) => void;
26
+ export declare const handleArrowLeft: (e: KeyboardEvent<any>, params: KeyHandlerParams) => void;
27
+ export declare const handleArrowUp: (e: KeyboardEvent<any>, params: KeyHandlerParams) => void;
28
+ export declare const handleArrowDown: (e: KeyboardEvent<any>, params: KeyHandlerParams) => "" | undefined;
29
+ export declare const handleTab: (e: KeyboardEvent<any>, params: KeyHandlerParams) => void;
30
+ export declare const handleEnter: (e: KeyboardEvent<any>, params: KeyHandlerParams) => "" | undefined;
31
+ export declare const handleCtrlD: (e: KeyboardEvent<any>, params: KeyHandlerParams) => void;
@@ -162,8 +162,6 @@ export type IColumnTable = {
162
162
  headerText?: string;
163
163
  /** Tiêu đề hiển thị trên giao diện */
164
164
  headerDisplay?: string;
165
- /** Tiêu đề hiển thị trên giao diện nhóm*/
166
- columnGroupText?: string;
167
165
  /** Khóa chính */
168
166
  isPrimarykey?: boolean;
169
167
  /** Duy nhất trong bảng */
package/dist/index.d.ts CHANGED
@@ -166,8 +166,6 @@ type IColumnTable = {
166
166
  headerText?: string;
167
167
  /** Tiêu đề hiển thị trên giao diện */
168
168
  headerDisplay?: string;
169
- /** Tiêu đề hiển thị trên giao diện nhóm*/
170
- columnGroupText?: string;
171
169
  /** Khóa chính */
172
170
  isPrimarykey?: boolean;
173
171
  /** Duy nhất trong bảng */
package/dist/index.js CHANGED
@@ -5967,6 +5967,13 @@ 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
+
5970
5977
  var SvgBecoxyHome = function (_a) {
5971
5978
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
5972
5979
  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),
@@ -9010,13 +9017,6 @@ var SvgPieChart = function (_a) {
9010
9017
  React__namespace.createElement("path", { d: "M22 12A10 10 0 0 0 12 2v10z" })));
9011
9018
  };
9012
9019
 
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,32 +9263,6 @@ 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
-
9292
9266
  var SvgShare = function (_a) {
9293
9267
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9294
9268
  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),
@@ -9465,14 +9439,6 @@ var SvgSortDecending = function (_a) {
9465
9439
  React__namespace.createElement("path", { d: "M15 5v17h2V8h4l-6-6v3Z", fill: props.color || "currentColor" })));
9466
9440
  };
9467
9441
 
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
-
9476
9442
  var SvgSpeaker = function (_a) {
9477
9443
  var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
9478
9444
  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),
@@ -10143,6 +10109,7 @@ var Icon = /*#__PURE__*/Object.freeze({
10143
10109
  BecoxyGrowth: SvgBecoxyGrowth,
10144
10110
  BecoxyHandshake: SvgBecoxyHandshake,
10145
10111
  BecoxyHome: SvgBecoxyHome,
10112
+ BecoxyHome2: SvgBecoxyHome2,
10146
10113
  BecoxyHospital: SvgBecoxyHospital,
10147
10114
  BecoxyHrm: SvgBecoxyHrm,
10148
10115
  BecoxyImportWarehouse: SvgBecoxyImportWarehouse,
@@ -10470,7 +10437,6 @@ var Icon = /*#__PURE__*/Object.freeze({
10470
10437
  PhoneOff: SvgPhoneOff,
10471
10438
  PhoneOutgoing: SvgPhoneOutgoing,
10472
10439
  PieChart: SvgPieChart,
10473
- Pin: SvgPin,
10474
10440
  Play: SvgPlay,
10475
10441
  PlayCircle: SvgPlayCircle,
10476
10442
  Plus: SvgPlus,
@@ -10501,9 +10467,6 @@ var Icon = /*#__PURE__*/Object.freeze({
10501
10467
  Settings: SvgSettings,
10502
10468
  Share: SvgShare,
10503
10469
  Share2: SvgShare2,
10504
- Share3: SvgShare3,
10505
- ShareBoxed: SvgShareBoxed,
10506
- ShareFilled: SvgShareFilled,
10507
10470
  Shield: SvgShield,
10508
10471
  ShieldOff: SvgShieldOff,
10509
10472
  ShoppingBag: SvgShoppingBag,
@@ -10525,7 +10488,6 @@ var Icon = /*#__PURE__*/Object.freeze({
10525
10488
  SortCancel: SvgSortCancel,
10526
10489
  SortDecending: SvgSortDecending,
10527
10490
  Speaker: SvgSpeaker,
10528
- SpeakerPhone: SvgSpeakerPhone,
10529
10491
  Square: SvgSquare,
10530
10492
  Star: SvgStar,
10531
10493
  StarFill: SvgStarFill,
@@ -19849,7 +19811,7 @@ const formartNumberic = (str, decimalSeparator, thousandSeparator, fraction = 10
19849
19811
  const arr = value.toString().split(decimalSeparator ?? '', 2);
19850
19812
  let flag = value.toString().includes(decimalSeparator ?? '');
19851
19813
  if (arr[0].length < 3) {
19852
- return flag ? `${arr[0]}${decimalSeparator}${arr[1]?.substring(0, fraction) ?? ''}` : arr[0];
19814
+ return haveNegative ? arr[0] : arr[0].replace('-', '');
19853
19815
  }
19854
19816
  else {
19855
19817
  let flagNegative = false;
@@ -19977,7 +19939,7 @@ const calculateTableStructure = (columns, settingColumns, groupColumns) => {
19977
19939
  cell.numericSettings = { fraction: setting.fraction };
19978
19940
  }
19979
19941
  }
19980
- cell.headerDisplay = setting.headerText || cell.headerText;
19942
+ cell.headerDisplay = setting.headerText || (cell.headerDisplay ?? cell.headerText);
19981
19943
  }
19982
19944
  else {
19983
19945
  if (cell.columns?.length) {
@@ -20567,19 +20529,6 @@ const ReactInput = (props) => {
20567
20529
  }), value: value, onChange: (val) => setValue(val.target.value) }), value ? jsxRuntime.jsx(SvgX, { className: 'input__clear-icon', onClick: handelClear, strokeWidth: 3, fontSize: 16 }) : ''] }));
20568
20530
  };
20569
20531
 
20570
- const RenderToolbarTop = ({ toolbarTopOption }) => {
20571
- 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) => {
20572
- return item.align === 'left' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
20573
- }) }), jsxRuntime.jsx("div", { className: "r-toolbar-center", children: toolbarTopOption?.map((item, index) => {
20574
- return item.align === 'center' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
20575
- }) }), jsxRuntime.jsx("div", { className: "r-toolbar-right", children: toolbarTopOption?.map((item, index) => {
20576
- return item.align === 'right' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
20577
- }) })] }) }));
20578
- };
20579
- const ToolBarElement = ({ item, index }) => {
20580
- return (jsxRuntime.jsx("div", { className: "r-toolbar-item", "aria-disabled": "false", children: item.template?.() }, `toolbar-top-${index}`));
20581
- };
20582
-
20583
20532
  const handleAdd = (dataSource, containerRef, indexFirstEdit,
20584
20533
  /*eslint-disable*/
20585
20534
  changeDataSource, handleFocusCell,
@@ -31654,7 +31603,63 @@ class DateLib {
31654
31603
  formatNumber(value) {
31655
31604
  return this.replaceDigits(value.toString());
31656
31605
  }
31657
- }
31606
+ /**
31607
+ * Returns the preferred ordering for month and year labels for the current
31608
+ * locale.
31609
+ */
31610
+ getMonthYearOrder() {
31611
+ const code = this.options.locale?.code;
31612
+ if (!code) {
31613
+ return "month-first";
31614
+ }
31615
+ return DateLib.yearFirstLocales.has(code) ? "year-first" : "month-first";
31616
+ }
31617
+ /**
31618
+ * Formats the month/year pair respecting locale conventions.
31619
+ *
31620
+ * @since 9.11.0
31621
+ */
31622
+ formatMonthYear(date) {
31623
+ const { locale, timeZone, numerals } = this.options;
31624
+ const localeCode = locale?.code;
31625
+ if (localeCode && DateLib.yearFirstLocales.has(localeCode)) {
31626
+ try {
31627
+ const intl = new Intl.DateTimeFormat(localeCode, {
31628
+ month: "long",
31629
+ year: "numeric",
31630
+ timeZone,
31631
+ numberingSystem: numerals,
31632
+ });
31633
+ const formatted = intl.format(date);
31634
+ return formatted;
31635
+ }
31636
+ catch {
31637
+ // Fallback to date-fns formatting below.
31638
+ }
31639
+ }
31640
+ const pattern = this.getMonthYearOrder() === "year-first" ? "y LLLL" : "LLLL y";
31641
+ return this.format(date, pattern);
31642
+ }
31643
+ }
31644
+ DateLib.yearFirstLocales = new Set([
31645
+ "eu",
31646
+ "hu",
31647
+ "ja",
31648
+ "ja-Hira",
31649
+ "ja-JP",
31650
+ "ko",
31651
+ "ko-KR",
31652
+ "lt",
31653
+ "lt-LT",
31654
+ "lv",
31655
+ "lv-LV",
31656
+ "mn",
31657
+ "mn-MN",
31658
+ "zh",
31659
+ "zh-CN",
31660
+ "zh-HK",
31661
+ "zh-TW",
31662
+ ]);
31658
31663
  /**
31659
31664
  * The default date library with English locale.
31660
31665
  *
@@ -32550,7 +32555,7 @@ function getDefaultClassNames() {
32550
32555
  /**
32551
32556
  * Formats the caption of the month.
32552
32557
  *
32553
- * @defaultValue `LLLL y` (e.g., "November 2022").
32558
+ * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32554
32559
  * @param month The date representing the month.
32555
32560
  * @param options Configuration options for the date library.
32556
32561
  * @param dateLib The date library to use for formatting. If not provided, a new
@@ -32560,7 +32565,8 @@ function getDefaultClassNames() {
32560
32565
  * @see https://daypicker.dev/docs/translation#custom-formatters
32561
32566
  */
32562
32567
  function formatCaption(month, options, dateLib) {
32563
- return (dateLib ?? new DateLib(options)).format(month, "LLLL y");
32568
+ const lib = dateLib ?? new DateLib(options);
32569
+ return lib.formatMonthYear(month);
32564
32570
  }
32565
32571
  /**
32566
32572
  * @private
@@ -32854,7 +32860,7 @@ const labelDay = labelDayButton;
32854
32860
  * Generates the ARIA label for the month grid, which is announced when entering
32855
32861
  * the grid.
32856
32862
  *
32857
- * @defaultValue `LLLL y` (e.g., "November 2022").
32863
+ * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32858
32864
  * @param date - The date representing the month.
32859
32865
  * @param options - Optional configuration for the date formatting library.
32860
32866
  * @param dateLib - An optional instance of the date formatting library.
@@ -32863,7 +32869,8 @@ const labelDay = labelDayButton;
32863
32869
  * @see https://daypicker.dev/docs/translation#aria-labels
32864
32870
  */
32865
32871
  function labelGrid(date, options, dateLib) {
32866
- return (dateLib ?? new DateLib(options)).format(date, "LLLL y");
32872
+ const lib = dateLib ?? new DateLib(options);
32873
+ return lib.formatMonthYear(date);
32867
32874
  }
32868
32875
  /**
32869
32876
  * @ignore
@@ -34346,7 +34353,7 @@ function DayPicker(initialProps) {
34346
34353
  formatters,
34347
34354
  };
34348
34355
  return (React__default["default"].createElement(dayPickerContext.Provider, { value: contextValue },
34349
- React__default["default"].createElement(components.Root, { rootRef: props.animate ? rootElRef : undefined, className: className, style: style, dir: props.dir, id: props.id, lang: props.lang, nonce: props.nonce, title: props.title, role: props.role, "aria-label": props["aria-label"], ...dataAttributes },
34356
+ 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 },
34350
34357
  React__default["default"].createElement(components.Months, { className: classNames[UI.Months], style: styles?.[UI.Months] },
34351
34358
  !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 })),
34352
34359
  months.map((calendarMonth, displayIndex) => {
@@ -34358,10 +34365,16 @@ function DayPicker(initialProps) {
34358
34365
  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 },
34359
34366
  React__default["default"].createElement(components.Chevron, { disabled: previousMonth ? undefined : true, className: classNames[UI.Chevron], orientation: props.dir === "rtl" ? "right" : "left" }))),
34360
34367
  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] },
34361
- captionLayout === "dropdown" ||
34362
- captionLayout === "dropdown-months" ? (React__default["default"].createElement(components.MonthsDropdown, { className: classNames[UI.MonthsDropdown], "aria-label": labelMonthDropdown(), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleMonthChange(calendarMonth.date), options: getMonthOptions(calendarMonth.date, navStart, navEnd, formatters, dateLib), style: styles?.[UI.Dropdown], value: dateLib.getMonth(calendarMonth.date) })) : (React__default["default"].createElement("span", null, formatMonthDropdown(calendarMonth.date, dateLib))),
34363
- captionLayout === "dropdown" ||
34364
- captionLayout === "dropdown-years" ? (React__default["default"].createElement(components.YearsDropdown, { className: classNames[UI.YearsDropdown], "aria-label": labelYearDropdown(dateLib.options), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleYearChange(calendarMonth.date), options: getYearOptions(navStart, navEnd, formatters, dateLib, Boolean(props.reverseYears)), style: styles?.[UI.Dropdown], value: dateLib.getYear(calendarMonth.date) })) : (React__default["default"].createElement("span", null, formatYearDropdown(calendarMonth.date, dateLib))),
34368
+ (() => {
34369
+ const monthControl = captionLayout === "dropdown" ||
34370
+ 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)));
34371
+ const yearControl = captionLayout === "dropdown" ||
34372
+ 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)));
34373
+ const controls = dateLib.getMonthYearOrder() === "year-first"
34374
+ ? [yearControl, monthControl]
34375
+ : [monthControl, yearControl];
34376
+ return controls;
34377
+ })(),
34365
34378
  React__default["default"].createElement("span", { role: "status", "aria-live": "polite", style: {
34366
34379
  border: 0,
34367
34380
  clip: "rect(0 0 0 0)",
@@ -38782,7 +38795,10 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38782
38795
  const newDate = new Date(viewDateFrom);
38783
38796
  newDate.setFullYear(newYear);
38784
38797
  setViewDateFrom(newDate);
38785
- }, value: { value: viewDateFrom.getFullYear(), label: viewDateFrom.getFullYear() } }) })] }), jsxRuntime.jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38798
+ }, value: {
38799
+ value: viewDateFrom.getFullYear(),
38800
+ label: viewDateFrom.getFullYear()
38801
+ } }) })] }), jsxRuntime.jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38786
38802
  const newDate = new Date(viewDateFrom);
38787
38803
  newDate.setMonth(viewDateFrom.getMonth() + 1);
38788
38804
  setViewDateFrom(newDate);
@@ -38794,6 +38810,8 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38794
38810
  inRange: 'rdp-in-range',
38795
38811
  rangeStart: 'rdp-selected',
38796
38812
  rangeEnd: 'rdp-selected'
38813
+ }, formatters: {
38814
+ formatWeekdayName: (day) => [t('Su'), t('Mo'), t('Tu'), t('We'), t('Th'), t('Fr'), t('Sa')][day.getDay() === 0 ? 6 : day.getDay() - 1]
38797
38815
  } })] }), jsxRuntime.jsxs("div", { children: [jsxRuntime.jsxs("div", { className: "select-month-year", children: [jsxRuntime.jsx(SvgChevronLeft, { cursor: 'pointer', fontSize: 22, onClick: () => {
38798
38816
  const newDate = new Date(viewDateTo);
38799
38817
  newDate.setMonth(viewDateTo.getMonth() - 1);
@@ -38808,7 +38826,10 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38808
38826
  const newDate = new Date(viewDateTo);
38809
38827
  newDate.setFullYear(newYear);
38810
38828
  setViewDateTo(newDate);
38811
- }, value: { value: viewDateTo.getFullYear(), label: viewDateTo.getFullYear() } }) })] }), jsxRuntime.jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38829
+ }, value: {
38830
+ value: viewDateTo.getFullYear(),
38831
+ label: viewDateTo.getFullYear()
38832
+ } }) })] }), jsxRuntime.jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
38812
38833
  const newDate = new Date(viewDateTo);
38813
38834
  newDate.setMonth(viewDateTo.getMonth() + 1);
38814
38835
  setViewDateTo(newDate);
@@ -38820,6 +38841,8 @@ const DateRangePicker = React$5.forwardRef((props, ref) => {
38820
38841
  inRange: 'rdp-in-range',
38821
38842
  rangeStart: 'rdp-selected',
38822
38843
  rangeEnd: 'rdp-selected'
38844
+ }, formatters: {
38845
+ formatWeekdayName: (day) => [t('Su'), t('Mo'), t('Tu'), t('We'), t('Th'), t('Fr'), t('Sa')][day.getDay() === 0 ? 6 : day.getDay() - 1]
38823
38846
  } })] })] }), jsxRuntime.jsxs("div", { className: "d-flex border-top ms-50", style: { gap: 20, paddingTop: 10 }, children: [jsxRuntime.jsx("div", { className: "btn-today", onClick: () => {
38824
38847
  handleSelect(today, today);
38825
38848
  setOpen(false);
@@ -39024,7 +39047,7 @@ const HeaderTableCol = (props) => {
39024
39047
  top: `${indexParent * 42}px`,
39025
39048
  left: col.fixedType === 'left' ? objHeaderWidthFixLeft[`${indexParent}-${indexCol ?? 0}`] : undefined,
39026
39049
  right: col.fixedType === 'right' ? objHeaderWidthFixRight[`${indexParent}-${indexCol ?? 0}`] : undefined
39027
- }, children: jsxRuntime.jsxs("div", { style: { justifyContent: 'space-between' }, onClick: () => {
39050
+ }, children: jsxRuntime.jsxs("div", { style: { justifyContent: col.textAlign === 'center' ? 'center' : 'space-between' }, onClick: () => {
39028
39051
  if (!allowSorting || col.columns?.length) {
39029
39052
  return;
39030
39053
  }
@@ -39831,6 +39854,19 @@ const ToolbarBottom = ({ handleAdd, handleDuplicate, handleInsertBefore, handleI
39831
39854
  }), 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" })] }) })] }) })] })] }) }));
39832
39855
  };
39833
39856
 
39857
+ const RenderToolbarTop = ({ toolbarTopOption }) => {
39858
+ 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) => {
39859
+ return item.align === 'left' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
39860
+ }) }), jsxRuntime.jsx("div", { className: "r-toolbar-center", children: toolbarTopOption?.map((item, index) => {
39861
+ return item.align === 'center' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
39862
+ }) }), jsxRuntime.jsx("div", { className: "r-toolbar-right", children: toolbarTopOption?.map((item, index) => {
39863
+ return item.align === 'right' ? jsxRuntime.jsx(ToolBarElement, { item: item, index: index }) : '';
39864
+ }) })] }) }));
39865
+ };
39866
+ const ToolBarElement = ({ item, index }) => {
39867
+ return (jsxRuntime.jsx("div", { className: "r-toolbar-item", "aria-disabled": "false", children: item.template?.() }, `toolbar-top-${index}`));
39868
+ };
39869
+
39834
39870
  const TableEdit = React$5.forwardRef((props, ref) => {
39835
39871
  const { t } = reactI18next.useTranslation();
39836
39872
  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;
@@ -68702,8 +68738,10 @@ const RenderContentCol = (props) => {
68702
68738
  return element && element.scrollWidth > element.clientWidth;
68703
68739
  };
68704
68740
  const RenderElement = () => {
68705
- if (col.type === 'checkbox' && !col.field) {
68706
- return (jsxRuntime.jsx("div", { className: "r-rowcell-div cursor-pointer", style: { alignItems: 'center' }, onClick: (e) => {
68741
+ if (col.type === 'checkbox' || col.field === 'checkbox') {
68742
+ 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) => {
68743
+ console.log(isMulti);
68744
+ console.log(selectEnable);
68707
68745
  if (selectEnable) {
68708
68746
  const index = selectedRows?.findIndex((x) => x[fieldKey] === row[fieldKey]);
68709
68747
  if (index > -1) {
@@ -68751,7 +68789,8 @@ const RenderContentCol = (props) => {
68751
68789
  const suffix = isNegative ? formatSetting?.suffixNegative ?? '' : '';
68752
68790
  const displayText = isNegative ? `${prefix}${value}${suffix}` : value ?? '';
68753
68791
  return (jsxRuntime.jsxs("div", { className: classNames$1('r-rowcell-div'), style: {
68754
- fontWeight: row.sortOrder < 0 || row.sortOrder > 100000 ? 600 : 400
68792
+ fontWeight: row.sortOrder < 0 || row.sortOrder > 100000 || row.haveBoldType ? 600 : 400,
68793
+ fontStyle: row.haveItalicType ? 'italic' : 'normal'
68755
68794
  }, children: [jsxRuntime.jsx("div", { className: "r-cell-text", style: {
68756
68795
  display: 'flex',
68757
68796
  justifyContent: col.textAlign === 'center' ? 'center' : col.textAlign === 'right' ? 'flex-end' : 'flex-start',
@@ -68827,7 +68866,6 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68827
68866
  setContentColumns(rs.flat);
68828
68867
  return rs;
68829
68868
  }, [columns, settingColumns, groupSetting?.groupColumns]);
68830
- const optionGroupColumns = React$5.useMemo(() => contentColumns.map((x) => ({ ...x, headerDisplay: t(x.headerText) })), [contentColumns]);
68831
68869
  const firstColSpan = React$5.useMemo(() => {
68832
68870
  let count = 0;
68833
68871
  let index = 3;
@@ -68927,7 +68965,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68927
68965
  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 }) }));
68928
68966
  };
68929
68967
  const groupbtnTemplate = () => {
68930
- 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) => {
68968
+ 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) => {
68931
68969
  if (val) {
68932
68970
  groupColumns[0] = val.field;
68933
68971
  }
@@ -68935,7 +68973,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68935
68973
  groupColumns.pop();
68936
68974
  }
68937
68975
  setGroupColumns([...groupColumns]);
68938
- }, 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) => {
68976
+ }, 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) => {
68939
68977
  if (val) {
68940
68978
  groupColumns[1] = val.field;
68941
68979
  }
@@ -68943,7 +68981,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
68943
68981
  groupColumns.pop();
68944
68982
  }
68945
68983
  setGroupColumns([...groupColumns]);
68946
- }, 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) => {
68984
+ }, 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) => {
68947
68985
  if (groupSetting) {
68948
68986
  if (val) {
68949
68987
  groupColumns[2] = val.field;
@@ -69096,7 +69134,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69096
69134
  sumValue = '';
69097
69135
  }
69098
69136
  }
69099
- 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}`));
69137
+ 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(row[colSum.field] ?? '0') < 0 ? jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] }) : sumValue }) }, `group-sum-cell-${level}-${indexRow}-${indexCol}`));
69100
69138
  })] }), expand && jsxRuntime.jsx(RenderContent, { datas: row.children, level: level + 1 })] }, `row-${level}-${indexRow}`));
69101
69139
  }
69102
69140
  else {
@@ -69165,7 +69203,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
69165
69203
  left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
69166
69204
  right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined,
69167
69205
  textAlign: col.textAlign ? col.textAlign : 'left'
69168
- }, 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}`));
69206
+ }, children: jsxRuntime.jsx("div", { className: "r-footer-div", children: (item || col.haveSum === true) && Number(item?.value ?? '0') < 0 ? jsxRuntime.jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] }) : sumValue }) }, `summarycell-${indexCol}`));
69169
69207
  }) })) })] }), 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) => {
69170
69208
  return (jsxRuntime.jsxs("div", { className: "r-context-item", onClick: () => {
69171
69209
  handleCloseContext();