react-table-edit 1.4.19 → 1.4.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.mjs CHANGED
@@ -41779,7 +41779,7 @@ function styleInject(css, ref) {
41779
41779
  var css_248z$1 = ".react-resizable {\n position: relative;\n}\n.react-resizable-handle {\n position: absolute;\n width: 20px;\n height: 20px;\n background-repeat: no-repeat;\n background-origin: content-box;\n box-sizing: border-box;\n background-image: url('');\n background-position: bottom right;\n padding: 0 3px 3px 0;\n}\n.react-resizable-handle-sw {\n bottom: 0;\n left: 0;\n cursor: sw-resize;\n transform: rotate(90deg);\n}\n.react-resizable-handle-se {\n bottom: 0;\n right: 0;\n cursor: se-resize;\n}\n.react-resizable-handle-nw {\n top: 0;\n left: 0;\n cursor: nw-resize;\n transform: rotate(180deg);\n}\n.react-resizable-handle-ne {\n top: 0;\n right: 0;\n cursor: ne-resize;\n transform: rotate(270deg);\n}\n.react-resizable-handle-w,\n.react-resizable-handle-e {\n top: 50%;\n margin-top: -10px;\n cursor: ew-resize;\n}\n.react-resizable-handle-w {\n left: 0;\n transform: rotate(135deg);\n}\n.react-resizable-handle-e {\n right: 0;\n transform: rotate(315deg);\n}\n.react-resizable-handle-n,\n.react-resizable-handle-s {\n left: 50%;\n margin-left: -10px;\n cursor: ns-resize;\n}\n.react-resizable-handle-n {\n top: 0;\n transform: rotate(225deg);\n}\n.react-resizable-handle-s {\n bottom: 0;\n transform: rotate(45deg);\n}";
41780
41780
  styleInject(css_248z$1);
41781
41781
 
41782
- const HeaderTableCol = (props) => {
41782
+ const HeaderTableCol$1 = (props) => {
41783
41783
  const { selectEnable, dataSource, setSelectedRows, col, indexCol, indexParent, objWidthFixLeft, objWidthFixRight, totalCount, selectedRows, column, setColumn, fisrtObjWidthFixRight, lastObjWidthFixLeft, isMulti } = props;
41784
41784
  const { t } = useTranslation();
41785
41785
  const handleResize = (e, { size }) => {
@@ -43479,7 +43479,7 @@ const TableEdit = forwardRef((props, ref) => {
43479
43479
  }, [searchTerm, searchSetting?.searchTerm]);
43480
43480
  return (jsxs(Fragment, { children: [jsxs("div", { className: "react-table-edit", children: [jsxs("div", { className: 'r-grid', ref: gridRef, children: [toolbarSetting?.showTopToolbar && jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), jsx("div", { ref: tableElement, className: "r-gridtable", style: { height: `${height ? `${height}px` : 'auto'}`, minHeight: `${minHeight ? `${minHeight}px` : ''}`, maxHeight: `${maxHeight ? `${maxHeight}px` : '400px'}` }, children: jsxs("table", { style: { width: '100%' }, children: [jsx("thead", { className: 'r-gridheader', children: headerColumns.map((element, indexParent) => {
43481
43481
  return (jsx("tr", { className: "r-row", role: "row", children: element?.map((col, index) => {
43482
- return (jsx(HeaderTableCol, { col: col, dataSource: dataSource, indexCol: index, indexParent: indexParent, isMulti: isMulti ?? false, objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, column: contentColumns, setColumn: setContentColumns, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, totalCount: totalCount }, `header-${indexParent}-${index}`));
43482
+ return (jsx(HeaderTableCol$1, { col: col, dataSource: dataSource, indexCol: index, indexParent: indexParent, isMulti: isMulti ?? false, objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, column: contentColumns, setColumn: setContentColumns, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, totalCount: totalCount }, `header-${indexParent}-${index}`));
43483
43483
  }) }, `header-${-indexParent}`));
43484
43484
  }) }), jsx("tbody", { className: 'r-gridcontent', children: renderData() }), jsx("tfoot", { className: "r-gridfoot", children: haveSum == true ? jsx("tr", { className: 'r-row', children: contentColumns.map((col, index) => {
43485
43485
  return (renderFooterCol(col, index));
@@ -65378,5 +65378,352 @@ const ImportExcelComponent = (props) => {
65378
65378
  ] }) }));
65379
65379
  };
65380
65380
 
65381
- export { ExportExcelComponent, FindNodeByPath, ImportExcelComponent, InputStyleComponent, SelectTable, SelectTableTree, TabsMenuComponent, Wizard, calculateTableStructure, checkDecimalSeparator, checkThousandSeparator, TableEdit as default, formartNumberic, formatDateTime, generateUUID, isNullOrUndefined$1 as isNullOrUndefined, messageBoxConfirm, messageBoxConfirm2, messageBoxConfirmDelete, messageBoxError, messageHtmlBoxConfirm, messageHtmlBoxError, notificationError, notificationSuccess, roundNumber, useOnClickOutside };
65381
+ const HeaderTableCol = (props) => {
65382
+ const { selectEnable, dataSource, setSelectedRows, col, indexCol, indexParent, objWidthFixLeft, objWidthFixRight, totalCount, selectedRows, columns, setColumns, orderBy, changeFilter, filterBy, changeOrder, allowFilter, allowOrder, container, fisrtObjWidthFixRight, lastObjWidthFixLeft, formatSetting, optionsFilter, idTable, isMulti } = props;
65383
+ const { t } = useTranslation();
65384
+ const headerRef = useRef(null);
65385
+ const order = orderBy.find((item) => item.key === col.field);
65386
+ const [openFilter, setOpenFilter] = useState(false);
65387
+ const filter = filterBy.find((item) => item.key === col.field);
65388
+ const handleResize = (e, { size }) => {
65389
+ // Update the column width here
65390
+ // You might need to update the state or call a callback to update the width
65391
+ if (size.width > 50) {
65392
+ const newColumns = [...columns];
65393
+ newColumns[indexCol].width = size.width;
65394
+ if ((columns[indexCol]?.maxWidth ?? 0) < size.width) {
65395
+ newColumns[indexCol].maxWidth = size.width;
65396
+ }
65397
+ if ((columns[indexCol]?.minWidth ?? 0) > size.width) {
65398
+ newColumns[indexCol].minWidth = size.width;
65399
+ }
65400
+ if (setColumns) {
65401
+ setColumns(newColumns);
65402
+ }
65403
+ }
65404
+ };
65405
+ const checkOverflow = () => {
65406
+ return headerRef.current && headerRef.current.scrollHeight > headerRef.current.clientHeight;
65407
+ };
65408
+ return (jsx(Fragment, { children: col.visible !== false && (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: false }, 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: {
65409
+ top: `${indexParent * 42}px`,
65410
+ left: col.fixedType === 'left' ? objWidthFixLeft[indexCol ?? 0] : undefined,
65411
+ right: col.fixedType === 'right' ? objWidthFixRight[indexCol ?? 0] : undefined
65412
+ }, children: jsxs("div", { style: { justifyContent: 'space-between' }, onClick: () => {
65413
+ if (order) {
65414
+ if (order.direction === 'asc') {
65415
+ order.direction = 'desc';
65416
+ changeOrder(orderBy);
65417
+ }
65418
+ else {
65419
+ changeOrder(orderBy.filter((x) => x.key !== col.field));
65420
+ }
65421
+ }
65422
+ else {
65423
+ orderBy.push({ direction: 'asc', key: col.field });
65424
+ changeOrder(orderBy);
65425
+ }
65426
+ }, className: classNames$1('r-headercell-div', { 'cursor-pointer': allowOrder }), children: [col.type === 'checkbox' && (jsx(Input$1, { checked: !!(totalCount > 0 && selectedRows?.length >= totalCount), type: "checkbox", className: classNames$1('cursor-pointer', { 'd-none': !isMulti }), style: { textAlign: col.textAlign ?? 'left', marginTop: 6 }, onChange: (e) => {
65427
+ if (selectEnable) {
65428
+ if (e.target.checked) {
65429
+ setSelectedRows(dataSource.map((item) => { return item; }));
65430
+ }
65431
+ else {
65432
+ setSelectedRows([]);
65433
+ }
65434
+ }
65435
+ } })), col.type !== 'checkbox' && jsxs(Fragment$1, { children: [jsxs("div", { className: 'header-content', style: { justifyContent: col.textAlign ?? 'left' }, children: [jsx("span", { id: `header-${idTable}-${indexParent}-${indexCol}`, ref: headerRef, className: 'text-content', children: t(col.headerText ?? '') }), checkOverflow() && jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: `header-${idTable}-${indexParent}-${indexCol}`, children: t(col.headerText ?? '') })] }), col.type !== '#' && col.type !== 'command' && jsxs("div", { className: 'd-flex', children: [allowOrder && order?.direction === 'asc' && jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", className: 'ms-25', width: "10", height: "10", viewBox: "0 0 16 18", fill: "none", children: [jsx("g", { "clip-path": "url(#clip0_520_6)", children: jsx("path", { d: "M8.70711 0.292893C8.31658 -0.0976311 7.68342 -0.0976311 7.29289 0.292893L0.928932 6.65685C0.538408 7.04738 0.538408 7.68054 0.928932 8.07107C1.31946 8.46159 1.95262 8.46159 2.34315 8.07107L8 2.41421L13.6569 8.07107C14.0474 8.46159 14.6805 8.46159 15.0711 8.07107C15.4616 7.68054 15.4616 7.04738 15.0711 6.65685L8.70711 0.292893ZM8 18H9L9 1H8H7L7 18H8Z", fill: "black" }) }), jsx("defs", { children: jsx("clipPath", { id: "clip0_520_6", children: jsx("rect", { width: "16", height: "18", fill: "white" }) }) })] }), allowOrder && order?.direction === 'desc' && jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", className: 'ms-25', width: "10", height: "10", viewBox: "0 0 16 18", fill: "none", children: [jsx("g", { "clip-path": "url(#clip0_520_2)", children: jsx("path", { d: "M7.29289 17.7071C7.68342 18.0976 8.31658 18.0976 8.70711 17.7071L15.0711 11.3431C15.4616 10.9526 15.4616 10.3195 15.0711 9.92893C14.6805 9.53841 14.0474 9.53841 13.6569 9.92893L8 15.5858L2.34315 9.92893C1.95262 9.53841 1.31946 9.53841 0.928932 9.92893C0.538408 10.3195 0.538408 10.9526 0.928932 11.3431L7.29289 17.7071ZM8 0L7 0L7 17H8H9L9 0L8 0Z", fill: "black" }) }), jsx("defs", { children: jsx("clipPath", { id: "clip0_520_2", children: jsx("rect", { width: "16", height: "18", fill: "white" }) }) })] }), allowFilter && jsxs(Dropdown$1, { isOpen: openFilter, toggle: (e) => {
65436
+ setOpenFilter(!openFilter);
65437
+ e.stopPropagation();
65438
+ }, onClick: (e) => {
65439
+ e.stopPropagation();
65440
+ }, children: [jsx(DropdownToggle$1, { tag: 'div', className: 'p-0 r-filter', children: jsxs("svg", { className: classNames$1('ms-25', { 'active': filter }), width: "10", height: "10", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", "stroke-width": "1.5", "font-size": "12", children: [jsx("path", { d: "M14.7 11.998v10.506c.052.4-.08.826-.381 1.106a1.306 1.306 0 0 1-.925.39 1.289 1.289 0 0 1-.926-.39l-2.637-2.68a1.323 1.323 0 0 1-.38-1.106v-7.826h-.04L1.85 2.16A1.348 1.348 0 0 1 2.076.293C2.325.107 2.6 0 2.888 0h18.373c.289 0 .564.107.814.293a1.348 1.348 0 0 1 .223 1.866L14.738 12H14.7Z", fill: "currentColor" }), " "] }) }), jsx(DropdownMenu$1, { container: container, className: 'formula-dropdown icon-dropdown p-0', style: {
65441
+ borderRadius: 8,
65442
+ zIndex: 1056
65443
+ }, children: jsx(DropdownItem$1, { className: 'p-1', style: { borderRadius: '6px' }, tag: 'div', header: true, children: jsx(RenderFilterElement, { setOpenFilter: setOpenFilter, filter: filter, filterBy: filterBy, optionsFilter: optionsFilter, formatSetting: formatSetting, changeFilter: changeFilter, column: col }) }) })] })] })] })] }) }) })) }, `header-${indexCol}`));
65444
+ };
65445
+ const RenderFilterElement = ({ filter, optionsFilter, formatSetting, filterBy, setOpenFilter, changeFilter, column }) => {
65446
+ const { t } = useTranslation();
65447
+ const [operator, setOperator] = useState(filter?.ope ?? ((!column.filterType && column.type === 'numeric') || column.filterType === 'select' ? 'equal' : 'contains'));
65448
+ const [valueFilter, setValueFilter] = useState(filter?.value ?? '');
65449
+ const RenderStringFilter = () => {
65450
+ const options = [
65451
+ { label: 'Bắt đầu bởi', value: 'startswith' },
65452
+ { label: 'Kết thúc bởi', value: 'endswith' },
65453
+ { label: 'Chứa', value: 'contains' },
65454
+ { label: 'Bằng', value: 'equal' },
65455
+ { label: 'Không bằng', value: 'notequal' }
65456
+ ];
65457
+ return (jsxs(Fragment$1, { children: [jsx(SelectTable, { value: options.find((x) => x.value === (operator)), options: options, onChange: (val) => {
65458
+ setOperator(val.value);
65459
+ }, placeholder: 'Select' }), jsx(Input$1, { className: 'my-1', value: valueFilter, onChange: (val) => {
65460
+ setValueFilter(val.target.value);
65461
+ } })] }));
65462
+ };
65463
+ const RenderNumberFilter = () => {
65464
+ const options = [
65465
+ { label: 'Lớn hơn', value: 'greaterthan' },
65466
+ { label: 'Lớn hơn hoặc bằng', value: 'greaterthanorequal' },
65467
+ { label: 'Bằng', value: 'equal' },
65468
+ { label: 'Bé hơn', value: 'lessthan' },
65469
+ { label: 'Bé hơn hoặc bằng', value: 'lessthanorequal' }
65470
+ ];
65471
+ const numericFormatProps = {
65472
+ value: !isNullOrUndefined$1(valueFilter) ? valueFilter.toString() : '',
65473
+ thousandSeparator: checkThousandSeparator(formatSetting?.thousandSeparator, formatSetting?.decimalSeparator),
65474
+ decimalSeparator: checkDecimalSeparator(formatSetting?.thousandSeparator, formatSetting?.decimalSeparator),
65475
+ allowNegative: column.numericSettings?.allowNegative ?? false,
65476
+ decimalScale: column.numericSettings?.fraction ?? 0
65477
+ };
65478
+ let floatValue = parseFloat(valueFilter ?? '0');
65479
+ return (jsxs(Fragment$1, { children: [jsx(SelectTable, { value: options.find((x) => x.value === (operator)), options: options, onChange: (val) => {
65480
+ setOperator(val.value);
65481
+ }, placeholder: t('Select') }), jsx(NumericFormat, { style: { textAlign: column.textAlign, height: 29 }, ...numericFormatProps, defaultValue: formartNumberic(valueFilter, formatSetting?.decimalSeparator ?? ',', formatSetting?.thousandSeparator ?? '.', column.numericSettings?.fraction), className: classNames$1('form-control my-1 input-numeric'), onValueChange: (values) => {
65482
+ floatValue = values?.floatValue;
65483
+ }, onFocus: (e) => {
65484
+ e.target.setSelectionRange(0, e.target.innerText.length - 1);
65485
+ }, onBlur: () => {
65486
+ if (floatValue !== valueFilter) {
65487
+ setValueFilter(!isNaN(floatValue) ? floatValue : 0);
65488
+ }
65489
+ } })] }));
65490
+ };
65491
+ const RenderSelectFilter = () => {
65492
+ return (jsx("div", { className: 'mb-1', children: jsx(SelectTable, { value: optionsFilter ? optionsFilter[column.field]?.find((x) => x.value === valueFilter) : undefined, options: (optionsFilter && optionsFilter[column.field]) ?? [], isClearable: true, onChange: (val) => {
65493
+ setValueFilter(val?.value);
65494
+ }, placeholder: t('Select') }) }));
65495
+ };
65496
+ const handleSave = () => {
65497
+ if (valueFilter || valueFilter === 0) {
65498
+ if (filter) {
65499
+ filter.ope = operator;
65500
+ filter.value = valueFilter;
65501
+ }
65502
+ else {
65503
+ filterBy.push({ key: column.field, ope: operator, value: valueFilter });
65504
+ }
65505
+ changeFilter([...filterBy]);
65506
+ }
65507
+ else {
65508
+ changeFilter(filterBy.filter((x) => x.key !== column.field));
65509
+ }
65510
+ setOpenFilter(false);
65511
+ };
65512
+ return (jsxs("div", { className: 'r-filter-popup', onKeyDown: (e) => {
65513
+ if (e.code === 'Enter' || e.code === 'NumpadEnter') {
65514
+ handleSave();
65515
+ e.stopPropagation();
65516
+ }
65517
+ }, children: [((!column.filterType && column.type === 'numeric') || column.filterType === 'numeric') ? jsxs(Fragment$1, { children: [RenderNumberFilter(), " "] }) : (column.filterType === 'select' ? jsxs(Fragment$1, { children: [RenderSelectFilter(), " "] }) : RenderStringFilter()), jsxs("div", { className: 'd-flex justify-content-end', children: [jsx(Button$1, { outline: true, color: 'primary', style: { borderRadius: 3 }, className: 'me-50 py-25 px-50', onClick: handleSave, children: t('Filter') }), jsx(Button$1, { className: 'py-25 px-50', outline: true, style: { borderRadius: 3 }, onClick: () => {
65518
+ if (filterBy) {
65519
+ changeFilter(filterBy.filter((x) => x.key !== column.field));
65520
+ }
65521
+ setOpenFilter(false);
65522
+ }, children: t('Clear') })] })] }));
65523
+ };
65524
+
65525
+ const RenderContentCol = (props) => {
65526
+ const { col, indexCol, indexRow, isSelected, row, formatSetting, idTable, fisrtObjWidthFixRight, lastObjWidthFixLeft, objWidthFixLeft, objWidthFixRight, selectedRows, selectEnable, setSelectedRows, handleCommandClick, fieldKey, isMulti } = props;
65527
+ const RenderElement = () => {
65528
+ if (col.type === 'command') {
65529
+ return jsx("div", { className: "r-rowcell-div command", children: jsx(CommandElement, { commandItems: col.commandItems ?? [], handleCommandClick: handleCommandClick, indexRow: indexRow, rowData: row }) });
65530
+ }
65531
+ else if (col.type === '#') {
65532
+ jsx("div", { className: "r-rowcell-div", children: indexRow + 1 });
65533
+ }
65534
+ else if (col.type === 'checkbox') {
65535
+ return (jsx("div", { className: "r-rowcell-div cursor-pointer", style: { alignItems: 'center' }, onClick: (e) => {
65536
+ if (selectEnable) {
65537
+ const index = selectedRows?.findIndex((x) => x[fieldKey] === row[fieldKey]);
65538
+ if (index > -1) {
65539
+ if (isMulti) {
65540
+ selectedRows?.splice(index, 1);
65541
+ setSelectedRows([...selectedRows]);
65542
+ }
65543
+ else {
65544
+ setSelectedRows([]);
65545
+ }
65546
+ }
65547
+ else {
65548
+ if (isMulti) {
65549
+ setSelectedRows([...selectedRows, row]);
65550
+ }
65551
+ else {
65552
+ setSelectedRows([row]);
65553
+ }
65554
+ }
65555
+ e.stopPropagation();
65556
+ }
65557
+ }, children: jsx(Input$1, { checked: isSelected, type: "checkbox", className: "cursor-pointer", style: { textAlign: col.textAlign ?? 'center' } }) }));
65558
+ }
65559
+ else {
65560
+ let value = row[col.field];
65561
+ if (col.type === 'numeric') {
65562
+ value = formartNumberic(row[col.field], formatSetting?.decimalSeparator ?? ',', formatSetting?.thousandSeparator ?? '.', col.numericSettings?.fraction, true, false) ?? 0;
65563
+ }
65564
+ else if (col.type === 'date') {
65565
+ value = value ? formatDateTime(value, formatSetting?.dateFormat) : '';
65566
+ }
65567
+ else if (col.type === 'datetime') {
65568
+ value = value ? formatDateTime(value, formatSetting?.dateFormat ?? 'DD/MM/yyyy HH:mm') : '';
65569
+ }
65570
+ if (col.template) {
65571
+ value = col.template(row, indexRow) ?? '';
65572
+ }
65573
+ return (jsx("div", { className: classNames$1('r-rowcell-div'), children: jsxs("div", { className: classNames$1('r-rowcell-content'), style: {
65574
+ textAlign: col.textAlign ? col.textAlign : 'left'
65575
+ }, children: [jsx("div", { id: `content-${idTable}-row${indexRow}col-${indexCol}`, className: "r-cell-text", children: (col.type === 'numeric' && Number(row[col.field]) < 0 ? jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] }) : value) }), col.haveToolTip && jsx(UncontrolledTooltip, { className: "r-tooltip", autohide: false, target: `content-${idTable}-row${indexRow}col-${indexCol}`, children: (col.type === 'numeric' && Number(row[col.field]) < 0 ? jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${value}${formatSetting?.suffixNegative ?? ''}`] }) : value) })] }) }));
65576
+ }
65577
+ };
65578
+ return (col.visible !== false && 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: {
65579
+ left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
65580
+ right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined
65581
+ }, onClick: (e) => {
65582
+ if (e.target.nodeName === 'DIV' || e.target.nodeName === 'TD') {
65583
+ if (selectEnable) {
65584
+ const index = selectedRows?.findIndex((x) => x[fieldKey] === row[fieldKey]);
65585
+ if (index > -1) {
65586
+ if (isMulti) {
65587
+ selectedRows?.splice(index, 1);
65588
+ setSelectedRows([...selectedRows]);
65589
+ }
65590
+ else {
65591
+ setSelectedRows([]);
65592
+ }
65593
+ }
65594
+ else {
65595
+ if (isMulti) {
65596
+ setSelectedRows([...selectedRows, row]);
65597
+ }
65598
+ else {
65599
+ setSelectedRows([row]);
65600
+ }
65601
+ }
65602
+ }
65603
+ e.stopPropagation();
65604
+ }
65605
+ }, children: RenderElement() }, `col-${indexRow}-${indexCol}`));
65606
+ };
65607
+
65608
+ const RenderColGroup = ({ contentColumns }) => (jsx("colgroup", { children: contentColumns.map((col, index) => (jsx("col", { style: {
65609
+ width: typeof col.width === 'number' ? `${col.width}px` : col.width || undefined,
65610
+ minWidth: typeof col.minWidth === 'number' ? `${col.minWidth}px` : col.minWidth || undefined,
65611
+ maxWidth: typeof col.maxWidth === 'number' ? `${col.maxWidth}px` : col.maxWidth || undefined
65612
+ } }, index))) }));
65613
+
65614
+ const VirtualTable = ({ idTable, dataSource, rowHeight = 33, height = 400, columns, isMutil, isLoading, selectEnable, formatSetting, commandClick, allowFilter, allowOrder, setColumns, pagingSetting, changeFilter, changeOrder, searchSetting, columnsAggregate, toolbarSetting, optionsFilter }) => {
65615
+ const gridRef = useRef(null);
65616
+ const [startIndex, setStartIndex] = useState(0);
65617
+ const [selectedRows, setSelectedRows] = useState([]);
65618
+ const [orderBy, setOrderBy] = useState([]);
65619
+ const [filterBy, setFilterBy] = useState([]);
65620
+ const [searchTerm, setSearchTerm] = useState('');
65621
+ const fieldKey = columns.find((item) => item.isPrimarykey === true)?.field ?? 'id';
65622
+ //trường liên quan đến virtul loading
65623
+ const visibleRowCount = Math.ceil(height / rowHeight) + 5;
65624
+ const buffer = 10; // số dòng dự phòng phía trên và dưới
65625
+ const adjustedStartIndex = Math.max(startIndex - buffer, 0);
65626
+ const adjustedEndIndex = Math.min(startIndex + visibleRowCount + buffer, dataSource.length);
65627
+ const visibleData = dataSource.slice(adjustedStartIndex, adjustedEndIndex);
65628
+ const { t } = useTranslation();
65629
+ const { levels: headerColumns, flat: contentColumns, flatVisble, objWidthFixLeft, objWidthFixRight, lastObjWidthFixLeft, fisrtObjWidthFixRight } = useMemo(() => calculateTableStructure(columns), [columns]);
65630
+ const scrollTimeoutRef = useRef(null);
65631
+ const lastScrollTop = useRef(0);
65632
+ const handleScroll = (e) => {
65633
+ if (!gridRef.current) {
65634
+ return;
65635
+ }
65636
+ // Nếu không có sự thay đổi về scrollTop => người dùng chỉ scroll ngang => không xử lý
65637
+ if (e.target.scrollTop === lastScrollTop.current) {
65638
+ return;
65639
+ }
65640
+ lastScrollTop.current = e.target.scrollTop;
65641
+ if (scrollTimeoutRef.current !== null) {
65642
+ cancelAnimationFrame(scrollTimeoutRef.current);
65643
+ }
65644
+ scrollTimeoutRef.current = requestAnimationFrame(() => {
65645
+ const scrollTop = gridRef.current.scrollTop;
65646
+ const newStartIndex = Math.floor(scrollTop / rowHeight);
65647
+ if (newStartIndex !== startIndex) {
65648
+ setStartIndex(newStartIndex);
65649
+ }
65650
+ });
65651
+ };
65652
+ const handleCommandClick = (id, rowData, index) => {
65653
+ if (commandClick) {
65654
+ commandClick({ id, rowData, index });
65655
+ }
65656
+ };
65657
+ const handleKeyPress = (e) => {
65658
+ if ((e.code === 'Enter' || e.code === 'NumpadEnter')) {
65659
+ if (searchSetting?.setSearchTerm) {
65660
+ searchSetting?.setSearchTerm(e.target.value);
65661
+ }
65662
+ else {
65663
+ setSearchTerm(e.target.value);
65664
+ }
65665
+ e.stopPropagation();
65666
+ e.preventDefault();
65667
+ }
65668
+ };
65669
+ const searchTemplate = () => {
65670
+ 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 }) }));
65671
+ };
65672
+ const defaultToolbarOption = searchSetting?.searchEnable ? [{ template: searchTemplate, align: 'left' }] : [];
65673
+ let toolbarTopOption = [];
65674
+ if (toolbarSetting?.toolbarOptions) {
65675
+ toolbarTopOption = [...defaultToolbarOption, ...toolbarSetting?.toolbarOptions];
65676
+ }
65677
+ else {
65678
+ toolbarTopOption = [...defaultToolbarOption];
65679
+ }
65680
+ const onChangePage = (args) => {
65681
+ if (pagingSetting?.setCurrentPage) {
65682
+ if (args.currentPage === args.oldPage) {
65683
+ return;
65684
+ }
65685
+ pagingSetting.setCurrentPage(args.currentPage);
65686
+ }
65687
+ };
65688
+ const onChangePageSize = (args) => {
65689
+ if (pagingSetting?.allowPaging) {
65690
+ if (pagingSetting?.pageSize !== args.pageSize) {
65691
+ if (pagingSetting?.setPageSize) {
65692
+ pagingSetting.setPageSize(args.pageSize);
65693
+ }
65694
+ if (pagingSetting?.setCurrentPage) {
65695
+ pagingSetting.setCurrentPage(1);
65696
+ }
65697
+ }
65698
+ }
65699
+ };
65700
+ return (jsxs("div", { className: "react-table-edit", children: [jsxs("div", { className: 'r-grid', children: [toolbarSetting?.showTopToolbar && jsx(RenderToolbarTop, { toolbarTopOption: toolbarTopOption }), jsxs("div", { ref: gridRef, className: "r-gridtable", onScroll: handleScroll, style: { height: `${height ? `${height}px` : 'auto'}` }, children: [jsxs("table", { style: { width: '100%' }, children: [jsx(RenderColGroup, { contentColumns: flatVisble }), jsx("thead", { className: 'r-gridheader', children: headerColumns.map((rowColumn, indexParent) => (jsx("tr", { className: "r-row", role: "row", children: rowColumn.map((column, indexColumn) => (jsx(HeaderTableCol, { idTable: idTable, col: column, dataSource: dataSource, indexCol: indexColumn, indexParent: indexParent, isMulti: isMutil ?? false, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, columns: contentColumns, setColumns: setColumns, objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, orderBy: orderBy, allowFilter: allowFilter, allowOrder: allowOrder, filterBy: filterBy, optionsFilter: optionsFilter, changeFilter: (val) => {
65701
+ setFilterBy([...val]);
65702
+ if (changeFilter) {
65703
+ changeFilter(val);
65704
+ }
65705
+ }, changeOrder: (val) => {
65706
+ setOrderBy([...val]);
65707
+ if (changeOrder) {
65708
+ changeOrder(val);
65709
+ }
65710
+ }, container: gridRef, totalCount: dataSource.length }, `header-${indexParent}-${indexColumn}`))) }, indexParent))) }), jsxs("tbody", { className: 'r-gridcontent', children: [adjustedStartIndex > 0 && (jsx("tr", { style: { height: adjustedStartIndex * rowHeight }, children: jsx("td", { style: { padding: 0 }, colSpan: flatVisble.length }) })), visibleData.map((row, index) => {
65711
+ const indexRow = index + startIndex;
65712
+ const isSelected = selectedRows?.some((x) => x[fieldKey] === row[fieldKey]);
65713
+ return (jsx("tr", { className: classNames$1('r-row'), children: contentColumns.map((column, indexCol) => (jsx(RenderContentCol, { idTable: idTable, col: column, fieldKey: 'field', objWidthFixLeft: objWidthFixLeft, objWidthFixRight: objWidthFixRight, fisrtObjWidthFixRight: fisrtObjWidthFixRight, lastObjWidthFixLeft: lastObjWidthFixLeft, isMulti: isMutil ?? false, selectEnable: selectEnable ?? false, selectedRows: selectedRows, setSelectedRows: setSelectedRows, formatSetting: formatSetting, handleCommandClick: handleCommandClick, indexCol: indexCol, indexRow: indexRow, isSelected: isSelected, row: row }, indexCol))) }, `row-${indexRow}`));
65714
+ }), dataSource.length > adjustedEndIndex && (jsx("tr", { style: { height: (dataSource.length - adjustedEndIndex) * rowHeight }, children: jsx("td", { style: { padding: 0 }, colSpan: flatVisble.length }) }))] }), dataSource.length > 0 && jsx("tfoot", { className: "r-gridfoot", children: (columnsAggregate?.length ?? 0) > 0 ? jsx("tr", { className: 'r-row', children: contentColumns.map((col, indexCol) => {
65715
+ const item = columnsAggregate?.find((x) => x.field === col.field);
65716
+ let sumValue = item?.value;
65717
+ if (!item && col.haveSum === true && col.type === "numeric") {
65718
+ sumValue = dataSource.reduce(function (accumulator, currentValue) { return (Number(accumulator ?? 0) + Number(currentValue[col.field] ?? 0)); }, 0);
65719
+ }
65720
+ return col.visible !== false && jsx("td", { className: classNames$1(`p-0 px-50 r-footer fix-${col.fixedType}`, { 'cell-fixed': col.fixedType }), style: {
65721
+ left: col.fixedType === 'left' ? objWidthFixLeft[indexCol] : undefined,
65722
+ right: col.fixedType === 'right' ? objWidthFixRight[indexCol] : undefined,
65723
+ textAlign: col.textAlign ? col.textAlign : 'left'
65724
+ }, children: jsxs("div", { className: "r-footer-div", children: [(item || (col.haveSum === true && col.type === "numeric")) && col.type === "numeric" && (Number(sumValue) >= 0) && jsx(Fragment$1, { children: formartNumberic(sumValue, formatSetting?.decimalSeparator ?? ',', formatSetting?.thousandSeparator ?? '.', col.numericSettings?.fraction, true, false) }), (item || (col.haveSum === true && col.type === "numeric")) && col.type === "numeric" && (Number(sumValue) < 0) && jsxs("div", { style: { color: formatSetting?.colorNegative ?? 'red' }, children: [" ", `${formatSetting?.prefixNegative ?? '-'}${formartNumberic(sumValue, formatSetting?.decimalSeparator ?? ',', formatSetting?.thousandSeparator ?? '.', col.numericSettings?.fraction, true, false)}${formatSetting?.suffixNegative ?? ''}`] })] }) }, `summarycell-${indexCol}`);
65725
+ }) }) : jsx(Fragment$1, {}) })] }), (((dataSource.length ?? 0) === 0) && !isLoading) && jsxs("div", { className: "r-no-data", children: [jsx("svg", { width: "64", height: "41", viewBox: "0 0 64 41", xmlns: "http://www.w3.org/2000/svg", children: jsxs("g", { transform: "translate(0 1)", fill: "none", fillRule: "evenodd", children: [jsx("ellipse", { fill: "#f5f5f5", cx: "32", cy: "33", rx: "32", ry: "7" }), jsxs("g", { fillRule: "nonzero", stroke: "#d9d9d9", children: [jsx("path", { d: "M55 12.76L44.854 1.258C44.367.474 43.656 0 42.907 0H21.093c-.749 0-1.46.474-1.947 1.257L9 12.761V22h46v-9.24z" }), jsx("path", { d: "M41.613 15.931c0-1.605.994-2.93 2.227-2.931H55v18.137C55 33.26 53.68 35 52.05 35h-40.1C10.32 35 9 33.259 9 31.137V13h11.16c1.233 0 2.227 1.323 2.227 2.928v.022c0 1.605 1.005 2.901 2.237 2.901h14.752c1.232 0 2.237-1.308 2.237-2.913v-.007z", fill: "#fafafa" })] })] }) }), t('No data available.')] }), isLoading && jsx("div", { className: "r-loading-overlay", children: jsxs("div", { className: "r-loading", children: [jsx(Spinner$1, { className: "me-1" }), t('Loading...')] }) })] })] }), pagingSetting?.allowPaging ? jsx(PagingComponent, { onChangePage: onChangePage, pageSize: pagingSetting?.pageSize ?? 0, currentPage: pagingSetting?.currentPage ?? 0, pageOptions: pagingSetting?.pageOptions ?? [20, 30, 50, 100], totalItem: (pagingSetting?.totalItem ?? 0), onChangePageSize: onChangePageSize }) : jsx(Fragment$1, {})] }));
65726
+ };
65727
+
65728
+ export { ExportExcelComponent, FindNodeByPath, ImportExcelComponent, InputStyleComponent, SelectTable, SelectTableTree, TabsMenuComponent, VirtualTable, Wizard, calculateTableStructure, checkDecimalSeparator, checkThousandSeparator, TableEdit as default, formartNumberic, formatDateTime, generateUUID, isNullOrUndefined$1 as isNullOrUndefined, messageBoxConfirm, messageBoxConfirm2, messageBoxConfirmDelete, messageBoxError, messageHtmlBoxConfirm, messageHtmlBoxError, notificationError, notificationSuccess, roundNumber, useOnClickOutside };
65382
65729
  //# sourceMappingURL=index.mjs.map