Commit d2a09844 authored by Bryce Johnson's avatar Bryce Johnson

Condense time for display in stringifyTime.

parent 79fd521b
...@@ -101,9 +101,11 @@ ...@@ -101,9 +101,11 @@
this.displayHelp = show; this.displayHelp = show;
}, },
stringifyTime(obj) { stringifyTime(obj) {
return _.reduce(obj, (memo, val, key) => { const reducedTime = _.reduce(obj, (memo, unitValue, unitName) => {
return memo + `${val}${key.charAt(0)} `; const isNonZero = !!unitValue;
return isNonZero ? (memo + `${unitValue}${unitName.charAt(0)} `) : memo;
}, '').trim(); }, '').trim();
return reducedTime.length ? reducedTime : '0m';
}, },
}, },
template: ` template: `
......
...@@ -57,14 +57,14 @@ function initComponent(time_estimate = 100000, time_spent = 5000 ) { ...@@ -57,14 +57,14 @@ function initComponent(time_estimate = 100000, time_spent = 5000 ) {
it('should display the human readable version of time estimated', function() { it('should display the human readable version of time estimated', function() {
const estimateText = this.timeTracker.$el.querySelector('.time-tracking-pane-compare .estimated .compare-value').innerText; const estimateText = this.timeTracker.$el.querySelector('.time-tracking-pane-compare .estimated .compare-value').innerText;
const correctText = '0w 3d 3h 46m'; const correctText = '3d 3h 46m';
expect(estimateText).toBe(correctText); expect(estimateText).toBe(correctText);
}); });
it('should display the human readable version of time spent', function() { it('should display the human readable version of time spent', function() {
const spentText = this.timeTracker.$el.querySelector('.time-tracking-pane-compare .compare-value.spent').innerText; const spentText = this.timeTracker.$el.querySelector('.time-tracking-pane-compare .compare-value.spent').innerText;
const correctText = '0w 0d 1h 23m'; const correctText = '1h 23m';
expect(spentText).toBe(correctText); expect(spentText).toBe(correctText);
}); });
...@@ -107,7 +107,7 @@ function initComponent(time_estimate = 100000, time_spent = 5000 ) { ...@@ -107,7 +107,7 @@ function initComponent(time_estimate = 100000, time_spent = 5000 ) {
it('should display the human readable version of time estimated', function() { it('should display the human readable version of time estimated', function() {
const estimateText = this.timeTracker.$el.querySelector('.time-tracking-estimate-only').innerText; const estimateText = this.timeTracker.$el.querySelector('.time-tracking-estimate-only').innerText;
const correctText = 'Estimated: 0w 0d 2h 46m'; const correctText = 'Estimated: 2h 46m';
expect(estimateText).toBe(correctText); expect(estimateText).toBe(correctText);
}); });
...@@ -127,7 +127,7 @@ function initComponent(time_estimate = 100000, time_spent = 5000 ) { ...@@ -127,7 +127,7 @@ function initComponent(time_estimate = 100000, time_spent = 5000 ) {
it('should display the human readable version of time spent', function() { it('should display the human readable version of time spent', function() {
const spentText = this.timeTracker.$el.querySelector('.time-tracking-spend-only').innerText; const spentText = this.timeTracker.$el.querySelector('.time-tracking-spend-only').innerText;
const correctText = 'Spent: 0w 0d 1h 23m'; const correctText = 'Spent: 1h 23m';
expect(spentText).toBe(correctText); expect(spentText).toBe(correctText);
}); });
...@@ -323,7 +323,7 @@ function initComponent(time_estimate = 100000, time_spent = 5000 ) { ...@@ -323,7 +323,7 @@ function initComponent(time_estimate = 100000, time_spent = 5000 ) {
const timeString = this.timeTracker.stringifyTime(timeObject); const timeString = this.timeTracker.stringifyTime(timeObject);
expect(timeString).toBe('0w 4d 0h 20m'); expect(timeString).toBe('4d 20m');
}); });
it('should stringify values with no non-zero units', function() { it('should stringify values with no non-zero units', function() {
...@@ -336,7 +336,7 @@ function initComponent(time_estimate = 100000, time_spent = 5000 ) { ...@@ -336,7 +336,7 @@ function initComponent(time_estimate = 100000, time_spent = 5000 ) {
const timeString = this.timeTracker.stringifyTime(timeObject); const timeString = this.timeTracker.stringifyTime(timeObject);
expect(timeString).toBe('0w 0d 0h 0m'); expect(timeString).toBe('0m');
}); });
}); });
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment