Skip to content

Commit

Permalink
🔀 Merge development updates
Browse files Browse the repository at this point in the history
  • Loading branch information
nwingt committed Dec 5, 2022
2 parents a21affe + c73bd63 commit 28bff4b
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 25 deletions.
8 changes: 6 additions & 2 deletions src/components/NFTPortfolio/MainView.vue
Original file line number Diff line number Diff line change
Expand Up @@ -90,9 +90,13 @@
<NFTPortfolioEmpty :preset="portfolioTab" />
</li>
<li
v-for="nft in portfolioItemsTrimmed"
v-for="(nft, i) in portfolioItemsTrimmed"
:key="nft.classId"
class="absolute left-[12px] w-[310px] pb-[20px]"
:class="[
'absolute left-[12px] w-[310px] pb-[20px]',
// Let the first item covers the items not ready to be shown
i > 0 ? 'z-0' : 'z-[1]',
]"
>
<NFTPortfolioItem
:class-id="nft.classId"
Expand Down
4 changes: 3 additions & 1 deletion src/mixins/nft.js
Original file line number Diff line number Diff line change
Expand Up @@ -224,7 +224,9 @@ export default {
});
},
nftCollectorCollectedNFTList() {
return this.collectorMap[this.nftCollectorWalletAddress] || [];
return [
...(this.collectorMap[this.nftCollectorWalletAddress] || []),
].sort();
},
nftCollectorCollectedCount() {
return this.nftCollectorCollectedNFTList.length || 0;
Expand Down
26 changes: 5 additions & 21 deletions src/store/modules/nft.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
/* eslint no-param-reassign: "off" */
import Vue from 'vue';
import { LIKECOIN_NFT_HIDDEN_ITEMS } from '~/constant';
import * as api from '@/util/api';
import {
NFT_CLASS_LIST_SORTING,
NFT_CLASS_LIST_SORTING_ORDER,
checkIsWritingNFT,
normalizeNFTList,
isValidHttpUrl,
formatOwnerInfoFromChain,
getNFTsRespectDualPrefix,
Expand Down Expand Up @@ -354,38 +354,22 @@ const actions = {
return owners;
},
async fetchNFTListByAddress({ commit }, address) {
const [nfts, createdNFTs] = await Promise.all([
const [collectedNFTs, createdNFTClasses] = await Promise.all([
getNFTsRespectDualPrefix(this.$api, address),
getNFTClassesRespectDualPrefix(this.$api, address),
]);
const timestampMap = {};
nfts.forEach(nft => {
collectedNFTs.forEach(nft => {
const { classId, timestamp } = nft;
if (!timestampMap[classId] || timestampMap[classId] < timestamp) {
timestampMap[classId] = timestamp;
}
});
const collected = [
...new Map(
[...nfts]
.filter(({ classId }) => !LIKECOIN_NFT_HIDDEN_ITEMS.has(classId))
.sort((a, b) => b.timestamp - a.timestamp)
.map(({ classId, nftId }) => [classId, { classId, id: nftId }])
).values(),
];
const created = [
...new Map(
[...createdNFTs]
.filter(({ classId }) => !LIKECOIN_NFT_HIDDEN_ITEMS.has(classId))
.map(({ classId }) => [classId, { classId }])
).values(),
];

commit(TYPES.NFT_SET_USER_CLASSID_LIST_MAP, {
address,
nfts: {
created,
collected,
created: normalizeNFTList(createdNFTClasses),
collected: normalizeNFTList(collectedNFTs),
},
});
commit(TYPES.NFT_SET_USER_LAST_COLLECTED_TIMESTAMP_MAP, {
Expand Down
35 changes: 34 additions & 1 deletion src/util/nft.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import {
LIKECOIN_CHAIN_NFT_RPC,
LIKECOIN_CHAIN_MIN_DENOM,
LIKECOIN_NFT_API_WALLET,
LIKECOIN_NFT_HIDDEN_ITEMS,
} from '../constant';

let queryClient = null;
Expand Down Expand Up @@ -176,6 +177,14 @@ export function checkIsWritingNFT(classMetadata) {
);
}

// NOTE: This is a temporary solution to check Writing NFT by NFT ID,
// should be removed after created NFT list return proper content metadata
export function checkIsWritingNFTByNFTId(id) {
return /^writing-[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i.test(
id
);
}

export function formatNFTInfo(nftInfo) {
const {
class_id: classId,
Expand Down Expand Up @@ -266,7 +275,10 @@ const fetchAllNFTClassFromChain = async (axios, owner) => {
);
// TODO: getNFTClasses API already contains chain metadata
// should reuse them instead of dropping
return classes.map(c => ({ classId: c.id }));
return classes.map(c => ({
classId: c.id,
timestamp: new Date(c.created_at).getTime(),
}));
};

export const getNFTClassesRespectDualPrefix = async (axios, owner) => {
Expand Down Expand Up @@ -299,3 +311,24 @@ export function parseNFTMetadataURL(url) {
if (schema === 'ipfs') return `${IPFS_VIEW_GATEWAY_URL}/${path}`;
return url;
}

export function normalizeNFTList(list) {
return [
...new Map(
[...list].map(({ classId, nftId, ...data }) => [
classId,
{ ...data, classId, id: nftId },
])
).values(),
]
.filter(({ classId }) => !LIKECOIN_NFT_HIDDEN_ITEMS.has(classId))
.sort((a, b) => {
if (a.id && b.id) {
const aIsWritingNFT = checkIsWritingNFTByNFTId(a.id);
const bIsWritingNFT = checkIsWritingNFTByNFTId(b.id);
if (aIsWritingNFT && !bIsWritingNFT) return -1;
if (!aIsWritingNFT && bIsWritingNFT) return 1;
}
return b.timestamp - a.timestamp;
});
}

0 comments on commit 28bff4b

Please sign in to comment.