# Load necessary libraries
library(ggplot2)
library(dplyr)
library(tidyr)
library(gridExtra)
library(grid)
library(ggthemes)
library(scales)

# Define the custom theme and scale functions from plot-bar-synthetic.r
theme_Publication <- function(base_size=14, base_family="sans") {
  (theme_foundation(base_size=base_size, base_family=base_family)
   + theme(plot.title = element_text(face = "bold",
                                     size = rel(1.2), hjust = 0.5),
           text = element_text(),
           panel.background = element_rect(colour = NA),
           plot.background = element_rect(colour = NA),
           panel.border = element_rect(colour = NA),
           axis.title = element_text(face = "bold",size = rel(1.2)),
           axis.title.y = element_text(angle=90,vjust =2),
           axis.title.x = element_text(vjust = -0.2),
           axis.text = element_text(), 
           axis.line = element_line(colour="black"),
           axis.ticks = element_line(),
           panel.grid.major = element_line(colour="#f0f0f0"),
           panel.grid.minor = element_blank(),
           legend.key = element_rect(colour = NA),
           legend.position = "bottom",
           legend.direction = "horizontal",
           legend.key.size= unit(0.2, "cm"),
           legend.spacing = unit(0, "cm"),
           legend.title = element_text(face="italic"),
           plot.margin=unit(c(10,5,5,5),"mm"),
           strip.background=element_rect(colour="#f0f0f0",fill="#f0f0f0"),
           strip.text = element_text(face="bold")
   ))
}

scale_fill_Publication <- function(...){
  discrete_scale("fill","Publication",manual_pal(values = c("#0f7ba2","#7fc97f","#dd5129")), ...)
}

# Create data frame with the decreasing CHD risk/increasing HRT sequence
treatment_data <- data.frame(
  sequence = c(
    # Sequence that shows increasing HRT rates
    "Overall", 
    "Age < 55", 
    "Age < 55, Very High Function (≥ 95)",
    "Age < 55, Very High Function (≥ 95), Optimal BMI (21-23)",
    "Age < 55, Very High Function (≥ 95), Optimal BMI (21-23), Never Smoker",
    "Age < 55, Very High Function (≥ 95), Optimal BMI (21-23), Never Smoker, Post-Grad Education",
    "Age < 55, Very High Function (≥ 95), Optimal BMI (21-23), Never Smoker, Post-Grad Ed., Recent Menopause"
  ),
  
  probability = c(
    # Updated HRT probability values (P(A=1))
    0.3330,
    0.4896,
    0.5383,
    0.6186,
    0.6111,
    0.6939,
    0.7105
  ),
  
  subgroup_size = c(
    # Updated subgroup sizes
    51824,
    7040,
    2883,
    679,
    342,
    49,
    38
  ),
  
  group = rep("Lower Risk Subgroups", 7),  # Add a group column for faceting
  subgroup_num = 1:7
)

# Create factor levels to ensure proper ordering
treatment_data$group <- factor(treatment_data$group)

treatment_data$sequence <- factor(treatment_data$sequence, 
                                  levels = treatment_data$sequence)

# Create background gradient data - INVERTED so darkest at p=0.5
gradient_data <- data.frame(
  p = seq(0, 1, length.out = 100),
  uncertainty = 2 * abs(0.5 - seq(0, 1, length.out = 100)),  # Inverted calculation
  group = "Lower Risk Subgroups"  # Same group for faceting
)

# Create the line plot visualization with faceting for the title strip
p <- ggplot() +
  # # Add background gradient for uncertainty - INVERTED color gradient
  # geom_rect(data = gradient_data,
  #           aes(xmin = -Inf, xmax = Inf, 
  #               ymin = p, ymax = lead(p, default = 1),
  #               fill = uncertainty),
  #           alpha = 0.25) +
  # scale_fill_gradient(high = "white", low = "darkred", guide = "none") +  # Inverted colors
  # Add existing line plot elements
  geom_line(data = treatment_data, aes(x = subgroup_num, y = probability),
            size = 1.2, color = "#0f7ba2") +
  geom_point(data = treatment_data, aes(x = subgroup_num, y = probability),
             size = 4, shape = 21, fill = "white", color = "#0f7ba2") +
  geom_text(data = treatment_data, aes(x = subgroup_num, y = probability, 
                                       label = paste0(round(probability*100, 1), "%")), 
            vjust = -1.5, size = 3.5) +
  # Add facet for the title strip
  facet_grid(. ~ group) +
  labs(x = "",
       y = "Probability of HRT (A=1)") +  # Remove the title as it's replaced by facet
  scale_x_continuous(breaks = 1:7, 
                     labels = c("Overall", "Age<55", "High\nFunction", "Optimal\nBMI", 
                                "Never\nSmoker", "Higher\nEducation", "Recent\nMenopause")) +
  scale_y_continuous(limits = c(0.3, 0.85), breaks = seq(0.3, 0.8, by = 0.1)) +
  theme_Publication() +
  theme(
    legend.position = "none",
    strip.text = element_text(size = rel(1.1), face = "bold"),
    strip.background = element_rect(fill = "#f0f0f0"),  # Match the gray color from the example
    panel.spacing = unit(1, "lines"),
    axis.text.x = element_text(angle = 0, hjust = 0.5)
  )

# Display the plot
print(p)

# Save the plot
# ggsave("hrt_probability_progression.png", p, width = 10, height = 6, dpi = 300)