Web Authoring
This website is under construction. Content on this page is a placeholder.
Almost all embedded deployments of Tableau embed pre-built dashboards. But some embed other components of Tableau such as:
- web authoring experience
- The Tableau Server UI (embedded for integration and single sign-on reasons). (Note that Tableau does not offer support for this deployment).
The easiest and best way to include web authoring in your embedding scenario is to use the Tableau Embedding API v3 (opens in a new tab). The Tableau Embedding API v3 provides a web component, <tableau-viz-authoring>, which in just a few lines of HTML code, allows users to author the view in your web application (if permissions allow). You can also use the Embedding API v3 to call JavaScript methods that let you to customize the authoring lifecycle. For example, you can dynamically configure and switch between the authoring or viewing experience.
Embedding Web Authoring
Web authoring allows someone to edit a visualization just as they would in Tableau Desktop. Embedding a view with web authoring gives your users the ability to modify and update a view, all while staying in their workflow. Embedded web authoring means that you can create comprehensive embedded applications for your customers that include options for self-servicing.
When it comes to editing a visualization, it is often acceptable to simply use the default settings and allow the user to click Edit on the toolbar of an embedded dashboard. The result will be a new browser tab opened to the web authoring screen for that workbook. However, now you can embed the Tableau authoring experience directly in the application. There's no need to have users jump to another window or tab. You can use the Edit button in the toolbar, or create your own edit button that matches the look and feel of your application. To do that:
- 
Add a <tableau-authoring-viz>element to your HTML code or use the Embedding API v3 JavaScript methods to create aTableauAuthoringVizobject. Set thesrcattribute or property to the URL of the viz. Then link to, or import, the Embedding API v3 library.<tableau-authoring-viz id="AuthoringViz" src='https://my-server/authoring/my-workbook/my-view'> </tableau-authoring-viz>
Create a custom editing workflow
To create your own editing workflows, you can hide the default Edit, Close, and Edit in Desktop buttons on the toolbar, by setting attributes on the <tableau-authoring-viz> and <tableau-viz> web components, or by setting those properties on the JavaScript objects. And then create your own custom buttons in your application and switch between authoring and viewing.
You could also change a setting to suppress the default actions that occur when the Close, Edit, or Edit in Desktop buttons in the toolbar are clicked. You can then setup event listeners (for example, EditButtonClick, or PublishedAs) to handle the button clicks and customize the authoring and publishing flow to suit the needs of your users. For example, you might follow this scenario to switch between viewing and web authoring modes.
- 
Create a <tableau-viz>component (orTableauVizobject), set thesuppress-default-edit-behaviorattribute to turn off the default actions that occur when the user clicks the Edit button, or closes, or publishes the view.
- 
In the <tableau-viz>component, set thesrcURL and then add theonEditButtonClickedevent listener to call your custom handler (handleEditButtonClicked()) when the user wants to switch to edit mode.<tableau-viz id="viewingViz" src="https://myserver/t/site/workbook/sheet" width="800" height="600" suppress-default-edit-behavior onEditButtonClicked="handleEditButtonClicked"> </tableau-viz>
- 
Create a <tableau-authoring-viz>component orTableauAuthoringVizobject, but don't specify thesrcURL to the view, so that the view doesn't appear until after the Edit button is clicked. You can also set the HTML style properties to hide the component or<div>that will contain the authoring view.
- 
In your custom handleEditButtonClicked()method, you should assign thesrcURL to theTableauAuthoringVizobject so that when it is rendered it shows the view. You should also set the style properties to show the authoring component and to hide theTableauVizobject.
- 
In the <tableau-authoring-viz>component, add theonWorkbookPublishedAsevent attribute or property to be able to get the new URL for the saved workbook. In your custom handler for the published-as event, assign the new URL to theTableauVizobject.
- 
In the <tableau-authoring-viz>component, add theonWorkbookReadyToCloseevent attribute to know when to switch back to view mode. In your custom event handler for the close event, hide the authoring component from view and show the viewing component.
For an overview of the embedded web authoring feature, see How to Enable Self-Service Analytics in Your Application with Embedded Web Authoring (opens in a new tab). For a hands-on tutorial, see Embedded API - Web Authoring Tutorial (opens in a new tab). And for more information, see Embedded Web Authoring (opens in a new tab) in the Embedding API v3 Help documentation.
Additional Considerations:
- You will likely want to allow your users to save their edits, but not have their personalized versions affect other users. In that case, you should turn off save permissions, but allow save-as permissions. It also makes sense to give each of the users a 'sandbox' project that only they can save to.
Embedding other Tableau Server pages
You can also use the iframe approach to embed the Tableau Server UI. This is a rarer technique, but is useful if you want to use the out-of-the-box UI, but want to achieve single sign-on from your application.
To do so, simply embed into an iframe. Be sure to enable unrestricted tickets (opens in a new tab).