diff options
| author | shpuld <shp@cock.li> | 2019-01-30 19:15:35 +0200 |
|---|---|---|
| committer | shpuld <shp@cock.li> | 2019-01-30 19:24:47 +0200 |
| commit | 15603981f8309d979465c40175f9b3cd4f6617b4 (patch) | |
| tree | eb82d500358c6bbc83410617ccdd4d8b7372755e /src/components/status/status.js | |
| parent | 3cfbf0141f9e5c2c835699c5427d4829da412328 (diff) | |
Capture clicks on statuses to hijack mention clicks, match mention href to user somehow
Diffstat (limited to 'src/components/status/status.js')
| -rw-r--r-- | src/components/status/status.js | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/src/components/status/status.js b/src/components/status/status.js index 558125df..e268ddaa 100644 --- a/src/components/status/status.js +++ b/src/components/status/status.js @@ -9,6 +9,7 @@ import LinkPreview from '../link-preview/link-preview.vue' import { filter, find } from 'lodash' import { highlightClass, highlightStyle } from '../../services/user_highlighter/user_highlighter.js' import generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator' +import { mentionMatchesUrl } from 'src/services/mention_matcher/mention_matcher.js' const Status = { name: 'Status', @@ -237,11 +238,23 @@ const Status = { return 'icon-globe' } }, - linkClicked ({target}) { + linkClicked (event) { + let { target } = event if (target.tagName === 'SPAN') { target = target.parentNode } if (target.tagName === 'A') { + if (target.className.match(/mention/)) { + const href = target.getAttribute('href') + const attn = this.status.attentions.find(attn => mentionMatchesUrl(attn, href)) + if (attn) { + event.stopPropagation() + event.preventDefault() + const link = this.generateUserProfileLink(attn.id, attn.screen_name) + this.$router.push(link) + return + } + } window.open(target.href, '_blank') } }, |
