@perses-dev/table-plugin 0.8.1 → 0.10.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.
- package/__mf/css/async/2341.d3010b86.css +1 -0
- package/__mf/css/async/5263.d3010b86.css +1 -0
- package/__mf/css/async/6759.d3010b86.css +1 -0
- package/__mf/js/{Table.1ddb6c06.js → Table.02a0172e.js} +4 -4
- package/__mf/js/async/2178.23b43aaf.js +1 -0
- package/__mf/js/async/2472.d6b3b5c6.js +22 -0
- package/__mf/js/async/2849.0d68beb5.js +2 -0
- package/__mf/js/async/{4075.e2a2c230.js → 4075.98f26cf8.js} +1 -1
- package/__mf/js/async/{4238.ea9515aa.js → 4238.8989501f.js} +1 -1
- package/__mf/js/async/6377.1f2ba730.js +38 -0
- package/__mf/js/async/9830.a2983642.js +7 -0
- package/__mf/js/async/__federation_expose_Table.0dbf0d6d.js +1 -0
- package/__mf/js/{main.688de0b9.js → main.f7b12b00.js} +4 -4
- package/lib/Table.d.ts +2 -2
- package/lib/Table.d.ts.map +1 -1
- package/lib/Table.js +2 -6
- package/lib/Table.js.map +1 -1
- package/lib/cjs/Table.js +9 -13
- package/lib/cjs/components/CellsEditor/CellsEditor.js +30 -0
- package/lib/cjs/{CellsEditor → components/CellsEditor}/index.js +0 -1
- package/lib/cjs/components/ColumnsEditor/ColumnEditor.js +241 -0
- package/lib/cjs/{CellsEditor/CellEditor.js → components/ConditionalPanel.js} +167 -197
- package/lib/cjs/components/TablePanel.js +576 -0
- package/lib/cjs/{TableSettingsEditor.js → components/TableSettingsEditor.js} +32 -4
- package/lib/cjs/components/index.js +37 -0
- package/lib/cjs/index.js +2 -9
- package/lib/cjs/models/index.js +31 -0
- package/lib/cjs/{table-model.js → models/model.js} +1 -12
- package/lib/cjs/models/table-model.js +252 -0
- package/lib/{CellsEditor → components/CellsEditor}/CellsEditor.d.ts +1 -1
- package/lib/components/CellsEditor/CellsEditor.d.ts.map +1 -0
- package/lib/components/CellsEditor/CellsEditor.js +22 -0
- package/lib/components/CellsEditor/CellsEditor.js.map +1 -0
- package/lib/components/CellsEditor/index.d.ts +2 -0
- package/lib/components/CellsEditor/index.d.ts.map +1 -0
- package/lib/{CellsEditor → components/CellsEditor}/index.js +0 -1
- package/lib/components/CellsEditor/index.js.map +1 -0
- package/lib/{ColumnsEditor → components/ColumnsEditor}/ColumnEditor.d.ts +1 -1
- package/lib/components/ColumnsEditor/ColumnEditor.d.ts.map +1 -0
- package/lib/components/ColumnsEditor/ColumnEditor.js +233 -0
- package/lib/components/ColumnsEditor/ColumnEditor.js.map +1 -0
- package/lib/components/ColumnsEditor/ColumnEditorContainer.d.ts.map +1 -0
- package/lib/components/ColumnsEditor/ColumnEditorContainer.js.map +1 -0
- package/lib/{ColumnsEditor → components/ColumnsEditor}/ColumnsEditor.d.ts +1 -1
- package/lib/components/ColumnsEditor/ColumnsEditor.d.ts.map +1 -0
- package/lib/components/ColumnsEditor/ColumnsEditor.js.map +1 -0
- package/lib/components/ColumnsEditor/index.d.ts.map +1 -0
- package/lib/components/ColumnsEditor/index.js.map +1 -0
- package/lib/components/ConditionalPanel.d.ts +15 -0
- package/lib/components/ConditionalPanel.d.ts.map +1 -0
- package/lib/{CellsEditor/CellEditor.js → components/ConditionalPanel.js} +159 -197
- package/lib/components/ConditionalPanel.js.map +1 -0
- package/lib/components/EmbeddedPanel.d.ts.map +1 -0
- package/lib/components/EmbeddedPanel.js.map +1 -0
- package/lib/{TableCellsEditor.d.ts → components/TableCellsEditor.d.ts} +1 -1
- package/lib/components/TableCellsEditor.d.ts.map +1 -0
- package/lib/components/TableCellsEditor.js.map +1 -0
- package/lib/{TableColumnsEditor.d.ts → components/TableColumnsEditor.d.ts} +1 -1
- package/lib/components/TableColumnsEditor.d.ts.map +1 -0
- package/lib/components/TableColumnsEditor.js.map +1 -0
- package/lib/{TablePanel.d.ts → components/TablePanel.d.ts} +1 -1
- package/lib/components/TablePanel.d.ts.map +1 -0
- package/lib/components/TablePanel.js +560 -0
- package/lib/components/TablePanel.js.map +1 -0
- package/lib/{TableSettingsEditor.d.ts → components/TableSettingsEditor.d.ts} +1 -1
- package/lib/components/TableSettingsEditor.d.ts.map +1 -0
- package/lib/{TableSettingsEditor.js → components/TableSettingsEditor.js} +32 -4
- package/lib/components/TableSettingsEditor.js.map +1 -0
- package/lib/{TableTransformsEditor.d.ts → components/TableTransformsEditor.d.ts} +1 -1
- package/lib/components/TableTransformsEditor.d.ts.map +1 -0
- package/lib/components/TableTransformsEditor.js.map +1 -0
- package/lib/components/index.d.ts +9 -0
- package/lib/components/index.d.ts.map +1 -0
- package/lib/components/index.js +22 -0
- package/lib/components/index.js.map +1 -0
- package/lib/index.d.ts +2 -9
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +2 -9
- package/lib/index.js.map +1 -1
- package/lib/models/index.d.ts +3 -0
- package/lib/models/index.d.ts.map +1 -0
- package/lib/{table-model.js → models/index.js} +4 -9
- package/lib/models/index.js.map +1 -0
- package/lib/models/model.d.ts.map +1 -0
- package/lib/models/model.js +15 -0
- package/lib/models/model.js.map +1 -0
- package/lib/{table-model.d.ts → models/table-model.d.ts} +24 -1
- package/lib/models/table-model.d.ts.map +1 -0
- package/lib/models/table-model.js +233 -0
- package/lib/models/table-model.js.map +1 -0
- package/mf-manifest.json +21 -22
- package/mf-stats.json +22 -23
- package/package.json +6 -6
- package/__mf/css/async/2341.cbbd94a8.css +0 -1
- package/__mf/css/async/5263.cbbd94a8.css +0 -1
- package/__mf/css/async/6759.cbbd94a8.css +0 -1
- package/__mf/js/async/3391.62c7afd4.js +0 -73
- package/__mf/js/async/4300.fc319dfb.js +0 -38
- package/__mf/js/async/4368.3e460b07.js +0 -1
- package/__mf/js/async/5061.85655462.js +0 -2
- package/__mf/js/async/5377.6522c49a.js +0 -1
- package/__mf/js/async/8313.b86a056a.js +0 -7
- package/__mf/js/async/__federation_expose_Table.3668e352.js +0 -1
- package/lib/CellsEditor/CellEditor.d.ts +0 -10
- package/lib/CellsEditor/CellEditor.d.ts.map +0 -1
- package/lib/CellsEditor/CellEditor.js.map +0 -1
- package/lib/CellsEditor/CellsEditor.d.ts.map +0 -1
- package/lib/CellsEditor/CellsEditor.js +0 -123
- package/lib/CellsEditor/CellsEditor.js.map +0 -1
- package/lib/CellsEditor/index.d.ts +0 -3
- package/lib/CellsEditor/index.d.ts.map +0 -1
- package/lib/CellsEditor/index.js.map +0 -1
- package/lib/ColumnsEditor/ColumnEditor.d.ts.map +0 -1
- package/lib/ColumnsEditor/ColumnEditor.js +0 -213
- package/lib/ColumnsEditor/ColumnEditor.js.map +0 -1
- package/lib/ColumnsEditor/ColumnEditorContainer.d.ts.map +0 -1
- package/lib/ColumnsEditor/ColumnEditorContainer.js.map +0 -1
- package/lib/ColumnsEditor/ColumnsEditor.d.ts.map +0 -1
- package/lib/ColumnsEditor/ColumnsEditor.js.map +0 -1
- package/lib/ColumnsEditor/index.d.ts.map +0 -1
- package/lib/ColumnsEditor/index.js.map +0 -1
- package/lib/EmbeddedPanel.d.ts.map +0 -1
- package/lib/EmbeddedPanel.js.map +0 -1
- package/lib/TableCellsEditor.d.ts.map +0 -1
- package/lib/TableCellsEditor.js.map +0 -1
- package/lib/TableColumnsEditor.d.ts.map +0 -1
- package/lib/TableColumnsEditor.js.map +0 -1
- package/lib/TablePanel.d.ts.map +0 -1
- package/lib/TablePanel.js +0 -325
- package/lib/TablePanel.js.map +0 -1
- package/lib/TableSettingsEditor.d.ts.map +0 -1
- package/lib/TableSettingsEditor.js.map +0 -1
- package/lib/TableTransformsEditor.d.ts.map +0 -1
- package/lib/TableTransformsEditor.js.map +0 -1
- package/lib/cjs/CellsEditor/CellsEditor.js +0 -136
- package/lib/cjs/ColumnsEditor/ColumnEditor.js +0 -221
- package/lib/cjs/TablePanel.js +0 -341
- package/lib/cjs/model.js +0 -4
- package/lib/model.d.ts.map +0 -1
- package/lib/model.js +0 -3
- package/lib/model.js.map +0 -1
- package/lib/table-model.d.ts.map +0 -1
- package/lib/table-model.js.map +0 -1
- /package/__mf/js/async/{3391.62c7afd4.js.LICENSE.txt → 2472.d6b3b5c6.js.LICENSE.txt} +0 -0
- /package/__mf/js/async/{5061.85655462.js.LICENSE.txt → 2849.0d68beb5.js.LICENSE.txt} +0 -0
- /package/__mf/js/async/{8313.b86a056a.js.LICENSE.txt → 9830.a2983642.js.LICENSE.txt} +0 -0
- /package/lib/cjs/{ColumnsEditor → components/ColumnsEditor}/ColumnEditorContainer.js +0 -0
- /package/lib/cjs/{ColumnsEditor → components/ColumnsEditor}/ColumnsEditor.js +0 -0
- /package/lib/cjs/{ColumnsEditor → components/ColumnsEditor}/index.js +0 -0
- /package/lib/cjs/{EmbeddedPanel.js → components/EmbeddedPanel.js} +0 -0
- /package/lib/cjs/{TableCellsEditor.js → components/TableCellsEditor.js} +0 -0
- /package/lib/cjs/{TableColumnsEditor.js → components/TableColumnsEditor.js} +0 -0
- /package/lib/cjs/{TableTransformsEditor.js → components/TableTransformsEditor.js} +0 -0
- /package/lib/{ColumnsEditor → components/ColumnsEditor}/ColumnEditorContainer.d.ts +0 -0
- /package/lib/{ColumnsEditor → components/ColumnsEditor}/ColumnEditorContainer.js +0 -0
- /package/lib/{ColumnsEditor → components/ColumnsEditor}/ColumnsEditor.js +0 -0
- /package/lib/{ColumnsEditor → components/ColumnsEditor}/index.d.ts +0 -0
- /package/lib/{ColumnsEditor → components/ColumnsEditor}/index.js +0 -0
- /package/lib/{EmbeddedPanel.d.ts → components/EmbeddedPanel.d.ts} +0 -0
- /package/lib/{EmbeddedPanel.js → components/EmbeddedPanel.js} +0 -0
- /package/lib/{TableCellsEditor.js → components/TableCellsEditor.js} +0 -0
- /package/lib/{TableColumnsEditor.js → components/TableColumnsEditor.js} +0 -0
- /package/lib/{TableTransformsEditor.js → components/TableTransformsEditor.js} +0 -0
- /package/lib/{model.d.ts → models/model.d.ts} +0 -0
|
@@ -34,10 +34,12 @@ function DefaultColumnsDimensionsControl({ label, defaultValue, value, onChange
|
|
|
34
34
|
control: /*#__PURE__*/ _jsx(TextField, {
|
|
35
35
|
type: "number",
|
|
36
36
|
value: value ?? defaultValue,
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
37
|
+
slotProps: {
|
|
38
|
+
input: {
|
|
39
|
+
inputProps: {
|
|
40
|
+
min: 1,
|
|
41
|
+
step: 1
|
|
42
|
+
}
|
|
41
43
|
}
|
|
42
44
|
},
|
|
43
45
|
onChange: (e)=>onChange(parseInt(e.target.value))
|
|
@@ -59,6 +61,12 @@ export function TableSettingsEditor({ onChange, value }) {
|
|
|
59
61
|
pagination: newValue
|
|
60
62
|
});
|
|
61
63
|
}
|
|
64
|
+
function handleDefaultColumnHiddenChange(_event, newValue) {
|
|
65
|
+
onChange({
|
|
66
|
+
...value,
|
|
67
|
+
defaultColumnHidden: newValue
|
|
68
|
+
});
|
|
69
|
+
}
|
|
62
70
|
function handleAutoWidthChange(newValue) {
|
|
63
71
|
onChange({
|
|
64
72
|
...value,
|
|
@@ -71,6 +79,12 @@ export function TableSettingsEditor({ onChange, value }) {
|
|
|
71
79
|
defaultColumnHeight: newValue
|
|
72
80
|
});
|
|
73
81
|
}
|
|
82
|
+
function handleEnableFilteringChange(_event, checked) {
|
|
83
|
+
onChange({
|
|
84
|
+
...value,
|
|
85
|
+
enableFiltering: checked
|
|
86
|
+
});
|
|
87
|
+
}
|
|
74
88
|
return /*#__PURE__*/ _jsx(OptionsEditorGrid, {
|
|
75
89
|
children: /*#__PURE__*/ _jsx(OptionsEditorColumn, {
|
|
76
90
|
children: /*#__PURE__*/ _jsxs(OptionsEditorGroup, {
|
|
@@ -87,6 +101,20 @@ export function TableSettingsEditor({ onChange, value }) {
|
|
|
87
101
|
onChange: handlePaginationChange
|
|
88
102
|
})
|
|
89
103
|
}),
|
|
104
|
+
/*#__PURE__*/ _jsx(OptionsEditorControl, {
|
|
105
|
+
label: "Columns Hidden by Default",
|
|
106
|
+
control: /*#__PURE__*/ _jsx(Switch, {
|
|
107
|
+
checked: !!value.defaultColumnHidden,
|
|
108
|
+
onChange: handleDefaultColumnHiddenChange
|
|
109
|
+
})
|
|
110
|
+
}),
|
|
111
|
+
/*#__PURE__*/ _jsx(OptionsEditorControl, {
|
|
112
|
+
label: "Enable Column Filtering",
|
|
113
|
+
control: /*#__PURE__*/ _jsx(Switch, {
|
|
114
|
+
checked: !!value.enableFiltering,
|
|
115
|
+
onChange: handleEnableFilteringChange
|
|
116
|
+
})
|
|
117
|
+
}),
|
|
90
118
|
/*#__PURE__*/ _jsx(DefaultColumnsDimensionsControl, {
|
|
91
119
|
label: "Width",
|
|
92
120
|
defaultValue: DEFAULT_COLUMN_WIDTH,
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/TableSettingsEditor.tsx"],"sourcesContent":["// Copyright 2024 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 { Switch, TextField } from '@mui/material';\nimport {\n DEFAULT_COLUMN_HEIGHT,\n DEFAULT_COLUMN_WIDTH,\n DensitySelector,\n OptionsEditorColumn,\n OptionsEditorControl,\n OptionsEditorGrid,\n OptionsEditorGroup,\n TableDensity,\n} from '@perses-dev/components';\nimport { ChangeEvent, ReactElement } from 'react';\nimport { TableSettingsEditorProps } from '../models';\n\ninterface DefaultColumnsDimensionsControlProps {\n label: string;\n defaultValue: number;\n value?: 'auto' | number;\n onChange: (value: 'auto' | number) => void;\n}\n\nfunction DefaultColumnsDimensionsControl({\n label,\n defaultValue,\n value,\n onChange,\n}: DefaultColumnsDimensionsControlProps): ReactElement {\n function handleAutoSwitchChange(_: ChangeEvent, checked: boolean): void {\n if (checked) {\n return onChange('auto');\n }\n onChange(defaultValue);\n }\n\n return (\n <>\n <OptionsEditorControl\n label={`Auto Columns ${label}`}\n control={<Switch checked={value === undefined || value === 'auto'} onChange={handleAutoSwitchChange} />}\n />\n {value !== undefined && value !== 'auto' && (\n <OptionsEditorControl\n label={`Default Columns ${label}`}\n control={\n <TextField\n type=\"number\"\n value={value ?? defaultValue}\n slotProps={{ input: { inputProps: { min: 1, step: 1 } } }}\n onChange={(e) => onChange(parseInt(e.target.value))}\n />\n }\n />\n )}\n </>\n );\n}\n\nexport function TableSettingsEditor({ onChange, value }: TableSettingsEditorProps): ReactElement {\n function handleDensityChange(density: TableDensity): void {\n onChange({ ...value, density: density });\n }\n\n function handlePaginationChange(_event: ChangeEvent, newValue: boolean): void {\n onChange({ ...value, pagination: newValue });\n }\n\n function handleDefaultColumnHiddenChange(_event: ChangeEvent, newValue: boolean): void {\n onChange({ ...value, defaultColumnHidden: newValue });\n }\n\n function handleAutoWidthChange(newValue: 'auto' | number): void {\n onChange({ ...value, defaultColumnWidth: newValue });\n }\n\n function handleAutoHeightChange(newValue: 'auto' | number): void {\n onChange({ ...value, defaultColumnHeight: newValue });\n }\n\n function handleEnableFilteringChange(_event: ChangeEvent, checked: boolean): void {\n onChange({ ...value, enableFiltering: checked });\n }\n\n return (\n <OptionsEditorGrid>\n <OptionsEditorColumn>\n <OptionsEditorGroup title=\"Display\">\n <DensitySelector value={value.density} onChange={handleDensityChange} />\n <OptionsEditorControl\n label=\"Pagination\"\n control={<Switch checked={!!value.pagination} onChange={handlePaginationChange} />}\n />\n <OptionsEditorControl\n label=\"Columns Hidden by Default\"\n control={<Switch checked={!!value.defaultColumnHidden} onChange={handleDefaultColumnHiddenChange} />}\n />\n <OptionsEditorControl\n label=\"Enable Column Filtering\"\n control={<Switch checked={!!value.enableFiltering} onChange={handleEnableFilteringChange} />}\n />\n\n <DefaultColumnsDimensionsControl\n label=\"Width\"\n defaultValue={DEFAULT_COLUMN_WIDTH}\n value={value.defaultColumnWidth}\n onChange={handleAutoWidthChange}\n />\n <DefaultColumnsDimensionsControl\n label=\"Height\"\n defaultValue={DEFAULT_COLUMN_HEIGHT}\n value={value.defaultColumnHeight}\n onChange={handleAutoHeightChange}\n />\n </OptionsEditorGroup>\n </OptionsEditorColumn>\n </OptionsEditorGrid>\n );\n}\n"],"names":["Switch","TextField","DEFAULT_COLUMN_HEIGHT","DEFAULT_COLUMN_WIDTH","DensitySelector","OptionsEditorColumn","OptionsEditorControl","OptionsEditorGrid","OptionsEditorGroup","DefaultColumnsDimensionsControl","label","defaultValue","value","onChange","handleAutoSwitchChange","_","checked","control","undefined","type","slotProps","input","inputProps","min","step","e","parseInt","target","TableSettingsEditor","handleDensityChange","density","handlePaginationChange","_event","newValue","pagination","handleDefaultColumnHiddenChange","defaultColumnHidden","handleAutoWidthChange","defaultColumnWidth","handleAutoHeightChange","defaultColumnHeight","handleEnableFilteringChange","enableFiltering","title"],"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,SAASA,MAAM,EAAEC,SAAS,QAAQ,gBAAgB;AAClD,SACEC,qBAAqB,EACrBC,oBAAoB,EACpBC,eAAe,EACfC,mBAAmB,EACnBC,oBAAoB,EACpBC,iBAAiB,EACjBC,kBAAkB,QAEb,yBAAyB;AAWhC,SAASC,gCAAgC,EACvCC,KAAK,EACLC,YAAY,EACZC,KAAK,EACLC,QAAQ,EAC6B;IACrC,SAASC,uBAAuBC,CAAc,EAAEC,OAAgB;QAC9D,IAAIA,SAAS;YACX,OAAOH,SAAS;QAClB;QACAA,SAASF;IACX;IAEA,qBACE;;0BACE,KAACL;gBACCI,OAAO,CAAC,aAAa,EAAEA,OAAO;gBAC9BO,uBAAS,KAACjB;oBAAOgB,SAASJ,UAAUM,aAAaN,UAAU;oBAAQC,UAAUC;;;YAE9EF,UAAUM,aAAaN,UAAU,wBAChC,KAACN;gBACCI,OAAO,CAAC,gBAAgB,EAAEA,OAAO;gBACjCO,uBACE,KAAChB;oBACCkB,MAAK;oBACLP,OAAOA,SAASD;oBAChBS,WAAW;wBAAEC,OAAO;4BAAEC,YAAY;gCAAEC,KAAK;gCAAGC,MAAM;4BAAE;wBAAE;oBAAE;oBACxDX,UAAU,CAACY,IAAMZ,SAASa,SAASD,EAAEE,MAAM,CAACf,KAAK;;;;;AAO/D;AAEA,OAAO,SAASgB,oBAAoB,EAAEf,QAAQ,EAAED,KAAK,EAA4B;IAC/E,SAASiB,oBAAoBC,OAAqB;QAChDjB,SAAS;YAAE,GAAGD,KAAK;YAAEkB,SAASA;QAAQ;IACxC;IAEA,SAASC,uBAAuBC,MAAmB,EAAEC,QAAiB;QACpEpB,SAAS;YAAE,GAAGD,KAAK;YAAEsB,YAAYD;QAAS;IAC5C;IAEA,SAASE,gCAAgCH,MAAmB,EAAEC,QAAiB;QAC7EpB,SAAS;YAAE,GAAGD,KAAK;YAAEwB,qBAAqBH;QAAS;IACrD;IAEA,SAASI,sBAAsBJ,QAAyB;QACtDpB,SAAS;YAAE,GAAGD,KAAK;YAAE0B,oBAAoBL;QAAS;IACpD;IAEA,SAASM,uBAAuBN,QAAyB;QACvDpB,SAAS;YAAE,GAAGD,KAAK;YAAE4B,qBAAqBP;QAAS;IACrD;IAEA,SAASQ,4BAA4BT,MAAmB,EAAEhB,OAAgB;QACxEH,SAAS;YAAE,GAAGD,KAAK;YAAE8B,iBAAiB1B;QAAQ;IAChD;IAEA,qBACE,KAACT;kBACC,cAAA,KAACF;sBACC,cAAA,MAACG;gBAAmBmC,OAAM;;kCACxB,KAACvC;wBAAgBQ,OAAOA,MAAMkB,OAAO;wBAAEjB,UAAUgB;;kCACjD,KAACvB;wBACCI,OAAM;wBACNO,uBAAS,KAACjB;4BAAOgB,SAAS,CAAC,CAACJ,MAAMsB,UAAU;4BAAErB,UAAUkB;;;kCAE1D,KAACzB;wBACCI,OAAM;wBACNO,uBAAS,KAACjB;4BAAOgB,SAAS,CAAC,CAACJ,MAAMwB,mBAAmB;4BAAEvB,UAAUsB;;;kCAEnE,KAAC7B;wBACCI,OAAM;wBACNO,uBAAS,KAACjB;4BAAOgB,SAAS,CAAC,CAACJ,MAAM8B,eAAe;4BAAE7B,UAAU4B;;;kCAG/D,KAAChC;wBACCC,OAAM;wBACNC,cAAcR;wBACdS,OAAOA,MAAM0B,kBAAkB;wBAC/BzB,UAAUwB;;kCAEZ,KAAC5B;wBACCC,OAAM;wBACNC,cAAcT;wBACdU,OAAOA,MAAM4B,mBAAmB;wBAChC3B,UAAU0B;;;;;;AAMtB"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { ReactElement } from 'react';
|
|
2
|
-
import { TableSettingsEditorProps } from '
|
|
2
|
+
import { TableSettingsEditorProps } from '../models';
|
|
3
3
|
export declare function TableTransformsEditor({ value, onChange }: TableSettingsEditorProps): ReactElement;
|
|
4
4
|
//# sourceMappingURL=TableTransformsEditor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TableTransformsEditor.d.ts","sourceRoot":"","sources":["../../../src/components/TableTransformsEditor.tsx"],"names":[],"mappings":"AAeA,OAAO,EAAE,YAAY,EAAE,MAAM,OAAO,CAAC;AACrC,OAAO,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC;AAErD,wBAAgB,qBAAqB,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,wBAAwB,GAAG,YAAY,CAMjG"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/TableTransformsEditor.tsx"],"sourcesContent":["// Copyright 2024 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 { TransformsEditor } from '@perses-dev/components';\nimport { Transform } from '@perses-dev/core';\nimport { ReactElement } from 'react';\nimport { TableSettingsEditorProps } from '../models';\n\nexport function TableTransformsEditor({ value, onChange }: TableSettingsEditorProps): ReactElement {\n function handleTransformsChange(transforms: Transform[]): void {\n onChange({ ...value, transforms: transforms });\n }\n\n return <TransformsEditor value={value.transforms ?? []} onChange={handleTransformsChange} />;\n}\n"],"names":["TransformsEditor","TableTransformsEditor","value","onChange","handleTransformsChange","transforms"],"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,SAASA,gBAAgB,QAAQ,yBAAyB;AAK1D,OAAO,SAASC,sBAAsB,EAAEC,KAAK,EAAEC,QAAQ,EAA4B;IACjF,SAASC,uBAAuBC,UAAuB;QACrDF,SAAS;YAAE,GAAGD,KAAK;YAAEG,YAAYA;QAAW;IAC9C;IAEA,qBAAO,KAACL;QAAiBE,OAAOA,MAAMG,UAAU,IAAI,EAAE;QAAEF,UAAUC;;AACpE"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export * from './CellsEditor';
|
|
2
|
+
export * from './ColumnsEditor';
|
|
3
|
+
export * from './EmbeddedPanel';
|
|
4
|
+
export * from './TableCellsEditor';
|
|
5
|
+
export * from './TableColumnsEditor';
|
|
6
|
+
export * from './TablePanel';
|
|
7
|
+
export * from './TableSettingsEditor';
|
|
8
|
+
export * from './TableTransformsEditor';
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAaA,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,iBAAiB,CAAC;AAChC,cAAc,oBAAoB,CAAC;AACnC,cAAc,sBAAsB,CAAC;AACrC,cAAc,cAAc,CAAC;AAC7B,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
// Copyright 2025 The Perses Authors
|
|
2
|
+
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
3
|
+
// you may not use this file except in compliance with the License.
|
|
4
|
+
// You may obtain a copy of the License at
|
|
5
|
+
//
|
|
6
|
+
// http://www.apache.org/licenses/LICENSE-2.0
|
|
7
|
+
//
|
|
8
|
+
// Unless required by applicable law or agreed to in writing, software
|
|
9
|
+
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
10
|
+
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
11
|
+
// See the License for the specific language governing permissions and
|
|
12
|
+
// limitations under the License.
|
|
13
|
+
export * from './CellsEditor';
|
|
14
|
+
export * from './ColumnsEditor';
|
|
15
|
+
export * from './EmbeddedPanel';
|
|
16
|
+
export * from './TableCellsEditor';
|
|
17
|
+
export * from './TableColumnsEditor';
|
|
18
|
+
export * from './TablePanel';
|
|
19
|
+
export * from './TableSettingsEditor';
|
|
20
|
+
export * from './TableTransformsEditor';
|
|
21
|
+
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/index.ts"],"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\nexport * from './CellsEditor';\nexport * from './ColumnsEditor';\nexport * from './EmbeddedPanel';\nexport * from './TableCellsEditor';\nexport * from './TableColumnsEditor';\nexport * from './TablePanel';\nexport * from './TableSettingsEditor';\nexport * from './TableTransformsEditor';\n"],"names":[],"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,cAAc,gBAAgB;AAC9B,cAAc,kBAAkB;AAChC,cAAc,kBAAkB;AAChC,cAAc,qBAAqB;AACnC,cAAc,uBAAuB;AACrC,cAAc,eAAe;AAC7B,cAAc,wBAAwB;AACtC,cAAc,0BAA0B"}
|
package/lib/index.d.ts
CHANGED
|
@@ -1,12 +1,5 @@
|
|
|
1
1
|
export { getPluginModule } from './getPluginModule';
|
|
2
|
-
export * from './CellsEditor';
|
|
3
|
-
export * from './ColumnsEditor';
|
|
4
2
|
export * from './Table';
|
|
5
|
-
export * from './
|
|
6
|
-
export * from './
|
|
7
|
-
export * from './TablePanel';
|
|
8
|
-
export * from './TableSettingsEditor';
|
|
9
|
-
export * from './TableTransformsEditor';
|
|
10
|
-
export * from './model';
|
|
11
|
-
export * from './table-model';
|
|
3
|
+
export * from './components';
|
|
4
|
+
export * from './models';
|
|
12
5
|
//# sourceMappingURL=index.d.ts.map
|
package/lib/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,cAAc,SAAS,CAAC;AACxB,cAAc,cAAc,CAAC;AAC7B,cAAc,UAAU,CAAC"}
|
package/lib/index.js
CHANGED
|
@@ -1,13 +1,6 @@
|
|
|
1
1
|
export { getPluginModule } from './getPluginModule';
|
|
2
|
-
export * from './CellsEditor';
|
|
3
|
-
export * from './ColumnsEditor';
|
|
4
2
|
export * from './Table';
|
|
5
|
-
export * from './
|
|
6
|
-
export * from './
|
|
7
|
-
export * from './TablePanel';
|
|
8
|
-
export * from './TableSettingsEditor';
|
|
9
|
-
export * from './TableTransformsEditor';
|
|
10
|
-
export * from './model';
|
|
11
|
-
export * from './table-model';
|
|
3
|
+
export * from './components';
|
|
4
|
+
export * from './models';
|
|
12
5
|
|
|
13
6
|
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts"],"sourcesContent":["export { getPluginModule } from './getPluginModule';\nexport * from './
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts"],"sourcesContent":["export { getPluginModule } from './getPluginModule';\nexport * from './Table';\nexport * from './components';\nexport * from './models';\n"],"names":["getPluginModule"],"mappings":"AAAA,SAASA,eAAe,QAAQ,oBAAoB;AACpD,cAAc,UAAU;AACxB,cAAc,eAAe;AAC7B,cAAc,WAAW"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/models/index.ts"],"names":[],"mappings":"AAaA,cAAc,SAAS,CAAC;AACxB,cAAc,eAAe,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
// Copyright
|
|
1
|
+
// Copyright 2025 The Perses Authors
|
|
2
2
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
3
3
|
// you may not use this file except in compliance with the License.
|
|
4
4
|
// You may obtain a copy of the License at
|
|
@@ -10,12 +10,7 @@
|
|
|
10
10
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
11
11
|
// See the License for the specific language governing permissions and
|
|
12
12
|
// limitations under the License.
|
|
13
|
-
|
|
14
|
-
*
|
|
15
|
-
*/ export function createInitialTableOptions() {
|
|
16
|
-
return {
|
|
17
|
-
density: 'standard'
|
|
18
|
-
};
|
|
19
|
-
}
|
|
13
|
+
export * from './model';
|
|
14
|
+
export * from './table-model';
|
|
20
15
|
|
|
21
|
-
//# sourceMappingURL=
|
|
16
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/models/index.ts"],"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\nexport * from './model';\nexport * from './table-model';\n"],"names":[],"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,cAAc,UAAU;AACxB,cAAc,gBAAgB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"model.d.ts","sourceRoot":"","sources":["../../../src/models/model.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAGvD,UAAU,sBAAsB;CAAG;AAEnC,MAAM,MAAM,oBAAoB,GAAG,UAAU,CAAC,sBAAsB,CAAC,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
// Copyright 2025 The Perses Authors
|
|
2
|
+
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
3
|
+
// you may not use this file except in compliance with the License.
|
|
4
|
+
// You may obtain a copy of the License at
|
|
5
|
+
//
|
|
6
|
+
// http://www.apache.org/licenses/LICENSE-2.0
|
|
7
|
+
//
|
|
8
|
+
// Unless required by applicable law or agreed to in writing, software
|
|
9
|
+
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
10
|
+
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
11
|
+
// See the License for the specific language governing permissions and
|
|
12
|
+
// limitations under the License.
|
|
13
|
+
export { };
|
|
14
|
+
|
|
15
|
+
//# sourceMappingURL=model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/models/model.ts"],"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 { PanelProps } from '@perses-dev/plugin-system';\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\ninterface TimeSeriesTableOptions {}\n\nexport type TimeSeriesTableProps = PanelProps<TimeSeriesTableOptions>;\n"],"names":[],"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;AAOjC,WAAsE"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Definition, FormatOptions, Transform, UnknownSpec } from '@perses-dev/core';
|
|
2
|
-
import { TableDensity } from '@perses-dev/components';
|
|
2
|
+
import { TableDensity, TableCellConfig } from '@perses-dev/components';
|
|
3
3
|
import { OptionsEditorProps } from '@perses-dev/plugin-system';
|
|
4
|
+
import React from 'react';
|
|
4
5
|
export interface ColumnSettings {
|
|
5
6
|
name: string;
|
|
6
7
|
header?: string;
|
|
@@ -33,6 +34,7 @@ export interface ColumnSettings {
|
|
|
33
34
|
*/
|
|
34
35
|
width?: number | 'auto';
|
|
35
36
|
hide?: boolean;
|
|
37
|
+
cellSettings?: CellSettings[];
|
|
36
38
|
}
|
|
37
39
|
export interface ValueCondition {
|
|
38
40
|
kind: 'Value';
|
|
@@ -63,6 +65,8 @@ export type Condition = ValueCondition | RangeCondition | RegexCondition | MiscC
|
|
|
63
65
|
export interface CellSettings {
|
|
64
66
|
condition: Condition;
|
|
65
67
|
text?: string;
|
|
68
|
+
prefix?: string;
|
|
69
|
+
suffix?: string;
|
|
66
70
|
textColor?: `#${string}`;
|
|
67
71
|
backgroundColor?: `#${string}`;
|
|
68
72
|
}
|
|
@@ -79,7 +83,9 @@ export interface TableOptions {
|
|
|
79
83
|
density?: TableDensity;
|
|
80
84
|
defaultColumnWidth?: 'auto' | number;
|
|
81
85
|
defaultColumnHeight?: 'auto' | number;
|
|
86
|
+
defaultColumnHidden?: boolean;
|
|
82
87
|
pagination?: boolean;
|
|
88
|
+
enableFiltering?: boolean;
|
|
83
89
|
columnSettings?: ColumnSettings[];
|
|
84
90
|
cellSettings?: CellSettings[];
|
|
85
91
|
transforms?: Transform[];
|
|
@@ -89,4 +95,21 @@ export interface TableOptions {
|
|
|
89
95
|
*/
|
|
90
96
|
export declare function createInitialTableOptions(): TableOptions;
|
|
91
97
|
export type TableSettingsEditorProps = OptionsEditorProps<TableOptions>;
|
|
98
|
+
/**
|
|
99
|
+
* Formats the display text and colors based on cell settings
|
|
100
|
+
*/
|
|
101
|
+
export declare function formatCellDisplay(value: unknown, setting: CellSettings, defaultText?: string): TableCellConfig;
|
|
102
|
+
/**
|
|
103
|
+
* Evaluates if a condition matches the given value
|
|
104
|
+
*/
|
|
105
|
+
export declare function evaluateCondition(condition: Condition, value: unknown): boolean;
|
|
106
|
+
/**
|
|
107
|
+
* Evaluates all conditions and returns the cell config for the first matching condition
|
|
108
|
+
*/
|
|
109
|
+
export declare function evaluateConditionalFormatting(value: unknown, settings: CellSettings[]): TableCellConfig | undefined;
|
|
110
|
+
/**
|
|
111
|
+
* Renders the condition editor component for a given condition
|
|
112
|
+
* This function can be used by both CellEditor and ColumnEditor to maintain consistency
|
|
113
|
+
*/
|
|
114
|
+
export declare function renderConditionEditor(condition: Condition, onChange: (condition: Condition) => void, size?: 'small' | 'medium'): React.ReactElement | null;
|
|
92
115
|
//# sourceMappingURL=table-model.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"table-model.d.ts","sourceRoot":"","sources":["../../../src/models/table-model.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
// Copyright 2024 The Perses Authors
|
|
2
|
+
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
3
|
+
// you may not use this file except in compliance with the License.
|
|
4
|
+
// You may obtain a copy of the License at
|
|
5
|
+
//
|
|
6
|
+
// http://www.apache.org/licenses/LICENSE-2.0
|
|
7
|
+
//
|
|
8
|
+
// Unless required by applicable law or agreed to in writing, software
|
|
9
|
+
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
10
|
+
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
11
|
+
// See the License for the specific language governing permissions and
|
|
12
|
+
// limitations under the License.
|
|
13
|
+
import React from 'react';
|
|
14
|
+
import { TextField, Stack, MenuItem, Typography } from '@mui/material';
|
|
15
|
+
/**
|
|
16
|
+
* Creates the initial/empty options for a Table panel.
|
|
17
|
+
*/ export function createInitialTableOptions() {
|
|
18
|
+
return {
|
|
19
|
+
density: 'standard',
|
|
20
|
+
enableFiltering: true
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Formats the display text and colors based on cell settings
|
|
25
|
+
*/ export function formatCellDisplay(value, setting, defaultText) {
|
|
26
|
+
const baseText = setting.text || defaultText || String(value);
|
|
27
|
+
const displayText = `${setting.prefix ?? ''}${baseText}${setting.suffix ?? ''}`;
|
|
28
|
+
return {
|
|
29
|
+
text: displayText,
|
|
30
|
+
textColor: setting.textColor,
|
|
31
|
+
backgroundColor: setting.backgroundColor
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Evaluates if a condition matches the given value
|
|
36
|
+
*/ export function evaluateCondition(condition, value) {
|
|
37
|
+
switch(condition.kind){
|
|
38
|
+
case 'Value':
|
|
39
|
+
return condition.spec?.value === String(value);
|
|
40
|
+
case 'Range':
|
|
41
|
+
{
|
|
42
|
+
if (Number.isNaN(Number(value))) return false;
|
|
43
|
+
const numericValue = Number(value);
|
|
44
|
+
// Both min and max defined
|
|
45
|
+
if (condition.spec?.min !== undefined && condition.spec?.max !== undefined) {
|
|
46
|
+
return numericValue >= +condition.spec.min && numericValue <= +condition.spec.max;
|
|
47
|
+
}
|
|
48
|
+
// Only min defined
|
|
49
|
+
if (condition.spec?.min !== undefined) {
|
|
50
|
+
return numericValue >= +condition.spec.min;
|
|
51
|
+
}
|
|
52
|
+
// Only max defined
|
|
53
|
+
if (condition.spec?.max !== undefined) {
|
|
54
|
+
return numericValue <= +condition.spec.max;
|
|
55
|
+
}
|
|
56
|
+
return false;
|
|
57
|
+
}
|
|
58
|
+
case 'Regex':
|
|
59
|
+
if (!condition.spec?.expr) return false;
|
|
60
|
+
try {
|
|
61
|
+
const regex = new RegExp(condition.spec.expr);
|
|
62
|
+
return regex.test(String(value));
|
|
63
|
+
} catch {
|
|
64
|
+
return false; // Invalid regex
|
|
65
|
+
}
|
|
66
|
+
case 'Misc':
|
|
67
|
+
switch(condition.spec?.value){
|
|
68
|
+
case 'empty':
|
|
69
|
+
return value === '';
|
|
70
|
+
case 'null':
|
|
71
|
+
return value === null || value === undefined;
|
|
72
|
+
case 'NaN':
|
|
73
|
+
return Number.isNaN(value);
|
|
74
|
+
case 'true':
|
|
75
|
+
return value === true;
|
|
76
|
+
case 'false':
|
|
77
|
+
return value === false;
|
|
78
|
+
default:
|
|
79
|
+
return false;
|
|
80
|
+
}
|
|
81
|
+
default:
|
|
82
|
+
return false;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Evaluates all conditions and returns the cell config for the first matching condition
|
|
87
|
+
*/ export function evaluateConditionalFormatting(value, settings) {
|
|
88
|
+
for (const setting of settings){
|
|
89
|
+
if (evaluateCondition(setting.condition, value)) {
|
|
90
|
+
// Handle special default text cases
|
|
91
|
+
let defaultText;
|
|
92
|
+
if (setting.condition.kind === 'Misc') {
|
|
93
|
+
switch(setting.condition.spec?.value){
|
|
94
|
+
case 'null':
|
|
95
|
+
defaultText = 'null';
|
|
96
|
+
break;
|
|
97
|
+
case 'NaN':
|
|
98
|
+
defaultText = 'NaN';
|
|
99
|
+
break;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
return formatCellDisplay(value, setting, defaultText);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
return undefined; // No conditions matched
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Renders the condition editor component for a given condition
|
|
109
|
+
* This function can be used by both CellEditor and ColumnEditor to maintain consistency
|
|
110
|
+
*/ export function renderConditionEditor(condition, onChange, size = 'small') {
|
|
111
|
+
if (condition.kind === 'Value') {
|
|
112
|
+
return React.createElement(TextField, {
|
|
113
|
+
label: 'Value',
|
|
114
|
+
placeholder: 'Exact value',
|
|
115
|
+
value: condition.spec?.value ?? '',
|
|
116
|
+
onChange: (e)=>onChange({
|
|
117
|
+
...condition,
|
|
118
|
+
spec: {
|
|
119
|
+
value: e.target.value
|
|
120
|
+
}
|
|
121
|
+
}),
|
|
122
|
+
fullWidth: true,
|
|
123
|
+
size: size
|
|
124
|
+
});
|
|
125
|
+
} else if (condition.kind === 'Range') {
|
|
126
|
+
return React.createElement(Stack, {
|
|
127
|
+
gap: 1,
|
|
128
|
+
direction: 'row'
|
|
129
|
+
}, [
|
|
130
|
+
React.createElement(TextField, {
|
|
131
|
+
key: 'min',
|
|
132
|
+
label: 'From',
|
|
133
|
+
placeholder: 'Start of range',
|
|
134
|
+
value: condition.spec?.min ?? '',
|
|
135
|
+
onChange: (e)=>onChange({
|
|
136
|
+
...condition,
|
|
137
|
+
spec: {
|
|
138
|
+
...condition.spec,
|
|
139
|
+
min: +e.target.value
|
|
140
|
+
}
|
|
141
|
+
}),
|
|
142
|
+
fullWidth: true,
|
|
143
|
+
size: size
|
|
144
|
+
}),
|
|
145
|
+
React.createElement(TextField, {
|
|
146
|
+
key: 'max',
|
|
147
|
+
label: 'To',
|
|
148
|
+
placeholder: 'End of range (inclusive)',
|
|
149
|
+
value: condition.spec?.max ?? '',
|
|
150
|
+
onChange: (e)=>onChange({
|
|
151
|
+
...condition,
|
|
152
|
+
spec: {
|
|
153
|
+
...condition.spec,
|
|
154
|
+
max: +e.target.value
|
|
155
|
+
}
|
|
156
|
+
}),
|
|
157
|
+
fullWidth: true,
|
|
158
|
+
size: size
|
|
159
|
+
})
|
|
160
|
+
]);
|
|
161
|
+
} else if (condition.kind === 'Regex') {
|
|
162
|
+
return React.createElement(TextField, {
|
|
163
|
+
label: 'Regular Expression',
|
|
164
|
+
placeholder: 'JavaScript regular expression',
|
|
165
|
+
value: condition.spec?.expr ?? '',
|
|
166
|
+
onChange: (e)=>onChange({
|
|
167
|
+
...condition,
|
|
168
|
+
spec: {
|
|
169
|
+
expr: e.target.value
|
|
170
|
+
}
|
|
171
|
+
}),
|
|
172
|
+
fullWidth: true,
|
|
173
|
+
size: size
|
|
174
|
+
});
|
|
175
|
+
} else if (condition.kind === 'Misc') {
|
|
176
|
+
const options = [
|
|
177
|
+
{
|
|
178
|
+
value: 'empty',
|
|
179
|
+
label: 'Empty',
|
|
180
|
+
caption: 'Matches empty string'
|
|
181
|
+
},
|
|
182
|
+
{
|
|
183
|
+
value: 'null',
|
|
184
|
+
label: 'Null',
|
|
185
|
+
caption: 'Matches null or undefined'
|
|
186
|
+
},
|
|
187
|
+
{
|
|
188
|
+
value: 'NaN',
|
|
189
|
+
label: 'NaN',
|
|
190
|
+
caption: 'Matches Not a Number value'
|
|
191
|
+
},
|
|
192
|
+
{
|
|
193
|
+
value: 'true',
|
|
194
|
+
label: 'True',
|
|
195
|
+
caption: 'Matches true boolean'
|
|
196
|
+
},
|
|
197
|
+
{
|
|
198
|
+
value: 'false',
|
|
199
|
+
label: 'False',
|
|
200
|
+
caption: 'Matches false boolean'
|
|
201
|
+
}
|
|
202
|
+
];
|
|
203
|
+
return React.createElement(TextField, {
|
|
204
|
+
select: true,
|
|
205
|
+
label: 'Value',
|
|
206
|
+
value: condition.spec?.value ?? '',
|
|
207
|
+
onChange: (e)=>onChange({
|
|
208
|
+
...condition,
|
|
209
|
+
spec: {
|
|
210
|
+
value: e.target.value
|
|
211
|
+
}
|
|
212
|
+
}),
|
|
213
|
+
fullWidth: true,
|
|
214
|
+
size: size
|
|
215
|
+
}, options.map((option)=>React.createElement(MenuItem, {
|
|
216
|
+
key: option.value,
|
|
217
|
+
value: option.value
|
|
218
|
+
}, React.createElement(Stack, {
|
|
219
|
+
key: 'stack'
|
|
220
|
+
}, [
|
|
221
|
+
React.createElement(Typography, {
|
|
222
|
+
key: 'title'
|
|
223
|
+
}, option.label),
|
|
224
|
+
React.createElement(Typography, {
|
|
225
|
+
key: 'caption',
|
|
226
|
+
variant: 'caption'
|
|
227
|
+
}, option.caption)
|
|
228
|
+
]))));
|
|
229
|
+
}
|
|
230
|
+
return null;
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
//# sourceMappingURL=table-model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/models/table-model.ts"],"sourcesContent":["// Copyright 2024 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 { Definition, FormatOptions, Transform, UnknownSpec } from '@perses-dev/core';\nimport { TableDensity, TableCellConfig } from '@perses-dev/components';\nimport { OptionsEditorProps } from '@perses-dev/plugin-system';\nimport React from 'react';\nimport { TextField, Stack, MenuItem, Typography } from '@mui/material';\n\nexport interface ColumnSettings {\n name: string;\n\n // Text to display in the header for the column.\n header?: string;\n /**\n * Text to display when hovering over the header text. This can be useful for\n * providing additional information about the column when you want to keep the\n * header text relatively short to manage the column width.\n */\n headerDescription?: string;\n /**\n * Text to display when hovering over a cell. This can be useful for\n * providing additional information about the column when the content is\n * ellipsized to fit in the space.\n */\n cellDescription?: string;\n\n /**\n * Panel plugin to render.\n * By default, the cells are rendered as text.\n */\n plugin?: Definition<UnknownSpec>;\n\n /** Formatting options. Only applicable if plugin is unset. */\n format?: FormatOptions;\n\n // Alignment of the content in the cell.\n align?: 'left' | 'center' | 'right';\n\n // When `true`, the column will be sortable.\n enableSorting?: boolean;\n\n // Default sort order for the column.\n sort?: 'asc' | 'desc';\n\n /**\n * Width of the column when rendered in a table. It should be a number in pixels\n * or \"auto\" to allow the table to automatically adjust the width to fill\n * space.\n */\n width?: number | 'auto';\n // When `true`, the column will not be displayed.\n hide?: boolean;\n // Customize cell display based on their value for this specific column.\n cellSettings?: CellSettings[];\n}\n\nexport interface ValueCondition {\n kind: 'Value';\n spec: {\n value: string;\n };\n}\n\nexport interface RangeCondition {\n kind: 'Range';\n spec: {\n min?: number;\n max?: number;\n };\n}\n\nexport interface RegexCondition {\n kind: 'Regex';\n spec: {\n expr: string;\n };\n}\n\nexport interface MiscCondition {\n kind: 'Misc';\n spec: {\n value: 'empty' | 'null' | 'NaN' | 'true' | 'false';\n };\n}\n\nexport type Condition = ValueCondition | RangeCondition | RegexCondition | MiscCondition;\n\nexport interface CellSettings {\n condition: Condition;\n text?: string;\n prefix?: string;\n suffix?: string;\n textColor?: `#${string}`;\n backgroundColor?: `#${string}`;\n}\n\n/**\n * The schema for a Table panel.\n */\nexport interface TableDefinition extends Definition<TableOptions> {\n kind: 'Table';\n}\n\n/**\n * The Options object type supported by the Table panel plugin.\n */\nexport interface TableOptions {\n // Change row height.\n density?: TableDensity;\n // When set to 'auto', the table will try to automatically adjust the width of columns to fit without overflowing.\n // Only for column without custom width specified in columnSettings.\n defaultColumnWidth?: 'auto' | number;\n // When set to 'auto', the table will calculate the cell height based on the line height of the theme and the density setting of the table.\n // Only for column without custom height specified in columnSettings.\n defaultColumnHeight?: 'auto' | number;\n // When true, columns are hidden by default unless specified in columnSettings.\n defaultColumnHidden?: boolean;\n // Enable pagination.\n pagination?: boolean;\n // Enable filtering for individual columns.\n enableFiltering?: boolean;\n // Customize column display and order them by their index in the array.\n columnSettings?: ColumnSettings[];\n // Customize cell display based on their value.\n cellSettings?: CellSettings[];\n // Apply transforms to the data before rendering the table.\n transforms?: Transform[];\n}\n\n/**\n * Creates the initial/empty options for a Table panel.\n */\nexport function createInitialTableOptions(): TableOptions {\n return {\n density: 'standard',\n enableFiltering: true,\n };\n}\n\nexport type TableSettingsEditorProps = OptionsEditorProps<TableOptions>;\n\n/**\n * Formats the display text and colors based on cell settings\n */\nexport function formatCellDisplay(value: unknown, setting: CellSettings, defaultText?: string): TableCellConfig {\n const baseText = setting.text || defaultText || String(value);\n const displayText = `${setting.prefix ?? ''}${baseText}${setting.suffix ?? ''}`;\n return {\n text: displayText,\n textColor: setting.textColor,\n backgroundColor: setting.backgroundColor,\n };\n}\n\n/**\n * Evaluates if a condition matches the given value\n */\nexport function evaluateCondition(condition: Condition, value: unknown): boolean {\n switch (condition.kind) {\n case 'Value':\n return condition.spec?.value === String(value);\n\n case 'Range': {\n if (Number.isNaN(Number(value))) return false;\n const numericValue = Number(value);\n\n // Both min and max defined\n if (condition.spec?.min !== undefined && condition.spec?.max !== undefined) {\n return numericValue >= +condition.spec.min && numericValue <= +condition.spec.max;\n }\n\n // Only min defined\n if (condition.spec?.min !== undefined) {\n return numericValue >= +condition.spec.min;\n }\n\n // Only max defined\n if (condition.spec?.max !== undefined) {\n return numericValue <= +condition.spec.max;\n }\n\n return false;\n }\n\n case 'Regex':\n if (!condition.spec?.expr) return false;\n try {\n const regex = new RegExp(condition.spec.expr);\n return regex.test(String(value));\n } catch {\n return false; // Invalid regex\n }\n\n case 'Misc':\n switch (condition.spec?.value) {\n case 'empty':\n return value === '';\n case 'null':\n return value === null || value === undefined;\n case 'NaN':\n return Number.isNaN(value);\n case 'true':\n return value === true;\n case 'false':\n return value === false;\n default:\n return false;\n }\n\n default:\n return false;\n }\n}\n\n/**\n * Evaluates all conditions and returns the cell config for the first matching condition\n */\nexport function evaluateConditionalFormatting(value: unknown, settings: CellSettings[]): TableCellConfig | undefined {\n for (const setting of settings) {\n if (evaluateCondition(setting.condition, value)) {\n // Handle special default text cases\n let defaultText: string | undefined;\n if (setting.condition.kind === 'Misc') {\n switch (setting.condition.spec?.value) {\n case 'null':\n defaultText = 'null';\n break;\n case 'NaN':\n defaultText = 'NaN';\n break;\n }\n }\n\n return formatCellDisplay(value, setting, defaultText);\n }\n }\n\n return undefined; // No conditions matched\n}\n\n/**\n * Renders the condition editor component for a given condition\n * This function can be used by both CellEditor and ColumnEditor to maintain consistency\n */\nexport function renderConditionEditor(\n condition: Condition,\n onChange: (condition: Condition) => void,\n size: 'small' | 'medium' = 'small'\n): React.ReactElement | null {\n if (condition.kind === 'Value') {\n return React.createElement(TextField, {\n label: 'Value',\n placeholder: 'Exact value',\n value: condition.spec?.value ?? '',\n onChange: (e: { target: { value: string } }) =>\n onChange({ ...condition, spec: { value: e.target.value } } as ValueCondition),\n fullWidth: true,\n size: size,\n });\n } else if (condition.kind === 'Range') {\n return React.createElement(\n Stack,\n {\n gap: 1,\n direction: 'row',\n },\n [\n React.createElement(TextField, {\n key: 'min',\n label: 'From',\n placeholder: 'Start of range',\n value: condition.spec?.min ?? '',\n onChange: (e: { target: { value: string } }) =>\n onChange({ ...condition, spec: { ...condition.spec, min: +e.target.value } } as RangeCondition),\n fullWidth: true,\n size: size,\n }),\n React.createElement(TextField, {\n key: 'max',\n label: 'To',\n placeholder: 'End of range (inclusive)',\n value: condition.spec?.max ?? '',\n onChange: (e: { target: { value: string } }) =>\n onChange({ ...condition, spec: { ...condition.spec, max: +e.target.value } } as RangeCondition),\n fullWidth: true,\n size: size,\n }),\n ]\n );\n } else if (condition.kind === 'Regex') {\n return React.createElement(TextField, {\n label: 'Regular Expression',\n placeholder: 'JavaScript regular expression',\n value: condition.spec?.expr ?? '',\n onChange: (e: { target: { value: string } }) =>\n onChange({ ...condition, spec: { expr: e.target.value } } as RegexCondition),\n fullWidth: true,\n size: size,\n });\n } else if (condition.kind === 'Misc') {\n const options = [\n { value: 'empty', label: 'Empty', caption: 'Matches empty string' },\n { value: 'null', label: 'Null', caption: 'Matches null or undefined' },\n { value: 'NaN', label: 'NaN', caption: 'Matches Not a Number value' },\n { value: 'true', label: 'True', caption: 'Matches true boolean' },\n { value: 'false', label: 'False', caption: 'Matches false boolean' },\n ];\n\n return React.createElement(\n TextField,\n {\n select: true,\n label: 'Value',\n value: condition.spec?.value ?? '',\n onChange: (e: { target: { value: string } }) =>\n onChange({ ...condition, spec: { value: e.target.value } } as MiscCondition),\n fullWidth: true,\n size: size,\n },\n options.map((option) =>\n React.createElement(\n MenuItem,\n {\n key: option.value,\n value: option.value,\n },\n React.createElement(Stack, { key: 'stack' }, [\n React.createElement(Typography, { key: 'title' }, option.label),\n React.createElement(\n Typography,\n {\n key: 'caption',\n variant: 'caption',\n },\n option.caption\n ),\n ])\n )\n )\n );\n }\n return null;\n}\n"],"names":["React","TextField","Stack","MenuItem","Typography","createInitialTableOptions","density","enableFiltering","formatCellDisplay","value","setting","defaultText","baseText","text","String","displayText","prefix","suffix","textColor","backgroundColor","evaluateCondition","condition","kind","spec","Number","isNaN","numericValue","min","undefined","max","expr","regex","RegExp","test","evaluateConditionalFormatting","settings","renderConditionEditor","onChange","size","createElement","label","placeholder","e","target","fullWidth","gap","direction","key","options","caption","select","map","option","variant"],"mappings":"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"}
|