billboard.js
Version:
Re-usable easy interface JavaScript chart library, based on D3 v4+
109 lines (97 loc) • 2.68 kB
text/typescript
/**
* Copyright (c) 2017 ~ present NAVER Corp.
* billboard.js project is licensed under the MIT license
*/
import type {DataRow} from "../../types/types";
import {isString, isValue} from "./util";
/**
* Constant for cache key
* - NOTE: Prefixed with '$', will be resetted when .load() is called
* @private
*/
export const KEY = {
bubbleBaseLength: "$baseLength",
colorPattern: "__colorPattern__",
dataMinMax: "$dataMinMax",
dataTotalSum: "$dataTotalSum",
dataTotalPerIndex: "$totalPerIndex",
legendItemTextBox: "legendItemTextBox",
radarPoints: "$radarPoints",
radarTextWidth: "$radarTextWidth",
setOverOut: "setOverOut",
callOverOutForTouch: "callOverOutForTouch",
textRect: "textRect"
};
export default class Cache {
private cache = {};
/**
* Add cache
* @param {string} key Cache key
* @param {*} value Value to be stored
* @param {boolean} isDataType Weather the cache is data typed '{id:'data', id_org: 'data', values: [{x:0, index:0,...}, ...]}'
* @returns {*} Added data value
* @private
*/
add(key: string, value, isDataType = false) {
this.cache[key] = isDataType ? this.cloneTarget(value) : value;
return this.cache[key];
}
/**
* Remove cache
* @param {string|Array} key Cache key
* @private
*/
remove(key: string | string[]) {
(isString(key) ? [key] : key)
.forEach(v => delete this.cache[v]);
}
/**
* Get cahce
* @param {string|Array} key Cache key
* @param {boolean} isDataType Weather the cache is data typed '{id:'data', id_org: 'data', values: [{x:0, index:0,...}, ...]}'
* @returns {*}
* @private
*/
get(key: string | string[], isDataType = false): any | null {
// when is isDataType, key should be string array
if (isDataType && Array.isArray(key)) {
const targets: any[] = [];
for (let i = 0, id; (id = key[i]); i++) {
if (id in this.cache) {
targets.push(this.cloneTarget(this.cache[id]));
}
}
return targets;
} else {
const value = this.cache[key as string];
return isValue(value) ? value : null;
}
}
/**
* Reset cached data
* @param {boolean} all true: reset all data, false: reset only '$' prefixed key data
* @private
*/
reset(all?: boolean): void {
const $$ = this;
for (const x in $$.cache) {
// reset the prefixed '$' key(which is internal use data) only.
if (all || /^\$/.test(x)) {
$$.cache[x] = null;
}
}
}
/**
* Clone data target object
* @param {object} target Data object
* @returns {object}
* @private
*/
cloneTarget(target: DataRow): DataRow {
return {
id: target.id,
id_org: target.id_org,
values: target.values.map(d => ({x: d.x, value: d.value, id: d.id}))
};
}
}