mirror of
https://github.com/fazo96/ipfs-boards
synced 2025-01-24 14:44:19 +01:00
UI work
This commit is contained in:
parent
502244dbe1
commit
ec017b32a8
@ -1,15 +1,74 @@
|
|||||||
import React from 'react'
|
import React from 'react'
|
||||||
import Post from './Post'
|
import Post from './Post'
|
||||||
import { Segment, Button } from 'semantic-ui-react'
|
import { Divider, Icon, Grid, Segment, Header, List, Button, Card } from 'semantic-ui-react'
|
||||||
import { Link } from 'react-router-dom'
|
import { Link } from 'react-router-dom'
|
||||||
import { shortenAddress } from '../utils/orbitdb';
|
import { shortenAddress } from '../utils/orbitdb';
|
||||||
|
|
||||||
export default function Board({ address, posts }) {
|
export default function Board({ address, posts, metadata }) {
|
||||||
return <div>
|
const { email, website, title } = metadata || {}
|
||||||
<Segment>{address}</Segment>
|
const url = window.location.href
|
||||||
<Segment><Button as={Link} to={shortenAddress(address)+'/p/new'}>New Post</Button></Segment>
|
return <Grid container divided colums={2}>
|
||||||
<Segment>
|
<Grid.Column width={8}>
|
||||||
<ul>{Object.keys(posts || {}).map(i => <Post key={posts[i].multihash} {...posts[i]}/>)}</ul>
|
<Header size='large' style={{marginTop:'.5em'}}>
|
||||||
</Segment>
|
<Header.Content>{title || 'Unnamed Board'}</Header.Content>
|
||||||
</div>
|
<Header.Subheader>Board</Header.Subheader>
|
||||||
|
</Header>
|
||||||
|
<Divider />
|
||||||
|
<List relaxed>
|
||||||
|
<List.Item>
|
||||||
|
<List.Icon name='linkify' size="large" verticalAlign="middle"/>
|
||||||
|
<List.Content>
|
||||||
|
<List.Header>Board Address</List.Header>
|
||||||
|
<List.Content>
|
||||||
|
<a href={url}>{address}</a>
|
||||||
|
</List.Content>
|
||||||
|
</List.Content>
|
||||||
|
</List.Item>
|
||||||
|
<List.Item>
|
||||||
|
<List.Icon name='users' size="large" verticalAlign="middle"/>
|
||||||
|
<List.Content>
|
||||||
|
<List.Header>Users</List.Header>
|
||||||
|
<List.Content>?</List.Content>
|
||||||
|
</List.Content>
|
||||||
|
</List.Item>
|
||||||
|
<List.Item>
|
||||||
|
<List.Icon name='file text outline' size="large" verticalAlign="middle"/>
|
||||||
|
<List.Content>
|
||||||
|
<List.Header>Posts</List.Header>
|
||||||
|
<List.Content>{Object.values(posts || {}).length}</List.Content>
|
||||||
|
</List.Content>
|
||||||
|
</List.Item>
|
||||||
|
<List.Item>
|
||||||
|
<List.Icon name='wifi' size="large" verticalAlign="middle"/>
|
||||||
|
<List.Content>
|
||||||
|
<List.Header>Replication Status</List.Header>
|
||||||
|
<List.Content>Idle</List.Content>
|
||||||
|
</List.Content>
|
||||||
|
</List.Item>
|
||||||
|
<List.Item>
|
||||||
|
<List.Icon name='globe' size="large" verticalAlign="middle"/>
|
||||||
|
<List.Content>
|
||||||
|
<List.Header>Website</List.Header>
|
||||||
|
<List.Content>{website ? <a href={website}>{website}</a> : 'N/A'}</List.Content>
|
||||||
|
</List.Content>
|
||||||
|
</List.Item>
|
||||||
|
<List.Item>
|
||||||
|
<List.Icon name='mail' size="large" verticalAlign="middle"/>
|
||||||
|
<List.Content>
|
||||||
|
<List.Header>Mail</List.Header>
|
||||||
|
<List.Content>{email ? <a href={'mailto:'+email}>{email}</a> : 'N/A'}</List.Content>
|
||||||
|
</List.Content>
|
||||||
|
</List.Item>
|
||||||
|
</List>
|
||||||
|
<div className='ui two buttons'>
|
||||||
|
<Button>Edit</Button>
|
||||||
|
<Button as={Link} to={shortenAddress(address)+'/p/new'}>New Post</Button>
|
||||||
|
</div>
|
||||||
|
</Grid.Column>
|
||||||
|
<Grid.Column width={8}>
|
||||||
|
<Card.Group className="centered" style={{marginTop:'.5em'}}>
|
||||||
|
{Object.keys(posts || {}).map(i => <Post key={posts[i].multihash} {...posts[i]}/>)}
|
||||||
|
</Card.Group>
|
||||||
|
</Grid.Column>
|
||||||
|
</Grid>
|
||||||
}
|
}
|
@ -1,5 +1,16 @@
|
|||||||
import React from 'react'
|
import React from 'react'
|
||||||
|
import { Card, Icon } from 'semantic-ui-react'
|
||||||
|
|
||||||
export default function Post({ title, multihash}) {
|
export default function Post({ title, multihash}) {
|
||||||
return <li>{title}: {multihash}</li>
|
return <Card fluid>
|
||||||
|
<Card.Content>
|
||||||
|
<Icon name="file text outline"/> {title}
|
||||||
|
</Card.Content>
|
||||||
|
<Card.Content style={{wordBreak:'break-all'}}>
|
||||||
|
<Icon name="chain"/> <a href={'//ipfs.io/ipfs/'+multihash}>View</a>
|
||||||
|
</Card.Content>
|
||||||
|
<Card.Content extra>
|
||||||
|
<Icon name="comments"/> Comments not supported yet
|
||||||
|
</Card.Content>
|
||||||
|
</Card>
|
||||||
}
|
}
|
@ -1,4 +1,5 @@
|
|||||||
import React, { Component } from 'react'
|
import React, { Component } from 'react'
|
||||||
|
import { Loader, Dimmer } from 'semantic-ui-react'
|
||||||
import { connect } from 'react-redux'
|
import { connect } from 'react-redux'
|
||||||
import { openBoard } from '../actions/board'
|
import { openBoard } from '../actions/board'
|
||||||
import { getBoardAddress } from '../utils/orbitdb'
|
import { getBoardAddress } from '../utils/orbitdb'
|
||||||
@ -40,7 +41,9 @@ export default function WithBoard(WrappedComponent) {
|
|||||||
if (board) {
|
if (board) {
|
||||||
return <WrappedComponent {...board} {...this.props} />
|
return <WrappedComponent {...board} {...this.props} />
|
||||||
} else {
|
} else {
|
||||||
return <div>Opening this board...</div>
|
return <Dimmer page active={true}>
|
||||||
|
Opening this board
|
||||||
|
</Dimmer>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
import multihashes from 'multihashes'
|
|
||||||
|
|
||||||
export async function ipfsPut(content) {
|
export async function ipfsPut(content) {
|
||||||
const dagNode = await window.ipfs.object.put(Buffer.from(content))
|
const obj = {
|
||||||
return multihashes.toB58String(dagNode.multihash)
|
content: Buffer.from(content),
|
||||||
|
path: '/'
|
||||||
|
}
|
||||||
|
const response = await window.ipfs.files.add(obj)
|
||||||
|
return response[0].hash
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user