"""Add menu_item table.

Revision ID: 0009_add_menu_item_table
Revises: 0008_add_notification_table
Create Date: 2026-02-25
"""

from collections.abc import Sequence

import sqlalchemy as sa
import sqlmodel

from alembic import op

revision: str = "0009_add_menu_item_table"
down_revision: str | None = "0008_add_notification_table"
branch_labels: str | Sequence[str] | None = None
depends_on: str | Sequence[str] | None = None


def upgrade() -> None:
    op.create_table(
        "menu_item",
        sa.Column("id", sa.String(length=36), nullable=False),
        sa.Column("restaurant_id", sa.String(length=36), nullable=False),
        sa.Column("name", sqlmodel.sql.sqltypes.AutoString(), nullable=False),
        sa.Column("description", sa.Text(), nullable=True),
        sa.Column("price_cents", sa.Integer(), nullable=False),
        sa.Column("category", sqlmodel.sql.sqltypes.AutoString(), nullable=False),
        sa.Column("photo_url", sqlmodel.sql.sqltypes.AutoString(), nullable=True),
        sa.Column("is_active", sa.Boolean(), nullable=False, server_default=sa.true()),
        sa.Column("sort_order", sa.Integer(), nullable=False, server_default=sa.text("0")),
        sa.Column("created_at", sa.DateTime(), nullable=False, server_default=sa.text("now()")),
        sa.Column("updated_at", sa.DateTime(), nullable=True),
        sa.ForeignKeyConstraint(["restaurant_id"], ["restaurant.id"]),
        sa.PrimaryKeyConstraint("id"),
    )
    op.create_index(
        "ix_menu_item_restaurant_id",
        "menu_item",
        ["restaurant_id"],
        unique=False,
    )
    op.create_index(
        "ix_menu_item_restaurant_category",
        "menu_item",
        ["restaurant_id", "category"],
        unique=False,
    )


def downgrade() -> None:
    op.drop_index("ix_menu_item_restaurant_category", table_name="menu_item")
    op.drop_index("ix_menu_item_restaurant_id", table_name="menu_item")
    op.drop_table("menu_item")
