Skip to content

Commit

Permalink
feat(hogql): debugger split view
Browse files Browse the repository at this point in the history
  • Loading branch information
mariusandra committed Oct 13, 2023
1 parent 3fdef43 commit 42f9ece
Show file tree
Hide file tree
Showing 3 changed files with 78 additions and 42 deletions.
84 changes: 53 additions & 31 deletions frontend/src/scenes/debug/DebugScene.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,45 +10,71 @@ import { LemonButton } from 'lib/lemon-ui/LemonButton'
import { HogQLQuery } from '~/queries/schema'
import { HogQLDebug } from 'scenes/debug/HogQLDebug'

export function DebugScene(): JSX.Element {
const { query } = useValues(debugSceneLogic)
const { setQuery } = useActions(debugSceneLogic)

interface QueryDebugProps {
queryKey: string
query: string
setQuery: (query: string) => void
}
function QueryDebug({ query, setQuery, queryKey }: QueryDebugProps): JSX.Element {
let parsed: Record<string, any> | undefined
try {
parsed = JSON.parse(query)
} catch (e) {
// do nothing
}

const showQueryEditor = !(
parsed &&
parsed.kind == 'DataTableNode' &&
parsed.source.kind == 'HogQLQuery' &&
(parsed.full || parsed.showHogQLEditor)
return (
<>
{parsed && parsed?.kind === 'HogQLQuery' ? (
<HogQLDebug
queryKey={queryKey}
query={parsed as HogQLQuery}
setQuery={(query) => setQuery(JSON.stringify(query, null, 2))}
/>
) : (
<Query
query={query}
setQuery={(query) => setQuery(JSON.stringify(query, null, 2))}
context={{
showQueryEditor:
parsed &&
parsed.kind == 'DataTableNode' &&
parsed.source.kind == 'HogQLQuery' &&
(parsed.full || parsed.showHogQLEditor),
}}
/>
)}
</>
)
}

export function DebugScene(): JSX.Element {
const { query1, query2 } = useValues(debugSceneLogic)
const { setQuery1, setQuery2 } = useActions(debugSceneLogic)

return (
<div className="QueryScene">
<PageHeader
title="Query Debugger"
buttons={
<>
<LemonButton active={!!query2} onClick={() => (query2 ? setQuery2('') : setQuery2(query1))}>
Split
</LemonButton>
<LemonButton
active={query === stringifiedExamples.HogQLRaw}
onClick={() => setQuery(stringifiedExamples.HogQLRaw)}
active={query1 === stringifiedExamples.HogQLRaw}
onClick={() => setQuery1(stringifiedExamples.HogQLRaw)}
>
HogQL Debug
</LemonButton>
<LemonButton
active={query === stringifiedExamples.HogQLTable}
onClick={() => setQuery(stringifiedExamples.HogQLTable)}
active={query1 === stringifiedExamples.HogQLTable}
onClick={() => setQuery1(stringifiedExamples.HogQLTable)}
>
HogQL Table
</LemonButton>
<LemonButton
active={query === stringifiedExamples.Events}
onClick={() => setQuery(stringifiedExamples.Events)}
active={query1 === stringifiedExamples.Events}
onClick={() => setQuery1(stringifiedExamples.Events)}
>
Any Query
</LemonButton>
Expand All @@ -62,28 +88,24 @@ export function DebugScene(): JSX.Element {
})}
onChange={(v) => {
if (v) {
setQuery(v)
setQuery1(v)
}
}}
/>
</LemonLabel>
</>
}
/>
{parsed && parsed?.kind === 'HogQLQuery' ? (
<HogQLDebug
query={parsed as HogQLQuery}
setQuery={(query) => setQuery(JSON.stringify(query, null, 2))}
/>
) : (
<Query
query={query}
setQuery={(query) => setQuery(JSON.stringify(query, null, 2))}
context={{
showQueryEditor: showQueryEditor,
}}
/>
)}
<div className="flex gap-2">
<div className="flex-1 w-1/2">
<QueryDebug query={query1} setQuery={setQuery1} queryKey="hogql-debug-1" />
</div>
{query2 ? (
<div className="flex-1 w-1/2">
<QueryDebug query={query2} setQuery={setQuery2} queryKey="hogql-debug-2" />
</div>
) : null}
</div>
</div>
)
}
Expand Down
5 changes: 3 additions & 2 deletions frontend/src/scenes/debug/HogQLDebug.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,12 @@ import { LemonSelect } from 'lib/lemon-ui/LemonSelect'
import { LemonLabel } from 'lib/lemon-ui/LemonLabel'

interface HogQLDebugProps {
queryKey: string
query: HogQLQuery
setQuery: (query: DataNode) => void
}
export function HogQLDebug({ query, setQuery }: HogQLDebugProps): JSX.Element {
const dataNodeLogicProps: DataNodeLogicProps = { query, key: 'debug-scene' }
export function HogQLDebug({ query, setQuery, queryKey }: HogQLDebugProps): JSX.Element {
const dataNodeLogicProps: DataNodeLogicProps = { query, key: queryKey }
const { dataLoading, response, responseErrorObject, elapsedTime } = useValues(dataNodeLogic(dataNodeLogicProps))
return (
<BindLogic logic={dataNodeLogic} props={dataNodeLogicProps}>
Expand Down
31 changes: 22 additions & 9 deletions frontend/src/scenes/debug/debugSceneLogic.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,20 +10,33 @@ const DEFAULT_QUERY: string = stringifiedExamples['HogQLRaw']
export const debugSceneLogic = kea<debugSceneLogicType>([
path(['scenes', 'query', 'debugSceneLogic']),
actions({
setQuery: (query: string) => ({ query: query }),
setQuery1: (query: string) => ({ query: query }),
setQuery2: (query: string) => ({ query: query }),
}),
reducers({
query: [DEFAULT_QUERY, { setQuery: (_, { query }) => query }],
query1: [DEFAULT_QUERY, { setQuery1: (_, { query }) => query }],
query2: [DEFAULT_QUERY, { setQuery2: (_, { query }) => query }],
}),
actionToUrl({
setQuery: ({ query }) => {
return [urls.debugQuery(), {}, { q: query }, { replace: true }]
actionToUrl(({ values }) => ({
setQuery1: ({ query }) => {
return [
urls.debugQuery(),
{},
{ ...{ q: query }, ...(values.query2 ? { q2: values.query2 } : {}) },
{ replace: true },
]
},
}),
setQuery2: () => {
return [urls.debugQuery(), {}, { q: values.query1, q2: values.query2 }, { replace: true }]
},
})),
urlToAction(({ actions, values }) => ({
[urls.debugQuery()]: (_, __, { q }) => {
if (q && q !== values.query) {
actions.setQuery(q)
[urls.debugQuery()]: (_, __, { q, q2 }) => {
if (q && q !== values.query1) {
actions.setQuery1(q)
}
if ((q2 ?? '') !== (values.query2 ?? '')) {
actions.setQuery2(q2 ?? '')
}
},
})),
Expand Down

0 comments on commit 42f9ece

Please sign in to comment.