Skip to main content
Module

x/billboardjs/module/generator.ts

πŸ“Š Re-usable, easy interface JavaScript chart library based on D3.js
Go to Latest
File
/** * Copyright (c) 2017 ~ present NAVER Corp. * billboard.js project is licensed under the MIT license */import {window} from "./browser";import {isArray} from "./util";
const {setTimeout, clearTimeout} = window;
/** * Generate resize queue function * @returns {Fucntion} * @private */export function generateResize() { const fn: any[] = []; let timeout;
const callResizeFn = function() { // Delay all resize functions call, to prevent unintended excessive call from resize event callResizeFn.clear();
timeout = setTimeout(() => { fn.forEach((f: Function) => f()); }, 200); };
callResizeFn.clear = () => { if (timeout) { clearTimeout(timeout); timeout = null; } };
callResizeFn.add = f => fn.push(f); callResizeFn.remove = f => fn.splice(fn.indexOf(f), 1);
return callResizeFn;}
/** * Generate transition queue function * @returns {Function} * @private */export function generateWait() { let transitionsToWait: any = []; const f = function(t, callback) { let timer;
// eslint-disable-next-line function loop() { let done = 0;
for (let i = 0, t; (t = transitionsToWait[i]); i++) { if (t === true || (t.empty && t.empty())) { done++; continue; }
try { t.transition(); } catch (e) { done++; } }
timer && clearTimeout(timer);
if (done === transitionsToWait.length) { callback && callback(); } else { timer = setTimeout(loop, 50); } }
loop(); };
f.add = function(t) { isArray(t) ? (transitionsToWait = transitionsToWait.concat(t)) : transitionsToWait.push(t); };
return f;}