Skip to content

Commit

Permalink
Build 404 page
Browse files Browse the repository at this point in the history
  • Loading branch information
foxyblocks committed Jul 19, 2023
1 parent ce12602 commit 2aaa1b2
Show file tree
Hide file tree
Showing 7 changed files with 545 additions and 43 deletions.
33 changes: 33 additions & 0 deletions components/atoms/FullHeightContainer/full-height-container.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
/**
* A react component that will ensure that its min-height is the same as the screen height.
* This is not possible with pure css because some mobile browsers don't account for the top and bottom bars
* when calculating `vh`.
* see https://dev.to/nirazanbasnet/dont-use-100vh-for-mobile-responsive-3o97
*/

import clsx from "clsx";
import React, { useEffect, useState } from "react";
import { useWindowSize } from "react-use";

interface Props extends React.HTMLAttributes<HTMLDivElement> {
}

export default function FullHeightContainer(props: Props) {
const { children, className, ...rest } = props;
const { height: innerHeight } = useWindowSize();
const [minHeight, setMinHeight] = useState<string>("100vh");

useEffect(() => {
setMinHeight(`${innerHeight}px`);
}, [innerHeight]);

return (
<div
className={clsx("grid min-h-screen max-h-screen", className)}
style={{ minHeight: minHeight }}
{...rest}
>
{children}
</div>
);
}
30 changes: 15 additions & 15 deletions components/molecules/DevCard/dev-card.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ export interface DevCardProps {
isLoading?: boolean;
isFlipped?: boolean;
isInteractive?: boolean;
hideProfileButton?: boolean;
age?: number;
onFlip?: () => void;
}
Expand All @@ -50,6 +51,9 @@ export default function DevCard(props: DevCardProps) {
const profileHref = `/user/${props.username}`;

function handleCardClick(event: React.MouseEvent<HTMLElement, MouseEvent>) {
if (!isInteractive) {
return;
}
// flip the card if the click is not on the button
if (!(event.target instanceof HTMLAnchorElement || event.target instanceof HTMLButtonElement)) {
if (props.isFlipped === undefined) {
Expand All @@ -73,7 +77,7 @@ export default function DevCard(props: DevCardProps) {
"h-full",
"absolute",
"left-0",
"top-0",
"top-0"
);

const faceStyle: React.CSSProperties = {
Expand All @@ -85,11 +89,10 @@ export default function DevCard(props: DevCardProps) {

return (
<div
className="DevCard rounded-3x"
className="DevCard"
style={{
width: "245px",
height: "348px",
boxShadow: "0px 0px 20px -12px rgba(0, 0, 0, 0.25)",
}}
>
<Tilt
Expand All @@ -98,14 +101,9 @@ export default function DevCard(props: DevCardProps) {
trackOnWindow={isInteractive}
glareBorderRadius="1.5rem"
flipHorizontally={isFlipped}
className={clsx(
"DevCard-card",
"relative",
"rounded-3x",
"w-full",
"h-full",
)}
className={clsx("DevCard-card", "relative", "rounded-3xl", "w-full", "h-full", "border", "border-gray-400")}
style={{
boxShadow: "0px 0px 20px -12px rgba(0, 0, 0, 0.25)",
transformStyle: "preserve-3d",
}}
>
Expand Down Expand Up @@ -238,11 +236,13 @@ export default function DevCard(props: DevCardProps) {
</div>
{/* bottom */}
<div className="px-2 mt-auto justify-self-end">
<Link href={profileHref} passHref>
<Button variant="primary" className="w-full text-center justify-center mt-4 !py-1">
View Profile
</Button>
</Link>
{!props.hideProfileButton && (
<Link href={profileHref} passHref>
<Button variant="primary" className="w-full text-center justify-center mt-4 !py-1">
View Profile
</Button>
</Link>
)}
<div className="flex justify-center mt-2">
<Image className="rounded" alt="Open Sauced Logo" width={13} height={13} src={openSaucedImg} />
<p className={"font-semibold text-white ml-1"} style={{ fontSize: "8px" }}>
Expand Down
Loading

0 comments on commit 2aaa1b2

Please sign in to comment.