You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
session-desktop/ts/components/session/SessionDropdownItem.tsx

69 lines
1.5 KiB
TypeScript

import React from 'react';
import classNames from 'classnames';
import { SessionIcon, SessionIconSize, SessionIconType } from './icon/';
import { generateID } from './tools/ComponentTools';
export enum SessionDropDownItemType {
Default = 'default',
Danger = 'danger',
}
interface Props {
id: string,
content: string,
type: SessionDropDownItemType,
icon: SessionIconType | null,
active: boolean,
onClick: any,
}
export class SessionDropdownItem extends React.PureComponent<Props> {
public static defaultProps = {
id: generateID(),
type: SessionDropDownItemType.Default,
icon: null,
active: false,
onClick: () => null,
};
constructor(props: any) {
super(props);
this.clickHandler = this.clickHandler.bind(this);
}
public render() {
const { id, content, type, icon, active } = this.props;
return (
<li
id={id}
className={classNames(active ? 'active' : '', type || '')}
onClick={this.clickHandler}
>
{ icon ? <SessionIcon
iconType = { icon }
iconSize = { SessionIconSize.Small }
/>
: ''
}
<div className="item-content">
{content}
</div>
</li>
);
}
private clickHandler(e: any){
if (this.props.onClick) {
e.stopPropagation();
this.props.onClick();
}
}
}