feat: features 025-032 - favoritos, contatos, trabalhe-conosco, area-cliente, navbar, hero-light-dark, performance-homepage
- feat(025): favoritos locais com FavoritesContext, HeartButton, PublicFavoritesPage
- feat(026): central de contatos admin (leads/contatos unificados)
- feat(027): configuração da página de contato via admin
- feat(028): trabalhe conosco - candidaturas com upload e admin
- feat(029): UX área do cliente - visitas, comparação, perfil
- feat(030): navbar UX - menu mobile, ThemeToggle, useFavorites
- feat(031): hero light/dark - imagens separadas por tema, upload, preview, seed
- feat(032): performance homepage - Promise.all parallel fetches, sessionStorage cache,
preload hero image, loading=lazy nos cards, useInView hook, will-change carrossel,
keyframes em index.css, AgentsCarousel e HomeScrollScene via props
- fix: light mode HomeScrollScene - gradiente, cores de texto, scroll hint
migrations: g1h2i3j4k5l6 (source em leads), h1i2j3k4l5m6 (contact_config),
i1j2k3l4m5n6 (job_applications), j2k3l4m5n6o7 (hero theme images)
This commit is contained in:
parent
6ef5a7a17e
commit
cf5603243c
106 changed files with 11927 additions and 1367 deletions
|
|
@ -0,0 +1,32 @@
|
|||
"""add source and source_detail to contact_leads
|
||||
|
||||
Revision ID: g1h2i3j4k5l6
|
||||
Revises: f2a3b4c5d6e7
|
||||
Create Date: 2026-04-21 00:00:00.000000
|
||||
|
||||
"""
|
||||
|
||||
from alembic import op
|
||||
import sqlalchemy as sa
|
||||
|
||||
|
||||
revision = "g1h2i3j4k5l6"
|
||||
down_revision = "f2a3b4c5d6e7"
|
||||
branch_labels = None
|
||||
depends_on = None
|
||||
|
||||
|
||||
def upgrade():
|
||||
op.add_column(
|
||||
"contact_leads",
|
||||
sa.Column("source", sa.String(100), nullable=True),
|
||||
)
|
||||
op.add_column(
|
||||
"contact_leads",
|
||||
sa.Column("source_detail", sa.String(255), nullable=True),
|
||||
)
|
||||
|
||||
|
||||
def downgrade():
|
||||
op.drop_column("contact_leads", "source_detail")
|
||||
op.drop_column("contact_leads", "source")
|
||||
|
|
@ -0,0 +1,55 @@
|
|||
"""create contact_config table
|
||||
|
||||
Revision ID: h1i2j3k4l5m6
|
||||
Revises: g1h2i3j4k5l6
|
||||
Create Date: 2026-04-21 00:01:00.000000
|
||||
|
||||
"""
|
||||
|
||||
from alembic import op
|
||||
import sqlalchemy as sa
|
||||
|
||||
revision = "h1i2j3k4l5m6"
|
||||
down_revision = "g1h2i3j4k5l6"
|
||||
branch_labels = None
|
||||
depends_on = None
|
||||
|
||||
|
||||
def upgrade():
|
||||
op.create_table(
|
||||
"contact_config",
|
||||
sa.Column("id", sa.Integer(), primary_key=True, autoincrement=True),
|
||||
sa.Column("address_street", sa.String(200), nullable=True),
|
||||
sa.Column("address_neighborhood_city", sa.String(200), nullable=True),
|
||||
sa.Column("address_zip", sa.String(20), nullable=True),
|
||||
sa.Column("phone", sa.String(30), nullable=True),
|
||||
sa.Column("email", sa.String(254), nullable=True),
|
||||
sa.Column("business_hours", sa.Text(), nullable=True),
|
||||
sa.Column(
|
||||
"updated_at",
|
||||
sa.DateTime(),
|
||||
nullable=False,
|
||||
server_default=sa.func.now(),
|
||||
),
|
||||
)
|
||||
# Seed inicial com os valores atualmente hardcoded na página de contato
|
||||
op.execute(
|
||||
"""
|
||||
INSERT INTO contact_config (
|
||||
id, address_street, address_neighborhood_city, address_zip,
|
||||
phone, email, business_hours
|
||||
) VALUES (
|
||||
1,
|
||||
'Rua das Imobiliárias, 123',
|
||||
'Centro — São Paulo, SP',
|
||||
'CEP 01000-000',
|
||||
'(11) 99999-0000',
|
||||
'contato@imobiliariahub.com.br',
|
||||
'Segunda a sexta: 9h às 18h\nSábados: 9h às 13h\nDomingos e feriados: fechado'
|
||||
)
|
||||
"""
|
||||
)
|
||||
|
||||
|
||||
def downgrade():
|
||||
op.drop_table("contact_config")
|
||||
|
|
@ -0,0 +1,44 @@
|
|||
"""add job_applications table
|
||||
|
||||
Revision ID: i1j2k3l4m5n6
|
||||
Revises: h1i2j3k4l5m6
|
||||
Create Date: 2026-04-21 00:00:00.000000
|
||||
|
||||
"""
|
||||
|
||||
import sqlalchemy as sa
|
||||
from alembic import op
|
||||
|
||||
revision = "i1j2k3l4m5n6"
|
||||
down_revision = "h1i2j3k4l5m6"
|
||||
branch_labels = None
|
||||
depends_on = None
|
||||
|
||||
|
||||
def upgrade():
|
||||
op.create_table(
|
||||
"job_applications",
|
||||
sa.Column("id", sa.Integer(), autoincrement=True, nullable=False),
|
||||
sa.Column("name", sa.String(150), nullable=False),
|
||||
sa.Column("email", sa.String(254), nullable=False),
|
||||
sa.Column("phone", sa.String(30), nullable=True),
|
||||
sa.Column("role_interest", sa.String(100), nullable=False),
|
||||
sa.Column("message", sa.Text(), nullable=False),
|
||||
sa.Column("file_name", sa.String(255), nullable=True),
|
||||
sa.Column("status", sa.String(50), nullable=False, server_default="pending"),
|
||||
sa.Column(
|
||||
"created_at",
|
||||
sa.DateTime(),
|
||||
nullable=False,
|
||||
server_default=sa.text("now()"),
|
||||
),
|
||||
sa.PrimaryKeyConstraint("id"),
|
||||
)
|
||||
op.create_index("ix_job_applications_created_at", "job_applications", ["created_at"], unique=False)
|
||||
op.create_index("ix_job_applications_status", "job_applications", ["status"], unique=False)
|
||||
|
||||
|
||||
def downgrade():
|
||||
op.drop_index("ix_job_applications_status", table_name="job_applications")
|
||||
op.drop_index("ix_job_applications_created_at", table_name="job_applications")
|
||||
op.drop_table("job_applications")
|
||||
|
|
@ -0,0 +1,31 @@
|
|||
"""add homepage hero light/dark image urls
|
||||
|
||||
Revision ID: j2k3l4m5n6o7
|
||||
Revises: i1j2k3l4m5n6
|
||||
Create Date: 2026-04-22 00:00:00.000000
|
||||
|
||||
"""
|
||||
|
||||
import sqlalchemy as sa
|
||||
from alembic import op
|
||||
|
||||
revision = "j2k3l4m5n6o7"
|
||||
down_revision = "i1j2k3l4m5n6"
|
||||
branch_labels = None
|
||||
depends_on = None
|
||||
|
||||
|
||||
def upgrade():
|
||||
op.add_column(
|
||||
"homepage_config",
|
||||
sa.Column("hero_image_light_url", sa.String(length=512), nullable=True),
|
||||
)
|
||||
op.add_column(
|
||||
"homepage_config",
|
||||
sa.Column("hero_image_dark_url", sa.String(length=512), nullable=True),
|
||||
)
|
||||
|
||||
|
||||
def downgrade():
|
||||
op.drop_column("homepage_config", "hero_image_dark_url")
|
||||
op.drop_column("homepage_config", "hero_image_light_url")
|
||||
Loading…
Add table
Add a link
Reference in a new issue