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);
/**
* Load some Options
*
*
*
* @author Julien Fastré <julien.fastre@champs-libres.coop>
*/
@ -38,26 +38,26 @@ class LoadOption extends AbstractFixture implements OrderedFixtureInterface
* @var \Faker\Generator
*/
public $fakerFr;
/**
*
* @var \Faker\Generator
*/
public $fakerEn;
/**
*
* @var \Faker\Generator
*/
public $fakerNl;
public function __construct()
{
$this->fakerFr = \Faker\Factory::create('fr_FR');
$this->fakerEn = \Faker\Factory::create('en_EN');
$this->fakerNl = \Faker\Factory::create('nl_NL');
}
public function getOrder()
{
return 1000;
@ -66,52 +66,39 @@ class LoadOption extends AbstractFixture implements OrderedFixtureInterface
public function load(ObjectManager $manager)
{
echo "Loading Options \n";
// load companies
/*
* 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);
$this->loadingCompanies($manager);
$this->loadingWords($manager);
$manager->flush();
}
private function loadingWords(\Doctrine\Persistence\ObjectManager $manager)
{
echo "Loading some words...\n";
$parents = array(
array(
'fr' => 'Categorie 1',
'nl' => 'Categorie 1',
'en' => 'Category 1'
),
),
array(
'fr' => 'Categorie 2',
'nl' => 'Categorie 2',
'en' => 'Category 2'
)
);
foreach ($parents as $text) {
$parent = (new Option())
->setText($text)
->setKey('word')
;
$manager->persist($parent);
//Load children
$expected_nb_children = rand(10, 50);
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)
{
echo "Loading companies \n";
@ -145,21 +132,21 @@ class LoadOption extends AbstractFixture implements OrderedFixtureInterface
)
);
foreach ($companiesParents as $text) {
$parent = (new Option())
->setText($text)
->setKey('company')
;
$manager->persist($parent);
//Load children
$expected_nb_children = rand(10, 50);
for ($i=0; $i < $expected_nb_children; $i++) {
$companyName = $this->fakerFr->company;
$manager->persist(
$this->createChildOption($parent, array(
'fr' => $companyName,
@ -167,14 +154,14 @@ class LoadOption extends AbstractFixture implements OrderedFixtureInterface
'en' => $companyName
)));
}
}
}
private $counter = 0;
/**
*
*
* @param Option $parent
* @param array $text
* @return Option
@ -182,13 +169,13 @@ class LoadOption extends AbstractFixture implements OrderedFixtureInterface
private function createChildOption(Option $parent, array $text)
{
$this->counter ++;
return (new Option())
->setText($text)
->setParent($parent)
->setActive(true)
->setInternalKey($parent->getKey().'-'.$this->counter);
;
;
}
}

View File

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