The categorizations are based on https://unstats.un.org/unsd/gender/timeuse/23012019%20ICATUS.pdf

1 Average sleep over the ages

timeuse_df %>%
  filter(activity == "Sleep", age < 90) %>%
  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"
  ) +
  #geom_line()+
  scale_y_continuous(limits = c(8, 13), breaks = seq(8, 13, by = 1)) +
  scale_x_continuous(breaks = seq(0, 90, by = 10), limits = c(6, 95)) +
    labs(
    title = "Average Daily Sleep Declines Through Adolescence",
    x = "Age",
    y = "Average Sleep (hours per day)",
    caption = "Source: MoSPI Time Use Survey, 2024"
  ) +
    theme_fivethirtyeight() +
    theme(
    text = element_text(family = "ath"),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 18,
      margin = margin(b = 20)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 10,
      color = "gray50"
    ),
    axis.title = element_text(family = "ath", size = 12),
    axis.title.y = element_text(margin = margin(r = 15)),
    axis.title.x = element_text(margin = margin(t = 15)),
    axis.text.y = element_text(
      family = "ath",
      size = 12,
      margin = margin(r = 8)
    ),
    axis.text.x = element_text(
      family = "ath",
      size = 12,
      margin = margin(t = 8)
    ),
    
    panel.grid.major = element_line(linewidth = 0.5, color = "gray90"),
    panel.grid.minor = element_blank()
  )
## `geom_smooth()` using formula = 'y ~ x'

1.1 Difference in activities by gender

all_persons <- timeuse_df %>%
  distinct(person_id, gender, mult)

person_activity_summary <- timeuse_df %>%
  filter(!is.na(activity) & activity != "Unclassified") %>%
  group_by(person_id, activity) %>%
  summarise(total_duration_mins = sum(duration_mins, na.rm = TRUE), .groups = 'drop')

gender_summary <- all_persons %>%
  tidyr::crossing(activity = unique(person_activity_summary$activity)) %>%
  left_join(person_activity_summary, by = c("person_id", "activity")) %>%
  mutate(total_duration_mins = ifelse(is.na(total_duration_mins), 0, total_duration_mins)) %>%
  group_by(gender, activity) %>%
  summarise(
    avg_hours_per_person = weighted.mean(total_duration_mins, w = mult, na.rm = TRUE) / 60,
    .groups = 'drop'
  )

gender_summary_wide <- gender_summary %>%
  pivot_wider(names_from = gender, values_from = avg_hours_per_person) %>%
  mutate(gap = female - male) %>%
  slice_max(order_by = abs(gap), n = 15) %>%
  mutate(activity = fct_reorder(activity, gap))

ggplot(gender_summary_wide, aes(y = activity)) +
  geom_segment(aes(x = male, xend = female), color = "gray", linewidth = 1.5, alpha = 0.5) +
  geom_point(aes(x = female, color = "Female"), size = 4) +
  geom_point(aes(x = male, color = "Male"), size = 4) +
  
  theme_fivethirtyeight() +
  scale_color_manual(name = "", values = c("Female" = "#0072B2", "Male" = "#D55E00")) +
  labs(
    title = "Unpaid Work Accounts for the Largest Gender Gap in Time Use",
    subtitle = "Comparing the average daily hours for men and women",
    x = "Average Hours Per Day (per person)",
    y = "",
    caption = "Source: MoSPI Time Use Survey, 2024"
  ) +
    theme(
    text = element_text(family = "ath"),
    plot.title = element_text(family = "ath", size = 16, margin = margin(b = 10, l = -130)),
    plot.subtitle = element_text(family = "ath", size = 14, margin = margin(b = 20, l = -130), color = "gray40"),
    plot.caption = element_text(family = "ath", size = 10, color = "gray50", margin = margin(t = 20)),
    axis.title = element_text(family = "ath", size = 12),
    axis.text = element_text(family = "ath", size = 11),
    plot.margin = margin(15, 50, 10, 0),
    
    legend.position = "top",
    legend.direction = "horizontal", 
    legend.background = element_rect(fill = "transparent"),
    legend.key = element_rect(fill = "transparent", color = NA), 
    legend.title = element_blank(), 
    legend.text = element_text(size = 10, family = "ath")
  )

all_persons_sector <- timeuse_df %>%
  distinct(person_id, sector, mult)

person_activity_summary_sector <- timeuse_df %>%
  filter(!is.na(activity) & activity != "Unclassified") %>%
  group_by(person_id, activity) %>%
  summarise(total_duration_mins = sum(duration_mins, na.rm = TRUE), .groups = 'drop')

sector_summary <- all_persons_sector %>%
  tidyr::crossing(activity = unique(person_activity_summary_sector$activity)) %>%
  left_join(person_activity_summary_sector, by = c("person_id", "activity")) %>%
  mutate(total_duration_mins = ifelse(is.na(total_duration_mins), 0, total_duration_mins)) %>%
  group_by(sector, activity) %>%
  summarise(
    avg_hours_per_person = weighted.mean(total_duration_mins, w = mult, na.rm = TRUE) / 60,
    .groups = 'drop'
  )

sector_summary_wide <- sector_summary %>%
  pivot_wider(names_from = sector, values_from = avg_hours_per_person) %>%
  mutate(gap = Urban - Rural) %>%
  slice_max(order_by = abs(gap), n = 15) %>%
  mutate(activity = fct_reorder(activity, gap))

ggplot(sector_summary_wide, aes(y = activity)) +
  geom_segment(aes(x = Rural, xend = Urban), color = "gray", linewidth = 1.5, alpha = 0.5) +
  geom_point(aes(x = Urban, color = "Urban"), size = 4) +
  geom_point(aes(x = Rural, color = "Rural"), size = 4) +
  
  theme_fivethirtyeight() +
  scale_color_manual(name = "", values = c("Urban" = "#0072B2", "Rural" = "#D55E00")) +
  
  labs(
    title = "Rural-Urban Divide in Daily Time Use",
    subtitle = "Comparing daily hours for the 15 activities with the largest urban-rural disparities",
    x = "Average Hours Per Day (per person)",
    y = "",
    caption = "Source: MoSPI Time Use Survey, 2024"
  ) +
  
  theme(
    text = element_text(family = "ath"),
    plot.title = element_text(family = "ath", size = 20, margin = margin(b = 10)),
    plot.subtitle = element_text(family = "ath", size = 14, margin = margin(b = 20), color = "gray40"),
    plot.caption = element_text(family = "ath", size = 10, color = "gray50", margin = margin(t = 20)),
    axis.title = element_text(family = "ath", size = 12),
    axis.text = element_text(family = "ath", size = 11),
    plot.margin = margin(15, 15, 10, 15),
    
    legend.position = "top",
    legend.direction = "horizontal", 
    legend.background = element_rect(fill = "transparent"),
    legend.key = element_rect(fill = "transparent", color = NA), 
    legend.title = element_blank(), 
    legend.text = element_text(size = 14, family = "ath")
  )

2 Activity strips by 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",
      # Group all leisure, social, and travel into one bucket for this high-level view
      TRUE ~ "Leisure, Social & Travel"
    )
  )

age_group_summary <- high_level_summary %>%
  mutate(age_group = cut(
    age,
    breaks = c(5, 14, 24, 59, Inf),
    labels = c(
      "Children (6-14)",
      "Youth (15-24)",
      "Adults (25-59)",
      "Seniors (60+)"
    ),
    right = TRUE,
    include.lowest = TRUE
  )) %>%
  filter(!is.na(age_group)) %>%
  group_by(person_id, age_group, activity_group, mult) %>%
  summarise(total_duration = sum(duration_mins, na.rm = TRUE),
            .groups = "drop") %>%
  group_by(age_group, activity_group) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60,
            .groups = "drop")

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

age_group_summary$activity_group <- factor(age_group_summary$activity_group, levels = stacking_order)


ggplot(age_group_summary,
       aes(x = age_group, y = avg_hours, fill = activity_group)) +
  geom_col(position = "fill", colour = "transparent") +
  scale_y_continuous(labels = scales::percent) +
  
  scale_fill_brewer(palette = "Dark2", name = "") +
  labs(
    title = "Share of a 24-hour day spent on major activities, by age group",
    x = "",
    y = "Percentage of Day",
    caption = "Source: MoSPI Time Use Survey, 2024"
  ) +
  theme_fivethirtyeight() +
  
  theme(
    text = element_text(family = "ath"),
    plot.title = element_text(
      family = "ath",
      size = 20,
      margin = margin(b = 10)
    ),
    plot.subtitle = element_text(
      family = "ath",
      size = 14,
      margin = margin(b = 20),
      color = "gray40"
    ),
    plot.caption = element_text(
      family = "ath",
      size = 10,
      color = "gray50",
      margin = margin(t = 20)
    ),
    axis.title = element_text(family = "ath", size = 12),
    axis.text = element_text(family = "ath", size = 11),
    plot.margin = margin(15, 15, 10, 15),
    
    legend.position = "bottom",
    legend.direction = "horizontal",
    legend.background = element_rect(fill = "transparent"),
    legend.key = element_rect(fill = "transparent", color = NA),
    legend.title = element_blank(),
    legend.text = element_text(size = 14, family = "ath")
  )

3 Time use on key activities in children and youth

“children” are defined as persons under 15 years of age, and “youth” are defined as those aged 15–24.

youth_activities <- c(
  "Formal Education", "Homework", 
  "Food & Meal Management", "Cleaning & Maintenance", "Childcare & Instruction",
  "Mass Media", "Sports & Exercise", "Hobbies & Games",
  "Socializing & Communication"
  )

youth_summary <- timeuse_df %>%
  filter(age >= 6 & age <= 24, activity %in% youth_activities, gender %in% c('male', 'female')) %>%
  group_by(person_id, age, gender, activity, mult) %>%
  summarise(total_duration = sum(duration_mins, na.rm = TRUE), .groups = "drop") %>%
  group_by(age, gender, activity) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60, .groups = "drop")

ggplot(youth_summary, aes(x = age, y = avg_hours, color = gender)) +
  geom_smooth(se = FALSE, size = 1.2) +
  facet_wrap(~ activity, scales = "free", ncol = 3) + 
  
  scale_color_manual(name = "Gender", values = c("female" = "#0072B2", "male" = "#D55E00")) +
  labs(
    title = "Average daily hours spent on key activities for ages 6-24, by gender",
    x = "Age (years)",
    y = "Average Hours Per Day",
    caption = "Source: MoSPI Time Use Survey, 2024"
  ) +
  theme_minimal(base_family = "ath") +
  theme(
    plot.title = element_text(face = "bold", size = 20, margin = margin(b = 10)),
    plot.subtitle = element_text(size = 14, color = "gray40", margin = margin(b = 20)),
    strip.text = element_text(face = "bold", size = 11, hjust = 0),
    legend.position = "top",
    panel.spacing = unit(1.5, "lines")
  ) +
theme_fivethirtyeight() +
  
  theme(
    text = element_text(family = "ath"),
    plot.title = element_text(
      family = "ath",
      size = 20,
      margin = margin(b = 10)
    ),
    plot.subtitle = element_text(
      family = "ath",
      size = 14,
      margin = margin(b = 20),
      color = "gray40"
    ),
    plot.caption = element_text(
      family = "ath",
      size = 10,
      color = "gray50",
      margin = margin(t = 20)
    ),
    axis.title = element_text(family = "ath", size = 12),
    axis.text = element_text(family = "ath", size = 11),
    plot.margin = margin(15, 15, 10, 15),
    
    legend.position = "bottom",
    legend.direction = "horizontal",
    legend.background = element_rect(fill = "transparent"),
    legend.key = element_rect(fill = "transparent", color = NA),
    legend.title = element_blank(),
    legend.text = element_text(size = 14, family = "ath")
  )
## Warning: Using `size` aesthetic for lines was deprecated in ggplot2 3.4.0.
## ℹ Please use `linewidth` instead.
## This warning is displayed once every 8 hours.
## Call `lifecycle::last_lifecycle_warnings()` to see where this warning was
## generated.
## `geom_smooth()` using method = 'loess' and formula = 'y ~ x'

---
title: "Time Use Analysis"
output:
  html_document:
    theme: readable
    highlight: tango
    toc: true
    toc_depth: 3
    toc_float:
      collapsed: false
      smooth_scroll: true
    code_folding: show
    code_download: true
    df_print: paged
    number_sections: true
    fig_width: 10
    fig_height: 6
    fig_caption: true
    self_contained: true
    keep_md: false
editor_options:
  chunk_output_type: console
---

The categorizations are based on https://unstats.un.org/unsd/gender/timeuse/23012019%20ICATUS.pdf

```{r setup, include=FALSE}

library(arrow)
library(tidyverse)
library(hrbrthemes)
library(showtext)
library(stringr)
library(ggtext)
library(glue)
library(ggthemes)

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


tryCatch({
  timeuse_df <- arrow::read_parquet("timeuse.parquet")
  print("Successfully loaded the timeuse.parquet file.")
  print(head(timeuse_df))
}, 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) # 1440 minutes in a day
    )
}

timeuse_df <- calculate_duration(timeuse_df)

timeuse_df <- timeuse_df %>%
  mutate(
    activity = case_when(
      # --- 1: Employment and related activities ---
      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)",
      
      # --- 2: Production of goods for own final use ---
      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)",
      
      # --- 3: Unpaid domestic services ---
      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",
      
      # --- 4: Unpaid caregiving 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",
      
      # --- 5: Unpaid volunteer, trainee and other unpaid work ---
      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",
      
      # --- 6: Learning ---
      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",
      
      # --- 7: Socializing and communication, community participation and religious practice ---
      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)",
      
      # --- 8: Culture, leisure, mass media and sports practices ---
      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",
      
      # --- 9: Self-care and maintenance ---
      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

```{r}
timeuse_df %>%
  filter(activity == "Sleep", age < 90) %>%
  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"
  ) +
  #geom_line()+
  scale_y_continuous(limits = c(8, 13), breaks = seq(8, 13, by = 1)) +
  scale_x_continuous(breaks = seq(0, 90, by = 10), limits = c(6, 95)) +
    labs(
    title = "Average Daily Sleep Declines Through Adolescence",
    x = "Age",
    y = "Average Sleep (hours per day)",
    caption = "Source: MoSPI Time Use Survey, 2024"
  ) +
    theme_fivethirtyeight() +
    theme(
    text = element_text(family = "ath"),
    plot.title = element_text(
      family = "ath",
      face = "bold",
      size = 18,
      margin = margin(b = 20)
    ),
    plot.caption = element_text(
      family = "ath",
      size = 10,
      color = "gray50"
    ),
    axis.title = element_text(family = "ath", size = 12),
    axis.title.y = element_text(margin = margin(r = 15)),
    axis.title.x = element_text(margin = margin(t = 15)),
    axis.text.y = element_text(
      family = "ath",
      size = 12,
      margin = margin(r = 8)
    ),
    axis.text.x = element_text(
      family = "ath",
      size = 12,
      margin = margin(t = 8)
    ),
    
    panel.grid.major = element_line(linewidth = 0.5, color = "gray90"),
    panel.grid.minor = element_blank()
  )
```

### Difference in activities by gender

```{r}
all_persons <- timeuse_df %>%
  distinct(person_id, gender, mult)

person_activity_summary <- timeuse_df %>%
  filter(!is.na(activity) & activity != "Unclassified") %>%
  group_by(person_id, activity) %>%
  summarise(total_duration_mins = sum(duration_mins, na.rm = TRUE), .groups = 'drop')

gender_summary <- all_persons %>%
  tidyr::crossing(activity = unique(person_activity_summary$activity)) %>%
  left_join(person_activity_summary, by = c("person_id", "activity")) %>%
  mutate(total_duration_mins = ifelse(is.na(total_duration_mins), 0, total_duration_mins)) %>%
  group_by(gender, activity) %>%
  summarise(
    avg_hours_per_person = weighted.mean(total_duration_mins, w = mult, na.rm = TRUE) / 60,
    .groups = 'drop'
  )

gender_summary_wide <- gender_summary %>%
  pivot_wider(names_from = gender, values_from = avg_hours_per_person) %>%
  mutate(gap = female - male) %>%
  slice_max(order_by = abs(gap), n = 15) %>%
  mutate(activity = fct_reorder(activity, gap))

ggplot(gender_summary_wide, aes(y = activity)) +
  geom_segment(aes(x = male, xend = female), color = "gray", linewidth = 1.5, alpha = 0.5) +
  geom_point(aes(x = female, color = "Female"), size = 4) +
  geom_point(aes(x = male, color = "Male"), size = 4) +
  
  theme_fivethirtyeight() +
  scale_color_manual(name = "", values = c("Female" = "#0072B2", "Male" = "#D55E00")) +
  labs(
    title = "Unpaid Work Accounts for the Largest Gender Gap in Time Use",
    subtitle = "Comparing the average daily hours for men and women",
    x = "Average Hours Per Day (per person)",
    y = "",
    caption = "Source: MoSPI Time Use Survey, 2024"
  ) +
    theme(
    text = element_text(family = "ath"),
    plot.title = element_text(family = "ath", size = 16, margin = margin(b = 10, l = -130)),
    plot.subtitle = element_text(family = "ath", size = 14, margin = margin(b = 20, l = -130), color = "gray40"),
    plot.caption = element_text(family = "ath", size = 10, color = "gray50", margin = margin(t = 20)),
    axis.title = element_text(family = "ath", size = 12),
    axis.text = element_text(family = "ath", size = 11),
    plot.margin = margin(15, 50, 10, 0),
    
    legend.position = "top",
    legend.direction = "horizontal", 
    legend.background = element_rect(fill = "transparent"),
    legend.key = element_rect(fill = "transparent", color = NA), 
    legend.title = element_blank(), 
    legend.text = element_text(size = 10, family = "ath")
  )
```

```{r sector-gap-plot}

all_persons_sector <- timeuse_df %>%
  distinct(person_id, sector, mult)

person_activity_summary_sector <- timeuse_df %>%
  filter(!is.na(activity) & activity != "Unclassified") %>%
  group_by(person_id, activity) %>%
  summarise(total_duration_mins = sum(duration_mins, na.rm = TRUE), .groups = 'drop')

sector_summary <- all_persons_sector %>%
  tidyr::crossing(activity = unique(person_activity_summary_sector$activity)) %>%
  left_join(person_activity_summary_sector, by = c("person_id", "activity")) %>%
  mutate(total_duration_mins = ifelse(is.na(total_duration_mins), 0, total_duration_mins)) %>%
  group_by(sector, activity) %>%
  summarise(
    avg_hours_per_person = weighted.mean(total_duration_mins, w = mult, na.rm = TRUE) / 60,
    .groups = 'drop'
  )

sector_summary_wide <- sector_summary %>%
  pivot_wider(names_from = sector, values_from = avg_hours_per_person) %>%
  mutate(gap = Urban - Rural) %>%
  slice_max(order_by = abs(gap), n = 15) %>%
  mutate(activity = fct_reorder(activity, gap))

ggplot(sector_summary_wide, aes(y = activity)) +
  geom_segment(aes(x = Rural, xend = Urban), color = "gray", linewidth = 1.5, alpha = 0.5) +
  geom_point(aes(x = Urban, color = "Urban"), size = 4) +
  geom_point(aes(x = Rural, color = "Rural"), size = 4) +
  
  theme_fivethirtyeight() +
  scale_color_manual(name = "", values = c("Urban" = "#0072B2", "Rural" = "#D55E00")) +
  
  labs(
    title = "Rural-Urban Divide in Daily Time Use",
    subtitle = "Comparing daily hours for the 15 activities with the largest urban-rural disparities",
    x = "Average Hours Per Day (per person)",
    y = "",
    caption = "Source: MoSPI Time Use Survey, 2024"
  ) +
  
  theme(
    text = element_text(family = "ath"),
    plot.title = element_text(family = "ath", size = 20, margin = margin(b = 10)),
    plot.subtitle = element_text(family = "ath", size = 14, margin = margin(b = 20), color = "gray40"),
    plot.caption = element_text(family = "ath", size = 10, color = "gray50", margin = margin(t = 20)),
    axis.title = element_text(family = "ath", size = 12),
    axis.text = element_text(family = "ath", size = 11),
    plot.margin = margin(15, 15, 10, 15),
    
    legend.position = "top",
    legend.direction = "horizontal", 
    legend.background = element_rect(fill = "transparent"),
    legend.key = element_rect(fill = "transparent", color = NA), 
    legend.title = element_blank(), 
    legend.text = element_text(size = 14, family = "ath")
  )
```

## Activity strips by age groups

```{r}
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",
      # Group all leisure, social, and travel into one bucket for this high-level view
      TRUE ~ "Leisure, Social & Travel"
    )
  )

age_group_summary <- high_level_summary %>%
  mutate(age_group = cut(
    age,
    breaks = c(5, 14, 24, 59, Inf),
    labels = c(
      "Children (6-14)",
      "Youth (15-24)",
      "Adults (25-59)",
      "Seniors (60+)"
    ),
    right = TRUE,
    include.lowest = TRUE
  )) %>%
  filter(!is.na(age_group)) %>%
  group_by(person_id, age_group, activity_group, mult) %>%
  summarise(total_duration = sum(duration_mins, na.rm = TRUE),
            .groups = "drop") %>%
  group_by(age_group, activity_group) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60,
            .groups = "drop")

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

age_group_summary$activity_group <- factor(age_group_summary$activity_group, levels = stacking_order)


ggplot(age_group_summary,
       aes(x = age_group, y = avg_hours, fill = activity_group)) +
  geom_col(position = "fill", colour = "transparent") +
  scale_y_continuous(labels = scales::percent) +
  
  scale_fill_brewer(palette = "Dark2", name = "") +
  labs(
    title = "Share of a 24-hour day spent on major activities, by age group",
    x = "",
    y = "Percentage of Day",
    caption = "Source: MoSPI Time Use Survey, 2024"
  ) +
  theme_fivethirtyeight() +
  
  theme(
    text = element_text(family = "ath"),
    plot.title = element_text(
      family = "ath",
      size = 20,
      margin = margin(b = 10)
    ),
    plot.subtitle = element_text(
      family = "ath",
      size = 14,
      margin = margin(b = 20),
      color = "gray40"
    ),
    plot.caption = element_text(
      family = "ath",
      size = 10,
      color = "gray50",
      margin = margin(t = 20)
    ),
    axis.title = element_text(family = "ath", size = 12),
    axis.text = element_text(family = "ath", size = 11),
    plot.margin = margin(15, 15, 10, 15),
    
    legend.position = "bottom",
    legend.direction = "horizontal",
    legend.background = element_rect(fill = "transparent"),
    legend.key = element_rect(fill = "transparent", color = NA),
    legend.title = element_blank(),
    legend.text = element_text(size = 14, family = "ath")
  )
```


## Time use on key activities in children and youth

“children” are defined as persons under 15 years of age, and “youth” are defined as those aged 15–24.

```{r}

youth_activities <- c(
  "Formal Education", "Homework", 
  "Food & Meal Management", "Cleaning & Maintenance", "Childcare & Instruction",
  "Mass Media", "Sports & Exercise", "Hobbies & Games",
  "Socializing & Communication"
  )

youth_summary <- timeuse_df %>%
  filter(age >= 6 & age <= 24, activity %in% youth_activities, gender %in% c('male', 'female')) %>%
  group_by(person_id, age, gender, activity, mult) %>%
  summarise(total_duration = sum(duration_mins, na.rm = TRUE), .groups = "drop") %>%
  group_by(age, gender, activity) %>%
  summarise(avg_hours = weighted.mean(total_duration, w = mult, na.rm = TRUE) / 60, .groups = "drop")

ggplot(youth_summary, aes(x = age, y = avg_hours, color = gender)) +
  geom_smooth(se = FALSE, size = 1.2) +
  facet_wrap(~ activity, scales = "free", ncol = 3) + 
  
  scale_color_manual(name = "Gender", values = c("female" = "#0072B2", "male" = "#D55E00")) +
  labs(
    title = "Average daily hours spent on key activities for ages 6-24, by gender",
    x = "Age (years)",
    y = "Average Hours Per Day",
    caption = "Source: MoSPI Time Use Survey, 2024"
  ) +
  theme_minimal(base_family = "ath") +
  theme(
    plot.title = element_text(face = "bold", size = 20, margin = margin(b = 10)),
    plot.subtitle = element_text(size = 14, color = "gray40", margin = margin(b = 20)),
    strip.text = element_text(face = "bold", size = 11, hjust = 0),
    legend.position = "top",
    panel.spacing = unit(1.5, "lines")
  ) +
theme_fivethirtyeight() +
  
  theme(
    text = element_text(family = "ath"),
    plot.title = element_text(
      family = "ath",
      size = 20,
      margin = margin(b = 10)
    ),
    plot.subtitle = element_text(
      family = "ath",
      size = 14,
      margin = margin(b = 20),
      color = "gray40"
    ),
    plot.caption = element_text(
      family = "ath",
      size = 10,
      color = "gray50",
      margin = margin(t = 20)
    ),
    axis.title = element_text(family = "ath", size = 12),
    axis.text = element_text(family = "ath", size = 11),
    plot.margin = margin(15, 15, 10, 15),
    
    legend.position = "bottom",
    legend.direction = "horizontal",
    legend.background = element_rect(fill = "transparent"),
    legend.key = element_rect(fill = "transparent", color = NA),
    legend.title = element_blank(),
    legend.text = element_text(size = 14, family = "ath")
  )
```

