From 2204157ac04daaa09fe9a15bcac48d9e21c32d9c Mon Sep 17 00:00:00 2001 From: Sami Mazouz Date: Thu, 19 Sep 2024 22:35:20 +0100 Subject: [PATCH] fix(a11y): convert empty links to buttons (#3926) --- extensions/tags/js/src/forum/addTagComposer.js | 8 ++++++-- extensions/tags/less/forum.less | 1 + .../src/forum/components/DiscussionListItem.tsx | 12 +++++++++--- .../core/js/src/forum/components/LogInModal.tsx | 10 ++++++++-- .../core/js/src/forum/components/PostMeta.js | 5 +++-- .../js/src/forum/components/PostStreamScrubber.js | 13 +++++++------ .../core/js/src/forum/components/SignUpModal.tsx | 6 +++++- framework/core/less/common/Button.less | 7 ++++++- framework/core/less/common/mixins.less | 1 + framework/core/less/common/mixins/typography.less | 9 +++++++++ framework/core/less/common/scaffolding.less | 8 +------- framework/core/less/forum/Post.less | 2 +- framework/core/less/forum/Scrubber.less | 15 +++------------ 13 files changed, 60 insertions(+), 37 deletions(-) create mode 100644 framework/core/less/common/mixins/typography.less diff --git a/extensions/tags/js/src/forum/addTagComposer.js b/extensions/tags/js/src/forum/addTagComposer.js index 7cffe7ce1..a55cbdd30 100644 --- a/extensions/tags/js/src/forum/addTagComposer.js +++ b/extensions/tags/js/src/forum/addTagComposer.js @@ -2,6 +2,7 @@ import app from 'flarum/forum/app'; import { extend, override } from 'flarum/common/extend'; import IndexSidebar from 'flarum/forum/components/IndexSidebar'; import classList from 'flarum/common/utils/classList'; +import Button from 'flarum/common/components/Button'; import tagsLabel from '../common/helpers/tagsLabel'; import getSelectableTags from './utils/getSelectableTags'; @@ -47,13 +48,16 @@ export default function addTagComposer() { items.add( 'tags', - + , 10 ); }); diff --git a/extensions/tags/less/forum.less b/extensions/tags/less/forum.less index bca726db6..15798ee4b 100644 --- a/extensions/tags/less/forum.less +++ b/extensions/tags/less/forum.less @@ -32,6 +32,7 @@ } .DiscussionComposer-changeTags { margin-right: 15px; + line-height: inherit; &.disabled { opacity: 0.5; diff --git a/framework/core/js/src/forum/components/DiscussionListItem.tsx b/framework/core/js/src/forum/components/DiscussionListItem.tsx index e71d5597d..d0c04855b 100644 --- a/framework/core/js/src/forum/components/DiscussionListItem.tsx +++ b/framework/core/js/src/forum/components/DiscussionListItem.tsx @@ -153,9 +153,15 @@ export default class DiscussionListItem - - - + {user ? ( + + + + ) : ( + + + + )} , 100 ); diff --git a/framework/core/js/src/forum/components/LogInModal.tsx b/framework/core/js/src/forum/components/LogInModal.tsx index 71747c4f5..00157a4e0 100644 --- a/framework/core/js/src/forum/components/LogInModal.tsx +++ b/framework/core/js/src/forum/components/LogInModal.tsx @@ -123,10 +123,16 @@ export default class LogInModal

- {app.translator.trans('core.forum.log_in.forgot_password_link')} +

{app.forum.attribute('allowSignUp') && ( -

{app.translator.trans('core.forum.log_in.sign_up_text', { a: })}

+

+ {app.translator.trans('core.forum.log_in.sign_up_text', { + a:

{app.translator.trans('core.forum.post.number_tooltip', { number: post.number() })}{' '} diff --git a/framework/core/js/src/forum/components/PostStreamScrubber.js b/framework/core/js/src/forum/components/PostStreamScrubber.js index 6880bc9ab..a16949786 100644 --- a/framework/core/js/src/forum/components/PostStreamScrubber.js +++ b/framework/core/js/src/forum/components/PostStreamScrubber.js @@ -3,6 +3,7 @@ import Component from '../../common/Component'; import formatNumber from '../../common/utils/formatNumber'; import ScrollListener from '../../common/utils/ScrollListener'; import Icon from '../../common/components/Icon'; +import Button from '../../common/components/Button'; /** * The `PostStreamScrubber` component displays a scrubber which can be used to @@ -63,9 +64,9 @@ export default class PostStreamScrubber extends Component {
- - {app.translator.trans('core.forum.post_scrubber.original_post_link')} - +
@@ -83,9 +84,9 @@ export default class PostStreamScrubber extends Component {
- - {app.translator.trans('core.forum.post_scrubber.now_link')} - +
diff --git a/framework/core/js/src/forum/components/SignUpModal.tsx b/framework/core/js/src/forum/components/SignUpModal.tsx index f989e1e15..e34da6bbe 100644 --- a/framework/core/js/src/forum/components/SignUpModal.tsx +++ b/framework/core/js/src/forum/components/SignUpModal.tsx @@ -137,7 +137,11 @@ export default class SignUpModal{app.translator.trans('core.forum.sign_up.log_in_text', { a: })}

, +

+ {app.translator.trans('core.forum.sign_up.log_in_text', { + a: