Skip to content

Commit

Permalink
Create page for LSP4 Metadata encoding
Browse files Browse the repository at this point in the history
  • Loading branch information
b00ste committed Jul 30, 2024
1 parent 8c51f82 commit a2660ee
Show file tree
Hide file tree
Showing 34 changed files with 1,454 additions and 130 deletions.
5 changes: 1 addition & 4 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -25,10 +25,7 @@ yarn-debug.log*
yarn-error.log*

# local env files
.env.local
.env.development.local
.env.test.local
.env.production.local
.env*

# vercel
.vercel
Expand Down
2 changes: 1 addition & 1 deletion components/AddressButtons/AddressButtons.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
* @author Felix Hildebrandt <fhildeb>
*/
import React, { useContext } from 'react';
import { NetworkContext } from '../../contexts/NetworksContext';
import { NetworkContext } from '@/contexts/NetworksContext';

interface Props {
address: string;
Expand Down
8 changes: 4 additions & 4 deletions components/AddressInfos/AddressInfos.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,15 +5,15 @@ import React, { useState, useContext, useEffect } from 'react';
import Skeleton from 'react-loading-skeleton';
import { ERC725YDataKeys } from '@lukso/lsp-smart-contracts';

import { NetworkContext } from '../../contexts/NetworksContext';
import useWeb3 from '../../hooks/useWeb3';
import { NetworkContext } from '@/contexts/NetworksContext';
import useWeb3 from '@/hooks/useWeb3';
import {
EXPLORER_BASE_URL,
LSP1_DELEGATE_VERSIONS,
LSP1_GRAVE_FORWARDER,
UP_RECOVERY_ADDRESSES,
} from '../../globals';
import { checkInterface, getData, checkIsGnosisSafe } from '../../utils/web3';
} from '@/globals';
import { checkInterface, getData, checkIsGnosisSafe } from '@/utils/web3';

import LSP7Artifact from '@lukso/lsp-smart-contracts/artifacts/LSP7DigitalAsset.json';
import { AbiItem } from 'web3-utils';
Expand Down
6 changes: 3 additions & 3 deletions components/ContractOwner/ContractOwner.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import { useState, useEffect } from 'react';
import ERC725Account from '@lukso/lsp-smart-contracts/artifacts/LSP0ERC725Account.json';
import useWeb3 from '../../hooks/useWeb3';
import useWeb3 from '@/hooks/useWeb3';

import { eip165ABI } from '../../constants';
import { eip165ABI } from '@/constants';
import { AbiItem, isAddress } from 'web3-utils';
import { INTERFACE_IDS } from '@lukso/lsp-smart-contracts';
import AddressButtons from '../AddressButtons';
import AddressButtons from '@/components/AddressButtons';

type Props = {
contractAddress: string;
Expand Down
6 changes: 3 additions & 3 deletions components/ControllersList/ControllersList.tsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
import React, { useEffect, useState } from 'react';
import ERC725, { encodeArrayKey, encodeKeyName } from '@erc725/erc725.js';

import { getDataBatch } from '../../utils/web3';
import useWeb3 from '../../hooks/useWeb3';
import AddressInfos from '../AddressInfos';
import { getDataBatch } from '@/utils/web3';
import useWeb3 from '@/hooks/useWeb3';
import AddressInfos from '@/components/AddressInfos';
import { ERC725YDataKeys } from '@lukso/lsp-smart-contracts';

interface Props {
Expand Down
8 changes: 4 additions & 4 deletions components/DataKeysTable/DataKeysTable.tsx
Original file line number Diff line number Diff line change
@@ -1,18 +1,18 @@
import React, { useEffect, useState } from 'react';
import { ERC725JSONSchema } from '@erc725/erc725.js';

import AddressButtons from '../AddressButtons';
import ValueTypeDecoder from '../ValueTypeDecoder';
import AddressButtons from '@/components/AddressButtons';
import ValueTypeDecoder from '@/components/ValueTypeDecoder';

import ProfileSchema from './ProfileSchema.json';
import AssetSchema from './AssetSchema.json';
import LSP8Schema from './LSP8Schema.json';

import { SCHEMA_DOCS_LINKS, SchemaName } from './schemas';

import { getDataBatch } from '../../utils/web3';
import { getDataBatch } from '@/utils/web3';

import useWeb3 from '../../hooks/useWeb3';
import useWeb3 from '@/hooks/useWeb3';

interface Props {
address: string;
Expand Down
4 changes: 2 additions & 2 deletions components/Decode/Decode.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@ import Web3 from 'web3';
import {
TRANSACTION_SELECTORS,
TRANSACTION_TYPES,
} from '../../interfaces/transaction';
import ErrorMessage from '../ErrorMessage/ErrorMessage';
} from '@/interfaces/transaction';
import ErrorMessage from '@/components/ErrorMessage';
import styles from './Decode.module.scss';

interface Props {
Expand Down
2 changes: 1 addition & 1 deletion components/Encode/Encode.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import EncodeSetData from './components/EncodeSetData';
import EncodeTransferOwnership from './components/EncodeTransferOwnership';
import styles from './Encode.module.scss';

import { TRANSACTION_TYPES } from '../../interfaces/transaction';
import { TRANSACTION_TYPES } from '@/interfaces/transaction';

interface Props {
web3: Web3;
Expand Down
2 changes: 1 addition & 1 deletion components/Encode/components/EncodeExecute.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { useState } from 'react';
import Web3 from 'web3';
import EncodedPayload from './EncodedPayload';
import ERC725Account from '@lukso/lsp-smart-contracts/artifacts/LSP0ERC725Account.json';
import ErrorMessage from '../../ErrorMessage';
import ErrorMessage from '@/components/ErrorMessage';
import styles from './EncodeExecute.module.scss';

interface Props {
Expand Down
2 changes: 1 addition & 1 deletion components/Encode/components/EncodeSetData.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { useState } from 'react';
import Web3 from 'web3';
import EncodedPayload from './EncodedPayload';
import ERC725Account from '@lukso/lsp-smart-contracts/artifacts/LSP0ERC725Account.json';
import ErrorMessage from '../../ErrorMessage';
import ErrorMessage from '@/components/ErrorMessage';
import { AbiItem } from 'web3-utils';
import styles from './EncodeSetData.module.scss';

Expand Down
2 changes: 1 addition & 1 deletion components/Encode/components/EncodeTransferOwnership.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { useState } from 'react';
import Web3 from 'web3';
import EncodedPayload from './EncodedPayload';
import ERC725Account from '@lukso/lsp-smart-contracts/artifacts/LSP0ERC725Account.json';
import ErrorMessage from '../../ErrorMessage';
import ErrorMessage from '@/components/ErrorMessage';
import { Contract } from 'web3-eth-contract';
import styles from './EncodeTransferOwnership.module.scss';
interface Props {
Expand Down
4 changes: 2 additions & 2 deletions components/KeyManagerNonceChecker/KeyManagerNonceChecker.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@
import { useContext, useState } from 'react';

import LSP6KeyManager from '@lukso/lsp-smart-contracts/artifacts/LSP6KeyManager.json';
import useWeb3 from '../../hooks/useWeb3';
import { NetworkContext } from '../../contexts/NetworksContext';
import useWeb3 from '@/hooks/useWeb3';
import { NetworkContext } from '@/contexts/NetworksContext';

const KeyManagerNonceChecker: React.FC = () => {
const web3 = useWeb3();
Expand Down
2 changes: 1 addition & 1 deletion components/KeyManagerPermissions/KeyManagerPermissions.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

import { useState } from 'react';
import ERC725 from '@erc725/erc725.js';
import PermissionsBtns from '../PermissionsBtns';
import PermissionsBtns from '@/components/PermissionsBtns';

const KeyManagerPermissions: React.FC = () => {
const initialEncodedPermissions =
Expand Down
154 changes: 99 additions & 55 deletions components/NavBar/NavBar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,122 +4,166 @@
*/
import React, { useState } from 'react';
import Link from 'next/link';
import { useRouter } from 'next/router';
import { NextRouter, useRouter } from 'next/router';
import NetworkSwitch from './components/NetworksSwitch';
import styles from './NavBar.module.scss';

const NavBar: React.FC = () => {
const LinksMenu = ({
router,
createLink,
}: {
router: NextRouter;
createLink: (path: string) => string;
}) => {
const [isActive, setIsActive] = useState(false);
const router = useRouter();

const toggleNavbar = () => {
setIsActive(!isActive);
};

const createLink = (path) => {
if (typeof window === 'undefined') {
return path;
}
const urlParams = new URLSearchParams(window.location.search);

const keys = Array.from(urlParams.keys());

// Remove all page-specific parameters
for (const key of keys) {
if (key !== 'network') {
urlParams.delete(key);
}
}

return `${path}?${urlParams.toString()}`;
};

return (
<nav className="navbar is-light sticky">
<div className={`navbar-brand ${styles.navbarHeight}`}>
<Link href={createLink('/')}>
<a className="navbar-item is-hidden-desktop">🛠 ERC725 Tools</a>
</Link>
<div className={`navbar-item dropdown ${isActive ? 'is-active' : ''}`}>
<div className="dropdown-trigger">
<a
role="button"
className={`navbar-burger burger ${isActive ? 'is-active' : ''}`}
aria-label="menu"
aria-expanded="false"
onClick={toggleNavbar}
className="navbar-link is-flex"
aria-haspopup="true"
aria-controls="dropdown-menu"
onClick={() => setIsActive(!isActive)}
>
<span aria-hidden="true"></span>
<span aria-hidden="true"></span>
<span aria-hidden="true"></span>
Menu
</a>
</div>

<div className={`navbar-menu ${isActive ? 'is-active' : ''}`}>
<div className="navbar-start ml-3">
<Link href={createLink('/')}>
<a className={`navbar-item is-hidden-touch ${styles.navbarHeight}`}>
🛠 ERC725 Tools
</a>
</Link>
<div className="dropdown-menu" id="dropdown-menu" role="menu">
<div className="dropdown-content" style={{ background: '#F0F0F0' }}>
<Link href={createLink('/inspector')}>
<a
className={`navbar-item ${
className={`dropdown-item ${
router.pathname === '/inspector' && 'has-text-link'
}`}
onClick={() => setIsActive(false)}
>
🔎 Inspector
</a>
</Link>
<Link href={createLink('/lsp-checker')}>
<a
className={`navbar-item ${
className={`dropdown-item ${
router.pathname === '/lsp-checker' && 'has-text-link'
}`}
onClick={() => setIsActive(false)}
>
✅ LSP Checker
</a>
</Link>
<Link href={createLink('/data-fetcher')}>
<a
className={`navbar-item ${
className={`dropdown-item ${
router.pathname === '/data-fetcher' && 'has-text-link'
}`}
onClick={() => setIsActive(false)}
>
💽 Data Fetcher
</a>
</Link>
<Link href={createLink('/key-manager')}>
<a
className={`navbar-item ${
className={`dropdown-item ${
router.pathname === '/key-manager' && 'has-text-link'
}`}
onClick={() => setIsActive(false)}
>
🔐 Key Manager
</a>
</Link>
<Link href={createLink('/abi-encoder')}>
<a
className={`navbar-item ${
className={`dropdown-item ${
router.pathname === '/abi-encoder' && 'has-text-link'
}`}
onClick={() => setIsActive(false)}
>
📜 ABI Encoder
</a>
</Link>
<Link href={createLink('/lsp2-encoder')}>
<a
className={`navbar-item ${
className={`dropdown-item ${
router.pathname === '/lsp2-encoder' && 'has-text-link'
}`}
onClick={() => setIsActive(false)}
>
📖 LSP2 Encoder
</a>
</Link>
<Link href="/lsp4-metadata-encoder">
<a
className={`dropdown-item ${
router.pathname === '/lsp4-metadata-encoder' && 'has-text-link'
}`}
onClick={() => setIsActive(false)}
>
📖 LSP4 Metadata Encoder
</a>
</Link>
</div>
</div>
</div>
);
};

const NavBar: React.FC = () => {
const [isActive, setIsActive] = useState(false);
const router = useRouter();

const toggleNavbar = () => {
setIsActive(!isActive);
};

const createLink = (path: string) => {
if (typeof window === 'undefined') {
return path;
}
const urlParams = new URLSearchParams(window.location.search);

const keys = Array.from(urlParams.keys());

// Remove all page-specific parameters
for (const key of keys) {
if (key !== 'network') {
urlParams.delete(key);
}
}

return `${path}?${urlParams.toString()}`;
};

return (
<nav className="navbar is-light sticky">
<div className={`navbar-brand ${styles.navbarHeight}`}>
<Link href={createLink('/')}>
<a className="navbar-item is-hidden-desktop">🛠 ERC725 Tools</a>
</Link>
<a
role="button"
className={`navbar-burger burger ${isActive ? 'is-active' : ''}`}
aria-label="menu"
aria-expanded="false"
onClick={toggleNavbar}
>
<span aria-hidden="true"></span>
<span aria-hidden="true"></span>
<span aria-hidden="true"></span>
</a>
</div>

<div className={`navbar-menu ${isActive ? 'is-active' : ''}`}>
<div className="navbar-start ml-3">
<Link href={createLink('/')}>
<a className={`navbar-item is-hidden-touch ${styles.navbarHeight}`}>
🛠 ERC725 Tools
</a>
</Link>
</div>

<div className="navbar-end">
<div className="navbar-item">
<NetworkSwitch />
</div>
<LinksMenu router={router} createLink={createLink} />
<NetworkSwitch />
<div className="navbar-item">
<div className="buttons">
<a
Expand Down
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
import React, { useContext, useState } from 'react';
import { useRouter } from 'next/router';
import { INetwork, NetworkContext } from '../../../../contexts/NetworksContext';
import { INetwork, NetworkContext } from '@/contexts/NetworksContext';

import { RPC_URL } from '../../../../globals';
import { NetworkName } from '../../../../types/network';
import { RPC_URL } from '@/globals';
import { NetworkName } from '@/types/network';

const luksoChains: INetwork[] = [
{
Expand Down
Loading

0 comments on commit a2660ee

Please sign in to comment.