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

Feature/edit history subgraph (#423)

* fetching Subgraph data

* updates ordered by timestamp

* comment removed

* comment removed

* apollo generated  typing used

* date converted to string

Co-authored-by: claudia.holhos <claudia.holhos@hpm.ro>
This commit is contained in:
claudiaHash 2021-03-04 19:31:10 +02:00 committed by GitHub
parent 8737264816
commit be82d9ef2e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 30 additions and 39 deletions

View File

@ -4,52 +4,53 @@ import { useAsset } from '../../../providers/Asset'
import EtherscanLink from '../../atoms/EtherscanLink' import EtherscanLink from '../../atoms/EtherscanLink'
import Time from '../../atoms/Time' import Time from '../../atoms/Time'
import styles from './EditHistory.module.css' import styles from './EditHistory.module.css'
import { gql, useQuery } from '@apollo/client'
import { ReceiptData_datatokens_updates as ReceiptData } from '../../../@types/apollo/ReceiptData'
interface Receipt { const getReceipts = gql`
hash: string query ReceiptData($address: String!) {
timestamp: string datatokens(where: { id: $address }) {
createTime
tx
updates(orderBy: timestamp, orderDirection: desc) {
id
tx
timestamp
} }
// TODO: fetch for real
const fakeReceipts = [
{
hash: '0xxxxxxxxx',
timestamp: '1607460269'
},
{
hash: '0xxxxxxxxx',
timestamp: '1606460159'
},
{
hash: '0xxxxxxxxx',
timestamp: '1506460159'
} }
] }
`
export default function EditHistory(): ReactElement { export default function EditHistory(): ReactElement {
const { networkId } = useOcean() const { networkId } = useOcean()
const { ddo } = useAsset() const { ddo } = useAsset()
const { data } = useQuery(getReceipts, {
variables: { address: ddo?.dataToken.toLowerCase() }
})
const [receipts, setReceipts] = useState<Receipt[]>() const [receipts, setReceipts] = useState<ReceiptData[]>()
const [creationTx, setCreationTx] = useState<string>()
useEffect(() => { useEffect(() => {
setReceipts(fakeReceipts) if (!data) return
}, []) setReceipts(data.datatokens[0].updates)
setCreationTx(data.datatokens[0].tx)
}, [data])
return ( return (
<> <>
<h3 className={styles.title}>Metadata History</h3> <h3 className={styles.title}>Metadata History</h3>
<ul className={styles.history}> <ul className={styles.history}>
{receipts?.map((receipt) => ( {receipts?.map((receipt) => (
<li key={receipt.hash} className={styles.item}> <li key={receipt.id} className={styles.item}>
<EtherscanLink networkId={networkId} path={`/tx/${receipt.hash}`}> <EtherscanLink networkId={networkId} path={`/tx/${receipt.tx}`}>
edited <Time date={receipt.timestamp} relative isUnix /> edited{' '}
<Time date={receipt.timestamp.toString()} relative isUnix />
</EtherscanLink> </EtherscanLink>
</li> </li>
))} ))}
<li className={styles.item}> <li className={styles.item}>
{/* TODO: get this initial metadata creation tx somehow */} <EtherscanLink networkId={networkId} path={`/tx/${creationTx}`}>
<EtherscanLink networkId={networkId} path="/tx/xxx">
published <Time date={ddo.created} relative /> published <Time date={ddo.created} relative />
</EtherscanLink> </EtherscanLink>
</li> </li>

View File

@ -17,16 +17,6 @@ export default function MetaFull(): ReactElement {
title="Owner" title="Owner"
content={<Publisher account={ddo?.publicKey[0].owner} />} content={<Publisher account={ddo?.publicKey[0].owner} />}
/> />
{/* <MetaItem
title="Data Created"
content={<Time date={metadata?.main.dateCreated} />}
/> */}
{/* TODO: remove those 2 date items here when EditHistory component is ready */}
<MetaItem title="Published" content={<Time date={ddo?.created} />} />
{ddo?.created !== ddo?.updated && (
<MetaItem title="Updated" content={<Time date={ddo?.updated} />} />
)}
<MetaItem title="DID" content={<code>{ddo?.id}</code>} /> <MetaItem title="DID" content={<code>{ddo?.id}</code>} />
</div> </div>
) )

View File

@ -15,7 +15,7 @@ import Button from '../../atoms/Button'
import Edit from '../AssetActions/Edit' import Edit from '../AssetActions/Edit'
import DebugOutput from '../../atoms/DebugOutput' import DebugOutput from '../../atoms/DebugOutput'
import MetaMain from './MetaMain' import MetaMain from './MetaMain'
// import EditHistory from './EditHistory' import EditHistory from './EditHistory'
export interface AssetContentProps { export interface AssetContentProps {
path?: string path?: string
@ -97,7 +97,7 @@ export default function AssetContent(props: AssetContentProps): ReactElement {
)} )}
<MetaFull /> <MetaFull />
{/* <EditHistory /> */} <EditHistory />
{debug === true && <DebugOutput title="DDO" output={ddo} />} {debug === true && <DebugOutput title="DDO" output={ddo} />}
</div> </div>
</div> </div>