diff --git a/src/routes/_components/status/Notification.html b/src/routes/_components/status/Notification.html
index c2dd90c..333aaf4 100644
--- a/src/routes/_components/status/Notification.html
+++ b/src/routes/_components/status/Notification.html
@@ -9,9 +9,7 @@
aria-posinset={index}
aria-setsize={length}
aria-label={ariaLabel}
- on:focus="onFocus()"
- on:blur="onBlur()"
- ref:article
+ on:applyFocusStylesToParent="noop()"
>
@@ -48,6 +46,8 @@
import { goto } from '../../../../__sapper__/client'
import { composeNewStatusMentioning } from '../../_actions/mention'
import { classname } from '../../_utils/classname'
+ import { applyFocusStylesToParent } from '../../_utils/events'
+ import noop from 'lodash-es/noop'
export default {
components: {
@@ -80,6 +80,7 @@
))
},
methods: {
+ noop,
openAuthorProfile () {
let { accountId } = this.get()
goto(`/accounts/${accountId}`)
@@ -87,14 +88,10 @@
async mentionAuthor () {
let { account } = this.get()
await composeNewStatusMentioning(account)
- },
- // apply focus styles to parent rather than article because it shows up better
- onFocus () {
- this.refs.article.parentElement.classList.toggle('focus', true)
- },
- onBlur () {
- this.refs.article.parentElement.classList.toggle('focus', false)
}
+ },
+ events: {
+ applyFocusStylesToParent
}
}
diff --git a/src/routes/_components/status/Status.html b/src/routes/_components/status/Status.html
index 442783f..e10aa0d 100644
--- a/src/routes/_components/status/Status.html
+++ b/src/routes/_components/status/Status.html
@@ -5,9 +5,7 @@
aria-setsize={length}
aria-label={ariaLabel}
on:recalculateHeight
- on:focus="onFocus()"
- on:blur="onBlur()"
- ref:article
+ on:applyFocusStylesToParent="noop()"
>
{#if showHeader}
@@ -136,6 +134,8 @@
import { LONG_POST_LENGTH, LONG_POST_TEXT } from '../../_static/statuses'
import { absoluteDateFormatter } from '../../_utils/formatters'
import { composeNewStatusMentioning } from '../../_actions/mention'
+ import { applyFocusStylesToParent } from '../../_utils/events'
+ import noop from 'lodash-es/noop'
const INPUT_TAGS = new Set(['a', 'button', 'input', 'textarea'])
const isUserInputElement = node => INPUT_TAGS.has(node.localName)
@@ -181,6 +181,7 @@
}),
store: () => store,
methods: {
+ noop,
onClickOrKeydown (e) {
let { type, keyCode, target } = e
@@ -214,13 +215,6 @@
async mentionAuthor () {
let { accountForShortcut } = this.get()
await composeNewStatusMentioning(accountForShortcut)
- },
- // apply focus styles to parent rather than article because it shows up better
- onFocus () {
- this.refs.article.parentElement.classList.toggle('focus', true)
- },
- onBlur () {
- this.refs.article.parentElement.classList.toggle('focus', false)
}
},
computed: {
@@ -324,6 +318,9 @@
absoluteFormattedDate,
shortcutScope
})
+ },
+ events: {
+ applyFocusStylesToParent
}
}
diff --git a/src/routes/_utils/events.js b/src/routes/_utils/events.js
index 3188479..1b0839f 100644
--- a/src/routes/_utils/events.js
+++ b/src/routes/_utils/events.js
@@ -49,3 +49,25 @@ export function selectionChange (node, callback) {
}
}
}
+
+// in some cases we apply focus styles to parent rather
+// than the node itself because it shows up better
+export function applyFocusStylesToParent (node) {
+ function onFocus () {
+ node.parentElement.classList.toggle('focus', true)
+ }
+
+ function onBlur () {
+ node.parentElement.classList.toggle('focus', false)
+ }
+
+ node.addEventListener('focus', onFocus)
+ node.addEventListener('blur', onBlur)
+
+ return {
+ destroy () {
+ node.removeEventListener('focus', onFocus)
+ node.removeEventListener('blur', onBlur)
+ }
+ }
+}