-
Notifications
You must be signed in to change notification settings - Fork 324
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
✨(lld): add actions in ordis drawer (#7951)
- Loading branch information
1 parent
92df3b4
commit a7696cc
Showing
15 changed files
with
322 additions
and
164 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
--- | ||
"ledger-live-desktop": patch | ||
"@ledgerhq/live-nft": patch | ||
--- | ||
|
||
Refactor nft links to use it for ordinals and simplehash |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
99 changes: 99 additions & 0 deletions
99
apps/ledger-live-desktop/src/newArch/features/Collectibles/hooks/useCreateLinks.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,99 @@ | ||
import { useMemo } from "react"; | ||
import { TFunction } from "i18next"; | ||
import { ContextMenuItemType } from "~/renderer/components/ContextMenu/ContextMenuWrapper"; | ||
import { openURL } from "~/renderer/linking"; | ||
import { safeList } from "LLD/features/Collectibles/utils/useSafeList"; | ||
import { ExternalIdEnum, ItemType, ViewerEnum } from "LLD/features/Collectibles/types/enum/Links"; | ||
import IconOpensea from "~/renderer/icons/Opensea"; | ||
import IconRarible from "~/renderer/icons/Rarible"; | ||
import IconMagicEden from "~/renderer/icons/MagicEden"; | ||
import { IconsLegacy } from "@ledgerhq/react-ui"; | ||
import { SimpleHashNft } from "@ledgerhq/live-nft/api/types"; | ||
import { NFTMetadata, ProtoNFT } from "@ledgerhq/types-live"; | ||
import { isNFTMetadata } from "../utils/typeGuardsChecker"; | ||
import { createOrdinalExplorerUrl } from "../utils/createOrdinalExplorerUrl"; | ||
|
||
const createLinks = ( | ||
t: TFunction, | ||
links: Record<string, string> | SimpleHashNft["collection"]["marketplace_pages"] | undefined, | ||
isSimpleHash: boolean, | ||
explorerLink?: string, | ||
): ContextMenuItemType[] => { | ||
if (isSimpleHash) { | ||
const marketplacePages = Array.isArray(links) ? links : []; | ||
return safeList( | ||
[ | ||
...marketplacePages | ||
.filter(link => link.marketplace_id === ExternalIdEnum.MAGICEDEN) | ||
.map(link => ({ | ||
id: link.marketplace_id, | ||
label: t("NFT.viewer.actions.open", { viewer: ViewerEnum.MAGICEDEN }), | ||
Icon: IconMagicEden, | ||
type: ItemType.EXTERNAL, | ||
callback: () => openURL(link.nft_url), | ||
})), | ||
...(marketplacePages.length > 0 ? [{ id: "sep2", type: "separator", label: "" }] : []), | ||
...(explorerLink | ||
? [ | ||
{ | ||
id: ExternalIdEnum.EXPLORER, | ||
label: t("NFT.viewer.actions.open", { viewer: ViewerEnum.EXPLORER }), | ||
Icon: IconsLegacy.GlobeMedium, | ||
type: ItemType.EXTERNAL, | ||
callback: () => openURL(explorerLink), | ||
}, | ||
] | ||
: []), | ||
].filter(Boolean), | ||
); | ||
} else { | ||
const linksRecord = links as Record<string, string>; | ||
return safeList( | ||
[ | ||
linksRecord.opensea && { | ||
id: ExternalIdEnum.OPENSEA, | ||
label: t("NFT.viewer.actions.open", { viewer: ViewerEnum.OPENSEA }), | ||
Icon: IconOpensea, | ||
type: ItemType.EXTERNAL, | ||
callback: () => openURL(linksRecord.opensea), | ||
}, | ||
linksRecord.rarible && { | ||
id: ExternalIdEnum.RARIBLE, | ||
label: t("NFT.viewer.actions.open", { viewer: ViewerEnum.RARIBLE }), | ||
Icon: IconRarible, | ||
type: ItemType.EXTERNAL, | ||
callback: () => openURL(linksRecord.rarible), | ||
}, | ||
{ id: "sep2", type: "separator", label: "" }, | ||
linksRecord.explorer && { | ||
id: ExternalIdEnum.EXPLORER, | ||
label: t("NFT.viewer.actions.open", { viewer: ViewerEnum.EXPLORER }), | ||
Icon: IconsLegacy.GlobeMedium, | ||
type: ItemType.EXTERNAL, | ||
callback: () => openURL(linksRecord.explorer), | ||
}, | ||
].filter(Boolean), | ||
); | ||
} | ||
}; | ||
|
||
export const useCreateLinks = ( | ||
t: TFunction, | ||
metadata: NFTMetadata | SimpleHashNft["extra_metadata"], | ||
nft: ProtoNFT | SimpleHashNft, | ||
isSimpleHash: boolean, | ||
): ContextMenuItemType[] => { | ||
const inscriptionNumber = (nft as SimpleHashNft).extra_metadata?.ordinal_details | ||
?.inscription_number; | ||
|
||
return useMemo(() => { | ||
const links = isNFTMetadata(metadata) | ||
? metadata.links | ||
: (nft as SimpleHashNft).collection?.marketplace_pages; | ||
const explorerLink = isNFTMetadata(metadata) | ||
? metadata.links?.explorer | ||
: createOrdinalExplorerUrl(inscriptionNumber); | ||
|
||
return createLinks(t, links, isSimpleHash, explorerLink); | ||
}, [t, metadata, nft, isSimpleHash, inscriptionNumber]); | ||
}; |
59 changes: 59 additions & 0 deletions
59
apps/ledger-live-desktop/src/newArch/features/Collectibles/hooks/useCustomImage.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
import { isCustomLockScreenSupported } from "@ledgerhq/live-common/device/use-cases/screenSpecs"; | ||
import { SimpleHashNft } from "@ledgerhq/live-nft/api/types"; | ||
import { IconsLegacy } from "@ledgerhq/react-ui"; | ||
import { NFTMetadata, NFTMedias } from "@ledgerhq/types-live"; | ||
import { TFunction } from "i18next"; | ||
import { useMemo } from "react"; | ||
import { useSelector } from "react-redux"; | ||
import { getMetadataMediaTypes } from "~/helpers/nft"; | ||
import { setDrawer } from "~/renderer/drawers/Provider"; | ||
import { devicesModelListSelector } from "~/renderer/reducers/settings"; | ||
import { isNFTMetadata } from "LLD/features/Collectibles/utils/typeGuardsChecker"; | ||
import CustomImage from "~/renderer/screens/customImage"; | ||
|
||
export const useCustomImage = ( | ||
t: TFunction, | ||
metadata: NFTMetadata | SimpleHashNft["extra_metadata"], | ||
inscription?: SimpleHashNft, | ||
) => { | ||
const devicesModelList = useSelector(devicesModelListSelector); | ||
const customImageUri = useMemo(() => { | ||
if (!isNFTMetadata(metadata)) | ||
return inscription?.previews?.image_large_url || inscription?.image_url; | ||
|
||
const mediaTypes = metadata ? getMetadataMediaTypes(metadata) : null; | ||
const mediaSizeForCustomImage = mediaTypes | ||
? ["original", "big", "preview"].find(size => mediaTypes[size] === "image") | ||
: null; | ||
return mediaSizeForCustomImage | ||
? metadata?.medias?.[mediaSizeForCustomImage as keyof NFTMedias]?.uri | ||
: null; | ||
}, [inscription?.image_url, inscription?.previews?.image_large_url, metadata]); | ||
|
||
const customImageDeviceModelIds = devicesModelList.filter(isCustomLockScreenSupported); | ||
const customImageDeviceModelId = | ||
customImageDeviceModelIds.length === 1 ? customImageDeviceModelIds[0] : null; | ||
const showCustomImageButton = Boolean(customImageUri) && customImageDeviceModelIds.length > 0; | ||
|
||
return useMemo( | ||
() => ({ | ||
customImageUri, | ||
customImageDeviceModelId, | ||
showCustomImageButton, | ||
customImage: { | ||
id: "custom-image", | ||
label: t("customImage.cta"), | ||
Icon: IconsLegacy.PhotographMedium, | ||
callback: () => { | ||
if (customImageUri) | ||
setDrawer(CustomImage, { | ||
imageUri: customImageUri, | ||
deviceModelId: customImageDeviceModelId, | ||
isFromNFTEntryPoint: true, | ||
}); | ||
}, | ||
}, | ||
}), | ||
[customImageDeviceModelId, customImageUri, showCustomImageButton, t], | ||
); | ||
}; |
Oops, something went wrong.