mirror of
https://github.com/elastic/kibana.git
synced 2025-04-24 17:59:23 -04:00
Embeddable input (#73033)
* refactor: 💡 move timeRange, filters and query to base embeddabl * refactor: 💡 use new base embeddable input in explore data * feat: 🎸 import types as types
This commit is contained in:
parent
3ddc2acd66
commit
74ab9897b5
5 changed files with 23 additions and 13 deletions
|
@ -22,6 +22,7 @@ import { Adapters } from '../types';
|
|||
import { IContainer } from '../containers/i_container';
|
||||
import { ViewMode } from '../types';
|
||||
import { TriggerContextMapping } from '../../../../ui_actions/public';
|
||||
import type { TimeRange, Query, Filter } from '../../../../data/common';
|
||||
|
||||
export interface EmbeddableError {
|
||||
name: string;
|
||||
|
@ -55,6 +56,21 @@ export interface EmbeddableInput {
|
|||
*/
|
||||
disableTriggers?: boolean;
|
||||
|
||||
/**
|
||||
* Time range of the chart.
|
||||
*/
|
||||
timeRange?: TimeRange;
|
||||
|
||||
/**
|
||||
* Visualization query string used to narrow down results.
|
||||
*/
|
||||
query?: Query;
|
||||
|
||||
/**
|
||||
* Visualization filters used to narrow down results.
|
||||
*/
|
||||
filters?: Filter[];
|
||||
|
||||
[key: string]: unknown;
|
||||
}
|
||||
|
||||
|
|
|
@ -60,9 +60,6 @@ export interface VisualizeEmbeddableConfiguration {
|
|||
}
|
||||
|
||||
export interface VisualizeInput extends EmbeddableInput {
|
||||
timeRange?: TimeRange;
|
||||
query?: Query;
|
||||
filters?: Filter[];
|
||||
vis?: {
|
||||
colors?: { [key: string]: string };
|
||||
};
|
||||
|
|
|
@ -59,6 +59,7 @@ export abstract class AbstractExploreDataAction<Context extends { embeddable?: I
|
|||
|
||||
if (!shared.hasExactlyOneIndexPattern(embeddable)) return false;
|
||||
if (embeddable.getInput().viewMode !== ViewMode.VIEW) return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
|
@ -7,9 +7,6 @@
|
|||
import { Action } from '../../../../../../src/plugins/ui_actions/public';
|
||||
import { DiscoverUrlGeneratorState } from '../../../../../../src/plugins/discover/public';
|
||||
import {
|
||||
isTimeRange,
|
||||
isQuery,
|
||||
isFilters,
|
||||
ApplyGlobalFilterActionContext,
|
||||
esFilters,
|
||||
} from '../../../../../../src/plugins/data/public';
|
||||
|
@ -64,9 +61,9 @@ export class ExploreDataChartAction extends AbstractExploreDataAction<ExploreDat
|
|||
|
||||
const input = embeddable.getInput();
|
||||
|
||||
if (isTimeRange(input.timeRange) && !state.timeRange) state.timeRange = input.timeRange;
|
||||
if (isQuery(input.query)) state.query = input.query;
|
||||
if (isFilters(input.filters)) state.filters = [...input.filters, ...(state.filters || [])];
|
||||
if (input.timeRange && !state.timeRange) state.timeRange = input.timeRange;
|
||||
if (input.query) state.query = input.query;
|
||||
if (input.filters) state.filters = [...input.filters, ...(state.filters || [])];
|
||||
}
|
||||
|
||||
const path = await urlGenerator.createUrl(state);
|
||||
|
|
|
@ -7,7 +7,6 @@
|
|||
import { Action } from '../../../../../../src/plugins/ui_actions/public';
|
||||
import { EmbeddableContext } from '../../../../../../src/plugins/embeddable/public';
|
||||
import { DiscoverUrlGeneratorState } from '../../../../../../src/plugins/discover/public';
|
||||
import { isTimeRange, isQuery, isFilters } from '../../../../../../src/plugins/data/public';
|
||||
import { KibanaURL } from './kibana_url';
|
||||
import * as shared from './shared';
|
||||
import { AbstractExploreDataAction } from './abstract_explore_data_action';
|
||||
|
@ -42,9 +41,9 @@ export class ExploreDataContextMenuAction extends AbstractExploreDataAction<Embe
|
|||
|
||||
const input = embeddable.getInput();
|
||||
|
||||
if (isTimeRange(input.timeRange) && !state.timeRange) state.timeRange = input.timeRange;
|
||||
if (isQuery(input.query)) state.query = input.query;
|
||||
if (isFilters(input.filters)) state.filters = [...input.filters, ...(state.filters || [])];
|
||||
if (input.timeRange && !state.timeRange) state.timeRange = input.timeRange;
|
||||
if (input.query) state.query = input.query;
|
||||
if (input.filters) state.filters = [...input.filters, ...(state.filters || [])];
|
||||
}
|
||||
|
||||
const path = await urlGenerator.createUrl(state);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue