2017 © Pedro PelĂĄez
 

library data-aggregator

...

image

brunohanai/data-aggregator

...

  • Tuesday, March 14, 2017
  • by bruno.hanai
  • Repository
  • 1 Watchers
  • 0 Stars
  • 196 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 2 % Grown

The README.md

data-aggregator Open Source Love Build Status Coverage Status

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., (*1)

Exemplo 1

Transformar isso:, (*2)

$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:, (*3)

$data = array(
    array('_label' => 'Grupo 1', 'atendidas' => 60, 'abandonadas' => 6),
    array('_label' => 'Grupo 2', 'atendidas' => 90, 'abandonadas' => 9),
);

CĂłdigo:, (*4)

$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:, (*5)

$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:, (*6)

$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:, (*7)

$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());

The Versions