@grafana/scenes 6.7.0 → 6.8.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 (331) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/dist/esm/components/layout/CSSGrid/SceneCSSGridItem.js +33 -0
  3. package/dist/esm/dist/esm/behaviors/CursorSync.js +76 -0
  4. package/dist/esm/dist/esm/behaviors/LiveNowTimer.js +44 -0
  5. package/dist/esm/dist/esm/behaviors/SceneQueryController.js +14 -0
  6. package/dist/esm/dist/esm/components/EmbeddedScene.js +59 -0
  7. package/dist/esm/dist/esm/components/NestedScene.js +95 -0
  8. package/dist/esm/dist/esm/components/SceneApp/SceneApp.js +27 -0
  9. package/dist/esm/dist/esm/components/SceneApp/SceneAppPage.js +176 -0
  10. package/dist/esm/dist/esm/components/SceneApp/SceneAppPageView.js +104 -0
  11. package/dist/esm/dist/esm/components/SceneApp/utils.js +42 -0
  12. package/dist/esm/dist/esm/components/SceneByFrameRepeater.js +41 -0
  13. package/dist/esm/dist/esm/components/SceneByVariableRepeater.js +55 -0
  14. package/dist/esm/dist/esm/components/SceneCanvasText.js +32 -0
  15. package/dist/esm/dist/esm/components/SceneControlsSpacer.js +17 -0
  16. package/dist/esm/dist/esm/components/SceneDebugger/DebugDetails.js +82 -0
  17. package/dist/esm/dist/esm/components/SceneDebugger/DebugTreeNode.js +72 -0
  18. package/dist/esm/dist/esm/components/SceneDebugger/SceneDebugger.js +77 -0
  19. package/dist/esm/dist/esm/components/SceneReactObject.js +34 -0
  20. package/dist/esm/dist/esm/components/SceneRefreshPicker.js +205 -0
  21. package/dist/esm/dist/esm/components/SceneTimePicker.js +139 -0
  22. package/dist/esm/dist/esm/components/SceneTimeRangeCompare.js +240 -0
  23. package/dist/esm/dist/esm/components/SceneToolbarButton.js +33 -0
  24. package/dist/esm/dist/esm/components/VizPanel/VizPanel.js +406 -0
  25. package/dist/esm/dist/esm/components/VizPanel/VizPanelExploreButton.js +44 -0
  26. package/dist/esm/dist/esm/components/VizPanel/VizPanelMenu.js +59 -0
  27. package/dist/esm/dist/esm/components/VizPanel/VizPanelRenderer.js +285 -0
  28. package/dist/esm/dist/esm/components/VizPanel/VizPanelSeriesLimit.js +45 -0
  29. package/dist/esm/dist/esm/components/VizPanel/colorSeriesConfigFactory.js +72 -0
  30. package/dist/esm/dist/esm/components/VizPanel/registerRuntimePanelPlugin.js +11 -0
  31. package/dist/esm/dist/esm/components/VizPanel/seriesVisibilityConfigFactory.js +164 -0
  32. package/dist/esm/dist/esm/components/layout/CSSGrid/SceneCSSGridLayout.js +124 -0
  33. package/dist/esm/dist/esm/components/layout/LazyLoader.js +103 -0
  34. package/dist/esm/dist/esm/components/layout/SceneFlexLayout.js +135 -0
  35. package/dist/esm/dist/esm/components/layout/grid/SceneGridItem.js +30 -0
  36. package/dist/esm/dist/esm/components/layout/grid/SceneGridLayout.js +283 -0
  37. package/dist/esm/dist/esm/components/layout/grid/SceneGridLayoutRenderer.js +178 -0
  38. package/dist/esm/dist/esm/components/layout/grid/SceneGridRow.js +190 -0
  39. package/dist/esm/dist/esm/components/layout/grid/constants.js +7 -0
  40. package/dist/esm/dist/esm/components/layout/grid/utils.js +36 -0
  41. package/dist/esm/dist/esm/components/layout/split/SplitLayout.js +17 -0
  42. package/dist/esm/dist/esm/components/layout/split/SplitLayoutRenderer.js +29 -0
  43. package/dist/esm/dist/esm/components/layout/split/Splitter.js +386 -0
  44. package/dist/esm/dist/esm/core/SceneComponentWrapper.js +57 -0
  45. package/dist/esm/dist/esm/core/SceneDataNode.js +43 -0
  46. package/dist/esm/dist/esm/core/SceneObjectBase.js +286 -0
  47. package/dist/esm/dist/esm/core/SceneObjectRef.js +32 -0
  48. package/dist/esm/dist/esm/core/SceneTimeRange.js +231 -0
  49. package/dist/esm/dist/esm/core/events.js +11 -0
  50. package/dist/esm/dist/esm/core/sceneGraph/getTimeRange.js +10 -0
  51. package/dist/esm/dist/esm/core/sceneGraph/index.js +25 -0
  52. package/dist/esm/dist/esm/core/sceneGraph/sceneGraph.js +178 -0
  53. package/dist/esm/dist/esm/core/sceneGraph/utils.js +64 -0
  54. package/dist/esm/dist/esm/core/types.js +15 -0
  55. package/dist/esm/dist/esm/querying/DataLayersMerger.js +46 -0
  56. package/dist/esm/dist/esm/querying/ExtraQueryProvider.js +6 -0
  57. package/dist/esm/dist/esm/querying/RuntimeDataSource.js +6 -0
  58. package/dist/esm/dist/esm/querying/SceneDataLayerSet.js +100 -0
  59. package/dist/esm/dist/esm/querying/SceneQueryRunner.js +468 -0
  60. package/dist/esm/dist/esm/querying/extraQueryProcessingOperator.js +46 -0
  61. package/dist/esm/dist/esm/querying/getEnrichedDataRequest.js +12 -0
  62. package/dist/esm/dist/esm/querying/layers/SceneDataLayerBase.js +112 -0
  63. package/dist/esm/dist/esm/querying/layers/SceneDataLayerControls.js +51 -0
  64. package/dist/esm/dist/esm/querying/layers/annotations/AnnotationsDataLayer.js +130 -0
  65. package/dist/esm/dist/esm/querying/layers/annotations/filterAnnotations.js +85 -0
  66. package/dist/esm/dist/esm/querying/layers/annotations/standardAnnotationQuery.js +121 -0
  67. package/dist/esm/dist/esm/querying/layers/annotations/standardAnnotationsSupport.js +211 -0
  68. package/dist/esm/dist/esm/querying/layers/annotations/utils.js +77 -0
  69. package/dist/esm/dist/esm/querying/registerQueryWithController.js +41 -0
  70. package/dist/esm/dist/esm/services/SceneObjectUrlSyncConfig.js +30 -0
  71. package/dist/esm/dist/esm/services/UniqueUrlKeyMapper.js +45 -0
  72. package/dist/esm/dist/esm/services/UrlSyncManager.js +167 -0
  73. package/dist/esm/dist/esm/services/useUrlSync.js +29 -0
  74. package/dist/esm/dist/esm/services/utils.js +71 -0
  75. package/dist/esm/dist/esm/utils/ControlsLabel.js +107 -0
  76. package/dist/esm/dist/esm/utils/LoadingIndicator.js +19 -0
  77. package/dist/esm/dist/esm/utils/SafeSerializableSceneObject.js +39 -0
  78. package/dist/esm/dist/esm/utils/compatibility/setWindowGrafanaSceneContext.js +16 -0
  79. package/dist/esm/dist/esm/utils/date.js +15 -0
  80. package/dist/esm/dist/esm/utils/evaluateTimeRange.js +16 -0
  81. package/dist/esm/dist/esm/utils/explore.js +47 -0
  82. package/dist/esm/dist/esm/utils/getCompareSeriesRefId.js +4 -0
  83. package/dist/esm/dist/esm/utils/getDataSource.js +18 -0
  84. package/dist/esm/dist/esm/utils/getMessageFromError.js +24 -0
  85. package/dist/esm/dist/esm/utils/metricTree.js +53 -0
  86. package/dist/esm/dist/esm/utils/parseUrlParam.js +41 -0
  87. package/dist/esm/dist/esm/utils/utils.js +11 -0
  88. package/dist/esm/dist/esm/utils/wrapInSafeSerializableSceneObject.js +30 -0
  89. package/dist/esm/dist/esm/utils/writeSceneLog.js +12 -0
  90. package/dist/esm/dist/esm/variables/VariableDependencyConfig.js +150 -0
  91. package/dist/esm/dist/esm/variables/VariableValueRecorder.js +71 -0
  92. package/dist/esm/dist/esm/variables/adhoc/AdHocFilterBuilder.js +24 -0
  93. package/dist/esm/dist/esm/variables/adhoc/AdHocFilterRenderer.js +303 -0
  94. package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFilterPill.js +162 -0
  95. package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersAlwaysWipCombobox.js +20 -0
  96. package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersCombobox.js +640 -0
  97. package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersComboboxRenderer.js +65 -0
  98. package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/DropdownItem.js +146 -0
  99. package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/MultiValuePill.js +114 -0
  100. package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/useFloatingInteractions.js +68 -0
  101. package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersCombobox/utils.js +146 -0
  102. package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersVariable.js +289 -0
  103. package/dist/esm/dist/esm/variables/adhoc/AdHocFiltersVariableUrlSyncHandler.js +76 -0
  104. package/dist/esm/dist/esm/variables/adhoc/getAdhocOptionSearcher.js +13 -0
  105. package/dist/esm/dist/esm/variables/adhoc/patchGetAdhocFilters.js +47 -0
  106. package/dist/esm/dist/esm/variables/components/VariableValueControl.js +23 -0
  107. package/dist/esm/dist/esm/variables/components/VariableValueInput.js +33 -0
  108. package/dist/esm/dist/esm/variables/components/VariableValueSelect.js +228 -0
  109. package/dist/esm/dist/esm/variables/components/VariableValueSelectors.js +72 -0
  110. package/dist/esm/dist/esm/variables/components/getOptionSearcher.js +15 -0
  111. package/dist/esm/dist/esm/variables/constants.js +9 -0
  112. package/dist/esm/dist/esm/variables/getEnrichedFiltersRequest.js +12 -0
  113. package/dist/esm/dist/esm/variables/groupby/GroupByVariable.js +259 -0
  114. package/dist/esm/dist/esm/variables/groupby/GroupByVariableUrlSyncHandler.js +63 -0
  115. package/dist/esm/dist/esm/variables/groupby/findActiveGroupByVariablesByUid.js +13 -0
  116. package/dist/esm/dist/esm/variables/interpolation/ScopedVarsVariable.js +40 -0
  117. package/dist/esm/dist/esm/variables/interpolation/defaults.js +21 -0
  118. package/dist/esm/dist/esm/variables/interpolation/fieldAccessorCache.js +13 -0
  119. package/dist/esm/dist/esm/variables/interpolation/formatRegistry.js +296 -0
  120. package/dist/esm/dist/esm/variables/interpolation/sceneInterpolator.js +87 -0
  121. package/dist/esm/dist/esm/variables/lookupVariable.js +20 -0
  122. package/dist/esm/dist/esm/variables/macros/AllVariablesMacro.js +57 -0
  123. package/dist/esm/dist/esm/variables/macros/contextMacros.js +43 -0
  124. package/dist/esm/dist/esm/variables/macros/dataMacros.js +134 -0
  125. package/dist/esm/dist/esm/variables/macros/index.js +26 -0
  126. package/dist/esm/dist/esm/variables/macros/templateProxies.js +51 -0
  127. package/dist/esm/dist/esm/variables/macros/timeMacros.js +86 -0
  128. package/dist/esm/dist/esm/variables/macros/types.js +11 -0
  129. package/dist/esm/dist/esm/variables/macros/urlMacros.js +56 -0
  130. package/dist/esm/dist/esm/variables/sets/SceneVariableSet.js +254 -0
  131. package/dist/esm/dist/esm/variables/types.js +11 -0
  132. package/dist/esm/dist/esm/variables/utils.js +172 -0
  133. package/dist/esm/dist/esm/variables/variants/ConstantVariable.js +38 -0
  134. package/dist/esm/dist/esm/variables/variants/CustomVariable.js +60 -0
  135. package/dist/esm/dist/esm/variables/variants/DataSourceVariable.js +88 -0
  136. package/dist/esm/dist/esm/variables/variants/IntervalVariable.js +117 -0
  137. package/dist/esm/dist/esm/variables/variants/MultiValueVariable.js +295 -0
  138. package/dist/esm/dist/esm/variables/variants/TestVariable.js +117 -0
  139. package/dist/esm/dist/esm/variables/variants/TextBoxVariable.js +61 -0
  140. package/dist/esm/dist/esm/variables/variants/query/QueryVariable.js +139 -0
  141. package/dist/esm/dist/esm/variables/variants/query/createQueryVariableRunner.js +129 -0
  142. package/dist/esm/dist/esm/variables/variants/query/guards.js +28 -0
  143. package/dist/esm/dist/esm/variables/variants/query/toMetricFindValues.js +96 -0
  144. package/dist/esm/dist/esm/variables/variants/query/utils.js +124 -0
  145. package/dist/esm/index.js +1 -1
  146. package/dist/esm/index.js.map +1 -1
  147. package/dist/esm/querying/DataProviderSharer.js +39 -0
  148. package/dist/esm/src/behaviors/ActWhenVariableChanged.js +27 -0
  149. package/dist/esm/src/behaviors/CursorSync.js +76 -0
  150. package/dist/esm/src/behaviors/LiveNowTimer.js +44 -0
  151. package/dist/esm/src/behaviors/SceneQueryController.js +60 -0
  152. package/dist/esm/src/behaviors/index.js +5 -0
  153. package/dist/esm/src/components/EmbeddedScene.js +59 -0
  154. package/dist/esm/src/components/NestedScene.js +95 -0
  155. package/dist/esm/src/components/SceneApp/SceneApp.js +37 -0
  156. package/dist/esm/src/components/SceneApp/SceneAppPage.js +176 -0
  157. package/dist/esm/src/components/SceneApp/SceneAppPageView.js +104 -0
  158. package/dist/esm/src/components/SceneApp/utils.js +42 -0
  159. package/dist/esm/src/components/SceneByFrameRepeater.js +41 -0
  160. package/dist/esm/src/components/SceneByVariableRepeater.js +55 -0
  161. package/dist/esm/src/components/SceneCanvasText.js +32 -0
  162. package/dist/esm/src/components/SceneControlsSpacer.js +17 -0
  163. package/dist/esm/src/components/SceneDebugger/DebugDetails.js +82 -0
  164. package/dist/esm/src/components/SceneDebugger/DebugTreeNode.js +72 -0
  165. package/dist/esm/src/components/SceneDebugger/SceneDebugger.js +77 -0
  166. package/dist/esm/src/components/SceneReactObject.js +34 -0
  167. package/dist/esm/src/components/SceneRefreshPicker.js +205 -0
  168. package/dist/esm/src/components/SceneTimePicker.js +139 -0
  169. package/dist/esm/src/components/SceneTimeRangeCompare.js +240 -0
  170. package/dist/esm/src/components/SceneToolbarButton.js +33 -0
  171. package/dist/esm/src/components/VizPanel/VizPanel.js +406 -0
  172. package/dist/esm/src/components/VizPanel/VizPanelExploreButton.js +44 -0
  173. package/dist/esm/src/components/VizPanel/VizPanelMenu.js +59 -0
  174. package/dist/esm/src/components/VizPanel/VizPanelRenderer.js +285 -0
  175. package/dist/esm/src/components/VizPanel/VizPanelSeriesLimit.js +45 -0
  176. package/dist/esm/src/components/VizPanel/colorSeriesConfigFactory.js +72 -0
  177. package/dist/esm/src/components/VizPanel/registerRuntimePanelPlugin.js +56 -0
  178. package/dist/esm/src/components/VizPanel/seriesVisibilityConfigFactory.js +164 -0
  179. package/dist/esm/src/components/layout/CSSGrid/SceneCSSGridLayout.js +124 -0
  180. package/dist/esm/src/components/layout/LazyLoader.js +103 -0
  181. package/dist/esm/src/components/layout/SceneFlexLayout.js +135 -0
  182. package/dist/esm/src/components/layout/grid/SceneGridItem.js +30 -0
  183. package/dist/esm/src/components/layout/grid/SceneGridLayout.js +283 -0
  184. package/dist/esm/src/components/layout/grid/SceneGridLayoutRenderer.js +178 -0
  185. package/dist/esm/src/components/layout/grid/SceneGridRow.js +190 -0
  186. package/dist/esm/src/components/layout/grid/constants.js +7 -0
  187. package/dist/esm/src/components/layout/grid/utils.js +36 -0
  188. package/dist/esm/src/components/layout/split/SplitLayout.js +17 -0
  189. package/dist/esm/src/components/layout/split/SplitLayoutRenderer.js +29 -0
  190. package/dist/esm/src/components/layout/split/Splitter.js +386 -0
  191. package/dist/esm/src/core/PanelBuilders/FieldConfigBuilder.js +100 -0
  192. package/dist/esm/src/core/PanelBuilders/FieldConfigBuilders.js +75 -0
  193. package/dist/esm/src/core/PanelBuilders/FieldConfigOverridesBuilder.js +75 -0
  194. package/dist/esm/src/core/PanelBuilders/PanelOptionsBuilder.js +22 -0
  195. package/dist/esm/src/core/PanelBuilders/PanelOptionsBuilders.js +85 -0
  196. package/dist/esm/src/core/PanelBuilders/StandardFieldConfigBuilders.js +52 -0
  197. package/dist/esm/src/core/PanelBuilders/VizConfigBuilder.js +78 -0
  198. package/dist/esm/src/core/PanelBuilders/VizConfigBuilders.js +114 -0
  199. package/dist/esm/src/core/PanelBuilders/VizPanelBuilder.js +162 -0
  200. package/dist/esm/src/core/PanelBuilders/index.js +116 -0
  201. package/dist/esm/src/core/SceneComponentWrapper.js +57 -0
  202. package/dist/esm/src/core/SceneDataNode.js +43 -0
  203. package/dist/esm/src/core/SceneObjectBase.js +286 -0
  204. package/dist/esm/src/core/SceneObjectRef.js +32 -0
  205. package/dist/esm/src/core/SceneTimeRange.js +231 -0
  206. package/dist/esm/src/core/SceneTimeRangeTransformerBase.js +35 -0
  207. package/dist/esm/src/core/SceneTimeZoneOverride.js +63 -0
  208. package/dist/esm/src/core/events.js +11 -0
  209. package/dist/esm/src/core/sceneGraph/getTimeRange.js +10 -0
  210. package/dist/esm/src/core/sceneGraph/index.js +25 -0
  211. package/dist/esm/src/core/sceneGraph/sceneGraph.js +178 -0
  212. package/dist/esm/src/core/sceneGraph/utils.js +64 -0
  213. package/dist/esm/src/core/types.js +15 -0
  214. package/dist/esm/src/index.js +108 -0
  215. package/dist/esm/src/querying/DataLayersMerger.js +46 -0
  216. package/dist/esm/src/querying/DataProviderProxy.js +37 -0
  217. package/dist/esm/src/querying/DataProviderSharer.js +108 -0
  218. package/dist/esm/src/querying/ExtraQueryProvider.js +6 -0
  219. package/dist/esm/src/querying/RuntimeDataSource.js +49 -0
  220. package/dist/esm/src/querying/SceneDataLayerSet.js +100 -0
  221. package/dist/esm/src/querying/SceneDataTransformer.js +178 -0
  222. package/dist/esm/src/querying/SceneQueryRunner.js +468 -0
  223. package/dist/esm/src/querying/extraQueryProcessingOperator.js +46 -0
  224. package/dist/esm/src/querying/getEnrichedDataRequest.js +12 -0
  225. package/dist/esm/src/querying/layers/SceneDataLayerBase.js +112 -0
  226. package/dist/esm/src/querying/layers/SceneDataLayerControls.js +51 -0
  227. package/dist/esm/src/querying/layers/annotations/AnnotationsDataLayer.js +130 -0
  228. package/dist/esm/src/querying/layers/annotations/filterAnnotations.js +85 -0
  229. package/dist/esm/src/querying/layers/annotations/standardAnnotationQuery.js +121 -0
  230. package/dist/esm/src/querying/layers/annotations/standardAnnotationsSupport.js +211 -0
  231. package/dist/esm/src/querying/layers/annotations/utils.js +77 -0
  232. package/dist/esm/src/querying/layers/index.js +2 -0
  233. package/dist/esm/src/querying/registerQueryWithController.js +41 -0
  234. package/dist/esm/src/services/SceneObjectUrlSyncConfig.js +30 -0
  235. package/dist/esm/src/services/UniqueUrlKeyMapper.js +45 -0
  236. package/dist/esm/src/services/UrlSyncContextProvider.js +17 -0
  237. package/dist/esm/src/services/UrlSyncManager.js +167 -0
  238. package/dist/esm/src/services/useUrlSync.js +29 -0
  239. package/dist/esm/src/services/utils.js +75 -0
  240. package/dist/esm/src/utils/ControlsLabel.js +107 -0
  241. package/dist/esm/src/utils/LoadingIndicator.js +19 -0
  242. package/dist/esm/src/utils/SafeSerializableSceneObject.js +39 -0
  243. package/dist/esm/src/utils/compatibility/setWindowGrafanaSceneContext.js +16 -0
  244. package/dist/esm/src/utils/date.js +15 -0
  245. package/dist/esm/src/utils/evaluateTimeRange.js +16 -0
  246. package/dist/esm/src/utils/explore.js +47 -0
  247. package/dist/esm/src/utils/getCompareSeriesRefId.js +4 -0
  248. package/dist/esm/src/utils/getDataSource.js +18 -0
  249. package/dist/esm/src/utils/getMessageFromError.js +24 -0
  250. package/dist/esm/src/utils/metricTree.js +53 -0
  251. package/dist/esm/src/utils/parseUrlParam.js +41 -0
  252. package/dist/esm/src/utils/utils.js +11 -0
  253. package/dist/esm/src/utils/wrapInSafeSerializableSceneObject.js +30 -0
  254. package/dist/esm/src/utils/writeSceneLog.js +12 -0
  255. package/dist/esm/src/variables/VariableDependencyConfig.js +150 -0
  256. package/dist/esm/src/variables/VariableValueRecorder.js +71 -0
  257. package/dist/esm/src/variables/adhoc/AdHocFilterBuilder.js +24 -0
  258. package/dist/esm/src/variables/adhoc/AdHocFilterRenderer.js +303 -0
  259. package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFilterPill.js +162 -0
  260. package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersAlwaysWipCombobox.js +20 -0
  261. package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersCombobox.js +640 -0
  262. package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/AdHocFiltersComboboxRenderer.js +65 -0
  263. package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/DropdownItem.js +146 -0
  264. package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/MultiValuePill.js +114 -0
  265. package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/useFloatingInteractions.js +68 -0
  266. package/dist/esm/src/variables/adhoc/AdHocFiltersCombobox/utils.js +146 -0
  267. package/dist/esm/src/variables/adhoc/AdHocFiltersVariable.js +289 -0
  268. package/dist/esm/src/variables/adhoc/AdHocFiltersVariableUrlSyncHandler.js +76 -0
  269. package/dist/esm/src/variables/adhoc/getAdhocOptionSearcher.js +13 -0
  270. package/dist/esm/src/variables/adhoc/patchGetAdhocFilters.js +47 -0
  271. package/dist/esm/src/variables/components/VariableValueControl.js +23 -0
  272. package/dist/esm/src/variables/components/VariableValueInput.js +33 -0
  273. package/dist/esm/src/variables/components/VariableValueSelect.js +228 -0
  274. package/dist/esm/src/variables/components/VariableValueSelectors.js +72 -0
  275. package/dist/esm/src/variables/components/getOptionSearcher.js +15 -0
  276. package/dist/esm/src/variables/constants.js +9 -0
  277. package/dist/esm/src/variables/getEnrichedFiltersRequest.js +12 -0
  278. package/dist/esm/src/variables/groupby/GroupByVariable.js +259 -0
  279. package/dist/esm/src/variables/groupby/GroupByVariableUrlSyncHandler.js +63 -0
  280. package/dist/esm/src/variables/groupby/findActiveGroupByVariablesByUid.js +13 -0
  281. package/dist/esm/src/variables/interpolation/ScopedVarsVariable.js +40 -0
  282. package/dist/esm/src/variables/interpolation/defaults.js +21 -0
  283. package/dist/esm/src/variables/interpolation/fieldAccessorCache.js +13 -0
  284. package/dist/esm/src/variables/interpolation/formatRegistry.js +296 -0
  285. package/dist/esm/src/variables/interpolation/sceneInterpolator.js +87 -0
  286. package/dist/esm/src/variables/lookupVariable.js +20 -0
  287. package/dist/esm/src/variables/macros/AllVariablesMacro.js +57 -0
  288. package/dist/esm/src/variables/macros/contextMacros.js +43 -0
  289. package/dist/esm/src/variables/macros/dataMacros.js +134 -0
  290. package/dist/esm/src/variables/macros/index.js +35 -0
  291. package/dist/esm/src/variables/macros/templateProxies.js +51 -0
  292. package/dist/esm/src/variables/macros/timeMacros.js +86 -0
  293. package/dist/esm/src/variables/macros/types.js +11 -0
  294. package/dist/esm/src/variables/macros/urlMacros.js +56 -0
  295. package/dist/esm/src/variables/sets/SceneVariableSet.js +254 -0
  296. package/dist/esm/src/variables/types.js +11 -0
  297. package/dist/esm/src/variables/utils.js +172 -0
  298. package/dist/esm/src/variables/variants/ConstantVariable.js +38 -0
  299. package/dist/esm/src/variables/variants/CustomVariable.js +60 -0
  300. package/dist/esm/src/variables/variants/DataSourceVariable.js +88 -0
  301. package/dist/esm/src/variables/variants/IntervalVariable.js +117 -0
  302. package/dist/esm/src/variables/variants/JsonVariable.js +193 -0
  303. package/dist/esm/src/variables/variants/LocalValueVariable.js +56 -0
  304. package/dist/esm/src/variables/variants/MultiValueVariable.js +295 -0
  305. package/dist/esm/src/variables/variants/TestVariable.js +117 -0
  306. package/dist/esm/src/variables/variants/TextBoxVariable.js +61 -0
  307. package/dist/esm/src/variables/variants/guards.js +27 -0
  308. package/dist/esm/src/variables/variants/query/QueryVariable.js +139 -0
  309. package/dist/esm/src/variables/variants/query/createQueryVariableRunner.js +129 -0
  310. package/dist/esm/src/variables/variants/query/guards.js +28 -0
  311. package/dist/esm/src/variables/variants/query/toMetricFindValues.js +96 -0
  312. package/dist/esm/src/variables/variants/query/utils.js +124 -0
  313. package/dist/esm/variables/components/VariableValueSelect.js +13 -9
  314. package/dist/esm/variables/components/VariableValueSelect.js.map +1 -1
  315. package/dist/esm/variables/variants/ConstantVariable.js +22 -0
  316. package/dist/esm/variables/variants/ConstantVariable.js.map +1 -1
  317. package/dist/esm/variables/variants/CustomVariable.js +3 -2
  318. package/dist/esm/variables/variants/CustomVariable.js.map +1 -1
  319. package/dist/esm/variables/variants/DataSourceVariable.js +3 -2
  320. package/dist/esm/variables/variants/DataSourceVariable.js.map +1 -1
  321. package/dist/esm/variables/variants/JsonVariable.js +96 -0
  322. package/dist/esm/variables/variants/TestVariable.js +3 -2
  323. package/dist/esm/variables/variants/TestVariable.js.map +1 -1
  324. package/dist/esm/variables/variants/json/JsonVariable.js +95 -0
  325. package/dist/esm/variables/variants/json/JsonVariableOptionProviders.js +70 -0
  326. package/dist/esm/variables/variants/query/QueryVariable.js +3 -2
  327. package/dist/esm/variables/variants/query/QueryVariable.js.map +1 -1
  328. package/dist/index.d.ts +14 -6
  329. package/dist/index.js +35 -13
  330. package/dist/index.js.map +1 -1
  331. package/package.json +2 -2
@@ -0,0 +1,178 @@
1
+ import React, { useRef, useEffect } from 'react';
2
+ import ReactGridLayout from 'react-grid-layout';
3
+ import { GRID_CELL_VMARGIN, GRID_COLUMN_COUNT, GRID_CELL_HEIGHT } from './constants.js';
4
+ import { LazyLoader } from '../LazyLoader.js';
5
+ import { useStyles2 } from '@grafana/ui';
6
+ import { cx, css } from '@emotion/css';
7
+ import { useMeasure } from 'react-use';
8
+
9
+ var __defProp = Object.defineProperty;
10
+ var __defProps = Object.defineProperties;
11
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
12
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
13
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
14
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
15
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
16
+ var __spreadValues = (a, b) => {
17
+ for (var prop in b || (b = {}))
18
+ if (__hasOwnProp.call(b, prop))
19
+ __defNormalProp(a, prop, b[prop]);
20
+ if (__getOwnPropSymbols)
21
+ for (var prop of __getOwnPropSymbols(b)) {
22
+ if (__propIsEnum.call(b, prop))
23
+ __defNormalProp(a, prop, b[prop]);
24
+ }
25
+ return a;
26
+ };
27
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
28
+ var __objRest = (source, exclude) => {
29
+ var target = {};
30
+ for (var prop in source)
31
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
32
+ target[prop] = source[prop];
33
+ if (source != null && __getOwnPropSymbols)
34
+ for (var prop of __getOwnPropSymbols(source)) {
35
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
36
+ target[prop] = source[prop];
37
+ }
38
+ return target;
39
+ };
40
+ function SceneGridLayoutRenderer({ model }) {
41
+ const { children, isLazy, isDraggable, isResizable } = model.useState();
42
+ const [outerDivRef, { width, height }] = useMeasure();
43
+ const ref = useRef(null);
44
+ useEffect(() => {
45
+ updateAnimationClass(ref, !!isDraggable);
46
+ }, [isDraggable]);
47
+ validateChildrenSize(children);
48
+ const renderGrid = (width2, height2) => {
49
+ if (!width2 || !height2) {
50
+ return null;
51
+ }
52
+ const layout = model.buildGridLayout(width2, height2);
53
+ return /* @__PURE__ */ React.createElement("div", {
54
+ ref,
55
+ style: { width: `${width2}px`, height: "100%" },
56
+ className: "react-grid-layout"
57
+ }, /* @__PURE__ */ React.createElement(ReactGridLayout, {
58
+ width: width2,
59
+ isDraggable: isDraggable && width2 > 768,
60
+ isResizable: isResizable != null ? isResizable : false,
61
+ containerPadding: [0, 0],
62
+ useCSSTransforms: true,
63
+ margin: [GRID_CELL_VMARGIN, GRID_CELL_VMARGIN],
64
+ cols: GRID_COLUMN_COUNT,
65
+ rowHeight: GRID_CELL_HEIGHT,
66
+ draggableHandle: `.grid-drag-handle-${model.state.key}`,
67
+ draggableCancel: ".grid-drag-cancel",
68
+ layout,
69
+ onDragStart: model.onDragStart,
70
+ onDragStop: model.onDragStop,
71
+ onResizeStop: model.onResizeStop,
72
+ onLayoutChange: model.onLayoutChange,
73
+ isBounded: false,
74
+ resizeHandle: /* @__PURE__ */ React.createElement(ResizeHandle, null)
75
+ }, layout.map((gridItem, index) => /* @__PURE__ */ React.createElement(GridItemWrapper, {
76
+ key: gridItem.i,
77
+ grid: model,
78
+ layoutItem: gridItem,
79
+ index,
80
+ isLazy,
81
+ totalCount: layout.length
82
+ }))));
83
+ };
84
+ return /* @__PURE__ */ React.createElement("div", {
85
+ ref: outerDivRef,
86
+ style: { flex: "1 1 auto", position: "relative", zIndex: 1, width: "100%" }
87
+ }, renderGrid(width, height));
88
+ }
89
+ const GridItemWrapper = React.forwardRef((props, ref) => {
90
+ var _b;
91
+ const _a = props, { grid, layoutItem, index, totalCount, isLazy, style, onLoad, onChange, children } = _a, divProps = __objRest(_a, ["grid", "layoutItem", "index", "totalCount", "isLazy", "style", "onLoad", "onChange", "children"]);
92
+ const sceneChild = grid.getSceneLayoutChild(layoutItem.i);
93
+ const className = (_b = sceneChild.getClassName) == null ? void 0 : _b.call(sceneChild);
94
+ const innerContent = /* @__PURE__ */ React.createElement(sceneChild.Component, {
95
+ model: sceneChild,
96
+ key: sceneChild.state.key
97
+ });
98
+ if (isLazy) {
99
+ return /* @__PURE__ */ React.createElement(LazyLoader, __spreadProps(__spreadValues({}, divProps), {
100
+ key: sceneChild.state.key,
101
+ "data-griditem-key": sceneChild.state.key,
102
+ className: cx(className, props.className),
103
+ style,
104
+ ref
105
+ }), innerContent, children);
106
+ }
107
+ return /* @__PURE__ */ React.createElement("div", __spreadProps(__spreadValues({}, divProps), {
108
+ ref,
109
+ key: sceneChild.state.key,
110
+ "data-griditem-key": sceneChild.state.key,
111
+ className: cx(className, props.className),
112
+ style
113
+ }), innerContent, children);
114
+ });
115
+ GridItemWrapper.displayName = "GridItemWrapper";
116
+ function validateChildrenSize(children) {
117
+ if (children.some(
118
+ (c) => c.state.height === void 0 || c.state.width === void 0 || c.state.x === void 0 || c.state.y === void 0
119
+ )) {
120
+ throw new Error("All children must have a size specified");
121
+ }
122
+ }
123
+ function updateAnimationClass(ref, isDraggable, retry) {
124
+ if (ref.current) {
125
+ if (isDraggable) {
126
+ ref.current.classList.add("react-grid-layout--enable-move-animations");
127
+ } else {
128
+ ref.current.classList.remove("react-grid-layout--enable-move-animations");
129
+ }
130
+ } else if (!retry) {
131
+ setTimeout(() => updateAnimationClass(ref, isDraggable, true), 50);
132
+ }
133
+ }
134
+ const ResizeHandle = React.forwardRef((_a, ref) => {
135
+ var _b = _a, divProps = __objRest(_b, ["handleAxis"]);
136
+ const customCssClass = useStyles2(getResizeHandleStyles);
137
+ return /* @__PURE__ */ React.createElement("div", __spreadProps(__spreadValues({
138
+ ref
139
+ }, divProps), {
140
+ className: `${customCssClass} scene-resize-handle`
141
+ }), /* @__PURE__ */ React.createElement("svg", {
142
+ width: "16px",
143
+ height: "16px",
144
+ viewBox: "0 0 24 24",
145
+ fill: "none",
146
+ xmlns: "http://www.w3.org/2000/svg"
147
+ }, /* @__PURE__ */ React.createElement("path", {
148
+ d: "M21 15L15 21M21 8L8 21",
149
+ stroke: "currentColor",
150
+ strokeWidth: "2",
151
+ strokeLinecap: "round",
152
+ strokeLinejoin: "round"
153
+ })));
154
+ });
155
+ ResizeHandle.displayName = "ResizeHandle";
156
+ function getResizeHandleStyles(theme) {
157
+ return css({
158
+ position: "absolute",
159
+ bottom: 0,
160
+ right: 0,
161
+ zIndex: 999,
162
+ padding: theme.spacing(1.5, 0, 0, 1.5),
163
+ color: theme.colors.border.strong,
164
+ cursor: "se-resize",
165
+ "&:hover": {
166
+ color: theme.colors.text.link
167
+ },
168
+ svg: {
169
+ display: "block"
170
+ },
171
+ ".react-resizable-hide &": {
172
+ display: "none"
173
+ }
174
+ });
175
+ }
176
+
177
+ export { SceneGridLayoutRenderer };
178
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"SceneGridLayoutRenderer.js","sources":["../../../../../components/layout/grid/SceneGridLayoutRenderer.js"],"sourcesContent":["import React, { useRef, useEffect } from 'react';\nimport ReactGridLayout from 'react-grid-layout';\nimport { GRID_CELL_VMARGIN, GRID_COLUMN_COUNT, GRID_CELL_HEIGHT } from './constants.js';\nimport { LazyLoader } from '../LazyLoader.js';\nimport { useStyles2 } from '@grafana/ui';\nimport { cx, css } from '@emotion/css';\nimport { useMeasure } from 'react-use';\n\nvar __defProp = Object.defineProperty;\nvar __defProps = Object.defineProperties;\nvar __getOwnPropDescs = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp.call(b, prop))\n      __defNormalProp(a, prop, b[prop]);\n  if (__getOwnPropSymbols)\n    for (var prop of __getOwnPropSymbols(b)) {\n      if (__propIsEnum.call(b, prop))\n        __defNormalProp(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));\nvar __objRest = (source, exclude) => {\n  var target = {};\n  for (var prop in source)\n    if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)\n      target[prop] = source[prop];\n  if (source != null && __getOwnPropSymbols)\n    for (var prop of __getOwnPropSymbols(source)) {\n      if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))\n        target[prop] = source[prop];\n    }\n  return target;\n};\nfunction SceneGridLayoutRenderer({ model }) {\n  const { children, isLazy, isDraggable, isResizable } = model.useState();\n  const [outerDivRef, { width, height }] = useMeasure();\n  const ref = useRef(null);\n  useEffect(() => {\n    updateAnimationClass(ref, !!isDraggable);\n  }, [isDraggable]);\n  validateChildrenSize(children);\n  const renderGrid = (width2, height2) => {\n    if (!width2 || !height2) {\n      return null;\n    }\n    const layout = model.buildGridLayout(width2, height2);\n    return /* @__PURE__ */ React.createElement(\"div\", {\n      ref,\n      style: { width: `${width2}px`, height: \"100%\" },\n      className: \"react-grid-layout\"\n    }, /* @__PURE__ */ React.createElement(ReactGridLayout, {\n      width: width2,\n      isDraggable: isDraggable && width2 > 768,\n      isResizable: isResizable != null ? isResizable : false,\n      containerPadding: [0, 0],\n      useCSSTransforms: true,\n      margin: [GRID_CELL_VMARGIN, GRID_CELL_VMARGIN],\n      cols: GRID_COLUMN_COUNT,\n      rowHeight: GRID_CELL_HEIGHT,\n      draggableHandle: `.grid-drag-handle-${model.state.key}`,\n      draggableCancel: \".grid-drag-cancel\",\n      layout,\n      onDragStart: model.onDragStart,\n      onDragStop: model.onDragStop,\n      onResizeStop: model.onResizeStop,\n      onLayoutChange: model.onLayoutChange,\n      isBounded: false,\n      resizeHandle: /* @__PURE__ */ React.createElement(ResizeHandle, null)\n    }, layout.map((gridItem, index) => /* @__PURE__ */ React.createElement(GridItemWrapper, {\n      key: gridItem.i,\n      grid: model,\n      layoutItem: gridItem,\n      index,\n      isLazy,\n      totalCount: layout.length\n    }))));\n  };\n  return /* @__PURE__ */ React.createElement(\"div\", {\n    ref: outerDivRef,\n    style: { flex: \"1 1 auto\", position: \"relative\", zIndex: 1, width: \"100%\" }\n  }, renderGrid(width, height));\n}\nconst GridItemWrapper = React.forwardRef((props, ref) => {\n  var _b;\n  const _a = props, { grid, layoutItem, index, totalCount, isLazy, style, onLoad, onChange, children } = _a, divProps = __objRest(_a, [\"grid\", \"layoutItem\", \"index\", \"totalCount\", \"isLazy\", \"style\", \"onLoad\", \"onChange\", \"children\"]);\n  const sceneChild = grid.getSceneLayoutChild(layoutItem.i);\n  const className = (_b = sceneChild.getClassName) == null ? void 0 : _b.call(sceneChild);\n  const innerContent = /* @__PURE__ */ React.createElement(sceneChild.Component, {\n    model: sceneChild,\n    key: sceneChild.state.key\n  });\n  if (isLazy) {\n    return /* @__PURE__ */ React.createElement(LazyLoader, __spreadProps(__spreadValues({}, divProps), {\n      key: sceneChild.state.key,\n      \"data-griditem-key\": sceneChild.state.key,\n      className: cx(className, props.className),\n      style,\n      ref\n    }), innerContent, children);\n  }\n  return /* @__PURE__ */ React.createElement(\"div\", __spreadProps(__spreadValues({}, divProps), {\n    ref,\n    key: sceneChild.state.key,\n    \"data-griditem-key\": sceneChild.state.key,\n    className: cx(className, props.className),\n    style\n  }), innerContent, children);\n});\nGridItemWrapper.displayName = \"GridItemWrapper\";\nfunction validateChildrenSize(children) {\n  if (children.some(\n    (c) => c.state.height === void 0 || c.state.width === void 0 || c.state.x === void 0 || c.state.y === void 0\n  )) {\n    throw new Error(\"All children must have a size specified\");\n  }\n}\nfunction updateAnimationClass(ref, isDraggable, retry) {\n  if (ref.current) {\n    if (isDraggable) {\n      ref.current.classList.add(\"react-grid-layout--enable-move-animations\");\n    } else {\n      ref.current.classList.remove(\"react-grid-layout--enable-move-animations\");\n    }\n  } else if (!retry) {\n    setTimeout(() => updateAnimationClass(ref, isDraggable, true), 50);\n  }\n}\nconst ResizeHandle = React.forwardRef((_a, ref) => {\n  var _b = _a, divProps = __objRest(_b, [\"handleAxis\"]);\n  const customCssClass = useStyles2(getResizeHandleStyles);\n  return /* @__PURE__ */ React.createElement(\"div\", __spreadProps(__spreadValues({\n    ref\n  }, divProps), {\n    className: `${customCssClass} scene-resize-handle`\n  }), /* @__PURE__ */ React.createElement(\"svg\", {\n    width: \"16px\",\n    height: \"16px\",\n    viewBox: \"0 0 24 24\",\n    fill: \"none\",\n    xmlns: \"http://www.w3.org/2000/svg\"\n  }, /* @__PURE__ */ React.createElement(\"path\", {\n    d: \"M21 15L15 21M21 8L8 21\",\n    stroke: \"currentColor\",\n    strokeWidth: \"2\",\n    strokeLinecap: \"round\",\n    strokeLinejoin: \"round\"\n  })));\n});\nResizeHandle.displayName = \"ResizeHandle\";\nfunction getResizeHandleStyles(theme) {\n  return css({\n    position: \"absolute\",\n    bottom: 0,\n    right: 0,\n    zIndex: 999,\n    padding: theme.spacing(1.5, 0, 0, 1.5),\n    color: theme.colors.border.strong,\n    cursor: \"se-resize\",\n    \"&:hover\": {\n      color: theme.colors.text.link\n    },\n    svg: {\n      display: \"block\"\n    },\n    \".react-resizable-hide &\": {\n      display: \"none\"\n    }\n  });\n}\n\nexport { SceneGridLayoutRenderer };\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"SceneGridLayoutRenderer.js","sources":["../../../../../src/components/layout/grid/SceneGridLayoutRenderer.tsx"],"sourcesContent":["import React, { RefCallback, useEffect, useRef } from 'react';\nimport ReactGridLayout from 'react-grid-layout';\nimport { SceneComponentProps } from '../../../core/types';\nimport { GRID_CELL_HEIGHT, GRID_CELL_VMARGIN, GRID_COLUMN_COUNT } from './constants';\nimport { LazyLoader } from '../LazyLoader';\nimport { SceneGridLayout } from './SceneGridLayout';\nimport { SceneGridItemLike } from './types';\nimport { useStyles2 } from '@grafana/ui';\nimport { css, cx } from '@emotion/css';\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { useMeasure } from 'react-use';\n\nexport function SceneGridLayoutRenderer({ model }: SceneComponentProps<SceneGridLayout>) {\n  const { children, isLazy, isDraggable, isResizable } = model.useState();\n  const [outerDivRef, { width, height }] = useMeasure();\n  const ref = useRef<HTMLDivElement | null>(null);\n\n  /**\n   * The class that enables drag animations needs to be added after mount otherwise panels move on mount to their set positions which is annoying\n   */\n  useEffect(() => {\n    updateAnimationClass(ref, !!isDraggable);\n  }, [isDraggable]);\n\n  validateChildrenSize(children);\n\n  const renderGrid = (width: number, height: number) => {\n    if (!width || !height) {\n      return null;\n    }\n\n    const layout = model.buildGridLayout(width, height);\n\n    return (\n      /**\n       * The children is using a width of 100% so we need to guarantee that it is wrapped\n       * in an element that has the calculated size given by the AutoSizer. The AutoSizer\n       * has a width of 0 and will let its content overflow its div.\n       */\n      <div ref={ref} style={{ width: `${width}px`, height: '100%' }} className=\"react-grid-layout\">\n        <ReactGridLayout\n          width={width}\n          /**\n                Disable draggable if mobile device, solving an issue with unintentionally\n                moving panels. https://github.com/grafana/grafana/issues/18497\n                theme.breakpoints.md = 769\n           */\n          isDraggable={isDraggable && width > 768}\n          isResizable={isResizable ?? false}\n          containerPadding={[0, 0]}\n          useCSSTransforms={true}\n          margin={[GRID_CELL_VMARGIN, GRID_CELL_VMARGIN]}\n          cols={GRID_COLUMN_COUNT}\n          rowHeight={GRID_CELL_HEIGHT}\n          draggableHandle={`.grid-drag-handle-${model.state.key}`}\n          draggableCancel=\".grid-drag-cancel\"\n          layout={layout}\n          onDragStart={model.onDragStart}\n          onDragStop={model.onDragStop}\n          onResizeStop={model.onResizeStop}\n          onLayoutChange={model.onLayoutChange}\n          isBounded={false}\n          resizeHandle={<ResizeHandle />}\n        >\n          {layout.map((gridItem, index) => (\n            <GridItemWrapper\n              key={gridItem.i}\n              grid={model}\n              layoutItem={gridItem}\n              index={index}\n              isLazy={isLazy}\n              totalCount={layout.length}\n            />\n          ))}\n        </ReactGridLayout>\n      </div>\n    );\n  };\n\n  return (\n    <div\n      ref={outerDivRef as RefCallback<HTMLDivElement>}\n      style={{ flex: '1 1 auto', position: 'relative', zIndex: 1, width: '100%' }}\n    >\n      {renderGrid(width, height)}\n    </div>\n  );\n}\n\ninterface GridItemWrapperProps extends React.HTMLAttributes<HTMLDivElement> {\n  grid: SceneGridLayout;\n  layoutItem: ReactGridLayout.Layout;\n  index: number;\n  totalCount: number;\n  isLazy?: boolean;\n}\n\nconst GridItemWrapper = React.forwardRef<HTMLDivElement, GridItemWrapperProps>((props, ref) => {\n  const { grid, layoutItem, index, totalCount, isLazy, style, onLoad, onChange, children, ...divProps } = props;\n  const sceneChild = grid.getSceneLayoutChild(layoutItem.i)!;\n  const className = sceneChild.getClassName?.();\n\n  const innerContent = <sceneChild.Component model={sceneChild} key={sceneChild.state.key} />;\n\n  if (isLazy) {\n    return (\n      <LazyLoader\n        {...divProps}\n        key={sceneChild.state.key!}\n        data-griditem-key={sceneChild.state.key}\n        className={cx(className, props.className)}\n        style={style}\n        ref={ref}\n      >\n        {innerContent}\n        {children}\n      </LazyLoader>\n    );\n  }\n\n  return (\n    <div\n      {...divProps}\n      ref={ref}\n      key={sceneChild.state.key}\n      data-griditem-key={sceneChild.state.key}\n      className={cx(className, props.className)}\n      style={style}\n    >\n      {innerContent}\n      {children}\n    </div>\n  );\n});\n\nGridItemWrapper.displayName = 'GridItemWrapper';\n\nfunction validateChildrenSize(children: SceneGridItemLike[]) {\n  if (\n    children.some(\n      (c) =>\n        c.state.height === undefined ||\n        c.state.width === undefined ||\n        c.state.x === undefined ||\n        c.state.y === undefined\n    )\n  ) {\n    throw new Error('All children must have a size specified');\n  }\n}\n\nfunction updateAnimationClass(\n  ref: React.MutableRefObject<HTMLDivElement | null>,\n  isDraggable: boolean,\n  retry?: boolean\n) {\n  if (ref.current) {\n    if (isDraggable) {\n      ref.current.classList.add('react-grid-layout--enable-move-animations');\n    } else {\n      ref.current.classList.remove('react-grid-layout--enable-move-animations');\n    }\n  } else if (!retry) {\n    setTimeout(() => updateAnimationClass(ref, isDraggable, true), 50);\n  }\n}\n\ninterface ResizeHandleProps extends React.HTMLAttributes<HTMLDivElement> {\n  handleAxis?: string;\n}\n\nconst ResizeHandle = React.forwardRef<HTMLDivElement, ResizeHandleProps>(({ handleAxis, ...divProps }, ref) => {\n  const customCssClass = useStyles2(getResizeHandleStyles);\n\n  return (\n    <div ref={ref} {...divProps} className={`${customCssClass} scene-resize-handle`}>\n      <svg width=\"16px\" height=\"16px\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path\n          d=\"M21 15L15 21M21 8L8 21\"\n          stroke=\"currentColor\"\n          strokeWidth=\"2\"\n          strokeLinecap=\"round\"\n          strokeLinejoin=\"round\"\n        />\n      </svg>\n    </div>\n  );\n});\n\nResizeHandle.displayName = 'ResizeHandle';\n\nfunction getResizeHandleStyles(theme: GrafanaTheme2) {\n  return css({\n    position: 'absolute',\n    bottom: 0,\n    right: 0,\n    zIndex: 999,\n    padding: theme.spacing(1.5, 0, 0, 1.5),\n    color: theme.colors.border.strong,\n    cursor: 'se-resize',\n    '&:hover': {\n      color: theme.colors.text.link,\n    },\n    svg: {\n      display: 'block',\n    },\n    '.react-resizable-hide &': {\n      display: 'none',\n    },\n  });\n}\n"],"names":["width","height"],"mappings":"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"}\n"],"names":["width","height"],"mappings":"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"}
@@ -0,0 +1,190 @@
1
+ import { cx, css } from '@emotion/css';
2
+ import React from 'react';
3
+ import { useStyles2, Icon } from '@grafana/ui';
4
+ import { SceneObjectBase } from '../../../core/SceneObjectBase.js';
5
+ import { SceneGridLayout } from './SceneGridLayout.js';
6
+ import { GRID_COLUMN_COUNT } from './constants.js';
7
+ import { sceneGraph } from '../../../core/sceneGraph/index.js';
8
+ import { selectors } from '@grafana/e2e-selectors';
9
+ import { VariableDependencyConfig } from '../../../variables/VariableDependencyConfig.js';
10
+
11
+ var __defProp = Object.defineProperty;
12
+ var __defProps = Object.defineProperties;
13
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
14
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
15
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
16
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
17
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
18
+ var __spreadValues = (a, b) => {
19
+ for (var prop in b || (b = {}))
20
+ if (__hasOwnProp.call(b, prop))
21
+ __defNormalProp(a, prop, b[prop]);
22
+ if (__getOwnPropSymbols)
23
+ for (var prop of __getOwnPropSymbols(b)) {
24
+ if (__propIsEnum.call(b, prop))
25
+ __defNormalProp(a, prop, b[prop]);
26
+ }
27
+ return a;
28
+ };
29
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
30
+ class SceneGridRow extends SceneObjectBase {
31
+ constructor(state) {
32
+ super(__spreadProps(__spreadValues({
33
+ children: state.children || [],
34
+ isCollapsible: state.isCollapsible || true,
35
+ title: state.title || ""
36
+ }, state), {
37
+ x: 0,
38
+ height: 1,
39
+ width: GRID_COLUMN_COUNT
40
+ }));
41
+ this._variableDependency = new VariableDependencyConfig(this, {
42
+ statePaths: ["title"],
43
+ handleTimeMacros: true
44
+ });
45
+ this.onCollapseToggle = () => {
46
+ if (!this.state.isCollapsible) {
47
+ return;
48
+ }
49
+ this.getGridLayout().toggleRow(this);
50
+ };
51
+ }
52
+ getGridLayout() {
53
+ const layout = this.parent;
54
+ if (!layout || !(layout instanceof SceneGridLayout)) {
55
+ throw new Error("SceneGridRow must be a child of SceneGridLayout");
56
+ }
57
+ return layout;
58
+ }
59
+ getUrlState() {
60
+ return { rowc: this.state.isCollapsed ? "1" : "0" };
61
+ }
62
+ updateFromUrl(values) {
63
+ if (values.rowc == null) {
64
+ return;
65
+ }
66
+ if (values.rowc !== this.getUrlState().rowc) {
67
+ this.onCollapseToggle();
68
+ }
69
+ }
70
+ }
71
+ SceneGridRow.Component = SceneGridRowRenderer;
72
+ function SceneGridRowRenderer({ model }) {
73
+ const styles = useStyles2(getSceneGridRowStyles);
74
+ const { isCollapsible, isCollapsed, title, actions, children } = model.useState();
75
+ const layout = model.getGridLayout();
76
+ const layoutDragClass = layout.getDragClass();
77
+ const isDraggable = layout.isDraggable();
78
+ const count = children ? children.length : 0;
79
+ const panels = count === 1 ? "panel" : "panels";
80
+ return /* @__PURE__ */ React.createElement("div", {
81
+ className: cx(styles.row, isCollapsed && styles.rowCollapsed)
82
+ }, /* @__PURE__ */ React.createElement("div", {
83
+ className: styles.rowTitleAndActionsGroup
84
+ }, /* @__PURE__ */ React.createElement("button", {
85
+ onClick: model.onCollapseToggle,
86
+ className: styles.rowTitleButton,
87
+ "aria-label": isCollapsed ? "Expand row" : "Collapse row",
88
+ "data-testid": selectors.components.DashboardRow.title(sceneGraph.interpolate(model, title, void 0, "text"))
89
+ }, isCollapsible && /* @__PURE__ */ React.createElement(Icon, {
90
+ name: isCollapsed ? "angle-right" : "angle-down"
91
+ }), /* @__PURE__ */ React.createElement("span", {
92
+ className: styles.rowTitle,
93
+ role: "heading"
94
+ }, sceneGraph.interpolate(model, title, void 0, "text"))), /* @__PURE__ */ React.createElement("span", {
95
+ className: cx(styles.panelCount, isCollapsed && styles.panelCountCollapsed)
96
+ }, "(", count, " ", panels, ")"), actions && /* @__PURE__ */ React.createElement("div", {
97
+ className: styles.rowActions
98
+ }, /* @__PURE__ */ React.createElement(actions.Component, {
99
+ model: actions
100
+ }))), isDraggable && isCollapsed && /* @__PURE__ */ React.createElement("div", {
101
+ className: cx(styles.dragHandle, layoutDragClass)
102
+ }, /* @__PURE__ */ React.createElement(Icon, {
103
+ name: "draggabledots"
104
+ })));
105
+ }
106
+ const getSceneGridRowStyles = (theme) => {
107
+ return {
108
+ row: css({
109
+ width: "100%",
110
+ height: "30px",
111
+ display: "flex",
112
+ justifyContent: "space-between",
113
+ gap: theme.spacing(1)
114
+ }),
115
+ rowTitleButton: css({
116
+ display: "flex",
117
+ alignItems: "center",
118
+ cursor: "pointer",
119
+ background: "transparent",
120
+ border: "none",
121
+ minWidth: 0,
122
+ gap: theme.spacing(1)
123
+ }),
124
+ rowCollapsed: css({
125
+ borderBottom: `1px solid ${theme.colors.border.weak}`
126
+ }),
127
+ rowTitle: css({
128
+ fontSize: theme.typography.h5.fontSize,
129
+ fontWeight: theme.typography.fontWeightMedium,
130
+ whiteSpace: "nowrap",
131
+ overflow: "hidden",
132
+ textOverflow: "ellipsis",
133
+ maxWidth: "100%",
134
+ flexGrow: 1,
135
+ minWidth: 0
136
+ }),
137
+ collapsedInfo: css({
138
+ fontSize: theme.typography.bodySmall.fontSize,
139
+ color: theme.colors.text.secondary,
140
+ display: "flex",
141
+ alignItems: "center",
142
+ flexGrow: 1
143
+ }),
144
+ rowTitleAndActionsGroup: css({
145
+ display: "flex",
146
+ minWidth: 0,
147
+ "&:hover, &:focus-within": {
148
+ "& > div": {
149
+ opacity: 1
150
+ }
151
+ }
152
+ }),
153
+ rowActions: css({
154
+ display: "flex",
155
+ whiteSpace: "nowrap",
156
+ opacity: 0,
157
+ transition: "200ms opacity ease-in 200ms",
158
+ "&:hover, &:focus-within": {
159
+ opacity: 1
160
+ }
161
+ }),
162
+ dragHandle: css({
163
+ display: "flex",
164
+ padding: theme.spacing(0, 1),
165
+ alignItems: "center",
166
+ justifyContent: "flex-end",
167
+ cursor: "move",
168
+ color: theme.colors.text.secondary,
169
+ "&:hover": {
170
+ color: theme.colors.text.primary
171
+ }
172
+ }),
173
+ panelCount: css({
174
+ whiteSpace: "nowrap",
175
+ paddingLeft: theme.spacing(2),
176
+ color: theme.colors.text.secondary,
177
+ fontStyle: "italic",
178
+ fontSize: theme.typography.size.sm,
179
+ fontWeight: "normal",
180
+ display: "none",
181
+ lineHeight: "30px"
182
+ }),
183
+ panelCountCollapsed: css({
184
+ display: "inline-block"
185
+ })
186
+ };
187
+ };
188
+
189
+ export { SceneGridRow, SceneGridRowRenderer, getSceneGridRowStyles };
190
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"SceneGridRow.js","sources":["../../../../../components/layout/grid/SceneGridRow.js"],"sourcesContent":["import { cx, css } from '@emotion/css';\nimport React from 'react';\nimport { useStyles2, Icon } from '@grafana/ui';\nimport { SceneObjectBase } from '../../../core/SceneObjectBase.js';\nimport { SceneGridLayout } from './SceneGridLayout.js';\nimport { GRID_COLUMN_COUNT } from './constants.js';\nimport { sceneGraph } from '../../../core/sceneGraph/index.js';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { VariableDependencyConfig } from '../../../variables/VariableDependencyConfig.js';\n\nvar __defProp = Object.defineProperty;\nvar __defProps = Object.defineProperties;\nvar __getOwnPropDescs = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp.call(b, prop))\n      __defNormalProp(a, prop, b[prop]);\n  if (__getOwnPropSymbols)\n    for (var prop of __getOwnPropSymbols(b)) {\n      if (__propIsEnum.call(b, prop))\n        __defNormalProp(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));\nclass SceneGridRow extends SceneObjectBase {\n  constructor(state) {\n    super(__spreadProps(__spreadValues({\n      children: state.children || [],\n      isCollapsible: state.isCollapsible || true,\n      title: state.title || \"\"\n    }, state), {\n      x: 0,\n      height: 1,\n      width: GRID_COLUMN_COUNT\n    }));\n    this._variableDependency = new VariableDependencyConfig(this, {\n      statePaths: [\"title\"],\n      handleTimeMacros: true\n    });\n    this.onCollapseToggle = () => {\n      if (!this.state.isCollapsible) {\n        return;\n      }\n      this.getGridLayout().toggleRow(this);\n    };\n  }\n  getGridLayout() {\n    const layout = this.parent;\n    if (!layout || !(layout instanceof SceneGridLayout)) {\n      throw new Error(\"SceneGridRow must be a child of SceneGridLayout\");\n    }\n    return layout;\n  }\n  getUrlState() {\n    return { rowc: this.state.isCollapsed ? \"1\" : \"0\" };\n  }\n  updateFromUrl(values) {\n    if (values.rowc == null) {\n      return;\n    }\n    if (values.rowc !== this.getUrlState().rowc) {\n      this.onCollapseToggle();\n    }\n  }\n}\nSceneGridRow.Component = SceneGridRowRenderer;\nfunction SceneGridRowRenderer({ model }) {\n  const styles = useStyles2(getSceneGridRowStyles);\n  const { isCollapsible, isCollapsed, title, actions, children } = model.useState();\n  const layout = model.getGridLayout();\n  const layoutDragClass = layout.getDragClass();\n  const isDraggable = layout.isDraggable();\n  const count = children ? children.length : 0;\n  const panels = count === 1 ? \"panel\" : \"panels\";\n  return /* @__PURE__ */ React.createElement(\"div\", {\n    className: cx(styles.row, isCollapsed && styles.rowCollapsed)\n  }, /* @__PURE__ */ React.createElement(\"div\", {\n    className: styles.rowTitleAndActionsGroup\n  }, /* @__PURE__ */ React.createElement(\"button\", {\n    onClick: model.onCollapseToggle,\n    className: styles.rowTitleButton,\n    \"aria-label\": isCollapsed ? \"Expand row\" : \"Collapse row\",\n    \"data-testid\": selectors.components.DashboardRow.title(sceneGraph.interpolate(model, title, void 0, \"text\"))\n  }, isCollapsible && /* @__PURE__ */ React.createElement(Icon, {\n    name: isCollapsed ? \"angle-right\" : \"angle-down\"\n  }), /* @__PURE__ */ React.createElement(\"span\", {\n    className: styles.rowTitle,\n    role: \"heading\"\n  }, sceneGraph.interpolate(model, title, void 0, \"text\"))), /* @__PURE__ */ React.createElement(\"span\", {\n    className: cx(styles.panelCount, isCollapsed && styles.panelCountCollapsed)\n  }, \"(\", count, \" \", panels, \")\"), actions && /* @__PURE__ */ React.createElement(\"div\", {\n    className: styles.rowActions\n  }, /* @__PURE__ */ React.createElement(actions.Component, {\n    model: actions\n  }))), isDraggable && isCollapsed && /* @__PURE__ */ React.createElement(\"div\", {\n    className: cx(styles.dragHandle, layoutDragClass)\n  }, /* @__PURE__ */ React.createElement(Icon, {\n    name: \"draggabledots\"\n  })));\n}\nconst getSceneGridRowStyles = (theme) => {\n  return {\n    row: css({\n      width: \"100%\",\n      height: \"30px\",\n      display: \"flex\",\n      justifyContent: \"space-between\",\n      gap: theme.spacing(1)\n    }),\n    rowTitleButton: css({\n      display: \"flex\",\n      alignItems: \"center\",\n      cursor: \"pointer\",\n      background: \"transparent\",\n      border: \"none\",\n      minWidth: 0,\n      gap: theme.spacing(1)\n    }),\n    rowCollapsed: css({\n      borderBottom: `1px solid ${theme.colors.border.weak}`\n    }),\n    rowTitle: css({\n      fontSize: theme.typography.h5.fontSize,\n      fontWeight: theme.typography.fontWeightMedium,\n      whiteSpace: \"nowrap\",\n      overflow: \"hidden\",\n      textOverflow: \"ellipsis\",\n      maxWidth: \"100%\",\n      flexGrow: 1,\n      minWidth: 0\n    }),\n    collapsedInfo: css({\n      fontSize: theme.typography.bodySmall.fontSize,\n      color: theme.colors.text.secondary,\n      display: \"flex\",\n      alignItems: \"center\",\n      flexGrow: 1\n    }),\n    rowTitleAndActionsGroup: css({\n      display: \"flex\",\n      minWidth: 0,\n      \"&:hover, &:focus-within\": {\n        \"& > div\": {\n          opacity: 1\n        }\n      }\n    }),\n    rowActions: css({\n      display: \"flex\",\n      whiteSpace: \"nowrap\",\n      opacity: 0,\n      transition: \"200ms opacity ease-in 200ms\",\n      \"&:hover, &:focus-within\": {\n        opacity: 1\n      }\n    }),\n    dragHandle: css({\n      display: \"flex\",\n      padding: theme.spacing(0, 1),\n      alignItems: \"center\",\n      justifyContent: \"flex-end\",\n      cursor: \"move\",\n      color: theme.colors.text.secondary,\n      \"&:hover\": {\n        color: theme.colors.text.primary\n      }\n    }),\n    panelCount: css({\n      whiteSpace: \"nowrap\",\n      paddingLeft: theme.spacing(2),\n      color: theme.colors.text.secondary,\n      fontStyle: \"italic\",\n      fontSize: theme.typography.size.sm,\n      fontWeight: \"normal\",\n      display: \"none\",\n      lineHeight: \"30px\"\n    }),\n    panelCountCollapsed: css({\n      display: \"inline-block\"\n    })\n  };\n};\n\nexport { SceneGridRow, SceneGridRowRenderer, getSceneGridRowStyles };\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"SceneGridRow.js","sources":["../../../../../src/components/layout/grid/SceneGridRow.tsx"],"sourcesContent":["import { css, cx } from '@emotion/css';\nimport React from 'react';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { Icon, useStyles2 } from '@grafana/ui';\n\nimport { SceneObjectBase } from '../../../core/SceneObjectBase';\nimport { SceneComponentProps, SceneObject, SceneObjectUrlValues } from '../../../core/types';\n\nimport { SceneGridLayout } from './SceneGridLayout';\nimport { GRID_COLUMN_COUNT } from './constants';\nimport { SceneGridItemLike, SceneGridItemStateLike } from './types';\nimport { sceneGraph } from '../../../core/sceneGraph';\nimport { selectors } from '@grafana/e2e-selectors';\nimport { VariableDependencyConfig } from '../../../variables/VariableDependencyConfig';\n\nexport interface SceneGridRowState extends SceneGridItemStateLike {\n  title: string;\n  isCollapsible?: boolean;\n  isCollapsed?: boolean;\n  actions?: SceneObject;\n  children: SceneGridItemLike[];\n}\n\nexport class SceneGridRow extends SceneObjectBase<SceneGridRowState> {\n  public static Component = SceneGridRowRenderer;\n\n  protected _variableDependency = new VariableDependencyConfig(this, {\n    statePaths: ['title'],\n    handleTimeMacros: true,\n  });\n\n  public constructor(state: Partial<SceneGridRowState>) {\n    super({\n      children: state.children || [],\n      isCollapsible: state.isCollapsible || true,\n      title: state.title || '',\n      ...state,\n      x: 0,\n      height: 1,\n      width: GRID_COLUMN_COUNT,\n    });\n  }\n\n  public getGridLayout(): SceneGridLayout {\n    const layout = this.parent;\n\n    if (!layout || !(layout instanceof SceneGridLayout)) {\n      throw new Error('SceneGridRow must be a child of SceneGridLayout');\n    }\n\n    return layout;\n  }\n\n  public onCollapseToggle = () => {\n    if (!this.state.isCollapsible) {\n      return;\n    }\n\n    this.getGridLayout().toggleRow(this);\n  };\n\n  public getUrlState() {\n    return { rowc: this.state.isCollapsed ? '1' : '0' };\n  }\n\n  public updateFromUrl(values: SceneObjectUrlValues) {\n    if (values.rowc == null) {\n      return;\n    }\n\n    if (values.rowc !== this.getUrlState().rowc) {\n      this.onCollapseToggle();\n    }\n  }\n}\n\nexport function SceneGridRowRenderer({ model }: SceneComponentProps<SceneGridRow>) {\n  const styles = useStyles2(getSceneGridRowStyles);\n  const { isCollapsible, isCollapsed, title, actions, children } = model.useState();\n  const layout = model.getGridLayout();\n  const layoutDragClass = layout.getDragClass();\n  const isDraggable = layout.isDraggable();\n\n  const count = children ? children.length : 0;\n  const panels = count === 1 ? 'panel' : 'panels';\n\n  return (\n    <div className={cx(styles.row, isCollapsed && styles.rowCollapsed)}>\n      <div className={styles.rowTitleAndActionsGroup}>\n        <button\n          onClick={model.onCollapseToggle}\n          className={styles.rowTitleButton}\n          aria-label={isCollapsed ? 'Expand row' : 'Collapse row'}\n          data-testid={selectors.components.DashboardRow.title(sceneGraph.interpolate(model, title, undefined, 'text'))}\n        >\n          {isCollapsible && <Icon name={isCollapsed ? 'angle-right' : 'angle-down'} />}\n          <span className={styles.rowTitle} role=\"heading\">\n            {sceneGraph.interpolate(model, title, undefined, 'text')}\n          </span>\n        </button>\n        <span className={cx(styles.panelCount, isCollapsed && styles.panelCountCollapsed)}>\n          ({count} {panels})\n        </span>\n        {actions && (\n          <div className={styles.rowActions}>\n            <actions.Component model={actions} />\n          </div>\n        )}\n      </div>\n      {isDraggable && isCollapsed && (\n        <div className={cx(styles.dragHandle, layoutDragClass)}>\n          <Icon name=\"draggabledots\" />\n        </div>\n      )}\n    </div>\n  );\n}\n\nexport const getSceneGridRowStyles = (theme: GrafanaTheme2) => {\n  return {\n    row: css({\n      width: '100%',\n      height: '30px',\n      display: 'flex',\n      justifyContent: 'space-between',\n      gap: theme.spacing(1),\n    }),\n    rowTitleButton: css({\n      display: 'flex',\n      alignItems: 'center',\n      cursor: 'pointer',\n      background: 'transparent',\n      border: 'none',\n      minWidth: 0,\n      gap: theme.spacing(1),\n    }),\n    rowCollapsed: css({\n      borderBottom: `1px solid ${theme.colors.border.weak}`,\n    }),\n    rowTitle: css({\n      fontSize: theme.typography.h5.fontSize,\n      fontWeight: theme.typography.fontWeightMedium,\n      whiteSpace: 'nowrap',\n      overflow: 'hidden',\n      textOverflow: 'ellipsis',\n      maxWidth: '100%',\n      flexGrow: 1,\n      minWidth: 0,\n    }),\n    collapsedInfo: css({\n      fontSize: theme.typography.bodySmall.fontSize,\n      color: theme.colors.text.secondary,\n      display: 'flex',\n      alignItems: 'center',\n      flexGrow: 1,\n    }),\n    rowTitleAndActionsGroup: css({\n      display: 'flex',\n      minWidth: 0,\n\n      '&:hover, &:focus-within': {\n        '& > div': {\n          opacity: 1,\n        },\n      },\n    }),\n    rowActions: css({\n      display: 'flex',\n      whiteSpace: 'nowrap',\n      opacity: 0,\n      transition: '200ms opacity ease-in 200ms',\n\n      '&:hover, &:focus-within': {\n        opacity: 1,\n      },\n    }),\n    dragHandle: css({\n      display: 'flex',\n      padding: theme.spacing(0, 1),\n      alignItems: 'center',\n      justifyContent: 'flex-end',\n      cursor: 'move',\n      color: theme.colors.text.secondary,\n      '&:hover': {\n        color: theme.colors.text.primary,\n      },\n    }),\n    panelCount: css({\n      whiteSpace: 'nowrap',\n      paddingLeft: theme.spacing(2),\n      color: theme.colors.text.secondary,\n      fontStyle: 'italic',\n      fontSize: theme.typography.size.sm,\n      fontWeight: 'normal',\n      display: 'none',\n      lineHeight: '30px',\n    }),\n    panelCountCollapsed: css({\n      display: 'inline-block',\n    }),\n  };\n};\n"],"names":[],"mappings":"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"}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ const DEFAULT_PANEL_SPAN = 4;
2
+ const GRID_CELL_HEIGHT = 30;
3
+ const GRID_CELL_VMARGIN = 8;
4
+ const GRID_COLUMN_COUNT = 24;
5
+
6
+ export { DEFAULT_PANEL_SPAN, GRID_CELL_HEIGHT, GRID_CELL_VMARGIN, GRID_COLUMN_COUNT };
7
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9jb21wb25lbnRzL2xheW91dC9ncmlkL2NvbnN0YW50cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBERUZBVUxUX1BBTkVMX1NQQU4gPSA0O1xuY29uc3QgR1JJRF9DRUxMX0hFSUdIVCA9IDMwO1xuY29uc3QgR1JJRF9DRUxMX1ZNQVJHSU4gPSA4O1xuY29uc3QgR1JJRF9DT0xVTU5fQ09VTlQgPSAyNDtcblxuZXhwb3J0IHsgREVGQVVMVF9QQU5FTF9TUEFOLCBHUklEX0NFTExfSEVJR0hULCBHUklEX0NFTExfVk1BUkdJTiwgR1JJRF9DT0xVTU5fQ09VTlQgfTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWRhdGE6YXBwbGljYXRpb24vanNvbjtjaGFyc2V0PXV0Zi04O2Jhc2U2NCxleUoyWlhKemFXOXVJam96TENKbWFXeGxJam9pWTI5dWMzUmhiblJ6TG1weklpd2ljMjkxY21ObGN5STZXeUl1TGk4dUxpOHVMaTh1TGk4dUxpOXpjbU12WTI5dGNHOXVaVzUwY3k5c1lYbHZkWFF2WjNKcFpDOWpiMjV6ZEdGdWRITXVkSE1pWFN3aWMyOTFjbU5sYzBOdmJuUmxiblFpT2xzaVpYaHdiM0owSUdOdmJuTjBJRVJGUmtGVlRGUmZVRUZPUlV4ZlUxQkJUaUE5SURRN1hHNWxlSEJ2Y25RZ1kyOXVjM1FnUjFKSlJGOURSVXhNWDBoRlNVZElWQ0E5SURNd08xeHVaWGh3YjNKMElHTnZibk4wSUVkU1NVUmZRMFZNVEY5V1RVRlNSMGxPSUQwZ09EdGNibVY0Y0c5eWRDQmpiMjV6ZENCSFVrbEVYME5QVEZWTlRsOURUMVZPVkNBOUlESTBPMXh1SWwwc0ltNWhiV1Z6SWpwYlhTd2liV0Z3Y0dsdVozTWlPaUpCUVVGUExFMUJRVTBzYTBKQlFYRkNMRWRCUVVFc1JVRkJRVHRCUVVNelFpeE5RVUZOTEdkQ1FVRnRRaXhIUVVGQkxFZEJRVUU3UVVGRGVrSXNUVUZCVFN4cFFrRkJiMElzUjBGQlFTeEZRVUZCTzBGQlF6RkNMRTFCUVUwc2FVSkJRVzlDTEVkQlFVRTdPenM3SW4wPVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFPLE1BQU0sa0JBQXFCLEdBQUEsRUFBQTtBQUMzQixNQUFNLGdCQUFtQixHQUFBLEdBQUE7QUFDekIsTUFBTSxpQkFBb0IsR0FBQSxFQUFBO0FBQzFCLE1BQU0saUJBQW9CLEdBQUE7Ozs7In0=
@@ -0,0 +1,36 @@
1
+ import { GRID_CELL_HEIGHT, GRID_CELL_VMARGIN } from './constants.js';
2
+
3
+ var __defProp = Object.defineProperty;
4
+ var __defProps = Object.defineProperties;
5
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
6
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
9
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
10
+ var __spreadValues = (a, b) => {
11
+ for (var prop in b || (b = {}))
12
+ if (__hasOwnProp.call(b, prop))
13
+ __defNormalProp(a, prop, b[prop]);
14
+ if (__getOwnPropSymbols)
15
+ for (var prop of __getOwnPropSymbols(b)) {
16
+ if (__propIsEnum.call(b, prop))
17
+ __defNormalProp(a, prop, b[prop]);
18
+ }
19
+ return a;
20
+ };
21
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
22
+ function fitPanelsInHeight(cells, height) {
23
+ const visibleHeight = height - GRID_CELL_VMARGIN * 4;
24
+ const currentGridHeight = Math.max(...cells.map((cell) => cell.h + cell.y));
25
+ const visibleGridHeight = Math.floor(visibleHeight / (GRID_CELL_HEIGHT + GRID_CELL_VMARGIN));
26
+ const scaleFactor = currentGridHeight / visibleGridHeight;
27
+ return cells.map((cell) => {
28
+ return __spreadProps(__spreadValues({}, cell), {
29
+ y: Math.round(cell.y / scaleFactor) || 0,
30
+ h: Math.round(cell.h / scaleFactor) || 1
31
+ });
32
+ });
33
+ }
34
+
35
+ export { fitPanelsInHeight };
36
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2NvbXBvbmVudHMvbGF5b3V0L2dyaWQvdXRpbHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR1JJRF9DRUxMX0hFSUdIVCwgR1JJRF9DRUxMX1ZNQVJHSU4gfSBmcm9tICcuL2NvbnN0YW50cy5qcyc7XG5cbnZhciBfX2RlZlByb3AgPSBPYmplY3QuZGVmaW5lUHJvcGVydHk7XG52YXIgX19kZWZQcm9wcyA9IE9iamVjdC5kZWZpbmVQcm9wZXJ0aWVzO1xudmFyIF9fZ2V0T3duUHJvcERlc2NzID0gT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnM7XG52YXIgX19nZXRPd25Qcm9wU3ltYm9scyA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHM7XG52YXIgX19oYXNPd25Qcm9wID0gT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eTtcbnZhciBfX3Byb3BJc0VudW0gPSBPYmplY3QucHJvdG90eXBlLnByb3BlcnR5SXNFbnVtZXJhYmxlO1xudmFyIF9fZGVmTm9ybWFsUHJvcCA9IChvYmosIGtleSwgdmFsdWUpID0+IGtleSBpbiBvYmogPyBfX2RlZlByb3Aob2JqLCBrZXksIHsgZW51bWVyYWJsZTogdHJ1ZSwgY29uZmlndXJhYmxlOiB0cnVlLCB3cml0YWJsZTogdHJ1ZSwgdmFsdWUgfSkgOiBvYmpba2V5XSA9IHZhbHVlO1xudmFyIF9fc3ByZWFkVmFsdWVzID0gKGEsIGIpID0+IHtcbiAgZm9yICh2YXIgcHJvcCBpbiBiIHx8IChiID0ge30pKVxuICAgIGlmIChfX2hhc093blByb3AuY2FsbChiLCBwcm9wKSlcbiAgICAgIF9fZGVmTm9ybWFsUHJvcChhLCBwcm9wLCBiW3Byb3BdKTtcbiAgaWYgKF9fZ2V0T3duUHJvcFN5bWJvbHMpXG4gICAgZm9yICh2YXIgcHJvcCBvZiBfX2dldE93blByb3BTeW1ib2xzKGIpKSB7XG4gICAgICBpZiAoX19wcm9wSXNFbnVtLmNhbGwoYiwgcHJvcCkpXG4gICAgICAgIF9fZGVmTm9ybWFsUHJvcChhLCBwcm9wLCBiW3Byb3BdKTtcbiAgICB9XG4gIHJldHVybiBhO1xufTtcbnZhciBfX3NwcmVhZFByb3BzID0gKGEsIGIpID0+IF9fZGVmUHJvcHMoYSwgX19nZXRPd25Qcm9wRGVzY3MoYikpO1xuZnVuY3Rpb24gZml0UGFuZWxzSW5IZWlnaHQoY2VsbHMsIGhlaWdodCkge1xuICBjb25zdCB2aXNpYmxlSGVpZ2h0ID0gaGVpZ2h0IC0gR1JJRF9DRUxMX1ZNQVJHSU4gKiA0O1xuICBjb25zdCBjdXJyZW50R3JpZEhlaWdodCA9IE1hdGgubWF4KC4uLmNlbGxzLm1hcCgoY2VsbCkgPT4gY2VsbC5oICsgY2VsbC55KSk7XG4gIGNvbnN0IHZpc2libGVHcmlkSGVpZ2h0ID0gTWF0aC5mbG9vcih2aXNpYmxlSGVpZ2h0IC8gKEdSSURfQ0VMTF9IRUlHSFQgKyBHUklEX0NFTExfVk1BUkdJTikpO1xuICBjb25zdCBzY2FsZUZhY3RvciA9IGN1cnJlbnRHcmlkSGVpZ2h0IC8gdmlzaWJsZUdyaWRIZWlnaHQ7XG4gIHJldHVybiBjZWxscy5tYXAoKGNlbGwpID0+IHtcbiAgICByZXR1cm4gX19zcHJlYWRQcm9wcyhfX3NwcmVhZFZhbHVlcyh7fSwgY2VsbCksIHtcbiAgICAgIHk6IE1hdGgucm91bmQoY2VsbC55IC8gc2NhbGVGYWN0b3IpIHx8IDAsXG4gICAgICBoOiBNYXRoLnJvdW5kKGNlbGwuaCAvIHNjYWxlRmFjdG9yKSB8fCAxXG4gICAgfSk7XG4gIH0pO1xufVxuXG5leHBvcnQgeyBmaXRQYW5lbHNJbkhlaWdodCB9O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGF0YTphcHBsaWNhdGlvbi9qc29uO2NoYXJzZXQ9dXRmLTg7YmFzZTY0LGV5SjJaWEp6YVc5dUlqb3pMQ0ptYVd4bElqb2lkWFJwYkhNdWFuTWlMQ0p6YjNWeVkyVnpJanBiSWk0dUx5NHVMeTR1THk0dUx5NHVMM055WXk5amIyMXdiMjVsYm5SekwyeGhlVzkxZEM5bmNtbGtMM1YwYVd4ekxuUnpJbDBzSW5OdmRYSmpaWE5EYjI1MFpXNTBJanBiSW1sdGNHOXlkQ0I3SUVkU1NVUmZRMFZNVEY5SVJVbEhTRlFzSUVkU1NVUmZRMFZNVEY5V1RVRlNSMGxPSUgwZ1puSnZiU0FuTGk5amIyNXpkR0Z1ZEhNbk8xeHVYRzVsZUhCdmNuUWdablZ1WTNScGIyNGdabWwwVUdGdVpXeHpTVzVJWldsbmFIUW9ZMlZzYkhNNklGSmxZV04wUjNKcFpFeGhlVzkxZEM1TVlYbHZkWFJiWFN3Z2FHVnBaMmgwT2lCdWRXMWlaWElwSUh0Y2JpQWdMeThnVkdGclpTQnBiblJ2SUdGalkyOTFiblFnWTJWc2JDQnRZWEpuYVc1MElIUnZjQ0FySUdObGJHd2diV0Z5WjJsdUlHSnZkSFJ2YlNBcklHRmtaR2x1WnlCemIyMWxJRzFoY21kcGJtY2dZWFFnZEdobElHSnZkSFJ2YlZ4dUlDQmpiMjV6ZENCMmFYTnBZbXhsU0dWcFoyaDBJRDBnYUdWcFoyaDBJQzBnUjFKSlJGOURSVXhNWDFaTlFWSkhTVTRnS2lBME8xeHVJQ0JqYjI1emRDQmpkWEp5Wlc1MFIzSnBaRWhsYVdkb2RDQTlJRTFoZEdndWJXRjRLQzR1TG1ObGJHeHpMbTFoY0Nnb1kyVnNiQ2tnUFQ0Z1kyVnNiQzVvSUNzZ1kyVnNiQzU1S1NrN1hHNWNiaUFnWTI5dWMzUWdkbWx6YVdKc1pVZHlhV1JJWldsbmFIUWdQU0JOWVhSb0xtWnNiMjl5S0hacGMybGliR1ZJWldsbmFIUWdMeUFvUjFKSlJGOURSVXhNWDBoRlNVZElWQ0FySUVkU1NVUmZRMFZNVEY5V1RVRlNSMGxPS1NrN1hHNGdJR052Ym5OMElITmpZV3hsUm1GamRHOXlJRDBnWTNWeWNtVnVkRWR5YVdSSVpXbG5hSFFnTHlCMmFYTnBZbXhsUjNKcFpFaGxhV2RvZER0Y2JseHVJQ0J5WlhSMWNtNGdZMlZzYkhNdWJXRndLQ2hqWld4c0tTQTlQaUI3WEc0Z0lDQWdjbVYwZFhKdUlIdGNiaUFnSUNBZ0lDNHVMbU5sYkd3c1hHNGdJQ0FnSUNCNU9pQk5ZWFJvTG5KdmRXNWtLR05sYkd3dWVTQXZJSE5qWVd4bFJtRmpkRzl5S1NCOGZDQXdMRnh1SUNBZ0lDQWdhRG9nVFdGMGFDNXliM1Z1WkNoalpXeHNMbWdnTHlCelkyRnNaVVpoWTNSdmNpa2dmSHdnTVN4Y2JpQWdJQ0I5TzF4dUlDQjlLVHRjYm4xY2JpSmRMQ0p1WVcxbGN5STZXMTBzSW0xaGNIQnBibWR6SWpvaU96czdPenM3T3pzN096czdPenM3T3pzN096czdRVUZGWjBJc1UwRkJRU3hwUWtGQlFTeERRVUZyUWl4UFFVRnBReXhOUVVGblFpeEZRVUZCTzBGQlJXcEdMRVZCUVUwc1RVRkJRU3hoUVVGQkxFZEJRV2RDTEZOQlFWTXNhVUpCUVc5Q0xFZEJRVUVzUTBGQlFTeERRVUZCTzBGQlEyNUVMRVZCUVVFc1RVRkJUU3hwUWtGQmIwSXNSMEZCUVN4SlFVRkJMRU5CUVVzc1IwRkJTU3hEUVVGQkxFZEJRVWNzUzBGQlRTeERRVUZCTEVkQlFVRXNRMEZCU1N4RFFVRkRMRWxCUVVFc1MwRkJVeXhKUVVGTExFTkJRVUVzUTBGQlFTeEhRVUZKTEVsQlFVc3NRMEZCUVN4RFFVRkRMRU5CUVVNc1EwRkJRU3hEUVVGQk8wRkJSVEZGTEVWQlFVRXNUVUZCVFN4cFFrRkJiMElzUjBGQlFTeEpRVUZCTEVOQlFVc3NTMEZCVFN4RFFVRkJMR0ZCUVVFc1NVRkJhVUlzYlVKQlFXMUNMR2xDUVVGclFpeERRVUZCTEVOQlFVRXNRMEZCUVR0QlFVTXpSaXhGUVVGQkxFMUJRVTBzWTBGQll5eHBRa0ZCYjBJc1IwRkJRU3hwUWtGQlFTeERRVUZCTzBGQlJYaERMRVZCUVU4c1QwRkJRU3hMUVVGQkxFTkJRVTBzUjBGQlNTeERRVUZCTEVOQlFVTXNTVUZCVXl4TFFVRkJPMEZCUTNwQ0xFbEJRVUVzVDBGQlR5eHBRMEZEUml4SlFVUkZMRU5CUVVFc1JVRkJRVHRCUVVGQkxFMUJSVXdzUjBGQlJ5eEpRVUZMTEVOQlFVRXNTMEZCUVN4RFFVRk5MRWxCUVVzc1EwRkJRU3hEUVVGQkxFZEJRVWtzVjBGQlZ5eERRVUZMTEVsQlFVRXNRMEZCUVR0QlFVRkJMRTFCUTNaRExFZEJRVWNzU1VGQlN5eERRVUZCTEV0QlFVRXNRMEZCVFN4SlFVRkxMRU5CUVVFc1EwRkJRU3hIUVVGSkxGZEJRVmNzUTBGQlN5eEpRVUZCTEVOQlFVRTdRVUZCUVN4TFFVTjZReXhEUVVGQkxFTkJRVUU3UVVGQlFTeEhRVU5FTEVOQlFVRXNRMEZCUVR0QlFVTklPenM3T3lKOVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVnQixTQUFBLGlCQUFBLENBQWtCLE9BQWlDLE1BQWdCLEVBQUE7QUFFM0UsRUFBQSxNQUFBLGFBQUEsR0FBZ0IsU0FBUyxpQkFBb0IsR0FBQSxDQUFBLENBQUE7QUFDbkQsRUFBQSxNQUFNLGlCQUFvQixHQUFBLElBQUEsQ0FBSyxHQUFJLENBQUEsR0FBRyxLQUFNLENBQUEsR0FBQSxDQUFJLENBQUMsSUFBQSxLQUFTLElBQUssQ0FBQSxDQUFBLEdBQUksSUFBSyxDQUFBLENBQUMsQ0FBQyxDQUFBLENBQUE7QUFFMUUsRUFBQSxNQUFNLGlCQUFvQixHQUFBLElBQUEsQ0FBSyxLQUFNLENBQUEsYUFBQSxJQUFpQixtQkFBbUIsaUJBQWtCLENBQUEsQ0FBQSxDQUFBO0FBQzNGLEVBQUEsTUFBTSxjQUFjLGlCQUFvQixHQUFBLGlCQUFBLENBQUE7QUFFakMsRUFBQSxPQUFBLEtBQUEsQ0FBTSxHQUFJLENBQUEsQ0FBQyxJQUFTLEtBQUE7QUFDekIsSUFBQSxPQUFPLGFBQUEsQ0FBQSxjQUFBLENBQUEsRUFBQSxFQUNGLElBREUsQ0FBQSxFQUFBO0FBRUwsTUFBQSxDQUFBLEVBQUcsSUFBSyxDQUFBLEtBQUEsQ0FBTSxJQUFLLENBQUEsQ0FBQSxHQUFJLFdBQVcsQ0FBSyxJQUFBLENBQUE7QUFDdkMsTUFBQSxDQUFBLEVBQUcsSUFBSyxDQUFBLEtBQUEsQ0FBTSxJQUFLLENBQUEsQ0FBQSxHQUFJLFdBQVcsQ0FBSyxJQUFBLENBQUE7S0FDekMsQ0FBQSxDQUFBO0dBQ0QsQ0FBQSxDQUFBO0FBQ0g7Ozs7In0=
@@ -0,0 +1,17 @@
1
+ import { SceneObjectBase } from '../../../core/SceneObjectBase.js';
2
+ import { SplitLayoutRenderer } from './SplitLayoutRenderer.js';
3
+
4
+ class SplitLayout extends SceneObjectBase {
5
+ toggleDirection() {
6
+ this.setState({
7
+ direction: this.state.direction === "row" ? "column" : "row"
8
+ });
9
+ }
10
+ isDraggable() {
11
+ return false;
12
+ }
13
+ }
14
+ SplitLayout.Component = SplitLayoutRenderer;
15
+
16
+ export { SplitLayout };
17
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3BsaXRMYXlvdXQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2NvbXBvbmVudHMvbGF5b3V0L3NwbGl0L1NwbGl0TGF5b3V0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNjZW5lT2JqZWN0QmFzZSB9IGZyb20gJy4uLy4uLy4uL2NvcmUvU2NlbmVPYmplY3RCYXNlLmpzJztcbmltcG9ydCB7IFNwbGl0TGF5b3V0UmVuZGVyZXIgfSBmcm9tICcuL1NwbGl0TGF5b3V0UmVuZGVyZXIuanMnO1xuXG5jbGFzcyBTcGxpdExheW91dCBleHRlbmRzIFNjZW5lT2JqZWN0QmFzZSB7XG4gIHRvZ2dsZURpcmVjdGlvbigpIHtcbiAgICB0aGlzLnNldFN0YXRlKHtcbiAgICAgIGRpcmVjdGlvbjogdGhpcy5zdGF0ZS5kaXJlY3Rpb24gPT09IFwicm93XCIgPyBcImNvbHVtblwiIDogXCJyb3dcIlxuICAgIH0pO1xuICB9XG4gIGlzRHJhZ2dhYmxlKCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuU3BsaXRMYXlvdXQuQ29tcG9uZW50ID0gU3BsaXRMYXlvdXRSZW5kZXJlcjtcblxuZXhwb3J0IHsgU3BsaXRMYXlvdXQgfTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWRhdGE6YXBwbGljYXRpb24vanNvbjtjaGFyc2V0PXV0Zi04O2Jhc2U2NCxleUoyWlhKemFXOXVJam96TENKbWFXeGxJam9pVTNCc2FYUk1ZWGx2ZFhRdWFuTWlMQ0p6YjNWeVkyVnpJanBiSWk0dUx5NHVMeTR1THk0dUx5NHVMM055WXk5amIyMXdiMjVsYm5SekwyeGhlVzkxZEM5emNHeHBkQzlUY0d4cGRFeGhlVzkxZEM1MGN5SmRMQ0p6YjNWeVkyVnpRMjl1ZEdWdWRDSTZXeUpwYlhCdmNuUWdleUJEVTFOUWNtOXdaWEowYVdWeklIMGdabkp2YlNBbmNtVmhZM1FuTzF4dWFXMXdiM0owSUhzZ1UyTmxibVZQWW1wbFkzUkNZWE5sSUgwZ1puSnZiU0FuTGk0dkxpNHZMaTR2WTI5eVpTOVRZMlZ1WlU5aWFtVmpkRUpoYzJVbk8xeHVhVzF3YjNKMElIc2dVMk5sYm1WUFltcGxZM1JUZEdGMFpTQjlJR1p5YjIwZ0p5NHVMeTR1THk0dUwyTnZjbVV2ZEhsd1pYTW5PMXh1YVcxd2IzSjBJSHNnVTJObGJtVkdiR1Y0U1hSbGJWQnNZV05sYldWdWRDd2dVMk5sYm1WR2JHVjRTWFJsYlV4cGEyVWdmU0JtY205dElDY3VMaTlUWTJWdVpVWnNaWGhNWVhsdmRYUW5PMXh1YVcxd2IzSjBJSHNnVTNCc2FYUk1ZWGx2ZFhSU1pXNWtaWEpsY2lCOUlHWnliMjBnSnk0dlUzQnNhWFJNWVhsdmRYUlNaVzVrWlhKbGNpYzdYRzVjYm1sdWRHVnlabUZqWlNCVGNHeHBkRXhoZVc5MWRGTjBZWFJsSUdWNGRHVnVaSE1nVTJObGJtVlBZbXBsWTNSVGRHRjBaU3dnVTJObGJtVkdiR1Y0U1hSbGJWQnNZV05sYldWdWRDQjdYRzRnSUhCeWFXMWhjbms2SUZOalpXNWxSbXhsZUVsMFpXMU1hV3RsTzF4dUlDQnpaV052Ym1SaGNuay9PaUJUWTJWdVpVWnNaWGhKZEdWdFRHbHJaVHRjYmlBZ1pHbHlaV04wYVc5dU9pQW5jbTkzSnlCOElDZGpiMngxYlc0bk8xeHVJQ0JwYm1sMGFXRnNVMmw2WlQ4NklHNTFiV0psY2p0Y2JpQWdjSEpwYldGeWVWQmhibVZUZEhsc1pYTS9PaUJEVTFOUWNtOXdaWEowYVdWek8xeHVJQ0J6WldOdmJtUmhjbmxRWVc1bFUzUjViR1Z6UHpvZ1ExTlRVSEp2Y0dWeWRHbGxjenRjYm4xY2JseHVaWGh3YjNKMElHTnNZWE56SUZOd2JHbDBUR0Y1YjNWMElHVjRkR1Z1WkhNZ1UyTmxibVZQWW1wbFkzUkNZWE5sUEZOd2JHbDBUR0Y1YjNWMFUzUmhkR1UrSUh0Y2JpQWdjSFZpYkdsaklITjBZWFJwWXlCRGIyMXdiMjVsYm5RZ1BTQlRjR3hwZEV4aGVXOTFkRkpsYm1SbGNtVnlPMXh1WEc0Z0lIQjFZbXhwWXlCMGIyZG5iR1ZFYVhKbFkzUnBiMjRvS1NCN1hHNGdJQ0FnZEdocGN5NXpaWFJUZEdGMFpTaDdYRzRnSUNBZ0lDQmthWEpsWTNScGIyNDZJSFJvYVhNdWMzUmhkR1V1WkdseVpXTjBhVzl1SUQwOVBTQW5jbTkzSnlBL0lDZGpiMngxYlc0bklEb2dKM0p2ZHljc1hHNGdJQ0FnZlNrN1hHNGdJSDFjYmx4dUlDQndkV0pzYVdNZ2FYTkVjbUZuWjJGaWJHVW9LVG9nWW05dmJHVmhiaUI3WEc0Z0lDQWdjbVYwZFhKdUlHWmhiSE5sTzF4dUlDQjlYRzU5WEc0aVhTd2libUZ0WlhNaU9sdGRMQ0p0WVhCd2FXNW5jeUk2SWpzN08wRkJaVThzVFVGQlRTeHZRa0ZCYjBJc1pVRkJhME1zUTBGQlFUdEJRVUZCTEVWQlJ6RkVMR1ZCUVd0Q0xFZEJRVUU3UVVGRGRrSXNTVUZCUVN4SlFVRkJMRU5CUVVzc1VVRkJVeXhEUVVGQk8wRkJRVUVzVFVGRFdpeFRRVUZYTEVWQlFVRXNTVUZCUVN4RFFVRkxMRXRCUVUwc1EwRkJRU3hUUVVGQkxFdEJRV01zVVVGQlVTeFJRVUZYTEVkQlFVRXNTMEZCUVR0QlFVRkJMRXRCUTNoRUxFTkJRVUVzUTBGQlFUdEJRVUZCTEVkQlEwZzdRVUZCUVN4RlFVVlBMRmRCUVhWQ0xFZEJRVUU3UVVGRE5VSXNTVUZCVHl4UFFVRkJMRXRCUVVFc1EwRkJRVHRCUVVGQkxFZEJRMVE3UVVGRFJpeERRVUZCTzBGQldtRXNWMEZCUVN4RFFVTkhMRk5CUVZrc1IwRkJRU3h0UWtGQlFUczdPenNpZlE9PVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQWVPLE1BQU0sb0JBQW9CLGVBQWtDLENBQUE7RUFHMUQsZUFBa0IsR0FBQTtBQUN2QixJQUFBLElBQUEsQ0FBSyxRQUFTLENBQUE7QUFDWixNQUFBLFNBQUEsRUFBVyxJQUFLLENBQUEsS0FBQSxDQUFNLFNBQWMsS0FBQSxLQUFBLEdBQVEsUUFBVyxHQUFBLEtBQUE7S0FDeEQsQ0FBQSxDQUFBO0FBQUEsR0FBQTtFQUdJLFdBQXVCLEdBQUE7QUFDckIsSUFBQSxPQUFBLEtBQUEsQ0FBQTtBQUFBLEdBQUE7QUFFWCxDQUFBO0FBWmEsV0FBQSxDQUNHLFNBQVksR0FBQSxtQkFBQTs7OzsifQ==