-
-
Notifications
You must be signed in to change notification settings - Fork 502
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
Polish user-created subgraph nodes: imports in the Properties panel; reorder/delete/rename imports/exports #2105
Merged
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Keavon
force-pushed
the
modify-import-export
branch
from
November 12, 2024 22:32
73e1ae5
to
0fbbffd
Compare
Deferred code review comments/requests from Hypercube in the precursor PR to this one:
|
Keavon
changed the title
Continue adding support for user created node graphs
Continue adding support for user created subgraphs
Nov 12, 2024
Keavon
force-pushed
the
master
branch
2 times, most recently
from
January 18, 2025 00:03
7465fad
to
ab724d8
Compare
Keavon
changed the title
Continue adding support for user created subgraphs
Polish the experience around user created subgraph nodes
Jan 20, 2025
Keavon
changed the title
Polish the experience around user created subgraph nodes
Polish user-created subgraph nodes: imports in the Properties panel; reorder/delete/rename imports/exports
Jan 20, 2025
I'll discuss this with you on Discord but here are my notes of unresolved questions/potential concerns from my code review:
|
Keavon
approved these changes
Jan 21, 2025
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Closes #2208 and continues to resolve #2043. Also resolves #2069.
Allows removing, renaming, and reordering imports/exports.
Input based properties for network nodes to allow useable reordering
Adds Tooltips for acceptable types of a node input
Annotations for both node and input based overrides added to the node macro
Reworks how the properties panel is generated. A full node level override for the entire panel is still possible, which is stored as a lambda in the definition. Modifying the imports/exports means that the reference is lost, and the properties are instead generated individually for each input. By default, this will use the data type/type annotation to generate an appropriate set of widgets. This is done in
property_from_type
. For custom input overrides, each input has the PropertiesRow struct, which can store a reference to a widget override (a lambda which will generate a custom set of widgets). This lambda is stored in a hashmap, since it would not be possible to serialize it for every node. This also makes it easily extendible, just like how the definitions are stored. This lambda has access to the entire network interface, which it can use to access any information it needs to generate the widget. In addition to the widget override reference, each input also stores a hashmap of serializable data, which can store any information necessary. For the most part this will just contain the input name, but the author of the node could store additional data as they need.TODO: