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/component/sidebar-setting-column/index.d.ts +2 -0
- package/dist/component/table/group-col.d.ts +6 -0
- package/dist/component/table/header.d.ts +0 -4
- package/dist/component/table-view/content.d.ts +0 -4
- package/dist/component/table-view/header.d.ts +1 -1
- package/dist/component/tree-table/key-handlers.d.ts +8 -8
- package/dist/component/type/index.d.ts +3 -2
- package/dist/component/utils.d.ts +1 -1
- package/dist/index.d.ts +4 -3
- package/dist/index.js +127 -133
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +127 -133
- package/dist/index.mjs.map +1 -1
- package/dist/styles/index.css +1 -24
- package/dist/styles/index.css.map +1 -1
- package/package.json +1 -1
- package/dist/component/input/input-date-gange/index.d.ts +0 -21
- package/dist/component/table/gourp-col.d.ts +0 -10
package/dist/index.mjs
CHANGED
|
@@ -5938,13 +5938,6 @@ var SvgBecoxyHandshake = function (_a) {
|
|
|
5938
5938
|
React$5.createElement("image", { id: "becoxy-handshake_svg__b", width: 512, height: 512, xlinkHref: "" }))));
|
|
5939
5939
|
};
|
|
5940
5940
|
|
|
5941
|
-
var SvgBecoxyHome2 = function (_a) {
|
|
5942
|
-
var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
|
|
5943
|
-
return (React$5.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
|
|
5944
|
-
title ? React$5.createElement("title", { id: titleId }, title) : null,
|
|
5945
|
-
React$5.createElement("path", { d: "M19.734 9.105V2.629h-4.218v2.274L12 1.403 0 13.352v1.463h2.86v7.782h8.421v-3.75h1.406v3.75h8.454v-7.781H24v-1.465l-4.266-4.247Zm-2.812-5.07h1.406v3.67l-1.406-1.401V4.035Zm2.812 9.375v7.782h-5.64v-3.75H9.875v3.75h-5.61V13.41h-2.33L12 3.387 22.065 13.41h-2.33Z", fill: props.color || "currentColor" })));
|
|
5946
|
-
};
|
|
5947
|
-
|
|
5948
5941
|
var SvgBecoxyHome = function (_a) {
|
|
5949
5942
|
var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
|
|
5950
5943
|
return (React$5.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
|
|
@@ -8988,6 +8981,13 @@ var SvgPieChart = function (_a) {
|
|
|
8988
8981
|
React$5.createElement("path", { d: "M22 12A10 10 0 0 0 12 2v10z" })));
|
|
8989
8982
|
};
|
|
8990
8983
|
|
|
8984
|
+
var SvgPin = function (_a) {
|
|
8985
|
+
var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
|
|
8986
|
+
return (React$5.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
|
|
8987
|
+
title ? React$5.createElement("title", { id: titleId }, title) : null,
|
|
8988
|
+
React$5.createElement("path", { d: "M14.743 1.083a.75.75 0 0 1 .53.219L22.7 8.727a.75.75 0 0 1 0 1.06c-.72.72-1.608.882-2.255.882-.265 0-.502-.027-.69-.058l-4.7 4.701c.123.499.203 1.007.24 1.52.068 1.052-.049 2.53-1.08 3.562a.75.75 0 0 1-1.061 0l-4.244-4.242-4.773 4.773c-.292.293-1.828 1.353-2.12 1.06-.293-.292.767-1.83 1.06-2.12l4.773-4.773-4.242-4.244a.75.75 0 0 1 0-1.06c1.032-1.032 2.51-1.151 3.562-1.08a9 9 0 0 1 1.52.24l4.7-4.7a4.488 4.488 0 0 1-.06-.691c0-.645.163-1.533.884-2.255a.75.75 0 0 1 .53-.219Zm.183 3.165v.003a.75.75 0 0 1-.183.765L9.44 10.317a.75.75 0 0 1-.766.18H8.67l-.021-.006a7.485 7.485 0 0 0-1.58-.288c-.633-.042-1.254.012-1.762.225l8.265 8.264c.211-.51.265-1.13.223-1.763a7.503 7.503 0 0 0-.288-1.581l-.006-.02a.755.755 0 0 1 .18-.769l5.304-5.302a.75.75 0 0 1 .798-.173l.144.033c.13.026.312.051.516.051a2.05 2.05 0 0 0 .515-.06L14.89 3.042a2.06 2.06 0 0 0-.06.515c.002.233.033.464.093.69l.002.001Z", fill: props.color || "currentColor", stroke: props.color || "currentColor", strokeWidth: 0.25 })));
|
|
8989
|
+
};
|
|
8990
|
+
|
|
8991
8991
|
var SvgPlayCircle = function (_a) {
|
|
8992
8992
|
var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
|
|
8993
8993
|
return (React$5.createElement("svg", __assign({ xmlns: "http://www.w3.org/2000/svg", width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: props.strokeWidth || 1.5, strokeLinecap: "round", strokeLinejoin: "round", className: "play-circle_svg__feather play-circle_svg__feather-play-circle", "aria-labelledby": titleId }, props),
|
|
@@ -9234,6 +9234,32 @@ var SvgShare2 = function (_a) {
|
|
|
9234
9234
|
React$5.createElement("path", { d: "m8.59 13.51 6.83 3.98M15.41 6.51l-6.82 3.98" })));
|
|
9235
9235
|
};
|
|
9236
9236
|
|
|
9237
|
+
var SvgShare3 = function (_a) {
|
|
9238
|
+
var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
|
|
9239
|
+
return (React$5.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
|
|
9240
|
+
title ? React$5.createElement("title", { id: titleId }, title) : null,
|
|
9241
|
+
React$5.createElement("g", { clipPath: "url(#share-3_svg__a)" },
|
|
9242
|
+
React$5.createElement("path", { d: "M9.643 2.693c.208 0 .408.09.555.248a.88.88 0 0 1 .23.599.88.88 0 0 1-.23.598.758.758 0 0 1-.555.248H4.928c-.625 0-1.224.267-1.666.743a2.64 2.64 0 0 0-.69 1.795V18.77c0 .673.248 1.318.69 1.794a2.275 2.275 0 0 0 1.666.744h11c.625 0 1.225-.268 1.667-.744a2.64 2.64 0 0 0 .69-1.794v-3.385a.88.88 0 0 1 .23-.598.758.758 0 0 1 .556-.248c.208 0 .408.09.555.248a.88.88 0 0 1 .23.598v3.385a4.4 4.4 0 0 1-1.15 2.99c-.737.794-1.736 1.24-2.778 1.24h-11c-1.041 0-2.04-.446-2.777-1.24A4.401 4.401 0 0 1 1 18.77V6.924c0-1.122.414-2.198 1.15-2.991.737-.794 1.737-1.24 2.778-1.24h4.715Zm5.154-1.607a.737.737 0 0 1 .828.093l7.071 5.923c.095.079.171.18.224.296a.9.9 0 0 1 0 .744.836.836 0 0 1-.224.297l-7.071 5.922a.738.738 0 0 1-.828.092.81.81 0 0 1-.321-.312.894.894 0 0 1-.12-.448v-2.496c-3.507.389-5.694 3.339-6.907 5.752l-.247.507a.816.816 0 0 1-.37.388c-.16.08-.34.1-.513.057a.782.782 0 0 1-.435-.299.888.888 0 0 1-.17-.525c0-3.513.814-6.669 2.415-8.968 1.474-2.116 3.593-3.464 6.228-3.688V1.847c0-.158.04-.314.118-.448a.81.81 0 0 1 .322-.313Zm1.131 4.146a.88.88 0 0 1-.23.598.758.758 0 0 1-.556.248c-2.498 0-4.426 1.139-5.754 3.046-.844 1.211-1.458 2.751-1.798 4.535 1.616-2.17 4.056-4.197 7.552-4.197.209 0 .409.09.556.248a.88.88 0 0 1 .23.598v1.655l5.005-4.193-5.005-4.195v1.657Z", fill: props.color || "currentColor", stroke: props.color || "currentColor", strokeWidth: 0.45 })),
|
|
9243
|
+
React$5.createElement("defs", null,
|
|
9244
|
+
React$5.createElement("clipPath", { id: "share-3_svg__a" },
|
|
9245
|
+
React$5.createElement("path", { fill: "#fff", d: "M0 0h24v24H0z" })))));
|
|
9246
|
+
};
|
|
9247
|
+
|
|
9248
|
+
var SvgShareBoxed = function (_a) {
|
|
9249
|
+
var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
|
|
9250
|
+
return (React$5.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
|
|
9251
|
+
title ? React$5.createElement("title", { id: titleId }, title) : null,
|
|
9252
|
+
React$5.createElement("path", { d: "M2.25 0C1.02 0 0 1.02 0 2.25v16.5C0 19.98 1.02 21 2.25 21h13.5c1.23 0 2.25-1.02 2.25-2.25V15h-2v4H2V2h7V0H2.25ZM18 0v3C11.85 3 6.9 7.62 6.18 13.59A5.958 5.958 0 0 1 12 9h6v3l6-6-6-6Z", fill: props.color || "currentColor" })));
|
|
9253
|
+
};
|
|
9254
|
+
|
|
9255
|
+
var SvgShareFilled = function (_a) {
|
|
9256
|
+
var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
|
|
9257
|
+
return (React$5.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
|
|
9258
|
+
title ? React$5.createElement("title", { id: titleId }, title) : null,
|
|
9259
|
+
React$5.createElement("path", { d: "M10.25 2c.199 0 .39.088.53.244.141.156.22.368.22.59a.882.882 0 0 1-.22.589.714.714 0 0 1-.53.244h-4.5c-.597 0-1.169.263-1.591.732A2.648 2.648 0 0 0 3.5 6.167v11.666c0 .663.237 1.3.659 1.768.422.469.994.732 1.591.732h10.5c.597 0 1.169-.263 1.591-.732a2.648 2.648 0 0 0 .659-1.768V14.5c0-.221.079-.433.22-.59a.714.714 0 0 1 .53-.243c.199 0 .39.088.53.244.141.156.22.368.22.589v3.333c0 1.105-.395 2.165-1.098 2.947-.704.781-1.657 1.22-2.652 1.22H5.75c-.995 0-1.948-.439-2.652-1.22C2.395 19.998 2 18.938 2 17.833V6.167c0-1.105.395-2.165 1.098-2.947C3.802 2.44 4.755 2 5.75 2h4.5Z", fill: props.color || "currentColor", stroke: props.color || "currentColor", strokeWidth: 0.5 }),
|
|
9260
|
+
React$5.createElement("path", { d: "M14.67 2.325a.75.75 0 0 1 .79.083l6.75 5.25a.75.75 0 0 1 0 1.185l-6.75 5.25a.75.75 0 0 1-1.21-.593v-2.212c-3.348.345-5.436 2.96-6.594 5.098l-.236.45A.75.75 0 0 1 6 16.5c0-3.114.777-5.911 2.306-7.95 1.407-1.875 3.429-3.07 5.944-3.268V3a.75.75 0 0 1 .42-.675Z", fill: props.color || "currentColor" })));
|
|
9261
|
+
};
|
|
9262
|
+
|
|
9237
9263
|
var SvgShare = function (_a) {
|
|
9238
9264
|
var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
|
|
9239
9265
|
return (React$5.createElement("svg", __assign({ xmlns: "http://www.w3.org/2000/svg", width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: props.strokeWidth || 1.5, strokeLinecap: "round", strokeLinejoin: "round", className: "share_svg__feather share_svg__feather-share", "aria-labelledby": titleId }, props),
|
|
@@ -9410,6 +9436,14 @@ var SvgSortDecending = function (_a) {
|
|
|
9410
9436
|
React$5.createElement("path", { d: "M15 5v17h2V8h4l-6-6v3Z", fill: props.color || "currentColor" })));
|
|
9411
9437
|
};
|
|
9412
9438
|
|
|
9439
|
+
var SvgSpeakerPhone = function (_a) {
|
|
9440
|
+
var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
|
|
9441
|
+
return (React$5.createElement("svg", __assign({ width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", strokeWidth: props.strokeWidth || 1.5, "aria-labelledby": titleId }, props),
|
|
9442
|
+
title ? React$5.createElement("title", { id: titleId }, title) : null,
|
|
9443
|
+
React$5.createElement("path", { d: "M19.334 6.863a3.666 3.666 0 0 1 0 7.333M9.557 6.863v13.444a1.222 1.222 0 0 1-1.222 1.222H7.113a1.222 1.222 0 0 1-1.222-1.222v-6.111", stroke: props.color || "currentColor", strokeWidth: 1.6, strokeLinecap: "round", strokeLinejoin: "round" }),
|
|
9444
|
+
React$5.createElement("path", { d: "m12 6.863 5.528-4.608a1.1 1.1 0 0 1 1.804.846v14.857a1.1 1.1 0 0 1-1.804.846L12 14.196H2.222A1.222 1.222 0 0 1 1 12.974v-4.89a1.222 1.222 0 0 1 1.222-1.221H12Z", stroke: props.color || "currentColor", strokeWidth: 1.6, strokeLinecap: "round", strokeLinejoin: "round" })));
|
|
9445
|
+
};
|
|
9446
|
+
|
|
9413
9447
|
var SvgSpeaker = function (_a) {
|
|
9414
9448
|
var title = _a.title, titleId = _a.titleId, props = __rest$1(_a, ["title", "titleId"]);
|
|
9415
9449
|
return (React$5.createElement("svg", __assign({ xmlns: "http://www.w3.org/2000/svg", width: props.fontSize || 24, height: props.fontSize || 24, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: props.strokeWidth || 1.5, strokeLinecap: "round", strokeLinejoin: "round", className: "speaker_svg__feather speaker_svg__feather-speaker", "aria-labelledby": titleId }, props),
|
|
@@ -10080,7 +10114,6 @@ var Icon = /*#__PURE__*/Object.freeze({
|
|
|
10080
10114
|
BecoxyGrowth: SvgBecoxyGrowth,
|
|
10081
10115
|
BecoxyHandshake: SvgBecoxyHandshake,
|
|
10082
10116
|
BecoxyHome: SvgBecoxyHome,
|
|
10083
|
-
BecoxyHome2: SvgBecoxyHome2,
|
|
10084
10117
|
BecoxyHospital: SvgBecoxyHospital,
|
|
10085
10118
|
BecoxyHrm: SvgBecoxyHrm,
|
|
10086
10119
|
BecoxyImportWarehouse: SvgBecoxyImportWarehouse,
|
|
@@ -10408,6 +10441,7 @@ var Icon = /*#__PURE__*/Object.freeze({
|
|
|
10408
10441
|
PhoneOff: SvgPhoneOff,
|
|
10409
10442
|
PhoneOutgoing: SvgPhoneOutgoing,
|
|
10410
10443
|
PieChart: SvgPieChart,
|
|
10444
|
+
Pin: SvgPin,
|
|
10411
10445
|
Play: SvgPlay,
|
|
10412
10446
|
PlayCircle: SvgPlayCircle,
|
|
10413
10447
|
Plus: SvgPlus,
|
|
@@ -10438,6 +10472,9 @@ var Icon = /*#__PURE__*/Object.freeze({
|
|
|
10438
10472
|
Settings: SvgSettings,
|
|
10439
10473
|
Share: SvgShare,
|
|
10440
10474
|
Share2: SvgShare2,
|
|
10475
|
+
Share3: SvgShare3,
|
|
10476
|
+
ShareBoxed: SvgShareBoxed,
|
|
10477
|
+
ShareFilled: SvgShareFilled,
|
|
10441
10478
|
Shield: SvgShield,
|
|
10442
10479
|
ShieldOff: SvgShieldOff,
|
|
10443
10480
|
ShoppingBag: SvgShoppingBag,
|
|
@@ -10459,6 +10496,7 @@ var Icon = /*#__PURE__*/Object.freeze({
|
|
|
10459
10496
|
SortCancel: SvgSortCancel,
|
|
10460
10497
|
SortDecending: SvgSortDecending,
|
|
10461
10498
|
Speaker: SvgSpeaker,
|
|
10499
|
+
SpeakerPhone: SvgSpeakerPhone,
|
|
10462
10500
|
Square: SvgSquare,
|
|
10463
10501
|
Star: SvgStar,
|
|
10464
10502
|
StarFill: SvgStarFill,
|
|
@@ -19864,7 +19902,7 @@ const FindNodeByPath = (tree, path) => {
|
|
|
19864
19902
|
* fisrtObjWidthFixRight: number // Chỉ số cột đầu tiên fixed right
|
|
19865
19903
|
* }
|
|
19866
19904
|
*/
|
|
19867
|
-
const calculateTableStructure = (columns, settingColumns) => {
|
|
19905
|
+
const calculateTableStructure = (columns, settingColumns, groupColumns) => {
|
|
19868
19906
|
const levels = [];
|
|
19869
19907
|
const flat = [];
|
|
19870
19908
|
const objWidthFixLeft = {};
|
|
@@ -19898,9 +19936,7 @@ const calculateTableStructure = (columns, settingColumns) => {
|
|
|
19898
19936
|
if (!cell.visibleLocked) {
|
|
19899
19937
|
cell.visible = setting.visible ?? true;
|
|
19900
19938
|
}
|
|
19901
|
-
|
|
19902
|
-
cell.fixedType = setting.fixedType;
|
|
19903
|
-
}
|
|
19939
|
+
cell.fixedType = setting.fixedType;
|
|
19904
19940
|
if (setting.width !== undefined && setting.width !== null) {
|
|
19905
19941
|
cell.width = setting.width;
|
|
19906
19942
|
}
|
|
@@ -19912,7 +19948,7 @@ const calculateTableStructure = (columns, settingColumns) => {
|
|
|
19912
19948
|
cell.numericSettings = { fraction: setting.fraction };
|
|
19913
19949
|
}
|
|
19914
19950
|
}
|
|
19915
|
-
cell.headerDisplay = setting.headerText || cell.headerText;
|
|
19951
|
+
cell.headerDisplay = setting.headerText || (cell.headerDisplay ?? cell.headerText);
|
|
19916
19952
|
}
|
|
19917
19953
|
else {
|
|
19918
19954
|
if (cell.columns?.length) {
|
|
@@ -19931,6 +19967,7 @@ const calculateTableStructure = (columns, settingColumns) => {
|
|
|
19931
19967
|
}
|
|
19932
19968
|
}
|
|
19933
19969
|
}
|
|
19970
|
+
cell.isGroup = groupColumns?.includes(cell.field);
|
|
19934
19971
|
return cell;
|
|
19935
19972
|
});
|
|
19936
19973
|
};
|
|
@@ -19951,7 +19988,7 @@ const calculateTableStructure = (columns, settingColumns) => {
|
|
|
19951
19988
|
};
|
|
19952
19989
|
levels[level].push(cell);
|
|
19953
19990
|
const headerKey = `${level}-${indexCol}`;
|
|
19954
|
-
if (cell.fixedType === 'left' && cell.visible !== false) {
|
|
19991
|
+
if (cell.fixedType === 'left' && cell.visible !== false && cell.isGroup !== true) {
|
|
19955
19992
|
objHeaderWidthFixLeft[headerKey] = leftTotal;
|
|
19956
19993
|
}
|
|
19957
19994
|
if (!hasChildren) {
|
|
@@ -19959,16 +19996,16 @@ const calculateTableStructure = (columns, settingColumns) => {
|
|
|
19959
19996
|
const width = cell.width ?? 40;
|
|
19960
19997
|
cell.index = index;
|
|
19961
19998
|
flat.push(cell);
|
|
19962
|
-
if (cell.fixedType === 'left' && cell.visible !== false) {
|
|
19999
|
+
if (cell.fixedType === 'left' && cell.visible !== false && cell.isGroup !== true) {
|
|
19963
20000
|
objWidthFixLeft[index] = leftTotal;
|
|
19964
20001
|
leftTotal += width;
|
|
19965
20002
|
}
|
|
19966
|
-
if (cell.fixedType === 'right' && cell.visible !== false) {
|
|
20003
|
+
if (cell.fixedType === 'right' && cell.visible !== false && cell.isGroup !== true) {
|
|
19967
20004
|
rightTotal -= width;
|
|
19968
20005
|
objWidthFixRight[index] = rightTotal;
|
|
19969
20006
|
}
|
|
19970
20007
|
}
|
|
19971
|
-
if (cell.fixedType === 'right' && cell.visible !== false) {
|
|
20008
|
+
if (cell.fixedType === 'right' && cell.visible !== false && cell.isGroup !== true) {
|
|
19972
20009
|
objHeaderWidthFixRight[headerKey] = rightTotal;
|
|
19973
20010
|
}
|
|
19974
20011
|
return colspanSum + colspan;
|
|
@@ -20501,19 +20538,6 @@ const ReactInput = (props) => {
|
|
|
20501
20538
|
}), value: value, onChange: (val) => setValue(val.target.value) }), value ? jsx(SvgX, { className: 'input__clear-icon', onClick: handelClear, strokeWidth: 3, fontSize: 16 }) : ''] }));
|
|
20502
20539
|
};
|
|
20503
20540
|
|
|
20504
|
-
const RenderToolbarTop = ({ toolbarTopOption }) => {
|
|
20505
|
-
return (jsx("div", { id: "table_custom_top_toolbar", className: "r-toolbar r-toolbar-top", "aria-orientation": "horizontal", children: jsxs("div", { className: "r-toolbar-items", children: [jsx("div", { className: "r-toolbar-left", children: toolbarTopOption?.map((item, index) => {
|
|
20506
|
-
return item.align === 'left' ? jsx(ToolBarElement, { item: item, index: index }) : '';
|
|
20507
|
-
}) }), jsx("div", { className: "r-toolbar-center", children: toolbarTopOption?.map((item, index) => {
|
|
20508
|
-
return item.align === 'center' ? jsx(ToolBarElement, { item: item, index: index }) : '';
|
|
20509
|
-
}) }), jsx("div", { className: "r-toolbar-right", children: toolbarTopOption?.map((item, index) => {
|
|
20510
|
-
return item.align === 'right' ? jsx(ToolBarElement, { item: item, index: index }) : '';
|
|
20511
|
-
}) })] }) }));
|
|
20512
|
-
};
|
|
20513
|
-
const ToolBarElement = ({ item, index }) => {
|
|
20514
|
-
return (jsx("div", { className: "r-toolbar-item", "aria-disabled": "false", children: item.template?.() }, `toolbar-top-${index}`));
|
|
20515
|
-
};
|
|
20516
|
-
|
|
20517
20541
|
const handleAdd = (dataSource, containerRef, indexFirstEdit,
|
|
20518
20542
|
/*eslint-disable*/
|
|
20519
20543
|
changeDataSource, handleFocusCell,
|
|
@@ -31588,63 +31612,7 @@ class DateLib {
|
|
|
31588
31612
|
formatNumber(value) {
|
|
31589
31613
|
return this.replaceDigits(value.toString());
|
|
31590
31614
|
}
|
|
31591
|
-
|
|
31592
|
-
* Returns the preferred ordering for month and year labels for the current
|
|
31593
|
-
* locale.
|
|
31594
|
-
*/
|
|
31595
|
-
getMonthYearOrder() {
|
|
31596
|
-
const code = this.options.locale?.code;
|
|
31597
|
-
if (!code) {
|
|
31598
|
-
return "month-first";
|
|
31599
|
-
}
|
|
31600
|
-
return DateLib.yearFirstLocales.has(code) ? "year-first" : "month-first";
|
|
31601
|
-
}
|
|
31602
|
-
/**
|
|
31603
|
-
* Formats the month/year pair respecting locale conventions.
|
|
31604
|
-
*
|
|
31605
|
-
* @since 9.11.0
|
|
31606
|
-
*/
|
|
31607
|
-
formatMonthYear(date) {
|
|
31608
|
-
const { locale, timeZone, numerals } = this.options;
|
|
31609
|
-
const localeCode = locale?.code;
|
|
31610
|
-
if (localeCode && DateLib.yearFirstLocales.has(localeCode)) {
|
|
31611
|
-
try {
|
|
31612
|
-
const intl = new Intl.DateTimeFormat(localeCode, {
|
|
31613
|
-
month: "long",
|
|
31614
|
-
year: "numeric",
|
|
31615
|
-
timeZone,
|
|
31616
|
-
numberingSystem: numerals,
|
|
31617
|
-
});
|
|
31618
|
-
const formatted = intl.format(date);
|
|
31619
|
-
return formatted;
|
|
31620
|
-
}
|
|
31621
|
-
catch {
|
|
31622
|
-
// Fallback to date-fns formatting below.
|
|
31623
|
-
}
|
|
31624
|
-
}
|
|
31625
|
-
const pattern = this.getMonthYearOrder() === "year-first" ? "y LLLL" : "LLLL y";
|
|
31626
|
-
return this.format(date, pattern);
|
|
31627
|
-
}
|
|
31628
|
-
}
|
|
31629
|
-
DateLib.yearFirstLocales = new Set([
|
|
31630
|
-
"eu",
|
|
31631
|
-
"hu",
|
|
31632
|
-
"ja",
|
|
31633
|
-
"ja-Hira",
|
|
31634
|
-
"ja-JP",
|
|
31635
|
-
"ko",
|
|
31636
|
-
"ko-KR",
|
|
31637
|
-
"lt",
|
|
31638
|
-
"lt-LT",
|
|
31639
|
-
"lv",
|
|
31640
|
-
"lv-LV",
|
|
31641
|
-
"mn",
|
|
31642
|
-
"mn-MN",
|
|
31643
|
-
"zh",
|
|
31644
|
-
"zh-CN",
|
|
31645
|
-
"zh-HK",
|
|
31646
|
-
"zh-TW",
|
|
31647
|
-
]);
|
|
31615
|
+
}
|
|
31648
31616
|
/**
|
|
31649
31617
|
* The default date library with English locale.
|
|
31650
31618
|
*
|
|
@@ -32540,7 +32508,7 @@ function getDefaultClassNames() {
|
|
|
32540
32508
|
/**
|
|
32541
32509
|
* Formats the caption of the month.
|
|
32542
32510
|
*
|
|
32543
|
-
* @defaultValue
|
|
32511
|
+
* @defaultValue `LLLL y` (e.g., "November 2022").
|
|
32544
32512
|
* @param month The date representing the month.
|
|
32545
32513
|
* @param options Configuration options for the date library.
|
|
32546
32514
|
* @param dateLib The date library to use for formatting. If not provided, a new
|
|
@@ -32550,8 +32518,7 @@ function getDefaultClassNames() {
|
|
|
32550
32518
|
* @see https://daypicker.dev/docs/translation#custom-formatters
|
|
32551
32519
|
*/
|
|
32552
32520
|
function formatCaption(month, options, dateLib) {
|
|
32553
|
-
|
|
32554
|
-
return lib.formatMonthYear(month);
|
|
32521
|
+
return (dateLib ?? new DateLib(options)).format(month, "LLLL y");
|
|
32555
32522
|
}
|
|
32556
32523
|
/**
|
|
32557
32524
|
* @private
|
|
@@ -32845,7 +32812,7 @@ const labelDay = labelDayButton;
|
|
|
32845
32812
|
* Generates the ARIA label for the month grid, which is announced when entering
|
|
32846
32813
|
* the grid.
|
|
32847
32814
|
*
|
|
32848
|
-
* @defaultValue
|
|
32815
|
+
* @defaultValue `LLLL y` (e.g., "November 2022").
|
|
32849
32816
|
* @param date - The date representing the month.
|
|
32850
32817
|
* @param options - Optional configuration for the date formatting library.
|
|
32851
32818
|
* @param dateLib - An optional instance of the date formatting library.
|
|
@@ -32854,8 +32821,7 @@ const labelDay = labelDayButton;
|
|
|
32854
32821
|
* @see https://daypicker.dev/docs/translation#aria-labels
|
|
32855
32822
|
*/
|
|
32856
32823
|
function labelGrid(date, options, dateLib) {
|
|
32857
|
-
|
|
32858
|
-
return lib.formatMonthYear(date);
|
|
32824
|
+
return (dateLib ?? new DateLib(options)).format(date, "LLLL y");
|
|
32859
32825
|
}
|
|
32860
32826
|
/**
|
|
32861
32827
|
* @ignore
|
|
@@ -34338,7 +34304,7 @@ function DayPicker(initialProps) {
|
|
|
34338
34304
|
formatters,
|
|
34339
34305
|
};
|
|
34340
34306
|
return (React__default.createElement(dayPickerContext.Provider, { value: contextValue },
|
|
34341
|
-
React__default.createElement(components.Root, { rootRef: props.animate ? rootElRef : undefined, className: className, style: style, dir: props.dir, id: props.id, lang: props.lang, nonce: props.nonce, title: props.title, role: props.role, "aria-label": props["aria-label"],
|
|
34307
|
+
React__default.createElement(components.Root, { rootRef: props.animate ? rootElRef : undefined, className: className, style: style, dir: props.dir, id: props.id, lang: props.lang, nonce: props.nonce, title: props.title, role: props.role, "aria-label": props["aria-label"], ...dataAttributes },
|
|
34342
34308
|
React__default.createElement(components.Months, { className: classNames[UI.Months], style: styles?.[UI.Months] },
|
|
34343
34309
|
!props.hideNavigation && !navLayout && (React__default.createElement(components.Nav, { "data-animated-nav": props.animate ? "true" : undefined, className: classNames[UI.Nav], style: styles?.[UI.Nav], "aria-label": labelNav(), onPreviousClick: handlePreviousClick, onNextClick: handleNextClick, previousMonth: previousMonth, nextMonth: nextMonth })),
|
|
34344
34310
|
months.map((calendarMonth, displayIndex) => {
|
|
@@ -34350,16 +34316,10 @@ function DayPicker(initialProps) {
|
|
|
34350
34316
|
displayIndex === 0 && (React__default.createElement(components.PreviousMonthButton, { type: "button", className: classNames[UI.PreviousMonthButton], tabIndex: previousMonth ? undefined : -1, "aria-disabled": previousMonth ? undefined : true, "aria-label": labelPrevious(previousMonth), onClick: handlePreviousClick, "data-animated-button": props.animate ? "true" : undefined },
|
|
34351
34317
|
React__default.createElement(components.Chevron, { disabled: previousMonth ? undefined : true, className: classNames[UI.Chevron], orientation: props.dir === "rtl" ? "right" : "left" }))),
|
|
34352
34318
|
React__default.createElement(components.MonthCaption, { "data-animated-caption": props.animate ? "true" : undefined, className: classNames[UI.MonthCaption], style: styles?.[UI.MonthCaption], calendarMonth: calendarMonth, displayIndex: displayIndex }, captionLayout?.startsWith("dropdown") ? (React__default.createElement(components.DropdownNav, { className: classNames[UI.Dropdowns], style: styles?.[UI.Dropdowns] },
|
|
34353
|
-
|
|
34354
|
-
|
|
34355
|
-
|
|
34356
|
-
|
|
34357
|
-
captionLayout === "dropdown-years" ? (React__default.createElement(components.YearsDropdown, { key: "year", className: classNames[UI.YearsDropdown], "aria-label": labelYearDropdown(dateLib.options), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleYearChange(calendarMonth.date), options: getYearOptions(navStart, navEnd, formatters, dateLib, Boolean(props.reverseYears)), style: styles?.[UI.Dropdown], value: dateLib.getYear(calendarMonth.date) })) : (React__default.createElement("span", { key: "year" }, formatYearDropdown(calendarMonth.date, dateLib)));
|
|
34358
|
-
const controls = dateLib.getMonthYearOrder() === "year-first"
|
|
34359
|
-
? [yearControl, monthControl]
|
|
34360
|
-
: [monthControl, yearControl];
|
|
34361
|
-
return controls;
|
|
34362
|
-
})(),
|
|
34319
|
+
captionLayout === "dropdown" ||
|
|
34320
|
+
captionLayout === "dropdown-months" ? (React__default.createElement(components.MonthsDropdown, { className: classNames[UI.MonthsDropdown], "aria-label": labelMonthDropdown(), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleMonthChange(calendarMonth.date), options: getMonthOptions(calendarMonth.date, navStart, navEnd, formatters, dateLib), style: styles?.[UI.Dropdown], value: dateLib.getMonth(calendarMonth.date) })) : (React__default.createElement("span", null, formatMonthDropdown(calendarMonth.date, dateLib))),
|
|
34321
|
+
captionLayout === "dropdown" ||
|
|
34322
|
+
captionLayout === "dropdown-years" ? (React__default.createElement(components.YearsDropdown, { className: classNames[UI.YearsDropdown], "aria-label": labelYearDropdown(dateLib.options), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleYearChange(calendarMonth.date), options: getYearOptions(navStart, navEnd, formatters, dateLib, Boolean(props.reverseYears)), style: styles?.[UI.Dropdown], value: dateLib.getYear(calendarMonth.date) })) : (React__default.createElement("span", null, formatYearDropdown(calendarMonth.date, dateLib))),
|
|
34363
34323
|
React__default.createElement("span", { role: "status", "aria-live": "polite", style: {
|
|
34364
34324
|
border: 0,
|
|
34365
34325
|
clip: "rect(0 0 0 0)",
|
|
@@ -36809,9 +36769,8 @@ const FooterCol = ({ col, indexCol, dataSource, objWidthFix, formatSetting }) =>
|
|
|
36809
36769
|
}, children: jsx("div", { className: "r-footer-div", children: col.haveSum === true && col.type === "numeric" && (jsx(Fragment$1, { children: Number(sumValue) >= 0 ? (jsx(Fragment$1, { children: formartNumberic(sumValue, formatSetting?.decimalSeparator ?? ",", formatSetting?.thousandSeparator ?? ".", col.numericSettings?.fraction, true, false) })) : (jsx("div", { style: { color: formatSetting?.colorNegative ?? "red" }, children: `${formatSetting?.prefixNegative ?? "-"}${formartNumberic(sumValue, formatSetting?.decimalSeparator ?? ",", formatSetting?.thousandSeparator ?? ".", col.numericSettings?.fraction, true, false)}${formatSetting?.suffixNegative ?? ""}` })) })) }) })) }, `summarycell-${indexCol}`));
|
|
36810
36770
|
};
|
|
36811
36771
|
|
|
36812
|
-
const RenderColGroup = ({ contentColumns
|
|
36813
|
-
return (col.visible !== false &&
|
|
36814
|
-
(groupSetting?.visibleGroupColumn || !groupSetting?.groupColumns?.includes(col.field)) && (jsx("col", { style: {
|
|
36772
|
+
const RenderColGroup = ({ contentColumns }) => (jsx("colgroup", { children: contentColumns.map((col, index) => {
|
|
36773
|
+
return (col.visible !== false && col.isGroup !== true && (jsx("col", { style: {
|
|
36815
36774
|
width: typeof col.width === 'number' ? `${col.width}px` : col.width || undefined,
|
|
36816
36775
|
minWidth: typeof col.minWidth === 'number' ? `${col.minWidth}px` : col.minWidth || undefined,
|
|
36817
36776
|
maxWidth: typeof col.maxWidth === 'number' ? `${col.maxWidth}px` : col.maxWidth || undefined
|
|
@@ -38703,7 +38662,7 @@ const DateRangePicker = forwardRef((props, ref) => {
|
|
|
38703
38662
|
setViewDateTo(selectedTo || today);
|
|
38704
38663
|
}
|
|
38705
38664
|
else if (!newRange.from || (selected && selected < newRange.from)) {
|
|
38706
|
-
newRange = { from: selected, to };
|
|
38665
|
+
newRange = { from: selected, to: undefined };
|
|
38707
38666
|
setViewDateFrom(selected || today);
|
|
38708
38667
|
}
|
|
38709
38668
|
else if (newRange.from && selected && selected > newRange.from && (!newRange.to || selected < newRange.to)) {
|
|
@@ -38714,6 +38673,16 @@ const DateRangePicker = forwardRef((props, ref) => {
|
|
|
38714
38673
|
newRange = { from, to: selected };
|
|
38715
38674
|
setViewDateTo(selected || today);
|
|
38716
38675
|
}
|
|
38676
|
+
else if (newRange.from && !selected) {
|
|
38677
|
+
if (newRange.to) {
|
|
38678
|
+
newRange = { from: newRange.to, to };
|
|
38679
|
+
setViewDateFrom(newRange.to || today);
|
|
38680
|
+
}
|
|
38681
|
+
else {
|
|
38682
|
+
newRange = { from, to: newRange.from };
|
|
38683
|
+
setViewDateTo(newRange.from || today);
|
|
38684
|
+
}
|
|
38685
|
+
}
|
|
38717
38686
|
onChange(newRange);
|
|
38718
38687
|
setInputValue(formatDisplay(newRange.from, newRange.to));
|
|
38719
38688
|
};
|
|
@@ -38771,7 +38740,10 @@ const DateRangePicker = forwardRef((props, ref) => {
|
|
|
38771
38740
|
const newDate = new Date(viewDateFrom);
|
|
38772
38741
|
newDate.setFullYear(newYear);
|
|
38773
38742
|
setViewDateFrom(newDate);
|
|
38774
|
-
}, value: {
|
|
38743
|
+
}, value: {
|
|
38744
|
+
value: viewDateFrom.getFullYear(),
|
|
38745
|
+
label: viewDateFrom.getFullYear()
|
|
38746
|
+
} }) })] }), jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
|
|
38775
38747
|
const newDate = new Date(viewDateFrom);
|
|
38776
38748
|
newDate.setMonth(viewDateFrom.getMonth() + 1);
|
|
38777
38749
|
setViewDateFrom(newDate);
|
|
@@ -38783,6 +38755,8 @@ const DateRangePicker = forwardRef((props, ref) => {
|
|
|
38783
38755
|
inRange: 'rdp-in-range',
|
|
38784
38756
|
rangeStart: 'rdp-selected',
|
|
38785
38757
|
rangeEnd: 'rdp-selected'
|
|
38758
|
+
}, formatters: {
|
|
38759
|
+
formatWeekdayName: (day) => [t('Su'), t('Mo'), t('Tu'), t('We'), t('Th'), t('Fr'), t('Sa')][day.getDay() === 0 ? 6 : day.getDay() - 1]
|
|
38786
38760
|
} })] }), jsxs("div", { children: [jsxs("div", { className: "select-month-year", children: [jsx(SvgChevronLeft, { cursor: 'pointer', fontSize: 22, onClick: () => {
|
|
38787
38761
|
const newDate = new Date(viewDateTo);
|
|
38788
38762
|
newDate.setMonth(viewDateTo.getMonth() - 1);
|
|
@@ -38797,7 +38771,10 @@ const DateRangePicker = forwardRef((props, ref) => {
|
|
|
38797
38771
|
const newDate = new Date(viewDateTo);
|
|
38798
38772
|
newDate.setFullYear(newYear);
|
|
38799
38773
|
setViewDateTo(newDate);
|
|
38800
|
-
}, value: {
|
|
38774
|
+
}, value: {
|
|
38775
|
+
value: viewDateTo.getFullYear(),
|
|
38776
|
+
label: viewDateTo.getFullYear()
|
|
38777
|
+
} }) })] }), jsx(SvgChevronRight, { cursor: 'pointer', fontSize: 22, onClick: () => {
|
|
38801
38778
|
const newDate = new Date(viewDateTo);
|
|
38802
38779
|
newDate.setMonth(viewDateTo.getMonth() + 1);
|
|
38803
38780
|
setViewDateTo(newDate);
|
|
@@ -38809,6 +38786,8 @@ const DateRangePicker = forwardRef((props, ref) => {
|
|
|
38809
38786
|
inRange: 'rdp-in-range',
|
|
38810
38787
|
rangeStart: 'rdp-selected',
|
|
38811
38788
|
rangeEnd: 'rdp-selected'
|
|
38789
|
+
}, formatters: {
|
|
38790
|
+
formatWeekdayName: (day) => [t('Su'), t('Mo'), t('Tu'), t('We'), t('Th'), t('Fr'), t('Sa')][day.getDay() === 0 ? 6 : day.getDay() - 1]
|
|
38812
38791
|
} })] })] }), jsxs("div", { className: "d-flex border-top ms-50", style: { gap: 20, paddingTop: 10 }, children: [jsx("div", { className: "btn-today", onClick: () => {
|
|
38813
38792
|
handleSelect(today, today);
|
|
38814
38793
|
setOpen(false);
|
|
@@ -38990,7 +38969,7 @@ const DateRangeFilterComponent = ({ fieldFilter, filterBy, handleSave }) => {
|
|
|
38990
38969
|
};
|
|
38991
38970
|
|
|
38992
38971
|
const HeaderTableCol = (props) => {
|
|
38993
|
-
const { selectEnable, dataSource, setSelectedRows, col, indexCol, indexParent, objHeaderWidthFixLeft, objHeaderWidthFixRight, totalCount, selectedRows, columns, orderBy, changeFilter, filterBy, changeOrder, allowFiltering, allowSorting, container, fisrtObjWidthFixRight, lastObjWidthFixLeft, setContentColumns, formatSetting, optionsFilter, idTable, isMulti
|
|
38972
|
+
const { selectEnable, dataSource, setSelectedRows, col, indexCol, indexParent, objHeaderWidthFixLeft, objHeaderWidthFixRight, totalCount, selectedRows, columns, orderBy, changeFilter, filterBy, changeOrder, allowFiltering, allowSorting, container, fisrtObjWidthFixRight, lastObjWidthFixLeft, setContentColumns, formatSetting, optionsFilter, idTable, isMulti } = props;
|
|
38994
38973
|
const { t } = useTranslation();
|
|
38995
38974
|
const headerRef = useRef(null);
|
|
38996
38975
|
const order = orderBy.find((item) => item.key === col.field);
|
|
@@ -39009,11 +38988,11 @@ const HeaderTableCol = (props) => {
|
|
|
39009
38988
|
const checkOverflow = () => {
|
|
39010
38989
|
return headerRef.current && headerRef.current.scrollHeight > headerRef.current.clientHeight;
|
|
39011
38990
|
};
|
|
39012
|
-
return (jsx(Fragment, { children: col.visible !== false &&
|
|
38991
|
+
return (jsx(Fragment, { children: col.visible !== false && col.isGroup !== true && (jsx(Resizable, { className: "r-resize", width: typeof col.width === 'number' ? col.width : Number((col.width ?? '').replaceAll(new RegExp(`[^0-9]`, 'g'), '')), height: 0, onResize: handleResize, draggableOpts: { enableUserSelectHack: true }, children: jsx("th", { rowSpan: col.rowspan !== 1 ? col.rowspan : 1, colSpan: col.columns?.filter((x) => x.visible !== false)?.length ?? 1, className: classNames$1(`r-headercell fix-${col.fixedType}`, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'cell-fixed': col.fixedType }), style: {
|
|
39013
38992
|
top: `${indexParent * 42}px`,
|
|
39014
38993
|
left: col.fixedType === 'left' ? objHeaderWidthFixLeft[`${indexParent}-${indexCol ?? 0}`] : undefined,
|
|
39015
38994
|
right: col.fixedType === 'right' ? objHeaderWidthFixRight[`${indexParent}-${indexCol ?? 0}`] : undefined
|
|
39016
|
-
}, children: jsxs("div", { style: { justifyContent: 'space-between' }, onClick: () => {
|
|
38995
|
+
}, children: jsxs("div", { style: { justifyContent: col.textAlign === 'center' ? 'center' : 'space-between' }, onClick: () => {
|
|
39017
38996
|
if (!allowSorting || col.columns?.length) {
|
|
39018
38997
|
return;
|
|
39019
38998
|
}
|
|
@@ -39820,6 +39799,19 @@ const ToolbarBottom = ({ handleAdd, handleDuplicate, handleInsertBefore, handleI
|
|
|
39820
39799
|
}), jsx("div", { className: classNames$1('r-toolbar-item me-25'), "aria-disabled": "false", children: jsx(SvgSettings, { className: "text-primary cursor-pointer", onClick: () => setOpenPopupSetupColumn(true) }) }), jsx("div", { className: classNames$1('r-toolbar-item me-25', { 'd-none': editDisable || addDisable }), "aria-disabled": "false", children: jsxs(UncontrolledDropdown, { className: "dropdown-user nav-item", children: [jsx(DropdownToggle$1, { tag: "div", color: "primary", onClick: (e) => e.preventDefault(), children: jsx(SvgInfo, { className: "cursor-pointer text-primary" }) }), jsx(DropdownMenu$1, { className: "formula-dropdown icon-dropdown", children: jsxs("ul", { className: "mb-0 pe-50", children: [jsx("li", { style: { fontSize: 13 }, children: "Nh\u1EA5n v\u00E0o c\u1ED9t STT \u0111\u1EC3 ch\u1ECDn h\u00E0ng v\u00E0 nh\u1EA5n Ctrl + D \u0111\u1EC3 nh\u00E2n b\u1EA3n" }), jsx("li", { style: { fontSize: 13 }, children: "Ch\u1ECDn \u00F4 v\u00E0 Ctrl + V \u0111\u1EC3 d\u00E1n th\u00F4ng tin t\u1EEB excel" }), jsx("li", { style: { fontSize: 13 }, children: "Nh\u1EA5n v\u00E0o c\u1ED9t STT \u0111\u1EC3 ch\u1ECDn h\u00E0ng v\u00E0 nh\u1EA5n Ctrl + C \u0111\u1EC3 sao ch\u00E9p h\u00E0ng" }), jsx("li", { style: { fontSize: 13 }, children: "Nh\u1EA5n v\u00E0o c\u1ED9t STT \u0111\u1EC3 ch\u1ECDn h\u00E0ng v\u00E0 nh\u1EA5n Ctrl + V \u0111\u1EC3 d\u00E1n h\u00E0ng" }), jsx("li", { style: { fontSize: 13 }, children: "Nh\u1EA5n Ctrl ho\u1EB7c Alt + Shift + \u2193 \u0111\u1EC3 sao ch\u00E9p d\u1EEF li\u1EC7u \u00F4 cho c\u00E1c d\u00F2ng d\u01B0\u1EDBi" }), jsx("li", { style: { fontSize: 13 }, children: "Nh\u1EA5n Ctrl ho\u1EB7c Alt + Shift + \u2191 \u0111\u1EC3 sao ch\u00E9p d\u1EEF li\u1EC7u \u00F4 cho c\u00E1c d\u00F2ng tr\u00EAn" })] }) })] }) })] })] }) }));
|
|
39821
39800
|
};
|
|
39822
39801
|
|
|
39802
|
+
const RenderToolbarTop = ({ toolbarTopOption }) => {
|
|
39803
|
+
return (jsx("div", { id: "table_custom_top_toolbar", className: "r-toolbar r-toolbar-top", "aria-orientation": "horizontal", children: jsxs("div", { className: "r-toolbar-items", children: [jsx("div", { className: "r-toolbar-left", children: toolbarTopOption?.map((item, index) => {
|
|
39804
|
+
return item.align === 'left' ? jsx(ToolBarElement, { item: item, index: index }) : '';
|
|
39805
|
+
}) }), jsx("div", { className: "r-toolbar-center", children: toolbarTopOption?.map((item, index) => {
|
|
39806
|
+
return item.align === 'center' ? jsx(ToolBarElement, { item: item, index: index }) : '';
|
|
39807
|
+
}) }), jsx("div", { className: "r-toolbar-right", children: toolbarTopOption?.map((item, index) => {
|
|
39808
|
+
return item.align === 'right' ? jsx(ToolBarElement, { item: item, index: index }) : '';
|
|
39809
|
+
}) })] }) }));
|
|
39810
|
+
};
|
|
39811
|
+
const ToolBarElement = ({ item, index }) => {
|
|
39812
|
+
return (jsx("div", { className: "r-toolbar-item", "aria-disabled": "false", children: item.template?.() }, `toolbar-top-${index}`));
|
|
39813
|
+
};
|
|
39814
|
+
|
|
39823
39815
|
const TableEdit = forwardRef((props, ref) => {
|
|
39824
39816
|
const { t } = useTranslation();
|
|
39825
39817
|
const { idTable, dataSource, columns, setDataSource, height = 400, rowHeight = 31.3, defaultValue, toolbarSetting, searchSetting, selectedItem, selectEnable, editDisable, addDisable, buttonSetting, formatSetting, haveSum, isMulti, disableAutoKey, commandClick, dataSourceChange, rowChange, setSelectedItem, handleSelect, onDuplicate, saveSettingColumn, allowFiltering = true, allowSorting, settingColumns, optionsFilter, pagingSetting, resetDefaultColumns } = props;
|
|
@@ -68684,15 +68676,17 @@ const UnExpandAllIcon = ({ className, color = '#7F7F7F', size = 24, onClick, sty
|
|
|
68684
68676
|
};
|
|
68685
68677
|
|
|
68686
68678
|
const RenderContentCol = (props) => {
|
|
68687
|
-
const { col, indexCol, indexRow, isSelected, row, zeroVisiable,
|
|
68679
|
+
const { col, indexCol, indexRow, isSelected, row, zeroVisiable, formatSetting, idTable, fisrtObjWidthFixRight, lastObjWidthFixLeft, objWidthFixLeft, objWidthFixRight, selectedRows, selectEnable, setSelectedRows, fieldKey, isMulti } = props;
|
|
68688
68680
|
const cellId = `content-${idTable}-row${indexRow}col-${indexCol}`;
|
|
68689
68681
|
const checkOverflow = () => {
|
|
68690
68682
|
const element = document.getElementById(cellId);
|
|
68691
68683
|
return element && element.scrollWidth > element.clientWidth;
|
|
68692
68684
|
};
|
|
68693
68685
|
const RenderElement = () => {
|
|
68694
|
-
if (col.type === 'checkbox'
|
|
68695
|
-
return (jsx("div", { className: "r-rowcell-div cursor-pointer", style: { alignItems: 'center' }, onClick: (e) => {
|
|
68686
|
+
if (col.type === 'checkbox' || col.field === 'checkbox') {
|
|
68687
|
+
return (jsx("div", { className: "r-rowcell-div cursor-pointer", style: { display: 'flex', justifyContent: col.textAlign === 'center' ? 'center' : col.textAlign === 'right' ? 'flex-end' : 'flex-start', alignItems: 'center' }, onClick: (e) => {
|
|
68688
|
+
console.log(isMulti);
|
|
68689
|
+
console.log(selectEnable);
|
|
68696
68690
|
if (selectEnable) {
|
|
68697
68691
|
const index = selectedRows?.findIndex((x) => x[fieldKey] === row[fieldKey]);
|
|
68698
68692
|
if (index > -1) {
|
|
@@ -68740,7 +68734,8 @@ const RenderContentCol = (props) => {
|
|
|
68740
68734
|
const suffix = isNegative ? formatSetting?.suffixNegative ?? '' : '';
|
|
68741
68735
|
const displayText = isNegative ? `${prefix}${value}${suffix}` : value ?? '';
|
|
68742
68736
|
return (jsxs("div", { className: classNames$1('r-rowcell-div'), style: {
|
|
68743
|
-
fontWeight: row.sortOrder < 0 || row.sortOrder > 100000 ? 600 : 400
|
|
68737
|
+
fontWeight: row.sortOrder < 0 || row.sortOrder > 100000 || row.haveBoldType ? 600 : 400,
|
|
68738
|
+
fontStyle: row.haveItalicType ? 'italic' : 'normal'
|
|
68744
68739
|
}, children: [jsx("div", { className: "r-cell-text", style: {
|
|
68745
68740
|
display: 'flex',
|
|
68746
68741
|
justifyContent: col.textAlign === 'center' ? 'center' : col.textAlign === 'right' ? 'flex-end' : 'flex-start',
|
|
@@ -68754,7 +68749,7 @@ const RenderContentCol = (props) => {
|
|
|
68754
68749
|
}, children: displayText }) }), checkOverflow() && (jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: cellId, placement: "top", children: jsx("div", { style: { color: textColor }, children: displayText }) }))] }));
|
|
68755
68750
|
}
|
|
68756
68751
|
};
|
|
68757
|
-
return (jsx(Fragment$1, { children: col.visible !== false &&
|
|
68752
|
+
return (jsx(Fragment$1, { children: col.visible !== false && col.isGroup !== true && (jsx("td", { className: classNames$1(`r-rowcell fix-${col.fixedType}`, { 'cell-fixed': col.fixedType }, { 'fixed-last': (col.fixedType === 'left' && indexCol === lastObjWidthFixLeft) || (col.fixedType === 'right' && indexCol === fisrtObjWidthFixRight) }, { 'r-active': isSelected }), style: {
|
|
68758
68753
|
left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
|
|
68759
68754
|
right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined
|
|
68760
68755
|
}, onClick: (e) => {
|
|
@@ -68812,17 +68807,16 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
|
|
|
68812
68807
|
setExpandsAll(true);
|
|
68813
68808
|
}, [groupSetting?.groupColumns]);
|
|
68814
68809
|
const { levels: headerColumns, objHeaderWidthFixLeft, objHeaderWidthFixRight, objWidthFixLeft, objWidthFixRight, lastObjWidthFixLeft, fisrtObjWidthFixRight } = useMemo(() => {
|
|
68815
|
-
const rs = calculateTableStructure(columns, settingColumns?.value);
|
|
68810
|
+
const rs = calculateTableStructure(columns, settingColumns?.value, groupSetting?.groupColumns);
|
|
68816
68811
|
setContentColumns(rs.flat);
|
|
68817
68812
|
return rs;
|
|
68818
|
-
}, [columns, settingColumns]);
|
|
68819
|
-
const optionGroupColumns = useMemo(() => contentColumns.filter((x) => !groupSetting?.groupColumns.includes(x.field)).map((x) => ({ ...x, headerDisplay: t(x.columnGroupText ?? x.headerDisplay ?? x.headerText) })), [groupSetting?.groupColumns, contentColumns]);
|
|
68813
|
+
}, [columns, settingColumns, groupSetting?.groupColumns]);
|
|
68820
68814
|
const firstColSpan = useMemo(() => {
|
|
68821
68815
|
let count = 0;
|
|
68822
68816
|
let index = 3;
|
|
68823
68817
|
for (let i = 0; i < contentColumns.length; i++) {
|
|
68824
68818
|
const col = contentColumns[i];
|
|
68825
|
-
if (col.visible !== false &&
|
|
68819
|
+
if (col.visible !== false && col.isGroup !== true) {
|
|
68826
68820
|
count++;
|
|
68827
68821
|
}
|
|
68828
68822
|
if (count === 3) {
|
|
@@ -68831,7 +68825,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
|
|
|
68831
68825
|
}
|
|
68832
68826
|
}
|
|
68833
68827
|
return index;
|
|
68834
|
-
}, [contentColumns
|
|
68828
|
+
}, [contentColumns]);
|
|
68835
68829
|
// Tính toán dữ liệu hiển thị dựa trên các điều kiện lọc, tìm kiếm và sắp xếp
|
|
68836
68830
|
const viewData = useMemo(() => {
|
|
68837
68831
|
if (!dataSource || dataSource.length === 0) {
|
|
@@ -68916,7 +68910,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
|
|
|
68916
68910
|
return (jsx("div", { className: "me-50 r-search", children: jsx(ReactInput, { style: { width: '230px' }, value: searchSetting?.searchTerm !== undefined ? searchSetting?.searchTerm : searchTerm, setSearchTerm: searchSetting?.setSearchTerm ? searchSetting?.setSearchTerm : setSearchTerm, placeholder: t('Search'), onKeyPress: handleKeyPress }) }));
|
|
68917
68911
|
};
|
|
68918
68912
|
const groupbtnTemplate = () => {
|
|
68919
|
-
return (jsxs(UncontrolledDropdown, { children: [jsx(DropdownToggle$1, { tag: "div", id: "group-dropdown-toggle", style: { position: 'relative' }, onClick: (e) => e.preventDefault(), children: jsx(GroupIcon, { color: "#7F7F7F", size: 24 }) }), jsxs(DropdownMenu$1, { className: "formula-dropdown icon-dropdown p-1", children: [jsx("div", { className: "mb-1", style: { fontSize: 16, fontWeight: 500 }, children: "Nh\u00F3m d\u1EEF li\u1EC7u theo c\u1ED9t" }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-1`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 1" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options:
|
|
68913
|
+
return (jsxs(UncontrolledDropdown, { children: [jsx(DropdownToggle$1, { tag: "div", id: "group-dropdown-toggle", style: { position: 'relative' }, onClick: (e) => e.preventDefault(), children: jsx(GroupIcon, { color: "#7F7F7F", size: 24 }) }), jsxs(DropdownMenu$1, { className: "formula-dropdown icon-dropdown p-1", children: [jsx("div", { className: "mb-1", style: { fontSize: 16, fontWeight: 500 }, children: "Nh\u00F3m d\u1EEF li\u1EC7u theo c\u1ED9t" }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-1`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 1" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options: contentColumns, fieldLabel: 'headerText', fieldValue: 'field', value: groupColumns[0] ? { headerText: t(contentColumns.find((x) => x.field === groupColumns[0])?.headerText ?? contentColumns.find((x) => x.field === groupColumns[0])?.headerText) } : undefined, onChange: (val) => {
|
|
68920
68914
|
if (val) {
|
|
68921
68915
|
groupColumns[0] = val.field;
|
|
68922
68916
|
}
|
|
@@ -68924,7 +68918,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
|
|
|
68924
68918
|
groupColumns.pop();
|
|
68925
68919
|
}
|
|
68926
68920
|
setGroupColumns([...groupColumns]);
|
|
68927
|
-
}, isClearable: groupColumns?.length === 1 }) })] }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-2`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 2" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options:
|
|
68921
|
+
}, isClearable: groupColumns?.length === 1 }) })] }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-2`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 2" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options: contentColumns, fieldLabel: 'headerText', fieldValue: 'field', value: groupColumns[1] ? { headerText: t(contentColumns.find((x) => x.field === groupColumns[1])?.headerText ?? contentColumns.find((x) => x.field === groupColumns[1])?.headerText) } : undefined, onChange: (val) => {
|
|
68928
68922
|
if (val) {
|
|
68929
68923
|
groupColumns[1] = val.field;
|
|
68930
68924
|
}
|
|
@@ -68932,7 +68926,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
|
|
|
68932
68926
|
groupColumns.pop();
|
|
68933
68927
|
}
|
|
68934
68928
|
setGroupColumns([...groupColumns]);
|
|
68935
|
-
}, isClearable: groupColumns?.length === 2 }) })] }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-3`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 3" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options:
|
|
68929
|
+
}, isClearable: groupColumns?.length === 2 }) })] }), jsxs("div", { className: 'form-group', children: [jsx(Label$1, { id: `label-group-3`, style: { fontWeight: 500, fontSize: 13 }, children: "M\u1EE9c 3" }), jsx("div", { className: "form-input", children: jsx(SelectTable, { options: contentColumns, fieldLabel: 'headerText', fieldValue: 'field', value: groupColumns[2] ? { headerText: t(contentColumns.find((x) => x.field === groupColumns[2])?.headerText ?? contentColumns.find((x) => x.field === groupColumns[2])?.headerText) } : undefined, onChange: (val) => {
|
|
68936
68930
|
if (groupSetting) {
|
|
68937
68931
|
if (val) {
|
|
68938
68932
|
groupColumns[2] = val.field;
|
|
@@ -69069,7 +69063,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
|
|
|
69069
69063
|
setExpandsAll(undefined);
|
|
69070
69064
|
row.expand = !expand;
|
|
69071
69065
|
} }), t(col.headerDisplay ?? col.headerText), ": ", value, " (", row.children.length, ")"] }) }), contentColumns.map((colSum, indexCol) => {
|
|
69072
|
-
if (indexCol <= firstColSpan || colSum.visible === false ||
|
|
69066
|
+
if (indexCol <= firstColSpan || colSum.visible === false || colSum.isGroup === true) {
|
|
69073
69067
|
return;
|
|
69074
69068
|
}
|
|
69075
69069
|
let sumValue = row[colSum.field];
|
|
@@ -69085,7 +69079,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
|
|
|
69085
69079
|
sumValue = '';
|
|
69086
69080
|
}
|
|
69087
69081
|
}
|
|
69088
|
-
return (jsx("td", { className: "r-rowcell r-cell-sum-group", children: jsx("div", { className: "r-rowcell-div", style: { justifyContent: colSum.textAlign ? colSum.textAlign : 'left' }, children: (haveSum || colSum.haveSum === true) && Number(sumValue) < 0 ?
|
|
69082
|
+
return (jsx("td", { className: "r-rowcell r-cell-sum-group", children: jsx("div", { className: "r-rowcell-div", style: { justifyContent: colSum.textAlign ? colSum.textAlign : 'left' }, children: (haveSum || colSum.haveSum === true) && Number(sumValue) < 0 ? jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] }) : sumValue }) }, `group-sum-cell-${level}-${indexRow}-${indexCol}`));
|
|
69089
69083
|
})] }), expand && jsx(RenderContent, { datas: row.children, level: level + 1 })] }, `row-${level}-${indexRow}`));
|
|
69090
69084
|
}
|
|
69091
69085
|
else {
|
|
@@ -69097,7 +69091,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
|
|
|
69097
69091
|
}, onContextMenu: (e) => {
|
|
69098
69092
|
e.preventDefault();
|
|
69099
69093
|
handleContextMenu(e, row);
|
|
69100
|
-
}, children: contentColumns.map((column, indexCol) => (jsx(RenderContentCol, { idTable: idTable, col: column, fieldKey: fieldKey, objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, isMulti: isMutil ?? false, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, formatSetting: formatSetting, indexCol: indexCol, indexRow: indexRow, isSelected: isSelected, row: row, zeroVisiable: zeroVisiable
|
|
69094
|
+
}, children: contentColumns.map((column, indexCol) => (jsx(RenderContentCol, { idTable: idTable, col: column, fieldKey: fieldKey, objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, isMulti: isMutil ?? false, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, formatSetting: formatSetting, indexCol: indexCol, indexRow: indexRow, isSelected: isSelected, row: row, zeroVisiable: zeroVisiable }, indexCol))) }, `row-content-${indexRow}`));
|
|
69101
69095
|
}
|
|
69102
69096
|
}) }));
|
|
69103
69097
|
};
|
|
@@ -69124,7 +69118,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
|
|
|
69124
69118
|
virtualDivRef.current.style.height = '0px';
|
|
69125
69119
|
}
|
|
69126
69120
|
}, [context]);
|
|
69127
|
-
return (jsxs("div", { className: "r-table-edit r-virtualized-table", children: [jsxs("div", { className: "r-grid", children: [toolbarSetting?.showTopToolbar && jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), headerComponent && headerComponent(), jsxs("div", { ref: gridRef, className: "r-gridtable", style: { height: `${height ? `${height}px` : 'auto'}`, position: 'relative' }, children: [jsxs("table", { role: "presentation", style: { width: '100%' }, children: [jsx(RenderColGroup, { contentColumns: contentColumns
|
|
69121
|
+
return (jsxs("div", { className: "r-table-edit r-virtualized-table", children: [jsxs("div", { className: "r-grid", children: [toolbarSetting?.showTopToolbar && jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), headerComponent && headerComponent(), jsxs("div", { ref: gridRef, className: "r-gridtable", style: { height: `${height ? `${height}px` : 'auto'}`, position: 'relative' }, children: [jsxs("table", { role: "presentation", style: { width: '100%' }, children: [jsx(RenderColGroup, { contentColumns: contentColumns }), jsx("thead", { className: "r-gridheader", role: "rowgroup", children: headerColumns.map((rowColumn, indexParent) => {
|
|
69128
69122
|
return (jsx("tr", { className: "r-row", role: "row", children: rowColumn.map((col, index) => (jsx(HeaderTableCol, { col: col, idTable: idTable ?? '', dataSource: dataSource, indexCol: index, indexParent: indexParent, isMulti: isMulti ?? false, objHeaderWidthFixLeft: objHeaderWidthFixLeft, objHeaderWidthFixRight: objHeaderWidthFixRight, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, container: gridRef, filterBy: filterBy, orderBy: orderBy, optionsFilter: querySetting?.optionsFilter, allowFiltering: querySetting?.allowFiltering, allowSorting: querySetting?.allowSorting, formatSetting: formatSetting, changeFilter: (val) => {
|
|
69129
69123
|
setFilterBy([...val]);
|
|
69130
69124
|
if (querySetting?.changeFilter) {
|
|
@@ -69135,9 +69129,9 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
|
|
|
69135
69129
|
if (querySetting?.changeOrder) {
|
|
69136
69130
|
querySetting.changeOrder(val);
|
|
69137
69131
|
}
|
|
69138
|
-
}, columns: contentColumns,
|
|
69132
|
+
}, columns: contentColumns, setContentColumns: setContentColumns, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, totalCount: dataSource?.length ?? 0 }, `header-${indexParent}-${index}`))) }, `header-${-indexParent}`));
|
|
69139
69133
|
}) }), jsx("tbody", { className: "r-gridcontent", role: "rowgroup", children: jsx(RenderContent, { datas: viewData }) }), jsx("tfoot", { className: "r-gridfoot", children: (columnsAggregate?.length ?? 0) > 0 && (jsx("tr", { className: "r-row", children: contentColumns.map((col, indexCol) => {
|
|
69140
|
-
if (col.visible === false ||
|
|
69134
|
+
if (col.visible === false || col.isGroup === true) {
|
|
69141
69135
|
return;
|
|
69142
69136
|
}
|
|
69143
69137
|
const item = columnsAggregate?.find((x) => x.field === col.field);
|
|
@@ -69154,7 +69148,7 @@ const TableView = ({ idTable, dataSource, height = 400, columns, isMutil = false
|
|
|
69154
69148
|
left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
|
|
69155
69149
|
right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined,
|
|
69156
69150
|
textAlign: col.textAlign ? col.textAlign : 'left'
|
|
69157
|
-
}, children: jsx("div", { className: "r-footer-div", children: (item || col.haveSum === true) && Number(sumValue) < 0 ?
|
|
69151
|
+
}, children: jsx("div", { className: "r-footer-div", children: (item || col.haveSum === true) && Number(sumValue) < 0 ? jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${sumValue}${formatSetting?.suffixNegative ?? ''}`] }) : sumValue }) }, `summarycell-${indexCol}`));
|
|
69158
69152
|
}) })) })] }), jsx("div", { ref: virtualDivRef }), context && (contextMenuItems?.length ?? 0) > 0 && handleContextMenuClick && (jsx(Popover$1, { className: "r-context-popover", placement: "right-start", isOpen: context.show, target: virtualDivRef.current, toggle: handleCloseContext, fade: false, children: jsx(PopoverBody$1, { children: contextMenuItems?.map((item, index) => {
|
|
69159
69153
|
return (jsxs("div", { className: "r-context-item", onClick: () => {
|
|
69160
69154
|
handleCloseContext();
|