Skip to content
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

Custom hours daily #1091

Closed
wants to merge 5 commits into from
Closed

Conversation

Rameen260
Copy link

@Rameen260 Rameen260 commented Dec 10, 2024

Related issue

Closes #1077

Context / Background

Issue Description:
Describe the current limitation
In the current state you can choose days in the preferences and choose hours per day (for all days).

Describe the proposed feature or enhancement
Add option to choose hours per day for every day.
For example for days: Sun, Tue, Thu set hours-per-day to 10:15 and for Mon, Wed set hours-per-day to 11:45.

What change is being introduced by this PR?

- What changes did you make to achieve the goal? / How did you approach this problem?

  • Added a new section in the preferences.html/preferences.js page for "Hours per day" that dynamically displays inputs for working hours based on selected weekdays.
  • Also ensured that the new section is compatible and functional with the translation system set in place
  • Updated the parameters in user-preferences.js, then updated the logic in:

BaseCalender.js
FlexibleDayCalender.js
FlexibleMonthCalender.js
time-balance.js

to use these new params, and calculate the time to leave using the new daily hours

If the user works Mon-Fri:
image

If the user works on Mon and Fri:
image

- What are the indirect and direct consequences of the change?
Direct Consequences:

  • The "Hours per day" section dynamically adjusts to display inputs for the selected working days. This enables users to set specific working hours for each day.
  • Users now have greater flexibility to customize their preferences, improving the overall usability.

Indirect Consequence:
As a result one test case from "npm run test:jest" is failing, this is based on the old logic, where hours per day was a single value, So it was bound to fail, this needs to be updated in the case this issue is resolved.
image

How will this be tested?

- How will you verify whether your changes worked as expected once merged?

  • As of now it is functional, once merged, manual testing of the "Hours per day" section can be done to verify that inputs are displayed, updated, and saved correctly.
  • Additionally, the old logic's unit test can be updated to ensure this functionality is working with future updates.

  • I confirm I'm a native or fluent speaker of the language I'm translating to.

@tupaschoal
Copy link
Collaborator

Hi @Rameen260,

This is a major feature update on the app which we need to discuss how best to implement it first, as outlined in the mentioned issue. Thus, I'm closing the PR, here are a few additional reasons:

  1. This is a mode we're not sure we want to support/maintain yet, as it adds considerable complexity to the app
  2. The implementation suggested was not discussed first. I think it does not provide the best value in terms of user experience. I'd say an obvious improvement would be showing the time pickers for each day under the actual day on the "working days" section, not creating another section.
  3. We cannot take such a comprehensive change without adding unit tests
  4. We were in the middle of heavily updating the code and tests to refactor some stuff and it now requires a lot of merge conflict resolution.

Thanks for your effort! We can keep discussing in the issue if you feel like it.

@tupaschoal tupaschoal closed this Jan 3, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Customize hours per day
2 participants