. */ declare(strict_types=1); namespace App\Entity\EDA; use Doctrine\DBAL\Types\Types; use Doctrine\ORM\Mapping\Column; use Doctrine\ORM\Mapping\Embeddable; use Symfony\Component\Serializer\Annotation\Groups; #[Embeddable] class EDAPartInfo { /** * @var string|null The reference prefix of the Part in the schematic. E.g. "R" for resistors, or "C" for capacitors. */ #[Column(type: Types::STRING, nullable: true)] #[Groups(['full', 'eda_info:read', 'eda_info:write'])] private ?string $reference_prefix = null; /** @var string|null The value, which should be shown together with the part (e.g. 470 for a 470 Ohm resistor) */ #[Column(type: Types::STRING, nullable: true)] #[Groups(['full', 'eda_info:read', 'eda_info:write'])] private ?string $value = null; /** @var bool|null Visibility of this part to EDA software in trinary logic. True=Visible, False=Invisible, Null=Auto */ #[Column(name: 'invisible', type: Types::BOOLEAN, nullable: true)] //TODO: Rename column to visibility #[Groups(['full', 'eda_info:read', 'eda_info:write'])] private ?bool $visibility = null; /** @var bool|null If this is set to true, then this part will be excluded from the BOM */ #[Column(type: Types::BOOLEAN, nullable: true)] #[Groups(['full', 'eda_info:read', 'eda_info:write'])] private ?bool $exclude_from_bom = null; /** @var bool|null If this is set to true, then this part will be excluded from the board/the PCB */ #[Column(type: Types::BOOLEAN, nullable: true)] #[Groups(['full', 'eda_info:read', 'eda_info:write'])] private ?bool $exclude_from_board = null; /** @var bool|null If this is set to true, then this part will be excluded in the simulation */ #[Column(type: Types::BOOLEAN, nullable: true)] #[Groups(['full', 'eda_info:read', 'eda_info:write'])] private ?bool $exclude_from_sim = null; /** @var string|null The KiCAD schematic symbol, which should be used (the path to the library) */ #[Column(type: Types::STRING, nullable: true)] #[Groups(['full', 'eda_info:read', 'eda_info:write'])] private ?string $kicad_symbol = null; /** @var string|null The KiCAD footprint, which should be used (the path to the library) */ #[Column(type: Types::STRING, nullable: true)] #[Groups(['full', 'eda_info:read', 'eda_info:write'])] private ?string $kicad_footprint = null; public function __construct() { } public function getReferencePrefix(): ?string { return $this->reference_prefix; } public function setReferencePrefix(?string $reference_prefix): EDAPartInfo { $this->reference_prefix = $reference_prefix; return $this; } public function getValue(): ?string { return $this->value; } public function setValue(?string $value): EDAPartInfo { $this->value = $value; return $this; } public function getVisibility(): ?bool { return $this->visibility; } public function setVisibility(?bool $visibility): EDAPartInfo { $this->visibility = $visibility; return $this; } public function getExcludeFromBom(): ?bool { return $this->exclude_from_bom; } public function setExcludeFromBom(?bool $exclude_from_bom): EDAPartInfo { $this->exclude_from_bom = $exclude_from_bom; return $this; } public function getExcludeFromBoard(): ?bool { return $this->exclude_from_board; } public function setExcludeFromBoard(?bool $exclude_from_board): EDAPartInfo { $this->exclude_from_board = $exclude_from_board; return $this; } public function getExcludeFromSim(): ?bool { return $this->exclude_from_sim; } public function setExcludeFromSim(?bool $exclude_from_sim): EDAPartInfo { $this->exclude_from_sim = $exclude_from_sim; return $this; } public function getKicadSymbol(): ?string { return $this->kicad_symbol; } public function setKicadSymbol(?string $kicad_symbol): EDAPartInfo { $this->kicad_symbol = $kicad_symbol; return $this; } public function getKicadFootprint(): ?string { return $this->kicad_footprint; } public function setKicadFootprint(?string $kicad_footprint): EDAPartInfo { $this->kicad_footprint = $kicad_footprint; return $this; } }