signal-desktop/ts/components/conversation/MessageBodyReadMore.stories.tsx
Jamie Kyle 502ea174ab
Upgrade Storybook
Co-authored-by: Scott Nonnenberg <scott@signal.org>
2023-10-11 12:06:43 -07:00

263 lines
8.2 KiB
TypeScript

// Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import React, { useState } from 'react';
import { action } from '@storybook/addon-actions';
import type { Meta } from '@storybook/react';
import type { Props } from './MessageBodyReadMore';
import { MessageBodyReadMore } from './MessageBodyReadMore';
import { setupI18n } from '../../util/setupI18n';
import enMessages from '../../../_locales/en/messages.json';
import type { HydratedBodyRangesType } from '../../types/BodyRange';
import { BodyRange } from '../../types/BodyRange';
import { generateAci } from '../../types/ServiceId';
import { RenderLocation } from './MessageTextRenderer';
const i18n = setupI18n('en', enMessages);
export default {
title: 'Components/Conversation/MessageBodyReadMore',
} satisfies Meta<Props>;
const createProps = (overrideProps: Partial<Props> = {}): Props => ({
bodyRanges: overrideProps.bodyRanges,
direction: 'incoming',
displayLimit: overrideProps.displayLimit,
i18n,
id: 'some-id',
isSpoilerExpanded: overrideProps.isSpoilerExpanded || {},
messageExpanded: action('messageExpanded'),
onExpandSpoiler: overrideProps.onExpandSpoiler || action('onExpandSpoiler'),
renderLocation: RenderLocation.Timeline,
text: overrideProps.text || '',
});
function MessageBodyReadMoreTest({
bodyRanges,
isSpoilerExpanded,
onExpandSpoiler,
text: messageBodyText,
}: {
bodyRanges?: HydratedBodyRangesType;
isSpoilerExpanded?: Record<number, boolean>;
onExpandSpoiler?: (data: Record<number, boolean>) => void;
text: string;
}): JSX.Element {
const [displayLimit, setDisplayLimit] = useState<number | undefined>();
return (
<MessageBodyReadMore
{...createProps({
bodyRanges,
isSpoilerExpanded,
onExpandSpoiler,
text: messageBodyText,
})}
displayLimit={displayLimit}
messageExpanded={(_, newDisplayLimit) => setDisplayLimit(newDisplayLimit)}
/>
);
}
export function LongText100More(): JSX.Element {
return (
<MessageBodyReadMoreTest
text={`${'test '.repeat(160)}${'extra '.repeat(10)}`}
/>
);
}
export function LotsOfCakeWithSomeCherriesOnTop(): JSX.Element {
return (
<MessageBodyReadMoreTest text={`x${'🍰'.repeat(399)}${'🍒'.repeat(100)}`} />
);
}
export function LeafyNotBuffered(): JSX.Element {
return <MessageBodyReadMoreTest text={`x${'🌿'.repeat(450)}`} />;
}
export function LongTextWithMention(): JSX.Element {
const bodyRanges = [
// This is right at boundary for better testing
{
start: 800,
length: 1,
mentionAci: generateAci(),
conversationID: 'x',
replacementText: 'Alice',
},
];
const text = `${'x '.repeat(400)}\uFFFC woo!${'y '.repeat(100)}`;
return <MessageBodyReadMoreTest bodyRanges={bodyRanges} text={text} />;
}
export function LongTextWithFormatting(): JSX.Element {
const bodyRanges = [
{
start: 0,
length: 5,
style: BodyRange.Style.ITALIC,
},
{
start: 7,
length: 3,
style: BodyRange.Style.BOLD,
},
{
start: 1019,
length: 4,
style: BodyRange.Style.BOLD,
},
{
start: 1024,
length: 6,
style: BodyRange.Style.ITALIC,
},
];
const text = `ready? set... g${'o'.repeat(1000)}al! bold italic`;
return <MessageBodyReadMoreTest bodyRanges={bodyRanges} text={text} />;
}
export function LongTextMostlySpoiler(): JSX.Element {
const [isSpoilerExpanded, setIsSpoilerExpanded] = React.useState({});
const bodyRanges = [
{
start: 7,
length: 1010,
style: BodyRange.Style.SPOILER,
},
];
const text = `ready? set... g${'o'.repeat(1000)}al! bold italic`;
return (
<MessageBodyReadMoreTest
bodyRanges={bodyRanges}
text={text}
isSpoilerExpanded={isSpoilerExpanded}
onExpandSpoiler={data => setIsSpoilerExpanded(data)}
/>
);
}
export function Links(): JSX.Element {
return (
<MessageBodyReadMoreTest
text={`${'test '.repeat(176)}https://www.signal.org`}
/>
);
}
export function ExcessiveAmountsOfCake(): JSX.Element {
return <MessageBodyReadMoreTest text={`x${'🍰'.repeat(20000)}`} />;
}
export function LongText(): JSX.Element {
return (
<MessageBodyReadMoreTest
text={`
SCENE I. Rome. A street.
Enter FLAVIUS, MARULLUS, and certain Commoners
FLAVIUS
Hence! home, you idle creatures get you home:
Is this a holiday? what! know you not,
Being mechanical, you ought not walk
Upon a labouring day without the sign
Of your profession? Speak, what trade art thou?
First Commoner
Why, sir, a carpenter.
MARULLUS
Where is thy leather apron and thy rule?
What dost thou with thy best apparel on?
You, sir, what trade are you?
Second Commoner
Truly, sir, in respect of a fine workman, I am but,
as you would say, a cobbler.
MARULLUS
But what trade art thou? answer me directly.
Second Commoner
A trade, sir, that, I hope, I may use with a safe
conscience; which is, indeed, sir, a mender of bad soles.
MARULLUS
What trade, thou knave? thou naughty knave, what trade?
Second Commoner
Nay, I beseech you, sir, be not out with me: yet,
if you be out, sir, I can mend you.
MARULLUS
What meanest thou by that? mend me, thou saucy fellow!
Second Commoner
Why, sir, cobble you.
FLAVIUS
Thou art a cobbler, art thou?
Second Commoner
Truly, sir, all that I live by is with the awl: I
meddle with no tradesman's matters, nor women's
matters, but with awl. I am, indeed, sir, a surgeon
to old shoes; when they are in great danger, I
recover them. As proper men as ever trod upon
neat's leather have gone upon my handiwork.
FLAVIUS
But wherefore art not in thy shop today?
Why dost thou lead these men about the streets?
Second Commoner
Truly, sir, to wear out their shoes, to get myself
into more work. But, indeed, sir, we make holiday,
to see Caesar and to rejoice in his triumph.
MARULLUS
Wherefore rejoice? What conquest brings he home?
What tributaries follow him to Rome,
To grace in captive bonds his chariot-wheels?
You blocks, you stones, you worse than senseless things!
O you hard hearts, you cruel men of Rome,
Knew you not Pompey? Many a time and oft
Have you climb'd up to walls and battlements,
To towers and windows, yea, to chimney-tops,
Your infants in your arms, and there have sat
The livelong day, with patient expectation,
To see great Pompey pass the streets of Rome:
And when you saw his chariot but appear,
Have you not made an universal shout,
That Tiber trembled underneath her banks,
To hear the replication of your sounds
Made in her concave shores?
And do you now put on your best attire?
And do you now cull out a holiday?
And do you now strew flowers in his way
That comes in triumph over Pompey's blood? Be gone!
Run to your houses, fall upon your knees,
Pray to the gods to intermit the plague
That needs must light on this ingratitude.
FLAVIUS
Go, go, good countrymen, and, for this fault,
Assemble all the poor men of your sort;
Draw them to Tiber banks, and weep your tears
Into the channel, till the lowest stream
Do kiss the most exalted shores of all.
Exeunt all the Commoners
See whether their basest metal be not moved;
They vanish tongue-tied in their guiltiness.
Go you down that way towards the Capitol;
This way will I
disrobe the images,
If you do find them deck'd with ceremonies.
MARULLUS
May we do so?
You know it is the feast of Lupercal.
FLAVIUS
It is no matter; let no images
Be hung with Caesar's trophies. I'll about,
And drive away the vulgar from the streets:
So do you too, where you perceive them thick.
These growing feathers pluck'd from Caesar's wing
Will make him fly an ordinary pitch,
Who else would soar above the view of men
And keep us all in servile fearfulness.
`}
/>
);
}