A more practical and semantic use for DIALOG tag

In the current spec, the <dialog> tag was used to indicate a conversation or
chat log. This tag was removed for various reasons, some people still feel
it ought to be included. I am personally indifferent to this need (I
wouldn't have thought that chat logs in HTML documents are common enough to
warrant their own element group), but I am opposed to the semantics of the
term "dialog" being used to apply to chat logs and the like. To most in the
field, a "dialog" is an interactive or informative popup window element used
for notification and gathering contextual user input.

Currently, the need for such user interaction is provided for by external
javascript UI libraries or through the stock javascript
window.alert()/confirm()/prompt() methods. The standard javascript methods
are inconsistent in appearance between user agents and have the sometimes
unfortunate quality of being a blocking call (execution of script
non-optionally halts upon calling). The library-provided dialogs have the
advantage of using DOM elements and thus CSS for total control of the dialog
appearance, but have the drawback of not being ABLE to block when desired.
When you have such a clear and widespread need for an interface pattern and
two different approaches to providing that need, the dichotomy between what
developers *want* to do using either and what one *can* do with either
leaves a gap in functionality that is ripe for improvement. One should not
have to trade control of appearance just to get a blocking call, and
likewise one should not have to trade blocking just so you can style the
dialog in a manner consistent with the context in which it is being used.

In my view, there is a need for a semantic tag to wrap dialog interfaces to
provide a clear way to wrap, style, and address elements that will be used
for a specific utility. The content of a dialog box is not semantically a
SECTION, an ASIDE, or a DIV. Currently, however, most developers use DIV (or
ASIDE) tags to wrap such user prompts. My proposal on this score is
three-fold:
* bring back the <dialog> tag, but rather as a semantic tag for wrapping and
styling popup dialogs
* extend the existent javascript methods for user interaction to optionally
work with a given DOM element as the interface instead of the standard
OS-level window
* allow calls to standard javascript prompt methods to optionally and by
default block

Thus, we have:

window.prompt(message [, default=false, blocking=true ] )

....where message may be a string (use the default UI) or a DOM node (use
this as the UI instead). This also maintains backward compatibility.

The <dialog> tag could behave essentially like a <section> element with the
additional optional properties "dragable" and "modal":

<dialog id="areyousure" modal="true" draggable="true">
  <header>
    Dialog title
  <header>
  <p>
    Are you sure you want to do that?
  </p>
  <button>Yes</button>
  <button>No</button>
  <footer>
     Dialog footer
  </footer>
</dialog>

<script type="text/javascript">
  var d = document.getElementById('areyousure');

  // make a blocking call
  var result = window.prompt(d, false, true);

  // make a non-blocking call
  window.prompt(d, false, function (result) {
     alert('The result was '+result);
  });
</script>

http://www.whatwg.org/specs/web-apps/current-work/#user-prompts

I feel like the showModalDialog method is trying to achieve this, and I am
excited by the functionality brought to bear.  However, the need for
external files can bring a level of complexity to bear that might mitigate
any benefit; I'm still better served by using a javascript UI library. Given
the indisputable fact that user prompts are an ever-increasingly vital part
of modern web applications, it is astounding that we have to look outside
the core of HTML to find a flexible provider of this need and that even our
best bet is not able to offer a complete solution.

Received on Wednesday, 27 July 2011 03:17:42 UTC