Compare commits

..

No commits in common. "main" and "tsukasa-2" have entirely different histories.

4 changed files with 8 additions and 36 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 475 KiB

After

Width:  |  Height:  |  Size: 321 KiB

View File

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

Binary file not shown.

Before

Width:  |  Height:  |  Size: 487 KiB

After

Width:  |  Height:  |  Size: 335 KiB

View File

@ -499,8 +499,7 @@ static void set_active_chip(MoeMojiWindow *self, int index) {
} }
} }
static void scroll_chip_into_view(G_GNUC_UNUSED MoeMojiWindow *self, static void scroll_chip_into_view(MoeMojiWindow *self, GtkWidget *chip) {
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;
@ -537,13 +536,7 @@ 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);
graphene_point_t p; scroll_to_category(self, (int)i);
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;
} }
} }
@ -945,7 +938,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_opacity(active, 0); gtk_widget_set_visible(active, FALSE);
g_object_set_data(G_OBJECT(chip_box), "active-drop-sep", NULL); g_object_set_data(G_OBJECT(chip_box), "active-drop-sep", NULL);
} }
} }
@ -963,7 +956,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_opacity(sep, 1); gtk_widget_set_visible(sep, TRUE);
g_object_set_data(G_OBJECT(chip_box), "active-drop-sep", sep); g_object_set_data(G_OBJECT(chip_box), "active-drop-sep", sep);
} }
} }
@ -1199,8 +1192,7 @@ 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_opacity(sep, 0); gtk_widget_set_visible(sep, FALSE);
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) {
@ -1215,8 +1207,7 @@ 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_opacity(tail, 0); gtk_widget_set_visible(tail, FALSE);
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);
} }
@ -1815,31 +1806,12 @@ 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");
} }