[gnome-shell/wip/carlosg/osk-updates: 2/2] keyboard: Change page switching animation in emoji picker
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-shell/wip/carlosg/osk-updates: 2/2] keyboard: Change page switching animation in emoji picker
- Date: Thu, 30 Jun 2022 10:10:42 +0000 (UTC)
commit 64a8277b2acadea3642c547effe36563d3905a4e
Author: Carlos Garnacho <carlosg gnome org>
Date: Wed Jun 29 20:26:27 2022 +0200
keyboard: Change page switching animation in emoji picker
Use a carousel animation to switch pages, and set up the emoji
picker to have the system text direction so that coordinate
flipping is mostly done for us in RTL.
Closes: https://gitlab.gnome.org/GNOME/gnome-shell/-/issues/5616
js/ui/keyboard.js | 26 +++++++++++---------------
1 file changed, 11 insertions(+), 15 deletions(-)
---
diff --git a/js/ui/keyboard.js b/js/ui/keyboard.js
index 838ad40f4f..f1a5c0017b 100644
--- a/js/ui/keyboard.js
+++ b/js/ui/keyboard.js
@@ -698,18 +698,13 @@ var EmojiPager = GObject.registerClass({
}
set delta(value) {
- if (value > this._width)
- value = this._width;
- else if (value < -this._width)
- value = -this._width;
-
+ value = Math.clamp(value, -this.width, this.width);
if (this._delta == value)
return;
this._delta = value;
this.notify('delta');
- let relValue = Math.abs(value / this._width);
let followingPage = this.getFollowingPage();
if (this._followingPage != followingPage) {
@@ -720,21 +715,22 @@ var EmojiPager = GObject.registerClass({
if (followingPage != null) {
this._followingPanel = this._generatePanel(followingPage);
- this._followingPanel.set_pivot_point(0.5, 0.5);
this.add_child(this._followingPanel);
- this.set_child_below_sibling(this._followingPanel, this._panel);
}
this._followingPage = followingPage;
}
- this._panel.translation_x = value;
- this._panel.opacity = 255 * (1 - Math.pow(relValue, 3));
+ const multiplier = this.text_direction === Clutter.TextDirection.RTL
+ ? -1 : 1;
+ this._panel.translation_x = value * multiplier;
if (this._followingPanel) {
- this._followingPanel.scale_x = 0.8 + (0.2 * relValue);
- this._followingPanel.scale_y = 0.8 + (0.2 * relValue);
- this._followingPanel.opacity = 255 * relValue;
+ const translation = value < 0
+ ? this._width : -this._width;
+
+ this._followingPanel.translation_x =
+ (value * multiplier) + (translation * multiplier);
}
}
@@ -750,8 +746,7 @@ var EmojiPager = GObject.registerClass({
if (this.delta == 0)
return null;
- if ((this.delta < 0 && global.stage.text_direction == Clutter.TextDirection.LTR) ||
- (this.delta > 0 && global.stage.text_direction == Clutter.TextDirection.RTL))
+ if (this.delta < 0)
return this._nextPage(this._curPage);
else
return this._prevPage(this._curPage);
@@ -943,6 +938,7 @@ var EmojiSelection = GObject.registerClass({
style_class: 'emoji-panel',
x_expand: true,
y_expand: true,
+ text_direction: global.stage.text_direction,
});
this._sections = [
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]