@thoughtspot/visual-embed-sdk 1.20.0-prerender.2 → 1.20.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/src/auth.d.ts +2 -38
- package/dist/src/auth.d.ts.map +1 -1
- package/dist/src/config.d.ts +0 -1
- package/dist/src/config.d.ts.map +1 -1
- package/dist/src/embed/app.d.ts +5 -17
- package/dist/src/embed/app.d.ts.map +1 -1
- package/dist/src/embed/base.d.ts +9 -20
- package/dist/src/embed/base.d.ts.map +1 -1
- package/dist/src/embed/liveboard.d.ts +5 -17
- package/dist/src/embed/liveboard.d.ts.map +1 -1
- package/dist/src/embed/search-bar.d.ts +0 -3
- package/dist/src/embed/search-bar.d.ts.map +1 -1
- package/dist/src/embed/search.d.ts +5 -9
- package/dist/src/embed/search.d.ts.map +1 -1
- package/dist/src/embed/ts-embed.d.ts +6 -43
- package/dist/src/embed/ts-embed.d.ts.map +1 -1
- package/dist/src/errors.d.ts.map +1 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/mixpanel-service.d.ts +0 -8
- package/dist/src/mixpanel-service.d.ts.map +1 -1
- package/dist/src/react/index.d.ts.map +1 -1
- package/dist/src/react/util.d.ts +0 -4
- package/dist/src/react/util.d.ts.map +1 -1
- package/dist/src/test/test-utils.d.ts +2 -11
- package/dist/src/test/test-utils.d.ts.map +1 -1
- package/dist/src/types.d.ts +76 -273
- package/dist/src/types.d.ts.map +1 -1
- package/dist/src/utils/answerService.d.ts +0 -7
- package/dist/src/utils/answerService.d.ts.map +1 -1
- package/dist/src/utils/authService.d.ts +0 -30
- package/dist/src/utils/authService.d.ts.map +1 -1
- package/dist/src/utils/processData.d.ts +0 -12
- package/dist/src/utils/processData.d.ts.map +1 -1
- package/dist/src/utils/processTrigger.d.ts +0 -7
- package/dist/src/utils/processTrigger.d.ts.map +1 -1
- package/dist/src/utils.d.ts +0 -12
- package/dist/src/utils.d.ts.map +1 -1
- package/dist/tsembed.es.js +262 -637
- package/dist/tsembed.js +261 -629
- package/lib/package.json +8 -3
- package/lib/src/auth.d.ts +2 -38
- package/lib/src/auth.d.ts.map +1 -1
- package/lib/src/auth.js +25 -70
- package/lib/src/auth.js.map +1 -1
- package/lib/src/auth.spec.js +5 -14
- package/lib/src/auth.spec.js.map +1 -1
- package/lib/src/config.d.ts +0 -1
- package/lib/src/config.d.ts.map +1 -1
- package/lib/src/config.js +3 -5
- package/lib/src/config.js.map +1 -1
- package/lib/src/config.spec.js.map +1 -1
- package/lib/src/embed/app.d.ts +5 -17
- package/lib/src/embed/app.d.ts.map +1 -1
- package/lib/src/embed/app.js +15 -25
- package/lib/src/embed/app.js.map +1 -1
- package/lib/src/embed/app.spec.js +12 -12
- package/lib/src/embed/app.spec.js.map +1 -1
- package/lib/src/embed/base.d.ts +9 -20
- package/lib/src/embed/base.d.ts.map +1 -1
- package/lib/src/embed/base.js +15 -31
- package/lib/src/embed/base.js.map +1 -1
- package/lib/src/embed/base.spec.js.map +1 -1
- package/lib/src/embed/embed.spec.js +1 -1
- package/lib/src/embed/embed.spec.js.map +1 -1
- package/lib/src/embed/liveboard.d.ts +5 -17
- package/lib/src/embed/liveboard.d.ts.map +1 -1
- package/lib/src/embed/liveboard.js +37 -49
- package/lib/src/embed/liveboard.js.map +1 -1
- package/lib/src/embed/liveboard.spec.js +30 -37
- package/lib/src/embed/liveboard.spec.js.map +1 -1
- package/lib/src/embed/pinboard.spec.js +26 -14
- package/lib/src/embed/pinboard.spec.js.map +1 -1
- package/lib/src/embed/search-bar.d.ts +0 -3
- package/lib/src/embed/search-bar.d.ts.map +1 -1
- package/lib/src/embed/search-bar.js +6 -5
- package/lib/src/embed/search-bar.js.map +1 -1
- package/lib/src/embed/search.d.ts +5 -9
- package/lib/src/embed/search.d.ts.map +1 -1
- package/lib/src/embed/search.js +14 -18
- package/lib/src/embed/search.js.map +1 -1
- package/lib/src/embed/search.spec.js +19 -16
- package/lib/src/embed/search.spec.js.map +1 -1
- package/lib/src/embed/searchEmbed-basic-auth.spec.js +0 -4
- package/lib/src/embed/searchEmbed-basic-auth.spec.js.map +1 -1
- package/lib/src/embed/ts-embed.d.ts +6 -43
- package/lib/src/embed/ts-embed.d.ts.map +1 -1
- package/lib/src/embed/ts-embed.js +72 -117
- package/lib/src/embed/ts-embed.js.map +1 -1
- package/lib/src/embed/ts-embed.spec.js +24 -23
- package/lib/src/embed/ts-embed.spec.js.map +1 -1
- package/lib/src/errors.d.ts.map +1 -1
- package/lib/src/errors.js.map +1 -1
- package/lib/src/index.d.ts.map +1 -1
- package/lib/src/index.js +2 -2
- package/lib/src/index.js.map +1 -1
- package/lib/src/mixpanel-service.d.ts +0 -8
- package/lib/src/mixpanel-service.d.ts.map +1 -1
- package/lib/src/mixpanel-service.js +1 -13
- package/lib/src/mixpanel-service.js.map +1 -1
- package/lib/src/mixpanel-service.spec.js.map +1 -1
- package/lib/src/react/index.d.ts.map +1 -1
- package/lib/src/react/index.js +6 -6
- package/lib/src/react/index.js.map +1 -1
- package/lib/src/react/index.spec.js +6 -15
- package/lib/src/react/index.spec.js.map +1 -1
- package/lib/src/react/util.d.ts +0 -4
- package/lib/src/react/util.d.ts.map +1 -1
- package/lib/src/react/util.js +0 -4
- package/lib/src/react/util.js.map +1 -1
- package/lib/src/test/test-utils.d.ts +2 -11
- package/lib/src/test/test-utils.d.ts.map +1 -1
- package/lib/src/test/test-utils.js +25 -36
- package/lib/src/test/test-utils.js.map +1 -1
- package/lib/src/types.d.ts +76 -273
- package/lib/src/types.d.ts.map +1 -1
- package/lib/src/types.js +54 -200
- package/lib/src/types.js.map +1 -1
- package/lib/src/utils/answerService.d.ts +0 -7
- package/lib/src/utils/answerService.d.ts.map +1 -1
- package/lib/src/utils/answerService.js +0 -7
- package/lib/src/utils/answerService.js.map +1 -1
- package/lib/src/utils/answerService.spec.js.map +1 -1
- package/lib/src/utils/authService.d.ts +0 -30
- package/lib/src/utils/authService.d.ts.map +1 -1
- package/lib/src/utils/authService.js +2 -39
- package/lib/src/utils/authService.js.map +1 -1
- package/lib/src/utils/authService.spec.js.map +1 -1
- package/lib/src/utils/processData.d.ts +0 -12
- package/lib/src/utils/processData.d.ts.map +1 -1
- package/lib/src/utils/processData.js +5 -33
- package/lib/src/utils/processData.js.map +1 -1
- package/lib/src/utils/processData.spec.js.map +1 -1
- package/lib/src/utils/processTrigger.d.ts +0 -7
- package/lib/src/utils/processTrigger.d.ts.map +1 -1
- package/lib/src/utils/processTrigger.js +3 -17
- package/lib/src/utils/processTrigger.js.map +1 -1
- package/lib/src/utils/processTrigger.spec.js.map +1 -1
- package/lib/src/utils.d.ts +0 -12
- package/lib/src/utils.d.ts.map +1 -1
- package/lib/src/utils.js +19 -24
- package/lib/src/utils.js.map +1 -1
- package/lib/src/utils.spec.js.map +1 -1
- package/lib/src/visual-embed-sdk.d.ts +102 -406
- package/package.json +8 -3
- package/src/auth.spec.ts +150 -68
- package/src/auth.ts +108 -102
- package/src/config.spec.ts +4 -2
- package/src/config.ts +3 -5
- package/src/embed/app.spec.ts +14 -25
- package/src/embed/app.ts +35 -47
- package/src/embed/base.spec.ts +9 -3
- package/src/embed/base.ts +53 -51
- package/src/embed/embed.spec.ts +6 -5
- package/src/embed/liveboard.spec.ts +37 -56
- package/src/embed/liveboard.ts +64 -66
- package/src/embed/pinboard.spec.ts +29 -26
- package/src/embed/search-bar.tsx +8 -10
- package/src/embed/search.spec.ts +21 -31
- package/src/embed/search.ts +25 -26
- package/src/embed/searchEmbed-basic-auth.spec.ts +28 -22
- package/src/embed/ts-embed.spec.ts +148 -70
- package/src/embed/ts-embed.ts +157 -147
- package/src/errors.ts +6 -3
- package/src/index.ts +10 -4
- package/src/mixpanel-service.spec.ts +3 -1
- package/src/mixpanel-service.ts +1 -13
- package/src/react/index.spec.tsx +13 -37
- package/src/react/index.tsx +57 -38
- package/src/react/util.ts +4 -8
- package/src/test/test-utils.ts +39 -43
- package/src/types.ts +78 -270
- package/src/utils/answerService.spec.ts +5 -3
- package/src/utils/answerService.ts +17 -21
- package/src/utils/authService.spec.ts +41 -26
- package/src/utils/authService.ts +21 -47
- package/src/utils/processData.spec.ts +59 -26
- package/src/utils/processData.ts +14 -36
- package/src/utils/processTrigger.spec.ts +6 -1
- package/src/utils/processTrigger.ts +9 -18
- package/src/utils.spec.ts +12 -8
- package/src/utils.ts +26 -25
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../src/react/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../src/react/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAGnE,MAAM,MAAM,kBAAkB,GAAG;KAAG,GAAG,IAAI,MAAM,OAAO,UAAU,IAAI,KAAK,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,eAAe;CAAE,CAAC;AAGlH,MAAM,WAAW,UAAW,SAAQ,UAAU,EAAE,kBAAkB;IAC9D,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,sBAAsB,CAAC,CAAC,SAAS,UAAU;IACxD,UAAU,EAAE,CAAC,CAAC;IACd,SAAS,EAAE;SAAG,GAAG,IAAI,UAAU,CAAC,CAAC,EAAE,eAAe;KAAE,CAAC;CACxD;AAED,wBAAgB,wBAAwB,CAAC,CAAC,SAAS,UAAU,EAAE,CAAC,SAAS,UAAU,EAAE,KAAK,EAAE,CAAC,GAAG,sBAAsB,CAAC,CAAC,CAAC,CAgBxH"}
|
package/lib/src/react/util.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../src/react/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAA+B,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../src/react/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAA+B,MAAM,UAAU,CAAC;AAenE,MAAM,UAAU,wBAAwB,CAA6C,KAAQ;IACzF,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAC5B,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE;QACV,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;YACtB,MAAM,SAAS,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAChC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC;SACtD;aAAM;YACH,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC;SACrC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC,EACD;QACI,UAAU,EAAE,EAAO;QACnB,SAAS,EAAE,EAAE;KAChB,CACJ,CAAC;AACN,CAAC"}
|
|
@@ -14,15 +14,12 @@ export declare const waitFor: (fn: () => boolean) => Promise<void>;
|
|
|
14
14
|
* programmatically and use dispatchEvent instead of the
|
|
15
15
|
* postMessage API
|
|
16
16
|
* Reference: https://github.com/jsdom/jsdom/issues/2745
|
|
17
|
-
*
|
|
18
17
|
* @param window
|
|
19
18
|
* @param data
|
|
20
|
-
* @param port
|
|
21
19
|
*/
|
|
22
20
|
export declare const postMessageToParent: (window: WindowProxy, data: any, port?: any) => void;
|
|
23
21
|
/**
|
|
24
22
|
* Execute a given function after a certain time has elapsed
|
|
25
|
-
*
|
|
26
23
|
* @param fn The function to be executed after the wait period
|
|
27
24
|
* @param waitTime The wait period in milliseconds
|
|
28
25
|
*/
|
|
@@ -31,18 +28,12 @@ export declare const executeAfterWait: (fn: (...args: any[]) => void, waitTime?:
|
|
|
31
28
|
* Time (in milliseconds) to wait for async events to be triggered
|
|
32
29
|
*/
|
|
33
30
|
export declare const EVENT_WAIT_TIME = 1000;
|
|
34
|
-
/**
|
|
35
|
-
*
|
|
36
|
-
* @param str
|
|
37
|
-
*/
|
|
38
31
|
export declare function fixedEncodeURI(str: string): string;
|
|
39
32
|
/**
|
|
40
|
-
* MessageChannel is available in Node > 15.0.0. Since the current node
|
|
41
|
-
*
|
|
42
|
-
* for the current unit tests.
|
|
33
|
+
* MessageChannel is available in Node > 15.0.0. Since the current node environment's
|
|
34
|
+
* used for github actions is not above 14, we are mocking this for the current unit tests.
|
|
43
35
|
*/
|
|
44
36
|
export declare const messageChannelMock: any;
|
|
45
37
|
export declare const mockMessageChannel: () => void;
|
|
46
|
-
export declare const expectUrlMatchesWithParams: (source: string, target: string) => void;
|
|
47
38
|
export {};
|
|
48
39
|
//# sourceMappingURL=test-utils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"test-utils.d.ts","sourceRoot":"","sources":["../../../src/test/test-utils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"test-utils.d.ts","sourceRoot":"","sources":["../../../src/test/test-utils.ts"],"names":[],"mappings":"AAYA,eAAO,MAAM,iCAAiC,QAAgH,CAAC;AAC/J,eAAO,MAAM,aAAa,QAAmF,CAAC;AAC9G,eAAO,MAAM,6BAA6B,QAA6I,CAAC;AACxL,eAAO,MAAM,eAAe,cACwB,CAAC;AAErD,KAAK,UAAU,GAAG,WAAW,GAAG,QAAQ,CAAC;AAEzC,eAAO,MAAM,SAAS,mBAAyC,CAAC;AAEhE,eAAO,MAAM,UAAU,mBAA2C,CAAC;AAEnE,eAAO,MAAM,WAAW,eAAe,UAAU,sBAEhD,CAAC;AAEF,eAAO,MAAM,cAAc,qCAA4C,CAAC;AAExE,eAAO,MAAM,YAAY,eAAe,UAAU,WACpB,CAAC;AAE/B,eAAO,MAAM,OAAO,OAAQ,MAAM,OAAO,KAAG,QAAQ,IAAI,CAUvD,CAAC;AAEF;;;;;;;GAOG;AACH,eAAO,MAAM,mBAAmB,WACpB,WAAW,QACb,GAAG,SACF,GAAG,SAQb,CAAC;AAEF;;;;GAIG;AACH,eAAO,MAAM,gBAAgB,iBACX,GAAG,EAAE,KAAK,IAAI,wCAS/B,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,eAAe,OAAO,CAAC;AAEpC,wBAAgB,cAAc,CAAC,GAAG,EAAE,MAAM,UAEzC;AAED;;;GAGG;AACH,eAAO,MAAM,kBAAkB,EAAE,GAGhC,CAAC;AACF,eAAO,MAAM,kBAAkB,YAM9B,CAAC"}
|
|
@@ -2,7 +2,7 @@ import { version } from '../../package.json';
|
|
|
2
2
|
import { Action, AuthType } from '../types';
|
|
3
3
|
/**
|
|
4
4
|
Initialises fetch to the global object
|
|
5
|
-
|
|
5
|
+
*/
|
|
6
6
|
global.fetch = jest.fn(() => Promise.resolve({
|
|
7
7
|
json: () => ({ mixpanelAccessToken: '' }),
|
|
8
8
|
}));
|
|
@@ -12,27 +12,29 @@ export const defaultParamsForPinboardEmbed = `hostAppUrl=local-host&viewPortHeig
|
|
|
12
12
|
export const getDocumentBody = () => '<div id="embed"></div><div id="embed-2"></div>';
|
|
13
13
|
export const getRootEl = () => document.getElementById('embed');
|
|
14
14
|
export const getRootEl2 = () => document.getElementById('embed-2');
|
|
15
|
-
export const getIFrameEl = (container = document) =>
|
|
15
|
+
export const getIFrameEl = (container = document) => {
|
|
16
|
+
return container.querySelector('iframe');
|
|
17
|
+
};
|
|
16
18
|
export const getAllIframeEl = () => document.querySelectorAll('iframe');
|
|
17
19
|
export const getIFrameSrc = (container = document) => getIFrameEl(container).src;
|
|
18
|
-
export const waitFor = (fn) =>
|
|
19
|
-
|
|
20
|
-
const
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
});
|
|
20
|
+
export const waitFor = (fn) => {
|
|
21
|
+
return new Promise((resolve) => {
|
|
22
|
+
const interval = setInterval(() => {
|
|
23
|
+
const value = fn();
|
|
24
|
+
if (value) {
|
|
25
|
+
clearInterval(interval);
|
|
26
|
+
resolve();
|
|
27
|
+
}
|
|
28
|
+
}, 100);
|
|
29
|
+
});
|
|
30
|
+
};
|
|
27
31
|
/**
|
|
28
32
|
* jsdom does not set event source, therefore we do it
|
|
29
33
|
* programmatically and use dispatchEvent instead of the
|
|
30
34
|
* postMessage API
|
|
31
35
|
* Reference: https://github.com/jsdom/jsdom/issues/2745
|
|
32
|
-
*
|
|
33
36
|
* @param window
|
|
34
37
|
* @param data
|
|
35
|
-
* @param port
|
|
36
38
|
*/
|
|
37
39
|
export const postMessageToParent = (window, data, port) => {
|
|
38
40
|
const message = new MessageEvent('message', {
|
|
@@ -44,31 +46,27 @@ export const postMessageToParent = (window, data, port) => {
|
|
|
44
46
|
};
|
|
45
47
|
/**
|
|
46
48
|
* Execute a given function after a certain time has elapsed
|
|
47
|
-
*
|
|
48
49
|
* @param fn The function to be executed after the wait period
|
|
49
50
|
* @param waitTime The wait period in milliseconds
|
|
50
51
|
*/
|
|
51
|
-
export const executeAfterWait = (fn, waitTime = 0) =>
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
});
|
|
52
|
+
export const executeAfterWait = (fn, waitTime = 0) => {
|
|
53
|
+
return new Promise((resolve, reject) => {
|
|
54
|
+
setTimeout(() => {
|
|
55
|
+
const value = fn();
|
|
56
|
+
resolve(value);
|
|
57
|
+
}, waitTime);
|
|
58
|
+
});
|
|
59
|
+
};
|
|
57
60
|
/**
|
|
58
61
|
* Time (in milliseconds) to wait for async events to be triggered
|
|
59
62
|
*/
|
|
60
63
|
export const EVENT_WAIT_TIME = 1000;
|
|
61
|
-
/**
|
|
62
|
-
*
|
|
63
|
-
* @param str
|
|
64
|
-
*/
|
|
65
64
|
export function fixedEncodeURI(str) {
|
|
66
65
|
return encodeURI(str).replace(/%5B/g, '[').replace(/%5D/g, ']');
|
|
67
66
|
}
|
|
68
67
|
/**
|
|
69
|
-
* MessageChannel is available in Node > 15.0.0. Since the current node
|
|
70
|
-
*
|
|
71
|
-
* for the current unit tests.
|
|
68
|
+
* MessageChannel is available in Node > 15.0.0. Since the current node environment's
|
|
69
|
+
* used for github actions is not above 14, we are mocking this for the current unit tests.
|
|
72
70
|
*/
|
|
73
71
|
export const messageChannelMock = {
|
|
74
72
|
port1: {},
|
|
@@ -81,13 +79,4 @@ export const mockMessageChannel = () => {
|
|
|
81
79
|
return messageChannelMock;
|
|
82
80
|
};
|
|
83
81
|
};
|
|
84
|
-
export const expectUrlMatchesWithParams = (source, target) => {
|
|
85
|
-
const sourceUrl = new URL(source);
|
|
86
|
-
const targetUrl = new URL(target);
|
|
87
|
-
expect(sourceUrl.origin).toBe(targetUrl.origin);
|
|
88
|
-
expect(sourceUrl.pathname).toBe(targetUrl.pathname);
|
|
89
|
-
const sourceParamsObj = Object.fromEntries(sourceUrl.searchParams);
|
|
90
|
-
const targetParamsObj = Object.fromEntries(targetUrl.searchParams);
|
|
91
|
-
expect(sourceParamsObj).toMatchObject(targetParamsObj);
|
|
92
|
-
};
|
|
93
82
|
//# sourceMappingURL=test-utils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"test-utils.js","sourceRoot":"","sources":["../../../src/test/test-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AAE5C;;
|
|
1
|
+
{"version":3,"file":"test-utils.js","sourceRoot":"","sources":["../../../src/test/test-utils.ts"],"names":[],"mappings":"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"}
|