@epam/statgpt-conversation-view 0.1.0-rc.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 (62) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +80 -0
  3. package/constants/charting-default-colors.d.ts +2 -0
  4. package/constants/filter-display-mode.d.ts +4 -0
  5. package/constants/grid.d.ts +17 -0
  6. package/constants/message-stages.d.ts +3 -0
  7. package/index.css +1 -0
  8. package/index.d.ts +10 -0
  9. package/index.js +41 -0
  10. package/index.mjs +11586 -0
  11. package/models/actions.d.ts +24 -0
  12. package/models/advance-view-styles.d.ts +4 -0
  13. package/models/attachments-styles.d.ts +26 -0
  14. package/models/attachments.d.ts +22 -0
  15. package/models/charting.d.ts +18 -0
  16. package/models/filters.d.ts +73 -0
  17. package/models/message.d.ts +12 -0
  18. package/models/metadata.d.ts +3 -0
  19. package/models/periods.d.ts +8 -0
  20. package/models/structure-component.d.ts +6 -0
  21. package/models/titles.d.ts +49 -0
  22. package/package.json +39 -0
  23. package/types/actions.d.ts +18 -0
  24. package/types/charting-icon.d.ts +4 -0
  25. package/types/data-grid/grid-data.d.ts +1 -0
  26. package/types/data-grid/obs-col-getter.d.ts +2 -0
  27. package/utils/attachments/attachment-parser.d.ts +11 -0
  28. package/utils/attachments/attachment-utils.d.ts +2 -0
  29. package/utils/attachments/charting/chart-config-building.d.ts +3 -0
  30. package/utils/attachments/charting/chart-data.d.ts +9 -0
  31. package/utils/attachments/charting/data-uniqueness.d.ts +4 -0
  32. package/utils/attachments/charting/serie-title.d.ts +3 -0
  33. package/utils/attachments/charting/sort-dimensions.d.ts +3 -0
  34. package/utils/attachments/charting/split-for-units.d.ts +4 -0
  35. package/utils/attachments/convert-to-grid-data.d.ts +6 -0
  36. package/utils/attachments/data-grid/columns.d.ts +9 -0
  37. package/utils/attachments/data-grid/data-grid.d.ts +13 -0
  38. package/utils/attachments/data-grid/get-converted-data.d.ts +5 -0
  39. package/utils/attachments/data-grid/grid-height.d.ts +1 -0
  40. package/utils/attachments/data-grid/rows-data.d.ts +6 -0
  41. package/utils/attachments/group-attributes.d.ts +7 -0
  42. package/utils/attachments/localized-value.d.ts +10 -0
  43. package/utils/attachments/markdown-validator.d.ts +2 -0
  44. package/utils/attachments/metadata.d.ts +42 -0
  45. package/utils/attachments/parse-data-query.d.ts +3 -0
  46. package/utils/attachments/time-period.d.ts +12 -0
  47. package/utils/conversation-request.d.ts +6 -0
  48. package/utils/date-format.d.ts +1 -0
  49. package/utils/extract-partial-message.d.ts +3 -0
  50. package/utils/filters.d.ts +36 -0
  51. package/utils/generate-conversation.d.ts +2 -0
  52. package/utils/generate-downloaded-document.d.ts +1 -0
  53. package/utils/get-conversation-path.d.ts +2 -0
  54. package/utils/get-filled-filters.d.ts +30 -0
  55. package/utils/get-series-filters.d.ts +7 -0
  56. package/utils/is-read-only-conversation.d.ts +5 -0
  57. package/utils/messages.d.ts +3 -0
  58. package/utils/query-filters-details.d.ts +6 -0
  59. package/utils/query-filters.d.ts +8 -0
  60. package/utils/system-message.d.ts +4 -0
  61. package/utils/transform-message-api.d.ts +3 -0
  62. package/utils/validate-message.d.ts +10 -0
@@ -0,0 +1,24 @@
1
+ import { GetAttachmentContent, GetBucket, GetDatasetData, GetDatasetDetails, UpdateConversation, getConstraints, CreateConversation } from '../types/actions';
2
+ import { DataQuery } from '../../../shared-toolkit/src/models/data-query';
3
+ import { Dataflow } from '../../../sdmx-toolkit/src/models/structural-metadata/dataflow';
4
+ import { DownloadDatasetAction } from '../../../download-panel/src/types/actions';
5
+ import { GetConversation } from '../../../share-conversation/src/models/share-conversation';
6
+ import { ConversationInfo } from '@epam/ai-dial-shared';
7
+ export interface AttachmentsActions {
8
+ getFile: GetAttachmentContent;
9
+ getDataSet: GetDatasetDetails;
10
+ getDataSetData: GetDatasetData;
11
+ getConstraints: getConstraints;
12
+ downloadDataSet: DownloadDatasetAction;
13
+ updateCurrentDataQuery: (dataQuery?: DataQuery) => void;
14
+ updateDataQueries: (dataQueries?: DataQuery[]) => void;
15
+ updateDatasets: (datasets?: Dataflow[]) => void;
16
+ }
17
+ export type ConversationViewActions = AttachmentsActions & {
18
+ getConversation: GetConversation;
19
+ getConversations: (locale: string) => Promise<ConversationInfo[]>;
20
+ getBucket: GetBucket;
21
+ updateConversation: UpdateConversation;
22
+ createConversation: CreateConversation;
23
+ };
24
+ export type AdvancedViewActions = AttachmentsActions;
@@ -0,0 +1,4 @@
1
+ export interface AdvanceViewStyles {
2
+ isShowShare?: boolean;
3
+ isShowAgency?: boolean;
4
+ }
@@ -0,0 +1,26 @@
1
+ import { ReactNode } from 'react';
2
+ import { ChartingIcon } from '../types/charting-icon';
3
+ import { DownloadTitles } from '../../../download-panel/src/models/titles';
4
+ export interface AttachmentsStyles {
5
+ showTabIcon?: boolean;
6
+ showChevronIcon?: boolean;
7
+ openAdvancedViewIcon?: ReactNode;
8
+ chartingStyles?: ChartingStyles;
9
+ chartingIcons: Record<ChartingIcon, ReactNode>;
10
+ downloadIcon?: ReactNode;
11
+ downloadChevronIcon?: ReactNode;
12
+ openLinkTitle?: string;
13
+ dataGridTitle?: string;
14
+ downloadTitle?: string;
15
+ closeTitle?: string;
16
+ successDownloadIcon?: ReactNode;
17
+ errorDownloadIcon?: ReactNode;
18
+ datasetIcon?: ReactNode;
19
+ isDownloadDescriptionVisible?: boolean;
20
+ downloadTitles?: DownloadTitles;
21
+ }
22
+ export interface ChartingStyles {
23
+ colors?: string[];
24
+ ticksColor?: string;
25
+ labelsColor?: string;
26
+ }
@@ -0,0 +1,22 @@
1
+ import { Attachment } from '@epam/ai-dial-shared';
2
+ import { AttachmentsStyles } from './attachments-styles';
3
+ import { GridData } from '../types/data-grid/grid-data';
4
+ import { DataQuery } from '../../../shared-toolkit/src/models/data-query';
5
+ import { ColDef } from 'ag-grid-community';
6
+ import { ChartingData } from './charting';
7
+ import { Dataflow } from '../../../sdmx-toolkit/src/models/structural-metadata/dataflow';
8
+ export interface CustomGridAttachment extends Attachment {
9
+ grid_data?: {
10
+ data: GridData[];
11
+ columns: ColDef[];
12
+ };
13
+ }
14
+ export interface CustomChartAttachmentType extends Attachment {
15
+ charting_data?: ChartingData;
16
+ }
17
+ export interface AttachmentsProps {
18
+ currentDataQuery?: DataQuery;
19
+ dataQueries?: DataQuery[];
20
+ datasets?: Dataflow[];
21
+ styles?: AttachmentsStyles;
22
+ }
@@ -0,0 +1,18 @@
1
+ import { GridData } from '../types/data-grid/grid-data';
2
+ import { EChartsOption } from 'echarts-for-react';
3
+ export interface ChartUnitRows {
4
+ rows: GridData[];
5
+ }
6
+ export interface ChartUnit extends ChartUnitRows {
7
+ config: EChartsOption;
8
+ dimensions: DimensionInfo[];
9
+ limitedByRowsAmountTo: number | undefined;
10
+ }
11
+ export interface DimensionInfo {
12
+ id: string;
13
+ title: string;
14
+ value: string;
15
+ }
16
+ export interface ChartingData {
17
+ units: ChartUnit[];
18
+ }
@@ -0,0 +1,73 @@
1
+ import { Dispatch, ReactNode, SetStateAction } from 'react';
2
+ import { UpdateConversation } from '../types/actions';
3
+ import { Dimension } from '../../../sdmx-toolkit/src/models/structural-metadata/data-structure';
4
+ import { StructuralData, StructuralMetaData } from '../../../sdmx-toolkit/src/models/structural-metadata';
5
+ import { StructureItemBase } from '../../../sdmx-toolkit/src/models/data/structure';
6
+ import { Conversation } from '@epam/ai-dial-shared';
7
+ import { DataQuery } from '../../../shared-toolkit/src/models/data-query';
8
+ import { TimeRangeOptions, TimeRange } from '../../../shared-toolkit/src/models/time-range';
9
+ import { DataConstraints } from '../../../sdmx-toolkit/src/models/structural-metadata/constraints';
10
+ import { SeriesFilterDto } from '../../../sdmx-toolkit/src/models/series-filter';
11
+ import { DatasetQueryFilters } from '../../../sdmx-toolkit/src/models/dataset-query-filters';
12
+ import { ConversationViewTitles } from './titles';
13
+ export interface Filter {
14
+ id?: string;
15
+ title?: string;
16
+ dimensionValues?: FilterValue[];
17
+ isSelectedFilter?: boolean;
18
+ isTimeDimension?: boolean;
19
+ timeRange?: TimeRange;
20
+ isHierarchical?: boolean;
21
+ isDisabled?: boolean;
22
+ displayMode?: string;
23
+ }
24
+ export interface FilterValue {
25
+ id: string;
26
+ name?: string;
27
+ isSelectedValue?: boolean;
28
+ isExpanded?: boolean;
29
+ parent?: string;
30
+ }
31
+ export interface FilterTreeNodeProps extends FilterValue {
32
+ children?: FilterTreeNodeProps[];
33
+ level?: number;
34
+ }
35
+ export interface FilterButtonProps {
36
+ title?: string;
37
+ isShowBadge?: boolean;
38
+ }
39
+ export interface FilterValuesProps {
40
+ searchIconSize?: number;
41
+ checkboxIcon?: ReactNode;
42
+ radioIcon?: ReactNode;
43
+ calendarIcon?: ReactNode;
44
+ dateFormat?: string;
45
+ }
46
+ export interface FiltersModalProps {
47
+ isShowDividers?: boolean;
48
+ isHideFacetCounterByDefault?: boolean;
49
+ isShowTimeSeriesCount?: boolean;
50
+ isShowClearIcon?: boolean;
51
+ isShowCancelButton?: boolean;
52
+ filterValuesProps?: FilterValuesProps;
53
+ }
54
+ export interface FiltersProps {
55
+ actions?: {
56
+ getConstraints: (urn: string, filters?: SeriesFilterDto[]) => Promise<StructuralMetaData>;
57
+ };
58
+ dimensions?: Dimension[];
59
+ structureDimensions?: StructureItemBase[];
60
+ structures?: StructuralData;
61
+ initialConstraints?: DataConstraints[];
62
+ buttonProps?: FilterButtonProps;
63
+ modalProps?: FiltersModalProps;
64
+ attachmentsDataQuery?: DataQuery;
65
+ onFiltersChange?: (filterParams: DatasetQueryFilters) => void;
66
+ locale?: string;
67
+ timeRangeOptions?: TimeRangeOptions[];
68
+ titles?: ConversationViewTitles;
69
+ conversationKey: string;
70
+ conversation?: Conversation | null;
71
+ setConversation?: Dispatch<SetStateAction<Conversation | null>>;
72
+ updateConversation: UpdateConversation;
73
+ }
@@ -0,0 +1,12 @@
1
+ import { ReactNode } from 'react';
2
+ export interface MessageStyles {
3
+ advanceViewIcon: ReactNode;
4
+ systemMessageIcon?: ReactNode;
5
+ processingTitle?: string;
6
+ openAdvanceViewTitle?: string;
7
+ messagesWrapperClass?: string;
8
+ }
9
+ export interface InputMessageStyles {
10
+ inputContainerClass?: string;
11
+ sendMessageIcon?: ReactNode;
12
+ }
@@ -0,0 +1,3 @@
1
+ export interface MetadataSettings {
2
+ isMetadataDescription?: boolean;
3
+ }
@@ -0,0 +1,8 @@
1
+ export interface ExistingPeriods {
2
+ isDailyExist: boolean;
3
+ isWeeklyExist: boolean;
4
+ isMonthlyExist: boolean;
5
+ isQuarterlyExist: boolean;
6
+ isSemiAnnualExist: boolean;
7
+ isYearlyExist: boolean;
8
+ }
@@ -0,0 +1,6 @@
1
+ export interface StructureComponentValue {
2
+ id?: string;
3
+ title?: string;
4
+ value?: string | string[];
5
+ attachedKeysTitles?: string[];
6
+ }
@@ -0,0 +1,49 @@
1
+ export interface ConversationViewTitles {
2
+ newChat?: string;
3
+ welcomeTitle?: string;
4
+ askAnything?: string;
5
+ close?: string;
6
+ duplicate?: string;
7
+ chart?: string;
8
+ metadata?: string;
9
+ noMetadata?: string;
10
+ settings?: string;
11
+ searchPlaceholder?: string;
12
+ cancel?: string;
13
+ apply?: string;
14
+ explore?: string;
15
+ content?: string;
16
+ advanceViewTitle?: string;
17
+ timeSeries?: string;
18
+ observation?: string;
19
+ dataset?: string;
20
+ agency?: string;
21
+ lastUpdated?: string;
22
+ dataGrid?: string;
23
+ quarterly?: string;
24
+ monthly?: string;
25
+ clearAll?: string;
26
+ clearAllFilters?: string;
27
+ to?: string;
28
+ from?: string;
29
+ all?: string;
30
+ displayOrder?: string;
31
+ hierarchy?: string;
32
+ reset?: string;
33
+ flatList?: string;
34
+ chartNoData?: string;
35
+ chartInfo?: string;
36
+ limits?: string;
37
+ timeseriesLimit?: string;
38
+ limitLinkInfoP1_1?: string;
39
+ limitLinkInfoP1_2?: string;
40
+ limitLinkInfoP1_3?: string;
41
+ limitLinkInfoP2_1?: string;
42
+ limitLinkInfoP2_2?: string;
43
+ limitLinkInfoP2_3?: string;
44
+ limitLinkInfoP2_4?: string;
45
+ limitLinkInfoP2_5?: string;
46
+ limitLinkInfoLink?: string;
47
+ queryUpdatedManually?: string;
48
+ setTo?: string;
49
+ }
package/package.json ADDED
@@ -0,0 +1,39 @@
1
+ {
2
+ "name": "@epam/statgpt-conversation-view",
3
+ "version": "0.1.0-rc.0",
4
+ "license": "MIT",
5
+ "dependencies": {
6
+ "react": "^19.1.0",
7
+ "classnames": "^2.5.1",
8
+ "@epam/ai-dial-shared": "^0.34.0",
9
+ "@tabler/icons-react": "^3.34.1",
10
+ "@epam/statgpt-shared-toolkit": "0.1.0-rc.0",
11
+ "@epam/statgpt-ui-components": "0.1.0-rc.0",
12
+ "@epam/statgpt-sdmx-toolkit": "0.1.0-rc.0",
13
+ "react-window": "^1.8.11",
14
+ "react-virtualized-auto-sizer": "^1.0.26",
15
+ "ag-grid-community": "33.3.2",
16
+ "ag-grid-react": "^33.3.2",
17
+ "@floating-ui/react": "^0.27.14",
18
+ "echarts-for-react": "^3.0.2",
19
+ "@epam/statgpt-dial-toolkit": "0.1.0-rc.0",
20
+ "react-markdown": "^10.1.0",
21
+ "remark-gfm": "^4.0.1",
22
+ "@epam/statgpt-conversation-list": "0.1.0-rc.0",
23
+ "flatpickr": "4.6.13",
24
+ "react-flatpickr": "^4.0.11",
25
+ "date-fns": "^4.1.0",
26
+ "lodash": "^4.17.21"
27
+ },
28
+ "exports": {
29
+ ".": {
30
+ "import": "./index.mjs",
31
+ "require": "./index.js",
32
+ "types": "./index.d.ts"
33
+ }
34
+ },
35
+ "main": "index",
36
+ "browser": "index.js",
37
+ "module": "index.mjs",
38
+ "types": "index.d.ts"
39
+ }
@@ -0,0 +1,18 @@
1
+ import { GridAttachmentContent } from '../../../dial-toolkit/src/models/grid-attachment';
2
+ import { StructuralMetaData } from '../../../sdmx-toolkit/src/models/structural-metadata';
3
+ import { UpdateConversationRequest } from '../../../dial-toolkit/src/models/conversation';
4
+ import { Conversation, ConversationInfo } from '@epam/ai-dial-shared';
5
+ import { DataMessage } from '../../../sdmx-toolkit/src/models/data/data-message';
6
+ import { SeriesFilterDto } from '../../../sdmx-toolkit/src/models/series-filter';
7
+ import { SdmxReferences } from '../../../sdmx-toolkit/src/types/references';
8
+ import { TimeRange } from '../../../shared-toolkit/src/models/time-range';
9
+ import { DatasetQueryFilters } from '../../../sdmx-toolkit/src/models/dataset-query-filters';
10
+ export type GetAttachmentContent = (fileId: string) => Promise<GridAttachmentContent | null>;
11
+ export type GetDatasetDetails = (datasetId: string, references?: SdmxReferences) => Promise<StructuralMetaData | null>;
12
+ export type GetDatasetData = (datasetId: string, filters: DatasetQueryFilters) => Promise<DataMessage | null>;
13
+ export type CreateConversation = (conversation: Conversation, locale: string) => Promise<ConversationInfo>;
14
+ export type GetBucket = () => Promise<{
15
+ bucket: string;
16
+ }>;
17
+ export type UpdateConversation = (conversationId: string, request: UpdateConversationRequest) => Promise<ConversationInfo>;
18
+ export type getConstraints = (urn: string, filters?: SeriesFilterDto[], timeRange?: TimeRange) => Promise<StructuralMetaData>;
@@ -0,0 +1,4 @@
1
+ export declare enum ChartingIcon {
2
+ PREVIOUS = "previous",
3
+ NEXT = "next"
4
+ }
@@ -0,0 +1 @@
1
+ export type GridData = Record<string, unknown>;
@@ -0,0 +1,2 @@
1
+ import { ColDef } from 'ag-grid-community';
2
+ export type ObsColGetter = (colId: string, colName?: string) => ColDef;
@@ -0,0 +1,11 @@
1
+ import { Attachment } from '@epam/ai-dial-shared';
2
+ import { Message } from '../../../../dial-toolkit/src/models/message';
3
+ export declare const parseMessageAttachments: (message: Message) => Attachment[];
4
+ export declare function isUrlAttachment(attachment: Attachment): boolean;
5
+ export declare function isJsonAttachment(attachment: Attachment): boolean;
6
+ export declare function isMarkdownAttachment(attachment: Attachment): boolean;
7
+ export declare function isFileAttachment(attachment: Attachment): boolean;
8
+ export declare function isGridAttachment(attachment: Attachment): boolean;
9
+ export declare function isCustomGridAttachment(attachment: Attachment): boolean;
10
+ export declare function isCustomChartAttachment(attachment: Attachment): boolean;
11
+ export declare function isChartAttachment(attachment: Attachment): boolean;
@@ -0,0 +1,2 @@
1
+ export declare const isValidUrl: (url: string) => boolean;
2
+ export declare const sanitizeUrl: (url: string) => string;
@@ -0,0 +1,3 @@
1
+ import { ChartingStyles } from '../../../models/attachments-styles';
2
+ import { EChartsOption } from 'echarts-for-react/src/types';
3
+ export declare function buildChartConfig(timePeriods: string[], series: Record<string, string | unknown>[], styles?: ChartingStyles): EChartsOption;
@@ -0,0 +1,9 @@
1
+ import { DataMessage } from '../../../../../sdmx-toolkit/src/models/data/data-message';
2
+ import { StructuralData } from '../../../../../sdmx-toolkit/src/models/structural-metadata';
3
+ import { DataQuery } from '../../../../../shared-toolkit/src/models/data-query';
4
+ import { ChartingStyles } from '../../../models/attachments-styles';
5
+ import { GridData } from '../../../types/data-grid/grid-data';
6
+ import { ChartingData, ChartUnit, ChartUnitRows } from '../../../models/charting';
7
+ export declare function buildChartData(structures: StructuralData, data: DataMessage, dataQuery: DataQuery | undefined, locale: string, styles?: ChartingStyles): ChartingData;
8
+ export declare function buildSingleLineUnit(row: GridData, sortedTimePeriods: string[], structures: StructuralData, dataQuery: DataQuery | undefined, locale: string, styles?: ChartingStyles): ChartUnit;
9
+ export declare function buildUnit(unit: ChartUnitRows, structures: StructuralData, dataQuery: DataQuery | undefined, timePeriods: string[], locale: string, styles?: ChartingStyles): ChartUnit;
@@ -0,0 +1,4 @@
1
+ import { GridData } from '../../../types/data-grid/grid-data';
2
+ export declare function getDimensionsUniquenessByValues(dimensionsKeys: string[], rows: GridData[]): {
3
+ nonUniqDimensions: string[];
4
+ };
@@ -0,0 +1,3 @@
1
+ import { GridData } from '../../../types/data-grid/grid-data';
2
+ import { StructuralData } from '../../../../../sdmx-toolkit/src/models/structural-metadata';
3
+ export declare function buildSerieKeyTitle(serie: GridData, dimensionsKeys: string[], structures: StructuralData, locale: string): string;
@@ -0,0 +1,3 @@
1
+ import { StructuralData } from '../../../../../sdmx-toolkit/src/models/structural-metadata';
2
+ import { DataQuery } from '../../../../../shared-toolkit/src/models/data-query';
3
+ export declare function buildSortedNonRegionDimensionsList(structures: StructuralData, dataQuery: DataQuery | undefined): string[];
@@ -0,0 +1,4 @@
1
+ import { GridData } from '../../../types/data-grid/grid-data';
2
+ import { StructuralData } from '../../../../../sdmx-toolkit/src/models/structural-metadata';
3
+ import { ChartUnitRows } from '../../../models/charting';
4
+ export declare function splitForUnits(rows: GridData[], notUniqDimensions: string[], structures: StructuralData): ChartUnitRows[];
@@ -0,0 +1,6 @@
1
+ import { ColDef } from 'ag-grid-community';
2
+ import { GridAttachmentContent, RowData } from '../../../../dial-toolkit/src/models/grid-attachment';
3
+ export declare const convertToGridData: (visualizerData: GridAttachmentContent) => {
4
+ data: RowData[];
5
+ columns: ColDef[];
6
+ };
@@ -0,0 +1,9 @@
1
+ import { StructuralData } from '../../../../../sdmx-toolkit/src/models/structural-metadata';
2
+ import { DataMessage } from '../../../../../sdmx-toolkit/src/models/data/data-message';
3
+ import { ColDef } from 'ag-grid-community';
4
+ import { FormatNumbersType } from '../../../../../shared-toolkit/src/models/format-numbers-type';
5
+ import { MetadataSettings } from '../../../models/metadata';
6
+ import { ConversationViewTitles } from '../../../models/titles';
7
+ export declare function getColumns(structures: StructuralData, data: DataMessage, locale: string, formattingSettings?: FormatNumbersType, metadataSettings?: MetadataSettings, titles?: ConversationViewTitles): ColDef[];
8
+ export declare function getDimensionsColumns(data: StructuralData, locale: string): ColDef[];
9
+ export declare function getTimeseriesColumns(structures: StructuralData, data: DataMessage, locale: string, formattingSettings?: FormatNumbersType, metadataSettings?: MetadataSettings, titles?: ConversationViewTitles): ColDef[];
@@ -0,0 +1,13 @@
1
+ import { ColDef } from 'ag-grid-community';
2
+ import { StructuralData } from '../../../../../sdmx-toolkit/src/models/structural-metadata';
3
+ import { DataMessage } from '../../../../../sdmx-toolkit/src/models/data/data-message';
4
+ import { GridData } from '../../../types/data-grid/grid-data';
5
+ import { FormatNumbersType } from '../../../../../shared-toolkit/src/models/format-numbers-type';
6
+ import { MetadataSettings } from '../../../models/metadata';
7
+ import { DataQuery } from '../../../../../shared-toolkit/src/models/data-query';
8
+ import { ChartingStyles } from '../../../models/attachments-styles';
9
+ import { ConversationViewTitles } from '../../../models/titles';
10
+ export declare function buildGridData(structures: StructuralData, data: DataMessage, dataQuery: DataQuery | undefined, locale: string, formattingSettings?: FormatNumbersType, metadataSettings?: MetadataSettings, chartStyles?: ChartingStyles, titles?: ConversationViewTitles): {
11
+ data: GridData[];
12
+ columns: ColDef[];
13
+ };
@@ -0,0 +1,5 @@
1
+ import { TimeSeries } from '../../../../../sdmx-toolkit/src/models/data/time-series';
2
+ import { Dimension } from '../../../../../sdmx-toolkit/src/models/structural-metadata/data-structure';
3
+ import { GridData } from '../../../types/data-grid/grid-data';
4
+ export declare function getConvertedData(timeSeries: TimeSeries[], dimensions: Dimension[], timeDimensions: Dimension[]): GridData[];
5
+ export declare const getGridData: (data: TimeSeries[], dimensions: string[], columns: string[], rows: string[]) => GridData[];
@@ -0,0 +1 @@
1
+ export declare const getGridHeight: (rowDataLength: number) => number;
@@ -0,0 +1,6 @@
1
+ import { DataMessage } from '../../../../../sdmx-toolkit/src/models/data/data-message';
2
+ import { StructuralData } from '../../../../../sdmx-toolkit/src/models/structural-metadata';
3
+ import { GridData } from '../../../types/data-grid/grid-data';
4
+ import { DataQuery } from '../../../../../shared-toolkit/src/models/data-query';
5
+ import { ChartingStyles } from '../../../models/attachments-styles';
6
+ export declare function getRowsData(data: DataMessage, structures: StructuralData, dataQuery: DataQuery | undefined, locale: string, chartStyles?: ChartingStyles): GridData[];
@@ -0,0 +1,7 @@
1
+ import { Data } from '../../../../sdmx-toolkit/src/models/data/data-message';
2
+ import { DataStructure } from '../../../../sdmx-toolkit/src/models/structural-metadata/data-structure';
3
+ import { Codelist } from '../../../../sdmx-toolkit/src/models/structural-metadata/codelist';
4
+ import { ElementBase } from '../../../../sdmx-toolkit/src/models/structural-metadata-base';
5
+ import { Locale } from '../../../../shared-toolkit/src/types/locale';
6
+ import { StructureComponentValue } from '../../models/structure-component';
7
+ export declare const getDimensionGroupAttributes: (data?: Data, dataStructure?: DataStructure, structureComponentsMap?: Map<string, Codelist | ElementBase>, seriesIds?: string[], locale?: Locale) => StructureComponentValue[];
@@ -0,0 +1,10 @@
1
+ import { Dimension } from '../../../../sdmx-toolkit/src/models/structural-metadata/data-structure';
2
+ import { Concept, ConceptScheme } from '../../../../sdmx-toolkit/src/models/structural-metadata/concept-scheme';
3
+ import { Codelist } from '../../../../sdmx-toolkit/src/models/structural-metadata/codelist';
4
+ import { GridData } from '../../types/data-grid/grid-data';
5
+ export declare function getDimRelatedStructures(dimension: Dimension, conceptSchemes: ConceptScheme[], codeLists: Codelist[]): {
6
+ concept: Concept | undefined;
7
+ codeList: Codelist | undefined;
8
+ };
9
+ export declare function getDimValue(dimensions: Dimension[], dimensionId: string | undefined, data: GridData): string | undefined;
10
+ export declare function getDimValueLocalizedName(dimensions: Dimension[], dimensionId: string | undefined, codeList: Codelist | undefined, data: GridData, locale: string): string | undefined;
@@ -0,0 +1,2 @@
1
+ export declare function prepareMarkdownContent(rawData: string | undefined): string | undefined;
2
+ export declare function validateJson(rawJson: string | undefined): string;
@@ -0,0 +1,42 @@
1
+ import { ICellRendererParams, ColDef } from 'ag-grid-community';
2
+ import { ElementBase } from '../../../../sdmx-toolkit/src/models/structural-metadata-base';
3
+ import { Codelist } from '../../../../sdmx-toolkit/src/models/structural-metadata/codelist';
4
+ import { StructureComponentValue } from '../../models/structure-component';
5
+ import { StructuralData } from '../../../../sdmx-toolkit/src/models/structural-metadata';
6
+ import { GridData } from '../../types/data-grid/grid-data';
7
+ import { Data } from '../../../../sdmx-toolkit/src/models/data/data-message';
8
+ import { StructureAttribute } from '../../../../sdmx-toolkit/src/models/data/structure';
9
+ import { Dataflow } from '../../../../sdmx-toolkit/src/models/structural-metadata/dataflow';
10
+ import { ConversationViewTitles } from '../../models/titles';
11
+ export declare const getObsAttributesFromParams: (params: ICellRendererParams) => any;
12
+ export declare const getAttributesFromParams: (params: ICellRendererParams) => any;
13
+ export declare const getDimensionsFromParams: (params: ICellRendererParams, structureComponentsMap: Map<string, Codelist | ElementBase>) => {
14
+ name: string;
15
+ value: string;
16
+ }[];
17
+ export declare const getStructureComponentsValues: (structureComponents: {
18
+ name: string;
19
+ value: string;
20
+ }[], structureComponentsMap: Map<string, Codelist | ElementBase>, locale: string) => StructureComponentValue[];
21
+ export declare const getDatasetNameItem: (dataset: Dataflow | undefined | null, locale: string, titles?: ConversationViewTitles) => {
22
+ title: string;
23
+ value: string | undefined;
24
+ };
25
+ export declare const getDatasetDescription: (dataset: Dataflow | undefined | null, lastUpdatedDate: string, locale: string, titles?: ConversationViewTitles) => {
26
+ title: string;
27
+ value: string | undefined;
28
+ }[];
29
+ export declare const getTimeDimensionItem: (dataSetData: StructuralData, locale: string, colDef?: ColDef) => {
30
+ title: string | undefined;
31
+ value: string;
32
+ };
33
+ export declare const getObservationItem: (value: string, titles?: ConversationViewTitles) => {
34
+ title: string;
35
+ value: string;
36
+ };
37
+ export declare const getMetadataDescriptionItems: (dataSetData: StructuralData, locale: string, value: string, titles?: ConversationViewTitles, colDef?: ColDef, data?: GridData) => {
38
+ title: string | undefined;
39
+ value: string;
40
+ }[];
41
+ export declare const getStructureAttributes: (data?: Data) => StructureAttribute[];
42
+ export declare const getDataSetAttributes: (structureAttributes: StructureAttribute[], structureComponentsMap: Map<string, Codelist | ElementBase>, locale: string) => StructureComponentValue[];
@@ -0,0 +1,3 @@
1
+ import { DataQuery } from '../../../../shared-toolkit/src/models/data-query';
2
+ import { Attachment } from '@epam/ai-dial-shared';
3
+ export declare function getDataQueries(attachments: Attachment[]): DataQuery[] | undefined;
@@ -0,0 +1,12 @@
1
+ import { CalendarResolution } from '../../../../shared-toolkit/src/types/calendar';
2
+ import { OptionsType } from 'react-flatpickr';
3
+ import { TimeRange } from '../../../../shared-toolkit/src/models/time-range';
4
+ import { ConversationViewTitles } from '../../models/titles';
5
+ export declare const getPickerOptions: (minDate: Date, maxDate: Date, calendarResolution: CalendarResolution, lang: string, startFromMonday?: boolean, dateFormat?: string) => OptionsType;
6
+ export declare const correctTimeZone: (date: Date) => void;
7
+ export declare const dayTimeFormatOptions: Intl.DateTimeFormatOptions;
8
+ export declare const monthTimeFormatOptions: Intl.DateTimeFormatOptions;
9
+ export declare const getDateString: (date?: Date | null, locale?: string) => string;
10
+ export declare const getMergedTimeRange: (attachmentTimeRange: TimeRange, constraintsTimeRange: TimeRange) => TimeRange;
11
+ export declare const getRangedTimePeriod: (initialTimeRange: TimeRange, period: string | number) => TimeRange;
12
+ export declare const localizeTimePeriod: (period: string, titles?: ConversationViewTitles) => string;
@@ -0,0 +1,6 @@
1
+ export declare const getCreateConversationRequest: (bucket: string, locale: string, defaultName: string, prompt?: string) => {
2
+ name: string;
3
+ folderId: string;
4
+ prompt: string | undefined;
5
+ };
6
+ export declare const prepareEntityName: (prompt?: string) => string;
@@ -0,0 +1 @@
1
+ export declare const getDateFormattedValue: (value: string | number | undefined, locale: string) => string;
@@ -0,0 +1,3 @@
1
+ import { Message } from '../../../dial-toolkit/src/models/message';
2
+ import { MessageStreamResponse } from '../../../dial-toolkit/src/models/chat-stream';
3
+ export declare const extractPartialMessageData: (data: MessageStreamResponse) => Partial<Message>;
@@ -0,0 +1,36 @@
1
+ import { Dimension } from '../../../sdmx-toolkit/src/models/structural-metadata/data-structure';
2
+ import { StructuralData } from '../../../sdmx-toolkit/src/models/structural-metadata';
3
+ import { Filter, FilterTreeNodeProps, FilterValue } from '../models/filters';
4
+ import { StructureItemBase } from '../../../sdmx-toolkit/src/models/data/structure';
5
+ import { DataQuery } from '../../../shared-toolkit/src/models/data-query';
6
+ import { FilterDisplayMode } from '../constants/filter-display-mode';
7
+ import { DataConstraints } from '../../../sdmx-toolkit/src/models/structural-metadata/constraints';
8
+ import { ConversationViewTitles } from '../models/titles';
9
+ export declare const getDatasetFilters: (dimensions?: Dimension[], structures?: StructuralData, structureDimensions?: StructureItemBase[], locale?: string) => Filter[];
10
+ export declare const updateFiltersWithSelectedItem: (filters: Filter[], selectedFilter?: Filter) => Filter[];
11
+ export declare const updateFiltersWithDisplayMode: (filters: Filter[], filterId?: string, displayMode?: string) => Filter[];
12
+ export declare const getSelectedDimensionValues: (dimensionValues?: FilterValue[]) => FilterValue[];
13
+ export declare const getSelectedFilterValues: (filters: Filter[]) => Filter[];
14
+ export declare const getTotalSelectedValuesLength: (selectedFilterValues: Filter[]) => number;
15
+ export declare const clearFilterValues: (filter: Filter) => Filter;
16
+ export declare const getFiltersAfterDelete: (filters: Filter[], deleteFilterId?: string) => Filter[];
17
+ export declare const getFiltersAfterClear: (filters: Filter[]) => Filter[];
18
+ export declare const getFiltersPreselectedByDataQuery: (filters: Filter[], attachmentsFilters?: DataQuery, constraints?: DataConstraints[]) => Filter[];
19
+ export declare const updateFiltersWithDisabledOption: (filters: Filter[]) => {
20
+ isDisabled: boolean;
21
+ id?: string;
22
+ title?: string;
23
+ dimensionValues?: FilterValue[];
24
+ isSelectedFilter?: boolean;
25
+ isTimeDimension?: boolean;
26
+ timeRange?: import('../../../shared-toolkit/src').TimeRange;
27
+ isHierarchical?: boolean;
28
+ displayMode?: string;
29
+ }[];
30
+ export declare const getFilterValuesTree: (filterValues?: FilterValue[]) => FilterTreeNodeProps[];
31
+ export declare const getFilterTreeNodePadding: (level: number, isHasChildren?: boolean) => string;
32
+ export declare const getFilterNodesBySelection: (node: FilterTreeNodeProps) => FilterTreeNodeProps[];
33
+ export declare const getFilterDisplaySettings: (titles?: ConversationViewTitles) => {
34
+ key: FilterDisplayMode;
35
+ title: string;
36
+ }[];
@@ -0,0 +1,2 @@
1
+ import { Conversation } from '@epam/ai-dial-shared';
2
+ export declare const generateConversation: (conversation: Conversation, currentBucket: string, locale: string) => Conversation;
@@ -0,0 +1 @@
1
+ export declare const generateDownloadedFile: (fileContent?: string, fileName?: string, format?: string) => void;
@@ -0,0 +1,2 @@
1
+ import { Conversation } from '@epam/ai-dial-shared';
2
+ export declare const getRedirectConversationPath: (conversation: Conversation, locale?: string, conversationsRoute?: string) => string;