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}
+
+
+
+ );
+};
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 (
+
+ );
+};
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}
+
+
+
+
+ {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"]
+}