"""init

Revision ID: c72a6ce11b44
Revises: a8250fbb7fe0
Create Date: 2025-09-22 21:42:01.762510

"""
from typing import Sequence, Union

from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import mysql

# revision identifiers, used by Alembic.
revision: str = 'c72a6ce11b44'
down_revision: Union[str, Sequence[str], None] = 'a8250fbb7fe0'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None


def upgrade() -> None:
    """Upgrade schema."""
    # ### commands auto generated by Alembic - please adjust! ###
    op.create_table('review_response',
    sa.Column('response_id', sa.Integer(), autoincrement=True, nullable=False),
    sa.Column('review_type', sa.String(length=50), nullable=False),
    sa.Column('review_id', sa.Integer(), nullable=False),
    sa.Column('author_type', sa.String(length=50), nullable=False),
    sa.Column('author_id', sa.Integer(), nullable=True),
    sa.Column('author_name', sa.String(length=255), nullable=False),
    sa.Column('response_text', sa.Text(), nullable=False),
    sa.Column('date_added', sa.DateTime(), nullable=False),
    sa.Column('date_modify', sa.DateTime(), nullable=False),
    sa.Column('status', sa.Enum('new', 'approved', 'rejected', name='reviewstatusenum'), nullable=False),
    sa.Column('ip', sa.String(length=75), nullable=True),
    sa.PrimaryKeyConstraint('response_id')
    )
    op.add_column('cart', sa.Column('date_updated', sa.DateTime(), nullable=True))
    op.add_column('category', sa.Column('icon', sa.String(length=255), nullable=True))
    op.add_column('category', sa.Column('sort_order', sa.Integer(), nullable=True))
    op.add_column('current_cart_product', sa.Column('store_id', sa.Integer(), nullable=False))
    op.drop_index(op.f('phone'), table_name='customer')
    op.alter_column('manufacturer', 'meta_description',
               existing_type=mysql.VARCHAR(length=1028),
               type_=sa.Text(),
               existing_nullable=True)
    op.add_column('manufacturer_review', sa.Column('has_response', sa.Boolean(), nullable=False))
    op.add_column('product', sa.Column('price_old', sa.Float(), nullable=True))
    op.alter_column('product', 'description',
               existing_type=mysql.VARCHAR(length=255),
               type_=sa.Text(),
               existing_nullable=True)
    op.alter_column('product', 'meta_description',
               existing_type=mysql.VARCHAR(length=255),
               type_=sa.Text(),
               existing_nullable=True)
    op.add_column('product_review', sa.Column('store_id', sa.Integer(), nullable=True))
    op.add_column('product_review', sa.Column('has_response', sa.Boolean(), nullable=False))
    op.create_foreign_key(None, 'product_review', 'store', ['store_id'], ['store_id'], ondelete='CASCADE')
    op.add_column('product_store', sa.Column('price_old', sa.Float(), nullable=True))
    op.add_column('service_review', sa.Column('has_response', sa.Boolean(), nullable=False))
    op.add_column('store', sa.Column('website', sa.String(length=255), nullable=True))
    op.add_column('store', sa.Column('url_youtube', sa.String(length=255), nullable=True))
    op.add_column('store', sa.Column('url_viber', sa.String(length=255), nullable=True))
    op.add_column('store', sa.Column('url_facebook', sa.String(length=255), nullable=True))
    op.add_column('store', sa.Column('url_telegram', sa.String(length=255), nullable=True))
    op.alter_column('store', 'meta_description',
               existing_type=mysql.VARCHAR(length=255),
               type_=sa.Text(),
               existing_nullable=True)
    op.add_column('store_review', sa.Column('has_response', sa.Boolean(), nullable=False))
    # ### end Alembic commands ###


def downgrade() -> None:
    """Downgrade schema."""
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_column('store_review', 'has_response')
    op.alter_column('store', 'meta_description',
               existing_type=sa.Text(),
               type_=mysql.VARCHAR(length=255),
               existing_nullable=True)
    op.drop_column('store', 'url_telegram')
    op.drop_column('store', 'url_facebook')
    op.drop_column('store', 'url_viber')
    op.drop_column('store', 'url_youtube')
    op.drop_column('store', 'website')
    op.drop_column('service_review', 'has_response')
    op.drop_column('product_store', 'price_old')
    op.drop_constraint(None, 'product_review', type_='foreignkey')
    op.drop_column('product_review', 'has_response')
    op.drop_column('product_review', 'store_id')
    op.alter_column('product', 'meta_description',
               existing_type=sa.Text(),
               type_=mysql.VARCHAR(length=255),
               existing_nullable=True)
    op.alter_column('product', 'description',
               existing_type=sa.Text(),
               type_=mysql.VARCHAR(length=255),
               existing_nullable=True)
    op.drop_column('product', 'price_old')
    op.drop_column('manufacturer_review', 'has_response')
    op.alter_column('manufacturer', 'meta_description',
               existing_type=sa.Text(),
               type_=mysql.VARCHAR(length=1028),
               existing_nullable=True)
    op.create_index(op.f('phone'), 'customer', ['phone'], unique=True)
    op.drop_column('current_cart_product', 'store_id')
    op.drop_column('category', 'sort_order')
    op.drop_column('category', 'icon')
    op.drop_column('cart', 'date_updated')
    op.drop_table('review_response')
    # ### end Alembic commands ###
