"""Add is_manual to penebusan and create penerimaan table.

Revision ID: h3c4d5e6f7a8
Revises: g2b3c4d5e6f7
Create Date: 2026-04-02
"""

from alembic import op
import sqlalchemy as sa

revision = 'h3c4d5e6f7a8'
down_revision = 'g2b3c4d5e6f7'
branch_labels = None
depends_on = None


def upgrade() -> None:
    # Add is_manual to penebusan
    op.add_column('penebusan', sa.Column('is_manual', sa.Boolean(), nullable=False, server_default='false'))

    # Create penerimaan table
    op.create_table(
        'penerimaan',
        sa.Column('id', sa.Integer(), nullable=False),
        sa.Column('spbu_id', sa.Integer(), nullable=False),
        sa.Column('penebusan_id', sa.Integer(), nullable=False),
        sa.Column('tangki_id', sa.Integer(), nullable=False),
        sa.Column('tanggal', sa.Date(), nullable=False),
        sa.Column('jam', sa.Time(), nullable=True),
        sa.Column('no_segel', sa.String(100), nullable=True),
        sa.Column('dipstick_sebelum_mm', sa.Numeric(10, 1), nullable=False),
        sa.Column('volume_sebelum', sa.Numeric(15, 3), nullable=False),
        sa.Column('dipstick_sesudah_mm', sa.Numeric(10, 1), nullable=False),
        sa.Column('volume_sesudah', sa.Numeric(15, 3), nullable=False),
        sa.Column('volume_diterima', sa.Numeric(15, 3), nullable=False),
        sa.Column('density', sa.Numeric(8, 4), nullable=True),
        sa.Column('surat_jalan_url', sa.String(500), nullable=True),
        sa.Column('catatan', sa.Text(), nullable=True),
        sa.Column('created_by_id', sa.Integer(), nullable=True),
        sa.Column('created_at', sa.DateTime(timezone=True), server_default=sa.text('now()'), nullable=False),
        sa.Column('updated_at', sa.DateTime(timezone=True), server_default=sa.text('now()'), nullable=False),
        sa.ForeignKeyConstraint(['spbu_id'], ['master_spbu.id'], ondelete='CASCADE'),
        sa.ForeignKeyConstraint(['penebusan_id'], ['penebusan.id'], ondelete='RESTRICT'),
        sa.ForeignKeyConstraint(['tangki_id'], ['master_spbu_tangki.id'], ondelete='RESTRICT'),
        sa.ForeignKeyConstraint(['created_by_id'], ['master_user.id'], ondelete='SET NULL'),
        sa.PrimaryKeyConstraint('id'),
    )
    op.create_index('ix_penerimaan_spbu_tanggal', 'penerimaan', ['spbu_id', 'tanggal'])
    op.create_index('ix_penerimaan_penebusan_id', 'penerimaan', ['penebusan_id'])


def downgrade() -> None:
    op.drop_index('ix_penerimaan_penebusan_id', table_name='penerimaan')
    op.drop_index('ix_penerimaan_spbu_tanggal', table_name='penerimaan')
    op.drop_table('penerimaan')
    op.drop_column('penebusan', 'is_manual')
