import { useWalletSettings } from '@0xsequence/connect'
function WalletConfigPanel() {
const { displayedAssets, readOnlyNetworks, setDisplayedAssets } = useWalletSettings()
// Example function to add a new asset
const addNewAsset = (contractAddress: string, chainId: number) => {
setDisplayedAssets([
...displayedAssets,
{ contractAddress, chainId }
])
}
// Example function to check if network is read-only
const isNetworkReadOnly = (chainId: number) => {
return readOnlyNetworks?.includes(chainId)
}
return (
<div>
<h2>Wallet Settings</h2>
<div>
<h3>Displayed Assets</h3>
<ul>
{displayedAssets.map(asset => (
<li key={`${asset.chainId}-${asset.contractAddress}`}>
Chain ID: {asset.chainId}, Contract: {asset.contractAddress}
</li>
))}
</ul>
<button
onClick={() => addNewAsset('0x1234...', 1)}
disabled={isNetworkReadOnly(1)}
>
Add ETH Mainnet Asset
</button>
</div>
<div>
<h3>Network Status</h3>
<ul>
{[1, 137, 10].map(chainId => (
<li key={chainId}>
Chain {chainId}: {isNetworkReadOnly(chainId) ? 'Read-only' : 'Active'}
</li>
))}
</ul>
</div>
</div>
)
}