| | | 1 | | <div class="settings-section"> |
| | | 2 | | <h2>Timer Durations</h2> |
| | | 3 | | |
| | | 4 | | <div class="setting-item"> |
| | | 5 | | <div class="setting-label"> |
| | | 6 | | <span class="setting-icon">🍅</span> |
| | | 7 | | <span class="setting-name">Pomodoro</span> |
| | | 8 | | </div> |
| | | 9 | | <input type="number" class="setting-input" @bind="Settings.PomodoroMinutes" @bind:after="NotifyChanged" min="1" |
| | | 10 | | </div> |
| | | 11 | | |
| | | 12 | | <div class="setting-item"> |
| | | 13 | | <div class="setting-label"> |
| | | 14 | | <span class="setting-icon">☕</span> |
| | | 15 | | <span class="setting-name">Short Break</span> |
| | | 16 | | </div> |
| | | 17 | | <input type="number" class="setting-input" @bind="Settings.ShortBreakMinutes" @bind:after="NotifyChanged" min="1 |
| | | 18 | | </div> |
| | | 19 | | |
| | | 20 | | <div class="setting-item"> |
| | | 21 | | <div class="setting-label"> |
| | | 22 | | <span class="setting-icon">🏖️</span> |
| | | 23 | | <span class="setting-name">Long Break</span> |
| | | 24 | | </div> |
| | | 25 | | <input type="number" class="setting-input" @bind="Settings.LongBreakMinutes" @bind:after="NotifyChanged" min="1" |
| | | 26 | | </div> |
| | | 27 | | </div> |
| | | 28 | | |
| | | 29 | | @code { |
| | | 30 | | [Parameter] |
| | 1900 | 31 | | public TimerSettings Settings { get; set; } = default!; |
| | | 32 | | |
| | | 33 | | [Parameter] |
| | 178 | 34 | | public EventCallback OnChanged { get; set; } |
| | | 35 | | |
| | 4 | 36 | | private async Task NotifyChanged() => await OnChanged.InvokeAsync(); |
| | | 37 | | } |