A blog template powered by Astro
Go to file
2025-04-05 16:59:41 +08:00
.vscode feat: vscode settings 2025-02-12 12:21:20 +08:00
public/favicon feat: remove stylesheet of RSS feed 2025-04-02 15:16:05 +08:00
scaffolds feat: add useful scripts 2025-02-01 18:01:24 +08:00
scripts feat(user scripts): post file name sanitization 2025-03-19 16:05:29 +08:00
src refactor(icon): use width and height attributes instead of text-[size] 2025-04-04 23:11:46 +08:00
.gitignore init: first demo 2025-01-12 03:54:02 +08:00
.prettierignore chore: update .prettierignore 2025-02-24 09:52:47 +08:00
.prettierrc.cjs style: prettier format 2025-01-23 13:34:59 +08:00
.stylelintignore style: prettier format 2025-01-23 13:34:59 +08:00
astro.config.mjs fix: remove outdated TypeScript error comment in astro.config.mjs 2025-03-28 14:56:28 +08:00
eslint.config.js style: prettier format 2025-01-23 13:34:59 +08:00
LICENSE doc: Create LICENSE 2025-02-01 19:21:29 +08:00
package.json feat(comment): supports artalk 2025-04-04 21:14:40 +08:00
README.md docs: update README 2025-04-01 19:30:41 +08:00
README.zh-CN.md docs: rename README Chinese version 2025-04-04 18:13:06 +00:00
stylelint.config.mjs build(deps): upgrade TailwindCSS to v4 2025-02-07 21:39:05 +08:00
tsconfig.json feat: support Waline 2025-03-06 14:37:23 +08:00

Astral Halo

Warning

This project is still under development and may contain bugs and breaking changes. Use with caution.

Live Demo (Netlify) | English | 简体中文

Astral Halo is a static blog template developed with Astro.

Features/TODO

  • Built with Astro and Tailwind CSS (using daisyUI)
  • Freely switchable light/dark themes
  • Responsive design
  • Search functionality (currently only supports Pagefind)
  • Responsive article table of contents
  • Bidirectional references in articles
  • Comments system (supports Twikoo, Giscus and Waline)
  • Various components that can be used in articles
  • Smooth animations and page transitions
  • Useful JS script tools
  • PWA supports

Getting Started

  1. Use this template to generate a new repository or fork this repository.

  2. For local development, clone the repository, run pnpm install to install dependencies, and pnpm dev to start the development server.

    • If pnpm is not installed, first run npm install -g pnpm to install it.
  3. Customize your blog through the configuration file src/config.ts. Configuration documentation can be found in the comments of src/types/config.ts.

  4. Run pnpm new [draft|post] [title] to create a new article. If creating a draft, run pnpm pub [title] to publish it to the src/content/posts directory when finished.

  5. Refer to the official guide to deploy your blog to Vercel, Netlify, GitHub Pages, etc. Before deployment, edit the site settings in astro.config.mjs.

Article Front Matter

---
title: Article Title
slug: post-entry # The article will be generated at the path [BASE_URL]/posts/post-entry/
published: 1970-01-01T00:00:00Z
description: Article Description
category: Lorem
tags: [Foo, Bar]
cover: /path/to/cover.jpg
lang: en # Only needed when article language differs from site language in `config.ts`
comment: true # Enable comments, requires comment system to be enabled and configured in `config.ts`
---

Commands

All commands need to be run from the project root directory:

Command Action
pnpm install Install dependencies
pnpm dev Start dev server at localhost:4321
pnpm build Build static site to ./dist/
pnpm preview Preview built site locally
pnpm new [draft|post] [title] Create new article
pnpm pub Publish draft
pnpm lint Check code
pnpm format Format code
pnpm astro ... Run Astro CLI

Acknowledgments

  • This project is inspired by Fuwari and references some of its code and design elements.
  • This project is inspired by Pure and references some of its code and design elements.
  • This project is inspired by Solitude and references some of its design elements.