View Liquidity Page UI Development
Author of this section: @Fish
in this talk, we will implement the UI page development of Wtfswap's liquidity (position) list.
Framework building
first, let's look at the design draft:
similar to the trading pool list page, this page is mainly used to display a list of positions under the current account number and contains entry points for adding positions, removing positions, and withdrawing positions.
We can directly copy the code of the trading pool list page pool.tsx for positions.tsx
, and pool.module.css for positions.module.css
, and then modify the title and button content, columns
and data
the content of can be left blank first and then supplemented later.
import React from "react";
import { Flex, Table, Space, Typography, Button } from "antd";
import type { TableProps } from "antd";
import WtfLayout from "@/components/WtfLayout";
import styles from "./positions.module.css";
const columns: TableProps["columns"] = [];
const PoolListTable: React.FC = () => {
const data = [];
return (
<Table
title={() => (
<Flex justify="space-between">
<div>My Positions</div>
<Space>
<Button type="primary">Add</Button>
</Space>
</Flex>
)}
columns={columns}
dataSource={data}
/>
);
};
export default function WtfswapPool() {
return (
<WtfLayout>
<div className={styles.container}>
<Typography.Title level={2}>Postions</Typography.Title>
<PoolListTable />
</div>
</WtfLayout>
);
}
You will get the following effect:
add Mock data
next, let's add column definitions and Mock data to populate the table. The specific fields refer to the ones we defined in the contract. PositionInfo .
import type { TableProps } from "antd";
const columns: TableProps["columns"] = [
{
title: "Owner",
dataIndex: "owner",
key: "owner",
ellipsis: true,
},
{
title: "Token 0",
dataIndex: "token0",
key: "token0",
ellipsis: true,
},
{
title: "Token 1",
dataIndex: "token1",
key: "token1",
ellipsis: true,
},
{
title: "Index",
dataIndex: "index",
key: "index",
},
{
title: "Fee",
dataIndex: "fee",
key: "fee",
},
{
title: "Liquidity",
dataIndex: "liquidity",
key: "liquidity",
render: (value: bigint) => {
return value.toString();
},
},
{
title: "Tick Lower",
dataIndex: "tickLower",
key: "tickLower",
},
{
title: "Tick Upper",
dataIndex: "tickUpper",
key: "tickUpper",
},
{
title: "Tokens Owed 0",
dataIndex: "tokensOwed0",
key: "tokensOwed0",
render: (value: bigint) => {
return value.toString();
},
},
{
title: "Tokens Owed 1",
dataIndex: "tokensOwed1",
key: "tokensOwed1",
render: (value: bigint) => {
return value.toString();
},
},
{
title: "Fee Growth Inside 0",
dataIndex: "feeGrowthInside0LastX128",
key: "feeGrowthInside0LastX128",
render: (value: bigint) => {
return value.toString();
},
},
{
title: "Fee Growth Inside 1",
dataIndex: "feeGrowthInside1LastX128",
key: "feeGrowthInside1LastX128",
render: (value: bigint) => {
return value.toString();
},
},
{
title: "Actions",
key: "actions",
render: () => (
<Space className={styles.actions}>
<a>Remove</a>
<a>Collect</a>
</Space>
),
},
];
Simply construct a Mock data:
const data = [
{
owner: "0x1234567890abcdef1234567890abcdef12345678",
token0: "0x1234567890abcdef1234567890abcdef12345678",
token1: "0x1234567890abcdef1234567890abcdef12345678",
index: 0,
fee: 3000,
liquidity: BigInt(1234560000000),
tickLower: -123456,
tickUpper: 123456,
tokensOwed0: BigInt(123456),
tokensOwed1: BigInt(654321),
feeGrowthInside0LastX128: BigInt(123456),
feeGrowthInside1LastX128: BigInt(654321),
},
];
in this way, our UI part is completed, and the final effect is (may be inconsistent with the design draft, the design draft is more of a UI style reference, please ignore):
please refer to the complete code: positions.tsx
we'll refine the code and add logic for interacting with contracts in later lessons.