-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
91 lines (81 loc) · 2.24 KB
/
index.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
const deepClone = (v) => {
if (v instanceof Object) {
let result;
if (v instanceof Array) {
result = [];
} else {
result = {};
}
for (let key in v) {
if (v.hasOwnProperty(key)) {
result[key] = deepClone(v[key]);
}
}
return result;
} else {
return v;
}
};
/**
* Example problem with existing solution and passing test.
* See problem 0 in the spec file for the assertion
* @returns {string}
*/
exports.example = () => "hello world";
exports.stripPrivateProperties = (properties, objects) => {
objects.forEach((o) => properties.forEach((property) => delete o[property]));
return objects;
};
exports.excludeByProperty = (property, objects) => {
return objects.filter((o) => !o.hasOwnProperty(property));
};
exports.sumDeep = (source) => {
const clonedSource = deepClone(source);
clonedSource.forEach((o) => {
const sum = o.objects.reduce((prev, cur) => cur.val + prev, 0);
o.objects = sum;
});
return clonedSource;
};
exports.applyStatusColor = (rule, sources) => {
let ruleMap = new Map();
Object.keys(rule).forEach((color) => {
const statusArr = rule[color];
statusArr.forEach((status) => {
ruleMap.set(status, color);
});
});
const DefaultColor = "DefaultColor";
const result = sources
.map((o) => {
o.color = ruleMap.get(o.status) || DefaultColor;
return o;
})
.filter((o) => o.color !== DefaultColor);
return result;
};
exports.createGreeting = (greetTemplateFunc, greeting) => {
return (name) => greetTemplateFunc(greeting, name);
};
exports.setDefaults = () => {
return (obj) => Object.assign({ subscribed: true }, obj);
};
exports.fetchUserByNameAndUsersCompany = (name, services) => {
async function fetchUserAndCompany() {
const users = await services.fetchUsers();
const user = users.find((user) => user.name === name);
const company = await services.fetchCompanyById(user.companyId);
return { user, company };
}
return new Promise((resolve) => {
return Promise.all([fetchUserAndCompany(), services.fetchStatus()]).then(
(values) => {
resolve({
user: values[0].user,
company: values[0].company,
status: values[1],
});
}
);
});
};