Skip to content

Commit

Permalink
enhance(MkMention): Acctが長い場合省略して表示する、他 (#209)
Browse files Browse the repository at this point in the history
* enh: Acctが長い場合省略して表示する (fix: Acctが長い場合謎の改行が発生する問題)
* fix: 一部の値がリアクティブでない問題
* fix: 特定の条件下で自分自身を判定できない問題
  • Loading branch information
taiyme authored May 1, 2024
1 parent 5a329a0 commit eab973d
Showing 1 changed file with 50 additions and 20 deletions.
70 changes: 50 additions & 20 deletions packages/frontend/src/components/MkMention.vue
Original file line number Diff line number Diff line change
Expand Up @@ -4,17 +4,23 @@ SPDX-License-Identifier: AGPL-3.0-only
-->

<template>
<MkA v-user-preview="canonical" :class="[$style.root, { [$style.isMe]: isMe }]" :to="url" :style="{ background: bgCss }" :behavior="behavior">
<img :class="$style.icon" :src="avatarUrl" alt="">
<span>
<MkA
v-user-preview="canonicalRef"
:class="[$style.root, { [$style.isMe]: isMeRef }]"
:to="userPageUrlRef"
:style="{ background: bgColorRef }"
:behavior="behavior"
>
<img :class="$style.icon" :src="avatarUrlRef" alt="">
<span :class="$style.acct">
<span>@{{ username }}</span>
<span v-if="(host != localHost) || defaultStore.state.showFullAcct" :class="$style.host">@{{ toUnicode(host) }}</span>
<span v-if="showHostRef" :class="$style.host">@{{ toUnicode(host) }}</span>
</span>
</MkA>
</template>

<script lang="ts" setup>
import { toUnicode } from 'punycode';
import { toASCII, toUnicode } from 'punycode';
import { computed } from 'vue';
import tinycolor from 'tinycolor2';
import { host as localHost } from '@/config.js';
Expand All @@ -29,27 +35,47 @@ const props = defineProps<{
behavior?: MkABehavior;
}>();

const canonical = props.host === localHost ? `@${props.username}` : `@${props.username}@${toUnicode(props.host)}`;
const canonicalRef = computed(() => {
if (toASCII(props.host) === toASCII(localHost)) {
return `@${props.username}`;
}
return `@${props.username}@${toUnicode(props.host)}`;
});

const isMeRef = computed(() => {
if ($i == null) return false;
return canonicalRef.value.toLowerCase() === `@${$i.username}`.toLowerCase();
});

const url = `/${canonical}`;
const showHostRef = computed(() => {
return (toASCII(props.host) !== toASCII(localHost)) || defaultStore.reactiveState.showFullAcct.value;
});

const isMe = $i && (
`@${props.username}@${toUnicode(props.host)}` === `@${$i.username}@${toUnicode(localHost)}`.toLowerCase()
);
const userPageUrlRef = computed(() => {
return `/${canonicalRef.value}`;
});

const bg = tinycolor(getComputedStyle(document.documentElement).getPropertyValue(isMe ? '--mentionMe' : '--mention'));
bg.setAlpha(0.1);
const bgCss = bg.toRgbString();
const avatarUrlRef = computed(() => {
if (defaultStore.state.disableShowingAnimatedImages) {
return getStaticImageUrl(`/avatar/@${props.username}@${toASCII(props.host)}`);
}
return `/avatar/@${props.username}@${toASCII(props.host)}`;
});

const avatarUrl = computed(() => defaultStore.state.disableShowingAnimatedImages
? getStaticImageUrl(`/avatar/@${props.username}@${props.host}`)
: `/avatar/@${props.username}@${props.host}`,
);
const bgColorRef = computed(() => {
const fgColor = window.getComputedStyle(document.documentElement).getPropertyValue(isMeRef.value ? '--mentionMe' : '--mention');
return tinycolor(fgColor).setAlpha(0.1).toRgbString();
});
</script>

<style lang="scss" module>
.root {
display: inline-block;
box-sizing: border-box;
display: inline-flex;
max-width: 100%;
gap: 0.2em;
align-items: center;
vertical-align: middle;
padding: 4px 8px 4px 4px;
border-radius: 999px;
color: var(--mention);
Expand All @@ -63,11 +89,15 @@ const avatarUrl = computed(() => defaultStore.state.disableShowingAnimatedImages
width: 1.5em;
height: 1.5em;
object-fit: cover;
margin: 0 0.2em 0 0;
vertical-align: bottom;
border-radius: 100%;
}

.acct {
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}

.host {
opacity: 0.5;
}
Expand Down

0 comments on commit eab973d

Please sign in to comment.