Skip to content

Commit

Permalink
fix: Show the tips for locked cells.
Browse files Browse the repository at this point in the history
  • Loading branch information
yanguoyu committed Nov 17, 2023
1 parent ce83292 commit 6ee6200
Show file tree
Hide file tree
Showing 7 changed files with 86 additions and 25 deletions.
22 changes: 14 additions & 8 deletions packages/neuron-ui/src/components/CellManage/hooks.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,33 +30,39 @@ const getLockStatusAndReason = (item: State.LiveCellWithLocalInfo) => {
locked: true,
}
}
let lockedReason = ''
let lockedReason: { key: string; params?: Record<string, any> } | undefined
if (item.typeScriptType) {
switch (item.typeScriptType) {
case TypeScriptCategory.NFT:
case TypeScriptCategory.NFTClass:
case TypeScriptCategory.NFTIssuer:
case TypeScriptCategory.Unknown:
lockedReason = 'cell-manage.locked-reason.operate-in-special-assets'
lockedReason = { key: 'cell-manage.locked-reason.NFT-SUDT-DAO', params: { type: 'NTF' } }
break
case TypeScriptCategory.SUDT:
lockedReason = 'cell-manage.locked-reason.operate-in-assets-account'
lockedReason = { key: 'cell-manage.locked-reason.NFT-SUDT-DAO', params: { type: 'SUDT' } }
break
case TypeScriptCategory.DAO:
lockedReason = 'cell-manage.locked-reason.operate-in-dao'
lockedReason = { key: 'cell-manage.locked-reason.NFT-SUDT-DAO', params: { type: 'Nervos DAO' } }
break
case TypeScriptCategory.Unknown:
lockedReason = { key: 'cell-manage.locked-reason.Unknown' }
break
default:
break
}
} else {
switch (item.lockScriptType) {
case LockScriptCategory.Cheque:
lockedReason = { key: 'cell-manage.locked-reason.cheque-acp-multisig', params: { type: 'Cheque' } }
break
case LockScriptCategory.ANYONE_CAN_PAY:
case LockScriptCategory.MULTI_LOCK_TIME:
lockedReason = 'cell-manage.locked-reason.operate-in-special-assets'
lockedReason = { key: 'cell-manage.locked-reason.cheque-acp-multisig', params: { type: 'Acp' } }
break
case LockScriptCategory.MULTISIG:
lockedReason = 'cell-manage.locked-reason.operate-in-multisig'
lockedReason = { key: 'cell-manage.locked-reason.cheque-acp-multisig', params: { type: 'Multisig' } }
break
case LockScriptCategory.MULTI_LOCK_TIME:
lockedReason = { key: 'cell-manage.locked-reason.multi-locktime' }
break
default:
break
Expand Down
41 changes: 38 additions & 3 deletions packages/neuron-ui/src/components/CellManage/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ import {
useCopy,
clsx,
outPointToStr,
LockScriptCategory,
getLockTimestamp,
} from 'utils'
import { HIDE_BALANCE } from 'utils/const'
import Tooltip from 'widgets/Tooltip'
Expand All @@ -34,6 +36,8 @@ const getColumns = ({
selectedOutPoints,
onSelectAll,
onSelect,
epoch,
bestKnownBlockTimestamp,
}: {
updateLiveCell: (params: State.UpdateLiveCellLocalInfo) => void
t: TFunction
Expand All @@ -42,6 +46,8 @@ const getColumns = ({
selectedOutPoints: Set<string>
onSelectAll: (e: React.ChangeEvent<HTMLInputElement>) => void
onSelect: (e: React.ChangeEvent<HTMLInputElement>) => void
epoch: string
bestKnownBlockTimestamp: number
}): TableProps<State.LiveCellWithLocalInfo>['columns'] => {
return [
{
Expand Down Expand Up @@ -109,11 +115,24 @@ const getColumns = ({
render(_, __, item: State.LiveCellWithLocalInfo) {
const { locked, lockedReason } = item
if (locked) {
let params = lockedReason?.params
if (item.lockScriptType === LockScriptCategory.MULTI_LOCK_TIME) {
if (bestKnownBlockTimestamp) {
const targetTime = new Date(
getLockTimestamp({ lockArgs: item.lock.args, epoch, bestKnownBlockTimestamp })
)
params = {
time: `${targetTime.getFullYear()}-${targetTime.getMonth() + 1}-${targetTime.getDate()}`,
}
} else {
params = { time: '--' }
}
}
return (
<div className={styles.lockedWithTip}>
{t('cell-manage.table.locked')}
{lockedReason ? (
<Tooltip tip={t(lockedReason)} className={styles.lockedTip} placement="top" showTriangle>
<Tooltip tip={t(lockedReason.key, params)} className={styles.lockedTip} placement="top" showTriangle>
<Attention />
</Tooltip>
) : null}
Expand Down Expand Up @@ -188,8 +207,12 @@ const getColumns = ({

const CellManage = () => {
const {
app: { epoch },
wallet: { balance = '' },
chain: { networkID },
chain: {
networkID,
syncState: { bestKnownBlockTimestamp },
},
settings: { networks },
} = useGlobalState()
const isMainnet = isMainnetUtil(networks, networkID)
Expand Down Expand Up @@ -231,8 +254,20 @@ const CellManage = () => {
onSelectAll,
isAllSelected,
selectedOutPoints,
epoch,
bestKnownBlockTimestamp,
}),
[updateLiveCell, t, onOpenActionDialog, onSelect, onSelectAll, isAllSelected, selectedOutPoints]
[
updateLiveCell,
t,
onOpenActionDialog,
onSelect,
onSelectAll,
isAllSelected,
selectedOutPoints,
epoch,
bestKnownBlockTimestamp,
]
)
const { copied, onCopy, copyTimes } = useCopy()
const { onViewDetail, rawData, rawLock, rawType, usedCapacity } = useViewCell({
Expand Down
8 changes: 4 additions & 4 deletions packages/neuron-ui/src/locales/en.json
Original file line number Diff line number Diff line change
Expand Up @@ -1174,10 +1174,10 @@
"used": "Used"
},
"locked-reason": {
"operate-in-special-assets": "Please use in special assets page",
"operate-in-assets-account": "Please use in assets account page",
"operate-in-dao": "Please use in Nervos DAO page",
"operate-in-multisig": "Please use in multisig page"
"multi-locktime": "The cell has a time lock and you can't use it until {{time}}.",
"cheque-acp-multisig": "This is a {{type}} cell and does not support unlocking.",
"NFT-SUDT-DAO": " This is a {{type}} asset and does not support unlocking.",
"Unknown": "This is an uncataloged asset,please check and confirm before proceeding."
},
"cell-lock-dialog": {
"title": "Lock Cell",
Expand Down
8 changes: 4 additions & 4 deletions packages/neuron-ui/src/locales/zh-tw.json
Original file line number Diff line number Diff line change
Expand Up @@ -1145,10 +1145,10 @@
"used": "已用"
},
"locked-reason": {
"operate-in-special-assets": "請在自定義資產操作",
"operate-in-assets-account": "請在資產賬戶操作",
"operate-in-dao": "請在 Nervos DAO 操作",
"operate-in-multisig": "請在多簽地址操作"
"multi-locktime": "The cell has a time lock and you can't use it until {{time}}.",
"cheque-acp-multisig": "這是壹個 {{type}} 的 cell, 不支持解鎖。",
"NFT-SUDT-DAO": "這是壹個 {{type}} 的資產,不支持解鎖。",
"Unknown": "This is an uncataloged asset,please check and confirm before proceeding."
},
"cell-lock-dialog": {
"title": "鎖定 Cell",
Expand Down
8 changes: 4 additions & 4 deletions packages/neuron-ui/src/locales/zh.json
Original file line number Diff line number Diff line change
Expand Up @@ -1166,10 +1166,10 @@
"used": "已用"
},
"locked-reason": {
"operate-in-special-assets": "请在自定义资产操作",
"operate-in-assets-account": "请在资产账户操作",
"operate-in-dao": "请在 Nervos DAO 操作",
"operate-in-multisig": "请在多签地址操作"
"multi-locktime": "The cell has a time lock and you can't use it until {{time}}。",
"cheque-acp-multisig": "这是一个 {{type}} 的 cell, 不支持解锁。",
"NFT-SUDT-DAO": "这是一个 {{type}} 的资产,不支持解锁。",
"Unknown": "這是壹項未知的資產,請在繼續操作之前進行檢查和確認。"
},
"cell-lock-dialog": {
"title": "锁定 Cell",
Expand Down
2 changes: 1 addition & 1 deletion packages/neuron-ui/src/types/App/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -365,7 +365,7 @@ declare namespace State {
locked?: boolean
}
interface LiveCellWithLocalInfo extends LiveCellWithLocalInfoAPI {
lockedReason?: string
lockedReason?: { key: string; params?: Record<string, any> }
cellType?: 'CKB' | 'SUDT' | 'NFT' | 'Unknown'
}

Expand Down
22 changes: 21 additions & 1 deletion packages/neuron-ui/src/utils/parsers.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { toUint64Le, parseEpoch } from 'services/chain'
import { PAGE_SIZE } from './const'
import { MILLISECONDS, PAGE_SIZE } from './const'

export const listParams = (search: string) => {
const query = new URLSearchParams(search)
Expand Down Expand Up @@ -44,3 +44,23 @@ export const toUint128Le = (hexString: string) => {

return `${toUint64Le(`0x${s.substr(18, 16)}`)}${toUint64Le(s.substr(0, 18)).slice(2)}`
}

export const getLockTimestamp = ({
lockArgs,
epoch,
bestKnownBlockTimestamp,
}: {
lockArgs: string
epoch: string
bestKnownBlockTimestamp: number
}) => {
const targetEpochInfo = epochParser(toUint64Le(`0x${lockArgs.slice(-16)}`))
const currentEpochInfo = epochParser(epoch)
const targetEpochFraction =
Number(targetEpochInfo.length) > 0 ? Number(targetEpochInfo.index) / Number(targetEpochInfo.length) : 1
const epochsInfo = {
target: Number(targetEpochInfo.number) + Math.min(targetEpochFraction, 1),
current: Number(currentEpochInfo.number) + Number(currentEpochInfo.index) / Number(currentEpochInfo.length),
}
return bestKnownBlockTimestamp + (epochsInfo.target - epochsInfo.current) * MILLISECONDS
}

0 comments on commit 6ee6200

Please sign in to comment.