Skip to content

Commit

Permalink
feat: connected to backend api
Browse files Browse the repository at this point in the history
  • Loading branch information
PainterPuppets committed Dec 12, 2023
1 parent ea6069d commit b67c6e3
Show file tree
Hide file tree
Showing 28 changed files with 541 additions and 171 deletions.
27 changes: 15 additions & 12 deletions app/components/apiClient/base.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,7 @@ export function isAPIError(reason: unknown): reason is APIError {

export type FetchLike<R extends any = any> = (
input: string,
init?: {
method?: string
body?: string
headers: { [key in string]: string }
},
init?: NodeJS.fetch.RequestInit,
) => Promise<{
status: number
json(): Promise<R>
Expand All @@ -46,22 +42,29 @@ export class APIClient {
params: P = {} as P,
) {
return new Promise<R>((resolve, reject) => {
this.fetch(`${this.origin}/api/${endpoint}`, {
const init: NodeJS.fetch.RequestInit = {
method,
body: JSON.stringify({
...params,
}),
headers: {
'Content-Type': 'application/json',
},
})
}

if (Object.keys(params).length !== 0) {
Object.assign(init, {
body: JSON.stringify({
...params,
}),
})
}

this.fetch(`${this.origin}${endpoint}`, init)
.then(async (res) => {
const body = res.status === 204 ? null : await res.json()

if (res.status === 200) {
resolve(body)
resolve(body.data ?? body)
} else if (res.status === 204) {
resolve(body)
resolve(body.data ?? body)
} else {
reject({
[API_ERROR]: true,
Expand Down
20 changes: 13 additions & 7 deletions app/components/apiClient/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,12 @@ import {
Assets,
AddressHashParams,
TokenCreateData,
TokenUpdateData,
TokenTransferParams,
TokenMintParams,
Transaction,
ServerTransaction,
} from '@/app/type'
import { RawTransaction } from '@ckb-lumos/base'
import { APIClient, APIClientOptions } from './base'
import { MockApi } from './mock'

Expand All @@ -21,19 +22,24 @@ export class SUDTApi extends APIClient {
this.get<Token[]>(`/token?${new URLSearchParams(params)}`),
detail: (args: string) => this.get<Token>(`/token/${args}`),
create: (data: TokenCreateData) =>
this.post<TokenCreateData, RawTransaction>('/token', data),
update: (data: TokenCreateData) =>
this.put<TokenCreateData, Token>('/token', data),
transfer: (data: TokenTransferParams) =>
this.post<TokenTransferParams, RawTransaction>('/token/transfer', data),
this.post<TokenCreateData, ServerTransaction>('/token', data),
update: (typeId: string, data: TokenUpdateData) =>
this.put<TokenUpdateData, Token>(`/token/${typeId}`, data),
transfer: (typeId: string, data: TokenTransferParams) =>
this.post<TokenTransferParams, ServerTransaction>(
`/token/send/${typeId}/`,
data,
),
mint: (typeId: string, params: TokenMintParams) =>
this.post<TokenMintParams, RawTransaction>(
this.post<TokenMintParams, ServerTransaction>(
`/token/mint/${typeId}/`,
params,
),
}

account = {
meta: (addressHash: string) =>
this.get<{ capacity: string }>(`/account/meta/${addressHash}`),
asyncAddress: (addressHash: string, addresses: string[]) =>
this.post(`/account/${addressHash}`, { addresses }),
listAssets: (addressHash: string) =>
Expand Down
8 changes: 3 additions & 5 deletions app/components/apiClient/mock.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import {
TokenCreateData,
TokenTransferParams,
TokenMintParams,
History,
TokenUpdateData,
} from '@/app/type'
import { APIClient } from './base'
import {
Expand All @@ -19,10 +19,8 @@ export class MockApi extends APIClient {
detail: (args: string) =>
Promise.resolve(MOCK_TOKENS.find((token) => token.symbol === args)),
create: (_: TokenCreateData) => Promise.resolve(MOCK_RAW_TRANSACTION),
update: (data: TokenCreateData) =>
Promise.resolve(
MOCK_TOKENS.find((token) => token.symbol === data.symbol),
),
update: (typeId: string, data: TokenUpdateData) =>
Promise.resolve(MOCK_TOKENS.find((token) => token.typeId === typeId)),
transfer: (_: TokenTransferParams) => Promise.resolve(MOCK_RAW_TRANSACTION),
mint: (_: string, __: TokenMintParams) =>
Promise.resolve(MOCK_RAW_TRANSACTION),
Expand Down
100 changes: 62 additions & 38 deletions app/components/apiClient/mockData.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import type { Transaction, Assets, Token } from '@/app/type'
import type { RawTransaction } from '@ckb-lumos/base'
import type { Transaction, Assets, Token, ServerTransaction } from '@/app/type'
// import type { RawTransaction } from '@ckb-lumos/base'

export const MOCK_ACCOUNTS: {
[namke: string]: Record<'address' | 'balance', string>
Expand Down Expand Up @@ -28,24 +28,28 @@ export const MOCK_ACCOUNTS: {

export const MOCK_ASSETS: Assets[] = [
{
typeId: '1',
displayName: 'CKB',
uan: 'CKB',
decimal: '8',
amount: '10000000000',
},
{
typeId: '2',
displayName: 'SUDT1',
uan: 'SUDT1',
decimal: '8',
amount: '10000000000',
},
{
typeId: '3',
displayName: 'SUDT2',
uan: 'SUDT2',
decimal: '8',
amount: '20000000000',
},
{
typeId: '4',
displayName: 'SUDT3',
uan: 'SUDT3',
decimal: '8',
Expand All @@ -59,11 +63,15 @@ export const MOCK_TOKENS: Token[] = [
decimal: '8',
name: 'Demo Simple User Define Token',
email: '[email protected]',
typeId: '1',
amount: '10000',
description: '',
website: '',
icon: '',
},
{
typeId: '2',
amount: '10000',
symbol: 'SUDT2',
decimal: '8',
name: 'Demo Simple User Define Token',
Expand All @@ -73,6 +81,8 @@ export const MOCK_TOKENS: Token[] = [
icon: '',
},
{
typeId: '3',
amount: '10000',
symbol: 'SUDT3',
decimal: '8',
name: 'Demo Simple User Define Token',
Expand All @@ -83,75 +93,89 @@ export const MOCK_TOKENS: Token[] = [
},
]

export const MOCK_RAW_TRANSACTION: RawTransaction = {
version: '0x0',
export const MOCK_RAW_TRANSACTION: ServerTransaction = {
cellDeps: [
{
outPoint: {
txHash:
'0xbcdb11e9815b3d9fb6278af097e2ae54fe4f8c9c97d352d8a15538ed0398ac83',
index: '0x1',
'0xec26b0f85ed839ece5f11c4c4e837ec359f5adc4420410f6453b1f6b60fb96a6',
index: '0x0',
},
depType: 'depGroup',
},
{
outPoint: {
txHash:
'0xbcdb11e9815b3d9fb6278af097e2ae54fe4f8c9c97d352d8a15538ed0398ac83',
'0xe12877ebd2c3c364dc46c5c992bcfaf4fee33fa13eebdf82c591fc9825aab769',
index: '0x0',
},
depType: 'depGroup',
depType: 'code',
},
],
headerDeps: [],
inputs: [
{
since: '0x0',
previousOutput: {
txHash:
'0xa401e0b880329ea492e95f3fc085fe03e33a66f5e010aadbf8fcd0d5ecc09e5f',
index: '0x0',
cellOutput: {
capacity: '0x90fcedc3f20',
lock: {
codeHash:
'0x3419a1c09eb2567f6552ee7a8ecffd64155cffe0f1796e6e61ec088d740c1356',
hashType: 'type',
args: '0x1b3e74a036a21f94eba3d7c94b9d5619e1e84f7c',
},
},
},
{
since: '0x0',
previousOutput: {
data: '0x',
outPoint: {
txHash:
'0x3fdc5faa485a9687dcf7b12445cb77376798cbbc6efbc9fd5e8e22589c385921',
'0x6827d1fb91b10d589303e66ec574bde9f4b1ca6eacbd05c475cd194391e6fc78',
index: '0x1',
},
blockNumber: '0xb0d5de',
},
],
outputs: [
{
capacity: '0x2540be400',
lock: {
codeHash:
'0x9bd7e06f3ecf4be0f2fcd2188b23f1b9fcc88e5d4b65a8637b17723bbda3cce8',
hashType: 'type',
args: '0x6cd8ae51f91bacd7910126f880138b30ac5d3015',
cellOutput: {
capacity: '0x34e62ce00',
lock: {
codeHash:
'0x3419a1c09eb2567f6552ee7a8ecffd64155cffe0f1796e6e61ec088d740c1356',
hashType: 'type',
args: '0x1b3e74a036a21f94eba3d7c94b9d5619e1e84f7c',
},
type: {
codeHash:
'0xc5e5dcf215925f7ef4dfaf5f4b4f105bc321c02776d6e7d52a1db3fcd9d011a4',
hashType: 'type',
args: '0x0226fc667898d411d97a2603210b3636737b18b8d36bebad98c3eeca7562acdb',
},
},
data: '0xa0860100000000000000000000000000',
},
{
capacity: '0x5af0bc6e5c00',
lock: {
codeHash:
'0x5c5069eb0857efc65e1bca0c07df34c31663b3622fd3876c876320fc9634e2a8',
hashType: 'type',
args: '0x8bebce3e7dd7b7179defe4d06ecf9776b1ba686d',
cellOutput: {
lock: {
codeHash:
'0x3419a1c09eb2567f6552ee7a8ecffd64155cffe0f1796e6e61ec088d740c1356',
hashType: 'type',
args: '0x1b3e74a036a21f94eba3d7c94b9d5619e1e84f7c',
},
capacity: '0x90c8077ea80',
},
data: '0x',
},
],
witnesses: [
'0x55000000100000005500000055000000410000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000',
],
fixedEntries: [
{
capacity: '0x1bc0b78127dd9f00',
lock: {
codeHash:
'0x9bd7e06f3ecf4be0f2fcd2188b23f1b9fcc88e5d4b65a8637b17723bbda3cce8',
hashType: 'type',
args: '0xe390d4b9b4c7637ec80799bdaf644ae625cdb922',
},
field: 'outputs',
index: 0,
},
],
outputsData: ['0x', '0x', '0x'],
signingEntries: [],
inputSinces: {},
}

export const MOCK_TRANSACTION: Transaction[] = [
Expand Down
5 changes: 3 additions & 2 deletions app/components/asset/AssetList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,9 @@ interface AssetListProps

export const AssetList: FC<AssetListProps> = ({ className, ...attrs }) => {
const { addressHash } = useAccount()
const { data: assets } = useSWR(['assets'], () =>
sudtApi.account.listAssets(addressHash),
const { data: assets } = useSWR(
addressHash ? ['assets', addressHash] : null,
() => sudtApi.account.listAssets(addressHash),
)

if (!assets) {
Expand Down
28 changes: 28 additions & 0 deletions app/components/body/index.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
'use client'
import { useAccount } from '@/app/hooks/useAccount'
import { Inter } from 'next/font/google'
import { Account } from '../account'
import { MainSection } from '../section'
import { ConnectAccount } from '../connect-account'
const inter = Inter({ subsets: ['latin'] })

export function Body({ children }: { children: React.ReactNode }) {
const account = useAccount()

return (
<body className={inter.className}>
<main className="flex min-h-screen flex-col items-center p-10">
{account.isConnected ? (
<>
<Account />
<MainSection>{children}</MainSection>
</>
) : (
<MainSection>
<ConnectAccount />
</MainSection>
)}
</main>
</body>
)
}
18 changes: 9 additions & 9 deletions app/components/token/TokenInfomationForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,15 +23,6 @@ export function TokenInfomationForm({
return (
<form className="flex flex-col gap-4" onSubmit={handleSubmit(onSubmit)}>
<div className="bg-lighter-color p-4 rounded-xl flex flex-col gap-4">
<div className="flex flex-col">
<label>Symbol</label>
<Input
disabled={readonly}
{...register('symbol')}
error={errors.symbol !== undefined}
/>
</div>

<div className="flex flex-col">
<label>Name</label>
<Input
Expand All @@ -50,6 +41,15 @@ export function TokenInfomationForm({
/>
</div>

<div className="flex flex-col">
<label>Amount</label>
<Input
disabled={readonly}
{...register('amount')}
error={errors.amount !== undefined}
/>
</div>

<div className="flex flex-col">
<label>Decimal</label>
<Input
Expand Down
8 changes: 4 additions & 4 deletions app/components/token/TokenItem.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -19,14 +19,14 @@ export const TokenItem: FC<TokenItemProps> = ({
} w-full flex items-center bg-lighter-color p-3 rounded-lg text-sm`}
>
<span>{token.symbol}</span>
<Link className="ml-1" href={`/token/${token.symbol}`}>
<Link className="ml-1" href={`/token/${token.typeId}`}>
<img src="/icons/open.svg" alt="open" />
</Link>
<div className="ml-auto flex gap-1 text-primary-color">
<a className="cursor-pointer">Distribution</a>
<Link href={`/token/${token.symbol}`}>View</Link>
<Link href={`/token/${token.symbol}/modify`}>Modify</Link>
<Link href={`/token/${token.symbol}/mint`}>Mint</Link>
<Link href={`/token/${token.typeId}`}>View</Link>
<Link href={`/token/${token.typeId}/modify`}>Modify</Link>
<Link href={`/token/${token.typeId}/mint`}>Mint</Link>
</div>
</div>
)
Loading

0 comments on commit b67c6e3

Please sign in to comment.