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

PRO Dashboard #40

Merged
merged 34 commits into from
Mar 12, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
34 commits
Select commit Hold shift + click to select a range
b51afbd
fix: pro subscription state integrated to the banner, columns choose …
siandreev Feb 29, 2024
568c0c7
fix: tg oauth integrated
siandreev Mar 1, 2024
8de65b9
Merge branch 'feature/pro' into feature/pro-dashboard
siandreev Mar 1, 2024
0d05000
Merge branch 'main' into feature/pro-dashboard
KuznetsovNikita Mar 5, 2024
4e063d0
Fix rebase
KuznetsovNikita Mar 5, 2024
1d71837
Merge branch 'main' into feature/pro-dashboard
siandreev Mar 6, 2024
f1c52fc
Merge remote-tracking branch 'origin/feature/pro-dashboard' into feat…
siandreev Mar 6, 2024
329637c
feat: dashboard api integrated
siandreev Mar 7, 2024
cb42b79
fix: telegram-widget script moved to a separate file
siandreev Mar 7, 2024
ebb4cf9
fix: trial & auth updates
siandreev Mar 8, 2024
c67bc53
chore: locales update
siandreev Mar 8, 2024
2771464
fix: updating from trial to pro
siandreev Mar 8, 2024
20abca3
fix: ton connect modal desktop view; Swap manifest.url and manifest.n…
siandreev Mar 8, 2024
6881592
fix: trial start notification (modal) added
siandreev Mar 8, 2024
80a8801
Merge branch 'main' into feature/pro-dashboard
siandreev Mar 8, 2024
10b4f39
chore: change telegram-oauth filename
siandreev Mar 8, 2024
ab64003
fix: start trial modal i18n translations added
siandreev Mar 8, 2024
f05ebca
chore: i18n update
siandreev Mar 8, 2024
9c68a94
Add REACT_APP_TG_BOT_ID to CI
KuznetsovNikita Mar 11, 2024
3bc8f20
Update version
KuznetsovNikita Mar 11, 2024
93f1a1d
chore: pipeline env vars added
siandreev Mar 11, 2024
0a62297
Merge remote-tracking branch 'origin/feature/pro-dashboard' into feat…
siandreev Mar 11, 2024
871bd1e
chore: pipeline env vars added
siandreev Mar 11, 2024
6150e13
Show menu bar
KuznetsovNikita Mar 11, 2024
a97e9e8
fix: ton connect modal didn't open in dashboard page
siandreev Mar 11, 2024
05c89f4
fix: locales update
siandreev Mar 11, 2024
33c948e
Merge remote-tracking branch 'origin/feature/pro-dashboard' into feat…
siandreev Mar 11, 2024
8702053
fix: dashboard skeleton added
siandreev Mar 11, 2024
87718e3
fix: dashboard wallets filtered, only mainnet are shown
siandreev Mar 11, 2024
fd4b1f2
feat: emoji picker added
siandreev Mar 11, 2024
848c97c
feat: custom emojis added
siandreev Mar 11, 2024
3aabacd
feat: emojis added to all layouts that includes wallet.name
siandreev Mar 12, 2024
a2bdd2e
fix: aside menu bottom maid sticky. tg -> ton_proof Auth fixes
siandreev Mar 12, 2024
fcbd946
Remove zoom factor
KuznetsovNikita Mar 12, 2024
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
13 changes: 8 additions & 5 deletions packages/uikit/src/components/dashboard/DashboardTable.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,9 @@ import { useDashboardColumnsAsForm } from '../../state/dashboard/useDashboardCol
import { useDashboardData } from '../../state/dashboard/useDashboardData';
import { DashboardCellAddress, DashboardColumnType } from '@tonkeeper/core/dist/entries/dashboard';
import { Skeleton } from '../shared/Skeleton';
import { useAppContext } from '../../hooks/appContext';
import { DashboardCell } from './columns/DashboardCell';
import { useWalletsState } from '../../state/wallet';
import { Network } from '@tonkeeper/core/dist/entries/network';

const TableStyled = styled.table`
width: 100%;
Expand Down Expand Up @@ -100,8 +101,10 @@ const isNumericColumn = (columnType: DashboardColumnType): boolean => {
export const DashboardTable: FC<{ className?: string }> = ({ className }) => {
const { data: columns } = useDashboardColumnsAsForm();
const { data: dashboardData } = useDashboardData();
const { account } = useAppContext();
const publicKeys = account?.publicKeys;
const { data: wallets, isFetched: isWalletsFetched } = useWalletsState();
const mainnetPubkeys = wallets
?.filter(w => w?.network === Network.MAINNET)
KuznetsovNikita marked this conversation as resolved.
Show resolved Hide resolved
.map(w => w!.publicKey);

const [isResizing, setIsResizing] = useState<boolean>(false);
const [hoverOnColumn, setHoverOnColumn] = useState<number | undefined>(undefined);
Expand Down Expand Up @@ -156,7 +159,7 @@ export const DashboardTable: FC<{ className?: string }> = ({ className }) => {
return hoverOnColumn !== undefined && hoverOnColumn >= i && hoverOnColumn <= i + 1;
};

if (!columns) {
if (!columns || !isWalletsFetched) {
return null;
}

Expand Down Expand Up @@ -221,7 +224,7 @@ export const DashboardTable: FC<{ className?: string }> = ({ className }) => {
))}
</TrStyled>
))
: (publicKeys || [1, 2, 3]).map(key => (
: (mainnetPubkeys || [1, 2, 3]).map(key => (
<TrStyled key={key}>
{selectedColumns.map((col, colIndex) => (
<Td key={col.id}>
Expand Down
1 change: 1 addition & 0 deletions packages/uikit/src/libs/queryKey.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
export enum QueryKey {
account = 'account',
wallet = 'wallet',
wallets = 'wallets',
lock = 'lock',
country = 'country',
password = 'password',
Expand Down
38 changes: 19 additions & 19 deletions packages/uikit/src/state/dashboard/useDashboardData.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,33 +5,34 @@ import { useAppContext } from '../../hooks/appContext';
import { DashboardCell } from '@tonkeeper/core/dist/entries/dashboard';
import { getDashboardData } from '@tonkeeper/core/dist/service/proService';
import { useTranslation } from '../../hooks/translation';
import { useAppSdk } from '../../hooks/appSdk';
import { getWalletState } from '@tonkeeper/core/dist/service/wallet/storeService';
import { WalletState } from '@tonkeeper/core/dist/entries/wallet';
import { Address } from 'ton-core';
import { Network } from '@tonkeeper/core/dist/entries/network';
import { useWalletsState } from '../wallet';

export function useDashboardData() {
const { data: columns } = useDashboardColumnsAsForm();
const selectedColumns = columns?.filter(c => c.isEnabled);
const { fiat, account } = useAppContext();
const { fiat } = useAppContext();
const {
i18n: { language },
t
} = useTranslation();
const selectedColIds = selectedColumns?.map(c => c.id);
const publicKeys = account?.publicKeys;
const { storage } = useAppSdk();
const client = useQueryClient();

const { data: walletsState } = useWalletsState();
const mainnetWallets = walletsState?.filter(w => w?.network === Network.MAINNET);
KuznetsovNikita marked this conversation as resolved.
Show resolved Hide resolved
const publicKeysMainnet = mainnetWallets?.map(w => w!.publicKey);

return useQuery<DashboardCell[][]>(
[QueryKey.dashboardData, selectedColIds, publicKeys, fiat, language],
[QueryKey.dashboardData, selectedColIds, publicKeysMainnet, fiat, language],
async ctx => {
if (!selectedColIds?.length || !publicKeys?.length) {
if (!selectedColIds?.length || !publicKeysMainnet?.length || !mainnetWallets?.length) {
return [];
}

const wallets = await Promise.all(publicKeys.map(pk => getWalletState(storage, pk)));
const accounts = wallets.map(acc => acc!.active.friendlyAddress);
const accounts = mainnetWallets.map(acc => acc!.active.friendlyAddress);

const loadData = async (query: { columns: string[]; accounts: string[] }) => {
const queryToFetch = {
Expand All @@ -51,7 +52,7 @@ export function useDashboardData() {
const defaultWalletName = t('wallet_title');
const result: DashboardCell[][] = query.accounts.map(() => []);
query.accounts.forEach((walletAddress, rowIndex) => {
const wallet = wallets.find(w =>
const wallet = mainnetWallets.find(w =>
Address.parse(w!.active.friendlyAddress).equals(
Address.parse(walletAddress)
)
Expand Down Expand Up @@ -91,8 +92,8 @@ export function useDashboardData() {
const walletsToQuerySet = new Set<WalletState>();
const columnsToQuerySet = new Set<string>();

const result: (DashboardCell | null)[][] = publicKeys.map(() => []);
publicKeys.forEach((pk, walletIndex) => {
const result: (DashboardCell | null)[][] = publicKeysMainnet.map(() => []);
publicKeysMainnet.forEach((pk, walletIndex) => {
selectedColIds.forEach((col, colIndex) => {
const matchingQueries = pastQueries.filter(
([key, _]) =>
Expand All @@ -102,7 +103,7 @@ export function useDashboardData() {

if (!matchingQueries.length) {
result[walletIndex][colIndex] = null;
walletsToQuerySet.add(wallets[walletIndex]!);
walletsToQuerySet.add(mainnetWallets[walletIndex]!);
columnsToQuerySet.add(col);
return;
}
Expand All @@ -119,10 +120,7 @@ export function useDashboardData() {
});

const walletsToQuery = [...walletsToQuerySet.values()];
let accountsToQuery = walletsToQuery.map(acc => acc.active.friendlyAddress);
if (columnsToQuerySet.size > 0) {
accountsToQuery = accounts;
}
const accountsToQuery = walletsToQuery.map(acc => acc.active.friendlyAddress);
const columnsToQuery = [...columnsToQuerySet.values()];

if (!accountsToQuery.length || !columnsToQuery.length) {
Expand All @@ -135,7 +133,9 @@ export function useDashboardData() {
});

newData.forEach((row, rowIndex) => {
const walletIndex = publicKeys.indexOf(walletsToQuery[rowIndex].publicKey);
const walletIndex = publicKeysMainnet.indexOf(
walletsToQuery[rowIndex].publicKey
);
row.forEach(cell => {
const colIndex = selectedColIds.indexOf(cell.columnId);
result[walletIndex][colIndex] = cell;
Expand All @@ -149,7 +149,7 @@ export function useDashboardData() {
return loadData({ accounts, columns: selectedColIds });
},
{
enabled: !!selectedColIds && !!publicKeys
enabled: !!selectedColIds && !!mainnetWallets
}
);
}
9 changes: 9 additions & 0 deletions packages/uikit/src/state/wallet.ts
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,15 @@ export const useWalletState = (publicKey: string) => {
);
};

export const useWalletsState = () => {
const { account } = useAppContext();
const sdk = useAppSdk();
return useQuery<(WalletState | null)[], Error>(
[QueryKey.account, QueryKey.wallets, account.publicKeys],
() => Promise.all(account.publicKeys.map(key => getWalletState(sdk.storage, key)))
);
};

export const useMutateLogOut = (publicKey: string, remove = false) => {
const sdk = useAppSdk();
const client = useQueryClient();
Expand Down
Loading