Adding new screenshots.

This commit is contained in:
Sergiotarxz 2024-11-27 17:33:37 +01:00
parent 9b253d3f30
commit 3de6ac7fef
14 changed files with 76 additions and 50 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 18 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 28 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 33 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 37 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 33 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 20 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 35 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 52 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 67 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 52 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 34 KiB

View File

@ -45,11 +45,11 @@ has app => ( is => 'ro' );
has _kanji => ( is => 'lazy' ); has _kanji => ( is => 'lazy' );
sub _build__kanji($self) { sub _build__kanji($self) {
return JapaChar::Kanji->new(app => JapaChar->new); return JapaChar::Kanji->new( app => JapaChar->new );
} }
sub run($self) { sub run($self) {
if (!$self->_kanji->migrated) { if ( !$self->_kanji->migrated ) {
$self->_migrate_kanji; $self->_migrate_kanji;
return; return;
} }
@ -67,16 +67,19 @@ sub _migrate_kanji($self) {
$box->append($label); $box->append($label);
$box->append($progress_bar); $box->append($progress_bar);
$self->app->window_set_child($box); $self->app->window_set_child($box);
my ($read, $write); my ( $read, $write );
pipe $read, $write; pipe $read, $write;
my $parent_pid = $$; my $parent_pid = $$;
my $pid = fork; my $pid = fork;
if (!$pid) {
$self->_kanji->populate_kanji($parent_pid, $write); if ( !$pid ) {
$self->_kanji->populate_kanji( $parent_pid, $write );
exit; exit;
} }
my $n_characters; my $n_characters;
Glib::Timeout->add(1_000, sub { Glib::Timeout->add(
1_000,
sub {
$n_characters = <$read>; $n_characters = <$read>;
chomp $n_characters; chomp $n_characters;
say 'Copying ' . $n_characters . ' kanji'; say 'Copying ' . $n_characters . ' kanji';
@ -86,13 +89,14 @@ sub _migrate_kanji($self) {
$read->blocking(0); $read->blocking(0);
my $last_number; my $last_number;
my $line; my $line;
while ($line = <$read>) { while ( $line = <$read> ) {
$last_number = $line; $last_number = $line;
} }
if ($last_number) { if ($last_number) {
$progress_bar->set_fraction($last_number / $n_characters); $progress_bar->set_fraction(
$last_number / $n_characters );
} }
if (0 == waitpid $pid, WNOHANG) { if ( 0 == waitpid $pid, WNOHANG ) {
return 1; return 1;
} }
$self->_select_kanji; $self->_select_kanji;
@ -100,7 +104,8 @@ sub _migrate_kanji($self) {
} }
); );
return 0; return 0;
}); }
);
} }
sub _select_kanji($self) { sub _select_kanji($self) {
@ -117,39 +122,60 @@ sub _select_kanji($self) {
my $discord = Gtk::Button->new_with_label('Report bugs and share feedback'); my $discord = Gtk::Button->new_with_label('Report bugs and share feedback');
$discord->signal_connect(clicked => sub { $discord->signal_connect(
clicked => sub {
$self->app->launch_discord; $self->app->launch_discord;
}); }
);
$discord->add_css_class('destructive-action'); $discord->add_css_class('destructive-action');
$discord->set_halign('center'); $discord->set_halign('center');
my $label = Gtk::Label->new(
'This feature is in BETA and will become for paid users when stabilized.
Your kanji progress until stabilized may be lost between updates because
the processing of Kanji may vary wildly.'
);
$box->append(Gtk::Label->new('This feature is in BETA and will become for paid users when stabilized, your kanji progress until stabilized may be lost between updates because the processing of Kanji may vary wildly.')); $label->set_margin_top(20);
$box->append($label);
my $button = Gtk::Button->new_with_label("Study everything ordered by grade"); my $button =
$button->signal_connect(clicked => sub { Gtk::Button->new_with_label("Study everything ordered by grade");
JapaChar::View::KanjiLesson->new(app => $self->app)->run; $button->signal_connect(
}); clicked => sub {
JapaChar::View::KanjiLesson->new( app => $self->app )->run;
}
);
$button->set_margin_top(20); $button->set_margin_top(20);
$button->add_css_class('accent'); $button->add_css_class('accent');
$button->set_halign('center'); $button->set_halign('center');
$button->set_property('width-request', 330); $button->set_property( 'width-request', 330 );
$box->append($button); $box->append($button);
for my $grade (@$grades) { for my $grade (@$grades) {
my $button = Gtk::Button->new_with_label("Study kanji grade $grade"); my $button = Gtk::Button->new_with_label("Study kanji grade $grade");
$button->signal_connect(clicked => sub { $button->signal_connect(
JapaChar::View::KanjiLesson->new(app => $self->app, type => $grade)->run; clicked => sub {
}); JapaChar::View::KanjiLesson->new(
app => $self->app,
type => $grade
)->run;
}
);
$button->set_halign('center'); $button->set_halign('center');
$button->set_property('width-request', 330); $button->set_property( 'width-request', 330 );
$box->append($button); $box->append($button);
} }
$button = Gtk::Button->new_with_label("Study unclassified kanjis"); $button = Gtk::Button->new_with_label("Study unclassified kanjis");
$button->signal_connect(clicked => sub { $button->signal_connect(
JapaChar::View::KanjiLesson->new(app => $self->app, type => undef)->run; clicked => sub {
}); JapaChar::View::KanjiLesson->new(
$button->set_property('width-request', 330); app => $self->app,
type => undef
)->run;
}
);
$button->set_property( 'width-request', 330 );
$button->set_halign('center'); $button->set_halign('center');
$box->append($button); $box->append($button);
$box->append($discord); $box->append($discord);