2019-09-17 20:57:53 +02:00
|
|
|
/*
|
|
|
|
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
|
|
|
* or more contributor license agreements. Licensed under the Elastic License;
|
|
|
|
* you may not use this file except in compliance with the Elastic License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import { Ast } from '@kbn/interpreter/common';
|
2019-10-03 19:30:33 +02:00
|
|
|
import { IconType } from '@elastic/eui/src/components/icon/icon';
|
2019-09-17 20:57:53 +02:00
|
|
|
import { CoreSetup } from 'src/core/public';
|
2019-11-19 01:26:13 +01:00
|
|
|
import { KibanaDatatable } from '../../../../../src/plugins/expressions/public';
|
2019-09-17 20:57:53 +02:00
|
|
|
import { DragContextState } from './drag_drop';
|
|
|
|
import { Document } from './persistence';
|
2020-02-05 18:35:40 +01:00
|
|
|
import { DateRange } from '../../../../plugins/lens/common';
|
2020-03-12 08:58:49 +01:00
|
|
|
import { Query, Filter, SavedQuery } from '../../../../../src/plugins/data/public';
|
2019-09-17 20:57:53 +02:00
|
|
|
|
|
|
|
// eslint-disable-next-line
|
|
|
|
export interface EditorFrameOptions {}
|
|
|
|
|
|
|
|
export type ErrorCallback = (e: { message: string }) => void;
|
|
|
|
|
2019-10-29 17:48:30 +01:00
|
|
|
export interface PublicAPIProps<T> {
|
|
|
|
state: T;
|
|
|
|
setState: StateSetter<T>;
|
|
|
|
layerId: string;
|
|
|
|
dateRange: DateRange;
|
|
|
|
}
|
|
|
|
|
2019-09-17 20:57:53 +02:00
|
|
|
export interface EditorFrameProps {
|
|
|
|
onError: ErrorCallback;
|
|
|
|
doc?: Document;
|
2019-10-29 17:48:30 +01:00
|
|
|
dateRange: DateRange;
|
2019-09-17 20:57:53 +02:00
|
|
|
query: Query;
|
2020-02-12 12:22:06 +01:00
|
|
|
filters: Filter[];
|
2019-10-03 17:24:45 +02:00
|
|
|
savedQuery?: SavedQuery;
|
2019-09-17 20:57:53 +02:00
|
|
|
|
|
|
|
// Frame loader (app or embeddable) is expected to call this when it loads and updates
|
2019-10-03 17:24:45 +02:00
|
|
|
onChange: (newState: {
|
|
|
|
filterableIndexPatterns: DatasourceMetaData['filterableIndexPatterns'];
|
|
|
|
doc: Document;
|
|
|
|
}) => void;
|
2019-09-17 20:57:53 +02:00
|
|
|
}
|
|
|
|
export interface EditorFrameInstance {
|
|
|
|
mount: (element: Element, props: EditorFrameProps) => void;
|
|
|
|
unmount: () => void;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface EditorFrameSetup {
|
|
|
|
// generic type on the API functions to pull the "unknown vs. specific type" error into the implementation
|
2020-02-13 13:54:51 +01:00
|
|
|
registerDatasource: <T, P>(datasource: Datasource<T, P> | Promise<Datasource<T, P>>) => void;
|
|
|
|
registerVisualization: <T, P>(
|
|
|
|
visualization: Visualization<T, P> | Promise<Visualization<T, P>>
|
|
|
|
) => void;
|
2019-09-17 20:57:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface EditorFrameStart {
|
2020-02-13 13:54:51 +01:00
|
|
|
createInstance: (options: EditorFrameOptions) => Promise<EditorFrameInstance>;
|
2019-09-17 20:57:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Hints the default nesting to the data source. 0 is the highest priority
|
|
|
|
export type DimensionPriority = 0 | 1 | 2;
|
|
|
|
|
|
|
|
export interface TableSuggestionColumn {
|
|
|
|
columnId: string;
|
|
|
|
operation: Operation;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A possible table a datasource can create. This object is passed to the visualization
|
|
|
|
* which tries to build a meaningful visualization given the shape of the table. If this
|
|
|
|
* is possible, the visualization returns a `VisualizationSuggestion` object
|
|
|
|
*/
|
|
|
|
export interface TableSuggestion {
|
|
|
|
/**
|
|
|
|
* Flag indicating whether the table will include more than one column.
|
|
|
|
* This is not the case for example for a single metric aggregation
|
|
|
|
* */
|
|
|
|
isMultiRow: boolean;
|
|
|
|
/**
|
|
|
|
* The columns of the table. Each column has to be mapped to a dimension in a chart. If a visualization
|
|
|
|
* can't use all columns of a suggestion, it should not return a `VisualizationSuggestion` based on it
|
|
|
|
* because there would be unreferenced columns
|
|
|
|
*/
|
|
|
|
columns: TableSuggestionColumn[];
|
|
|
|
/**
|
|
|
|
* The layer this table will replace. This is only relevant if the visualization this suggestion is passed
|
|
|
|
* is currently active and has multiple layers configured. If this suggestion is applied, the table of this
|
|
|
|
* layer will be replaced by the columns specified in this suggestion
|
|
|
|
*/
|
|
|
|
layerId: string;
|
|
|
|
/**
|
|
|
|
* A label describing the table. This can be used to provide a title for the `VisualizationSuggestion`,
|
|
|
|
* but the visualization can also decide to overwrite it.
|
|
|
|
*/
|
|
|
|
label?: string;
|
|
|
|
/**
|
|
|
|
* The change type indicates what was changed in this table compared to the currently active table of this layer.
|
|
|
|
*/
|
|
|
|
changeType: TableChangeType;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Indicates what was changed in this table compared to the currently active table of this layer.
|
|
|
|
* * `initial` means the layer associated with this table does not exist in the current configuration
|
|
|
|
* * `unchanged` means the table is the same in the currently active configuration
|
|
|
|
* * `reduced` means the table is a reduced version of the currently active table (some columns dropped, but not all of them)
|
|
|
|
* * `extended` means the table is an extended version of the currently active table (added one or multiple additional columns)
|
2019-10-30 00:05:03 +01:00
|
|
|
* * `layers` means the change is a change to the layer structure, not to the table
|
2019-09-17 20:57:53 +02:00
|
|
|
*/
|
2019-10-30 00:05:03 +01:00
|
|
|
export type TableChangeType = 'initial' | 'unchanged' | 'reduced' | 'extended' | 'layers';
|
2019-09-17 20:57:53 +02:00
|
|
|
|
|
|
|
export interface DatasourceSuggestion<T = unknown> {
|
|
|
|
state: T;
|
|
|
|
table: TableSuggestion;
|
2019-10-30 00:05:03 +01:00
|
|
|
keptLayerIds: string[];
|
2019-09-17 20:57:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface DatasourceMetaData {
|
|
|
|
filterableIndexPatterns: Array<{ id: string; title: string }>;
|
|
|
|
}
|
|
|
|
|
|
|
|
export type StateSetter<T> = (newState: T | ((prevState: T) => T)) => void;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface for the datasource registry
|
|
|
|
*/
|
|
|
|
export interface Datasource<T = unknown, P = unknown> {
|
2019-12-04 14:36:21 +01:00
|
|
|
id: string;
|
|
|
|
|
2019-09-17 20:57:53 +02:00
|
|
|
// For initializing, either from an empty state or from persisted state
|
|
|
|
// Because this will be called at runtime, state might have a type of `any` and
|
|
|
|
// datasources should validate their arguments
|
|
|
|
initialize: (state?: P) => Promise<T>;
|
|
|
|
|
|
|
|
// Given the current state, which parts should be saved?
|
|
|
|
getPersistableState: (state: T) => P;
|
|
|
|
|
|
|
|
insertLayer: (state: T, newLayerId: string) => T;
|
|
|
|
removeLayer: (state: T, layerId: string) => T;
|
2020-01-14 18:06:51 +01:00
|
|
|
clearLayer: (state: T, layerId: string) => T;
|
2019-09-17 20:57:53 +02:00
|
|
|
getLayers: (state: T) => string[];
|
|
|
|
|
|
|
|
renderDataPanel: (domElement: Element, props: DatasourceDataPanelProps<T>) => void;
|
|
|
|
|
|
|
|
toExpression: (state: T, layerId: string) => Ast | string | null;
|
|
|
|
|
|
|
|
getMetaData: (state: T) => DatasourceMetaData;
|
|
|
|
|
|
|
|
getDatasourceSuggestionsForField: (state: T, field: unknown) => Array<DatasourceSuggestion<T>>;
|
|
|
|
getDatasourceSuggestionsFromCurrentState: (state: T) => Array<DatasourceSuggestion<T>>;
|
|
|
|
|
2019-10-29 17:48:30 +01:00
|
|
|
getPublicAPI: (props: PublicAPIProps<T>) => DatasourcePublicAPI;
|
2019-09-17 20:57:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This is an API provided to visualizations by the frame, which calls the publicAPI on the datasource
|
|
|
|
*/
|
|
|
|
export interface DatasourcePublicAPI {
|
|
|
|
getTableSpec: () => TableSpec;
|
|
|
|
getOperationForColumnId: (columnId: string) => Operation | null;
|
|
|
|
|
|
|
|
// Render can be called many times
|
|
|
|
renderDimensionPanel: (domElement: Element, props: DatasourceDimensionPanelProps) => void;
|
|
|
|
renderLayerPanel: (domElement: Element, props: DatasourceLayerPanelProps) => void;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface TableSpecColumn {
|
|
|
|
// Column IDs are the keys for internal state in data sources and visualizations
|
|
|
|
columnId: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
// TableSpec is managed by visualizations
|
|
|
|
export type TableSpec = TableSpecColumn[];
|
|
|
|
|
|
|
|
export interface DatasourceDataPanelProps<T = unknown> {
|
|
|
|
state: T;
|
|
|
|
dragDropContext: DragContextState;
|
|
|
|
setState: StateSetter<T>;
|
|
|
|
core: Pick<CoreSetup, 'http' | 'notifications' | 'uiSettings'>;
|
|
|
|
query: Query;
|
2019-10-29 17:48:30 +01:00
|
|
|
dateRange: DateRange;
|
2020-02-12 12:22:06 +01:00
|
|
|
filters: Filter[];
|
2019-09-17 20:57:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// The only way a visualization has to restrict the query building
|
|
|
|
export interface DatasourceDimensionPanelProps {
|
|
|
|
layerId: string;
|
|
|
|
columnId: string;
|
|
|
|
|
|
|
|
dragDropContext: DragContextState;
|
|
|
|
|
|
|
|
// Visualizations can restrict operations based on their own rules
|
|
|
|
filterOperations: (operation: OperationMetadata) => boolean;
|
|
|
|
|
|
|
|
// Visualizations can hint at the role this dimension would play, which
|
|
|
|
// affects the default ordering of the query
|
|
|
|
suggestedPriority?: DimensionPriority;
|
|
|
|
onRemove?: (accessor: string) => void;
|
2019-10-16 06:42:58 +02:00
|
|
|
|
|
|
|
// Some dimension editors will allow users to change the operation grouping
|
|
|
|
// from the panel, and this lets the visualization hint that it doesn't want
|
|
|
|
// users to have that level of control
|
|
|
|
hideGrouping?: boolean;
|
2019-09-17 20:57:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface DatasourceLayerPanelProps {
|
|
|
|
layerId: string;
|
|
|
|
}
|
|
|
|
|
2019-10-29 21:36:45 +01:00
|
|
|
export type DataType = 'document' | 'string' | 'number' | 'date' | 'boolean' | 'ip';
|
2019-09-17 20:57:53 +02:00
|
|
|
|
|
|
|
// An operation represents a column in a table, not any information
|
|
|
|
// about how the column was created such as whether it is a sum or average.
|
|
|
|
// Visualizations are able to filter based on the output, not based on the
|
|
|
|
// underlying data
|
|
|
|
export interface Operation extends OperationMetadata {
|
|
|
|
// User-facing label for the operation
|
|
|
|
label: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface OperationMetadata {
|
|
|
|
// The output of this operation will have this data type
|
|
|
|
dataType: DataType;
|
|
|
|
// A bucketed operation is grouped by duplicate values, otherwise each row is
|
|
|
|
// treated as unique
|
|
|
|
isBucketed: boolean;
|
|
|
|
scale?: 'ordinal' | 'interval' | 'ratio';
|
|
|
|
// Extra meta-information like cardinality, color
|
|
|
|
// TODO currently it's not possible to differentiate between a field from a raw
|
|
|
|
// document and an aggregated metric which might be handy in some cases. Once we
|
|
|
|
// introduce a raw document datasource, this should be considered here.
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface LensMultiTable {
|
|
|
|
type: 'lens_multitable';
|
|
|
|
tables: Record<string, KibanaDatatable>;
|
2019-10-16 00:14:40 +02:00
|
|
|
dateRange?: {
|
|
|
|
fromDate: Date;
|
|
|
|
toDate: Date;
|
|
|
|
};
|
2019-09-17 20:57:53 +02:00
|
|
|
}
|
|
|
|
|
2020-01-14 18:06:51 +01:00
|
|
|
export interface VisualizationLayerConfigProps<T = unknown> {
|
|
|
|
layerId: string;
|
2019-09-17 20:57:53 +02:00
|
|
|
dragDropContext: DragContextState;
|
|
|
|
frame: FramePublicAPI;
|
|
|
|
state: T;
|
|
|
|
setState: (newState: T) => void;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Object passed to `getSuggestions` of a visualization.
|
|
|
|
* It contains a possible table the current datasource could
|
|
|
|
* provide and the state of the visualization if it is currently active.
|
|
|
|
*
|
|
|
|
* If the current datasource suggests multiple tables, `getSuggestions`
|
|
|
|
* is called multiple times with separate `SuggestionRequest` objects.
|
|
|
|
*/
|
|
|
|
export interface SuggestionRequest<T = unknown> {
|
|
|
|
/**
|
|
|
|
* A table configuration the datasource could provide.
|
|
|
|
*/
|
|
|
|
table: TableSuggestion;
|
|
|
|
/**
|
|
|
|
* State is only passed if the visualization is active.
|
|
|
|
*/
|
|
|
|
state?: T;
|
2019-10-30 00:05:03 +01:00
|
|
|
/**
|
|
|
|
* The visualization needs to know which table is being suggested
|
|
|
|
*/
|
|
|
|
keptLayerIds: string[];
|
2019-09-17 20:57:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A possible configuration of a given visualization. It is based on a `TableSuggestion`.
|
|
|
|
* Suggestion might be shown in the UI to be chosen by the user directly, but they are
|
|
|
|
* also applied directly under some circumstances (dragging in the first field from the data
|
|
|
|
* panel or switching to another visualization in the chart switcher).
|
|
|
|
*/
|
|
|
|
export interface VisualizationSuggestion<T = unknown> {
|
|
|
|
/**
|
|
|
|
* The score of a suggestion should indicate how valuable the suggestion is. It is used
|
|
|
|
* to rank multiple suggestions of multiple visualizations. The number should be between 0 and 1
|
|
|
|
*/
|
|
|
|
score: number;
|
|
|
|
/**
|
|
|
|
* Flag indicating whether this suggestion should not be advertised to the user. It is still
|
|
|
|
* considered in scenarios where the available suggestion with the highest suggestion is applied
|
|
|
|
* directly.
|
|
|
|
*/
|
|
|
|
hide?: boolean;
|
|
|
|
/**
|
|
|
|
* Descriptive title of the suggestion. Should be as short as possible. This title is shown if
|
|
|
|
* the suggestion is advertised to the user and will also show either the `previewExpression` or
|
|
|
|
* the `previewIcon`
|
|
|
|
*/
|
|
|
|
title: string;
|
|
|
|
/**
|
|
|
|
* The new state of the visualization if this suggestion is applied.
|
|
|
|
*/
|
|
|
|
state: T;
|
|
|
|
/**
|
|
|
|
* An EUI icon type shown instead of the preview expression.
|
|
|
|
*/
|
2019-10-03 19:30:33 +02:00
|
|
|
previewIcon: IconType;
|
2019-09-17 20:57:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface FramePublicAPI {
|
|
|
|
datasourceLayers: Record<string, DatasourcePublicAPI>;
|
2019-10-03 17:24:45 +02:00
|
|
|
|
2019-10-29 17:48:30 +01:00
|
|
|
dateRange: DateRange;
|
2019-09-17 20:57:53 +02:00
|
|
|
query: Query;
|
2020-02-12 12:22:06 +01:00
|
|
|
filters: Filter[];
|
2019-09-17 20:57:53 +02:00
|
|
|
|
|
|
|
// Adds a new layer. This has a side effect of updating the datasource state
|
|
|
|
addNewLayer: () => string;
|
|
|
|
removeLayers: (layerIds: string[]) => void;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface VisualizationType {
|
|
|
|
id: string;
|
2019-10-03 19:30:33 +02:00
|
|
|
icon?: IconType;
|
|
|
|
largeIcon?: IconType;
|
2019-09-17 20:57:53 +02:00
|
|
|
label: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface Visualization<T = unknown, P = unknown> {
|
|
|
|
id: string;
|
|
|
|
|
|
|
|
visualizationTypes: VisualizationType[];
|
|
|
|
|
2020-01-14 18:06:51 +01:00
|
|
|
getLayerIds: (state: T) => string[];
|
|
|
|
|
|
|
|
clearLayer: (state: T, layerId: string) => T;
|
|
|
|
|
|
|
|
removeLayer?: (state: T, layerId: string) => T;
|
|
|
|
|
|
|
|
appendLayer?: (state: T, layerId: string) => T;
|
|
|
|
|
|
|
|
getLayerContextMenuIcon?: (opts: { state: T; layerId: string }) => IconType | undefined;
|
|
|
|
|
|
|
|
renderLayerContextMenu?: (domElement: Element, props: VisualizationLayerConfigProps<T>) => void;
|
|
|
|
|
2019-09-17 20:57:53 +02:00
|
|
|
getDescription: (
|
|
|
|
state: T
|
|
|
|
) => {
|
2019-10-03 19:30:33 +02:00
|
|
|
icon?: IconType;
|
2019-09-17 20:57:53 +02:00
|
|
|
label: string;
|
|
|
|
};
|
|
|
|
|
|
|
|
switchVisualizationType?: (visualizationTypeId: string, state: T) => T;
|
|
|
|
|
|
|
|
// For initializing from saved object
|
|
|
|
initialize: (frame: FramePublicAPI, state?: P) => T;
|
|
|
|
|
|
|
|
getPersistableState: (state: T) => P;
|
|
|
|
|
2020-01-14 18:06:51 +01:00
|
|
|
renderLayerConfigPanel: (domElement: Element, props: VisualizationLayerConfigProps<T>) => void;
|
2019-09-17 20:57:53 +02:00
|
|
|
|
|
|
|
toExpression: (state: T, frame: FramePublicAPI) => Ast | string | null;
|
|
|
|
|
[Lens] Transient suggestions (#44234)
* [lens] Initial Commit (#35627)
* [visualization editor] Initial Commit
* [lens] Add more complete initial state
* [lens] Fix type issues
* [lens] Remove feature control
* [lens] Bring back feature control and add tests
* [lens] Update plugin structure and naming per comments
* replace any usage by safe casting
* [lens] Respond to review comments
* [lens] Remove unused EditorFrameState type
* [lens] Initial state for IndexPatternDatasource (#36052)
* [lens] Add first tests to indexpattern data source
* Respond to review comments
* Fix type definitions
* [lens] Editor frame initializes datasources and visualizations (#36060)
* [lens] Editor frame initializes datasources and visualizations
* Respond to review comments
* Fix build issues
* Fix state management issue
* [lens][draft] Lens/drag drop (#36268)
Add basic drag / drop component to Lens
* remove local package (#36456)
* [lens] Native renderer (#36165)
* Add nativerenderer component
* Use native renderer in app and editor frame
* [Lens] No explicit any (#36515)
* [Lens] Implement basic editor frame state handling (#36443)
* [lens] Load index patterns and render in data panel (#36463)
* [lens] Editor frame initializes datasources and visualizations
* Respond to review comments
* Fix build issues
* remove local package
* [lens] Load index patterns into data source
* Redo types for Index Pattern Datasource
* Fix one more type
* Respond to review comments
* [draft] Lens/line chart renderer (#36827)
Expression logic for the Lens xy chart.
* [lens] Index pattern data panel (initial) (#37015)
* [lens] Index pattern switcher
* Respond to review comments
* [Lens] Editor state 2 (#36513)
* [lens] Dimension panel that generates columns (#37117)
* [lens] Dimension panel that generates columns
* Update from review comments
* [lens] Generate esdocs queries from index pattern (#37361)
* [lens] Generate esdocs queries from index pattern
* Remove unused code
* Update yarn.lock from yarn kbn bootstrap
* [Lens] Add basic Lens xy chart suggestions (#37030)
Basic xy chart suggestions
* [Lens] Expression rendering (#37648)
* [Lens] Expression handling (#37876)
* [Lens] Lens/xy config panel (#37391)
Basic xy chart configuration panel
* [Lens] Xy expression building (#37967)
* [Lens] Initialize visualization with datasource api (#38142)
* [lens] Dimension panel lets users select operations and fields individually (#37573)
* [lens] Dimension panel lets users select operations and fields individually
* Split files and add tests
* Fix dimension labeling and add clear button
* Support more aggregations, aggregation nesting, rollups, and clearing
* Fix esaggs expression
* Increase top-level test coverage of dimension panel
* Update from review comments
* [Lens] Rename columns (#38278)
* [Lens] Lens/index pattern drag drop (#37711)
* Basic xy chart suggestions
* Re-apply XY config panel after force merge
* Initial integration of lens drag and drop
* Tweak naming, remove irellevant comment
* Tweaks per Wylie's feedback
* Add xy chart internationalization
Tweak types per Joe's feedback
* Update xy chart i18n implementation
* Fix i18n id
* Add drop tests to the lens index pattern
* improve tests
* [lens] Only allow aggregated dimensions (#38820)
* [lens] Only allow aggregated dimensions
* [lens] Index pattern suggest on drop
* Fully remove value
* Revert "[lens] Index pattern suggest on drop"
This reverts commit 604c6ed68ca394441ddafa662bdfc5f421de300c.
* Fix type errors
* [lens] Suggest on drop (#38848)
* [lens] Index pattern suggest on drop
* Add test for suggestion without date field
* fix merge
* [Lens] Parameter configurations and new dimension config flow (#38863)
* fix eslint failure
* [lens] Fix build by updating saved objects and i18n (#39391)
* [lens] Update location of saved objects code
* Update internatationalization
* Remove added file
* Lens basic metric visualization
* [lens] Fix arguments to esaggs using booleans (#39462)
* [lens] Datatable visualization plugin (#39390)
* [lens] Datatable visualization plugin
* Fix merge issues and add tests
* Update from review
* Fix file locations
* Fix merge issues, localize expression help text
* Add auto-scaling to the lens metric visualization
* Fix unit tests broken by autoscale
* Move autoscale to the new Lens folder
* [lens] Use first suggestion when switching visualizations (#39377)
* [lens] Label each Y axis with its operation label (#39461)
* [lens] Label each Y axis with its operation label
* Remove comment
* Add link to chart issue
* [Lens] Suggestion preview rendering (#39576)
* [Lens] Popover configs (#39565)
* [Lens] Basic layouting (#39587)
* remove datasource public API in suggestions (#39772)
* [Lens] Basic save / load (#39257)
Add basic routing, save, and load to Lens
* [lens] Fix lint error
* [lens] Use node scripts/eslint.js --fix to fix errors
* [lens] Include link to lens from Visualize (#40542)
* [lens] Support stacking in xy visualization (#40546)
* [lens] Support stacking in xy visualization
* Use chart type switcher for stacked and horizontal xy charts
* Clean up remaining isStacked code
* Fix type error
* [Lens] Add xy split series support (#39726)
* Add split series to lens xy chart
* [lens] Lens Filter Ratio (#40196)
* WIP filter ratio
* Fix test issues
* Pass dependencies through plugin like new platform
* Pass props into filter ratio popover editor
* Provide mocks to filter_ratio popover test
* Add another test
* Clean up to prepare for review
* Clean up unnecessary changes
* Respond to review comments
* Fix tests
* [Lens] Terms order direction (#39884)
* fix types
* [Lens] Data panel styling and optimizations (#40787)
Style the data panel (mostly Joe Reuter's doing). Optimize a bunch of the Lens stack.
* Add metric preview icon
* Fix metric vis tests
* Fix metric plugin imports
* Use the operation label as the metric title
* [Lens] Optimize dimension panel flow (#41114)
* [Lens] re-introduce no-explicit-any (#41454)
* [Lens] No results marker (#41450)
* [lens] Support layers for visualizing results of multiple queries (#41290)
* [lens] WIP add support for layers
* [lens] WIP switch to nested tables
* Get basic layering to work
* Load multiple tables and render in one chart
* Fix priority ordering
* Reduce quantity of linting errors
* Ensure that new xy layer state has a split column
* Make the "add" y / split the trailing accessor
* Various fixes for datasource public API and implementation
* Unify datasource deletion and accessor removal
* Fix broken scss
* Fix xy visualization TypeScript errors?
* Build basic suggestions
* Restore save/load and fix typescript bugs
* simplify init routine
* fix save tests
* fix persistence tests
* fix state management tests
* Ensure the data table is aligned to the top
* Add layer support to Lens datatable
* Give xy chart a default layer initially
* Allow deletion of layers in xy charts
* xy: Make split accessor singular
Remove commented code blocks
* Change expression type for lens_merge_tables
* Fix XY chart rendering expression
* Fix type errors relating to `layerId` in table suggestions
* Pass around tables for suggestions with associated layerIds
* fix tests in workspace panel
* fix editor_frame tests
* Fix xy tests, skip inapplicable tests
that will be implemented in a separate PR
* add some tests for multiple datasources and layers
* Suggest that split series comes before X axis in XY chart
* Get datatable suggestion working
* Adjust how xy axis labels are computed
* Datasource suggestions should handle layers and have tests
* Fix linting in XY chart and remove commented code
* Update snapshots from earlier change
* Fix linting errors
* More cleanup
* Remove commented code
* Test the multi-column editor
* XY Visualization does not need to track datasourceId
* Fix various comments
* Remove unused xy prop
Add datasource header to datatable config
* Use operation labels for XY chart
* Adding and removing layers is reflected in the datasource
* rewrote datasource state init
* clean up editor_frame frame api implementation
* clean up editor frame
* [Lens] Embeddable (#41361)
* [lens] Move XY chart config into popover and fix layering (#41927)
* [lens] Move XY chart config into popover and fix layering
* Fix tests
* Update style
* Change wrapping of layer settings popover
* [Lens] Fix bugs in date_histogram and filter ratio (#42046)
* [Lens] Performance improvements (#41784)
* fix type error
* switch default size of terms operation to 3 (#42334)
* [lens] Improve suggestions for split series (#42052)
* [lens] Add chart switcher (#42093)
* solve merge conflicts
* fix test case
* [Lens] Allow only current visualization on field drop in workspace (#42344)
* [Lens] Remove indexpattern id on column (#42429)
* [lens] Implement app-level filtering and time picker (#42031)
* [lens] Implement app-level filtering and time picker
* More integration with filter bar
* Clean up test code and type errors
* Add frame level tests for syncing with app
* Add test coverage for app logic
* Simplify state management from app down
* Fix import errors
* Clarify whether properties are ids or titles for index pattern
* pass new saved object by ref
* add dirty state checking
* Fix tests
* [Lens] Add some tests around document handling in dimension panel (#42670)
* [Lens] Terms operation boolean support (#42817)
* [lens] Minor UX/UI improvements in Lens (#42852)
* Make dimension popover toggle when clicking button
* Without suggestions hide suggestion panel
* Add missing translations (#42921)
* [Lens] Config panel design (#42980)
* Fix up design of config panel
Does not include config popover
* Add metric suggestions, fix tests
* Remove a couple of non-null assertions (#43013)
* Remove a couple of non-null assertions
* Remove orphaned import
* [Lens] Switch indexpattern manually (#42599)
* [Lens] Update frame to put suggestions at the bottom (#42997)
* Back out suggestion changes, in lieu
of Joe's work
* fix type errors
* switch indexpattern on layer if there is only a single empty one (#43079)
* [Lens] Suggest reduced versions of current data table (#42537)
* [Lens] Field formatter support (#38874)
* Fix bugs
* Fix metric autoscale logic
* Register metric as an embeddable
* Fix metric autoscale flicker
* Render mini metric in suggestions panel
* Cache the metric filterOperations function
* fix auto scaling edge cases
* [Lens] Add bucket nesting editor to indexpattern (#42869)
* Modify auto-scale to handle resize events
* use format hints in metric vis
* start cleaning up suggestions
* [Lens] Remove unnecessary fields and indexing from mappings (#43285)
* Tweak metric to only scale down so far, and
scale both the number and the label.
* Fix lens metric tests
* [Lens] Xy scale type (#42142)
* start adding more suggestions
* remove unused imports
* work on suggestions
* work more on suggestions
* work more on suggestions
* work more on suggestions
* [lens] Allow updater function to be used for updating state (#43373)
* [Lens] Lens metric visualization (#39364)
* clean up tests and add new ones
* remove isMetric
* area as default on time dimension
* fix bug in area chart for time
* Fix axis rotation (#43792)
* remove title form layer
* [Lens] Auto date histogram (#43775)
* Add auto date histogram
* Improve documentation and cleanup
* Add tests
* Change test name
* handle state in app
* fix isMetric usages
* fix integration tests
* fix type errors
* fix date handling on submit
* add new suggestion types
* fix test
* do not suggest single tables
* remove unused import
* [Lens] Fix query bar integration (#43865)
* switch order of appending new string column
* resolve merge conflicts
* [Lens] Clean up operations code (#43784)
* fix merge conflicts
* poc implementation
* highlight currently active suggestion and provide button to submit current choice
* [Lens] Functional tests (#44279)
Foundational layer for lens functional tests. Lens-specific page objects are not in this PR.
* [Lens] Add Lens visualizations to Visualize list (#43398)
* [Lens] Suggestion improvements (#43688)
* fix bugs
* [lens] Calculate existence of fields in datasource (#44422)
* [lens] Calculate existence of fields in datasource
* Fix route registration
* Add page object and use existence in functional test
* Simplify layout of filters for index pattern
* Respond to review feedback
* Update class names
* Use new URL constant
* Fix usage of base path
* Fix lint errors
* [Lens ] Preview metric (#43755)
* format filter ratio as percentage (#44625)
* [Lens] Remove datasource suggestion id (#44495)
* [Lens] Make breadcrumbs look and feel like Visualize (#44258)
* [lens] Fix breakage from app-arch movements (#44720)
* Design cleanup
* PR review comments
* fix tests
* small cleanup
* remove unused import
* [lens] Fix type error in test from merge
* [lens] Fix registration of embeddable (#45171)
* keep references stable if table is just extended and add tests
* changed label for stack/unstack
* fix test
* [Lens] Functional tests (#44814)
Basic functional tests for Lens, by no means comprehensive. This is more of a smokescreen test of some normal use cases.
* [lens] Add Lens to CODEOWNERS (#45296)
* [lens] Fix visualization alias registration
* [lens] Fix usage of EUI after typescript upgrade (#45404)
* [lens] Fix usage of EUI after typescript upgrade
* Use local fix instead of workaround
* fix bug and address reviews
* Fix frame tests
2019-09-19 00:28:26 +02:00
|
|
|
/**
|
|
|
|
* Epression to render a preview version of the chart in very constraint space.
|
|
|
|
* If there is no expression provided, the preview icon is used.
|
|
|
|
*/
|
|
|
|
toPreviewExpression?: (state: T, frame: FramePublicAPI) => Ast | string | null;
|
|
|
|
|
2019-09-17 20:57:53 +02:00
|
|
|
// The frame will call this function on all visualizations when the table changes, or when
|
|
|
|
// rendering additional ways of using the data
|
|
|
|
getSuggestions: (context: SuggestionRequest<T>) => Array<VisualizationSuggestion<T>>;
|
|
|
|
}
|