```

---
title: "Gráfico Atividade Econômica por Setores"
date: "2026-03-11"
output: 
 html_document:
  toc: true
  theme: lumen
  highlight: tango
  code_folding: show
  code_download: true
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = FALSE, message = FALSE, warning = FALSE)

library(dplyr)
library(ggplot2)
library(highcharter)
library(plotly)
library(sidrar)
library(ipeadatar)
library(quantmod)
library(scales)
library(lubridate)
library(rbcb)
library(readxl)
library(writexl)
library(httr)
library(tidyr)
```


```{r}
library(tidyverse)
library(highcharter)
library(lubridate)

# Coletar dados dos setores (IBC-Br setorial) de janeiro/2024 até dezembro/2025
# ATENÇÃO: São números-índice com base 2022 = 100, NÃO são valores em R$ milhões

dados_servicos <- get_series(29606, start_date = "2024-01-01", end_date = "2025-12-30") %>% 
  rename(Servicos = `29606`)  # IBC-Br Serviços (índice) - com ajuste sazonal

dados_agro <- get_series(29602, start_date = "2024-01-01", end_date = "2025-12-30") %>% 
  rename(Agropecuaria = `29602`)  # IBC-Br Agropecuária (índice) - com ajuste sazonal

dados_industria <- get_series(29604, start_date = "2024-01-01", end_date = "2025-12-30") %>% 
  rename(Industria = `29604`)  # IBC-Br Indústria (índice) - com ajuste sazonal

# Combinar todos os dados
dados_setores <- dados_servicos %>%
  left_join(dados_agro, by = "date") %>%
  left_join(dados_industria, by = "date") %>%
  mutate(
    timestamp = datetime_to_timestamp(date),
    # Manter valores originais do índice (base 2022 = 100)
    Servicos_indice = Servicos,
    Agropecuaria_indice = Agropecuaria,
    Industria_indice = Industria
  ) %>%
  select(date, timestamp, Servicos_indice, Agropecuaria_indice, Industria_indice) %>%
  arrange(date)

# Verificar se há dados
if(nrow(dados_setores) == 0) {
  stop("Não foram encontrados dados para o período selecionado. Verifique se os códigos estão corretos e se os dados estão disponíveis.")
}

# Calcular limites do eixo Y para zoom automático
y_min <- min(c(dados_setores$Servicos_indice, 
               dados_setores$Agropecuaria_indice, 
               dados_setores$Industria_indice), na.rm = TRUE)
y_max <- max(c(dados_setores$Servicos_indice, 
               dados_setores$Agropecuaria_indice, 
               dados_setores$Industria_indice), na.rm = TRUE)

# Adicionar uma margem de 5% para melhor visualização
y_range <- y_max - y_min
y_min_ajustado <- max(0, floor(y_min - 0.05 * y_range))
y_max_ajustado <- ceiling(y_max + 0.05 * y_range)

# Criar o gráfico com pontos (markers) nas linhas
highchart(type = "stock") %>%
  # Série: Serviços
  hc_add_series(
    data = list_parse2(dados_setores %>% select(timestamp, Servicos_indice)),
    type = "line",
    name = "IBC-Br Serviços",
    color = "#46b1e1",  # Azul claro
    lineWidth = 2,
    marker = list(
      enabled = TRUE,        # HABILITA OS PONTOS
      radius = 3,            # Tamanho do ponto
      symbol = "circle",     # Formato: círculo
      fillColor = "#46b1e1", # Cor de preenchimento
      lineWidth = 1,         # Borda do ponto
      lineColor = "#FFFFFF"  # Cor da borda (branco para destacar)
    ),
    yAxis = 0,
    tooltip = list(valueDecimals = 1)
  ) %>%
  # Série: Agropecuária
  hc_add_series(
    data = list_parse2(dados_setores %>% select(timestamp, Agropecuaria_indice)),
    type = "line",
    name = "IBC-Br Agropecuária",
    color = "#feb712",  # Dourado
    lineWidth = 2,
    marker = list(
      enabled = TRUE,
      radius = 3,
      symbol = "circle",
      fillColor = "#feb712",
      lineWidth = 1,
      lineColor = "#FFFFFF"
    ),
    yAxis = 0,
    tooltip = list(valueDecimals = 1)
  ) %>%
  # Série: Indústria
  hc_add_series(
    data = list_parse2(dados_setores %>% select(timestamp, Industria_indice)),
    type = "line",
    name = "IBC-Br Indústria",
    color = "#02023c",  # Azul escuro
    lineWidth = 2,
    marker = list(
      enabled = TRUE,
      radius = 3,
      symbol = "circle",
      fillColor = "#02023c",
      lineWidth = 1,
      lineColor = "#FFFFFF"
    ),
    yAxis = 0,
    tooltip = list(valueDecimals = 1)
  ) %>%
  hc_yAxis(
    title = list(text = "Índice (base: 2022 = 100)"),
    opposite = FALSE,
    labels = list(format = "{value}"),
    min = y_min_ajustado,
    max = y_max_ajustado,
    plotLines = list(
      list(
        value = 100,
        color = "#666666",
        dashStyle = "dash",
        width = 1,
        label = list(text = "Base (2022 = 100)")
      )
    )
  ) %>%
  hc_xAxis(
    type = 'datetime',
    labels = list(format = '{value:%b %Y}')
  ) %>%
  hc_title(text = "IBC-Br por Setor - Atividade Econômica com Ajuste Sazonal") %>%
  hc_subtitle(text = "Índice base: 2022 = 100 - Período: Jan/2024 a Dez/2025") %>%
  hc_credits(
    enabled = TRUE, 
    text = "Fonte: Banco Central do Brasil (SGS - Códigos: 29606, 29602, 29604)"
  ) %>%
  hc_rangeSelector(
    enabled = TRUE,
    buttons = list(
      list(type = 'month', count = 3, text = '3M'),
      list(type = 'month', count = 6, text = '6M'),
      list(type = 'all', text = 'Todo período')
    ),
    selected = 2
  ) %>%
  hc_tooltip(
    shared = TRUE,
    headerFormat = '<span style="font-size: 12px"><b>{point.key}</b></span><br/>',
    pointFormat = '<span style="color:{series.color}">●</span> {series.name}: <b>{point.y:.1f}</b><br/>',
    valueDecimals = 1
  ) %>%
  hc_legend(
    enabled = TRUE,
    align = "center",
    verticalAlign = "bottom",
    layout = "horizontal"
  ) %>%
  hc_plotOptions(
    series = list(
      animation = TRUE,
      connectNulls = TRUE
    )
  ) %>%
hc_exporting(
    enabled = TRUE,
    filename = "IBC-Br_por_setor",
    buttons = list(
      contextButton = list(
        text = "Baixar gráfico",
        menuItems = c("downloadPNG", "downloadJPEG", "downloadPDF", "downloadSVG")
      )
    ),
    chartOptions = list(
      chart = list(backgroundColor = "#FFFFFF"),
      plotOptions = list(
        series = list(
          dataLabels = list(enabled = FALSE)
        )
      )
    )
  )
```
```

