Customizing WebViewer UI Styles

WebViewer UI supports style customizations using an API, through a CSS file or using the Modular UI.

Modular WebViewer UI

See this guide for more information about styling WebViewer with Modular UI.

Changing color theme

See this guide for more information about changing the theme.

Changing CSS properties

If you want to change more CSS properties, you can use a custom stylesheet to define them using normal CSS selectors.

To make the customization easier and consistent, WebViewer UI provides 5 top level classes:

  • Button
  • Panel
  • Overlay
  • Popup
  • Modal

Example

JavaScript

1WebViewer({
2 licenseKey: 'YOUR_LICENSE_KEY',
3 path: 'lib',
4 css: 'path/to/stylesheet.css'
5}, document.getElementById('viewer'));

CSS

1.Button.Icon {
2 color: red;
3}
4
5.Panel.open {
6 transition: all ease 0.5s;
7}

Accessing DOM directly

The more recent versions of WebViewer (starting with version 11.0) use Web Components as part of a modular UI. Earlier versions use iframe. To learn more about how to access the DOM directly, depending on your version of WebViewer, select either the Web Components tab or iframe tab below. The Web Component vs Iframe article provides more detail about the differences.

Avoid Direct DOM Manipulation

While it is technically possible to access the iframe or Web Component DOM and modify UI elements using querySelector, this approach is strongly discouraged.

WebViewer's internal DOM structure is not part of the public API and may change between releases. Direct DOM manipulation can easily break when upgrading WebViewer, even between minor versions. We recommend using the provided APIs and configuration options instead, which are designed to be stable, supported, and forward-compatible.

WebViewer's UI will be loaded inside a modular UI.

JavaScript

1WebViewer({
2 // ...
3}).then(instance => {
4 const root = document.querySelector('apryse-webviewer').shadowRoot;
5 const topHeader = root.querySelector('[data-element="default-top-header"]');
6});

Applying the :host CSS selector with WebViewer WebComponent

When using an external CSS file in WebViewer with a WebComponent and styling a custom modal panel or an existing panel, you should utilize the :host CSS pseudo-class selector.

The :host CSS pseudo-class targets the shadow host of the shadow DOM where the CSS is applied, enabling you to select the WebViewer WebComponent element.

Here’s an example of how this is used.

JavaScript

1WebViewer.WebCompnent({
2 css: 'path/main.css'
3}).then(instance => {
4 // ...
5});

And here is the content of our main.css file.

CSS

1.DocumentContainer {
2 background: tomato;
3}
4
5:host {
6 --icon-color: #00a5e4 !important;
7}

WebViewer with new background color and changed icon color

Apryse Docs Image

Did you find this helpful?

Trial setup questions?

Ask experts on Discord

Need other help?

Contact Support

Pricing or product questions?

Contact Sales