mirror of
https://github.com/discourse/discourse.git
synced 2025-01-16 06:42:41 +08:00
DEV: Display feedback in the Glimmer post menu on iOS / iPadOS devices (#30594)
This commit introduces a workaround for a behavior observed in Safari for iOS / iPadOS where the feedback message wasn't being displayed after clicking on the copy button in the Glimmer post menu
This commit is contained in:
parent
9b4dfbbbfe
commit
7fd2fb6b85
|
@ -1,3 +1,4 @@
|
|||
import { next } from "@ember/runloop";
|
||||
import { SVG_NAMESPACE } from "discourse-common/lib/icon-library";
|
||||
import { i18n } from "discourse-i18n";
|
||||
|
||||
|
@ -43,7 +44,11 @@ export function showAlert(postId, actionClass, messageKey, opts = {}) {
|
|||
const actionBtn =
|
||||
opts.actionBtn || document.querySelector(`${postSelector} .${actionClass}`);
|
||||
|
||||
actionBtn?.classList.add("post-action-feedback-button");
|
||||
// using `next` here is a workaround for a behavior observed in Safari for iOS / iPadOS
|
||||
// that somehow trigger Ember to restore the button's original classes
|
||||
next(() => {
|
||||
actionBtn?.classList.add("post-action-feedback-button");
|
||||
});
|
||||
|
||||
createAlert(i18n(messageKey), postId, actionBtn);
|
||||
createCheckmark(actionBtn, actionClass, postId);
|
||||
|
@ -73,7 +78,12 @@ function createCheckmark(btn, actionClass, postId) {
|
|||
}
|
||||
|
||||
function styleBtn(btn) {
|
||||
btn.classList.add("--activated", "--transition");
|
||||
// using `next` here is a workaround for a behavior observed in Safari for iOS / iPadOS
|
||||
// that somehow trigger Ember to restore the button's original classes preventing the message/checkmark from being
|
||||
// displayed
|
||||
next(() => {
|
||||
btn.classList.add("--activated", "--transition");
|
||||
});
|
||||
setTimeout(
|
||||
() => btn.classList.remove("--activated"),
|
||||
TIMEOUT - TRANSITION_BUFFER
|
||||
|
|
Loading…
Reference in New Issue
Block a user