-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* wip * wip refactor * wip refactor * wip refactor * wip-refactor * wip-refactor * lint fixes * wip-refactor * remove console.log * wip-refactor * wip-refactor * upd readme * wip-refactor * update codec * Refactor * Refactor * Refactor * Refactor * Refactor * Refactor * Refactor enums * Refactor * Refactor * Refactor * Refactor * Refactor * Refactor * Refactor * Fix config * Add missing links --------- Co-authored-by: nikolay_cholakov <[email protected]>
- Loading branch information
1 parent
00dcb4d
commit edde46d
Showing
73 changed files
with
4,655 additions
and
26 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
import { Icon } from '@components/icon'; | ||
import { cn } from '@utils/helpers'; | ||
|
||
interface ICallDocs { | ||
docs: string[]; | ||
className?: string; | ||
} | ||
|
||
export const CallDocs = ({ | ||
docs, | ||
className, | ||
}: ICallDocs) => { | ||
if (docs.length <= 0) { | ||
return null; | ||
} else { | ||
return ( | ||
<div className={cn( | ||
'p-3 font-body1-regular', | ||
'grid grid-cols-[24px_1fr] gap-2', | ||
'bg-dev-black-800 dark:bg-dev-purple-300', | ||
'border border-dev-purple-700 dark:border-dev-purple-200', | ||
'text-dev-purple-50 dark:text-dev-black-1000', | ||
className, | ||
)} | ||
> | ||
<Icon | ||
name="icon-info" | ||
size={[24]} | ||
/> | ||
<div className="flex flex-col gap-2"> | ||
{ | ||
docs?.map((doc, i) => ( | ||
<p key={`doc-${i}`}> | ||
{doc} | ||
</p> | ||
)) | ||
} | ||
</div> | ||
</div> | ||
); | ||
} | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
export { default as InvocationStorageArgs } from './invocationStorageArgs'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
import { NotImplemented } from '@components/invocationArgsMapper/notImplemented'; | ||
import { useStoreChain } from '@stores'; | ||
|
||
import { InvocationMapper } from '../invocationArgsMapper/invocationMapper'; | ||
|
||
import type { InvocationStorageArgs as Type } from '@components/invocationArgsMapper/types'; | ||
import type { TMetaDataStorageItem } from '@custom-types/papi'; | ||
import type { MetadataLookup } from '@polkadot-api/metadata-builders'; | ||
|
||
const shouldSkipRendering = (storage: TMetaDataStorageItem, lookup: MetadataLookup | null): boolean => { | ||
return storage.type.tag === 'plain' || !lookup; | ||
}; | ||
|
||
const InvocationStorageArgs = ({ args, onChange }: Type) => { | ||
const lookup = useStoreChain?.use?.lookup?.(); | ||
if (!lookup) { | ||
return null; | ||
} | ||
|
||
try { | ||
if (!shouldSkipRendering(args, lookup)) { | ||
return ( | ||
<InvocationMapper | ||
invokationVar={lookup!((args.type.value as { key: number }).key)} | ||
onChange={onChange} | ||
/> | ||
); | ||
} else { | ||
return null; | ||
} | ||
} catch (error) { | ||
console.error(error); | ||
return <NotImplemented />; | ||
} | ||
}; | ||
|
||
export default InvocationStorageArgs; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
export { default as InvocationDecoder } from './invocationDecoder'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
/* eslint-disable react/jsx-no-bind */ | ||
/* eslint-disable react-hooks/exhaustive-deps */ | ||
import { useCallback } from 'react'; | ||
|
||
import { InvocationDecoderArgs } from '@components/decoder/invocationDecoderArgs'; | ||
import { NotImplemented } from '@components/invocationArgsMapper/notImplemented'; | ||
|
||
import styles from '../invocationArgsMapper/styles.module.css'; | ||
|
||
import type { InvocationDecoder as Type } from '@components/invocationArgsMapper/types'; | ||
|
||
const InvocationDecoder = ({ fields, onChange }: Type) => { | ||
const handleOnChange = useCallback((index: number, args: unknown) => { | ||
onChange(index, args); | ||
}, []); | ||
|
||
if (!fields) { | ||
return null; | ||
} else { | ||
return ( | ||
<div className="flex flex-col gap-6 empty:hidden"> | ||
{ | ||
fields.map((field, index) => { | ||
const { name, type, description } = field; | ||
if (!type) { | ||
return <NotImplemented key={`rpc-field-not-implemented-${name}`} />; | ||
} else { | ||
return ( | ||
<div key={`rpc-field-${name}-${type}`}> | ||
<span className="block pb-1 font-geist capitalize font-body1-regular"> | ||
{name} | ||
</span> | ||
<div className={styles['invocationContainer']}> | ||
<div className={styles['invocationGroup']}> | ||
<InvocationDecoderArgs | ||
decoder={field} | ||
onChange={(args) => handleOnChange(index, args)} | ||
placeholder={description} | ||
/> | ||
</div> | ||
</div> | ||
</div> | ||
); | ||
} | ||
}) | ||
} | ||
</div> | ||
); | ||
} | ||
}; | ||
|
||
export default InvocationDecoder; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
import { NotImplemented } from '@components/invocationArgsMapper/notImplemented'; | ||
import { OrderBuilder } from '@components/metadataBuilders/orderBuilder'; | ||
import { PrimitiveBuilder } from '@components/metadataBuilders/primitiveBuilder'; | ||
|
||
import type { IDecoderBuilderProps } from '@components/invocationArgsMapper/types'; | ||
import type { InvocationDecoderArgs as Type } from '@constants/decoders/types'; | ||
|
||
const mapperCore: Record<Type['type'], (props: IDecoderBuilderProps) => JSX.Element> = { | ||
array: (props) => ( | ||
<OrderBuilder | ||
{...props} | ||
sequence={{ | ||
type: 'sequence', | ||
value: { | ||
type: 'primitive', | ||
value: 'str', | ||
id: 1, /* hardcoding it does not cause a problem */ | ||
}, | ||
}} | ||
/> | ||
), | ||
string: (props) => ( | ||
<PrimitiveBuilder | ||
{...props} | ||
primitive={{ value: 'str', type: 'primitive' }} | ||
/> | ||
), | ||
hex: (props) => ( | ||
<PrimitiveBuilder | ||
{...props} | ||
primitive={{ value: 'str', type: 'primitive' }} | ||
/> | ||
), | ||
}; | ||
export const InvocationDecoderArgs = (props: IDecoderBuilderProps) => { | ||
if (!props) { | ||
return null; | ||
} else { | ||
try { | ||
const decoderType = props.decoder.type; | ||
const InvocationComponent = mapperCore[decoderType] ?? NotImplemented; | ||
|
||
return <InvocationComponent {...props} />; | ||
} catch (error) { | ||
console.error(error); | ||
return <NotImplemented />; | ||
} | ||
} | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
export { default as InvocationDecoderDynamic } from './invocationDecoderDynamic'; |
28 changes: 28 additions & 0 deletions
28
src/components/decoderDynamic/invocationDecoderDynamic.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
import { PrimitiveBuilder } from '@components/metadataBuilders/primitiveBuilder'; | ||
|
||
import styles from '../invocationArgsMapper/styles.module.css'; | ||
|
||
import type { InvocationDecoderDynamic as Type } from '@components/invocationArgsMapper/types'; | ||
|
||
const InvocationDecoderDynamic = ({ onChange }: Type) => { | ||
return ( | ||
<div className="flex flex-col gap-6 empty:hidden"> | ||
<div> | ||
<span className="block pb-1 font-geist capitalize font-body1-regular"> | ||
SCALE-encoded value | ||
</span> | ||
<div className={styles['invocationContainer']}> | ||
<div className={styles['invocationGroup']}> | ||
<PrimitiveBuilder | ||
onChange={onChange} | ||
placeholder="hex" | ||
primitive={{ value: 'str', type: 'primitive' }} | ||
/> | ||
</div> | ||
</div> | ||
</div> | ||
</div> | ||
); | ||
}; | ||
|
||
export default InvocationDecoderDynamic; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
import { NotImplemented } from '@components/invocationArgsMapper/notImplemented'; | ||
import { useStoreChain } from '@stores'; | ||
|
||
import { InvocationMapper } from './invocationMapper'; | ||
|
||
import type { InvocationArgsMapper as Type } from '@components/invocationArgsMapper/types'; | ||
|
||
export const InvocationArgsMapper = ({ invocationVar, onChange }: Type) => { | ||
const lookup = useStoreChain?.use?.lookup?.(); | ||
|
||
try { | ||
if (!lookup) { | ||
return null; | ||
} else { | ||
if (!invocationVar?.type) { | ||
return <NotImplemented />; | ||
} else { | ||
if (invocationVar.type !== 'lookupEntry') { | ||
return ( | ||
<InvocationMapper | ||
invokationVar={invocationVar} | ||
onChange={onChange} | ||
/> | ||
); | ||
} else { | ||
return ( | ||
<InvocationMapper | ||
invokationVar={lookup(invocationVar.value.id)} | ||
onChange={onChange} | ||
/> | ||
); | ||
} | ||
} | ||
} | ||
} catch (error) { | ||
console.error(error); | ||
return <NotImplemented />; | ||
} | ||
}; |
Oops, something went wrong.