2018-03-26 14:32:43 -07:00
|
|
|
// @flow
|
2018-11-25 20:21:25 -05:00
|
|
|
import * as ICONS from 'constants/icons';
|
2018-03-26 14:32:43 -07:00
|
|
|
import React from 'react';
|
2018-05-22 20:11:20 -04:00
|
|
|
import Tooltip from 'component/common/tooltip';
|
2019-03-31 19:04:01 -04:00
|
|
|
import classnames from 'classnames';
|
2019-06-28 03:27:55 -04:00
|
|
|
import { icons } from './icon-custom';
|
2018-03-26 14:32:43 -07:00
|
|
|
|
2018-06-25 02:28:03 -04:00
|
|
|
// It would be nice to standardize this somehow
|
|
|
|
// These are copied from `scss/vars`, can they both come from the same source?
|
2018-03-26 14:32:43 -07:00
|
|
|
const RED_COLOR = '#e2495e';
|
2018-06-25 02:28:03 -04:00
|
|
|
const GREEN_COLOR = '#44b098';
|
2018-09-12 12:42:15 -04:00
|
|
|
const BLUE_COLOR = '#49b2e2';
|
2018-03-26 14:32:43 -07:00
|
|
|
|
|
|
|
type Props = {
|
|
|
|
icon: string,
|
2019-06-28 03:27:55 -04:00
|
|
|
tooltip?: boolean,
|
2020-01-20 11:47:03 -05:00
|
|
|
customTooltipText?: string,
|
2018-05-22 23:48:22 -04:00
|
|
|
iconColor?: string,
|
2018-10-09 11:01:54 -04:00
|
|
|
size?: number,
|
2019-03-31 19:04:01 -04:00
|
|
|
className?: string,
|
2019-09-26 12:07:11 -04:00
|
|
|
sectionIcon?: boolean,
|
2018-03-26 14:32:43 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
class IconComponent extends React.PureComponent<Props> {
|
2018-05-22 20:11:20 -04:00
|
|
|
getTooltip = (icon: string) => {
|
|
|
|
switch (icon) {
|
2020-04-23 12:15:51 -04:00
|
|
|
case ICONS.REWARDS:
|
2018-05-22 20:11:20 -04:00
|
|
|
return __('Featured content. Earn rewards for watching.');
|
2019-05-13 02:05:38 -04:00
|
|
|
case ICONS.DOWNLOAD:
|
2019-08-14 14:09:45 -04:00
|
|
|
return __('This file is in your library.');
|
2019-06-28 03:33:07 -04:00
|
|
|
case ICONS.SUBSCRIBE:
|
2019-06-28 03:27:55 -04:00
|
|
|
return __('You are subscribed to this channel.');
|
|
|
|
case ICONS.SETTINGS:
|
|
|
|
return __('Your settings.');
|
2018-05-22 20:11:20 -04:00
|
|
|
default:
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
};
|
2018-05-22 23:48:22 -04:00
|
|
|
|
|
|
|
getIconColor = (color: string) => {
|
|
|
|
switch (color) {
|
|
|
|
case 'red':
|
|
|
|
return RED_COLOR;
|
2018-06-25 02:28:03 -04:00
|
|
|
case 'green':
|
|
|
|
return GREEN_COLOR;
|
2018-09-12 12:42:15 -04:00
|
|
|
case 'blue':
|
|
|
|
return BLUE_COLOR;
|
2018-05-22 23:48:22 -04:00
|
|
|
default:
|
2020-01-29 20:02:21 -05:00
|
|
|
return color;
|
2018-05-22 23:48:22 -04:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-03-26 14:32:43 -07:00
|
|
|
render() {
|
2020-01-20 11:47:03 -05:00
|
|
|
const { icon, tooltip, customTooltipText, iconColor, size, className, sectionIcon = false } = this.props;
|
2019-06-28 03:27:55 -04:00
|
|
|
const Icon = icons[this.props.icon];
|
2019-03-26 23:40:02 -05:00
|
|
|
|
2018-05-22 20:11:20 -04:00
|
|
|
if (!Icon) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2018-03-26 14:32:43 -07:00
|
|
|
let color;
|
2018-05-22 23:48:22 -04:00
|
|
|
if (iconColor) {
|
|
|
|
color = this.getIconColor(iconColor);
|
2018-03-26 14:32:43 -07:00
|
|
|
}
|
|
|
|
|
2020-04-01 14:43:50 -04:00
|
|
|
const iconSize = size || 16;
|
2018-03-26 14:32:43 -07:00
|
|
|
|
2018-05-22 20:11:20 -04:00
|
|
|
let tooltipText;
|
|
|
|
if (tooltip) {
|
2020-01-20 11:47:03 -05:00
|
|
|
tooltipText = customTooltipText || this.getTooltip(icon);
|
2018-05-22 20:11:20 -04:00
|
|
|
}
|
2019-05-01 15:26:47 -04:00
|
|
|
|
2019-09-26 12:07:11 -04:00
|
|
|
const component = (
|
|
|
|
<Icon size={sectionIcon ? 20 : iconSize} className={classnames(`icon icon--${icon}`, className)} color={color} />
|
|
|
|
);
|
|
|
|
|
2020-03-18 13:11:37 -04:00
|
|
|
const inner = sectionIcon ? <span className={`icon__wrapper icon__wrapper--${icon}`}>{component}</span> : component;
|
2018-05-22 20:11:20 -04:00
|
|
|
|
2019-06-28 03:27:55 -04:00
|
|
|
return tooltipText ? <Tooltip label={tooltipText}>{inner}</Tooltip> : inner;
|
2018-03-26 14:32:43 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default IconComponent;
|