From b01768924e108e6535b7b5f6fbbf9050c9bcf910 Mon Sep 17 00:00:00 2001 From: Kanika Bansal Date: Wed, 4 Dec 2024 17:11:58 +0530 Subject: [PATCH] fix: horizontal scroll in views (#1830) --- src/components/FilterSelectBox.res | 2 +- src/components/LoadedTable.res | 2 + src/components/LoadedTable.resi | 1 + .../LoadedTableWithCustomColumns.res | 2 + src/components/Table.res | 39 ++++++++++++------- src/components/Table.resi | 1 + src/screens/Customers/Customers.res | 1 + src/screens/Disputes/Disputes.res | 1 + src/screens/Order/Orders.res | 1 + src/screens/Payouts/PayoutsList.res | 1 + src/screens/Refunds/Refund.res | 1 + 11 files changed, 36 insertions(+), 16 deletions(-) diff --git a/src/components/FilterSelectBox.res b/src/components/FilterSelectBox.res index 70db4341c..c554fdf2e 100644 --- a/src/components/FilterSelectBox.res +++ b/src/components/FilterSelectBox.res @@ -1919,7 +1919,7 @@ module BaseDropdown = { selectButton }}
newInputSelect.name->onDeleteClick}>
diff --git a/src/components/LoadedTable.res b/src/components/LoadedTable.res index 24703cff6..7a0069caf 100644 --- a/src/components/LoadedTable.res +++ b/src/components/LoadedTable.res @@ -230,6 +230,7 @@ let make = ( ~nonFrozenTableParentClass="", ~loadedTableParentClass="", ~remoteSortEnabled=false, + ~showAutoScroll=false, ) => { open LogicUtils let showPopUp = PopUpState.useShowPopUp() @@ -828,6 +829,7 @@ let make = ( ?showborderColor tableHeadingTextClass nonFrozenTableParentClass + showAutoScroll /> switch tableLocalFilter { | true => diff --git a/src/components/LoadedTable.resi b/src/components/LoadedTable.resi index a0906f9f8..1d6bb7adf 100644 --- a/src/components/LoadedTable.resi +++ b/src/components/LoadedTable.resi @@ -116,4 +116,5 @@ let make: ( ~nonFrozenTableParentClass: string=?, ~loadedTableParentClass: string=?, ~remoteSortEnabled: bool=?, + ~showAutoScroll: bool=?, ) => React.element diff --git a/src/components/LoadedTableWithCustomColumns.res b/src/components/LoadedTableWithCustomColumns.res index 3992ec10d..38c4d6ba3 100644 --- a/src/components/LoadedTableWithCustomColumns.res +++ b/src/components/LoadedTableWithCustomColumns.res @@ -64,6 +64,7 @@ let make = ( ~noScrollbar=false, ~previewOnly=false, ~remoteSortEnabled=false, + ~showAutoScroll=false, ) => { let (showColumnSelector, setShowColumnSelector) = React.useState(() => false) let activeColumnsAtom = customColumnMapper->Some @@ -151,5 +152,6 @@ let make = ( ?setExtFilteredDataLength noScrollbar remoteSortEnabled + showAutoScroll /> } diff --git a/src/components/Table.res b/src/components/Table.res index ed9c10b86..133123a34 100644 --- a/src/components/Table.res +++ b/src/components/Table.res @@ -656,6 +656,7 @@ let make = ( ~showborderColor=true, ~tableHeadingTextClass="", ~nonFrozenTableParentClass="", + ~showAutoScroll=false, ) => { let isMobileView = MatchMedia.useMobileChecker() let rowInfo: array> = rows @@ -888,22 +889,30 @@ let make = ( ? "" : "overflow-scroll" let parentBorderRadius = !isHighchartLegend ? "rounded-lg" : "" - let sidebarScrollbarCss = ` - @supports (-webkit-appearance: none) { - .sidebar-scrollbar { - scrollbar-color: #8a8c8f; - } + let tableScrollbarCss = ` + @supports (-webkit-appearance: none) { + .table-scrollbar { + scrollbar-width: auto; + scrollbar-color: #8a8c8f; + } - .sidebar-scrollbar::-webkit-scrollbar-thumb { - background-color: #8a8c8f; - border-radius: 3px; - } + .table-scrollbar::-webkit-scrollbar { + display: block; + height: 4px; + width: 5px; + } - .sidebar-scrollbar::-webkit-scrollbar-track { - display: none; - } - } + .table-scrollbar::-webkit-scrollbar-thumb { + background-color: #8a8c8f; + border-radius: 3px; + } + + .table-scrollbar::-webkit-scrollbar-track { + display:none; + } + } ` + let autoscrollcss = showAutoScroll ? "table-scrollbar" : ""
Option.getOr( parentBorderRadius, @@ -920,9 +929,9 @@ let make = ( } //replaced "overflow-auto" -> to be tested with master > 0}> {frozenTable} - +
+ className={`flex-1 ${overflowClass} no-scrollbar ${childMinWidthClass} ${nonFrozenTableParentClass} ${autoscrollcss} `}> nonFrozenTable
{switch customizeColumnNewTheme { diff --git a/src/components/Table.resi b/src/components/Table.resi index 2e38a23ff..139fe636d 100644 --- a/src/components/Table.resi +++ b/src/components/Table.resi @@ -305,4 +305,5 @@ let make: ( ~showborderColor: bool=?, ~tableHeadingTextClass: string=?, ~nonFrozenTableParentClass: string=?, + ~showAutoScroll: bool=?, ) => React.element diff --git a/src/screens/Customers/Customers.res b/src/screens/Customers/Customers.res index 9f0840f6c..0472f2759 100644 --- a/src/screens/Customers/Customers.res +++ b/src/screens/Customers/Customers.res @@ -44,6 +44,7 @@ let make = () => { customColumnMapper={TableAtoms.customersMapDefaultCols} showSerialNumberInCustomizeColumns=false sortingBasedOnDisabled=false + showAutoScroll=true /> } diff --git a/src/screens/Disputes/Disputes.res b/src/screens/Disputes/Disputes.res index 2ae10b6f7..6ec4f440c 100644 --- a/src/screens/Disputes/Disputes.res +++ b/src/screens/Disputes/Disputes.res @@ -130,6 +130,7 @@ let make = () => { customColumnMapper={TableAtoms.disputesMapDefaultCols} showSerialNumberInCustomizeColumns=false sortingBasedOnDisabled=false + showAutoScroll=true />
diff --git a/src/screens/Order/Orders.res b/src/screens/Order/Orders.res index 9ed72e78b..746f218e8 100644 --- a/src/screens/Order/Orders.res +++ b/src/screens/Order/Orders.res @@ -193,6 +193,7 @@ let make = (~previewOnly=false) => { hideTitle=true previewOnly remoteSortEnabled=true + showAutoScroll=true /> diff --git a/src/screens/Payouts/PayoutsList.res b/src/screens/Payouts/PayoutsList.res index 164e22067..2b805d056 100644 --- a/src/screens/Payouts/PayoutsList.res +++ b/src/screens/Payouts/PayoutsList.res @@ -102,6 +102,7 @@ let make = () => { customColumnMapper=TableAtoms.payoutsMapDefaultCols showSerialNumberInCustomizeColumns=false sortingBasedOnDisabled=false + showAutoScroll=true /> diff --git a/src/screens/Refunds/Refund.res b/src/screens/Refunds/Refund.res index a4435a305..49fb4c01c 100644 --- a/src/screens/Refunds/Refund.res +++ b/src/screens/Refunds/Refund.res @@ -120,6 +120,7 @@ let make = () => { customColumnMapper=TableAtoms.refundsMapDefaultCols showSerialNumberInCustomizeColumns=false sortingBasedOnDisabled=false + showAutoScroll=true />