rsnext/examples/cms-prismic/components/post-header.tsx
Steven 4466ba436b
chore(examples): use default prettier for examples/templates (#60530)
## Description
This PR ensures that the default prettier config is used for examples
and templates.

This config is compatible with `prettier@3` as well (upgrading prettier
is bigger change that can be a future PR).

## Changes
- Updated `.prettierrc.json` in root with `"trailingComma": "es5"` (will
be needed upgrading to prettier@3)
- Added `examples/.prettierrc.json` with default config (this will
change every example)
- Added `packages/create-next-app/templates/.prettierrc.json` with
default config (this will change every template)

## Related

- Fixes #54402
- Closes #54409
2024-01-11 16:01:44 -07:00

56 lines
1.5 KiB
TypeScript

import { PrismicText } from "@prismicio/react";
import { asText, isFilled } from "@prismicio/helpers";
import { DateField, ImageField, TitleField } from "@prismicio/types";
import { AuthorContentRelationshipField } from "../lib/types";
import Avatar from "../components/avatar";
import Date from "../components/date";
import CoverImage from "../components/cover-image";
import PostTitle from "../components/post-title";
type PostHeaderProps = {
title: TitleField;
coverImage: ImageField;
date: DateField;
author: AuthorContentRelationshipField;
};
export default function PostHeader({
title,
coverImage,
date,
author,
}: PostHeaderProps) {
return (
<>
<PostTitle>
<PrismicText field={title} />
</PostTitle>
<div className="hidden md:block md:mb-12">
{isFilled.contentRelationship(author) && (
<Avatar
name={asText(author.data.name)}
picture={author.data.picture}
/>
)}
</div>
<div className="mb-8 md:mb-16 sm:mx-0">
<CoverImage title={asText(title)} image={coverImage} />
</div>
<div className="max-w-2xl mx-auto">
<div className="block md:hidden mb-6">
{isFilled.contentRelationship(author) && (
<Avatar
name={asText(author.data.name)}
picture={author.data.picture}
/>
)}
</div>
<div className="mb-6 text-lg">
<Date dateField={date} />
</div>
</div>
</>
);
}