react-table-edit 1.5.31 → 1.5.33

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.
@@ -4,6 +4,8 @@ export interface IFPropsDetail {
4
4
  setColumn: any;
5
5
  openSidebar: boolean;
6
6
  handleSidebar: any;
7
+ resetDefaultColumns?: () => void;
8
+ formatSetting?: any;
7
9
  }
8
10
  declare const SidebarSetColumn: (props: IFPropsDetail) => import("react/jsx-runtime").JSX.Element;
9
11
  export default SidebarSetColumn;
@@ -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
- addMoveNewCell: () => void;
15
+ moveIndexRowToNewPage: () => 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) => 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;
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;
@@ -56,3 +56,4 @@ export declare const calculateTableStructure: (columns: any[], settingColumns?:
56
56
  */
57
57
  export declare const CheckRowMatch: (row: Record<string, any>, filters: IFFilterTable[], keyword: string, searchKeys: string[]) => boolean;
58
58
  export declare const getMaxExpandedLevel: (items: any[], fieldChildren?: string, level?: number) => number;
59
+ export declare const findItemInTree: (items: any[], filter: string, keyFilter?: string, keyChildren?: string) => any;
package/dist/index.d.ts CHANGED
@@ -802,6 +802,7 @@ declare const calculateTableStructure: (columns: any[], settingColumns?: IFSetti
802
802
  */
803
803
  declare const CheckRowMatch: (row: Record<string, any>, filters: IFFilterTable[], keyword: string, searchKeys: string[]) => boolean;
804
804
  declare const getMaxExpandedLevel: (items: any[], fieldChildren?: string, level?: number) => number;
805
+ declare const findItemInTree: (items: any[], filter: string, keyFilter?: string, keyChildren?: string) => any;
805
806
 
806
807
  type IFSteps = {
807
808
  id: string;
@@ -829,5 +830,5 @@ type IFProps = {
829
830
  };
830
831
  declare const Wizard: React.ForwardRefExoticComponent<IFProps & React.RefAttributes<unknown>>;
831
832
 
832
- export { CheckRowMatch, ExportExcelComponent, FindNodeByPath, InputStyleComponent, ModalImportComponent, SelectTable, SelectTableTree, TableView, TabsMenuComponent, Wizard, calculateTableStructure, checkDecimalSeparator, checkThousandSeparator, TableEdit as default, formartNumberic, formatDateTime, generateUUID, getMaxExpandedLevel, isNullOrUndefined, messageBoxConfirm, messageBoxConfirmAsync, messageBoxConfirmDelete, messageBoxError, messageHtmlBoxConfirm, messageHtmlBoxConfirmAsync, messageHtmlBoxError, notificationError, notificationSuccess, roundNumber, useOnClickOutside };
833
+ export { CheckRowMatch, ExportExcelComponent, FindNodeByPath, InputStyleComponent, ModalImportComponent, SelectTable, SelectTableTree, TableView, TabsMenuComponent, Wizard, calculateTableStructure, checkDecimalSeparator, checkThousandSeparator, TableEdit as default, findItemInTree, formartNumberic, formatDateTime, generateUUID, getMaxExpandedLevel, isNullOrUndefined, messageBoxConfirm, messageBoxConfirmAsync, messageBoxConfirmDelete, messageBoxError, messageHtmlBoxConfirm, messageHtmlBoxConfirmAsync, messageHtmlBoxError, notificationError, notificationSuccess, roundNumber, useOnClickOutside };
833
834
  export type { FromItemsField, ICellInfo, IColumnTable, IColumnType, IColumnsAgg, ICommandItem, IContextItem, IFColumnSelectTable, IFColumnSelectTableTree, IFCurrentPage, IFCurrentPageConfig, IFFilterTable, IFOrderTable, IFPageSize, IFSettingColumns, IFTableEditButton, IFTableEditFormat, IFTableEditPaging, IFTableEditSearchSetting, IFTableEditToolbar, IFTableSelectFormat, IFTableTreeSelectFormat, IFToolbarOptions, IFilterType, IHeaderColumnTable, ISettingFormElement, ISettingNumericElement, ISettingSelectElement };
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,
@@ -19811,7 +19849,8 @@ const formartNumberic = (str, decimalSeparator, thousandSeparator, fraction = 10
19811
19849
  const arr = value.toString().split(decimalSeparator ?? '', 2);
19812
19850
  let flag = value.toString().includes(decimalSeparator ?? '');
19813
19851
  if (arr[0].length < 3) {
19814
- return haveNegative ? arr[0] : arr[0].replace('-', '');
19852
+ const intergerArr = haveNegative ? arr[0] : arr[0].replace('-', '');
19853
+ return flag ? `${intergerArr}${decimalSeparator}${arr[1]?.substring(0, fraction) ?? ''}` : intergerArr;
19815
19854
  }
19816
19855
  else {
19817
19856
  let flagNegative = false;
@@ -19875,7 +19914,12 @@ const FindNodeByPath = (tree, path) => {
19875
19914
  node = current[level];
19876
19915
  current = current[level].children ?? [];
19877
19916
  }
19878
- return { parent: current, lastIndex: levels.at(-1), firstIndex: levels.length === 1 ? levels[0] : -1, node };
19917
+ return {
19918
+ parent: current,
19919
+ lastIndex: levels.at(-1),
19920
+ firstIndex: levels.length === 1 ? levels[0] : -1,
19921
+ node
19922
+ };
19879
19923
  };
19880
19924
  /**
19881
19925
  * Tính toán cấu trúc bảng từ dữ liệu column dạng cây:
@@ -20084,6 +20128,20 @@ const getMaxExpandedLevel = (items, fieldChildren = 'children', level = 0) => {
20084
20128
  });
20085
20129
  return max;
20086
20130
  };
20131
+ const findItemInTree = (items, filter, keyFilter = "value", keyChildren = "children") => {
20132
+ for (let index = 0; index < items.length; index++) {
20133
+ const item = items[index];
20134
+ if (item[keyFilter] === filter) {
20135
+ return { ...item };
20136
+ }
20137
+ else if (item[keyChildren]?.length > 0) {
20138
+ const itemFilter = findItemInTree(item[keyChildren], filter, keyFilter, keyChildren);
20139
+ if (itemFilter) {
20140
+ return itemFilter;
20141
+ }
20142
+ }
20143
+ }
20144
+ };
20087
20145
 
20088
20146
  const defaultMaxHeight$1 = 250;
20089
20147
  const SelectTable = React$5.forwardRef((props, ref) => {
@@ -31603,63 +31661,7 @@ class DateLib {
31603
31661
  formatNumber(value) {
31604
31662
  return this.replaceDigits(value.toString());
31605
31663
  }
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
- ]);
31664
+ }
31663
31665
  /**
31664
31666
  * The default date library with English locale.
31665
31667
  *
@@ -32555,7 +32557,7 @@ function getDefaultClassNames() {
32555
32557
  /**
32556
32558
  * Formats the caption of the month.
32557
32559
  *
32558
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32560
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32559
32561
  * @param month The date representing the month.
32560
32562
  * @param options Configuration options for the date library.
32561
32563
  * @param dateLib The date library to use for formatting. If not provided, a new
@@ -32565,8 +32567,7 @@ function getDefaultClassNames() {
32565
32567
  * @see https://daypicker.dev/docs/translation#custom-formatters
32566
32568
  */
32567
32569
  function formatCaption(month, options, dateLib) {
32568
- const lib = dateLib ?? new DateLib(options);
32569
- return lib.formatMonthYear(month);
32570
+ return (dateLib ?? new DateLib(options)).format(month, "LLLL y");
32570
32571
  }
32571
32572
  /**
32572
32573
  * @private
@@ -32860,7 +32861,7 @@ const labelDay = labelDayButton;
32860
32861
  * Generates the ARIA label for the month grid, which is announced when entering
32861
32862
  * the grid.
32862
32863
  *
32863
- * @defaultValue Locale-specific month/year order (e.g., "November 2022").
32864
+ * @defaultValue `LLLL y` (e.g., "November 2022").
32864
32865
  * @param date - The date representing the month.
32865
32866
  * @param options - Optional configuration for the date formatting library.
32866
32867
  * @param dateLib - An optional instance of the date formatting library.
@@ -32869,8 +32870,7 @@ const labelDay = labelDayButton;
32869
32870
  * @see https://daypicker.dev/docs/translation#aria-labels
32870
32871
  */
32871
32872
  function labelGrid(date, options, dateLib) {
32872
- const lib = dateLib ?? new DateLib(options);
32873
- return lib.formatMonthYear(date);
32873
+ return (dateLib ?? new DateLib(options)).format(date, "LLLL y");
32874
32874
  }
32875
32875
  /**
32876
32876
  * @ignore
@@ -34353,7 +34353,7 @@ function DayPicker(initialProps) {
34353
34353
  formatters,
34354
34354
  };
34355
34355
  return (React__default["default"].createElement(dayPickerContext.Provider, { value: contextValue },
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 },
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"], ...dataAttributes },
34357
34357
  React__default["default"].createElement(components.Months, { className: classNames[UI.Months], style: styles?.[UI.Months] },
34358
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 })),
34359
34359
  months.map((calendarMonth, displayIndex) => {
@@ -34365,16 +34365,10 @@ function DayPicker(initialProps) {
34365
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 },
34366
34366
  React__default["default"].createElement(components.Chevron, { disabled: previousMonth ? undefined : true, className: classNames[UI.Chevron], orientation: props.dir === "rtl" ? "right" : "left" }))),
34367
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] },
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
- })(),
34368
+ captionLayout === "dropdown" ||
34369
+ 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))),
34370
+ captionLayout === "dropdown" ||
34371
+ 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))),
34378
34372
  React__default["default"].createElement("span", { role: "status", "aria-live": "polite", style: {
34379
34373
  border: 0,
34380
34374
  clip: "rect(0 0 0 0)",
@@ -40060,7 +40054,13 @@ const TableEdit = React$5.forwardRef((props, ref) => {
40060
40054
  return;
40061
40055
  }
40062
40056
  let objCallback;
40063
- const ele = column.selectSettings?.options?.find((item) => item[column.selectSettings?.fieldValue ?? 'value'] === copyData);
40057
+ let ele;
40058
+ if (column.type === 'select') {
40059
+ ele = column.selectSettings?.options?.find((item) => item[column.selectSettings?.fieldValue ?? 'value'] === copyData);
40060
+ }
40061
+ else if (column.type === 'selectTree') {
40062
+ ele = findItemInTree(column.selectSettings?.options ?? [], copyData, column.selectSettings?.fieldValue ?? 'value');
40063
+ }
40064
40064
  if (ele) {
40065
40065
  objCallback = ele;
40066
40066
  }
@@ -69232,6 +69232,7 @@ exports.calculateTableStructure = calculateTableStructure;
69232
69232
  exports.checkDecimalSeparator = checkDecimalSeparator;
69233
69233
  exports.checkThousandSeparator = checkThousandSeparator;
69234
69234
  exports["default"] = TableEdit;
69235
+ exports.findItemInTree = findItemInTree;
69235
69236
  exports.formartNumberic = formartNumberic;
69236
69237
  exports.formatDateTime = formatDateTime;
69237
69238
  exports.generateUUID = generateUUID;