Updated to Astro 1.0.3
This commit is contained in:
parent
a5b62fe90e
commit
7006f071a9
6
.gitignore
vendored
6
.gitignore
vendored
@ -1,14 +1,16 @@
|
|||||||
# build output
|
# build output
|
||||||
dist
|
dist/
|
||||||
|
.output/
|
||||||
|
|
||||||
# dependencies
|
# dependencies
|
||||||
node_modules/
|
node_modules/
|
||||||
.snowpack/
|
|
||||||
|
|
||||||
# logs
|
# logs
|
||||||
npm-debug.log*
|
npm-debug.log*
|
||||||
yarn-debug.log*
|
yarn-debug.log*
|
||||||
yarn-error.log*
|
yarn-error.log*
|
||||||
|
pnpm-debug.log*
|
||||||
|
|
||||||
|
|
||||||
# environment variables
|
# environment variables
|
||||||
.env
|
.env
|
||||||
|
2
.npmrc
2
.npmrc
@ -1,2 +1,2 @@
|
|||||||
## force pnpm to hoist
|
# Expose Astro dependencies for `pnpm` users
|
||||||
shamefully-hoist=true
|
shamefully-hoist=true
|
4
.vscode/extensions.json
vendored
Normal file
4
.vscode/extensions.json
vendored
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
{
|
||||||
|
"recommendations": ["astro-build.astro-vscode"],
|
||||||
|
"unwantedRecommendations": []
|
||||||
|
}
|
11
.vscode/launch.json
vendored
Normal file
11
.vscode/launch.json
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"version": "0.2.0",
|
||||||
|
"configurations": [
|
||||||
|
{
|
||||||
|
"command": "./node_modules/.bin/astro dev",
|
||||||
|
"name": "Development server",
|
||||||
|
"request": "launch",
|
||||||
|
"type": "node-terminal"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
2
LICENSE
2
LICENSE
@ -1,6 +1,6 @@
|
|||||||
MIT License
|
MIT License
|
||||||
|
|
||||||
Copyright (c) 2021 Maxi Ferreira
|
Copyright (c) 2022 Maxi Ferreira
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
@ -18,6 +18,7 @@ npm init astro -- --template Charca/astro-blog-template
|
|||||||
|
|
||||||
## ✨ Features:
|
## ✨ Features:
|
||||||
|
|
||||||
|
- ✅ Astro 1.0
|
||||||
- ✅ Dark Mode
|
- ✅ Dark Mode
|
||||||
- ✅ Full Markdown support
|
- ✅ Full Markdown support
|
||||||
- ✅ SEO-friendly setup with canonical URLs and OpenGraph data
|
- ✅ SEO-friendly setup with canonical URLs and OpenGraph data
|
||||||
@ -52,7 +53,7 @@ Any static assets, like images, can be placed in the `public/` directory.
|
|||||||
All commands are run from the root of the project, from a terminal:
|
All commands are run from the root of the project, from a terminal:
|
||||||
|
|
||||||
| Command | Action |
|
| Command | Action |
|
||||||
|:---------------- |:-------------------------------------------- |
|
| :---------------- | :------------------------------------------- |
|
||||||
| `npm install` | Installs dependencies |
|
| `npm install` | Installs dependencies |
|
||||||
| `npm run dev` | Starts local dev server at `localhost:3030` |
|
| `npm run dev` | Starts local dev server at `localhost:3030` |
|
||||||
| `npm run build` | Build your production site to `./dist/` |
|
| `npm run build` | Build your production site to `./dist/` |
|
||||||
|
@ -1,17 +1,9 @@
|
|||||||
export default {
|
import { defineConfig } from 'astro/config'
|
||||||
// projectRoot: '.', // Where to resolve all URLs relative to. Useful if you have a monorepo project.
|
import svelte from '@astrojs/svelte'
|
||||||
// pages: './src/pages', // Path to Astro components, pages, and data
|
import mdx from '@astrojs/mdx'
|
||||||
// dist: './dist', // When running `astro build`, path to final static output
|
|
||||||
// public: './public', // A folder of static files Astro will copy to the root. Useful for favicons, images, and other files that don’t need processing.
|
// https://astro.build/config
|
||||||
buildOptions: {
|
export default defineConfig({
|
||||||
site: 'https://astro-blog-template.netlify.app', // Your public domain, e.g.: https://my-site.dev/. Used to generate sitemaps and canonical URLs.
|
site: 'https://astro-blog-template.netlify.app',
|
||||||
sitemap: true, // Generate sitemap (set to "false" to disable)
|
integrations: [mdx(), svelte()],
|
||||||
},
|
})
|
||||||
devOptions: {
|
|
||||||
// hostname: 'localhost', // The hostname to run the dev server on.
|
|
||||||
port: 3030, // The port to run the dev server on.
|
|
||||||
},
|
|
||||||
renderers: [
|
|
||||||
"@astrojs/renderer-svelte"
|
|
||||||
],
|
|
||||||
};
|
|
||||||
|
10452
package-lock.json
generated
10452
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -6,11 +6,13 @@
|
|||||||
"dev": "astro dev",
|
"dev": "astro dev",
|
||||||
"start": "astro dev",
|
"start": "astro dev",
|
||||||
"build": "astro build",
|
"build": "astro build",
|
||||||
"preview": "astro preview"
|
"preview": "astro preview",
|
||||||
|
"astro": "astro"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"astro": "^0.21.5",
|
"@astrojs/mdx": "^0.8.3",
|
||||||
"@astrojs/renderer-svelte": "^0.2.1"
|
"@astrojs/svelte": "^1.0.0",
|
||||||
|
"astro": "^1.0.3"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"reading-time": "^1.5.0"
|
"reading-time": "^1.5.0"
|
||||||
|
@ -1,9 +1,13 @@
|
|||||||
---
|
---
|
||||||
|
import '../styles/global.css'
|
||||||
|
import '../styles/highlight.css'
|
||||||
|
|
||||||
export interface Props {
|
export interface Props {
|
||||||
title: string;
|
title: string;
|
||||||
description: string;
|
description: string;
|
||||||
permalink: string;
|
permalink: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
const { title, description, permalink } = Astro.props;
|
const { title, description, permalink } = Astro.props;
|
||||||
const socialUrl = Astro.site.href + 'assets/social.png'
|
const socialUrl = Astro.site.href + 'assets/social.png'
|
||||||
---
|
---
|
||||||
@ -38,10 +42,6 @@ const socialUrl = Astro.site.href + 'assets/social.png'
|
|||||||
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
|
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
|
||||||
<link href="https://fonts.googleapis.com/css2?family=Fira+Sans:wght@400;600;700&family=Merriweather:ital,wght@0,400;0,700;1,400;1,700&display=swap" rel="stylesheet">
|
<link href="https://fonts.googleapis.com/css2?family=Fira+Sans:wght@400;600;700&family=Merriweather:ital,wght@0,400;0,700;1,400;1,700&display=swap" rel="stylesheet">
|
||||||
|
|
||||||
<!-- Styles -->
|
|
||||||
<link rel="stylesheet" href={Astro.resolve('../styles/global.css')} />
|
|
||||||
<link rel="stylesheet" href={Astro.resolve('../styles/highlight.css')} />
|
|
||||||
|
|
||||||
<!-- This is intentionally inlined to avoid FOUC -->
|
<!-- This is intentionally inlined to avoid FOUC -->
|
||||||
<script>
|
<script>
|
||||||
const root = document.documentElement;
|
const root = document.documentElement;
|
||||||
|
@ -3,15 +3,16 @@ import BaseLayout from '../../layouts/BaseLayout.astro';
|
|||||||
import Bio from '../../components/Bio.astro';
|
import Bio from '../../components/Bio.astro';
|
||||||
import getPostData from '../../utils/getPostData';
|
import getPostData from '../../utils/getPostData';
|
||||||
|
|
||||||
export function getStaticPaths() {
|
export async function getStaticPaths() {
|
||||||
const posts = Astro.fetchContent('../../data/blog-posts/*.md');
|
const posts = await Astro.glob('../../data/blog-posts/*.md');
|
||||||
return posts.map(p => ({
|
return posts.map(p => ({
|
||||||
params: { slug: p.file.pathname.split('/').pop().split('.').shift() },
|
params: { slug: p.file.split('/').pop().split('.').shift() },
|
||||||
props: { post: p },
|
props: { post: p },
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
const { Content, title, description, publishDate, heroImage } = Astro.props.post;
|
const { Content, frontmatter } = Astro.props.post;
|
||||||
|
const { title, description, publishDate } = frontmatter;
|
||||||
const { slug, readingTime } = getPostData(Astro.props.post);
|
const { slug, readingTime } = getPostData(Astro.props.post);
|
||||||
const permalink = `${Astro.site.href}${slug}`;
|
const permalink = `${Astro.site.href}${slug}`;
|
||||||
---
|
---
|
||||||
|
@ -5,25 +5,25 @@ const title = 'Blog';
|
|||||||
const description = 'Latest articles.';
|
const description = 'Latest articles.';
|
||||||
const permalink = `${Astro.site.href}blog`;
|
const permalink = `${Astro.site.href}blog`;
|
||||||
|
|
||||||
let allPosts = await Astro.fetchContent('../../data/blog-posts/*.md');
|
let allPosts = await Astro.glob('../../data/blog-posts/*.md');
|
||||||
allPosts = allPosts.sort((a, b) => new Date(b.publishDate).valueOf() - new Date(a.publishDate).valueOf());
|
allPosts = allPosts.sort((a, b) => new Date(b.frontmatter.publishDate).valueOf() - new Date(a.frontmatter.publishDate).valueOf());
|
||||||
---
|
---
|
||||||
|
|
||||||
<BaseLayout title={title} description={description} permalink={permalink} current="blog">
|
<BaseLayout title={title} description={description} permalink={permalink} current="blog">
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<h1>Blog</h1>
|
<h1>Blog</h1>
|
||||||
{allPosts.map((post, index) => {
|
{allPosts.map((post, index) => {
|
||||||
const href = `/blog/${post.file.pathname.split('/').pop().split('.').shift()}`;
|
const href = `/blog/${post.file.split('/').pop().split('.').shift()}`;
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
{ index !== 0 && <hr /> }
|
{ index !== 0 && <hr /> }
|
||||||
<div class="post-item">
|
<div class="post-item">
|
||||||
<h2>
|
<h2>
|
||||||
<a href={href}>{post.title}</a>
|
<a href={href}>{post.frontmatter.title}</a>
|
||||||
</h2>
|
</h2>
|
||||||
<p>{post.description}</p>
|
<p>{post.frontmatter.description}</p>
|
||||||
<div class="post-item-footer">
|
<div class="post-item-footer">
|
||||||
<span class="post-item-date">— {post.publishDate}</span>
|
<span class="post-item-date">— {post.frontmatter.publishDate}</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,14 +1,14 @@
|
|||||||
import readingTime from 'reading-time';
|
import readingTime from 'reading-time'
|
||||||
|
|
||||||
type Post = {
|
type Post = {
|
||||||
title: string,
|
title: string
|
||||||
file: URL,
|
file: string
|
||||||
content: { source: string }
|
rawContent: () => string
|
||||||
}
|
}
|
||||||
|
|
||||||
export default function getPostData(post: Post) {
|
export default function getPostData(post: Post) {
|
||||||
return {
|
return {
|
||||||
slug: post.file.pathname.split('/').pop().split('.').shift(),
|
slug: post.file.split('/').pop().split('.').shift(),
|
||||||
readingTime: readingTime(post.content.source).text,
|
readingTime: readingTime(post.rawContent()).text,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,15 @@
|
|||||||
{
|
{
|
||||||
"moduleResolution": "node"
|
"compilerOptions": {
|
||||||
|
// Enable top-level await, and other modern ESM features.
|
||||||
|
"target": "ESNext",
|
||||||
|
"module": "ESNext",
|
||||||
|
// Enable node-style module resolution, for things like npm package imports.
|
||||||
|
"moduleResolution": "node",
|
||||||
|
// Enable JSON imports.
|
||||||
|
"resolveJsonModule": true,
|
||||||
|
// Enable stricter transpilation for better output.
|
||||||
|
"isolatedModules": true,
|
||||||
|
// Astro will directly run your TypeScript code, no transpilation needed.
|
||||||
|
"noEmit": true
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user