-
-
Notifications
You must be signed in to change notification settings - Fork 270
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* add pinned room events hook * room pinned message - WIP * add room event hook * fetch pinned messages before displaying * use react-query in room event hook * disable staleTime and gc to 1 hour in room event hook * use room event hook in reply component * render pinned messages * add option to pin/unpin messages * remove message base from message placeholders and add variant * display message placeholder while loading pinned messages * render pinned event error * show no pinned message placeholder * fix message placeholder flickering
- Loading branch information
Showing
14 changed files
with
939 additions
and
191 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
43 changes: 24 additions & 19 deletions
43
src/app/components/message/placeholder/CompactPlaceholder.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,22 +1,27 @@ | ||
import React from 'react'; | ||
import { as, toRem } from 'folds'; | ||
import React, { useMemo } from 'react'; | ||
import { as, ContainerColor, toRem } from 'folds'; | ||
import { randomNumberBetween } from '../../../utils/common'; | ||
import { LinePlaceholder } from './LinePlaceholder'; | ||
import { CompactLayout, MessageBase } from '../layout'; | ||
import { CompactLayout } from '../layout'; | ||
|
||
export const CompactPlaceholder = as<'div'>(({ ...props }, ref) => ( | ||
<MessageBase> | ||
<CompactLayout | ||
{...props} | ||
ref={ref} | ||
before={ | ||
<> | ||
<LinePlaceholder style={{ maxWidth: toRem(50) }} /> | ||
<LinePlaceholder style={{ maxWidth: toRem(randomNumberBetween(40, 100)) }} /> | ||
</> | ||
} | ||
> | ||
<LinePlaceholder style={{ maxWidth: toRem(randomNumberBetween(120, 500)) }} /> | ||
</CompactLayout> | ||
</MessageBase> | ||
)); | ||
export const CompactPlaceholder = as<'div', { variant?: ContainerColor }>( | ||
({ variant, ...props }, ref) => { | ||
const nameSize = useMemo(() => randomNumberBetween(40, 100), []); | ||
const msgSize = useMemo(() => randomNumberBetween(120, 500), []); | ||
|
||
return ( | ||
<CompactLayout | ||
{...props} | ||
ref={ref} | ||
before={ | ||
<> | ||
<LinePlaceholder variant={variant} style={{ maxWidth: toRem(50) }} /> | ||
<LinePlaceholder variant={variant} style={{ maxWidth: toRem(nameSize) }} /> | ||
</> | ||
} | ||
> | ||
<LinePlaceholder variant={variant} style={{ maxWidth: toRem(msgSize) }} /> | ||
</CompactLayout> | ||
); | ||
} | ||
); |
52 changes: 33 additions & 19 deletions
52
src/app/components/message/placeholder/DefaultPlaceholder.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,25 +1,39 @@ | ||
import React, { CSSProperties } from 'react'; | ||
import { Avatar, Box, as, color, toRem } from 'folds'; | ||
import React, { CSSProperties, useMemo } from 'react'; | ||
import { Avatar, Box, ContainerColor, as, color, toRem } from 'folds'; | ||
import { randomNumberBetween } from '../../../utils/common'; | ||
import { LinePlaceholder } from './LinePlaceholder'; | ||
import { MessageBase, ModernLayout } from '../layout'; | ||
import { ModernLayout } from '../layout'; | ||
|
||
const contentMargin: CSSProperties = { marginTop: toRem(3) }; | ||
const avatarBg: CSSProperties = { backgroundColor: color.SurfaceVariant.Container }; | ||
|
||
export const DefaultPlaceholder = as<'div'>(({ ...props }, ref) => ( | ||
<MessageBase> | ||
<ModernLayout {...props} ref={ref} before={<Avatar style={avatarBg} size="300" />}> | ||
<Box style={contentMargin} grow="Yes" direction="Column" gap="200"> | ||
<Box grow="Yes" gap="200" alignItems="Center" justifyContent="SpaceBetween"> | ||
<LinePlaceholder style={{ maxWidth: toRem(randomNumberBetween(40, 100)) }} /> | ||
<LinePlaceholder style={{ maxWidth: toRem(50) }} /> | ||
</Box> | ||
<Box grow="Yes" gap="200" wrap="Wrap"> | ||
<LinePlaceholder style={{ maxWidth: toRem(randomNumberBetween(80, 200)) }} /> | ||
<LinePlaceholder style={{ maxWidth: toRem(randomNumberBetween(80, 200)) }} /> | ||
export const DefaultPlaceholder = as<'div', { variant?: ContainerColor }>( | ||
({ variant, ...props }, ref) => { | ||
const nameSize = useMemo(() => randomNumberBetween(40, 100), []); | ||
const msgSize = useMemo(() => randomNumberBetween(80, 200), []); | ||
const msg2Size = useMemo(() => randomNumberBetween(80, 200), []); | ||
|
||
return ( | ||
<ModernLayout | ||
{...props} | ||
ref={ref} | ||
before={ | ||
<Avatar | ||
style={{ backgroundColor: color[variant ?? 'SurfaceVariant'].Container }} | ||
size="300" | ||
/> | ||
} | ||
> | ||
<Box style={contentMargin} grow="Yes" direction="Column" gap="200"> | ||
<Box grow="Yes" gap="200" alignItems="Center" justifyContent="SpaceBetween"> | ||
<LinePlaceholder variant={variant} style={{ maxWidth: toRem(nameSize) }} /> | ||
<LinePlaceholder variant={variant} style={{ maxWidth: toRem(50) }} /> | ||
</Box> | ||
<Box grow="Yes" gap="200" wrap="Wrap"> | ||
<LinePlaceholder variant={variant} style={{ maxWidth: toRem(msgSize) }} /> | ||
<LinePlaceholder variant={variant} style={{ maxWidth: toRem(msg2Size) }} /> | ||
</Box> | ||
</Box> | ||
</Box> | ||
</ModernLayout> | ||
</MessageBase> | ||
)); | ||
</ModernLayout> | ||
); | ||
} | ||
); |
43 changes: 33 additions & 10 deletions
43
src/app/components/message/placeholder/LinePlaceholder.css.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,12 +1,35 @@ | ||
import { style } from '@vanilla-extract/css'; | ||
import { DefaultReset, color, config, toRem } from 'folds'; | ||
import { ComplexStyleRule } from '@vanilla-extract/css'; | ||
import { recipe, RecipeVariants } from '@vanilla-extract/recipes'; | ||
import { ContainerColor, DefaultReset, color, config, toRem } from 'folds'; | ||
|
||
export const LinePlaceholder = style([ | ||
DefaultReset, | ||
{ | ||
width: '100%', | ||
height: toRem(16), | ||
borderRadius: config.radii.R300, | ||
backgroundColor: color.SurfaceVariant.Container, | ||
const getVariant = (variant: ContainerColor): ComplexStyleRule => ({ | ||
backgroundColor: color[variant].Container, | ||
}); | ||
|
||
export const LinePlaceholder = recipe({ | ||
base: [ | ||
DefaultReset, | ||
{ | ||
width: '100%', | ||
height: toRem(16), | ||
borderRadius: config.radii.R300, | ||
}, | ||
], | ||
variants: { | ||
variant: { | ||
Background: getVariant('Background'), | ||
Surface: getVariant('Surface'), | ||
SurfaceVariant: getVariant('SurfaceVariant'), | ||
Primary: getVariant('Primary'), | ||
Secondary: getVariant('Secondary'), | ||
Success: getVariant('Success'), | ||
Warning: getVariant('Warning'), | ||
Critical: getVariant('Critical'), | ||
}, | ||
}, | ||
defaultVariants: { | ||
variant: 'SurfaceVariant', | ||
}, | ||
]); | ||
}); | ||
|
||
export type LinePlaceholderVariants = RecipeVariants<typeof LinePlaceholder>; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.