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

Connect Wallet #4

Merged
merged 2 commits into from
Oct 14, 2024
Merged
Show file tree
Hide file tree
Changes from all 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
8 changes: 6 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,10 @@

![dashboard v1](images/image.png)

## TODO: Telegram bot
## Telegram bot

> https://www.launchfa.st/blog/telegram-nextjs-app-router
[Get quote bot](https://t.me/cto_empowery_bot)

## Connect Wallet

![Connect Wallet TONcoin](images/image-ui-connect-wallet.png)
6 changes: 5 additions & 1 deletion dash.board/.env.example
Original file line number Diff line number Diff line change
@@ -1 +1,5 @@
TELEGRAM_BOT_TOKEN=your_actual_telegram_bot_token_here
TELEGRAM_BOT_TOKEN=your_actual_telegram_bot_token_here
TON_CONNECT_PROJECT_ID=cto-dashboard-project-id
NEXT_PUBLIC_TON_CONNECT_PROJECT_ID=cto-dashboard-project-id
TONCENTER_API_KEY=6b428c719e25b6cffee5b759d8b4798237493498
TON_CONSOLE_API_KEY=AE6T5FKHQAAAALWSO7A6TO2K3YM53774934987A3TJHFJJ6USNTORFAPQGR62BJZQEXCI
10 changes: 7 additions & 3 deletions dash.board/next.config.mjs
Original file line number Diff line number Diff line change
@@ -1,12 +1,16 @@
import createNextIntlPlugin from 'next-intl/plugin';

const withNextIntl = createNextIntlPlugin("./src/core/i18n/i18n.ts");

/** @type {import('next').NextConfig} */
const nextConfig = {
experimental: {
serverComponentsExternalPackages: ['grammy'],
},
},
env: {
TON_CONNECT_PROJECT_ID: process.env.NEXT_PUBLIC_TON_CONNECT_PROJECT_ID,
TONCENTER_API_KEY: process.env.TONCENTER_API_KEY,
},
};

export default withNextIntl(nextConfig);
export default withNextIntl(nextConfig);
3 changes: 2 additions & 1 deletion dash.board/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,8 @@
"react": "^18",
"react-dom": "^18",
"tailwind-merge": "^2.5.3",
"tailwindcss-animate": "^1.0.7"
"tailwindcss-animate": "^1.0.7",
"tonweb": "^0.0.66"
},
"devDependencies": {
"@types/node": "^20",
Expand Down
11,043 changes: 9,428 additions & 1,615 deletions dash.board/pnpm-lock.yaml

Large diffs are not rendered by default.

Binary file added dash.board/public/placeholder-user.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
File renamed without changes
10 changes: 8 additions & 2 deletions dash.board/public/tonconnect-manifest.json
Original file line number Diff line number Diff line change
@@ -1,5 +1,11 @@
{
"url": "https://ton.vote",
"name": "TON Vote",
"iconUrl": "https://ton.vote/logo.png"
"name": "CTO Dashboard",
"iconUrl": "https://ton.vote/logo.png",
"projectId": "cto-dash-board-project-id", // Add this line
"redirectURL": "https://dashbooard-nine.vercel.app", // Replace with your actual redirect URL
"network": {
"chainId": 1, // Replace with the appropriate chain ID
"network": "mainnet" // Replace with "testnet" if applicable
}
}
10 changes: 8 additions & 2 deletions dash.board/src/components/Root/Root.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,9 @@ import { init } from '@/core/init';

import './styles.css';

// Define your TONConnect project ID and other configurations
const TON_CONNECT_PROJECT_ID = process.env.TON_CONNECT_PROJECT_ID || 'cto-dashboard-project-id'; // Use environment variable

function RootInner({ children }: PropsWithChildren) {
const isDev = process.env.NODE_ENV === 'development';

Expand Down Expand Up @@ -51,7 +54,10 @@ function RootInner({ children }: PropsWithChildren) {
}, [debug]);

return (
<TonConnectUIProvider manifestUrl="/tonconnect-manifest.json">
<TonConnectUIProvider
projectId={TON_CONNECT_PROJECT_ID}
manifestUrl="/tonconnect-manifest.json"
>
<AppRoot
appearance={isDark ? 'dark' : 'light'}
platform={['macos', 'ios'].includes(lp.platform) ? 'ios' : 'base'}
Expand All @@ -73,4 +79,4 @@ export function Root(props: PropsWithChildren) {
<RootInner {...props}/>
</ErrorBoundary>
) : <div className="root__loading">Loading</div>;
}
}
88 changes: 65 additions & 23 deletions dash.board/src/components/dashboard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ import { Button } from "@/components/ui/button"
import { Avatar, AvatarFallback, AvatarImage } from "@/components/ui/avatar"
import { Progress } from "@/components/ui/progress"
import { Globe, Plus, Heart } from "lucide-react"
import { useTonWallet, TonConnectButton } from '@tonconnect/ui-react'
import { getTokenBalance } from '@/lib/tonUtils' // Import the utility function

// Define the type for the dashboard data
type DashboardData = {
Expand All @@ -15,27 +17,11 @@ type DashboardData = {
topIdeas: { id: number; name: string; completionRate: number }[];
};

// Mock function to simulate data fetching
const fetchDashboardData = () => {
return new Promise((resolve) => {
setTimeout(() => {
resolve({
totalIdeas: 83,
avgImplementationRate: 94,
globalReach: 42,
topIdeas: [
{ id: 1, name: "Idea 1", completionRate: 75 },
{ id: 2, name: "Idea 2", completionRate: 50 },
{ id: 3, name: "Idea 3", completionRate: 25 },
]
})
}, 1000)
})
}

export function DashboardComponent() {
const [dashboardData, setDashboardData] = useState<DashboardData | null>(null)
const [loading, setLoading] = useState(true)
const [tokenBalance, setTokenBalance] = useState<string | null>(null)
const wallet = useTonWallet()

useEffect(() => {
fetchDashboardData().then((data: any) => {
Expand All @@ -44,6 +30,22 @@ export function DashboardComponent() {
})
}, [])

useEffect(() => {
if (wallet && wallet.account.address) {
fetchTokenBalance(wallet.account.address)
}
}, [wallet])

const fetchTokenBalance = async (address: string) => {
try {
const balance = await getTokenBalance(address)
setTokenBalance(balance)
} catch (error) {
console.error('Error fetching token balance:', error)
setTokenBalance('Error')
}
}

if (loading) {
return <div className="flex justify-center items-center h-screen">Loading...</div>
}
Expand All @@ -52,13 +54,20 @@ export function DashboardComponent() {
<div className="min-h-screen bg-background p-8">
<div className="flex justify-between items-center mb-8">
<h1 className="text-3xl font-bold">Dash Board Dashboard</h1>
<Avatar>
<AvatarImage src="/placeholder-avatar.jpg" alt="User" />
<AvatarFallback>JD</AvatarFallback>
</Avatar>
{wallet ? (
<div className="flex items-center space-x-2">
<Avatar>
<AvatarImage src="/placeholder-avatar.jpg" alt="User" />
<AvatarFallback>JD</AvatarFallback>
</Avatar>
<span className="text-sm">{wallet.account.address}</span>
</div>
) : (
<TonConnectButton />
)}
</div>

<div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6">
<div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 gap-6">
<Card>
<CardHeader className="flex flex-row items-center justify-between space-y-0 pb-2">
<CardTitle className="text-sm font-medium">Total Ideas</CardTitle>
Expand Down Expand Up @@ -86,6 +95,21 @@ export function DashboardComponent() {
<span className="absolute text-2xl font-bold">{dashboardData?.globalReach}</span>
</CardContent>
</Card>

<Card>
<CardHeader className="flex flex-row items-center justify-between space-y-0 pb-2">
<CardTitle className="text-sm font-medium">TON Token Balance</CardTitle>
</CardHeader>
<CardContent>
<div className="text-2xl font-bold">
{tokenBalance !== null
? tokenBalance === 'Error'
? 'Error fetching balance'
: `${tokenBalance} TON`
: 'Fetching...'}
</div>
</CardContent>
</Card>
</div>

<Card className="mt-6">
Expand Down Expand Up @@ -119,3 +143,21 @@ export function DashboardComponent() {
</div>
)
}

// Mock function to simulate fetching dashboard data
const fetchDashboardData = () => {
return new Promise((resolve) => {
setTimeout(() => {
resolve({
totalIdeas: 83,
avgImplementationRate: 94,
globalReach: 42,
topIdeas: [
{ id: 1, name: "Idea 1", completionRate: 75 },
{ id: 2, name: "Idea 2", completionRate: 50 },
{ id: 3, name: "Idea 3", completionRate: 25 },
]
})
}, 1000)
})
}
17 changes: 17 additions & 0 deletions dash.board/src/lib/tonUtils.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import TonWeb from 'tonweb'

// Initialize TonWeb with a public endpoint
const tonweb = new TonWeb(new TonWeb.HttpProvider('https://toncenter.com/api/v2/jsonRPC'))

/**
* Fetches the token balance for a given TON address.
* @param address - The TON wallet address.
* @returns The balance in TON.
*/
export async function getTokenBalance(address: string): Promise<string> {
const addressObj = tonweb.address(address)
const balance = await tonweb.getBalance(addressObj)
// Convert from nanotons to tons
const balanceInTons = TonWeb.utils.fromNano(balance)
return balanceInTons.toString()
}
Binary file added images/image-ui-connect-wallet.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading