Skip to content
This repository has been archived by the owner on May 7, 2020. It is now read-only.

[core] Added min, max and step parameters for slider widget #6777

Merged
merged 4 commits into from
Jan 7, 2019

Conversation

FlorianSW
Copy link
Contributor

@FlorianSW FlorianSW commented Jan 2, 2019

Like for the setpoint, the min and max value for a slider can differ based
on the underlying thing that is being controlled, so it shouldn't be
hardcoded and a user should be able to change these values.

The default values, if the parameters are not given, are 0 (minValue) and
100 (maxValue), like they're currently, so that users shouldn't see a
difference when they're not changing their configurations.

Fixes #6776

Signed-off-by: Florian [email protected]

FlorianSW added a commit to FlorianSW/smarthome that referenced this pull request Jan 2, 2019
Like for the setpoint, the min and max value for a slider can differ based
on the underlying thing that is being controlled, so it shouldn't be
hardcoded and a user should be able to change these values.

The default values, if the parameters are not given, are 0 (minValue) and
100 (maxValue), like they're currently, so that users shouldn't see a
difference when they're not changing their configurations.

Fixes eclipse-archived#6777

Signed-off-by: Florian <[email protected]>
Like for the setpoint, the min and max value for a slider can differ based
on the underlying thing that is being controlled, so it shouldn't be
hardcoded and a user should be able to change these values.

The default values, if the parameters are not given, are 0 (minValue) and
100 (maxValue), like they're currently, so that users shouldn't see a
difference when they're not changing their configurations.

Fixes eclipse-archived#6776

Signed-off-by: Florian <[email protected]>
@lolodomo
Copy link
Contributor

lolodomo commented Jan 2, 2019

Could you please adjust Classic UI too ?

@kaikreuzer
Copy link
Contributor

The slider widget was originally only introduced for Dimmer items and no others.
What does it do for number items right now?
If we want to extend its use to number items, shouldn't we also introduce a "step" parameter as for the Setpoints?

@FlorianSW
Copy link
Contributor Author

FlorianSW commented Jan 2, 2019

Could you please adjust Classic UI too ?

I looked at it, too, however, I've two questions here:

  1. The classic UI renders sliders like setpoints, to there're only two buttons, I'm not sure where to put the min and max values there (no-where?)
  2. Where is the non-minified source code of the "Logic.js" where I would expect to put some min/max-value handling?

What does it do for number items right now?

E.g. the temperature (like in the openHAB example) or, in the actual use case, controlling the brightness of an item, which expects the brightness as a range from 0 to 255 instead of 0 to 100. Currently it would need to be "translated" in a rule to work with a slider.

If we want to extend its use to number items, shouldn't we also introduce a "step" parameter as for the Setpoints?

Hmm, I don't think so. The step parameter in the setpoint means, that when pressing the minus or plus to increase or decrease the current value by the value of step. Whereas I would expect a slider to change the value based on the relative position on the slider. Is it understandable what I mean here? :D

@maggu2810
Copy link
Contributor

For a slider you need to know the minimum step size, too. Or how do you want decide which values the slider position should be assigned to?

@FlorianSW
Copy link
Contributor Author

Why? The assignment of the values doesn't change when you make the min and Max values configurable (the slider had min and Max values before, too, they were just hardcoded). The slider had a specific width and based on that width the range between the min andax values are assigned to the slider relatively. Let's say, that the slider width is 100%, then each step of the slider position is 1%, it doesn't really matter what the absolute values are then, they are calculated by the relative position of the slider.

@maggu2810
Copy link
Contributor

I did not have a look at the code so I could be wrong and if you already checked it...
I had in mind that a slider has a fixed minimum of 0 a maximum of 100 and a step size of 1.
So, you cannot set e.g. 3,75 using a slider (but I really don't know if this is correct).
My assumption has been, if we could change the minimum and maximum (e.g. min=0 and max=1) we need also to set if the step size should be 1, 0.1, 0.01, 0.001 or so on.
It would not make sense to allow a more granular step size if it is not handled on the item's linked channel.

@FlorianSW
Copy link
Contributor Author

So, for now the slider has a default step size (in basic UI only), which is 1 (see the mdl documentation), so it would be possible to add a step parameter, too. I really do not care so much about this part of it, so I'm ok with adding a step parameter, too (which should default to 1 I think).

The default is 1, if not set, otherwise a user might set another value to
make the step of the slider bigger or shorter.

Signed-off-by: Florian <[email protected]>
@FlorianSW
Copy link
Contributor Author

The latest commit changes the slider to have another new parameter (step) and made changes to the basic UI to take this into account.

I didn't changed the classic UI so far because I want to check with you guys first about one thing:
If we make this change to the classic ui (min, max and step), then the widget in the classic UI renders really like the setpoint widget. The only difference now is, that the slider currently uses the "magic" INCREASE and DECREASE command to set the new value, the setpoint pre-calculates the new value, as it needs to take the step parameter into account.

My solution here would be to use the same widget for a slider and a setpoint in the classic UI, is that ok? Any other opinions? :)

@maggu2810
Copy link
Contributor

I am not a user of the basic or classic UI, so hopefully another one can comment.

@kaikreuzer
Copy link
Contributor

@FlorianSW I do not think that anything should be changed in the Classic UI, because the widget just works fine and min/max do not have any impact on it. Completely changing its behavior to not send INCREASE/DECREASE anymore would rather be a breaking change that might annoy some users.

Copy link
Contributor

@kaikreuzer kaikreuzer left a comment

Choose a reason for hiding this comment

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

lgtm, thanks!

@kaikreuzer kaikreuzer merged commit 4f331ef into eclipse-archived:master Jan 7, 2019
@kaikreuzer
Copy link
Contributor

May I ask you to also do an update to https://www.openhab.org/docs/configuration/sitemaps.html#element-type-slider?

@kaikreuzer kaikreuzer changed the title Make min and max value for slider configurable [core] Added min, max and step parameters for slider widget Jan 7, 2019
@FlorianSW FlorianSW deleted the issue/6776 branch January 7, 2019 21:19
@FlorianSW
Copy link
Contributor Author

Of course, I'll submit a PR :) May I ask if there's already a plan when (not exactly of course, just an estimation) this will be included in an ESH release, as well as an openHAB release?

@kaikreuzer
Copy link
Contributor

Will be in the latest openHAB distro snapshots later this week, so the docs can be adapted right away!

@maniac103
Copy link

Just jumping in here to thank you for not forgetting about step ;-)

Why? The assignment of the values doesn't change when you make the min and Max values configurable (the slider had min and Max values before, too, they were just hardcoded). The slider had a specific width and based on that width the range between the min andax values are assigned to the slider relatively. Let's say, that the slider width is 100%, then each step of the slider position is 1%, it doesn't really matter what the absolute values are then, they are calculated by the relative position of the slider.

That's all right, but still, step is absolutely needed in order to have a defined granularity. Say the 0..100% slider is 100 pixels wide: the minimum increment then would be 1%. If the slider grows to 500 pixels (presentation is up to the UI after all), the minimum increment suddenly becomes 0.2%. Since the UI doesn't know whether the underlying number should be integer or floating point, what increment between data points should it use? Having 'step' solves that uncertaincy, so thanks for not making my life hard when implementing this in the Android app 👍

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

Successfully merging this pull request may close these issues.

5 participants