Add tooltip support to Link component
This commit is contained in:
parent
73a70b7a61
commit
6f16b76bb3
1 changed files with 61 additions and 7 deletions
|
@ -11,19 +11,73 @@ var Icon = React.createClass({
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
var Link = React.createClass({
|
var toolTipStyle = {
|
||||||
|
position: 'absolute',
|
||||||
|
top: '100%',
|
||||||
|
left: '-120px',
|
||||||
|
width: '260px',
|
||||||
|
padding: '15px',
|
||||||
|
border: '1px solid #aaa',
|
||||||
|
fontSize: '14px',
|
||||||
|
};
|
||||||
|
var ToolTip = React.createClass({
|
||||||
|
propTypes: {
|
||||||
|
open: React.PropTypes.bool.isRequired,
|
||||||
|
onMouseOut: React.PropTypes.func
|
||||||
|
},
|
||||||
|
render: function() {
|
||||||
|
return (
|
||||||
|
<div className={this.props.open ? '' : 'hidden'} style={toolTipStyle} onMouseOut={this.props.onMouseOut}>
|
||||||
|
{this.props.children}
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
var linkContainerStyle = {
|
||||||
|
position: 'relative',
|
||||||
|
};
|
||||||
|
var Link = React.createClass({
|
||||||
|
getInitialState: function() {
|
||||||
|
return {
|
||||||
|
showTooltip: false,
|
||||||
|
};
|
||||||
|
},
|
||||||
|
handleClick: function() {
|
||||||
|
if (this.props.tooltip) {
|
||||||
|
this.setState({
|
||||||
|
showTooltip: !this.state.showTooltip,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (this.props.onClick) {
|
||||||
|
this.props.onClick();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
handleTooltipMouseOut: function() {
|
||||||
|
this.setState({
|
||||||
|
showTooltip: false,
|
||||||
|
});
|
||||||
|
},
|
||||||
render: function() {
|
render: function() {
|
||||||
console.log(this.props);
|
|
||||||
var href = this.props.href ? this.props.href : 'javascript:;',
|
var href = this.props.href ? this.props.href : 'javascript:;',
|
||||||
icon = this.props.icon ? <Icon icon={this.props.icon} /> : '',
|
icon = this.props.icon ? <Icon icon={this.props.icon} /> : '',
|
||||||
className = (this.props.button ? 'button-block button-' + this.props.button : 'button-text') +
|
className = (this.props.button ? 'button-block button-' + this.props.button : 'button-text') +
|
||||||
(this.props.hidden ? ' hidden' : '') + (this.props.disabled ? ' disabled' : '');
|
(this.props.hidden ? ' hidden' : '') + (this.props.disabled ? ' disabled' : '');
|
||||||
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
<span style={linkContainerStyle}>
|
||||||
<a className={className} href={href} style={this.props.style ? this.props.style : {}}
|
<a className={className} href={href} style={this.props.style ? this.props.style : {}}
|
||||||
title={this.props.title} onClick={this.props.onClick}>
|
title={this.props.title} onClick={this.handleClick}>
|
||||||
{this.props.icon ? icon : '' }
|
{this.props.icon ? icon : '' }
|
||||||
{this.props.label}
|
{this.props.label}
|
||||||
</a>
|
</a>
|
||||||
|
{(!this.props.tooltip ? null :
|
||||||
|
<ToolTip open={this.state.showTooltip} onMouseOut={this.handleTooltipMouseOut}>
|
||||||
|
{this.props.tooltip}
|
||||||
|
</ToolTip>
|
||||||
|
)}
|
||||||
|
</span>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue