Use @superset-ui/number-format and @superset-ui/time-format for formatting. (#6470)

refactor: proxy all d3 number and time formatting calls
This commit is contained in:
Krist Wongsuphasawat
2018-12-04 13:24:07 -08:00
committed by GitHub
parent cc3a625a4b
commit fcec748b62
29 changed files with 162 additions and 346 deletions

View File

@@ -1,9 +1,5 @@
import {
formatSelectOptionsForRange,
d3format,
d3FormatPreset,
d3TimeFormatPreset,
defaultNumberFormatter,
mainMetric,
roundDecimal,
} from '../../../src/modules/utils';
@@ -25,54 +21,6 @@ describe('utils', () => {
});
});
describe('d3format', () => {
it('returns a string formatted number as specified', () => {
expect(d3format('.3s', 1234)).toBe('1.23k');
expect(d3format('.3s', 1237)).toBe('1.24k');
expect(d3format('', 1237)).toBe('1.24k');
expect(d3format('.2efd2.ef.2.e', 1237)).toBe('1237 (Invalid format: .2efd2.ef.2.e)');
});
});
describe('d3FormatPreset', () => {
it('is a function', () => {
expect(typeof d3FormatPreset).toBe('function');
});
it('returns a working formatter', () => {
expect(d3FormatPreset('.3s')(3000000)).toBe('3.00M');
});
});
describe('d3TimeFormatPreset', () => {
it('is a function', () => {
expect(typeof d3TimeFormatPreset).toBe('function');
});
it('returns a working formatter', () => {
expect(d3FormatPreset('smart_date')(0)).toBe('1970');
expect(d3FormatPreset('%%GIBBERISH')(0)).toBe('0 (Invalid format: %%GIBBERISH)');
});
});
describe('defaultNumberFormatter', () => {
expect(defaultNumberFormatter(10)).toBe('10');
expect(defaultNumberFormatter(1)).toBe('1');
expect(defaultNumberFormatter(1.0)).toBe('1');
expect(defaultNumberFormatter(10.0)).toBe('10');
expect(defaultNumberFormatter(10001)).toBe('10.0k');
expect(defaultNumberFormatter(10100)).toBe('10.1k');
expect(defaultNumberFormatter(111000000)).toBe('111M');
expect(defaultNumberFormatter(0.23)).toBe('230m');
expect(defaultNumberFormatter(-10)).toBe('-10');
expect(defaultNumberFormatter(-1)).toBe('-1');
expect(defaultNumberFormatter(-1.0)).toBe('-1');
expect(defaultNumberFormatter(-10.0)).toBe('-10');
expect(defaultNumberFormatter(-10001)).toBe('-10.0k');
expect(defaultNumberFormatter(-10101)).toBe('-10.1k');
expect(defaultNumberFormatter(-111000000)).toBe('-111M');
expect(defaultNumberFormatter(-0.23)).toBe('-230m');
});
describe('mainMetric', () => {
it('is null when no options', () => {
expect(mainMetric([])).toBeUndefined();