Ето моето решение за това:
function cost_centres_format($items,$parent_id,$array=array()) {
foreach($items as $item) {
if($item->parent_id == $parent_id) {
$array[] = $item;
if($item->internal_purchase_order_cost_centre_id>0) {
$array = cost_centres_format($items,$item->internal_purchase_order_cost_centre_id,$array);
}
}
}
return $array;
}
$array = cost_centres_format($items,0);
Дизелът (id:5) ще бъде под поддръжката на превозното средство (id:4) поради първоначалната си поръчка. Можете да направите допълнително сортиране по име, но във вашия пример Capital (id:3) беше под Overheads (id:2).