DEV: optionally removes links/avatars from user-info (#16388)

Usage:

```
{{user-info user=user includeLink=false includeAvatar=false}}
```

This is useful when using user-info in a dropdown list for example.
This commit is contained in:
Joffrey JAFFEUX 2022-04-06 14:07:38 +02:00 committed by GitHub
parent 254f48e568
commit 8f03baaf8e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 66 additions and 7 deletions

View File

@ -13,6 +13,8 @@ export default Component.extend({
attributeBindings: ["data-username"], attributeBindings: ["data-username"],
size: "small", size: "small",
"data-username": alias("user.username"), "data-username": alias("user.username"),
includeLink: true,
includeAvatar: true,
@discourseComputed("user.username") @discourseComputed("user.username")
userPath(username) { userPath(username) {

View File

@ -1,14 +1,32 @@
{{#if includeAvatar}}
<div class="user-image"> <div class="user-image">
<div class="user-image-inner"> <div class="user-image-inner">
<a href={{this.userPath}} data-user-card={{@user.username}}>{{avatar @user imageSize="large"}}</a> <a href={{this.userPath}} data-user-card={{@user.username}}>{{avatar @user imageSize="large"}}</a>
{{user-avatar-flair user=@user}} {{user-avatar-flair user=@user}}
</div> </div>
</div> </div>
{{/if}}
<div class="user-detail"> <div class="user-detail">
<div class="name-line"> <div class="name-line">
<span class={{if nameFirst "name bold" "username bold"}}><a href={{this.userPath}} data-user-card={{@user.username}}>{{if nameFirst this.name (format-username @user.username)}}</a></span> <span class={{if nameFirst "name bold" "username bold"}}>
<span class={{if nameFirst "username margin" "name margin"}}><a href={{this.userPath}} data-user-card={{@user.username}}>{{if nameFirst (format-username @user.username) this.name}}</a></span> {{#if includeLink}}
<a href={{this.userPath}} data-user-card={{@user.username}}>
{{if nameFirst this.name (format-username @user.username)}}
</a>
{{else}}
{{if nameFirst this.name (format-username @user.username)}}
{{/if}}
</span>
<span class={{if nameFirst "username margin" "name margin"}}>
{{#if includeLink}}
<a href={{this.userPath}} data-user-card={{@user.username}}>
{{if nameFirst (format-username @user.username) this.name}}
</a>
{{else}}
{{if nameFirst (format-username @user.username) this.name}}
{{/if}}
</span>
{{plugin-outlet name="after-user-name" tagName="span" connectorTagName="span" args=(hash user=user)}} {{plugin-outlet name="after-user-name" tagName="span" connectorTagName="span" args=(hash user=user)}}
</div> </div>
<div class="title">{{@user.title}}</div> <div class="title">{{@user.title}}</div>

View File

@ -0,0 +1,39 @@
import componentTest, {
setupRenderingTest,
} from "discourse/tests/helpers/component-test";
import hbs from "htmlbars-inline-precompile";
import { discourseModule, exists } from "discourse/tests/helpers/qunit-helpers";
discourseModule("Integration | Component | user-info", function (hooks) {
setupRenderingTest(hooks);
componentTest("includeLink", {
template: hbs`{{user-info user=currentUser includeLink=includeLink}}`,
async test(assert) {
this.set("includeLink", true);
assert.ok(exists(`.username a[href="/u/${this.currentUser.username}"]`));
this.set("includeLink", false);
assert.notOk(
exists(`.username a[href="/u/${this.currentUser.username}"]`)
);
},
});
componentTest("includeAvatar", {
template: hbs`{{user-info user=currentUser includeAvatar=includeAvatar}}`,
async test(assert) {
this.set("includeAvatar", true);
assert.ok(exists(".user-image"));
this.set("includeAvatar", false);
assert.notOk(exists(".user-image"));
},
});
});