"""add housekeeping tables

Revision ID: c5d6e7f8a9b0
Revises: b4c5d6e7f8a9
Create Date: 2026-04-10

"""
import sqlalchemy as sa
from alembic import op

revision = "c5d6e7f8a9b0"
down_revision = "b4c5d6e7f8a9"
branch_labels = None
depends_on = None


def upgrade() -> None:
    op.execute("ALTER TYPE modulenum ADD VALUE IF NOT EXISTS 'housekeeping'")

    op.create_table(
        "housekeeping",
        sa.Column("id", sa.Integer(), primary_key=True),
        sa.Column("spbu_id", sa.Integer(), sa.ForeignKey("master_spbu.id", ondelete="CASCADE"), nullable=False, index=True),
        sa.Column("shift_id", sa.Integer(), sa.ForeignKey("master_spbu_shift.id", ondelete="CASCADE"), nullable=False),
        sa.Column("tanggal", sa.Date(), nullable=False),
        sa.Column("status", sa.String(20), nullable=False, server_default="pending"),
        sa.Column("uploaded_by_id", sa.Integer(), sa.ForeignKey("master_user.id", ondelete="SET NULL"), nullable=True),
        sa.Column("uploaded_at", sa.DateTime(timezone=True), nullable=True),
        sa.Column("reviewed_by_id", sa.Integer(), sa.ForeignKey("master_user.id", ondelete="SET NULL"), nullable=True),
        sa.Column("reviewed_at", sa.DateTime(timezone=True), nullable=True),
        sa.Column("created_at", sa.DateTime(timezone=True), server_default=sa.func.now()),
        sa.Column("updated_at", sa.DateTime(timezone=True), server_default=sa.func.now()),
        sa.UniqueConstraint("spbu_id", "shift_id", "tanggal", name="uq_housekeeping"),
    )

    op.create_table(
        "housekeeping_item",
        sa.Column("id", sa.Integer(), primary_key=True),
        sa.Column("housekeeping_id", sa.Integer(), sa.ForeignKey("housekeeping.id", ondelete="CASCADE"), nullable=False, index=True),
        sa.Column("deskripsi", sa.Text(), nullable=False),
        sa.Column("urutan", sa.Integer(), nullable=False, server_default="0"),
    )

    op.create_table(
        "housekeeping_foto",
        sa.Column("id", sa.Integer(), primary_key=True),
        sa.Column("housekeeping_id", sa.Integer(), sa.ForeignKey("housekeeping.id", ondelete="CASCADE"), nullable=False, index=True),
        sa.Column("tipe", sa.String(10), nullable=False),  # 'before' | 'after'
        sa.Column("foto_url", sa.String(500), nullable=False),
        sa.Column("urutan", sa.Integer(), nullable=False, server_default="0"),
    )


def downgrade() -> None:
    op.drop_table("housekeeping_foto")
    op.drop_table("housekeeping_item")
    op.drop_table("housekeeping")
