ref(toolbox): getter for the recording/streaming disabled tooltip

This commit is contained in:
Leonard Kim 2018-10-28 19:10:43 -07:00 committed by Leonard Kim
parent 85f487cca5
commit 007d60eb6c
3 changed files with 26 additions and 36 deletions

View File

@ -206,6 +206,16 @@ export default class AbstractButton<P: Props, S: *> extends Component<P, S> {
return buttonStyles; return buttonStyles;
} }
/**
* Get the tooltip to display when hovering over the button.
*
* @private
* @returns {string}
*/
_getTooltip() {
return this.tooltip || '';
}
/** /**
* Helper function to be implemented by subclasses, which must return a * Helper function to be implemented by subclasses, which must return a
* boolean value indicating if this button is disabled or not. * boolean value indicating if this button is disabled or not.
@ -258,7 +268,7 @@ export default class AbstractButton<P: Props, S: *> extends Component<P, S> {
iconName: this._getIconName(), iconName: this._getIconName(),
label: this._getLabel(), label: this._getLabel(),
styles: this._getStyles(), styles: this._getStyles(),
tooltip: this.tooltip tooltip: this._getTooltip()
}; };
return ( return (

View File

@ -37,26 +37,6 @@ class LiveStreamButton extends AbstractLiveStreamButton<Props> {
iconName = 'icon-public'; iconName = 'icon-public';
toggledIconName = 'icon-public'; toggledIconName = 'icon-public';
/**
* Constructor of the component.
*
* @inheritdoc
*/
constructor(props: Props) {
super(props);
this.tooltip = props._liveStreamDisabledTooltipKey;
}
/**
* Implements {@code Component}'s componentWillReceiveProps.
*
* @inheritdoc
*/
componentWillReceiveProps(newProps: Props) {
this.tooltip = newProps._liveStreamDisabledTooltipKey;
}
/** /**
* Helper function to be implemented by subclasses, which returns * Helper function to be implemented by subclasses, which returns
* a React Element to display (a beta tag) at the end of the button. * a React Element to display (a beta tag) at the end of the button.
@ -76,6 +56,16 @@ class LiveStreamButton extends AbstractLiveStreamButton<Props> {
); );
} }
/**
* Returns the tooltip that should be displayed when the button is disabled.
*
* @private
* @returns {string}
*/
_getTooltip() {
return this.props._liveStreamDisabledTooltipKey || '';
}
/** /**
* Helper function to be implemented by subclasses, which must return a * Helper function to be implemented by subclasses, which must return a
* boolean value indicating if this button is disabled or not. * boolean value indicating if this button is disabled or not.

View File

@ -36,23 +36,13 @@ class RecordButton extends AbstractRecordButton<Props> {
toggledIconName = 'icon-camera-take-picture'; toggledIconName = 'icon-camera-take-picture';
/** /**
* Constructor of the component. * Returns the tooltip that should be displayed when the button is disabled.
* *
* @inheritdoc * @private
* @returns {string}
*/ */
constructor(props: Props) { _getTooltip() {
super(props); return this.tooltip || '';
this.tooltip = props._fileRecordingsDisabledTooltipKey;
}
/**
* Implements {@code Component}'s componentWillReceiveProps.
*
* @inheritdoc
*/
componentWillReceiveProps(newProps: Props) {
this.tooltip = newProps._fileRecordingsDisabledTooltipKey;
} }
/** /**