@perses-dev/clickhouse-plugin 0.3.0 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/__mf/js/{ClickHouse.8f89cb2c.js → ClickHouse.fef0738b.js} +3 -3
  2. package/__mf/js/async/1398.f2193c83.js +2 -0
  3. package/__mf/js/async/{4421.750852d0.js → 4421.d9d48d4f.js} +1 -1
  4. package/__mf/js/async/4557.aa037aea.js +2 -0
  5. package/__mf/js/async/4676.cae72135.js +22 -0
  6. package/__mf/js/async/58.c1431e49.js +2 -0
  7. package/__mf/js/async/7797.36d938e5.js +1 -0
  8. package/__mf/js/async/{7991.64a1aaaf.js → 7991.11320a4d.js} +2 -2
  9. package/__mf/js/async/__federation_expose_ClickHouseDatasource.b909c7ef.js +2 -0
  10. package/__mf/js/async/__federation_expose_ClickHouseLogQuery.8e9aa83b.js +20 -0
  11. package/__mf/js/async/__federation_expose_ClickHouseTimeSeriesQuery.b3723b8b.js +20 -0
  12. package/__mf/js/{main.3bc5d901.js → main.56f92cce.js} +3 -3
  13. package/lib/cjs/queries/click-house-log-query/ClickHouseLogQueryEditor.js +4 -15
  14. package/lib/cjs/queries/click-house-time-series-query/ClickHouseQueryEditor.js +4 -15
  15. package/lib/queries/click-house-log-query/ClickHouseLogQueryEditor.d.ts.map +1 -1
  16. package/lib/queries/click-house-log-query/ClickHouseLogQueryEditor.js +4 -15
  17. package/lib/queries/click-house-log-query/ClickHouseLogQueryEditor.js.map +1 -1
  18. package/lib/queries/click-house-log-query/log-query-plugin-interface.d.ts +1 -3
  19. package/lib/queries/click-house-log-query/log-query-plugin-interface.d.ts.map +1 -1
  20. package/lib/queries/click-house-log-query/log-query-plugin-interface.js.map +1 -1
  21. package/lib/queries/click-house-time-series-query/ClickHouseQueryEditor.d.ts.map +1 -1
  22. package/lib/queries/click-house-time-series-query/ClickHouseQueryEditor.js +4 -15
  23. package/lib/queries/click-house-time-series-query/ClickHouseQueryEditor.js.map +1 -1
  24. package/mf-manifest.json +25 -25
  25. package/mf-stats.json +25 -25
  26. package/package.json +6 -6
  27. package/__mf/js/async/2178.16cf2da3.js +0 -2
  28. package/__mf/js/async/2472.9f5fd5cf.js +0 -22
  29. package/__mf/js/async/2708.7448dd5c.js +0 -1
  30. package/__mf/js/async/6620.1d8e42fd.js +0 -2
  31. package/__mf/js/async/9563.6903fd59.js +0 -2
  32. package/__mf/js/async/__federation_expose_ClickHouseDatasource.e3722d39.js +0 -2
  33. package/__mf/js/async/__federation_expose_ClickHouseLogQuery.63888cb7.js +0 -20
  34. package/__mf/js/async/__federation_expose_ClickHouseTimeSeriesQuery.6a30813e.js +0 -20
  35. /package/__mf/js/async/{9563.6903fd59.js.LICENSE.txt → 1398.f2193c83.js.LICENSE.txt} +0 -0
  36. /package/__mf/js/async/{2178.16cf2da3.js.LICENSE.txt → 4557.aa037aea.js.LICENSE.txt} +0 -0
  37. /package/__mf/js/async/{2472.9f5fd5cf.js.LICENSE.txt → 4676.cae72135.js.LICENSE.txt} +0 -0
  38. /package/__mf/js/async/{6620.1d8e42fd.js.LICENSE.txt → 58.c1431e49.js.LICENSE.txt} +0 -0
  39. /package/__mf/js/async/{7991.64a1aaaf.js.LICENSE.txt → 7991.11320a4d.js.LICENSE.txt} +0 -0
  40. /package/__mf/js/async/{__federation_expose_ClickHouseDatasource.e3722d39.js.LICENSE.txt → __federation_expose_ClickHouseDatasource.b909c7ef.js.LICENSE.txt} +0 -0
  41. /package/__mf/js/async/{__federation_expose_ClickHouseLogQuery.63888cb7.js.LICENSE.txt → __federation_expose_ClickHouseLogQuery.8e9aa83b.js.LICENSE.txt} +0 -0
  42. /package/__mf/js/async/{__federation_expose_ClickHouseTimeSeriesQuery.6a30813e.js.LICENSE.txt → __federation_expose_ClickHouseTimeSeriesQuery.b3723b8b.js.LICENSE.txt} +0 -0
@@ -24,13 +24,13 @@ const _jsxruntime = require("react/jsx-runtime");
24
24
  const _pluginsystem = require("@perses-dev/plugin-system");
25
25
  const _react = require("react");
26
26
  const _immer = require("immer");
27
+ const _material = require("@mui/material");
27
28
  const _constants = require("../constants");
28
29
  const _components = require("../../components");
29
- const _material = require("@mui/material");
30
30
  const _constants1 = require("../../components/constants");
31
31
  const _queryeditormodel = require("../query-editor-model");
32
32
  function ClickHouseLogQueryEditor(props) {
33
- const { onChange, value, queryHandlerSettings } = props;
33
+ const { onChange, value } = props;
34
34
  const { datasource } = value;
35
35
  const selectedDatasource = datasource ?? _constants.DEFAULT_DATASOURCE;
36
36
  const { query, handleQueryChange, handleQueryBlur } = (0, _queryeditormodel.useQueryState)(props);
@@ -39,31 +39,20 @@ function ClickHouseLogQueryEditor(props) {
39
39
  onChange((0, _immer.produce)(value, (draft)=>{
40
40
  draft.datasource = newDatasourceSelection;
41
41
  }));
42
- if (queryHandlerSettings?.setWatchOtherSpecs) queryHandlerSettings.setWatchOtherSpecs({
43
- ...value,
44
- datasource: newDatasourceSelection
45
- });
46
42
  return;
47
43
  }
48
44
  throw new Error('Got unexpected non ClickHouse datasource selection');
49
45
  };
50
46
  // Immediate query execution on Enter or blur
51
47
  const handleQueryExecute = (query)=>{
52
- if (queryHandlerSettings?.watchQueryChanges) {
53
- queryHandlerSettings.watchQueryChanges(query);
54
- }
55
48
  onChange((0, _immer.produce)(value, (draft)=>{
56
49
  draft.query = query;
57
50
  }));
58
51
  };
59
52
  const handleClickHouseQueryChange = (0, _react.useCallback)((e)=>{
60
53
  handleQueryChange(e);
61
- if (queryHandlerSettings?.watchQueryChanges) {
62
- queryHandlerSettings.watchQueryChanges(e);
63
- }
64
54
  }, [
65
- handleQueryChange,
66
- queryHandlerSettings
55
+ handleQueryChange
67
56
  ]);
68
57
  const examplesStyle = {
69
58
  fontSize: '11px',
@@ -88,7 +77,7 @@ function ClickHouseLogQueryEditor(props) {
88
77
  /*#__PURE__*/ (0, _jsxruntime.jsx)(_components.ClickQLEditor, {
89
78
  value: query,
90
79
  onChange: handleClickHouseQueryChange,
91
- onBlur: queryHandlerSettings?.runWithOnBlur ? handleQueryBlur : undefined,
80
+ onBlur: handleQueryBlur,
92
81
  onKeyDown: (event)=>{
93
82
  if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {
94
83
  event.preventDefault();
@@ -24,13 +24,13 @@ const _jsxruntime = require("react/jsx-runtime");
24
24
  const _pluginsystem = require("@perses-dev/plugin-system");
25
25
  const _react = require("react");
26
26
  const _immer = require("immer");
27
+ const _material = require("@mui/material");
27
28
  const _constants = require("../constants");
28
29
  const _components = require("../../components");
29
- const _material = require("@mui/material");
30
30
  const _constants1 = require("../../components/constants");
31
31
  const _queryeditormodel = require("../query-editor-model");
32
32
  function ClickHouseTimeSeriesQueryEditor(props) {
33
- const { onChange, value, queryHandlerSettings } = props;
33
+ const { onChange, value } = props;
34
34
  const { datasource } = value;
35
35
  const selectedDatasource = datasource ?? _constants.DEFAULT_DATASOURCE;
36
36
  const { query, handleQueryChange, handleQueryBlur } = (0, _queryeditormodel.useQueryState)(props);
@@ -39,31 +39,20 @@ function ClickHouseTimeSeriesQueryEditor(props) {
39
39
  onChange((0, _immer.produce)(value, (draft)=>{
40
40
  draft.datasource = newDatasourceSelection;
41
41
  }));
42
- if (queryHandlerSettings?.setWatchOtherSpecs) queryHandlerSettings.setWatchOtherSpecs({
43
- ...value,
44
- datasource: newDatasourceSelection
45
- });
46
42
  return;
47
43
  }
48
44
  throw new Error('Got unexpected non ClickHouse datasource selection');
49
45
  };
50
46
  // Immediate query execution on Enter or blur
51
47
  const handleQueryExecute = (query)=>{
52
- if (queryHandlerSettings?.watchQueryChanges) {
53
- queryHandlerSettings.watchQueryChanges(query);
54
- }
55
48
  onChange((0, _immer.produce)(value, (draft)=>{
56
49
  draft.query = query;
57
50
  }));
58
51
  };
59
52
  const handleClickHouseQueryChange = (0, _react.useCallback)((e)=>{
60
53
  handleQueryChange(e);
61
- if (queryHandlerSettings?.watchQueryChanges) {
62
- queryHandlerSettings.watchQueryChanges(e);
63
- }
64
54
  }, [
65
- handleQueryChange,
66
- queryHandlerSettings
55
+ handleQueryChange
67
56
  ]);
68
57
  const examplesStyle = {
69
58
  fontSize: '11px',
@@ -88,7 +77,7 @@ function ClickHouseTimeSeriesQueryEditor(props) {
88
77
  /*#__PURE__*/ (0, _jsxruntime.jsx)(_components.ClickQLEditor, {
89
78
  value: query,
90
79
  onChange: handleClickHouseQueryChange,
91
- onBlur: queryHandlerSettings?.runWithOnBlur ? handleQueryBlur : undefined,
80
+ onBlur: handleQueryBlur,
92
81
  onKeyDown: (event)=>{
93
82
  if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {
94
83
  event.preventDefault();
@@ -1 +1 @@
1
- {"version":3,"file":"ClickHouseLogQueryEditor.d.ts","sourceRoot":"","sources":["../../../../src/queries/click-house-log-query/ClickHouseLogQueryEditor.tsx"],"names":[],"mappings":"AAaA,OAAO,EAIL,kBAAkB,EACnB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,YAAY,EAAe,MAAM,OAAO,CAAC;AAMlD,OAAO,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAC;AAGvE,KAAK,0BAA0B,GAAG,kBAAkB,CAAC,sBAAsB,CAAC,CAAC;AAE7E,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,0BAA0B,GAAG,YAAY,CAoFxF"}
1
+ {"version":3,"file":"ClickHouseLogQueryEditor.d.ts","sourceRoot":"","sources":["../../../../src/queries/click-house-log-query/ClickHouseLogQueryEditor.tsx"],"names":[],"mappings":"AAaA,OAAO,EAIL,kBAAkB,EACnB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,YAAY,EAAe,MAAM,OAAO,CAAC;AAOlD,OAAO,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAC;AAEvE,KAAK,0BAA0B,GAAG,kBAAkB,CAAC,sBAAsB,CAAC,CAAC;AAE7E,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,0BAA0B,GAAG,YAAY,CA2ExF"}
@@ -14,13 +14,13 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
14
14
  import { DatasourceSelect, isVariableDatasource } from '@perses-dev/plugin-system';
15
15
  import { useCallback } from 'react';
16
16
  import { produce } from 'immer';
17
+ import { Stack } from '@mui/material';
17
18
  import { DATASOURCE_KIND, DEFAULT_DATASOURCE } from '../constants';
18
19
  import { ClickQLEditor } from '../../components';
19
- import { Stack } from '@mui/material';
20
20
  import { queryExample } from '../../components/constants';
21
21
  import { useQueryState } from '../query-editor-model';
22
22
  export function ClickHouseLogQueryEditor(props) {
23
- const { onChange, value, queryHandlerSettings } = props;
23
+ const { onChange, value } = props;
24
24
  const { datasource } = value;
25
25
  const selectedDatasource = datasource ?? DEFAULT_DATASOURCE;
26
26
  const { query, handleQueryChange, handleQueryBlur } = useQueryState(props);
@@ -29,31 +29,20 @@ export function ClickHouseLogQueryEditor(props) {
29
29
  onChange(produce(value, (draft)=>{
30
30
  draft.datasource = newDatasourceSelection;
31
31
  }));
32
- if (queryHandlerSettings?.setWatchOtherSpecs) queryHandlerSettings.setWatchOtherSpecs({
33
- ...value,
34
- datasource: newDatasourceSelection
35
- });
36
32
  return;
37
33
  }
38
34
  throw new Error('Got unexpected non ClickHouse datasource selection');
39
35
  };
40
36
  // Immediate query execution on Enter or blur
41
37
  const handleQueryExecute = (query)=>{
42
- if (queryHandlerSettings?.watchQueryChanges) {
43
- queryHandlerSettings.watchQueryChanges(query);
44
- }
45
38
  onChange(produce(value, (draft)=>{
46
39
  draft.query = query;
47
40
  }));
48
41
  };
49
42
  const handleClickHouseQueryChange = useCallback((e)=>{
50
43
  handleQueryChange(e);
51
- if (queryHandlerSettings?.watchQueryChanges) {
52
- queryHandlerSettings.watchQueryChanges(e);
53
- }
54
44
  }, [
55
- handleQueryChange,
56
- queryHandlerSettings
45
+ handleQueryChange
57
46
  ]);
58
47
  const examplesStyle = {
59
48
  fontSize: '11px',
@@ -78,7 +67,7 @@ export function ClickHouseLogQueryEditor(props) {
78
67
  /*#__PURE__*/ _jsx(ClickQLEditor, {
79
68
  value: query,
80
69
  onChange: handleClickHouseQueryChange,
81
- onBlur: queryHandlerSettings?.runWithOnBlur ? handleQueryBlur : undefined,
70
+ onBlur: handleQueryBlur,
82
71
  onKeyDown: (event)=>{
83
72
  if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {
84
73
  event.preventDefault();
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/queries/click-house-log-query/ClickHouseLogQueryEditor.tsx"],"sourcesContent":["// Copyright 2025 The Perses Authors\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n// http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\nimport {\n DatasourceSelect,\n DatasourceSelectProps,\n isVariableDatasource,\n OptionsEditorProps,\n} from '@perses-dev/plugin-system';\nimport { ReactElement, useCallback } from 'react';\nimport { produce } from 'immer';\nimport { DATASOURCE_KIND, DEFAULT_DATASOURCE } from '../constants';\nimport { ClickQLEditor } from '../../components';\nimport { Stack } from '@mui/material';\nimport { queryExample } from '../../components/constants';\nimport { ClickHouseLogQuerySpec } from './click-house-log-query-types';\nimport { useQueryState } from '../query-editor-model';\n\ntype ClickHouseQueryEditorProps = OptionsEditorProps<ClickHouseLogQuerySpec>;\n\nexport function ClickHouseLogQueryEditor(props: ClickHouseQueryEditorProps): ReactElement {\n const { onChange, value, queryHandlerSettings } = props;\n const { datasource } = value;\n const selectedDatasource = datasource ?? DEFAULT_DATASOURCE;\n const { query, handleQueryChange, handleQueryBlur } = useQueryState(props);\n\n const handleDatasourceChange: DatasourceSelectProps['onChange'] = (newDatasourceSelection) => {\n if (!isVariableDatasource(newDatasourceSelection) && newDatasourceSelection.kind === DATASOURCE_KIND) {\n onChange(\n produce(value, (draft) => {\n draft.datasource = newDatasourceSelection;\n })\n );\n\n if (queryHandlerSettings?.setWatchOtherSpecs)\n queryHandlerSettings.setWatchOtherSpecs({ ...value, datasource: newDatasourceSelection });\n return;\n }\n throw new Error('Got unexpected non ClickHouse datasource selection');\n };\n\n // Immediate query execution on Enter or blur\n const handleQueryExecute = (query: string) => {\n if (queryHandlerSettings?.watchQueryChanges) {\n queryHandlerSettings.watchQueryChanges(query);\n }\n onChange(\n produce(value, (draft) => {\n draft.query = query;\n })\n );\n };\n\n const handleClickHouseQueryChange = useCallback(\n (e: string) => {\n handleQueryChange(e);\n if (queryHandlerSettings?.watchQueryChanges) {\n queryHandlerSettings.watchQueryChanges(e);\n }\n },\n [handleQueryChange, queryHandlerSettings]\n );\n\n const examplesStyle: React.CSSProperties = {\n fontSize: '11px',\n color: '#777',\n backgroundColor: '#f5f5f5',\n padding: '8px',\n borderRadius: '4px',\n fontFamily: 'Monaco, Menlo, \"Ubuntu Mono\", monospace',\n whiteSpace: 'pre-wrap',\n lineHeight: '1.3',\n };\n\n return (\n <Stack spacing={1.5}>\n <DatasourceSelect\n datasourcePluginKind={DATASOURCE_KIND}\n value={selectedDatasource}\n onChange={handleDatasourceChange}\n label=\"ClickHouse Datasource\"\n notched\n />\n <ClickQLEditor\n value={query}\n onChange={handleClickHouseQueryChange}\n onBlur={queryHandlerSettings?.runWithOnBlur ? handleQueryBlur : undefined}\n onKeyDown={(event) => {\n if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {\n event.preventDefault();\n handleQueryExecute(query);\n }\n }}\n placeholder=\"Enter ClickHouse SQL query\"\n />\n\n <details>\n <summary style={{ cursor: 'pointer', fontSize: '12px', color: '#666', marginBottom: '8px' }}>\n Query Examples\n </summary>\n <div style={examplesStyle}>{queryExample}</div>\n </details>\n </Stack>\n );\n}\n"],"names":["DatasourceSelect","isVariableDatasource","useCallback","produce","DATASOURCE_KIND","DEFAULT_DATASOURCE","ClickQLEditor","Stack","queryExample","useQueryState","ClickHouseLogQueryEditor","props","onChange","value","queryHandlerSettings","datasource","selectedDatasource","query","handleQueryChange","handleQueryBlur","handleDatasourceChange","newDatasourceSelection","kind","draft","setWatchOtherSpecs","Error","handleQueryExecute","watchQueryChanges","handleClickHouseQueryChange","e","examplesStyle","fontSize","color","backgroundColor","padding","borderRadius","fontFamily","whiteSpace","lineHeight","spacing","datasourcePluginKind","label","notched","onBlur","runWithOnBlur","undefined","onKeyDown","event","key","ctrlKey","metaKey","preventDefault","placeholder","details","summary","style","cursor","marginBottom","div"],"mappings":"AAAA,oCAAoC;AACpC,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,6CAA6C;AAC7C,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;;AAEjC,SACEA,gBAAgB,EAEhBC,oBAAoB,QAEf,4BAA4B;AACnC,SAAuBC,WAAW,QAAQ,QAAQ;AAClD,SAASC,OAAO,QAAQ,QAAQ;AAChC,SAASC,eAAe,EAAEC,kBAAkB,QAAQ,eAAe;AACnE,SAASC,aAAa,QAAQ,mBAAmB;AACjD,SAASC,KAAK,QAAQ,gBAAgB;AACtC,SAASC,YAAY,QAAQ,6BAA6B;AAE1D,SAASC,aAAa,QAAQ,wBAAwB;AAItD,OAAO,SAASC,yBAAyBC,KAAiC;IACxE,MAAM,EAAEC,QAAQ,EAAEC,KAAK,EAAEC,oBAAoB,EAAE,GAAGH;IAClD,MAAM,EAAEI,UAAU,EAAE,GAAGF;IACvB,MAAMG,qBAAqBD,cAAcV;IACzC,MAAM,EAAEY,KAAK,EAAEC,iBAAiB,EAAEC,eAAe,EAAE,GAAGV,cAAcE;IAEpE,MAAMS,yBAA4D,CAACC;QACjE,IAAI,CAACpB,qBAAqBoB,2BAA2BA,uBAAuBC,IAAI,KAAKlB,iBAAiB;YACpGQ,SACET,QAAQU,OAAO,CAACU;gBACdA,MAAMR,UAAU,GAAGM;YACrB;YAGF,IAAIP,sBAAsBU,oBACxBV,qBAAqBU,kBAAkB,CAAC;gBAAE,GAAGX,KAAK;gBAAEE,YAAYM;YAAuB;YACzF;QACF;QACA,MAAM,IAAII,MAAM;IAClB;IAEA,6CAA6C;IAC7C,MAAMC,qBAAqB,CAACT;QAC1B,IAAIH,sBAAsBa,mBAAmB;YAC3Cb,qBAAqBa,iBAAiB,CAACV;QACzC;QACAL,SACET,QAAQU,OAAO,CAACU;YACdA,MAAMN,KAAK,GAAGA;QAChB;IAEJ;IAEA,MAAMW,8BAA8B1B,YAClC,CAAC2B;QACCX,kBAAkBW;QAClB,IAAIf,sBAAsBa,mBAAmB;YAC3Cb,qBAAqBa,iBAAiB,CAACE;QACzC;IACF,GACA;QAACX;QAAmBJ;KAAqB;IAG3C,MAAMgB,gBAAqC;QACzCC,UAAU;QACVC,OAAO;QACPC,iBAAiB;QACjBC,SAAS;QACTC,cAAc;QACdC,YAAY;QACZC,YAAY;QACZC,YAAY;IACd;IAEA,qBACE,MAAC/B;QAAMgC,SAAS;;0BACd,KAACvC;gBACCwC,sBAAsBpC;gBACtBS,OAAOG;gBACPJ,UAAUQ;gBACVqB,OAAM;gBACNC,OAAO;;0BAET,KAACpC;gBACCO,OAAOI;gBACPL,UAAUgB;gBACVe,QAAQ7B,sBAAsB8B,gBAAgBzB,kBAAkB0B;gBAChEC,WAAW,CAACC;oBACV,IAAIA,MAAMC,GAAG,KAAK,WAAYD,CAAAA,MAAME,OAAO,IAAIF,MAAMG,OAAO,AAAD,GAAI;wBAC7DH,MAAMI,cAAc;wBACpBzB,mBAAmBT;oBACrB;gBACF;gBACAmC,aAAY;;0BAGd,MAACC;;kCACC,KAACC;wBAAQC,OAAO;4BAAEC,QAAQ;4BAAWzB,UAAU;4BAAQC,OAAO;4BAAQyB,cAAc;wBAAM;kCAAG;;kCAG7F,KAACC;wBAAIH,OAAOzB;kCAAgBtB;;;;;;AAIpC"}
1
+ {"version":3,"sources":["../../../../src/queries/click-house-log-query/ClickHouseLogQueryEditor.tsx"],"sourcesContent":["// Copyright 2025 The Perses Authors\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n// http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\nimport {\n DatasourceSelect,\n DatasourceSelectProps,\n isVariableDatasource,\n OptionsEditorProps,\n} from '@perses-dev/plugin-system';\nimport { ReactElement, useCallback } from 'react';\nimport { produce } from 'immer';\nimport { Stack } from '@mui/material';\nimport { DATASOURCE_KIND, DEFAULT_DATASOURCE } from '../constants';\nimport { ClickQLEditor } from '../../components';\nimport { queryExample } from '../../components/constants';\nimport { useQueryState } from '../query-editor-model';\nimport { ClickHouseLogQuerySpec } from './click-house-log-query-types';\n\ntype ClickHouseQueryEditorProps = OptionsEditorProps<ClickHouseLogQuerySpec>;\n\nexport function ClickHouseLogQueryEditor(props: ClickHouseQueryEditorProps): ReactElement {\n const { onChange, value } = props;\n const { datasource } = value;\n const selectedDatasource = datasource ?? DEFAULT_DATASOURCE;\n const { query, handleQueryChange, handleQueryBlur } = useQueryState(props);\n\n const handleDatasourceChange: DatasourceSelectProps['onChange'] = (newDatasourceSelection) => {\n if (!isVariableDatasource(newDatasourceSelection) && newDatasourceSelection.kind === DATASOURCE_KIND) {\n onChange(\n produce(value, (draft) => {\n draft.datasource = newDatasourceSelection;\n })\n );\n return;\n }\n throw new Error('Got unexpected non ClickHouse datasource selection');\n };\n\n // Immediate query execution on Enter or blur\n const handleQueryExecute = (query: string) => {\n onChange(\n produce(value, (draft) => {\n draft.query = query;\n })\n );\n };\n\n const handleClickHouseQueryChange = useCallback(\n (e: string) => {\n handleQueryChange(e);\n },\n [handleQueryChange]\n );\n\n const examplesStyle: React.CSSProperties = {\n fontSize: '11px',\n color: '#777',\n backgroundColor: '#f5f5f5',\n padding: '8px',\n borderRadius: '4px',\n fontFamily: 'Monaco, Menlo, \"Ubuntu Mono\", monospace',\n whiteSpace: 'pre-wrap',\n lineHeight: '1.3',\n };\n\n return (\n <Stack spacing={1.5}>\n <DatasourceSelect\n datasourcePluginKind={DATASOURCE_KIND}\n value={selectedDatasource}\n onChange={handleDatasourceChange}\n label=\"ClickHouse Datasource\"\n notched\n />\n <ClickQLEditor\n value={query}\n onChange={handleClickHouseQueryChange}\n onBlur={handleQueryBlur}\n onKeyDown={(event) => {\n if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {\n event.preventDefault();\n handleQueryExecute(query);\n }\n }}\n placeholder=\"Enter ClickHouse SQL query\"\n />\n\n <details>\n <summary style={{ cursor: 'pointer', fontSize: '12px', color: '#666', marginBottom: '8px' }}>\n Query Examples\n </summary>\n <div style={examplesStyle}>{queryExample}</div>\n </details>\n </Stack>\n );\n}\n"],"names":["DatasourceSelect","isVariableDatasource","useCallback","produce","Stack","DATASOURCE_KIND","DEFAULT_DATASOURCE","ClickQLEditor","queryExample","useQueryState","ClickHouseLogQueryEditor","props","onChange","value","datasource","selectedDatasource","query","handleQueryChange","handleQueryBlur","handleDatasourceChange","newDatasourceSelection","kind","draft","Error","handleQueryExecute","handleClickHouseQueryChange","e","examplesStyle","fontSize","color","backgroundColor","padding","borderRadius","fontFamily","whiteSpace","lineHeight","spacing","datasourcePluginKind","label","notched","onBlur","onKeyDown","event","key","ctrlKey","metaKey","preventDefault","placeholder","details","summary","style","cursor","marginBottom","div"],"mappings":"AAAA,oCAAoC;AACpC,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,6CAA6C;AAC7C,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;;AAEjC,SACEA,gBAAgB,EAEhBC,oBAAoB,QAEf,4BAA4B;AACnC,SAAuBC,WAAW,QAAQ,QAAQ;AAClD,SAASC,OAAO,QAAQ,QAAQ;AAChC,SAASC,KAAK,QAAQ,gBAAgB;AACtC,SAASC,eAAe,EAAEC,kBAAkB,QAAQ,eAAe;AACnE,SAASC,aAAa,QAAQ,mBAAmB;AACjD,SAASC,YAAY,QAAQ,6BAA6B;AAC1D,SAASC,aAAa,QAAQ,wBAAwB;AAKtD,OAAO,SAASC,yBAAyBC,KAAiC;IACxE,MAAM,EAAEC,QAAQ,EAAEC,KAAK,EAAE,GAAGF;IAC5B,MAAM,EAAEG,UAAU,EAAE,GAAGD;IACvB,MAAME,qBAAqBD,cAAcR;IACzC,MAAM,EAAEU,KAAK,EAAEC,iBAAiB,EAAEC,eAAe,EAAE,GAAGT,cAAcE;IAEpE,MAAMQ,yBAA4D,CAACC;QACjE,IAAI,CAACnB,qBAAqBmB,2BAA2BA,uBAAuBC,IAAI,KAAKhB,iBAAiB;YACpGO,SACET,QAAQU,OAAO,CAACS;gBACdA,MAAMR,UAAU,GAAGM;YACrB;YAEF;QACF;QACA,MAAM,IAAIG,MAAM;IAClB;IAEA,6CAA6C;IAC7C,MAAMC,qBAAqB,CAACR;QAC1BJ,SACET,QAAQU,OAAO,CAACS;YACdA,MAAMN,KAAK,GAAGA;QAChB;IAEJ;IAEA,MAAMS,8BAA8BvB,YAClC,CAACwB;QACCT,kBAAkBS;IACpB,GACA;QAACT;KAAkB;IAGrB,MAAMU,gBAAqC;QACzCC,UAAU;QACVC,OAAO;QACPC,iBAAiB;QACjBC,SAAS;QACTC,cAAc;QACdC,YAAY;QACZC,YAAY;QACZC,YAAY;IACd;IAEA,qBACE,MAAC/B;QAAMgC,SAAS;;0BACd,KAACpC;gBACCqC,sBAAsBhC;gBACtBQ,OAAOE;gBACPH,UAAUO;gBACVmB,OAAM;gBACNC,OAAO;;0BAET,KAAChC;gBACCM,OAAOG;gBACPJ,UAAUa;gBACVe,QAAQtB;gBACRuB,WAAW,CAACC;oBACV,IAAIA,MAAMC,GAAG,KAAK,WAAYD,CAAAA,MAAME,OAAO,IAAIF,MAAMG,OAAO,AAAD,GAAI;wBAC7DH,MAAMI,cAAc;wBACpBtB,mBAAmBR;oBACrB;gBACF;gBACA+B,aAAY;;0BAGd,MAACC;;kCACC,KAACC;wBAAQC,OAAO;4BAAEC,QAAQ;4BAAWvB,UAAU;4BAAQC,OAAO;4BAAQuB,cAAc;wBAAM;kCAAG;;kCAG7F,KAACC;wBAAIH,OAAOvB;kCAAgBnB;;;;;;AAIpC"}
@@ -1,6 +1,5 @@
1
- import { AbsoluteTimeRange, UnknownSpec } from '@perses-dev/core';
1
+ import { AbsoluteTimeRange, UnknownSpec, LogData } from '@perses-dev/core';
2
2
  import { DatasourceStore, Plugin, VariableStateMap } from '@perses-dev/plugin-system';
3
- import { LogData } from '@perses-dev/core';
4
3
  export interface LogQueryResult {
5
4
  logs: LogData;
6
5
  timeRange: AbsoluteTimeRange;
@@ -12,7 +11,6 @@ export interface ClickHouseQueryContext {
12
11
  timeRange: AbsoluteTimeRange;
13
12
  variableState: VariableStateMap;
14
13
  datasourceStore: DatasourceStore;
15
- refreshKey: string;
16
14
  }
17
15
  type LogQueryPluginDependencies = {
18
16
  variables?: string[];
@@ -1 +1 @@
1
- {"version":3,"file":"log-query-plugin-interface.d.ts","sourceRoot":"","sources":["../../../../src/queries/click-house-log-query/log-query-plugin-interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AACtF,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAE3C,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,OAAO,CAAC;IACd,SAAS,EAAE,iBAAiB,CAAC;IAC7B,QAAQ,CAAC,EAAE;QACT,mBAAmB,EAAE,MAAM,CAAC;KAC7B,CAAC;CACH;AAED,MAAM,WAAW,sBAAsB;IACrC,SAAS,EAAE,iBAAiB,CAAC;IAC7B,aAAa,EAAE,gBAAgB,CAAC;IAChC,eAAe,EAAE,eAAe,CAAC;IACjC,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,KAAK,0BAA0B,GAAG;IAChC,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;CACtB,CAAC;AAEF,MAAM,WAAW,cAAc,CAAC,IAAI,GAAG,WAAW,CAAE,SAAQ,MAAM,CAAC,IAAI,CAAC;IACtE,UAAU,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,sBAAsB,KAAK,OAAO,CAAC,cAAc,CAAC,CAAC;IACjF,SAAS,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,sBAAsB,KAAK,0BAA0B,CAAC;CACrF"}
1
+ {"version":3,"file":"log-query-plugin-interface.d.ts","sourceRoot":"","sources":["../../../../src/queries/click-house-log-query/log-query-plugin-interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAEtF,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,OAAO,CAAC;IACd,SAAS,EAAE,iBAAiB,CAAC;IAC7B,QAAQ,CAAC,EAAE;QACT,mBAAmB,EAAE,MAAM,CAAC;KAC7B,CAAC;CACH;AAED,MAAM,WAAW,sBAAsB;IACrC,SAAS,EAAE,iBAAiB,CAAC;IAC7B,aAAa,EAAE,gBAAgB,CAAC;IAChC,eAAe,EAAE,eAAe,CAAC;CAClC;AAED,KAAK,0BAA0B,GAAG;IAChC,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;CACtB,CAAC;AAEF,MAAM,WAAW,cAAc,CAAC,IAAI,GAAG,WAAW,CAAE,SAAQ,MAAM,CAAC,IAAI,CAAC;IACtE,UAAU,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,sBAAsB,KAAK,OAAO,CAAC,cAAc,CAAC,CAAC;IACjF,SAAS,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,sBAAsB,KAAK,0BAA0B,CAAC;CACrF"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/queries/click-house-log-query/log-query-plugin-interface.ts"],"sourcesContent":["import { AbsoluteTimeRange, UnknownSpec } from '@perses-dev/core';\nimport { DatasourceStore, Plugin, VariableStateMap } from '@perses-dev/plugin-system';\nimport { LogData } from '@perses-dev/core';\n\nexport interface LogQueryResult {\n logs: LogData;\n timeRange: AbsoluteTimeRange;\n metadata?: {\n executedQueryString: string;\n };\n}\n\nexport interface ClickHouseQueryContext {\n timeRange: AbsoluteTimeRange;\n variableState: VariableStateMap;\n datasourceStore: DatasourceStore;\n refreshKey: string;\n}\n\ntype LogQueryPluginDependencies = {\n variables?: string[];\n};\n\nexport interface LogQueryPlugin<Spec = UnknownSpec> extends Plugin<Spec> {\n getLogData: (spec: Spec, ctx: ClickHouseQueryContext) => Promise<LogQueryResult>;\n dependsOn?: (spec: Spec, ctx: ClickHouseQueryContext) => LogQueryPluginDependencies;\n}\n"],"names":[],"mappings":"AAuBA,WAGC"}
1
+ {"version":3,"sources":["../../../../src/queries/click-house-log-query/log-query-plugin-interface.ts"],"sourcesContent":["import { AbsoluteTimeRange, UnknownSpec, LogData } from '@perses-dev/core';\nimport { DatasourceStore, Plugin, VariableStateMap } from '@perses-dev/plugin-system';\n\nexport interface LogQueryResult {\n logs: LogData;\n timeRange: AbsoluteTimeRange;\n metadata?: {\n executedQueryString: string;\n };\n}\n\nexport interface ClickHouseQueryContext {\n timeRange: AbsoluteTimeRange;\n variableState: VariableStateMap;\n datasourceStore: DatasourceStore;\n}\n\ntype LogQueryPluginDependencies = {\n variables?: string[];\n};\n\nexport interface LogQueryPlugin<Spec = UnknownSpec> extends Plugin<Spec> {\n getLogData: (spec: Spec, ctx: ClickHouseQueryContext) => Promise<LogQueryResult>;\n dependsOn?: (spec: Spec, ctx: ClickHouseQueryContext) => LogQueryPluginDependencies;\n}\n"],"names":[],"mappings":"AAqBA,WAGC"}
@@ -1 +1 @@
1
- {"version":3,"file":"ClickHouseQueryEditor.d.ts","sourceRoot":"","sources":["../../../../src/queries/click-house-time-series-query/ClickHouseQueryEditor.tsx"],"names":[],"mappings":"AAaA,OAAO,EAIL,kBAAkB,EACnB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,YAAY,EAAe,MAAM,OAAO,CAAC;AAElD,OAAO,EAAE,6BAA6B,EAAE,MAAM,2BAA2B,CAAC;AAO1E,KAAK,oCAAoC,GAAG,kBAAkB,CAAC,6BAA6B,CAAC,CAAC;AAE9F,wBAAgB,+BAA+B,CAAC,KAAK,EAAE,oCAAoC,GAAG,YAAY,CAoFzG"}
1
+ {"version":3,"file":"ClickHouseQueryEditor.d.ts","sourceRoot":"","sources":["../../../../src/queries/click-house-time-series-query/ClickHouseQueryEditor.tsx"],"names":[],"mappings":"AAaA,OAAO,EAIL,kBAAkB,EACnB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,YAAY,EAAe,MAAM,OAAO,CAAC;AAOlD,OAAO,EAAE,6BAA6B,EAAE,MAAM,2BAA2B,CAAC;AAE1E,KAAK,oCAAoC,GAAG,kBAAkB,CAAC,6BAA6B,CAAC,CAAC;AAE9F,wBAAgB,+BAA+B,CAAC,KAAK,EAAE,oCAAoC,GAAG,YAAY,CA2EzG"}
@@ -14,13 +14,13 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
14
14
  import { DatasourceSelect, isVariableDatasource } from '@perses-dev/plugin-system';
15
15
  import { useCallback } from 'react';
16
16
  import { produce } from 'immer';
17
+ import { Stack } from '@mui/material';
17
18
  import { DATASOURCE_KIND, DEFAULT_DATASOURCE } from '../constants';
18
19
  import { ClickQLEditor } from '../../components';
19
- import { Stack } from '@mui/material';
20
20
  import { queryExample } from '../../components/constants';
21
21
  import { useQueryState } from '../query-editor-model';
22
22
  export function ClickHouseTimeSeriesQueryEditor(props) {
23
- const { onChange, value, queryHandlerSettings } = props;
23
+ const { onChange, value } = props;
24
24
  const { datasource } = value;
25
25
  const selectedDatasource = datasource ?? DEFAULT_DATASOURCE;
26
26
  const { query, handleQueryChange, handleQueryBlur } = useQueryState(props);
@@ -29,31 +29,20 @@ export function ClickHouseTimeSeriesQueryEditor(props) {
29
29
  onChange(produce(value, (draft)=>{
30
30
  draft.datasource = newDatasourceSelection;
31
31
  }));
32
- if (queryHandlerSettings?.setWatchOtherSpecs) queryHandlerSettings.setWatchOtherSpecs({
33
- ...value,
34
- datasource: newDatasourceSelection
35
- });
36
32
  return;
37
33
  }
38
34
  throw new Error('Got unexpected non ClickHouse datasource selection');
39
35
  };
40
36
  // Immediate query execution on Enter or blur
41
37
  const handleQueryExecute = (query)=>{
42
- if (queryHandlerSettings?.watchQueryChanges) {
43
- queryHandlerSettings.watchQueryChanges(query);
44
- }
45
38
  onChange(produce(value, (draft)=>{
46
39
  draft.query = query;
47
40
  }));
48
41
  };
49
42
  const handleClickHouseQueryChange = useCallback((e)=>{
50
43
  handleQueryChange(e);
51
- if (queryHandlerSettings?.watchQueryChanges) {
52
- queryHandlerSettings.watchQueryChanges(e);
53
- }
54
44
  }, [
55
- handleQueryChange,
56
- queryHandlerSettings
45
+ handleQueryChange
57
46
  ]);
58
47
  const examplesStyle = {
59
48
  fontSize: '11px',
@@ -78,7 +67,7 @@ export function ClickHouseTimeSeriesQueryEditor(props) {
78
67
  /*#__PURE__*/ _jsx(ClickQLEditor, {
79
68
  value: query,
80
69
  onChange: handleClickHouseQueryChange,
81
- onBlur: queryHandlerSettings?.runWithOnBlur ? handleQueryBlur : undefined,
70
+ onBlur: handleQueryBlur,
82
71
  onKeyDown: (event)=>{
83
72
  if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {
84
73
  event.preventDefault();
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/queries/click-house-time-series-query/ClickHouseQueryEditor.tsx"],"sourcesContent":["// Copyright 2025 The Perses Authors\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n// http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\nimport {\n DatasourceSelect,\n DatasourceSelectProps,\n isVariableDatasource,\n OptionsEditorProps,\n} from '@perses-dev/plugin-system';\nimport { ReactElement, useCallback } from 'react';\nimport { produce } from 'immer';\nimport { ClickHouseTimeSeriesQuerySpec } from './click-house-query-types';\nimport { DATASOURCE_KIND, DEFAULT_DATASOURCE } from '../constants';\nimport { ClickQLEditor } from '../../components';\nimport { Stack } from '@mui/material';\nimport { queryExample } from '../../components/constants';\nimport { useQueryState } from '../query-editor-model';\n\ntype ClickHouseTimeSeriesQueryEditorProps = OptionsEditorProps<ClickHouseTimeSeriesQuerySpec>;\n\nexport function ClickHouseTimeSeriesQueryEditor(props: ClickHouseTimeSeriesQueryEditorProps): ReactElement {\n const { onChange, value, queryHandlerSettings } = props;\n const { datasource } = value;\n const selectedDatasource = datasource ?? DEFAULT_DATASOURCE;\n const { query, handleQueryChange, handleQueryBlur } = useQueryState(props);\n\n const handleDatasourceChange: DatasourceSelectProps['onChange'] = (newDatasourceSelection) => {\n if (!isVariableDatasource(newDatasourceSelection) && newDatasourceSelection.kind === DATASOURCE_KIND) {\n onChange(\n produce(value, (draft) => {\n draft.datasource = newDatasourceSelection;\n })\n );\n\n if (queryHandlerSettings?.setWatchOtherSpecs)\n queryHandlerSettings.setWatchOtherSpecs({ ...value, datasource: newDatasourceSelection });\n return;\n }\n throw new Error('Got unexpected non ClickHouse datasource selection');\n };\n\n // Immediate query execution on Enter or blur\n const handleQueryExecute = (query: string) => {\n if (queryHandlerSettings?.watchQueryChanges) {\n queryHandlerSettings.watchQueryChanges(query);\n }\n onChange(\n produce(value, (draft) => {\n draft.query = query;\n })\n );\n };\n\n const handleClickHouseQueryChange = useCallback(\n (e: string) => {\n handleQueryChange(e);\n if (queryHandlerSettings?.watchQueryChanges) {\n queryHandlerSettings.watchQueryChanges(e);\n }\n },\n [handleQueryChange, queryHandlerSettings]\n );\n\n const examplesStyle: React.CSSProperties = {\n fontSize: '11px',\n color: '#777',\n backgroundColor: '#f5f5f5',\n padding: '8px',\n borderRadius: '4px',\n fontFamily: 'Monaco, Menlo, \"Ubuntu Mono\", monospace',\n whiteSpace: 'pre-wrap',\n lineHeight: '1.3',\n };\n\n return (\n <Stack spacing={1.5}>\n <DatasourceSelect\n datasourcePluginKind={DATASOURCE_KIND}\n value={selectedDatasource}\n onChange={handleDatasourceChange}\n label=\"ClickHouse Datasource\"\n notched\n />\n <ClickQLEditor\n value={query}\n onChange={handleClickHouseQueryChange}\n onBlur={queryHandlerSettings?.runWithOnBlur ? handleQueryBlur : undefined}\n onKeyDown={(event) => {\n if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {\n event.preventDefault();\n handleQueryExecute(query);\n }\n }}\n placeholder=\"Enter ClickHouse SQL query\"\n />\n\n <details>\n <summary style={{ cursor: 'pointer', fontSize: '12px', color: '#666', marginBottom: '8px' }}>\n Query Examples\n </summary>\n <div style={examplesStyle}>{queryExample}</div>\n </details>\n </Stack>\n );\n}\n"],"names":["DatasourceSelect","isVariableDatasource","useCallback","produce","DATASOURCE_KIND","DEFAULT_DATASOURCE","ClickQLEditor","Stack","queryExample","useQueryState","ClickHouseTimeSeriesQueryEditor","props","onChange","value","queryHandlerSettings","datasource","selectedDatasource","query","handleQueryChange","handleQueryBlur","handleDatasourceChange","newDatasourceSelection","kind","draft","setWatchOtherSpecs","Error","handleQueryExecute","watchQueryChanges","handleClickHouseQueryChange","e","examplesStyle","fontSize","color","backgroundColor","padding","borderRadius","fontFamily","whiteSpace","lineHeight","spacing","datasourcePluginKind","label","notched","onBlur","runWithOnBlur","undefined","onKeyDown","event","key","ctrlKey","metaKey","preventDefault","placeholder","details","summary","style","cursor","marginBottom","div"],"mappings":"AAAA,oCAAoC;AACpC,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,6CAA6C;AAC7C,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;;AAEjC,SACEA,gBAAgB,EAEhBC,oBAAoB,QAEf,4BAA4B;AACnC,SAAuBC,WAAW,QAAQ,QAAQ;AAClD,SAASC,OAAO,QAAQ,QAAQ;AAEhC,SAASC,eAAe,EAAEC,kBAAkB,QAAQ,eAAe;AACnE,SAASC,aAAa,QAAQ,mBAAmB;AACjD,SAASC,KAAK,QAAQ,gBAAgB;AACtC,SAASC,YAAY,QAAQ,6BAA6B;AAC1D,SAASC,aAAa,QAAQ,wBAAwB;AAItD,OAAO,SAASC,gCAAgCC,KAA2C;IACzF,MAAM,EAAEC,QAAQ,EAAEC,KAAK,EAAEC,oBAAoB,EAAE,GAAGH;IAClD,MAAM,EAAEI,UAAU,EAAE,GAAGF;IACvB,MAAMG,qBAAqBD,cAAcV;IACzC,MAAM,EAAEY,KAAK,EAAEC,iBAAiB,EAAEC,eAAe,EAAE,GAAGV,cAAcE;IAEpE,MAAMS,yBAA4D,CAACC;QACjE,IAAI,CAACpB,qBAAqBoB,2BAA2BA,uBAAuBC,IAAI,KAAKlB,iBAAiB;YACpGQ,SACET,QAAQU,OAAO,CAACU;gBACdA,MAAMR,UAAU,GAAGM;YACrB;YAGF,IAAIP,sBAAsBU,oBACxBV,qBAAqBU,kBAAkB,CAAC;gBAAE,GAAGX,KAAK;gBAAEE,YAAYM;YAAuB;YACzF;QACF;QACA,MAAM,IAAII,MAAM;IAClB;IAEA,6CAA6C;IAC7C,MAAMC,qBAAqB,CAACT;QAC1B,IAAIH,sBAAsBa,mBAAmB;YAC3Cb,qBAAqBa,iBAAiB,CAACV;QACzC;QACAL,SACET,QAAQU,OAAO,CAACU;YACdA,MAAMN,KAAK,GAAGA;QAChB;IAEJ;IAEA,MAAMW,8BAA8B1B,YAClC,CAAC2B;QACCX,kBAAkBW;QAClB,IAAIf,sBAAsBa,mBAAmB;YAC3Cb,qBAAqBa,iBAAiB,CAACE;QACzC;IACF,GACA;QAACX;QAAmBJ;KAAqB;IAG3C,MAAMgB,gBAAqC;QACzCC,UAAU;QACVC,OAAO;QACPC,iBAAiB;QACjBC,SAAS;QACTC,cAAc;QACdC,YAAY;QACZC,YAAY;QACZC,YAAY;IACd;IAEA,qBACE,MAAC/B;QAAMgC,SAAS;;0BACd,KAACvC;gBACCwC,sBAAsBpC;gBACtBS,OAAOG;gBACPJ,UAAUQ;gBACVqB,OAAM;gBACNC,OAAO;;0BAET,KAACpC;gBACCO,OAAOI;gBACPL,UAAUgB;gBACVe,QAAQ7B,sBAAsB8B,gBAAgBzB,kBAAkB0B;gBAChEC,WAAW,CAACC;oBACV,IAAIA,MAAMC,GAAG,KAAK,WAAYD,CAAAA,MAAME,OAAO,IAAIF,MAAMG,OAAO,AAAD,GAAI;wBAC7DH,MAAMI,cAAc;wBACpBzB,mBAAmBT;oBACrB;gBACF;gBACAmC,aAAY;;0BAGd,MAACC;;kCACC,KAACC;wBAAQC,OAAO;4BAAEC,QAAQ;4BAAWzB,UAAU;4BAAQC,OAAO;4BAAQyB,cAAc;wBAAM;kCAAG;;kCAG7F,KAACC;wBAAIH,OAAOzB;kCAAgBtB;;;;;;AAIpC"}
1
+ {"version":3,"sources":["../../../../src/queries/click-house-time-series-query/ClickHouseQueryEditor.tsx"],"sourcesContent":["// Copyright 2025 The Perses Authors\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n// http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\nimport {\n DatasourceSelect,\n DatasourceSelectProps,\n isVariableDatasource,\n OptionsEditorProps,\n} from '@perses-dev/plugin-system';\nimport { ReactElement, useCallback } from 'react';\nimport { produce } from 'immer';\nimport { Stack } from '@mui/material';\nimport { DATASOURCE_KIND, DEFAULT_DATASOURCE } from '../constants';\nimport { ClickQLEditor } from '../../components';\nimport { queryExample } from '../../components/constants';\nimport { useQueryState } from '../query-editor-model';\nimport { ClickHouseTimeSeriesQuerySpec } from './click-house-query-types';\n\ntype ClickHouseTimeSeriesQueryEditorProps = OptionsEditorProps<ClickHouseTimeSeriesQuerySpec>;\n\nexport function ClickHouseTimeSeriesQueryEditor(props: ClickHouseTimeSeriesQueryEditorProps): ReactElement {\n const { onChange, value } = props;\n const { datasource } = value;\n const selectedDatasource = datasource ?? DEFAULT_DATASOURCE;\n const { query, handleQueryChange, handleQueryBlur } = useQueryState(props);\n\n const handleDatasourceChange: DatasourceSelectProps['onChange'] = (newDatasourceSelection) => {\n if (!isVariableDatasource(newDatasourceSelection) && newDatasourceSelection.kind === DATASOURCE_KIND) {\n onChange(\n produce(value, (draft) => {\n draft.datasource = newDatasourceSelection;\n })\n );\n return;\n }\n throw new Error('Got unexpected non ClickHouse datasource selection');\n };\n\n // Immediate query execution on Enter or blur\n const handleQueryExecute = (query: string) => {\n onChange(\n produce(value, (draft) => {\n draft.query = query;\n })\n );\n };\n\n const handleClickHouseQueryChange = useCallback(\n (e: string) => {\n handleQueryChange(e);\n },\n [handleQueryChange]\n );\n\n const examplesStyle: React.CSSProperties = {\n fontSize: '11px',\n color: '#777',\n backgroundColor: '#f5f5f5',\n padding: '8px',\n borderRadius: '4px',\n fontFamily: 'Monaco, Menlo, \"Ubuntu Mono\", monospace',\n whiteSpace: 'pre-wrap',\n lineHeight: '1.3',\n };\n\n return (\n <Stack spacing={1.5}>\n <DatasourceSelect\n datasourcePluginKind={DATASOURCE_KIND}\n value={selectedDatasource}\n onChange={handleDatasourceChange}\n label=\"ClickHouse Datasource\"\n notched\n />\n <ClickQLEditor\n value={query}\n onChange={handleClickHouseQueryChange}\n onBlur={handleQueryBlur}\n onKeyDown={(event) => {\n if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {\n event.preventDefault();\n handleQueryExecute(query);\n }\n }}\n placeholder=\"Enter ClickHouse SQL query\"\n />\n\n <details>\n <summary style={{ cursor: 'pointer', fontSize: '12px', color: '#666', marginBottom: '8px' }}>\n Query Examples\n </summary>\n <div style={examplesStyle}>{queryExample}</div>\n </details>\n </Stack>\n );\n}\n"],"names":["DatasourceSelect","isVariableDatasource","useCallback","produce","Stack","DATASOURCE_KIND","DEFAULT_DATASOURCE","ClickQLEditor","queryExample","useQueryState","ClickHouseTimeSeriesQueryEditor","props","onChange","value","datasource","selectedDatasource","query","handleQueryChange","handleQueryBlur","handleDatasourceChange","newDatasourceSelection","kind","draft","Error","handleQueryExecute","handleClickHouseQueryChange","e","examplesStyle","fontSize","color","backgroundColor","padding","borderRadius","fontFamily","whiteSpace","lineHeight","spacing","datasourcePluginKind","label","notched","onBlur","onKeyDown","event","key","ctrlKey","metaKey","preventDefault","placeholder","details","summary","style","cursor","marginBottom","div"],"mappings":"AAAA,oCAAoC;AACpC,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,6CAA6C;AAC7C,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;;AAEjC,SACEA,gBAAgB,EAEhBC,oBAAoB,QAEf,4BAA4B;AACnC,SAAuBC,WAAW,QAAQ,QAAQ;AAClD,SAASC,OAAO,QAAQ,QAAQ;AAChC,SAASC,KAAK,QAAQ,gBAAgB;AACtC,SAASC,eAAe,EAAEC,kBAAkB,QAAQ,eAAe;AACnE,SAASC,aAAa,QAAQ,mBAAmB;AACjD,SAASC,YAAY,QAAQ,6BAA6B;AAC1D,SAASC,aAAa,QAAQ,wBAAwB;AAKtD,OAAO,SAASC,gCAAgCC,KAA2C;IACzF,MAAM,EAAEC,QAAQ,EAAEC,KAAK,EAAE,GAAGF;IAC5B,MAAM,EAAEG,UAAU,EAAE,GAAGD;IACvB,MAAME,qBAAqBD,cAAcR;IACzC,MAAM,EAAEU,KAAK,EAAEC,iBAAiB,EAAEC,eAAe,EAAE,GAAGT,cAAcE;IAEpE,MAAMQ,yBAA4D,CAACC;QACjE,IAAI,CAACnB,qBAAqBmB,2BAA2BA,uBAAuBC,IAAI,KAAKhB,iBAAiB;YACpGO,SACET,QAAQU,OAAO,CAACS;gBACdA,MAAMR,UAAU,GAAGM;YACrB;YAEF;QACF;QACA,MAAM,IAAIG,MAAM;IAClB;IAEA,6CAA6C;IAC7C,MAAMC,qBAAqB,CAACR;QAC1BJ,SACET,QAAQU,OAAO,CAACS;YACdA,MAAMN,KAAK,GAAGA;QAChB;IAEJ;IAEA,MAAMS,8BAA8BvB,YAClC,CAACwB;QACCT,kBAAkBS;IACpB,GACA;QAACT;KAAkB;IAGrB,MAAMU,gBAAqC;QACzCC,UAAU;QACVC,OAAO;QACPC,iBAAiB;QACjBC,SAAS;QACTC,cAAc;QACdC,YAAY;QACZC,YAAY;QACZC,YAAY;IACd;IAEA,qBACE,MAAC/B;QAAMgC,SAAS;;0BACd,KAACpC;gBACCqC,sBAAsBhC;gBACtBQ,OAAOE;gBACPH,UAAUO;gBACVmB,OAAM;gBACNC,OAAO;;0BAET,KAAChC;gBACCM,OAAOG;gBACPJ,UAAUa;gBACVe,QAAQtB;gBACRuB,WAAW,CAACC;oBACV,IAAIA,MAAMC,GAAG,KAAK,WAAYD,CAAAA,MAAME,OAAO,IAAIF,MAAMG,OAAO,AAAD,GAAI;wBAC7DH,MAAMI,cAAc;wBACpBtB,mBAAmBR;oBACrB;gBACF;gBACA+B,aAAY;;0BAGd,MAACC;;kCACC,KAACC;wBAAQC,OAAO;4BAAEC,QAAQ;4BAAWvB,UAAU;4BAAQC,OAAO;4BAAQuB,cAAc;wBAAM;kCAAG;;kCAG7F,KAACC;wBAAIH,OAAOvB;kCAAgBnB;;;;;;AAIpC"}
package/mf-manifest.json CHANGED
@@ -5,11 +5,11 @@
5
5
  "name": "ClickHouse",
6
6
  "type": "app",
7
7
  "buildInfo": {
8
- "buildVersion": "0.3.0",
8
+ "buildVersion": "0.4.0",
9
9
  "buildName": "@perses-dev/clickhouse-plugin"
10
10
  },
11
11
  "remoteEntry": {
12
- "name": "__mf/js/ClickHouse.8f89cb2c.js",
12
+ "name": "__mf/js/ClickHouse.fef0738b.js",
13
13
  "path": "",
14
14
  "type": "global"
15
15
  },
@@ -87,14 +87,14 @@
87
87
  {
88
88
  "id": "ClickHouse:@perses-dev/components",
89
89
  "name": "@perses-dev/components",
90
- "version": "0.53.0-beta.1",
90
+ "version": "0.53.0-beta.2",
91
91
  "singleton": true,
92
- "requiredVersion": "^0.53.0-beta.1",
92
+ "requiredVersion": "^0.53.0-beta.2",
93
93
  "assets": {
94
94
  "js": {
95
95
  "async": [],
96
96
  "sync": [
97
- "__mf/js/async/7991.64a1aaaf.js"
97
+ "__mf/js/async/7991.11320a4d.js"
98
98
  ]
99
99
  },
100
100
  "css": {
@@ -106,14 +106,14 @@
106
106
  {
107
107
  "id": "ClickHouse:@perses-dev/dashboards",
108
108
  "name": "@perses-dev/dashboards",
109
- "version": "0.53.0-beta.1",
109
+ "version": "0.53.0-beta.2",
110
110
  "singleton": true,
111
- "requiredVersion": "^0.53.0-beta.1",
111
+ "requiredVersion": "^0.53.0-beta.2",
112
112
  "assets": {
113
113
  "js": {
114
114
  "async": [],
115
115
  "sync": [
116
- "__mf/js/async/2472.9f5fd5cf.js"
116
+ "__mf/js/async/4676.cae72135.js"
117
117
  ]
118
118
  },
119
119
  "css": {
@@ -125,14 +125,14 @@
125
125
  {
126
126
  "id": "ClickHouse:@perses-dev/explore",
127
127
  "name": "@perses-dev/explore",
128
- "version": "0.53.0-beta.1",
128
+ "version": "0.53.0-beta.2",
129
129
  "singleton": true,
130
- "requiredVersion": "^0.53.0-beta.1",
130
+ "requiredVersion": "^0.53.0-beta.2",
131
131
  "assets": {
132
132
  "js": {
133
133
  "async": [],
134
134
  "sync": [
135
- "__mf/js/async/4421.750852d0.js"
135
+ "__mf/js/async/4421.d9d48d4f.js"
136
136
  ]
137
137
  },
138
138
  "css": {
@@ -144,14 +144,14 @@
144
144
  {
145
145
  "id": "ClickHouse:@perses-dev/plugin-system",
146
146
  "name": "@perses-dev/plugin-system",
147
- "version": "0.53.0-beta.1",
147
+ "version": "0.53.0-beta.2",
148
148
  "singleton": true,
149
- "requiredVersion": "^0.53.0-beta.1",
149
+ "requiredVersion": "^0.53.0-beta.2",
150
150
  "assets": {
151
151
  "js": {
152
152
  "async": [],
153
153
  "sync": [
154
- "__mf/js/async/2178.16cf2da3.js"
154
+ "__mf/js/async/4557.aa037aea.js"
155
155
  ]
156
156
  },
157
157
  "css": {
@@ -340,17 +340,17 @@
340
340
  "assets": {
341
341
  "js": {
342
342
  "sync": [
343
- "__mf/js/async/__federation_expose_ClickHouseDatasource.e3722d39.js"
343
+ "__mf/js/async/__federation_expose_ClickHouseDatasource.b909c7ef.js"
344
344
  ],
345
345
  "async": [
346
346
  "__mf/js/async/282.76b8b044.js",
347
347
  "__mf/js/async/1360.33f7e672.js",
348
348
  "__mf/js/async/2114.27f707a0.js",
349
- "__mf/js/async/__federation_expose_ClickHouseTimeSeriesQuery.6a30813e.js",
350
- "__mf/js/async/__federation_expose_ClickHouseLogQuery.63888cb7.js",
349
+ "__mf/js/async/__federation_expose_ClickHouseTimeSeriesQuery.b3723b8b.js",
350
+ "__mf/js/async/__federation_expose_ClickHouseLogQuery.8e9aa83b.js",
351
351
  "__mf/js/async/2226.1d4436dc.js",
352
352
  "__mf/js/async/7376.c01a7f82.js",
353
- "__mf/js/async/6620.1d8e42fd.js",
353
+ "__mf/js/async/58.c1431e49.js",
354
354
  "__mf/js/async/2652.fd27ec3f.js",
355
355
  "__mf/js/async/3431.54fb88df.js",
356
356
  "__mf/js/async/6134.a0f2d3c5.js",
@@ -359,7 +359,7 @@
359
359
  "__mf/js/async/2292.248bd1ea.js",
360
360
  "__mf/js/async/8488.16a69ea5.js",
361
361
  "__mf/js/async/8216.44c6334e.js",
362
- "__mf/js/async/2708.7448dd5c.js"
362
+ "__mf/js/async/7797.36d938e5.js"
363
363
  ]
364
364
  },
365
365
  "css": {
@@ -380,12 +380,12 @@
380
380
  "__mf/js/async/282.76b8b044.js",
381
381
  "__mf/js/async/1360.33f7e672.js",
382
382
  "__mf/js/async/2114.27f707a0.js",
383
- "__mf/js/async/__federation_expose_ClickHouseTimeSeriesQuery.6a30813e.js"
383
+ "__mf/js/async/__federation_expose_ClickHouseTimeSeriesQuery.b3723b8b.js"
384
384
  ],
385
385
  "async": [
386
386
  "__mf/js/async/2226.1d4436dc.js",
387
387
  "__mf/js/async/7376.c01a7f82.js",
388
- "__mf/js/async/6620.1d8e42fd.js",
388
+ "__mf/js/async/58.c1431e49.js",
389
389
  "__mf/js/async/2652.fd27ec3f.js",
390
390
  "__mf/js/async/3431.54fb88df.js",
391
391
  "__mf/js/async/6134.a0f2d3c5.js",
@@ -394,7 +394,7 @@
394
394
  "__mf/js/async/2292.248bd1ea.js",
395
395
  "__mf/js/async/8488.16a69ea5.js",
396
396
  "__mf/js/async/8216.44c6334e.js",
397
- "__mf/js/async/2708.7448dd5c.js"
397
+ "__mf/js/async/7797.36d938e5.js"
398
398
  ]
399
399
  },
400
400
  "css": {
@@ -415,12 +415,12 @@
415
415
  "__mf/js/async/282.76b8b044.js",
416
416
  "__mf/js/async/1360.33f7e672.js",
417
417
  "__mf/js/async/2114.27f707a0.js",
418
- "__mf/js/async/__federation_expose_ClickHouseLogQuery.63888cb7.js"
418
+ "__mf/js/async/__federation_expose_ClickHouseLogQuery.8e9aa83b.js"
419
419
  ],
420
420
  "async": [
421
421
  "__mf/js/async/2226.1d4436dc.js",
422
422
  "__mf/js/async/7376.c01a7f82.js",
423
- "__mf/js/async/6620.1d8e42fd.js",
423
+ "__mf/js/async/58.c1431e49.js",
424
424
  "__mf/js/async/2652.fd27ec3f.js",
425
425
  "__mf/js/async/3431.54fb88df.js",
426
426
  "__mf/js/async/6134.a0f2d3c5.js",
@@ -429,7 +429,7 @@
429
429
  "__mf/js/async/2292.248bd1ea.js",
430
430
  "__mf/js/async/8488.16a69ea5.js",
431
431
  "__mf/js/async/8216.44c6334e.js",
432
- "__mf/js/async/2708.7448dd5c.js"
432
+ "__mf/js/async/7797.36d938e5.js"
433
433
  ]
434
434
  },
435
435
  "css": {