@thoughtspot/visual-embed-sdk 1.40.1-alpha.3 → 1.40.2
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/cjs/package.json +2 -2
- package/cjs/src/embed/ts-embed.d.ts.map +1 -1
- package/cjs/src/embed/ts-embed.js +13 -2
- package/cjs/src/embed/ts-embed.js.map +1 -1
- package/cjs/src/embed/ts-embed.spec.d.ts.map +1 -1
- package/cjs/src/embed/ts-embed.spec.js +124 -2
- package/cjs/src/embed/ts-embed.spec.js.map +1 -1
- package/cjs/src/errors.d.ts +11 -0
- package/cjs/src/errors.d.ts.map +1 -1
- package/cjs/src/errors.js +12 -1
- package/cjs/src/errors.js.map +1 -1
- package/cjs/src/index.d.ts +2 -2
- package/cjs/src/index.d.ts.map +1 -1
- package/cjs/src/index.js +3 -1
- package/cjs/src/index.js.map +1 -1
- package/cjs/src/react/index.d.ts +1 -1
- package/cjs/src/react/index.d.ts.map +1 -1
- package/cjs/src/react/index.js +2 -1
- package/cjs/src/react/index.js.map +1 -1
- package/cjs/src/types.d.ts +94 -3
- package/cjs/src/types.d.ts.map +1 -1
- package/cjs/src/types.js +22 -11
- package/cjs/src/types.js.map +1 -1
- package/cjs/src/utils/custom-actions.d.ts +12 -0
- package/cjs/src/utils/custom-actions.d.ts.map +1 -0
- package/cjs/src/utils/custom-actions.js +191 -0
- package/cjs/src/utils/custom-actions.js.map +1 -0
- package/cjs/src/utils/custom-actions.spec.d.ts +2 -0
- package/cjs/src/utils/custom-actions.spec.d.ts.map +1 -0
- package/cjs/src/utils/custom-actions.spec.js +437 -0
- package/cjs/src/utils/custom-actions.spec.js.map +1 -0
- package/cjs/src/utils.d.ts +7 -0
- package/cjs/src/utils.d.ts.map +1 -1
- package/cjs/src/utils.js +11 -1
- package/cjs/src/utils.js.map +1 -1
- package/cjs/src/utils.spec.js +28 -0
- package/cjs/src/utils.spec.js.map +1 -1
- package/dist/{index-B0uCTBbm.js → index-Dx5UP5Ip.js} +1 -1
- package/dist/src/embed/ts-embed.d.ts.map +1 -1
- package/dist/src/embed/ts-embed.spec.d.ts.map +1 -1
- package/dist/src/errors.d.ts +11 -0
- package/dist/src/errors.d.ts.map +1 -1
- package/dist/src/index.d.ts +2 -2
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/react/index.d.ts +1 -1
- package/dist/src/react/index.d.ts.map +1 -1
- package/dist/src/types.d.ts +94 -3
- package/dist/src/types.d.ts.map +1 -1
- package/dist/src/utils/custom-actions.d.ts +12 -0
- package/dist/src/utils/custom-actions.d.ts.map +1 -0
- package/dist/src/utils/custom-actions.spec.d.ts +2 -0
- package/dist/src/utils/custom-actions.spec.d.ts.map +1 -0
- package/dist/src/utils.d.ts +7 -0
- package/dist/src/utils.d.ts.map +1 -1
- package/dist/tsembed-react.es.js +1684 -201
- package/dist/tsembed-react.js +1683 -200
- package/dist/tsembed.es.js +1636 -153
- package/dist/tsembed.js +1635 -152
- package/dist/visual-embed-sdk-react-full.d.ts +95 -4
- package/dist/visual-embed-sdk-react.d.ts +95 -4
- package/dist/visual-embed-sdk.d.ts +95 -4
- package/lib/package.json +2 -2
- package/lib/src/embed/ts-embed.d.ts.map +1 -1
- package/lib/src/embed/ts-embed.js +13 -2
- package/lib/src/embed/ts-embed.js.map +1 -1
- package/lib/src/embed/ts-embed.spec.d.ts.map +1 -1
- package/lib/src/embed/ts-embed.spec.js +125 -3
- package/lib/src/embed/ts-embed.spec.js.map +1 -1
- package/lib/src/errors.d.ts +11 -0
- package/lib/src/errors.d.ts.map +1 -1
- package/lib/src/errors.js +11 -0
- package/lib/src/errors.js.map +1 -1
- package/lib/src/index.d.ts +2 -2
- 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/react/index.d.ts +1 -1
- package/lib/src/react/index.d.ts.map +1 -1
- package/lib/src/react/index.js +1 -1
- package/lib/src/react/index.js.map +1 -1
- package/lib/src/types.d.ts +94 -3
- package/lib/src/types.d.ts.map +1 -1
- package/lib/src/types.js +21 -10
- package/lib/src/types.js.map +1 -1
- package/lib/src/utils/custom-actions.d.ts +12 -0
- package/lib/src/utils/custom-actions.d.ts.map +1 -0
- package/lib/src/utils/custom-actions.js +186 -0
- package/lib/src/utils/custom-actions.js.map +1 -0
- package/lib/src/utils/custom-actions.spec.d.ts +2 -0
- package/lib/src/utils/custom-actions.spec.d.ts.map +1 -0
- package/lib/src/utils/custom-actions.spec.js +435 -0
- package/lib/src/utils/custom-actions.spec.js.map +1 -0
- package/lib/src/utils.d.ts +7 -0
- package/lib/src/utils.d.ts.map +1 -1
- package/lib/src/utils.js +9 -0
- package/lib/src/utils.js.map +1 -1
- package/lib/src/utils.spec.js +29 -1
- package/lib/src/utils.spec.js.map +1 -1
- package/lib/src/visual-embed-sdk.d.ts +96 -5
- package/package.json +2 -2
- package/src/embed/ts-embed.spec.ts +137 -3
- package/src/embed/ts-embed.ts +13 -1
- package/src/errors.ts +12 -0
- package/src/index.ts +4 -0
- package/src/react/index.tsx +1 -0
- package/src/types.ts +110 -15
- package/src/utils/custom-actions.spec.ts +471 -0
- package/src/utils/custom-actions.ts +228 -0
- package/src/utils.spec.ts +34 -0
- package/src/utils.ts +10 -0
- package/dist/es/index-BwesxE_h.js +0 -7369
- package/dist/es/index.js +0 -17539
- package/dist/es/react/index.js +0 -24039
- package/dist/es/react/src/auth.d.ts +0 -171
- package/dist/es/react/src/auth.d.ts.map +0 -1
- package/dist/es/react/src/auth.spec.d.ts +0 -15
- package/dist/es/react/src/auth.spec.d.ts.map +0 -1
- package/dist/es/react/src/authToken.d.ts +0 -17
- package/dist/es/react/src/authToken.d.ts.map +0 -1
- package/dist/es/react/src/authToken.spec.d.ts +0 -2
- package/dist/es/react/src/authToken.spec.d.ts.map +0 -1
- package/dist/es/react/src/config.d.ts +0 -21
- package/dist/es/react/src/config.d.ts.map +0 -1
- package/dist/es/react/src/config.spec.d.ts +0 -5
- package/dist/es/react/src/config.spec.d.ts.map +0 -1
- package/dist/es/react/src/css-variables.d.ts +0 -384
- package/dist/es/react/src/css-variables.d.ts.map +0 -1
- package/dist/es/react/src/embed/app.d.ts +0 -478
- package/dist/es/react/src/embed/app.d.ts.map +0 -1
- package/dist/es/react/src/embed/app.spec.d.ts +0 -2
- package/dist/es/react/src/embed/app.spec.d.ts.map +0 -1
- package/dist/es/react/src/embed/base.d.ts +0 -136
- package/dist/es/react/src/embed/base.d.ts.map +0 -1
- package/dist/es/react/src/embed/base.spec.d.ts +0 -2
- package/dist/es/react/src/embed/base.spec.d.ts.map +0 -1
- package/dist/es/react/src/embed/bodyless-conversation.d.ts +0 -26
- package/dist/es/react/src/embed/bodyless-conversation.d.ts.map +0 -1
- package/dist/es/react/src/embed/bodyless-conversation.spec.d.ts +0 -2
- package/dist/es/react/src/embed/bodyless-conversation.spec.d.ts.map +0 -1
- package/dist/es/react/src/embed/conversation.d.ts +0 -43
- package/dist/es/react/src/embed/conversation.d.ts.map +0 -1
- package/dist/es/react/src/embed/conversation.spec.d.ts +0 -2
- package/dist/es/react/src/embed/conversation.spec.d.ts.map +0 -1
- package/dist/es/react/src/embed/embed.spec.d.ts +0 -2
- package/dist/es/react/src/embed/embed.spec.d.ts.map +0 -1
- package/dist/es/react/src/embed/embedConfig.d.ts +0 -17
- package/dist/es/react/src/embed/embedConfig.d.ts.map +0 -1
- package/dist/es/react/src/embed/events.spec.d.ts +0 -2
- package/dist/es/react/src/embed/events.spec.d.ts.map +0 -1
- package/dist/es/react/src/embed/liveboard.d.ts +0 -379
- package/dist/es/react/src/embed/liveboard.d.ts.map +0 -1
- package/dist/es/react/src/embed/liveboard.spec.d.ts +0 -2
- package/dist/es/react/src/embed/liveboard.spec.d.ts.map +0 -1
- package/dist/es/react/src/embed/pinboard.spec.d.ts +0 -2
- package/dist/es/react/src/embed/pinboard.spec.d.ts.map +0 -1
- package/dist/es/react/src/embed/sage.d.ts +0 -148
- package/dist/es/react/src/embed/sage.d.ts.map +0 -1
- package/dist/es/react/src/embed/sage.spec.d.ts +0 -2
- package/dist/es/react/src/embed/sage.spec.d.ts.map +0 -1
- package/dist/es/react/src/embed/search-bar.d.ts +0 -93
- package/dist/es/react/src/embed/search-bar.d.ts.map +0 -1
- package/dist/es/react/src/embed/search.d.ts +0 -282
- package/dist/es/react/src/embed/search.d.ts.map +0 -1
- package/dist/es/react/src/embed/search.spec.d.ts +0 -2
- package/dist/es/react/src/embed/search.spec.d.ts.map +0 -1
- package/dist/es/react/src/embed/ts-embed-trigger.spec.d.ts +0 -2
- package/dist/es/react/src/embed/ts-embed-trigger.spec.d.ts.map +0 -1
- package/dist/es/react/src/embed/ts-embed.d.ts +0 -374
- package/dist/es/react/src/embed/ts-embed.d.ts.map +0 -1
- package/dist/es/react/src/embed/ts-embed.spec.d.ts +0 -2
- package/dist/es/react/src/embed/ts-embed.spec.d.ts.map +0 -1
- package/dist/es/react/src/errors.d.ts +0 -19
- package/dist/es/react/src/errors.d.ts.map +0 -1
- package/dist/es/react/src/index.d.ts +0 -29
- package/dist/es/react/src/index.d.ts.map +0 -1
- package/dist/es/react/src/mixpanel-service.d.ts +0 -35
- package/dist/es/react/src/mixpanel-service.d.ts.map +0 -1
- package/dist/es/react/src/mixpanel-service.spec.d.ts +0 -2
- package/dist/es/react/src/mixpanel-service.spec.d.ts.map +0 -1
- package/dist/es/react/src/react/all-types-export.d.ts +0 -3
- package/dist/es/react/src/react/all-types-export.d.ts.map +0 -1
- package/dist/es/react/src/react/all-types-export.spec.d.ts +0 -2
- package/dist/es/react/src/react/all-types-export.spec.d.ts.map +0 -1
- package/dist/es/react/src/react/index.d.ts +0 -254
- package/dist/es/react/src/react/index.d.ts.map +0 -1
- package/dist/es/react/src/react/index.spec.d.ts +0 -3
- package/dist/es/react/src/react/index.spec.d.ts.map +0 -1
- package/dist/es/react/src/react/util.d.ts +0 -19
- package/dist/es/react/src/react/util.d.ts.map +0 -1
- package/dist/es/react/src/test/test-utils.d.ts +0 -61
- package/dist/es/react/src/test/test-utils.d.ts.map +0 -1
- package/dist/es/react/src/tokenizedFetch.d.ts +0 -18
- package/dist/es/react/src/tokenizedFetch.d.ts.map +0 -1
- package/dist/es/react/src/types.d.ts +0 -4363
- package/dist/es/react/src/types.d.ts.map +0 -1
- package/dist/es/react/src/utils/authService/authService.d.ts +0 -45
- package/dist/es/react/src/utils/authService/authService.d.ts.map +0 -1
- package/dist/es/react/src/utils/authService/authService.spec.d.ts +0 -2
- package/dist/es/react/src/utils/authService/authService.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/authService/index.d.ts +0 -3
- package/dist/es/react/src/utils/authService/index.d.ts.map +0 -1
- package/dist/es/react/src/utils/authService/tokenizedAuthService.d.ts +0 -22
- package/dist/es/react/src/utils/authService/tokenizedAuthService.d.ts.map +0 -1
- package/dist/es/react/src/utils/authService/tokenizedAuthService.spec.d.ts +0 -2
- package/dist/es/react/src/utils/authService/tokenizedAuthService.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/global-styles.d.ts +0 -2
- package/dist/es/react/src/utils/global-styles.d.ts.map +0 -1
- package/dist/es/react/src/utils/global-styles.spec.d.ts +0 -2
- package/dist/es/react/src/utils/global-styles.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/answerService/answer-queries.d.ts +0 -10
- package/dist/es/react/src/utils/graphql/answerService/answer-queries.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/answerService/answerService.d.ts +0 -180
- package/dist/es/react/src/utils/graphql/answerService/answerService.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/answerService/answerService.spec.d.ts +0 -2
- package/dist/es/react/src/utils/graphql/answerService/answerService.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/graphql-request.d.ts +0 -15
- package/dist/es/react/src/utils/graphql/graphql-request.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/graphql-request.spec.d.ts +0 -2
- package/dist/es/react/src/utils/graphql/graphql-request.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/nlsService/conversation-queries.d.ts +0 -3
- package/dist/es/react/src/utils/graphql/nlsService/conversation-queries.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/nlsService/conversation-service.d.ts +0 -12
- package/dist/es/react/src/utils/graphql/nlsService/conversation-service.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/nlsService/nls-answer-queries.d.ts +0 -2
- package/dist/es/react/src/utils/graphql/nlsService/nls-answer-queries.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/nlsService/nls-answer-service.d.ts +0 -17
- package/dist/es/react/src/utils/graphql/nlsService/nls-answer-service.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/nlsService/nls-answer-service.spec.d.ts +0 -2
- package/dist/es/react/src/utils/graphql/nlsService/nls-answer-service.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/preview-service.d.ts +0 -9
- package/dist/es/react/src/utils/graphql/preview-service.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/preview-service.spec.d.ts +0 -2
- package/dist/es/react/src/utils/graphql/preview-service.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/sourceService.d.ts +0 -8
- package/dist/es/react/src/utils/graphql/sourceService.d.ts.map +0 -1
- package/dist/es/react/src/utils/graphql/sourceService.spec.d.ts +0 -2
- package/dist/es/react/src/utils/graphql/sourceService.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/liveboardService/liveboardService.d.ts +0 -16
- package/dist/es/react/src/utils/liveboardService/liveboardService.d.ts.map +0 -1
- package/dist/es/react/src/utils/liveboardService/liveboardService.spec.d.ts +0 -2
- package/dist/es/react/src/utils/liveboardService/liveboardService.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/logger.d.ts +0 -18
- package/dist/es/react/src/utils/logger.d.ts.map +0 -1
- package/dist/es/react/src/utils/logger.spec.d.ts +0 -25
- package/dist/es/react/src/utils/logger.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/processData.d.ts +0 -22
- package/dist/es/react/src/utils/processData.d.ts.map +0 -1
- package/dist/es/react/src/utils/processData.spec.d.ts +0 -2
- package/dist/es/react/src/utils/processData.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/processTrigger.d.ts +0 -16
- package/dist/es/react/src/utils/processTrigger.d.ts.map +0 -1
- package/dist/es/react/src/utils/processTrigger.spec.d.ts +0 -2
- package/dist/es/react/src/utils/processTrigger.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/reporting.d.ts +0 -16
- package/dist/es/react/src/utils/reporting.d.ts.map +0 -1
- package/dist/es/react/src/utils/reporting.spec.d.ts +0 -2
- package/dist/es/react/src/utils/reporting.spec.d.ts.map +0 -1
- package/dist/es/react/src/utils/sessionInfoService.d.ts +0 -66
- package/dist/es/react/src/utils/sessionInfoService.d.ts.map +0 -1
- package/dist/es/react/src/utils.d.ts +0 -104
- package/dist/es/react/src/utils.d.ts.map +0 -1
- package/dist/es/react/src/utils.spec.d.ts +0 -2
- package/dist/es/react/src/utils.spec.d.ts.map +0 -1
- package/dist/es/src/auth.d.ts +0 -171
- package/dist/es/src/auth.d.ts.map +0 -1
- package/dist/es/src/auth.spec.d.ts +0 -15
- package/dist/es/src/auth.spec.d.ts.map +0 -1
- package/dist/es/src/authToken.d.ts +0 -17
- package/dist/es/src/authToken.d.ts.map +0 -1
- package/dist/es/src/authToken.spec.d.ts +0 -2
- package/dist/es/src/authToken.spec.d.ts.map +0 -1
- package/dist/es/src/config.d.ts +0 -21
- package/dist/es/src/config.d.ts.map +0 -1
- package/dist/es/src/config.spec.d.ts +0 -5
- package/dist/es/src/config.spec.d.ts.map +0 -1
- package/dist/es/src/css-variables.d.ts +0 -384
- package/dist/es/src/css-variables.d.ts.map +0 -1
- package/dist/es/src/embed/app.d.ts +0 -478
- package/dist/es/src/embed/app.d.ts.map +0 -1
- package/dist/es/src/embed/app.spec.d.ts +0 -2
- package/dist/es/src/embed/app.spec.d.ts.map +0 -1
- package/dist/es/src/embed/base.d.ts +0 -136
- package/dist/es/src/embed/base.d.ts.map +0 -1
- package/dist/es/src/embed/base.spec.d.ts +0 -2
- package/dist/es/src/embed/base.spec.d.ts.map +0 -1
- package/dist/es/src/embed/bodyless-conversation.d.ts +0 -26
- package/dist/es/src/embed/bodyless-conversation.d.ts.map +0 -1
- package/dist/es/src/embed/bodyless-conversation.spec.d.ts +0 -2
- package/dist/es/src/embed/bodyless-conversation.spec.d.ts.map +0 -1
- package/dist/es/src/embed/conversation.d.ts +0 -43
- package/dist/es/src/embed/conversation.d.ts.map +0 -1
- package/dist/es/src/embed/conversation.spec.d.ts +0 -2
- package/dist/es/src/embed/conversation.spec.d.ts.map +0 -1
- package/dist/es/src/embed/embed.spec.d.ts +0 -2
- package/dist/es/src/embed/embed.spec.d.ts.map +0 -1
- package/dist/es/src/embed/embedConfig.d.ts +0 -17
- package/dist/es/src/embed/embedConfig.d.ts.map +0 -1
- package/dist/es/src/embed/events.spec.d.ts +0 -2
- package/dist/es/src/embed/events.spec.d.ts.map +0 -1
- package/dist/es/src/embed/liveboard.d.ts +0 -379
- package/dist/es/src/embed/liveboard.d.ts.map +0 -1
- package/dist/es/src/embed/liveboard.spec.d.ts +0 -2
- package/dist/es/src/embed/liveboard.spec.d.ts.map +0 -1
- package/dist/es/src/embed/pinboard.spec.d.ts +0 -2
- package/dist/es/src/embed/pinboard.spec.d.ts.map +0 -1
- package/dist/es/src/embed/sage.d.ts +0 -148
- package/dist/es/src/embed/sage.d.ts.map +0 -1
- package/dist/es/src/embed/sage.spec.d.ts +0 -2
- package/dist/es/src/embed/sage.spec.d.ts.map +0 -1
- package/dist/es/src/embed/search-bar.d.ts +0 -93
- package/dist/es/src/embed/search-bar.d.ts.map +0 -1
- package/dist/es/src/embed/search.d.ts +0 -282
- package/dist/es/src/embed/search.d.ts.map +0 -1
- package/dist/es/src/embed/search.spec.d.ts +0 -2
- package/dist/es/src/embed/search.spec.d.ts.map +0 -1
- package/dist/es/src/embed/ts-embed-trigger.spec.d.ts +0 -2
- package/dist/es/src/embed/ts-embed-trigger.spec.d.ts.map +0 -1
- package/dist/es/src/embed/ts-embed.d.ts +0 -374
- package/dist/es/src/embed/ts-embed.d.ts.map +0 -1
- package/dist/es/src/embed/ts-embed.spec.d.ts +0 -2
- package/dist/es/src/embed/ts-embed.spec.d.ts.map +0 -1
- package/dist/es/src/errors.d.ts +0 -19
- package/dist/es/src/errors.d.ts.map +0 -1
- package/dist/es/src/index.d.ts +0 -29
- package/dist/es/src/index.d.ts.map +0 -1
- package/dist/es/src/mixpanel-service.d.ts +0 -35
- package/dist/es/src/mixpanel-service.d.ts.map +0 -1
- package/dist/es/src/mixpanel-service.spec.d.ts +0 -2
- package/dist/es/src/mixpanel-service.spec.d.ts.map +0 -1
- package/dist/es/src/react/all-types-export.d.ts +0 -3
- package/dist/es/src/react/all-types-export.d.ts.map +0 -1
- package/dist/es/src/react/all-types-export.spec.d.ts +0 -2
- package/dist/es/src/react/all-types-export.spec.d.ts.map +0 -1
- package/dist/es/src/react/index.d.ts +0 -254
- package/dist/es/src/react/index.d.ts.map +0 -1
- package/dist/es/src/react/index.spec.d.ts +0 -3
- package/dist/es/src/react/index.spec.d.ts.map +0 -1
- package/dist/es/src/react/util.d.ts +0 -19
- package/dist/es/src/react/util.d.ts.map +0 -1
- package/dist/es/src/test/test-utils.d.ts +0 -61
- package/dist/es/src/test/test-utils.d.ts.map +0 -1
- package/dist/es/src/tokenizedFetch.d.ts +0 -18
- package/dist/es/src/tokenizedFetch.d.ts.map +0 -1
- package/dist/es/src/types.d.ts +0 -4363
- package/dist/es/src/types.d.ts.map +0 -1
- package/dist/es/src/utils/authService/authService.d.ts +0 -45
- package/dist/es/src/utils/authService/authService.d.ts.map +0 -1
- package/dist/es/src/utils/authService/authService.spec.d.ts +0 -2
- package/dist/es/src/utils/authService/authService.spec.d.ts.map +0 -1
- package/dist/es/src/utils/authService/index.d.ts +0 -3
- package/dist/es/src/utils/authService/index.d.ts.map +0 -1
- package/dist/es/src/utils/authService/tokenizedAuthService.d.ts +0 -22
- package/dist/es/src/utils/authService/tokenizedAuthService.d.ts.map +0 -1
- package/dist/es/src/utils/authService/tokenizedAuthService.spec.d.ts +0 -2
- package/dist/es/src/utils/authService/tokenizedAuthService.spec.d.ts.map +0 -1
- package/dist/es/src/utils/global-styles.d.ts +0 -2
- package/dist/es/src/utils/global-styles.d.ts.map +0 -1
- package/dist/es/src/utils/global-styles.spec.d.ts +0 -2
- package/dist/es/src/utils/global-styles.spec.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/answerService/answer-queries.d.ts +0 -10
- package/dist/es/src/utils/graphql/answerService/answer-queries.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/answerService/answerService.d.ts +0 -180
- package/dist/es/src/utils/graphql/answerService/answerService.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/answerService/answerService.spec.d.ts +0 -2
- package/dist/es/src/utils/graphql/answerService/answerService.spec.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/graphql-request.d.ts +0 -15
- package/dist/es/src/utils/graphql/graphql-request.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/graphql-request.spec.d.ts +0 -2
- package/dist/es/src/utils/graphql/graphql-request.spec.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/nlsService/conversation-queries.d.ts +0 -3
- package/dist/es/src/utils/graphql/nlsService/conversation-queries.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/nlsService/conversation-service.d.ts +0 -12
- package/dist/es/src/utils/graphql/nlsService/conversation-service.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/nlsService/nls-answer-queries.d.ts +0 -2
- package/dist/es/src/utils/graphql/nlsService/nls-answer-queries.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/nlsService/nls-answer-service.d.ts +0 -17
- package/dist/es/src/utils/graphql/nlsService/nls-answer-service.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/nlsService/nls-answer-service.spec.d.ts +0 -2
- package/dist/es/src/utils/graphql/nlsService/nls-answer-service.spec.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/preview-service.d.ts +0 -9
- package/dist/es/src/utils/graphql/preview-service.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/preview-service.spec.d.ts +0 -2
- package/dist/es/src/utils/graphql/preview-service.spec.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/sourceService.d.ts +0 -8
- package/dist/es/src/utils/graphql/sourceService.d.ts.map +0 -1
- package/dist/es/src/utils/graphql/sourceService.spec.d.ts +0 -2
- package/dist/es/src/utils/graphql/sourceService.spec.d.ts.map +0 -1
- package/dist/es/src/utils/liveboardService/liveboardService.d.ts +0 -16
- package/dist/es/src/utils/liveboardService/liveboardService.d.ts.map +0 -1
- package/dist/es/src/utils/liveboardService/liveboardService.spec.d.ts +0 -2
- package/dist/es/src/utils/liveboardService/liveboardService.spec.d.ts.map +0 -1
- package/dist/es/src/utils/logger.d.ts +0 -18
- package/dist/es/src/utils/logger.d.ts.map +0 -1
- package/dist/es/src/utils/logger.spec.d.ts +0 -25
- package/dist/es/src/utils/logger.spec.d.ts.map +0 -1
- package/dist/es/src/utils/processData.d.ts +0 -22
- package/dist/es/src/utils/processData.d.ts.map +0 -1
- package/dist/es/src/utils/processData.spec.d.ts +0 -2
- package/dist/es/src/utils/processData.spec.d.ts.map +0 -1
- package/dist/es/src/utils/processTrigger.d.ts +0 -16
- package/dist/es/src/utils/processTrigger.d.ts.map +0 -1
- package/dist/es/src/utils/processTrigger.spec.d.ts +0 -2
- package/dist/es/src/utils/processTrigger.spec.d.ts.map +0 -1
- package/dist/es/src/utils/reporting.d.ts +0 -16
- package/dist/es/src/utils/reporting.d.ts.map +0 -1
- package/dist/es/src/utils/reporting.spec.d.ts +0 -2
- package/dist/es/src/utils/reporting.spec.d.ts.map +0 -1
- package/dist/es/src/utils/sessionInfoService.d.ts +0 -66
- package/dist/es/src/utils/sessionInfoService.d.ts.map +0 -1
- package/dist/es/src/utils.d.ts +0 -104
- package/dist/es/src/utils.d.ts.map +0 -1
- package/dist/es/src/utils.spec.d.ts +0 -2
- package/dist/es/src/utils.spec.d.ts.map +0 -1
|
@@ -0,0 +1,471 @@
|
|
|
1
|
+
import { getCustomActions } from './custom-actions';
|
|
2
|
+
import { CustomAction, CustomActionsPosition, CustomActionTarget } from '../types';
|
|
3
|
+
import { logger } from './logger';
|
|
4
|
+
|
|
5
|
+
// Mock logger
|
|
6
|
+
jest.mock('./logger', () => ({
|
|
7
|
+
logger: {
|
|
8
|
+
warn: jest.fn(),
|
|
9
|
+
error: jest.fn(),
|
|
10
|
+
},
|
|
11
|
+
}));
|
|
12
|
+
|
|
13
|
+
describe('getCustomActions function', () => {
|
|
14
|
+
describe('Static getCustomActions method', () => {
|
|
15
|
+
test('should return empty result for empty array', () => {
|
|
16
|
+
const result = getCustomActions([]);
|
|
17
|
+
expect(result.actions).toEqual([]);
|
|
18
|
+
expect(result.errors).toEqual([]);
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
test('should return empty result for null/undefined input', () => {
|
|
22
|
+
const result1 = getCustomActions(null as any);
|
|
23
|
+
expect(result1.actions).toEqual([]);
|
|
24
|
+
expect(result1.errors).toEqual([]);
|
|
25
|
+
|
|
26
|
+
const result2 = getCustomActions(undefined as any);
|
|
27
|
+
expect(result2.actions).toEqual([]);
|
|
28
|
+
expect(result2.errors).toEqual([]);
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
test('should validate and return valid actions', () => {
|
|
32
|
+
const actions: CustomAction[] = [
|
|
33
|
+
{
|
|
34
|
+
name: 'Test Action',
|
|
35
|
+
id: 'test-id',
|
|
36
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
37
|
+
position: CustomActionsPosition.PRIMARY,
|
|
38
|
+
},
|
|
39
|
+
];
|
|
40
|
+
const result = getCustomActions(actions);
|
|
41
|
+
|
|
42
|
+
expect(result.actions).toEqual(actions);
|
|
43
|
+
expect(result.errors).toEqual([]);
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
test('should reject invalid actions and collect errors', () => {
|
|
47
|
+
const actions: CustomAction[] = [
|
|
48
|
+
{
|
|
49
|
+
name: 'Valid Action',
|
|
50
|
+
id: 'valid-id',
|
|
51
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
52
|
+
position: CustomActionsPosition.PRIMARY,
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
name: 'Invalid Action',
|
|
56
|
+
id: 'invalid-id',
|
|
57
|
+
target: CustomActionTarget.SPOTTER,
|
|
58
|
+
position: CustomActionsPosition.PRIMARY, // Invalid for SPOTTER
|
|
59
|
+
},
|
|
60
|
+
];
|
|
61
|
+
const result = getCustomActions(actions);
|
|
62
|
+
|
|
63
|
+
expect(result.actions).toEqual([actions[0]]);
|
|
64
|
+
expect(result.errors).toHaveLength(1);
|
|
65
|
+
expect(result.errors[0]).toContain("Position 'PRIMARY' is not supported for spotter-level custom actions. Supported positions: MENU, CONTEXTMENU");
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
test('should sort actions by name', () => {
|
|
69
|
+
const actions: CustomAction[] = [
|
|
70
|
+
{
|
|
71
|
+
name: 'Zebra Action',
|
|
72
|
+
id: 'zebra-id',
|
|
73
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
74
|
+
position: CustomActionsPosition.PRIMARY,
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
name: 'Alpha Action',
|
|
78
|
+
id: 'alpha-id',
|
|
79
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
80
|
+
position: CustomActionsPosition.MENU,
|
|
81
|
+
},
|
|
82
|
+
];
|
|
83
|
+
const result = getCustomActions(actions);
|
|
84
|
+
|
|
85
|
+
expect(result.actions).toHaveLength(2);
|
|
86
|
+
expect(result.actions[0].name).toBe('Alpha Action');
|
|
87
|
+
expect(result.actions[1].name).toBe('Zebra Action');
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
describe('Input Validation', () => {
|
|
92
|
+
test('should return false for null action', () => {
|
|
93
|
+
const result = getCustomActions([null as any]);
|
|
94
|
+
expect(result.actions).toEqual([]);
|
|
95
|
+
expect(result.errors).toHaveLength(1);
|
|
96
|
+
expect(result.errors[0]).toContain('Custom Action Validation Error: Invalid action object provided');
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
test('should return false for undefined action', () => {
|
|
100
|
+
const result = getCustomActions([undefined as any]);
|
|
101
|
+
expect(result.actions).toEqual([]);
|
|
102
|
+
expect(result.errors).toHaveLength(1);
|
|
103
|
+
expect(result.errors[0]).toContain('Custom Action Validation Error: Invalid action object provided');
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
test('should return false for non-object action', () => {
|
|
107
|
+
const result = getCustomActions(['string' as any]);
|
|
108
|
+
expect(result.actions).toEqual([]);
|
|
109
|
+
expect(result.errors).toHaveLength(1);
|
|
110
|
+
expect(result.errors[0]).toContain('Custom Action Validation Error: Invalid action object provided');
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
test('should return false for action missing id', () => {
|
|
114
|
+
const action = {
|
|
115
|
+
name: 'Test Action',
|
|
116
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
117
|
+
position: CustomActionsPosition.PRIMARY,
|
|
118
|
+
};
|
|
119
|
+
const result = getCustomActions([action as CustomAction]);
|
|
120
|
+
expect(result.actions).toEqual([]);
|
|
121
|
+
expect(result.errors).toHaveLength(1);
|
|
122
|
+
expect(result.errors[0]).toContain("Missing required fields: id");
|
|
123
|
+
});
|
|
124
|
+
|
|
125
|
+
test('should return false for action missing name', () => {
|
|
126
|
+
const action = {
|
|
127
|
+
id: 'test-id',
|
|
128
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
129
|
+
position: CustomActionsPosition.PRIMARY,
|
|
130
|
+
};
|
|
131
|
+
const result = getCustomActions([action as CustomAction]);
|
|
132
|
+
expect(result.actions).toEqual([]);
|
|
133
|
+
expect(result.errors).toHaveLength(1);
|
|
134
|
+
expect(result.errors[0]).toContain("Missing required fields: name");
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
test('should return false for action missing target', () => {
|
|
138
|
+
const action = {
|
|
139
|
+
id: 'test-id',
|
|
140
|
+
name: 'Test Action',
|
|
141
|
+
position: CustomActionsPosition.PRIMARY,
|
|
142
|
+
};
|
|
143
|
+
const result = getCustomActions([action as CustomAction]);
|
|
144
|
+
expect(result.actions).toEqual([]);
|
|
145
|
+
expect(result.errors).toHaveLength(1);
|
|
146
|
+
expect(result.errors[0]).toContain("Missing required fields: target");
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
test('should return false for action missing position', () => {
|
|
150
|
+
const action = {
|
|
151
|
+
id: 'test-id',
|
|
152
|
+
name: 'Test Action',
|
|
153
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
154
|
+
};
|
|
155
|
+
const result = getCustomActions([action as CustomAction]);
|
|
156
|
+
expect(result.actions).toEqual([]);
|
|
157
|
+
expect(result.errors).toHaveLength(1);
|
|
158
|
+
expect(result.errors[0]).toContain("Missing required fields: position");
|
|
159
|
+
});
|
|
160
|
+
});
|
|
161
|
+
|
|
162
|
+
describe('Target Type Validation', () => {
|
|
163
|
+
test('should reject unsupported target type', () => {
|
|
164
|
+
const action = {
|
|
165
|
+
id: 'test-id',
|
|
166
|
+
name: 'Test Action',
|
|
167
|
+
target: 'UNSUPPORTED' as any,
|
|
168
|
+
position: CustomActionsPosition.PRIMARY,
|
|
169
|
+
};
|
|
170
|
+
const result = getCustomActions([action]);
|
|
171
|
+
expect(result.actions).toEqual([]);
|
|
172
|
+
expect(result.errors).toHaveLength(1);
|
|
173
|
+
expect(result.errors[0]).toContain("Target type 'UNSUPPORTED' is not supported");
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
test('should accept LIVEBOARD target type', () => {
|
|
177
|
+
const action = {
|
|
178
|
+
id: 'test-id',
|
|
179
|
+
name: 'Test Action',
|
|
180
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
181
|
+
position: CustomActionsPosition.PRIMARY,
|
|
182
|
+
};
|
|
183
|
+
const result = getCustomActions([action]);
|
|
184
|
+
expect(result.actions).toEqual([action]);
|
|
185
|
+
expect(result.errors).toEqual([]);
|
|
186
|
+
});
|
|
187
|
+
|
|
188
|
+
test('should accept VIZ target type', () => {
|
|
189
|
+
const action = {
|
|
190
|
+
id: 'test-id',
|
|
191
|
+
name: 'Test Action',
|
|
192
|
+
target: CustomActionTarget.VIZ,
|
|
193
|
+
position: CustomActionsPosition.MENU,
|
|
194
|
+
};
|
|
195
|
+
const result = getCustomActions([action]);
|
|
196
|
+
expect(result.actions).toEqual([action]);
|
|
197
|
+
expect(result.errors).toEqual([]);
|
|
198
|
+
});
|
|
199
|
+
|
|
200
|
+
test('should accept ANSWER target type', () => {
|
|
201
|
+
const action = {
|
|
202
|
+
id: 'test-id',
|
|
203
|
+
name: 'Test Action',
|
|
204
|
+
target: CustomActionTarget.ANSWER,
|
|
205
|
+
position: CustomActionsPosition.MENU,
|
|
206
|
+
};
|
|
207
|
+
const result = getCustomActions([action]);
|
|
208
|
+
expect(result.actions).toEqual([action]);
|
|
209
|
+
expect(result.errors).toEqual([]);
|
|
210
|
+
});
|
|
211
|
+
|
|
212
|
+
test('should accept SPOTTER target type', () => {
|
|
213
|
+
const action = {
|
|
214
|
+
id: 'test-id',
|
|
215
|
+
name: 'Test Action',
|
|
216
|
+
target: CustomActionTarget.SPOTTER,
|
|
217
|
+
position: CustomActionsPosition.MENU,
|
|
218
|
+
};
|
|
219
|
+
const result = getCustomActions([action]);
|
|
220
|
+
expect(result.actions).toEqual([action]);
|
|
221
|
+
expect(result.errors).toEqual([]);
|
|
222
|
+
});
|
|
223
|
+
});
|
|
224
|
+
|
|
225
|
+
describe('Position Validation', () => {
|
|
226
|
+
test('should reject invalid position for LIVEBOARD', () => {
|
|
227
|
+
const action = {
|
|
228
|
+
id: 'test-id',
|
|
229
|
+
name: 'Test Action',
|
|
230
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
231
|
+
position: CustomActionsPosition.CONTEXTMENU, // Invalid for LIVEBOARD
|
|
232
|
+
};
|
|
233
|
+
const result = getCustomActions([action]);
|
|
234
|
+
expect(result.actions).toEqual([]);
|
|
235
|
+
expect(result.errors).toHaveLength(1);
|
|
236
|
+
expect(result.errors).toContain("Position 'CONTEXTMENU' is not supported for liveboard-level custom actions. Supported positions: PRIMARY, MENU");
|
|
237
|
+
});
|
|
238
|
+
|
|
239
|
+
test('should reject invalid position for SPOTTER', () => {
|
|
240
|
+
const action = {
|
|
241
|
+
id: 'test-id',
|
|
242
|
+
name: 'Test Action',
|
|
243
|
+
target: CustomActionTarget.SPOTTER,
|
|
244
|
+
position: CustomActionsPosition.PRIMARY, // Invalid for SPOTTER
|
|
245
|
+
};
|
|
246
|
+
const result = getCustomActions([action]);
|
|
247
|
+
expect(result.actions).toEqual([]);
|
|
248
|
+
expect(result.errors).toHaveLength(1);
|
|
249
|
+
expect(result.errors[0]).toContain("Position 'PRIMARY' is not supported for spotter-level custom actions. Supported positions: MENU, CONTEXTMENU");
|
|
250
|
+
});
|
|
251
|
+
|
|
252
|
+
test('should accept valid positions for LIVEBOARD', () => {
|
|
253
|
+
const primaryAction = {
|
|
254
|
+
id: 'primary-id',
|
|
255
|
+
name: 'Primary Action',
|
|
256
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
257
|
+
position: CustomActionsPosition.PRIMARY,
|
|
258
|
+
};
|
|
259
|
+
const menuAction = {
|
|
260
|
+
id: 'menu-id',
|
|
261
|
+
name: 'Menu Action',
|
|
262
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
263
|
+
position: CustomActionsPosition.MENU,
|
|
264
|
+
};
|
|
265
|
+
const result = getCustomActions([primaryAction, menuAction]);
|
|
266
|
+
expect(result.actions).toHaveLength(2);
|
|
267
|
+
expect(result.errors).toEqual([]);
|
|
268
|
+
});
|
|
269
|
+
});
|
|
270
|
+
|
|
271
|
+
describe('Primary Action Conflicts', () => {
|
|
272
|
+
test('should warn about multiple primary actions for same target', () => {
|
|
273
|
+
const firstAction = {
|
|
274
|
+
id: 'first-id',
|
|
275
|
+
name: 'First Action',
|
|
276
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
277
|
+
position: CustomActionsPosition.PRIMARY,
|
|
278
|
+
};
|
|
279
|
+
const secondAction = {
|
|
280
|
+
id: 'second-id',
|
|
281
|
+
name: 'Second Action',
|
|
282
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
283
|
+
position: CustomActionsPosition.PRIMARY,
|
|
284
|
+
};
|
|
285
|
+
const result = getCustomActions([firstAction, secondAction]);
|
|
286
|
+
expect(result.actions).toHaveLength(1);
|
|
287
|
+
expect(result.actions[0]).toEqual(firstAction);
|
|
288
|
+
expect(result.errors).toHaveLength(1);
|
|
289
|
+
expect(result.errors[0]).toContain("Multiple primary actions found for liveboard-level custom actions");
|
|
290
|
+
});
|
|
291
|
+
|
|
292
|
+
test('should allow multiple primary actions for different targets', () => {
|
|
293
|
+
const liveboardAction = {
|
|
294
|
+
id: 'lb-id',
|
|
295
|
+
name: 'Liveboard Action',
|
|
296
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
297
|
+
position: CustomActionsPosition.PRIMARY,
|
|
298
|
+
};
|
|
299
|
+
const vizAction = {
|
|
300
|
+
id: 'viz-id',
|
|
301
|
+
name: 'Viz Action',
|
|
302
|
+
target: CustomActionTarget.VIZ,
|
|
303
|
+
position: CustomActionsPosition.PRIMARY,
|
|
304
|
+
};
|
|
305
|
+
const result = getCustomActions([liveboardAction, vizAction]);
|
|
306
|
+
expect(result.actions).toHaveLength(2);
|
|
307
|
+
expect(result.errors).toEqual([]);
|
|
308
|
+
});
|
|
309
|
+
});
|
|
310
|
+
|
|
311
|
+
describe('Metadata IDs Validation', () => {
|
|
312
|
+
test('should reject invalid metadata IDs for LIVEBOARD', () => {
|
|
313
|
+
const action = {
|
|
314
|
+
id: 'test-id',
|
|
315
|
+
name: 'Test Action',
|
|
316
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
317
|
+
position: CustomActionsPosition.PRIMARY,
|
|
318
|
+
metadataIds: {
|
|
319
|
+
invalidId: 'some-value',
|
|
320
|
+
},
|
|
321
|
+
} as any;
|
|
322
|
+
const result = getCustomActions([action]);
|
|
323
|
+
expect(result.actions).toEqual([]);
|
|
324
|
+
expect(result.errors).toHaveLength(1);
|
|
325
|
+
expect(result.errors[0]).toContain("Invalid metadata IDs for liveboard-level custom actions: invalidId. Supported metadata IDs: liveboardIds");
|
|
326
|
+
});
|
|
327
|
+
|
|
328
|
+
test('should accept valid metadata IDs for LIVEBOARD', () => {
|
|
329
|
+
const action = {
|
|
330
|
+
id: 'test-id',
|
|
331
|
+
name: 'Test Action',
|
|
332
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
333
|
+
position: CustomActionsPosition.PRIMARY,
|
|
334
|
+
metadataIds: {
|
|
335
|
+
liveboardIds: ['lb-1', 'lb-2'],
|
|
336
|
+
},
|
|
337
|
+
};
|
|
338
|
+
const result = getCustomActions([action]);
|
|
339
|
+
expect(result.actions).toEqual([action]);
|
|
340
|
+
expect(result.errors).toEqual([]);
|
|
341
|
+
});
|
|
342
|
+
});
|
|
343
|
+
|
|
344
|
+
describe('Data Model IDs Validation', () => {
|
|
345
|
+
test('should reject invalid data model IDs for VIZ', () => {
|
|
346
|
+
const action = {
|
|
347
|
+
id: 'test-id',
|
|
348
|
+
name: 'Test Action',
|
|
349
|
+
target: CustomActionTarget.VIZ,
|
|
350
|
+
position: CustomActionsPosition.MENU,
|
|
351
|
+
dataModelIds: {
|
|
352
|
+
invalidId: 'some-value',
|
|
353
|
+
},
|
|
354
|
+
} as any;
|
|
355
|
+
const result = getCustomActions([action]);
|
|
356
|
+
expect(result.actions).toEqual([]);
|
|
357
|
+
expect(result.errors).toHaveLength(1);
|
|
358
|
+
expect(result.errors[0]).toContain("Invalid data model IDs for viz-level custom actions: invalidId. Supported data model IDs: modelIds, modelColumnNames");
|
|
359
|
+
});
|
|
360
|
+
|
|
361
|
+
test('should accept valid data model IDs for VIZ', () => {
|
|
362
|
+
const action = {
|
|
363
|
+
id: 'test-id',
|
|
364
|
+
name: 'Test Action',
|
|
365
|
+
target: CustomActionTarget.VIZ,
|
|
366
|
+
position: CustomActionsPosition.MENU,
|
|
367
|
+
dataModelIds: {
|
|
368
|
+
modelIds: ['model-1'],
|
|
369
|
+
modelColumnNames: ['col-1'],
|
|
370
|
+
},
|
|
371
|
+
};
|
|
372
|
+
const result = getCustomActions([action]);
|
|
373
|
+
expect(result.actions).toEqual([action]);
|
|
374
|
+
expect(result.errors).toEqual([]);
|
|
375
|
+
});
|
|
376
|
+
});
|
|
377
|
+
|
|
378
|
+
describe('Field Validation', () => {
|
|
379
|
+
test('should reject invalid fields for LIVEBOARD', () => {
|
|
380
|
+
const action = {
|
|
381
|
+
id: 'test-id',
|
|
382
|
+
name: 'Test Action',
|
|
383
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
384
|
+
position: CustomActionsPosition.PRIMARY,
|
|
385
|
+
invalidField: 'some-value',
|
|
386
|
+
};
|
|
387
|
+
const result = getCustomActions([action]);
|
|
388
|
+
expect(result.actions).toEqual([]);
|
|
389
|
+
expect(result.errors).toHaveLength(1);
|
|
390
|
+
expect(result.errors[0]).toContain("Invalid fields for liveboard-level custom actions: invalidField. Supported fields: name, id, position, target, metadataIds, orgIds, groupIds");
|
|
391
|
+
});
|
|
392
|
+
|
|
393
|
+
test('should accept valid fields for LIVEBOARD', () => {
|
|
394
|
+
const action = {
|
|
395
|
+
id: 'test-id',
|
|
396
|
+
name: 'Test Action',
|
|
397
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
398
|
+
position: CustomActionsPosition.PRIMARY,
|
|
399
|
+
orgIds: ['org-1'],
|
|
400
|
+
groupIds: ['group-1'],
|
|
401
|
+
};
|
|
402
|
+
const result = getCustomActions([action]);
|
|
403
|
+
expect(result.actions).toEqual([action]);
|
|
404
|
+
expect(result.errors).toEqual([]);
|
|
405
|
+
});
|
|
406
|
+
});
|
|
407
|
+
|
|
408
|
+
describe('Duplicate ID Handling', () => {
|
|
409
|
+
test('should keep only the first action when duplicate IDs are found and report duplicate errors', () => {
|
|
410
|
+
const action1 = {
|
|
411
|
+
id: 'duplicate-id',
|
|
412
|
+
name: 'First Action',
|
|
413
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
414
|
+
position: CustomActionsPosition.PRIMARY,
|
|
415
|
+
};
|
|
416
|
+
const action2 = {
|
|
417
|
+
id: 'duplicate-id',
|
|
418
|
+
name: 'Second Action',
|
|
419
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
420
|
+
position: CustomActionsPosition.MENU,
|
|
421
|
+
};
|
|
422
|
+
const result = getCustomActions([action1, action2]);
|
|
423
|
+
expect(result.actions).toHaveLength(1);
|
|
424
|
+
expect(result.actions[0]).toEqual(action1);
|
|
425
|
+
expect(result.errors).toHaveLength(1);
|
|
426
|
+
expect(result.errors[0]).toContain("Duplicate custom action ID 'duplicate-id' found");
|
|
427
|
+
expect(result.errors[0]).toContain("Actions with names 'Second Action' will be ignored");
|
|
428
|
+
expect(result.errors[0]).toContain("Keeping 'First Action'");
|
|
429
|
+
});
|
|
430
|
+
});
|
|
431
|
+
|
|
432
|
+
describe('Complex Validation Scenarios', () => {
|
|
433
|
+
test('should handle multiple validation errors for a single action', () => {
|
|
434
|
+
const action = {
|
|
435
|
+
id: 'test-id',
|
|
436
|
+
name: 'Test Action',
|
|
437
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
438
|
+
position: CustomActionsPosition.CONTEXTMENU, // Invalid position
|
|
439
|
+
metadataIds: {
|
|
440
|
+
invalidId: 'some-value', // Invalid metadata ID
|
|
441
|
+
},
|
|
442
|
+
invalidField: 'some-value', // Invalid field
|
|
443
|
+
} as any;
|
|
444
|
+
const result = getCustomActions([action]);
|
|
445
|
+
expect(result.actions).toEqual([]);
|
|
446
|
+
expect(result.errors).toHaveLength(3);
|
|
447
|
+
expect(result.errors).toContain("Position 'CONTEXTMENU' is not supported for liveboard-level custom actions. Supported positions: PRIMARY, MENU");
|
|
448
|
+
expect(result.errors).toContain("Invalid metadata IDs for liveboard-level custom actions: invalidId. Supported metadata IDs: liveboardIds");
|
|
449
|
+
expect(result.errors).toContain("Invalid fields for liveboard-level custom actions: invalidField. Supported fields: name, id, position, target, metadataIds, orgIds, groupIds");
|
|
450
|
+
});
|
|
451
|
+
|
|
452
|
+
test('should handle mix of valid and invalid actions', () => {
|
|
453
|
+
const validAction = {
|
|
454
|
+
id: 'valid-id',
|
|
455
|
+
name: 'Valid Action',
|
|
456
|
+
target: CustomActionTarget.LIVEBOARD,
|
|
457
|
+
position: CustomActionsPosition.PRIMARY,
|
|
458
|
+
};
|
|
459
|
+
const invalidAction = {
|
|
460
|
+
id: 'invalid-id',
|
|
461
|
+
name: 'Invalid Action',
|
|
462
|
+
target: CustomActionTarget.SPOTTER,
|
|
463
|
+
position: CustomActionsPosition.PRIMARY, // Invalid for SPOTTER
|
|
464
|
+
};
|
|
465
|
+
const result = getCustomActions([validAction, invalidAction]);
|
|
466
|
+
expect(result.actions).toEqual([validAction]);
|
|
467
|
+
expect(result.errors).toHaveLength(1);
|
|
468
|
+
expect(result.errors[0]).toContain("Position 'PRIMARY' is not supported for spotter-level custom actions. Supported positions: MENU, CONTEXTMENU");
|
|
469
|
+
});
|
|
470
|
+
});
|
|
471
|
+
});
|