У меня есть массив категорий, например:
0: {_id: 1, image: "/static/categories/apartment.png", name: "apartments", properties: Array(2), rootCategoryId: null, …}
1: {_id: 2, image: "/static/categories/car.png", name: "cars", properties: Array(1), rootCategoryId: null, …}
2: {_id: 3, image: "/static/categories/dress.png", name: "cloathes", properties: Array(1), rootCategoryId: null, …}
3: {_id: 4, image: "/static/categories/fridge.png", name: "electronicsAndGadgets", properties: Array(1), rootCategoryId: null, …}
4: {_id: 99, image: "/static/categories/phone.png", name: "smartPhones", properties: Array(0), rootCategoryId: 4, …}
5: {_id: 100, image: "/static/categories/shoes.png", name: "shoes", properties: Array(0), rootCategoryId: 3, …}
6: {_id: 1000, image: null, name: "sneakers", properties: Array(0), rootCategoryId: 100, …}
7: {_id: 1001, image: null, name: "sandals", properties: Array(0), rootCategoryId: 100, …}
Другими словами.
Root category (image: '../png', rootCategoryId: null)
Sub categories (image: '../png' OR null, rootCategoryId: ID)
1 (root) -> 100 (sub1) -> 1000 (sub2)
Поскольку root всегда имеет изображение, а иногда подкатегории не имеют изображения,Я пытаюсь сделать обратный поиск, пока не найду картинку. Создал эту функцию, чтобы получить связанные категории, но я думаю, что это можно сделать лучше:
export const getCategoryImageByByCategoryId = id => {
if (!store) return null;
const getCategory = (id) => _.find(categoriesList, category => category._id === id);
const state = store.getState();
const categoriesList = state.categories.categoriestList;
let currentCategory = getCategory(id);
const result = [currentCategory];
while (currentCategory !== null) {
const nextId = currentCategory.rootCategoryId;
if (!nextId) {
currentCategory = null;
} else {
currentCategory = getCategory(nextId);
result.push(currentCategory);
}
}
return result;
};
Каков наилучший способ сделать это? Следует использовать уменьшить FN?