Advanced Properties

This page documents advanced manifest properties that provide fine-grained control over your PWA's behavior and integration with the operating system.

Display Override

The display_override property allows you to specify a sequence of display modes that the browser will consider before falling back to the standard display property. This gives you more control over how your app is displayed on different platforms and browsers.

/config/packages/pwa.yaml
pwa:
    manifest:
        enabled: true
        display: "standalone"
        display_override: ['window-controls-overlay', 'minimal-ui']

Available Display Modes

The browser will try each mode in order and use the first one it supports:

  • "fullscreen" - Full screen without any browser UI

  • "standalone" - Looks like a standalone app with no browser UI

  • "minimal-ui" - Similar to standalone but with minimal browser UI (back/forward buttons)

  • "browser" - Standard browser tab experience

  • "window-controls-overlay" - Places window controls (minimize, maximize, close) in the title bar, giving your app more screen space

  • "tabbed" - Multiple app windows appear as tabs in a single window (experimental)

Example with Fallbacks

/config/packages/pwa.yaml
pwa:
    manifest:
        display: "standalone"
        display_override:
            - 'window-controls-overlay'
            - 'minimal-ui'
            - 'standalone'

In this example:

  1. The browser first tries window-controls-overlay (modern desktop browsers)

  2. If not supported, falls back to minimal-ui

  3. If not supported, uses standalone

  4. If none are supported, uses the standard display value

The display_override is particularly useful for providing an enhanced experience on desktop browsers that support window controls overlay while maintaining compatibility with mobile browsers.

Use Credentials

The use_credentials property controls whether the manifest is fetched with credentials (cookies, HTTP authentication). This is useful when your manifest file is protected or when you need to serve different manifests to different users.

/config/packages/pwa.yaml
pwa:
    manifest:
        enabled: true
        use_credentials: true

Default value: true

When use_credentials is set to true:

  • The browser includes cookies when fetching the manifest

  • HTTP authentication headers are included

  • CORS credentials mode is used

When set to false:

  • The manifest is fetched without credentials

  • No cookies or authentication headers are sent

When to Use Credentials

Set to true when:

  • Your manifest is behind authentication

  • You serve different manifests to different users

  • Your manifest URL is on a protected subdomain

Set to false when:

  • Your manifest is publicly accessible

  • You want to avoid potential CORS issues

  • You're serving the manifest from a CDN

The handle_links property specifies how the PWA should handle links when it's already open. This gives you control over whether links should open in the PWA window or in the browser.

/config/packages/pwa.yaml
pwa:
    manifest:
        enabled: true
        handle_links: "preferred"

Available Values

  • "auto" (default) - The browser decides based on its own heuristics

  • "preferred" - Prefer opening links in the PWA when it's already open

  • "not-preferred" - Prefer opening links in the browser

Example Use Cases

E-commerce app:

pwa:
    manifest:
        handle_links: "preferred"

Keep users in the PWA for a seamless shopping experience.

Documentation site:

pwa:
    manifest:
        handle_links: "auto"

Let the browser decide based on user behavior and context.

External link aggregator:

pwa:
    manifest:
        handle_links: "not-preferred"

Most links point to external sites, so prefer opening in the browser.

The handle_links property works in conjunction with the scope property. Links outside the scope are not affected by this setting.

Complete Example

Here's how these advanced properties work together:

/config/packages/pwa.yaml
pwa:
    manifest:
        enabled: true
        use_credentials: true

        # Core display settings
        display: "standalone"
        display_override:
            - 'window-controls-overlay'
            - 'minimal-ui'

        # Link handling
        handle_links: "preferred"

        # Other properties
        scope: "/"
        start_url: "app_homepage"

Browser Support

Best Practices

  1. Progressive Enhancement: Use display_override to provide enhanced experiences while maintaining a solid baseline

  2. Test Thoroughly: Test link handling behavior to ensure it matches user expectations

  3. Document Behavior: Make it clear to users how your PWA handles links, especially for external URLs

  4. Consider Privacy: Be mindful of credentials when fetching manifests, especially on shared devices

Last updated

Was this helpful?