-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
59 lines (51 loc) · 1.92 KB
/
app.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
// map structure to link DOM item to dataset column
const mapDomColumns = [
{ id: 'title', key: 'city', column: 'city' },
{ id: 'title', key: 'zip', column: 'zip' },
{ id: 'homes-listed', key: 'num_homes_listed', column: 'num_homes_listed' },
{ id: 'avg-dom', key: 'avg_dom', column: 'avg_dom' },
{ id: 'median-list-price', key: 'median_list_price', column: 'median_list_price', price: true },
{ id: 'price-change', key: 'price_change_pct', column: 'price_change_pct' },
{ id: 'market-type', key: 'market_type', column: 'market_type', market_type: true },
];
// function to fetch the dataset
const fetchData = async () => domo.get('/data/v2/infographicData?limit=100&useBeastMode=true');
// formatting price number
const formatPrice = (price) => {
return isNaN(Number(price)) ? price : new Intl.NumberFormat('en-US', {
minimumFractionDigits: 0,
maximumFractionDigits: 0,
}).format(Number(price));
}
const formatMarketType = (marketType) => {
console.log("formatting market type");
if (Number(marketType) >= 30) {
return `${marketType} (Seller's Market)`
} else {
return `${marketType} (Buyers's Market)`
}
}
// function to interpolate the data into the HTML template
const interpolateData = (data) => {
const row = data[0];
console.log("interpolating data");
console.log(row);
mapDomColumns.forEach(value => {
let columnValue = "";
const defaultValue = document.getElementById(value.id).innerHTML.toString();
if (value.price) {
columnValue = formatPrice(row[value.column]);
} else if (value.market_type) {
columnValue = formatMarketType(row[value.column]);
} else {
columnValue = row[value.column];
}
const newValue = defaultValue.replaceAll(`{${value.key}}`, columnValue);
document.getElementById(value.id).innerHTML = newValue;
});
}
const init = async () => {
const data = await fetchData();
console.log("data: ", data);
interpolateData(data);
}