Story creator improvements

This commit is contained in:
Josh Perez 2022-07-08 17:14:01 -04:00 committed by GitHub
parent 46aee24faa
commit 06b606cec3
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 69 additions and 11 deletions

View file

@ -58,6 +58,12 @@
} }
} }
&__preview-container {
position: relative;
margin-left: 72px;
margin-right: 72px;
}
&__preview { &__preview {
align-items: center; align-items: center;
background: $color-black-alpha-40; background: $color-black-alpha-40;
@ -66,10 +72,30 @@
flex-direction: row; flex-direction: row;
height: 122px; height: 122px;
justify-content: center; justify-content: center;
margin-left: 72px;
margin-right: 72px;
padding: 34px; padding: 34px;
&__remove {
backdrop-filter: blur(26px);
background: $color-black-alpha-40;
border-radius: 100%;
height: 48px;
position: absolute;
right: -16px;
top: -16px;
width: 48px;
z-index: $z-index-base;
button {
@include button-reset;
height: 24px;
position: absolute;
right: 12px;
top: 12px;
width: 24px;
@include color-svg('../images/icons/v2/x-24.svg', $color-gray-15);
}
}
.TextAttachment__preview-container--large & { .TextAttachment__preview-container--large & {
height: 192px; height: 192px;
} }

View file

@ -104,7 +104,7 @@ export const StoryCreator = ({
const [textBackground, setTextBackground] = useState<TextBackground>( const [textBackground, setTextBackground] = useState<TextBackground>(
TextBackground.None TextBackground.None
); );
const [sliderValue, setSliderValue] = useState<number>(0); const [sliderValue, setSliderValue] = useState<number>(100);
const [text, setText] = useState<string>(''); const [text, setText] = useState<string>('');
const textEditorRef = useRef<HTMLInputElement | null>(null); const textEditorRef = useRef<HTMLInputElement | null>(null);
@ -234,9 +234,18 @@ export const StoryCreator = ({
<div className="StoryCreator"> <div className="StoryCreator">
<div className="StoryCreator__container"> <div className="StoryCreator__container">
<TextAttachment <TextAttachment
disableLinkPreviewPopup
i18n={i18n} i18n={i18n}
isEditingText={isEditingText} isEditingText={isEditingText}
onChange={setText} onChange={setText}
onClick={() => {
if (!isEditingText) {
setIsEditingText(true);
}
}}
onRemoveLinkPreview={() => {
setHasLinkPreviewApplied(false);
}}
textAttachment={{ textAttachment={{
...getBackground(selectedBackground), ...getBackground(selectedBackground),
text, text,

View file

@ -41,10 +41,13 @@ enum TextSize {
} }
export type PropsType = { export type PropsType = {
disableLinkPreviewPopup?: boolean;
i18n: LocalizerType; i18n: LocalizerType;
isEditingText?: boolean; isEditingText?: boolean;
isThumbnail?: boolean; isThumbnail?: boolean;
onChange?: (text: string) => unknown; onChange?: (text: string) => unknown;
onClick?: () => unknown;
onRemoveLinkPreview?: () => unknown;
textAttachment: TextAttachmentType; textAttachment: TextAttachmentType;
}; };
@ -102,10 +105,13 @@ function getTextStyles(
} }
export const TextAttachment = ({ export const TextAttachment = ({
disableLinkPreviewPopup,
i18n, i18n,
isEditingText, isEditingText,
isThumbnail, isThumbnail,
onChange, onChange,
onClick,
onRemoveLinkPreview,
textAttachment, textAttachment,
}: PropsType): JSX.Element | null => { }: PropsType): JSX.Element | null => {
const linkPreview = useRef<HTMLDivElement | null>(null); const linkPreview = useRef<HTMLDivElement | null>(null);
@ -137,6 +143,7 @@ export const TextAttachment = ({
if (linkPreviewOffsetTop) { if (linkPreviewOffsetTop) {
setLinkPreviewOffsetTop(undefined); setLinkPreviewOffsetTop(undefined);
} }
onClick?.();
}} }}
onKeyUp={ev => { onKeyUp={ev => {
if (ev.key === 'Escape' && linkPreviewOffsetTop) { if (ev.key === 'Escape' && linkPreviewOffsetTop) {
@ -222,17 +229,31 @@ export const TextAttachment = ({
), ),
})} })}
ref={linkPreview} ref={linkPreview}
onFocus={() => onFocus={() => {
setLinkPreviewOffsetTop(linkPreview?.current?.offsetTop) if (!disableLinkPreviewPopup) {
} setLinkPreviewOffsetTop(linkPreview?.current?.offsetTop);
onMouseOver={() => }
setLinkPreviewOffsetTop(linkPreview?.current?.offsetTop) }}
} onMouseOver={() => {
if (!disableLinkPreviewPopup) {
setLinkPreviewOffsetTop(linkPreview?.current?.offsetTop);
}
}}
> >
{onRemoveLinkPreview && (
<div className="TextAttachment__preview__remove">
<button
aria-label={i18n('Keyboard--remove-draft-link-preview')}
type="button"
onClick={onRemoveLinkPreview}
/>
</div>
)}
<StagedLinkPreview <StagedLinkPreview
domain={getDomain(String(textAttachment.preview.url))} domain={getDomain(String(textAttachment.preview.url))}
i18n={i18n} i18n={i18n}
image={textAttachment.preview.image} image={textAttachment.preview.image}
imageSize={textAttachment.preview.title ? 144 : 72}
moduleClassName="TextAttachment__preview" moduleClassName="TextAttachment__preview"
title={textAttachment.preview.title || undefined} title={textAttachment.preview.title || undefined}
url={textAttachment.preview.url} url={textAttachment.preview.url}

View file

@ -15,6 +15,7 @@ import { isImageAttachment } from '../../types/Attachment';
export type Props = LinkPreviewType & { export type Props = LinkPreviewType & {
i18n: LocalizerType; i18n: LocalizerType;
imageSize?: number;
moduleClassName?: string; moduleClassName?: string;
onClose?: () => void; onClose?: () => void;
}; };
@ -25,6 +26,7 @@ export const StagedLinkPreview: React.FC<Props> = ({
domain, domain,
i18n, i18n,
image, image,
imageSize,
moduleClassName, moduleClassName,
onClose, onClose,
title, title,
@ -58,10 +60,10 @@ export const StagedLinkPreview: React.FC<Props> = ({
curveBottomRight={CurveType.Tiny} curveBottomRight={CurveType.Tiny}
curveTopLeft={CurveType.Tiny} curveTopLeft={CurveType.Tiny}
curveTopRight={CurveType.Tiny} curveTopRight={CurveType.Tiny}
height={72} height={imageSize || 72}
i18n={i18n} i18n={i18n}
url={image.url} url={image.url}
width={72} width={imageSize || 72}
/> />
</div> </div>
) : null} ) : null}