diff --git a/spec.bs b/spec.bs index c2bf81a..eb0945a 100644 --- a/spec.bs +++ b/spec.bs @@ -148,13 +148,20 @@ A close watcher is a [=struct=] with the following [=struct/it
@@ -224,12 +231,15 @@ Objects implementing the {{CloseWatcher}} interface must support the signal close on a {{CloseWatcher}} |closeWatcher|: 1. If |closeWatcher|'s [=CloseWatcher/is active=] is false, then return. + 1. If |closeWatcher|'s [=CloseWatcher/firing cancel event=] is true, then return. 1. Let |window| be |closeWatcher|'s [=relevant global object=]. 1. If |window|'s [=associated Document=] is [=Document/fully active=], and |window|'s [=timestamp of last activation used for close watchers=] does not equal |window|'s last activation timestamp, then: - 1. Let |shouldContinue| be the result of [=firing an event=] named {{CloseWatcher/cancel}} at |closeWatcher|, with the {{Event/cancelable}} attribute initialized to true. 1. Set |window|'s [=timestamp of last activation used for close watchers=] to |window|'s last activation timestamp. + 1. Set |closeWatcher|'s [=CloseWatcher/firing cancel event=] to true. + 1. Let |shouldContinue| be the result of [=firing an event=] named {{CloseWatcher/cancel}} at |closeWatcher|, with the {{Event/cancelable}} attribute initialized to true. + 1. Set |closeWatcher|'s [=CloseWatcher/firing cancel event=] to false. 1. If |shouldContinue| is false, then return. - 1. If |window|'s [=associated Document=] is [=Document/fully active=], then [=fire an event=] named {{CloseWatcher/close}} at |closeWatcher|. + 1. If |closeWatcher|'s [=CloseWatcher/is active=] is true, and |window|'s [=associated Document=] is [=Document/fully active=], then [=fire an event=] named {{CloseWatcher/close}} at |closeWatcher|. 1. Set |closeWatcher|'s [=CloseWatcher/is active=] to false. @@ -248,12 +258,12 @@ Update HTML's In the {{HTMLDialogElement/showModal()}} steps, after adding |subject| to the [=top layer=], append the following step: - 1. If we [=can create a developer-controlled close watcher=] given |subject|'s [=Node/node document=], then [=stack/push=] a new [=close watcher=] on |subject|'s [=Node/node document=]'s [=close watcher stack=], with its [=struct/items=] set as follows: + 1. If the result of [=checking if we can create a developer-controlled close watcher=] given |subject|'s [=relevant global object=] is true, then [=stack/push=] a new [=close watcher=] on |subject|'s [=Node/node document=]'s [=close watcher stack=], with its [=struct/items=] set as follows: * [=close watcher/close action=] being to [=cancel the dialog=] |subject| * [=close watcher/is still valid=] steps being to return true if |subject|'s [=Node/node document=] is blocked by the modal dialog |subject|, and return false otherwise * [=close watcher/blocks further developer-controlled close watchers=] being true -
If we [=cannot create a developer-controlled close watcher=], then this modal dialog will not respond to [=close signals=]. The {{HTMLDialogElement/showModal()}} method proceeds without any exception or other indication of this, although the browser could [=report a warning to the console=]. +
If we cannot create a developer-controlled close watcher, then this modal dialog will not respond to [=close signals=]. The {{HTMLDialogElement/showModal()}} method proceeds without any exception or other indication of this, although the browser could [=report a warning to the console=]. Replace the "Canceling dialogs" section entirely with the following definition. (The previous prose about providing a user interface to cancel such dialogs, and the task-queuing, is now handled by the infrastructure in [[#close-signals]].)