Skip to content

Commit

Permalink
feat: Cell manage (nervosnetwork#2859)
Browse files Browse the repository at this point in the history
* feat: Cell manage

* fix: Fix bugs of issue 298(1, 2, 3, 4, 5, 6)

* fix: Disable lock or unlock when all of the selected status is same.

Others optimize
1. rename `type` to `Category`
2. delete `walletId` in the `getSudtTokenInfo` function.

* fix: Add left join to add assetAccounts field.

* fix: Show the tips for locked cells.

* fix: Send max for consume appointed cells.

* fix: Show claim in Customized Assets if the lock time is reached.

* fix: Use filter option to get live and sent cell.

* fix: fix conversation

1. Better name cellManagement.
2. Move transformer to CellLocalInfo entity.
3. Use `UpdateCellLocalInfo` to replace multi params.

* fix: Fix test case

* fix: Adapt Spore for cell management.

* fix: Hide the balance when use consume cell
  • Loading branch information
yanguoyu committed Mar 14, 2024
1 parent 6c4efc6 commit 645c6e4
Show file tree
Hide file tree
Showing 69 changed files with 3,241 additions and 435 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -132,6 +132,7 @@
height: 56px;
line-height: 56px;
min-width: 100px;
max-width: 200px;
.descTips {
@media screen and (max-width: 1400px) {
transform: translateX(-70%) !important;
Expand Down Expand Up @@ -165,47 +166,6 @@
transform: translateX(-40%) !important;
}
}

.descTipRoot {
position: relative;
width: 208px;
.autoHeight {
width: 100%;
height: 100%;
position: absolute;

& > svg {
position: absolute;
right: 0;
bottom: 8px;
}
}
.descInput {
border: none;
word-break: break-word;
resize: none;
width: 100%;
height: 100%;
line-height: 24px;
background-color: transparent;
color: var(--main-text-color);
caret-color: #000000;
pointer-events: none;

@media (prefers-color-scheme: dark) {
caret-color: #fff;
}
}
& > .hidden {
word-break: break-word;
white-space: break-spaces;
visibility: hidden;
min-width: 100px;
min-height: 24px;
padding: 2px;
line-height: 24px;
}
}
}

@media screen and (max-width: 1330px) {
Expand Down
37 changes: 10 additions & 27 deletions packages/neuron-ui/src/components/AddressBook/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,12 @@ import { useTranslation } from 'react-i18next'
import { useState as useGlobalState, useDispatch } from 'states'
import Dialog from 'widgets/Dialog'
import CopyZone from 'widgets/CopyZone'
import { Copy, Edit } from 'widgets/Icons/icon'
import { Copy } from 'widgets/Icons/icon'
import Table, { TableProps, SortType } from 'widgets/Table'
import { shannonToCKBFormatter, useLocalDescription } from 'utils'
import { HIDE_BALANCE } from 'utils/const'
import Tooltip from 'widgets/Tooltip'
import ShowOrEditDesc from 'widgets/ShowOrEditDesc'
import styles from './addressBook.module.scss'

enum TabIdx {
Expand Down Expand Up @@ -42,8 +43,7 @@ const AddressBook = ({ onClose }: { onClose?: () => void }) => {
}, [tabIdx, addresses])

const dispatch = useDispatch()
const { localDescription, onDescriptionPress, onDescriptionChange, onDescriptionFieldBlur, onDescriptionSelected } =
useLocalDescription('address', walletId, dispatch, 'textarea')
const { onChangeEditStatus, onSubmitDescription } = useLocalDescription('address', walletId, dispatch)

const columns = useMemo<TableProps<State.Address>['columns']>(
() => [
Expand Down Expand Up @@ -87,32 +87,15 @@ const AddressBook = ({ onClose }: { onClose?: () => void }) => {
dataIndex: 'description',
align: 'center',
render(description: string, _idx, item) {
const isSelected = localDescription.key === item.address
return (
<Tooltip
tip={
<div className={styles.descTipRoot}>
<div className={styles.autoHeight}>
<textarea
className={styles.descInput}
data-is-selected={isSelected}
data-description-key={item.address}
value={isSelected ? localDescription.description : description}
onChange={onDescriptionChange}
onKeyDown={onDescriptionPress}
onBlur={onDescriptionFieldBlur}
/>
<Edit
data-description-key={item.address}
data-description-value={item.description}
onClick={onDescriptionSelected}
/>
</div>
<div className={styles.hidden}>
{isSelected ? localDescription.description : description}
<Edit />
</div>
</div>
<ShowOrEditDesc
description={description}
descKey={item.address}
onSubmitDescription={onSubmitDescription}
onChangeEditStatus={onChangeEditStatus}
/>
}
showTriangle
isTriggerNextToChild
Expand Down Expand Up @@ -167,7 +150,7 @@ const AddressBook = ({ onClose }: { onClose?: () => void }) => {
},
},
],
[t, localDescription]
[t]
)

return (
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,238 @@
@use 'sass:color';
@import '../../styles/mixin.scss';

.head {
display: flex;

.balance {
font-size: 14px;
margin-left: 14px;
display: flex;
align-items: center;

&::before {
content: '';
width: 1px;
height: 12px;
background-color: var(--border-color);
}

& > svg {
margin: 0 8px;
cursor: pointer;
path {
fill: currentColor;
}
}
}
}

.tableHead {
padding: 18px 0 16px 16px;
font-size: 16px;
font-weight: 500;
}

.container {
margin: 20px 0;
}

.lockedWithTip {
display: flex;
align-items: center;

.lockedTip {
margin-left: 4px;
g,
path {
fill: var(--main-text-color);
}
}
}

.actions {
& > svg {
cursor: pointer;
&[data-disabled='true'] {
cursor: not-allowed;
opacity: 50%;
}
margin-right: 16px;
}
}

.cellDetailDialog {
width: 680px;

.section {
margin-bottom: 20px;

.txHash {
padding: 10px 0 10px 16px;
border-radius: 8px;
display: flex;
background-color: var(--input-disabled-color);
p {
font-family: 'JetBrains Mono';
font-size: 14px;
font-weight: 400;
color: var(--main-text-color);
}
.cellActions {
width: 80px;
display: flex;
align-items: center;
justify-content: space-evenly;
flex-shrink: 0;

& > svg {
cursor: pointer;
width: 16px;
height: 16px;
}
}
}

.title {
font-size: 14px;
font-weight: 400;
line-height: 20px;
color: var(--secondary-text-color);
margin: 0 0 8px 0;
}

& > pre {
border: 1px solid var(--lock-info-title-border);
border-radius: 12px;
padding: 16px;
font-family: 'JetBrains Mono';
line-height: 18px;
overflow-y: auto;
margin: 0;
color: var(--main-text-color);
}

.capacity {
display: flex;
justify-content: space-between;
align-items: center;

.capacityDetail {
font-weight: 400;
color: var(--main-text-color);
}
}

.slider {
width: 648px;
height: 8px;
border-radius: 8px;
background-color: var(--process-background-color);
position: relative;

& > div {
position: absolute;
left: 0;
top: 0;
height: 100%;
border-radius: 8px;
background-color: var(--primary-color);
}
}
}

.notice {
@include dialog-copy-animation;
}
}

.description {
height: 56px;
line-height: 56px;
min-width: 100px;

.descText {
@include text-overflow-ellipsis;
max-width: calc(100vw - 1050px);
cursor: pointer;
}
}

.table {
position: relative;
@include checkbox;

.multiActions {
position: absolute;
bottom: 24px;
left: 50%;
transform: translateX(-50%);
padding: 12px 40px 12px 40px;
border-radius: 40px;
background-color: var(--secondary-background-color);
box-shadow: 0px 8px 16px 4px var(--divide-line-color);
display: flex;
justify-content: space-evenly;
column-gap: 56px;

& > button {
display: flex;
flex-direction: column;
align-items: center;
border: none;
background-color: transparent;
color: var(--secondary-text-color);
column-gap: 2px;
cursor: pointer;
&[disabled] {
cursor: not-allowed;
opacity: 50%;
}

& > svg {
width: 20px;
height: 20px;
}
}
}
}

.consumeNotice {
color: var(--main-text-color);
padding: 0 24px;
font-size: 14px;
font-weight: 400;
}

.lockCell {
width: 648px;
text-align: center;

.cellsCapacity {
text-align: center;
color: var(--main-text-color);
font-size: 16px;
font-weight: 500;
margin: 0;
}

.passwordInput {
margin-top: 12px;
}

.canNotUse {
display: inline-flex;
align-items: center;
background: color-mix(in srgb, #fc8800 5%, var(--warn-background-color));
border: 1px solid #fc880033;
border-radius: 4px;
color: var(--warn-text-color);
font-size: 12px;
text-align: center;
padding: 8px 36px;

& > svg {
margin-right: 4px;
}
}
}
Loading

0 comments on commit 645c6e4

Please sign in to comment.