1 Average Sleep Over the Ages

This chart shows how our average sleep duration changes as we age. Notice the decline during adolescence, followed by a more gradual change throughout adulthood.

sleep_vs_age_plot <- timeuse_df %>%
  filter(activity == "Sleep", age < 90, age >= 6) %>%
  group_by(person_id, age, mult) %>%
  summarise(total_sleep_mins = sum(duration_mins, na.rm = TRUE),
            .groups = 'drop') %>%
  group_by(age) %>%
  summarise(avg_sleep_weighted_mins = weighted.mean(total_sleep_mins, w = mult, na.rm = TRUE)) %>%
  mutate(avg_sleep_hours = avg_sleep_weighted_mins / 60) %>%
  ggplot(aes(x = age, y = avg_sleep_hours)) +
  geom_smooth(
    method = "loess",
    se = TRUE,
    color = "black",
    fill = "gray80",
    linewidth = 0.8
  ) +
  scale_y_continuous(limits = c(0, 12), breaks = seq(0, 12, by = 2)) +
  scale_x_continuous(breaks = seq(10, 90, by = 20), limits = c(6, 95)) +
  labs(
    title = "Average daily sleep across ages",
    x = "Age (years)",
    y = "Sleep (hours/day)",
    caption = "Source: National Time Use Survey 2024"
  ) +
  theme_minimal() +
  theme(
    text = element_text(family = "ath", size = 9),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 10,
      margin = margin(b = 8)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 7,
      color = "gray50",
      hjust = 0
    ),
    axis.title = element_text(family = "ath", size = 9),
    axis.text = element_text(size = 8),
    panel.grid.minor = element_blank(),
    panel.grid.major = element_line(color = "gray90", linewidth = 0.3),
    plot.margin = margin(10, 10, 10, 10)
  )

sleep_vs_age_plot
## `geom_smooth()` using formula = 'y ~ x'

# --- Essential Sleep Only ---

night_sleep_vs_age_plot <- timeuse_df %>%
  filter(activity_code == "Night sleep/essential sleep", age < 90, age >= 6) %>%
  group_by(person_id, age, mult) %>%
  summarise(total_sleep_mins = sum(duration_mins, na.rm = TRUE),
            .groups = 'drop') %>%
  group_by(age) %>%
  summarise(avg_sleep_weighted_mins = weighted.mean(total_sleep_mins, w = mult, na.rm = TRUE)) %>%
  mutate(avg_sleep_hours = avg_sleep_weighted_mins / 60) %>%
  ggplot(aes(x = age, y = avg_sleep_hours)) +
  geom_smooth(
    method = "loess",
    se = TRUE,
    color = "navy",
    fill = "lightblue",
    linewidth = 0.8
  ) +
  scale_y_continuous(limits = c(0, 12), breaks = seq(0, 12, by = 2)) +
  scale_x_continuous(breaks = seq(10, 90, by = 20), limits = c(6, 95)) +
  labs(
    title = "Night sleep across ages",
    x = "Age (years)",
    y = "Sleep (hours/day)",
    caption = "Source: National Time Use Survey 2024"
  ) +
  theme_minimal() +
  theme(
    text = element_text(family = "ath", size = 9),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 12,
      margin = margin(b = 8)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 7,
      color = "gray50",
      hjust = 0
    ),
    axis.title = element_text(family = "ath", size = 9),
    axis.text = element_text(size = 10),
    panel.grid.minor = element_blank(),
    panel.grid.major = element_line(color = "gray90", linewidth = 0.3),
    plot.margin = margin(10, 10, 10, 10)
  )

night_sleep_vs_age_plot
## `geom_smooth()` using formula = 'y ~ x'

2 A Day in the Life Across Age Groups

high_level_summary <- timeuse_df %>%
  filter(!is.na(activity) & activity != "Unclassified") %>%
  mutate(
    activity_group = case_when(
      activity == "Sleep" ~ "Sleep",
      activity %in% c("Eating & Drinking", "Personal Hygiene & Health", "Receiving Care") ~ "Personal Care",
      activity %in% c(
        "Formal Employment",
        "Household Enterprise (Goods)",
        "Household Enterprise (Services)",
        "Work-Related Training",
        "Seeking Employment",
        "Setting up a Business"
      ) ~ "Paid Work",
      activity %in% c(
        "Food & Meal Management",
        "Cleaning & Maintenance",
        "Childcare & Instruction",
        "Shopping",
        "Agriculture & Fishing (Own-Use)",
        "Community Volunteering",
        "Direct Volunteering"
      ) ~ "Unpaid Work & Care",
      activity %in% c("Formal Education", "Homework", "Additional Study") ~ "Learning",
      TRUE ~ "Leisure, Social & Travel"
    )
  )

person_activity_group_summary <- high_level_summary %>%
  group_by(person_id, activity_group) %>%
  summarise(total_duration = sum(duration_mins, na.rm = TRUE),
            .groups = "drop")

stacking_order <- c(
  "Sleep",
  "Personal Care",
  "Paid Work",
  "Unpaid Work & Care",
  "Learning",
  "Leisure, Social & Travel"
)

# Summary for Total Population
all_persons_age_group <- high_level_summary %>%
  mutate(age_group = cut(
    age,
    breaks = c(5, 14, 24, 59, Inf),
    labels = c(
      "Children\n(6-14)",
      "Youth\n(15-24)",
      "Adults\n(25-59)",
      "Elderly\n(60+)"
    ),
    right = TRUE,
    include.lowest = TRUE
  )) %>%
  filter(!is.na(age_group)) %>%
  distinct(person_id, age_group, mult)

age_group_summary_total <- all_persons_age_group %>%
  tidyr::crossing(activity_group = unique(person_activity_group_summary$activity_group)) %>%
  left_join(person_activity_group_summary,
            by = c("person_id", "activity_group")) %>%
  mutate(total_duration = ifelse(is.na(total_duration), 0, total_duration)) %>%
  group_by(age_group, activity_group) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60,
            .groups = "drop") %>%
  mutate(activity_group = factor(activity_group, levels = stacking_order))

# Summary by Gender
all_persons_age_gender_group <- high_level_summary %>%
  filter(gender %in% c("male", "female")) %>%
  mutate(age_group = cut(
    age,
    breaks = c(5, 14, 24, 59, Inf),
    labels = c(
      "Children\n(6-14)",
      "Youth\n(15-24)",
      "Adults\n(25-59)",
      "Elderly\n(60+)"
    ),
    right = TRUE,
    include.lowest = TRUE
  )) %>%
  filter(!is.na(age_group)) %>%
  distinct(person_id, age_group, gender, mult)

age_gender_group_summary <- all_persons_age_gender_group %>%
  tidyr::crossing(activity_group = unique(person_activity_group_summary$activity_group)) %>%
  left_join(person_activity_group_summary,
            by = c("person_id", "activity_group")) %>%
  mutate(total_duration = ifelse(is.na(total_duration), 0, total_duration)) %>%
  group_by(age_group, gender, activity_group) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60,
            .groups = "drop") %>%
  mutate(activity_group = factor(activity_group, levels = stacking_order))

# Summary by Sector
all_persons_age_sector_group <- high_level_summary %>%
  mutate(age_group = cut(
    age,
    breaks = c(5, 14, 24, 59, Inf),
    labels = c(
      "Children\n(6-14)",
      "Youth\n(15-24)",
      "Adults\n(25-59)",
      "Elderly\n(60+)"
    ),
    right = TRUE,
    include.lowest = TRUE
  )) %>%
  filter(!is.na(age_group)) %>%
  distinct(person_id, age_group, sector, mult)

age_sector_group_summary <- all_persons_age_sector_group %>%
  tidyr::crossing(activity_group = unique(person_activity_group_summary$activity_group)) %>%
  left_join(person_activity_group_summary,
            by = c("person_id", "activity_group")) %>%
  mutate(total_duration = ifelse(is.na(total_duration), 0, total_duration)) %>%
  group_by(age_group, sector, activity_group) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60,
            .groups = "drop") %>%
  mutate(activity_group = factor(activity_group, levels = stacking_order))



# 1. Define consistent colors and a reusable plotting function
activity_colors <- c(
  "Sleep" = "#1B9E77",
  "Personal Care" = "#D95F02",
  "Paid Work" = "#7570B3",
  "Unpaid Work & Care" = "#E7298A",
  "Learning" = "#666666",
  "Leisure, Social & Travel" = "#E6AB02"
)

create_age_strips_plot <- function(data, x_var = "age_group", main_title) {
  ggplot(data, aes(x = .data[[x_var]], y = avg_hours, fill = activity_group)) +
    geom_col(position = "fill", colour = "white", linewidth = 0.2) +
    scale_y_continuous(labels = scales::percent_format(accuracy = 1)) +
    scale_fill_manual(values = activity_colors, name = "") +
    labs(
      title = main_title,
      x = NULL,
      y = "% of day",
      caption = "Source: National Time Use Survey 2024"
    ) +
    theme_minimal() +
    theme(
      text = element_text(family = "ath", size = 8),
      plot.title = element_text(
        family = "ath",
        face = "bold",
        size = 12,
        margin = margin(b = 8)
      ),
      plot.caption = element_text(
        family = "ath",
        size = 7,
        color = "gray50",
        hjust = 0
      ),
      legend.position = "bottom",
      legend.text = element_text(size = 9),
      legend.key.size = unit(0.3, "cm"),
      axis.text = element_text(size = 8),
      axis.text.x = element_text(lineheight = 0.4),
      panel.grid = element_blank(),
      plot.margin = margin(10, 10, 10, 10)
    ) +
    guides(fill = guide_legend(nrow = 2, byrow = TRUE))
}

# 2. Generate the individual plots using the function
age_strips_plot_total <- create_age_strips_plot(
  data = age_group_summary_total, 
  main_title = "Time use by age group"
)

age_strips_plot_male <- create_age_strips_plot(
  data = age_gender_group_summary %>% filter(gender == "male"),
  main_title = "Time use by age: Men"
)

age_strips_plot_female <- create_age_strips_plot(
  data = age_gender_group_summary %>% filter(gender == "female"),
  main_title = "Time use by age: Women"
)

age_strips_plot_rural <- create_age_strips_plot(
  data = age_sector_group_summary %>% filter(sector == "Rural"),
  main_title = "Time use by age: Rural"
)

age_strips_plot_urban <- create_age_strips_plot(
  data = age_sector_group_summary %>% filter(sector == "Urban"),
  main_title = "Time use by age: Urban"
)


# 3. Generate the combined plot (it's different due to faceting)
combined_gender_strips_plot <- age_gender_group_summary %>%
  mutate(gender = str_to_title(gender)) %>%
  ggplot(aes(x = gender, y = avg_hours, fill = activity_group)) +
  geom_col(
    position = "fill",
    width = 0.8,
    color = "white",
    linewidth = 0.2
  ) +
  facet_wrap( ~ age_group, nrow = 1) +
  scale_y_continuous(labels = scales::percent_format(accuracy = 1)) +
  scale_fill_manual(values = activity_colors, name = "") +
  labs(
    title = "Time use by gender and age",
    x = NULL,
    y = "% of day",
    caption = "Source: National Time Use Survey 2024"
  ) +
  theme_minimal() +
  theme(
    text = element_text(family = "ath", size = 8),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 10,
      margin = margin(b = 8)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 7,
      color = "gray50",
      hjust = 0
    ),
    legend.position = "bottom",
    legend.text = element_text(size = 7),
    legend.key.size = unit(0.3, "cm"),
    strip.text = element_text(face = "bold", size = 8, lineheight = 0.4),
    axis.text = element_text(size = 7),
    panel.grid = element_blank(),
    panel.spacing = unit(0.3, "lines"),
    plot.margin = margin(10, 10, 10, 10)
  ) +
  guides(fill = guide_legend(nrow = 2, byrow = TRUE))

age_strips_plot_rural

age_strips_plot_urban

age_strips_plot_total

age_strips_plot_male

age_strips_plot_female

combined_gender_strips_plot

2.1 Rural vs. Urban Comparison

all_persons_age_gender_sector_group <- high_level_summary %>%
  filter(gender %in% c("male", "female")) %>%
  mutate(age_group = cut(
    age,
    breaks = c(5, 14, 24, 59, Inf),
    labels = c(
      "Children\n(6-14)",
      "Youth\n(15-24)",
      "Adults\n(25-59)",
      "Elderly\n(60+)"
    ),
    right = TRUE,
    include.lowest = TRUE
  )) %>%
  filter(!is.na(age_group)) %>%
  distinct(person_id, age_group, gender, sector, mult)

age_gender_sector_group_summary <- all_persons_age_gender_sector_group %>%
  tidyr::crossing(activity_group = unique(person_activity_group_summary$activity_group)) %>%
  left_join(person_activity_group_summary,
            by = c("person_id", "activity_group")) %>%
  mutate(total_duration = ifelse(is.na(total_duration), 0, total_duration)) %>%
  group_by(age_group, gender, sector, activity_group) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60,
            .groups = "drop") %>%
  mutate(activity_group = factor(activity_group, levels = stacking_order))


male_sector_strips_plot <- age_gender_sector_group_summary %>%
  filter(gender == "male") %>%
  ggplot(aes(x = sector, y = avg_hours, fill = activity_group)) +
  geom_col(
    position = "fill",
    width = 0.8,
    color = "white",
    linewidth = 0.2
  ) +
  facet_wrap( ~ age_group, nrow = 1) +
  scale_y_continuous(labels = scales::percent_format(accuracy = 1)) +
  scale_fill_manual(values = activity_colors, name = "") +
  labs(
    title = "Men: Time use by location and age",
    x = NULL,
    y = "% of day",
    caption = "Source: National Time Use Survey 2024"
  ) +
  theme_minimal() +
  theme(
    text = element_text(family = "ath", size = 8),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 10,
      margin = margin(b = 8)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 7,
      color = "gray50",
      hjust = 0
    ),
    legend.position = "bottom",
    legend.text = element_text(size = 7),
    legend.key.size = unit(0.3, "cm"),
    strip.text = element_text(face = "bold", size = 8, lineheight = 0.4),
    axis.text = element_text(size = 7),
    panel.grid = element_blank(),
    panel.spacing = unit(0.3, "lines"),
    plot.margin = margin(10, 10, 10, 10)
  ) +
  guides(fill = guide_legend(nrow = 2, byrow = TRUE))

female_sector_strips_plot <- age_gender_sector_group_summary %>%
  filter(gender == "female") %>%
  ggplot(aes(x = sector, y = avg_hours, fill = activity_group)) +
  geom_col(
    position = "fill",
    width = 0.8,
    color = "white",
    linewidth = 0.2
  ) +
  facet_wrap( ~ age_group, nrow = 1) +
  scale_y_continuous(labels = scales::percent_format(accuracy = 1)) +
  scale_fill_manual(values = activity_colors, name = "") +
  labs(
    title = "Women: Time use by location and age",
    x = NULL,
    y = "% of day",
    caption = "Source: National Time Use Survey 2024"
  ) +
  theme_minimal() +
  theme(
    text = element_text(family = "ath", size = 8),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 10,
      margin = margin(b = 8)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 7,
      color = "gray50",
      hjust = 0
    ),
    legend.position = "bottom",
    legend.text = element_text(size = 7),
    legend.key.size = unit(0.3, "cm"),
    strip.text = element_text(face = "bold", size = 8, lineheight = 0.4),
    axis.text = element_text(size = 7),
    panel.grid = element_blank(),
    panel.spacing = unit(0.3, "lines"),
    plot.margin = margin(10, 10, 10, 10)
  ) +
  guides(fill = guide_legend(nrow = 2, byrow = TRUE))

male_sector_strips_plot

female_sector_strips_plot

3 Exports and Download

dir.create("shortlisted_textbook", showWarnings = FALSE)

export_theme <- theme(
  plot.title = element_text(size = 20, face = "bold"),
  plot.subtitle = element_text(size = 16),
  plot.caption = element_text(size = 11),
  axis.title = element_text(size = 14),
  axis.text = element_text(size = 14),
  legend.text = element_text(size = 14),
  legend.title = element_text(size = 14),
  strip.text = element_text(size = 14, face = "bold"),
  legend.key.size = unit(0.4, "cm")
)

# 1. Sleep plots - compact single-column width (4" x 3.5")
ggsave(filename = "shortlisted_textbook/01_sleep_vs_age.png",
       plot = sleep_vs_age_plot + export_theme,
       width = 2, height = 2, dpi = 300, units = "in")
## `geom_smooth()` using formula = 'y ~ x'
ggsave(filename = "shortlisted_textbook/02_essential_sleep_vs_age.png",
       plot = night_sleep_vs_age_plot + export_theme,
       width = 2, height = 2, dpi = 300, units = "in")
## `geom_smooth()` using formula = 'y ~ x'
# 2. Simple strip plots - slightly wider (5" x 4")
ggsave(filename = "shortlisted_textbook/03_age_strips_total.png",
       plot = age_strips_plot_total + export_theme,
       width = 3, height = 3, dpi = 300, units = "in")

ggsave(filename = "shortlisted_textbook/04_age_strips_rural.png",
       plot = age_strips_plot_rural + export_theme,
       width = 3, height = 3, dpi = 300, units = "in")

ggsave(filename = "shortlisted_textbook/05_age_strips_urban.png",
       plot = age_strips_plot_urban + export_theme,
       width = 3, height = 3, dpi = 300, units = "in")

# 3. Gender-specific plots (5" x 4")
ggsave(filename = "shortlisted_textbook/06_age_strips_male.png",
       plot = age_strips_plot_male + export_theme,
       width = 3, height = 3, dpi = 300, units = "in")

ggsave(filename = "shortlisted_textbook/07_age_strips_female.png",
       plot = age_strips_plot_female + export_theme,
       width = 3, height = 3, dpi = 300, units = "in")

# 4. Faceted plots - wider for readability (6.5" x 4")
ggsave(filename = "shortlisted_textbook/08_combined_gender_strips.png",
       plot = combined_gender_strips_plot + export_theme,
       width = 4, height = 3, dpi = 300, units = "in")

ggsave(filename = "shortlisted_textbook/09_male_sector_strips.png",
       plot = male_sector_strips_plot + export_theme,
       width = 4, height = 3, dpi = 300, units = "in")

ggsave(filename = "shortlisted_textbook/10_female_sector_strips.png",
       plot = female_sector_strips_plot + export_theme,
       width = 4, height = 3, dpi = 300, units = "in")
zip_file <- "time_use_textbook_bundle.zip"
files_to_zip <- c(
  list.files("shortlisted_textbook", full.names = TRUE, pattern = "\\.png$"),
  "shortlisted-tus-2024.Rmd"
)

if (file.exists(zip_file)) file.remove(zip_file)
zip::zip(zipfile = zip_file, files = files_to_zip, mode = "cherry-pick")

download_file(
  path = zip_file,
  output_name = "Download Textbook Bundle (ZIP)",
  button_label = "Download Bundle",
  button_type = "success",
  has_icon = TRUE,
  icon = "fa fa-download",
  self_contained = TRUE
)
---
title: "Shortlisted TUS 2024 Graphs"
output:
  html_document:
    theme: readable
    highlight: tango
    toc: true
    toc_depth: 3
    toc_float:
      collapsed: false
      smooth_scroll: true
    code_folding: hide
    code_download: true
    df_print: paged
    number_sections: true
    fig_width: 10
    fig_height: 8
    fig_caption: true
    self_contained: true
    keep_md: false
editor_options:
  chunk_output_type: console
---

```{r setup, include=FALSE}
library(arrow)
library(tidyverse)
library(hrbrthemes)
library(showtext)
library(stringr)
library(ggtext)
library(glue)
library(ggthemes)
library(scales)
library(zip)
library(downloadthis)

font_add_google("Atkinson Hyperlegible", "ath")
showtext_auto()

format_hours_minutes <- function(x) {
  out <- rep(NA_character_, length(x))
  valid_indices <- !is.na(x)
  if (!any(valid_indices)) {
    return(out)
  }
  valid_x <- x[valid_indices]
  hours <- floor(valid_x)
  minutes <- round((valid_x %% 1) * 60)
  is_60 <- minutes == 60
  hours[is_60] <- hours[is_60] + 1
  minutes[is_60] <- 0
  formatted_strings <- case_when(
    hours < 1 ~ sprintf("%dm", as.integer(minutes)),
    minutes == 0 ~ sprintf("%dh", as.integer(hours)),
    TRUE ~ sprintf("%dh %02dm", as.integer(hours), as.integer(minutes))
  )
  out[valid_indices] <- formatted_strings
  return(out)
}


tryCatch({
  timeuse_df <- arrow::read_parquet("timeuse.parquet")
  print("Successfully loaded the timeuse.parquet file.")
}, error = function(e) {
  print(
    "Error loading parquet file. Make sure the file 'timeuse.parquet' is in your working directory."
  )
  print(e)
})

calculate_duration <- function(df) {
  df %>%
    mutate(
      start_secs = lubridate::period_to_seconds(lubridate::hm(time_from)),
      end_secs = lubridate::period_to_seconds(lubridate::hm(time_to)),
      duration_mins = (end_secs - start_secs) / 60,
      duration_mins = ifelse(duration_mins < 0, duration_mins + 1440, duration_mins)
    )
}

timeuse_df <- calculate_duration(timeuse_df)

timeuse_df <- timeuse_df %>%
  mutate(
    activity = case_when(
      activity_code %in% c(
        "Employment in corporations, government and non-profit institutions"
      ) ~ "Formal Employment",
      activity_code %in% c(
        "Growing of crops for the market in household enterprises",
        "Raising animals for the market in household enterprises",
        "Forestry and logging for the market in household enterprises",
        "Fishing for the market in household enterprises",
        "Aquaculture for the market in household enterprises",
        "Mining and quarrying for the market in household enterprises",
        "Making and processing goods for the market in household enterprises",
        "Construction activities for the market in household enterprises",
        "Other activities related to employment in household enterprises to produce goods"
      ) ~ "Household Enterprise (Goods)",
      activity_code %in% c(
        "Vending and trading of goods in household enterprises",
        "Providing paid repair, installation, maintenance and disposal in household enterprises",
        "Providing paid business and professional services in household enterprises",
        "Transporting goods and passengers for pay or profit in household enterprises",
        "Providing paid personal care services in household enterprises",
        "Providing paid domestic services",
        "Other activities related to employment in household enterprises providing services"
      ) ~ "Household Enterprise (Services)",
      activity_code %in% c(
        "Activities ancillary to employment",
        "Breaks during working time within employment"
      ) ~ "Ancillary & Breaks (Work)",
      activity_code %in% c("Training and studies in relation to employment") ~ "Work-Related Training",
      activity_code %in% c("Seeking employment") ~ "Seeking Employment",
      activity_code %in% c("Setting up a business") ~ "Setting up a Business",
      activity_code %in% c("Employment-related travel", "Commuting") ~ "Travel (Work)",
      activity_code %in% c(
        "Growing crops and kitchen gardening, for own final use",
        "Farming of animals and production of animal products for own final use",
        "Hunting, trapping and production of animal skins for own final use",
        "Forestry and logging for own final use",
        "Gathering wild products for own final use",
        "Fishing for own final use",
        "Aquaculture for own final use",
        "Mining and quarrying for own final use"
      ) ~ "Agriculture & Fishing (Own-Use)",
      activity_code %in% c(
        "Making, processing food products, beverages and tobacco for own final use",
        "Making, processing textiles, wearing apparel, leather and related products for own final use",
        "Making, processing of wood and bark products for own final use",
        "Making, processing bricks, concrete slabs, hollow blocks, tiles for own final use",
        "Making, processing herbal and medicinal preparations for own final use",
        "Making, processing metals and metal products for own final use",
        "Making, processing of products using other materials for own final use",
        "Acquiring supplies and disposing of products and other activities related to making and processing goods for own final use"
      ) ~ "Processing Goods (Own-Use)",
      activity_code %in% c("Construction activities for own final use") ~ "Construction (Own-Use)",
      activity_code %in% c(
        "Gathering firewood and other natural products used as fuel for own final use",
        "Fetching water from natural and other sources for own final use"
      ) ~ "Collecting Water & Fuel (Own-Use)",
      activity_code %in% c(
        "Travelling, moving, transporting or accompanying goods or persons related to own-use production of goods"
      ) ~ "Travel (Own-Use Production)",
      activity_code %in% c(
        "Preparing meals/snacks",
        "Serving meals/snacks",
        "Cleaning up after food preparation/meals/snacks",
        "Storing, arranging, preserving food stocks",
        "Other activities related to food and meals management and preparation"
      ) ~ "Food & Meal Management",
      activity_code %in% c(
        "Indoor cleaning",
        "Outdoor cleaning",
        "Recycling and disposal of garbage",
        "Upkeep of indoor/outdoor plants, hedges, garden, grounds, landscape, etc.",
        "Tending furnace, boiler, fireplace for heating and water supply",
        "Other activities related to cleaning and upkeep of dwelling and surroundings"
      ) ~ "Cleaning & Maintenance",
      activity_code %in% c(
        "Do-it-yourself improvement, maintenance and repair of own dwelling",
        "Installation, servicing and repair of personal and household goods including ICT equipment",
        "Vehicle maintenance and repairs",
        "Other activities related to do-it-yourself decoration, maintenance and repair"
      ) ~ "DIY Maintenance & Repair",
      activity_code %in% c(
        "Hand/machine-washing",
        "Drying textiles and clothing",
        "Ironing/pressing/folding",
        "Mending/repairing and care of clothes and shoes; cleaning and polishing shoes",
        "Other activities related to care of textiles and footwear"
      ) ~ "Textiles & Footwear Care",
      activity_code %in% c(
        "Paying household bills",
        "Budgeting, planning, organizing duties and activities in the household",
        "Other activities related to household management"
      ) ~ "Household Management",
      activity_code %in% c(
        "Daily pet care",
        "Using veterinary care or other pet care services (grooming, stabling, holiday or day care)",
        "Other activities related to pet care"
      ) ~ "Pet Care",
      activity_code %in% c(
        "Shopping for/purchasing of goods and related activities",
        "Shopping for/availing of services and related activity"
      ) ~ "Shopping",
      activity_code %in% c(
        "Travelling, moving, transporting or accompanying goods or persons related to unpaid domestic services for household members"
      ) ~ "Travel (Domestic Services)",
      activity_code %in% c("Other unpaid domestic services for household members") ~ "Other Domestic Services",
      activity_code %in% c(
        "Caring for children including feeding, cleaning, physical care",
        "Providing medical care to children",
        "Instructing, teaching, training, helping children",
        "Talking with and reading to children",
        "Playing and sports with children",
        "Minding children (passive care)",
        "Meetings and arrangements with schools and child care service providers",
        "Other activities related to childcare and instruction"
      ) ~ "Childcare & Instruction",
      activity_code %in% c(
        "Assisting dependent adults with tasks of daily living",
        "Assisting dependent adults with medical care",
        "Assisting dependent adults with forms, administration, accounts",
        "Affective/emotional support for dependent adults",
        "Passive care of dependent adult",
        "Meetings and arrangements with adult care service providers",
        "Other activities related to care for dependent adults"
      ) ~ "Care for Dependent Adults",
      activity_code %in% c(
        "Feeding, cleaning, physical care for non-dependent adult household members including for temporary illness",
        "Affective/emotional support for non-dependent adult household members",
        "Other activities related to care for non-dependent adult household members"
      ) ~ "Help to Non-Dependent Adults",
      activity_code %in% c(
        "Travelling related to care-giving services for household members",
        "Accompanying own children",
        "Accompanying dependent adults",
        "Accompanying non-dependent adult household members"
      ) ~ "Travel (Caregiving)",
      activity_code %in% c(
        "Other activities related to unpaid caregiving services for household members"
      ) ~ "Other Caregiving",
      activity_code %in% c(
        "Unpaid volunteer household maintenance, management, construction, renovation and repair",
        "Unpaid volunteer shopping/purchasing goods and services",
        "Unpaid volunteer childcare and instruction",
        "Unpaid volunteer care for adults",
        "Unpaid volunteer activities in enterprises owned by other households",
        "Other activities related to direct unpaid volunteering for other households"
      ) ~ "Direct Volunteering",
      activity_code %in% c(
        "Unpaid volunteer work on road/building repair, clearing and preparing land, cleaning (streets, markets, etc.), and construction",
        "Unpaid volunteer preparing/serving meals, cleaning up",
        "Unpaid volunteer cultural activities, recreation and sports activities",
        "Unpaid volunteer office/administrative work",
        "Other activities related to community- and organizationbased unpaid volunteering"
      ) ~ "Community Volunteering",
      activity_code %in% c("Unpaid trainee work and related activities") ~ "Trainee Work",
      activity_code %in% c(
        "Travelling time related to unpaid volunteer, trainee and other unpaid work"
      ) ~ "Travel (Volunteering)",
      activity_code %in% c("Other unpaid work activities") ~ "Other Unpaid Work",
      activity_code %in% c(
        "School/university attendance",
        "Extra-curricular activities",
        "Breaks at place of formal education",
        "Self-study for distance education course work (video, audio, online)",
        "Other activities related to formal education"
      ) ~ "Formal Education",
      activity_code %in% c(
        "Homework, being tutored, course review, research and activities related to formal education"
      ) ~ "Homework",
      activity_code %in% c("Additional study, non-formal education and courses") ~ "Additional Study",
      activity_code %in% c("Travelling time related to learning") ~ "Travel (Learning)",
      activity_code %in% c("Other activities related to learning") ~ "Other Learning",
      activity_code %in% c(
        "Talking, conversing, chatting",
        "Socializing/getting together/gathering activities",
        "Reading and writing mail (including email)",
        "Other activities related to socializing and communication"
      ) ~ "Socializing & Communication",
      activity_code %in% c(
        "Participating in community celebrations of cultural/historic events",
        "Participating in community rites/events (non-religious) of weddings, funerals, births and similar rites-ofpassage",
        "Participating in community social functions (music, dance, etc.)",
        "Other activities related to community participation"
      ) ~ "Community Events",
      activity_code %in% c("Involvement in civic and related responsibilities") ~ "Civic Responsibilities",
      activity_code %in% c(
        "Private prayer, meditation and other spiritual activities",
        "Participating in collective religious practice",
        "Other activities related to religious practice"
      ) ~ "Religious Practices",
      activity_code %in% c(
        "Travelling time related to socializing and communication, community participation and religious practice"
      ) ~ "Travel (Social/Community)",
      activity_code %in% c(
        "Attendance at organized/mass cultural events and shows",
        "Attendance at parks/gardens",
        "Attendance at sports events",
        "Other activities related to attendance at cultural, entertainment and sports events"
      ) ~ "Attending Events",
      activity_code %in% c(
        "Visual, literary and performing arts (as hobby)",
        "Hobbies",
        "Playing games and other pastime activities",
        "Other activities related to cultural participation, hobbies, games"
      ) ~ "Hobbies & Games",
      activity_code %in% c("Participating in sports", "Exercising") ~ "Sports & Exercise",
      activity_code %in% c(
        "Reading for leisure",
        "Watching/listening to television and video",
        "Listening to radio and audio devices",
        "Other activities related to mass media use"
      ) ~ "Mass Media",
      activity_code %in% c("Activities associated with reflecting, resting, relaxing") ~ "Resting & Relaxing",
      activity_code %in% c(
        "Travelling time related to culture, leisure, mass-media and sports practices"
      ) ~ "Travel (Leisure)",
      activity_code %in% c(
        "Other activities related to culture, leisure, mass-media and sports practices",
        "Culture, leisure, mass-media and sports practices"
      ) ~ "Other Leisure",
      activity_code %in% c(
        "Night sleep/essential sleep",
        "Incidental sleep/naps",
        "Sleeplessness",
        "Other sleep and related activities"
      ) ~ "Sleep",
      activity_code %in% c("Eating meals/snack", "Drinking other than with meal or snack") ~ "Eating & Drinking",
      activity_code %in% c(
        "Personal hygiene and care",
        "Health/medical care to oneself",
        "Other activities related to personal hygiene and care"
      ) ~ "Personal Hygiene & Health",
      activity_code %in% c(
        "Receiving personal care from others",
        "Receiving health/medical care from others",
        "Other activities related to receiving personal and health/medical care"
      ) ~ "Receiving Care",
      activity_code %in% c("Travelling time related to self-care and maintenance activities") ~ "Travel (Self-Care)",
      activity_code %in% c("Other self-care and maintenance activities") ~ "Other Self-Care",
      TRUE ~ "Unclassified"
    )
  )
```

## Average Sleep Over the Ages

This chart shows how our average sleep duration changes as we age. Notice the decline during adolescence, followed by a more gradual change throughout adulthood.

```{r sleep-age-plot, fig.height=4, fig.width=5}
sleep_vs_age_plot <- timeuse_df %>%
  filter(activity == "Sleep", age < 90, age >= 6) %>%
  group_by(person_id, age, mult) %>%
  summarise(total_sleep_mins = sum(duration_mins, na.rm = TRUE),
            .groups = 'drop') %>%
  group_by(age) %>%
  summarise(avg_sleep_weighted_mins = weighted.mean(total_sleep_mins, w = mult, na.rm = TRUE)) %>%
  mutate(avg_sleep_hours = avg_sleep_weighted_mins / 60) %>%
  ggplot(aes(x = age, y = avg_sleep_hours)) +
  geom_smooth(
    method = "loess",
    se = TRUE,
    color = "black",
    fill = "gray80",
    linewidth = 0.8
  ) +
  scale_y_continuous(limits = c(0, 12), breaks = seq(0, 12, by = 2)) +
  scale_x_continuous(breaks = seq(10, 90, by = 20), limits = c(6, 95)) +
  labs(
    title = "Average daily sleep across ages",
    x = "Age (years)",
    y = "Sleep (hours/day)",
    caption = "Source: National Time Use Survey 2024"
  ) +
  theme_minimal() +
  theme(
    text = element_text(family = "ath", size = 9),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 10,
      margin = margin(b = 8)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 7,
      color = "gray50",
      hjust = 0
    ),
    axis.title = element_text(family = "ath", size = 9),
    axis.text = element_text(size = 8),
    panel.grid.minor = element_blank(),
    panel.grid.major = element_line(color = "gray90", linewidth = 0.3),
    plot.margin = margin(10, 10, 10, 10)
  )

sleep_vs_age_plot

# --- Essential Sleep Only ---

night_sleep_vs_age_plot <- timeuse_df %>%
  filter(activity_code == "Night sleep/essential sleep", age < 90, age >= 6) %>%
  group_by(person_id, age, mult) %>%
  summarise(total_sleep_mins = sum(duration_mins, na.rm = TRUE),
            .groups = 'drop') %>%
  group_by(age) %>%
  summarise(avg_sleep_weighted_mins = weighted.mean(total_sleep_mins, w = mult, na.rm = TRUE)) %>%
  mutate(avg_sleep_hours = avg_sleep_weighted_mins / 60) %>%
  ggplot(aes(x = age, y = avg_sleep_hours)) +
  geom_smooth(
    method = "loess",
    se = TRUE,
    color = "navy",
    fill = "lightblue",
    linewidth = 0.8
  ) +
  scale_y_continuous(limits = c(0, 12), breaks = seq(0, 12, by = 2)) +
  scale_x_continuous(breaks = seq(10, 90, by = 20), limits = c(6, 95)) +
  labs(
    title = "Night sleep across ages",
    x = "Age (years)",
    y = "Sleep (hours/day)",
    caption = "Source: National Time Use Survey 2024"
  ) +
  theme_minimal() +
  theme(
    text = element_text(family = "ath", size = 9),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 12,
      margin = margin(b = 8)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 7,
      color = "gray50",
      hjust = 0
    ),
    axis.title = element_text(family = "ath", size = 9),
    axis.text = element_text(size = 10),
    panel.grid.minor = element_blank(),
    panel.grid.major = element_line(color = "gray90", linewidth = 0.3),
    plot.margin = margin(10, 10, 10, 10)
  )

night_sleep_vs_age_plot
```

## A Day in the Life Across Age Groups

```{r age-strips-plot, fig.height=4.5, fig.width=6}
high_level_summary <- timeuse_df %>%
  filter(!is.na(activity) & activity != "Unclassified") %>%
  mutate(
    activity_group = case_when(
      activity == "Sleep" ~ "Sleep",
      activity %in% c("Eating & Drinking", "Personal Hygiene & Health", "Receiving Care") ~ "Personal Care",
      activity %in% c(
        "Formal Employment",
        "Household Enterprise (Goods)",
        "Household Enterprise (Services)",
        "Work-Related Training",
        "Seeking Employment",
        "Setting up a Business"
      ) ~ "Paid Work",
      activity %in% c(
        "Food & Meal Management",
        "Cleaning & Maintenance",
        "Childcare & Instruction",
        "Shopping",
        "Agriculture & Fishing (Own-Use)",
        "Community Volunteering",
        "Direct Volunteering"
      ) ~ "Unpaid Work & Care",
      activity %in% c("Formal Education", "Homework", "Additional Study") ~ "Learning",
      TRUE ~ "Leisure, Social & Travel"
    )
  )

person_activity_group_summary <- high_level_summary %>%
  group_by(person_id, activity_group) %>%
  summarise(total_duration = sum(duration_mins, na.rm = TRUE),
            .groups = "drop")

stacking_order <- c(
  "Sleep",
  "Personal Care",
  "Paid Work",
  "Unpaid Work & Care",
  "Learning",
  "Leisure, Social & Travel"
)

# Summary for Total Population
all_persons_age_group <- high_level_summary %>%
  mutate(age_group = cut(
    age,
    breaks = c(5, 14, 24, 59, Inf),
    labels = c(
      "Children\n(6-14)",
      "Youth\n(15-24)",
      "Adults\n(25-59)",
      "Elderly\n(60+)"
    ),
    right = TRUE,
    include.lowest = TRUE
  )) %>%
  filter(!is.na(age_group)) %>%
  distinct(person_id, age_group, mult)

age_group_summary_total <- all_persons_age_group %>%
  tidyr::crossing(activity_group = unique(person_activity_group_summary$activity_group)) %>%
  left_join(person_activity_group_summary,
            by = c("person_id", "activity_group")) %>%
  mutate(total_duration = ifelse(is.na(total_duration), 0, total_duration)) %>%
  group_by(age_group, activity_group) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60,
            .groups = "drop") %>%
  mutate(activity_group = factor(activity_group, levels = stacking_order))

# Summary by Gender
all_persons_age_gender_group <- high_level_summary %>%
  filter(gender %in% c("male", "female")) %>%
  mutate(age_group = cut(
    age,
    breaks = c(5, 14, 24, 59, Inf),
    labels = c(
      "Children\n(6-14)",
      "Youth\n(15-24)",
      "Adults\n(25-59)",
      "Elderly\n(60+)"
    ),
    right = TRUE,
    include.lowest = TRUE
  )) %>%
  filter(!is.na(age_group)) %>%
  distinct(person_id, age_group, gender, mult)

age_gender_group_summary <- all_persons_age_gender_group %>%
  tidyr::crossing(activity_group = unique(person_activity_group_summary$activity_group)) %>%
  left_join(person_activity_group_summary,
            by = c("person_id", "activity_group")) %>%
  mutate(total_duration = ifelse(is.na(total_duration), 0, total_duration)) %>%
  group_by(age_group, gender, activity_group) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60,
            .groups = "drop") %>%
  mutate(activity_group = factor(activity_group, levels = stacking_order))

# Summary by Sector
all_persons_age_sector_group <- high_level_summary %>%
  mutate(age_group = cut(
    age,
    breaks = c(5, 14, 24, 59, Inf),
    labels = c(
      "Children\n(6-14)",
      "Youth\n(15-24)",
      "Adults\n(25-59)",
      "Elderly\n(60+)"
    ),
    right = TRUE,
    include.lowest = TRUE
  )) %>%
  filter(!is.na(age_group)) %>%
  distinct(person_id, age_group, sector, mult)

age_sector_group_summary <- all_persons_age_sector_group %>%
  tidyr::crossing(activity_group = unique(person_activity_group_summary$activity_group)) %>%
  left_join(person_activity_group_summary,
            by = c("person_id", "activity_group")) %>%
  mutate(total_duration = ifelse(is.na(total_duration), 0, total_duration)) %>%
  group_by(age_group, sector, activity_group) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60,
            .groups = "drop") %>%
  mutate(activity_group = factor(activity_group, levels = stacking_order))



# 1. Define consistent colors and a reusable plotting function
activity_colors <- c(
  "Sleep" = "#1B9E77",
  "Personal Care" = "#D95F02",
  "Paid Work" = "#7570B3",
  "Unpaid Work & Care" = "#E7298A",
  "Learning" = "#666666",
  "Leisure, Social & Travel" = "#E6AB02"
)

create_age_strips_plot <- function(data, x_var = "age_group", main_title) {
  ggplot(data, aes(x = .data[[x_var]], y = avg_hours, fill = activity_group)) +
    geom_col(position = "fill", colour = "white", linewidth = 0.2) +
    scale_y_continuous(labels = scales::percent_format(accuracy = 1)) +
    scale_fill_manual(values = activity_colors, name = "") +
    labs(
      title = main_title,
      x = NULL,
      y = "% of day",
      caption = "Source: National Time Use Survey 2024"
    ) +
    theme_minimal() +
    theme(
      text = element_text(family = "ath", size = 8),
      plot.title = element_text(
        family = "ath",
        face = "bold",
        size = 12,
        margin = margin(b = 8)
      ),
      plot.caption = element_text(
        family = "ath",
        size = 7,
        color = "gray50",
        hjust = 0
      ),
      legend.position = "bottom",
      legend.text = element_text(size = 9),
      legend.key.size = unit(0.3, "cm"),
      axis.text = element_text(size = 8),
      axis.text.x = element_text(lineheight = 0.4),
      panel.grid = element_blank(),
      plot.margin = margin(10, 10, 10, 10)
    ) +
    guides(fill = guide_legend(nrow = 2, byrow = TRUE))
}

# 2. Generate the individual plots using the function
age_strips_plot_total <- create_age_strips_plot(
  data = age_group_summary_total, 
  main_title = "Time use by age group"
)

age_strips_plot_male <- create_age_strips_plot(
  data = age_gender_group_summary %>% filter(gender == "male"),
  main_title = "Time use by age: Men"
)

age_strips_plot_female <- create_age_strips_plot(
  data = age_gender_group_summary %>% filter(gender == "female"),
  main_title = "Time use by age: Women"
)

age_strips_plot_rural <- create_age_strips_plot(
  data = age_sector_group_summary %>% filter(sector == "Rural"),
  main_title = "Time use by age: Rural"
)

age_strips_plot_urban <- create_age_strips_plot(
  data = age_sector_group_summary %>% filter(sector == "Urban"),
  main_title = "Time use by age: Urban"
)


# 3. Generate the combined plot (it's different due to faceting)
combined_gender_strips_plot <- age_gender_group_summary %>%
  mutate(gender = str_to_title(gender)) %>%
  ggplot(aes(x = gender, y = avg_hours, fill = activity_group)) +
  geom_col(
    position = "fill",
    width = 0.8,
    color = "white",
    linewidth = 0.2
  ) +
  facet_wrap( ~ age_group, nrow = 1) +
  scale_y_continuous(labels = scales::percent_format(accuracy = 1)) +
  scale_fill_manual(values = activity_colors, name = "") +
  labs(
    title = "Time use by gender and age",
    x = NULL,
    y = "% of day",
    caption = "Source: National Time Use Survey 2024"
  ) +
  theme_minimal() +
  theme(
    text = element_text(family = "ath", size = 8),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 10,
      margin = margin(b = 8)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 7,
      color = "gray50",
      hjust = 0
    ),
    legend.position = "bottom",
    legend.text = element_text(size = 7),
    legend.key.size = unit(0.3, "cm"),
    strip.text = element_text(face = "bold", size = 8, lineheight = 0.4),
    axis.text = element_text(size = 7),
    panel.grid = element_blank(),
    panel.spacing = unit(0.3, "lines"),
    plot.margin = margin(10, 10, 10, 10)
  ) +
  guides(fill = guide_legend(nrow = 2, byrow = TRUE))

age_strips_plot_rural
age_strips_plot_urban
age_strips_plot_total
age_strips_plot_male
age_strips_plot_female
combined_gender_strips_plot
```

### Rural vs. Urban Comparison

```{r rural-urban-gender-strips-plot, fig.height=4.5, fig.width=7}
all_persons_age_gender_sector_group <- high_level_summary %>%
  filter(gender %in% c("male", "female")) %>%
  mutate(age_group = cut(
    age,
    breaks = c(5, 14, 24, 59, Inf),
    labels = c(
      "Children\n(6-14)",
      "Youth\n(15-24)",
      "Adults\n(25-59)",
      "Elderly\n(60+)"
    ),
    right = TRUE,
    include.lowest = TRUE
  )) %>%
  filter(!is.na(age_group)) %>%
  distinct(person_id, age_group, gender, sector, mult)

age_gender_sector_group_summary <- all_persons_age_gender_sector_group %>%
  tidyr::crossing(activity_group = unique(person_activity_group_summary$activity_group)) %>%
  left_join(person_activity_group_summary,
            by = c("person_id", "activity_group")) %>%
  mutate(total_duration = ifelse(is.na(total_duration), 0, total_duration)) %>%
  group_by(age_group, gender, sector, activity_group) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60,
            .groups = "drop") %>%
  mutate(activity_group = factor(activity_group, levels = stacking_order))


male_sector_strips_plot <- age_gender_sector_group_summary %>%
  filter(gender == "male") %>%
  ggplot(aes(x = sector, y = avg_hours, fill = activity_group)) +
  geom_col(
    position = "fill",
    width = 0.8,
    color = "white",
    linewidth = 0.2
  ) +
  facet_wrap( ~ age_group, nrow = 1) +
  scale_y_continuous(labels = scales::percent_format(accuracy = 1)) +
  scale_fill_manual(values = activity_colors, name = "") +
  labs(
    title = "Men: Time use by location and age",
    x = NULL,
    y = "% of day",
    caption = "Source: National Time Use Survey 2024"
  ) +
  theme_minimal() +
  theme(
    text = element_text(family = "ath", size = 8),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 10,
      margin = margin(b = 8)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 7,
      color = "gray50",
      hjust = 0
    ),
    legend.position = "bottom",
    legend.text = element_text(size = 7),
    legend.key.size = unit(0.3, "cm"),
    strip.text = element_text(face = "bold", size = 8, lineheight = 0.4),
    axis.text = element_text(size = 7),
    panel.grid = element_blank(),
    panel.spacing = unit(0.3, "lines"),
    plot.margin = margin(10, 10, 10, 10)
  ) +
  guides(fill = guide_legend(nrow = 2, byrow = TRUE))

female_sector_strips_plot <- age_gender_sector_group_summary %>%
  filter(gender == "female") %>%
  ggplot(aes(x = sector, y = avg_hours, fill = activity_group)) +
  geom_col(
    position = "fill",
    width = 0.8,
    color = "white",
    linewidth = 0.2
  ) +
  facet_wrap( ~ age_group, nrow = 1) +
  scale_y_continuous(labels = scales::percent_format(accuracy = 1)) +
  scale_fill_manual(values = activity_colors, name = "") +
  labs(
    title = "Women: Time use by location and age",
    x = NULL,
    y = "% of day",
    caption = "Source: National Time Use Survey 2024"
  ) +
  theme_minimal() +
  theme(
    text = element_text(family = "ath", size = 8),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 10,
      margin = margin(b = 8)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 7,
      color = "gray50",
      hjust = 0
    ),
    legend.position = "bottom",
    legend.text = element_text(size = 7),
    legend.key.size = unit(0.3, "cm"),
    strip.text = element_text(face = "bold", size = 8, lineheight = 0.4),
    axis.text = element_text(size = 7),
    panel.grid = element_blank(),
    panel.spacing = unit(0.3, "lines"),
    plot.margin = margin(10, 10, 10, 10)
  ) +
  guides(fill = guide_legend(nrow = 2, byrow = TRUE))

male_sector_strips_plot
female_sector_strips_plot
```

## Exports and Download

```{r save-all-plots, include=TRUE}
dir.create("shortlisted_textbook", showWarnings = FALSE)

export_theme <- theme(
  plot.title = element_text(size = 20, face = "bold"),
  plot.subtitle = element_text(size = 16),
  plot.caption = element_text(size = 11),
  axis.title = element_text(size = 14),
  axis.text = element_text(size = 14),
  legend.text = element_text(size = 14),
  legend.title = element_text(size = 14),
  strip.text = element_text(size = 14, face = "bold"),
  legend.key.size = unit(0.4, "cm")
)

# 1. Sleep plots - compact single-column width (4" x 3.5")
ggsave(filename = "shortlisted_textbook/01_sleep_vs_age.png",
       plot = sleep_vs_age_plot + export_theme,
       width = 2, height = 2, dpi = 300, units = "in")

ggsave(filename = "shortlisted_textbook/02_essential_sleep_vs_age.png",
       plot = night_sleep_vs_age_plot + export_theme,
       width = 2, height = 2, dpi = 300, units = "in")

# 2. Simple strip plots - slightly wider (5" x 4")
ggsave(filename = "shortlisted_textbook/03_age_strips_total.png",
       plot = age_strips_plot_total + export_theme,
       width = 3, height = 3, dpi = 300, units = "in")

ggsave(filename = "shortlisted_textbook/04_age_strips_rural.png",
       plot = age_strips_plot_rural + export_theme,
       width = 3, height = 3, dpi = 300, units = "in")

ggsave(filename = "shortlisted_textbook/05_age_strips_urban.png",
       plot = age_strips_plot_urban + export_theme,
       width = 3, height = 3, dpi = 300, units = "in")

# 3. Gender-specific plots (5" x 4")
ggsave(filename = "shortlisted_textbook/06_age_strips_male.png",
       plot = age_strips_plot_male + export_theme,
       width = 3, height = 3, dpi = 300, units = "in")

ggsave(filename = "shortlisted_textbook/07_age_strips_female.png",
       plot = age_strips_plot_female + export_theme,
       width = 3, height = 3, dpi = 300, units = "in")

# 4. Faceted plots - wider for readability (6.5" x 4")
ggsave(filename = "shortlisted_textbook/08_combined_gender_strips.png",
       plot = combined_gender_strips_plot + export_theme,
       width = 4, height = 3, dpi = 300, units = "in")

ggsave(filename = "shortlisted_textbook/09_male_sector_strips.png",
       plot = male_sector_strips_plot + export_theme,
       width = 4, height = 3, dpi = 300, units = "in")

ggsave(filename = "shortlisted_textbook/10_female_sector_strips.png",
       plot = female_sector_strips_plot + export_theme,
       width = 4, height = 3, dpi = 300, units = "in")
```

```{r create-zip-and-download, include=TRUE}
zip_file <- "time_use_textbook_bundle.zip"
files_to_zip <- c(
  list.files("shortlisted_textbook", full.names = TRUE, pattern = "\\.png$"),
  "shortlisted-tus-2024.Rmd"
)

if (file.exists(zip_file)) file.remove(zip_file)
zip::zip(zipfile = zip_file, files = files_to_zip, mode = "cherry-pick")

download_file(
  path = zip_file,
  output_name = "Download Textbook Bundle (ZIP)",
  button_label = "Download Bundle",
  button_type = "success",
  has_icon = TRUE,
  icon = "fa fa-download",
  self_contained = TRUE
)
```
