From b8ae69f79b83490620c9a6a59bf6951ce63fe8e0 Mon Sep 17 00:00:00 2001 From: AykutSarac Date: Sat, 9 Sep 2023 22:26:16 +0300 Subject: [PATCH] feat: colorize text nodes --- .../Graph/CustomNode/ObjectNode.tsx | 17 +++---- src/components/Graph/CustomNode/TextNode.tsx | 5 ++- src/components/Graph/CustomNode/styles.tsx | 45 +++++++++++-------- 3 files changed, 36 insertions(+), 31 deletions(-) diff --git a/src/components/Graph/CustomNode/ObjectNode.tsx b/src/components/Graph/CustomNode/ObjectNode.tsx index c60e92c..cb36bee 100644 --- a/src/components/Graph/CustomNode/ObjectNode.tsx +++ b/src/components/Graph/CustomNode/ObjectNode.tsx @@ -13,17 +13,14 @@ type RowProps = { }; const Row = ({ val, x, y, index }: RowProps) => { + const key = JSON.stringify(val); + const rowKey = JSON.stringify(val[0]).replaceAll('"', ""); + const rowValue = JSON.stringify(val[1]); + return ( - - - {JSON.stringify(val[0]).replaceAll('"', "")}:{" "} - - {JSON.stringify(val[1])} + + {rowKey}: + {rowValue} ); }; diff --git a/src/components/Graph/CustomNode/TextNode.tsx b/src/components/Graph/CustomNode/TextNode.tsx index 9f74a48..70c48bb 100644 --- a/src/components/Graph/CustomNode/TextNode.tsx +++ b/src/components/Graph/CustomNode/TextNode.tsx @@ -59,6 +59,7 @@ const Node: React.FC = ({ node, x, y, hasCollapse = false }) => const collapseNodes = useGraph(state => state.collapseNodes); const isExpanded = useGraph(state => state.collapsedParents.includes(id)); const isImage = imagePreview && isContentImage(text as string); + const value = JSON.stringify(text).replaceAll('"', ""); const handleExpand = (e: React.MouseEvent) => { e.stopPropagation(); @@ -81,8 +82,8 @@ const Node: React.FC = ({ node, x, y, hasCollapse = false }) => data-key={JSON.stringify(text)} $hasCollapse={isParent && hideCollapse} > - - {JSON.stringify(text).replaceAll('"', "")} + + {value} {isParent && childrenCount > 0 && showChildrenCount && ( ({childrenCount}) diff --git a/src/components/Graph/CustomNode/styles.tsx b/src/components/Graph/CustomNode/styles.tsx index d262caf..a63fb8d 100644 --- a/src/components/Graph/CustomNode/styles.tsx +++ b/src/components/Graph/CustomNode/styles.tsx @@ -1,23 +1,29 @@ import styled, { DefaultTheme } from "styled-components"; -import { NodeType } from "jsonc-parser"; import { LinkItUrl } from "react-linkify-it"; import { firaMono } from "src/constants/fonts"; -function getTypeColor(value: string, theme: DefaultTheme) { - if (!Number.isNaN(+value)) return theme.NODE_COLORS.INTEGER; - if (value === "true") return theme.NODE_COLORS.BOOL.TRUE; - if (value === "false") return theme.NODE_COLORS.BOOL.FALSE; - if (value === "null") return theme.NODE_COLORS.NULL; - return theme.NODE_COLORS.NODE_VALUE; -} +type TextColorFn = { + theme: DefaultTheme; + $type?: string; + $value?: string; + $parent?: boolean; +}; -function getKeyColor(theme: DefaultTheme, parent: boolean, type: NodeType) { - if (parent) { - if (type === "array") return theme.NODE_COLORS.PARENT_ARR; - return theme.NODE_COLORS.PARENT_OBJ; - } - if (type === "object") return theme.NODE_COLORS.NODE_KEY; - return theme.NODE_COLORS.TEXT; +function getTextColor({ $value, $type, $parent, theme }: TextColorFn) { + // per type + if ($parent && $type === "array") return theme.NODE_COLORS.PARENT_ARR; + if ($parent && $type === "object") return theme.NODE_COLORS.PARENT_OBJ; + if ($type === "object") return theme.NODE_COLORS.NODE_KEY; + if ($type === "array") return theme.NODE_COLORS.NODE_VALUE; + + // per value + if ($value && !Number.isNaN(+$value)) return theme.NODE_COLORS.INTEGER; + if ($value === "true") return theme.NODE_COLORS.BOOL.TRUE; + if ($value === "false") return theme.NODE_COLORS.BOOL.FALSE; + if ($value === "null") return theme.NODE_COLORS.NULL; + + // default + return theme.NODE_COLORS.NODE_VALUE; } export const StyledLinkItUrl = styled(LinkItUrl)` @@ -57,10 +63,11 @@ export const StyledForeignObject = styled.foreignObject<{ $isObject?: boolean }> } `; -export const StyledKey = styled.span<{ $parent?: boolean; $type?: NodeType }>` +export const StyledKey = styled.span<{ $parent?: boolean; $type: string; $value?: string }>` display: inline; flex: 1; - color: ${({ theme, $type = "null", $parent = false }) => getKeyColor(theme, $parent, $type)}; + color: ${({ theme, $type, $parent = false, $value = "" }) => + getTextColor({ $parent, $type, $value, theme })}; font-size: ${({ $parent }) => $parent && "14px"}; overflow: hidden; text-overflow: ellipsis; @@ -68,9 +75,9 @@ export const StyledKey = styled.span<{ $parent?: boolean; $type?: NodeType }>` white-space: nowrap; `; -export const StyledRow = styled.span<{ $type: string }>` +export const StyledRow = styled.span<{ $value: string }>` padding: 0 10px; - color: ${({ theme, $type }) => getTypeColor($type, theme)}; + color: ${({ theme, $value }) => getTextColor({ $value, theme })}; display: block; overflow: hidden; text-overflow: ellipsis;