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

[3222] Disabling sliders when set to random #3268

Merged

Conversation

sulikdan
Copy link
Contributor

@sulikdan sulikdan commented Nov 1, 2024

Did some code clean-up, though naming may not be ideal - any suggestions welcomed.

added 3 tests.

Feature:
If propCombo set to Random -> slider disabled
If resourceCombo set to Random -> slider disabled

Solving ticket #3222

@sulikdan sulikdan requested a review from Sheikah45 November 4, 2024 17:23
Comment on lines 93 to 101
private BooleanBinding customizationAllowed;

@Override
protected void onInitialize() {
customizationAllowed = previousMapName.textProperty().isNotEmpty()
.or(generationTypeComboBox.valueProperty()
.isNotEqualTo(GenerationType.CASUAL))
.or(commandLineArgsText.textProperty().isNotEmpty());

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is better as a private final BooleanProperty that then gets bound in onInitialize, also as is wouldn't the variable be better named noCustomizatonAllowed?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ehm, not sure if I get you on the first part. if I make property final, it won't go as it will fall into category to be autowired (there is no bean to be autowire) additionally, it depends on previousMapName textField. So therefore no way to make it final. Alternative is to make it local and then pass it as param. Or am I thinking about something else? Is there Object BooleanBinding that can be specified at later time?

hmm, yeah or forbidCustomization / disableCustomization? In general, I'm lost in these logical operators and then their binding to field/property....

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The property wouldn't be auto wired because we should initialize it at declaration so just 'private final BooleanProperty disableCustomization = new Simple BooleanProperty();'

And then in onInit we would just disableCustomization.bind(...).

This way the property itself is final and we don't have to worry about it being reassigned. And it fits the pattern in most of the other controllers

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ouch, forgot about SimpleBooleanProperty ... jobs done.

Anyway, are these all Property() classes used nowadays in projects? I've never came upon them till now, though I'm working only on web-applications ...

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

They are used pretty heavily in JavaFX and are specific to it. But JavaFX is a desktop application library so if you have mainly done web application development you probably don't see them very often.

But mainly they are JavaFX's general solution to reactivity and event listeners. Somewhat like promises but with change detection and the like that you expect from fields.

@Sheikah45 Sheikah45 merged commit a53f5a9 into FAForever:develop Nov 4, 2024
2 checks passed
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

Successfully merging this pull request may close these issues.

2 participants