AstroPaper is a highly customizable Astro blog theme. With AstroPaper, you can customize everything according to your personal taste. This article will explain how you can make some customizations easily in the config file.
Table of contents
Open Table of contents
Configuring SITE
The important configurations resides in src/config.ts file. Within that file, you’ll see the SITE object where you can specify your website’s main configurations.
During development, it’s okay to leave SITE.website empty. But in production mode, you should specify your deployed url in SITE.website option since this will be used for canonical URL, social card URL etc.. which are important for SEO.
export const SITE = {
  website: "https://astro-paper.pages.dev/", // replace this with your deployed domain
  author: "Sat Naing",
  profile: "https://satnaing.dev/",
  desc: "A minimal, responsive and SEO-friendly Astro blog theme.",
  title: "AstroPaper",
  ogImage: "astropaper-og.jpg",
  lightAndDarkMode: true,
  postPerIndex: 4,
  postPerPage: 4,
  scheduledPostMargin: 15 * 60 * 1000, // 15 minutes
  showArchives: true,
  showBackButton: true, // show back button in post detail
  editPost: {
    enabled: true,
    text: "Suggest Changes",
    url: "https://github.com/satnaing/astro-paper/edit/main/",
  },
  dynamicOgImage: true, // enable automatic dynamic og-image generation
  dir: "ltr", // "rtl" | "auto"
  lang: "en", // html lang code. Set this empty and default will be "en"
  timezone: "Asia/Bangkok", // Default global timezone (IANA format) https://en.wikipedia.org/wiki/List_of_tz_database_time_zones
} as const;src/config.tsHere are SITE configuration options
| Options | Description | 
|---|---|
| website | Your deployed website URL | 
| author | Your name | 
| profile | Your personal/portfolio website URL which is used for better SEO. Put nullor empty string""if you don’t have any. | 
| desc | Your site description. Useful for SEO and social media sharing. | 
| title | Your site name | 
| ogImage | Your default OG image for the site. Useful for social media sharing. OG images can be an external image URL or they can be placed under /publicdirectory. | 
| lightAndDarkMode | Enable or disable light & dark modefor the website. If disabled, primary color scheme will be used. This option is enabled by default. | 
| postPerIndex | The number of posts to be displayed at the home page under Recentsection. | 
| postPerPage | You can specify how many posts will be displayed in each posts page. (eg: if you set SITE.postPerPageto 3, each page will only show 3 posts per page) | 
| scheduledPostMargin | In Production mode, posts with a future pubDatetimewill not be visible. However, if a post’spubDatetimeis within the next 15 minutes, it will be visible. You can setscheduledPostMarginif you don’t like the default 15 minutes margin. | 
| showArchives | Determines whether to display the Archivesmenu (positioned between theAboutandSearchmenus) and its corresponding page on the site. This option is set totrueby default. | 
| showBackButton | Determines whether to display the Go backbutton in each blog post. | 
| editPost | This option allows users to suggest changes to a blog post by providing an edit link under blog post titles. This feature can be disabled by setting SITE.editPost.enabledtofalse. | 
| dynamicOgImage | This option controls whether to generate dynamic og-image if no ogImageis specified in the blog post frontmatter. If you have many blog posts, you might want to disable this feature. See the trade-off for more details. | 
| dir | Specifies the text direction of the entire blog. Used as HTML dir attribute in <html dir="ltr">. Supported values:ltr|rtl|auto | 
| lang | Used as HTML ISO Language code in <html lang"en">. Default isen. | 
| timezone | This option allows you to specify your timezone using the IANA format. Setting this ensures consistent timestamps across your localhost and deployed site, eliminating time differences. | 
Update layout width
The default max-width for the entire blog is 768px (max-w-3xl). If you’d like to change it, you can easily update the max-w-app utility in your global.css. For instance:
@utility max-w-app {
  @apply max-w-3xl;
  @apply max-w-4xl xl:max-w-5xl;
}src/styles/global.cssYou can explore more max-width values in the Tailwind CSS docs.
Configuring logo or title
Prior to AstroPaper v5, you can update your site name/logo in LOGO_IMAGE object inside src/config.ts file. However, in AstroPaper v5, this option has been removed in favor of Astro’s built-in SVG and Image components.

There are 3 options you can do:
Option 1: SITE title text
This is the easiest option. You just have to update SITE.title in src/config.ts file.
Option 2: Astro’s SVG component
You might want to use this option if you want to use an SVG logo.
- 
First add an SVG inside src/assetsdirectory. (eg:src/assets/dummy-logo.svg)
- 
Then import that SVG inside Header.astro--- // ... import DummyLogo from "@/assets/dummy-logo.svg"; ---src/components/Header.astro
- 
Finally, replace {SITE.title}with imported logo.<a href="/" class="absolute py-1 text-left text-2xl leading-7 font-semibold whitespace-nowrap sm:static" > <DummyLogo class="scale-75 dark:invert" /> <!-- {SITE.title} --> </a>
The best part of this approach is that you can customize your SVG styles as needed. In the example above, you can see how the SVG logo color can be inverted in dark mode.
Option 3: Astro’s Image component
If your logo is an image but not SVG, you can use Astro’s Image component.
- 
Add your logo inside src/assetsdirectory. (eg:src/assets/dummy-logo.png)
- 
Import Imageand your logo inHeader.astro--- // ... import { Image } from "astro:assets"; import dummyLogo from "@/assets/dummy-logo.png"; ---src/components/Header.astro
- 
Then, replace {SITE.title}with imported logo.<a href="/" class="absolute py-1 text-left text-2xl leading-7 font-semibold whitespace-nowrap sm:static" > <image src="{dummyLogo}" alt="Dummy Blog" class="dark:invert" /> <!-- {SITE.title} --> </a>
With this approach, you can still adjust your image’s appearance using CSS classes. However, this might not always fit what you want. If you need to display different logo images based on light or dark mode, check how light/dark icons are handled inside the Header.astro component.
Configuring social links
You can configure social links in SOCIALS object inside constants.ts.
export const SOCIALS = [
  {
    name: "GitHub",
    href: "https://github.com/satnaing/astro-paper",
    linkTitle: ` ${SITE.title} on GitHub`,
    icon: IconGitHub,
  },
  {
    name: "X",
    href: "https://x.com/username",
    linkTitle: `${SITE.title} on X`,
    icon: IconBrandX,
  },
  {
    name: "LinkedIn",
    href: "https://www.linkedin.com/in/username/",
    linkTitle: `${SITE.title} on LinkedIn`,
    icon: IconLinkedin,
  },
  {
    name: "Mail",
    href: "mailto:yourmail@gmail.com",
    linkTitle: `Send an email to ${SITE.title}`,
    icon: IconMail,
  },
] as const;src/constants.tsConfiguring share links
You can configure share links in SHARE_LINKS object inside src/constants.ts.
Conclusion
This is the brief specification of how you can customize this theme. You can customize more if you know some coding. For customizing styles, please read this article. Thanks for reading.✌🏻