Skip to content

Commit

Permalink
Merge pull request #5447 from kamilkrzyskow/social-patch
Browse files Browse the repository at this point in the history
Fix crash in social plugin and add support for logo in custom_dir
  • Loading branch information
squidfunk committed May 2, 2023
2 parents 84959a5 + 9485b6f commit 5c57458
Show file tree
Hide file tree
Showing 3 changed files with 59 additions and 14 deletions.
11 changes: 5 additions & 6 deletions docs/setup/setting-up-social-cards.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,12 +19,11 @@ The social preview image for the page on [setting up site analytics].
</figure>

[^1]:
Both types of logos, images (`theme.logo`) and icons (`theme.icon.logo`)
are supported. While an image logo is used as-is, icons are filled with the
color used in the header (white or black), which depends on the primary
color. Note that custom logos and icons must reside in the `docs_dir` for
the plugin to find them. For guidance, see #4920. This limitation will be
lifted in the future when the social plugin will receive its next update.
Both types of logos, images ([`theme.logo`](changing-the-logo-and-icons.md#image))
and icons ([`theme.icon.logo`](changing-the-logo-and-icons.md#icon-bundled)) are supported.
While an image logo is used as-is, icons are filled with the
([`social.cards_color.text`](#+social.cards_color)) color. Valid file paths inside the
[`custom_dir`](../customization.md#setup-and-theme-structure) will take priority.

[colors]: changing-the-colors.md#primary-color
[fonts]: changing-the-fonts.md#regular-font
Expand Down
31 changes: 27 additions & 4 deletions material/plugins/social/plugin.py
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ class SocialPlugin(BasePlugin[SocialPluginConfig]):

def __init__(self):
self._executor = concurrent.futures.ThreadPoolExecutor(4)
self.custom_dir = None

# Retrieve configuration
def on_config(self, config):
Expand Down Expand Up @@ -112,6 +113,13 @@ def on_config(self, config):
# Retrieve color overrides
self.color = { **self.color, **self.config.cards_color }

# Retrieve custom_dir path
for user_config in config.user_configs:
custom_dir = user_config.get("theme", {}).get("custom_dir")
if custom_dir:
self.custom_dir = custom_dir
break

# Retrieve logo and font
self._resized_logo_promise = self._executor.submit(self._load_resized_logo, config)
self.font = self._load_font(config)
Expand Down Expand Up @@ -344,28 +352,43 @@ def _load_logo(self, config):
if "logo" in theme:
_, extension = os.path.splitext(theme["logo"])

# Load SVG and convert to PNG
path = os.path.join(config.docs_dir, theme["logo"])

# Allow users to put the logo inside their custom_dir (theme["logo"] case)
if self.custom_dir:
custom_dir_logo = os.path.join(self.custom_dir, theme["logo"])
if os.path.exists(custom_dir_logo):
path = custom_dir_logo

# Load SVG and convert to PNG
if extension == ".svg":
return self._load_logo_svg(path)

# Load PNG, JPEG, etc.
return Image.open(path).convert("RGBA")

# Handle icons
logo = "material/library"
icon = theme["icon"] or {}
if "logo" in icon and icon["logo"]:
logo = icon["logo"]
else:
logo = "material/library"

# Resolve path of package
base = os.path.abspath(os.path.join(
os.path.dirname(__file__),
"../.."
))

# Load icon data and fill with color
path = f"{base}/.icons/{logo}.svg"

# Allow users to put the logo inside their custom_dir (theme["icon"]["logo"] case)
if self.custom_dir:
custom_dir_logo = os.path.join(self.custom_dir, ".icons", f"{logo}.svg")
if os.path.exists(custom_dir_logo):
path = custom_dir_logo

# Load icon data and fill with color
return self._load_logo_svg(path, self.color["text"])

# Load SVG file and convert to PNG
Expand All @@ -388,7 +411,7 @@ def _load_font(self, config):

# Retrieve from theme (default: Roboto)
theme = config.theme
if theme["font"]:
if isinstance(theme["font"], dict) and "text" in theme["font"]:
name = theme["font"]["text"]
else:
name = "Roboto"
Expand Down
31 changes: 27 additions & 4 deletions src/plugins/social/plugin.py
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ class SocialPlugin(BasePlugin[SocialPluginConfig]):

def __init__(self):
self._executor = concurrent.futures.ThreadPoolExecutor(4)
self.custom_dir = None

# Retrieve configuration
def on_config(self, config):
Expand Down Expand Up @@ -112,6 +113,13 @@ def on_config(self, config):
# Retrieve color overrides
self.color = { **self.color, **self.config.cards_color }

# Retrieve custom_dir path
for user_config in config.user_configs:
custom_dir = user_config.get("theme", {}).get("custom_dir")
if custom_dir:
self.custom_dir = custom_dir
break

# Retrieve logo and font
self._resized_logo_promise = self._executor.submit(self._load_resized_logo, config)
self.font = self._load_font(config)
Expand Down Expand Up @@ -344,28 +352,43 @@ def _load_logo(self, config):
if "logo" in theme:
_, extension = os.path.splitext(theme["logo"])

# Load SVG and convert to PNG
path = os.path.join(config.docs_dir, theme["logo"])

# Allow users to put the logo inside their custom_dir (theme["logo"] case)
if self.custom_dir:
custom_dir_logo = os.path.join(self.custom_dir, theme["logo"])
if os.path.exists(custom_dir_logo):
path = custom_dir_logo

# Load SVG and convert to PNG
if extension == ".svg":
return self._load_logo_svg(path)

# Load PNG, JPEG, etc.
return Image.open(path).convert("RGBA")

# Handle icons
logo = "material/library"
icon = theme["icon"] or {}
if "logo" in icon and icon["logo"]:
logo = icon["logo"]
else:
logo = "material/library"

# Resolve path of package
base = os.path.abspath(os.path.join(
os.path.dirname(__file__),
"../.."
))

# Load icon data and fill with color
path = f"{base}/.icons/{logo}.svg"

# Allow users to put the logo inside their custom_dir (theme["icon"]["logo"] case)
if self.custom_dir:
custom_dir_logo = os.path.join(self.custom_dir, ".icons", f"{logo}.svg")
if os.path.exists(custom_dir_logo):
path = custom_dir_logo

# Load icon data and fill with color
return self._load_logo_svg(path, self.color["text"])

# Load SVG file and convert to PNG
Expand All @@ -388,7 +411,7 @@ def _load_font(self, config):

# Retrieve from theme (default: Roboto)
theme = config.theme
if theme["font"]:
if isinstance(theme["font"], dict) and "text" in theme["font"]:
name = theme["font"]["text"]
else:
name = "Roboto"
Expand Down

0 comments on commit 5c57458

Please sign in to comment.