Merge branch 'sf4' of framagit.org:chill-project/Chill-CustomFields into sf4

This commit is contained in:
Mathieu Jaumotte 2021-02-09 10:02:45 +01:00
commit ecb6006835
2 changed files with 28 additions and 41 deletions

View File

@ -27,7 +27,7 @@ use Doctrine\Persistence\ObjectManager;
error_reporting(0); error_reporting(0);
/** /**
* Load some Options * Load some Options
* *
* *
* @author Julien Fastré <julien.fastre@champs-libres.coop> * @author Julien Fastré <julien.fastre@champs-libres.coop>
*/ */
@ -38,26 +38,26 @@ class LoadOption extends AbstractFixture implements OrderedFixtureInterface
* @var \Faker\Generator * @var \Faker\Generator
*/ */
public $fakerFr; public $fakerFr;
/** /**
* *
* @var \Faker\Generator * @var \Faker\Generator
*/ */
public $fakerEn; public $fakerEn;
/** /**
* *
* @var \Faker\Generator * @var \Faker\Generator
*/ */
public $fakerNl; public $fakerNl;
public function __construct() public function __construct()
{ {
$this->fakerFr = \Faker\Factory::create('fr_FR'); $this->fakerFr = \Faker\Factory::create('fr_FR');
$this->fakerEn = \Faker\Factory::create('en_EN'); $this->fakerEn = \Faker\Factory::create('en_EN');
$this->fakerNl = \Faker\Factory::create('nl_NL'); $this->fakerNl = \Faker\Factory::create('nl_NL');
} }
public function getOrder() public function getOrder()
{ {
return 1000; return 1000;
@ -66,52 +66,39 @@ class LoadOption extends AbstractFixture implements OrderedFixtureInterface
public function load(ObjectManager $manager) public function load(ObjectManager $manager)
{ {
echo "Loading Options \n"; echo "Loading Options \n";
// load companies // load companies
$this->loadingCompanies($manager);
/* $this->loadingWords($manager);
* TODO sf4 - disabled to avoid error :
*
* An exception occurred while executing 'INSERT INTO custom_field_long_choice_options (id, key, text, internal_key, active, parent_id)
* VALUES (?, ?, ?, ?, ?, ?)' with params [1153, "company", {"fr":"Grandes Entreprises","nl":"Grotes Bedrijven","en":"Big Companies"}, "", 1, null]:
*
* SQLSTATE[22P02]: Invalid text representation: 7 ERROR: invalid input syntax for type json
* DETAIL: Token "Array" is invalid.
* CONTEXT: JSON data, line 1: Array
*
*/
//$this->loadingCompanies($manager);
//$this->loadingWords($manager);
$manager->flush(); $manager->flush();
} }
private function loadingWords(\Doctrine\Persistence\ObjectManager $manager) private function loadingWords(\Doctrine\Persistence\ObjectManager $manager)
{ {
echo "Loading some words...\n"; echo "Loading some words...\n";
$parents = array( $parents = array(
array( array(
'fr' => 'Categorie 1', 'fr' => 'Categorie 1',
'nl' => 'Categorie 1', 'nl' => 'Categorie 1',
'en' => 'Category 1' 'en' => 'Category 1'
), ),
array( array(
'fr' => 'Categorie 2', 'fr' => 'Categorie 2',
'nl' => 'Categorie 2', 'nl' => 'Categorie 2',
'en' => 'Category 2' 'en' => 'Category 2'
) )
); );
foreach ($parents as $text) { foreach ($parents as $text) {
$parent = (new Option()) $parent = (new Option())
->setText($text) ->setText($text)
->setKey('word') ->setKey('word')
; ;
$manager->persist($parent); $manager->persist($parent);
//Load children //Load children
$expected_nb_children = rand(10, 50); $expected_nb_children = rand(10, 50);
for ($i=0; $i < $expected_nb_children; $i++) { for ($i=0; $i < $expected_nb_children; $i++) {
@ -123,7 +110,7 @@ class LoadOption extends AbstractFixture implements OrderedFixtureInterface
} }
} }
} }
private function loadingCompanies(\Doctrine\Persistence\ObjectManager $manager) private function loadingCompanies(\Doctrine\Persistence\ObjectManager $manager)
{ {
echo "Loading companies \n"; echo "Loading companies \n";
@ -145,21 +132,21 @@ class LoadOption extends AbstractFixture implements OrderedFixtureInterface
) )
); );
foreach ($companiesParents as $text) { foreach ($companiesParents as $text) {
$parent = (new Option()) $parent = (new Option())
->setText($text) ->setText($text)
->setKey('company') ->setKey('company')
; ;
$manager->persist($parent); $manager->persist($parent);
//Load children //Load children
$expected_nb_children = rand(10, 50); $expected_nb_children = rand(10, 50);
for ($i=0; $i < $expected_nb_children; $i++) { for ($i=0; $i < $expected_nb_children; $i++) {
$companyName = $this->fakerFr->company; $companyName = $this->fakerFr->company;
$manager->persist( $manager->persist(
$this->createChildOption($parent, array( $this->createChildOption($parent, array(
'fr' => $companyName, 'fr' => $companyName,
@ -167,14 +154,14 @@ class LoadOption extends AbstractFixture implements OrderedFixtureInterface
'en' => $companyName 'en' => $companyName
))); )));
} }
} }
} }
private $counter = 0; private $counter = 0;
/** /**
* *
* @param Option $parent * @param Option $parent
* @param array $text * @param array $text
* @return Option * @return Option
@ -182,13 +169,13 @@ class LoadOption extends AbstractFixture implements OrderedFixtureInterface
private function createChildOption(Option $parent, array $text) private function createChildOption(Option $parent, array $text)
{ {
$this->counter ++; $this->counter ++;
return (new Option()) return (new Option())
->setText($text) ->setText($text)
->setParent($parent) ->setParent($parent)
->setActive(true) ->setActive(true)
->setInternalKey($parent->getKey().'-'.$this->counter); ->setInternalKey($parent->getKey().'-'.$this->counter);
; ;
} }
} }

View File

@ -50,7 +50,7 @@ class Option
* A json representation of text (multilingual) * A json representation of text (multilingual)
* *
* @var array * @var array
* @ORM\Column(type="text") * @ORM\Column(type="json_array")
*/ */
private $text; private $text;