f6a0673082
CI Pipeline / test (20) (pull_request) Failing after 1m17s
CI Pipeline / test (18) (pull_request) Failing after 1m28s
CI Pipeline / e2e (chromium) (pull_request) Failing after 1m33s
CI Pipeline / e2e (firefox) (pull_request) Failing after 1m27s
CI Pipeline / e2e (webkit) (pull_request) Failing after 1m34s
CI Pipeline / visual-regression (pull_request) Failing after 2m9s
CI Pipeline / storybook (pull_request) Failing after 1m5s
CI Pipeline / performance (pull_request) Failing after 1m42s
CI Pipeline / lint (pull_request) Failing after 49s
CI Pipeline / build (pull_request) Failing after 1m29s
137 lines
6.7 KiB
TypeScript
137 lines
6.7 KiB
TypeScript
import React, { memo } from "react";
|
|
import Logo from "./Logo";
|
|
import Separator from "./Separator";
|
|
import { getAssetPath, ASSETS } from "../../lib/assetUtils";
|
|
|
|
const Footer = memo(() => {
|
|
// Schema markup for organization information
|
|
const schemaData = {
|
|
"@context": "https://schema.org",
|
|
"@type": "Organization",
|
|
name: "Media Economies Design Lab",
|
|
email: "medlab@colorado.edu",
|
|
url: "https://communityrule.com",
|
|
sameAs: [
|
|
"https://bsky.app/profile/medlabboulder",
|
|
"https://gitlab.com/medlabboulder",
|
|
],
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<script
|
|
type="application/ld+json"
|
|
dangerouslySetInnerHTML={{ __html: JSON.stringify(schemaData) }}
|
|
/>
|
|
<footer className="bg-[var(--color-surface-default-primary)] w-full">
|
|
<div
|
|
className="flex flex-col items-start mx-auto
|
|
px-[var(--spacing-measures-spacing-016)]
|
|
py-[var(--spacing-measures-spacing-040)]
|
|
gap-[var(--spacing-measures-spacing-040)]
|
|
sm:px-[var(--spacing-measures-spacing-032)]
|
|
sm:py-[var(--spacing-measures-spacing-024)]
|
|
sm:gap-[var(--spacing-measures-spacing-024)]
|
|
lg:px-[var(--spacing-measures-spacing-120,120px)]
|
|
lg:py-[var(--spacing-measures-spacing-096,96px)]
|
|
lg:gap-[var(--spacing-measures-spacing-060,60px)]"
|
|
>
|
|
{/* Logo*/}
|
|
<div className="block sm:hidden">
|
|
<Logo />
|
|
</div>
|
|
<div className="hidden sm:block lg:hidden">
|
|
<Logo size="footer" />
|
|
</div>
|
|
<div className="hidden lg:block">
|
|
<Logo size="footerLg" />
|
|
</div>
|
|
|
|
{/* Content section */}
|
|
<div className="flex flex-col items-start w-full gap-[var(--spacing-measures-spacing-048,48px)] sm:flex-row sm:justify-between sm:gap-0">
|
|
{/* Branding Section */}
|
|
<div className="flex flex-col items-start gap-[var(--spacing-measures-spacing-064,64px)] order-2 sm:order-1">
|
|
{/* Contact info */}
|
|
<div className="flex flex-col items-start gap-[var(--spacing-measures-spacing-016,16px)]">
|
|
<div className="text-[var(--color-content-default-primary)] font-inter text-base leading-5 font-medium tracking-[0%] lg:text-2xl lg:leading-7 lg:font-normal">
|
|
Media Economies Design Lab
|
|
</div>
|
|
<a
|
|
href="mailto:medlab@colorado.edu"
|
|
className="text-[var(--color-content-default-primary)] font-inter text-base leading-5 font-medium tracking-[0%] lg:text-2xl lg:leading-7 lg:font-normal hover:opacity-80 active:opacity-60 focus:opacity-80 focus:outline-none focus:ring-2 focus:ring-[var(--color-content-default-primary)] focus:ring-offset-2 focus:ring-offset-[var(--color-surface-default-primary)] transition-opacity p-2 -m-2 cursor-pointer"
|
|
>
|
|
medlab@colorado.edu
|
|
</a>
|
|
</div>
|
|
|
|
{/* Social media links */}
|
|
<div className="flex flex-col items-start gap-[var(--spacing-measures-spacing-016,16px)]">
|
|
<a
|
|
href="#"
|
|
className="flex items-center gap-[var(--spacing-measures-spacing-06,6px)] hover:opacity-80 active:opacity-60 focus:opacity-80 focus:outline-none focus:ring-2 focus:ring-[var(--color-content-default-primary)] focus:ring-offset-2 focus:ring-offset-[var(--color-surface-default-primary)] transition-opacity p-2 -m-2 cursor-pointer group"
|
|
aria-label="Follow us on Bluesky"
|
|
>
|
|
<img
|
|
src={getAssetPath(ASSETS.BLUESKY_LOGO)}
|
|
alt="Bluesky"
|
|
width={24}
|
|
height={22}
|
|
className="flex-shrink-0 group-hover:scale-110 transition-transform"
|
|
/>
|
|
<div className="text-[var(--color-content-default-primary)] font-inter text-base leading-5 font-medium tracking-[0%] lg:text-2xl lg:leading-7 lg:font-normal">
|
|
medlabboulder
|
|
</div>
|
|
</a>
|
|
<a
|
|
href="#"
|
|
className="flex items-center gap-[var(--spacing-measures-spacing-06,6px)] hover:opacity-80 active:opacity-60 focus:opacity-80 focus:outline-none focus:ring-2 focus:ring-[var(--color-content-default-primary)] focus:ring-offset-2 focus:ring-offset-[var(--color-surface-default-primary)] transition-opacity p-2 -m-2 cursor-pointer group"
|
|
aria-label="Follow us on GitLab"
|
|
>
|
|
<img
|
|
src={getAssetPath(ASSETS.GITLAB_ICON)}
|
|
alt="GitLab"
|
|
width={22}
|
|
height={22}
|
|
className="flex-shrink-0 grayscale group-hover:scale-110 transition-transform"
|
|
/>
|
|
<div className="text-[var(--color-content-default-primary)] font-inter text-base leading-5 font-medium tracking-[0%] lg:text-2xl lg:leading-7 lg:font-normal">
|
|
medlabboulder
|
|
</div>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
|
|
{/* Links Section */}
|
|
<div className="flex flex-col items-start gap-[var(--spacing-measures-spacing-016,16px)] order-1 sm:order-2">
|
|
<a
|
|
href="/learn"
|
|
className="text-[var(--color-content-default-primary)] font-inter text-base leading-5 font-medium tracking-[0%] lg:text-2xl lg:leading-7 lg:font-normal hover:opacity-80 active:opacity-60 focus:opacity-80 focus:outline-none focus:ring-2 focus:ring-[var(--color-content-default-primary)] focus:ring-offset-2 focus:ring-offset-[var(--color-surface-default-primary)] transition-opacity p-2 -m-2 cursor-pointer"
|
|
>
|
|
Learn
|
|
</a>
|
|
<a
|
|
href="/blog"
|
|
className="text-[var(--color-content-default-primary)] font-inter text-base leading-5 font-medium tracking-[0%] lg:text-2xl lg:leading-7 lg:font-normal hover:opacity-80 active:opacity-60 focus:opacity-80 focus:outline-none focus:ring-2 focus:ring-[var(--color-content-default-primary)] focus:ring-offset-2 focus:ring-offset-[var(--color-surface-default-primary)] transition-opacity p-2 -m-2 cursor-pointer"
|
|
>
|
|
Blog
|
|
</a>
|
|
</div>
|
|
</div>
|
|
|
|
<Separator />
|
|
|
|
{/* Copyright */}
|
|
<div className="text-[var(--color-content-default-secondary)] font-inter text-sm leading-5 font-normal tracking-[0%] lg:text-base lg:leading-6">
|
|
© {new Date().getFullYear()} Media Economies Design Lab. All rights
|
|
reserved.
|
|
</div>
|
|
</div>
|
|
</footer>
|
|
</>
|
|
);
|
|
});
|
|
|
|
Footer.displayName = "Footer";
|
|
|
|
export default Footer;
|