aboutsummaryrefslogtreecommitdiffstats
path: root/webui/src/bug/Message.js
diff options
context:
space:
mode:
authorMichael Muré <batolettre@gmail.com>2018-08-15 20:31:53 +0200
committerMichael Muré <batolettre@gmail.com>2018-08-15 20:31:53 +0200
commit1984d4343db770fc2c8e251a81f1ab997a4c4d5e (patch)
treed60630e0d36ea24ee9eaf16653194703f4b46dd8 /webui/src/bug/Message.js
parent2530cee1eac225924e1119554cf475cdc46ed7dc (diff)
downloadgit-bug-1984d4343db770fc2c8e251a81f1ab997a4c4d5e.tar.gz
webui: rework of the bug page with a timeline
Diffstat (limited to 'webui/src/bug/Message.js')
-rw-r--r--webui/src/bug/Message.js75
1 files changed, 75 insertions, 0 deletions
diff --git a/webui/src/bug/Message.js b/webui/src/bug/Message.js
new file mode 100644
index 00000000..04c7dfab
--- /dev/null
+++ b/webui/src/bug/Message.js
@@ -0,0 +1,75 @@
+import { withStyles } from '@material-ui/core/styles'
+import Tooltip from '@material-ui/core/Tooltip/Tooltip'
+import Typography from '@material-ui/core/Typography'
+import gql from 'graphql-tag'
+import * as moment from 'moment'
+import React from 'react'
+
+const styles = theme => ({
+ header: {
+ ...theme.typography.body2,
+ padding: '3px 3px 3px 6px',
+ backgroundColor: '#f1f8ff',
+ border: '1px solid #d1d5da',
+ borderTopLeftRadius: 3,
+ borderTopRightRadius: 3,
+ },
+ author: {
+ ...theme.typography.body2,
+ fontWeight: 'bold'
+ },
+ message: {
+ borderLeft: '1px solid #d1d5da',
+ borderRight: '1px solid #d1d5da',
+ borderBottom: '1px solid #d1d5da',
+ borderBottomLeftRadius: 3,
+ borderBottomRightRadius: 3,
+ backgroundColor: '#fff',
+ minHeight: 50
+ }
+})
+
+const Message = ({message, classes}) => (
+ <div>
+ <div className={classes.header}>
+ <Tooltip title={message.author.email}>
+ <span className={classes.author}>{message.author.name}</span>
+ </Tooltip>
+ <span> commented </span>
+ <Tooltip title={moment(message.date).format('MMMM D, YYYY, h:mm a')}>
+ <span> {moment(message.date).fromNow()} </span>
+ </Tooltip>
+ </div>
+ <div className={classes.message}>
+ <Typography>{message.message}</Typography>
+ </div>
+ </div>
+)
+
+Message.createFragment = gql`
+ fragment Create on Operation {
+ ... on CreateOperation {
+ date
+ author {
+ name
+ email
+ }
+ message
+ }
+ }
+`
+
+Message.commentFragment = gql`
+ fragment Comment on Operation {
+ ... on AddCommentOperation {
+ date
+ author {
+ name
+ email
+ }
+ message
+ }
+ }
+`
+
+export default withStyles(styles)(Message)