@perses-dev/dashboards 0.10.0 → 0.12.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 (225) hide show
  1. package/dist/cjs/components/Dashboard.js +4 -5
  2. package/dist/cjs/components/DashboardToolbar.js +18 -5
  3. package/dist/cjs/components/GridLayout/GridItemContent.js +3 -11
  4. package/dist/cjs/components/GridLayout/GridLayout.js +20 -20
  5. package/dist/cjs/components/GridLayout/GridTitle.js +9 -11
  6. package/dist/cjs/components/Panel/DeletePanelDialog.js +12 -10
  7. package/dist/cjs/components/Panel/Panel.js +12 -22
  8. package/dist/cjs/components/Panel/Panel.test.js +5 -3
  9. package/dist/cjs/components/Panel/index.js +1 -0
  10. package/dist/cjs/components/PanelDrawer/PanelDrawer.js +1 -1
  11. package/dist/cjs/components/PanelDrawer/PanelDrawer.test.js +13 -5
  12. package/dist/cjs/components/PanelDrawer/PanelEditorForm.js +21 -15
  13. package/dist/cjs/components/PanelDrawer/PanelPreview.js +9 -3
  14. package/dist/cjs/components/PanelGroupDialog/DeletePanelGroupDialog.js +13 -11
  15. package/dist/cjs/components/PanelGroupDialog/PanelGroupDialog.js +70 -111
  16. package/dist/cjs/components/PanelGroupDialog/PanelGroupDialog.test.js +22 -16
  17. package/dist/cjs/components/PanelGroupDialog/PanelGroupEditorForm.js +92 -0
  18. package/dist/cjs/components/PanelGroupDialog/index.js +29 -0
  19. package/dist/cjs/components/TimeRangeControls/TimeRangeControls.js +8 -11
  20. package/dist/cjs/components/TimeRangeControls/TimeRangeControls.test.js +20 -13
  21. package/dist/cjs/components/Variables/Variable.js +1 -0
  22. package/dist/cjs/components/Variables/VariableEditor.js +40 -6
  23. package/dist/cjs/components/Variables/VariableEditorForm/VariableEditorForm.js +9 -5
  24. package/dist/cjs/components/Variables/VariableList.js +0 -1
  25. package/dist/cjs/components/index.js +1 -0
  26. package/dist/cjs/context/DashboardProvider/DashboardProvider.js +26 -8
  27. package/dist/cjs/context/DashboardProvider/common.js +10 -0
  28. package/dist/cjs/context/DashboardProvider/dashboard-provider-api.js +122 -29
  29. package/dist/cjs/context/DashboardProvider/delete-panel-group-slice.js +70 -0
  30. package/dist/cjs/context/DashboardProvider/delete-panel-slice.js +85 -0
  31. package/dist/cjs/context/DashboardProvider/panel-editor-slice.js +182 -0
  32. package/dist/cjs/context/DashboardProvider/panel-group-editor-slice.js +89 -0
  33. package/dist/cjs/context/DashboardProvider/panel-group-slice.js +83 -18
  34. package/dist/cjs/context/DashboardProvider/panel-slice.js +36 -0
  35. package/dist/cjs/context/TimeRangeProvider.js +20 -44
  36. package/dist/cjs/context/index.js +1 -1
  37. package/dist/cjs/context/useDashboardSpec.js +90 -0
  38. package/dist/cjs/index.js +1 -0
  39. package/dist/cjs/test/render.js +25 -5
  40. package/dist/cjs/test/setup-tests.js +4 -1
  41. package/dist/cjs/test/testDashboard.js +11 -10
  42. package/dist/cjs/utils/index.js +28 -0
  43. package/dist/cjs/utils/time-range-params.js +151 -0
  44. package/dist/cjs/views/ViewDashboard/DashboardApp.js +2 -5
  45. package/dist/cjs/views/ViewDashboard/ViewDashboard.js +5 -22
  46. package/dist/cjs/views/ViewDashboard/tests/panelGroups.test.js +42 -93
  47. package/dist/components/Dashboard.js +5 -6
  48. package/dist/components/Dashboard.js.map +1 -1
  49. package/dist/components/DashboardToolbar.d.ts.map +1 -1
  50. package/dist/components/DashboardToolbar.js +20 -7
  51. package/dist/components/DashboardToolbar.js.map +1 -1
  52. package/dist/components/GridLayout/GridItemContent.d.ts +2 -4
  53. package/dist/components/GridLayout/GridItemContent.d.ts.map +1 -1
  54. package/dist/components/GridLayout/GridItemContent.js +4 -12
  55. package/dist/components/GridLayout/GridItemContent.js.map +1 -1
  56. package/dist/components/GridLayout/GridLayout.d.ts +2 -3
  57. package/dist/components/GridLayout/GridLayout.d.ts.map +1 -1
  58. package/dist/components/GridLayout/GridLayout.js +22 -22
  59. package/dist/components/GridLayout/GridLayout.js.map +1 -1
  60. package/dist/components/GridLayout/GridTitle.d.ts +2 -1
  61. package/dist/components/GridLayout/GridTitle.d.ts.map +1 -1
  62. package/dist/components/GridLayout/GridTitle.js +10 -12
  63. package/dist/components/GridLayout/GridTitle.js.map +1 -1
  64. package/dist/components/Panel/DeletePanelDialog.d.ts +0 -1
  65. package/dist/components/Panel/DeletePanelDialog.d.ts.map +1 -1
  66. package/dist/components/Panel/DeletePanelDialog.js +13 -11
  67. package/dist/components/Panel/DeletePanelDialog.js.map +1 -1
  68. package/dist/components/Panel/Panel.d.ts +2 -2
  69. package/dist/components/Panel/Panel.d.ts.map +1 -1
  70. package/dist/components/Panel/Panel.js +12 -22
  71. package/dist/components/Panel/Panel.js.map +1 -1
  72. package/dist/components/Panel/Panel.test.d.ts +1 -1
  73. package/dist/components/Panel/Panel.test.d.ts.map +1 -1
  74. package/dist/components/Panel/Panel.test.js +5 -3
  75. package/dist/components/Panel/Panel.test.js.map +1 -1
  76. package/dist/components/Panel/index.d.ts +1 -0
  77. package/dist/components/Panel/index.d.ts.map +1 -1
  78. package/dist/components/Panel/index.js +1 -0
  79. package/dist/components/Panel/index.js.map +1 -1
  80. package/dist/components/PanelDrawer/PanelDrawer.js +2 -2
  81. package/dist/components/PanelDrawer/PanelDrawer.js.map +1 -1
  82. package/dist/components/PanelDrawer/PanelDrawer.test.js +13 -5
  83. package/dist/components/PanelDrawer/PanelDrawer.test.js.map +1 -1
  84. package/dist/components/PanelDrawer/PanelEditorForm.d.ts +1 -1
  85. package/dist/components/PanelDrawer/PanelEditorForm.d.ts.map +1 -1
  86. package/dist/components/PanelDrawer/PanelEditorForm.js +22 -16
  87. package/dist/components/PanelDrawer/PanelEditorForm.js.map +1 -1
  88. package/dist/components/PanelDrawer/PanelPreview.d.ts +2 -2
  89. package/dist/components/PanelDrawer/PanelPreview.d.ts.map +1 -1
  90. package/dist/components/PanelDrawer/PanelPreview.js +9 -3
  91. package/dist/components/PanelDrawer/PanelPreview.js.map +1 -1
  92. package/dist/components/PanelGroupDialog/DeletePanelGroupDialog.d.ts +1 -2
  93. package/dist/components/PanelGroupDialog/DeletePanelGroupDialog.d.ts.map +1 -1
  94. package/dist/components/PanelGroupDialog/DeletePanelGroupDialog.js +13 -11
  95. package/dist/components/PanelGroupDialog/DeletePanelGroupDialog.js.map +1 -1
  96. package/dist/components/PanelGroupDialog/PanelGroupDialog.d.ts +4 -2
  97. package/dist/components/PanelGroupDialog/PanelGroupDialog.d.ts.map +1 -1
  98. package/dist/components/PanelGroupDialog/PanelGroupDialog.js +73 -112
  99. package/dist/components/PanelGroupDialog/PanelGroupDialog.js.map +1 -1
  100. package/dist/components/PanelGroupDialog/PanelGroupDialog.test.js +21 -15
  101. package/dist/components/PanelGroupDialog/PanelGroupDialog.test.js.map +1 -1
  102. package/dist/components/PanelGroupDialog/PanelGroupEditorForm.d.ts +12 -0
  103. package/dist/components/PanelGroupDialog/PanelGroupEditorForm.d.ts.map +1 -0
  104. package/dist/components/PanelGroupDialog/PanelGroupEditorForm.js +82 -0
  105. package/dist/components/PanelGroupDialog/PanelGroupEditorForm.js.map +1 -0
  106. package/dist/components/PanelGroupDialog/index.d.ts +3 -0
  107. package/dist/components/PanelGroupDialog/index.d.ts.map +1 -0
  108. package/dist/components/PanelGroupDialog/index.js +16 -0
  109. package/dist/components/PanelGroupDialog/index.js.map +1 -0
  110. package/dist/components/TimeRangeControls/TimeRangeControls.d.ts.map +1 -1
  111. package/dist/components/TimeRangeControls/TimeRangeControls.js +11 -14
  112. package/dist/components/TimeRangeControls/TimeRangeControls.js.map +1 -1
  113. package/dist/components/TimeRangeControls/TimeRangeControls.test.js +21 -14
  114. package/dist/components/TimeRangeControls/TimeRangeControls.test.js.map +1 -1
  115. package/dist/components/Variables/Variable.js +1 -0
  116. package/dist/components/Variables/Variable.js.map +1 -1
  117. package/dist/components/Variables/VariableEditor.d.ts.map +1 -1
  118. package/dist/components/Variables/VariableEditor.js +40 -6
  119. package/dist/components/Variables/VariableEditor.js.map +1 -1
  120. package/dist/components/Variables/VariableEditorForm/VariableEditorForm.d.ts.map +1 -1
  121. package/dist/components/Variables/VariableEditorForm/VariableEditorForm.js +9 -5
  122. package/dist/components/Variables/VariableEditorForm/VariableEditorForm.js.map +1 -1
  123. package/dist/components/Variables/VariableList.js +0 -1
  124. package/dist/components/Variables/VariableList.js.map +1 -1
  125. package/dist/components/index.d.ts +1 -0
  126. package/dist/components/index.d.ts.map +1 -1
  127. package/dist/components/index.js +1 -0
  128. package/dist/components/index.js.map +1 -1
  129. package/dist/context/DashboardProvider/DashboardProvider.d.ts +10 -5
  130. package/dist/context/DashboardProvider/DashboardProvider.d.ts.map +1 -1
  131. package/dist/context/DashboardProvider/DashboardProvider.js +26 -8
  132. package/dist/context/DashboardProvider/DashboardProvider.js.map +1 -1
  133. package/dist/context/DashboardProvider/common.d.ts +7 -0
  134. package/dist/context/DashboardProvider/common.d.ts.map +1 -1
  135. package/dist/context/DashboardProvider/common.js +8 -1
  136. package/dist/context/DashboardProvider/common.js.map +1 -1
  137. package/dist/context/DashboardProvider/dashboard-provider-api.d.ts +65 -22
  138. package/dist/context/DashboardProvider/dashboard-provider-api.d.ts.map +1 -1
  139. package/dist/context/DashboardProvider/dashboard-provider-api.js +133 -26
  140. package/dist/context/DashboardProvider/dashboard-provider-api.js.map +1 -1
  141. package/dist/context/DashboardProvider/delete-panel-group-slice.d.ts +23 -0
  142. package/dist/context/DashboardProvider/delete-panel-group-slice.d.ts.map +1 -0
  143. package/dist/context/DashboardProvider/delete-panel-group-slice.js +64 -0
  144. package/dist/context/DashboardProvider/delete-panel-group-slice.js.map +1 -0
  145. package/dist/context/DashboardProvider/delete-panel-slice.d.ts +36 -0
  146. package/dist/context/DashboardProvider/delete-panel-slice.d.ts.map +1 -0
  147. package/dist/context/DashboardProvider/delete-panel-slice.js +81 -0
  148. package/dist/context/DashboardProvider/delete-panel-slice.js.map +1 -0
  149. package/dist/context/DashboardProvider/index.d.ts +3 -0
  150. package/dist/context/DashboardProvider/index.d.ts.map +1 -1
  151. package/dist/context/DashboardProvider/index.js.map +1 -1
  152. package/dist/context/DashboardProvider/panel-editor-slice.d.ts +56 -0
  153. package/dist/context/DashboardProvider/panel-editor-slice.d.ts.map +1 -0
  154. package/dist/context/DashboardProvider/panel-editor-slice.js +178 -0
  155. package/dist/context/DashboardProvider/panel-editor-slice.js.map +1 -0
  156. package/dist/context/DashboardProvider/panel-group-editor-slice.d.ts +33 -0
  157. package/dist/context/DashboardProvider/panel-group-editor-slice.d.ts.map +1 -0
  158. package/dist/context/DashboardProvider/panel-group-editor-slice.js +83 -0
  159. package/dist/context/DashboardProvider/panel-group-editor-slice.js.map +1 -0
  160. package/dist/context/DashboardProvider/panel-group-slice.d.ts +60 -11
  161. package/dist/context/DashboardProvider/panel-group-slice.d.ts.map +1 -1
  162. package/dist/context/DashboardProvider/panel-group-slice.js +85 -18
  163. package/dist/context/DashboardProvider/panel-group-slice.js.map +1 -1
  164. package/dist/context/DashboardProvider/panel-slice.d.ts +23 -0
  165. package/dist/context/DashboardProvider/panel-slice.d.ts.map +1 -0
  166. package/dist/context/DashboardProvider/panel-slice.js +32 -0
  167. package/dist/context/DashboardProvider/panel-slice.js.map +1 -0
  168. package/dist/context/TimeRangeProvider.d.ts +9 -2
  169. package/dist/context/TimeRangeProvider.d.ts.map +1 -1
  170. package/dist/context/TimeRangeProvider.js +15 -43
  171. package/dist/context/TimeRangeProvider.js.map +1 -1
  172. package/dist/context/index.d.ts +1 -1
  173. package/dist/context/index.d.ts.map +1 -1
  174. package/dist/context/index.js +1 -1
  175. package/dist/context/index.js.map +1 -1
  176. package/dist/context/useDashboardSpec.d.ts +11 -0
  177. package/dist/context/useDashboardSpec.d.ts.map +1 -0
  178. package/dist/context/useDashboardSpec.js +84 -0
  179. package/dist/context/useDashboardSpec.js.map +1 -0
  180. package/dist/index.d.ts +1 -0
  181. package/dist/index.d.ts.map +1 -1
  182. package/dist/index.js +1 -0
  183. package/dist/index.js.map +1 -1
  184. package/dist/test/render.d.ts +2 -1
  185. package/dist/test/render.d.ts.map +1 -1
  186. package/dist/test/render.js +25 -5
  187. package/dist/test/render.js.map +1 -1
  188. package/dist/test/setup-tests.d.ts.map +1 -1
  189. package/dist/test/setup-tests.js +4 -0
  190. package/dist/test/setup-tests.js.map +1 -1
  191. package/dist/test/testDashboard.d.ts.map +1 -1
  192. package/dist/test/testDashboard.js +11 -10
  193. package/dist/test/testDashboard.js.map +1 -1
  194. package/dist/utils/index.d.ts +2 -0
  195. package/dist/utils/index.d.ts.map +1 -0
  196. package/dist/utils/index.js +15 -0
  197. package/dist/utils/index.js.map +1 -0
  198. package/dist/utils/time-range-params.d.ts +25 -0
  199. package/dist/utils/time-range-params.d.ts.map +1 -0
  200. package/dist/utils/time-range-params.js +143 -0
  201. package/dist/utils/time-range-params.js.map +1 -0
  202. package/dist/views/ViewDashboard/DashboardApp.d.ts.map +1 -1
  203. package/dist/views/ViewDashboard/DashboardApp.js +1 -4
  204. package/dist/views/ViewDashboard/DashboardApp.js.map +1 -1
  205. package/dist/views/ViewDashboard/ViewDashboard.d.ts.map +1 -1
  206. package/dist/views/ViewDashboard/ViewDashboard.js +5 -22
  207. package/dist/views/ViewDashboard/ViewDashboard.js.map +1 -1
  208. package/dist/views/ViewDashboard/tests/panelGroups.test.js +45 -96
  209. package/dist/views/ViewDashboard/tests/panelGroups.test.js.map +1 -1
  210. package/package.json +5 -4
  211. package/dist/cjs/context/DashboardProvider/layout-slice.js +0 -200
  212. package/dist/cjs/context/DashboardProvider/panel-editing-slice.js +0 -156
  213. package/dist/cjs/context/QueryStringProvider.js +0 -89
  214. package/dist/context/DashboardProvider/layout-slice.d.ts +0 -57
  215. package/dist/context/DashboardProvider/layout-slice.d.ts.map +0 -1
  216. package/dist/context/DashboardProvider/layout-slice.js +0 -196
  217. package/dist/context/DashboardProvider/layout-slice.js.map +0 -1
  218. package/dist/context/DashboardProvider/panel-editing-slice.d.ts +0 -70
  219. package/dist/context/DashboardProvider/panel-editing-slice.d.ts.map +0 -1
  220. package/dist/context/DashboardProvider/panel-editing-slice.js +0 -152
  221. package/dist/context/DashboardProvider/panel-editing-slice.js.map +0 -1
  222. package/dist/context/QueryStringProvider.d.ts +0 -13
  223. package/dist/context/QueryStringProvider.d.ts.map +0 -1
  224. package/dist/context/QueryStringProvider.js +0 -40
  225. package/dist/context/QueryStringProvider.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/PanelGroupDialog/DeletePanelGroupDialog.tsx"],"sourcesContent":["// Copyright 2022 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 { FormEvent } from 'react';\nimport { IconButton, Dialog, DialogTitle, DialogContent, DialogActions, Button } from '@mui/material';\nimport CloseIcon from 'mdi-material-ui/Close';\nimport { usePanelGroupDialog, useLayouts } from '../../context';\n\nconst DeletePanelGroupDialog = () => {\n const { layouts, deletePanelGroup } = useLayouts();\n const { deletePanelGroupDialog, closeDeletePanelGroupDialog } = usePanelGroupDialog();\n\n const groupIndex = deletePanelGroupDialog?.groupIndex;\n\n const handleDelete = (e: FormEvent) => {\n e.preventDefault();\n if (groupIndex == undefined) {\n throw new Error('group index is undefined');\n }\n deletePanelGroup(groupIndex);\n closeDeletePanelGroupDialog();\n };\n\n return (\n <Dialog open={deletePanelGroupDialog !== undefined}>\n <DialogTitle>Delete Panel Group</DialogTitle>\n <IconButton\n aria-label=\"Close\"\n onClick={() => closeDeletePanelGroupDialog()}\n sx={(theme) => ({\n position: 'absolute',\n top: theme.spacing(0.5),\n right: theme.spacing(0.5),\n })}\n >\n <CloseIcon />\n </IconButton>\n <form onSubmit={handleDelete}>\n <DialogContent sx={{ width: '500px' }}>\n {`Are you sure you want to delete ${\n groupIndex !== undefined && layouts[groupIndex] !== undefined ? layouts[groupIndex]?.title : 'panel group'\n }? This will delete all the panels within the group.`}\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" type=\"submit\">\n Delete\n </Button>\n <Button onClick={() => closeDeletePanelGroupDialog()}>Cancel</Button>\n </DialogActions>\n </form>\n </Dialog>\n );\n};\n\nexport default DeletePanelGroupDialog;\n"],"names":["IconButton","Dialog","DialogTitle","DialogContent","DialogActions","Button","CloseIcon","usePanelGroupDialog","useLayouts","DeletePanelGroupDialog","layouts","deletePanelGroup","deletePanelGroupDialog","closeDeletePanelGroupDialog","groupIndex","handleDelete","e","preventDefault","undefined","Error","open","aria-label","onClick","sx","theme","position","top","spacing","right","form","onSubmit","width","title","variant","type"],"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;AACA,SAASA,UAAU,EAAEC,MAAM,EAAEC,WAAW,EAAEC,aAAa,EAAEC,aAAa,EAAEC,MAAM,QAAQ,eAAe,CAAC;AACtG,OAAOC,SAAS,MAAM,uBAAuB,CAAC;AAC9C,SAASC,mBAAmB,EAAEC,UAAU,QAAQ,eAAe,CAAC;AAEhE,MAAMC,sBAAsB,GAAG,IAAM;QAgCuCC,GAAmB;IA/B7F,MAAM,EAAEA,OAAO,CAAA,EAAEC,gBAAgB,CAAA,EAAE,GAAGH,UAAU,EAAE,AAAC;IACnD,MAAM,EAAEI,sBAAsB,CAAA,EAAEC,2BAA2B,CAAA,EAAE,GAAGN,mBAAmB,EAAE,AAAC;IAEtF,MAAMO,UAAU,GAAGF,sBAAsB,aAAtBA,sBAAsB,WAAY,GAAlCA,KAAAA,CAAkC,GAAlCA,sBAAsB,CAAEE,UAAU,AAAC;IAEtD,MAAMC,YAAY,GAAG,CAACC,CAAY,GAAK;QACrCA,CAAC,CAACC,cAAc,EAAE,CAAC;QACnB,IAAIH,UAAU,IAAII,SAAS,EAAE;YAC3B,MAAM,IAAIC,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAC9C,CAAC;QACDR,gBAAgB,CAACG,UAAU,CAAC,CAAC;QAC7BD,2BAA2B,EAAE,CAAC;IAChC,CAAC,AAAC;IAEF,qBACE,MAACZ,MAAM;QAACmB,IAAI,EAAER,sBAAsB,KAAKM,SAAS;;0BAChD,KAAChB,WAAW;0BAAC,oBAAkB;cAAc;0BAC7C,KAACF,UAAU;gBACTqB,YAAU,EAAC,OAAO;gBAClBC,OAAO,EAAE,IAAMT,2BAA2B,EAAE;gBAC5CU,EAAE,EAAE,CAACC,KAAK,GAAM,CAAA;wBACdC,QAAQ,EAAE,UAAU;wBACpBC,GAAG,EAAEF,KAAK,CAACG,OAAO,CAAC,GAAG,CAAC;wBACvBC,KAAK,EAAEJ,KAAK,CAACG,OAAO,CAAC,GAAG,CAAC;qBAC1B,CAAA,AAAC;0BAEF,cAAA,KAACrB,SAAS,KAAG;cACF;0BACb,MAACuB,MAAI;gBAACC,QAAQ,EAAEf,YAAY;;kCAC1B,KAACZ,aAAa;wBAACoB,EAAE,EAAE;4BAAEQ,KAAK,EAAE,OAAO;yBAAE;kCAClC,CAAC,gCAAgC,EAChCjB,UAAU,KAAKI,SAAS,IAAIR,OAAO,CAACI,UAAU,CAAC,KAAKI,SAAS,GAAGR,CAAAA,GAAmB,GAAnBA,OAAO,CAACI,UAAU,CAAC,cAAnBJ,GAAmB,WAAO,GAA1BA,KAAAA,CAA0B,GAA1BA,GAAmB,CAAEsB,KAAK,GAAG,aAAa,CAC3G,mDAAmD,CAAC;sBACvC;kCAChB,MAAC5B,aAAa;;0CACZ,KAACC,MAAM;gCAAC4B,OAAO,EAAC,WAAW;gCAACC,IAAI,EAAC,QAAQ;0CAAC,QAE1C;8BAAS;0CACT,KAAC7B,MAAM;gCAACiB,OAAO,EAAE,IAAMT,2BAA2B,EAAE;0CAAE,QAAM;8BAAS;;sBACvD;;cACX;;MACA,CACT;AACJ,CAAC,AAAC;AAEF,eAAeJ,sBAAsB,CAAC"}
1
+ {"version":3,"sources":["../../../src/components/PanelGroupDialog/DeletePanelGroupDialog.tsx"],"sourcesContent":["// Copyright 2022 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 { FormEvent } from 'react';\nimport { IconButton, Dialog, DialogTitle, DialogContent, DialogActions, Button } from '@mui/material';\nimport CloseIcon from 'mdi-material-ui/Close';\nimport { useDeletePanelGroupDialog } from '../../context';\n\nexport const DeletePanelGroupDialog = () => {\n const { deletePanelGroupDialog, closeDeletePanelGroupDialog, deletePanelGroup } = useDeletePanelGroupDialog();\n\n const panelGroupId = deletePanelGroupDialog?.panelGroupId;\n\n const handleDelete = (e: FormEvent) => {\n e.preventDefault();\n if (panelGroupId == undefined) {\n throw new Error('group index is undefined');\n }\n deletePanelGroup(panelGroupId);\n closeDeletePanelGroupDialog();\n };\n\n return (\n <Dialog open={deletePanelGroupDialog !== undefined}>\n <DialogTitle>Delete Panel Group</DialogTitle>\n <IconButton\n aria-label=\"Close\"\n onClick={() => closeDeletePanelGroupDialog()}\n sx={(theme) => ({\n position: 'absolute',\n top: theme.spacing(0.5),\n right: theme.spacing(0.5),\n })}\n >\n <CloseIcon />\n </IconButton>\n <form onSubmit={handleDelete}>\n <DialogContent sx={{ width: '500px' }}>\n Are you sure you want to delete {deletePanelGroupDialog?.panelGroupName ?? 'panel group'}? This will delete\n all the panels within the group.\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" type=\"submit\">\n Delete\n </Button>\n <Button onClick={() => closeDeletePanelGroupDialog()}>Cancel</Button>\n </DialogActions>\n </form>\n </Dialog>\n );\n};\n"],"names":["IconButton","Dialog","DialogTitle","DialogContent","DialogActions","Button","CloseIcon","useDeletePanelGroupDialog","DeletePanelGroupDialog","deletePanelGroupDialog","closeDeletePanelGroupDialog","deletePanelGroup","panelGroupId","handleDelete","e","preventDefault","undefined","Error","open","aria-label","onClick","sx","theme","position","top","spacing","right","form","onSubmit","width","panelGroupName","variant","type"],"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;AACA,SAASA,UAAU,EAAEC,MAAM,EAAEC,WAAW,EAAEC,aAAa,EAAEC,aAAa,EAAEC,MAAM,QAAQ,eAAe,CAAC;AACtG,OAAOC,SAAS,MAAM,uBAAuB,CAAC;AAC9C,SAASC,yBAAyB,QAAQ,eAAe,CAAC;AAE1D,OAAO,MAAMC,sBAAsB,GAAG,IAAM;IAC1C,MAAM,EAAEC,sBAAsB,CAAA,EAAEC,2BAA2B,CAAA,EAAEC,gBAAgB,CAAA,EAAE,GAAGJ,yBAAyB,EAAE,AAAC;IAE9G,MAAMK,YAAY,GAAGH,sBAAsB,aAAtBA,sBAAsB,WAAc,GAApCA,KAAAA,CAAoC,GAApCA,sBAAsB,CAAEG,YAAY,AAAC;IAE1D,MAAMC,YAAY,GAAG,CAACC,CAAY,GAAK;QACrCA,CAAC,CAACC,cAAc,EAAE,CAAC;QACnB,IAAIH,YAAY,IAAII,SAAS,EAAE;YAC7B,MAAM,IAAIC,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAC9C,CAAC;QACDN,gBAAgB,CAACC,YAAY,CAAC,CAAC;QAC/BF,2BAA2B,EAAE,CAAC;IAChC,CAAC,AAAC;QAkBuCD,GAAsC;IAhB/E,qBACE,MAACR,MAAM;QAACiB,IAAI,EAAET,sBAAsB,KAAKO,SAAS;;0BAChD,KAACd,WAAW;0BAAC,oBAAkB;cAAc;0BAC7C,KAACF,UAAU;gBACTmB,YAAU,EAAC,OAAO;gBAClBC,OAAO,EAAE,IAAMV,2BAA2B,EAAE;gBAC5CW,EAAE,EAAE,CAACC,KAAK,GAAM,CAAA;wBACdC,QAAQ,EAAE,UAAU;wBACpBC,GAAG,EAAEF,KAAK,CAACG,OAAO,CAAC,GAAG,CAAC;wBACvBC,KAAK,EAAEJ,KAAK,CAACG,OAAO,CAAC,GAAG,CAAC;qBAC1B,CAAA,AAAC;0BAEF,cAAA,KAACnB,SAAS,KAAG;cACF;0BACb,MAACqB,MAAI;gBAACC,QAAQ,EAAEf,YAAY;;kCAC1B,MAACV,aAAa;wBAACkB,EAAE,EAAE;4BAAEQ,KAAK,EAAE,OAAO;yBAAE;;4BAAE,kCACL;4BAACpB,CAAAA,GAAsC,GAAtCA,sBAAsB,aAAtBA,sBAAsB,WAAgB,GAAtCA,KAAAA,CAAsC,GAAtCA,sBAAsB,CAAEqB,cAAc,cAAtCrB,GAAsC,cAAtCA,GAAsC,GAAI,aAAa;4BAAC,qDAE3F;;sBAAgB;kCAChB,MAACL,aAAa;;0CACZ,KAACC,MAAM;gCAAC0B,OAAO,EAAC,WAAW;gCAACC,IAAI,EAAC,QAAQ;0CAAC,QAE1C;8BAAS;0CACT,KAAC3B,MAAM;gCAACe,OAAO,EAAE,IAAMV,2BAA2B,EAAE;0CAAE,QAAM;8BAAS;;sBACvD;;cACX;;MACA,CACT;AACJ,CAAC,CAAC"}
@@ -1,4 +1,6 @@
1
1
  /// <reference types="react" />
2
- declare const PanelGroupDialog: () => JSX.Element;
3
- export default PanelGroupDialog;
2
+ /**
3
+ * A dialog for adding or editing a Panel Group. Open and initial state is controlled by the DashboardStore.
4
+ */
5
+ export declare function PanelGroupDialog(): JSX.Element;
4
6
  //# sourceMappingURL=PanelGroupDialog.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"PanelGroupDialog.d.ts","sourceRoot":"","sources":["../../../src/components/PanelGroupDialog/PanelGroupDialog.tsx"],"names":[],"mappings":";AAkCA,QAAA,MAAM,gBAAgB,mBAkFrB,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"PanelGroupDialog.d.ts","sourceRoot":"","sources":["../../../src/components/PanelGroupDialog/PanelGroupDialog.tsx"],"names":[],"mappings":";AAmBA;;GAEG;AACH,wBAAgB,gBAAgB,gBAsD/B"}
@@ -10,122 +10,83 @@
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
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
14
- import { useState } from 'react';
15
- import { IconButton, Dialog, DialogTitle, DialogContent, FormControl, InputLabel, TextField, Stack, Box, DialogActions, Button, Select, MenuItem } from '@mui/material';
13
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
14
+ import { IconButton, Dialog, DialogTitle, DialogContent, DialogActions, Button } from '@mui/material';
16
15
  import CloseIcon from 'mdi-material-ui/Close';
17
- import { usePanelGroupDialog, useLayouts } from '../../context';
18
- const PanelGroupDialog = ()=>{
19
- var ref, ref1;
20
- const { layouts , updatePanelGroup } = useLayouts();
21
- const { panelGroupDialog , closePanelGroupDialog } = usePanelGroupDialog();
22
- const groupIndex = panelGroupDialog === null || panelGroupDialog === void 0 ? void 0 : panelGroupDialog.groupIndex;
23
- const isEditingPanelGroup = groupIndex !== undefined;
24
- const [isCollapsed, setIsCollapsed] = useState(isEditingPanelGroup && ((ref = layouts[groupIndex]) === null || ref === void 0 ? void 0 : ref.isCollapsed));
25
- const [name, setName] = useState(isEditingPanelGroup ? (ref1 = layouts[groupIndex]) === null || ref1 === void 0 ? void 0 : ref1.title : '');
26
- const handleSubmit = (e)=>{
27
- var ref;
28
- e.preventDefault();
29
- var ref1;
30
- const newGroup = {
31
- isCollapsed,
32
- title: name !== null && name !== void 0 ? name : '',
33
- items: groupIndex === undefined ? [] : (ref1 = (ref = layouts[groupIndex]) === null || ref === void 0 ? void 0 : ref.items) !== null && ref1 !== void 0 ? ref1 : []
34
- };
35
- updatePanelGroup(newGroup, groupIndex);
36
- closePanelGroupDialog();
16
+ import { useState } from 'react';
17
+ import { usePanelGroupEditor } from '../../context';
18
+ import { PanelGroupEditorForm, panelGroupEditorFormId } from './PanelGroupEditorForm';
19
+ /**
20
+ * A dialog for adding or editing a Panel Group. Open and initial state is controlled by the DashboardStore.
21
+ */ export function PanelGroupDialog() {
22
+ const panelGroupEditor = usePanelGroupEditor();
23
+ // When the user clicks close, start closing but don't call the store yet to keep values stable during animtation
24
+ const [isClosing, setIsClosing] = useState(false);
25
+ const handleClose = ()=>setIsClosing(true);
26
+ // Don't call close on the store until the Dialog has completely transitioned out
27
+ const handleExited = ()=>{
28
+ panelGroupEditor === null || panelGroupEditor === void 0 ? void 0 : panelGroupEditor.close();
29
+ setIsClosing(false);
37
30
  };
38
- const handleSelectCollapsedStateChange = (e)=>{
39
- const isCollapsed = e.target.value === 'Close';
40
- setIsCollapsed(isCollapsed);
31
+ // Dialog is open if we have a model and we're not transitioning out
32
+ const isOpen = panelGroupEditor !== undefined && isClosing === false;
33
+ const handleSubmit = (values)=>{
34
+ // This shouldn't happen since we don't render the submit button until we have a model, but check to make TS happy
35
+ if (panelGroupEditor === undefined) {
36
+ throw new Error('Cannot apply changes');
37
+ }
38
+ panelGroupEditor.applyChanges(values);
39
+ handleClose();
41
40
  };
42
- return /*#__PURE__*/ _jsxs(Dialog, {
43
- open: panelGroupDialog !== undefined,
44
- children: [
45
- /*#__PURE__*/ _jsx(DialogTitle, {
46
- children: "Panel Group"
47
- }),
48
- /*#__PURE__*/ _jsx(IconButton, {
49
- "aria-label": "Close",
50
- onClick: ()=>closePanelGroupDialog(),
51
- sx: (theme)=>({
52
- position: 'absolute',
53
- top: theme.spacing(0.5),
54
- right: theme.spacing(0.5)
55
- }),
56
- children: /*#__PURE__*/ _jsx(CloseIcon, {})
57
- }),
58
- /*#__PURE__*/ _jsxs("form", {
59
- onSubmit: handleSubmit,
60
- children: [
61
- /*#__PURE__*/ _jsx(DialogContent, {
62
- sx: {
63
- width: '500px'
64
- },
65
- children: /*#__PURE__*/ _jsxs(Stack, {
66
- spacing: 2,
67
- children: [
68
- /*#__PURE__*/ _jsx(FormControl, {
69
- children: /*#__PURE__*/ _jsx(TextField, {
70
- required: true,
71
- label: "Name",
72
- variant: "outlined",
73
- value: name,
74
- onChange: (e)=>setName(e.target.value)
75
- })
76
- }),
77
- /*#__PURE__*/ _jsxs(Box, {
78
- sx: {
79
- display: 'flex',
80
- alignItems: 'center',
81
- width: '100%',
82
- justifyContent: 'space-between'
83
- },
84
- children: [
85
- /*#__PURE__*/ _jsx(InputLabel, {
86
- children: "Collapse State"
87
- }),
88
- /*#__PURE__*/ _jsxs(Select, {
89
- required: true,
90
- displayEmpty: true,
91
- labelId: "select-collapse-state",
92
- size: "small",
93
- value: isCollapsed ? 'Close' : 'Open',
94
- onChange: handleSelectCollapsedStateChange,
95
- children: [
96
- /*#__PURE__*/ _jsx(MenuItem, {
97
- value: 'Open',
98
- children: "Open"
99
- }, 'open'),
100
- /*#__PURE__*/ _jsx(MenuItem, {
101
- value: 'Close',
102
- children: "Close"
103
- }, 'close')
104
- ]
105
- })
106
- ]
107
- })
108
- ]
109
- })
110
- }),
111
- /*#__PURE__*/ _jsxs(DialogActions, {
112
- children: [
113
- /*#__PURE__*/ _jsx(Button, {
114
- variant: "contained",
115
- type: "submit",
116
- children: isEditingPanelGroup ? 'Apply' : 'Add'
117
- }),
118
- /*#__PURE__*/ _jsx(Button, {
119
- onClick: ()=>closePanelGroupDialog(),
120
- children: "Cancel"
121
- })
122
- ]
41
+ return /*#__PURE__*/ _jsx(Dialog, {
42
+ open: isOpen,
43
+ TransitionProps: {
44
+ onExited: handleExited
45
+ },
46
+ children: panelGroupEditor !== undefined && /*#__PURE__*/ _jsxs(_Fragment, {
47
+ children: [
48
+ /*#__PURE__*/ _jsxs(DialogTitle, {
49
+ children: [
50
+ panelGroupEditor.mode,
51
+ " Panel Group"
52
+ ]
53
+ }),
54
+ /*#__PURE__*/ _jsx(IconButton, {
55
+ "aria-label": "Close",
56
+ onClick: panelGroupEditor.close,
57
+ sx: (theme)=>({
58
+ position: 'absolute',
59
+ top: theme.spacing(0.5),
60
+ right: theme.spacing(0.5)
61
+ }),
62
+ children: /*#__PURE__*/ _jsx(CloseIcon, {})
63
+ }),
64
+ /*#__PURE__*/ _jsx(DialogContent, {
65
+ sx: {
66
+ width: '500px'
67
+ },
68
+ children: /*#__PURE__*/ _jsx(PanelGroupEditorForm, {
69
+ initialValues: panelGroupEditor.initialValues,
70
+ onSubmit: handleSubmit
123
71
  })
124
- ]
125
- })
126
- ]
72
+ }),
73
+ /*#__PURE__*/ _jsxs(DialogActions, {
74
+ children: [
75
+ /*#__PURE__*/ _jsx(Button, {
76
+ variant: "contained",
77
+ type: "submit",
78
+ form: panelGroupEditorFormId,
79
+ children: panelGroupEditor.mode === 'Edit' ? 'Apply' : 'Add'
80
+ }),
81
+ /*#__PURE__*/ _jsx(Button, {
82
+ onClick: panelGroupEditor.close,
83
+ children: "Cancel"
84
+ })
85
+ ]
86
+ })
87
+ ]
88
+ })
127
89
  });
128
- };
129
- export default PanelGroupDialog;
90
+ }
130
91
 
131
92
  //# sourceMappingURL=PanelGroupDialog.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/PanelGroupDialog/PanelGroupDialog.tsx"],"sourcesContent":["// Copyright 2022 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 { FormEvent, useState } from 'react';\nimport {\n IconButton,\n Dialog,\n DialogTitle,\n DialogContent,\n FormControl,\n InputLabel,\n TextField,\n Stack,\n Box,\n DialogActions,\n Button,\n Select,\n SelectChangeEvent,\n MenuItem,\n} from '@mui/material';\nimport CloseIcon from 'mdi-material-ui/Close';\nimport { usePanelGroupDialog, useLayouts } from '../../context';\nimport { PanelGroupDefinition } from '../../context/DashboardProvider/layout-slice';\n\nconst PanelGroupDialog = () => {\n const { layouts, updatePanelGroup } = useLayouts();\n const { panelGroupDialog, closePanelGroupDialog } = usePanelGroupDialog();\n\n const groupIndex = panelGroupDialog?.groupIndex;\n\n const isEditingPanelGroup = groupIndex !== undefined;\n\n const [isCollapsed, setIsCollapsed] = useState(isEditingPanelGroup && layouts[groupIndex]?.isCollapsed);\n const [name, setName] = useState(isEditingPanelGroup ? layouts[groupIndex]?.title : '');\n\n const handleSubmit = (e: FormEvent) => {\n e.preventDefault();\n const newGroup: Omit<PanelGroupDefinition, 'id'> = {\n isCollapsed,\n title: name ?? '',\n items: groupIndex === undefined ? [] : layouts[groupIndex]?.items ?? [],\n };\n updatePanelGroup(newGroup, groupIndex);\n closePanelGroupDialog();\n };\n\n const handleSelectCollapsedStateChange = (e: SelectChangeEvent<string>) => {\n const isCollapsed = e.target.value === 'Close';\n setIsCollapsed(isCollapsed);\n };\n\n return (\n <Dialog open={panelGroupDialog !== undefined}>\n <DialogTitle>Panel Group</DialogTitle>\n <IconButton\n aria-label=\"Close\"\n onClick={() => closePanelGroupDialog()}\n sx={(theme) => ({\n position: 'absolute',\n top: theme.spacing(0.5),\n right: theme.spacing(0.5),\n })}\n >\n <CloseIcon />\n </IconButton>\n <form onSubmit={handleSubmit}>\n <DialogContent sx={{ width: '500px' }}>\n <Stack spacing={2}>\n <FormControl>\n <TextField\n required\n label=\"Name\"\n variant=\"outlined\"\n value={name}\n onChange={(e) => setName(e.target.value)}\n />\n </FormControl>\n <Box sx={{ display: 'flex', alignItems: 'center', width: '100%', justifyContent: 'space-between' }}>\n <InputLabel>Collapse State</InputLabel>\n <Select\n required\n displayEmpty\n labelId=\"select-collapse-state\"\n size=\"small\"\n value={isCollapsed ? 'Close' : 'Open'}\n onChange={handleSelectCollapsedStateChange}\n >\n <MenuItem key={'open'} value={'Open'}>\n Open\n </MenuItem>\n <MenuItem key={'close'} value={'Close'}>\n Close\n </MenuItem>\n </Select>\n </Box>\n </Stack>\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" type=\"submit\">\n {isEditingPanelGroup ? 'Apply' : 'Add'}\n </Button>\n <Button onClick={() => closePanelGroupDialog()}>Cancel</Button>\n </DialogActions>\n </form>\n </Dialog>\n );\n};\n\nexport default PanelGroupDialog;\n"],"names":["useState","IconButton","Dialog","DialogTitle","DialogContent","FormControl","InputLabel","TextField","Stack","Box","DialogActions","Button","Select","MenuItem","CloseIcon","usePanelGroupDialog","useLayouts","PanelGroupDialog","layouts","updatePanelGroup","panelGroupDialog","closePanelGroupDialog","groupIndex","isEditingPanelGroup","undefined","isCollapsed","setIsCollapsed","name","setName","title","handleSubmit","e","preventDefault","newGroup","items","handleSelectCollapsedStateChange","target","value","open","aria-label","onClick","sx","theme","position","top","spacing","right","form","onSubmit","width","required","label","variant","onChange","display","alignItems","justifyContent","displayEmpty","labelId","size","type"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../src/components/PanelGroupDialog/PanelGroupDialog.tsx"],"sourcesContent":["// Copyright 2022 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 { IconButton, Dialog, DialogTitle, DialogContent, DialogActions, Button } from '@mui/material';\nimport CloseIcon from 'mdi-material-ui/Close';\nimport { useState } from 'react';\nimport { usePanelGroupEditor } from '../../context';\nimport { PanelGroupEditorForm, panelGroupEditorFormId, PanelGroupEditorFormProps } from './PanelGroupEditorForm';\n\n/**\n * A dialog for adding or editing a Panel Group. Open and initial state is controlled by the DashboardStore.\n */\nexport function PanelGroupDialog() {\n const panelGroupEditor = usePanelGroupEditor();\n\n // When the user clicks close, start closing but don't call the store yet to keep values stable during animtation\n const [isClosing, setIsClosing] = useState(false);\n const handleClose = () => setIsClosing(true);\n\n // Don't call close on the store until the Dialog has completely transitioned out\n const handleExited = () => {\n panelGroupEditor?.close();\n setIsClosing(false);\n };\n\n // Dialog is open if we have a model and we're not transitioning out\n const isOpen = panelGroupEditor !== undefined && isClosing === false;\n\n const handleSubmit: PanelGroupEditorFormProps['onSubmit'] = (values) => {\n // This shouldn't happen since we don't render the submit button until we have a model, but check to make TS happy\n if (panelGroupEditor === undefined) {\n throw new Error('Cannot apply changes');\n }\n panelGroupEditor.applyChanges(values);\n handleClose();\n };\n\n return (\n <Dialog open={isOpen} TransitionProps={{ onExited: handleExited }}>\n {panelGroupEditor !== undefined && (\n <>\n <DialogTitle>{panelGroupEditor.mode} Panel Group</DialogTitle>\n <IconButton\n aria-label=\"Close\"\n onClick={panelGroupEditor.close}\n sx={(theme) => ({\n position: 'absolute',\n top: theme.spacing(0.5),\n right: theme.spacing(0.5),\n })}\n >\n <CloseIcon />\n </IconButton>\n <DialogContent sx={{ width: '500px' }}>\n <PanelGroupEditorForm initialValues={panelGroupEditor.initialValues} onSubmit={handleSubmit} />\n </DialogContent>\n <DialogActions>\n <Button variant=\"contained\" type=\"submit\" form={panelGroupEditorFormId}>\n {panelGroupEditor.mode === 'Edit' ? 'Apply' : 'Add'}\n </Button>\n <Button onClick={panelGroupEditor.close}>Cancel</Button>\n </DialogActions>\n </>\n )}\n </Dialog>\n );\n}\n"],"names":["IconButton","Dialog","DialogTitle","DialogContent","DialogActions","Button","CloseIcon","useState","usePanelGroupEditor","PanelGroupEditorForm","panelGroupEditorFormId","PanelGroupDialog","panelGroupEditor","isClosing","setIsClosing","handleClose","handleExited","close","isOpen","undefined","handleSubmit","values","Error","applyChanges","open","TransitionProps","onExited","mode","aria-label","onClick","sx","theme","position","top","spacing","right","width","initialValues","onSubmit","variant","type","form"],"mappings":"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"}
@@ -16,8 +16,7 @@ import userEvent from '@testing-library/user-event';
16
16
  import { act } from 'react-dom/test-utils';
17
17
  import { DashboardProvider } from '../../context';
18
18
  import { createDashboardProviderSpy, getTestDashboard, renderWithContext } from '../../test';
19
- import testDashboard from '../../test/testDashboard';
20
- import PanelGroupDialog from './PanelGroupDialog';
19
+ import { PanelGroupDialog } from './PanelGroupDialog';
21
20
  describe('Add Panel Group', ()=>{
22
21
  const renderDialog = ()=>{
23
22
  const { store , DashboardProviderSpy } = createDashboardProviderSpy();
@@ -40,33 +39,40 @@ describe('Add Panel Group', ()=>{
40
39
  it('should add new panel group', async ()=>{
41
40
  const storeApi = renderDialog();
42
41
  // Open the dialog for a new panel group
43
- act(()=>storeApi.getState().openPanelGroupDialog());
42
+ act(()=>storeApi.getState().openAddPanelGroup());
44
43
  const nameInput = await screen.findByLabelText(/Name/);
45
44
  userEvent.type(nameInput, 'New Panel Group');
46
45
  userEvent.click(screen.getByText('Add'));
47
- const layouts = storeApi.getState().layouts;
48
- expect(layouts).toContainEqual({
49
- id: 3,
46
+ // TODO: Figure out how to test this without coupling to the store state
47
+ const panelGroups = Object.values(storeApi.getState().panelGroups);
48
+ expect(panelGroups).toContainEqual({
49
+ id: expect.any(Number),
50
50
  title: 'New Panel Group',
51
51
  isCollapsed: false,
52
- items: []
52
+ itemLayouts: expect.any(Array),
53
+ itemPanelKeys: expect.any(Object)
53
54
  });
54
55
  });
55
56
  it('should edit existing panel group', async ()=>{
56
- var ref;
57
57
  const storeApi = renderDialog();
58
58
  // Open the dialog for an existing panel group
59
- act(()=>storeApi.getState().openPanelGroupDialog(0));
59
+ const group = Object.values(storeApi.getState().panelGroups).find((group)=>group.title === 'CPU Stats');
60
+ if (group === undefined) {
61
+ throw new Error('Missing test group');
62
+ }
63
+ act(()=>storeApi.getState().openEditPanelGroup(group.id));
60
64
  const nameInput = await screen.findByLabelText(/Name/);
61
65
  userEvent.clear(nameInput);
62
66
  userEvent.type(nameInput, 'New Name');
63
67
  userEvent.click(screen.getByText('Apply'));
64
- const layouts = storeApi.getState().layouts;
65
- expect(layouts).toContainEqual({
66
- id: 0,
67
- title: 'New Name',
68
- isCollapsed: false,
69
- items: (ref = testDashboard.spec.layouts[0]) === null || ref === void 0 ? void 0 : ref.spec.items
68
+ // TODO: Figure out how to test this without coupling to the store state
69
+ const panelGroups = storeApi.getState().panelGroups;
70
+ expect(panelGroups).toMatchObject({
71
+ [group.id]: {
72
+ id: group.id,
73
+ title: 'New Name',
74
+ isCollapsed: false
75
+ }
70
76
  });
71
77
  });
72
78
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/PanelGroupDialog/PanelGroupDialog.test.tsx"],"sourcesContent":["// Copyright 2022 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 { screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { act } from 'react-dom/test-utils';\nimport { DashboardProvider } from '../../context';\nimport { createDashboardProviderSpy, getTestDashboard, renderWithContext } from '../../test';\nimport testDashboard from '../../test/testDashboard';\nimport PanelGroupDialog from './PanelGroupDialog';\n\ndescribe('Add Panel Group', () => {\n const renderDialog = () => {\n const { store, DashboardProviderSpy } = createDashboardProviderSpy();\n\n renderWithContext(\n <DashboardProvider initialState={{ dashboardSpec: getTestDashboard().spec, isEditMode: true }}>\n <DashboardProviderSpy />\n <PanelGroupDialog />\n </DashboardProvider>\n );\n\n const { value: storeApi } = store;\n if (storeApi === undefined) {\n throw new Error('Expected dashboard store to be set after initial render');\n }\n\n return storeApi;\n };\n\n it('should add new panel group', async () => {\n const storeApi = renderDialog();\n\n // Open the dialog for a new panel group\n act(() => storeApi.getState().openPanelGroupDialog());\n\n const nameInput = await screen.findByLabelText(/Name/);\n userEvent.type(nameInput, 'New Panel Group');\n userEvent.click(screen.getByText('Add'));\n\n const layouts = storeApi.getState().layouts;\n expect(layouts).toContainEqual({\n id: 3,\n title: 'New Panel Group',\n isCollapsed: false,\n items: [],\n });\n });\n\n it('should edit existing panel group', async () => {\n const storeApi = renderDialog();\n\n // Open the dialog for an existing panel group\n act(() => storeApi.getState().openPanelGroupDialog(0));\n\n const nameInput = await screen.findByLabelText(/Name/);\n userEvent.clear(nameInput);\n userEvent.type(nameInput, 'New Name');\n userEvent.click(screen.getByText('Apply'));\n\n const layouts = storeApi.getState().layouts;\n expect(layouts).toContainEqual({\n id: 0,\n title: 'New Name',\n isCollapsed: false,\n items: testDashboard.spec.layouts[0]?.spec.items,\n });\n });\n});\n"],"names":["screen","userEvent","act","DashboardProvider","createDashboardProviderSpy","getTestDashboard","renderWithContext","testDashboard","PanelGroupDialog","describe","renderDialog","store","DashboardProviderSpy","initialState","dashboardSpec","spec","isEditMode","value","storeApi","undefined","Error","it","getState","openPanelGroupDialog","nameInput","findByLabelText","type","click","getByText","layouts","expect","toContainEqual","id","title","isCollapsed","items","clear"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../src/components/PanelGroupDialog/PanelGroupDialog.test.tsx"],"sourcesContent":["// Copyright 2022 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 { screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { act } from 'react-dom/test-utils';\nimport { DashboardProvider } from '../../context';\nimport { createDashboardProviderSpy, getTestDashboard, renderWithContext } from '../../test';\nimport { PanelGroupDialog } from './PanelGroupDialog';\n\ndescribe('Add Panel Group', () => {\n const renderDialog = () => {\n const { store, DashboardProviderSpy } = createDashboardProviderSpy();\n\n renderWithContext(\n <DashboardProvider initialState={{ dashboardSpec: getTestDashboard().spec, isEditMode: true }}>\n <DashboardProviderSpy />\n <PanelGroupDialog />\n </DashboardProvider>\n );\n\n const { value: storeApi } = store;\n if (storeApi === undefined) {\n throw new Error('Expected dashboard store to be set after initial render');\n }\n\n return storeApi;\n };\n\n it('should add new panel group', async () => {\n const storeApi = renderDialog();\n\n // Open the dialog for a new panel group\n act(() => storeApi.getState().openAddPanelGroup());\n\n const nameInput = await screen.findByLabelText(/Name/);\n userEvent.type(nameInput, 'New Panel Group');\n userEvent.click(screen.getByText('Add'));\n\n // TODO: Figure out how to test this without coupling to the store state\n const panelGroups = Object.values(storeApi.getState().panelGroups);\n expect(panelGroups).toContainEqual({\n id: expect.any(Number),\n title: 'New Panel Group',\n isCollapsed: false,\n itemLayouts: expect.any(Array),\n itemPanelKeys: expect.any(Object),\n });\n });\n\n it('should edit existing panel group', async () => {\n const storeApi = renderDialog();\n\n // Open the dialog for an existing panel group\n const group = Object.values(storeApi.getState().panelGroups).find((group) => group.title === 'CPU Stats');\n if (group === undefined) {\n throw new Error('Missing test group');\n }\n act(() => storeApi.getState().openEditPanelGroup(group.id));\n\n const nameInput = await screen.findByLabelText(/Name/);\n userEvent.clear(nameInput);\n userEvent.type(nameInput, 'New Name');\n userEvent.click(screen.getByText('Apply'));\n\n // TODO: Figure out how to test this without coupling to the store state\n const panelGroups = storeApi.getState().panelGroups;\n expect(panelGroups).toMatchObject({\n [group.id]: {\n id: group.id,\n title: 'New Name',\n isCollapsed: false,\n },\n });\n });\n});\n"],"names":["screen","userEvent","act","DashboardProvider","createDashboardProviderSpy","getTestDashboard","renderWithContext","PanelGroupDialog","describe","renderDialog","store","DashboardProviderSpy","initialState","dashboardSpec","spec","isEditMode","value","storeApi","undefined","Error","it","getState","openAddPanelGroup","nameInput","findByLabelText","type","click","getByText","panelGroups","Object","values","expect","toContainEqual","id","any","Number","title","isCollapsed","itemLayouts","Array","itemPanelKeys","group","find","openEditPanelGroup","clear","toMatchObject"],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ /// <reference types="react" />
2
+ import { PanelGroupEditorValues } from '../../context';
3
+ export interface PanelGroupEditorFormProps {
4
+ initialValues: PanelGroupEditorValues;
5
+ onSubmit: (next: PanelGroupEditorValues) => void;
6
+ }
7
+ export declare function PanelGroupEditorForm(props: PanelGroupEditorFormProps): JSX.Element;
8
+ /**
9
+ * The `id` attribute added to the `PanelGroupEditorForm` component, allowing submit buttons to live outside the form.
10
+ */
11
+ export declare const panelGroupEditorFormId = "panel-group-editor-form";
12
+ //# sourceMappingURL=PanelGroupEditorForm.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PanelGroupEditorForm.d.ts","sourceRoot":"","sources":["../../../src/components/PanelGroupDialog/PanelGroupEditorForm.tsx"],"names":[],"mappings":";AAeA,OAAO,EAAE,sBAAsB,EAAE,MAAM,eAAe,CAAC;AAIvD,MAAM,WAAW,yBAAyB;IACxC,aAAa,EAAE,sBAAsB,CAAC;IACtC,QAAQ,EAAE,CAAC,IAAI,EAAE,sBAAsB,KAAK,IAAI,CAAC;CAClD;AAED,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,yBAAyB,eAsCpE;AAED;;GAEG;AACH,eAAO,MAAM,sBAAsB,4BAA4B,CAAC"}
@@ -0,0 +1,82 @@
1
+ // Copyright 2022 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 { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
14
+ import { useState } from 'react';
15
+ import { FormControl, InputLabel, TextField, Select, MenuItem } from '@mui/material';
16
+ export function PanelGroupEditorForm(props) {
17
+ const { initialValues , onSubmit } = props;
18
+ const [title, setTitle] = useState(initialValues.title);
19
+ const [isCollapsed, setIsCollapsed] = useState(initialValues.isCollapsed);
20
+ const handleCollapsedChange = (e)=>{
21
+ const next = e.target.value;
22
+ setIsCollapsed(next === 'Closed');
23
+ };
24
+ const handleSubmit = (e)=>{
25
+ e.preventDefault();
26
+ onSubmit({
27
+ title,
28
+ isCollapsed
29
+ });
30
+ };
31
+ return /*#__PURE__*/ _jsxs("form", {
32
+ id: panelGroupEditorFormId,
33
+ onSubmit: handleSubmit,
34
+ children: [
35
+ /*#__PURE__*/ _jsx(FormControl, {
36
+ fullWidth: true,
37
+ margin: "normal",
38
+ children: /*#__PURE__*/ _jsx(TextField, {
39
+ required: true,
40
+ label: "Name",
41
+ variant: "outlined",
42
+ value: title,
43
+ onChange: (e)=>setTitle(e.target.value)
44
+ })
45
+ }),
46
+ /*#__PURE__*/ _jsxs(FormControl, {
47
+ fullWidth: true,
48
+ margin: "normal",
49
+ children: [
50
+ /*#__PURE__*/ _jsx(InputLabel, {
51
+ id: "select-collapse-state",
52
+ children: "Collapse State"
53
+ }),
54
+ /*#__PURE__*/ _jsxs(Select, {
55
+ required: true,
56
+ displayEmpty: true,
57
+ labelId: "select-collapse-state",
58
+ label: "Collapse State",
59
+ size: "small",
60
+ value: isCollapsed ? 'Closed' : 'Open',
61
+ onChange: handleCollapsedChange,
62
+ children: [
63
+ /*#__PURE__*/ _jsx(MenuItem, {
64
+ value: "Open",
65
+ children: "Open"
66
+ }),
67
+ /*#__PURE__*/ _jsx(MenuItem, {
68
+ value: "Closed",
69
+ children: "Closed"
70
+ })
71
+ ]
72
+ })
73
+ ]
74
+ })
75
+ ]
76
+ });
77
+ }
78
+ /**
79
+ * The `id` attribute added to the `PanelGroupEditorForm` component, allowing submit buttons to live outside the form.
80
+ */ export const panelGroupEditorFormId = 'panel-group-editor-form';
81
+
82
+ //# sourceMappingURL=PanelGroupEditorForm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/components/PanelGroupDialog/PanelGroupEditorForm.tsx"],"sourcesContent":["// Copyright 2022 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 { FormEventHandler, useState } from 'react';\nimport { FormControl, InputLabel, TextField, Select, SelectProps, MenuItem } from '@mui/material';\nimport { PanelGroupEditorValues } from '../../context';\n\ntype CollapsedState = 'Open' | 'Closed';\n\nexport interface PanelGroupEditorFormProps {\n initialValues: PanelGroupEditorValues;\n onSubmit: (next: PanelGroupEditorValues) => void;\n}\n\nexport function PanelGroupEditorForm(props: PanelGroupEditorFormProps) {\n const { initialValues, onSubmit } = props;\n\n const [title, setTitle] = useState(initialValues.title);\n const [isCollapsed, setIsCollapsed] = useState(initialValues.isCollapsed);\n\n const handleCollapsedChange: SelectProps<CollapsedState>['onChange'] = (e) => {\n const next = e.target.value;\n setIsCollapsed(next === 'Closed');\n };\n\n const handleSubmit: FormEventHandler = (e) => {\n e.preventDefault();\n onSubmit({ title, isCollapsed });\n };\n\n return (\n <form id={panelGroupEditorFormId} onSubmit={handleSubmit}>\n <FormControl fullWidth margin=\"normal\">\n <TextField required label=\"Name\" variant=\"outlined\" value={title} onChange={(e) => setTitle(e.target.value)} />\n </FormControl>\n <FormControl fullWidth margin=\"normal\">\n <InputLabel id=\"select-collapse-state\">Collapse State</InputLabel>\n <Select<CollapsedState>\n required\n displayEmpty\n labelId=\"select-collapse-state\"\n label=\"Collapse State\"\n size=\"small\"\n value={isCollapsed ? 'Closed' : 'Open'}\n onChange={handleCollapsedChange}\n >\n <MenuItem value=\"Open\">Open</MenuItem>\n <MenuItem value=\"Closed\">Closed</MenuItem>\n </Select>\n </FormControl>\n </form>\n );\n}\n\n/**\n * The `id` attribute added to the `PanelGroupEditorForm` component, allowing submit buttons to live outside the form.\n */\nexport const panelGroupEditorFormId = 'panel-group-editor-form';\n"],"names":["useState","FormControl","InputLabel","TextField","Select","MenuItem","PanelGroupEditorForm","props","initialValues","onSubmit","title","setTitle","isCollapsed","setIsCollapsed","handleCollapsedChange","e","next","target","value","handleSubmit","preventDefault","form","id","panelGroupEditorFormId","fullWidth","margin","required","label","variant","onChange","displayEmpty","labelId","size"],"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;AAAA,SAA2BA,QAAQ,QAAQ,OAAO,CAAC;AACnD,SAASC,WAAW,EAAEC,UAAU,EAAEC,SAAS,EAAEC,MAAM,EAAeC,QAAQ,QAAQ,eAAe,CAAC;AAUlG,OAAO,SAASC,oBAAoB,CAACC,KAAgC,EAAE;IACrE,MAAM,EAAEC,aAAa,CAAA,EAAEC,QAAQ,CAAA,EAAE,GAAGF,KAAK,AAAC;IAE1C,MAAM,CAACG,KAAK,EAAEC,QAAQ,CAAC,GAAGX,QAAQ,CAACQ,aAAa,CAACE,KAAK,CAAC,AAAC;IACxD,MAAM,CAACE,WAAW,EAAEC,cAAc,CAAC,GAAGb,QAAQ,CAACQ,aAAa,CAACI,WAAW,CAAC,AAAC;IAE1E,MAAME,qBAAqB,GAA4C,CAACC,CAAC,GAAK;QAC5E,MAAMC,IAAI,GAAGD,CAAC,CAACE,MAAM,CAACC,KAAK,AAAC;QAC5BL,cAAc,CAACG,IAAI,KAAK,QAAQ,CAAC,CAAC;IACpC,CAAC,AAAC;IAEF,MAAMG,YAAY,GAAqB,CAACJ,CAAC,GAAK;QAC5CA,CAAC,CAACK,cAAc,EAAE,CAAC;QACnBX,QAAQ,CAAC;YAAEC,KAAK;YAAEE,WAAW;SAAE,CAAC,CAAC;IACnC,CAAC,AAAC;IAEF,qBACE,MAACS,MAAI;QAACC,EAAE,EAAEC,sBAAsB;QAAEd,QAAQ,EAAEU,YAAY;;0BACtD,KAAClB,WAAW;gBAACuB,SAAS;gBAACC,MAAM,EAAC,QAAQ;0BACpC,cAAA,KAACtB,SAAS;oBAACuB,QAAQ;oBAACC,KAAK,EAAC,MAAM;oBAACC,OAAO,EAAC,UAAU;oBAACV,KAAK,EAAER,KAAK;oBAAEmB,QAAQ,EAAE,CAACd,CAAC,GAAKJ,QAAQ,CAACI,CAAC,CAACE,MAAM,CAACC,KAAK,CAAC;kBAAI;cACnG;0BACd,MAACjB,WAAW;gBAACuB,SAAS;gBAACC,MAAM,EAAC,QAAQ;;kCACpC,KAACvB,UAAU;wBAACoB,EAAE,EAAC,uBAAuB;kCAAC,gBAAc;sBAAa;kCAClE,MAAClB,MAAM;wBACLsB,QAAQ;wBACRI,YAAY;wBACZC,OAAO,EAAC,uBAAuB;wBAC/BJ,KAAK,EAAC,gBAAgB;wBACtBK,IAAI,EAAC,OAAO;wBACZd,KAAK,EAAEN,WAAW,GAAG,QAAQ,GAAG,MAAM;wBACtCiB,QAAQ,EAAEf,qBAAqB;;0CAE/B,KAACT,QAAQ;gCAACa,KAAK,EAAC,MAAM;0CAAC,MAAI;8BAAW;0CACtC,KAACb,QAAQ;gCAACa,KAAK,EAAC,QAAQ;0CAAC,QAAM;8BAAW;;sBACnC;;cACG;;MACT,CACP;AACJ,CAAC;AAED;;CAEC,GACD,OAAO,MAAMK,sBAAsB,GAAG,yBAAyB,CAAC"}
@@ -0,0 +1,3 @@
1
+ export * from './PanelGroupDialog';
2
+ export * from './DeletePanelGroupDialog';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/PanelGroupDialog/index.ts"],"names":[],"mappings":"AAaA,cAAc,oBAAoB,CAAC;AACnC,cAAc,0BAA0B,CAAC"}
@@ -0,0 +1,16 @@
1
+ // Copyright 2022 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 './PanelGroupDialog';
14
+ export * from './DeletePanelGroupDialog';
15
+
16
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/components/PanelGroupDialog/index.ts"],"sourcesContent":["// Copyright 2022 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 './PanelGroupDialog';\nexport * from './DeletePanelGroupDialog';\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,oBAAoB,CAAC;AACnC,cAAc,0BAA0B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"TimeRangeControls.d.ts","sourceRoot":"","sources":["../../../src/components/TimeRangeControls/TimeRangeControls.tsx"],"names":[],"mappings":";AAeA,OAAO,EAAyC,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAY3F,eAAO,MAAM,YAAY,EAAE,UAAU,EAUpC,CAAC;AAEF,wBAAgB,iBAAiB,gBA2DhC"}
1
+ {"version":3,"file":"TimeRangeControls.d.ts","sourceRoot":"","sources":["../../../src/components/TimeRangeControls/TimeRangeControls.tsx"],"names":[],"mappings":";AAeA,OAAO,EAAyC,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAW3F,eAAO,MAAM,YAAY,EAAE,UAAU,EAUpC,CAAC;AAEF,wBAAgB,iBAAiB,gBAsDhC"}