Skip to content

Commit

Permalink
Handle custom selectors in dark mode query re #11624
Browse files Browse the repository at this point in the history
  • Loading branch information
jacobtylerwalls committed Dec 3, 2024
1 parent 3050821 commit ce61abe
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 12 deletions.
15 changes: 13 additions & 2 deletions arches/app/media/js/utils/create-vue-application.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import { createGettext } from "vue3-gettext";
import arches from 'arches';
import { DEFAULT_THEME } from "@/arches/themes/default.ts";

export default async function createVueApplication(vueComponent, themeConfiguration) {
export default async function createVueApplication(vueComponent, themeConfiguration = DEFAULT_THEME) {
/**
* This wrapper allows us to maintain a level of control inside arches-core
* over Vue apps. For instance this allows us to abstract i18n setup/config
Expand All @@ -40,8 +40,19 @@ export default async function createVueApplication(vueComponent, themeConfigurat
});

const app = createApp(vueComponent);
const darkModeClass = themeConfiguration.theme.options.darkModeSelector.substring(1);
const darkModeStorageKey = `arches.${darkModeClass}`;

app.use(PrimeVue, themeConfiguration || DEFAULT_THEME);
const darkModeToggleState = localStorage.getItem(darkModeStorageKey);
if (
darkModeToggleState === "true" ||
(darkModeToggleState === null &&
window.matchMedia("(prefers-color-scheme: dark)").matches)
) {
document.documentElement.classList.add(darkModeClass);
}

app.use(PrimeVue, themeConfiguration);
app.use(gettext);
app.use(ConfirmationService);
app.use(DialogService);
Expand Down
10 changes: 0 additions & 10 deletions arches/app/templates/base-root.htm
Original file line number Diff line number Diff line change
Expand Up @@ -35,16 +35,6 @@
gtag('config', '{{app_settings.GOOGLE_ANALYTICS_TRACKING_ID}}');
</script>
{% endif %}
<script>
const darkModeToggleState = localStorage.getItem("arches-dark");
if (
darkModeToggleState === "true" ||
(darkModeToggleState === null &&
window.matchMedia("(prefers-color-scheme: dark)").matches)
) {
document.documentElement.classList.add("arches-dark");
}
</script>
<title>
{% block title %}{% endblock title %}
</title>
Expand Down

0 comments on commit ce61abe

Please sign in to comment.