<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
final class Version20251231001017 extends AbstractMigration
{
public function getDescription(): string
{
return 'Kanban tables creation';
}
public function up(Schema $schema): void
{
$this->addSql('CREATE TABLE mybiz_kanban_cards (id INT AUTO_INCREMENT NOT NULL, column_id INT NOT NULL, member_id INT DEFAULT NULL, title VARCHAR(255) NOT NULL, description LONGTEXT DEFAULT NULL, position INT NOT NULL, due_date DATETIME DEFAULT NULL COMMENT \'(DC2Type:datetime_immutable)\', archived_at DATETIME DEFAULT NULL COMMENT \'(DC2Type:datetime_immutable)\', created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', INDEX IDX_67A76DEABE8E8ED5 (column_id), INDEX IDX_67A76DEA7597D3FE (member_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE mybiz_kanban_card_tags (kanban_card_id INT NOT NULL, kanban_tag_id INT NOT NULL, INDEX IDX_A0D071D9F9C2CF7B (kanban_card_id), INDEX IDX_A0D071D9D2FD16E9 (kanban_tag_id), PRIMARY KEY(kanban_card_id, kanban_tag_id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE mybiz_kanban_columns (id INT AUTO_INCREMENT NOT NULL, member_id INT DEFAULT NULL, title VARCHAR(255) NOT NULL, position INT NOT NULL, is_system TINYINT(1) NOT NULL, INDEX IDX_FFFEE3677597D3FE (member_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE mybiz_kanban_tags (id INT AUTO_INCREMENT NOT NULL, member_id INT NOT NULL, label VARCHAR(50) NOT NULL, color_hex VARCHAR(20) NOT NULL, css_class VARCHAR(50) DEFAULT NULL, INDEX IDX_CE55A3B7597D3FE (member_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('ALTER TABLE mybiz_kanban_cards ADD CONSTRAINT FK_67A76DEABE8E8ED5 FOREIGN KEY (column_id) REFERENCES mybiz_kanban_columns (id)');
$this->addSql('ALTER TABLE mybiz_kanban_cards ADD CONSTRAINT FK_67A76DEA7597D3FE FOREIGN KEY (member_id) REFERENCES app_member (id)');
$this->addSql('ALTER TABLE mybiz_kanban_card_tags ADD CONSTRAINT FK_A0D071D9F9C2CF7B FOREIGN KEY (kanban_card_id) REFERENCES mybiz_kanban_cards (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE mybiz_kanban_card_tags ADD CONSTRAINT FK_A0D071D9D2FD16E9 FOREIGN KEY (kanban_tag_id) REFERENCES mybiz_kanban_tags (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE mybiz_kanban_columns ADD CONSTRAINT FK_FFFEE3677597D3FE FOREIGN KEY (member_id) REFERENCES app_member (id)');
$this->addSql('ALTER TABLE mybiz_kanban_tags ADD CONSTRAINT FK_CE55A3B7597D3FE FOREIGN KEY (member_id) REFERENCES app_member (id)');
}
public function down(Schema $schema): void
{
$this->addSql('ALTER TABLE mybiz_kanban_card_tags DROP FOREIGN KEY FK_A0D071D9F9C2CF7B');
$this->addSql('ALTER TABLE mybiz_kanban_cards DROP FOREIGN KEY FK_67A76DEABE8E8ED5');
$this->addSql('ALTER TABLE mybiz_kanban_card_tags DROP FOREIGN KEY FK_A0D071D9D2FD16E9');
$this->addSql('DROP TABLE mybiz_kanban_cards');
$this->addSql('DROP TABLE mybiz_kanban_card_tags');
$this->addSql('DROP TABLE mybiz_kanban_columns');
$this->addSql('DROP TABLE mybiz_kanban_tags');
}
}