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:
parent
8737264816
commit
be82d9ef2e
@ -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>
|
||||||
|
@ -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>
|
||||||
)
|
)
|
||||||
|
@ -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>
|
||||||
|
Loading…
Reference in New Issue
Block a user