rename chat message -> messages and cleanup

This commit is contained in:
Pavel Prichodko 2023-01-20 15:21:21 +01:00
parent 8f0fb27b1a
commit 510615c74b
No known key found for this signature in database
GPG Key ID: 8E4C82D464215E83
9 changed files with 246 additions and 79 deletions

View File

@ -1,15 +0,0 @@
import { Stack } from 'tamagui'
import { Paragraph } from '../../typography'
interface Props {
onClick?: VoidFunction
}
export const Actions = (_props: Props) => {
return (
<Stack position="absolute" top={0} right={0}>
<Paragraph>actions</Paragraph>
</Stack>
)
}

View File

@ -1,31 +0,0 @@
import { Pressable } from 'react-native'
import { Stack, XStack, YStack } from 'tamagui'
interface Props {}
const ReactionButton = ({ type }) => {
return (
<Stack
padding={3}
borderWidth={1}
borderColor="$neutral-100"
borderRadius={2}
>
{type}
</Stack>
)
}
export const Reactions = (props: Props) => {
const {} = props
return (
<XStack>
<ReactionButton type="like" />
<ReactionButton type="+1" />
<ReactionButton type="-1" />
<ReactionButton type="sad" />
<ReactionButton type="angry" />
</XStack>
)
}

View File

@ -2,6 +2,7 @@ import React from 'react'
import { Stack, Unspaced, XStack, YStack } from 'tamagui'
import { Author } from '../author/author'
import { Avatar } from '../avatar'
import { Image } from '../image'
import { Paragraph } from '../typography'
@ -24,7 +25,6 @@ const ChatMessage = (props: Props) => {
space={10}
position="relative"
alignItems="flex-start"
justifyContent="center"
paddingHorizontal={8}
paddingVertical={12}
borderRadius={16}
@ -36,7 +36,7 @@ const ChatMessage = (props: Props) => {
>
{hovered && (
<Unspaced>
<Actions />
<Actions onClick={() => {}} />
</Unspaced>
)}
@ -47,17 +47,12 @@ const ChatMessage = (props: Props) => {
/>
<YStack flex={1}>
<XStack space={8} alignItems="center">
<Paragraph weight="semibold" color="$neutral-100">
Alisher Yakupov
</Paragraph>
<Paragraph color="$neutral-50" fontSize={11}>
zQ3...9d4Gs0
</Paragraph>
<Paragraph color="$neutral-50" variant={11}>
09:30
</Paragraph>
</XStack>
<Author
name="Alisher Yakupov"
address="zQ3...9d4Gs0"
status="verified"
time="09:30"
/>
{text && (
<Paragraph flexGrow={0} weight="regular" color="$neutral-100">
@ -70,7 +65,7 @@ const ChatMessage = (props: Props) => {
key={image.url}
borderRadius={12}
overflow="hidden"
marginTop={6}
marginTop={8}
$gtMd={{
maxWidth: 320,
}}
@ -79,7 +74,11 @@ const ChatMessage = (props: Props) => {
</Stack>
))}
{reactions && <Reactions />}
{reactions && (
<Stack marginTop={8}>
<Reactions />
</Stack>
)}
</YStack>
</XStack>
)

View File

@ -0,0 +1,41 @@
import { Actions } from './actions'
import type { Meta, StoryObj } from '@storybook/react'
// More on how to set up stories at: https://storybook.js.org/docs/7.0/react/writing-stories/introduction
const meta: Meta<typeof Actions> = {
title: 'Messages/actions',
component: Actions,
argTypes: {},
parameters: {
layout: 'centered',
design: {
type: 'figma',
url: 'https://www.figma.com/file/IBmFKgGL1B4GzqD8LQTw6n/Design-System-for-Web?node-id=14560%3A157866&t=87Ziud3PyYYSvsRg-4',
},
},
decorators: [
Story => {
return (
<div
style={{
position: 'relative',
width: 110,
height: 38,
}}
>
<Story />
</div>
)
},
],
}
type Story = StoryObj<typeof Actions>
// More on writing stories with args: https://storybook.js.org/docs/7.0/react/writing-stories/args
export const Default: Story = {
args: {},
}
export default meta

View File

@ -0,0 +1,31 @@
import { AddReaction, Options, Reply } from '@status-im/icons/20'
import { Stack } from 'tamagui'
import { Button } from '../../button'
interface Props {
onClick: VoidFunction
}
export const Actions = (_props: Props) => {
return (
<Stack
backgroundColor="$white-100"
borderWidth={1}
borderColor="$neutral-10"
borderRadius={10}
overflow="hidden"
position="absolute"
top={-16}
right={0}
flexDirection="row"
shadowRadius={20}
shadowOffset={{ width: 0, height: 4 }}
shadowColor="rgba(9, 16, 28, 0.08)"
zIndex={10}
>
<Button type="ghost" icon={<AddReaction />} borderRadius={0} />
<Button type="ghost" icon={<Reply />} borderRadius={0} />
<Button type="ghost" icon={<Options />} borderRadius={0} />
</Stack>
)
}

View File

@ -0,0 +1,25 @@
import { Reactions } from './reactions'
import type { Meta, StoryObj } from '@storybook/react'
// More on how to set up stories at: https://storybook.js.org/docs/7.0/react/writing-stories/introduction
const meta: Meta<typeof Reactions> = {
title: 'messages/reactions',
component: Reactions,
argTypes: {},
parameters: {
design: {
type: 'figma',
url: 'https://www.figma.com/file/IBmFKgGL1B4GzqD8LQTw6n/Design-System-for-Web?node-id=12375%3A140482&t=87Ziud3PyYYSvsRg-4',
},
},
}
type Story = StoryObj<typeof Reactions>
// More on writing stories with args: https://storybook.js.org/docs/7.0/react/writing-stories/args
export const Default: Story = {
args: {},
}
export default meta

View File

@ -0,0 +1,88 @@
import { cloneElement } from 'react'
import { AddReaction } from '@status-im/icons/20'
import {
Angry,
Laugh,
Love,
Sad,
ThumbsDown,
ThumbsUp,
} from '@status-im/icons/reactions'
import { Stack, styled } from '@tamagui/core'
import { XStack } from 'tamagui'
import { Paragraph } from '../../typography'
import type React from 'react'
// import { Pressable } from 'react-native'
const ReactButton = styled(Stack, {
name: 'ReactButton',
accessibilityRole: 'button',
cursor: 'pointer',
userSelect: 'none',
borderRadius: 8,
display: 'inline-flex',
flexDirection: 'row',
space: 4,
alignItems: 'center',
justifyContent: 'center',
flexShrink: 0,
minWidth: 36,
height: 24,
paddingHorizontal: 8,
borderWidth: 1,
borderColor: '$neutral-20',
hoverStyle: {
borderColor: '$neutral-30',
},
variants: {
selected: {
true: {
backgroundColor: '$neutral-30',
borderColor: '$neutral-30',
},
},
} as const,
})
interface Props {
icon: React.ReactElement
count: number
selected?: boolean
}
const ReactionButton = (props: Props) => {
const { count, selected, icon } = props
return (
<ReactButton selected={selected}>
{cloneElement(icon, { color: '$neutral-100' })}
<Paragraph weight="medium" variant="smaller" whiteSpace="nowrap">
{count}
</Paragraph>
</ReactButton>
)
}
export const Reactions = (props: Props) => {
const {} = props
return (
<XStack space={8}>
<ReactionButton count={1} icon={<Love />} selected />
<ReactionButton count={10} icon={<ThumbsUp />} />
<ReactionButton count={99} icon={<ThumbsDown />} />
<ReactionButton count={100} icon={<Laugh />} />
<ReactionButton count={100} icon={<Sad />} />
{/* <ReactionButton count={100} icon={ang} /> */}
<ReactionButton count={100} icon={<Angry />} />
<ReactionButton icon={<AddReaction />} />
</XStack>
)
}

View File

@ -1,16 +1,10 @@
import { Stack } from '@tamagui/core'
import { ChatMessage } from './chat-message'
import type { GetProps } from '@tamagui/core'
export * from './chat-message'
type BaseProps = GetProps<typeof Stack>
export const Messages = (props: BaseProps) => {
export const Messages = () => {
return (
<Stack {...props}>
<>
<ChatMessage text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf" />
<ChatMessage text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf" />
<ChatMessage text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf" />
@ -21,12 +15,21 @@ export const Messages = (props: BaseProps) => {
},
]}
/>
<ChatMessage
text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf"
reactions={['123']}
/>
<ChatMessage text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf" />
<ChatMessage text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf" />
<ChatMessage text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf" />
<ChatMessage text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf" />
<ChatMessage text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf" />
<ChatMessage text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf" />
</Stack>
<ChatMessage
text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf"
reactions={['123']}
/>
<ChatMessage
text="fsdjkf kasldjf ksdlfjksdlfj asdklfj sdkljf"
reactions={['123']}
/>
</>
)
}

View File

@ -4,6 +4,7 @@ import type { Meta, StoryObj } from '@storybook/react'
// More on how to set up stories at: https://storybook.js.org/docs/7.0/react/writing-stories/introduction
const meta: Meta<typeof ChatMessage> = {
// title: 'Messages',
component: ChatMessage,
argTypes: {},
parameters: {
@ -16,28 +17,40 @@ const meta: Meta<typeof ChatMessage> = {
type Story = StoryObj<typeof ChatMessage>
const reactions = ['123']
// More on writing stories with args: https://storybook.js.org/docs/7.0/react/writing-stories/args
export const Simple: Story = {
export const Text: Story = {
args: {
text: 'This is a simple message.',
},
}
export const SimpleLongText: Story = {
export const TextWithReactions: Story = {
name: 'Text + Reactions',
args: {
text: 'This is a simple message.',
reactions,
},
}
export const LongText: Story = {
name: 'Long text',
args: {
text: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.',
},
}
export const SimpleWithReactions: Story = {
name: 'Simple with reactions',
export const LongTextReactions: Story = {
name: 'Long text + Reactions',
args: {
text: 'This is a simple message.',
reactions: ['thumb'],
text: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.',
reactions,
},
}
export const Image: Story = {
name: 'Image',
args: {
images: [
{
@ -47,4 +60,17 @@ export const Image: Story = {
},
}
export const ImageWithReactions: Story = {
name: 'Image + Reactions',
args: {
reactions,
images: [
{
url: 'https://images.unsplash.com/photo-1673831792265-68b44126c999?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=866&q=80',
},
],
},
}
export default meta