([])
const jarBalances = useMemo(() => {
if (!walletInfo) return []
@@ -54,24 +51,7 @@ export const SourceJarSelector = ({
)
}, [walletInfo])
- useEffect(() => {
- if (showUtxos?.jarIndex && walletInfo?.utxosByJar) {
- const data = Object.entries(walletInfo.utxosByJar).find(([key]) => key === showUtxos.jarIndex)
- const utxos: any = data ? data[1] : []
-
- const frozenUtxoList = utxos
- .filter((utxo: any) => utxo.frozen)
- .map((utxo: any) => ({ ...utxo, id: utxo.utxo, checked: false }))
- const unFrozenUtxosList = utxos
- .filter((utxo: any) => !utxo.frozen)
- .map((utxo: any) => ({ ...utxo, id: utxo.utxo, checked: true }))
-
- setFrozenUtxos(frozenUtxoList)
- setUnFrozenUtxos(unFrozenUtxosList)
- }
- }, [walletInfo, showUtxos?.jarIndex, t])
-
- useEffect(() => {
+ /*useEffect(() => {
if (frozenUtxos.length === 0 && unFrozenUtxos.length === 0) {
return
}
@@ -90,37 +70,44 @@ export const SourceJarSelector = ({
} else {
setAlert(undefined)
}
- }, [frozenUtxos, unFrozenUtxos, t, setAlert])
-
- const handleUtxosFrozenState = useCallback(async () => {
- const abortCtrl = new AbortController()
- const frozenUtxosToUpdate = frozenUtxos
- .filter((utxo) => utxo.checked && !utxo.locktime)
- .map((utxo) => ({ utxo: utxo.utxo, freeze: false }))
- const unFrozenUtxosToUpdate = unFrozenUtxos
- .filter((utxo) => !utxo.checked)
- .map((utxo) => ({ utxo: utxo.utxo, freeze: true }))
-
- try {
- const res = await Promise.all([
- ...frozenUtxosToUpdate.map((utxo) => Api.postFreeze({ ...wallet, signal: abortCtrl.signal }, utxo)),
- ...unFrozenUtxosToUpdate.map((utxo) => Api.postFreeze({ ...wallet, signal: abortCtrl.signal }, utxo)),
- ])
-
- if (res.length !== 0) {
- setIsUtxosLoading(true)
- await reloadCurrentWalletInfo.reloadUtxos({ signal: abortCtrl.signal })
- }
-
- setShowUtxos(undefined)
- } catch (err: any) {
- if (!abortCtrl.signal.aborted) {
- setAlert({ variant: 'danger', message: err.message, dismissible: true })
+ }, [frozenUtxos, unFrozenUtxos, t, setAlert])*/
+
+ const handleUtxosFrozenState = useCallback(
+ async (selectedUtxos: Utxos) => {
+ if (!showUtxos) return
+
+ const abortCtrl = new AbortController()
+
+ const selectedUtxosIds = selectedUtxos.map((it) => it.utxo)
+ const frozenUtxosToUnfreeze = selectedUtxos.filter((utxo) => utxo.frozen)
+ const unfrozenUtxosToFreeze = showUtxos.utxos
+ .filter((utxo) => !utxo.frozen)
+ .filter((it) => !selectedUtxosIds.includes(it.utxo))
+
+ try {
+ setShowUtxos({ ...showUtxos, isLoading: true, alert: undefined })
+
+ const res = await Promise.all([
+ ...frozenUtxosToUnfreeze.map((utxo) =>
+ Api.postFreeze({ ...wallet, signal: abortCtrl.signal }, { utxo: utxo.utxo, freeze: false }),
+ ),
+ ...unfrozenUtxosToFreeze.map((utxo) =>
+ Api.postFreeze({ ...wallet, signal: abortCtrl.signal }, { utxo: utxo.utxo, freeze: true }),
+ ),
+ ])
+
+ if (res.length !== 0) {
+ await reloadCurrentWalletInfo.reloadUtxos({ signal: abortCtrl.signal })
+ }
+
+ setShowUtxos(undefined)
+ } catch (err: any) {
+ if (abortCtrl.signal.aborted) return
+ setShowUtxos({ ...showUtxos, isLoading: false, alert: { variant: 'danger', message: err.message } })
}
- } finally {
- setIsUtxosLoading(false)
- }
- }, [frozenUtxos, unFrozenUtxos, wallet, reloadCurrentWalletInfo])
+ },
+ [showUtxos, wallet, reloadCurrentWalletInfo],
+ )
return (
<>
@@ -132,19 +119,14 @@ export const SourceJarSelector = ({
) : (
- {showUtxos?.isOpen && (
+ {showUtxos && (
{
- setShowUtxos(undefined)
- }}
- alert={alert}
- isLoading={isUtxosLoading}
- frozenUtxos={frozenUtxos}
- unFrozenUtxos={unFrozenUtxos}
- setFrozenUtxos={setFrozenUtxos}
- setUnFrozenUtxos={setUnFrozenUtxos}
+ onCancel={() => setShowUtxos(undefined)}
/>
)}
{jarBalances.map((it) => {
@@ -163,7 +145,7 @@ export const SourceJarSelector = ({
walletInfo.balanceSummary.calculatedTotalBalanceInSats,
)}
variant={it.accountIndex === field.value ? variant : undefined}
- onClick={(jarIndex: number) => {
+ onClick={(jarIndex) => {
form.setFieldValue(field.name, jarIndex, true)
if (
it.accountIndex === field.value &&
@@ -172,8 +154,8 @@ export const SourceJarSelector = ({
it.calculatedTotalBalanceInSats > 0
) {
setShowUtxos({
- jarIndex: it.accountIndex.toString(),
- isOpen: true,
+ utxos: walletInfo.utxosByJar[it.accountIndex],
+ isLoading: false,
})
}
}}
diff --git a/src/components/jar_details/UtxoList.tsx b/src/components/jar_details/UtxoList.tsx
index f6be3702b..e782f0800 100644
--- a/src/components/jar_details/UtxoList.tsx
+++ b/src/components/jar_details/UtxoList.tsx
@@ -156,7 +156,7 @@ const toUtxo = (tableNode: TableTypes.TableNode): Utxo => {
return utxo as Utxo
}
-interface UtxoTableRow extends Utxo {
+interface UtxoTableRow extends Utxo, TableTypes.TableNode {
_icon: JSX.Element
_tags: Tag[]
_confs: JSX.Element
diff --git a/src/components/settings/FeeConfigModal.module.css b/src/components/settings/FeeConfigModal.module.css
index faf340e8b..b16cbd893 100644
--- a/src/components/settings/FeeConfigModal.module.css
+++ b/src/components/settings/FeeConfigModal.module.css
@@ -33,7 +33,6 @@
.modalFooter .buttonContainer :global .btn {
flex-grow: 1;
- min-height: 2.8rem;
font-weight: 500;
border-color: none !important;
}
diff --git a/src/components/settings/FeeConfigModal.tsx b/src/components/settings/FeeConfigModal.tsx
index 581be1bcd..d38604774 100644
--- a/src/components/settings/FeeConfigModal.tsx
+++ b/src/components/settings/FeeConfigModal.tsx
@@ -10,9 +10,9 @@ import { useUpdateConfigValues } from '../../context/ServiceConfigContext'
import { isDebugFeatureEnabled } from '../../constants/debugFeatures'
import ToggleSwitch from '../ToggleSwitch'
import { isValidNumber, factorToPercentage, percentageToFactor } from '../../utils'
-import styles from './FeeConfigModal.module.css'
import BitcoinAmountInput, { AmountValue, toAmountValue } from '../BitcoinAmountInput'
import { JM_MAX_SWEEP_FEE_CHANGE_DEFAULT } from '../../constants/config'
+import styles from './FeeConfigModal.module.css'
const __dev_allowFeeValuesReset = isDebugFeatureEnabled('allowFeeValuesReset')
diff --git a/src/context/WalletContext.tsx b/src/context/WalletContext.tsx
index 5632f7975..080df1ae4 100644
--- a/src/context/WalletContext.tsx
+++ b/src/context/WalletContext.tsx
@@ -53,8 +53,7 @@ export type Utxo = {
// `locktime` in format "yyyy-MM-dd 00:00:00"
// NOTE: it is unparsable with safari Date constructor
locktime?: string
- id: string
- checked?: boolean
+ // TODO: remove 'tags' prop
tags?: { tag: string; color: string }[]
}
@@ -195,7 +194,6 @@ export const groupByJar = (utxos: Utxos): UtxosByJar => {
return utxos.reduce((res, utxo) => {
const { mixdepth } = utxo
res[mixdepth] = res[mixdepth] || []
- utxo.id = utxo.utxo
res[mixdepth].push(utxo)
return res
}, {} as UtxosByJar)
diff --git a/src/i18n/locales/en/translation.json b/src/i18n/locales/en/translation.json
index fcbdf99f4..00a3de510 100644
--- a/src/i18n/locales/en/translation.json
+++ b/src/i18n/locales/en/translation.json
@@ -706,9 +706,6 @@
"selected_utxos": "Selected 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.",
- "alert_for_unfreeze_utxos": "At least one UTXO is required to perform a transaction",
- "alert_for_time_locked": "Selected UTXO is Time Locked till",
- "alert_for_empty_utxos": "Please Unfreeze UTXOs to send"
+ "show_utxo_subtitle_when_allutxos_are_frozen": "The following UTXOs are frozen. Please select them to be considered in the transaction."
}
}