Skip to content

Commit

Permalink
feat: Create insight graphs directly in Notebooks (#17404)
Browse files Browse the repository at this point in the history
  • Loading branch information
benjackwhite authored Sep 13, 2023
1 parent e2a3bcf commit da52981
Show file tree
Hide file tree
Showing 3 changed files with 190 additions and 3 deletions.
6 changes: 6 additions & 0 deletions frontend/src/scenes/notebooks/Nodes/NotebookNodeQuery.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -123,6 +123,12 @@ export const NotebookNodeQuery = createPostHogWidgetNode<NotebookNodeQueryAttrib
} else {
title = 'Data exploration'
}
} else if (NodeKind.InsightVizNode === query.kind) {
if (query.source.kind) {
title = query.source.kind.replace('Node', '').replace('Query', '')
} else {
title = 'Insight'
}
}
return Promise.resolve(title)
},
Expand Down
2 changes: 1 addition & 1 deletion frontend/src/scenes/notebooks/Notebook/Notebook.scss
Original file line number Diff line number Diff line change
Expand Up @@ -145,7 +145,7 @@

&__content {
max-height: calc(100vh - 220px);
overflow: scroll;
overflow: auto;
}
}

Expand Down
185 changes: 183 additions & 2 deletions frontend/src/scenes/notebooks/Notebook/SlashCommands.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,19 @@ import Suggestion from '@tiptap/suggestion'

import { ReactRenderer } from '@tiptap/react'
import { LemonButton, LemonDivider, lemonToast } from '@posthog/lemon-ui'
import { IconCohort, IconQueryEditor, IconRecording, IconTableChart, IconUploadFile } from 'lib/lemon-ui/icons'
import {
IconCohort,
IconRecording,
IconTableChart,
IconUploadFile,
InsightSQLIcon,
InsightsFunnelsIcon,
InsightsLifecycleIcon,
InsightsPathsIcon,
InsightsRetentionIcon,
InsightsStickinessIcon,
InsightsTrendsIcon,
} from 'lib/lemon-ui/icons'
import { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useState } from 'react'
import { EditorCommands, EditorRange } from './utils'
import { NotebookNodeType } from '~/types'
Expand Down Expand Up @@ -57,10 +69,179 @@ const TEXT_CONTROLS: SlashCommandsItem[] = [
]

const SLASH_COMMANDS: SlashCommandsItem[] = [
{
title: 'Trend',
search: 'trend insight',
icon: <InsightsTrendsIcon noBackground color="currentColor" />,
command: (chain) =>
chain.insertContent({
type: NotebookNodeType.Query,
attrs: {
query: {
kind: 'InsightVizNode',
source: {
kind: 'TrendsQuery',
filterTestAccounts: false,
series: [
{
kind: 'EventsNode',
event: '$pageview',
name: '$pageview',
math: 'total',
},
],
interval: 'day',
trendsFilter: {
display: 'ActionsLineGraph',
},
},
},
},
}),
},
{
title: 'Funnel',
search: 'funnel insight',
icon: <InsightsFunnelsIcon noBackground color="currentColor" />,
command: (chain) =>
chain.insertContent({
type: NotebookNodeType.Query,
attrs: {
query: {
kind: 'InsightVizNode',
source: {
kind: 'FunnelsQuery',
series: [
{
kind: 'EventsNode',
name: '$pageview',
event: '$pageview',
},
{
kind: 'EventsNode',
name: '$pageview',
event: '$pageview',
},
],
funnelsFilter: {
funnel_viz_type: 'steps',
},
},
},
},
}),
},
{
title: 'Retention',
search: 'retention insight',
icon: <InsightsRetentionIcon noBackground color="currentColor" />,
command: (chain) =>
chain.insertContent({
type: NotebookNodeType.Query,
attrs: {
query: {
kind: 'InsightVizNode',
source: {
kind: 'RetentionQuery',
retentionFilter: {
period: 'Day',
total_intervals: 11,
target_entity: {
id: '$pageview',
name: '$pageview',
type: 'events',
},
returning_entity: {
id: '$pageview',
name: '$pageview',
type: 'events',
},
retention_type: 'retention_first_time',
},
},
},
},
}),
},
{
title: 'Paths',
search: 'paths insight',
icon: <InsightsPathsIcon noBackground color="currentColor" />,
command: (chain) =>
chain.insertContent({
type: NotebookNodeType.Query,
attrs: {
query: {
kind: 'InsightVizNode',
source: {
kind: 'PathsQuery',
pathsFilter: {
include_event_types: ['$pageview'],
},
},
},
},
}),
},
{
title: 'Stickiness',
search: 'stickiness insight',
icon: <InsightsStickinessIcon noBackground color="currentColor" />,
command: (chain) =>
chain.insertContent({
type: NotebookNodeType.Query,
attrs: {
query: {
kind: 'InsightVizNode',
source: {
kind: 'StickinessQuery',
series: [
{
kind: 'EventsNode',
name: '$pageview',
event: '$pageview',
math: 'total',
},
],
stickinessFilter: {},
},
},
},
}),
},
{
title: 'Lifecycle',
search: 'lifecycle insight',
icon: <InsightsLifecycleIcon noBackground color="currentColor" />,
command: (chain) =>
chain.insertContent({
type: NotebookNodeType.Query,
attrs: {
query: {
kind: 'InsightVizNode',
source: {
kind: 'LifecycleQuery',
series: [
{
kind: 'EventsNode',
name: '$pageview',
event: '$pageview',
math: 'total',
},
],
lifecycleFilter: {
shown_as: 'Lifecycle',
},
},
full: true,
},
},
}),
},
{
title: 'HogQL',
search: 'sql',
icon: <IconQueryEditor />,
icon: <InsightSQLIcon noBackground color="currentColor" />,
command: (chain) =>
chain.insertContent({ type: NotebookNodeType.Query, attrs: { query: examples['HogQLTable'] } }),
},
Expand Down

0 comments on commit da52981

Please sign in to comment.