deno.land / x / billboardjs@3.6.0 / ChartInternal / data / load.ts

نووسراو ببینە
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/** * Copyright (c) 2017 ~ present NAVER Corp. * billboard.js project is licensed under the MIT license */import {$LEGEND} from "../../config/classes";import {endall} from "../../module/util";
export default { load(rawTargets, args): void { const $$ = this; const {append} = args; let targets = rawTargets;
if (targets) { // filter loading targets if needed if (args.filter) { targets = targets.filter(args.filter); }
// set type if args.types || args.type specified if (args.type || args.types) { targets.forEach(t => { const type = args.types?.[t.id] || args.type;
$$.setTargetType(t.id, type); }); }
// Update/Add data $$.data.targets.forEach(d => { for (let i = 0; i < targets.length; i++) { if (d.id === targets[i].id) { d.values = append ? d.values.concat(targets[i].values) : targets[i].values;
targets.splice(i, 1); break; } } });
$$.data.targets = $$.data.targets.concat(targets); // add remained }
// Set targets $$.updateTargets($$.data.targets);
// Redraw with new targets $$.redraw({ withUpdateOrgXDomain: true, withUpdateXDomain: true, withLegend: true });
// Update current state chart type and elements list after redraw $$.updateTypesElements();
args.done?.call($$.api); },
loadFromArgs(args): void { const $$ = this;
// prevent load when chart is already destroyed if (!$$.config) { return; }
// reset internally cached data $$.cache.reset();
$$.convertData(args, d => { const data = args.data || d;
args.append && (data.__append__ = true); data && $$.load($$.convertDataToTargets(data), args); }); },
unload(rawTargetIds, customDoneCb): void { const $$ = this; const {state, $el, $T} = $$; let done = customDoneCb; let targetIds = rawTargetIds;
// reset internally cached data $$.cache.reset();
if (!done) { done = () => {}; }
// filter existing target targetIds = targetIds.filter(id => $$.hasTarget($$.data.targets, id));
// If no target, call done and return if (!targetIds || targetIds.length === 0) { done(); return; }
const targets = $el.svg.selectAll(targetIds.map(id => $$.selectorTarget(id)));
$T(targets) .style("opacity", "0") .remove() .call(endall, done);
targetIds.forEach(id => { // Reset fadein for future load state.withoutFadeIn[id] = false;
// Remove target's elements if ($el.legend) { $el.legend.selectAll(`.${$LEGEND.legendItem}${$$.getTargetSelectorSuffix(id)}`).remove(); }
// Remove target $$.data.targets = $$.data.targets.filter(t => t.id !== id); });
// Update current state chart type and elements list after redraw $$.updateTypesElements(); }};
billboardjs

Version Info

Tagged at
a year ago