From 8138d0e49aea326fb6ad3501fcb7d8d1623c0538 Mon Sep 17 00:00:00 2001
From: Pavel <14926950+prichodko@users.noreply.github.com>
Date: Wed, 22 Mar 2023 14:42:04 +0100
Subject: [PATCH] Add system messages (#356)
* add DynamicButton component
* add AnchorActions component
* add AnchorActions to web app
---
apps/web/src/app.tsx | 4 +
apps/web/styles/app.css | 6 ++
.../components/src/anchor-actions/index.tsx | 20 ++++
.../dynamic-button/dynamic-button.stories.tsx | 27 ++++++
.../src/dynamic-button/dynamic-button.tsx | 92 +++++++++++++++++++
.../components/src/dynamic-button/index.tsx | 1 +
packages/components/src/index.tsx | 2 +
7 files changed, 152 insertions(+)
create mode 100644 packages/components/src/anchor-actions/index.tsx
create mode 100644 packages/components/src/dynamic-button/dynamic-button.stories.tsx
create mode 100644 packages/components/src/dynamic-button/dynamic-button.tsx
create mode 100644 packages/components/src/dynamic-button/index.tsx
diff --git a/apps/web/src/app.tsx b/apps/web/src/app.tsx
index b99df1e5..7eec9bc8 100644
--- a/apps/web/src/app.tsx
+++ b/apps/web/src/app.tsx
@@ -1,6 +1,7 @@
import { useMemo, useRef, useState } from 'react'
import {
+ AnchorActions,
CHANNEL_GROUPS,
Composer,
Messages,
@@ -69,6 +70,9 @@ function App() {
diff --git a/apps/web/styles/app.css b/apps/web/styles/app.css
index 882669c6..2d2d2aa7 100644
--- a/apps/web/styles/app.css
+++ b/apps/web/styles/app.css
@@ -52,6 +52,12 @@ body,
padding: 32px 8px;
}
+#anchor-actions {
+ position: absolute;
+ right: 20px;
+ transform: translateY(calc(-100% - 12px));
+}
+
#composer {
position: sticky;
bottom: 0;
diff --git a/packages/components/src/anchor-actions/index.tsx b/packages/components/src/anchor-actions/index.tsx
new file mode 100644
index 00000000..fabc5a8d
--- /dev/null
+++ b/packages/components/src/anchor-actions/index.tsx
@@ -0,0 +1,20 @@
+import { Stack } from 'tamagui'
+
+import { DynamicButton } from '../dynamic-button'
+
+type Props = {
+ scrolled: boolean
+}
+
+const AnchorActions = (props: Props) => {
+ const { scrolled } = props
+
+ return (
+
+ {scrolled && }
+ {scrolled && }
+
+ )
+}
+
+export { AnchorActions }
diff --git a/packages/components/src/dynamic-button/dynamic-button.stories.tsx b/packages/components/src/dynamic-button/dynamic-button.stories.tsx
new file mode 100644
index 00000000..1080c01c
--- /dev/null
+++ b/packages/components/src/dynamic-button/dynamic-button.stories.tsx
@@ -0,0 +1,27 @@
+import { XStack } from 'tamagui'
+
+import { DynamicButton } from './dynamic-button'
+
+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 = {
+ title: 'DynamicButton',
+ component: DynamicButton,
+ args: {},
+ argTypes: {},
+}
+
+type Story = StoryObj
+
+export const Default: Story = {
+ render: () => (
+
+
+
+
+
+ ),
+}
+
+export default meta
diff --git a/packages/components/src/dynamic-button/dynamic-button.tsx b/packages/components/src/dynamic-button/dynamic-button.tsx
new file mode 100644
index 00000000..16b535db
--- /dev/null
+++ b/packages/components/src/dynamic-button/dynamic-button.tsx
@@ -0,0 +1,92 @@
+import { forwardRef } from 'react'
+
+import { ArrowDownIcon, MentionIcon } from '@status-im/icons/12'
+import { Stack, styled } from '@tamagui/core'
+
+import { Shadow } from '../shadow'
+import { Text } from '../text'
+
+import type { GetVariants } from '../types'
+import type { ColorTokens, StackProps } from '@tamagui/core'
+import type { Ref } from 'react'
+import type { PressableProps } from 'react-native'
+
+type Variants = GetVariants
+
+type Props = PressableProps & {
+ type: Variants['type']
+ count: number
+}
+
+const DynamicButton = (props: Props, ref: Ref) => {
+ const { type, count, ...pressableProps } = props
+
+ const color: ColorTokens = '$white-100'
+ const showCount = Boolean(count)
+
+ return (
+
+
+
+ )
+}
+
+const _DynamicButton = forwardRef(DynamicButton)
+
+export { _DynamicButton as DynamicButton }
+export type { Props as DynamicButtonProps }
+
+const Button = styled(Stack, {
+ name: 'DynamicButton',
+ accessibilityRole: 'button',
+ tag: 'button',
+
+ cursor: 'pointer',
+ userSelect: 'none',
+ flexDirection: 'row',
+ alignItems: 'center',
+ justifyContent: 'center',
+ flexShrink: 0,
+ height: 24,
+ borderRadius: 999,
+ animation: 'fast',
+ space: 3,
+
+ variants: {
+ type: {
+ mention: {
+ backgroundColor: '$primary-50',
+ hoverStyle: { backgroundColor: '$primary-60' },
+ pressStyle: { backgroundColor: '$primary-50' },
+ },
+
+ notification: {
+ backgroundColor: '$neutral-80-opa-70',
+ hoverStyle: { backgroundColor: '$neutral-90-opa-70' },
+ pressStyle: { backgroundColor: '$neutral-80-opa-80' },
+ },
+ },
+
+ iconOnly: {
+ true: {
+ width: 24,
+ },
+ false: {
+ paddingHorizontal: 8,
+ },
+ },
+ } as const,
+})
diff --git a/packages/components/src/dynamic-button/index.tsx b/packages/components/src/dynamic-button/index.tsx
new file mode 100644
index 00000000..2ba7d821
--- /dev/null
+++ b/packages/components/src/dynamic-button/index.tsx
@@ -0,0 +1 @@
+export { DynamicButton, type DynamicButtonProps } from './dynamic-button'
diff --git a/packages/components/src/index.tsx b/packages/components/src/index.tsx
index 2cabbc44..b878f49c 100644
--- a/packages/components/src/index.tsx
+++ b/packages/components/src/index.tsx
@@ -1,7 +1,9 @@
+export * from './anchor-actions'
export * from './button'
export * from './composer'
export * from './divider'
export * from './divider-label'
+export * from './dynamic-button'
export * from './icon-button'
export * from './image'
export * from './input'