From 0f6707de3023234b85e7186fa5cd10ad039d0109 Mon Sep 17 00:00:00 2001
From: Jb Audras <audrasjb@git.wordpress.org>
Date: Fri, 24 Jan 2025 10:56:38 +0000
Subject: [PATCH] Themes: Add `wp-theme-<name>` and `wp-child-theme-<name>`
 classes to `body_class`.

This changeset introduces new classes to the body tag. The classes `wp-theme-<name>` and `wp-child-theme-<name>` (when the current theme is a child theme) are added, where `<name>` represents the sanitized name of the active theme.

Props cais, GaryJ, nacin, SergeyBiryukov, johnjamesjacoby, nirajgirixd, poena, audrasjb, rinkalpagdar.
Fixes #19736.




git-svn-id: https://develop.svn.wordpress.org/trunk@59698 602fd350-edb4-49c9-b593-d223f7449a82
---
 src/wp-admin/admin-header.php     | 5 +++++
 src/wp-includes/post-template.php | 5 +++++
 2 files changed, 10 insertions(+)

diff --git a/src/wp-admin/admin-header.php b/src/wp-admin/admin-header.php
index 54bcc11ca5..ea0245fdb1 100644
--- a/src/wp-admin/admin-header.php
+++ b/src/wp-admin/admin-header.php
@@ -214,6 +214,11 @@ if ( $current_screen->is_block_editor() ) {
 	$admin_body_class .= ' block-editor-page wp-embed-responsive';
 }
 
+$admin_body_class .= ' wp-theme-' . sanitize_html_class( get_template() );
+if ( is_child_theme() ) {
+	$admin_body_class .= ' wp-child-theme-' . sanitize_html_class( get_stylesheet() );
+}
+
 $error_get_last = error_get_last();
 
 // Print a CSS class to make PHP errors visible.
diff --git a/src/wp-includes/post-template.php b/src/wp-includes/post-template.php
index 8b84b86702..ffcca1647d 100644
--- a/src/wp-includes/post-template.php
+++ b/src/wp-includes/post-template.php
@@ -838,6 +838,11 @@ function get_body_class( $css_class = '' ) {
 		}
 	}
 
+	$classes[] = 'wp-theme-' . sanitize_html_class( get_template() );
+	if ( is_child_theme() ) {
+		$classes[] = 'wp-child-theme-' . sanitize_html_class( get_stylesheet() );
+	}
+
 	if ( ! empty( $css_class ) ) {
 		if ( ! is_array( $css_class ) ) {
 			$css_class = preg_split( '#\s+#', $css_class );