У меня есть следующая функция, которая перебирает серию объектов для создания многомерного массива, возвращающего JSON:
public function calcularIndicadorBenchmark(int $idIndicador): array
{
$indicador = $this->buscarPorId($idIndicador);
$configGrupoBase = $this->entityManager->getRepository(ConfigGrupoBase::class)->findByIndicador($idIndicador);
$configGrupo = $this->entityManager->getRepository(ConfigGrupo::class)->findByConfigBase(end($configGrupoBase)->getId());
foreach ($configGrupo as $c) {
$arrayGrupos[] = [
'id' => $c->getId(),
'nome' => $c->getNome(),
'agrupamentos' => null
];
$configGrupoAtributo = $this->entityManager->getRepository(ConfigGrupoAtributo::class)->findByConfigGrupo($c->getId());
$agrupamento = $this->entityManager->getRepository(Agrupamento::class)->findByAtributo(end($configGrupoAtributo)->getId());
foreach ($agrupamento as $a) {
$arrayAgrupamentos[] = [
'id' => $a->getId(),
'nome' => $a->getNome(),
'periodos' => null
];
}
$arrayGrupos[] = $arrayAgrupamentos;
}
$json['indicador'] = [
'id' => $indicador->getId(),
'nome' => $indicador->getNome(),
'codigo' => $indicador->getCodigo(),
'grupos' => $arrayGrupos
];
return $json;
}
Мой код не возвращает никаких ошибок, но это не такименно то, что я ожидаю / нужно. Agrupamentos необходимо получить массив, ниже , и я пытаюсь заставить его работать, но не могу.
{
"indicador": {
"id": 20,
"nome": "Produtividade pessoal: Técnica",
"codigo": "IN014",
"grupos": [
{
"id": 1,
"nome": "Até/Acima 125 mil exames ao mês",
"agrupamentos": null
},
[
{
"id": 1,
"nome": "até 5 milhões por mês",
"periodos": null
},
{
"id": 2,
"nome": "Acima de 5 milhões por mês",
"periodos": null
}
],
{
"id": 99,
"nome": "Teste",
"agrupamentos": null
},
[
{
"id": 1,
"nome": "até 5 milhões por mês",
"periodos": null
},
{
"id": 2,
"nome": "Acima de 5 milhões por mês",
"periodos": null
}
]
]
}
}
Чтобы убедиться, что эторезультат, который мне нужно вернуть, предполагая те же данные:
{
"indicador":{
"id":20,
"nome":"Produtividade pessoal: Técnica",
"codigo":"IN014"
},
"grupos":[
{
"id":1,
"nome":"Até/Acima 125 mil exames ao mês",
"agrupamentos":[
{
"id":1,
"nome":"até 5 milhões por mês",
},
{
"id":2,
"nome":"Acima de 5 milhões por mês",
}
]
},
{
"id":99,
"nome":"Teste",
"agrupamentos":[
{
"id":1,
"nome":"até 5 milhões por mês",
"periodos":null
},
{
"id":2,
"nome":"Acima de 5 milhões por mês",
"periodos":null
}
]
}
]
}
Заранее спасибо и извините за случайные ошибки в английском.