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

[pending]Bera #144

Open
wants to merge 12 commits into
base: main
Choose a base branch
from
44 changes: 30 additions & 14 deletions src/components/Select/index.tsx
Original file line number Diff line number Diff line change
@@ -1,25 +1,41 @@
import React from 'react';
import React, { useState } from 'react';
import { MenuItem, Select, SelectChangeEvent } from '@mui/material';
interface TSelectProps {
defaultValue: string;
options: string[];
onChange: (value: string) => void;

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

options 的类型最好是 { value, label },不然无法满足后面的需求

}

import { Chain } from '../../config/chainConfig';
import useGlobalStore from '../../store/useGlobalStore';
const TSelect: React.FC<TSelectProps> = ({ defaultValue, options, onChange }) => {
const [currentValue, setCurrentValue] = useState(defaultValue);

const TSelect = () => {
const { chain } = useGlobalStore();

const handleInternalChange = (event: SelectChangeEvent<Chain>) => {
const value = event.target.value as Chain;
useGlobalStore.setState({ chain: value });
const handleInternalChange = (event: SelectChangeEvent<string>) => {
const value = (event.target.value as string) ?? '';
setCurrentValue(value);
onChange(value);
};

return (
<Select<Chain>
value={chain}
<Select<string>
value={currentValue}
onChange={handleInternalChange}
style={{ minWidth: '120px', height: '60px' }}
style={{
width: '100%',
height: '58.5px',
borderRadius: 8,
fontSize: '15px',
}}
sx={{
border: 'none',
'& .MuiOutlinedInput-notchedOutline': {
border: 'none',
},
}}
className="bg-[#F7F9FA] py-[18px] pl-[10px] text-base font-medium text-[#1A1D1F]"
>
<MenuItem value={Chain.Arb}>{Chain.Arb}</MenuItem>
<MenuItem value={Chain.Bera}>{Chain.Bera}</MenuItem>
{options.map((option: string) => (
<MenuItem value={option}>{option}</MenuItem>
))}
</Select>
);
};
Expand Down
10 changes: 10 additions & 0 deletions src/components/icons/ETHIcon.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,3 +18,13 @@ export default function Icon() {
</svg>
);
}

export function BeraIcon() {
return (
<img
src="https://cdn-xfans.buidlerdao.xyz/20240513-190428.jpeg"
className="mx-0 h-[18px] w-[18px] cursor-pointer rounded-full p-0"
alt="Logo"
/>
);
}
5 changes: 5 additions & 0 deletions src/constants.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,11 @@ export enum ContractError {
InsufficientBalance = 'Insufficient Balance',
}

export enum Token {
Bera = 'Bera',
WETH = 'WETH',
}

export const XFANS_CONTENT_WIDTH = 433;
export const XFANS_MIN_WIDTH = 458;

Expand Down
2 changes: 1 addition & 1 deletion src/content/addToTwitterHome.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ export const addUserPagePriceComponent = () => {
const elementId = `xfans-userPagePrice-${username}`;
const existingElement = document.getElementById(elementId);

console.log(username);
// console.log(username);
// 由于个人中心页面有复用,因此在插入之前要删除掉其他price tag
const elements = document.querySelectorAll('[id^="xfans-userPagePrice-"]');
elements.forEach((x) => {
Expand Down
2 changes: 0 additions & 2 deletions src/content/loginPage/signInWithXPage.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import React, { FC } from 'react';

import { NextButton } from '../../components/buttons/loginButton';
import TSelect from '../../components/Select/index';

import '../../tailwind.css';

Expand Down Expand Up @@ -54,7 +53,6 @@ const SignInWithXPage: FC<SignInWithXPageProps> = ({ handleButtonClick, showLoad
'Login With X'
)}
</NextButton>
<TSelect />
</div>
);
};
Expand Down
4 changes: 3 additions & 1 deletion src/hooks/useAccount.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import useUserStore from '../store/useUserStore';

// 账户相关的全局状态
export default function useAccount() {
const { accounts, balance } = useGlobalUserStore();
const { accounts, balance, wETHBalance } = useGlobalUserStore();
const { userInfo, inviteInfo } = useUserStore((state) => ({ ...state }));
const { run: getUserInfo } = useUserInfo();
const { run: getUserInviteInfo } = useUserInvite();
Expand All @@ -19,6 +19,7 @@ export default function useAccount() {
useGlobalUserStore.setState({
accounts: response.accounts,
balance: response.balance,
wETHBalance: response.weth_balance,
});
},
});
Expand All @@ -39,5 +40,6 @@ export default function useAccount() {
userInfo,
inviteInfo,
refresh,
wETHBalance,
};
}
14 changes: 14 additions & 0 deletions src/hooks/useETHPrice.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,3 +16,17 @@ export function useETHPrice() {

return ethPrice?.price ?? 0;
}

/**
* 获取最新 eth 价格
*/
export function useBeraPrice() {
const { run: getPrice } = useEthPriceService();
const { beraPrice } = useShareStore((state) => ({ ...state }));

useEffect(() => {
getPrice();
}, [getPrice]);

return beraPrice?.price ?? 0;
}
3 changes: 2 additions & 1 deletion src/service/contract/shares.ts
Original file line number Diff line number Diff line change
Expand Up @@ -87,10 +87,11 @@ export async function unstake(address: string, amount: number) {
amount: BigNumber(amount).times(SHARE_UNIT_MODIFIER).toFixed(),
});
}
export async function transfer(address: string, amount: string) {
export async function transfer(address: string, amount: string, token?: string) {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

我记得mpc那边是精准判断字符串的,这里补个类型把

await http.post<null>('/xfans/api/shares/transfer', {
amount,
address,
token,
});
}

Expand Down
12 changes: 6 additions & 6 deletions src/service/contract/user.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
import { contractRequestHttp as http } from '../request';

export async function getAccounts() {
const accounts = await http.get<{ accounts: string[]; balance: string }>(
const accounts = await http.get<{ accounts: string[]; balance: string; weth_balance: string }>(
'/xfans/api/user/accounts'
);
return accounts;
}

export async function getBalance() {
const balance = await http.get<string>('/xfans/api/user/getBalance');
return balance;
}
// todo: 建议删除,后端暂时没删除
// export async function getBalance() {
// const balance = await http.get<string>('/xfans/api/user/getBalance');
// return balance;
// }
28 changes: 17 additions & 11 deletions src/service/share/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -94,17 +94,23 @@ const useHolderList = () => {
};

const useEthPrice = () => {
const result = useRequest<ResultData<{ id: number; symbol: string; price: number }>, unknown[]>(
() => http.get('/api/share/eth-price'),
{
manual: true,
onSuccess(response) {
useShareStore.setState({
ethPrice: response.data,
});
},
}
);
const result = useRequest<
ResultData<{ items: { id: number; symbol: string; price: number }[] }>,
unknown[]
>(() => http.get('/api/share/prices'), {
manual: true,
onSuccess(response) {
const ethPrice = response.data.items.find((x) => x.symbol === 'eth');
const beraPrice = response.data.items.find((x) => x.symbol === 'bera');

console.log('eth-prices', response, ethPrice, beraPrice);

useShareStore.setState({
ethPrice: ethPrice,
beraPrice: beraPrice,
});
},
});

return result;
};
Expand Down
1 change: 1 addition & 0 deletions src/service/wallet/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ const useWalletAccounts = () => {
useGlobalUserStore.setState({
accounts: response.accounts,
balance: response.balance,
wETHBalance: response.weth_balance,
});
},
});
Expand Down
2 changes: 1 addition & 1 deletion src/store/useGlobalStore.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ const useGlobalStore = create<GlobalStoreProps>()(
});
},
userVote: null,
chain: Chain.Arb,
chain: Chain.Bera,

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

感觉把 chain 做成环境变量好点把,不然产品找你要 Arb 版本我们还得改源码。。

}),
{
name: 'xfans-user-config',
Expand Down
2 changes: 2 additions & 0 deletions src/store/useGlobalUserStore.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,13 @@ import { create } from 'zustand';
interface GlobalUserStoreProps {
accounts: string[];
balance: string;
wETHBalance: string;
}

const useGlobalUserStore = create<GlobalUserStoreProps>((set, get) => ({
accounts: [],
balance: '',
wETHBalance: '',
}));

export default useGlobalUserStore;
2 changes: 2 additions & 0 deletions src/store/useShareStore.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ interface ShareStoreProps {
holderingList: HolderProps[] | null;
holderingListTotal: number;
ethPrice: { id: number; symbol: string; price: number } | null;
beraPrice: { id: number; symbol: string; price: number } | null;
}

const useShareStore = create<ShareStoreProps>((set) => ({
Expand All @@ -22,6 +23,7 @@ const useShareStore = create<ShareStoreProps>((set) => ({
holderingList: null,
holderingListTotal: 0,
ethPrice: null,
beraPrice: null,
}));

export default useShareStore;
36 changes: 25 additions & 11 deletions src/welcome/Wallet/BuyModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,15 +9,16 @@ import NumberInput, { NumberInputRef } from '../../components/NumberInput';
import * as toaster from '../../components/Toaster';
import { ContractError } from '../../constants';
import useAccount from '../../hooks/useAccount';
import { useETHPrice } from '../../hooks/useETHPrice';
import { useBeraPrice, useETHPrice } from '../../hooks/useETHPrice';
import { BeraIcon } from '../../components/icons/ETHIcon';
import {
buyShares,
getBuyPrice,
getBuyPriceAfterFee,
getFloorPrice,
getSupply,
} from '../../service/contract/shares';
import { getBalance } from '../../service/contract/user';
import { getAccounts } from '../../service/contract/user';
import useProfileModal from '../../store/useProfileModal';
import { formatDollar } from '../../utils';

Expand Down Expand Up @@ -69,6 +70,7 @@ const BuyModal = ({ onClose }: BuyModalProps) => {
const [amount, setAmount] = useState<number>(0);
const [priceAfterFee, setPriceAfterFee] = useState('0');
const [balance, setBalance] = useState('0');
const [WETHbalance, setWETHBalance] = useState('0');
const [isBuying, setIsBuying] = useState(false);
const [floorPrice, setFloorPrice] = useState('0');
const [supply, setSupply] = useState(0);
Expand All @@ -81,7 +83,7 @@ const BuyModal = ({ onClose }: BuyModalProps) => {
const [loadingSupply, setLoadingSupply] = useState<boolean>(true);

const ethPrice = useETHPrice();

const beraPrice = useBeraPrice();
useEffect(() => {
if (currentInfo?.walletAddress != null) {
setLoadingSupply(true);
Expand Down Expand Up @@ -133,9 +135,10 @@ const BuyModal = ({ onClose }: BuyModalProps) => {
useEffect(() => {
if (wallet) {
setLoadingBalance(true);
getBalance().then((balance) => {
getAccounts().then((result) => {
setLoadingBalance(false);
setBalance(balance);
setBalance(result.balance);
setWETHBalance(result.weth_balance);
});
}
}, [wallet]);
Expand Down Expand Up @@ -165,9 +168,10 @@ const BuyModal = ({ onClose }: BuyModalProps) => {
numberInputRef.current?.reset();
refreshAccount();
setLoadingBalance(true);
getBalance().then((balance) => {
getAccounts().then((result) => {
setLoadingBalance(false);
setBalance(balance);
setBalance(result.balance);
setWETHBalance(result.weth_balance);
});
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
setLoadingFloorPrice(true);
Expand Down Expand Up @@ -285,12 +289,12 @@ const BuyModal = ({ onClose }: BuyModalProps) => {
<span className="text-lg font-medium text-[#919099]">Est. Gas Fee</span>
<div className="flex flex-col items-end">
<div className="flex items-center space-x-1">
<Icon1 />
<BeraIcon />
<span className="text-lg font-medium">
<NumberDisplayer text={gasFee} loading={loadingPrice} />
</span>
</div>
<span className="text-[#919099]">{formatDollar(gasFee, ethPrice)}</span>
<span className="text-[#919099]">{formatDollar(gasFee, beraPrice)}</span>
</div>
</div>
</div>
Expand All @@ -310,7 +314,17 @@ const BuyModal = ({ onClose }: BuyModalProps) => {
<div className="flex items-center space-x-1">
<Icon1 />
<span className="text-2xl font-bold">
<NumberDisplayer text={total} loading={loadingPrice || loadingPirceAfterFee} />
<NumberDisplayer
text={new BigNumber(priceAfterFee).toFixed()}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

这里为什么要new 以下来着,之前是 total 现在改成 priceAfterFee 是预期的吗

loading={loadingPrice || loadingPirceAfterFee}
/>
</span>
<BeraIcon />
<span className="text-2xl font-bold">
<NumberDisplayer
text={new BigNumber(gasFee).toFixed()}
loading={loadingPrice || loadingPirceAfterFee}
/>
</span>
</div>
</div>
Expand All @@ -319,7 +333,7 @@ const BuyModal = ({ onClose }: BuyModalProps) => {
<div className="flex items-center justify-center space-x-1 rounded-full bg-[#F5F5F5] px-5 py-1">
<Icon1 />
<span className="text-lg font-medium">
<NumberDisplayer text={balance} loading={loadingBalance} />
<NumberDisplayer text={WETHbalance} loading={loadingBalance} />
</span>
</div>
</div>
Expand Down
10 changes: 7 additions & 3 deletions src/welcome/Wallet/Deposit.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,11 @@ import { useToggle } from 'ahooks';
import { BackButton, BasicButton, PrimaryButton } from '../../components/Button';
import Modal from '../../components/Modal';
import * as toaster from '../../components/Toaster';
import TSelect from '../../components/Select';
import { chainNameMap } from '../../config/chainConfig';
import useGlobalStore from '../../store/useGlobalStore';
import useGlobalUserStore from '../../store/useGlobalUserStore';
import { Token } from '../../constants';

const Deposit = () => {
const [isOpen, { setLeft: close, setRight: open }] = useToggle(false);
Expand Down Expand Up @@ -52,9 +54,11 @@ const Deposit = () => {
</div>
<div className="flex flex-col space-y-[14px]">
<span className="text-base font-medium text-[#919099]">Asset</span>
<div className="rounded-[8px] bg-[#F7F9FA] py-[18px] pl-[26px] text-base font-medium text-[#1A1D1F]">
ETH
</div>
<TSelect
defaultValue={Token.WETH}
options={[Token.WETH, Token.Bera]}
onChange={(x) => {}}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

既然 onChange 没用上是不是它的类型改成可选的好点

/>
</div>
</div>
<div className="my-[30px] flex w-full justify-between">
Expand Down
Loading
Loading