[Budget] Feature: allow to desactive resources and charges in the

configuration

A new key `active` (default `true`) allow to activate or desactivate the
line in the resource or charge.
This commit is contained in:
Julien Fastré 2022-09-20 11:26:05 +02:00
parent 4d192d748f
commit 29b24fa506
5 changed files with 27 additions and 15 deletions

View File

@ -12,6 +12,7 @@ and this project adheres to
<!-- write down unreleased development here --> <!-- write down unreleased development here -->
* [workflow]: Fixed: the notification is sent when the user is added to the first step. * [workflow]: Fixed: the notification is sent when the user is added to the first step.
* [budget] Feature: allow to desactivate some charges and resources, adding an `active` key in the configuration
## Test releases ## Test releases

View File

@ -29,44 +29,58 @@ class ConfigRepository
$this->charges = $charges; $this->charges = $charges;
} }
public function getChargesKeys(): array public function getChargesKeys(bool $onlyActive = false): array
{ {
return array_map(static function ($element) { return $element['key']; }, $this->charges); return array_map(static function ($element) { return $element['key']; }, $this->getCharges($onlyActive));
} }
/** /**
* @return array where keys are the resource'key and label the ressource label * @return array where keys are the resource'key and label the ressource label
*/ */
public function getChargesLabels() public function getChargesLabels(bool $onlyActive = false)
{ {
$charges = []; $charges = [];
foreach ($this->charges as $definition) { foreach ($this->getCharges($onlyActive) as $definition) {
$charges[$definition['key']] = $this->normalizeLabel($definition['labels']); $charges[$definition['key']] = $this->normalizeLabel($definition['labels']);
} }
return $charges; return $charges;
} }
public function getResourcesKeys(): array public function getResourcesKeys(bool $onlyActive = false): array
{ {
return array_map(static function ($element) { return $element['key']; }, $this->resources); return array_map(static function ($element) { return $element['key']; }, $this->getResources($onlyActive));
} }
/** /**
* @return array where keys are the resource'key and label the ressource label * @return array where keys are the resource'key and label the ressource label
*/ */
public function getResourcesLabels() public function getResourcesLabels(bool $onlyActive = false)
{ {
$resources = []; $resources = [];
foreach ($this->resources as $definition) { foreach ($this->getResources($onlyActive) as $definition) {
$resources[$definition['key']] = $this->normalizeLabel($definition['labels']); $resources[$definition['key']] = $this->normalizeLabel($definition['labels']);
} }
return $resources; return $resources;
} }
private function getCharges(bool $onlyActive = false): array
{
return $onlyActive ?
array_filter($this->charges, function ($el) { return $el['active']; })
: $this->charges;
}
private function getResources(bool $onlyActive = false): array
{
return $onlyActive ?
array_filter($this->resources, function ($el) { return $el['active']; })
: $this->resources;
}
private function normalizeLabel($labels) private function normalizeLabel($labels)
{ {
$normalizedLabels = []; $normalizedLabels = [];

View File

@ -14,11 +14,6 @@ namespace Chill\BudgetBundle\DependencyInjection;
use Symfony\Component\Config\Definition\Builder\TreeBuilder; use Symfony\Component\Config\Definition\Builder\TreeBuilder;
use Symfony\Component\Config\Definition\ConfigurationInterface; use Symfony\Component\Config\Definition\ConfigurationInterface;
/**
* This is the class that validates and merges configuration from your app/config files.
*
* To learn more see {@link http://symfony.com/doc/current/cookbook/bundles/configuration.html}
*/
class Configuration implements ConfigurationInterface class Configuration implements ConfigurationInterface
{ {
public function getConfigTreeBuilder() public function getConfigTreeBuilder()
@ -37,6 +32,7 @@ class Configuration implements ConfigurationInterface
->info('the key stored in database') ->info('the key stored in database')
->example('salary') ->example('salary')
->end() ->end()
->booleanNode('active')->defaultTrue()->end()
->arrayNode('labels')->isRequired()->requiresAtLeastOneElement() ->arrayNode('labels')->isRequired()->requiresAtLeastOneElement()
->arrayPrototype() ->arrayPrototype()
->children() ->children()
@ -59,6 +55,7 @@ class Configuration implements ConfigurationInterface
->info('the key stored in database') ->info('the key stored in database')
->example('salary') ->example('salary')
->end() ->end()
->booleanNode('active')->defaultTrue()->end()
->arrayNode('labels')->isRequired()->requiresAtLeastOneElement() ->arrayNode('labels')->isRequired()->requiresAtLeastOneElement()
->arrayPrototype() ->arrayPrototype()
->children() ->children()

View File

@ -103,7 +103,7 @@ class ChargeType extends AbstractType
private function getTypes() private function getTypes()
{ {
$charges = $this->configRepository $charges = $this->configRepository
->getChargesLabels(); ->getChargesLabels(true);
// rewrite labels to filter in language // rewrite labels to filter in language
foreach ($charges as $key => $labels) { foreach ($charges as $key => $labels) {

View File

@ -87,7 +87,7 @@ class ResourceType extends AbstractType
private function getTypes() private function getTypes()
{ {
$resources = $this->configRepository $resources = $this->configRepository
->getResourcesLabels(); ->getResourcesLabels(true);
// rewrite labels to filter in language // rewrite labels to filter in language
foreach ($resources as $key => $labels) { foreach ($resources as $key => $labels) {