This repository was archived by the owner on Jan 29, 2026. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtext.tsx
More file actions
93 lines (86 loc) · 2.28 KB
/
text.tsx
File metadata and controls
93 lines (86 loc) · 2.28 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
import { styled, css } from 'styled-components'
import { Button } from '@titicaca/tds-ui'
import useATagNavigator from '../utils/a-tag-navigator'
import { ArrowRight } from '../icons/arrow-right-icon'
import { TextItem } from './item'
import Bubble from './bubble'
import { TextBubbleProp } from './type'
import { FullTextMessageView } from './full-text-message-view'
const MAX_VIEWABLE_TEXT_LENGTH = 300
const FullTextViewButton = styled(Button)<{ my: boolean }>`
display: flex;
align-items: center;
gap: 5px;
margin-top: 10px;
padding: 0 0 0 5px;
background-color: unset;
font-size: 13px;
font-weight: 500;
color: ${({ my }) => (my ? 'white' : 'var(--color-gray500)')};
`
export function TextBubble({
id,
message,
my,
created,
onOpenMenu,
fullTextViewAvailable,
openFullTextView,
closeFullTextView,
isFullTextViewOpen,
onParentMessageClick,
onLinkClick,
...props
}: TextBubbleProp) {
const aTagNavigator = useATagNavigator(onLinkClick)
const isEllipsis =
fullTextViewAvailable &&
openFullTextView &&
message.length > MAX_VIEWABLE_TEXT_LENGTH
return (
<>
<Bubble
id={id}
css={css`
a {
color: ${my ? '#B5FFFB' : 'var(--color-blue)'};
text-decoration: underline;
}
`}
my={my}
onParentMessageClick={onParentMessageClick}
{...props}
>
<TextItem
text={
isEllipsis
? `${message.substring(0, MAX_VIEWABLE_TEXT_LENGTH)}...`
: message
}
onClick={(e) => aTagNavigator(e)}
/>
{isEllipsis ? (
<FullTextViewButton my={my} onClick={() => openFullTextView?.(id)}>
전체보기
<ArrowRight
color={my ? 'var(--color-white900)' : 'var(--color-gray500)'}
style={{ width: 4, height: 8 }}
/>
</FullTextViewButton>
) : null}
</Bubble>
{fullTextViewAvailable &&
closeFullTextView &&
isFullTextViewOpen?.(id) ? (
<FullTextMessageView
open
onClose={closeFullTextView}
text={message}
openMenu={onOpenMenu}
onClick={(e) => aTagNavigator(e)}
disableMenu={!created}
/>
) : null}
</>
)
}