This post is an advanced guide on customizing the Astro AntfuStyle Theme. If you have not yet configured the src/config.ts
file, it is recommended to first review Basic Configuration.
Customizing Logo#
Designing Your Own Logo
Generate a text-based logo using Google Font to Svg Path or create one with AI tools. If proficient, you could use Adobe Illustrator for more professional designs.
Once your logo’s SVG file is ready, you’ll need to update the LogoButton
component and the template for the autogenerated OG Images to include your new logo.
Modifying the LogoButton Component
Open src/components/widgets/LogoButton.astro
. This file contains both an ICON SVG and a TEXT SVG, which are currently commented. You can uncomment and switch between them to see different effects.
Replace the existing SVG with your logo’s SVG in this component. Ensure to keep the aria-hidden="true"
attribute within the <svg>
tag for accessibility purposes.
If your logo includes black and white, you may need to adjust for theme changes between light and dark modes:
Further customize your logo through the CSS within the <style>
section of the component, such as adjusting opacity, scaling, or adding animations.
The existing grow keyframe animation, applied to the draw
class, can be modified or removed as needed. For tips on animating SVGs, see Animated SVG Logo.
Modifying the Autogenerated OG Images Template
Open the plugins/og-template/markup.ts
file and replace the SVG section entirely.
You may need to adjust the SVG element’s width
, height
, and viewBox
attributes to fit properly. It’s recommended to paste the code below into the Satori - OG Image Playground under the Tailwind (experimental) tab for testing.
Adjust Black Elements in Your Logo
Since the theme’s OG Images use a black background, modify any pure black elements in your logo to white for better visibility.
Replacing the Website Icon#
Once you’ve customized the logo and have the SVG file, it’s time to generate the necessary icons to replace the website’s favicon. You’ll need to generate the following Ultimate Favicon Setup:
favicon.ico
: For legacy browsers.favicon.svg
: A single SVG icon with light/dark modes for modern browsers.apple-touch-icon.png
: A 180×180 PNG for Apple devices.icon-192.png
,icon-512.png
,icon-mask.png
: Icons for the web app manifest, including a 192×192 icon for home screens, a 512×512 maskable icon for different Android launchers, and a 512×512 icon for splash screens when the PWA( Progressive Web App) is loading.
Web App Manifest
A web app manifest is a JSON file that helps a browser install your website as an app. It originated from Google’s PWA initiative.
First, open the favicon.svg
file in a text editor. Locate a <path>
element with a dark or missing fill, and add a CSS media query to adjust the fill color based on the theme:
Next, use the steps in How to Favicon in 2024 or Real Favicon Generator to generate the icons. Rename the files as mentioned above and copy them to the public
directory to replace the existing ones.
Lastly, update src/pages/manifest.webmanifest.js
with the following:
If you don’t need PWA support, you can delete manifest.webmanifest.js
, icon-192.png
, icon-512.png
, and icon-mask.png
.
Handling Icons after Using Real Favicon Generator
If you use Real Favicon Generator, rename android-chrome-192x192.png
to icon-192.png
and copy android-chrome-512x512.png
twice, renaming one to icon-512.png
and the other to icon-mask.png
.
Check the icon-mask.png
with maskable.app to ensure it meets the requirements for maskable icons. It should have bigger paddings around the icon so it can be cropped by the launcher to fit its design. The safe zone is a central circle of 409×409.
Customizing Website Styles#
While the theme offers some quick UI configuration options in the src/config.ts
, these are limited. If you’re familiar with CSS, you can fully customize the website styles, but it’s recommended to follow the methods outlined below.
Styling approaches
- Native CSS (in CSS files and component
<style>
tags) - UnoCSS utility classes (configured with @unocss/preset-uno, compatible with Tailwind CSS and Windi CSS)
- Custom CSS utility classes (in
unocss.config.ts
underrules
andshortcuts
)
Where styles are defined
styles/main.css
: Global styles.styles/prose.css
: Prose related styles.styles/markdown.css
: Plugin and integration-related styles.src/components/
: Component-specific styles.
To modify CSS rulesets in the stylesheets
For example, adjusting the max-width
of prose content:
To modify specific component styles
For example, changing the font of group titles on the /projects
page:
Additional Style Modification Tips
- Avoid modifying the core stylesheets or component
<style>
sections directly for easier updates, as future theme versions may bring changes. - Create a new
src/styles/your.css
file and override styles using class selectors. - For details on style application precedence in Astro, refer to Astro - CSS & Styling - Cascading Order. If your styles don’t apply, check for CSS specificity and try using
!important
as needed.
Customizing Fonts#
The theme has configured @unocss/preset-web-fonts. Simply choose a font from Google Fonts and modify the fonts
configuration in unocss.config.ts
:
Modifying the Class Utilities ( font-sans, font-serif, and font-mono) will append new fonts to the existing setup.
By default, UnoCSS fetches fonts from the provider’s CDN. To host fonts locally, refer to UnoCSS - Serve Fonts Locally.
Customizing Footer#
You can directly modify the src/components/base/Footer.astro
file. For instance, if you want to apply the CC BY-NC-SA 4.0 license, you can update the code as follows:
Of course, it would greatly appreciated if you could also keep the Powered by Astro AntfuStyle Theme
part to help more people discover it. 😊
Final Cleanup#
Finally, you may want to:
- Delete the
.github
directory Remove the.github
directory (mainly for workflows and templates, but thescheduled-vercel-deploy.yml
file may be useful for Customizing GitHub Activity Pages). - Clean up
public/og-images/
,src/content/
andsrc/assets/
directories。 - Check
.vscode/settings.json
for adjustments. - Rewrite
README.md
.
Wrapping Up#
This is a general overview of what you can customize in the project. If you’re proficient with code, there’s even more you can personalize!
Next, check out Authoring Content to learn how to tailor each page to your liking.
If you encounter any issues, find errors, or see opportunities for improvement, feel free to join the discussion or submit an issue or pull request. Your feedback is highly appreciated! ❤️