Adding new screenshots.
Before Width: | Height: | Size: 18 KiB |
Before Width: | Height: | Size: 28 KiB |
Before Width: | Height: | Size: 33 KiB |
Before Width: | Height: | Size: 37 KiB |
Before Width: | Height: | Size: 33 KiB |
Before Width: | Height: | Size: 20 KiB |
BIN
Screenshot from 2024-11-27 17-27-10.png
Normal file
After Width: | Height: | Size: 36 KiB |
BIN
Screenshot from 2024-11-27 17-28-21.png
Normal file
After Width: | Height: | Size: 35 KiB |
BIN
Screenshot from 2024-11-27 17-28-35.png
Normal file
After Width: | Height: | Size: 52 KiB |
BIN
Screenshot from 2024-11-27 17-31-28.png
Normal file
After Width: | Height: | Size: 67 KiB |
BIN
Screenshot from 2024-11-27 17-31-46.png
Normal file
After Width: | Height: | Size: 52 KiB |
BIN
Screenshot from 2024-11-27 17-31-53.png
Normal file
After Width: | Height: | Size: 36 KiB |
BIN
Screenshot from 2024-11-27 17-32-18.png
Normal file
After Width: | Height: | Size: 34 KiB |
@ -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);
|
||||||
|