diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/components/Widget/RecentPosts/RecentPosts.module.scss | 63 | ||||
| -rw-r--r-- | src/components/Widget/RecentPosts/RecentPosts.tsx | 63 | ||||
| -rw-r--r-- | src/components/Widget/index.tsx | 3 | ||||
| m--------- | src/content | 0 | ||||
| -rw-r--r-- | src/styles/pages/Home.module.scss | 8 | 
5 files changed, 137 insertions, 0 deletions
| diff --git a/src/components/Widget/RecentPosts/RecentPosts.module.scss b/src/components/Widget/RecentPosts/RecentPosts.module.scss new file mode 100644 index 0000000..ee7f40d --- /dev/null +++ b/src/components/Widget/RecentPosts/RecentPosts.module.scss @@ -0,0 +1,63 @@ +@use "@styles/abstracts/functions" as fun; +@use "@styles/abstracts/placeholders"; + +.list { +  @extend %flex-list; +  flex-flow: row nowrap; +  align-items: stretch; +  gap: var(--spacing-xs); +  margin-bottom: var(--spacing-md); +} + +.item { +  width: 33%; +} + +.link { +  display: block; +  height: 100%; +  padding: var(--spacing-sm) var(--spacing-sm) var(--spacing-md); +  background: var(--color-bg); +  color: inherit; +  text-decoration: none; +  border: fun.convert-px(3) solid var(--color-primary); +  border-radius: fun.convert-px(5); +  box-shadow: fun.convert-px(1) fun.convert-px(1) fun.convert-px(1) +      var(--color-shadow-light), +    fun.convert-px(1) fun.convert-px(2) fun.convert-px(2) fun.convert-px(-2) +      var(--color-shadow-light), +    fun.convert-px(3) fun.convert-px(4) fun.convert-px(5) fun.convert-px(-4) +      var(--color-shadow-light); +  transition: all 0.3s ease-in-out 0s; + +  &:hover, +  &:focus, +  &:active { +    color: inherit; +  } + +  &:hover, +  &:focus { +    box-shadow: fun.convert-px(1) fun.convert-px(1) fun.convert-px(1) +        var(--color-shadow-lighter), +      fun.convert-px(1) fun.convert-px(2) fun.convert-px(2) fun.convert-px(-2) +        var(--color-shadow-lighter), +      fun.convert-px(3) fun.convert-px(4) fun.convert-px(5) fun.convert-px(-4) +        var(--color-shadow-lighter), +      fun.convert-px(7) fun.convert-px(10) fun.convert-px(12) fun.convert-px(-3) +        var(--color-shadow-lighter); +    transform: scale(1.05); +  } + +  &:active { +    box-shadow: 0 0 0 0 var(--color-shadow-light); +    transform: scale(0.95); +  } +} + +.cover { +  width: 100%; +  height: 100px; +  position: relative; +  margin-bottom: var(--spacing-sm); +} diff --git a/src/components/Widget/RecentPosts/RecentPosts.tsx b/src/components/Widget/RecentPosts/RecentPosts.tsx new file mode 100644 index 0000000..1569284 --- /dev/null +++ b/src/components/Widget/RecentPosts/RecentPosts.tsx @@ -0,0 +1,63 @@ +import { t } from '@lingui/macro'; +import { getPublishedPosts } from '@services/graphql/queries'; +import { ArticlePreview } from '@ts/types/articles'; +import Image from 'next/image'; +import Link from 'next/link'; +import { useRouter } from 'next/router'; +import useSWR from 'swr'; +import styles from './RecentPosts.module.scss'; + +const RecentPosts = () => { +  const { data, error } = useSWR('/recent-posts', () => +    getPublishedPosts({ first: 3 }) +  ); +  const { locale } = useRouter(); +  const dateOptions: Intl.DateTimeFormatOptions = { +    day: 'numeric', +    month: 'long', +    year: 'numeric', +  }; + +  const getPost = (post: ArticlePreview) => { +    return ( +      <li key={post.id} className={styles.item}> +        <Link href={`/article/${post.slug}`}> +          <a className={styles.link}> +            <article className={styles.article}> +              {post.featuredImage && +                Object.keys(post.featuredImage).length > 0 && ( +                  <div className={styles.cover}> +                    <Image +                      src={post.featuredImage.sourceUrl} +                      alt={post.featuredImage.altText} +                      layout="fill" +                      objectFit="contain" +                    /> +                  </div> +                )} +              <h3 className={styles.title}>{post.title}</h3> +              <dl className={styles.meta}> +                <dt>{t`Published on:`}</dt> +                <dd> +                  {new Date(post.dates.publication).toLocaleDateString( +                    locale, +                    dateOptions +                  )} +                </dd> +              </dl> +            </article> +          </a> +        </Link> +      </li> +    ); +  }; + +  if (error) return <div>{t`Failed to load.`}</div>; +  if (!data) return <div>{t`Loading...`}</div>; + +  return ( +    <ul className={styles.list}>{data.posts.map((post) => getPost(post))}</ul> +  ); +}; + +export default RecentPosts; diff --git a/src/components/Widget/index.tsx b/src/components/Widget/index.tsx new file mode 100644 index 0000000..d6ce18f --- /dev/null +++ b/src/components/Widget/index.tsx @@ -0,0 +1,3 @@ +import RecentPosts from './RecentPosts/RecentPosts'; + +export { RecentPosts }; diff --git a/src/content b/src/content -Subproject 1b44310958dd736fa236f40b3c411a95a47e2ba +Subproject fbb25dbae6ba96dc7b8bf75caff9d331df548d5 diff --git a/src/styles/pages/Home.module.scss b/src/styles/pages/Home.module.scss new file mode 100644 index 0000000..3a8fd0e --- /dev/null +++ b/src/styles/pages/Home.module.scss @@ -0,0 +1,8 @@ +@use "@styles/abstracts/placeholders"; + +.links-list { +  @extend %flex-list; + +  gap: var(--spacing-md); +  margin: var(--spacing-md) 0; +} | 
