-
Notifications
You must be signed in to change notification settings - Fork 8.3k
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
[Embeddables Rebuild] Migrate Visualize #183197
Changes from 234 commits
98ef1fd
7d2c26f
2ca806b
1d86a45
806a98c
a9633f4
9c7377a
d08e1f7
48e51e6
8afa840
d655091
f87d0ac
6910163
e39ca14
0fa4d8f
4add2da
1ca2ce3
6b6e8ec
a590306
b9cc3a4
3708ab0
347f066
5501a96
8b5bfe9
c1d56e3
3587f7c
db5c257
6c915cc
eae8f8d
8a8c375
818f433
1997b37
d4a3fec
6a57013
b3b5e22
7d1d93b
027bd97
8ab5b31
36ebfb1
0720581
5eee91d
10da106
108003e
5473d35
76cdc32
160e34d
2603dd7
dee7dde
0e80a0a
300686f
3a9aa48
aac4b63
57e2c57
cf772ea
1921e9d
714987c
06e4aa5
fe39bd4
c377731
b42a21b
46567d2
986c432
6cd153e
d52b1a6
e3840c1
13f85f7
95eed5e
270b560
149443d
c2d4582
aaa078c
8e1cd68
eb41aa2
7f4f55f
dd49ca4
7ab95f3
ec52b76
7a0bf7e
20562a1
9444ebe
19cc33e
7a14da7
9fb5586
3fd9d67
afdd40a
ed65afe
b087b94
aa9f9d2
feae461
6f67794
c998350
5078d5b
6c71992
ca17fb4
7a83962
7cecf04
730a602
fd37567
55d61ea
88c9679
c50fa14
99c1c09
4c28c43
107ea3e
b07454a
78b2968
4604cf8
7112b8d
1159f06
6b4b45c
ad5d4cc
4c4fe34
a851d7d
aa85125
249d088
6443d14
8446bc0
aa61d4b
4a0e3b6
87d4db5
b7825cd
faabc35
f246104
98d070b
d804991
deaffdd
3678bb5
8fe79a3
07c702d
9e8808a
a671353
d03cd46
b1bd42b
2d8df0b
bc3920d
fe312f4
100cd7c
defa900
97d2199
337b7d4
362a544
476cca9
4594c83
2bc47d0
7cbb415
40636fe
36faec7
f6ecba6
4c9775f
4852cd9
2decc19
4222f35
1c76810
4790a72
6671dc4
39d5532
c7c0b2e
334d6d0
49f8a6a
79720c8
fb18006
18c94dd
4617626
31bed0a
9295992
e68fe77
eabfcdc
117b983
51765ce
c532778
be1f6e8
88df0ab
bd35717
446afb6
fa5a295
975c5ed
7d7789c
a05cb41
722dc35
1bb1c29
a59642e
60e2b68
510796e
54b89ba
4bf09da
c1136be
8fd77a0
d642aff
75fdbeb
eb79469
f4d4df0
eb7789e
19e8786
d8e66ad
b643f94
0ce26fe
38874c0
bd3fd14
3d5b8c4
0e46782
2662dcf
3d29ae2
7830ff6
0ca480f
dd2fc2c
5c145b0
05936a5
f7de7e7
ea32301
a0da8fb
7ffbea5
69990c8
ad8eab0
0d54a90
0fef75e
5e9b594
b4cb319
63c6b14
0d9a723
465e97f
813d8ca
ee65895
71476ee
990185e
08861d8
7a0a88e
5ac4c77
0a2f67c
7728b34
a6603b6
b8b9550
d09c0d8
656120a
4be626d
d701179
b02a3ba
7003cf3
924d105
af5012d
f1ff79d
48e9897
bbf95fb
2f8f46f
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -69,6 +69,8 @@ import { | |
ContentManagementPublicStart, | ||
} from '@kbn/content-management-plugin/public'; | ||
import type { NoDataPagePluginStart } from '@kbn/no-data-page-plugin/public'; | ||
import { EmbeddableEnhancedPluginStart } from '@kbn/embeddable-enhanced-plugin/public'; | ||
|
||
import type { TypesSetup, TypesStart } from './vis_types'; | ||
import type { VisualizeServices } from './visualize_app/types'; | ||
import { | ||
|
@@ -83,11 +85,7 @@ import { xyDimension as xyDimensionExpressionFunction } from '../common/expressi | |
import { visDimension as visDimensionExpressionFunction } from '../common/expression_functions/vis_dimension'; | ||
import { range as rangeExpressionFunction } from '../common/expression_functions/range'; | ||
import { TypesService } from './vis_types/types_service'; | ||
import { | ||
createVisEmbeddableFromObject, | ||
VISUALIZE_EMBEDDABLE_TYPE, | ||
VisualizeEmbeddableFactory, | ||
} from './embeddable'; | ||
import { createVisEmbeddableFromObject } from './embeddable'; | ||
import { | ||
setUISettings, | ||
setTypes, | ||
|
@@ -115,18 +113,21 @@ import { | |
setSavedObjectsManagement, | ||
setContentManagement, | ||
setSavedSearch, | ||
setDataViews, | ||
setInspector, | ||
getTypes, | ||
} from './services'; | ||
import { VisualizeConstants } from '../common/constants'; | ||
import { VisualizeConstants, VISUALIZE_EMBEDDABLE_TYPE } from '../common/constants'; | ||
import { EditInLensAction } from './actions/edit_in_lens_action'; | ||
import { ListingViewRegistry, SerializedVis } from './types'; | ||
import { ListingViewRegistry } from './types'; | ||
import { | ||
LATEST_VERSION, | ||
CONTENT_ID, | ||
VisualizationSavedObjectAttributes, | ||
} from '../common/content_management'; | ||
import { SerializedVisData } from '../common'; | ||
import { VisualizeByValueInput } from './embeddable/visualize_embeddable'; | ||
import { AddAggVisualizationPanelAction } from './actions/add_agg_vis_action'; | ||
import { VisualizeRuntimeState } from './react_embeddable/types'; | ||
import { savedObjectToRuntimeState } from './react_embeddable/state'; | ||
|
||
/** | ||
* Interface for this plugin's returned setup/start contracts. | ||
|
@@ -163,7 +164,6 @@ export interface VisualizationsStartDeps { | |
inspector: InspectorStart; | ||
uiActions: UiActionsStart; | ||
application: ApplicationStart; | ||
getAttributeService: EmbeddableStart['getAttributeService']; | ||
navigation: NavigationStart; | ||
presentationUtil: PresentationUtilPluginStart; | ||
savedObjects: SavedObjectsStart; | ||
|
@@ -181,6 +181,7 @@ export interface VisualizationsStartDeps { | |
contentManagement: ContentManagementPublicStart; | ||
serverless?: ServerlessPluginStart; | ||
noDataPage?: NoDataPagePluginStart; | ||
embeddableEnhanced?: EmbeddableEnhancedPluginStart; | ||
} | ||
|
||
/** | ||
|
@@ -400,8 +401,31 @@ export class VisualizationsPlugin | |
uiActions.registerTrigger(dashboardVisualizationPanelTrigger); | ||
const editInLensAction = new EditInLensAction(data.query.timefilter.timefilter); | ||
uiActions.addTriggerAction(CONTEXT_MENU_TRIGGER, editInLensAction); | ||
const embeddableFactory = new VisualizeEmbeddableFactory({ start }); | ||
embeddable.registerEmbeddableFactory(VISUALIZE_EMBEDDABLE_TYPE, embeddableFactory); | ||
embeddable.registerReactEmbeddableFactory(VISUALIZE_EMBEDDABLE_TYPE, async () => { | ||
const { | ||
plugins: { embeddable: embeddableStart, embeddableEnhanced: embeddableEnhancedStart }, | ||
} = start(); | ||
|
||
const { getVisualizeEmbeddableFactory } = await import('./react_embeddable'); | ||
return getVisualizeEmbeddableFactory({ embeddableStart, embeddableEnhancedStart }); | ||
}); | ||
embeddable.registerReactEmbeddableSavedObject<VisualizationSavedObjectAttributes>({ | ||
onAdd: (container, savedObject) => { | ||
container.addNewPanel<VisualizeRuntimeState>({ | ||
panelType: VISUALIZE_EMBEDDABLE_TYPE, | ||
initialState: savedObjectToRuntimeState(savedObject), | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Shouldn't The reason I ask is that this PR adds 10KB to the page load size and am trying to track down all possible increases. It would be great if we could avoid importing There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Just tested it and the following works.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. At one point this was necessary after a merge with |
||
}); | ||
}, | ||
embeddableType: VISUALIZE_EMBEDDABLE_TYPE, | ||
savedObjectType: VISUALIZE_EMBEDDABLE_TYPE, | ||
savedObjectName: i18n.translate('visualizations.visualizeSavedObjectName', { | ||
defaultMessage: 'Visualization', | ||
}), | ||
getIconForSavedObject: (savedObject) => { | ||
const visState = JSON.parse(savedObject.attributes.visState ?? '{}'); | ||
return getTypes().get(visState.type)?.icon ?? ''; | ||
}, | ||
}); | ||
|
||
contentManagement.registry.register({ | ||
id: CONTENT_ID, | ||
|
@@ -411,37 +435,6 @@ export class VisualizationsPlugin | |
name: 'Visualize Library', | ||
}); | ||
|
||
embeddable.registerSavedObjectToPanelMethod< | ||
VisualizationSavedObjectAttributes, | ||
VisualizeByValueInput | ||
>(CONTENT_ID, (savedObject) => { | ||
const visState = savedObject.attributes.visState; | ||
|
||
// not sure if visState actually is ever undefined, but following the type | ||
if (!savedObject.managed || !visState) { | ||
return { | ||
savedObjectId: savedObject.id, | ||
}; | ||
} | ||
|
||
// data is not always defined, so I added a default value since the extract | ||
// routine in the embeddable factory expects it to be there | ||
const savedVis = JSON.parse(visState) as Omit<SerializedVis, 'data'> & { | ||
data?: SerializedVisData; | ||
}; | ||
|
||
if (!savedVis.data) { | ||
savedVis.data = { | ||
searchSource: {}, | ||
aggs: [], | ||
}; | ||
} | ||
|
||
return { | ||
savedVis: savedVis as SerializedVis, // now we're sure we have "data" prop | ||
}; | ||
}); | ||
|
||
return { | ||
...this.types.setup(), | ||
visEditorsRegistry, | ||
|
@@ -456,14 +449,15 @@ export class VisualizationsPlugin | |
expressions, | ||
uiActions, | ||
embeddable, | ||
savedObjects, | ||
spaces, | ||
savedObjectsTaggingOss, | ||
fieldFormats, | ||
usageCollection, | ||
savedObjectsManagement, | ||
contentManagement, | ||
savedSearch, | ||
dataViews, | ||
inspector, | ||
}: VisualizationsStartDeps | ||
): VisualizationsStart { | ||
const types = this.types.start(); | ||
|
@@ -488,6 +482,8 @@ export class VisualizationsPlugin | |
setSavedObjectsManagement(savedObjectsManagement); | ||
setContentManagement(contentManagement); | ||
setSavedSearch(savedSearch); | ||
setDataViews(dataViews); | ||
setInspector(inspector); | ||
|
||
if (spaces) { | ||
setSpaces(spaces); | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
/* | ||
* 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 { SerializedVis } from '../vis'; | ||
import { createVisAsync } from '../vis_async'; | ||
import { getSavedSearch } from '../services'; | ||
|
||
export const createVisInstance = async (serializedVis: SerializedVis) => { | ||
const vis = await createVisAsync(serializedVis.type, serializedVis); | ||
if (serializedVis.data.savedSearchId) { | ||
const savedSearch = await getSavedSearch().get(serializedVis.data.savedSearchId); | ||
const indexPattern = savedSearch.searchSource.getField('index'); | ||
if (indexPattern) { | ||
vis.data.indexPattern = indexPattern; | ||
vis.data.searchSource?.setField('index', indexPattern); | ||
} | ||
} | ||
return vis; | ||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you async import
createVisEmbeddableFromObject
where its used inmount
callback?