Add types to examples and docs (#1347)
* Adds a changeset * Add types to examples and docs * Make changes based on review feedback * Avoid using the variable named props * Make path a const
This commit is contained in:
parent
72c916535d
commit
b6a75494b1
8 changed files with 60 additions and 20 deletions
5
.changeset/perfect-kids-occur.md
Normal file
5
.changeset/perfect-kids-occur.md
Normal file
|
@ -0,0 +1,5 @@
|
|||
---
|
||||
'astro': patch
|
||||
---
|
||||
|
||||
Adds interfaces for built-in components
|
|
@ -1,8 +1,14 @@
|
|||
---
|
||||
// fetch all commits for just this page's path
|
||||
const path = "docs/" + Astro.props.path;
|
||||
const url = `https://api.github.com/repos/snowpackjs/astro/commits?path=${path}`;
|
||||
const commitsURL = `https://github.com/snowpackjs/astro/commits/main/${path}`;
|
||||
|
||||
export interface Props {
|
||||
path: string;
|
||||
}
|
||||
|
||||
const { path } = Astro.props as Props;
|
||||
const commitPath = 'docs/' + path;
|
||||
const url = `https://api.github.com/repos/snowpackjs/astro/commits?path=${commitPath}`;
|
||||
const commitsURL = `https://github.com/snowpackjs/astro/commits/main/${commitPath}`;
|
||||
|
||||
async function getCommits(url) {
|
||||
try {
|
||||
|
|
|
@ -11,8 +11,16 @@ let canonicalURL = Astro.request.canonicalURL;
|
|||
|
||||
// collection
|
||||
import authorData from '../../data/authors.json';
|
||||
|
||||
interface MarkdownFrontmatter {
|
||||
date: number;
|
||||
description: string;
|
||||
title: string;
|
||||
author: string;
|
||||
}
|
||||
|
||||
export function getStaticPaths() {
|
||||
const allPosts = Astro.fetchContent('../post/*.md');
|
||||
const allPosts = Astro.fetchContent<MarkdownFrontmatter>('../post/*.md');
|
||||
let allAuthorsUnique = [...new Set(allPosts.map(p => p.author))];
|
||||
return allAuthorsUnique.map(author => ({params: {author}, props: {allPosts}}));
|
||||
}
|
||||
|
@ -23,7 +31,7 @@ const { params } = Astro.request;
|
|||
/** filter posts by author, sort by date */
|
||||
const posts = allPosts
|
||||
.filter((post) => post.author === params.author)
|
||||
.sort((a, b) => new Date(b.date) - new Date(a.date));
|
||||
.sort((a, b) => new Date(b.date).valueOf() - new Date(a.date).valueOf());
|
||||
const author = authorData[posts[0].author];
|
||||
---
|
||||
|
||||
|
@ -34,7 +42,7 @@ const author = authorData[posts[0].author];
|
|||
title={title}
|
||||
description={description}
|
||||
image={posts[0].image}
|
||||
canonicalURL={canonicalURL}
|
||||
canonicalURL={canonicalURL.toString()}
|
||||
/>
|
||||
|
||||
<style lang="scss">
|
||||
|
@ -76,7 +84,7 @@ const author = authorData[posts[0].author];
|
|||
|
||||
<main class="wrapper">
|
||||
<h2 class="title">
|
||||
<div class="avatar"><img class="avatar-img" src={author.image} alt=""}></div>
|
||||
<div class="avatar"><img class="avatar-img" src={author.image} alt="" /></div>
|
||||
{author.name}
|
||||
</h2>
|
||||
{posts.map((post) => <PostPreview post={post} author={author} />)}
|
||||
|
|
|
@ -6,6 +6,12 @@ import PostPreview from '../components/PostPreview.astro';
|
|||
import Pagination from '../components/Pagination.astro';
|
||||
import authorData from '../data/authors.json';
|
||||
|
||||
interface MarkdownFrontmatter {
|
||||
date: number;
|
||||
image: string;
|
||||
author: string;
|
||||
}
|
||||
|
||||
// Component Script:
|
||||
// You can write any JavaScript/TypeScript that you'd like here.
|
||||
// It will run during the build, but never in the browser.
|
||||
|
@ -14,8 +20,8 @@ let title = 'Don’s Blog';
|
|||
let description = 'An example blog on Astro';
|
||||
|
||||
// Data Fetching: List all Markdown posts in the repo.
|
||||
let allPosts = Astro.fetchContent('./post/*.md');
|
||||
allPosts.sort((a, b) => new Date(b.date) - new Date(a.date));
|
||||
let allPosts = Astro.fetchContent<MarkdownFrontmatter>('./post/*.md');
|
||||
allPosts.sort((a, b) => new Date(b.date).valueOf() - new Date(a.date).valueOf());
|
||||
let firstPage = allPosts.slice(0, 2);
|
||||
|
||||
// Full Astro Component Syntax:
|
||||
|
@ -33,14 +39,14 @@ let firstPage = allPosts.slice(0, 2);
|
|||
</head>
|
||||
|
||||
<body>
|
||||
<Nav />
|
||||
<Nav title={title} />
|
||||
|
||||
<main class="wrapper">
|
||||
{allPosts.map((post) => <PostPreview post={post} author={authorData[post.author]} />)}
|
||||
</main>
|
||||
|
||||
<footer>
|
||||
<Pagination nextUrl="/posts/2" />
|
||||
<Pagination prevUrl="/posts" nextUrl="/posts/2" />
|
||||
</footer>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -10,10 +10,16 @@ let description = 'An example blog on Astro';
|
|||
let canonicalURL = Astro.request.canonicalURL;
|
||||
|
||||
// collection
|
||||
interface MarkdownFrontmatter {
|
||||
date: number;
|
||||
description: string;
|
||||
title: string;
|
||||
}
|
||||
|
||||
import authorData from '../../data/authors.json';
|
||||
export async function getStaticPaths({paginate, rss}) {
|
||||
const allPosts = Astro.fetchContent('../post/*.md');
|
||||
const sortedPosts = allPosts.sort((a, b) => new Date(b.date) - new Date(a.date));
|
||||
const allPosts = Astro.fetchContent<MarkdownFrontmatter>('../post/*.md');
|
||||
const sortedPosts = allPosts.sort((a, b) => new Date(b.date).valueOf() - new Date(a.date).valueOf());
|
||||
|
||||
// Generate an RSS feed from this collection of posts.
|
||||
// NOTE: This is disabled by default, since it requires `buildOptions.site` to be set in your "astro.config.mjs" file.
|
||||
|
@ -28,7 +34,7 @@ export async function getStaticPaths({paginate, rss}) {
|
|||
// pubDate: item.date,
|
||||
// })),
|
||||
// });
|
||||
|
||||
|
||||
// Return a paginated collection of paths for all posts
|
||||
return paginate(sortedPosts, {pageSize: 1});
|
||||
}
|
||||
|
@ -43,7 +49,7 @@ const { page } = Astro.props;
|
|||
title={title}
|
||||
description={description}
|
||||
image={page.data[0].image}
|
||||
canonicalURL={canonicalURL}
|
||||
canonicalURL={canonicalURL.toString()}
|
||||
prev={page.url.prev}
|
||||
next={page.url.next}
|
||||
/>
|
||||
|
|
|
@ -23,6 +23,7 @@ const { title, author, publishDate, heroImage, alt } = Astro.props;
|
|||
<main>
|
||||
<slot />
|
||||
</main>
|
||||
</div>
|
||||
</article>
|
||||
</div>
|
||||
|
||||
|
|
|
@ -4,6 +4,9 @@ import BaseHead from '../components/BaseHead.astro';
|
|||
import BlogHeader from '../components/BlogHeader.astro';
|
||||
import BlogPostPreview from '../components/BlogPostPreview.astro';
|
||||
|
||||
interface MarkdownFrontmatter {
|
||||
publishDate: number;
|
||||
}
|
||||
|
||||
// Component Script:
|
||||
// You can write any JavaScript/TypeScript that you'd like here.
|
||||
|
@ -14,8 +17,9 @@ let description = 'The perfect starter for your perfect blog.';
|
|||
let permalink = 'https://example.com/';
|
||||
|
||||
// Data Fetching: List all Markdown posts in the repo.
|
||||
let allPosts = Astro.fetchContent('./posts/*.md');
|
||||
allPosts = allPosts.sort((a, b) => new Date(b.publishDate) - new Date(a.publishDate));
|
||||
|
||||
let allPosts = Astro.fetchContent<MarkdownFrontmatter>('./posts/*.md');
|
||||
allPosts = allPosts.sort((a, b) => new Date(b.publishDate).valueOf() - new Date(a.publishDate).valueOf());
|
||||
|
||||
// Full Astro Component Syntax:
|
||||
// https://docs.astro.build/core-concepts/astro-components/
|
||||
|
|
|
@ -4,9 +4,13 @@ import Footer from '../components/Footer/index.jsx';
|
|||
import Nav from '../components/Nav/index.jsx';
|
||||
import PortfolioPreview from '../components/PortfolioPreview/index.jsx';
|
||||
|
||||
const projects = Astro.fetchContent('./project/*.md')
|
||||
.filter(({ published_at }) => !!published_at)
|
||||
.sort((a, b) => new Date(b.published_at) - new Date(a.published_at));
|
||||
interface MarkdownFrontmatter {
|
||||
publishDate: number;
|
||||
}
|
||||
|
||||
const projects = Astro.fetchContent<MarkdownFrontmatter>('./project/*.md')
|
||||
.filter(({ publishDate }) => !!publishDate)
|
||||
.sort((a, b) => new Date(b.publishDate).valueOf() - new Date(a.publishDate).valueOf());
|
||||
---
|
||||
|
||||
<html lang="en">
|
||||
|
|
Loading…
Reference in a new issue