-
Notifications
You must be signed in to change notification settings - Fork 80
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
Discussion - Radio Options #3408
base: integration
Are you sure you want to change the base?
Conversation
This is an interesting discussion, thank you for putting this together @kathyavini! The problem with the approach in the current branch is that in the HTML standard, the value of a radio input is always a string. So when we pass down an object, in the DOM we'll actually see a string representation of it, [object Object] (see screenshot). If we went with this, we wouldn't be following HTML and we would also be making it harder for ourselves to debug potential issues since all radios would technically have the same value at the HTML level. The other disadvantage that I can think of is that, with the RadioGroup component setup as is right now, making the Have we considered/tried using only the keys on the UI side, and only looking up for the IDs when we need to send data back to the back end? That is, using the keys as values instead of the numerical IDs. What I'm thinking of is the IDs matter at the database level, but the UI probably shouldn't care about them since they're not semantic. Using numbers as the radio values makes things harder to read at the HTML level, too, I think it'd be cleaner if the inputs had actual meaningful strings as values. I might be missing something though 🤔 there's a ton of new code on animals so trying to get up to speed right now! |
@antsgar I agree with this soooo much! Do you think there is even the possibility leaving the IDs entirely on the backend and working only with keys on the front? Even at the point of sending data to the backend we do need access to both the semantic value (to do the right data processing) and the numeric id (to put in the actual request), and I would say the current question of how to deal with this radio is a microcosm of issues we've had with matching up numeric ids to semantic keys even at this step (sending data back). In soil amendment this came up with the handling of both
(It's a lot of code so I can also definitely go over it in tech daily next week!) In animals there is the If I were to put it in a nutshell, I would say that mostly I have wanted to hack together something (anything!) to deliver the semantic data alongside the numeric id, while Sayaka has mostly re-fetched the enum and passed the key through whatever it takes to put it in the right place -- so in that sense, this question of the It would very good I think to have a more consistent approach and I would love as a starting point to discuss making the value of both radios and React Select options semantic! |
Yes! That would be ideal, to separate concerns and have the UI be entirely agnostic to the IDs. The only reason the numerical IDs exist is to keep the database layer performant, so we can draw a line at the back end and forget about them from there on. We could have the API receive the key instead when writing an animal, and have the controller do the lookup for the right ID to write. In that first soil PR, I see that we're even looking up for the key in the back end https://github.com/LiteFarmOrg/LiteFarm/pull/3324/files#diff-b5cc8699bfe63f32843d007de630ff3401e9e3cebceea7c07988705fea31a466R34, which we wouldn't have to do if we had the UI pass down the key and not the ID in the first place if I'm understanding correctly. Something to take into account, if we aren't yet we would need to make the key column unique at the database level to ensure that we're getting unique strings all the way through to the UI, but honestly we should be doing that anyway -- it wouldn't make sense to have two rows with the same key. |
I am also on board for that removal of ids from frontend! ...I know I have floated this idea a few times.. but do we even need enum ids on the backend? I am curious about what the performance of a small and finite enum table with just string keys as primary key, since there will never be thousands of enums on I tested it when I first started on A side benefit is it makes for very clean reading of a single row, with no joins necessary! |
It's a good point! But I think it's a good idea to try to aim for consistency across tables, so even though it might not be a problem with a table this size in particular, doing numerical IDs in general prevents someone from thinking string IDs in a bigger table might be a good idea in the future. Also if we do the same thing for IDs throughout the entire database it's easier to know what your query needs to look like. The other thing is strings will take up more space to store, and since these primary keys are actually foreign keys in other tables which will be big (like animals), that could become a problem. |
Fair point about copy pasting new architecture. But I think for enum tables I would hope it might be more clear and why using it for big resources like animals would be a bad idea. Strings do take up more space but we save strings all the time like 'notes' with no issues. The question I am really interested in is: how expensive really is the Foreign Key relationship. I would be interested to see how much of a problem that actually is! Because we could save a lot of uneccessary joining and relationships on the backend too as well as the frontend. Edit : Doing a quick google -- we have used uuid -- which is a string so probably fine? |
Yeah, that's a fair point! Tbh it might not be a huge problem either way in this scenario, it's probably a matter of just picking something and moving forward. Another disadvantage that I can think of for using "semantic" strings as keys on the database side is that if for some reason we need to change that translation key, we'll need to update thousands of records throughout to reflect the change instead of just updating the lookup table, but that's probably not likely to happen since it's the actual translation that would need to change and not the key? If that's the case I think it'd be reasonable to get rid of the numerical IDs and the need to lookup joined tables altogether. |
@Duncan-Brain Happy birthday! Regarding specifically @antsgar we have indeed at times changed the translation key and not just the translation, e.g. So actually I guess I am declaring for team |
@kathyavini agreed no to uuid pk , but that context was for large resources like animals not small ones like enum tables. I am fairly confident he just agreed with the general content of an article about how to decide ( not as an antipattern) that I shared during that discussion https://www.bytebase.com/blog/choose-primary-key-uuid-or-auto-increment/ |
Description
Not for merging, just for discussion, based on the conversation in #3397
NOT URGENT, just documenting before I forget.
Background
A RadioGroup option (unlike a React Select option) is set up to only store a single primitive value (string/number) in React Hook Form. We have a RadioGroup option in the Add Animals (and later Readonly/Edit animals) which stores an Origin id (numeric key) from the AnimalOrigins enum table. But when we want to perform logic on AnimalOrigins (e.g. showing/hiding fields in the component or cleaning up submission data), we need the KEY, which has to be either 1) stored and passed down in some way in data otherwise available to the component and then re-matched to the numeric id (this was done in the component), or 2) re-fetched from the API (which luckily is not a network request though, as it should be cached) and then passed down to where the logic is needed.
To me, it read kind of messily in both places, so the idea was to discuss some alternatives and/or check if this was indeed the way it has to be done.
Options
{ id, key }
and update Radios to accept these values alongside primitives. Personally, I kind of like how this idea reads more than any of the others. We can continue to use the AnimalOrigins enum and the logic is trivial1:BROUGHT_IN
and parsed with split:but Sayaka mentioned not liking compound string keys and I also don't find that split very beautiful so I'm happy to discard that idea.
containers/AddAnimals/utils.ts
could be refactored into a hook in order to call the origins useQuery hook directly, see comment here which would save the passing down ofbroughtInId
through so many functions. However, this wouldn't work for the component, if we are keeping it pure (as I think we should).So, just wanted to discuss that. No rush though!
Type of change
How Has This Been Tested?
Please describe the tests that you ran to verify your changes. Provide instructions so we can reproduce. Please also list any relevant details for your test configuration
Checklist: