]> git.immae.eu Git - github/wallabag/wallabag.git/blame - src/Wallabag/CoreBundle/Form/Type/ConfigType.php
Merge pull request #2751 from bdunogier/2.2-guzzle_subscribers_improvement
[github/wallabag/wallabag.git] / src / Wallabag / CoreBundle / Form / Type / ConfigType.php
CommitLineData
4d85d7e9 1<?php
4346a860 2
4d85d7e9
J
3namespace Wallabag\CoreBundle\Form\Type;
4
5use Symfony\Component\Form\AbstractType;
619cc453
JB
6use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
7use Symfony\Component\Form\Extension\Core\Type\SubmitType;
4d85d7e9 8use Symfony\Component\Form\FormBuilderInterface;
75e9d1df 9use Symfony\Component\OptionsResolver\OptionsResolver;
f052f1fd 10use Wallabag\CoreBundle\Entity\Config;
4d85d7e9
J
11
12class ConfigType extends AbstractType
13{
4094ea47
JB
14 private $themes = [];
15 private $languages = [];
32da2a70
J
16
17 /**
c89d35e8
NL
18 * @param array $themes Themes come from the LiipThemeBundle (liip_theme.themes)
19 * @param array $languages Languages come from configuration, array just code language as key and label as value
32da2a70 20 */
c89d35e8 21 public function __construct($themes, $languages)
32da2a70
J
22 {
23 $this->themes = array_combine(
24 $themes,
0cecfa25
JB
25 array_map(function ($s) {
26 return ucwords(strtolower(str_replace('-', ' ', $s)));
27 }, $themes)
32da2a70 28 );
c89d35e8
NL
29
30 $this->languages = $languages;
32da2a70
J
31 }
32
4d85d7e9
J
33 public function buildForm(FormBuilderInterface $builder, array $options)
34 {
35 $builder
4094ea47 36 ->add('theme', ChoiceType::class, [
75e9d1df 37 'choices' => array_flip($this->themes),
0d42217e 38 'label' => 'config.form_settings.theme_label',
4094ea47
JB
39 ])
40 ->add('items_per_page', null, [
0d42217e 41 'label' => 'config.form_settings.items_per_page_label',
ab9eb5cd 42 'property_path' => 'itemsPerPage',
4094ea47
JB
43 ])
44 ->add('reading_speed', ChoiceType::class, [
f3e49264 45 'label' => 'config.form_settings.reading_speed.label',
ab9eb5cd 46 'property_path' => 'readingSpeed',
4094ea47 47 'choices' => [
f3e49264
JB
48 'config.form_settings.reading_speed.100_word' => '0.5',
49 'config.form_settings.reading_speed.200_word' => '1',
50 'config.form_settings.reading_speed.300_word' => '1.5',
51 'config.form_settings.reading_speed.400_word' => '2',
4094ea47
JB
52 ],
53 ])
a42f38d9
NL
54 ->add('action_mark_as_read', ChoiceType::class, [
55 'label' => 'config.form_settings.action_mark_as_read.label',
ab9eb5cd 56 'property_path' => 'actionMarkAsRead',
a42f38d9 57 'choices' => [
f052f1fd
NL
58 'config.form_settings.action_mark_as_read.redirect_homepage' => Config::REDIRECT_TO_HOMEPAGE,
59 'config.form_settings.action_mark_as_read.redirect_current_page' => Config::REDIRECT_TO_CURRENT_PAGE,
a42f38d9
NL
60 ],
61 ])
4094ea47 62 ->add('language', ChoiceType::class, [
5c895a7f 63 'choices' => array_flip($this->languages),
0d42217e 64 'label' => 'config.form_settings.language_label',
4094ea47 65 ])
ebe0787e 66 ->add('pocket_consumer_key', null, [
ab9eb5cd 67 'property_path' => 'pocketConsumerKey',
ebe0787e
JB
68 'label' => 'config.form_settings.pocket_consumer_key_label',
69 ])
4094ea47 70 ->add('save', SubmitType::class, [
0d42217e 71 'label' => 'config.form.save',
4094ea47 72 ])
4d85d7e9
J
73 ;
74 }
75
75e9d1df 76 public function configureOptions(OptionsResolver $resolver)
4d85d7e9 77 {
4094ea47 78 $resolver->setDefaults([
4d85d7e9 79 'data_class' => 'Wallabag\CoreBundle\Entity\Config',
4094ea47 80 ]);
4d85d7e9
J
81 }
82
619cc453 83 public function getBlockPrefix()
4d85d7e9
J
84 {
85 return 'config';
86 }
87}