Open media gallery item in lightbox

This commit is contained in:
Daniel Gasienica 2018-04-15 02:16:39 -04:00
parent a9f7f18721
commit 0d676a65b8
5 changed files with 46 additions and 7 deletions

View file

@ -592,14 +592,25 @@
); );
const mediaWithObjectURLs = await loadMessages(media); const mediaWithObjectURLs = await loadMessages(media);
const props = { const mediaGalleryProps = {
media: mediaWithObjectURLs, media: mediaWithObjectURLs,
documents: [], documents: [],
onItemClick: ({message}) => {
const lightboxProps = {
imageURL: message.objectURL,
};
this.lightboxView = new Whisper.ReactWrapperView({
Component: Signal.Components.Lightbox,
props: lightboxProps,
onClose: () => Signal.Backbone.Views.Lightbox.hide(),
});
Signal.Backbone.Views.Lightbox.show(this.lightboxView.el);
}
}; };
const view = new Whisper.ReactWrapperView({ const view = new Whisper.ReactWrapperView({
Component: MediaGallery, Component: MediaGallery,
props, props: mediaGalleryProps,
onClose: () => this.resetPanel(), onClose: () => this.resetPanel(),
}); });

View file

@ -4,6 +4,7 @@
import React from 'react'; import React from 'react';
import { DocumentListItem } from './DocumentListItem'; import { DocumentListItem } from './DocumentListItem';
import { ItemClickEvent } from './events/ItemClickEvent';
import { MediaGridItem } from './MediaGridItem'; import { MediaGridItem } from './MediaGridItem';
import { Message } from './propTypes/Message'; import { Message } from './propTypes/Message';
import { missingCaseError } from '../../../util/missingCaseError'; import { missingCaseError } from '../../../util/missingCaseError';
@ -31,19 +32,27 @@ interface Props {
header?: string; header?: string;
type: 'media' | 'documents'; type: 'media' | 'documents';
messages: Array<Message>; messages: Array<Message>;
onItemClick?: (event: ItemClickEvent) => void;
} }
export class AttachmentSection extends React.Component<Props, {}> { export class AttachmentSection extends React.Component<Props, {}> {
public renderItems() { private renderItems() {
const { i18n, messages, type } = this.props; const { i18n, messages, type } = this.props;
return messages.map(message => { return messages.map(message => {
const { attachments } = message; const { attachments } = message;
const firstAttachment = attachments[0]; const firstAttachment = attachments[0];
const onClick = this.createClickHandler(message);
switch (type) { switch (type) {
case 'media': case 'media':
return <MediaGridItem key={message.received_at} message={message} />; return (
<MediaGridItem
key={message.received_at}
message={message}
onClick={onClick}
/>
);
case 'documents': case 'documents':
return ( return (
<DocumentListItem <DocumentListItem
@ -52,6 +61,7 @@ export class AttachmentSection extends React.Component<Props, {}> {
fileSize={firstAttachment.size} fileSize={firstAttachment.size}
fileName={firstAttachment.fileName} fileName={firstAttachment.fileName}
timestamp={message.received_at} timestamp={message.received_at}
onClick={onClick}
/> />
); );
default: default:
@ -60,6 +70,15 @@ export class AttachmentSection extends React.Component<Props, {}> {
}); });
} }
private createClickHandler = (message: Message) => () => {
const { onItemClick } = this.props;
if (!onItemClick) {
return;
}
onItemClick({ message });
};
public render() { public render() {
const { header } = this.props; const { header } = this.props;

View file

@ -12,6 +12,7 @@ interface Props {
fileName?: string; fileName?: string;
fileSize?: number; fileSize?: number;
i18n: (key: string, values?: Array<string>) => string; i18n: (key: string, values?: Array<string>) => string;
onClick?: () => void;
timestamp: number; timestamp: number;
} }
@ -61,7 +62,7 @@ export class DocumentListItem extends React.Component<Props, {}> {
// } // }
return ( return (
<div style={styles.itemContainer}> <div style={styles.itemContainer} onClick={this.props.onClick}>
<img <img
src="images/file.svg" src="images/file.svg"
width="48" width="48"

View file

@ -7,6 +7,7 @@ import moment from 'moment';
import { AttachmentSection } from './AttachmentSection'; import { AttachmentSection } from './AttachmentSection';
import { groupMessagesByDate } from './groupMessagesByDate'; import { groupMessagesByDate } from './groupMessagesByDate';
import { ItemClickEvent } from './events/ItemClickEvent';
import { Message } from './propTypes/Message'; import { Message } from './propTypes/Message';
type AttachmentType = 'media' | 'documents'; type AttachmentType = 'media' | 'documents';
@ -15,6 +16,7 @@ interface Props {
documents: Array<Message>; documents: Array<Message>;
i18n: (key: string, values?: Array<string>) => string; i18n: (key: string, values?: Array<string>) => string;
media: Array<Message>; media: Array<Message>;
onItemClick?: (event: ItemClickEvent) => void;
} }
interface State { interface State {
@ -110,7 +112,7 @@ export class MediaGallery extends React.Component<Props, State> {
}; };
private renderSections() { private renderSections() {
const { i18n, media, documents } = this.props; const { i18n, media, documents, onItemClick } = this.props;
const { selectedTab } = this.state; const { selectedTab } = this.state;
const messages = selectedTab === 'media' ? media : documents; const messages = selectedTab === 'media' ? media : documents;
@ -137,6 +139,7 @@ export class MediaGallery extends React.Component<Props, State> {
i18n={i18n} i18n={i18n}
type={type} type={type}
messages={section.messages} messages={section.messages}
onItemClick={onItemClick}
/> />
); );
}); });

View file

@ -8,6 +8,7 @@ import { Message } from './propTypes/Message';
interface Props { interface Props {
message: Message; message: Message;
onClick?: () => void;
} }
const size = { const size = {
@ -47,6 +48,10 @@ export class MediaGridItem extends React.Component<Props, {}> {
} }
public render() { public render() {
return <div style={styles.container}>{this.renderContent()}</div>; return (
<div style={styles.container} onClick={this.props.onClick}>
{this.renderContent()}
</div>
);
} }
} }