UNPKG

@antv/scale

Version:

Toolkit for mapping abstract data into visual representation.

60 lines 2.09 kB
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 = [ [second, 1], [second, 5], [second, 15], [second, 30], [minute, 1], [minute, 5], [minute, 15], [minute, 30], [hour, 1], [hour, 3], [hour, 6], [hour, 12], [day, 1], [day, 2], [week, 1], [month, 1], [month, 3], [year, 1], ]; 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