Tips & Tricks

Como Implementar Analytics com Claude Code

Aprenda a implementar analytics usando o Claude Code. Inclui exemplos práticos de código e orientação passo a passo.

Desafios da Implementação de Analytics

A medição do comportamento do usuário é a base para melhorias de produto, mas implementar considerando múltiplos serviços de analytics, privacidade e impacto na performance não é simples. Com o Claude Code, você pode construir rapidamente uma infraestrutura de analytics extensível.

Camada Unificada de Rastreamento de Eventos

> Crie uma camada de rastreamento unificada que suporte múltiplos provedores de analytics.
> Deve enviar simultaneamente para Google Analytics, Mixpanel e API própria.
interface TrackingEvent {
  name: string;
  properties?: Record<string, any>;
  timestamp?: Date;
}

interface AnalyticsProvider {
  name: string;
  track(event: TrackingEvent): void;
  pageView(path: string, title: string): void;
  identify(userId: string, traits?: Record<string, any>): void;
}

class AnalyticsManager {
  private providers: AnalyticsProvider[] = [];
  private queue: TrackingEvent[] = [];
  private isReady = false;

  addProvider(provider: AnalyticsProvider) {
    this.providers.push(provider);
  }

  track(name: string, properties?: Record<string, any>) {
    const event: TrackingEvent = { name, properties, timestamp: new Date() };

    if (!this.isReady) {
      this.queue.push(event);
      return;
    }

    this.providers.forEach((p) => {
      try { p.track(event); }
      catch (e) { console.warn(`Erro de rastreamento em ${p.name}:`, e); }
    });
  }

  pageView(path: string, title: string) {
    this.providers.forEach((p) => p.pageView(path, title));
  }

  identify(userId: string, traits?: Record<string, any>) {
    this.providers.forEach((p) => p.identify(userId, traits));
  }

  flush() {
    this.isReady = true;
    this.queue.forEach((event) => this.track(event.name, event.properties));
    this.queue = [];
  }
}

export const analytics = new AnalyticsManager();

Provedor do Google Analytics

class GAProvider implements AnalyticsProvider {
  name = 'Google Analytics';

  track(event: TrackingEvent) {
    window.gtag?.('event', event.name, event.properties);
  }

  pageView(path: string, title: string) {
    window.gtag?.('event', 'page_view', { page_path: path, page_title: title });
  }

  identify(userId: string) {
    window.gtag?.('set', { user_id: userId });
  }
}

Utilização com React Hooks

import { useEffect } from 'react';
import { useLocation } from 'react-router-dom';

export function usePageTracking() {
  const location = useLocation();

  useEffect(() => {
    analytics.pageView(location.pathname, document.title);
  }, [location.pathname]);
}

export function useTrackEvent() {
  return (name: string, properties?: Record<string, any>) => {
    analytics.track(name, properties);
  };
}

// Exemplo de uso
function ProductPage({ product }: { product: Product }) {
  const trackEvent = useTrackEvent();

  const handleAddToCart = () => {
    trackEvent('add_to_cart', {
      productId: product.id,
      price: product.price,
      category: product.category,
    });
  };

  return <button onClick={handleAddToCart}>Adicionar ao carrinho</button>;
}

Privacidade (Gerenciamento de Consentimento)

class ConsentManager {
  private consent: Record<string, boolean> = {};

  setConsent(category: string, allowed: boolean) {
    this.consent[category] = allowed;
    localStorage.setItem('analytics_consent', JSON.stringify(this.consent));
  }

  isAllowed(category: string): boolean {
    return this.consent[category] ?? false;
  }

  loadSavedConsent() {
    const saved = localStorage.getItem('analytics_consent');
    if (saved) this.consent = JSON.parse(saved);
  }
}

Resumo

Com o Claude Code, você pode construir uma infraestrutura completa de analytics – desde rastreamento unificado para múltiplos provedores até React Hooks e privacidade. Para integração com testes A/B, consulte o guia de implementação de testes A/B, e para medição de performance, consulte otimização de performance.

Para informações sobre a configuração do Google Analytics, consulte a documentação oficial do GA4.

#Claude Code #analytics #tracking #React #TypeScript