-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
⚗️ [#2583] Reordered notifications order + forced focus on 1st element
- Loading branch information
1 parent
6389a61
commit 018744c
Showing
8 changed files
with
133 additions
and
18 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
48 changes: 48 additions & 0 deletions
48
src/open_inwoner/js/components/notifications/NotificationsList.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
/** | ||
* Surrounding Notifications class. | ||
* @class | ||
*/ | ||
export class NotificationsList { | ||
static selector = '.notifications' | ||
constructor(notificationContents) { | ||
this.notificationContents = notificationContents | ||
} | ||
|
||
scrollToFirstNotification() { | ||
if (this.notificationContents.length > 0) { | ||
// Log before the timeout starts | ||
console.log( | ||
'Scrolling to first notification and setting a timeout to focus.' | ||
) | ||
|
||
// Scroll to the first notification | ||
this.notificationContents[0].scrollIntoView({ | ||
block: 'center', | ||
behavior: 'smooth', | ||
}) | ||
|
||
// Add a delay before setting focus for screen readers | ||
setTimeout(() => { | ||
// Set focus on the first notification content | ||
this.notificationContents[0].focus() | ||
|
||
// Log after the timeout completes | ||
console.log('Focus set on the first notification content.') | ||
}, 100) // Adjust the delay as necessary | ||
} | ||
} | ||
} | ||
|
||
// Start! | ||
|
||
// Select all notification contents | ||
const notificationContents = document.querySelectorAll('.notification__content') | ||
|
||
// Create instances of NotificationsList for each matching element in the NodeList | ||
document | ||
.querySelectorAll(NotificationsList.selector) | ||
.forEach((notifications) => new NotificationsList(notifications)) | ||
|
||
// Create ScrollManager instance and focus the first notification content | ||
const scrollManager = new NotificationsList(notificationContents) | ||
scrollManager.scrollToFirstNotification() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters