Compare commits
11 Commits
feat/prett
...
mobile-opt
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d3b0fef406 | ||
|
|
4cbc316c62 | ||
|
|
2d9ca2674e | ||
|
|
221c727af6 | ||
|
|
3b0a8c44c9 | ||
|
|
094f739b80 | ||
|
|
a2077f9592 | ||
|
|
2d82966b3b | ||
|
|
93c5ef231e | ||
|
|
53c2104b94 | ||
|
|
c336ff8334 |
@@ -6,11 +6,14 @@ const ButtonGroup = styled('div', {
|
|||||||
marginLeft: '1px',
|
marginLeft: '1px',
|
||||||
[`& ${StyledButton}`]: {
|
[`& ${StyledButton}`]: {
|
||||||
marginLeft: '-1px',
|
marginLeft: '-1px',
|
||||||
px: '$4',
|
px: '0.65rem',
|
||||||
zIndex: 2,
|
zIndex: 2,
|
||||||
position: 'relative',
|
position: 'relative',
|
||||||
'&:hover, &:focus': {
|
'&:hover, &:focus': {
|
||||||
zIndex: 200
|
zIndex: 200
|
||||||
|
},
|
||||||
|
'@sm': {
|
||||||
|
px: '$4'
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
[`& ${StyledButton}:not(:only-of-type):not(:first-child):not(:last-child)`]: {
|
[`& ${StyledButton}:not(:only-of-type):not(:first-child):not(:last-child)`]: {
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ import { subscribeKey } from 'valtio/utils'
|
|||||||
import { Select } from '.'
|
import { Select } from '.'
|
||||||
import state, { ILog, transactionsState } from '../state'
|
import state, { ILog, transactionsState } from '../state'
|
||||||
import { extractJSON } from '../utils/json'
|
import { extractJSON } from '../utils/json'
|
||||||
|
import EnrichLog from './EnrichLog'
|
||||||
import LogBox from './LogBox'
|
import LogBox from './LogBox'
|
||||||
|
|
||||||
interface ISelect<T = string> {
|
interface ISelect<T = string> {
|
||||||
@@ -99,6 +100,11 @@ const addListeners = (account: ISelect | null) => {
|
|||||||
|
|
||||||
subscribeKey(streamState, 'selectedAccount', addListeners)
|
subscribeKey(streamState, 'selectedAccount', addListeners)
|
||||||
|
|
||||||
|
const clearLog = () => {
|
||||||
|
streamState.logs = []
|
||||||
|
streamState.statusChangeTimestamp = Date.now()
|
||||||
|
}
|
||||||
|
|
||||||
const DebugStream = () => {
|
const DebugStream = () => {
|
||||||
const { selectedAccount, logs } = useSnapshot(streamState)
|
const { selectedAccount, logs } = useSnapshot(streamState)
|
||||||
const { activeHeader: activeTxTab } = useSnapshot(transactionsState)
|
const { activeHeader: activeTxTab } = useSnapshot(transactionsState)
|
||||||
@@ -134,11 +140,6 @@ const DebugStream = () => {
|
|||||||
streamState.selectedAccount = account
|
streamState.selectedAccount = account
|
||||||
}, [activeTxTab])
|
}, [activeTxTab])
|
||||||
|
|
||||||
const clearLog = () => {
|
|
||||||
streamState.logs = []
|
|
||||||
streamState.statusChangeTimestamp = Date.now()
|
|
||||||
}
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<LogBox enhanced renderNav={renderNav} title="Debug stream" logs={logs} clearLog={clearLog} />
|
<LogBox enhanced renderNav={renderNav} title="Debug stream" logs={logs} clearLog={clearLog} />
|
||||||
)
|
)
|
||||||
@@ -157,9 +158,11 @@ export const pushLog = (str: any, opts: Partial<Pick<ILog, 'type'>> = {}): ILog
|
|||||||
const timestring = !timestamp ? tm : new Date(timestamp).toLocaleTimeString()
|
const timestring = !timestamp ? tm : new Date(timestamp).toLocaleTimeString()
|
||||||
|
|
||||||
const extracted = extractJSON(msg)
|
const extracted = extractJSON(msg)
|
||||||
const message = !extracted ? msg : msg.slice(0, extracted.start) + msg.slice(extracted.end + 1)
|
const _message = !extracted ? msg : msg.slice(0, extracted.start) + msg.slice(extracted.end + 1)
|
||||||
|
const message = ref(<EnrichLog str={_message} />)
|
||||||
|
|
||||||
const jsonData = extracted ? JSON.stringify(extracted.result, null, 2) : undefined
|
const _jsonData = extracted ? JSON.stringify(extracted.result, null, 2) : undefined
|
||||||
|
const jsonData = _jsonData ? ref(<EnrichLog str={_jsonData} />) : undefined
|
||||||
|
|
||||||
if (extracted?.result?.id?._Request?.includes('hooks-builder-req')) {
|
if (extracted?.result?.id?._Request?.includes('hooks-builder-req')) {
|
||||||
return
|
return
|
||||||
|
|||||||
@@ -40,11 +40,10 @@ const StyledContent = styled(DialogPrimitive.Content, {
|
|||||||
color: '$mauve12',
|
color: '$mauve12',
|
||||||
borderRadius: '$md',
|
borderRadius: '$md',
|
||||||
position: 'relative',
|
position: 'relative',
|
||||||
mb: '15%',
|
mb: '0%',
|
||||||
boxShadow: '0px 10px 38px -5px rgba(22, 23, 24, 0.25), 0px 10px 20px -5px rgba(22, 23, 24, 0.2)',
|
boxShadow: '0px 10px 38px -5px rgba(22, 23, 24, 0.25), 0px 10px 20px -5px rgba(22, 23, 24, 0.2)',
|
||||||
width: '90vw',
|
width: '90vw',
|
||||||
maxWidth: '450px',
|
maxWidth: '450px',
|
||||||
// maxHeight: "85vh",
|
|
||||||
padding: 25,
|
padding: 25,
|
||||||
'@media (prefers-reduced-motion: no-preference)': {
|
'@media (prefers-reduced-motion: no-preference)': {
|
||||||
animation: `${contentShow} 150ms cubic-bezier(0.16, 1, 0.3, 1)`
|
animation: `${contentShow} 150ms cubic-bezier(0.16, 1, 0.3, 1)`
|
||||||
@@ -53,6 +52,9 @@ const StyledContent = styled(DialogPrimitive.Content, {
|
|||||||
'.dark &': {
|
'.dark &': {
|
||||||
backgroundColor: '$mauve5',
|
backgroundColor: '$mauve5',
|
||||||
boxShadow: '0px 10px 38px 0px rgba(0, 0, 0, 0.85), 0px 10px 20px 0px rgba(0, 0, 0, 0.6)'
|
boxShadow: '0px 10px 38px 0px rgba(0, 0, 0, 0.85), 0px 10px 20px 0px rgba(0, 0, 0, 0.6)'
|
||||||
|
},
|
||||||
|
'@md': {
|
||||||
|
mb: '8%'
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@@ -78,7 +78,6 @@ const EditorNavigation = ({ renderNav }: { renderNav?: () => ReactNode }) => {
|
|||||||
return (
|
return (
|
||||||
<Flex css={{ flexShrink: 0, gap: '$0' }}>
|
<Flex css={{ flexShrink: 0, gap: '$0' }}>
|
||||||
<Flex
|
<Flex
|
||||||
id="kissa"
|
|
||||||
ref={scrollRef}
|
ref={scrollRef}
|
||||||
css={{
|
css={{
|
||||||
overflowX: 'scroll',
|
overflowX: 'scroll',
|
||||||
@@ -181,7 +180,21 @@ const EditorNavigation = ({ renderNav }: { renderNav?: () => ReactNode }) => {
|
|||||||
</DropdownMenuContent>
|
</DropdownMenuContent>
|
||||||
</DropdownMenu>
|
</DropdownMenu>
|
||||||
) : (
|
) : (
|
||||||
<Button outline size="sm" css={{ mr: '$3' }} onClick={() => setPopUp(true)}>
|
<Button
|
||||||
|
outline
|
||||||
|
size="sm"
|
||||||
|
css={{
|
||||||
|
mr: '-1px',
|
||||||
|
borderTopRightRadius: 0,
|
||||||
|
borderBottomRightRadius: 0,
|
||||||
|
'@sm': {
|
||||||
|
borderTopRightRadius: '$sm',
|
||||||
|
borderBottomRightRadius: '$sm',
|
||||||
|
mr: '$3'
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
onClick={() => setPopUp(true)}
|
||||||
|
>
|
||||||
<GithubLogo size="16px" /> Login
|
<GithubLogo size="16px" /> Login
|
||||||
</Button>
|
</Button>
|
||||||
)}
|
)}
|
||||||
@@ -202,6 +215,9 @@ const EditorNavigation = ({ renderNav }: { renderNav?: () => ReactNode }) => {
|
|||||||
alignSelf: 'flex-start',
|
alignSelf: 'flex-start',
|
||||||
boxShadow: 'none'
|
boxShadow: 'none'
|
||||||
},
|
},
|
||||||
|
'button:not(:last-child)': {
|
||||||
|
display: 'none'
|
||||||
|
},
|
||||||
'button:not(:first-child):not(:last-child)': {
|
'button:not(:first-child):not(:last-child)': {
|
||||||
borderRight: 0,
|
borderRight: 0,
|
||||||
borderLeft: 0
|
borderLeft: 0
|
||||||
@@ -217,6 +233,11 @@ const EditorNavigation = ({ renderNav }: { renderNav?: () => ReactNode }) => {
|
|||||||
'&:hover': {
|
'&:hover': {
|
||||||
boxShadow: 'inset 0px 0px 0px 1px $colors$mauve12'
|
boxShadow: 'inset 0px 0px 0px 1px $colors$mauve12'
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
'@sm': {
|
||||||
|
'button:not(:last-child)': {
|
||||||
|
display: 'flex'
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
|
|||||||
73
components/EnrichLog.tsx
Normal file
73
components/EnrichLog.tsx
Normal file
@@ -0,0 +1,73 @@
|
|||||||
|
import { FC, useState } from 'react'
|
||||||
|
import regexifyString from 'regexify-string'
|
||||||
|
import { useSnapshot } from 'valtio'
|
||||||
|
import { Link } from '.'
|
||||||
|
import state from '../state'
|
||||||
|
import { AccountDialog } from './Accounts'
|
||||||
|
import Tooltip from './Tooltip'
|
||||||
|
import hookSetCodes from '../content/hook-set-codes.json'
|
||||||
|
import { capitalize } from '../utils/helpers'
|
||||||
|
|
||||||
|
interface EnrichLogProps {
|
||||||
|
str?: string
|
||||||
|
}
|
||||||
|
|
||||||
|
const EnrichLog: FC<EnrichLogProps> = ({ str }) => {
|
||||||
|
const { accounts } = useSnapshot(state)
|
||||||
|
const [dialogAccount, setDialogAccount] = useState<string | null>(null)
|
||||||
|
if (!str || !accounts.length) return <>{str}</>
|
||||||
|
|
||||||
|
const addrs = accounts.map(acc => acc.address)
|
||||||
|
const regex = `(${addrs.join('|')}|HookSet\\(\\d+\\))`
|
||||||
|
const res = regexifyString({
|
||||||
|
pattern: new RegExp(regex, 'gim'),
|
||||||
|
decorator: (match, idx) => {
|
||||||
|
if (match.startsWith('r')) {
|
||||||
|
// Account
|
||||||
|
const name = accounts.find(acc => acc.address === match)?.name
|
||||||
|
return (
|
||||||
|
<Link
|
||||||
|
key={match + idx}
|
||||||
|
as="a"
|
||||||
|
onClick={() => setDialogAccount(match)}
|
||||||
|
title={match}
|
||||||
|
highlighted
|
||||||
|
>
|
||||||
|
{name || match}
|
||||||
|
</Link>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
if (match.startsWith('HookSet')) {
|
||||||
|
const code = match.match(/^HookSet\((\d+)\)/)?.[1]
|
||||||
|
const val = hookSetCodes.find(v => code && v.code === +code)
|
||||||
|
console.log({ code, val })
|
||||||
|
if (!val) return match
|
||||||
|
|
||||||
|
const content = capitalize(val.description) || 'No hint available!'
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
HookSet(
|
||||||
|
<Tooltip content={content}>
|
||||||
|
<Link>{val.identifier}</Link>
|
||||||
|
</Tooltip>
|
||||||
|
)
|
||||||
|
</>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
return match
|
||||||
|
},
|
||||||
|
input: str
|
||||||
|
})
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
{res}
|
||||||
|
<AccountDialog
|
||||||
|
setActiveAccountAddress={setDialogAccount}
|
||||||
|
activeAccountAddress={dialogAccount}
|
||||||
|
/>
|
||||||
|
</>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default EnrichLog
|
||||||
@@ -1,15 +1,12 @@
|
|||||||
import { useRef, useLayoutEffect, ReactNode, FC, useState, useCallback } from 'react'
|
import { useRef, useLayoutEffect, ReactNode, FC, useState } from 'react'
|
||||||
import { IconProps, Notepad, Prohibit } from 'phosphor-react'
|
import { IconProps, Notepad, Prohibit } from 'phosphor-react'
|
||||||
import useStayScrolled from 'react-stay-scrolled'
|
import useStayScrolled from 'react-stay-scrolled'
|
||||||
import NextLink from 'next/link'
|
import NextLink from 'next/link'
|
||||||
|
|
||||||
import Container from './Container'
|
import Container from './Container'
|
||||||
import LogText from './LogText'
|
import LogText from './LogText'
|
||||||
import state, { ILog } from '../state'
|
import { ILog } from '../state'
|
||||||
import { Pre, Link, Heading, Button, Text, Flex, Box } from '.'
|
import { Pre, Link, Heading, Button, Text, Flex, Box } from '.'
|
||||||
import regexifyString from 'regexify-string'
|
|
||||||
import { useSnapshot } from 'valtio'
|
|
||||||
import { AccountDialog } from './Accounts'
|
|
||||||
|
|
||||||
interface ILogBox {
|
interface ILogBox {
|
||||||
title: string
|
title: string
|
||||||
@@ -143,70 +140,25 @@ const LogBox: FC<ILogBox> = ({
|
|||||||
export const Log: FC<ILog> = ({
|
export const Log: FC<ILog> = ({
|
||||||
type,
|
type,
|
||||||
timestring,
|
timestring,
|
||||||
message: _message,
|
message,
|
||||||
link,
|
link,
|
||||||
linkText,
|
linkText,
|
||||||
defaultCollapsed,
|
defaultCollapsed,
|
||||||
jsonData: _jsonData
|
jsonData
|
||||||
}) => {
|
}) => {
|
||||||
const [expanded, setExpanded] = useState(!defaultCollapsed)
|
const [expanded, setExpanded] = useState(!defaultCollapsed)
|
||||||
const { accounts } = useSnapshot(state)
|
|
||||||
const [dialogAccount, setDialogAccount] = useState<string | null>(null)
|
|
||||||
|
|
||||||
const enrichAccounts = useCallback(
|
|
||||||
(str?: string): ReactNode => {
|
|
||||||
if (!str || !accounts.length) return str
|
|
||||||
|
|
||||||
const pattern = `(${accounts.map(acc => acc.address).join('|')})`
|
|
||||||
const res = regexifyString({
|
|
||||||
pattern: new RegExp(pattern, 'gim'),
|
|
||||||
decorator: (match, idx) => {
|
|
||||||
const name = accounts.find(acc => acc.address === match)?.name
|
|
||||||
return (
|
|
||||||
<Link
|
|
||||||
key={match + idx}
|
|
||||||
as="a"
|
|
||||||
onClick={() => setDialogAccount(match)}
|
|
||||||
title={match}
|
|
||||||
highlighted
|
|
||||||
>
|
|
||||||
{name || match}
|
|
||||||
</Link>
|
|
||||||
)
|
|
||||||
},
|
|
||||||
input: str
|
|
||||||
})
|
|
||||||
|
|
||||||
return <>{res}</>
|
|
||||||
},
|
|
||||||
[accounts]
|
|
||||||
)
|
|
||||||
|
|
||||||
let message: ReactNode
|
|
||||||
|
|
||||||
if (typeof _message === 'string') {
|
|
||||||
_message = _message.trim().replace(/\n /gi, '\n')
|
|
||||||
if (_message) message = enrichAccounts(_message)
|
|
||||||
else message = <Text muted>{'""'}</Text>
|
|
||||||
} else {
|
|
||||||
message = _message
|
|
||||||
}
|
|
||||||
|
|
||||||
const jsonData = enrichAccounts(_jsonData)
|
|
||||||
|
|
||||||
|
if (message === undefined) message = <Text muted>{'undefined'}</Text>
|
||||||
|
else if (message === '') message = <Text muted>{'""'}</Text>
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<AccountDialog
|
|
||||||
setActiveAccountAddress={setDialogAccount}
|
|
||||||
activeAccountAddress={dialogAccount}
|
|
||||||
/>
|
|
||||||
<LogText variant={type}>
|
<LogText variant={type}>
|
||||||
{timestring && (
|
{timestring && (
|
||||||
<Text muted monospace>
|
<Text muted monospace>
|
||||||
{timestring}{' '}
|
{timestring}{' '}
|
||||||
</Text>
|
</Text>
|
||||||
)}
|
)}
|
||||||
<Pre>{message} </Pre>
|
<Pre>{message}</Pre>
|
||||||
{link && (
|
{link && (
|
||||||
<NextLink href={link} shallow passHref>
|
<NextLink href={link} shallow passHref>
|
||||||
<Link as="a">{linkText}</Link>
|
<Link as="a">{linkText}</Link>
|
||||||
@@ -219,7 +171,6 @@ export const Log: FC<ILog> = ({
|
|||||||
)}
|
)}
|
||||||
{expanded && jsonData && <Pre block>{jsonData}</Pre>}
|
{expanded && jsonData && <Pre block>{jsonData}</Pre>}
|
||||||
</LogText>
|
</LogText>
|
||||||
<br />
|
|
||||||
</>
|
</>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ import { styled } from '../stitches.config'
|
|||||||
const ImageWrapper = styled(Flex, {
|
const ImageWrapper = styled(Flex, {
|
||||||
position: 'relative',
|
position: 'relative',
|
||||||
mt: '$2',
|
mt: '$2',
|
||||||
mb: '$10',
|
mb: '$6',
|
||||||
svg: {
|
svg: {
|
||||||
// fill: "red",
|
// fill: "red",
|
||||||
'.angle': {
|
'.angle': {
|
||||||
@@ -66,16 +66,23 @@ const Navigation = () => {
|
|||||||
<Container
|
<Container
|
||||||
css={{
|
css={{
|
||||||
display: 'flex',
|
display: 'flex',
|
||||||
alignItems: 'center'
|
alignItems: 'center',
|
||||||
|
px: '$3',
|
||||||
|
'@sm': {
|
||||||
|
px: '$4'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<Flex
|
<Flex
|
||||||
css={{
|
css={{
|
||||||
flex: 1,
|
flex: 1,
|
||||||
alignItems: 'center',
|
alignItems: 'center',
|
||||||
borderRight: '1px solid $colors$mauve6',
|
|
||||||
py: '$3',
|
py: '$3',
|
||||||
pr: '$4'
|
pr: '$0',
|
||||||
|
'@sm': {
|
||||||
|
borderRight: '1px solid $colors$mauve6',
|
||||||
|
pr: '$4'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<Link href={gistId ? `/develop/${gistId}` : '/develop'} passHref>
|
<Link href={gistId ? `/develop/${gistId}` : '/develop'} passHref>
|
||||||
@@ -84,7 +91,11 @@ const Navigation = () => {
|
|||||||
css={{
|
css={{
|
||||||
display: 'flex',
|
display: 'flex',
|
||||||
alignItems: 'center',
|
alignItems: 'center',
|
||||||
color: '$textColor'
|
color: '$textColor',
|
||||||
|
mr: '$2',
|
||||||
|
'@sm': {
|
||||||
|
mr: '$4'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<Logo width="32px" height="32px" />
|
<Logo width="32px" height="32px" />
|
||||||
@@ -92,9 +103,12 @@ const Navigation = () => {
|
|||||||
</Link>
|
</Link>
|
||||||
<Flex
|
<Flex
|
||||||
css={{
|
css={{
|
||||||
ml: '$5',
|
|
||||||
flexDirection: 'column',
|
flexDirection: 'column',
|
||||||
gap: '1px'
|
gap: '1px',
|
||||||
|
display: 'none',
|
||||||
|
'@md': {
|
||||||
|
display: 'flex'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
{snap.loading ? (
|
{snap.loading ? (
|
||||||
@@ -135,8 +149,8 @@ const Navigation = () => {
|
|||||||
css={{
|
css={{
|
||||||
display: 'flex',
|
display: 'flex',
|
||||||
maxWidth: '1080px',
|
maxWidth: '1080px',
|
||||||
width: '80vw',
|
width: '90vw',
|
||||||
maxHeight: '80%',
|
maxHeight: '90%',
|
||||||
backgroundColor: '$mauve1 !important',
|
backgroundColor: '$mauve1 !important',
|
||||||
overflowY: 'auto',
|
overflowY: 'auto',
|
||||||
background: 'black',
|
background: 'black',
|
||||||
@@ -265,15 +279,18 @@ const Navigation = () => {
|
|||||||
gridTemplateColumns: '1fr',
|
gridTemplateColumns: '1fr',
|
||||||
gridTemplateRows: 'max-content',
|
gridTemplateRows: 'max-content',
|
||||||
flex: 1,
|
flex: 1,
|
||||||
p: '$7',
|
p: '$4',
|
||||||
pb: '$16',
|
pb: '$8',
|
||||||
gap: '$3',
|
gap: '$3',
|
||||||
alignItems: 'normal',
|
alignItems: 'normal',
|
||||||
flexWrap: 'wrap',
|
flexWrap: 'wrap',
|
||||||
backgroundColor: '$mauve1',
|
backgroundColor: '$mauve1',
|
||||||
'@md': {
|
'@md': {
|
||||||
gridTemplateColumns: '1fr 1fr',
|
gridTemplateColumns: '1fr 1fr',
|
||||||
gridTemplateRows: 'max-content'
|
gridTemplateRows: 'max-content',
|
||||||
|
p: '$7',
|
||||||
|
pb: '$10',
|
||||||
|
paddingRight: '$12'
|
||||||
},
|
},
|
||||||
'@lg': {
|
'@lg': {
|
||||||
gridTemplateColumns: '1fr 1fr 1fr',
|
gridTemplateColumns: '1fr 1fr 1fr',
|
||||||
@@ -316,23 +333,30 @@ const Navigation = () => {
|
|||||||
<Flex
|
<Flex
|
||||||
css={{
|
css={{
|
||||||
flexWrap: 'nowrap',
|
flexWrap: 'nowrap',
|
||||||
marginLeft: '$4',
|
marginLeft: '$2',
|
||||||
overflowX: 'scroll',
|
overflowX: 'scroll',
|
||||||
'&::-webkit-scrollbar': {
|
'&::-webkit-scrollbar': {
|
||||||
height: 0,
|
height: 0,
|
||||||
background: 'transparent'
|
background: 'transparent'
|
||||||
},
|
},
|
||||||
scrollbarColor: 'transparent',
|
scrollbarColor: 'transparent',
|
||||||
scrollbarWidth: 'none'
|
scrollbarWidth: 'none',
|
||||||
|
'@sm': {
|
||||||
|
marginLeft: '$4'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<Stack
|
<Stack
|
||||||
css={{
|
css={{
|
||||||
ml: '$4',
|
ml: '$0',
|
||||||
gap: '$3',
|
gap: '$2',
|
||||||
flexWrap: 'nowrap',
|
flexWrap: 'nowrap',
|
||||||
alignItems: 'center',
|
alignItems: 'center',
|
||||||
marginLeft: 'auto'
|
marginLeft: 'auto',
|
||||||
|
'@sm': {
|
||||||
|
marginLeft: '$4',
|
||||||
|
gap: '$3'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<ButtonGroup>
|
<ButtonGroup>
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ const PanelBox = styled('div', {
|
|||||||
flexDirection: 'column',
|
flexDirection: 'column',
|
||||||
border: '1px solid $colors$mauve6',
|
border: '1px solid $colors$mauve6',
|
||||||
backgroundColor: '$mauve2',
|
backgroundColor: '$mauve2',
|
||||||
padding: '$3',
|
padding: '$5',
|
||||||
borderRadius: '$sm',
|
borderRadius: '$sm',
|
||||||
fontWeight: 'lighter',
|
fontWeight: 'lighter',
|
||||||
height: 'auto',
|
height: 'auto',
|
||||||
|
|||||||
24
components/ResultLink.tsx
Normal file
24
components/ResultLink.tsx
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
import { FC } from 'react'
|
||||||
|
import { Link } from '.'
|
||||||
|
|
||||||
|
interface Props {
|
||||||
|
result?: string
|
||||||
|
}
|
||||||
|
|
||||||
|
const ResultLink: FC<Props> = ({ result }) => {
|
||||||
|
if (!result) return null
|
||||||
|
let href: string
|
||||||
|
if (result === 'tesSUCCESS') {
|
||||||
|
href = 'https://xrpl.org/tes-success.html'
|
||||||
|
} else {
|
||||||
|
// Going shortcut here because of url structure, if that changes we will do it manually
|
||||||
|
href = `https://xrpl.org/${result.slice(0, 3)}-codes.html`
|
||||||
|
}
|
||||||
|
return (
|
||||||
|
<Link as="a" href={href} target="_blank" rel="noopener noreferrer">
|
||||||
|
{result}
|
||||||
|
</Link>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default ResultLink
|
||||||
@@ -72,7 +72,12 @@ const Tooltip: React.FC<React.ComponentProps<typeof StyledContent> & ITooltip> =
|
|||||||
...rest
|
...rest
|
||||||
}) => {
|
}) => {
|
||||||
return (
|
return (
|
||||||
<TooltipPrimitive.Root open={open} defaultOpen={defaultOpen} onOpenChange={onOpenChange}>
|
<TooltipPrimitive.Root
|
||||||
|
open={open}
|
||||||
|
defaultOpen={defaultOpen}
|
||||||
|
onOpenChange={onOpenChange}
|
||||||
|
delayDuration={100}
|
||||||
|
>
|
||||||
<TooltipPrimitive.Trigger asChild>{children}</TooltipPrimitive.Trigger>
|
<TooltipPrimitive.Trigger asChild>{children}</TooltipPrimitive.Trigger>
|
||||||
<StyledContent side="bottom" align="center" {...rest}>
|
<StyledContent side="bottom" align="center" {...rest}>
|
||||||
<div dangerouslySetInnerHTML={{ __html: content }} />
|
<div dangerouslySetInnerHTML={{ __html: content }} />
|
||||||
|
|||||||
@@ -185,11 +185,16 @@ const Transaction: FC<TransactionProps> = ({ header, state: txState, ...props })
|
|||||||
row
|
row
|
||||||
css={{
|
css={{
|
||||||
justifyContent: 'space-between',
|
justifyContent: 'space-between',
|
||||||
position: 'absolute',
|
|
||||||
left: 0,
|
|
||||||
bottom: 0,
|
|
||||||
width: '100%',
|
width: '100%',
|
||||||
mb: '$1'
|
mb: '$2',
|
||||||
|
mt: '$1',
|
||||||
|
'@md': {
|
||||||
|
position: 'absolute',
|
||||||
|
left: 0,
|
||||||
|
bottom: 0,
|
||||||
|
mt: '$0',
|
||||||
|
mb: '$2'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<Button
|
<Button
|
||||||
|
|||||||
@@ -137,11 +137,14 @@ export const TxUI: FC<UIProps> = ({ state: txState, setState, estimateFee }) =>
|
|||||||
row
|
row
|
||||||
fluid
|
fluid
|
||||||
css={{
|
css={{
|
||||||
justifyContent: 'flex-end',
|
justifyContent: 'space-between',
|
||||||
alignItems: 'center',
|
alignItems: 'center',
|
||||||
mb: '$3',
|
mb: '$3',
|
||||||
mt: '1px',
|
mt: '1px',
|
||||||
pr: '1px'
|
pr: '1px',
|
||||||
|
'@xl': {
|
||||||
|
justifyContent: 'flex-end'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<Text muted css={{ mr: '$3' }}>
|
<Text muted css={{ mr: '$3' }}>
|
||||||
@@ -152,7 +155,13 @@ export const TxUI: FC<UIProps> = ({ state: txState, setState, estimateFee }) =>
|
|||||||
placeholder="Select transaction type"
|
placeholder="Select transaction type"
|
||||||
options={transactionsOptions}
|
options={transactionsOptions}
|
||||||
hideSelectedOptions
|
hideSelectedOptions
|
||||||
css={{ width: '70%' }}
|
css={{
|
||||||
|
width: '60%',
|
||||||
|
minWidth: '200px',
|
||||||
|
'@lg': {
|
||||||
|
width: '70%'
|
||||||
|
}
|
||||||
|
}}
|
||||||
value={selectedTransaction}
|
value={selectedTransaction}
|
||||||
onChange={(tt: any) => handleChangeTxType(tt)}
|
onChange={(tt: any) => handleChangeTxType(tt)}
|
||||||
/>
|
/>
|
||||||
@@ -161,10 +170,13 @@ export const TxUI: FC<UIProps> = ({ state: txState, setState, estimateFee }) =>
|
|||||||
row
|
row
|
||||||
fluid
|
fluid
|
||||||
css={{
|
css={{
|
||||||
justifyContent: 'flex-end',
|
justifyContent: 'space-between',
|
||||||
alignItems: 'center',
|
alignItems: 'center',
|
||||||
mb: '$3',
|
mb: '$3',
|
||||||
pr: '1px'
|
pr: '1px',
|
||||||
|
'@xl': {
|
||||||
|
justifyContent: 'flex-end'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<Text muted css={{ mr: '$3' }}>
|
<Text muted css={{ mr: '$3' }}>
|
||||||
@@ -173,7 +185,13 @@ export const TxUI: FC<UIProps> = ({ state: txState, setState, estimateFee }) =>
|
|||||||
<Select
|
<Select
|
||||||
instanceId="from-account"
|
instanceId="from-account"
|
||||||
placeholder="Select your account"
|
placeholder="Select your account"
|
||||||
css={{ width: '70%' }}
|
css={{
|
||||||
|
width: '60%',
|
||||||
|
minWidth: '200px',
|
||||||
|
'@lg': {
|
||||||
|
width: '70%'
|
||||||
|
}
|
||||||
|
}}
|
||||||
options={accountOptions}
|
options={accountOptions}
|
||||||
value={selectedAccount}
|
value={selectedAccount}
|
||||||
onChange={(acc: any) => handleSetAccount(acc)} // TODO make react-select have correct types for acc
|
onChange={(acc: any) => handleSetAccount(acc)} // TODO make react-select have correct types for acc
|
||||||
@@ -184,10 +202,13 @@ export const TxUI: FC<UIProps> = ({ state: txState, setState, estimateFee }) =>
|
|||||||
row
|
row
|
||||||
fluid
|
fluid
|
||||||
css={{
|
css={{
|
||||||
justifyContent: 'flex-end',
|
justifyContent: 'space-between',
|
||||||
alignItems: 'center',
|
alignItems: 'center',
|
||||||
mb: '$3',
|
mb: '$3',
|
||||||
pr: '1px'
|
pr: '1px',
|
||||||
|
'@xl': {
|
||||||
|
justifyContent: 'flex-end'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<Text muted css={{ mr: '$3' }}>
|
<Text muted css={{ mr: '$3' }}>
|
||||||
@@ -196,7 +217,13 @@ export const TxUI: FC<UIProps> = ({ state: txState, setState, estimateFee }) =>
|
|||||||
<Select
|
<Select
|
||||||
instanceId="to-account"
|
instanceId="to-account"
|
||||||
placeholder="Select the destination account"
|
placeholder="Select the destination account"
|
||||||
css={{ width: '70%' }}
|
css={{
|
||||||
|
width: '60%',
|
||||||
|
minWidth: '200px',
|
||||||
|
'@lg': {
|
||||||
|
width: '70%'
|
||||||
|
}
|
||||||
|
}}
|
||||||
options={destAccountOptions}
|
options={destAccountOptions}
|
||||||
value={selectedDestAccount}
|
value={selectedDestAccount}
|
||||||
isClearable
|
isClearable
|
||||||
@@ -229,9 +256,12 @@ export const TxUI: FC<UIProps> = ({ state: txState, setState, estimateFee }) =>
|
|||||||
row
|
row
|
||||||
fluid
|
fluid
|
||||||
css={{
|
css={{
|
||||||
justifyContent: 'flex-end',
|
justifyContent: 'space-between',
|
||||||
alignItems: 'center',
|
alignItems: 'center',
|
||||||
position: 'relative'
|
position: 'relative',
|
||||||
|
'@xl': {
|
||||||
|
justifyContent: 'flex-end'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<Text muted css={{ mr: '$3' }}>
|
<Text muted css={{ mr: '$3' }}>
|
||||||
@@ -244,9 +274,13 @@ export const TxUI: FC<UIProps> = ({ state: txState, setState, estimateFee }) =>
|
|||||||
spellCheck={false}
|
spellCheck={false}
|
||||||
onChange={switchToJson}
|
onChange={switchToJson}
|
||||||
css={{
|
css={{
|
||||||
width: '70%',
|
width: '60%',
|
||||||
|
minWidth: '200px',
|
||||||
flex: 'inherit',
|
flex: 'inherit',
|
||||||
resize: 'vertical'
|
resize: 'vertical',
|
||||||
|
'@lg': {
|
||||||
|
width: '70%'
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
) : (
|
) : (
|
||||||
@@ -271,7 +305,8 @@ export const TxUI: FC<UIProps> = ({ state: txState, setState, estimateFee }) =>
|
|||||||
: undefined
|
: undefined
|
||||||
}
|
}
|
||||||
css={{
|
css={{
|
||||||
width: '70%',
|
width: '60%',
|
||||||
|
minWidth: '200px',
|
||||||
flex: 'inherit',
|
flex: 'inherit',
|
||||||
'-moz-appearance': 'textfield',
|
'-moz-appearance': 'textfield',
|
||||||
'&::-webkit-outer-spin-button': {
|
'&::-webkit-outer-spin-button': {
|
||||||
@@ -281,6 +316,9 @@ export const TxUI: FC<UIProps> = ({ state: txState, setState, estimateFee }) =>
|
|||||||
'&::-webkit-inner-spin-button ': {
|
'&::-webkit-inner-spin-button ': {
|
||||||
'-webkit-appearance': 'none',
|
'-webkit-appearance': 'none',
|
||||||
margin: 0
|
margin: 0
|
||||||
|
},
|
||||||
|
'@lg': {
|
||||||
|
width: '70%'
|
||||||
}
|
}
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
|
|||||||
409
content/hook-set-codes.json
Normal file
409
content/hook-set-codes.json
Normal file
@@ -0,0 +1,409 @@
|
|||||||
|
[
|
||||||
|
{
|
||||||
|
"code": 1,
|
||||||
|
"identifier": "AMENDMENT_DISABLED",
|
||||||
|
"description": "attempt to HookSet when amendment is not yet enabled."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 2,
|
||||||
|
"identifier": "API_ILLEGAL",
|
||||||
|
"description": "HookSet object contained HookApiVersion for existing HookDefinition"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 3,
|
||||||
|
"identifier": "API_INVALID",
|
||||||
|
"description": "HookSet object contained HookApiVersion for unrecognised hook API "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 4,
|
||||||
|
"identifier": "API_MISSING",
|
||||||
|
"description": "HookSet object lacked HookApiVersion"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 5,
|
||||||
|
"identifier": "BLOCK_ILLEGAL",
|
||||||
|
"description": " a block end instruction moves execution below depth 0 {{}}`}` <= like this"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 6,
|
||||||
|
"identifier": "CALL_ILLEGAL",
|
||||||
|
"description": "wasm tries to call a non-whitelisted function"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 7,
|
||||||
|
"identifier": "CALL_INDIRECT",
|
||||||
|
"description": "wasm used call indirect instruction which is disallowed"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 8,
|
||||||
|
"identifier": "CREATE_FLAG",
|
||||||
|
"description": "create operation requires hsoOVERRIDE"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 9,
|
||||||
|
"identifier": "DELETE_FIELD",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 10,
|
||||||
|
"identifier": "DELETE_FLAG",
|
||||||
|
"description": "delete operation requires hsoOVERRIDE"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 11,
|
||||||
|
"identifier": "DELETE_NOTHING",
|
||||||
|
"description": "delete operation would delete nothing"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 12,
|
||||||
|
"identifier": "EXPORTS_MISSING",
|
||||||
|
"description": "hook did not export *any* functions (should be cbak, hook)"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 13,
|
||||||
|
"identifier": "EXPORT_CBAK_FUNC",
|
||||||
|
"description": "hook did not export correct func def int64_t cbak(uint32_t)"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 14,
|
||||||
|
"identifier": "EXPORT_HOOK_FUNC",
|
||||||
|
"description": "hook did not export correct func def int64_t hook(uint32_t)"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": 15,
|
||||||
|
"identifier": "EXPORT_MISSING",
|
||||||
|
"description": "distinct from export*S*_missing, either hook or cbak is missing"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "FLAGS_INVALID",
|
||||||
|
"code": 16,
|
||||||
|
"description": "HookSet flags were invalid for specified operation "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "FUNCS_MISSING",
|
||||||
|
"code": 17,
|
||||||
|
"description": "hook did not include function code for any functions "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "FUNC_PARAM_INVALID",
|
||||||
|
"code": 18,
|
||||||
|
"description": "parameter types may only be i32 i64 u32 u64 "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "FUNC_RETURN_COUNT",
|
||||||
|
"code": 19,
|
||||||
|
"description": "a function type is defined in the wasm which returns > 1 return value "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "FUNC_RETURN_INVALID",
|
||||||
|
"code": 20,
|
||||||
|
"description": "a function type does not return i32 i64 u32 or u64 "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "FUNC_TYPELESS",
|
||||||
|
"code": 21,
|
||||||
|
"description": "hook defined hook/cbak but their type is not defined in wasm "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "FUNC_TYPE_INVALID",
|
||||||
|
"code": 22,
|
||||||
|
"description": "malformed and illegal wasm in the func type section "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "GRANTS_EMPTY",
|
||||||
|
"code": 23,
|
||||||
|
"description": "HookSet object contained an empty grants array (you should remove it) "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "GRANTS_EXCESS",
|
||||||
|
"code": 24,
|
||||||
|
"description": "HookSet object cotnained a grants array with too many grants "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "GRANTS_FIELD",
|
||||||
|
"code": 25,
|
||||||
|
"description": "HookSet object contained a grant without Authorize or HookHash "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "GRANTS_ILLEGAL",
|
||||||
|
"code": 26,
|
||||||
|
"description": "Hookset object contained grants array which contained a non Grant object "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "GUARD_IMPORT",
|
||||||
|
"code": 27,
|
||||||
|
"description": "guard import is missing "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "GUARD_MISSING",
|
||||||
|
"code": 28,
|
||||||
|
"description": "guard call missing at top of loop "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "GUARD_PARAMETERS",
|
||||||
|
"code": 29,
|
||||||
|
"description": "guard called but did not use constant expressions for params "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HASH_OR_CODE",
|
||||||
|
"code": 30,
|
||||||
|
"description": "HookSet object can contain only one of CreateCode and HookHash "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOKON_MISSING",
|
||||||
|
"code": 31,
|
||||||
|
"description": "HookSet object did not contain HookOn but should have "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOKS_ARRAY_BAD",
|
||||||
|
"code": 32,
|
||||||
|
"description": "attempt to HookSet with a Hooks array containing a non-Hook obj "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOKS_ARRAY_BLANK",
|
||||||
|
"code": 33,
|
||||||
|
"description": "all hook set objs were blank "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOKS_ARRAY_EMPTY",
|
||||||
|
"code": 34,
|
||||||
|
"description": "attempt to HookSet with an empty Hooks array "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOKS_ARRAY_MISSING",
|
||||||
|
"code": 35,
|
||||||
|
"description": "attempt to HookSet without a Hooks array "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOKS_ARRAY_TOO_BIG",
|
||||||
|
"code": 36,
|
||||||
|
"description": "attempt to HookSet with a Hooks array beyond the chain size limit "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOK_ADD",
|
||||||
|
"code": 37,
|
||||||
|
"description": "Informational: adding ltHook to directory "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOK_DEF_MISSING",
|
||||||
|
"code": 38,
|
||||||
|
"description": "attempt to reference a hook definition (by hash) that is not on ledger "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOK_DELETE",
|
||||||
|
"code": 39,
|
||||||
|
"description": "unable to delete ltHook from owner "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOK_INVALID_FIELD",
|
||||||
|
"code": 40,
|
||||||
|
"description": "HookSetObj contained an illegal/unexpected field "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOK_PARAMS_COUNT",
|
||||||
|
"code": 41,
|
||||||
|
"description": "hookset obj would create too many hook parameters "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOK_PARAM_SIZE",
|
||||||
|
"code": 42,
|
||||||
|
"description": "hookset obj sets a parameter or value that exceeds max allowable size "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "IMPORTS_MISSING",
|
||||||
|
"code": 43,
|
||||||
|
"description": "hook must import guard, and accept/rollback "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "IMPORT_ILLEGAL",
|
||||||
|
"code": 44,
|
||||||
|
"description": "attempted import of a non-whitelisted function "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "IMPORT_MODULE_BAD",
|
||||||
|
"code": 45,
|
||||||
|
"description": "hook attempted to specify no or a bad import module "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "IMPORT_MODULE_ENV",
|
||||||
|
"code": 46,
|
||||||
|
"description": "hook attempted to specify import module not named env "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "IMPORT_NAME_BAD",
|
||||||
|
"code": 47,
|
||||||
|
"description": "import name was too short or too long "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "INSTALL_FLAG",
|
||||||
|
"code": 48,
|
||||||
|
"description": "install operation requires hsoOVERRIDE "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "INSTALL_MISSING",
|
||||||
|
"code": 49,
|
||||||
|
"description": "install operation specifies hookhash which doesn't exist on the ledger "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "INSTRUCTION_COUNT",
|
||||||
|
"code": 50,
|
||||||
|
"description": "worst case execution instruction count as computed by HookSet "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "INSTRUCTION_EXCESS",
|
||||||
|
"code": 51,
|
||||||
|
"description": "worst case execution instruction count was too large "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "MEMORY_GROW",
|
||||||
|
"code": 52,
|
||||||
|
"description": "memory.grow instruction is present but disallowed "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NAMESPACE_MISSING",
|
||||||
|
"code": 53,
|
||||||
|
"description": "HookSet object lacked HookNamespace "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NSDELETE",
|
||||||
|
"code": 54,
|
||||||
|
"description": "Informational: a namespace is being deleted "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NSDELETE_ACCOUNT",
|
||||||
|
"code": 55,
|
||||||
|
"description": "nsdelete tried to delete ns from a non-existing account "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NSDELETE_COUNT",
|
||||||
|
"code": 56,
|
||||||
|
"description": "namespace state count less than 0 / overflow "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NSDELETE_DIR",
|
||||||
|
"code": 57,
|
||||||
|
"description": "could not delete directory node in ledger "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NSDELETE_DIRECTORY",
|
||||||
|
"code": 58,
|
||||||
|
"description": "nsdelete operation failed to delete ns directory "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NSDELETE_DIR_ENTRY",
|
||||||
|
"code": 59,
|
||||||
|
"description": "nsdelete operation failed due to bad entry in ns directory "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NSDELETE_ENTRY",
|
||||||
|
"code": 60,
|
||||||
|
"description": "nsdelete operation failed due to missing hook state entry "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NSDELETE_FIELD",
|
||||||
|
"code": 61
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NSDELETE_FLAGS",
|
||||||
|
"code": 62
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NSDELETE_NONSTATE",
|
||||||
|
"code": 63,
|
||||||
|
"description": "nsdelete operation failed due to the presence of a non-hookstate obj "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "NSDELETE_NOTHING",
|
||||||
|
"code": 64,
|
||||||
|
"description": "hsfNSDELETE provided but nothing to delete "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "OPERATION_INVALID",
|
||||||
|
"code": 65,
|
||||||
|
"description": "could not deduce an operation from the provided hookset obj "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "OVERRIDE_MISSING",
|
||||||
|
"code": 66,
|
||||||
|
"description": "HookSet object was trying to update or delete a hook but lacked hsfOVERRIDE "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "PARAMETERS_FIELD",
|
||||||
|
"code": 67,
|
||||||
|
"description": "HookParameters contained a HookParameter with an invalid key in it "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "PARAMETERS_ILLEGAL",
|
||||||
|
"code": 68,
|
||||||
|
"description": "HookParameters contained something other than a HookParameter "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "PARAMETERS_NAME",
|
||||||
|
"code": 69,
|
||||||
|
"description": "HookParameters contained a HookParameter which lacked ParameterName field "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "PARAM_HOOK_CBAK",
|
||||||
|
"code": 70,
|
||||||
|
"description": "hook and cbak must take exactly one u32 parameter "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "RETURN_HOOK_CBAK",
|
||||||
|
"code": 71,
|
||||||
|
"description": "hook and cbak must retunr i64 "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "SHORT_HOOK",
|
||||||
|
"code": 72,
|
||||||
|
"description": "web assembly byte code ended abruptly "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "TYPE_INVALID",
|
||||||
|
"code": 73,
|
||||||
|
"description": "malformed and illegal wasm specifying an illegal local var type "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "WASM_BAD_MAGIC",
|
||||||
|
"code": 74,
|
||||||
|
"description": "wasm magic number missing or not wasm "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "WASM_INVALID",
|
||||||
|
"code": 75,
|
||||||
|
"description": "set hook operation would set invalid wasm "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "WASM_PARSE_LOOP",
|
||||||
|
"code": 76,
|
||||||
|
"description": "wasm section parsing resulted in an infinite loop "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "WASM_SMOKE_TEST",
|
||||||
|
"code": 77,
|
||||||
|
"description": "Informational: first attempt to load wasm into wasm runtime "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "WASM_TEST_FAILURE",
|
||||||
|
"code": 78,
|
||||||
|
"description": "the smoke test failed "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "WASM_TOO_BIG",
|
||||||
|
"code": 79,
|
||||||
|
"description": "set hook would exceed maximum hook size "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "WASM_TOO_SMALL",
|
||||||
|
"code": 80
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "WASM_VALIDATION",
|
||||||
|
"code": 81,
|
||||||
|
"description": "a generic error while parsing wasm, usually leb128 overflow"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"identifier": "HOOK_CBAK_DIFF_TYPES",
|
||||||
|
"code": 82,
|
||||||
|
"description": "hook and cbak function definitions were different"
|
||||||
|
}
|
||||||
|
]
|
||||||
@@ -68,6 +68,7 @@ const Test = () => {
|
|||||||
justifyContent: 'center',
|
justifyContent: 'center',
|
||||||
p: '$3 $2'
|
p: '$3 $2'
|
||||||
}}
|
}}
|
||||||
|
className="split-mobile-forceAutoHeight"
|
||||||
>
|
>
|
||||||
<Split
|
<Split
|
||||||
direction="horizontal"
|
direction="horizontal"
|
||||||
@@ -82,6 +83,7 @@ const Test = () => {
|
|||||||
height: '100%'
|
height: '100%'
|
||||||
}}
|
}}
|
||||||
onDragEnd={e => saveSplit('testHorizontal', e)}
|
onDragEnd={e => saveSplit('testHorizontal', e)}
|
||||||
|
className="split-mobile-forceVertical"
|
||||||
>
|
>
|
||||||
<Box css={{ width: '55%', px: '$2' }}>
|
<Box css={{ width: '55%', px: '$2' }}>
|
||||||
<Tabs
|
<Tabs
|
||||||
@@ -105,7 +107,18 @@ const Test = () => {
|
|||||||
))}
|
))}
|
||||||
</Tabs>
|
</Tabs>
|
||||||
</Box>
|
</Box>
|
||||||
<Box css={{ width: '45%', mx: '$2', height: '100%' }}>
|
<Box
|
||||||
|
css={{
|
||||||
|
width: '45%',
|
||||||
|
mx: '$0',
|
||||||
|
mt: '$1',
|
||||||
|
height: '100%',
|
||||||
|
'@md': {
|
||||||
|
mx: '$2',
|
||||||
|
mt: '$0'
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
>
|
||||||
<Accounts card hideDeployBtn showHookStats />
|
<Accounts card hideDeployBtn showHookStats />
|
||||||
</Box>
|
</Box>
|
||||||
</Split>
|
</Split>
|
||||||
@@ -131,6 +144,7 @@ const Test = () => {
|
|||||||
<Flex>
|
<Flex>
|
||||||
<Split
|
<Split
|
||||||
direction="horizontal"
|
direction="horizontal"
|
||||||
|
className="split-mobile-forceVertical"
|
||||||
sizes={[50, 50]}
|
sizes={[50, 50]}
|
||||||
minSize={[320, 160]}
|
minSize={[320, 160]}
|
||||||
gutterSize={4}
|
gutterSize={4}
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ import { Link } from '../../components'
|
|||||||
import { ref } from 'valtio'
|
import { ref } from 'valtio'
|
||||||
import estimateFee from '../../utils/estimateFee'
|
import estimateFee from '../../utils/estimateFee'
|
||||||
import { SetHookData } from '../../utils/setHook'
|
import { SetHookData } from '../../utils/setHook'
|
||||||
|
import ResultLink from '../../components/ResultLink'
|
||||||
|
|
||||||
export const sha256 = async (string: string) => {
|
export const sha256 = async (string: string) => {
|
||||||
const utf8 = new TextEncoder().encode(string)
|
const utf8 = new TextEncoder().encode(string)
|
||||||
@@ -144,6 +145,25 @@ export const deployHook = async (account: IAccount & { name?: string }, data: Se
|
|||||||
tx_blob: signedTransaction
|
tx_blob: signedTransaction
|
||||||
})
|
})
|
||||||
|
|
||||||
|
const txHash = submitRes.tx_json?.hash
|
||||||
|
const resultMsg = ref(
|
||||||
|
<>
|
||||||
|
[<ResultLink result={submitRes.engine_result} />] {submitRes.engine_result_message}{' '}
|
||||||
|
{txHash && (
|
||||||
|
<>
|
||||||
|
Transaction hash:{' '}
|
||||||
|
<Link
|
||||||
|
as="a"
|
||||||
|
href={`https://${process.env.NEXT_PUBLIC_EXPLORER_URL}/${txHash}`}
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
>
|
||||||
|
{txHash}
|
||||||
|
</Link>
|
||||||
|
</>
|
||||||
|
)}
|
||||||
|
</>
|
||||||
|
)
|
||||||
if (submitRes.engine_result === 'tesSUCCESS') {
|
if (submitRes.engine_result === 'tesSUCCESS') {
|
||||||
state.deployLogs.push({
|
state.deployLogs.push({
|
||||||
type: 'success',
|
type: 'success',
|
||||||
@@ -151,27 +171,17 @@ export const deployHook = async (account: IAccount & { name?: string }, data: Se
|
|||||||
})
|
})
|
||||||
state.deployLogs.push({
|
state.deployLogs.push({
|
||||||
type: 'success',
|
type: 'success',
|
||||||
message: ref(
|
message: resultMsg
|
||||||
<>
|
})
|
||||||
[{submitRes.engine_result}] {submitRes.engine_result_message} Transaction hash:{' '}
|
} else if (submitRes.engine_result) {
|
||||||
<Link
|
state.deployLogs.push({
|
||||||
as="a"
|
type: 'error',
|
||||||
href={`https://${process.env.NEXT_PUBLIC_EXPLORER_URL}/${submitRes.tx_json?.hash}`}
|
message: resultMsg
|
||||||
target="_blank"
|
|
||||||
rel="noopener noreferrer"
|
|
||||||
>
|
|
||||||
{submitRes.tx_json?.hash}
|
|
||||||
</Link>
|
|
||||||
</>
|
|
||||||
)
|
|
||||||
// message: `[${submitRes.engine_result}] ${submitRes.engine_result_message} Validated ledger index: ${submitRes.validated_ledger_index}`,
|
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
state.deployLogs.push({
|
state.deployLogs.push({
|
||||||
type: 'error',
|
type: 'error',
|
||||||
message: `[${submitRes.engine_result || submitRes.error}] ${
|
message: `[${submitRes.error}] ${submitRes.error_exception}`
|
||||||
submitRes.engine_result_message || submitRes.error_exception
|
|
||||||
}`
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
|
|||||||
77
state/actions/sendTransaction.tsx
Normal file
77
state/actions/sendTransaction.tsx
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
import { derive, sign } from 'xrpl-accountlib'
|
||||||
|
|
||||||
|
import state from '..'
|
||||||
|
import type { IAccount } from '..'
|
||||||
|
import ResultLink from '../../components/ResultLink'
|
||||||
|
import { ref } from 'valtio'
|
||||||
|
|
||||||
|
interface TransactionOptions {
|
||||||
|
TransactionType: string
|
||||||
|
Account?: string
|
||||||
|
Fee?: string
|
||||||
|
Destination?: string
|
||||||
|
[index: string]: any
|
||||||
|
}
|
||||||
|
interface OtherOptions {
|
||||||
|
logPrefix?: string
|
||||||
|
}
|
||||||
|
|
||||||
|
export const sendTransaction = async (
|
||||||
|
account: IAccount,
|
||||||
|
txOptions: TransactionOptions,
|
||||||
|
options?: OtherOptions
|
||||||
|
) => {
|
||||||
|
if (!state.client) throw Error('XRPL client not initalized')
|
||||||
|
|
||||||
|
const { Fee = '1000', ...opts } = txOptions
|
||||||
|
const tx: TransactionOptions = {
|
||||||
|
Account: account.address,
|
||||||
|
Sequence: account.sequence,
|
||||||
|
Fee, // TODO auto-fillable default
|
||||||
|
...opts
|
||||||
|
}
|
||||||
|
const { logPrefix = '' } = options || {}
|
||||||
|
try {
|
||||||
|
const signedAccount = derive.familySeed(account.secret)
|
||||||
|
const { signedTransaction } = sign(tx, signedAccount)
|
||||||
|
const response = await state.client.send({
|
||||||
|
command: 'submit',
|
||||||
|
tx_blob: signedTransaction
|
||||||
|
})
|
||||||
|
|
||||||
|
const resultMsg = ref(
|
||||||
|
<>
|
||||||
|
{logPrefix}[<ResultLink result={response.engine_result} />] {response.engine_result_message}
|
||||||
|
</>
|
||||||
|
)
|
||||||
|
if (response.engine_result === 'tesSUCCESS') {
|
||||||
|
state.transactionLogs.push({
|
||||||
|
type: 'success',
|
||||||
|
message: resultMsg
|
||||||
|
})
|
||||||
|
} else if (response.engine_result) {
|
||||||
|
state.transactionLogs.push({
|
||||||
|
type: 'error',
|
||||||
|
message: resultMsg
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
state.transactionLogs.push({
|
||||||
|
type: 'error',
|
||||||
|
message: `${logPrefix}[${response.error}] ${response.error_exception}`
|
||||||
|
})
|
||||||
|
}
|
||||||
|
const currAcc = state.accounts.find(acc => acc.address === account.address)
|
||||||
|
if (currAcc && response.account_sequence_next) {
|
||||||
|
currAcc.sequence = response.account_sequence_next
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
console.error(err)
|
||||||
|
state.transactionLogs.push({
|
||||||
|
type: 'error',
|
||||||
|
message:
|
||||||
|
err instanceof Error
|
||||||
|
? `${logPrefix}Error: ${err.message}`
|
||||||
|
: `${logPrefix}Something went wrong, try again later`
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -54,3 +54,15 @@ html.light .gutter-horizontal:hover {
|
|||||||
.monaco-editor .monaco-hover {
|
.monaco-editor .monaco-hover {
|
||||||
z-index: 9999;
|
z-index: 9999;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@media screen and (max-width: 48rem) {
|
||||||
|
.split-mobile-forceAutoHeight {
|
||||||
|
height: auto !important;
|
||||||
|
}
|
||||||
|
.split-mobile-forceVertical {
|
||||||
|
flex-direction: column !important;
|
||||||
|
}
|
||||||
|
.split-mobile-forceVertical > div {
|
||||||
|
width: 100% !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user