33 lines
945 B
TypeScript
33 lines
945 B
TypeScript
import React from 'react';
|
|
import classnames from 'classnames';
|
|
|
|
|
|
interface Props {
|
|
/**
|
|
* Corresponds to the theme setting in the app, and the class added to the root element.
|
|
*/
|
|
theme: 'ios' | 'android' | 'android-dark';
|
|
conversationType: 'private' | 'group';
|
|
}
|
|
|
|
/**
|
|
* Provides the parent elements necessary to allow the main Signal Desktop stylesheet to
|
|
* apply (with no changes) to messages in the Style Guide.
|
|
*/
|
|
export class ConversationContext extends React.Component<Props, {}> {
|
|
public render() {
|
|
const { theme, conversationType } = this.props;
|
|
|
|
return (
|
|
<div className={theme || 'android'}>
|
|
<div className={classnames('conversation', conversationType || 'private')}>
|
|
<div className="discussion-container" style={{padding: '0.5em'}}>
|
|
<ul className="message-list">
|
|
{this.props.children}
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
}
|