feat: atualizar URLs para octtoengenharia.com.br, adicionar SEO dinâmico em projetos e corrigir WhatsApp button
This commit is contained in:
@@ -1,132 +1,34 @@
|
|||||||
# Google Search Console Setup Guide
|
# Google Search Console Setup Guide
|
||||||
|
|
||||||
## Como registrar o Octto Engenharia no Google Search Console
|
## Como registrar no Google Search Console
|
||||||
|
|
||||||
### 1. Acessar Google Search Console
|
1. Acesse: https://search.google.com/search-console
|
||||||
- Acesse: https://search.google.com/search-console
|
2. Clique em "Adicionar propriedade"
|
||||||
- Faça login com sua conta Google
|
3. Digite: `octto-engenharia.com`
|
||||||
|
4. Escolha "DNS" para verificar
|
||||||
|
5. Copie o registro TXT que aparece
|
||||||
|
6. Acesse seu painel de DNS (HostGator, 1&1, etc)
|
||||||
|
7. Adicione o registro TXT
|
||||||
|
8. Volte ao Google e clique em "Verificar"
|
||||||
|
9. Aguarde indexação (pode levar horas)
|
||||||
|
|
||||||
### 2. Adicionar Propriedade
|
## Enviar Sitemap
|
||||||
- Clique em "Adicionar propriedade" (Add property)
|
|
||||||
- Escolha "Domínio" e digite: `octto-engenharia.com`
|
|
||||||
- Clique em "Continuar"
|
|
||||||
|
|
||||||
### 3. Verificar Propriedade (Método DNS)
|
Depois de verificado:
|
||||||
A forma mais simples é via registro DNS:
|
1. Vá para "Sitemaps"
|
||||||
|
2. Adicione: `https://octto-engenharia.com/sitemap.xml`
|
||||||
|
3. Google começa a indexar automaticamente
|
||||||
|
|
||||||
1. Você receberá um registro TXT como:
|
## Verificar Indexação
|
||||||
```
|
|
||||||
google-site-verification=xxxxxxxxxxxxxxxxxxxxx
|
|
||||||
```
|
|
||||||
|
|
||||||
2. Acesse seu painel de controle de DNS (onde seu domínio está hospedado)
|
- Vá para "Cobertura" para ver quais páginas foram indexadas
|
||||||
|
- URLs em verde = indexadas com sucesso
|
||||||
3. Adicione um registro TXT com o código fornecido
|
- Vermelho = problemas
|
||||||
|
|
||||||
4. Aguarde a propagação DNS (pode levar até 24h, mas geralmente é imediato)
|
|
||||||
|
|
||||||
5. Clique em "Verificar" no Google Search Console
|
|
||||||
|
|
||||||
### 4. Enviar Sitemap
|
|
||||||
- No Google Search Console, vá para "Sitemaps"
|
|
||||||
- Adicione: `https://octto-engenharia.com/sitemap.xml`
|
|
||||||
- Google começará a indexar automaticamente
|
|
||||||
|
|
||||||
### 5. Verificar Indexação
|
|
||||||
- Vá para "Cobertura" (Coverage) para verificar quais páginas foram indexadas
|
|
||||||
- Procure por erros ou avisos
|
|
||||||
- As URLs em verde foram indexadas com sucesso
|
|
||||||
|
|
||||||
### 6. Submeter URLs Manualmente (Opcional)
|
|
||||||
Se quiser acelerar a indexação:
|
|
||||||
- Vá para "Inspeção de URL"
|
|
||||||
- Digite a URL que quer indexar
|
|
||||||
- Clique em "Solicitar indexação"
|
|
||||||
|
|
||||||
### 7. Monitorar Performance
|
|
||||||
- Acesse "Performance" para ver:
|
|
||||||
- CTR (Click-Through Rate)
|
|
||||||
- Impressões
|
|
||||||
- Posição média
|
|
||||||
- Cliques
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
## Checklist de SEO Implementado
|
|
||||||
|
|
||||||
✅ **Meta Tags**
|
|
||||||
- Title tags (único para cada página)
|
|
||||||
- Meta descriptions
|
|
||||||
- Meta keywords
|
|
||||||
- Open Graph tags (para compartilhamento social)
|
|
||||||
- Twitter Card tags
|
|
||||||
|
|
||||||
✅ **Structured Data**
|
|
||||||
- schema.org JSON-LD ready
|
|
||||||
- Open Graph implementado
|
|
||||||
|
|
||||||
✅ **Sitemap**
|
|
||||||
- `sitemap.xml` dinâmico
|
|
||||||
- Inclui todas as páginas principais
|
|
||||||
- Inclui todas as páginas de projetos
|
|
||||||
- Suporta múltiplas línguas (pt, en, es)
|
|
||||||
|
|
||||||
✅ **robots.txt**
|
|
||||||
- Configurado para permitir indexação
|
|
||||||
- Direciona para sitemap
|
|
||||||
- Bloqueia /admin e /api
|
|
||||||
|
|
||||||
✅ **URLs Amigáveis**
|
|
||||||
- URLs descritivas e em português
|
|
||||||
- Suporte a múltiplas línguas
|
|
||||||
|
|
||||||
✅ **Performance**
|
|
||||||
- Next.js otimizado para SEO
|
|
||||||
- Imagens otimizadas com Image component
|
|
||||||
- CSS inline onde apropriado
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
## Keywords Recomendadas
|
|
||||||
|
|
||||||
Use estas palavras-chave no conteúdo:
|
|
||||||
|
|
||||||
**Primárias:**
|
|
||||||
- Engenharia de movimentação de carga
|
|
||||||
- Projetos de içamento
|
|
||||||
- Laudos técnicos NR-11
|
|
||||||
- Segurança do trabalho
|
|
||||||
- Adequação de equipamentos
|
|
||||||
|
|
||||||
**Secundárias:**
|
|
||||||
- Inspeção de equipamentos
|
|
||||||
- Consultoria de segurança
|
|
||||||
- Projetos mecânicos
|
|
||||||
- Engenharia industrial
|
|
||||||
- Conformidade regulatória
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
## Próximos Passos
|
## Próximos Passos
|
||||||
|
|
||||||
1. **Link Building**: Obter links de sites relevantes (engenharia, segurança)
|
- Solicitar indexação de URLs específicas em "Inspeção de URL"
|
||||||
2. **Local SEO**: Registrar no Google My Business
|
- Acompanhar em "Performance" depois de alguns dias
|
||||||
3. **Content**: Blog com artigos sobre segurança, normativas, casos de sucesso
|
- Criar conteúdo com boas palavras-chave
|
||||||
4. **Social**: Compartilhar conteúdo em redes sociais
|
- Compartilhar no Google My Business (para aparecer em buscas locais)
|
||||||
5. **Reviews**: Estimular clientes a deixarem avaliações
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
## Dúvidas Frequentes
|
|
||||||
|
|
||||||
**P: Quanto tempo leva para aparecer no Google?**
|
|
||||||
R: Pode levar de 1 a 3 meses para indexação completa. Com bom SEO e backlinks, acelera.
|
|
||||||
|
|
||||||
**P: Por que não aparece para minhas palavras-chave?**
|
|
||||||
R: Pode ser concorrência alta. Foque em long-tail keywords (ex: "laudos NR-11 Jundiaí").
|
|
||||||
|
|
||||||
**P: Preciso pagar para aparecer no Google?**
|
|
||||||
R: Não, SEO orgânico é grátis. Você pode usar Google Ads para aparecer no topo mais rápido (pago).
|
|
||||||
|
|
||||||
**P: Que keywords devem ser prioritárias?**
|
|
||||||
R: Foco em "Engenharia de movimentação de carga [sua cidade]" e normativas (NR-11, NR-12).
|
|
||||||
|
|||||||
@@ -16,9 +16,9 @@ User-agent: Bingbot
|
|||||||
Allow: /
|
Allow: /
|
||||||
|
|
||||||
# Sitemap
|
# Sitemap
|
||||||
Sitemap: https://octto-engenharia.com/sitemap.xml
|
Sitemap: https://octtoengenharia.com.br/sitemap.xml
|
||||||
Sitemap: https://octto-engenharia.com/en/sitemap.xml
|
Sitemap: https://octtoengenharia.com.br/en/sitemap.xml
|
||||||
Sitemap: https://octto-engenharia.com/es/sitemap.xml
|
Sitemap: https://octtoengenharia.com.br/es/sitemap.xml
|
||||||
|
|
||||||
# Crawl delay (optional)
|
# Crawl delay (optional)
|
||||||
Crawl-delay: 1
|
Crawl-delay: 1
|
||||||
|
|||||||
82
frontend/src/app/[locale]/projetos/[id]/metadata.ts
Normal file
82
frontend/src/app/[locale]/projetos/[id]/metadata.ts
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
import { Metadata } from 'next';
|
||||||
|
|
||||||
|
interface Project {
|
||||||
|
id: string;
|
||||||
|
title: string;
|
||||||
|
description: string | null;
|
||||||
|
coverImage: string | null;
|
||||||
|
category: string;
|
||||||
|
client: string | null;
|
||||||
|
completionDate: string | null;
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getProject(id: string): Promise<Project | null> {
|
||||||
|
try {
|
||||||
|
const res = await fetch(`https://octtoengenharia.com.br/api/projects/${id}`, {
|
||||||
|
next: { revalidate: 3600 }, // Cache 1 hora
|
||||||
|
});
|
||||||
|
if (res.ok) {
|
||||||
|
return await res.json();
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Erro ao buscar projeto para metadata:', error);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function generateMetadata(
|
||||||
|
{ params }: { params: { id: string; locale: string } },
|
||||||
|
parent: any
|
||||||
|
): Promise<Metadata> {
|
||||||
|
const project = await getProject(params.id);
|
||||||
|
|
||||||
|
if (!project) {
|
||||||
|
return {
|
||||||
|
title: 'Projeto não encontrado',
|
||||||
|
description: 'O projeto que você procura não existe.',
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
const baseUrl = 'https://octtoengenharia.com.br';
|
||||||
|
const prefix = params.locale === 'pt' ? '' : `/${params.locale}`;
|
||||||
|
const projectUrl = `${baseUrl}${prefix}/projetos/${project.id}`;
|
||||||
|
const description = project.description || `Projeto de ${project.category} da Octto Engenharia${project.client ? ` para ${project.client}` : ''}`;
|
||||||
|
|
||||||
|
const localeMap: Record<string, string> = {
|
||||||
|
pt: 'pt_BR',
|
||||||
|
en: 'en_US',
|
||||||
|
es: 'es_ES',
|
||||||
|
};
|
||||||
|
|
||||||
|
return {
|
||||||
|
title: `${project.title} | Octto Engenharia`,
|
||||||
|
description,
|
||||||
|
keywords: `${project.title}, ${project.category}, engenharia, ${project.client || 'Octto Engenharia'}`,
|
||||||
|
openGraph: {
|
||||||
|
type: 'article',
|
||||||
|
title: project.title,
|
||||||
|
description,
|
||||||
|
url: projectUrl,
|
||||||
|
images: project.coverImage
|
||||||
|
? [
|
||||||
|
{
|
||||||
|
url: project.coverImage,
|
||||||
|
width: 1200,
|
||||||
|
height: 630,
|
||||||
|
alt: project.title,
|
||||||
|
},
|
||||||
|
]
|
||||||
|
: [],
|
||||||
|
locale: localeMap[params.locale] || 'pt_BR',
|
||||||
|
},
|
||||||
|
twitter: {
|
||||||
|
card: 'summary_large_image',
|
||||||
|
title: project.title,
|
||||||
|
description,
|
||||||
|
images: project.coverImage ? [project.coverImage] : [],
|
||||||
|
},
|
||||||
|
alternates: {
|
||||||
|
canonical: projectUrl,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -4,6 +4,7 @@ import Link from "next/link";
|
|||||||
import { notFound } from "next/navigation";
|
import { notFound } from "next/navigation";
|
||||||
import { useState, useEffect } from "react";
|
import { useState, useEffect } from "react";
|
||||||
import { useLocale } from "@/contexts/LocaleContext";
|
import { useLocale } from "@/contexts/LocaleContext";
|
||||||
|
export { generateMetadata } from "./metadata";
|
||||||
|
|
||||||
interface Project {
|
interface Project {
|
||||||
id: string;
|
id: string;
|
||||||
|
|||||||
@@ -19,17 +19,17 @@ export const metadata: Metadata = {
|
|||||||
title: "Octto Engenharia | Movimentação de Carga e Segurança",
|
title: "Octto Engenharia | Movimentação de Carga e Segurança",
|
||||||
description: "Especialistas em engenharia de movimentação de carga, projetos de dispositivos de içamento, laudos técnicos e adequação de equipamentos (NR-11/NR-12).",
|
description: "Especialistas em engenharia de movimentação de carga, projetos de dispositivos de içamento, laudos técnicos e adequação de equipamentos (NR-11/NR-12).",
|
||||||
keywords: "engenharia, movimentação de carga, içamento, laudos técnicos, NR-11, NR-12, segurança do trabalho, projetos mecânicos",
|
keywords: "engenharia, movimentação de carga, içamento, laudos técnicos, NR-11, NR-12, segurança do trabalho, projetos mecânicos",
|
||||||
metadataBase: new URL("https://octto-engenharia.com"),
|
metadataBase: new URL("https://octtoengenharia.com.br"),
|
||||||
openGraph: {
|
openGraph: {
|
||||||
type: "website",
|
type: "website",
|
||||||
locale: "pt_BR",
|
locale: "pt_BR",
|
||||||
url: "https://octto-engenharia.com",
|
url: "https://octtoengenharia.com.br",
|
||||||
siteName: "Octto Engenharia",
|
siteName: "Octto Engenharia",
|
||||||
title: "Octto Engenharia | Movimentação de Carga e Segurança",
|
title: "Octto Engenharia | Movimentação de Carga e Segurança",
|
||||||
description: "Especialistas em engenharia de movimentação de carga, projetos de dispositivos de içamento, laudos técnicos e adequação de equipamentos.",
|
description: "Especialistas em engenharia de movimentação de carga, projetos de dispositivos de içamento, laudos técnicos e adequação de equipamentos.",
|
||||||
images: [
|
images: [
|
||||||
{
|
{
|
||||||
url: "https://octto-engenharia.com/og-image.jpg",
|
url: "https://octtoengenharia.com.br/og-image.jpg",
|
||||||
width: 1200,
|
width: 1200,
|
||||||
height: 630,
|
height: 630,
|
||||||
alt: "Octto Engenharia",
|
alt: "Octto Engenharia",
|
||||||
@@ -54,9 +54,9 @@ export const metadata: Metadata = {
|
|||||||
},
|
},
|
||||||
alternates: {
|
alternates: {
|
||||||
languages: {
|
languages: {
|
||||||
"pt-BR": "https://octto-engenharia.com/pt",
|
"pt-BR": "https://octtoengenharia.com.br/pt",
|
||||||
en: "https://octto-engenharia.com/en",
|
en: "https://octtoengenharia.com.br/en",
|
||||||
es: "https://octto-engenharia.com/es",
|
es: "https://octtoengenharia.com.br/es",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import { MetadataRoute } from 'next';
|
import { MetadataRoute } from 'next';
|
||||||
|
|
||||||
export default async function sitemap(): Promise<MetadataRoute.Sitemap> {
|
export default async function sitemap(): Promise<MetadataRoute.Sitemap> {
|
||||||
const baseUrl = 'https://octto-engenharia.com';
|
const baseUrl = 'https://octtoengenharia.com.br';
|
||||||
const locales = ['', '/en', '/es'];
|
const locales = ['', '/en', '/es'];
|
||||||
|
|
||||||
// Páginas principais
|
// Páginas principais
|
||||||
|
|||||||
@@ -6,9 +6,9 @@ export function JsonLdScript() {
|
|||||||
'@type': 'LocalBusiness',
|
'@type': 'LocalBusiness',
|
||||||
name: 'Octto Engenharia',
|
name: 'Octto Engenharia',
|
||||||
description: 'Especialistas em engenharia de movimentação de carga e segurança do trabalho',
|
description: 'Especialistas em engenharia de movimentação de carga e segurança do trabalho',
|
||||||
url: 'https://octto-engenharia.com',
|
url: 'https://octtoengenharia.com.br',
|
||||||
logo: 'https://octto-engenharia.com/logo.png',
|
logo: 'https://octtoengenharia.com.br/logo.png',
|
||||||
image: 'https://octto-engenharia.com/og-image.jpg',
|
image: 'https://octtoengenharia.com.br/og-image.jpg',
|
||||||
telephone: '+55 13 99803-0036',
|
telephone: '+55 13 99803-0036',
|
||||||
email: 'contato@octto-engenharia.com',
|
email: 'contato@octto-engenharia.com',
|
||||||
areaServed: {
|
areaServed: {
|
||||||
@@ -41,25 +41,25 @@ export function JsonLdScript() {
|
|||||||
{
|
{
|
||||||
'@type': 'CollectionPage',
|
'@type': 'CollectionPage',
|
||||||
name: 'Projetos',
|
name: 'Projetos',
|
||||||
url: 'https://octto-engenharia.com/projetos',
|
url: 'https://octtoengenharia.com.br/projetos',
|
||||||
description: 'Portfólio de projetos de engenharia de movimentação de carga',
|
description: 'Portfólio de projetos de engenharia de movimentação de carga',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'@type': 'CollectionPage',
|
'@type': 'CollectionPage',
|
||||||
name: 'Serviços',
|
name: 'Serviços',
|
||||||
url: 'https://octto-engenharia.com/servicos',
|
url: 'https://octtoengenharia.com.br/servicos',
|
||||||
description: 'Serviços especializados em engenharia e segurança do trabalho',
|
description: 'Serviços especializados em engenharia e segurança do trabalho',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'@type': 'AboutPage',
|
'@type': 'AboutPage',
|
||||||
name: 'Sobre',
|
name: 'Sobre',
|
||||||
url: 'https://octto-engenharia.com/sobre',
|
url: 'https://octtoengenharia.com.br/sobre',
|
||||||
description: 'Conheça mais sobre a Octto Engenharia',
|
description: 'Conheça mais sobre a Octto Engenharia',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'@type': 'ContactPage',
|
'@type': 'ContactPage',
|
||||||
name: 'Contato',
|
name: 'Contato',
|
||||||
url: 'https://octto-engenharia.com/contato',
|
url: 'https://octtoengenharia.com.br/contato',
|
||||||
description: 'Entre em contato com a Octto Engenharia',
|
description: 'Entre em contato com a Octto Engenharia',
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
|
|||||||
@@ -6,30 +6,38 @@ import { useState, useEffect } from 'react';
|
|||||||
|
|
||||||
export default function WhatsAppButton() {
|
export default function WhatsAppButton() {
|
||||||
const { t } = useLanguage();
|
const { t } = useLanguage();
|
||||||
const [whatsappLink, setWhatsappLink] = useState('https://wa.me/5535988229445');
|
const [whatsappLink, setWhatsappLink] = useState('https://wa.me/5513998030036');
|
||||||
|
const [mounted, setMounted] = useState(false);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
// Busca o número do WhatsApp do CMS
|
setMounted(true);
|
||||||
fetch('/api/contact-info')
|
|
||||||
|
// Busca o número do WhatsApp das configurações
|
||||||
|
fetch('/api/settings')
|
||||||
.then(res => res.json())
|
.then(res => res.json())
|
||||||
.then(data => {
|
.then(data => {
|
||||||
if (data.whatsappLink) {
|
if (data.whatsapp) {
|
||||||
setWhatsappLink(data.whatsappLink);
|
const cleanNumber = data.whatsapp.replace(/\D/g, '');
|
||||||
|
setWhatsappLink(`https://wa.me/${cleanNumber}`);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.catch(console.error);
|
.catch(console.error);
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
|
if (!mounted) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Link
|
<Link
|
||||||
href={whatsappLink}
|
href={whatsappLink}
|
||||||
target="_blank"
|
target="_blank"
|
||||||
rel="noopener noreferrer"
|
rel="noopener noreferrer"
|
||||||
className="fixed bottom-6 right-6 z-40 flex flex-row-reverse items-center justify-center bg-[#25D366] text-white w-14 h-14 rounded-full shadow-lg hover:bg-[#20bd5a] transition-all hover:scale-110 group animate-in slide-in-from-bottom-4 duration-700 delay-1000 hover:w-auto hover:px-6"
|
className="fixed bottom-6 right-6 z-40 flex flex-row-reverse items-center justify-center bg-[#25D366] text-white w-14 h-14 rounded-full shadow-lg hover:bg-[#20bd5a] transition-all duration-300 group"
|
||||||
aria-label={t('whatsapp.label')}
|
aria-label={t('whatsapp.label')}
|
||||||
>
|
>
|
||||||
<i className="ri-whatsapp-line text-3xl leading-none"></i>
|
<i className="ri-whatsapp-line text-3xl leading-none group-hover:scale-110 transition-transform duration-300"></i>
|
||||||
<span className="font-bold max-w-0 overflow-hidden group-hover:max-w-xs group-hover:mr-3 transition-all duration-500 whitespace-nowrap">
|
<span className="font-bold text-sm ml-0 group-hover:ml-2 max-w-0 overflow-hidden group-hover:max-w-xs transition-all duration-300 whitespace-nowrap">
|
||||||
{t('whatsapp.label')}
|
{t('whatsapp.label')}
|
||||||
</span>
|
</span>
|
||||||
</Link>
|
</Link>
|
||||||
|
|||||||
Reference in New Issue
Block a user