Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: improve orders table when hidden orders #5226

Merged
merged 6 commits into from
Dec 18, 2024
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 3 additions & 3 deletions apps/explorer/src/components/common/Tabs/Tabs.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ export interface Props {
readonly tabTheme: TabTheme
readonly selectedTab?: TabId
readonly extra?: TabBarExtraContent
readonly extraPosition?: 'top' | 'bottom'
readonly extraPosition?: 'top' | 'bottom' | 'both'
readonly updateSelectedTab?: (activeId: TabId) => void
}

Expand Down Expand Up @@ -129,10 +129,10 @@ const Tabs: React.FC<Props> = (props) => {
tabTheme={tabTheme}
/>
))}
{extraPosition === 'top' && <ExtraContent extra={tabBarExtraContent} />}
{['top', 'both'].includes(extraPosition) && <ExtraContent extra={tabBarExtraContent} />}
</TabList>
<TabContent tabItems={tabItems} activeTab={selectedTab} />
{extraPosition === 'bottom' && <ExtraContent extra={tabBarExtraContent} />}
{['bottom', 'both'].includes(extraPosition) && <ExtraContent extra={tabBarExtraContent} />}
</Wrapper>
)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ import { ToggleFilter } from './ToggleFilter'
import { SimpleTable, SimpleTableProps } from '../../common/SimpleTable'
import { StatusLabel } from '../StatusLabel'
import { UnsignedOrderWarning } from '../UnsignedOrderWarning'
import { TableState } from 'explorer/components/TokensTableWidget/useTable'
anxolin marked this conversation as resolved.
Show resolved Hide resolved
import { Command } from '@cowprotocol/types'

const EXPIRED_CANCELED_STATES: OrderStatus[] = ['cancelled', 'cancelling', 'expired']

Expand Down Expand Up @@ -53,6 +55,8 @@ const Wrapper = styled.div`

export type Props = SimpleTableProps & {
orders: Order[] | undefined
tableState: TableState
handleNextPage: Command
messageWhenEmpty?: string | React.ReactNode
}

Expand Down Expand Up @@ -87,6 +91,32 @@ const NoOrdersContainer = styled.div`
padding: 2rem;
`

const HiddenOrdersLegend = styled.tr`
p {
text-align: center;
}

&:hover,
td:hover {
background-color: ${({ theme }) => theme.paper};
color: ${({ theme }) => theme.textSecondary1};
}

td {
padding: 0;
font-size: 1.2rem;
color: ${({ theme }) => theme.textSecondary1};

a {
text-decoration: underline;
}

a:hover {
color: ${({ theme }) => theme.textSecondary2};
}
}
`

const RowOrder: React.FC<RowProps> = ({ order, isPriceInverted, showCanceledAndExpired, showPreSigning }) => {
const { creationDate, buyToken, buyAmount, sellToken, sellAmount, kind, partiallyFilled, uid, filledPercentage } =
order
Expand Down Expand Up @@ -159,16 +189,19 @@ const RowOrder: React.FC<RowProps> = ({ order, isPriceInverted, showCanceledAndE
}

const OrdersUserDetailsTable: React.FC<Props> = (props) => {
const { orders, messageWhenEmpty } = props
const { orders, messageWhenEmpty, tableState, handleNextPage } = props
const [isPriceInverted, setIsPriceInverted] = useState(false)
const [showCanceledAndExpired, setShowCanceledAndExpired] = useState(false)
const [showPreSigning, setShowPreSigning] = useState(false)

const canceledAndExpiredCount = orders?.filter(isExpiredOrCanceled).length || 0
const preSigningCount = orders?.filter((order) => order.status === 'signing').length || 0
const showFilter = canceledAndExpiredCount > 0 || preSigningCount > 0
const areOrdersAllHidden =
orders?.length === (showPreSigning ? 0 : preSigningCount) + (showCanceledAndExpired ? 0 : canceledAndExpiredCount)

const hiddenOrdersCount =
(showPreSigning ? 0 : preSigningCount) + (showCanceledAndExpired ? 0 : canceledAndExpiredCount)

const areOrdersAllHidden = orders?.length === hiddenOrdersCount

const invertLimitPrice = (): void => {
setIsPriceInverted((previousValue) => !previousValue)
Expand Down Expand Up @@ -231,7 +264,7 @@ const OrdersUserDetailsTable: React.FC<Props> = (props) => {
}
body={
<>
{!areOrdersAllHidden ? (
{!areOrdersAllHidden &&
orders.map((item) => (
<RowOrder
key={item.uid}
Expand All @@ -240,12 +273,26 @@ const OrdersUserDetailsTable: React.FC<Props> = (props) => {
showCanceledAndExpired={showCanceledAndExpired}
showPreSigning={showPreSigning}
/>
))
) : (
<NoOrdersContainer>
<p>No orders found.</p>
<p>You can toggle the filters to show the {orders.length} hidden orders.</p>
</NoOrdersContainer>
))}

{hiddenOrdersCount > 0 && (
<HiddenOrdersLegend>
<td colSpan={8}>
<p>
Showing {orders.length - hiddenOrdersCount} out of {orders.length} orders for the current page.
</p>
<p>
{hiddenOrdersCount} orders are hidden, you can make them visible using the filters above
{tableState.hasNextPage ? (
<span>
, or go to&nbsp;<a onClick={handleNextPage}>next page</a>&nbsp;for more orders.
</span>
) : (
'.'
)}
</p>
</td>
</HiddenOrdersLegend>
)}
</>
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ export const OrdersTableWithData: React.FC = () => {
const {
data: orders,
addressAccountParams: { ownerAddress, networkId },
tableState,
handleNextPage,
} = useContext(OrdersTableContext)
const isFirstRender = useFirstRender()
const [isFirstLoading, setIsFirstLoading] = useState(true)
Expand Down Expand Up @@ -46,6 +48,8 @@ export const OrdersTableWithData: React.FC = () => {
) : (
<OrdersTable
orders={orders}
tableState={tableState}
handleNextPage={handleNextPage}
messageWhenEmpty={
<EmptyOrdersMessage
isLoading={searchInAnotherNetworkState}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@ const OrdersTableWidget: React.FC<Props> = ({ ownerAddress, networkId }) => {
>
<ConnectionStatus />
{error && <Notification type={error.type} message={error.message} />}
<StyledExplorerTabs tabItems={tabItems(isLoading)} extra={ExtraComponentNode} />
<StyledExplorerTabs tabItems={tabItems(isLoading)} extra={ExtraComponentNode} extraPosition="both" />
</OrdersTableContext.Provider>
)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,7 @@ import { Media } from '@cowprotocol/ui'
import styled from 'styled-components/macro'
import { DARK_COLOURS } from 'theme'

import Tabs, {
getTabTheme,
Props as TabsProps,
IndicatorTabSize,
} from '../../../../components/common/Tabs/Tabs'
import Tabs, { getTabTheme, Props as TabsProps, IndicatorTabSize } from '../../../../components/common/Tabs/Tabs'

const StyledTabs = styled.div`
display: flex;
Expand Down Expand Up @@ -56,7 +52,7 @@ const tabCustomThemeConfig = getTabTheme({
indicatorTabSize: IndicatorTabSize.big,
})

type ExplorerTabsProps = Omit<TabsProps, 'tabTheme'> & { extraPosition?: 'top' | 'bottom' }
type ExplorerTabsProps = Omit<TabsProps, 'tabTheme'> & { extraPosition?: 'top' | 'bottom' | 'both' }

const ExplorerTabs: React.FC<ExplorerTabsProps> = (props) => {
return (
Expand Down
Loading