@sisense/sdk-ui 1.4.1 → 1.6.0

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.
Files changed (97) hide show
  1. package/dist/ai/ai-context-provider.d.ts +1 -0
  2. package/dist/ai/api/chat-rest-api.d.ts +3 -0
  3. package/dist/ai/api/errors.d.ts +2 -1
  4. package/dist/ai/api/types.d.ts +10 -11
  5. package/dist/ai/chat-config.d.ts +10 -3
  6. package/dist/ai/chat-intro-blurb.d.ts +4 -0
  7. package/dist/ai/chatbot.d.ts +3 -2
  8. package/dist/ai/common/collapsible.d.ts +11 -0
  9. package/dist/ai/get-nlg-query-result.d.ts +12 -52
  10. package/dist/ai/icons/loading-dots-gif-base64.d.ts +2 -0
  11. package/dist/ai/index.d.ts +4 -2
  12. package/dist/ai/messages/feedback-wrapper.d.ts +2 -1
  13. package/dist/ai/messages/insights-message.d.ts +6 -4
  14. package/dist/ai/messages/message-list-resolver.d.ts +1 -2
  15. package/dist/ai/messages/message-resolver.d.ts +1 -3
  16. package/dist/ai/messages/nlq-message-group.d.ts +10 -0
  17. package/dist/ai/suggestions/index.d.ts +1 -1
  18. package/dist/ai/suggestions/suggestion-list.d.ts +1 -1
  19. package/dist/ai/suggestions/suggestions-with-intro.d.ts +2 -2
  20. package/dist/ai/translators/code-templates.d.ts +11 -0
  21. package/dist/ai/translators/generate-code.d.ts +9 -0
  22. package/dist/ai/translators/index.d.ts +4 -0
  23. package/dist/ai/translators/model-translator.d.ts +50 -0
  24. package/dist/ai/translators/query-translator.d.ts +122 -0
  25. package/dist/ai/translators/translate-props-to-code.d.ts +8 -0
  26. package/dist/ai/translators/types.d.ts +105 -0
  27. package/dist/ai/translators/use-get-data-source.d.ts +12 -0
  28. package/dist/ai/translators/utils.d.ts +2 -0
  29. package/dist/ai/use-chat-session.d.ts +9 -3
  30. package/dist/ai/use-get-nlg-query-result.d.ts +42 -66
  31. package/dist/ai/use-get-query-recommendations.d.ts +32 -34
  32. package/dist/ai.js +7101 -1729
  33. package/dist/area-chart.d.ts +1 -0
  34. package/dist/areamap-chart.d.ts +1 -0
  35. package/dist/bar-chart.d.ts +3 -0
  36. package/dist/boxplot-chart.d.ts +1 -0
  37. package/dist/boxplot-utils.d.ts +2 -1
  38. package/dist/chart/chart.d.ts +1 -0
  39. package/dist/chart-data-options/types.d.ts +3 -3
  40. package/dist/chart-options-processor/subtype-to-design-options.d.ts +6 -6
  41. package/dist/chart-options-processor/translations/tooltip-utils.d.ts +1 -0
  42. package/dist/charts/table/helpers/calc-column-widths.d.ts +1 -1
  43. package/dist/charts/table/styles/style-constants.d.ts +2 -2
  44. package/dist/column-chart.d.ts +4 -0
  45. package/dist/common/components/loading-indicator.d.ts +2 -0
  46. package/dist/common/components/loading-spinner.d.ts +5 -0
  47. package/dist/dashboard-widget/dashboard-widget.d.ts +5 -1
  48. package/dist/dashboard-widget/translate-widget-data-options.d.ts +5 -0
  49. package/dist/dashboard-widget/translate-widget-filters.d.ts +1 -0
  50. package/dist/dashboard-widget/types.d.ts +4 -3
  51. package/dist/filters/components/criteria-filter-tile/criteria-filter-tile.d.ts +1 -0
  52. package/dist/filters/components/date-filter/date-range-filter-tile/date-range-filter-tile.d.ts +1 -0
  53. package/dist/filters/components/date-filter/relative-date-filter-tile/relative-date-filter-tile.d.ts +1 -0
  54. package/dist/filters/components/member-filter-tile/member-filter-tile.d.ts +1 -0
  55. package/dist/formulas/fetch-formula.d.ts +2 -2
  56. package/dist/formulas/use-get-shared-formula.d.ts +1 -0
  57. package/dist/funnel-chart.d.ts +1 -0
  58. package/dist/index.d.ts +4 -0
  59. package/dist/index.js +6728 -37696
  60. package/dist/indicator-chart.d.ts +1 -0
  61. package/dist/line-chart.d.ts +1 -0
  62. package/dist/models/dashboard/get-dashboard-models.d.ts +1 -3
  63. package/dist/models/dashboard/translate-dashboard.d.ts +1 -1
  64. package/dist/models/dashboard/types.d.ts +17 -0
  65. package/dist/models/dashboard/use-get-dashboard-model.d.ts +1 -0
  66. package/dist/models/dashboard/use-get-dashboard-models.d.ts +1 -0
  67. package/dist/models/widget/use-get-widget-model.d.ts +1 -0
  68. package/dist/models/widget/widget-model.d.ts +10 -1
  69. package/dist/pie-chart.d.ts +1 -0
  70. package/dist/pivot-table/pivot-table.d.ts +1 -0
  71. package/dist/polar-chart.d.ts +1 -0
  72. package/dist/props.d.ts +197 -120
  73. package/dist/query-execution/execute-query-by-widget-id.d.ts +1 -0
  74. package/dist/query-execution/execute-query.d.ts +1 -0
  75. package/dist/query-execution/types.d.ts +46 -16
  76. package/dist/query-execution/use-execute-csv-query.d.ts +1 -0
  77. package/dist/query-execution/use-execute-pivot-query.d.ts +1 -0
  78. package/dist/query-execution/use-execute-query-by-widget-id.d.ts +1 -0
  79. package/dist/query-execution/use-execute-query.d.ts +1 -0
  80. package/dist/scatter-chart.d.ts +1 -0
  81. package/dist/scattermap-chart.d.ts +1 -0
  82. package/dist/sisense-context/sisense-context-provider.d.ts +1 -0
  83. package/dist/sisense-context/sisense-context.d.ts +4 -1
  84. package/dist/sunburst-chart.d.ts +1 -0
  85. package/dist/table/table.d.ts +1 -0
  86. package/dist/theme-provider/theme-provider.d.ts +8 -1
  87. package/dist/treemap-chart.d.ts +1 -0
  88. package/dist/types.d.ts +32 -32
  89. package/dist/widgets/chart-widget.d.ts +1 -0
  90. package/dist/widgets/common/context-menu.d.ts +5 -0
  91. package/dist/widgets/common/drilldown-breadcrumbs/drilldown-breadcrumbs.d.ts +5 -0
  92. package/dist/widgets/drilldown-widget.d.ts +1 -0
  93. package/dist/widgets/table-widget.d.ts +1 -1
  94. package/dist/with-tracking-e2a077f9.js +109112 -0
  95. package/package.json +19 -14
  96. package/dist/ai/loading-page.d.ts +0 -2
  97. package/dist/with-tracking-d12a4632.js +0 -78010
@@ -27,6 +27,7 @@ export type AiContextProviderProps = {
27
27
  * );
28
28
  * }
29
29
  * ```
30
+ * @group Generative AI
30
31
  * @beta
31
32
  */
32
33
  export default function AiContextProvider({ children, config }: AiContextProviderProps): JSX.Element;
@@ -1,5 +1,6 @@
1
1
  import { HttpClient } from '@sisense/sdk-rest-client';
2
2
  import type { Chat, ChatRequest, ChatResponse, ChatWithoutHistory, DataModel, GetNlgQueryResultRequest, GetNlgQueryResultResponse, LlmConfig, Perspective, QueryRecommendationConfig, QueryRecommendationResponse, SendFeedbackRequest } from './types';
3
+ import { DataSourceField } from '@sisense/sdk-query-client';
3
4
  export declare class ChatRestApi {
4
5
  private httpClient;
5
6
  constructor(httpClient: HttpClient);
@@ -14,11 +15,13 @@ export declare class ChatRestApi {
14
15
  private postChat;
15
16
  private deleteChatHistory;
16
17
  private sendFeedback;
18
+ private getDataSourceFields;
17
19
  ai: {
18
20
  getNlgQueryResult: (request: GetNlgQueryResultRequest) => Promise<GetNlgQueryResultResponse>;
19
21
  getQueryRecommendations: (contextTitle: string, config: QueryRecommendationConfig) => Promise<QueryRecommendationResponse>;
20
22
  setLlmConfig: (config: LlmConfig) => Promise<unknown>;
21
23
  sendFeedback: (request: SendFeedbackRequest) => Promise<unknown>;
24
+ getDataSourceFields: (dataSource: string) => Promise<DataSourceField[]>;
22
25
  chat: {
23
26
  getAll: () => Promise<ChatWithoutHistory[]>;
24
27
  getById: (chatId: string) => Promise<Chat>;
@@ -1 +1,2 @@
1
- export declare const UNKNOWN_ERROR = "Oh snap, something went wrong. Please try again later or try asking a different question.";
1
+ export declare const UNEXPECTED_ERROR = "Oh snap, something went wrong. Please try again later.";
2
+ export declare const UNEXPECTED_CHAT_RESPONSE_ERROR = "Oh snap, something went wrong. Please try again later or try asking a different question.";
@@ -1,4 +1,4 @@
1
- import { MetadataItem } from '@sisense/sdk-query-client';
1
+ import { JaqlQueryPayload, MetadataItem } from '@sisense/sdk-query-client';
2
2
  import { ChartDataOptions } from '../../types';
3
3
  export interface ChatContext {
4
4
  id: string;
@@ -61,7 +61,7 @@ export type AllPossibleChartOptionKeys = KeysOfUnion<ChartDataOptions>;
61
61
  export type AxesMappingKey = Exclude<AllPossibleChartOptionKeys, 'seriesToColorMap'>;
62
62
  export type AxesMapping = Partial<Record<AxesMappingKey, Array<{
63
63
  name: string;
64
- type: string;
64
+ type?: string;
65
65
  }>>>;
66
66
  export interface ChartRecommendations {
67
67
  chartFamily: string;
@@ -103,15 +103,7 @@ export interface Perspective {
103
103
  isDefault: boolean;
104
104
  }
105
105
  export interface GetNlgQueryResultRequest {
106
- style: 'Small' | 'Medium' | 'Large';
107
- jaql: {
108
- /** The data source that the JAQL metadata targets - e.g. `Sample ECommerce` */
109
- datasource: {
110
- title: string;
111
- };
112
- /** The metadata that composes the JAQL to be analyzed */
113
- metadata: unknown[];
114
- };
106
+ jaql: Pick<JaqlQueryPayload, 'datasource' | 'metadata' | 'filterRelations'>;
115
107
  }
116
108
  export interface GetNlgQueryResultResponse {
117
109
  data?: {
@@ -125,4 +117,11 @@ export interface SendFeedbackRequest {
125
117
  sourceId: string;
126
118
  rating: -1 | 1;
127
119
  }
120
+ /**
121
+ * The chat mode to use for a chat session
122
+ *
123
+ * analyze: Enable business users to uncover data insights
124
+ * develop: Enable developers to build queries and charts for embedded analytics
125
+ */
126
+ export type ChatMode = 'analyze' | 'develop';
128
127
  export {};
@@ -1,9 +1,10 @@
1
1
  import { ReactNode } from 'react';
2
+ import { ChatMode } from '../ai/api/types';
2
3
  export interface ChatConfig {
3
4
  /**
4
- * Boolean flag to show or hide suggested questions following a chat response
5
- *
6
- * If not specified, the default value is `false`
5
+ * Boolean flag to show or hide suggested questions following a chat response. Currently
6
+ * follow-up questions are still under development and are not validated. Therefore, follow-up
7
+ * questions are disabled by default.
7
8
  */
8
9
  enableFollowupQuestions: boolean;
9
10
  /**
@@ -18,6 +19,12 @@ export interface ChatConfig {
18
19
  * If specified, the data topic selector screen will not be shown.
19
20
  */
20
21
  defaultContextTitle?: string;
22
+ /**
23
+ * The chat mode to use for a chat session.
24
+ *
25
+ * @internal
26
+ */
27
+ chatMode?: ChatMode;
21
28
  }
22
29
  export declare const DEFAULTS: Readonly<ChatConfig>;
23
30
  export type ChatConfigProviderProps = {
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ export default function ChatIntroBlurb(props: {
3
+ title: string;
4
+ }): JSX.Element;
@@ -7,13 +7,13 @@ export type ChatbotProps = {
7
7
  /**
8
8
  * Total width of the chatbot
9
9
  *
10
- * If not specified, a default width of 500px will be used
10
+ * If not specified, a default width of `500px` will be used.
11
11
  */
12
12
  width?: CSSProperties['width'];
13
13
  /**
14
14
  * Total height of the chatbot
15
15
  *
16
- * If not specified, a default height of 500px will be used
16
+ * If not specified, a default height of `900px` will be used.
17
17
  */
18
18
  height?: CSSProperties['height'];
19
19
  /**
@@ -44,6 +44,7 @@ export type ChatbotProps = {
44
44
  * }
45
45
  * ```
46
46
  * @param props - {@link ChatbotProps}
47
+ * @group Generative AI
47
48
  * @beta
48
49
  */
49
50
  export declare const Chatbot: import("react").FunctionComponent<ChatbotProps>;
@@ -0,0 +1,11 @@
1
+ /// <reference types="react" />
2
+ type CollapsibleProps = {
3
+ text: string;
4
+ };
5
+ /**
6
+ * Text container with an expand/collapse button for text over the character limit.
7
+ *
8
+ * @internal
9
+ */
10
+ export default function Collapsible({ text }: CollapsibleProps): JSX.Element;
11
+ export {};
@@ -1,13 +1,13 @@
1
1
  /// <reference types="react" />
2
- import { GetNlgQueryResultRequest } from './api/types';
2
+ import { UseGetNlgQueryResultParams } from './use-get-nlg-query-result';
3
3
  /**
4
4
  * Props for {@link GetNlgQueryResult} component.
5
5
  */
6
- export type GetNlgQueryResultProps = GetNlgQueryResultRequest;
6
+ export interface GetNlgQueryResultProps extends Omit<UseGetNlgQueryResultParams, 'enabled'> {
7
+ }
7
8
  /**
8
- * React component that fetches and displays a collapsible analysis of the provided JAQL using natural language generation (NLG).
9
- *
10
- * This takes the same props as {@link useGetNlgQueryResult} and makes the same API call but presents the result in a collapsible container.
9
+ * React component that fetches and displays a collapsible analysis of the provided query using natural language generation (NLG).
10
+ * Specifying a query is similar to providing parameters to a {@link useExecuteQuery} hook, using dimensions, measures, and filters.
11
11
  *
12
12
  * ::: warning Note
13
13
  * This component is currently under private beta for selected customers and is subject to change as we make fixes and improvements.
@@ -15,56 +15,16 @@ export type GetNlgQueryResultProps = GetNlgQueryResultRequest;
15
15
  *
16
16
  * @example
17
17
  * ```tsx
18
- * import { SisenseContextProvider } from '@sisense/sdk-ui';
19
- * import { AiContextProvider, GetNlgQueryResult } from '@sisense/sdk-ui/ai';
20
- *
21
- * function Page() {
22
- * return (
23
- * <GetNlgQueryResult
24
- * jaql={{
25
- * datasource: { title: 'Sample ECommerce' },
26
- * metadata: [
27
- * {
28
- * jaql: {
29
- * column: 'Date',
30
- * datatype: 'datetime',
31
- * dim: '[Commerce.Date]',
32
- * firstday: 'mon',
33
- * level: 'years',
34
- * table: 'Commerce',
35
- * title: 'Date',
36
- * },
37
- * },
38
- * {
39
- * jaql: {
40
- * agg: 'sum',
41
- * column: 'Revenue',
42
- * datatype: 'numeric',
43
- * dim: '[Commerce.Revenue]',
44
- * table: 'Commerce',
45
- * title: 'total of Revenue',
46
- * },
47
- * },
48
- * ],
49
- * }}
50
- * style="Large"
51
- * />
52
- * );
53
- * }
54
- *
55
- * function App() {
56
- * return (
57
- * <SisenseContextProvider {...sisenseContextProps}>
58
- * <AiContextProvider>
59
- * <Page />
60
- * </AiContextProvider>
61
- * </SisenseContextProvider>
62
- * );
63
- * }
18
+ * <GetNlgQueryResult
19
+ * dataSource="Sample ECommerce"
20
+ * dimensions={[DM.Commerce.Date.Years]}
21
+ * measures={[measureFactory.sum(DM.Commerce.Revenue)]}
22
+ * />
64
23
  * ```
65
24
  * @param props - {@link GetNlgQueryResultProps}
66
25
  * @returns Collapsible container wrapping a text summary
26
+ * @group Generative AI
67
27
  * @beta
68
28
  */
69
- declare const _default: import("react").FunctionComponent<GetNlgQueryResultRequest>;
29
+ declare const _default: import("react").FunctionComponent<GetNlgQueryResultProps>;
70
30
  export default _default;
@@ -0,0 +1,2 @@
1
+ declare const _default: "";
2
+ export default _default;
@@ -1,7 +1,9 @@
1
1
  export { default as AiContextProvider, type AiContextProviderProps } from './ai-context-provider';
2
2
  export { type ChatConfig } from './chat-config';
3
- export { useGetNlgQueryResult, type UseGetNlgQueryResultParams } from './use-get-nlg-query-result';
4
- export { useGetQueryRecommendations, type UseGetQueryRecommendationsParams, } from './use-get-query-recommendations';
3
+ export { useGetNlgQueryResult, type UseGetNlgQueryResultParams, type UseGetNlgQueryResultState, } from './use-get-nlg-query-result';
4
+ export { useGetQueryRecommendations, type UseGetQueryRecommendationsParams, type UseGetQueryRecommendationsState, } from './use-get-query-recommendations';
5
+ export { useChatSession, type UseChatSessionResult } from './use-chat-session';
5
6
  export type { GetNlgQueryResultRequest, QueryRecommendationResponse, QueryRecommendation, NlqResponseData, ChartRecommendations, AxesMapping, AxesMappingKey, AllPossibleChartOptionKeys, KeysOfUnion, } from './api/types';
6
7
  export { Chatbot, type ChatbotProps } from './chatbot';
7
8
  export { default as GetNlgQueryResult, type GetNlgQueryResultProps } from './get-nlg-query-result';
9
+ export * from './translators';
@@ -3,7 +3,8 @@ type FeedbackWrapperProps = {
3
3
  sourceId: string;
4
4
  data: object;
5
5
  type: string;
6
+ rightFooter?: ReactNode;
6
7
  children: ReactNode;
7
8
  };
8
- export default function FeedbackWrapper({ sourceId, data, type, children }: FeedbackWrapperProps): JSX.Element;
9
+ export default function FeedbackWrapper({ sourceId, data, type, rightFooter, children, }: FeedbackWrapperProps): JSX.Element;
9
10
  export {};
@@ -1,10 +1,12 @@
1
1
  /// <reference types="react" />
2
- export declare function InsightsSummary({ summary }: {
3
- summary: string;
2
+ export declare function InsightsButton({ onClick, disabled, }: {
3
+ onClick?: () => void;
4
+ disabled?: boolean;
4
5
  }): JSX.Element;
5
6
  type InsightsMessageProps = {
6
7
  dataSource: string;
7
- metadata: unknown[];
8
+ metadata: object[];
9
+ visible?: boolean;
8
10
  };
9
- export default function InsightsMessage({ dataSource, metadata }: InsightsMessageProps): JSX.Element;
11
+ export default function InsightsMessage({ dataSource, metadata, visible, }: InsightsMessageProps): JSX.Element | null;
10
12
  export {};
@@ -2,6 +2,5 @@
2
2
  import { ChatMessage } from '../api/types';
3
3
  export type MessageListResolverProps = {
4
4
  messages: ChatMessage[];
5
- sendMessage?: (message: string) => void;
6
5
  };
7
- export default function MessageListResolver({ messages, sendMessage, }: MessageListResolverProps): JSX.Element;
6
+ export default function MessageListResolver({ messages }: MessageListResolverProps): JSX.Element;
@@ -2,9 +2,7 @@
2
2
  import { ChatMessage } from '../api/types';
3
3
  type MessageResolverProps = {
4
4
  message: ChatMessage;
5
- sendMessage?: (message: string) => void;
6
- allowFollowupQuestions?: boolean;
7
5
  };
8
- declare function MessageResolver({ message, allowFollowupQuestions, sendMessage, }: MessageResolverProps): JSX.Element;
6
+ declare function MessageResolver({ message }: MessageResolverProps): JSX.Element;
9
7
  declare const _default: import("react").MemoExoticComponent<typeof MessageResolver>;
10
8
  export default _default;
@@ -0,0 +1,10 @@
1
+ /// <reference types="react" />
2
+ import { NlqResponseData } from '../api/types';
3
+ /**
4
+ * Renders a NLQ response as a series of chat messages/buttons.
5
+ *
6
+ * @internal
7
+ */
8
+ export default function NlqMessageGroup({ data }: {
9
+ data: NlqResponseData;
10
+ }): JSX.Element;
@@ -1,4 +1,4 @@
1
1
  export { default as SuggestionItem } from './suggestion-item';
2
2
  export { default as SuggestionList } from './suggestion-list';
3
- export { default as SuggestionListWithIntro } from './suggestions-with-intro';
4
3
  export { default as SuggestionListSkeleton } from './suggestion-list-skeleton';
4
+ export { default as SuggestionsWithIntro } from './suggestions-with-intro';
@@ -3,5 +3,5 @@ type Props = {
3
3
  questions: string[];
4
4
  onSelection: (question: string) => void;
5
5
  };
6
- export default function SuggestionList(props: Props): JSX.Element;
6
+ export default function SuggestionList({ questions, onSelection }: Props): JSX.Element;
7
7
  export {};
@@ -1,8 +1,8 @@
1
1
  /// <reference types="react" />
2
2
  type Props = {
3
3
  questions: string[];
4
- title: string;
4
+ isLoading: boolean;
5
5
  onSelection: (question: string) => void;
6
6
  };
7
- export default function SuggestionsWithIntro(props: Props): JSX.Element;
7
+ export default function SuggestionsWithIntro({ questions, isLoading, onSelection }: Props): JSX.Element | null;
8
8
  export {};
@@ -0,0 +1,11 @@
1
+ import { CodeTemplates } from '../../ai/translators/types';
2
+ /**
3
+ * Code templates for different UI frameworks.
4
+ *
5
+ * A code template is made up of other code templates and placeholders.
6
+ * This allows a code template to be reused in other code templates.
7
+ * For example, a chart widget template can be reused in a dashboard template.
8
+ *
9
+ * @internal
10
+ */
11
+ export declare const CODE_TEMPLATES: CodeTemplates;
@@ -0,0 +1,9 @@
1
+ import { CodeTemplateKey, UiFramework } from '../../ai/translators/types';
2
+ /**
3
+ * Generates code from a template with the given data and UI framework.
4
+ *
5
+ * @param templateKey - the key of the template to use
6
+ * @param data - the data to populate the template with
7
+ * @param uiFramework - the UI framework for the generated code
8
+ */
9
+ export declare const generateCode: (templateKey: CodeTemplateKey, data: Record<string, string>, uiFramework?: UiFramework) => string;
@@ -0,0 +1,4 @@
1
+ export * from './types';
2
+ export { useGetDataSource } from './use-get-data-source';
3
+ export { ModelTranslator } from './model-translator';
4
+ export { QueryTranslator } from './query-translator';
@@ -0,0 +1,50 @@
1
+ import { ExpandedQueryModel, ChartWidgetModel, UiFramework } from '../../ai/translators/types';
2
+ /**
3
+ * A class that translates expanded query model to CSDK chart model and code.
4
+ *
5
+ * @internal
6
+ */
7
+ export declare class ModelTranslator {
8
+ queryModel: ExpandedQueryModel;
9
+ constructor(queryModel: ExpandedQueryModel);
10
+ /**
11
+ * Gets chart recommendations or default to table.
12
+ *
13
+ * @param chart - chart recommendations
14
+ * @returns chart recommendations or default to table
15
+ */
16
+ private getChartRecommendationsOrDefault;
17
+ /**
18
+ * Gets filters from metadata.
19
+ *
20
+ * @param metadata - metadata items
21
+ */
22
+ private getFilters;
23
+ /**
24
+ * Splits metadata into columns and filters.
25
+ *
26
+ * @param metadata - metadata items
27
+ */
28
+ private splitMetadata;
29
+ /**
30
+ * Converts query model to chart.
31
+ *
32
+ * TODO Refactor Chatbot to use this method to render the chart
33
+ */
34
+ toChart(): ChartWidgetModel | undefined;
35
+ private stringifyDataSource;
36
+ private stringifyChartType;
37
+ private stringifyFilters;
38
+ private stringifyDataOptions;
39
+ private stringifyExtraImports;
40
+ private getChartWidgetCode;
41
+ private getTableWidgetCode;
42
+ /**
43
+ * Converts chart widget model to CSDK code.
44
+ *
45
+ * @param chartWidgetModel - chart widget model
46
+ * @param uiFramework - UI framework
47
+ * @returns CSDK code string of the UI framework
48
+ */
49
+ toCode(chartWidgetModel: ChartWidgetModel, uiFramework?: UiFramework): string;
50
+ }