@xyo-network/react-payload-raw-info 2.70.5 → 2.71.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,4 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import { JsonViewerProps } from '@textea/json-viewer';
3
- export declare const JsonViewerEx: React.FC<JsonViewerProps>;
3
+ export type JsonViewerExProps = JsonViewerProps;
4
+ export declare const JsonViewerEx: React.FC<JsonViewerExProps>;
4
5
  //# sourceMappingURL=JsonViewerEx.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAgBlD,CAAA"}
1
+ {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,MAAM,MAAM,iBAAiB,GAAG,eAAe,CAAA;AAE/C,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAgBpD,CAAA"}
@@ -1,4 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import { JsonViewerProps } from '@textea/json-viewer';
3
- export declare const JsonViewerEx: React.FC<JsonViewerProps>;
3
+ export type JsonViewerExProps = JsonViewerProps;
4
+ export declare const JsonViewerEx: React.FC<JsonViewerExProps>;
4
5
  //# sourceMappingURL=JsonViewerEx.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAgBlD,CAAA"}
1
+ {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,MAAM,MAAM,iBAAiB,GAAG,eAAe,CAAA;AAE/C,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAgBpD,CAAA"}
@@ -1,4 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import { JsonViewerProps } from '@textea/json-viewer';
3
- export declare const JsonViewerEx: React.FC<JsonViewerProps>;
3
+ export type JsonViewerExProps = JsonViewerProps;
4
+ export declare const JsonViewerEx: React.FC<JsonViewerExProps>;
4
5
  //# sourceMappingURL=JsonViewerEx.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAgBlD,CAAA"}
1
+ {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,MAAM,MAAM,iBAAiB,GAAG,eAAe,CAAA;AAE/C,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAgBpD,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/components/Button/RawInfoButton.tsx","../../src/components/img/index.ts","../../src/components/shared/Dialog/JsonViewerCollapse.tsx","../../src/components/styled/StyledChipLabel.tsx","../../src/components/shared/JsonViewerEx.tsx","../../src/components/shared/Dialog/RawInfoDialog.tsx","../../src/components/Button/lib/presetIconSize.ts","../../src/components/Button/RawInfoIconButton.tsx"],"sourcesContent":["export * from './components'\n","import { toJson } from '@xylabs/object'\nimport { ButtonEx, ButtonExProps } from '@xylabs/react-button'\nimport { MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoButtonProps extends ButtonExProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoButton: React.FC<RawInfoButtonProps> = ({\n defaultExpandedJson = true,\n dialogContent,\n iconOnly,\n iconSize = 24,\n onCloseCallback,\n children,\n rawValue,\n presetIconSize,\n updateExpandedJson,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <span>\n <ButtonEx\n variant=\"outlined\"\n size=\"small\"\n startIcon={<img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />}\n onClick={handleClick}\n disabled={iconOnly ? false : !rawValue}\n {...props}\n >\n {children ?? <span>Data</span>}\n </ButtonEx>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </span>\n )\n}\n","export { default as xyoColorLogo } from './xyo-color-logo.svg'\n","import { Button, Chip, Collapse, CollapseProps, Typography } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { usePromise } from '@xylabs/react-promise'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { useDataState } from '@xyo-network/react-shared'\n\nimport { ExpansionProps } from '../../../lib'\nimport { StyledChipLabel } from '../../styled'\nimport { JsonViewerEx } from '../JsonViewerEx'\n\nexport interface RawInfoPayloadCollapse extends CollapseProps, ExpansionProps {\n jsonValue?: JsonValue\n}\n\nexport const JsonViewerCollapse: React.FC<RawInfoPayloadCollapse> = ({ defaultExpandedJson, jsonValue, updateExpandedJson, ...props }) => {\n const [expandedJson, setExpandedJson] = useDataState(defaultExpandedJson)\n\n const [hash] = usePromise(async () => {\n if (!jsonValue || !isAnyPayload(jsonValue)) return\n return await PayloadBuilder.dataHash(jsonValue)\n }, [jsonValue])\n\n const actionText = expandedJson ? 'Hide JSON' : 'Show JSON'\n\n const handleExpansion = () => {\n updateExpandedJson?.(!expandedJson)\n setExpandedJson(!expandedJson)\n }\n\n return (\n <>\n {jsonValue ?\n <FlexRow>\n <Button onClick={handleExpansion} size=\"small\" variant=\"outlined\">\n {actionText}\n </Button>\n </FlexRow>\n : null}\n <Collapse in={expandedJson} {...props}>\n {jsonValue ?\n <FlexCol alignItems=\"stretch\" gap={1.5}>\n <Typography sx={{ lineHeight: 1 }}>Payload Hash:</Typography>\n {hash ?\n <Chip label={<StyledChipLabel>{hash}</StyledChipLabel>} sx={{ alignSelf: 'start' }} />\n : null}\n <JsonViewerEx value={jsonValue} />\n </FlexCol>\n : null}\n </Collapse>\n </>\n )\n}\n","import { styled, Typography } from '@mui/material'\n\nexport const StyledChipLabel = styled(Typography, { name: 'StyledChipLabel' })(({ theme }) => ({\n display: 'block',\n lineHeight: 1,\n overflow: 'hidden',\n paddingRight: theme.spacing(0.95),\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n}))\n","import { useTheme } from '@mui/material'\nimport { JsonViewer, JsonViewerProps } from '@textea/json-viewer'\nimport { useColorSchemeEx } from '@xylabs/react-invertible-theme'\n\nexport const JsonViewerEx: React.FC<JsonViewerProps> = (props) => {\n const theme = useTheme()\n const { darkMode } = useColorSchemeEx()\n\n return (\n <JsonViewer\n theme={darkMode ? 'dark' : 'light'}\n collapseStringsAfterLength={50}\n style={{\n background: darkMode ? theme.palette.background.paper : theme.palette.grey[200],\n borderRadius: theme.shape.borderRadius,\n padding: theme.spacing(2),\n }}\n {...props}\n />\n )\n}\n","import { Button, Dialog, DialogActions, DialogContent, DialogProps, DialogTitle } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { MouseEventHandler, ReactNode } from 'react'\n\nimport { ExpansionProps } from '../../../lib'\nimport { JsonViewerCollapse } from './JsonViewerCollapse'\n\nexport interface RawInfoDialogProps extends DialogProps, ExpansionProps {\n dialogContent?: ReactNode\n jsonValue?: JsonValue\n onCloseCallback?: () => void\n}\n\nexport const RawInfoDialog: React.FC<RawInfoDialogProps> = ({\n defaultExpandedJson,\n dialogContent,\n onCloseCallback,\n jsonValue: jsonObject,\n updateExpandedJson,\n open = false,\n ...props\n}) => {\n const onDialogClick: MouseEventHandler<HTMLSpanElement> = (event) => {\n event.stopPropagation()\n }\n\n return (\n // Wrapping in a span so we can catch click events and prevent them from propagating outside the component\n <span onClick={onDialogClick}>\n <Dialog fullWidth maxWidth=\"lg\" onClose={() => onCloseCallback?.()} open={open} {...props}>\n <DialogTitle>Raw Data</DialogTitle>\n <DialogContent sx={{ display: 'flex', flexDirection: 'column', gap: 2 }}>\n {dialogContent}\n <JsonViewerCollapse defaultExpandedJson={defaultExpandedJson} jsonValue={jsonObject} updateExpandedJson={updateExpandedJson} />\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" onClick={() => onCloseCallback?.()}>\n Close\n </Button>\n </DialogActions>\n </Dialog>\n </span>\n )\n}\n","import { IconSize } from './IconSize'\n\nexport const presetIconSizeValue = (size?: IconSize) => {\n switch (size) {\n case 'small': {\n return 16\n }\n case 'medium': {\n return 32\n }\n case 'large': {\n return 48\n }\n }\n}\n","import { IconButton, IconButtonProps } from '@mui/material'\nimport { toJson } from '@xylabs/object'\nimport { forwardRef, MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoIconProps extends IconButtonProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoIconButton = forwardRef<HTMLButtonElement, RawInfoIconProps>(\n (\n { defaultExpandedJson = true, dialogContent, iconOnly, iconSize = 32, onCloseCallback, rawValue, presetIconSize, updateExpandedJson, ...props },\n ref,\n ) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <>\n <IconButton onClick={handleClick} ref={ref} {...props}>\n <img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />\n </IconButton>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </>\n )\n },\n)\n\nRawInfoIconButton.displayName = 'RawInfoIcon'\n"],"mappings":"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","names":["import_material","import_material","import_jsx_runtime","import_material","import_jsx_runtime","import_jsx_runtime","import_material","import_object","import_react","import_jsx_runtime"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/components/Button/RawInfoButton.tsx","../../src/components/img/index.ts","../../src/components/shared/Dialog/JsonViewerCollapse.tsx","../../src/components/styled/StyledChipLabel.tsx","../../src/components/shared/JsonViewerEx.tsx","../../src/components/shared/Dialog/RawInfoDialog.tsx","../../src/components/Button/lib/presetIconSize.ts","../../src/components/Button/RawInfoIconButton.tsx"],"sourcesContent":["export * from './components'\n","import { toJson } from '@xylabs/object'\nimport { ButtonEx, ButtonExProps } from '@xylabs/react-button'\nimport { MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoButtonProps extends ButtonExProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoButton: React.FC<RawInfoButtonProps> = ({\n defaultExpandedJson = true,\n dialogContent,\n iconOnly,\n iconSize = 24,\n onCloseCallback,\n children,\n rawValue,\n presetIconSize,\n updateExpandedJson,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <span>\n <ButtonEx\n variant=\"outlined\"\n size=\"small\"\n startIcon={<img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />}\n onClick={handleClick}\n disabled={iconOnly ? false : !rawValue}\n {...props}\n >\n {children ?? <span>Data</span>}\n </ButtonEx>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </span>\n )\n}\n","export { default as xyoColorLogo } from './xyo-color-logo.svg'\n","import { Button, Chip, Collapse, CollapseProps, Typography } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { usePromise } from '@xylabs/react-promise'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { useDataState } from '@xyo-network/react-shared'\n\nimport { ExpansionProps } from '../../../lib'\nimport { StyledChipLabel } from '../../styled'\nimport { JsonViewerEx } from '../JsonViewerEx'\n\nexport interface RawInfoPayloadCollapse extends CollapseProps, ExpansionProps {\n jsonValue?: JsonValue\n}\n\nexport const JsonViewerCollapse: React.FC<RawInfoPayloadCollapse> = ({ defaultExpandedJson, jsonValue, updateExpandedJson, ...props }) => {\n const [expandedJson, setExpandedJson] = useDataState(defaultExpandedJson)\n\n const [hash] = usePromise(async () => {\n if (!jsonValue || !isAnyPayload(jsonValue)) return\n return await PayloadBuilder.dataHash(jsonValue)\n }, [jsonValue])\n\n const actionText = expandedJson ? 'Hide JSON' : 'Show JSON'\n\n const handleExpansion = () => {\n updateExpandedJson?.(!expandedJson)\n setExpandedJson(!expandedJson)\n }\n\n return (\n <>\n {jsonValue ?\n <FlexRow>\n <Button onClick={handleExpansion} size=\"small\" variant=\"outlined\">\n {actionText}\n </Button>\n </FlexRow>\n : null}\n <Collapse in={expandedJson} {...props}>\n {jsonValue ?\n <FlexCol alignItems=\"stretch\" gap={1.5}>\n <Typography sx={{ lineHeight: 1 }}>Payload Hash:</Typography>\n {hash ?\n <Chip label={<StyledChipLabel>{hash}</StyledChipLabel>} sx={{ alignSelf: 'start' }} />\n : null}\n <JsonViewerEx value={jsonValue} />\n </FlexCol>\n : null}\n </Collapse>\n </>\n )\n}\n","import { styled, Typography } from '@mui/material'\n\nexport const StyledChipLabel = styled(Typography, { name: 'StyledChipLabel' })(({ theme }) => ({\n display: 'block',\n lineHeight: 1,\n overflow: 'hidden',\n paddingRight: theme.spacing(0.95),\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n}))\n","import { useTheme } from '@mui/material'\nimport { JsonViewer, JsonViewerProps } from '@textea/json-viewer'\nimport { useColorSchemeEx } from '@xylabs/react-invertible-theme'\n\nexport type JsonViewerExProps = JsonViewerProps\n\nexport const JsonViewerEx: React.FC<JsonViewerExProps> = (props) => {\n const theme = useTheme()\n const { darkMode } = useColorSchemeEx()\n\n return (\n <JsonViewer\n theme={darkMode ? 'dark' : 'light'}\n collapseStringsAfterLength={50}\n style={{\n background: darkMode ? theme.palette.background.paper : theme.palette.grey[200],\n borderRadius: theme.shape.borderRadius,\n padding: theme.spacing(2),\n }}\n {...props}\n />\n )\n}\n","import { Button, Dialog, DialogActions, DialogContent, DialogProps, DialogTitle } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { MouseEventHandler, ReactNode } from 'react'\n\nimport { ExpansionProps } from '../../../lib'\nimport { JsonViewerCollapse } from './JsonViewerCollapse'\n\nexport interface RawInfoDialogProps extends DialogProps, ExpansionProps {\n dialogContent?: ReactNode\n jsonValue?: JsonValue\n onCloseCallback?: () => void\n}\n\nexport const RawInfoDialog: React.FC<RawInfoDialogProps> = ({\n defaultExpandedJson,\n dialogContent,\n onCloseCallback,\n jsonValue: jsonObject,\n updateExpandedJson,\n open = false,\n ...props\n}) => {\n const onDialogClick: MouseEventHandler<HTMLSpanElement> = (event) => {\n event.stopPropagation()\n }\n\n return (\n // Wrapping in a span so we can catch click events and prevent them from propagating outside the component\n <span onClick={onDialogClick}>\n <Dialog fullWidth maxWidth=\"lg\" onClose={() => onCloseCallback?.()} open={open} {...props}>\n <DialogTitle>Raw Data</DialogTitle>\n <DialogContent sx={{ display: 'flex', flexDirection: 'column', gap: 2 }}>\n {dialogContent}\n <JsonViewerCollapse defaultExpandedJson={defaultExpandedJson} jsonValue={jsonObject} updateExpandedJson={updateExpandedJson} />\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" onClick={() => onCloseCallback?.()}>\n Close\n </Button>\n </DialogActions>\n </Dialog>\n </span>\n )\n}\n","import { IconSize } from './IconSize'\n\nexport const presetIconSizeValue = (size?: IconSize) => {\n switch (size) {\n case 'small': {\n return 16\n }\n case 'medium': {\n return 32\n }\n case 'large': {\n return 48\n }\n }\n}\n","import { IconButton, IconButtonProps } from '@mui/material'\nimport { toJson } from '@xylabs/object'\nimport { forwardRef, MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoIconProps extends IconButtonProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoIconButton = forwardRef<HTMLButtonElement, RawInfoIconProps>(\n (\n { defaultExpandedJson = true, dialogContent, iconOnly, iconSize = 32, onCloseCallback, rawValue, presetIconSize, updateExpandedJson, ...props },\n ref,\n ) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <>\n <IconButton onClick={handleClick} ref={ref} {...props}>\n <img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />\n </IconButton>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </>\n )\n },\n)\n\nRawInfoIconButton.displayName = 'RawInfoIcon'\n"],"mappings":"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","names":["import_material","import_material","import_jsx_runtime","import_material","import_jsx_runtime","import_jsx_runtime","import_material","import_object","import_react","import_jsx_runtime"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/components/Button/RawInfoButton.tsx","../../src/components/img/index.ts","../../src/components/shared/Dialog/JsonViewerCollapse.tsx","../../src/components/styled/StyledChipLabel.tsx","../../src/components/shared/JsonViewerEx.tsx","../../src/components/shared/Dialog/RawInfoDialog.tsx","../../src/components/Button/lib/presetIconSize.ts","../../src/components/Button/RawInfoIconButton.tsx"],"sourcesContent":["import { toJson } from '@xylabs/object'\nimport { ButtonEx, ButtonExProps } from '@xylabs/react-button'\nimport { MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoButtonProps extends ButtonExProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoButton: React.FC<RawInfoButtonProps> = ({\n defaultExpandedJson = true,\n dialogContent,\n iconOnly,\n iconSize = 24,\n onCloseCallback,\n children,\n rawValue,\n presetIconSize,\n updateExpandedJson,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <span>\n <ButtonEx\n variant=\"outlined\"\n size=\"small\"\n startIcon={<img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />}\n onClick={handleClick}\n disabled={iconOnly ? false : !rawValue}\n {...props}\n >\n {children ?? <span>Data</span>}\n </ButtonEx>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </span>\n )\n}\n","export { default as xyoColorLogo } from './xyo-color-logo.svg'\n","import { Button, Chip, Collapse, CollapseProps, Typography } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { usePromise } from '@xylabs/react-promise'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { useDataState } from '@xyo-network/react-shared'\n\nimport { ExpansionProps } from '../../../lib'\nimport { StyledChipLabel } from '../../styled'\nimport { JsonViewerEx } from '../JsonViewerEx'\n\nexport interface RawInfoPayloadCollapse extends CollapseProps, ExpansionProps {\n jsonValue?: JsonValue\n}\n\nexport const JsonViewerCollapse: React.FC<RawInfoPayloadCollapse> = ({ defaultExpandedJson, jsonValue, updateExpandedJson, ...props }) => {\n const [expandedJson, setExpandedJson] = useDataState(defaultExpandedJson)\n\n const [hash] = usePromise(async () => {\n if (!jsonValue || !isAnyPayload(jsonValue)) return\n return await PayloadBuilder.dataHash(jsonValue)\n }, [jsonValue])\n\n const actionText = expandedJson ? 'Hide JSON' : 'Show JSON'\n\n const handleExpansion = () => {\n updateExpandedJson?.(!expandedJson)\n setExpandedJson(!expandedJson)\n }\n\n return (\n <>\n {jsonValue ?\n <FlexRow>\n <Button onClick={handleExpansion} size=\"small\" variant=\"outlined\">\n {actionText}\n </Button>\n </FlexRow>\n : null}\n <Collapse in={expandedJson} {...props}>\n {jsonValue ?\n <FlexCol alignItems=\"stretch\" gap={1.5}>\n <Typography sx={{ lineHeight: 1 }}>Payload Hash:</Typography>\n {hash ?\n <Chip label={<StyledChipLabel>{hash}</StyledChipLabel>} sx={{ alignSelf: 'start' }} />\n : null}\n <JsonViewerEx value={jsonValue} />\n </FlexCol>\n : null}\n </Collapse>\n </>\n )\n}\n","import { styled, Typography } from '@mui/material'\n\nexport const StyledChipLabel = styled(Typography, { name: 'StyledChipLabel' })(({ theme }) => ({\n display: 'block',\n lineHeight: 1,\n overflow: 'hidden',\n paddingRight: theme.spacing(0.95),\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n}))\n","import { useTheme } from '@mui/material'\nimport { JsonViewer, JsonViewerProps } from '@textea/json-viewer'\nimport { useColorSchemeEx } from '@xylabs/react-invertible-theme'\n\nexport const JsonViewerEx: React.FC<JsonViewerProps> = (props) => {\n const theme = useTheme()\n const { darkMode } = useColorSchemeEx()\n\n return (\n <JsonViewer\n theme={darkMode ? 'dark' : 'light'}\n collapseStringsAfterLength={50}\n style={{\n background: darkMode ? theme.palette.background.paper : theme.palette.grey[200],\n borderRadius: theme.shape.borderRadius,\n padding: theme.spacing(2),\n }}\n {...props}\n />\n )\n}\n","import { Button, Dialog, DialogActions, DialogContent, DialogProps, DialogTitle } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { MouseEventHandler, ReactNode } from 'react'\n\nimport { ExpansionProps } from '../../../lib'\nimport { JsonViewerCollapse } from './JsonViewerCollapse'\n\nexport interface RawInfoDialogProps extends DialogProps, ExpansionProps {\n dialogContent?: ReactNode\n jsonValue?: JsonValue\n onCloseCallback?: () => void\n}\n\nexport const RawInfoDialog: React.FC<RawInfoDialogProps> = ({\n defaultExpandedJson,\n dialogContent,\n onCloseCallback,\n jsonValue: jsonObject,\n updateExpandedJson,\n open = false,\n ...props\n}) => {\n const onDialogClick: MouseEventHandler<HTMLSpanElement> = (event) => {\n event.stopPropagation()\n }\n\n return (\n // Wrapping in a span so we can catch click events and prevent them from propagating outside the component\n <span onClick={onDialogClick}>\n <Dialog fullWidth maxWidth=\"lg\" onClose={() => onCloseCallback?.()} open={open} {...props}>\n <DialogTitle>Raw Data</DialogTitle>\n <DialogContent sx={{ display: 'flex', flexDirection: 'column', gap: 2 }}>\n {dialogContent}\n <JsonViewerCollapse defaultExpandedJson={defaultExpandedJson} jsonValue={jsonObject} updateExpandedJson={updateExpandedJson} />\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" onClick={() => onCloseCallback?.()}>\n Close\n </Button>\n </DialogActions>\n </Dialog>\n </span>\n )\n}\n","import { IconSize } from './IconSize'\n\nexport const presetIconSizeValue = (size?: IconSize) => {\n switch (size) {\n case 'small': {\n return 16\n }\n case 'medium': {\n return 32\n }\n case 'large': {\n return 48\n }\n }\n}\n","import { IconButton, IconButtonProps } from '@mui/material'\nimport { toJson } from '@xylabs/object'\nimport { forwardRef, MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoIconProps extends IconButtonProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoIconButton = forwardRef<HTMLButtonElement, RawInfoIconProps>(\n (\n { defaultExpandedJson = true, dialogContent, iconOnly, iconSize = 32, onCloseCallback, rawValue, presetIconSize, updateExpandedJson, ...props },\n ref,\n ) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <>\n <IconButton onClick={handleClick} ref={ref} {...props}>\n <img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />\n </IconButton>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </>\n )\n },\n)\n\nRawInfoIconButton.displayName = 'RawInfoIcon'\n"],"mappings":";AAAA,SAAS,cAAc;AACvB,SAAS,gBAA+B;AACxC,SAAuC,SAAS,gBAAgB;;;ACFhE,SAAoB,WAAXA,gBAA+B;;;ACAxC,SAAS,QAAQ,MAAM,UAAyB,cAAAC,mBAAkB;AAElE,SAAS,SAAS,eAAe;AACjC,SAAS,kBAAkB;AAC3B,SAAS,sBAAsB;AAC/B,SAAS,oBAAoB;AAC7B,SAAS,oBAAoB;;;ACN7B,SAAS,QAAQ,kBAAkB;AAE5B,IAAM,kBAAkB,OAAO,YAAY,EAAE,MAAM,kBAAkB,CAAC,EAAE,CAAC,EAAE,MAAM,OAAO;AAAA,EAC7F,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,UAAU;AAAA,EACV,cAAc,MAAM,QAAQ,IAAI;AAAA,EAChC,cAAc;AAAA,EACd,YAAY;AACd,EAAE;;;ACTF,SAAS,gBAAgB;AACzB,SAAS,kBAAmC;AAC5C,SAAS,wBAAwB;AAO7B;AALG,IAAM,eAA0C,CAAC,UAAU;AAChE,QAAM,QAAQ,SAAS;AACvB,QAAM,EAAE,SAAS,IAAI,iBAAiB;AAEtC,SACE;AAAA,IAAC;AAAA;AAAA,MACC,OAAO,WAAW,SAAS;AAAA,MAC3B,4BAA4B;AAAA,MAC5B,OAAO;AAAA,QACL,YAAY,WAAW,MAAM,QAAQ,WAAW,QAAQ,MAAM,QAAQ,KAAK,GAAG;AAAA,QAC9E,cAAc,MAAM,MAAM;AAAA,QAC1B,SAAS,MAAM,QAAQ,CAAC;AAAA,MAC1B;AAAA,MACC,GAAG;AAAA;AAAA,EACN;AAEJ;;;AFYI,mBAGM,OAAAC,MAOA,YAVN;AAhBG,IAAM,qBAAuD,CAAC,EAAE,qBAAqB,WAAW,oBAAoB,GAAG,MAAM,MAAM;AACxI,QAAM,CAAC,cAAc,eAAe,IAAI,aAAa,mBAAmB;AAExE,QAAM,CAAC,IAAI,IAAI,WAAW,YAAY;AACpC,QAAI,CAAC,aAAa,CAAC,aAAa,SAAS;AAAG;AAC5C,WAAO,MAAM,eAAe,SAAS,SAAS;AAAA,EAChD,GAAG,CAAC,SAAS,CAAC;AAEd,QAAM,aAAa,eAAe,cAAc;AAEhD,QAAM,kBAAkB,MAAM;AAC5B,yBAAqB,CAAC,YAAY;AAClC,oBAAgB,CAAC,YAAY;AAAA,EAC/B;AAEA,SACE,iCACG;AAAA,gBACC,gBAAAA,KAAC,WACC,0BAAAA,KAAC,UAAO,SAAS,iBAAiB,MAAK,SAAQ,SAAQ,YACpD,sBACH,GACF,IACA;AAAA,IACF,gBAAAA,KAAC,YAAS,IAAI,cAAe,GAAG,OAC7B,sBACC,qBAAC,WAAQ,YAAW,WAAU,KAAK,KACjC;AAAA,sBAAAA,KAACC,aAAA,EAAW,IAAI,EAAE,YAAY,EAAE,GAAG,2BAAa;AAAA,MAC/C,OACC,gBAAAD,KAAC,QAAK,OAAO,gBAAAA,KAAC,mBAAiB,gBAAK,GAAoB,IAAI,EAAE,WAAW,QAAQ,GAAG,IACpF;AAAA,MACF,gBAAAA,KAAC,gBAAa,OAAO,WAAW;AAAA,OAClC,IACA,MACJ;AAAA,KACF;AAEJ;;;AGrDA,SAAS,UAAAE,SAAQ,QAAQ,eAAe,eAA4B,mBAAmB;AA8B/E,gBAAAC,MACA,QAAAC,aADA;AAjBD,IAAM,gBAA8C,CAAC;AAAA,EAC1D;AAAA,EACA;AAAA,EACA;AAAA,EACA,WAAW;AAAA,EACX;AAAA,EACA,OAAO;AAAA,EACP,GAAG;AACL,MAAM;AACJ,QAAM,gBAAoD,CAAC,UAAU;AACnE,UAAM,gBAAgB;AAAA,EACxB;AAEA;AAAA;AAAA,IAEE,gBAAAD,KAAC,UAAK,SAAS,eACb,0BAAAC,MAAC,UAAO,WAAS,MAAC,UAAS,MAAK,SAAS,MAAM,kBAAkB,GAAG,MAAa,GAAG,OAClF;AAAA,sBAAAD,KAAC,eAAY,sBAAQ;AAAA,MACrB,gBAAAC,MAAC,iBAAc,IAAI,EAAE,SAAS,QAAQ,eAAe,UAAU,KAAK,EAAE,GACnE;AAAA;AAAA,QACD,gBAAAD,KAAC,sBAAmB,qBAA0C,WAAW,YAAY,oBAAwC;AAAA,SAC/H;AAAA,MACA,gBAAAA,KAAC,iBACC,0BAAAA,KAACE,SAAA,EAAO,SAAQ,aAAY,SAAS,MAAM,kBAAkB,GAAG,mBAEhE,GACF;AAAA,OACF,GACF;AAAA;AAEJ;;;ACzCO,IAAM,sBAAsB,CAAC,SAAoB;AACtD,UAAQ,MAAM;AAAA,IACZ,KAAK,SAAS;AACZ,aAAO;AAAA,IACT;AAAA,IACA,KAAK,UAAU;AACb,aAAO;AAAA,IACT;AAAA,IACA,KAAK,SAAS;AACZ,aAAO;AAAA,IACT;AAAA,EACF;AACF;;;AN+BI,SAIe,OAAAC,MAJf,QAAAC,aAAA;AA3BG,IAAM,gBAA8C,CAAC;AAAA,EAC1D,sBAAsB;AAAA,EACtB;AAAA,EACA;AAAA,EACA,WAAW;AAAA,EACX;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,MAAM;AACJ,QAAM,CAAC,MAAM,OAAO,IAAI,SAAS,KAAK;AACtC,QAAM,OAAO,oBAAoB,cAAc;AAC/C,QAAM,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,CAAC,QAAQ,CAAC;AAEvD,QAAM,cAAoD,CAAC,UAAU;AACnE,UAAM,gBAAgB;AACtB,YAAQ,IAAI;AAAA,EACd;AAEA,QAAM,yBAAyB,MAAM;AACnC,YAAQ,KAAK;AACb,sBAAkB;AAAA,EACpB;AAEA,SACE,gBAAAA,MAAC,UACC;AAAA,oBAAAD;AAAA,MAAC;AAAA;AAAA,QACC,SAAQ;AAAA,QACR,MAAK;AAAA,QACL,WAAW,gBAAAA,KAAC,SAAI,KAAKE,UAAc,QAAQ,QAAQ,UAAU,OAAO,QAAQ,UAAU;AAAA,QACtF,SAAS;AAAA,QACT,UAAU,WAAW,QAAQ,CAAC;AAAA,QAC7B,GAAG;AAAA,QAEH,sBAAY,gBAAAF,KAAC,UAAK,kBAAI;AAAA;AAAA,IACzB;AAAA,IACC,WAAW,OACV,gBAAAA;AAAA,MAAC;AAAA;AAAA,QACC;AAAA,QACA,WAAW;AAAA,QACX,iBAAiB;AAAA,QACjB;AAAA,QACA;AAAA,QACA;AAAA;AAAA,IACF;AAAA,KAEJ;AAEJ;;;AOpEA,SAAS,kBAAmC;AAC5C,SAAS,UAAAG,eAAc;AACvB,SAAS,YAA0C,WAAAC,UAAS,YAAAC,iBAAgB;AAoCtE,qBAAAC,WAEI,OAAAC,MAFJ,QAAAC,aAAA;AApBC,IAAM,oBAAoB;AAAA,EAC/B,CACE,EAAE,sBAAsB,MAAM,eAAe,UAAU,WAAW,IAAI,iBAAiB,UAAU,gBAAgB,oBAAoB,GAAG,MAAM,GAC9I,QACG;AACH,UAAM,CAAC,MAAM,OAAO,IAAIC,UAAS,KAAK;AACtC,UAAM,OAAO,oBAAoB,cAAc;AAC/C,UAAM,OAAOC,SAAQ,MAAMC,QAAO,QAAQ,GAAG,CAAC,QAAQ,CAAC;AAEvD,UAAM,cAAoD,CAAC,UAAU;AACnE,YAAM,gBAAgB;AACtB,cAAQ,IAAI;AAAA,IACd;AAEA,UAAM,yBAAyB,MAAM;AACnC,cAAQ,KAAK;AACb,wBAAkB;AAAA,IACpB;AAEA,WACE,gBAAAH,MAAAF,WAAA,EACE;AAAA,sBAAAC,KAAC,cAAW,SAAS,aAAa,KAAW,GAAG,OAC9C,0BAAAA,KAAC,SAAI,KAAKK,UAAc,QAAQ,QAAQ,UAAU,OAAO,QAAQ,UAAU,GAC7E;AAAA,MACC,WAAW,OACV,gBAAAL;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA,WAAW;AAAA,UACX,iBAAiB;AAAA,UACjB;AAAA,UACA;AAAA,UACA;AAAA;AAAA,MACF;AAAA,OAEJ;AAAA,EAEJ;AACF;AAEA,kBAAkB,cAAc;","names":["default","Typography","jsx","Typography","Button","jsx","jsxs","Button","jsx","jsxs","default","toJson","useMemo","useState","Fragment","jsx","jsxs","useState","useMemo","toJson","default"]}
1
+ {"version":3,"sources":["../../src/components/Button/RawInfoButton.tsx","../../src/components/img/index.ts","../../src/components/shared/Dialog/JsonViewerCollapse.tsx","../../src/components/styled/StyledChipLabel.tsx","../../src/components/shared/JsonViewerEx.tsx","../../src/components/shared/Dialog/RawInfoDialog.tsx","../../src/components/Button/lib/presetIconSize.ts","../../src/components/Button/RawInfoIconButton.tsx"],"sourcesContent":["import { toJson } from '@xylabs/object'\nimport { ButtonEx, ButtonExProps } from '@xylabs/react-button'\nimport { MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoButtonProps extends ButtonExProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoButton: React.FC<RawInfoButtonProps> = ({\n defaultExpandedJson = true,\n dialogContent,\n iconOnly,\n iconSize = 24,\n onCloseCallback,\n children,\n rawValue,\n presetIconSize,\n updateExpandedJson,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <span>\n <ButtonEx\n variant=\"outlined\"\n size=\"small\"\n startIcon={<img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />}\n onClick={handleClick}\n disabled={iconOnly ? false : !rawValue}\n {...props}\n >\n {children ?? <span>Data</span>}\n </ButtonEx>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </span>\n )\n}\n","export { default as xyoColorLogo } from './xyo-color-logo.svg'\n","import { Button, Chip, Collapse, CollapseProps, Typography } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { usePromise } from '@xylabs/react-promise'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { useDataState } from '@xyo-network/react-shared'\n\nimport { ExpansionProps } from '../../../lib'\nimport { StyledChipLabel } from '../../styled'\nimport { JsonViewerEx } from '../JsonViewerEx'\n\nexport interface RawInfoPayloadCollapse extends CollapseProps, ExpansionProps {\n jsonValue?: JsonValue\n}\n\nexport const JsonViewerCollapse: React.FC<RawInfoPayloadCollapse> = ({ defaultExpandedJson, jsonValue, updateExpandedJson, ...props }) => {\n const [expandedJson, setExpandedJson] = useDataState(defaultExpandedJson)\n\n const [hash] = usePromise(async () => {\n if (!jsonValue || !isAnyPayload(jsonValue)) return\n return await PayloadBuilder.dataHash(jsonValue)\n }, [jsonValue])\n\n const actionText = expandedJson ? 'Hide JSON' : 'Show JSON'\n\n const handleExpansion = () => {\n updateExpandedJson?.(!expandedJson)\n setExpandedJson(!expandedJson)\n }\n\n return (\n <>\n {jsonValue ?\n <FlexRow>\n <Button onClick={handleExpansion} size=\"small\" variant=\"outlined\">\n {actionText}\n </Button>\n </FlexRow>\n : null}\n <Collapse in={expandedJson} {...props}>\n {jsonValue ?\n <FlexCol alignItems=\"stretch\" gap={1.5}>\n <Typography sx={{ lineHeight: 1 }}>Payload Hash:</Typography>\n {hash ?\n <Chip label={<StyledChipLabel>{hash}</StyledChipLabel>} sx={{ alignSelf: 'start' }} />\n : null}\n <JsonViewerEx value={jsonValue} />\n </FlexCol>\n : null}\n </Collapse>\n </>\n )\n}\n","import { styled, Typography } from '@mui/material'\n\nexport const StyledChipLabel = styled(Typography, { name: 'StyledChipLabel' })(({ theme }) => ({\n display: 'block',\n lineHeight: 1,\n overflow: 'hidden',\n paddingRight: theme.spacing(0.95),\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n}))\n","import { useTheme } from '@mui/material'\nimport { JsonViewer, JsonViewerProps } from '@textea/json-viewer'\nimport { useColorSchemeEx } from '@xylabs/react-invertible-theme'\n\nexport type JsonViewerExProps = JsonViewerProps\n\nexport const JsonViewerEx: React.FC<JsonViewerExProps> = (props) => {\n const theme = useTheme()\n const { darkMode } = useColorSchemeEx()\n\n return (\n <JsonViewer\n theme={darkMode ? 'dark' : 'light'}\n collapseStringsAfterLength={50}\n style={{\n background: darkMode ? theme.palette.background.paper : theme.palette.grey[200],\n borderRadius: theme.shape.borderRadius,\n padding: theme.spacing(2),\n }}\n {...props}\n />\n )\n}\n","import { Button, Dialog, DialogActions, DialogContent, DialogProps, DialogTitle } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { MouseEventHandler, ReactNode } from 'react'\n\nimport { ExpansionProps } from '../../../lib'\nimport { JsonViewerCollapse } from './JsonViewerCollapse'\n\nexport interface RawInfoDialogProps extends DialogProps, ExpansionProps {\n dialogContent?: ReactNode\n jsonValue?: JsonValue\n onCloseCallback?: () => void\n}\n\nexport const RawInfoDialog: React.FC<RawInfoDialogProps> = ({\n defaultExpandedJson,\n dialogContent,\n onCloseCallback,\n jsonValue: jsonObject,\n updateExpandedJson,\n open = false,\n ...props\n}) => {\n const onDialogClick: MouseEventHandler<HTMLSpanElement> = (event) => {\n event.stopPropagation()\n }\n\n return (\n // Wrapping in a span so we can catch click events and prevent them from propagating outside the component\n <span onClick={onDialogClick}>\n <Dialog fullWidth maxWidth=\"lg\" onClose={() => onCloseCallback?.()} open={open} {...props}>\n <DialogTitle>Raw Data</DialogTitle>\n <DialogContent sx={{ display: 'flex', flexDirection: 'column', gap: 2 }}>\n {dialogContent}\n <JsonViewerCollapse defaultExpandedJson={defaultExpandedJson} jsonValue={jsonObject} updateExpandedJson={updateExpandedJson} />\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" onClick={() => onCloseCallback?.()}>\n Close\n </Button>\n </DialogActions>\n </Dialog>\n </span>\n )\n}\n","import { IconSize } from './IconSize'\n\nexport const presetIconSizeValue = (size?: IconSize) => {\n switch (size) {\n case 'small': {\n return 16\n }\n case 'medium': {\n return 32\n }\n case 'large': {\n return 48\n }\n }\n}\n","import { IconButton, IconButtonProps } from '@mui/material'\nimport { toJson } from '@xylabs/object'\nimport { forwardRef, MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoIconProps extends IconButtonProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoIconButton = forwardRef<HTMLButtonElement, RawInfoIconProps>(\n (\n { defaultExpandedJson = true, dialogContent, iconOnly, iconSize = 32, onCloseCallback, rawValue, presetIconSize, updateExpandedJson, ...props },\n ref,\n ) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <>\n <IconButton onClick={handleClick} ref={ref} {...props}>\n <img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />\n </IconButton>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </>\n )\n },\n)\n\nRawInfoIconButton.displayName = 'RawInfoIcon'\n"],"mappings":"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","names":["default","Typography","jsx","Typography","Button","jsx","jsxs","Button","jsx","jsxs","default","toJson","useMemo","useState","Fragment","jsx","jsxs","useState","useMemo","toJson","default"]}
@@ -1,4 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import { JsonViewerProps } from '@textea/json-viewer';
3
- export declare const JsonViewerEx: React.FC<JsonViewerProps>;
3
+ export type JsonViewerExProps = JsonViewerProps;
4
+ export declare const JsonViewerEx: React.FC<JsonViewerExProps>;
4
5
  //# sourceMappingURL=JsonViewerEx.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAgBlD,CAAA"}
1
+ {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,MAAM,MAAM,iBAAiB,GAAG,eAAe,CAAA;AAE/C,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAgBpD,CAAA"}
@@ -1,4 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import { JsonViewerProps } from '@textea/json-viewer';
3
- export declare const JsonViewerEx: React.FC<JsonViewerProps>;
3
+ export type JsonViewerExProps = JsonViewerProps;
4
+ export declare const JsonViewerEx: React.FC<JsonViewerExProps>;
4
5
  //# sourceMappingURL=JsonViewerEx.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAgBlD,CAAA"}
1
+ {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,MAAM,MAAM,iBAAiB,GAAG,eAAe,CAAA;AAE/C,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAgBpD,CAAA"}
@@ -1,4 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import { JsonViewerProps } from '@textea/json-viewer';
3
- export declare const JsonViewerEx: React.FC<JsonViewerProps>;
3
+ export type JsonViewerExProps = JsonViewerProps;
4
+ export declare const JsonViewerEx: React.FC<JsonViewerExProps>;
4
5
  //# sourceMappingURL=JsonViewerEx.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAgBlD,CAAA"}
1
+ {"version":3,"file":"JsonViewerEx.d.ts","sourceRoot":"","sources":["../../../../src/components/shared/JsonViewerEx.tsx"],"names":[],"mappings":";AACA,OAAO,EAAc,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGjE,MAAM,MAAM,iBAAiB,GAAG,eAAe,CAAA;AAE/C,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAgBpD,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/components/Button/RawInfoButton.tsx","../../src/components/img/index.ts","../../src/components/shared/Dialog/JsonViewerCollapse.tsx","../../src/components/styled/StyledChipLabel.tsx","../../src/components/shared/JsonViewerEx.tsx","../../src/components/shared/Dialog/RawInfoDialog.tsx","../../src/components/Button/lib/presetIconSize.ts","../../src/components/Button/RawInfoIconButton.tsx"],"sourcesContent":["export * from './components'\n","import { toJson } from '@xylabs/object'\nimport { ButtonEx, ButtonExProps } from '@xylabs/react-button'\nimport { MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoButtonProps extends ButtonExProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoButton: React.FC<RawInfoButtonProps> = ({\n defaultExpandedJson = true,\n dialogContent,\n iconOnly,\n iconSize = 24,\n onCloseCallback,\n children,\n rawValue,\n presetIconSize,\n updateExpandedJson,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <span>\n <ButtonEx\n variant=\"outlined\"\n size=\"small\"\n startIcon={<img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />}\n onClick={handleClick}\n disabled={iconOnly ? false : !rawValue}\n {...props}\n >\n {children ?? <span>Data</span>}\n </ButtonEx>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </span>\n )\n}\n","export { default as xyoColorLogo } from './xyo-color-logo.svg'\n","import { Button, Chip, Collapse, CollapseProps, Typography } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { usePromise } from '@xylabs/react-promise'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { useDataState } from '@xyo-network/react-shared'\n\nimport { ExpansionProps } from '../../../lib'\nimport { StyledChipLabel } from '../../styled'\nimport { JsonViewerEx } from '../JsonViewerEx'\n\nexport interface RawInfoPayloadCollapse extends CollapseProps, ExpansionProps {\n jsonValue?: JsonValue\n}\n\nexport const JsonViewerCollapse: React.FC<RawInfoPayloadCollapse> = ({ defaultExpandedJson, jsonValue, updateExpandedJson, ...props }) => {\n const [expandedJson, setExpandedJson] = useDataState(defaultExpandedJson)\n\n const [hash] = usePromise(async () => {\n if (!jsonValue || !isAnyPayload(jsonValue)) return\n return await PayloadBuilder.dataHash(jsonValue)\n }, [jsonValue])\n\n const actionText = expandedJson ? 'Hide JSON' : 'Show JSON'\n\n const handleExpansion = () => {\n updateExpandedJson?.(!expandedJson)\n setExpandedJson(!expandedJson)\n }\n\n return (\n <>\n {jsonValue ?\n <FlexRow>\n <Button onClick={handleExpansion} size=\"small\" variant=\"outlined\">\n {actionText}\n </Button>\n </FlexRow>\n : null}\n <Collapse in={expandedJson} {...props}>\n {jsonValue ?\n <FlexCol alignItems=\"stretch\" gap={1.5}>\n <Typography sx={{ lineHeight: 1 }}>Payload Hash:</Typography>\n {hash ?\n <Chip label={<StyledChipLabel>{hash}</StyledChipLabel>} sx={{ alignSelf: 'start' }} />\n : null}\n <JsonViewerEx value={jsonValue} />\n </FlexCol>\n : null}\n </Collapse>\n </>\n )\n}\n","import { styled, Typography } from '@mui/material'\n\nexport const StyledChipLabel = styled(Typography, { name: 'StyledChipLabel' })(({ theme }) => ({\n display: 'block',\n lineHeight: 1,\n overflow: 'hidden',\n paddingRight: theme.spacing(0.95),\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n}))\n","import { useTheme } from '@mui/material'\nimport { JsonViewer, JsonViewerProps } from '@textea/json-viewer'\nimport { useColorSchemeEx } from '@xylabs/react-invertible-theme'\n\nexport const JsonViewerEx: React.FC<JsonViewerProps> = (props) => {\n const theme = useTheme()\n const { darkMode } = useColorSchemeEx()\n\n return (\n <JsonViewer\n theme={darkMode ? 'dark' : 'light'}\n collapseStringsAfterLength={50}\n style={{\n background: darkMode ? theme.palette.background.paper : theme.palette.grey[200],\n borderRadius: theme.shape.borderRadius,\n padding: theme.spacing(2),\n }}\n {...props}\n />\n )\n}\n","import { Button, Dialog, DialogActions, DialogContent, DialogProps, DialogTitle } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { MouseEventHandler, ReactNode } from 'react'\n\nimport { ExpansionProps } from '../../../lib'\nimport { JsonViewerCollapse } from './JsonViewerCollapse'\n\nexport interface RawInfoDialogProps extends DialogProps, ExpansionProps {\n dialogContent?: ReactNode\n jsonValue?: JsonValue\n onCloseCallback?: () => void\n}\n\nexport const RawInfoDialog: React.FC<RawInfoDialogProps> = ({\n defaultExpandedJson,\n dialogContent,\n onCloseCallback,\n jsonValue: jsonObject,\n updateExpandedJson,\n open = false,\n ...props\n}) => {\n const onDialogClick: MouseEventHandler<HTMLSpanElement> = (event) => {\n event.stopPropagation()\n }\n\n return (\n // Wrapping in a span so we can catch click events and prevent them from propagating outside the component\n <span onClick={onDialogClick}>\n <Dialog fullWidth maxWidth=\"lg\" onClose={() => onCloseCallback?.()} open={open} {...props}>\n <DialogTitle>Raw Data</DialogTitle>\n <DialogContent sx={{ display: 'flex', flexDirection: 'column', gap: 2 }}>\n {dialogContent}\n <JsonViewerCollapse defaultExpandedJson={defaultExpandedJson} jsonValue={jsonObject} updateExpandedJson={updateExpandedJson} />\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" onClick={() => onCloseCallback?.()}>\n Close\n </Button>\n </DialogActions>\n </Dialog>\n </span>\n )\n}\n","import { IconSize } from './IconSize'\n\nexport const presetIconSizeValue = (size?: IconSize) => {\n switch (size) {\n case 'small': {\n return 16\n }\n case 'medium': {\n return 32\n }\n case 'large': {\n return 48\n }\n }\n}\n","import { IconButton, IconButtonProps } from '@mui/material'\nimport { toJson } from '@xylabs/object'\nimport { forwardRef, MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoIconProps extends IconButtonProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoIconButton = forwardRef<HTMLButtonElement, RawInfoIconProps>(\n (\n { defaultExpandedJson = true, dialogContent, iconOnly, iconSize = 32, onCloseCallback, rawValue, presetIconSize, updateExpandedJson, ...props },\n ref,\n ) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <>\n <IconButton onClick={handleClick} ref={ref} {...props}>\n <img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />\n </IconButton>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </>\n )\n },\n)\n\nRawInfoIconButton.displayName = 'RawInfoIcon'\n"],"mappings":"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","names":["import_material","import_material","import_jsx_runtime","import_material","import_jsx_runtime","import_jsx_runtime","import_material","import_object","import_react","import_jsx_runtime"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/components/Button/RawInfoButton.tsx","../../src/components/img/index.ts","../../src/components/shared/Dialog/JsonViewerCollapse.tsx","../../src/components/styled/StyledChipLabel.tsx","../../src/components/shared/JsonViewerEx.tsx","../../src/components/shared/Dialog/RawInfoDialog.tsx","../../src/components/Button/lib/presetIconSize.ts","../../src/components/Button/RawInfoIconButton.tsx"],"sourcesContent":["export * from './components'\n","import { toJson } from '@xylabs/object'\nimport { ButtonEx, ButtonExProps } from '@xylabs/react-button'\nimport { MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoButtonProps extends ButtonExProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoButton: React.FC<RawInfoButtonProps> = ({\n defaultExpandedJson = true,\n dialogContent,\n iconOnly,\n iconSize = 24,\n onCloseCallback,\n children,\n rawValue,\n presetIconSize,\n updateExpandedJson,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <span>\n <ButtonEx\n variant=\"outlined\"\n size=\"small\"\n startIcon={<img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />}\n onClick={handleClick}\n disabled={iconOnly ? false : !rawValue}\n {...props}\n >\n {children ?? <span>Data</span>}\n </ButtonEx>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </span>\n )\n}\n","export { default as xyoColorLogo } from './xyo-color-logo.svg'\n","import { Button, Chip, Collapse, CollapseProps, Typography } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { usePromise } from '@xylabs/react-promise'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { useDataState } from '@xyo-network/react-shared'\n\nimport { ExpansionProps } from '../../../lib'\nimport { StyledChipLabel } from '../../styled'\nimport { JsonViewerEx } from '../JsonViewerEx'\n\nexport interface RawInfoPayloadCollapse extends CollapseProps, ExpansionProps {\n jsonValue?: JsonValue\n}\n\nexport const JsonViewerCollapse: React.FC<RawInfoPayloadCollapse> = ({ defaultExpandedJson, jsonValue, updateExpandedJson, ...props }) => {\n const [expandedJson, setExpandedJson] = useDataState(defaultExpandedJson)\n\n const [hash] = usePromise(async () => {\n if (!jsonValue || !isAnyPayload(jsonValue)) return\n return await PayloadBuilder.dataHash(jsonValue)\n }, [jsonValue])\n\n const actionText = expandedJson ? 'Hide JSON' : 'Show JSON'\n\n const handleExpansion = () => {\n updateExpandedJson?.(!expandedJson)\n setExpandedJson(!expandedJson)\n }\n\n return (\n <>\n {jsonValue ?\n <FlexRow>\n <Button onClick={handleExpansion} size=\"small\" variant=\"outlined\">\n {actionText}\n </Button>\n </FlexRow>\n : null}\n <Collapse in={expandedJson} {...props}>\n {jsonValue ?\n <FlexCol alignItems=\"stretch\" gap={1.5}>\n <Typography sx={{ lineHeight: 1 }}>Payload Hash:</Typography>\n {hash ?\n <Chip label={<StyledChipLabel>{hash}</StyledChipLabel>} sx={{ alignSelf: 'start' }} />\n : null}\n <JsonViewerEx value={jsonValue} />\n </FlexCol>\n : null}\n </Collapse>\n </>\n )\n}\n","import { styled, Typography } from '@mui/material'\n\nexport const StyledChipLabel = styled(Typography, { name: 'StyledChipLabel' })(({ theme }) => ({\n display: 'block',\n lineHeight: 1,\n overflow: 'hidden',\n paddingRight: theme.spacing(0.95),\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n}))\n","import { useTheme } from '@mui/material'\nimport { JsonViewer, JsonViewerProps } from '@textea/json-viewer'\nimport { useColorSchemeEx } from '@xylabs/react-invertible-theme'\n\nexport type JsonViewerExProps = JsonViewerProps\n\nexport const JsonViewerEx: React.FC<JsonViewerExProps> = (props) => {\n const theme = useTheme()\n const { darkMode } = useColorSchemeEx()\n\n return (\n <JsonViewer\n theme={darkMode ? 'dark' : 'light'}\n collapseStringsAfterLength={50}\n style={{\n background: darkMode ? theme.palette.background.paper : theme.palette.grey[200],\n borderRadius: theme.shape.borderRadius,\n padding: theme.spacing(2),\n }}\n {...props}\n />\n )\n}\n","import { Button, Dialog, DialogActions, DialogContent, DialogProps, DialogTitle } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { MouseEventHandler, ReactNode } from 'react'\n\nimport { ExpansionProps } from '../../../lib'\nimport { JsonViewerCollapse } from './JsonViewerCollapse'\n\nexport interface RawInfoDialogProps extends DialogProps, ExpansionProps {\n dialogContent?: ReactNode\n jsonValue?: JsonValue\n onCloseCallback?: () => void\n}\n\nexport const RawInfoDialog: React.FC<RawInfoDialogProps> = ({\n defaultExpandedJson,\n dialogContent,\n onCloseCallback,\n jsonValue: jsonObject,\n updateExpandedJson,\n open = false,\n ...props\n}) => {\n const onDialogClick: MouseEventHandler<HTMLSpanElement> = (event) => {\n event.stopPropagation()\n }\n\n return (\n // Wrapping in a span so we can catch click events and prevent them from propagating outside the component\n <span onClick={onDialogClick}>\n <Dialog fullWidth maxWidth=\"lg\" onClose={() => onCloseCallback?.()} open={open} {...props}>\n <DialogTitle>Raw Data</DialogTitle>\n <DialogContent sx={{ display: 'flex', flexDirection: 'column', gap: 2 }}>\n {dialogContent}\n <JsonViewerCollapse defaultExpandedJson={defaultExpandedJson} jsonValue={jsonObject} updateExpandedJson={updateExpandedJson} />\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" onClick={() => onCloseCallback?.()}>\n Close\n </Button>\n </DialogActions>\n </Dialog>\n </span>\n )\n}\n","import { IconSize } from './IconSize'\n\nexport const presetIconSizeValue = (size?: IconSize) => {\n switch (size) {\n case 'small': {\n return 16\n }\n case 'medium': {\n return 32\n }\n case 'large': {\n return 48\n }\n }\n}\n","import { IconButton, IconButtonProps } from '@mui/material'\nimport { toJson } from '@xylabs/object'\nimport { forwardRef, MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoIconProps extends IconButtonProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoIconButton = forwardRef<HTMLButtonElement, RawInfoIconProps>(\n (\n { defaultExpandedJson = true, dialogContent, iconOnly, iconSize = 32, onCloseCallback, rawValue, presetIconSize, updateExpandedJson, ...props },\n ref,\n ) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <>\n <IconButton onClick={handleClick} ref={ref} {...props}>\n <img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />\n </IconButton>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </>\n )\n },\n)\n\nRawInfoIconButton.displayName = 'RawInfoIcon'\n"],"mappings":"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","names":["import_material","import_material","import_jsx_runtime","import_material","import_jsx_runtime","import_jsx_runtime","import_material","import_object","import_react","import_jsx_runtime"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/components/Button/RawInfoButton.tsx","../../src/components/img/index.ts","../../src/components/shared/Dialog/JsonViewerCollapse.tsx","../../src/components/styled/StyledChipLabel.tsx","../../src/components/shared/JsonViewerEx.tsx","../../src/components/shared/Dialog/RawInfoDialog.tsx","../../src/components/Button/lib/presetIconSize.ts","../../src/components/Button/RawInfoIconButton.tsx"],"sourcesContent":["import { toJson } from '@xylabs/object'\nimport { ButtonEx, ButtonExProps } from '@xylabs/react-button'\nimport { MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoButtonProps extends ButtonExProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoButton: React.FC<RawInfoButtonProps> = ({\n defaultExpandedJson = true,\n dialogContent,\n iconOnly,\n iconSize = 24,\n onCloseCallback,\n children,\n rawValue,\n presetIconSize,\n updateExpandedJson,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <span>\n <ButtonEx\n variant=\"outlined\"\n size=\"small\"\n startIcon={<img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />}\n onClick={handleClick}\n disabled={iconOnly ? false : !rawValue}\n {...props}\n >\n {children ?? <span>Data</span>}\n </ButtonEx>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </span>\n )\n}\n","export { default as xyoColorLogo } from './xyo-color-logo.svg'\n","import { Button, Chip, Collapse, CollapseProps, Typography } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { usePromise } from '@xylabs/react-promise'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { useDataState } from '@xyo-network/react-shared'\n\nimport { ExpansionProps } from '../../../lib'\nimport { StyledChipLabel } from '../../styled'\nimport { JsonViewerEx } from '../JsonViewerEx'\n\nexport interface RawInfoPayloadCollapse extends CollapseProps, ExpansionProps {\n jsonValue?: JsonValue\n}\n\nexport const JsonViewerCollapse: React.FC<RawInfoPayloadCollapse> = ({ defaultExpandedJson, jsonValue, updateExpandedJson, ...props }) => {\n const [expandedJson, setExpandedJson] = useDataState(defaultExpandedJson)\n\n const [hash] = usePromise(async () => {\n if (!jsonValue || !isAnyPayload(jsonValue)) return\n return await PayloadBuilder.dataHash(jsonValue)\n }, [jsonValue])\n\n const actionText = expandedJson ? 'Hide JSON' : 'Show JSON'\n\n const handleExpansion = () => {\n updateExpandedJson?.(!expandedJson)\n setExpandedJson(!expandedJson)\n }\n\n return (\n <>\n {jsonValue ?\n <FlexRow>\n <Button onClick={handleExpansion} size=\"small\" variant=\"outlined\">\n {actionText}\n </Button>\n </FlexRow>\n : null}\n <Collapse in={expandedJson} {...props}>\n {jsonValue ?\n <FlexCol alignItems=\"stretch\" gap={1.5}>\n <Typography sx={{ lineHeight: 1 }}>Payload Hash:</Typography>\n {hash ?\n <Chip label={<StyledChipLabel>{hash}</StyledChipLabel>} sx={{ alignSelf: 'start' }} />\n : null}\n <JsonViewerEx value={jsonValue} />\n </FlexCol>\n : null}\n </Collapse>\n </>\n )\n}\n","import { styled, Typography } from '@mui/material'\n\nexport const StyledChipLabel = styled(Typography, { name: 'StyledChipLabel' })(({ theme }) => ({\n display: 'block',\n lineHeight: 1,\n overflow: 'hidden',\n paddingRight: theme.spacing(0.95),\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n}))\n","import { useTheme } from '@mui/material'\nimport { JsonViewer, JsonViewerProps } from '@textea/json-viewer'\nimport { useColorSchemeEx } from '@xylabs/react-invertible-theme'\n\nexport const JsonViewerEx: React.FC<JsonViewerProps> = (props) => {\n const theme = useTheme()\n const { darkMode } = useColorSchemeEx()\n\n return (\n <JsonViewer\n theme={darkMode ? 'dark' : 'light'}\n collapseStringsAfterLength={50}\n style={{\n background: darkMode ? theme.palette.background.paper : theme.palette.grey[200],\n borderRadius: theme.shape.borderRadius,\n padding: theme.spacing(2),\n }}\n {...props}\n />\n )\n}\n","import { Button, Dialog, DialogActions, DialogContent, DialogProps, DialogTitle } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { MouseEventHandler, ReactNode } from 'react'\n\nimport { ExpansionProps } from '../../../lib'\nimport { JsonViewerCollapse } from './JsonViewerCollapse'\n\nexport interface RawInfoDialogProps extends DialogProps, ExpansionProps {\n dialogContent?: ReactNode\n jsonValue?: JsonValue\n onCloseCallback?: () => void\n}\n\nexport const RawInfoDialog: React.FC<RawInfoDialogProps> = ({\n defaultExpandedJson,\n dialogContent,\n onCloseCallback,\n jsonValue: jsonObject,\n updateExpandedJson,\n open = false,\n ...props\n}) => {\n const onDialogClick: MouseEventHandler<HTMLSpanElement> = (event) => {\n event.stopPropagation()\n }\n\n return (\n // Wrapping in a span so we can catch click events and prevent them from propagating outside the component\n <span onClick={onDialogClick}>\n <Dialog fullWidth maxWidth=\"lg\" onClose={() => onCloseCallback?.()} open={open} {...props}>\n <DialogTitle>Raw Data</DialogTitle>\n <DialogContent sx={{ display: 'flex', flexDirection: 'column', gap: 2 }}>\n {dialogContent}\n <JsonViewerCollapse defaultExpandedJson={defaultExpandedJson} jsonValue={jsonObject} updateExpandedJson={updateExpandedJson} />\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" onClick={() => onCloseCallback?.()}>\n Close\n </Button>\n </DialogActions>\n </Dialog>\n </span>\n )\n}\n","import { IconSize } from './IconSize'\n\nexport const presetIconSizeValue = (size?: IconSize) => {\n switch (size) {\n case 'small': {\n return 16\n }\n case 'medium': {\n return 32\n }\n case 'large': {\n return 48\n }\n }\n}\n","import { IconButton, IconButtonProps } from '@mui/material'\nimport { toJson } from '@xylabs/object'\nimport { forwardRef, MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoIconProps extends IconButtonProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoIconButton = forwardRef<HTMLButtonElement, RawInfoIconProps>(\n (\n { defaultExpandedJson = true, dialogContent, iconOnly, iconSize = 32, onCloseCallback, rawValue, presetIconSize, updateExpandedJson, ...props },\n ref,\n ) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <>\n <IconButton onClick={handleClick} ref={ref} {...props}>\n <img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />\n </IconButton>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </>\n )\n },\n)\n\nRawInfoIconButton.displayName = 'RawInfoIcon'\n"],"mappings":"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","names":["default","Typography","jsx","Typography","Button","jsx","jsxs","Button","jsx","jsxs","default","toJson","useMemo","useState","Fragment","jsx","jsxs","useState","useMemo","toJson","default"]}
1
+ {"version":3,"sources":["../../src/components/Button/RawInfoButton.tsx","../../src/components/img/index.ts","../../src/components/shared/Dialog/JsonViewerCollapse.tsx","../../src/components/styled/StyledChipLabel.tsx","../../src/components/shared/JsonViewerEx.tsx","../../src/components/shared/Dialog/RawInfoDialog.tsx","../../src/components/Button/lib/presetIconSize.ts","../../src/components/Button/RawInfoIconButton.tsx"],"sourcesContent":["import { toJson } from '@xylabs/object'\nimport { ButtonEx, ButtonExProps } from '@xylabs/react-button'\nimport { MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoButtonProps extends ButtonExProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoButton: React.FC<RawInfoButtonProps> = ({\n defaultExpandedJson = true,\n dialogContent,\n iconOnly,\n iconSize = 24,\n onCloseCallback,\n children,\n rawValue,\n presetIconSize,\n updateExpandedJson,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <span>\n <ButtonEx\n variant=\"outlined\"\n size=\"small\"\n startIcon={<img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />}\n onClick={handleClick}\n disabled={iconOnly ? false : !rawValue}\n {...props}\n >\n {children ?? <span>Data</span>}\n </ButtonEx>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </span>\n )\n}\n","export { default as xyoColorLogo } from './xyo-color-logo.svg'\n","import { Button, Chip, Collapse, CollapseProps, Typography } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { usePromise } from '@xylabs/react-promise'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { useDataState } from '@xyo-network/react-shared'\n\nimport { ExpansionProps } from '../../../lib'\nimport { StyledChipLabel } from '../../styled'\nimport { JsonViewerEx } from '../JsonViewerEx'\n\nexport interface RawInfoPayloadCollapse extends CollapseProps, ExpansionProps {\n jsonValue?: JsonValue\n}\n\nexport const JsonViewerCollapse: React.FC<RawInfoPayloadCollapse> = ({ defaultExpandedJson, jsonValue, updateExpandedJson, ...props }) => {\n const [expandedJson, setExpandedJson] = useDataState(defaultExpandedJson)\n\n const [hash] = usePromise(async () => {\n if (!jsonValue || !isAnyPayload(jsonValue)) return\n return await PayloadBuilder.dataHash(jsonValue)\n }, [jsonValue])\n\n const actionText = expandedJson ? 'Hide JSON' : 'Show JSON'\n\n const handleExpansion = () => {\n updateExpandedJson?.(!expandedJson)\n setExpandedJson(!expandedJson)\n }\n\n return (\n <>\n {jsonValue ?\n <FlexRow>\n <Button onClick={handleExpansion} size=\"small\" variant=\"outlined\">\n {actionText}\n </Button>\n </FlexRow>\n : null}\n <Collapse in={expandedJson} {...props}>\n {jsonValue ?\n <FlexCol alignItems=\"stretch\" gap={1.5}>\n <Typography sx={{ lineHeight: 1 }}>Payload Hash:</Typography>\n {hash ?\n <Chip label={<StyledChipLabel>{hash}</StyledChipLabel>} sx={{ alignSelf: 'start' }} />\n : null}\n <JsonViewerEx value={jsonValue} />\n </FlexCol>\n : null}\n </Collapse>\n </>\n )\n}\n","import { styled, Typography } from '@mui/material'\n\nexport const StyledChipLabel = styled(Typography, { name: 'StyledChipLabel' })(({ theme }) => ({\n display: 'block',\n lineHeight: 1,\n overflow: 'hidden',\n paddingRight: theme.spacing(0.95),\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n}))\n","import { useTheme } from '@mui/material'\nimport { JsonViewer, JsonViewerProps } from '@textea/json-viewer'\nimport { useColorSchemeEx } from '@xylabs/react-invertible-theme'\n\nexport type JsonViewerExProps = JsonViewerProps\n\nexport const JsonViewerEx: React.FC<JsonViewerExProps> = (props) => {\n const theme = useTheme()\n const { darkMode } = useColorSchemeEx()\n\n return (\n <JsonViewer\n theme={darkMode ? 'dark' : 'light'}\n collapseStringsAfterLength={50}\n style={{\n background: darkMode ? theme.palette.background.paper : theme.palette.grey[200],\n borderRadius: theme.shape.borderRadius,\n padding: theme.spacing(2),\n }}\n {...props}\n />\n )\n}\n","import { Button, Dialog, DialogActions, DialogContent, DialogProps, DialogTitle } from '@mui/material'\nimport { JsonValue } from '@xylabs/object'\nimport { MouseEventHandler, ReactNode } from 'react'\n\nimport { ExpansionProps } from '../../../lib'\nimport { JsonViewerCollapse } from './JsonViewerCollapse'\n\nexport interface RawInfoDialogProps extends DialogProps, ExpansionProps {\n dialogContent?: ReactNode\n jsonValue?: JsonValue\n onCloseCallback?: () => void\n}\n\nexport const RawInfoDialog: React.FC<RawInfoDialogProps> = ({\n defaultExpandedJson,\n dialogContent,\n onCloseCallback,\n jsonValue: jsonObject,\n updateExpandedJson,\n open = false,\n ...props\n}) => {\n const onDialogClick: MouseEventHandler<HTMLSpanElement> = (event) => {\n event.stopPropagation()\n }\n\n return (\n // Wrapping in a span so we can catch click events and prevent them from propagating outside the component\n <span onClick={onDialogClick}>\n <Dialog fullWidth maxWidth=\"lg\" onClose={() => onCloseCallback?.()} open={open} {...props}>\n <DialogTitle>Raw Data</DialogTitle>\n <DialogContent sx={{ display: 'flex', flexDirection: 'column', gap: 2 }}>\n {dialogContent}\n <JsonViewerCollapse defaultExpandedJson={defaultExpandedJson} jsonValue={jsonObject} updateExpandedJson={updateExpandedJson} />\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" onClick={() => onCloseCallback?.()}>\n Close\n </Button>\n </DialogActions>\n </Dialog>\n </span>\n )\n}\n","import { IconSize } from './IconSize'\n\nexport const presetIconSizeValue = (size?: IconSize) => {\n switch (size) {\n case 'small': {\n return 16\n }\n case 'medium': {\n return 32\n }\n case 'large': {\n return 48\n }\n }\n}\n","import { IconButton, IconButtonProps } from '@mui/material'\nimport { toJson } from '@xylabs/object'\nimport { forwardRef, MouseEventHandler, ReactNode, useMemo, useState } from 'react'\n\nimport { ExpansionProps } from '../../lib'\nimport { xyoColorLogo } from '../img'\nimport { RawInfoDialog } from '../shared'\nimport { IconSize, presetIconSizeValue } from './lib'\n\nexport interface RawInfoIconProps extends IconButtonProps, ExpansionProps {\n dialogContent?: ReactNode\n iconOnly?: boolean\n iconSize?: number\n onCloseCallback?: () => void\n presetIconSize?: IconSize\n rawValue?: unknown\n}\n\nexport const RawInfoIconButton = forwardRef<HTMLButtonElement, RawInfoIconProps>(\n (\n { defaultExpandedJson = true, dialogContent, iconOnly, iconSize = 32, onCloseCallback, rawValue, presetIconSize, updateExpandedJson, ...props },\n ref,\n ) => {\n const [open, setOpen] = useState(false)\n const size = presetIconSizeValue(presetIconSize)\n const json = useMemo(() => toJson(rawValue), [rawValue])\n\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n event.stopPropagation()\n setOpen(true)\n }\n\n const onCloseCallBackWrapped = () => {\n setOpen(false)\n onCloseCallback?.()\n }\n\n return (\n <>\n <IconButton onClick={handleClick} ref={ref} {...props}>\n <img src={xyoColorLogo} height={size ?? iconSize} width={size ?? iconSize} />\n </IconButton>\n {iconOnly ? null : (\n <RawInfoDialog\n defaultExpandedJson={defaultExpandedJson}\n jsonValue={json}\n onCloseCallback={onCloseCallBackWrapped}\n dialogContent={dialogContent}\n open={open}\n updateExpandedJson={updateExpandedJson}\n />\n )}\n </>\n )\n },\n)\n\nRawInfoIconButton.displayName = 'RawInfoIcon'\n"],"mappings":"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","names":["default","Typography","jsx","Typography","Button","jsx","jsxs","Button","jsx","jsxs","default","toJson","useMemo","useState","Fragment","jsx","jsxs","useState","useMemo","toJson","default"]}
package/package.json CHANGED
@@ -11,20 +11,20 @@
11
11
  },
12
12
  "dependencies": {
13
13
  "@textea/json-viewer": "^3.4.0",
14
- "@xylabs/object": "^3.0.12",
15
- "@xylabs/react-button": "^3.1.5",
16
- "@xylabs/react-flexbox": "^3.1.5",
17
- "@xylabs/react-invertible-theme": "^3.1.5",
18
- "@xylabs/react-promise": "^3.1.5",
19
- "@xyo-network/payload-builder": "^2.92.3",
20
- "@xyo-network/payload-model": "^2.92.3",
21
- "@xyo-network/react-shared": "~2.70.6"
14
+ "@xylabs/object": "^3.0.24",
15
+ "@xylabs/react-button": "^3.1.6",
16
+ "@xylabs/react-flexbox": "^3.1.6",
17
+ "@xylabs/react-invertible-theme": "^3.1.6",
18
+ "@xylabs/react-promise": "^3.1.6",
19
+ "@xyo-network/payload-builder": "^2.93.4",
20
+ "@xyo-network/payload-model": "^2.93.4",
21
+ "@xyo-network/react-shared": "~2.71.0"
22
22
  },
23
23
  "devDependencies": {
24
24
  "@storybook/react": "^7.6.17",
25
25
  "@xylabs/ts-scripts-yarn3": "^3.5.2",
26
26
  "@xylabs/tsconfig-react": "^3.5.2",
27
- "typescript": "^5.4.2"
27
+ "typescript": "^5.4.3"
28
28
  },
29
29
  "peerDependencies": {
30
30
  "@emotion/react": "^11",
@@ -86,6 +86,6 @@
86
86
  "license": "yarn license-checker --exclude \"MIT, ISC, Apache-2.0, BSD, BSD-2-Clause, CC-BY-4.0, Unlicense, CC-BY-3.0, CC0-1.0\""
87
87
  },
88
88
  "sideEffects": false,
89
- "version": "2.70.5",
89
+ "version": "2.71.0",
90
90
  "type": "module"
91
91
  }
@@ -1,3 +1,2 @@
1
1
  export * from './JsonViewerCollapse'
2
2
  export * from './RawInfoDialog'
3
-
@@ -2,7 +2,9 @@ import { useTheme } from '@mui/material'
2
2
  import { JsonViewer, JsonViewerProps } from '@textea/json-viewer'
3
3
  import { useColorSchemeEx } from '@xylabs/react-invertible-theme'
4
4
 
5
- export const JsonViewerEx: React.FC<JsonViewerProps> = (props) => {
5
+ export type JsonViewerExProps = JsonViewerProps
6
+
7
+ export const JsonViewerEx: React.FC<JsonViewerExProps> = (props) => {
6
8
  const theme = useTheme()
7
9
  const { darkMode } = useColorSchemeEx()
8
10