1
0
mirror of https://github.com/oceanprotocol/market.git synced 2024-12-02 05:57:29 +01:00

NFT metadata updates

* switch to `image_data` instead of `image` key
* add `external_url` & `background_color`
* make following OpenSea standard more clear
* ref #944
This commit is contained in:
Matthias Kretschmann 2022-01-11 14:52:01 +00:00
parent a235255cc0
commit c3301fb437
Signed by: m
GPG Key ID: 606EEEF3C479A91F
3 changed files with 13 additions and 4 deletions

View File

@ -1,10 +1,16 @@
import { renderStaticWaves } from './oceanWaves' import { renderStaticWaves } from './oceanWaves'
// https://docs.opensea.io/docs/metadata-standards
export interface NftOptions { export interface NftOptions {
name: string name: string
symbol: string symbol: string
description: string description: string
image: string image?: string
/* eslint-disable camelcase */
external_url?: string
image_data?: string
background_color?: string
/* eslint-enable camelcase */
} }
function encodeSvg(svgString: string): string { function encodeSvg(svgString: string): string {
@ -36,9 +42,12 @@ export function generateNftOptions(): NftOptions {
name: 'Ocean Asset v4 NFT', name: 'Ocean Asset v4 NFT',
symbol: 'OCEAN-V4-NFT', symbol: 'OCEAN-V4-NFT',
description: `This NFT represents an asset in the Ocean Protocol v4 ecosystem.`, description: `This NFT represents an asset in the Ocean Protocol v4 ecosystem.`,
// TODO: ideally this includes the final DID
external_url: 'https://market.oceanprotocol.com',
background_color: '141414', // dark background
// TODO: figure out if also image URI needs base64 encoding // TODO: figure out if also image URI needs base64 encoding
// generated SVG embedded as 'data:image/svg+xml' and encoded characters // generated SVG embedded as 'data:image/svg+xml' and encoded characters
image: `data:image/svg+xml,${encodeSvg(image)}` image_data: `data:image/svg+xml,${encodeSvg(image)}`
// generated SVG embedded as 'data:image/svg+xml;base64' // generated SVG embedded as 'data:image/svg+xml;base64'
// image: `data:image/svg+xml;base64,${window?.btoa(image)}` // image: `data:image/svg+xml;base64,${window?.btoa(image)}`
// image: `data:image/svg+xml;base64,${Buffer.from(image).toString('base64')}` // image: `data:image/svg+xml;base64,${Buffer.from(image).toString('base64')}`

View File

@ -20,7 +20,7 @@ export default function Nft(props: InputProps): ReactElement {
return ( return (
<div className={styles.nft}> <div className={styles.nft}>
<figure className={styles.image}> <figure className={styles.image}>
<img src={field?.value?.image} width="128" height="128" /> <img src={field?.value?.image_data} width="128" height="128" />
<Button <Button
style="text" style="text"
size="small" size="small"

View File

@ -56,7 +56,7 @@ export const initialValues: FormPublishData = {
accountId: '' accountId: ''
}, },
metadata: { metadata: {
nft: { name: '', symbol: '', description: '', image: '' }, nft: { name: '', symbol: '', description: '', image_data: '' },
type: 'dataset', type: 'dataset',
name: '', name: '',
author: '', author: '',