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

chore: small quick freeze modal adaptions #847

Merged
merged 8 commits into from
Sep 30, 2024
38 changes: 24 additions & 14 deletions src/components/PaymentConfirmModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,15 +3,15 @@ import { Trans, useTranslation } from 'react-i18next'
import * as rb from 'react-bootstrap'
import Sprite from './Sprite'
import Balance from './Balance'
import { useSettings } from '../context/SettingsContext'
import { Settings, useSettings } from '../context/SettingsContext'
import { FeeValues, TxFee, useEstimatedMaxCollaboratorFee } from '../hooks/Fees'
import { ConfirmModal, ConfirmModalProps } from './Modal'
import { AmountSats, BitcoinAddress } from '../libs/JmWalletApi'
import { jarInitial } from './jars/Jar'
import { isValidNumber } from '../utils'
import styles from './PaymentConfirmModal.module.css'
import { Utxos } from '../context/WalletContext'
import { SelectableUtxo, UtxoListDisplay } from './Send/ShowUtxos'
import { UtxoListDisplay } from './Send/ShowUtxos'
import Divider from './Divider'

const feeRange: (txFee: TxFee, txFeeFactor: number) => [number, number] = (txFee, txFeeFactor) => {
Expand Down Expand Up @@ -58,26 +58,36 @@ const useMiningFeeText = ({ tx_fees, tx_fees_factor }: Pick<FeeValues, 'tx_fees'
}, [t, tx_fees, tx_fees_factor])
}

type ReviewConsideredUtxosProps = {
utxos: SelectableUtxo[]
type ReviewUtxosProps = Required<Pick<PaymentDisplayInfo, 'isSweep' | 'availableUtxos'>> & {
settings: Settings
}
const ReviewConsideredUtxos = ({ utxos }: ReviewConsideredUtxosProps) => {

const ReviewUtxos = ({ settings, availableUtxos, isSweep }: ReviewUtxosProps) => {
const { t } = useTranslation()
const settings = useSettings()
const [isOpen, setIsOpen] = useState<boolean>(false)
const [isOpen, setIsOpen] = useState<boolean>(availableUtxos.length === 1)

const allUtxosAreUsed = isSweep || availableUtxos.length === 1
return (
<rb.Row className="mt-2">
<rb.Col xs={4} md={3} className="text-end">
<strong>{t('show_utxos.considered_utxos')}</strong>
<strong>
{allUtxosAreUsed
? t('send.confirm_send_modal.label_selected_utxos')
: t('send.confirm_send_modal.label_eligible_utxos')}
</strong>
</rb.Col>
<rb.Col xs={8} md={9}>
<Divider toggled={isOpen} onToggle={() => setIsOpen((current) => !current)} />
</rb.Col>
<rb.Collapse in={isOpen}>
<rb.Col xs={12} className="mt-2">
<rb.Col xs={12}>
<div className="my-2 text-start text-secondary">
{allUtxosAreUsed
? t('send.confirm_send_modal.description_selected_utxos', { count: availableUtxos.length })
: t('send.confirm_send_modal.description_eligible_utxos')}
</div>
<UtxoListDisplay
utxos={utxos}
utxos={availableUtxos.map((it) => ({ ...it, checked: false, selectable: false }))}
settings={settings}
onToggle={() => {
// No-op since these UTXOs are only for review and are not selectable
Expand All @@ -98,7 +108,7 @@ interface PaymentDisplayInfo {
numCollaborators?: number
feeConfigValues?: FeeValues
showPrivacyInfo?: boolean
consideredUtxos?: Utxos
availableUtxos?: Utxos
}

interface PaymentConfirmModalProps extends ConfirmModalProps {
Expand All @@ -115,7 +125,7 @@ export function PaymentConfirmModal({
numCollaborators,
feeConfigValues,
showPrivacyInfo = true,
consideredUtxos = [],
availableUtxos = [],
},
children,
...confirmModalProps
Expand Down Expand Up @@ -243,8 +253,8 @@ export function PaymentConfirmModal({
</rb.Col>
</rb.Row>
)}
{consideredUtxos.length !== 0 && (
<ReviewConsideredUtxos utxos={consideredUtxos.map((it) => ({ ...it, checked: false, selectable: false }))} />
{availableUtxos.length > 0 && (
<ReviewUtxos settings={settings} availableUtxos={availableUtxos} isSweep={isSweep} />
)}
{children && (
<rb.Row>
Expand Down
22 changes: 9 additions & 13 deletions src/components/Send/ShowUtxos.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -35,16 +35,12 @@ interface UtxoRowProps {
settings: Settings
walletInfo: WalletInfo
t: TFunction
// TODO: remove
showBackgroundColor?: boolean
}

interface UtxoListDisplayProps {
utxos: SelectableUtxo[]
onToggle: (utxo: SelectableUtxo) => void
settings: Settings
// TODO: remove
showBackgroundColor?: boolean
}

const UtxoRow = ({ utxo, onToggle, settings, walletInfo, t }: UtxoRowProps) => {
Expand Down Expand Up @@ -78,7 +74,7 @@ const UtxoRow = ({ utxo, onToggle, settings, walletInfo, t }: UtxoRowProps) => {
<Cell>
<UtxoIcon value={utxo} tags={tags} />
</Cell>
<Cell className="slashed-zeroes">
<Cell className="font-monospace slashed-zeroes">
<rb.OverlayTrigger
overlay={(props) => (
<rb.Tooltip className="slashed-zeroes" {...props}>
Expand Down Expand Up @@ -113,7 +109,7 @@ type SelectableUtxoTableRowData = SelectableUtxo & Pick<TableTypes.TableNode, 'i

const DEFAULT_UTXO_LIST_THEME = {
Table: `
--data-table-library_grid-template-columns: 2.5rem 2.5rem 17rem 3rem 12rem 1fr};
--data-table-library_grid-template-columns: 2.5rem 2.5rem 17rem 3.75rem 11rem 1fr};
`,
BaseCell: `
padding: 0.35rem 0.25rem !important;
Expand Down Expand Up @@ -212,9 +208,9 @@ const ShowUtxos = ({ isOpen, onCancel, onConfirm, isLoading, utxos, alert }: Sho
<BaseModal
isShown={isOpen}
onCancel={onCancel}
backdrop={true}
title={t('show_utxos.show_utxo_title')}
closeButton
title={t('show_utxos.title')}
backdrop={!isLoading}
closeButton={!isLoading}
headerClassName=""
titleClassName=""
>
Expand All @@ -226,10 +222,9 @@ const ShowUtxos = ({ isOpen, onCancel, onConfirm, isLoading, utxos, alert }: Sho
</div>
) : (
<>
<rb.Row className="text-secondary px-3 mb-2">
{upperUtxos.length > 0
? t('show_utxos.show_utxo_subtitle')
: t('show_utxos.show_utxo_subtitle_when_allutxos_are_frozen')}
<rb.Row className="text-secondary mb-2">
<div>{t('show_utxos.subtitle', { count: selectedUtxos.length })}</div>
<div>{t('show_utxos.text_subtitle_addon')}</div>
</rb.Row>
{alert && (
<rb.Row>
Expand Down Expand Up @@ -274,6 +269,7 @@ const ShowUtxos = ({ isOpen, onCancel, onConfirm, isLoading, utxos, alert }: Sho
<rb.Button
variant="light"
onClick={() => onCancel()}
disabled={isLoading}
className="d-flex flex-1 justify-content-center align-items-center"
>
<Sprite symbol="cancel" width="26" height="26" />
Expand Down
2 changes: 1 addition & 1 deletion src/components/Send/SourceJarSelector.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,7 @@ export const SourceJarSelector = ({
return (
<div key={it.accountIndex}>
<SelectableJar
tooltipText={t('show_utxos.select_utxos')}
tooltipText={t('show_utxos.text_select_utxos_tooltip')}
isOpen={true}
index={it.accountIndex}
balance={it.calculatedAvailableBalanceInSats}
Expand Down
2 changes: 1 addition & 1 deletion src/components/Send/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -521,7 +521,7 @@ export default function Send({ wallet }: SendProps) {
isCoinjoin: showConfirmSendModal.isCoinJoin,
numCollaborators: showConfirmSendModal.numCollaborators!,
feeConfigValues: { ...feeConfigValues, tx_fees: showConfirmSendModal.txFee },
consideredUtxos: (walletInfo?.utxosByJar[showConfirmSendModal.sourceJarIndex!] || [])
availableUtxos: (walletInfo?.utxosByJar[showConfirmSendModal.sourceJarIndex!] || [])
.filter((utxo) => !utxo.frozen)
.sort((a, b) => a.confirmations - b.confirmations),
}}
Expand Down
3 changes: 0 additions & 3 deletions src/components/utxo/Confirmations.module.css
Original file line number Diff line number Diff line change
@@ -1,10 +1,7 @@
.confirmations {
width: 2rem;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
padding: 0.1rem 0.2rem;
border-radius: 0.2rem;
font-size: 0.75rem;
}
18 changes: 12 additions & 6 deletions src/i18n/locales/en/translation.json
Original file line number Diff line number Diff line change
Expand Up @@ -351,7 +351,12 @@
"text_miner_fee_in_satspervbyte_exact": "{{ value }} sats/vByte",
"text_miner_fee_in_satspervbyte_randomized": "{{ min }} - {{ max }} sats/vByte",
"text_miner_fee_in_targeted_blocks_one": "High priority estimate (next block)",
"text_miner_fee_in_targeted_blocks_other": "Using estimate for inclusion in next {{ count }} blocks"
"text_miner_fee_in_targeted_blocks_other": "Using estimate for inclusion in next {{ count }} blocks",
"label_eligible_utxos": "Eligible UTXOs",
"description_eligible_utxos": "One or more of the following UTXOs will be included in the transaction: ",
"label_selected_utxos": "Selected UTXOs",
"description_selected_utxos_one": "The following UTXO will be included the transaction: ",
"description_selected_utxos_other": "The following UTXOs will be included the transaction: "
theborakompanioni marked this conversation as resolved.
Show resolved Hide resolved
},
"confirm_abort_modal": {
"title": "Abort payment",
Expand Down Expand Up @@ -717,10 +722,11 @@
}
},
"show_utxos": {
"select_utxos": "Select UTXOs",
"considered_utxos": "Considered UTXOs",
"show_utxo_title": "Select UTXOs to be considered",
"show_utxo_subtitle": "The following UTXOs are considered in the transaction. Every unselected UTXO will be frozen and can be unfrozen later on.",
"show_utxo_subtitle_when_allutxos_are_frozen": "The following UTXOs are frozen. Please select them to be considered in the transaction."
"text_select_utxos_tooltip": "Select UTXOs",
"title": "Select eligible UTXOs",
"subtitle_zero": "Please select one or more UTXOs for possible inclusion in the transaction.",
"subtitle_one": "The selected UTXO is eligible for inclusion in the transaction.",
Copy link
Contributor

Choose a reason for hiding this comment

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

I see the matching with the subtitle_other, but it reads a bit weird imo "is eligible for inclusion" as it will for sure be included,
maybe something like The selected UTXO will be used in the transaction.

Copy link
Collaborator Author

@theborakompanioni theborakompanioni Sep 17, 2024

Choose a reason for hiding this comment

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

I open to any suggestion. However, doesn't

The selected UTXO will be used in the transaction.

sound more like it will "definitely used" in the transaction than the other phrase ("eligible for inclusion")?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Ahh.. okay. Now I think I get what you mean. If only one UTXO is selected, it will of course be included, yes?
Good point! I am not sure if the phrasing should change so "suddenly" when a user ticks some boxes in this component as it is just for quickly freezing/unfreezing..

I think @editwentyone might have good inputs to this also.

Choose a reason for hiding this comment

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

@MarnixCroes I can't tell right now what is the best way, I would try to avoid the switching during selecting. lets see when we keep it like this first and then we can adjust it in another PR if needed

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

@MarnixCroes Okay for you if it is merged the way it is currently?
I think it the context of "quickly freezing/unfreezing UTXOs", phrasing it this way is "okay".

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Hey @MarnixCroes - if it is okay for you, I'll merge this soon.

Copy link
Contributor

Choose a reason for hiding this comment

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

sorry I missed this.
yes sure it's ok

"subtitle_other": "The selected UTXOs are eligible for inclusion in the transaction.",
"text_subtitle_addon": "Unselected UTXOs will be frozen and can be unfrozen later anytime."
}
}