-
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
[Lens] Track actions in the UI by time #47919
Changes from 18 commits
a832b1e
8c818e4
5281cbd
bf26faa
5c7fdb7
e8e2b70
1fcce38
8a2dce4
c4c5639
e9590e8
bbe16fa
b75ca97
863f329
7dc94b8
2a60204
6c24d16
f1a1399
fd1f6d6
2a28500
16ebf6c
4da50b3
b5d54a7
5ef055f
1836ed1
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 |
---|---|---|
|
@@ -25,6 +25,7 @@ import { KibanaContextProvider } from '../../../../../../src/plugins/kibana_reac | |
import { Document, SavedObjectStore } from '../persistence'; | ||
import { EditorFrameInstance } from '../types'; | ||
import { NativeRenderer } from '../native_renderer'; | ||
import { trackUiEvent } from '../lens_ui_telemetry'; | ||
|
||
interface State { | ||
isLoading: boolean; | ||
|
@@ -84,6 +85,8 @@ export function App({ | |
const subscription = dataShim.filter.filterManager.getUpdates$().subscribe({ | ||
next: () => { | ||
setState(s => ({ ...s, filters: dataShim.filter.filterManager.getFilters() })); | ||
|
||
trackUiEvent('app_filters_updated'); | ||
}, | ||
}); | ||
return () => { | ||
|
@@ -198,6 +201,7 @@ export function App({ | |
} | ||
}) | ||
.catch(() => { | ||
trackUiEvent('save_failed'); | ||
core.notifications.toasts.addDanger( | ||
i18n.translate('xpack.lens.editorFrame.docSavingError', { | ||
defaultMessage: 'Error saving document', | ||
|
@@ -214,6 +218,16 @@ export function App({ | |
screenTitle={'lens'} | ||
onQuerySubmit={payload => { | ||
const { dateRange, query } = payload; | ||
|
||
if ( | ||
dateRange.from !== state.dateRange.fromDate || | ||
dateRange.to !== state.dateRange.toDate | ||
) { | ||
trackUiEvent('app_date_change'); | ||
} else { | ||
trackUiEvent('app_query_change'); | ||
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. Is this actually interesting? I'm not sure it's worth collecting, as I expect it to be just super noisy. 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. I could combine this with filter changes, but I do think it's interesting |
||
} | ||
|
||
setState(s => ({ | ||
...s, | ||
dateRange: { | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -25,6 +25,12 @@ import { | |
} from '../datatable_visualization_plugin'; | ||
import { App } from './app'; | ||
import { EditorFrameInstance } from '../types'; | ||
import { | ||
LensReportManager, | ||
setReportManager, | ||
stopReportManager, | ||
trackUiEvent, | ||
} from '../lens_ui_telemetry'; | ||
|
||
export interface LensPluginStartDependencies { | ||
data: DataPublicPluginStart; | ||
|
@@ -63,7 +69,16 @@ export class AppPlugin { | |
|
||
this.instance = editorFrameStartInterface.createInstance({}); | ||
|
||
setReportManager( | ||
wylieconlon marked this conversation as resolved.
Show resolved
Hide resolved
|
||
new LensReportManager({ | ||
storage: new Storage(localStorage), | ||
basePath: core.http.basePath.get(), | ||
http: core.http, | ||
}) | ||
); | ||
|
||
const renderEditor = (routeProps: RouteComponentProps<{ id?: string }>) => { | ||
trackUiEvent('loaded'); | ||
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. Is this worth tracking? Maybe. 404 certainly is. 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. If we don't track some kind of |
||
return ( | ||
<App | ||
core={core} | ||
|
@@ -85,6 +100,7 @@ export class AppPlugin { | |
}; | ||
|
||
function NotFound() { | ||
trackUiEvent('loaded_404'); | ||
return <FormattedMessage id="xpack.lens.app404" defaultMessage="404 Not Found" />; | ||
} | ||
|
||
|
@@ -106,6 +122,8 @@ export class AppPlugin { | |
this.instance.unmount(); | ||
} | ||
|
||
stopReportManager(); | ||
|
||
// TODO this will be handled by the plugin platform itself | ||
indexPatternDatasourceStop(); | ||
xyVisualizationStop(); | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,6 +7,7 @@ | |
import React, { useState, useContext } from 'react'; | ||
import classNames from 'classnames'; | ||
import { DragContext } from './providers'; | ||
import { trackUiEvent } from '../lens_ui_telemetry'; | ||
|
||
type DroppableEvent = React.DragEvent<HTMLElement>; | ||
|
||
|
@@ -121,7 +122,8 @@ export function DragDrop(props: Props) { | |
setState({ ...state, isActive: false }); | ||
setDragging(undefined); | ||
|
||
if (onDrop) { | ||
if (onDrop && droppable) { | ||
trackUiEvent('drop_total'); | ||
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. This is probably fine, but if we ever want to make this drag / drop thing more general, this would be something that requires yanking out. |
||
onDrop(dragging); | ||
} | ||
}; | ||
|
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.
I'm unfamiliar with this TypeScript signature. TIL