-
-
Notifications
You must be signed in to change notification settings - Fork 1.4k
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
Add ability to use data binding to drive disable state of a widget. #3890
base: develop
Are you sure you want to change the base?
Conversation
Isn't this a duplicate of fyne-io/fyne-x#46? As per discussions before the built-in bindings are currently about input/user data. We should complete the implementation of that for all widgets before we expand the scope IMHO. |
It does provide the same feature, but with an API that is more discoverable and inline with the rest of the data binding api, I think.
I have been heavily using data binding in a network oriented application and I have run into the limitation that we currently can't manage state information (button label, checkbox text, disable state, select options, ...). I have run into the limitation on the input/user data side only for table, but I do not have a good proposition for it yet as it is quite more complex. I think it would make sense to continue to move forward the usability of data binding by adding what is useful right away to application and has a relatively simple API. In that regard, I think we should have some Reader interface (ex: BoolReader) that only have listener and get api on their interface for this kind of use case. |
If that is the case we should be helping get the existing contributions to this level instead of replacing the work provided by contributors.
All of this is possible, you can add custom binding in app code with |
Both solution are pretty similar and have the same issue. If you want to bind an object that is inside a List or Table, you end up having to manipulate an additional data that somehow need to be undone when the object is recycled for another use. At the end, the only solution I could find that work is to extend the widget just to add the ability to bind the state. So yes, it can be done without a new API, but it is a lot more complex than it really should be without reason. |
Perhaps you can work with @Solander so we do not have parallel work on this same topic? |
I agree. Still this doesn't give us any direction in addressing the main problem. If there is a no to get this in fyne, there is likely not much better solution that is any better than what is proposed in fyne-x. An agreement of where the code and API should land does create constraint on what can be done and how the API can look like. |
I wasn't saying no, I was saying we should discuss with folk already working on this API. |
When I suggested discussing I was rather expecting we could work with the contributor rather than simply pointing them to this PR to get their feedback on your work. |
I simply don't think there is a way to implement this without major drawback outside of Fyne repository as I have pointed during our conversation here. |
I guess I don't understand what the major drawback is, or where we had the discussion. What I was discussing here is working with open PRs from community contributors before replacing their work. |
Description:
This add the ability to link the Disable state of a widget to a data binding.Bool.
Checklist:
Where applicable: