mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 10:52:45 +08:00
UX: ceil dahsboard values
This commit is contained in:
parent
6862194255
commit
43b1768987
|
@ -100,7 +100,7 @@ export default Ember.Component.extend(AsyncReport, {
|
|||
labels,
|
||||
datasets: reportsForPeriod.map(report => {
|
||||
return {
|
||||
data: Ember.makeArray(report.data).map(d => d.y),
|
||||
data: Ember.makeArray(report.data).map(d => number(d.y, { ceil: true })),
|
||||
backgroundColor: "rgba(200,220,240,0.3)",
|
||||
borderColor: report.color
|
||||
};
|
||||
|
@ -147,7 +147,7 @@ export default Ember.Component.extend(AsyncReport, {
|
|||
scales: {
|
||||
yAxes: [{
|
||||
display: true,
|
||||
ticks: { callback: (label) => number(label) }
|
||||
ticks: { callback: (label) => number(label, { ceil: true }) }
|
||||
}],
|
||||
xAxes: [{
|
||||
display: true,
|
||||
|
|
|
@ -5,18 +5,18 @@
|
|||
<a href="{{report.reportUrl}}">{{report.title}}</a>
|
||||
</td>
|
||||
|
||||
<td class="value">{{number report.todayCount}}</td>
|
||||
<td class="value">{{number report.todayCount ceil=true}}</td>
|
||||
|
||||
<td class="value {{report.yesterdayTrend}}" title={{report.yesterdayCountTitle}}>
|
||||
{{number report.yesterdayCount}} {{d-icon report.yesterdayTrendIcon}}
|
||||
{{number report.yesterdayCount ceil=true}} {{d-icon report.yesterdayTrendIcon}}
|
||||
</td>
|
||||
|
||||
<td class="value {{report.sevenDaysTrend}}" title={{report.sevenDaysCountTitle}}>
|
||||
{{number report.lastSevenDaysCount}} {{d-icon report.sevenDaysTrendIcon}}
|
||||
{{number report.lastSevenDaysCount ceil=true}} {{d-icon report.sevenDaysTrendIcon}}
|
||||
</td>
|
||||
|
||||
<td class="value {{report.thirtyDaysTrend}}" title={{report.thirtyDaysCountTitle}}>
|
||||
{{number report.lastThirtyDaysCount}} {{d-icon report.thirtyDaysTrendIcon}}
|
||||
{{number report.lastThirtyDaysCount ceil=true}} {{d-icon report.thirtyDaysTrendIcon}}
|
||||
</td>
|
||||
|
||||
{{#if allTime}}
|
||||
|
|
|
@ -14,9 +14,9 @@
|
|||
<div class="trend {{report.trend}}">
|
||||
<span class="trend-value" title="{{report.trendTitle}}">
|
||||
{{#if report.average}}
|
||||
{{number report.currentAverage}}{{#if report.percent}}%{{/if}}
|
||||
{{number report.currentAverage ceil=true}}{{#if report.percent}}%{{/if}}
|
||||
{{else}}
|
||||
{{number report.currentTotal noTitle="true"}}{{#if report.percent}}%{{/if}}
|
||||
{{number report.currentTotal ceil=true noTitle="true"}}{{#if report.percent}}%{{/if}}
|
||||
{{/if}}
|
||||
</span>
|
||||
|
||||
|
|
|
@ -8,6 +8,10 @@ registerUnbound('raw-date', dt => longDate(new Date(dt)));
|
|||
registerUnbound('age-with-tooltip', dt => new safe(autoUpdatingRelativeAge(new Date(dt), {title: true})));
|
||||
|
||||
registerUnbound('number', (orig, params) => {
|
||||
if (params.ceil) {
|
||||
orig = Math.ceil(orig);
|
||||
}
|
||||
|
||||
orig = parseInt(orig, 10);
|
||||
if (isNaN(orig)) { orig = 0; }
|
||||
|
||||
|
|
|
@ -301,9 +301,13 @@ export function relativeAge(date, options) {
|
|||
return "UNKNOWN FORMAT";
|
||||
}
|
||||
|
||||
export function number(val) {
|
||||
export function number(val, options = {}) {
|
||||
let formattedNumber;
|
||||
|
||||
if (options.ceil) {
|
||||
val = Math.ceil(val);
|
||||
}
|
||||
|
||||
val = parseInt(val, 10);
|
||||
if (isNaN(val)) val = 0;
|
||||
|
||||
|
|
|
@ -213,6 +213,8 @@ QUnit.test("number", assert => {
|
|||
assert.equal(number(2499999), "2.5M", "it abbreviates millions");
|
||||
assert.equal(number(1000000), "1.0M", "it abbreviates a million");
|
||||
assert.equal(number(999999), "999k", "it abbreviates hundreds of thousands");
|
||||
assert.equal(number(18.2), "18", "it returns a float number converted to an integer as a string");
|
||||
assert.equal(number(18.6, { ceil: true }), "19", "it ceils the value if requested");
|
||||
});
|
||||
|
||||
QUnit.test("durationTiny", assert => {
|
||||
|
|
Loading…
Reference in New Issue
Block a user