Giter Club home page Giter Club logo

astro-obsidian-blog-boilerplate's Introduction

Astro + Obsidian Blog Boilerplate

Logo

This blog boilerplate is ideal for developers looking for a robust, performance-optimized platform for blogging. Set it up on your GitHub repository and start sharing your ideas!

Showcase

DEMO

Kendrick's dev blog | Theo's dev box

Features of the Astro-Obsidian Blog Boilerplate

Icons

This boilerplate harnesses the power of Astro v4, ensuring your blog is built with the latest in web development standards. It leverages Obsidian for seamless content management, allowing you to write and organize posts effortlessly. Here are some key features:

  • Latest Astro v4 Integration: Stay up-to-date with the cutting-edge features of Astro v4.
  • Content Management with Obsidian: Use Obsidian to manage and author your blog posts with ease.
  • Image Optimization: Implements sharp for optimal image processing.
  • Astro View Transitions: Enhance user experience with smooth view transitions as detailed in the Astro documentation.
  • Web Analytics and Speed Insights on Vercel: Gain insights into your site's performance and visitor behavior.
  • Exceptional Performance Scores: Achieves a score of 100 on both Speed Insights and Lighthouse, ensuring top-tier site speed and SEO performance.
  • Syntax Highlighting: Includes syntax highlighting for code blocks, enhancing readability and aesthetics. It is using shiki
  • Responsive and Fast: A mobile-first approach ensures your blog is responsive and fast across all devices.
  • Built-In Dark Mode: Supports automatic light and dark modes.
  • Accessibility Focused: Delivers a site with thoughtful, semantic, and accessible design.
  • Easy Content Authoring: Create content directly in Markdown format from your favorite code editor or GitHub.
  • Extended Markdown Capabilities with Markdoc: Incorporate custom components like YouTube or Twitter embeds into your Markdown files using Markdoc.
  • Built-In RSS Feed: Automatically generates an RSS feed accessible at /rss.xml.
  • Comprehensive SEO Setup: Every page is equipped with essential SEO features to enhance visibility.

Installation

# Clone the repo
git clone [email protected]:sonim1/astro-obsidian-blog-boilerplate.git my-blog

cd my-blog
# Install dependencies
npm run ci

# Start the dev server
npm run dev

Using Obsidian when editing posts

Download Obsidian

  1. Open Obsidian
  2. Find > Open Vault > Select the /src folder where you have cloned this repo
  3. Done

Now you can use Obsidian to write your post.

  • You can use Obsidian's MakeMD to sort files by creation date.
  • Paste an image into Obsidian and it will be added to src/assets based on the current filename.
  • There are a number of plugins available to help with note taking in Community Plugins in Settings.

Add a new post

You can add new posts using Templater plugin in Obsidian.

Templater is a template language that lets you insert variables and functions results into your notes. It will also let you execute JavaScript code manipulating those variables and functions.

With Templater, you will be able to create powerful templates to automate manual tasks.
  1. Open Obsidian
  2. Open command palette Cmd + P or Ctrl + P
  3. Type Templater: Create new note from template and select it (You can also set a shortcut for this)
  4. Select the new-link-template.mdoc or new-post-template.mdoc template
  5. Done

How do I deploy?

Vercel

Analytics and Speed Insight on Vercel are already set up. After deploying from Vercel, activate them on the Analytics and Speed Insight pages.

You can also use Netlify or another service.

Site customization

Please update the site.config.mjs file

export default {
  localhostURL: `http://localhost:3000`,
  liveURL: 'https://astro-obsidian-blog-boilerplate.vercel.app',
  name: 'My name',
  site: {
    title: 'My Blog',
    description: `Hello world!`,
  },
  defaultLanguage: 'en', // ko | use ISO language code
  header: {
    github: {
      url: 'https://github.com/sonim1',
    },
    youtube: {
      url: 'https://www.youtube.com/@bumfoo/videos',
    },
    website: {
      url: 'https://welcome.sonim1.com',
    },
  },
  seo: {
    twitter: '@your_twitter_handle',
  },
};

Astro Themes

This template is built based on the Blogster theme.

If you want to change the theme. You can use other themes are existing here: https://astro.build/themes/ (Applying a theme manually may require a lot of modifications.)

Adding the new page

  1. Add the new file under the pages folder by following this documenetation
  2. Put your new page link into the src/components/Header.astro file
// src/components/Header.astro
// ...
<nav>
  <section class="text-text-bold">
    <ul class="unset flex gap-4 [&>li]:p-0">
      {/* Put the new link here */}
      <li>
        <HeaderLink href={`/`}>Home</HeaderLink>
      </li>
      <li>
        <HeaderLink href={`/blog`}>Blog</HeaderLink>
      </li>
    </ul>
  </section>
</nav>
// ...

Giscus

Giscus

src/components/CommentSection.astro You can simply add comments by adding the giscus script to the file above.

At this time, please activate lazy mode for page performance.

Contribute ๐Ÿค

TODO

  • Add the starlight link
  • Add the pagination

astro-obsidian-blog-boilerplate's People

Contributors

sonim1 avatar ksc-devbox avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.