Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[TSVB][Lens] Navigate to Lens with your current configuration #114794

Merged
merged 137 commits into from
Feb 14, 2022
Merged
Show file tree
Hide file tree
Changes from 136 commits
Commits
Show all changes
137 commits
Select commit Hold shift + click to select a range
76628e0
[Lens][TSVB] Convert to Lens
stratoula Oct 12, 2021
74f262a
Add logic for multiple series
stratoula Oct 13, 2021
065a9b1
Basic formula
stratoula Oct 13, 2021
6da7fac
Fix circular dependencies
stratoula Oct 13, 2021
b62ef23
Minor cleanup
stratoula Oct 13, 2021
502036f
Fix types
stratoula Oct 13, 2021
f132aad
fix jest tests
stratoula Oct 13, 2021
6e17315
Merge branch 'master' into convert-to-lens
kibanamachine Oct 13, 2021
8dd3b87
Fix test
stratoula Oct 13, 2021
e70ab64
Change the schema, add more styling options, fix bugs
stratoula Oct 14, 2021
089163d
Supports time shift and custom date interval
stratoula Oct 15, 2021
ff1cf81
Merge branch 'master' into convert-to-lens
kibanamachine Oct 15, 2021
5976aee
Merge branch 'master' into convert-to-lens
kibanamachine Oct 18, 2021
313871b
Merge branch 'master' into convert-to-lens
kibanamachine Oct 18, 2021
1a0959d
Merge branch 'master' into convert-to-lens
kibanamachine Oct 20, 2021
5ecaa0f
Merge with master and resolve conflicts
stratoula Oct 25, 2021
ea05e70
Fix types
stratoula Oct 25, 2021
40b8b36
Merge branch 'master' into convert-to-lens
kibanamachine Oct 25, 2021
99a4a70
Merge branch 'master' into convert-to-lens
kibanamachine Oct 26, 2021
5d67077
Merge branch 'master' into convert-to-lens
kibanamachine Oct 29, 2021
3e9b1c5
Merge branch 'main' into convert-to-lens
kibanamachine Nov 1, 2021
f7ca582
Merge branch 'main' into convert-to-lens
kibanamachine Nov 2, 2021
580ec72
Merge with main and resolve conflicts
stratoula Dec 6, 2021
fd38926
Fix some types
stratoula Dec 6, 2021
c784cbe
Move edit in lens button to top nav menu
stratoula Dec 6, 2021
5a0d721
Cleanup
stratoula Dec 6, 2021
b35a5b5
Further cleanup
stratoula Dec 6, 2021
0ce5f89
Add try it badge in menu, controlled by localStorage
stratoula Dec 7, 2021
d44bbea
Merge branch 'main' into convert-to-lens
kibanamachine Dec 7, 2021
0f1b990
Add go back to app button
stratoula Dec 7, 2021
ef6d4b5
Discard changes modal and go back to TSVB
stratoula Dec 8, 2021
da1e2c8
Update by value and by reference visualizations, delete existing by ref
stratoula Dec 8, 2021
73fcb51
Fix bug
stratoula Dec 8, 2021
528f05c
Apply some changes
stratoula Dec 8, 2021
9d86330
Merge branch 'main' into convert-to-lens
kibanamachine Dec 9, 2021
4272ef1
get title and description only if has context
stratoula Dec 13, 2021
956d942
Merge branch 'main' into convert-to-lens
kibanamachine Dec 13, 2021
31162dc
Pass originating app, title and description from the savedVis
stratoula Dec 13, 2021
a5e8a23
By ref TSVB to by ref Lens
stratoula Dec 13, 2021
62ee1a0
Merge branch 'main' into convert-to-lens
kibanamachine Dec 15, 2021
8794034
Match TSVB cardinality with Lens unique_count function
stratoula Dec 15, 2021
d4f7ccc
Support moving average
stratoula Dec 15, 2021
2716076
Fix test
stratoula Dec 16, 2021
9f6e116
Support derivative
stratoula Dec 16, 2021
9b3da9c
Support cumulative_sum
stratoula Dec 16, 2021
11932e5
Add overall functions
stratoula Dec 16, 2021
79df1fc
Merge branch 'main' into convert-to-lens
kibanamachine Dec 20, 2021
7ed8901
Support filter ratio
stratoula Dec 20, 2021
84ece5f
Refactor code for easier testing
stratoula Dec 20, 2021
0773170
Fix bug with auto interval
stratoula Dec 20, 2021
60f50d7
Fetch types from visualizations plugin
stratoula Dec 20, 2021
d1e3fb2
Pipeline aggs compatible with percentile
stratoula Dec 20, 2021
ad4c2fd
Add some bugs
stratoula Dec 20, 2021
7c74b98
Support nesred aggs
stratoula Dec 20, 2021
a581dd5
Merge branch 'main' into convert-to-lens
kibanamachine Dec 22, 2021
ba02a9f
Merge branch 'main' into convert-to-lens
kibanamachine Dec 23, 2021
6433b30
Mini refactor and support all aggregations to Math
stratoula Dec 23, 2021
e13b1c2
Transfer terms sorting options
stratoula Dec 24, 2021
7311e67
Transfer axis position
stratoula Dec 24, 2021
99d9211
Merge branch 'main' into convert-to-lens
kibanamachine Jan 4, 2022
e2024b7
Merge branch 'main' into convert-to-lens
kibanamachine Jan 10, 2022
51de080
Merge branch 'main' into convert-to-lens
kibanamachine Jan 12, 2022
03c4383
Merge with main and resolve conflicts
stratoula Jan 13, 2022
ae62c6c
Fix translations keys
stratoula Jan 13, 2022
3aa983c
Merge with main, resolve conflicts, use isLensEqual instead
stratoula Jan 14, 2022
26e842b
Revert
stratoula Jan 14, 2022
20b91ce
Fix redirectToOrigin buttion when the there is no embeddableId but co…
stratoula Jan 17, 2022
429ed12
Improve context identification
stratoula Jan 17, 2022
7040f38
Support yExtents
stratoula Jan 17, 2022
b039c0a
Merge branch 'main' into convert-to-lens
kibanamachine Jan 17, 2022
465f7db
Merge branch 'main' into convert-to-lens
stratoula Jan 18, 2022
331b965
Fix bug in formula caused by changes in the main branch
stratoula Jan 18, 2022
a3e57cb
Support formatters
stratoula Jan 18, 2022
467d4e0
Support custom label
stratoula Jan 18, 2022
8a1065e
Cleaning up
stratoula Jan 18, 2022
ede6341
Fix terms bugs
stratoula Jan 19, 2022
a6ce30d
Support filter breakdown by
stratoula Jan 19, 2022
185df2e
Merge branch 'main' into convert-to-lens
kibanamachine Jan 20, 2022
d870fb6
Fixes math bug and escapes filter ratio query
stratoula Jan 20, 2022
4202ff5
Merge branch 'main' into convert-to-lens
kibanamachine Jan 24, 2022
68c6274
Add some unit tests
stratoula Jan 24, 2022
d45e5ba
Testing triggerOptions payload
stratoula Jan 24, 2022
a7fc4fe
Fix console warning
stratoula Jan 25, 2022
943df02
Add more unit tests on TSVB function helpers
stratoula Jan 25, 2022
2d7cafc
Adds a unit test on the vis top nav menu testing the new menu item
stratoula Jan 25, 2022
3f50a21
Add unit tests
stratoula Jan 25, 2022
5126fc1
Merge branch 'main' into convert-to-lens
stratoula Jan 25, 2022
29c9a9f
Fix unsupported palette bug, clean up, add a unit test case
stratoula Jan 25, 2022
3c015da
Merge branch 'main' into convert-to-lens
kibanamachine Jan 26, 2022
3b3a25c
Add final unit tests
stratoula Jan 26, 2022
274b139
Support timeScale in derivative
stratoula Jan 26, 2022
5124288
Add functional tests
stratoula Jan 26, 2022
91bcecc
Cleanup
stratoula Jan 27, 2022
c210669
Fix jest test
stratoula Jan 27, 2022
f08fa3c
Merge branch 'main' into convert-to-lens
kibanamachine Jan 27, 2022
b655f4e
Fix some bugs
stratoula Jan 27, 2022
c49bc52
Fix some math agg bugs
stratoula Jan 27, 2022
3ff4105
Merge branch 'main' into convert-to-lens
stratoula Jan 27, 2022
1dd2d87
Fix more bugs
stratoula Jan 28, 2022
06f1ac1
Merge branch 'main' into convert-to-lens
kibanamachine Jan 31, 2022
27af228
Merge branch 'main' into convert-to-lens
kibanamachine Feb 2, 2022
25f6ced
Fixes jest test
stratoula Feb 2, 2022
4d65168
Fix the problem with the dashboard state
stratoula Feb 2, 2022
cde3576
Hides the badge and link instead of disabling it
stratoula Feb 2, 2022
208d1f5
Changes the text
stratoula Feb 2, 2022
0454f91
Merge with master and resolve conflicts
stratoula Feb 2, 2022
a8d8fa5
Merge branch 'main' into convert-to-lens
kibanamachine Feb 2, 2022
2f8a4e6
Merge branch 'main' into convert-to-lens
kibanamachine Feb 4, 2022
dc703f0
Merge branch 'main' into convert-to-lens
kibanamachine Feb 7, 2022
0e3644f
Adds menu item vertical separator
stratoula Feb 7, 2022
5afd257
Enhance the appLeace confirm modal to change the confirm button text …
stratoula Feb 7, 2022
879fd21
Fixes CI
stratoula Feb 7, 2022
b71296e
Adress code review comments
stratoula Feb 8, 2022
3f2d615
Address some of the comments
stratoula Feb 8, 2022
f2268b5
Fix more bugs
stratoula Feb 8, 2022
5f10a22
Fix more bugs
stratoula Feb 8, 2022
c01d3d7
Zero decimals for formatting
stratoula Feb 8, 2022
df9eaa0
fix tests
stratoula Feb 8, 2022
cce1e32
Merge branch 'main' into convert-to-lens
stratoula Feb 9, 2022
0f305b3
Navigate from dashboard to TSVB to Lens hides the appLeave modal
stratoula Feb 9, 2022
878c83f
Adds support for terms on a date field
stratoula Feb 9, 2022
2423d2b
Support filter by
stratoula Feb 9, 2022
7701b58
Move the trigger to the visualizations plugin
stratoula Feb 9, 2022
93f7449
Minor
stratoula Feb 9, 2022
fca4ebc
Fix CI
stratoula Feb 9, 2022
5d85886
Support percentage charts
stratoula Feb 10, 2022
70237f9
Merge with main and resolve conflicts
stratoula Feb 11, 2022
59d3183
Improve the vertical separator
stratoula Feb 11, 2022
c5f3124
Fixes on the appLeave logic
stratoula Feb 11, 2022
de999b5
Remove unecessary import
stratoula Feb 11, 2022
be11016
Add badge to the nav item level
stratoula Feb 11, 2022
8065703
Fix jest test
stratoula Feb 11, 2022
82deb26
Fi filter ratio and filter by bug
stratoula Feb 11, 2022
c47ffae
Merge branch 'main' into convert-to-lens
kibanamachine Feb 14, 2022
068b077
Replace all occurences of a variable
stratoula Feb 14, 2022
6047c9d
Nest badge into the button level
stratoula Feb 14, 2022
bd9340d
Design improvements
stratoula Feb 14, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
<!-- Do not edit this file. It is automatically generated by API Documenter. -->

[Home](./index.md) &gt; [kibana-plugin-core-public](./kibana-plugin-core-public.md) &gt; [AppLeaveConfirmAction](./kibana-plugin-core-public.appleaveconfirmaction.md) &gt; [buttonColor](./kibana-plugin-core-public.appleaveconfirmaction.buttoncolor.md)

## AppLeaveConfirmAction.buttonColor property

<b>Signature:</b>

```typescript
buttonColor?: ButtonColor;
```
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
<!-- Do not edit this file. It is automatically generated by API Documenter. -->

[Home](./index.md) &gt; [kibana-plugin-core-public](./kibana-plugin-core-public.md) &gt; [AppLeaveConfirmAction](./kibana-plugin-core-public.appleaveconfirmaction.md) &gt; [confirmButtonText](./kibana-plugin-core-public.appleaveconfirmaction.confirmbuttontext.md)

## AppLeaveConfirmAction.confirmButtonText property

<b>Signature:</b>

```typescript
confirmButtonText?: string;
```
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,9 @@ export interface AppLeaveConfirmAction

| Property | Type | Description |
| --- | --- | --- |
| [buttonColor?](./kibana-plugin-core-public.appleaveconfirmaction.buttoncolor.md) | ButtonColor | <i>(Optional)</i> |
| [callback?](./kibana-plugin-core-public.appleaveconfirmaction.callback.md) | () =&gt; void | <i>(Optional)</i> |
| [confirmButtonText?](./kibana-plugin-core-public.appleaveconfirmaction.confirmbuttontext.md) | string | <i>(Optional)</i> |
| [text](./kibana-plugin-core-public.appleaveconfirmaction.text.md) | string | |
| [title?](./kibana-plugin-core-public.appleaveconfirmaction.title.md) | string | <i>(Optional)</i> |
| [type](./kibana-plugin-core-public.appleaveconfirmaction.type.md) | AppLeaveActionType.confirm | |
Expand Down
12 changes: 12 additions & 0 deletions src/core/public/application/application_leave.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -54,5 +54,17 @@ describe('getLeaveAction', () => {
title: 'a title',
callback,
});
expect(
getLeaveAction((actions) =>
actions.confirm('another message', 'a title', callback, 'confirm button text', 'danger')
)
).toEqual({
type: AppLeaveActionType.confirm,
text: 'another message',
title: 'a title',
callback,
confirmButtonText: 'confirm button text',
buttonColor: 'danger',
});
});
});
19 changes: 16 additions & 3 deletions src/core/public/application/application_leave.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/

import type { ButtonColor } from '@elastic/eui';
import {
AppLeaveActionFactory,
AppLeaveActionType,
Expand All @@ -15,8 +15,21 @@ import {
} from './types';

const appLeaveActionFactory: AppLeaveActionFactory = {
confirm(text: string, title?: string, callback?: () => void) {
return { type: AppLeaveActionType.confirm, text, title, callback };
confirm(
text: string,
title?: string,
callback?: () => void,
confirmButtonText?: string,
buttonColor?: ButtonColor
) {
return {
type: AppLeaveActionType.confirm,
text,
title,
confirmButtonText,
buttonColor,
callback,
};
},
default() {
return { type: AppLeaveActionType.default };
Expand Down
2 changes: 2 additions & 0 deletions src/core/public/application/application_service.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -365,6 +365,8 @@ export class ApplicationService {
const confirmed = await overlays.openConfirm(action.text, {
title: action.title,
'data-test-subj': 'appLeaveConfirmModal',
confirmButtonText: action.confirmButtonText,
buttonColor: action.buttonColor,
});
if (!confirmed) {
if (action.callback) {
Expand Down
14 changes: 12 additions & 2 deletions src/core/public/application/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/

import type { ButtonColor } from '@elastic/eui';
import { Observable } from 'rxjs';
import { History } from 'history';
import { RecursiveReadonly } from '@kbn/utility-types';
Expand Down Expand Up @@ -597,6 +597,8 @@ export interface AppLeaveConfirmAction {
type: AppLeaveActionType.confirm;
text: string;
title?: string;
confirmButtonText?: string;
buttonColor?: ButtonColor;
callback?: () => void;
}

Expand All @@ -621,9 +623,17 @@ export interface AppLeaveActionFactory {
* @param text The text to display in the confirmation message
* @param title (optional) title to display in the confirmation message
* @param callback (optional) to know that the user want to stay on the page
* @param confirmButtonText (optional) text for the confirmation button
* @param buttonColor (optional) color for the confirmation button
* so we can show to the user the right UX for him to saved his/her/their changes
*/
confirm(text: string, title?: string, callback?: () => void): AppLeaveConfirmAction;
confirm(
text: string,
title?: string,
callback?: () => void,
confirmButtonText?: string,
buttonColor?: ButtonColor
): AppLeaveConfirmAction;

/**
* Returns a default action, resulting on executing the default behavior when
Expand Down
5 changes: 5 additions & 0 deletions src/core/public/public.api.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@

import { Action } from 'history';
import Boom from '@hapi/boom';
import type { ButtonColor } from '@elastic/eui';
import { ByteSizeValue } from '@kbn/config-schema';
import type { Client } from '@elastic/elasticsearch';
import { ConfigPath } from '@kbn/config';
Expand Down Expand Up @@ -115,9 +116,13 @@ export enum AppLeaveActionType {
//
// @public
export interface AppLeaveConfirmAction {
// (undocumented)
buttonColor?: ButtonColor;
// (undocumented)
callback?: () => void;
// (undocumented)
confirmButtonText?: string;
// (undocumented)
text: string;
// (undocumented)
title?: string;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,9 @@ export const buildDashboardContainer = async ({
gridData: originalPanelState.gridData,
type: incomingEmbeddable.type,
explicitInput: {
...originalPanelState.explicitInput,
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ℹ️ Not needed, allows a TSVB library panel to be replaced by a Lens by value panel

...(incomingEmbeddable.type === originalPanelState.type && {
...originalPanelState.explicitInput,
}),
...incomingEmbeddable.input,
id: incomingEmbeddable.embeddableId,
},
Expand Down
9 changes: 9 additions & 0 deletions src/plugins/navigation/public/top_nav_menu/_index.scss
Original file line number Diff line number Diff line change
Expand Up @@ -12,3 +12,12 @@
.kbnTopNavMenu__badgeGroup {
margin-right: $euiSizeM;
}

.kbnTopNavMenu__betaBadgeWrapper {
display: flex;
align-items: center;
}

.kbnTopNavMenu__betaBadgeItem {
margin-right: $euiSizeS;
}
stratoula marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
* Side Public License, v 1.
*/

import { EuiButtonProps } from '@elastic/eui';
import { EuiButtonProps, EuiBetaBadgeProps } from '@elastic/eui';

export type TopNavMenuAction = (anchorElement: HTMLElement) => void;

Expand All @@ -19,6 +19,7 @@ export interface TopNavMenuData {
className?: string;
disableButton?: boolean | (() => boolean);
tooltip?: string | (() => string | undefined);
badge?: EuiBetaBadgeProps;
emphasize?: boolean;
isLoading?: boolean;
iconType?: string;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@

import { upperFirst, isFunction } from 'lodash';
import React, { MouseEvent } from 'react';
import { EuiToolTip, EuiButton, EuiHeaderLink } from '@elastic/eui';
import { EuiToolTip, EuiButton, EuiHeaderLink, EuiBetaBadge } from '@elastic/eui';
import { TopNavMenuData } from './top_nav_menu_data';

export function TopNavMenuItem(props: TopNavMenuData) {
Expand All @@ -22,6 +22,19 @@ export function TopNavMenuItem(props: TopNavMenuData) {
return val!;
}

function getButtonContainer() {
if (props.badge) {
return (
<div className="kbnTopNavMenu__betaBadgeWrapper">
<EuiBetaBadge className="kbnTopNavMenu__betaBadgeItem" {...props.badge} size="s" />
{upperFirst(props.label || props.id!)}
</div>
stratoula marked this conversation as resolved.
Show resolved Hide resolved
);
} else {
return upperFirst(props.label || props.id!);
}
}

function handleClick(e: MouseEvent<HTMLButtonElement>) {
if (isDisabled()) return;
props.run(e.currentTarget);
Expand All @@ -39,11 +52,11 @@ export function TopNavMenuItem(props: TopNavMenuData) {

const btn = props.emphasize ? (
<EuiButton size="s" {...commonButtonProps} fill>
{upperFirst(props.label || props.id!)}
{getButtonContainer()}
</EuiButton>
) : (
<EuiHeaderLink size="s" color="primary" {...commonButtonProps}>
{upperFirst(props.label || props.id!)}
{getButtonContainer()}
</EuiHeaderLink>
);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ export interface Series {
chart_type: string;
color: string;
color_rules?: ColorRules[];
fill?: number;
fill?: string;
filter?: Query;
formatter: string;
hidden?: boolean;
Expand Down
7 changes: 7 additions & 0 deletions src/plugins/vis_types/timeseries/public/metrics_type.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ import {
} from '../../../visualizations/public';
import { getDataStart } from './services';
import type { TimeseriesVisDefaultParams, TimeseriesVisParams } from './types';
import { triggerTSVBtoLensConfiguration } from './trigger_action';
import type { IndexPatternValue, Panel } from '../common/types';
import { RequestAdapter } from '../../../inspector/public';

Expand Down Expand Up @@ -167,6 +168,12 @@ export const metricsVisDefinition: VisTypeDefinition<
}
return [];
},
navigateToLens: async (params?: VisParams) => {
const triggerConfiguration = params
? await triggerTSVBtoLensConfiguration(params as Panel)
: null;
return triggerConfiguration;
},
inspectorAdapters: () => ({
requests: new RequestAdapter(),
}),
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0 and the Server Side Public License, v 1; you may not use this file except
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/
import type { DataView } from '../../../../data/common';
import { getDataSourceInfo } from './get_datasource_info';
const dataViewsMap: Record<string, DataView> = {
test1: { id: 'test1', title: 'test1', timeFieldName: 'timeField1' } as DataView,
test2: {
id: 'test2',
title: 'test2',
timeFieldName: 'timeField2',
} as DataView,
test3: { id: 'test3', title: 'test3', timeFieldName: 'timeField3' } as DataView,
};

const getDataview = (id: string): DataView | undefined => dataViewsMap[id];
jest.mock('../services', () => {
return {
getDataStart: jest.fn(() => {
return {
dataViews: {
getDefault: jest.fn(() => {
return { id: '12345', title: 'default', timeFieldName: '@timestamp' };
}),
get: getDataview,
},
};
}),
};
});

describe('getDataSourceInfo', () => {
test('should return the default dataview if model_indexpattern is string', async () => {
const { indexPatternId, timeField } = await getDataSourceInfo(
'test',
undefined,
false,
undefined
);
expect(indexPatternId).toBe('12345');
expect(timeField).toBe('@timestamp');
});

test('should return the correct dataview if model_indexpattern is object', async () => {
const { indexPatternId, timeField } = await getDataSourceInfo(
{ id: 'dataview-1-id' },
'timeField-1',
false,
undefined
);
expect(indexPatternId).toBe('dataview-1-id');
expect(timeField).toBe('timeField-1');
});

test('should fetch the correct data if overwritten dataview is provided', async () => {
const { indexPatternId, timeField } = await getDataSourceInfo(
{ id: 'dataview-1-id' },
'timeField-1',
true,
{ id: 'test2' }
);
expect(indexPatternId).toBe('test2');
expect(timeField).toBe('timeField2');
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0 and the Server Side Public License, v 1; you may not use this file except
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/
import { fetchIndexPattern, isStringTypeIndexPattern } from '../../common/index_patterns_utils';
import type { IndexPatternValue } from '../../common/types';
import { getDataStart } from '../services';

export const getDataSourceInfo = async (
modelIndexPattern: IndexPatternValue,
modelTimeField: string | undefined,
isOverwritten: boolean,
overwrittenIndexPattern: IndexPatternValue | undefined
) => {
const { dataViews } = getDataStart();
let indexPatternId =
modelIndexPattern && !isStringTypeIndexPattern(modelIndexPattern) ? modelIndexPattern.id : '';

let timeField = modelTimeField;
// handle override index pattern
if (isOverwritten) {
const { indexPattern } = await fetchIndexPattern(overwrittenIndexPattern, dataViews);
if (indexPattern) {
indexPatternId = indexPattern.id ?? '';
timeField = indexPattern.timeFieldName;
}
}

if (!indexPatternId) {
const defaultIndex = await dataViews.getDefault();
indexPatternId = defaultIndex?.id ?? '';
timeField = defaultIndex?.timeFieldName;
}
if (!timeField) {
const indexPattern = await dataViews.get(indexPatternId);
timeField = indexPattern.timeFieldName;
}

return {
indexPatternId,
timeField,
};
};
Loading