|  |  |  | import React from 'react'; | 
					
						
							|  |  |  | import classNames from 'classnames'; | 
					
						
							|  |  |  | import { SessionButton } from './SessionButton'; | 
					
						
							|  |  |  | import { SessionIcon, SessionIconSize, SessionIconType } from './icon'; | 
					
						
							|  |  |  | import { | 
					
						
							|  |  |  |   NotificationCountSize, | 
					
						
							|  |  |  |   SessionNotificationCount, | 
					
						
							|  |  |  | } from './SessionNotificationCount'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const Tab = ({ | 
					
						
							|  |  |  |   isSelected, | 
					
						
							|  |  |  |   label, | 
					
						
							|  |  |  |   onSelect, | 
					
						
							|  |  |  |   type, | 
					
						
							|  |  |  | }: { | 
					
						
							|  |  |  |   isSelected: boolean; | 
					
						
							|  |  |  |   label: string; | 
					
						
							|  |  |  |   onSelect?: (event: number) => void; | 
					
						
							|  |  |  |   type: number; | 
					
						
							|  |  |  | }) => { | 
					
						
							|  |  |  |   const handleClick = onSelect | 
					
						
							|  |  |  |     ? () => { | 
					
						
							|  |  |  |         onSelect(type); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     : undefined; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <h1 | 
					
						
							|  |  |  |       className={classNames( | 
					
						
							|  |  |  |         'module-left-pane__title', | 
					
						
							|  |  |  |         isSelected ? 'active' : null | 
					
						
							|  |  |  |       )} | 
					
						
							|  |  |  |       onClick={handleClick} | 
					
						
							|  |  |  |       role="button" | 
					
						
							|  |  |  |     > | 
					
						
							|  |  |  |       {label} | 
					
						
							|  |  |  |     </h1> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | interface Props { | 
					
						
							|  |  |  |   onTabSelected: any; | 
					
						
							|  |  |  |   selectedTab: number; | 
					
						
							|  |  |  |   labels: Array<string>; | 
					
						
							|  |  |  |   notificationCount?: number; | 
					
						
							|  |  |  |   buttonLabel?: string; | 
					
						
							|  |  |  |   buttonIcon?: SessionIconType; | 
					
						
							|  |  |  |   buttonClicked?: any; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | interface State { | 
					
						
							|  |  |  |   selectedTab: number; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export class LeftPaneSectionHeader extends React.Component<Props, State> { | 
					
						
							|  |  |  |   constructor(props: any) { | 
					
						
							|  |  |  |     super(props); | 
					
						
							|  |  |  |     this.state = { selectedTab: 0 }; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   public render() { | 
					
						
							|  |  |  |     return this.renderTabs(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   private renderTabs() { | 
					
						
							|  |  |  |     const { selectedTab } = this.state; | 
					
						
							|  |  |  |     const { | 
					
						
							|  |  |  |       labels, | 
					
						
							|  |  |  |       buttonLabel, | 
					
						
							|  |  |  |       buttonIcon, | 
					
						
							|  |  |  |       buttonClicked, | 
					
						
							|  |  |  |       notificationCount, | 
					
						
							|  |  |  |     } = this.props; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const hasButton = buttonLabel || buttonIcon; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const children = []; | 
					
						
							|  |  |  |     //loop to create children
 | 
					
						
							|  |  |  |     for (let i = 0; i < labels.length; i++) { | 
					
						
							|  |  |  |       children.push( | 
					
						
							|  |  |  |         <Tab | 
					
						
							|  |  |  |           label={labels[i]} | 
					
						
							|  |  |  |           type={i} | 
					
						
							|  |  |  |           isSelected={selectedTab === i} | 
					
						
							|  |  |  |           onSelect={this.handleTabSelect} | 
					
						
							|  |  |  |           key={i} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (hasButton && !notificationCount) { | 
					
						
							|  |  |  |       const buttonContent = buttonIcon ? ( | 
					
						
							|  |  |  |         <SessionIcon iconType={buttonIcon} iconSize={SessionIconSize.Small} /> | 
					
						
							|  |  |  |       ) : ( | 
					
						
							|  |  |  |         buttonLabel | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |       const button = ( | 
					
						
							|  |  |  |         <SessionButton onClick={buttonClicked} key="compose" disabled={false}> | 
					
						
							|  |  |  |           {buttonContent} | 
					
						
							|  |  |  |         </SessionButton> | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       children.push(button); | 
					
						
							|  |  |  |     } else if (buttonLabel && notificationCount && notificationCount > 0) { | 
					
						
							|  |  |  |       children.push( | 
					
						
							|  |  |  |         <div className="contact-notification-section"> | 
					
						
							|  |  |  |           <SessionButton | 
					
						
							|  |  |  |             text={buttonLabel} | 
					
						
							|  |  |  |             onClick={buttonClicked} | 
					
						
							|  |  |  |             key="compose" | 
					
						
							|  |  |  |             disabled={false} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |           <SessionNotificationCount | 
					
						
							|  |  |  |             count={notificationCount} | 
					
						
							|  |  |  |             size={NotificationCountSize.ON_HEADER} | 
					
						
							|  |  |  |             onClick={this.props.buttonClicked} | 
					
						
							|  |  |  |             key="notification-count" // we can only have one of those here
 | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     } else if (notificationCount && notificationCount > 0) { | 
					
						
							|  |  |  |       children.push( | 
					
						
							|  |  |  |         <SessionNotificationCount | 
					
						
							|  |  |  |           count={notificationCount} | 
					
						
							|  |  |  |           size={NotificationCountSize.ON_HEADER} | 
					
						
							|  |  |  |           onClick={this.props.buttonClicked} | 
					
						
							|  |  |  |           key="notificationCount" | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Create the parent and add the children
 | 
					
						
							|  |  |  |     return <div className="module-left-pane__header">{children}</div>; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   private readonly handleTabSelect = (tabType: number): void => { | 
					
						
							|  |  |  |     this.setState({ | 
					
						
							|  |  |  |       selectedTab: tabType, | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |     if (this.props.onTabSelected) { | 
					
						
							|  |  |  |       this.props.onTabSelected(tabType); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | } |