brunohanai / data-aggregator
There is no license information available for the latest version (dev-master) of this package.
...
dev-master
2017-03-14 19:17 UTC
Requires
- cocur/slugify: ^2.3
- symfony/property-access: ^3.1
Requires (Dev)
- codeception/specify: ^0.4.5
- codeception/verify: ^0.3.2
- phpunit/phpunit: ^5.6
- squizlabs/php_codesniffer: ^2.7
This package is not auto-updated.
Last update: 2024-11-09 20:45:19 UTC
README
O objetivo do data-aggregator
é agrupar as informações de um array (futuramente objetos também) realizando
operações como Soma, Contagem e cálculos definidos manualmente.
Exemplo 1
Transformar isso:
$data = array(
array('grupo' => 'Grupo 1', 'fila' => 'Fila 1', 'atendidas' => 10, 'abandonadas' => 1, 'tma' => 230),
array('grupo' => 'Grupo 1', 'fila' => 'Fila 2', 'atendidas' => 20, 'abandonadas' => 2, 'tma' => 235),
array('grupo' => 'Grupo 1', 'fila' => 'Fila 3', 'atendidas' => 30, 'abandonadas' => 3, 'tma' => 240),
array('grupo' => 'Grupo 2', 'fila' => 'Fila 4', 'atendidas' => 40, 'abandonadas' => 4, 'tma' => 245),
array('grupo' => 'Grupo 2', 'fila' => 'Fila 5', 'atendidas' => 50, 'abandonadas' => 5, 'tma' => 250),
);
Em isso:
$data = array(
array('_label' => 'Grupo 1', 'atendidas' => 60, 'abandonadas' => 6),
array('_label' => 'Grupo 2', 'atendidas' => 90, 'abandonadas' => 9),
);
Código:
$data = array( array('grupo' => 'Grupo 1', 'fila' => 'Fila 1', 'atendidas' => 10, 'abandonadas' => 1, 'tma' => 230), array('grupo' => 'Grupo 1', 'fila' => 'Fila 2', 'atendidas' => 20, 'abandonadas' => 2, 'tma' => 235), array('grupo' => 'Grupo 1', 'fila' => 'Fila 3', 'atendidas' => 30, 'abandonadas' => 3, 'tma' => 240), array('grupo' => 'Grupo 2', 'fila' => 'Fila 4', 'atendidas' => 40, 'abandonadas' => 4, 'tma' => 245), array('grupo' => 'Grupo 2', 'fila' => 'Fila 5', 'atendidas' => 50, 'abandonadas' => 5, 'tma' => 250), ); $definition = new Definition(); $definition->addRow(new RowDefinition('[grupo]', 'Grupo')); $definition->addColumn(new ColumnDefinition('[atendidas]', new OperationSum())); $definition->addColumn(new ColumnDefinition('[abandonadas]', new OperationSum())); $aggregator = DataAggregator::createAggregator(); $aggregator->setDefinition($definition); $result = $aggregator->aggregate($data); print_r($result->getArrayResult());
Exemplo 2 (Linhas virtuais utilizando filtros)
Transformar isso:
$data = array(
array('grupo' => 'Grupo 1', 'fila' => 'Fila 1', 'atendidas' => 10, 'abandonadas' => 0, 'tma' => 230),
array('grupo' => 'Grupo 1', 'fila' => 'Fila 2', 'atendidas' => 15, 'abandonadas' => 0, 'tma' => 235),
array('grupo' => 'Grupo 1', 'fila' => 'Fila 3', 'atendidas' => 5, 'abandonadas' => 0, 'tma' => 240),
array('grupo' => 'Grupo 2', 'fila' => 'Fila 4', 'atendidas' => 50, 'abandonadas' => 40, 'tma' => 245),
array('grupo' => 'Grupo 2', 'fila' => 'Fila 5', 'atendidas' => 20, 'abandonadas' => 10, 'tma' => 250),
);
Em isso:
$data = array(
array('_label' => 'Todos', 'contagem' => 5, 'atendidas' => 100, 'abandonadas' => 50, 'atendidas-porcentagem' => 66.66),
array('_label' => 'Dentro da meta', 'contagem' => 3, 'atendidas' => 30, 'abandonadas' => 0, 'atendidas-porcentagem' => 100),
array('_label' => 'Fora da meta', 'contagem' => 2, 'atendidas' => 70, 'abandonadas' => 50, 'atendidas-porcentagem' => 58.33),
);
Código:
$data = array( array('grupo' => 'Grupo 1', 'fila' => 'Fila 1', 'atendidas' => 10, 'abandonadas' => 0, 'tma' => 230), array('grupo' => 'Grupo 1', 'fila' => 'Fila 2', 'atendidas' => 15, 'abandonadas' => 0, 'tma' => 235), array('grupo' => 'Grupo 1', 'fila' => 'Fila 3', 'atendidas' => 5, 'abandonadas' => 0, 'tma' => 240), array('grupo' => 'Grupo 2', 'fila' => 'Fila 4', 'atendidas' => 50, 'abandonadas' => 40, 'tma' => 245), array('grupo' => 'Grupo 2', 'fila' => 'Fila 5', 'atendidas' => 20, 'abandonadas' => 10, 'tma' => 250), ); $definition = new Definition(); $filterIn = (new RowDefinitionFilter(new AffirmativeStrategy())) ->setRowColumnFilter('[tma]', new Filter(new LessThanFilterRule(241))); $filterOut = (new RowDefinitionFilter(new AffirmativeStrategy())) ->setRowColumnFilter('[tma]', new Filter(new GreaterThanFilterRule(240))); $g = (new FilterGroup(new UnanimousStrategy())) ->addFilter(new Filter(new LessThanFilterRule(300))) ->addFilter(new Filter(new GreaterThanFilterRule(200))); $filterAll = (new RowDefinitionFilter(new AffirmativeStrategy()))->setRowColumnFilter('[tma]', $g); $definition->addRow((new RowDefinition('[virtual]', 'Todos'))->setRowDefinitionFilter($filterAll)); $definition->addRow((new RowDefinition('[virtual]', 'TMA Dentro da meta'))->setRowDefinitionFilter($filterIn)); $definition->addRow((new RowDefinition('[virtual]', 'TMA Fora da meta'))->setRowDefinitionFilter($filterOut)); $definition->addColumn(new ColumnDefinition('[contagem]', new OperationIncrement())); $definition->addColumn(new ColumnDefinition('[atendidas]', new OperationSum())); $definition->addColumn(new ColumnDefinition('[abandonadas]', new OperationSum())); $definition->addColumn(new ColumnDefinition('[atendidas_porcentagem]', new OperationManualCalc('[atendidas] / ([atendidas] + [abandonadas]) * 100'))); $aggregator = DataAggregator::createAggregator(); $aggregator->setDefinition($definition); $result = $aggregator->aggregate($data); print_r($result->getArrayResult());