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

[FEATURE_REQUEST] Auto dark/light theme #825

Closed
ghost opened this issue Jul 30, 2022 · 12 comments
Closed

[FEATURE_REQUEST] Auto dark/light theme #825

ghost opened this issue Jul 30, 2022 · 12 comments
Labels
🦄 Feature Request [ISSUE] Suggestion for new feature, update or change 🕸️ Inactive

Comments

@ghost
Copy link

ghost commented Jul 30, 2022

Is your feature request related to a problem? If so, please describe.

Using dashy in daytime with dark theme, it's look like uncomfortable, so can we switch theme automatically, that make our eyes healthy

Describe the solution you'd like

Set light theme and dark theme, and detected current operating system theme by browser, switch it automatic
Like vscode plugin Toggle Light/Dark Theme

Priority

Low (Nice-to-have)

Is this something you would be keen to implement

Yes!

@ghost ghost added the 🦄 Feature Request [ISSUE] Suggestion for new feature, update or change label Jul 30, 2022
@liss-bot
Copy link
Collaborator

If you're enjoying Dashy, consider dropping us a ⭐
🤖 I'm a bot, and this message was automated

@Lissy93
Copy link
Owner

Lissy93 commented Jul 30, 2022

Hiya @DaiYuANg

This is a nice idea 👍

I'm working on #799 at the moment, that includes refactoring the theme class.
So I'm going to wait until that's finished and merged before looking at this.


Possible Implementation

Could be done based on time of day, but user would need to specify times. And working with time is hard.

I'd probably keep it simple, and check if the users OS or browser is set to prefer-dark.
Most operating systems have the option to switch to dark mode at night, light at day, with custom times.

Then in the config, it'd the user could specify nightTheme and dayTheme instead of just theme.

Finally, in the code, we'd detect if browser / OS is set to dark or light, and apply the theme accordingly.

const prefersDark = window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches;
const theme = prefersDark ? appConfig.nightTheme : appConfig.dayTheme;

And if the user has specified a day / night theme, then in the UI could also show a "Quick Toggle" switch

@ghost
Copy link
Author

ghost commented Aug 10, 2022

Hi, I try to implement this issue last night, but the dev server is so slow, so I try to migrate to vite.
Unfortunately, I crash the project(I restored every changed I do). Are you planning to migrate to vue3 and vite?
This is a new question.

@liss-bot liss-bot added the 👤 Awaiting Maintainer Response [ISSUE] Response from repo author is pending label Aug 10, 2022
@Lissy93
Copy link
Owner

Lissy93 commented Aug 14, 2022

How were you running the dev server? I'm using yarn dev and there don't seem to be any performance issues.

But I wouldn't recommend working on this until the stuff in #799 is merged, as I've totally re-worked how all the theming is managed, it's in the REFACTOR/2.1.2_unified-config branch.

I'm happy to add the light/ dark theme feature, once I've got 2.1.2 finished and merged.

@liss-bot liss-bot removed the 👤 Awaiting Maintainer Response [ISSUE] Response from repo author is pending label Aug 14, 2022
@ghost
Copy link
Author

ghost commented Aug 14, 2022

I mean the compiled speed

I'm running a production version in my home server, and it's AMD 5600x. When I change something in my server config that waiting about 30s - 1minute for compile
I was run a development version in my laptop, and it's MacBook 14 version, I'm also using yarn for start dev server and backend server and when I change something that the situation seem like my home server.
However, when I develop on quasar framework that a vue3 framework, I can choose use webpack or vite on quasar-cli.
For vite version, start dev server only need 3s-5s, for webpack version, a new project started dev server need 10s-15s
It's not a vite advertisement ☻, but it's faster than vue-cli really.
Maybe the current performance is enough, I just want to make it batter one

@liss-bot liss-bot added the 👤 Awaiting Maintainer Response [ISSUE] Response from repo author is pending label Aug 14, 2022
@Lissy93
Copy link
Owner

Lissy93 commented Aug 14, 2022

I'm getting 0.4s server refresh time using yarn dev, and the changes are visible in the browser pretty much instantly on a 10 year old AMD FX-8350, so there's something not right there.

Yeah, Vue CLI isn't the fastest, your welcome to try switching to Vite ot upgrading, but I guess it will be more work than it's worth.

@liss-bot liss-bot removed the 👤 Awaiting Maintainer Response [ISSUE] Response from repo author is pending label Aug 14, 2022
@ghost
Copy link
Author

ghost commented Aug 14, 2022

I think your right, thanks for your answer

@ghost ghost closed this as completed Aug 14, 2022
@Lissy93 Lissy93 reopened this Aug 14, 2022
@liss-bot
Copy link
Collaborator

This issue has gone 6 weeks without an update. To keep the ticket open, please indicate that it is still relevant in a comment below. Otherwise it will be closed in 5 working days.

@liss-bot liss-bot added the ⚰️ Stale [ISSUE] [PR] No activity for over 1 month label Sep 14, 2022
@liss-bot
Copy link
Collaborator

This issue was automatically closed because it has been stalled for over 6 weeks with no activity.

@liss-bot liss-bot removed the ⚰️ Stale [ISSUE] [PR] No activity for over 1 month label Sep 20, 2022
@gadelkareem
Copy link

Any updates on this one?

@Lissy93 Lissy93 reopened this Dec 28, 2023
vishwamartur added a commit to vishwamartur/dashy that referenced this issue Dec 17, 2024
Related to Lissy93#825

Add automatic theme switching based on OS preference

* Add logic in `src/mixins/ThemingMixin.js` to detect OS theme preference using `window.matchMedia`.
* Update `initializeTheme` method in `src/mixins/ThemingMixin.js` to set theme based on OS preference.
* Modify `applyLocalTheme` method in `src/mixins/ThemingMixin.js` to apply the detected theme dynamically.
* Include logic in `src/App.vue` to detect and apply theme based on OS preference during app initialization.
@liss-bot
Copy link
Collaborator

This issue has gone 3 months without an update. To keep the ticket open, please indicate that it is still relevant in a comment below. Otherwise it will be closed in 5 working days.

@liss-bot liss-bot added the ⚰️ Stale [ISSUE] [PR] No activity for over 1 month label Dec 23, 2024
@liss-bot
Copy link
Collaborator

This issue was automatically closed because it has been stalled for over 1 year with no activity.

@liss-bot liss-bot removed the ⚰️ Stale [ISSUE] [PR] No activity for over 1 month label Dec 29, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🦄 Feature Request [ISSUE] Suggestion for new feature, update or change 🕸️ Inactive
Projects
None yet
Development

No branches or pull requests

3 participants