mirror of
https://github.com/discourse/discourse.git
synced 2025-01-16 03:32:40 +08:00
DEV: Convert UserFlagPercentage to gjs (#30453)
This commit is contained in:
parent
145c7e46e1
commit
d8e8c9f1e4
|
@ -0,0 +1,64 @@
|
|||
import Component from "@glimmer/component";
|
||||
import { cached } from "@glimmer/tracking";
|
||||
import { gte } from "truth-helpers";
|
||||
import icon from "discourse-common/helpers/d-icon";
|
||||
import { i18n } from "discourse-i18n";
|
||||
|
||||
export default class UserFlagPercentage extends Component {
|
||||
// We do a little logic to choose which icon to display and which text
|
||||
@cached
|
||||
get percentage() {
|
||||
const { agreed, disagreed, ignored } = this.args;
|
||||
const total = agreed + disagreed + ignored;
|
||||
const result = { total };
|
||||
|
||||
if (total <= 0) {
|
||||
return result;
|
||||
}
|
||||
|
||||
const roundedAgreed = Math.round((agreed / total) * 100);
|
||||
const roundedDisagreed = Math.round((disagreed / total) * 100);
|
||||
const roundedIgnored = Math.round((ignored / total) * 100);
|
||||
|
||||
const highest = Math.max(agreed, disagreed, ignored);
|
||||
if (highest === agreed) {
|
||||
result.icon = "thumbs-up";
|
||||
result.className = "agreed";
|
||||
result.label = `${roundedAgreed}%`;
|
||||
} else if (highest === disagreed) {
|
||||
result.icon = "thumbs-down";
|
||||
result.className = "disagreed";
|
||||
result.label = `${roundedDisagreed}%`;
|
||||
} else {
|
||||
result.icon = "up-right-from-square";
|
||||
result.className = "ignored";
|
||||
result.label = `${roundedIgnored}%`;
|
||||
}
|
||||
|
||||
result.title = i18n("review.user_percentage.summary", {
|
||||
agreed: i18n("review.user_percentage.agreed", {
|
||||
count: roundedAgreed,
|
||||
}),
|
||||
disagreed: i18n("review.user_percentage.disagreed", {
|
||||
count: roundedDisagreed,
|
||||
}),
|
||||
ignored: i18n("review.user_percentage.ignored", {
|
||||
count: roundedIgnored,
|
||||
}),
|
||||
count: total,
|
||||
});
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
<template>
|
||||
{{#if (gte this.percentage.total 3)}}
|
||||
<div title={{this.percentage.title}} class="user-flag-percentage">
|
||||
<span
|
||||
class="percentage-label {{this.percentage.className}}"
|
||||
>{{this.percentage.label}}</span>
|
||||
{{icon this.percentage.icon}}
|
||||
</div>
|
||||
{{/if}}
|
||||
</template>
|
||||
}
|
|
@ -1,8 +0,0 @@
|
|||
{{#if this.showPercentage}}
|
||||
<div title={{this.percentage.title}} class="user-flag-percentage">
|
||||
<span
|
||||
class="percentage-label {{this.percentage.className}}"
|
||||
>{{this.percentage.label}}</span>
|
||||
{{d-icon this.percentage.icon}}
|
||||
</div>
|
||||
{{/if}}
|
|
@ -1,55 +0,0 @@
|
|||
import Component from "@ember/component";
|
||||
import { tagName } from "@ember-decorators/component";
|
||||
import discourseComputed from "discourse-common/utils/decorators";
|
||||
import { i18n } from "discourse-i18n";
|
||||
|
||||
@tagName("")
|
||||
export default class UserFlagPercentage extends Component {
|
||||
@discourseComputed("percentage")
|
||||
showPercentage(percentage) {
|
||||
return percentage.total >= 3;
|
||||
}
|
||||
|
||||
// We do a little logic to choose which icon to display and which text
|
||||
@discourseComputed("agreed", "disagreed", "ignored")
|
||||
percentage(agreed, disagreed, ignored) {
|
||||
let total = agreed + disagreed + ignored;
|
||||
let result = { total };
|
||||
|
||||
if (total > 0) {
|
||||
result.agreed = Math.round((agreed / total) * 100);
|
||||
result.disagreed = Math.round((disagreed / total) * 100);
|
||||
result.ignored = Math.round((ignored / total) * 100);
|
||||
}
|
||||
|
||||
let highest = Math.max(agreed, disagreed, ignored);
|
||||
if (highest === agreed) {
|
||||
result.icon = "thumbs-up";
|
||||
result.className = "agreed";
|
||||
result.label = `${result.agreed}%`;
|
||||
} else if (highest === disagreed) {
|
||||
result.icon = "thumbs-down";
|
||||
result.className = "disagreed";
|
||||
result.label = `${result.disagreed}%`;
|
||||
} else {
|
||||
result.icon = "up-right-from-square";
|
||||
result.className = "ignored";
|
||||
result.label = `${result.ignored}%`;
|
||||
}
|
||||
|
||||
result.title = i18n("review.user_percentage.summary", {
|
||||
agreed: i18n("review.user_percentage.agreed", {
|
||||
count: result.agreed,
|
||||
}),
|
||||
disagreed: i18n("review.user_percentage.disagreed", {
|
||||
count: result.disagreed,
|
||||
}),
|
||||
ignored: i18n("review.user_percentage.ignored", {
|
||||
count: result.ignored,
|
||||
}),
|
||||
count: total,
|
||||
});
|
||||
|
||||
return result;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user