-
-
Notifications
You must be signed in to change notification settings - Fork 14
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Control the expansion of individual nodes #59
Comments
To help understand the problem, here is the current code i am trying to implement: <JsonView
id={rootNode}
key={treeKey}
value={tranformedTree}
style={customTheme}
keyName={rootNode}
// collapsed={
// searchQuery || selectedDatapoints.length > 0 ? false : true
// }
collapsed={true}
enableClipboard={false}
displayObjectSize={false}
displayDataTypes={false}
onExpand={({ expand, value, keyid, keyName }) => {
console.log('expand', expand, value, keyid, keyName);
}}
>
<JsonView.Colon render={() => <></>} />
<JsonView.Quote render={() => <></>} />
<JsonView.BraceLeft render={() => <></>} />
<JsonView.BraceRight render={() => <></>} />
<JsonView.Ellipsis render={() => <></>} />
<JsonView.KeyName
render={(
{ children, ...props },
{ keyName, value, keys, parentValue },
) => {
// Define whether the current node is a leaf node
const isLeafNode = isValueALeafNode(value);
// if (!keys) {
// return children;
// }
// const reversedKeys = [...keys].reverse();
// console.log('reversedKeys', reversedKeys);
// console.log('precomputedPaths', precomputedPaths);
// const shouldBeExpanded = precomputedPaths.some(
// (precomputedPath) =>
// reversedKeys.every(
// (key, index) =>
// precomputedPath[
// precomputedPath.length - reversedKeys.length + index
// ] === key,
// ),
// );
// props['data-expanded'] = shouldBeExpanded;
// Console log every incoming parameter
// console.log('children', children);
// console.log('props', props);
// console.log('keyName', keyName);
// console.log('keys', keys);
// console.log('value', value);
// console.log('parentValue', parentValue);
// console.log('');
if (!isLeafNode || !keyName || !keys) {
return children;
}
const selection = keypathToMPIDDPID(
[...(keys || [])].reverse(),
tranformedTree,
);
if (!selection) {
return children;
}
const assets = findAssetMemberAndMeasuredValue(
monitoringSiteDetails,
selection,
);
const isSelected = isDatapointSelected(selection);
const isAllowedToSelectForThisDatapoint = isAllowedToSelect(
selection,
selectedDatapoints,
);
const displayValue = `${keyName as string} (${
assets.measuredValue?.uomCode || '1'
})`;
return (
<span
onClick={() =>
isAllowedToSelectForThisDatapoint &&
handleValueClick(selection.dpid, selection.mpid)
}
style={{
cursor: isAllowedToSelectForThisDatapoint
? 'pointer'
: 'not-allowed',
color: isSelected
? 'var(--sdx-color-int-blue)'
: isAllowedToSelectForThisDatapoint
? 'var(--sdx-color-int-blue)'
: 'gray',
fontWeight: isSelected ? 'bold' : 'normal',
}}
>
{highlightMatch(displayValue, searchQuery || '')}
</span>
);
}}
/>
<JsonView.Arrow
// eslint-disable-next-line @typescript-eslint/no-explicit-any
render={(props: any) => {
const isExpanded = props['data-expanded'];
return (
<img
style={{
cursor: 'pointer',
width: '0.7rem',
marginRight: 10,
rotate: isExpanded ? '0deg' : '270deg',
}}
src="/icons/forms_selector.svg"
/>
);
}}
/>
<JsonView.ValueQuote render={() => <></>} />
</JsonView> If it would be possible to implement such function and pass it to the JsonView component, then it would be great. Here is an example implementation: shouldExpandNodeInitially={( // called for each node
keyPath: (string | number)[],
// data: unknown,
// level: number,
) => {
if (searchQuery) {
return true;
}
console.log('keyPath', keyPath); //
console.log('precomputedPaths', precomputedPaths); //<- keypaths to currently selected elements
const res = precomputedPaths.some((precomputedPath) =>
precomputedPath
.slice(0, keyPath.length)
.every((key, index) => key === keyPath[index]),
);
return res; // boolean result
}} |
@TomsBicans My understanding is that you might need an react-json-view/core/src/index.tsx Line 65 in 5a3a449
|
Hello. It is not exactly what i mean. The I have a problem, that i need to open up the json tree in a specific way for the initial state - some nodes of the json tree should be opened, some nodes should be closed. Currently i see no way on how to control this mechanism without user interaction. Another library i found has this kind of function i am talking about, but it lacks in other areas unrelated to the node expansion - it lets the developer implement the Maybe something like this can be implemented also in this project. Thank you for your time. |
@TomsBicans upgrade react-json-view/core/README.md Lines 734 to 742 in 044ff95
|
Hello. I found this library for json data display, but i do not see a way how to calculate the initial expansion and collapse state of each individual node. Ideally, there could be a function that can be implemented and passed to the JsonView component called:
if the result is true - node should be expanded
if the result is false - node should be collapsed
This way the initial expansion could be calculated for each node separately and it would be possible to decide for each node if it should be opened or not. The current attribute 'collapsed' lets me control the collapsion state of the whole tree, which does not seem to allow to configure each node separately and limits my needs.
Any idea on how this issue could be solved?
The text was updated successfully, but these errors were encountered: