```

---
title: "Grafico Reservas"
author: "João Pedro Godinho e Giulia Cardoso"
date: "2026-02-12"
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)
library(fredr)
```

```{r}
library(dplyr)
library(highcharter)

cofer_hist <- data.frame(
  Ano = 1999:2025,
  USD = c(71.0,71.1,71.5,67.1,65.9,65.9,66.9,65.5,63.9,64.2,
          62.1,62.1,62.6,61.5,61.2,65.1,65.7,65.4,62.7,61.7,
          60.9,58.9,58.8,58.4,58.4,57.8,56.8),
  EUR = c(17.9,18.3,19.2,23.8,25.2,24.9,24.1,25.2,26.3,26.4,
          27.7,26.0,24.4,24.0,24.2,21.2,19.9,19.1,20.2,20.7,
          20.6,21.3,20.6,20.6,20.0,19.8,20.3),
  JPY = c(6.4,6.1,5.1,4.5,4.1,3.9,3.7,3.2,2.9,3.1,
          2.9,3.7,3.6,4.1,3.8,3.6,4.0,4.0,4.9,5.2,
          5.9,6.0,5.6,5.3,5.7,5.8,5.8),
  GBP = c(2.9,2.8,2.7,2.9,2.8,3.4,3.6,4.4,4.7,4.0,
          4.3,3.9,3.8,4.0,4.0,3.8,4.7,4.4,4.5,4.4,
          4.6,4.7,4.8,4.9,4.9,4.7,4.4),
  CNY = c(0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,
          0.0,0.0,0.0,0.0,0.0,0.0,1.1,1.1,1.2,1.9,
          2.0,2.3,2.8,2.7,2.4,2.2,2.0)
)

atual  <- cofer_hist |> filter(Ano == 2025)
moedas <- c("USD", "EUR", "JPY", "GBP", "CNY")
nomes  <- c("USD — Dólar", "EUR — Euro", "JPY — Iene", "GBP — Libra", "CNY — Yuan")
cores  <- c("#feb712", "#02023c", "#46b1e1", "#808080", "#e63946")
# ── Série principal — colunas verticais ───────────────────────────────────
serie_atual <- list(
  list(
    name         = "Participação em 2025",
    type         = "column",
    colorByPoint = TRUE,
    colors       = cores,
    dataLabels   = list(
      enabled = TRUE,
      format  = "{y}%",
      style   = list(fontSize = "11px", fontWeight = "bold", textOutline = "none")
    ),
    data = lapply(seq_along(moedas), function(i) {
      list(
        name      = nomes[i],
        y         = as.numeric(atual[[moedas[i]]]),
        drilldown = paste0("hist_", moedas[i])
      )
    })
  )
)

# ── Drilldown — linha histórica 1999–2025 ─────────────────────────────────
drilldown_list <- lapply(seq_along(moedas), function(i) {
  list(
    id        = paste0("hist_", moedas[i]),
    name      = paste0(nomes[i], " — Evolução 1999–2025"),
    type      = "line",
    color     = cores[i],
    lineWidth = 2.5,
    marker    = list(radius = 3),
    dataLabels = list(enabled = FALSE),
    data = lapply(seq_len(nrow(cofer_hist)), function(j) {
      list(as.character(cofer_hist$Ano[j]), cofer_hist[[moedas[i]]][j])
    })
  )
})

# ── Gráfico ────────────────────────────────────────────────────────────────
highchart() |>
  hc_chart(
    type            = "column",
    backgroundColor = "#FFFFFF",
    events = list(
      drilldown = JS("function(e) {
        this.setTitle({
          text: e.point.name + ' — Evolução nas Reservas Globais (1999–2025)'
        });
        this.setSubtitle({
          text: 'Clique em Voltar para retornar à visão geral'
        });
        this.xAxis[0].update({ title: { text: 'Ano' } });
        this.yAxis[0].update({ max: null });
      }"),
      drillup = JS("function() {
        this.setTitle({
          text: 'Reservas Cambiais Globais por Moeda (2025)'
        });
        this.setSubtitle({
          text: '% sobre reservas globais divulgadas · Clique numa moeda para ver a evolução histórica | Fonte: IMF COFER'
        });
        this.xAxis[0].update({ title: { text: 'Moeda' } });
        this.yAxis[0].update({ max: 70 });
      }")
    )
  ) |>

  hc_title(
    text  = "Reservas Cambiais Globais por Moeda (2025)",
    style = list(fontSize = "17px", fontWeight = "bold", color = "#1a1a2e")
  ) |>

  hc_subtitle(
    text  = "% sobre reservas globais divulgadas · Clique numa moeda para ver a evolução histórica | Fonte: FMI COFER",
    style = list(fontSize = "11px", color = "#7f8c8d")
  ) |>

  hc_xAxis(
    type          = "category",
    title         = list(text = "Moeda"),
    gridLineWidth = 0
  ) |>

  hc_yAxis(
    title         = list(text = "% das Reservas Globais"),
    labels        = list(format = "{value}%"),
    max           = 70,
    gridLineColor = "#f0f0f0"
  ) |>

  hc_plotOptions(
    column = list(
      borderRadius = 4,
      showInLegend = FALSE
    ),
    line = list(
      animation = list(duration = 1000),
      states    = list(hover = list(lineWidth = 3.5))
    )
  ) |>

  hc_add_series_list(serie_atual) |>

  hc_drilldown(
    allowPointDrilldown = TRUE,
    series              = drilldown_list,
    activeAxisLabelStyle = list(textDecoration = "none", color = "#1a1a2e"),
    breadcrumbs = list(
      buttonTheme = list(
        fill    = "#f0f0f0",
        padding = 8,
        style   = list(color = "#1a1a2e", fontWeight = "bold")
      )
    )
  ) |>

  hc_tooltip(
    valueDecimals = 1,
    pointFormat   = '<span style="color:{point.color}">●</span> {series.name}: <b>{point.y}%</b>'
  ) |>

  hc_legend(enabled = FALSE) |>

  hc_exporting(
    enabled  = TRUE,
    filename = "cofer_historico",
    buttons  = list(contextButton = list(
      menuItems = c("downloadPNG", "downloadPDF", "downloadCSV")
    ))
  ) |>

  hc_credits(
    enabled = TRUE,
    text    = "Gráfico de confecção própria: IbMacro BH",
    href    = "https://data.imf.org",
    style   = list(fontSize = "10px")
  )
```
```

