The iTwin Web Viewer is a configurable iTwin.js viewer that offers basic configuration out-of-the-box and can be further extended through the use of iTwin.js UI Providers. This package should be used for web-based applications. For desktop applications, use @itwin/desktop-viewer-react.
yarn add @itwin/web-viewer-react
or
npm install @itwin/web-viewer-react
If you are creating a new application and are using React, it is advised that you use create-react-app with @bentley/react-scripts
. There is also a predefined template that includes the iTwin Viewer package:
npx create-react-app@latest my-app --scripts-version @bentley/react-scripts --template @itwin/web-viewer
import React, { useState, useEffect, useMemo } from "react";
import { Viewer } from "@itwin/web-viewer-react";
import { BrowserAuthorizationClient } from "@itwin/browser-authorization";
export const MyViewerComponent = () => {
const iTwinId = "myITwinId";
const iModelId = "myIModelId";
const authClient = useMemo(
() =>
new BrowserAuthorizationClient({
scope: "profile email",
clientId: "my-oidc-client",
redirectUri: "https://myredirecturi.com",
postSignoutRedirectUri: "https://mypostsignouturi.com",
responseType: "code",
}),
[]
);
return (
<Viewer
authClient={authClient}
iTwinId={iTwinId}
iModelId={iModelId}
enablePerformanceMonitors={true}
/>
);
};
authClient
- Client that implements the ViewerAuthorizationClient interfaceenablePerformanceMonitors
- Enable reporting of data from timed events in the iTwin Viewer in order to aid in future performance optimizations. These are the metrics that will be collected and logged to the browser's performance timeline:- Duration of startup to the initialization of iTwin.js services
- Duration of startup to the establishment of a connection to the iModel
- Duration of startup to the creation of a view state for the iModel
- Duration of startup until the last tile is loaded and rendered for the initial iModel view
iTwinId
- GUID for the iTwin (project, asset, etc.) that contains the iModel that you wish to viewiModelId
- GUID for the iModel that you wish to view
location
- The spatial location for the blank connection.extents
- The volume of interest, in meters, centered around locationiTwinId
- GUID for the iTwin (project, asset, etc.) that contains the iModel that you wish to views- Note: The props above cannot be used in conjunction with iModelId
- Note:
authClient
props will be optional if onlylocation
andextents
props are supplied. However, if theiTwinId
prop also is passed into the Viewer component,authClient
will be required.
changeSetId
- Changeset id to view if combined with the iTwinId and iModelId propsblankConnectionViewState
- Override options for the ViewState that is generated for the BlankConnectionbackendConfiguration
- Manage backend(s) connection info and RPC Interfaces. See belowtheme
- Override the default themedefaultUiConfig
- hide parts of the default frontstagehideNavigationAid
- hide the navigation aid cubehideStatusBar
- hide the status bar
onIModelConnected
- Callback function that executes after the iModel connection is successful and contains the iModel connection as a parameterfrontstages
- Provide additional frontstages for the viewer to renderbackstageItems
- Provide additional backstage items for the viewer's backstage composerviewportOptions
- Additional options for the default frontstage's IModelViewportControluiProviders
- Extend the viewer's default uiviewCreatorOptions
- Options for creating the default viewStateloadingComponent
- provide a custom React component to override the spinner when an iModel is loadingproductId
- application's GPRIDi18nUrlTemplate
- Override the default url template where i18n resource files are queriedonIModelAppInit
- Callback function that executes after IModelApp.startup completesadditionalI18nNamespaces
- Additional i18n namespaces to registerextensions
- Provide extensions for the viewerhubAccess
- OptionalhubAccess
to override the Viewer's default hub accessmapLayerOptions
- Optional key value pair to provide map layerstoolAdmin
- OptionalToolAdmin
to override the Viewer's default tool admintileAdmin
- OptionaltileAdmin
to override the Viewer's default tile adminrenderSys
- OptionalrenderSys
to override the Viewer's default render systemrealityDataAccess
- OptionalrealityDataAccess
to override the Viewer's default reality data accesslocalization
- Optionallocalization
to provide your own Localization instance
For cases where you would prefer to use a Blank iModelConnection, you should supply the location
and extents
props to the Viewer React component. The authClient
props will be optional unless the iTwinId
prop is also supplied.
import React, { useState, useEffect } from "react";
import { BlankConnectionViewState, Viewer } from "@itwin/web-viewer-react";
import { Range3d } from "@itwin/core-geometry";
import { Cartographic, ColorDef } from "@itwin/core-common";
import { BrowserAuthorizationClient } from "@itwin/browser-authorization";
export const MyBlankViewerComponent = () => {
const blankConnectionViewState: BlankConnectionViewState = {
displayStyle: {
backgroundColor: ColorDef.blue,
},
};
const authClient = useMemo(
() =>
new BrowserAuthorizationClient({
scope: "profile email",
clientId: "my-oidc-client",
redirectUri: "https://myredirecturi.com",
postSignoutRedirectUri: "https://mypostsignouturi.com",
responseType: "code",
}),
[]
);
return (
<Viewer
authClient={authClient}
location={Cartographic.fromDegrees(0, 0, 0)}
extents={new Range3d(-30, -30, -30, 30, 30, 30)}
blankConnectionViewState={blankConnectionViewState}
/>
);
};
If no backendConfiguration
is specified, the backend defaults to the iTwin Platform's iModel Access Service. You can modify or override this default backend, add additional RpcInterfaces to it, and/or add additional backends. The below examples are not mutually exclusive.
// ... rest of code omitted
<Viewer
// ...other props omitted
backendConfiguration={{
defaultBackend: {
config: {
info: {
title: "New Default Backend Title",
version: "v5.0"
},
uriPrefix: "https://new-default-backend-uri"
}
}
}}
/>
// ... rest of code omitted
<Viewer
// ...other props omitted
backendConfiguration={{
defaultBackend: {
rpcInterfaces: [
MyRpcInterface,
AnotherRpcInterface
]
}
}}
/>
Add one or more custom backends with any number of RPC Interfaces registered against each.
// ... rest of code omitted
<Viewer
// ...other props omitted
backendConfiguration={{
customBackends: [
{
config: {
info: {
title: "Custom Backend One",
version: "v3.0"
},
uriPrefix: "https://custom-backend-uri"
},
rpcInterfaces: [
BackendOneRpcInterface,
BackendOneRpcInterfaceTwo
]
},
{
config: {
info: {
title: "Custom Backend Two",
version: "v4.0"
},
uriPrefix: "https://custom-backend-two-uri"
},
rpcInterfaces: [
BackendTwoRpcInterface
]
}
]
}}
/>
When making changes to the src, run npm start
in the package's root folder to enable source watching and rebuild, so the dev-server will have access to updated code on successful code compilation.