components/common/listingCart/multipleItemsCart/ListingCartItem.vue
<template>
<div class="border-t border-k-shade py-5">
<CartItemDetails
:nft="nft"
:discarded="nft.discarded"
>
<template #right>
<NeoButton
class="text-k-grey pt-4"
variant="text"
no-shadow
:icon="nft.discarded ? 'plus' : 'trash'"
icon-pack="far"
@click="
listingCartStore.setItemDiscardedState({
id: nft.id,
discarded: !nft.discarded,
})
"
/>
</template>
<template
v-if="!nft.discarded"
#footer
>
<div class="mt-4 flex justify-between items-start">
<div class="flex flex-col">
<div class="text-k-grey text-xs">
{{ $t('activity.floor') }}
</div>
<span>{{ floor }}</span>
</div>
<div class="flex items-end">
<ListingCartPriceInput v-model="listingCartItem" />
</div>
</div>
</template>
</CartItemDetails>
</div>
</template>
<script setup lang="ts">
import { NeoButton } from '@kodadot1/brick'
import ListingCartPriceInput from '../shared/ListingCartPriceInput.vue'
import CartItemDetails from '@/components/common/CartItemDetails.vue'
import type { ListCartItem } from '@/stores/listingCart'
import { useListingCartStore } from '@/stores/listingCart'
const { decimals, chainSymbol } = useChain()
const listingCartStore = useListingCartStore()
const props = defineProps<{
nft: ListCartItem
}>()
const { formatted: floor } = useAmount(computed(() => props.nft.collection.floor || 0), decimals, chainSymbol, { withBlank: true })
const listingCartItem = computed({
get: () => listingCartStore.getItem(props.nft.id)?.listPrice,
set: price => listingCartStore.setItemPrice({ id: props.nft.id, price }),
})
</script>