To begin, clone the repository and navigate into the project directory:
git clone https://github.com/your-repo/angor-blog.git
cd angor-blog
Next, install the necessary dependencies:
pnpm install
pnpm add sharp
If pnpm
is not already installed, you can install it globally using:
npm install -g pnpm
All commands should be executed from the root directory of the project using a terminal:
Command | Description |
---|---|
pnpm install AND pnpm add sharp |
Install project dependencies |
pnpm dev |
Start the local development server at localhost:4321 |
pnpm build |
Build the production site into the ./dist/ directory |
pnpm preview |
Preview the built site locally before deploying |
pnpm new-post <foldername> |
Create a new blog post |
pnpm astro ... |
Execute Astro CLI commands like astro add , astro check |
pnpm astro --help |
Display help information for the Astro CLI |
Run the following command to create a new post:
pnpm new-post my-awesome-post
This will create:
src/content/posts/
└── my-awesome-post/
├── index.md
└── images/
Edit the frontmatter in index.md
:
---
title: "My Awesome Post" # The title that appears at the top of your post
published: 2024-02-19 # Publication date (auto-filled)
description: "A detailed introduction to blockchain technology" # Brief description
image: "./images/cover.jpg" # Post cover image (relative path)
tags: ["Blockchain", "Technology", "Crypto"] # Related topics
category: "Technology" # Main category
draft: false # Set to true to hide from production
lang: "en" # Language code (en, fa, etc)
---
- Place your post images in the
images
folder - Reference them in your markdown using relative paths:
data:image/s3,"s3://crabby-images/99b8f/99b8f41db95735db72b96d208fd6cde950b43c1b" alt="Image description"
Below the frontmatter, write your post content using Markdown:
## Introduction
This is a paragraph with **bold** and *italic* text.
### Code Examples
```javascript
console.log("Hello World!");
```
### Lists
- Item 1
- Item 2
- Sub-item 2.1
- Sub-item 2.2
### Links
[Visit our website](https://example.com)
### Tables
| Header 1 | Header 2 |
|----------|----------|
| Cell 1 | Cell 2 |
- Run the development server:
pnpm dev
- Open
http://localhost:4321
in your browser - Navigate to your new post
- Set
draft: false
in the frontmatter - Build the site:
pnpm build
- Keep image files under 1MB when possible
- Use descriptive image filenames
- Organize content with clear headings (H2, H3, etc.)
- Add relevant tags for better discoverability
- Include a meaningful description for SEO
Each post file (index.md
) should start with frontmatter in YAML format. Here is an example:
---
title: My First Blog Post
published: 2024-05-08
description: This is the first post.
image: /images/cover.jpg
tags: [Bitcoin, Investment, Angor]
category: Cryptocurrency
draft: false
---
title
: The title of your blog post.published
: The date when the post is published.description
: A brief description of the post.image
: Path to the cover image of the post.tags
: An array of tags relevant to the post.category
: The category under which the post falls.draft
: Set tofalse
when the post is ready to be published.