"""add_menu_tree_item

Revision ID: f7106986a217
Revises: 7eb8c581045c
Create Date: 2022-06-17 19:07:52.557350

"""
from alembic import op
import sqlalchemy as sa


# revision identifiers, used by Alembic.
revision = 'f7106986a217'
down_revision = '7eb8c581045c'
branch_labels = None
depends_on = None


def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.create_table('cmf_menu_tree_item',
    sa.Column('id', sa.String(length=64), nullable=False),
    sa.Column('cmf_locked_at', sa.TIMESTAMP(timezone=True), nullable=True),
    sa.Column('cmf_created_at', sa.TIMESTAMP(timezone=True), nullable=False),
    sa.Column('cmf_modified_at', sa.TIMESTAMP(timezone=True), nullable=False),
    sa.Column('cmf_viewed_at', sa.TIMESTAMP(timezone=True), nullable=True),
    sa.Column('cmf_deleted', sa.Boolean(), nullable=False),
    sa.Column('cmf_version', sa.BIGINT(), nullable=True),
    sa.Column('name', sa.String(length=256), nullable=True),
    sa.Column('code', sa.String(length=64), nullable=True),
    sa.Column('system', sa.Boolean(), nullable=False),
    sa.Column('text', sa.TEXT(), nullable=True),
    sa.Column('is_favorite', sa.Boolean(), nullable=True),
    sa.Column('has_tree_nodes', sa.Boolean(), nullable=True),
    sa.Column('tree_node_is_branch', sa.Boolean(), nullable=True),
    sa.Column('tree_hidden', sa.Boolean(), nullable=True),
    sa.Column('orderno', sa.Integer(), nullable=True),
    sa.Column('obj_ui_name', sa.String(length=64), nullable=True),
    sa.Column('obj_ui_module', sa.String(length=64), nullable=True),
    sa.Column('obj_code', sa.String(length=64), nullable=True),
    sa.Column('tree_parent_id', sa.String(length=64), nullable=True),
    sa.Column('is_public', sa.Boolean(), nullable=True),
    sa.Column('ext_url', sa.String(length=4096), nullable=True),
    sa.Column('cmf_author_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_owner_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_owner_assistant_id', sa.String(length=64), nullable=True),
    sa.Column('parent_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_modified_by_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_locked_by_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_import_id', sa.String(length=64), nullable=True),
    sa.Column('obj_id_id', sa.String(length=64), nullable=True),
    sa.Column('obj_parent_id', sa.String(length=64), nullable=True),
    sa.Column('tree_parent_id_id', sa.String(length=64), nullable=True),
    sa.ForeignKeyConstraint(['cmf_import_id'], ['cmf_import.id'], ),
    sa.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_author_id'), 'cmf_menu_tree_item', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_created_at'), 'cmf_menu_tree_item', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_deleted'), 'cmf_menu_tree_item', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_import_id'), 'cmf_menu_tree_item', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_locked_at'), 'cmf_menu_tree_item', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_locked_by_id'), 'cmf_menu_tree_item', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_modified_at'), 'cmf_menu_tree_item', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_modified_by_id'), 'cmf_menu_tree_item', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_owner_assistant_id'), 'cmf_menu_tree_item', ['cmf_owner_assistant_id'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_owner_id'), 'cmf_menu_tree_item', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_version'), 'cmf_menu_tree_item', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_cmf_viewed_at'), 'cmf_menu_tree_item', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_code'), 'cmf_menu_tree_item', ['code'], unique=True)
    op.create_index(op.f('ix_cmf_menu_tree_item_name'), 'cmf_menu_tree_item', ['name'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_obj_code'), 'cmf_menu_tree_item', ['obj_code'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_obj_id_id'), 'cmf_menu_tree_item', ['obj_id_id'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_obj_parent_id'), 'cmf_menu_tree_item', ['obj_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_obj_ui_module'), 'cmf_menu_tree_item', ['obj_ui_module'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_obj_ui_name'), 'cmf_menu_tree_item', ['obj_ui_name'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_orderno'), 'cmf_menu_tree_item', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_parent_id'), 'cmf_menu_tree_item', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_tree_parent_id'), 'cmf_menu_tree_item', ['tree_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_menu_tree_item_tree_parent_id_id'), 'cmf_menu_tree_item', ['tree_parent_id_id'], unique=False)
    # ### end Alembic commands ###


def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_index(op.f('ix_cmf_menu_tree_item_tree_parent_id_id'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_tree_parent_id'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_parent_id'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_orderno'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_obj_ui_name'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_obj_ui_module'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_obj_parent_id'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_obj_id_id'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_obj_code'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_name'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_code'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_viewed_at'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_version'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_owner_id'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_owner_assistant_id'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_modified_by_id'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_modified_at'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_locked_by_id'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_locked_at'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_import_id'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_deleted'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_created_at'), table_name='cmf_menu_tree_item')
    op.drop_index(op.f('ix_cmf_menu_tree_item_cmf_author_id'), table_name='cmf_menu_tree_item')
    op.drop_table('cmf_menu_tree_item')
    # ### end Alembic commands ###
