Skip to content

Commit

Permalink
editorial: Move the definition of display-mode back to APPMANIFEST. (#…
Browse files Browse the repository at this point in the history
…1039)

* Move the definition of display-mode back to APPMANIFEST.

Closes w3c/csswg-drafts#7306.

This text was moved out of the Manifest spec into CSS mediaqueries-5 in
w3c/csswg-drafts#6343, along with the display-mode media feature. The
actual definition of display mode belongs here, while the display-mode
media feature remains in CSS mediaqueries-5.

* Apply suggestions from code review

Co-authored-by: Aaron Gustafson <aaron@easy-designs.net>

* Tidy.

* display-mode: Rewrite note about display-mode media feature to helpfully point towards the CSS spec.

Also linkify display-mode properly.

---------

Co-authored-by: Marcos Cáceres <marcos@marcosc.com>
Co-authored-by: Aaron Gustafson <aaron@easy-designs.net>
  • Loading branch information
3 people authored Apr 12, 2024
1 parent 482c7fd commit a791201
Showing 1 changed file with 72 additions and 11 deletions.
83 changes: 72 additions & 11 deletions index.html
Original file line number Diff line number Diff line change
Expand Up @@ -2540,13 +2540,68 @@ <h3>
</section>
<section>
<h2>
Choosing a display mode
Display modes
</h2>
<p>
A [=display mode=], as defined in [[MEDIAQUERIES-5]], represents how
the web application is being presented within the context of an OS
(e.g., in fullscreen, etc.). Display modes correspond to user interface
(UI) metaphors and functionality in use on a given platform.
A <dfn class="export">display mode</dfn> represents how the web
application is being presented within the context of an OS (e.g., in
fullscreen, etc.). Display modes correspond to user interface (UI)
metaphors and functionality in use on a given platform. The UI
conventions of the display modes are purely advisory and implementers
are free to interpret them how they best see fit.
</p>
<p>
This specification defines the following [=display modes=]:
</p>
<dl>
<dt>
<dfn class="export" data-dfn-for="display mode">fullscreen</dfn>
</dt>
<dd>
Opens the web application with browser UI elements hidden and takes
up the entirety of the available display area.
</dd>
<dt>
<dfn class="export" data-dfn-for="display mode">standalone</dfn>
</dt>
<dd>
Opens the web application to look and feel like a standalone native
application. This can include the application having a different
window, its own icon in the application launcher, etc. In this mode,
the user agent will exclude standard browser UI elements such as an
URL bar, but can include other system UI elements such as a status
bar and/or system back button.
</dd>
<dt>
<dfn class="export" data-dfn-for="display mode">minimal-ui</dfn>
</dt>
<dd>
This mode is similar to [=display mode/standalone=], but provides the
end-user with some means to access a minimal set of UI elements for
controlling navigation (i.e., back, forward, reload, and perhaps some
way of viewing the document's address). A user agent can include
other platform specific UI elements, such as "share" and "print"
buttons or whatever is customary on the platform and user agent.
</dd>
<dt>
<dfn class="export" data-dfn-for="display mode">browser</dfn>
(default)
</dt>
<dd>
Opens the web application using the platform-specific convention for
opening hyperlinks in the user agent (e.g., in a browser tab or a new
window).
</dd>
</dl>
<p class="note">
The [=display mode/fullscreen=] <a>display mode</a> is orthogonal to,
and works independently of, the [[[FULLSCREEN]]]. The [=display
mode/fullscreen=] <a>display mode</a> affects the fullscreen state of
the browser window, while the [[FULLSCREEN]] API operates on an element
contained within the viewport. As such, a web application can have its
<a>display mode</a> set to [=display mode/fullscreen=], while
`document.fullScreenElement` returns `null`, and `fullscreenEnabled`
returns `false`.
</p>
<p>
Once a user agent [=applies=] a particular <a>display mode</a> to an
Expand Down Expand Up @@ -2628,14 +2683,20 @@ <h2>
</p>
<p>
A user agent MUST reflect the applied <a>display mode</a> of the web
application in the '`display-mode`' media feature [[MEDIAQUERIES-5]].
application in the <a data-xref-type="css-descriptor" data-xref-for=
"@media">`display-mode`</a> media feature [[MEDIAQUERIES-5]].
</p>
<p class="note">
A user agent will expose the '`display-mode`' media feature
irrespective of whether a manifest is being applied to a browsing
context. For example, if the end-user puts the application into
fullscreen, then the user agent would reflect this change to CSS and
scripts via the '`display-mode`' media feature.
A user agent will expose the actual display mode being applied — not
necessarily the one declared in the manifest — via the
<a data-xref-type="css-descriptor" data-xref-for=
"@media">`display-mode`</a> media feature, accessible through CSS or
JavaScript. Note that this media feature will also reflect other
display modes for a web page when a manifest is not being applied. For
example, if the end-user puts the page into fullscreen, then the user
agent would reflect this change to CSS and scripts via the
<a data-xref-type="css-descriptor" data-xref-for=
"@media">`display-mode`</a> media feature.
</p>
</section>
<section id="priv-sec">
Expand Down

0 comments on commit a791201

Please sign in to comment.