-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcreateDevDropdown.js
96 lines (84 loc) · 2.71 KB
/
createDevDropdown.js
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
import { composeGraphData } from './dataForGraphs.js';
import { renderChart } from './renderChart.js';
import { getDataAndLoadSelect2 } from "./getDataAndLoadSelect2.js";
export function createDevDropdown() {
const urlParams = new URLSearchParams(window.location.search);
const isDev = urlParams.has("dev");
if (isDev) {
// Create a new select element
const select = document.createElement("select");
select.id = "devData";
select.style.width = "270px";
const option = document.createElement("option");
option.value = "";
option.text = "developer shortcuts";
select.appendChild(option);
// Append the select element to the header
const header = document.querySelector("header");
header.appendChild(select);
_createDevDropdown();
}
}
function _createDevDropdown() {
const data = [
["846229100080", ["2021", "2022"]],
["846222900080", ["2022" ]],
["846229000080", ["2023" ]],
["846261100080", ["2022" ]],
["190190990080", ["2022", "2020"]],
["32502180", ["2019"]],
["32502181", ["2021", "2024"]],
["21201380", ["2021"]],
["854370900080", ["2018", "2022"]],
["382499920080", ["2018", "2022"]],
["760612200080", ["2019", "2021"]],
["760612920080", ["2019", "2022"]],
["190190990080", ["2020", "2022"]],
["392690970080", ["2020", "2021"]],
];
const devData = data.flatMap(([conceptId, years]) => {
const category = /^\d{8}$/.test(conceptId) ? "prodcom" : "cn";
const code =
category === "cn"
? conceptId.slice(0, 4) +
" " +
conceptId.slice(4, 6) +
" " +
conceptId.slice(6, 8)
: conceptId.slice(0, 2) +
"." +
conceptId.slice(2, 4) +
"." +
conceptId.slice(4, 6) +
"." +
conceptId.slice(6, 8);
return years.map(year => {
return {
id: conceptId,
text: `${code} (${category} ${year})`,
data: {
id: conceptId,
year: year,
code: code
}
};
});
});
$("#devData").select2({
placeholder: "Select an option",
allowClear: true,
data: devData,
}).on("select2:select", async function (e) {
$("#visualization").empty();
$("#errorContainer").empty();
const conceptId = e.params.data.data.id;
const family = /^\d{8}$/.test(conceptId) ? "prodcom" : "cn";
getDataAndLoadSelect2("families", family);
// Wait for getDataAndLoadSelect2 to finish, then wait an additional second
await new Promise(resolve => setTimeout(resolve, 1000));
const conceptLabel = e.params.data.data.code;
const year = e.params.data.data.year;
const graphData = await composeGraphData("concepts", family, (+year), conceptId, conceptLabel);
renderChart(graphData);
});
}