Skip to content

[[email protected]] Make Pomodoro completion more obvious. #6545

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Draft
wants to merge 1 commit into
base: master
Choose a base branch
from
Draft
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
122 changes: 105 additions & 17 deletions [email protected]/files/[email protected]/applet.js
Original file line number Diff line number Diff line change
Expand Up @@ -375,14 +375,21 @@ class PomodoroApplet extends Applet.TextIconApplet {
this._pomodoroFinishedDialog.open();
}
}
else if (!this._opt_autoContinueAfterShortBreak && timer === pomodoroTimer) {
timerQueue.preventStart(true);
timerQueue.stop();
this._appletMenu.toggleTimerState(false);
this._setAppletTooltip(0);
if (this._opt_showDialogMessages) {
this._playStartSound();
this._shortBreakdialog.open();
else if (timer === pomodoroTimer) {
// Close any short break dialog if we auto-continue once
// the break is over.
if (this._opt_autoContinueAfterShortBreak) {
if (this._shortBreakdialog.state == ModalDialog.State.OPENED)
this._shortBreakdialog.close();
} else {
timerQueue.preventStart(true);
timerQueue.stop();
this._appletMenu.toggleTimerState(false);
this._setAppletTooltip(0);
if (this._opt_showDialogMessages) {
this._playStartSound();
this._shortBreakdialog.open();
}
}
}
});
Expand Down Expand Up @@ -415,14 +422,19 @@ class PomodoroApplet extends Applet.TextIconApplet {
// connect the short break timer signals

shortBreakTimer.connect('timer-tick', this._timerTickUpdate.bind(this));

shortBreakTimer.connect('timer-tick', this._shortBreakdialog.setTimeRemaining.bind(this._shortBreakdialog));

shortBreakTimer.connect('timer-started', () => {
this._setCurrentState('short-break');
this._playBreakSound();
if (this._opt_showDialogMessages) {
this._shortBreakdialog.open();
} else {
Main.notify(_("Take a short break"));
}
this._numPomodoriFinished++;
this._appletMenu.updateCounts(this._numPomodoroSetFinished, this._numPomodoriFinished);
this._appletMenu.showPomodoroInProgress(this._opt_pomodoriNumber);
Main.notify(_("Take a short break"));
if (this._opt_enableScripts && this._opt_customShortBreakScript) {
this._checkAndExecuteCustomScript(this._opt_customShortBreakScript);
}
Expand Down Expand Up @@ -645,14 +657,32 @@ class PomodoroApplet extends Applet.TextIconApplet {

_createShortBreakDialog() {
this._shortBreakdialog = new PomodoroShortBreakFinishedDialog();

this._shortBreakdialog.connect('continue-current-pomodoro', () => {

this._shortBreakdialog.connect('take-break', () => {
this._shortBreakdialog.close();
});

this._shortBreakdialog.connect('skip-break', () => {
this._timerQueue.skip();
this._shortBreakdialog.close();
this._timerQueue.preventStart(false);
this._appletMenu.toggleTimerState(true);
this._timerQueue.start();
});


this._shortBreakdialog.connect('pause-pomodoro', () => {
this._timerQueue.stop();
this._appletMenu.toggleTimerState(false);
this._shortBreakdialog.close();
});

this._shortBreakdialog.connect('start-next-pomodoro', () => {
this._shortBreakdialog.close();
this._timerQueue.preventStart(false);
this._appletMenu.toggleTimerState(true);
this._timerQueue.start();
});

this._shortBreakdialog.connect('pause-pomodoro', () => {
this._timerQueue.stop();
this._appletMenu.toggleTimerState(false);
Expand Down Expand Up @@ -915,11 +945,26 @@ class PomodoroShortBreakFinishedDialog extends ModalDialog.ModalDialog {
this._timeLabel = new St.Label();
this.contentLayout.add(this._timeLabel);

this.reset();
}

close() {
super.close();
this.reset();
}

reset() {
this.setButtons([
{
label: _("Continue Current Pomodoro"),
label: _("Take Break"),
action: () => {
this.emit('continue-current-pomodoro');
this.emit('take-break');
}
},
{
label: _("Skip Break"),
action: () => {
this.emit('skip-break');
}
},
{
Expand All @@ -930,13 +975,56 @@ class PomodoroShortBreakFinishedDialog extends ModalDialog.ModalDialog {
}
]);

this.setDefaultLabels();
this._subjectLabel.set_text(_("Pomodoro finished, take a short break?") + "\n");
this._timeLabel.text = '';
}

setDefaultLabels() {
finished() {
this.setButtons([
{
label: _("Start Next Pomodoro"),
action: () => {
this.emit('start-next-pomodoro');
}
},
{
label: _("Pause Pomodoro"),
action: () => {
this.emit('pause-pomodoro');
}
}
]);

this._subjectLabel.set_text(_("Short break finished, ready to continue?") + "\n");
this._timeLabel.text = '';
}

setTimeRemaining(timer) {
let tickCount = timer.getTicksRemaining();

if (tickCount === 0) {
this.finished();
return;
}

// Update the time label text based on the time remaining
this._setTimeLabelText(_("A new pomodoro begins in %s.").format(this._getTimeString(tickCount)));
}

_setTimeLabelText(label) {
this._timeLabel.set_text(label + "\n");
}

_getTimeString(totalSeconds) {
// Convert total seconds to minutes and seconds
let minutes = parseInt(totalSeconds / 60);
let seconds = parseInt(totalSeconds % 60);

let min = Gettext.dngettext(UUID, "%d minute", "%d minutes", minutes).format(minutes);
let sec = Gettext.dngettext(UUID, "%d second", "%d seconds", seconds).format(seconds);

return _("%s and %s").format(min, sec);
}
}

class PomodoroFinishedDialog extends ModalDialog.ModalDialog {
Expand Down