Files
pwap/pezkuwi-sdk-ui/packages/react-hooks/src/useFavorites.ts
T
Claude c71ddb6e0d Add Pezkuwi SDK UI - Polkadot.js Apps clone
- Clone Polkadot.js Apps repository
- Update package.json with Pezkuwi branding
- Add Pezkuwi endpoint to production chains (wss://pezkuwichain.app:9944)
- Create comprehensive README for SDK UI
- Set up project structure with all packages

Next steps:
- Apply Kurdistan colors (Kesk, Sor, Zer, Spi + Black) to UI theme
- Replace logos with Pezkuwi branding
- Test build and deployment
2025-11-14 00:55:17 +00:00

32 lines
1003 B
TypeScript

// Copyright 2017-2025 @polkadot/react-hooks authors & contributors
// SPDX-License-Identifier: Apache-2.0
import { useCallback, useMemo, useState } from 'react';
import { createNamedHook } from './createNamedHook.js';
import { useCacheKey } from './useCacheKey.js';
// hook for favorites with local storage
function useFavoritesImpl (storageKeyBase: string): [string[], (address: string) => void] {
const [getCache, setCache] = useCacheKey<string[]>(storageKeyBase);
const [favorites, setFavorites] = useState<string[]>(() => getCache() || []);
const toggleFavorite = useCallback(
(address: string): void => setFavorites(
(favorites) => setCache(
favorites.includes(address)
? favorites.filter((a) => address !== a)
: [...favorites, address]
)
),
[setCache]
);
return useMemo(
() => [favorites, toggleFavorite],
[favorites, toggleFavorite]
);
}
export const useFavorites = createNamedHook('useFavorites', useFavoritesImpl);