[GH-411] Use relative date/time for comments (#1574)

This replaces the absolute date for comments on cards with a relative
date/time format and moves the absolute value into a tooltip.

Fixes: #411
This commit is contained in:
Johannes Marbach 2021-10-15 23:15:32 +02:00 committed by GitHub
parent 4b5436696f
commit f771878fa8
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 45 additions and 9 deletions

View file

@ -16,9 +16,14 @@ exports[`components/cardDetail/comment return comment 1`] = `
class="comment-username" class="comment-username"
/> />
<div <div
class="comment-date" class="octo-tooltip tooltip-top"
data-tooltip="October 01, 2020, 12:00 AM"
> >
October 01, 2020, 12:00 AM <div
class="comment-date"
>
a day ago
</div>
</div> </div>
<div <div
aria-label="menuwrapper" aria-label="menuwrapper"
@ -121,9 +126,14 @@ exports[`components/cardDetail/comment return comment and delete comment 1`] = `
class="comment-username" class="comment-username"
/> />
<div <div
class="comment-date" class="octo-tooltip tooltip-top"
data-tooltip="October 01, 2020, 12:00 AM"
> >
October 01, 2020, 12:00 AM <div
class="comment-date"
>
a day ago
</div>
</div> </div>
<div <div
aria-label="menuwrapper" aria-label="menuwrapper"
@ -226,9 +236,14 @@ exports[`components/cardDetail/comment return comment readonly 1`] = `
class="comment-username" class="comment-username"
/> />
<div <div
class="comment-date" class="octo-tooltip tooltip-top"
data-tooltip="October 01, 2020, 12:00 AM"
> >
October 01, 2020, 12:00 AM <div
class="comment-date"
>
a day ago
</div>
</div> </div>
</div> </div>
<div <div

View file

@ -4,6 +4,7 @@ import {render, screen} from '@testing-library/react'
import userEvent from '@testing-library/user-event' import userEvent from '@testing-library/user-event'
import React from 'react' import React from 'react'
import {Provider as ReduxProvider} from 'react-redux' import {Provider as ReduxProvider} from 'react-redux'
import moment from 'moment'
import {mocked} from 'ts-jest/utils' import {mocked} from 'ts-jest/utils'
@ -37,9 +38,20 @@ describe('components/cardDetail/comment', () => {
}, },
} }
const store = mockStateStore([], state) const store = mockStateStore([], state)
beforeEach(() => { beforeEach(() => {
jest.clearAllMocks() jest.clearAllMocks()
moment.now = () => {
return dateFixed + (24 * 60 * 60 * 1000)
}
}) })
afterEach(() => {
moment.now = () => {
return Number(new Date())
}
})
test('return comment', () => { test('return comment', () => {
const {container} = render(wrapIntl( const {container} = render(wrapIntl(
<ReduxProvider store={store}> <ReduxProvider store={store}>

View file

@ -13,6 +13,7 @@ import Menu from '../../widgets/menu'
import MenuWrapper from '../../widgets/menuWrapper' import MenuWrapper from '../../widgets/menuWrapper'
import {getUser} from '../../store/users' import {getUser} from '../../store/users'
import {useAppSelector} from '../../store/hooks' import {useAppSelector} from '../../store/hooks'
import Tooltip from '../../widgets/tooltip'
import './comment.scss' import './comment.scss'
@ -28,6 +29,7 @@ const Comment: FC<Props> = (props: Props) => {
const intl = useIntl() const intl = useIntl()
const html = Utils.htmlFromMarkdown(comment.title) const html = Utils.htmlFromMarkdown(comment.title)
const user = useAppSelector(getUser(userId)) const user = useAppSelector(getUser(userId))
const date = new Date(comment.createAt)
return ( return (
<div <div
@ -40,9 +42,11 @@ const Comment: FC<Props> = (props: Props) => {
src={userImageUrl} src={userImageUrl}
/> />
<div className='comment-username'>{user?.username}</div> <div className='comment-username'>{user?.username}</div>
<div className='comment-date'> <Tooltip title={Utils.displayDateTime(date, intl)}>
{Utils.displayDateTime(new Date(comment.createAt), intl)} <div className='comment-date'>
</div> {Utils.relativeDisplayDateTime(date, intl)}
</div>
</Tooltip>
{!props.readonly && ( {!props.readonly && (
<MenuWrapper> <MenuWrapper>

View file

@ -2,6 +2,7 @@
// See LICENSE.txt for license information. // See LICENSE.txt for license information.
import marked from 'marked' import marked from 'marked'
import {IntlShape} from 'react-intl' import {IntlShape} from 'react-intl'
import moment from 'moment'
import {Block} from './blocks/block' import {Block} from './blocks/block'
import {createBoard} from './blocks/board' import {createBoard} from './blocks/board'
@ -265,6 +266,10 @@ class Utils {
}) })
} }
static relativeDisplayDateTime(date: Date, intl: IntlShape): string {
return moment(date).locale(intl.locale.toLowerCase()).fromNow()
}
static sleep(miliseconds: number): Promise<void> { static sleep(miliseconds: number): Promise<void> {
return new Promise((resolve) => setTimeout(resolve, miliseconds)) return new Promise((resolve) => setTimeout(resolve, miliseconds))
} }