Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add braavos mobile #1004

Merged
merged 7 commits into from
Dec 27, 2024
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
58 changes: 33 additions & 25 deletions app/analytics/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,12 +17,12 @@ export default function Page() {
const { address } = useAccount();
const [loading, setLoading] = useState<boolean>(true);

const [quests, setQuests] = useState<QuestList> ({} as QuestList);
const [quests, setQuests] = useState<QuestList>({} as QuestList);

const fetchQuests = useCallback(async () => {
try {
setLoading(true);
const res = await getQuests() || {};
const res = (await getQuests()) || {};
setQuests(res);
setLoading(false);
} catch (error) {
Expand All @@ -39,34 +39,42 @@ export default function Page() {
<div className={styles.backButton}>
<BackButton onClick={() => router.back()} />
</div>
<Typography type={TEXT_TYPE.H1} color="transparent" className={styles.title}>Quest Analytics</Typography>
<Typography
type={TEXT_TYPE.H1}
color="transparent"
className={styles.title}
>
Quest Analytics
</Typography>
<div className={styles.card_container}>
{loading ? (
<FeaturedQuestSkeleton />
) : (
(Object.keys(quests) as (keyof typeof quests)[]).map((categoryName: keyof typeof quests) => {
const categoryValue = quests[categoryName];
if (Array.isArray(categoryValue)) {
return categoryValue.map((quest: QuestDocument) => {
return (
<Quest
key={quest.id}
title={quest.title_card}
onClick={() => router.push(`/analytics/${quest.id}`)}
imgSrc={quest.img_card}
issuer={{
name: quest.issuer,
logoFavicon: quest.logo,
}}
reward={quest.rewards_title}
id={quest.id}
expired={false}
/>
);
});
(Object.keys(quests) as (keyof typeof quests)[]).map(
(categoryName: keyof typeof quests) => {
const categoryValue = quests[categoryName];
if (Array.isArray(categoryValue)) {
return categoryValue.map((quest: QuestDocument) => {
return (
<Quest
key={quest.id}
title={quest.title_card}
onClick={() => router.push(`/analytics/${quest.id}`)}
imgSrc={quest.img_card}
issuer={{
name: quest.issuer,
logoFavicon: quest.logo,
}}
reward={quest.rewards_title}
id={quest.id}
expired={false}
/>
);
});
}
return null;
}
return null;
})
)
)}
</div>
</div>
Expand Down
6 changes: 1 addition & 5 deletions app/provider.tsx
Original file line number Diff line number Diff line change
@@ -1,20 +1,16 @@
"use client";

import React from "react";
import { InjectedConnector } from "starknetkit/injected";
import { WebWalletConnector } from "starknetkit/webwallet";
import { ArgentMobileConnector } from "starknetkit/argentMobile";
import { Chain, mainnet, sepolia } from "@starknet-react/chains";
import {
Connector,
StarknetConfig,
jsonRpcProvider,
} from "@starknet-react/core";
import { StarknetIdJsProvider } from "@context/StarknetIdJsProvider";
import { ThemeProvider, createTheme } from "@mui/material";
import { ThemeProvider } from "@mui/material";
import { QuestsContextProvider } from "@context/QuestsProvider";
import { getCurrentNetwork } from "@utils/network";
import { constants } from "starknet";
import { PostHogProvider } from "posthog-js/react";
import posthog from "posthog-js";
import { NotificationProvider } from "@context/NotificationProvider";
Expand Down
1 change: 0 additions & 1 deletion context/QuestsProvider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -138,7 +138,6 @@ export const QuestsContextProvider = ({
!quest.expired
)
: undefined;

setFeaturedQuest(
lastBoostedQuest ||
notExpired[Math.floor(Math.random() * notExpired.length)]
Expand Down
5 changes: 3 additions & 2 deletions jest.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
module.exports = {
testEnvironment: "node",
transform: {
"\\.[jt]sx?$": "ts-jest",
"^.+\\.(js|jsx|ts|tsx)$": ["babel-jest", { presets: ["next/babel"] }],
},
setupFilesAfterEnv: ["./jest.setup.js"],
moduleNameMapper: {
Expand All @@ -21,4 +21,5 @@ module.exports = {
statements: -10,
},
},
};
transformIgnorePatterns: ["node_modules/(?!(@starknet-react|@starknetkit)/)"],
};
5 changes: 3 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,8 @@
"chart.js": "^4.3.0",
"dayjs": "^1.11.11",
"eslint-config-next": "^14.0.1",
"get-starknet-core": "^3.2.0",
"get-starknet": "^3.3.3",
"get-starknet-core": "^3.3.3",
"jotai": "^2.5.0",
"jwt-decode": "^4.0.0",
"lottie-react": "^2.4.0",
Expand All @@ -51,7 +52,7 @@
"recharts": "^2.12.2",
"starknet": "^6.11.0",
"starknetid.js": "^4.0.1",
"starknetkit": "^2.3.3",
"starknetkit": "^2.6.1",
"three": "^0.155.0",
"twitter-api-sdk": "^1.2.1"
},
Expand Down
Binary file added public/visuals/braavosMobile.webp
Binary file not shown.
27 changes: 16 additions & 11 deletions tests/utils/domainService.test.js
Original file line number Diff line number Diff line change
@@ -1,23 +1,26 @@
import { getDomainFromAddress } from '@utils/domainService';
import { getDomainFromAddress } from "@utils/domainService";

const API_URL = process.env.NEXT_PUBLIC_STARKNET_ID_API_LINK;

describe("getDomainFromAddress function", () => {
it("should return a valid domain for a valid address", async () => {
const validAddress = "0x061b6c0a78f9edf13cea17b50719f3344533fadd470b8cb29c2b4318014f52d3";
it("should return a valid domain for a valid address", async () => {
const validAddress =
"0x061b6c0a78f9edf13cea17b50719f3344533fadd470b8cb29c2b4318014f52d3";
const expectedDomain = "fricoben.stark";

// Mocking the fetch function to return a predefined response
const mockResponse = { domain: expectedDomain };
const fetchMock = jest.fn().mockResolvedValue({
json: jest.fn().mockResolvedValue(mockResponse),
json: jest.fn().mockResolvedValue(mockResponse),
});
(fetch as jest.Mock) = fetchMock;
fetch = fetchMock;

Marchand-Nicolas marked this conversation as resolved.
Show resolved Hide resolved
const domain = await getDomainFromAddress(validAddress);

expect(domain).toBe(expectedDomain);
expect(fetchMock).toHaveBeenCalledWith(`${API_URL}/addr_to_domain?addr=${validAddress}`);
expect(fetchMock).toHaveBeenCalledWith(
`${API_URL}/addr_to_domain?addr=${validAddress}`
);
});

it("should return an empty string for an invalid address", async () => {
Expand All @@ -27,13 +30,15 @@ it("should return a valid domain for a valid address", async () => {
// Mocking the fetch function to simulate an error
const mockResponse = { domain: expectedDomain };
const fetchMock = jest.fn().mockResolvedValue({
json: jest.fn().mockResolvedValue(mockResponse),
});
(fetch as jest.Mock) = fetchMock;
json: jest.fn().mockResolvedValue(mockResponse),
});
fetch = fetchMock;

const domain = await getDomainFromAddress(invalidAddress);

expect(domain).toBe("");
expect(fetchMock).toHaveBeenCalledWith(`${API_URL}/addr_to_domain?addr=${invalidAddress}`);
expect(fetchMock).toHaveBeenCalledWith(
`${API_URL}/addr_to_domain?addr=${invalidAddress}`
);
});
});
});
14 changes: 7 additions & 7 deletions tests/utils/walletConfig.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import {
getConnectorIcon,
getConnectorName,
getConnectorDiscovery,
} from "../../utils/walletConfig";
} from "@utils/walletConfig";
class MockConnector {
constructor(id, name, isAvailable) {
this.id = id;
Expand Down Expand Up @@ -65,10 +65,10 @@ describe("sortConnectors function", () => {
describe("getConnectorIcon function", () => {
it("should return the icon for a wallet when the ID matches", () => {
expect(getConnectorIcon("argentX")).toBe(
"",
""
);
expect(getConnectorIcon("braavos")).toBe(
"",
""
);
});

Expand Down Expand Up @@ -123,26 +123,26 @@ describe("getConnectorDiscovery function", () => {

it("should return the wallet's website URL when no downloads are available", () => {
expect(getConnectorDiscovery("argentWebWallet")).toBe(
"https://www.argent.xyz/argent-x/",
"https://www.argent.xyz/argent-x/"
);
});

it("should return the correct download link for the user's browser if available", () => {
expect(getConnectorDiscovery("braavos")).toBe(
"https://chrome.google.com/webstore/detail/braavos-wallet/jnlgamecbpmbajjfhmmmlhejkemejdma",
"https://chrome.google.com/webstore/detail/braavos-wallet/jnlgamecbpmbajjfhmmmlhejkemejdma"
);
});

it("should return the ecosystem website if no wallet data is found", () => {
expect(getConnectorDiscovery("wallet")).toBe(
"https://www.starknet-ecosystem.com",
"https://www.starknet-ecosystem.com"
);
});

it("should return the wallet's website when navigator is undefined", () => {
Object.defineProperty(global, "navigator", { value: undefined });
expect(getConnectorDiscovery("argentX")).toBe(
"https://www.argent.xyz/argent-x/",
"https://www.argent.xyz/argent-x/"
);
});
});
Loading
Loading