UNPKG

@preset-sdk/embedded

Version:

Frontend SDK for embedding Preset data analytics into your own application

65 lines (64 loc) 2.71 kB
import { Switchboard } from '@superset-ui/switchboard'; /** * The function to fetch a guest token from your Host App's backend server. * The Host App backend must supply an API endpoint * which returns a guest token with appropriate resource access. */ export declare type GuestTokenFetchFn = () => Promise<string>; export declare type UiConfigType = { hideTitle?: boolean; hideTab?: boolean; hideChartControls?: boolean; emitDataMasks?: boolean; filters?: { [key: string]: boolean | undefined; visible?: boolean; expanded?: boolean; }; urlParams?: { [key: string]: any; }; showRowLimitWarning?: boolean; }; export declare type EmbedDashboardParams = { /** The id provided by the embed configuration UI in Superset */ id: string; /** The domain where Superset can be located, with protocol, such as: https://abc123.us1a.preset.io */ supersetDomain: string; /** The html element within which to mount the iframe */ mountPoint: HTMLElement; /** A function to fetch a guest token from the Host App's backend server */ fetchGuestToken: GuestTokenFetchFn; /** The dashboard UI config: hideTitle, hideTab, hideChartControls, filters.visible, filters.expanded **/ dashboardUiConfig?: UiConfigType; /** Enables extra logging */ debug?: boolean; /** The iframe title attribute */ iframeTitle?: string; /** additional iframe sandbox attributes ex (allow-top-navigation, allow-popups-to-escape-sandbox) **/ iframeSandboxExtras?: string[]; /** force a specific refererPolicy to be used in the iframe request **/ referrerPolicy?: ReferrerPolicy; }; export declare type Size = { width: number; height: number; }; export declare type ObserveDataMaskCallbackFn = (dataMask: Record<string, any> & { crossFiltersChanged: boolean; nativeFiltersChanged: boolean; }) => void; export declare type EmbeddedDashboard = { getScrollSize: () => Promise<Size>; unmount: () => void; getDashboardPermalink: (anchor: string) => Promise<string>; getActiveTabs: () => Promise<string[]>; observeDataMask: (callbackFn: ObserveDataMaskCallbackFn) => void; getDataMask: () => Record<string, any>; setThemeConfig: (themeConfig: Record<string, any>) => void; }; /** * Embeds a Superset dashboard into the page using an iframe. */ export declare function embedDashboard({ id, supersetDomain, mountPoint, fetchGuestToken, dashboardUiConfig, debug, iframeTitle, iframeSandboxExtras, referrerPolicy, }: EmbedDashboardParams): Promise<EmbeddedDashboard>; export declare function _initComms(window: Window, targetOrigin: string, debug?: boolean): Switchboard;