Skip to content
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

[Bug] Samples: "SubModelSeq" - weird selection/deselection behavior #621

Open
YkTru opened this issue Dec 27, 2024 · 8 comments
Open

[Bug] Samples: "SubModelSeq" - weird selection/deselection behavior #621

YkTru opened this issue Dec 27, 2024 · 8 comments

Comments

@YkTru
Copy link

YkTru commented Dec 27, 2024

BUG.Sample.ElmishWPF.-.SubModelSeq.mp4

Problematic sample: repo

Issues when pressing ''arrow up/down'' buttons:

  • Deselects selected item
  • Toggle item in place

Note: SelecteItem has no binding associated.

@TysonMN
Copy link
Member

TysonMN commented Dec 28, 2024

I know what you mean by the first issue

Deselects selected item

What do you mean by the second issue

Toggle item in place

?

@TysonMN
Copy link
Member

TysonMN commented Dec 28, 2024

Have you tried to fix this problem? If so, what have you tried?

Note: SelecteItem has no binding associated.

Have you tried adding a binding?

@YkTru
Copy link
Author

YkTru commented Jan 6, 2025

What do you mean by the second issue

Toggle item in place

@TysonMN Apologies for the delayed response—I only just noticed your reply. What I meant is that, as shown in the video, the initially selected item swaps cyclically ("toggle") with its predecessor when I click the "MoveUp" button two or more times, instead of continuing to move up.


Have you tried adding a binding?

First, I must say the SubModelSeq sample is quite complex and challenging for a +/- beginner like me, and because of this I don’t feel confident proposing anything that would be a valuable use of anyone’s time.

(I find the binding signatures ('Self,Parent") and InOutMsg pattern quite overwhelming honnestly, I wouldn't know how to make a MRE out of it without breaking a lot of stuff)

However, I attempted something similar based on the SubModelSeq sample's bindings here, and I provided a detailed (though overly exhaustive) account of all my attempts/intuitions here. (I only managed to resolve - I think - the MoveUp/Down issue by using Cmd.ofMsg (SelectItem(Some id)), though I’m not happy with that approach at all))

@YkTru
Copy link
Author

YkTru commented Jan 6, 2025

That said, if anyone has clues or insights on how to resolve these two issues in the SubModelSeq sample, I could try to create a simplified version based on it to make it more accessible for beginners.

@TysonMN
Copy link
Member

TysonMN commented Jan 6, 2025

What I meant is that, as shown in the video, the initially selected item swaps cyclically ("toggle") with its predecessor when I click the "MoveUp" button two or more times, instead of continuing to move up.

That is the intended behavior. Each time you click the "MoveUp" button, it is a different button. That is, all even clicks are on one button and all odd clicks are on another button.

(I only managed to resolve - I think - the MoveUp/Down issue by using Cmd.ofMsg (SelectItem(Some id)), though I’m not happy with that approach at all))

Yes, that solution is a hack.

When I have some free time, I will work on this issue since I think it is the simplest of the problems that you have raised. I do not currently know when I will have any free time.

@YkTru
Copy link
Author

YkTru commented Jan 8, 2025

That is the intended behavior.

Omg sorry I was dumb here haha.. However in my own attempt, I indeed encountered some issues while trying to implement a global moveUp, which led me to resort to hacking around with Cmd.ofMsg (it's the only way I was able to trigger moveUp button successively, but it didn't resolved the UI (visual blue background) deselection issue - as you can see in the GIF - which is quite strange).


When I have some free time, I will work on this issue.

Thank you so much! My intuition suggests that if the unwanted deselection issue is addressed, we may not need the Cmd.ofMsg hack to reselect the previously selected item.

However, I suspect there could be a problem with how F# records interact with WPF, possibly due to hashcode-related issues. Maybe using >> Binding.addLazy could help by setting an appropriate equality function?

@xperiandri
Copy link

xperiandri commented Jan 8, 2025

By the way, drag reorder is only possible if two ways seq is implemented

@YkTru YkTru changed the title [Bug] Samples: "SubModelSeq" - weird selection and moveUp/Down behaviors [Bug] Samples: "SubModelSeq" - weird selection behavior Jan 9, 2025
@YkTru YkTru changed the title [Bug] Samples: "SubModelSeq" - weird selection behavior [Bug] Samples: "SubModelSeq" - weird selection/deselection behavior Jan 9, 2025
@YkTru
Copy link
Author

YkTru commented Jan 14, 2025

@xperiandri

By the way, drag reorder is only possible if two ways seq is implemented

  • Could you please explain why that is?

  • are you experiencing similar unexcepted UI deselection (as in the video) with the Elmish.UNO "port/version" of that sample, or any other part in your repos?

I think we can work around that unusual bug using an attached property, behavior, event, or code-behind, because in fact the ItemsSource changes as expected —i.e., the model updates and keeps track of the selected item— and the UI reflects it instantly, even though the control (the UI) seems to lose track of the selected item.

A "OnSourceUpdated" event might do the trick, where it would re-set/reselect the selected item?

However, I'm unsure about the best "Elmish.WPF" approach to handle this, and I couldnt make work any of these approaches because of my limited skills

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants