diff --git a/public/DMMono-Light.ttf b/public/DMMono-Light.ttf new file mode 100644 index 0000000..b655a6e Binary files /dev/null and b/public/DMMono-Light.ttf differ diff --git a/public/DMMono-Medium.ttf b/public/DMMono-Medium.ttf new file mode 100644 index 0000000..8a9988e Binary files /dev/null and b/public/DMMono-Medium.ttf differ diff --git a/public/DMMono-Regular.ttf b/public/DMMono-Regular.ttf new file mode 100644 index 0000000..4bb53cf Binary files /dev/null and b/public/DMMono-Regular.ttf differ diff --git a/public/modern-era-bold.otf b/public/modern-era-bold.otf new file mode 100644 index 0000000..4252acc Binary files /dev/null and b/public/modern-era-bold.otf differ diff --git a/public/modern-era-medium.otf b/public/modern-era-medium.otf new file mode 100644 index 0000000..7907f0e Binary files /dev/null and b/public/modern-era-medium.otf differ diff --git a/public/modern-era-regular.otf b/public/modern-era-regular.otf new file mode 100644 index 0000000..3b91916 Binary files /dev/null and b/public/modern-era-regular.otf differ diff --git a/src/features/explorer/assets/alt1.svg b/src/features/explorer/assets/alt1.svg new file mode 100755 index 0000000..61fed25 --- /dev/null +++ b/src/features/explorer/assets/alt1.svg @@ -0,0 +1,34 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/features/explorer/assets/alt2.svg b/src/features/explorer/assets/alt2.svg new file mode 100755 index 0000000..08c9966 --- /dev/null +++ b/src/features/explorer/assets/alt2.svg @@ -0,0 +1,34 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/features/explorer/assets/alt3.svg b/src/features/explorer/assets/alt3.svg new file mode 100755 index 0000000..249c120 --- /dev/null +++ b/src/features/explorer/assets/alt3.svg @@ -0,0 +1,34 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/features/explorer/assets/alt4.svg b/src/features/explorer/assets/alt4.svg new file mode 100755 index 0000000..cab559b --- /dev/null +++ b/src/features/explorer/assets/alt4.svg @@ -0,0 +1,34 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/features/explorer/assets/alt5.svg b/src/features/explorer/assets/alt5.svg new file mode 100755 index 0000000..6381301 --- /dev/null +++ b/src/features/explorer/assets/alt5.svg @@ -0,0 +1,34 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/features/explorer/assets/attestation-frame-logo.svg b/src/features/explorer/assets/attestation-frame-logo.svg new file mode 100644 index 0000000..a919d88 --- /dev/null +++ b/src/features/explorer/assets/attestation-frame-logo.svg @@ -0,0 +1,23 @@ + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/features/explorer/assets/gg_22_logo.svg b/src/features/explorer/assets/gg_22_logo.svg new file mode 100644 index 0000000..ab1f3fd --- /dev/null +++ b/src/features/explorer/assets/gg_22_logo.svg @@ -0,0 +1,4 @@ + + + + diff --git a/src/features/explorer/assets/preview_alt_1.svg b/src/features/explorer/assets/preview_alt_1.svg new file mode 100755 index 0000000..164b1b7 --- /dev/null +++ b/src/features/explorer/assets/preview_alt_1.svg @@ -0,0 +1,106 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/features/explorer/assets/preview_alt_2.svg b/src/features/explorer/assets/preview_alt_2.svg new file mode 100755 index 0000000..034bcda --- /dev/null +++ b/src/features/explorer/assets/preview_alt_2.svg @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/features/explorer/assets/preview_alt_3.svg b/src/features/explorer/assets/preview_alt_3.svg new file mode 100755 index 0000000..984abad --- /dev/null +++ b/src/features/explorer/assets/preview_alt_3.svg @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/features/explorer/assets/preview_alt_4.svg b/src/features/explorer/assets/preview_alt_4.svg new file mode 100755 index 0000000..1d991a9 --- /dev/null +++ b/src/features/explorer/assets/preview_alt_4.svg @@ -0,0 +1,127 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/features/explorer/assets/preview_alt_5.svg b/src/features/explorer/assets/preview_alt_5.svg new file mode 100755 index 0000000..808c700 --- /dev/null +++ b/src/features/explorer/assets/preview_alt_5.svg @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/features/explorer/components/HiddenMintingAttestationFrame.tsx b/src/features/explorer/components/HiddenMintingAttestationFrame.tsx new file mode 100644 index 0000000..d363aa6 --- /dev/null +++ b/src/features/explorer/components/HiddenMintingAttestationFrame.tsx @@ -0,0 +1,36 @@ +import { MintingAttestationFrame, MintingAttestationFrameProps } from "./MintingAttestationFrame"; + +export type HiddenMintingAttestationFrameProps = MintingAttestationFrameProps & { + imagesBase64: string[] | undefined; + hidden?: boolean; +}; + +export const HiddenMintingAttestationFrame = (props: HiddenMintingAttestationFrameProps) => { + const { imagesBase64, hidden = true, projects, topRound, ...partialFrameProps } = props; + const projectsWithImage = projects.map((project, i) => ({ + ...project, + image: imagesBase64 ? imagesBase64[i] : "", + })); + + return ( +
+ +
+ ); +}; diff --git a/src/features/explorer/components/MintingAttestationFrame/MintingAttestationFrame.tsx b/src/features/explorer/components/MintingAttestationFrame/MintingAttestationFrame.tsx new file mode 100644 index 0000000..b236895 --- /dev/null +++ b/src/features/explorer/components/MintingAttestationFrame/MintingAttestationFrame.tsx @@ -0,0 +1,70 @@ +import useColorAndBackground from "../../hooks/useColorAndBackground"; +import { MintingProject } from "../../types/projects"; +import { HeaderSection, StatsSection, TopProjectsSection, TopRoundSection } from "./components"; + +export type MintingAttestationFrameProps = { + frameId: string; + selectedBackground: string; + topRound: string; + projectsFunded: number; + roundsSupported: number; + checkedOutChains: number; + projects: MintingProject[]; + address: string | undefined; + ensName: string | null | undefined; +}; + +export const MintingAttestationFrame = ({ + frameId, + selectedBackground, + topRound, + projectsFunded, + roundsSupported, + checkedOutChains, + projects, + address, + ensName, +}: { + frameId: string; + selectedBackground: string; + topRound: string; + projectsFunded: number; + roundsSupported: number; + checkedOutChains: number; + projects: MintingProject[]; + address: string | undefined; + ensName: string | null | undefined; +}) => { + const { attestationFrameLogo } = useColorAndBackground(); + + return ( +
+
+ + +
+
+ + + +
+ +
+
+
+ ); +}; diff --git a/src/features/explorer/components/MintingAttestationFrame/components/HeaderSection.tsx b/src/features/explorer/components/MintingAttestationFrame/components/HeaderSection.tsx new file mode 100644 index 0000000..854bb49 --- /dev/null +++ b/src/features/explorer/components/MintingAttestationFrame/components/HeaderSection.tsx @@ -0,0 +1,24 @@ +import clsx from "clsx"; + +export type HeaderSectionProps = { + logo: string; + ensName?: string; + address?: string; +}; + +export const HeaderSection = ({ logo, ensName = "", address = "" }: HeaderSectionProps) => { + const addressText = ensName ? ensName : address; + return ( +
+
+ {addressText} +
+ Logo +
+ ); +}; diff --git a/src/features/explorer/components/MintingAttestationFrame/components/StatItem.tsx b/src/features/explorer/components/MintingAttestationFrame/components/StatItem.tsx new file mode 100644 index 0000000..3ab7ddd --- /dev/null +++ b/src/features/explorer/components/MintingAttestationFrame/components/StatItem.tsx @@ -0,0 +1,21 @@ +import clsx from "clsx"; + +export type StatItemProps = { + label: string; + amount: number; + className?: string; +}; + +export const StatItem = ({ label, amount, className }: StatItemProps) => { + return ( +
+
{amount}
+
{label}
+
+ ); +}; diff --git a/src/features/explorer/components/MintingAttestationFrame/components/StatsSection.tsx b/src/features/explorer/components/MintingAttestationFrame/components/StatsSection.tsx new file mode 100644 index 0000000..26bc01f --- /dev/null +++ b/src/features/explorer/components/MintingAttestationFrame/components/StatsSection.tsx @@ -0,0 +1,21 @@ +import { StatItem } from "./StatItem"; + +export type StatsSectionProps = { + projectsFunded: number; + roundsSupported: number; + checkedOutChains: number; +}; + +export const StatsSection = ({ + projectsFunded, + roundsSupported, + checkedOutChains, +}: StatsSectionProps) => { + return ( +
+ + + +
+ ); +}; diff --git a/src/features/explorer/components/MintingAttestationFrame/components/TopProject.tsx b/src/features/explorer/components/MintingAttestationFrame/components/TopProject.tsx new file mode 100644 index 0000000..3334a40 --- /dev/null +++ b/src/features/explorer/components/MintingAttestationFrame/components/TopProject.tsx @@ -0,0 +1,28 @@ +import { MintingProject } from "../../../types/projects"; + +export type TopProjectProps = { + project: MintingProject; +}; + +export const TopProject = ({ project }: TopProjectProps) => { + const { rank, image, name, round } = project; + return ( +
+
{rank}
+ Project + +
+
+ {name} +
+
+ {round} +
+
+
+ ); +}; diff --git a/src/features/explorer/components/MintingAttestationFrame/components/TopProjectsSection.tsx b/src/features/explorer/components/MintingAttestationFrame/components/TopProjectsSection.tsx new file mode 100644 index 0000000..c702c5e --- /dev/null +++ b/src/features/explorer/components/MintingAttestationFrame/components/TopProjectsSection.tsx @@ -0,0 +1,19 @@ +import { MintingProject } from "../../../types/projects"; +import { TopProject } from "./TopProject"; + +export type TopProjectsSectionProps = { + projects?: MintingProject[]; +}; + +export const TopProjectsSection = ({ projects = [] }: TopProjectsSectionProps) => { + return ( +
+
+ Top Projects +
+ {projects.map((project, index) => ( + + ))} +
+ ); +}; diff --git a/src/features/explorer/components/MintingAttestationFrame/components/TopRoundSection.tsx b/src/features/explorer/components/MintingAttestationFrame/components/TopRoundSection.tsx new file mode 100644 index 0000000..4c225c7 --- /dev/null +++ b/src/features/explorer/components/MintingAttestationFrame/components/TopRoundSection.tsx @@ -0,0 +1,14 @@ +export type TopRoundSectionProps = { + roundName: string; +}; + +export const TopRoundSection = ({ roundName }: TopRoundSectionProps) => { + return ( +
+
Top Round
+
+ {roundName} +
+
+ ); +}; diff --git a/src/features/explorer/components/MintingAttestationFrame/components/index.ts b/src/features/explorer/components/MintingAttestationFrame/components/index.ts new file mode 100644 index 0000000..793c132 --- /dev/null +++ b/src/features/explorer/components/MintingAttestationFrame/components/index.ts @@ -0,0 +1,4 @@ +export * from "./HeaderSection"; +export * from "./StatsSection"; +export * from "./TopProjectsSection"; +export * from "./TopRoundSection"; diff --git a/src/features/explorer/components/MintingAttestationFrame/index.ts b/src/features/explorer/components/MintingAttestationFrame/index.ts new file mode 100644 index 0000000..2c35eac --- /dev/null +++ b/src/features/explorer/components/MintingAttestationFrame/index.ts @@ -0,0 +1,4 @@ +export { + MintingAttestationFrame, + type MintingAttestationFrameProps, +} from "./MintingAttestationFrame"; diff --git a/src/features/explorer/hooks/useColorAndBackground.ts b/src/features/explorer/hooks/useColorAndBackground.ts new file mode 100644 index 0000000..b0291f2 --- /dev/null +++ b/src/features/explorer/hooks/useColorAndBackground.ts @@ -0,0 +1,68 @@ +import React from "react"; +import alt1 from "../assets/alt1.svg"; +import alt2 from "../assets/alt2.svg"; +import alt3 from "../assets/alt3.svg"; +import alt4 from "../assets/alt4.svg"; +import alt5 from "../assets/alt5.svg"; +import preview_alt1 from "../assets/preview_alt_1.svg"; +import preview_alt2 from "../assets/preview_alt_2.svg"; +import preview_alt3 from "../assets/preview_alt_3.svg"; +import preview_alt4 from "../assets/preview_alt_4.svg"; +import preview_alt5 from "../assets/preview_alt_5.svg"; +import attestationFrameLogo from "../assets/gg_22_logo.svg"; + +const useColorAndBackground = () => { + const colorMapper = { + "0": "#8266BE", + "1": "#79A557", + "2": "#9BC8E7", + "3": "#E3734C", + "4": "#BCBFBF", + }; + + const backgroundMapper = { + "0": alt1, + "1": alt2, + "2": alt3, + "3": alt4, + "4": alt5, + }; + + const defaultColor = "#EBEBEB"; + + const backgroundAlternatives = [ + preview_alt1, + preview_alt2, + preview_alt3, + preview_alt4, + preview_alt5, + ]; + + const [selectedColor, setSelectedColor] = React.useState("0"); + const [previousColor, setPreviousColor] = React.useState("-0"); + const [selectedBackground, setSelectedBackground] = React.useState(backgroundMapper["0"]); + const [previewBackground, setPreviewBackground] = React.useState(preview_alt1); + + const selectBackground = (option: string) => { + setPreviousColor(selectedColor); + setSelectedColor(option); + setPreviewBackground(backgroundAlternatives[Number(option)]); + setSelectedBackground(backgroundMapper[option as keyof typeof backgroundMapper]); + }; + + return { + colorMapper, + backgroundMapper, + defaultColor, + backgroundAlternatives, + selectedColor, + previousColor, + previewBackground, + selectBackground, + selectedBackground, + preview_alt1, + attestationFrameLogo, + }; +}; + +export default useColorAndBackground; diff --git a/src/features/explorer/types/projects.ts b/src/features/explorer/types/projects.ts new file mode 100644 index 0000000..73cc9a5 --- /dev/null +++ b/src/features/explorer/types/projects.ts @@ -0,0 +1,6 @@ +export type MintingProject = { + rank: number; + name: string; + round: string; + image: string; +}; diff --git a/src/index.ts b/src/index.ts index ed044bd..bc1691c 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1 +1,5 @@ export * from "./legacy"; +export { + HiddenMintingAttestationFrame, + type HiddenMintingAttestationFrameProps, +} from "./features/explorer/components/HiddenMintingAttestationFrame"; diff --git a/src/styles.css b/src/styles.css index fb199e7..ffc0334 100644 --- a/src/styles.css +++ b/src/styles.css @@ -2,6 +2,54 @@ @tailwind components; @tailwind utilities; +@font-face { + font-family: "ModernEra"; + font-weight: 400; + src: + local("ModernEraRegular"), + url("/modern-era-regular.otf") format("opentype"); +} + +@font-face { + font-family: "ModernEra"; + font-weight: 500; + src: + local("ModernEraMedium"), + url("/modern-era-medium.otf") format("opentype"); +} + +@font-face { + font-family: "ModernEra"; + font-weight: 600; + src: + local("ModernEraBold"), + url("/modern-era-bold.otf") format("opentype"); +} + +@font-face { + font-family: "Mono"; + font-weight: 300; + src: + local("MonoLight"), + url("/DMMono-Light.ttf") format("opentype"); +} + +@font-face { + font-family: "Mono"; + font-weight: 400; + src: + local("MonoRegular"), + url("/DMMono-Regular.ttf") format("opentype"); +} + +@font-face { + font-family: "Mono"; + font-weight: 500; + src: + local("MonoMedium"), + url("/DMMono-Medium.ttf") format("opentype"); +} + @layer base { :root { --background: 0 0% 100%; diff --git a/stories/features/explorer/components/HiddenMintingAttestationFrame.stories.tsx b/stories/features/explorer/components/HiddenMintingAttestationFrame.stories.tsx new file mode 100644 index 0000000..d6921ba --- /dev/null +++ b/stories/features/explorer/components/HiddenMintingAttestationFrame.stories.tsx @@ -0,0 +1,156 @@ +import type { Meta, StoryObj } from "@storybook/react"; +import { HiddenMintingAttestationFrame } from "../../../../src/features/explorer/components/HiddenMintingAttestationFrame"; +import { imageBase64Mock } from "./mocks"; + +const meta = { + title: "Features/Explorer/Components/MintingAttestationFrame/HiddenMintingAttestationFrame", + component: HiddenMintingAttestationFrame, + argTypes: { + selectedBackground: { + control: { + type: "select", + }, + options: ["background1", "background2", "background3", "background4", "background5"], + mapping: { + background1: "../../../src/features/explorer/assets/alt1.svg", + background2: "../../../src/features/explorer/assets/alt2.svg", + background3: "../../../src/features/explorer/assets/alt3.svg", + background4: "../../../src/features/explorer/assets/alt4.svg", + background5: "../../../src/features/explorer/assets/alt5.svg", + }, + }, + }, + args: { + frameId: "1", + topRound: "OSS Round", + projectsFunded: 22, + roundsSupported: 3, + checkedOutChains: 4, + selectedBackground: "../../../src/features/explorer/assets/alt1.svg", + projects: [ + { + rank: 1, + name: "Saving forests around the world", + round: "Climate Round", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + { + rank: 2, + name: "Funding schools in Mexico", + round: "Education Round", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + { + rank: 3, + name: "Accessible software for humans", + round: "OSS Round", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + ], + address: "0x632A9882fb748853669b94a11b05E38a6cE3D7F2", + ensName: "fundingmaxi.ens", + hidden: false, + imagesBase64: [imageBase64Mock, imageBase64Mock, imageBase64Mock], + }, +} satisfies Meta; + +export default meta; + +type Story = StoryObj; + +export const Default: Story = {}; + +export const WithoutENS: Story = { + args: { + ensName: undefined, + }, +}; + +export const OneProject: Story = { + args: { + projects: [ + { + rank: 1, + name: "Saving forests around the world", + round: "Climate Round", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + ], + }, +}; + +export const TwoProjects: Story = { + args: { + projects: [ + { + rank: 1, + name: "Saving forests around the world", + round: "Climate Round", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + { + rank: 2, + name: "Funding schools in Mexico", + round: "Education Round", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + ], + }, +}; + +export const ThreeProjects: Story = { + args: { + projects: [ + { + rank: 1, + name: "Saving forests around the world", + round: "Climate Round", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + { + rank: 2, + name: "Funding schools in Mexico", + round: "Education Round", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + { + rank: 3, + name: "Accessible software for humans", + round: "OSS Round", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + ], + }, +}; + +export const WithLongNames: Story = { + args: { + ensName: "fundingmaxisomelongname.ens", + frameId: "1", + topRound: + "OSS Round Extended to overflow until it ellipsis or there is no space but actually there is a lot of space", + projectsFunded: 1000000, + roundsSupported: 1000000, + checkedOutChains: 1000000, + projects: [ + { + rank: 1, + name: "Saving forests around the world", + round: "Climate Round long name extended to overflow", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + { + rank: 2, + name: "Funding schools in Mexico", + round: "Education Round", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + { + rank: 3, + name: "Accessible software for humans", + round: "OSS Round", + image: "bafkreig6tpuhw7h6xeambh36afiemiqleih7q25yywdj36cvqnvpjegsqi", + }, + ], + }, +}; diff --git a/stories/features/explorer/components/mocks.ts b/stories/features/explorer/components/mocks.ts new file mode 100644 index 0000000..46efd3f --- /dev/null +++ b/stories/features/explorer/components/mocks.ts @@ -0,0 +1,2 @@ +export const imageBase64Mock = + ""; diff --git a/tailwind.config.ts b/tailwind.config.ts index 047eb51..0441f8d 100644 --- a/tailwind.config.ts +++ b/tailwind.config.ts @@ -112,7 +112,8 @@ const config: Config = { sm: "calc(var(--radius) - 4px)", }, fontFamily: { - sans: ["var(--font-sans)", ...fontFamily.sans], + mono: ["Mono", ...fontFamily.sans], + ["modern-era"]: ["ModernEra", ...fontFamily.sans], }, keyframes: { "accordion-down": { diff --git a/tsconfig.storybook.json b/tsconfig.storybook.json new file mode 100644 index 0000000..b9ab23b --- /dev/null +++ b/tsconfig.storybook.json @@ -0,0 +1,8 @@ +{ + "extends": "./tsconfig.json", // Extend the main tsconfig + "compilerOptions": { + "rootDir": "./" // Specify the root directory + }, + "include": ["./stories/**/*.tsx"], // Include only stories for type checking + "exclude": ["node_modules", "dist", "**/__tests__/*", "src/legacy/test-utils.tsx", "**/*.css"] +}