exports[`<DisplayName /> renders display name + account name 1`] = `
<span
className="display-name"
+ onMouseEnter={[Function]}
+ onMouseLeave={[Function]}
>
<bdi>
<strong
localDomain: PropTypes.string,
};
- _updateEmojis () {
- const node = this.node;
-
- if (!node || autoPlayGif) {
+ handleMouseEnter = ({ currentTarget }) => {
+ if (autoPlayGif) {
return;
}
- const emojis = node.querySelectorAll('.custom-emoji');
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
for (var i = 0; i < emojis.length; i++) {
let emoji = emojis[i];
- if (emoji.classList.contains('status-emoji')) {
- continue;
- }
- emoji.classList.add('status-emoji');
-
- emoji.addEventListener('mouseenter', this.handleEmojiMouseEnter, false);
- emoji.addEventListener('mouseleave', this.handleEmojiMouseLeave, false);
+ emoji.src = emoji.getAttribute('data-original');
}
}
- componentDidMount () {
- this._updateEmojis();
- }
-
- componentDidUpdate () {
- this._updateEmojis();
- }
-
- handleEmojiMouseEnter = ({ target }) => {
- target.src = target.getAttribute('data-original');
- }
+ handleMouseLeave = ({ currentTarget }) => {
+ if (autoPlayGif) {
+ return;
+ }
- handleEmojiMouseLeave = ({ target }) => {
- target.src = target.getAttribute('data-static');
- }
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
- setRef = (c) => {
- this.node = c;
+ for (var i = 0; i < emojis.length; i++) {
+ let emoji = emojis[i];
+ emoji.src = emoji.getAttribute('data-static');
+ }
}
render () {
}
return (
- <span className='display-name' ref={this.setRef}>
+ <span className='display-name' onMouseEnter={this.handleMouseEnter} onMouseLeave={this.handleMouseLeave}>
{displayName} {suffix}
</span>
);
}
}
- _updateStatusEmojis () {
- const node = this.node;
-
- if (!node || autoPlayGif) {
+ handleMouseEnter = ({ currentTarget }) => {
+ if (autoPlayGif) {
return;
}
- const emojis = node.querySelectorAll('.custom-emoji');
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
for (var i = 0; i < emojis.length; i++) {
let emoji = emojis[i];
- if (emoji.classList.contains('status-emoji')) {
- continue;
- }
- emoji.classList.add('status-emoji');
+ emoji.src = emoji.getAttribute('data-original');
+ }
+ }
+
+ handleMouseLeave = ({ currentTarget }) => {
+ if (autoPlayGif) {
+ return;
+ }
+
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
- emoji.addEventListener('mouseenter', this.handleEmojiMouseEnter, false);
- emoji.addEventListener('mouseleave', this.handleEmojiMouseLeave, false);
+ for (var i = 0; i < emojis.length; i++) {
+ let emoji = emojis[i];
+ emoji.src = emoji.getAttribute('data-static');
}
}
componentDidMount () {
this._updateStatusLinks();
- this._updateStatusEmojis();
}
componentDidUpdate () {
this._updateStatusLinks();
- this._updateStatusEmojis();
}
onMentionClick = (mention, e) => {
}
}
- handleEmojiMouseEnter = ({ target }) => {
- target.src = target.getAttribute('data-original');
- }
-
- handleEmojiMouseLeave = ({ target }) => {
- target.src = target.getAttribute('data-static');
- }
-
handleMouseDown = (e) => {
this.startXY = [e.clientX, e.clientY];
}
}
return (
- <div className={classNames} ref={this.setRef} tabIndex='0' onMouseDown={this.handleMouseDown} onMouseUp={this.handleMouseUp}>
+ <div className={classNames} ref={this.setRef} tabIndex='0' onMouseDown={this.handleMouseDown} onMouseUp={this.handleMouseUp} onMouseEnter={this.handleMouseEnter} onMouseLeave={this.handleMouseLeave}>
<p style={{ marginBottom: hidden && status.get('mentions').isEmpty() ? '0px' : null }}>
<span dangerouslySetInnerHTML={spoilerContent} className='translate' />
{' '}
);
} else if (this.props.onClick) {
const output = [
- <div className={classNames} ref={this.setRef} tabIndex='0' onMouseDown={this.handleMouseDown} onMouseUp={this.handleMouseUp} key='status-content'>
+ <div className={classNames} ref={this.setRef} tabIndex='0' onMouseDown={this.handleMouseDown} onMouseUp={this.handleMouseUp} key='status-content' onMouseEnter={this.handleMouseEnter} onMouseLeave={this.handleMouseLeave}>
<div className='status__content__text status__content__text--visible translate' dangerouslySetInnerHTML={content} />
{!!status.get('poll') && <PollContainer pollId={status.get('poll')} />}
return output;
} else {
return (
- <div className={classNames} ref={this.setRef} tabIndex='0'>
+ <div className={classNames} ref={this.setRef} tabIndex='0' onMouseEnter={this.handleMouseEnter} onMouseLeave={this.handleMouseLeave}>
<div className='status__content__text status__content__text--visible translate' dangerouslySetInnerHTML={content} />
{!!status.get('poll') && <PollContainer pollId={status.get('poll')} />}
return !location.pathname.match(/\/(followers|following)\/?$/);
}
- _updateEmojis () {
- const node = this.node;
-
- if (!node || autoPlayGif) {
+ handleMouseEnter = ({ currentTarget }) => {
+ if (autoPlayGif) {
return;
}
- const emojis = node.querySelectorAll('.custom-emoji');
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
for (var i = 0; i < emojis.length; i++) {
let emoji = emojis[i];
- if (emoji.classList.contains('status-emoji')) {
- continue;
- }
- emoji.classList.add('status-emoji');
-
- emoji.addEventListener('mouseenter', this.handleEmojiMouseEnter, false);
- emoji.addEventListener('mouseleave', this.handleEmojiMouseLeave, false);
+ emoji.src = emoji.getAttribute('data-original');
}
}
- componentDidMount () {
- this._updateEmojis();
- }
-
- componentDidUpdate () {
- this._updateEmojis();
- }
-
- handleEmojiMouseEnter = ({ target }) => {
- target.src = target.getAttribute('data-original');
- }
+ handleMouseLeave = ({ currentTarget }) => {
+ if (autoPlayGif) {
+ return;
+ }
- handleEmojiMouseLeave = ({ target }) => {
- target.src = target.getAttribute('data-static');
- }
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
- setRef = (c) => {
- this.node = c;
+ for (var i = 0; i < emojis.length; i++) {
+ let emoji = emojis[i];
+ emoji.src = emoji.getAttribute('data-static');
+ }
}
render () {
}
return (
- <div className={classNames('account__header', { inactive: !!account.get('moved') })} ref={this.setRef}>
+ <div className={classNames('account__header', { inactive: !!account.get('moved') })} onMouseEnter={this.handleMouseEnter} onMouseLeave={this.handleMouseLeave}>
<div className='account__header__image'>
<div className='account__header__info'>
{!suspended && info}
intl: PropTypes.object.isRequired,
};
- _updateEmojis () {
- const node = this.namesNode;
-
- if (!node || autoPlayGif) {
+ handleMouseEnter = ({ currentTarget }) => {
+ if (autoPlayGif) {
return;
}
- const emojis = node.querySelectorAll('.custom-emoji');
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
for (var i = 0; i < emojis.length; i++) {
let emoji = emojis[i];
- if (emoji.classList.contains('status-emoji')) {
- continue;
- }
- emoji.classList.add('status-emoji');
-
- emoji.addEventListener('mouseenter', this.handleEmojiMouseEnter, false);
- emoji.addEventListener('mouseleave', this.handleEmojiMouseLeave, false);
+ emoji.src = emoji.getAttribute('data-original');
}
}
- componentDidMount () {
- this._updateEmojis();
- }
+ handleMouseLeave = ({ currentTarget }) => {
+ if (autoPlayGif) {
+ return;
+ }
- componentDidUpdate () {
- this._updateEmojis();
- }
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
- handleEmojiMouseEnter = ({ target }) => {
- target.src = target.getAttribute('data-original');
- }
-
- handleEmojiMouseLeave = ({ target }) => {
- target.src = target.getAttribute('data-static');
+ for (var i = 0; i < emojis.length; i++) {
+ let emoji = emojis[i];
+ emoji.src = emoji.getAttribute('data-static');
+ }
}
handleClick = () => {
this.props.onToggleHidden(this.props.lastStatus);
}
- setNamesRef = (c) => {
- this.namesNode = c;
- }
-
render () {
const { accounts, lastStatus, unread, scrollKey, intl } = this.props;
{unread && <span className='conversation__unread' />} <RelativeTimestamp timestamp={lastStatus.get('created_at')} />
</div>
- <div className='conversation__content__names' ref={this.setNamesRef}>
+ <div className='conversation__content__names' onMouseEnter={this.handleMouseEnter} onMouseLeave={this.handleMouseLeave}>
<FormattedMessage id='conversation.with' defaultMessage='With {names}' values={{ names: <span>{names}</span> }} />
</div>
</div>
onMute: PropTypes.func.isRequired,
};
- _updateEmojis() {
- const node = this.node;
-
- if (!node || autoPlayGif) {
+ handleMouseEnter = ({ currentTarget }) => {
+ if (autoPlayGif) {
return;
}
- const emojis = node.querySelectorAll('.custom-emoji');
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
for (var i = 0; i < emojis.length; i++) {
let emoji = emojis[i];
- if (emoji.classList.contains('status-emoji')) {
- continue;
- }
- emoji.classList.add('status-emoji');
-
- emoji.addEventListener('mouseenter', this.handleEmojiMouseEnter, false);
- emoji.addEventListener('mouseleave', this.handleEmojiMouseLeave, false);
+ emoji.src = emoji.getAttribute('data-original');
}
}
- componentDidMount() {
- this._updateEmojis();
- }
-
- componentDidUpdate() {
- this._updateEmojis();
- }
+ handleMouseLeave = ({ currentTarget }) => {
+ if (autoPlayGif) {
+ return;
+ }
- handleEmojiMouseEnter = ({ target }) => {
- target.src = target.getAttribute('data-original');
- };
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
- handleEmojiMouseLeave = ({ target }) => {
- target.src = target.getAttribute('data-static');
- };
+ for (var i = 0; i < emojis.length; i++) {
+ let emoji = emojis[i];
+ emoji.src = emoji.getAttribute('data-static');
+ }
+ }
handleFollow = () => {
this.props.onFollow(this.props.account);
this.props.onMute(this.props.account);
};
- setRef = (c) => {
- this.node = c;
- };
-
render() {
const { account, intl } = this.props;
</div>
</div>
- <div className='directory__card__extra' ref={this.setRef}>
+ <div className='directory__card__extra' onMouseEnter={this.handleMouseEnter} onMouseLeave={this.handleMouseLeave}>
<div
className='account__header__content translate'
dangerouslySetInnerHTML={{ __html: account.get('note_emojified') }}
componentDidMount () {
this._updateLinks();
- this._updateEmojis();
}
componentDidUpdate () {
this._updateLinks();
- this._updateEmojis();
- }
-
- _updateEmojis () {
- const node = this.node;
-
- if (!node || autoPlayGif) {
- return;
- }
-
- const emojis = node.querySelectorAll('.custom-emoji');
-
- for (var i = 0; i < emojis.length; i++) {
- let emoji = emojis[i];
-
- if (emoji.classList.contains('status-emoji')) {
- continue;
- }
-
- emoji.classList.add('status-emoji');
-
- emoji.addEventListener('mouseenter', this.handleEmojiMouseEnter, false);
- emoji.addEventListener('mouseleave', this.handleEmojiMouseLeave, false);
- }
}
_updateLinks () {
}
}
- handleEmojiMouseEnter = ({ target }) => {
- target.src = target.getAttribute('data-original');
+ handleMouseEnter = ({ currentTarget }) => {
+ if (autoPlayGif) {
+ return;
+ }
+
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
+
+ for (var i = 0; i < emojis.length; i++) {
+ let emoji = emojis[i];
+ emoji.src = emoji.getAttribute('data-original');
+ }
}
- handleEmojiMouseLeave = ({ target }) => {
- target.src = target.getAttribute('data-static');
+ handleMouseLeave = ({ currentTarget }) => {
+ if (autoPlayGif) {
+ return;
+ }
+
+ const emojis = currentTarget.querySelectorAll('.custom-emoji');
+
+ for (var i = 0; i < emojis.length; i++) {
+ let emoji = emojis[i];
+ emoji.src = emoji.getAttribute('data-static');
+ }
}
render () {
className='announcements__item__content translate'
ref={this.setRef}
dangerouslySetInnerHTML={{ __html: announcement.get('contentHtml') }}
+ onMouseEnter={this.handleMouseEnter}
+ onMouseLeave={this.handleMouseLeave}
/>
);
}