2020-02-09 22:10:29 +01:00
|
|
|
<?php
|
2020-03-15 13:56:31 +01:00
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
2020-02-09 22:10:29 +01:00
|
|
|
/**
|
|
|
|
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony).
|
|
|
|
*
|
|
|
|
* Copyright (C) 2019 - 2020 Jan Böhmer (https://github.com/jbtronics)
|
|
|
|
*
|
2020-02-22 18:14:36 +01:00
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as published
|
|
|
|
* by the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
2020-02-09 22:10:29 +01:00
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2020-02-22 18:14:36 +01:00
|
|
|
* GNU Affero General Public License for more details.
|
2020-02-09 22:10:29 +01:00
|
|
|
*
|
2020-02-22 18:14:36 +01:00
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
2020-02-09 22:10:29 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
namespace App\DataFixtures;
|
|
|
|
|
|
|
|
use App\Entity\Attachments\AttachmentType;
|
|
|
|
use App\Entity\Attachments\PartAttachment;
|
|
|
|
use App\Entity\Parts\Category;
|
|
|
|
use App\Entity\Parts\Footprint;
|
|
|
|
use App\Entity\Parts\Manufacturer;
|
|
|
|
use App\Entity\Parts\Part;
|
|
|
|
use App\Entity\Parts\PartLot;
|
|
|
|
use App\Entity\Parts\Storelocation;
|
|
|
|
use App\Entity\Parts\Supplier;
|
|
|
|
use App\Entity\PriceInformations\Orderdetail;
|
|
|
|
use App\Entity\PriceInformations\Pricedetail;
|
|
|
|
use Doctrine\Bundle\FixturesBundle\Fixture;
|
|
|
|
use Doctrine\ORM\EntityManagerInterface;
|
|
|
|
use Doctrine\Persistence\ObjectManager;
|
|
|
|
|
|
|
|
class PartFixtures extends Fixture
|
|
|
|
{
|
|
|
|
protected $em;
|
|
|
|
|
|
|
|
public function __construct(EntityManagerInterface $entityManager)
|
|
|
|
{
|
|
|
|
$this->em = $entityManager;
|
|
|
|
}
|
|
|
|
|
2020-03-15 13:56:31 +01:00
|
|
|
public function load(ObjectManager $manager): void
|
2020-02-09 22:10:29 +01:00
|
|
|
{
|
|
|
|
$table_name = $this->em->getClassMetadata(Part::class)->getTableName();
|
|
|
|
$this->em->getConnection()->exec("ALTER TABLE `${table_name}` AUTO_INCREMENT = 1;");
|
|
|
|
|
|
|
|
/** Simple part */
|
|
|
|
$part = new Part();
|
|
|
|
$part->setName('Part 1');
|
|
|
|
$part->setCategory($manager->find(Category::class, 1));
|
|
|
|
$manager->persist($part);
|
|
|
|
|
|
|
|
/** More complex part */
|
|
|
|
$part = new Part();
|
|
|
|
$part->setName('Part 2');
|
|
|
|
$part->setCategory($manager->find(Category::class, 1));
|
|
|
|
$part->setFootprint($manager->find(Footprint::class, 1));
|
|
|
|
$part->setManufacturer($manager->find(Manufacturer::class, 1));
|
|
|
|
$part->setTags('test, Test, Part2');
|
|
|
|
$part->setMass(100.2);
|
|
|
|
$part->setNeedsReview(true);
|
|
|
|
$part->setManufacturingStatus('active');
|
|
|
|
$manager->persist($part);
|
|
|
|
|
|
|
|
/** Part with orderdetails, storelocations and Attachments */
|
|
|
|
$part = new Part();
|
|
|
|
$part->setFavorite(true);
|
2020-04-09 14:23:26 +02:00
|
|
|
$part->setName('Part 3');
|
2020-02-09 22:10:29 +01:00
|
|
|
$part->setCategory($manager->find(Category::class, 1));
|
|
|
|
$partLot1 = new PartLot();
|
|
|
|
$partLot1->setAmount(1.0);
|
|
|
|
$partLot1->setStorageLocation($manager->find(Storelocation::class, 1));
|
|
|
|
$part->addPartLot($partLot1);
|
|
|
|
|
|
|
|
$partLot2 = new PartLot();
|
|
|
|
$partLot2->setExpirationDate(new \DateTime());
|
|
|
|
$partLot2->setComment('Test');
|
|
|
|
$partLot2->setNeedsRefill(true);
|
|
|
|
$partLot2->setStorageLocation($manager->find(Storelocation::class, 3));
|
|
|
|
$part->addPartLot($partLot2);
|
|
|
|
|
|
|
|
$orderdetail = new Orderdetail();
|
|
|
|
$orderdetail->setSupplier($manager->find(Supplier::class, 1));
|
2020-03-29 22:16:06 +02:00
|
|
|
$orderdetail->addPricedetail((new Pricedetail())->setPriceRelatedQuantity(1.0)->setPrice('10.0'));
|
|
|
|
$orderdetail->addPricedetail((new Pricedetail())->setPriceRelatedQuantity(10.0)->setPrice('15.0'));
|
2020-02-09 22:10:29 +01:00
|
|
|
$part->addOrderdetail($orderdetail);
|
|
|
|
|
|
|
|
$orderdetail = new Orderdetail();
|
|
|
|
$orderdetail->setSupplierpartnr('BC 547');
|
|
|
|
$orderdetail->setObsolete(true);
|
|
|
|
$orderdetail->setSupplier($manager->find(Supplier::class, 1));
|
2020-03-29 22:16:06 +02:00
|
|
|
$orderdetail->addPricedetail((new Pricedetail())->setPriceRelatedQuantity(1.0)->setPrice('10.0'));
|
|
|
|
$orderdetail->addPricedetail((new Pricedetail())->setPriceRelatedQuantity(10.0)->setPrice('15.1'));
|
2020-02-09 22:10:29 +01:00
|
|
|
$part->addOrderdetail($orderdetail);
|
|
|
|
|
|
|
|
$attachment = new PartAttachment();
|
|
|
|
$attachment->setName('TestAttachment');
|
|
|
|
$attachment->setURL('www.foo.bar');
|
|
|
|
$attachment->setAttachmentType($manager->find(AttachmentType::class, 1));
|
|
|
|
$part->addAttachment($attachment);
|
|
|
|
|
|
|
|
$attachment = new PartAttachment();
|
|
|
|
$attachment->setName('Test2');
|
|
|
|
$attachment->setPath('invalid');
|
|
|
|
$attachment->setShowInTable(true);
|
|
|
|
$attachment->setAttachmentType($manager->find(AttachmentType::class, 1));
|
|
|
|
$part->addAttachment($attachment);
|
|
|
|
|
|
|
|
$manager->persist($part);
|
|
|
|
$manager->flush();
|
|
|
|
}
|
2020-03-15 13:56:31 +01:00
|
|
|
}
|