slider: Reverse handle direction in RTL
Rework slider handle to reverse directions when the slider is Right-to-Left. Fixes: https://gitlab.gnome.org/GNOME/gnome-shell/-/issues/5107 Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/2943>
This commit is contained in:
parent
c777425d39
commit
405b549a05
@ -37,6 +37,7 @@ export const Slider = GObject.registerClass({
|
|||||||
let cr = this.get_context();
|
let cr = this.get_context();
|
||||||
let themeNode = this.get_theme_node();
|
let themeNode = this.get_theme_node();
|
||||||
let [width, height] = this.get_surface_size();
|
let [width, height] = this.get_surface_size();
|
||||||
|
const rtl = this.get_text_direction() === Clutter.TextDirection.RTL;
|
||||||
|
|
||||||
let handleRadius = themeNode.get_length('-slider-handle-radius');
|
let handleRadius = themeNode.get_length('-slider-handle-radius');
|
||||||
|
|
||||||
@ -45,10 +46,13 @@ export const Slider = GObject.registerClass({
|
|||||||
themeNode.lookup_color('-slider-handle-border-color', false);
|
themeNode.lookup_color('-slider-handle-border-color', false);
|
||||||
|
|
||||||
const ceiledHandleRadius = Math.ceil(handleRadius + handleBorderWidth);
|
const ceiledHandleRadius = Math.ceil(handleRadius + handleBorderWidth);
|
||||||
const handleX = ceiledHandleRadius +
|
|
||||||
(width - 2 * ceiledHandleRadius) * this._value / this._maxValue;
|
|
||||||
const handleY = height / 2;
|
const handleY = height / 2;
|
||||||
|
|
||||||
|
let handleX = ceiledHandleRadius +
|
||||||
|
(width - 2 * ceiledHandleRadius) * this._value / this._maxValue;
|
||||||
|
if (rtl)
|
||||||
|
handleX = width - handleX;
|
||||||
|
|
||||||
let color = themeNode.get_foreground_color();
|
let color = themeNode.get_foreground_color();
|
||||||
Clutter.cairo_set_source_color(cr, color);
|
Clutter.cairo_set_source_color(cr, color);
|
||||||
cr.arc(handleX, handleY, handleRadius, 0, 2 * Math.PI);
|
cr.arc(handleX, handleY, handleRadius, 0, 2 * Math.PI);
|
||||||
@ -189,9 +193,13 @@ export const Slider = GObject.registerClass({
|
|||||||
_moveHandle(absX, _absY) {
|
_moveHandle(absX, _absY) {
|
||||||
let relX, sliderX;
|
let relX, sliderX;
|
||||||
[sliderX] = this.get_transformed_position();
|
[sliderX] = this.get_transformed_position();
|
||||||
relX = absX - sliderX;
|
const rtl = this.get_text_direction() === Clutter.TextDirection.RTL;
|
||||||
|
|
||||||
let width = this._barLevelWidth;
|
let width = this._barLevelWidth;
|
||||||
|
|
||||||
|
relX = absX - sliderX;
|
||||||
|
if (rtl)
|
||||||
|
relX = width - relX;
|
||||||
|
|
||||||
let handleRadius = this.get_theme_node().get_length('-slider-handle-radius');
|
let handleRadius = this.get_theme_node().get_length('-slider-handle-radius');
|
||||||
|
|
||||||
let newvalue;
|
let newvalue;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user