generated from nhcarrigan/template
377f81d978
### Explanation _No response_ ### Issue Closes #26 Closes #27 ### Attestations - [ ] I have read and agree to the [Code of Conduct](https://docs.nhcarrigan.com/community/coc/) - [ ] I have read and agree to the [Community Guidelines](https://docs.nhcarrigan.com/community/guide/). - [ ] My contribution complies with the [Contributor Covenant](https://docs.nhcarrigan.com/dev/covenant/). ### Dependencies - [ ] I have pinned the dependencies to a specific patch version. ### Style - [ ] I have run the linter and resolved any errors. - [ ] My pull request uses an appropriate title, matching the conventional commit standards. - [ ] My scope of feat/fix/chore/etc. correctly matches the nature of changes in my pull request. ### Tests - [ ] My contribution adds new code, and I have added tests to cover it. - [ ] My contribution modifies existing code, and I have updated the tests to reflect these changes. - [ ] All new and existing tests pass locally with my changes. - [ ] Code coverage remains at or above the configured threshold. ### Documentation _No response_ ### Versioning _No response_ Reviewed-on: #48 Co-authored-by: Naomi Carrigan <commits@nhcarrigan.com> Co-committed-by: Naomi Carrigan <commits@nhcarrigan.com>
24 lines
650 B
TypeScript
24 lines
650 B
TypeScript
import { configStore } from "./config";
|
|
import { soundPlayer } from "$lib/notifications";
|
|
|
|
let unsubscribe: (() => void) | null = null;
|
|
|
|
// Initialize notification settings sync - call this once on app startup
|
|
export function initNotificationSync() {
|
|
// Prevent duplicate subscriptions
|
|
if (unsubscribe) return;
|
|
|
|
unsubscribe = configStore.config.subscribe(($config) => {
|
|
soundPlayer.setEnabled($config.notifications_enabled);
|
|
soundPlayer.setGlobalVolume($config.notification_volume);
|
|
});
|
|
}
|
|
|
|
// Cleanup function if needed
|
|
export function cleanupNotificationSync() {
|
|
if (unsubscribe) {
|
|
unsubscribe();
|
|
unsubscribe = null;
|
|
}
|
|
}
|