mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 18:02:46 +08:00
FIX: Ensure dialogs are still rendered if triggered during boot (#22511)
When the loading slider is enabled, the rendering of `application.hbs` is slightly delayed compared to the old 'spinner' strategy. This means that if a route tried to render a dialog during its `model()` hook, the dialog wrapper element would not be present and an error would occur. This commit detects that situation and delays rendering the error until the next runloop iteration. If the element is still not found, we print a useful error to the console. In the long term, we should ideally convert the dialog service to use a pure-ember rendering strategy instead of leaning on a11y-dialog. But for now, this workaround should resolve the problems identified by the chat system specs.
This commit is contained in:
parent
c7cebbfe38
commit
ed2dae6d1a
|
@ -1,6 +1,7 @@
|
|||
import Service from "@ember/service";
|
||||
import A11yDialog from "a11y-dialog";
|
||||
import { bind } from "discourse-common/utils/decorators";
|
||||
import { next } from "@ember/runloop";
|
||||
|
||||
export default Service.extend({
|
||||
dialogInstance: null,
|
||||
|
@ -26,7 +27,7 @@ export default Service.extend({
|
|||
class: null,
|
||||
_confirming: false,
|
||||
|
||||
dialog(params) {
|
||||
async dialog(params) {
|
||||
const {
|
||||
message,
|
||||
bodyComponent,
|
||||
|
@ -48,7 +49,19 @@ export default Service.extend({
|
|||
buttons,
|
||||
} = params;
|
||||
|
||||
const element = document.getElementById("dialog-holder");
|
||||
let element = document.getElementById("dialog-holder");
|
||||
if (!element) {
|
||||
await new Promise((resolve) => next(resolve));
|
||||
element = document.getElementById("dialog-holder");
|
||||
}
|
||||
|
||||
if (!element) {
|
||||
const msg =
|
||||
"dialog-holder wrapper element not found. Unable to render dialog";
|
||||
// eslint-disable-next-line no-console
|
||||
console.error(msg, params);
|
||||
throw new Error(msg);
|
||||
}
|
||||
|
||||
this.setProperties({
|
||||
message,
|
||||
|
|
|
@ -61,7 +61,7 @@ RSpec.describe "Visit channel", type: :system do
|
|||
end
|
||||
|
||||
context "when channel is not found" do
|
||||
xit "shows an error" do
|
||||
it "shows an error" do
|
||||
visit("/chat/c/-/999")
|
||||
|
||||
expect(page).to have_content("Not Found") # this is not a translated key
|
||||
|
@ -78,7 +78,7 @@ RSpec.describe "Visit channel", type: :system do
|
|||
|
||||
context "when channel is not accessible" do
|
||||
context "when category channel" do
|
||||
xit "shows an error" do
|
||||
it "shows an error" do
|
||||
chat.visit_channel(private_category_channel_1)
|
||||
|
||||
expect(page).to have_content(I18n.t("invalid_access"))
|
||||
|
@ -86,7 +86,7 @@ RSpec.describe "Visit channel", type: :system do
|
|||
end
|
||||
|
||||
context "when direct message channel" do
|
||||
xit "shows an error" do
|
||||
it "shows an error" do
|
||||
chat.visit_channel(inaccessible_dm_channel_1)
|
||||
|
||||
expect(page).to have_content(I18n.t("invalid_access"))
|
||||
|
@ -111,7 +111,7 @@ RSpec.describe "Visit channel", type: :system do
|
|||
)
|
||||
end
|
||||
|
||||
xit "shows an error" do
|
||||
it "shows an error" do
|
||||
chat.visit_channel(inaccessible_dm_channel_1)
|
||||
|
||||
expect(page).to have_content(I18n.t("invalid_access"))
|
||||
|
|
Loading…
Reference in New Issue
Block a user