-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathblog-post.tsx
113 lines (109 loc) · 3.27 KB
/
blog-post.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
import { useLoaderData } from "@remix-run/react";
import { Image } from "@shopify/hydrogen";
import type { Article } from "@shopify/hydrogen/storefront-api-types";
import type {
HydrogenComponentProps,
HydrogenComponentSchema,
} from "@weaverse/hydrogen";
import { forwardRef } from "react";
import { IconFacebook, IconPinterest } from "~/modules/icon";
import { Section } from "~/modules/text";
interface BlogPostProps extends HydrogenComponentProps {
paddingTop: number;
paddingBottom: number;
}
let BlogPost = forwardRef<HTMLElement, BlogPostProps>((props, ref) => {
let { paddingTop, paddingBottom, ...rest } = props;
let { article, formattedDate } = useLoaderData<{
article: Article;
formattedDate: string;
}>();
let { title, image, contentHtml, author, tags } = article;
if (article) {
return (
<section ref={ref} {...rest}>
<div
style={{
paddingTop: `${paddingTop}px`,
paddingBottom: `${paddingBottom}px`,
}}
>
<div className="relative h-[520px]">
{image && (
<Image
data={image}
className="w-full absolute inset-0 z-0 object-cover h-full"
sizes="90vw"
/>
)}
<div className="space-y-5 w-full h-full flex items-center justify-end py-16 flex-col relative z-10">
<span className="font-semibold">{formattedDate}</span>
<h1 className="font-bold text-2xl">{title}</h1>
<span className="uppercase">by {author?.name}</span>
</div>
</div>
<Section as="article" padding="all" className="prose mx-auto">
<div className="lg:max-w-screen-lg md:max-w-screen-md max-w-screen-sm px-4 mx-auto space-y-8 md:space-y-16">
<div
suppressHydrationWarning
dangerouslySetInnerHTML={{ __html: contentHtml }}
/>
<div className="md:flex justify-between gap-2 space-y-2">
<div>
<strong>Tags:</strong>
<span className="ml-2">{tags.join(", ")}</span>
</div>
<div className="flex gap-4 items-center">
<strong>Share:</strong>
<IconPinterest viewBox="0 0 24 24" />
<IconFacebook viewBox="0 0 24 24" />
</div>
</div>
</div>
</Section>
</div>
</section>
);
}
return <section ref={ref} {...rest} />;
});
export default BlogPost;
export let schema: HydrogenComponentSchema = {
type: "blog-post",
title: "Blog post",
limit: 1,
enabledOn: {
pages: ["ARTICLE"],
},
inspector: [
{
group: "Blog post",
inputs: [
{
type: "range",
label: "Top padding",
name: "paddingTop",
configs: {
min: 0,
max: 100,
step: 4,
unit: "px",
},
defaultValue: 0,
},
{
type: "range",
label: "Bottom padding",
name: "paddingBottom",
configs: {
min: 0,
max: 100,
step: 4,
unit: "px",
},
defaultValue: 0,
},
],
},
],
};