Compare commits

...

5 Commits

Author SHA1 Message Date
6bd53de20c update preview 2026-03-08 01:29:16 +03:00
f921042824 bump manifest tag 2026-03-08 00:59:55 +03:00
2a0d0c75bf fixed another bug with reordering 2026-03-08 00:59:13 +03:00
60fc6ca5fc bump manifest tag 2026-03-08 00:33:43 +03:00
2915d7d5b4 fix sidebar jitter for real this time 2026-03-08 00:32:56 +03:00
4 changed files with 36 additions and 8 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 321 KiB

After

Width:  |  Height:  |  Size: 475 KiB

View File

@ -17,8 +17,8 @@
"sources": [ "sources": [
{ {
"type": "archive", "type": "archive",
"url": "https://gitea.angeltech.jp/Angel-Technologies/MoeMoji/archive/v0.3.1.tar.gz", "url": "https://gitea.angeltech.jp/Angel-Technologies/MoeMoji/archive/v0.3.3.tar.gz",
"sha256": "500bed5eafea7a2cc40b4833dc733434fcc9335010b90627e5e41ce45275edf7" "sha256": "3a002f44bd571f5f5e9f1be0abf9c2395bc14ff831531b3939a71524323cc576"
} }
] ]
} }

Binary file not shown.

Before

Width:  |  Height:  |  Size: 335 KiB

After

Width:  |  Height:  |  Size: 487 KiB

View File

@ -499,7 +499,8 @@ static void set_active_chip(MoeMojiWindow *self, int index) {
} }
} }
static void scroll_chip_into_view(MoeMojiWindow *self, GtkWidget *chip) { static void scroll_chip_into_view(G_GNUC_UNUSED MoeMojiWindow *self,
GtkWidget *chip) {
GtkWidget *sw = gtk_widget_get_ancestor(chip, GTK_TYPE_SCROLLED_WINDOW); GtkWidget *sw = gtk_widget_get_ancestor(chip, GTK_TYPE_SCROLLED_WINDOW);
if (!sw) if (!sw)
return; return;
@ -536,7 +537,13 @@ static void on_chip_clicked(GtkButton *button, gpointer user_data) {
CategoryWidgets *cw = g_ptr_array_index(self->category_widgets, i); CategoryWidgets *cw = g_ptr_array_index(self->category_widgets, i);
if (cw->chip == GTK_WIDGET(button)) { if (cw->chip == GTK_WIDGET(button)) {
set_active_chip(self, (int)i); set_active_chip(self, (int)i);
scroll_to_category(self, (int)i); graphene_point_t p;
if (gtk_widget_compute_point(cw->header, GTK_WIDGET(self->content_box),
&GRAPHENE_POINT_INIT(0, 0), &p)) {
GtkAdjustment *vadj = gtk_scrolled_window_get_vadjustment(
GTK_SCROLLED_WINDOW(self->kaomoji_scroll));
gtk_adjustment_set_value(vadj, p.y);
}
return; return;
} }
} }
@ -938,7 +945,7 @@ static void on_chip_drag_begin(GtkDragSource *source,
static void clear_drop_indicator(GtkWidget *chip_box) { static void clear_drop_indicator(GtkWidget *chip_box) {
GtkWidget *active = g_object_get_data(G_OBJECT(chip_box), "active-drop-sep"); GtkWidget *active = g_object_get_data(G_OBJECT(chip_box), "active-drop-sep");
if (active) { if (active) {
gtk_widget_set_visible(active, FALSE); gtk_widget_set_opacity(active, 0);
g_object_set_data(G_OBJECT(chip_box), "active-drop-sep", NULL); g_object_set_data(G_OBJECT(chip_box), "active-drop-sep", NULL);
} }
} }
@ -956,7 +963,7 @@ static void show_drop_indicator(GtkWidget *chip, double y) {
else else
sep = g_object_get_data(G_OBJECT(chip), "drop-sep-after"); sep = g_object_get_data(G_OBJECT(chip), "drop-sep-after");
if (sep) { if (sep) {
gtk_widget_set_visible(sep, TRUE); gtk_widget_set_opacity(sep, 1);
g_object_set_data(G_OBJECT(chip_box), "active-drop-sep", sep); g_object_set_data(G_OBJECT(chip_box), "active-drop-sep", sep);
} }
} }
@ -1192,7 +1199,8 @@ static void reload_categories(MoeMojiWindow *self) {
GtkWidget *sep = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); GtkWidget *sep = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0);
gtk_widget_add_css_class(sep, "chip-drop-line"); gtk_widget_add_css_class(sep, "chip-drop-line");
gtk_widget_set_size_request(sep, -1, 2); gtk_widget_set_size_request(sep, -1, 2);
gtk_widget_set_visible(sep, FALSE); gtk_widget_set_opacity(sep, 0);
gtk_widget_set_can_target(sep, FALSE);
gtk_box_append(GTK_BOX(chip_box), sep); gtk_box_append(GTK_BOX(chip_box), sep);
g_object_set_data(G_OBJECT(btn), "drop-sep-before", sep); g_object_set_data(G_OBJECT(btn), "drop-sep-before", sep);
if (i > 0) { if (i > 0) {
@ -1207,7 +1215,8 @@ static void reload_categories(MoeMojiWindow *self) {
GtkWidget *tail = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); GtkWidget *tail = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0);
gtk_widget_add_css_class(tail, "chip-drop-line"); gtk_widget_add_css_class(tail, "chip-drop-line");
gtk_widget_set_size_request(tail, -1, 2); gtk_widget_set_size_request(tail, -1, 2);
gtk_widget_set_visible(tail, FALSE); gtk_widget_set_opacity(tail, 0);
gtk_widget_set_can_target(tail, FALSE);
gtk_box_append(GTK_BOX(chip_box), tail); gtk_box_append(GTK_BOX(chip_box), tail);
g_object_set_data(G_OBJECT(btn), "drop-sep-after", tail); g_object_set_data(G_OBJECT(btn), "drop-sep-after", tail);
} }
@ -1806,12 +1815,31 @@ static void on_reset_kaomojis(G_GNUC_UNUSED GSimpleAction *action,
self); self);
} }
static void reset_chip_controllers(MoeMojiWindow *self) {
for (guint i = 0; i < self->category_widgets->len; i++) {
CategoryWidgets *cw = g_ptr_array_index(self->category_widgets, i);
if (!cw->chip)
continue;
GListModel *controllers = gtk_widget_observe_controllers(cw->chip);
guint n = g_list_model_get_n_items(controllers);
for (guint j = 0; j < n; j++) {
GtkEventController *c = g_list_model_get_item(controllers, j);
if (GTK_IS_DRAG_SOURCE(c) || GTK_IS_DROP_TARGET(c))
gtk_event_controller_reset(c);
g_object_unref(c);
}
g_object_unref(controllers);
}
}
static void on_sidebar_toggled(GtkToggleButton *toggle, gpointer user_data) { static void on_sidebar_toggled(GtkToggleButton *toggle, gpointer user_data) {
MoeMojiWindow *self = MOEMOJI_WINDOW(user_data); MoeMojiWindow *self = MOEMOJI_WINDOW(user_data);
gboolean active = gtk_toggle_button_get_active(toggle); gboolean active = gtk_toggle_button_get_active(toggle);
GtkWidget *start = gtk_paned_get_start_child(self->paned); GtkWidget *start = gtk_paned_get_start_child(self->paned);
if (start) if (start)
gtk_widget_set_visible(start, active); gtk_widget_set_visible(start, active);
if (active)
reset_chip_controllers(self);
gtk_button_set_icon_name(GTK_BUTTON(toggle), gtk_button_set_icon_name(GTK_BUTTON(toggle),
active ? "pan-start-symbolic" : "pan-end-symbolic"); active ? "pan-start-symbolic" : "pan-end-symbolic");
} }