UX: expand threads list tap area on mobile (#26818)

This change adds a wrapper link around the thread list details on mobile to make the click area larger.

We also update child div elements to span to ensure valid html, since the link is an inline element and divs are block level.

---------

Co-authored-by: chapoi <101828855+chapoi@users.noreply.github.com>
This commit is contained in:
David Battersby 2024-05-09 12:45:02 +04:00 committed by GitHub
parent efc21dd98b
commit 4404b6808c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
7 changed files with 73 additions and 39 deletions

View File

@ -3,7 +3,7 @@ import ChannelIcon from "discourse/plugins/chat/discourse/components/channel-ico
import ChannelName from "discourse/plugins/chat/discourse/components/channel-name"; import ChannelName from "discourse/plugins/chat/discourse/components/channel-name";
const ChatChannelTitle = <template> const ChatChannelTitle = <template>
<div <span
class={{concatClass class={{concatClass
"chat-channel-title" "chat-channel-title"
(if @channel.isDirectMessageChannel "is-dm" "is-category") (if @channel.isDirectMessageChannel "is-dm" "is-category")
@ -15,7 +15,7 @@ const ChatChannelTitle = <template>
{{#if (has-block)}} {{#if (has-block)}}
{{yield}} {{yield}}
{{/if}} {{/if}}
</div> </span>
</template>; </template>;
export default ChatChannelTitle; export default ChatChannelTitle;

View File

@ -1,11 +1,14 @@
import Component from "@glimmer/component"; import Component from "@glimmer/component";
import { LinkTo } from "@ember/routing"; import { LinkTo } from "@ember/routing";
import { service } from "@ember/service";
import { htmlSafe } from "@ember/template"; import { htmlSafe } from "@ember/template";
import replaceEmoji from "discourse/helpers/replace-emoji"; import replaceEmoji from "discourse/helpers/replace-emoji";
import { escapeExpression } from "discourse/lib/utilities"; import { escapeExpression } from "discourse/lib/utilities";
import ThreadUnreadIndicator from "discourse/plugins/chat/discourse/components/thread-unread-indicator"; import ThreadUnreadIndicator from "discourse/plugins/chat/discourse/components/thread-unread-indicator";
export default class ChatThreadTitle extends Component { export default class ChatThreadTitle extends Component {
@service site;
get title() { get title() {
if (this.args.thread.title) { if (this.args.thread.title) {
return replaceEmoji(htmlSafe(escapeExpression(this.args.thread.title))); return replaceEmoji(htmlSafe(escapeExpression(this.args.thread.title)));
@ -15,8 +18,9 @@ export default class ChatThreadTitle extends Component {
} }
<template> <template>
<div class="chat__thread-title-container"> <span class="chat__thread-title-container">
<div class="chat__thread-title"> <span class="chat__thread-title">
{{#if this.site.desktopView}}
<LinkTo <LinkTo
class="chat__thread-title__name" class="chat__thread-title__name"
@route="chat.channel.thread" @route="chat.channel.thread"
@ -24,9 +28,14 @@ export default class ChatThreadTitle extends Component {
> >
{{this.title}} {{this.title}}
</LinkTo> </LinkTo>
{{else}}
<span class="chat__thread-title__name">
{{this.title}}
</span>
{{/if}}
</span>
<ThreadUnreadIndicator @thread={{@thread}} /> <ThreadUnreadIndicator @thread={{@thread}} />
</div> </span>
</div>
</template> </template>
} }

View File

@ -15,11 +15,11 @@ export default class ChatThreadUnreadIndicator extends Component {
<template> <template>
{{#if this.showUnreadIndicator}} {{#if this.showUnreadIndicator}}
<div class="chat-thread-list-item-unread-indicator"> <span class="chat-thread-list-item-unread-indicator">
<div class="chat-thread-list-item-unread-indicator__number"> <span class="chat-thread-list-item-unread-indicator__number">
{{this.unreadCountLabel}} {{this.unreadCountLabel}}
</div> </span>
</div> </span>
{{/if}} {{/if}}
</template> </template>
} }

View File

@ -1,5 +1,6 @@
import Component from "@glimmer/component"; import Component from "@glimmer/component";
import { cached } from "@glimmer/tracking"; import { cached } from "@glimmer/tracking";
import { LinkTo } from "@ember/routing";
import { service } from "@ember/service"; import { service } from "@ember/service";
import i18n from "discourse-common/helpers/i18n"; import i18n from "discourse-common/helpers/i18n";
import { bind } from "discourse-common/utils/decorators"; import { bind } from "discourse-common/utils/decorators";
@ -97,12 +98,21 @@ export default class UserThreads extends Component {
<ChannelIcon @thread={{thread}} /> <ChannelIcon @thread={{thread}} />
{{/if}} {{/if}}
{{#if this.site.mobileView}}
<LinkTo
class="c-user-thread__link"
@route="chat.channel.thread"
@models={{thread.routeModels}}
>
<ChannelTitle @channel={{thread.channel}} /> <ChannelTitle @channel={{thread.channel}} />
<ThreadTitle @thread={{thread}} /> <ThreadTitle @thread={{thread}} />
{{#if this.site.mobileView}}
<ThreadPreview @preview={{thread.preview}} /> <ThreadPreview @preview={{thread.preview}} />
</LinkTo>
{{else}} {{else}}
<ChannelTitle @channel={{thread.channel}} />
<ThreadTitle @thread={{thread}} />
<ThreadIndicator <ThreadIndicator
@message={{thread.originalMessage}} @message={{thread.originalMessage}}
@interactiveUser={{false}} @interactiveUser={{false}}

View File

@ -10,14 +10,14 @@ export default class ThreadPreview extends Component {
<span class="chat-message-thread-indicator__last-reply-timestamp"> <span class="chat-message-thread-indicator__last-reply-timestamp">
{{this.lastReplyDate}} {{this.lastReplyDate}}
</span> </span>
<div class="c-user-thread__excerpt"> <span class="c-user-thread__excerpt">
<div class="c-user-thread__excerpt-poster"> <span class="c-user-thread__excerpt-poster">
{{@preview.lastReplyUser.username}} {{@preview.lastReplyUser.username}}
</div> </span>
<span>:</span> <span>:</span>
<span class="c-user-thread__excerpt-text"> <span class="c-user-thread__excerpt-text">
{{@preview.lastReplyExcerpt}} {{@preview.lastReplyExcerpt}}
</span> </span>
</div> </span>
</template> </template>
} }

View File

@ -17,7 +17,13 @@
} }
} }
.chat__thread-title__name { .chat__thread-title {
&-container {
display: flex;
gap: 1rem;
}
&__name {
font-size: var(--font-up-1-rem); font-size: var(--font-up-1-rem);
word-break: break-all; word-break: break-all;
@ -25,6 +31,7 @@
color: var(--primary-very-high); color: var(--primary-very-high);
} }
} }
}
.chat-channel-icon { .chat-channel-icon {
font-size: var(--font-down-1-rem); font-size: var(--font-down-1-rem);

View File

@ -1,11 +1,6 @@
.c-user-thread { .c-user-thread {
display: grid; display: flex;
grid-template-areas: gap: 1rem;
"avatar category timestamp"
"avatar title indicator"
"avatar excerpt excerpt";
grid-template-columns: auto 1fr auto;
grid-column-gap: 0.75em;
margin-inline: 0; margin-inline: 0;
padding: 0.5rem 1.5rem; padding: 0.5rem 1.5rem;
@ -20,6 +15,18 @@
} }
} }
.c-user-thread__link {
display: grid;
grid-column-gap: 0.75em;
grid-template-columns: 1fr auto;
margin-inline: 0;
width: 100%;
grid-template-areas:
"category timestamp"
"title title"
"excerpt excerpt";
}
.avatar-flair.--threads { .avatar-flair.--threads {
position: absolute; position: absolute;
top: -4px; top: -4px;
@ -33,9 +40,10 @@
} }
.chat__thread-title-container { .chat__thread-title-container {
@include ellipsis; display: flex;
grid-area: title; grid-area: title;
.chat__thread-title { .chat__thread-title {
@include ellipsis;
&__name { &__name {
@include ellipsis; @include ellipsis;
} }