@antv/scale
Version:
Toolkit for mapping abstract data into visual representation.
60 lines • 2.09 kB
JavaScript
import { localIntervalMap } from './time-interval';
import { utcIntervalMap } from './utc-interval';
import { bisect } from './bisect';
import { tickStep } from './ticks';
function chooseTickIntervals(utc) {
const intervalMap = utc ? utcIntervalMap : localIntervalMap;
const { year, month, week, day, hour, minute, second, millisecond } = intervalMap;
const tickIntervals = [
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
[ ],
];
return {
tickIntervals,
year,
millisecond,
};
}
export function findTickInterval(start, stop, count, interval, utc) {
const lo = +start;
const hi = +stop;
const { tickIntervals, year, millisecond } = chooseTickIntervals(utc);
const getter = ([interval, count]) => interval.duration * count;
const targetCount = interval ? (hi - lo) / interval : count || 5;
const targetInterval = interval || (hi - lo) / targetCount;
const len = tickIntervals.length;
const i = bisect(tickIntervals, targetInterval, 0, len, getter);
let matchInterval;
if (i === len) {
const step = tickStep(lo / year.duration, hi / year.duration, targetCount);
matchInterval = [year, step];
}
else if (i) {
const closeToLow = targetInterval / getter(tickIntervals[i - 1]) < getter(tickIntervals[i]) / targetInterval;
const [timeInterval, targetStep] = closeToLow ? tickIntervals[i - 1] : tickIntervals[i];
const step = interval ? Math.ceil(interval / timeInterval.duration) : targetStep;
matchInterval = [timeInterval, step];
}
else {
const step = Math.max(tickStep(lo, hi, targetCount), 1);
matchInterval = [millisecond, step];
}
return matchInterval;
}
//# sourceMappingURL=find-tick-interval.js.map