handleClick: PropTypes.func,
};
- _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={computedClass} ref={this.setRef}>
+ <span className={computedClass} onMouseEnter={this.handleMouseEnter} onMouseLeave={this.handleMouseLeave}>
{displayName}
{inline ? ' ' : null}
{suffix}
}
}
- _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();
if (this.props.onUpdate) this.props.onUpdate();
}
}
}
- handleEmojiMouseEnter = ({ target }) => {
- target.src = target.getAttribute('data-original');
- }
-
- handleEmojiMouseLeave = ({ target }) => {
- target.src = target.getAttribute('data-static');
- }
-
handleMouseDown = (e) => {
this.startXY = [e.clientX, e.clientY];
}
}
}
- setRef = (c) => {
- this.node = c;
- }
-
setContentsRef = (c) => {
this.contentsNode = c;
}
}
return (
- <div className={classNames} tabIndex='0' onMouseDown={this.handleMouseDown} onMouseUp={this.handleMouseUp} ref={this.setRef}>
+ <div className={classNames} tabIndex='0' onMouseDown={this.handleMouseDown} onMouseUp={this.handleMouseUp}>
<p
style={{ marginBottom: hidden && status.get('mentions').isEmpty() ? '0px' : null }}
>
tabIndex={!hidden ? 0 : null}
dangerouslySetInnerHTML={content}
className='status__content__text translate'
+ onMouseEnter={this.handleMouseEnter}
+ onMouseLeave={this.handleMouseLeave}
/>
{media}
</div>
onMouseDown={this.handleMouseDown}
onMouseUp={this.handleMouseUp}
tabIndex='0'
- ref={this.setRef}
>
<div
ref={this.setContentsRef}
dangerouslySetInnerHTML={content}
className='status__content__text translate'
tabIndex='0'
+ onMouseEnter={this.handleMouseEnter}
+ onMouseLeave={this.handleMouseLeave}
/>
{media}
</div>
<div
className='status__content'
tabIndex='0'
- ref={this.setRef}
>
- <div ref={this.setContentsRef} key={`contents-${tagLinks}`} className='status__content__text translate' dangerouslySetInnerHTML={content} tabIndex='0' />
+ <div
+ ref={this.setContentsRef}
+ key={`contents-${tagLinks}`}
+ className='status__content__text translate'
+ dangerouslySetInnerHTML={content}
+ tabIndex='0'
+ onMouseEnter={this.handleMouseEnter}
+ onMouseLeave={this.handleMouseLeave}
+ />
{media}
</div>
);
window.open(profileLink, '_blank');
}
- _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'>
{info}
}
}
- _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();
- }
-
- 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');
+ }
}
handleClick = () => {
this.setState({ isExpanded: value });
}
- setNamesRef = (c) => {
- this.namesNode = c;
- }
-
render () {
const { accounts, lastStatus, unread, scrollKey, intl } = this.props;
const { isExpanded } = this.state;
{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}
/>
);
}