@milaboratories/graph-maker 1.2.4 → 1.2.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/GraphMakerPlugin.js +5 -0
- package/dist/GraphMakerPlugin.js.map +1 -0
- package/dist/GraphMakerPlugin.vue.d.ts +37 -0
- package/dist/GraphMakerPlugin.vue.d.ts.map +1 -0
- package/dist/GraphMakerPlugin.vue2.js +61 -0
- package/dist/GraphMakerPlugin.vue2.js.map +1 -0
- package/dist/_virtual/_plugin-vue_export-helper.js +5 -9
- package/dist/assets/ui.css +1 -1
- package/dist/components/AesButton.js +5 -0
- package/dist/components/AesButton.js.map +1 -0
- package/dist/components/AesButton.vue2.js +41 -5
- package/dist/components/AesButton.vue2.js.map +1 -1
- package/dist/components/AesSettings/AesDataMappingContinuous.js +5 -0
- package/dist/components/AesSettings/AesDataMappingContinuous.js.map +1 -0
- package/dist/components/AesSettings/AesDataMappingContinuous.vue2.js +142 -5
- package/dist/components/AesSettings/AesDataMappingContinuous.vue2.js.map +1 -1
- package/dist/components/AesSettings/AesDataMappingDiscrete.js +7 -0
- package/dist/components/AesSettings/AesDataMappingDiscrete.js.map +1 -0
- package/dist/components/AesSettings/AesDataMappingDiscrete.style.js +7 -0
- package/dist/components/AesSettings/AesDataMappingDiscrete.style.js.map +1 -0
- package/dist/components/AesSettings/AesDataMappingDiscrete.vue.css +1 -0
- package/dist/components/AesSettings/AesDataMappingDiscrete.vue2.js +208 -230
- package/dist/components/AesSettings/AesDataMappingDiscrete.vue2.js.map +1 -1
- package/dist/components/AesSettings/DiscreteRow.js +7 -0
- package/dist/components/AesSettings/DiscreteRow.js.map +1 -0
- package/dist/components/AesSettings/DiscreteRow.style.js +12 -0
- package/dist/components/AesSettings/DiscreteRow.style.js.map +1 -0
- package/dist/components/AesSettings/DiscreteRow.vue.css +1 -0
- package/dist/components/AesSettings/DiscreteRow.vue2.js +116 -159
- package/dist/components/AesSettings/DiscreteRow.vue2.js.map +1 -1
- package/dist/components/AesSettings/FixedColorsList.js +5 -0
- package/dist/components/AesSettings/FixedColorsList.js.map +1 -0
- package/dist/components/AesSettings/FixedColorsList.vue2.js +28 -5
- package/dist/components/AesSettings/FixedColorsList.vue2.js.map +1 -1
- package/dist/components/AesSettings/FixedDotShapeList.js +5 -0
- package/dist/components/AesSettings/FixedDotShapeList.js.map +1 -0
- package/dist/components/AesSettings/FixedDotShapeList.vue2.js +24 -5
- package/dist/components/AesSettings/FixedDotShapeList.vue2.js.map +1 -1
- package/dist/components/AesSettings/FixedLineTypeList.js +5 -0
- package/dist/components/AesSettings/FixedLineTypeList.js.map +1 -0
- package/dist/components/AesSettings/FixedLineTypeList.vue2.js +29 -5
- package/dist/components/AesSettings/FixedLineTypeList.vue2.js.map +1 -1
- package/dist/components/AesSettings/FormWrapper.js +5 -0
- package/dist/components/AesSettings/FormWrapper.js.map +1 -0
- package/dist/components/AesSettings/FormWrapper.vue2.js +25 -5
- package/dist/components/AesSettings/FormWrapper.vue2.js.map +1 -1
- package/dist/components/AesSettings/PalettesForm.js +5 -0
- package/dist/components/AesSettings/PalettesForm.js.map +1 -0
- package/dist/components/AesSettings/PalettesForm.vue2.js +73 -5
- package/dist/components/AesSettings/PalettesForm.vue2.js.map +1 -1
- package/dist/components/BtnIconGroup.js +5 -0
- package/dist/components/BtnIconGroup.js.map +1 -0
- package/dist/components/BtnIconGroup.vue2.js +27 -5
- package/dist/components/BtnIconGroup.vue2.js.map +1 -1
- package/dist/components/Chart.js +5 -0
- package/dist/components/Chart.js.map +1 -0
- package/dist/components/Chart.vue2.js +233 -5
- package/dist/components/Chart.vue2.js.map +1 -1
- package/dist/components/ChartErrorNotificationAlert.js +7 -0
- package/dist/components/ChartErrorNotificationAlert.js.map +1 -0
- package/dist/components/ChartErrorNotificationAlert.style.js +9 -0
- package/dist/components/ChartErrorNotificationAlert.style.js.map +1 -0
- package/dist/components/ChartErrorNotificationAlert.vue.css +1 -0
- package/dist/components/ChartErrorNotificationAlert.vue2.js +44 -77
- package/dist/components/ChartErrorNotificationAlert.vue2.js.map +1 -1
- package/dist/components/ChartTruncationWarningAlert.js +7 -0
- package/dist/components/ChartTruncationWarningAlert.js.map +1 -0
- package/dist/components/ChartTruncationWarningAlert.style.js +4 -0
- package/dist/components/ChartTruncationWarningAlert.style.js.map +1 -0
- package/dist/components/ChartTruncationWarningAlert.vue.css +1 -0
- package/dist/components/ChartTruncationWarningAlert.vue2.js +37 -53
- package/dist/components/ChartTruncationWarningAlert.vue2.js.map +1 -1
- package/dist/components/CollapsableBlock.js +5 -0
- package/dist/components/CollapsableBlock.js.map +1 -0
- package/dist/components/CollapsableBlock.vue2.js +30 -5
- package/dist/components/CollapsableBlock.vue2.js.map +1 -1
- package/dist/components/DendroTable.js +5 -0
- package/dist/components/DendroTable.js.map +1 -0
- package/dist/components/DendroTable.vue2.js +86 -5
- package/dist/components/DendroTable.vue2.js.map +1 -1
- package/dist/components/DendroTooltip.js +5 -0
- package/dist/components/DendroTooltip.js.map +1 -0
- package/dist/components/DendroTooltip.vue2.js +102 -5
- package/dist/components/DendroTooltip.vue2.js.map +1 -1
- package/dist/components/DoubleContourTemp.js +11 -0
- package/dist/components/DoubleContourTemp.js.map +1 -0
- package/dist/components/DoubleContourTemp.vue2.js +4 -7
- package/dist/components/DoubleContourTemp.vue2.js.map +1 -1
- package/dist/components/DragAndDrop/DnDBasketChip.js +5 -0
- package/dist/components/DragAndDrop/DnDBasketChip.js.map +1 -0
- package/dist/components/DragAndDrop/DnDBasketChip.vue2.js +57 -5
- package/dist/components/DragAndDrop/DnDBasketChip.vue2.js.map +1 -1
- package/dist/components/DragAndDrop/DnDRangeChip.js +5 -0
- package/dist/components/DragAndDrop/DnDRangeChip.js.map +1 -0
- package/dist/components/DragAndDrop/DnDRangeChip.vue2.js +53 -5
- package/dist/components/DragAndDrop/DnDRangeChip.vue2.js.map +1 -1
- package/dist/components/DragAndDrop/DndBasket.js +5 -0
- package/dist/components/DragAndDrop/DndBasket.js.map +1 -0
- package/dist/components/DragAndDrop/DndBasket.vue2.js +161 -5
- package/dist/components/DragAndDrop/DndBasket.vue2.js.map +1 -1
- package/dist/components/DragAndDrop/DndChip.js +5 -0
- package/dist/components/DragAndDrop/DndChip.js.map +1 -0
- package/dist/components/DragAndDrop/DndChip.vue2.js +34 -5
- package/dist/components/DragAndDrop/DndChip.vue2.js.map +1 -1
- package/dist/components/DragAndDrop/DndDoubleChip.js +5 -0
- package/dist/components/DragAndDrop/DndDoubleChip.js.map +1 -0
- package/dist/components/DragAndDrop/DndDoubleChip.vue2.js +75 -5
- package/dist/components/DragAndDrop/DndDoubleChip.vue2.js.map +1 -1
- package/dist/components/GraphStatusScreen.js +7 -0
- package/dist/components/GraphStatusScreen.js.map +1 -0
- package/dist/components/GraphStatusScreen.style.js +7 -0
- package/dist/components/GraphStatusScreen.style.js.map +1 -0
- package/dist/components/GraphStatusScreen.vue.css +1 -0
- package/dist/components/GraphStatusScreen.vue2.js +44 -65
- package/dist/components/GraphStatusScreen.vue2.js.map +1 -1
- package/dist/components/LassoControls/index.js +7 -0
- package/dist/components/LassoControls/index.js.map +1 -0
- package/dist/components/LassoControls/index.style.js +15 -0
- package/dist/components/LassoControls/index.style.js.map +1 -0
- package/dist/components/LassoControls/index.vue.css +1 -0
- package/dist/components/LassoControls/index.vue2.js +101 -133
- package/dist/components/LassoControls/index.vue2.js.map +1 -1
- package/dist/components/MultiselectButton.js +5 -0
- package/dist/components/MultiselectButton.js.map +1 -0
- package/dist/components/MultiselectButton.vue2.js +55 -5
- package/dist/components/MultiselectButton.vue2.js.map +1 -1
- package/dist/components/PanelModal.js +5 -0
- package/dist/components/PanelModal.js.map +1 -0
- package/dist/components/PanelModal.vue2.js +29 -5
- package/dist/components/PanelModal.vue2.js.map +1 -1
- package/dist/components/PlColorSlider.js +5 -0
- package/dist/components/PlColorSlider.js.map +1 -0
- package/dist/components/PlColorSlider.vue2.js +63 -5
- package/dist/components/PlColorSlider.vue2.js.map +1 -1
- package/dist/components/PlColorSliderThumb.js +5 -0
- package/dist/components/PlColorSliderThumb.js.map +1 -0
- package/dist/components/PlColorSliderThumb.vue2.js +70 -5
- package/dist/components/PlColorSliderThumb.vue2.js.map +1 -1
- package/dist/components/Popup.js +5 -0
- package/dist/components/Popup.js.map +1 -0
- package/dist/components/Popup.vue2.js +53 -5
- package/dist/components/Popup.vue2.js.map +1 -1
- package/dist/components/ReorderForm.js +7 -0
- package/dist/components/ReorderForm.js.map +1 -0
- package/dist/components/ReorderForm.style.js +7 -0
- package/dist/components/ReorderForm.style.js.map +1 -0
- package/dist/components/{ReorderForm.css → ReorderForm.vue.css} +1 -1
- package/dist/components/ReorderForm.vue2.js +48 -53
- package/dist/components/ReorderForm.vue2.js.map +1 -1
- package/dist/components/SettingsTabs/icons/AxesIcon.js +26 -0
- package/dist/components/SettingsTabs/icons/AxesIcon.js.map +1 -0
- package/dist/components/SettingsTabs/icons/DeleteChartIcon.js +16 -0
- package/dist/components/SettingsTabs/icons/DeleteChartIcon.js.map +1 -0
- package/dist/components/SettingsTabs/icons/ExportIcon.js +27 -0
- package/dist/components/SettingsTabs/icons/ExportIcon.js.map +1 -0
- package/dist/components/SettingsTabs/icons/LayersIcon.js +29 -0
- package/dist/components/SettingsTabs/icons/LayersIcon.js.map +1 -0
- package/dist/components/SettingsTabs/icons/LinkIcon.js +16 -0
- package/dist/components/SettingsTabs/icons/LinkIcon.js.map +1 -0
- package/dist/components/SettingsTabs/icons/LogIcon.js +5 -0
- package/dist/components/SettingsTabs/icons/LogIcon.js.map +1 -0
- package/dist/components/SettingsTabs/icons/LogIcon.vue2.js +11 -5
- package/dist/components/SettingsTabs/icons/LogIcon.vue2.js.map +1 -1
- package/dist/components/SettingsTabs/icons/SettingsIcon.js +5 -0
- package/dist/components/SettingsTabs/icons/SettingsIcon.js.map +1 -0
- package/dist/components/SettingsTabs/icons/SettingsIcon.vue2.js +11 -5
- package/dist/components/SettingsTabs/icons/SettingsIcon.vue2.js.map +1 -1
- package/dist/components/SettingsTabs/index.js +5 -0
- package/dist/components/SettingsTabs/index.js.map +1 -0
- package/dist/components/SettingsTabs/index.vue2.js +83 -5
- package/dist/components/SettingsTabs/index.vue2.js.map +1 -1
- package/dist/components/TransitionSlidePanel.js +6 -0
- package/dist/components/TransitionSlidePanel.js.map +1 -0
- package/dist/components/{TransitionSlidePanel.css → TransitionSlidePanel.style.css} +1 -1
- package/dist/components/TransitionSlidePanel.vue2.js +23 -0
- package/dist/components/TransitionSlidePanel.vue2.js.map +1 -0
- package/dist/components/Zoom/ZoomInput.js +5 -0
- package/dist/components/Zoom/ZoomInput.js.map +1 -0
- package/dist/components/Zoom/ZoomInput.vue2.js +42 -5
- package/dist/components/Zoom/ZoomInput.vue2.js.map +1 -1
- package/dist/components/Zoom/index.js +5 -0
- package/dist/components/Zoom/index.js.map +1 -0
- package/dist/components/Zoom/index.vue2.js +39 -5
- package/dist/components/Zoom/index.vue2.js.map +1 -1
- package/dist/composition/useComponent.js +11 -15
- package/dist/composition/useComponent.js.map +1 -1
- package/dist/constantsAesthetic.js +357 -170
- package/dist/constantsAesthetic.js.map +1 -1
- package/dist/constantsCommon.js +479 -462
- package/dist/constantsCommon.js.map +1 -1
- package/dist/dataBindAes.js +155 -186
- package/dist/dataBindAes.js.map +1 -1
- package/dist/forms/AnnotationsForm.js +13 -0
- package/dist/forms/AnnotationsForm.js.map +1 -0
- package/dist/forms/AxesSettingsForm/BubbleAxesSettingsForm.js +5 -0
- package/dist/forms/AxesSettingsForm/BubbleAxesSettingsForm.js.map +1 -0
- package/dist/forms/AxesSettingsForm/BubbleAxesSettingsForm.vue2.js +239 -5
- package/dist/forms/AxesSettingsForm/BubbleAxesSettingsForm.vue2.js.map +1 -1
- package/dist/forms/AxesSettingsForm/DiscreteAxesSettingsForm.js +5 -0
- package/dist/forms/AxesSettingsForm/DiscreteAxesSettingsForm.js.map +1 -0
- package/dist/forms/AxesSettingsForm/DiscreteAxesSettingsForm.vue2.js +438 -5
- package/dist/forms/AxesSettingsForm/DiscreteAxesSettingsForm.vue2.js.map +1 -1
- package/dist/forms/AxesSettingsForm/HeatmapAxesSettingsForm.js +5 -0
- package/dist/forms/AxesSettingsForm/HeatmapAxesSettingsForm.js.map +1 -0
- package/dist/forms/AxesSettingsForm/HeatmapAxesSettingsForm.vue2.js +418 -5
- package/dist/forms/AxesSettingsForm/HeatmapAxesSettingsForm.vue2.js.map +1 -1
- package/dist/forms/AxesSettingsForm/HistogramAxesSettingsForm.js +5 -0
- package/dist/forms/AxesSettingsForm/HistogramAxesSettingsForm.js.map +1 -0
- package/dist/forms/AxesSettingsForm/HistogramAxesSettingsForm.vue2.js +295 -5
- package/dist/forms/AxesSettingsForm/HistogramAxesSettingsForm.vue2.js.map +1 -1
- package/dist/forms/AxesSettingsForm/ScatterplotAxesSettingsForm.js +5 -0
- package/dist/forms/AxesSettingsForm/ScatterplotAxesSettingsForm.js.map +1 -0
- package/dist/forms/AxesSettingsForm/ScatterplotAxesSettingsForm.vue2.js +472 -5
- package/dist/forms/AxesSettingsForm/ScatterplotAxesSettingsForm.vue2.js.map +1 -1
- package/dist/forms/AxesSettingsForm/index.js +5 -0
- package/dist/forms/AxesSettingsForm/index.js.map +1 -0
- package/dist/forms/AxesSettingsForm/index.vue2.js +23 -5
- package/dist/forms/AxesSettingsForm/index.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/BubbleForm.js +5 -0
- package/dist/forms/DataMappingForm/BubbleForm.js.map +1 -0
- package/dist/forms/DataMappingForm/BubbleForm.vue2.js +100 -5
- package/dist/forms/DataMappingForm/BubbleForm.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/DendroForm.js +5 -0
- package/dist/forms/DataMappingForm/DendroForm.js.map +1 -0
- package/dist/forms/DataMappingForm/DendroForm.vue2.js +196 -5
- package/dist/forms/DataMappingForm/DendroForm.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/DiscreteForm.js +5 -0
- package/dist/forms/DataMappingForm/DiscreteForm.js.map +1 -0
- package/dist/forms/DataMappingForm/DiscreteForm.vue2.js +74 -5
- package/dist/forms/DataMappingForm/DiscreteForm.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/HeatmapForm.js +5 -0
- package/dist/forms/DataMappingForm/HeatmapForm.js.map +1 -0
- package/dist/forms/DataMappingForm/HeatmapForm.vue2.js +85 -5
- package/dist/forms/DataMappingForm/HeatmapForm.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/HistogramForm.js +5 -0
- package/dist/forms/DataMappingForm/HistogramForm.js.map +1 -0
- package/dist/forms/DataMappingForm/HistogramForm.vue2.js +65 -5
- package/dist/forms/DataMappingForm/HistogramForm.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/Layout/FormLayout.js +5 -0
- package/dist/forms/DataMappingForm/Layout/FormLayout.js.map +1 -0
- package/dist/forms/DataMappingForm/Layout/FormLayout.vue2.js +25 -5
- package/dist/forms/DataMappingForm/Layout/FormLayout.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/Layout/MandatoryOptions.js +5 -0
- package/dist/forms/DataMappingForm/Layout/MandatoryOptions.js.map +1 -0
- package/dist/forms/DataMappingForm/Layout/MandatoryOptions.vue2.js +27 -5
- package/dist/forms/DataMappingForm/Layout/MandatoryOptions.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/Layout/OptionsList.js +7 -0
- package/dist/forms/DataMappingForm/Layout/OptionsList.js.map +1 -0
- package/dist/forms/DataMappingForm/Layout/OptionsList.style.js +4 -0
- package/dist/forms/DataMappingForm/Layout/OptionsList.style.js.map +1 -0
- package/dist/forms/DataMappingForm/Layout/OptionsList.vue2.js +45 -60
- package/dist/forms/DataMappingForm/Layout/OptionsList.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/ScatterplotForm.js +5 -0
- package/dist/forms/DataMappingForm/ScatterplotForm.js.map +1 -0
- package/dist/forms/DataMappingForm/ScatterplotForm.vue2.js +101 -5
- package/dist/forms/DataMappingForm/ScatterplotForm.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/ScatterplotUmapForm.js +5 -0
- package/dist/forms/DataMappingForm/ScatterplotUmapForm.js.map +1 -0
- package/dist/forms/DataMappingForm/ScatterplotUmapForm.vue2.js +95 -5
- package/dist/forms/DataMappingForm/ScatterplotUmapForm.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/index.js +5 -0
- package/dist/forms/DataMappingForm/index.js.map +1 -0
- package/dist/forms/DataMappingForm/index.vue2.js +27 -5
- package/dist/forms/DataMappingForm/index.vue2.js.map +1 -1
- package/dist/forms/DataMappingForm/useBaskets.js +106 -139
- package/dist/forms/DataMappingForm/useBaskets.js.map +1 -1
- package/dist/forms/DataMappingForm/utils.js +102 -131
- package/dist/forms/DataMappingForm/utils.js.map +1 -1
- package/dist/forms/LayersForm/AesSelector.js +5 -0
- package/dist/forms/LayersForm/AesSelector.js.map +1 -0
- package/dist/forms/LayersForm/AesSelector.vue2.js +214 -5
- package/dist/forms/LayersForm/AesSelector.vue2.js.map +1 -1
- package/dist/forms/LayersForm/DotSizeSelector.js +6 -0
- package/dist/forms/LayersForm/DotSizeSelector.js.map +1 -0
- package/dist/forms/LayersForm/DotSizeSelector.vue2.js +104 -0
- package/dist/forms/LayersForm/DotSizeSelector.vue2.js.map +1 -0
- package/dist/forms/LayersForm/Layer/Bubble.js +5 -0
- package/dist/forms/LayersForm/Layer/Bubble.js.map +1 -0
- package/dist/forms/LayersForm/Layer/Bubble.vue2.js +142 -5
- package/dist/forms/LayersForm/Layer/Bubble.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/Dendro.js +5 -0
- package/dist/forms/LayersForm/Layer/Dendro.js.map +1 -0
- package/dist/forms/LayersForm/Layer/Dendro.vue2.js +111 -5
- package/dist/forms/LayersForm/Layer/Dendro.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/Bar.js +5 -0
- package/dist/forms/LayersForm/Layer/discrete/Bar.js.map +1 -0
- package/dist/forms/LayersForm/Layer/discrete/Bar.vue2.js +62 -5
- package/dist/forms/LayersForm/Layer/discrete/Bar.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/BinnedDots.js +5 -0
- package/dist/forms/LayersForm/Layer/discrete/BinnedDots.js.map +1 -0
- package/dist/forms/LayersForm/Layer/discrete/BinnedDots.vue2.js +56 -5
- package/dist/forms/LayersForm/Layer/discrete/BinnedDots.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/Boxplot.js +5 -0
- package/dist/forms/LayersForm/Layer/discrete/Boxplot.js.map +1 -0
- package/dist/forms/LayersForm/Layer/discrete/Boxplot.vue2.js +81 -5
- package/dist/forms/LayersForm/Layer/discrete/Boxplot.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/Errorbar.js +5 -0
- package/dist/forms/LayersForm/Layer/discrete/Errorbar.js.map +1 -0
- package/dist/forms/LayersForm/Layer/discrete/Errorbar.vue2.js +98 -5
- package/dist/forms/LayersForm/Layer/discrete/Errorbar.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/JitteredDots.js +5 -0
- package/dist/forms/LayersForm/Layer/discrete/JitteredDots.js.map +1 -0
- package/dist/forms/LayersForm/Layer/discrete/JitteredDots.vue2.js +59 -5
- package/dist/forms/LayersForm/Layer/discrete/JitteredDots.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/Line.js +5 -0
- package/dist/forms/LayersForm/Layer/discrete/Line.js.map +1 -0
- package/dist/forms/LayersForm/Layer/discrete/Line.vue2.js +96 -5
- package/dist/forms/LayersForm/Layer/discrete/Line.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/Logo.js +5 -0
- package/dist/forms/LayersForm/Layer/discrete/Logo.js.map +1 -0
- package/dist/forms/LayersForm/Layer/discrete/Logo.vue2.js +30 -5
- package/dist/forms/LayersForm/Layer/discrete/Logo.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/Sina.js +5 -0
- package/dist/forms/LayersForm/Layer/discrete/Sina.js.map +1 -0
- package/dist/forms/LayersForm/Layer/discrete/Sina.vue2.js +55 -5
- package/dist/forms/LayersForm/Layer/discrete/Sina.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/StackedArea.js +5 -0
- package/dist/forms/LayersForm/Layer/discrete/StackedArea.js.map +1 -0
- package/dist/forms/LayersForm/Layer/discrete/StackedArea.vue2.js +85 -5
- package/dist/forms/LayersForm/Layer/discrete/StackedArea.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/StackedBar.js +5 -0
- package/dist/forms/LayersForm/Layer/discrete/StackedBar.js.map +1 -0
- package/dist/forms/LayersForm/Layer/discrete/StackedBar.vue2.js +66 -5
- package/dist/forms/LayersForm/Layer/discrete/StackedBar.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/Violin.js +5 -0
- package/dist/forms/LayersForm/Layer/discrete/Violin.js.map +1 -0
- package/dist/forms/LayersForm/Layer/discrete/Violin.vue2.js +89 -5
- package/dist/forms/LayersForm/Layer/discrete/Violin.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/discrete/utils.js +6 -7
- package/dist/forms/LayersForm/Layer/discrete/utils.js.map +1 -1
- package/dist/forms/LayersForm/Layer/heatmap/Heatmap.js +5 -0
- package/dist/forms/LayersForm/Layer/heatmap/Heatmap.js.map +1 -0
- package/dist/forms/LayersForm/Layer/heatmap/Heatmap.vue2.js +127 -5
- package/dist/forms/LayersForm/Layer/heatmap/Heatmap.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapAnnotations.js +5 -0
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapAnnotations.js.map +1 -0
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapAnnotations.vue2.js +55 -5
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapAnnotations.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapClustered.js +5 -0
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapClustered.js.map +1 -0
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapClustered.vue2.js +149 -5
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapClustered.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/histogram/Bins.js +5 -0
- package/dist/forms/LayersForm/Layer/histogram/Bins.js.map +1 -0
- package/dist/forms/LayersForm/Layer/histogram/Bins.vue2.js +49 -5
- package/dist/forms/LayersForm/Layer/histogram/Bins.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/scatterplot/Curve.js +5 -0
- package/dist/forms/LayersForm/Layer/scatterplot/Curve.js.map +1 -0
- package/dist/forms/LayersForm/Layer/scatterplot/Curve.vue2.js +53 -5
- package/dist/forms/LayersForm/Layer/scatterplot/Curve.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/scatterplot/Scatter.js +5 -0
- package/dist/forms/LayersForm/Layer/scatterplot/Scatter.js.map +1 -0
- package/dist/forms/LayersForm/Layer/scatterplot/Scatter.vue2.js +98 -5
- package/dist/forms/LayersForm/Layer/scatterplot/Scatter.vue2.js.map +1 -1
- package/dist/forms/LayersForm/Layer/scatterplot-umap/Scatter.js +5 -0
- package/dist/forms/LayersForm/Layer/scatterplot-umap/Scatter.js.map +1 -0
- package/dist/forms/LayersForm/Layer/scatterplot-umap/Scatter.vue2.js +71 -5
- package/dist/forms/LayersForm/Layer/scatterplot-umap/Scatter.vue2.js.map +1 -1
- package/dist/forms/LayersForm/index.js +5 -0
- package/dist/forms/LayersForm/index.js.map +1 -0
- package/dist/forms/LayersForm/index.vue2.js +144 -5
- package/dist/forms/LayersForm/index.vue2.js.map +1 -1
- package/dist/forms/LogForm.js +13 -0
- package/dist/forms/LogForm.js.map +1 -0
- package/dist/forms/SettingsForm.js +13 -0
- package/dist/forms/SettingsForm.js.map +1 -0
- package/dist/forms/StatisticsForm/DiscreteStatisticsForm.js +5 -0
- package/dist/forms/StatisticsForm/DiscreteStatisticsForm.js.map +1 -0
- package/dist/forms/StatisticsForm/DiscreteStatisticsForm.vue2.js +109 -5
- package/dist/forms/StatisticsForm/DiscreteStatisticsForm.vue2.js.map +1 -1
- package/dist/forms/StatisticsForm/ScatterplotStatisticsForm.js +5 -0
- package/dist/forms/StatisticsForm/ScatterplotStatisticsForm.js.map +1 -0
- package/dist/forms/StatisticsForm/ScatterplotStatisticsForm.vue2.js +22 -5
- package/dist/forms/StatisticsForm/ScatterplotStatisticsForm.vue2.js.map +1 -1
- package/dist/forms/StatisticsForm/index.js +5 -0
- package/dist/forms/StatisticsForm/index.js.map +1 -0
- package/dist/forms/StatisticsForm/index.vue2.js +17 -5
- package/dist/forms/StatisticsForm/index.vue2.js.map +1 -1
- package/dist/forms/TemplateForm.js +5 -0
- package/dist/forms/TemplateForm.js.map +1 -0
- package/dist/forms/TemplateForm.vue2.js +112 -5
- package/dist/forms/TemplateForm.vue2.js.map +1 -1
- package/dist/forms/index.js +92 -90
- package/dist/forms/index.js.map +1 -1
- package/dist/helpers.js +6 -8
- package/dist/helpers.js.map +1 -1
- package/dist/icons/AlignCenter.js +21 -0
- package/dist/icons/AlignCenter.js.map +1 -0
- package/dist/icons/AlignLeft.js +21 -0
- package/dist/icons/AlignLeft.js.map +1 -0
- package/dist/icons/AlignRight.js +21 -0
- package/dist/icons/AlignRight.js.map +1 -0
- package/dist/icons/Annotation.js +5 -0
- package/dist/icons/Annotation.js.map +1 -0
- package/dist/icons/Annotation.vue2.js +11 -5
- package/dist/icons/Annotation.vue2.js.map +1 -1
- package/dist/icons/ArrowLeft.js +22 -0
- package/dist/icons/ArrowLeft.js.map +1 -0
- package/dist/icons/BarAndErrorIcon.js +17 -0
- package/dist/icons/BarAndErrorIcon.js.map +1 -0
- package/dist/icons/BarAndLineIcon.js +17 -0
- package/dist/icons/BarAndLineIcon.js.map +1 -0
- package/dist/icons/BarIcon.js +17 -0
- package/dist/icons/BarIcon.js.map +1 -0
- package/dist/icons/BinnedDotsIcon.js +17 -0
- package/dist/icons/BinnedDotsIcon.js.map +1 -0
- package/dist/icons/BoxplotAndBinnedIcon.js +27 -0
- package/dist/icons/BoxplotAndBinnedIcon.js.map +1 -0
- package/dist/icons/BoxplotAndJitterIcon.js +27 -0
- package/dist/icons/BoxplotAndJitterIcon.js.map +1 -0
- package/dist/icons/BoxplotIcon.js +27 -0
- package/dist/icons/BoxplotIcon.js.map +1 -0
- package/dist/icons/ColorsIcon.js +36 -0
- package/dist/icons/ColorsIcon.js.map +1 -0
- package/dist/icons/DendroIcon.js +27 -0
- package/dist/icons/DendroIcon.js.map +1 -0
- package/dist/icons/Down.js +20 -0
- package/dist/icons/Down.js.map +1 -0
- package/dist/icons/EditIcon.js +24 -0
- package/dist/icons/EditIcon.js.map +1 -0
- package/dist/icons/FrameBottom.js +16 -0
- package/dist/icons/FrameBottom.js.map +1 -0
- package/dist/icons/FrameEmpty.js +16 -0
- package/dist/icons/FrameEmpty.js.map +1 -0
- package/dist/icons/FrameFull.js +21 -0
- package/dist/icons/FrameFull.js.map +1 -0
- package/dist/icons/FrameLeft.js +16 -0
- package/dist/icons/FrameLeft.js.map +1 -0
- package/dist/icons/FrameLeftBottom.js +16 -0
- package/dist/icons/FrameLeftBottom.js.map +1 -0
- package/dist/icons/HeatmapAnnotation.js +16 -0
- package/dist/icons/HeatmapAnnotation.js.map +1 -0
- package/dist/icons/HeatmapIcon.js +17 -0
- package/dist/icons/HeatmapIcon.js.map +1 -0
- package/dist/icons/JitteredDotsIcon.js +17 -0
- package/dist/icons/JitteredDotsIcon.js.map +1 -0
- package/dist/icons/LineAndBinnedIcon.js +27 -0
- package/dist/icons/LineAndBinnedIcon.js.map +1 -0
- package/dist/icons/LineAndErrorbarIcon.js +38 -0
- package/dist/icons/LineAndErrorbarIcon.js.map +1 -0
- package/dist/icons/LineAndJitterIcon.js +17 -0
- package/dist/icons/LineAndJitterIcon.js.map +1 -0
- package/dist/icons/LineIcon.js +17 -0
- package/dist/icons/LineIcon.js.map +1 -0
- package/dist/icons/LogoIcon.js +36 -0
- package/dist/icons/LogoIcon.js.map +1 -0
- package/dist/icons/MinusIcon.js +21 -0
- package/dist/icons/MinusIcon.js.map +1 -0
- package/dist/icons/PlusIcon.js +21 -0
- package/dist/icons/PlusIcon.js.map +1 -0
- package/dist/icons/Right.js +20 -0
- package/dist/icons/Right.js.map +1 -0
- package/dist/icons/Rotation0.js +22 -0
- package/dist/icons/Rotation0.js.map +1 -0
- package/dist/icons/Rotation45.js +29 -0
- package/dist/icons/Rotation45.js.map +1 -0
- package/dist/icons/Rotation90.js +29 -0
- package/dist/icons/Rotation90.js.map +1 -0
- package/dist/icons/ScatterplotIcon.js +17 -0
- package/dist/icons/ScatterplotIcon.js.map +1 -0
- package/dist/icons/SinaIcon.js +17 -0
- package/dist/icons/SinaIcon.js.map +1 -0
- package/dist/icons/StackedAreaIcon.js +17 -0
- package/dist/icons/StackedAreaIcon.js.map +1 -0
- package/dist/icons/StackedBarIcon.js +17 -0
- package/dist/icons/StackedBarIcon.js.map +1 -0
- package/dist/icons/StatisticsIcon.js +26 -0
- package/dist/icons/StatisticsIcon.js.map +1 -0
- package/dist/icons/TemplateIcon.js +26 -0
- package/dist/icons/TemplateIcon.js.map +1 -0
- package/dist/icons/ViolinAndBinnedIcon.js +26 -0
- package/dist/icons/ViolinAndBinnedIcon.js.map +1 -0
- package/dist/icons/ViolinAndJitterIcon.js +34 -0
- package/dist/icons/ViolinAndJitterIcon.js.map +1 -0
- package/dist/icons/ViolinIcon.js +34 -0
- package/dist/icons/ViolinIcon.js.map +1 -0
- package/dist/keys.js +4 -5
- package/dist/keys.js.map +1 -1
- package/dist/plugin.d.ts +57 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +33 -0
- package/dist/plugin.js.map +1 -0
- package/dist/store.js +152 -206
- package/dist/store.js.map +1 -1
- package/dist/ui.d.ts +4 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +3 -0
- package/dist/{index.vue.d.ts → ui.vue.d.ts} +1 -1
- package/dist/ui.vue.d.ts.map +1 -0
- package/dist/ui.vue2.js +371 -0
- package/dist/ui.vue2.js.map +1 -0
- package/dist/ui2.js +5 -0
- package/dist/ui2.js.map +1 -0
- package/dist/utils/addFixedOptionsToState.js +10 -13
- package/dist/utils/addFixedOptionsToState.js.map +1 -1
- package/dist/utils/calculateDiscreteGroups.js +5 -12
- package/dist/utils/calculateDiscreteGroups.js.map +1 -1
- package/dist/utils/copyJSON.js +5 -6
- package/dist/utils/copyJSON.js.map +1 -1
- package/dist/utils/createChartSettingsForRender/composeBubbleSettings.js +38 -28
- package/dist/utils/createChartSettingsForRender/composeBubbleSettings.js.map +1 -1
- package/dist/utils/createChartSettingsForRender/composeChartSettings.js +82 -99
- package/dist/utils/createChartSettingsForRender/composeChartSettings.js.map +1 -1
- package/dist/utils/createChartSettingsForRender/composeDendroSettings.js +46 -68
- package/dist/utils/createChartSettingsForRender/composeDendroSettings.js.map +1 -1
- package/dist/utils/createChartSettingsForRender/composeDiscreteSettings.js +45 -77
- package/dist/utils/createChartSettingsForRender/composeDiscreteSettings.js.map +1 -1
- package/dist/utils/createChartSettingsForRender/composeHeatmapSettings.js +61 -47
- package/dist/utils/createChartSettingsForRender/composeHeatmapSettings.js.map +1 -1
- package/dist/utils/createChartSettingsForRender/composeHistogramSettings.js +38 -38
- package/dist/utils/createChartSettingsForRender/composeHistogramSettings.js.map +1 -1
- package/dist/utils/createChartSettingsForRender/composeScatterplotSettings.js +112 -130
- package/dist/utils/createChartSettingsForRender/composeScatterplotSettings.js.map +1 -1
- package/dist/utils/createChartSettingsForRender/composeScatterplotUmapSettings.js +33 -46
- package/dist/utils/createChartSettingsForRender/composeScatterplotUmapSettings.js.map +1 -1
- package/dist/utils/createChartSettingsForRender/getAxesDataFromForms.js +38 -47
- package/dist/utils/createChartSettingsForRender/getAxesDataFromForms.js.map +1 -1
- package/dist/utils/createChartSettingsForRender/getLayersDataFromForms.js +259 -261
- package/dist/utils/createChartSettingsForRender/getLayersDataFromForms.js.map +1 -1
- package/dist/utils/getPopupHeightForFixedAesList.js +6 -9
- package/dist/utils/getPopupHeightForFixedAesList.js.map +1 -1
- package/dist/utils/getStatisticsOptions.js +21 -25
- package/dist/utils/getStatisticsOptions.js.map +1 -1
- package/dist/utils/getUsedAesInMapping.js +71 -82
- package/dist/utils/getUsedAesInMapping.js.map +1 -1
- package/dist/utils/loadDefaultSources.js +135 -136
- package/dist/utils/loadDefaultSources.js.map +1 -1
- package/dist/utils/loadUniqueValuesToSave.js +97 -99
- package/dist/utils/loadUniqueValuesToSave.js.map +1 -1
- package/dist/utils/saveToFile.js +12 -13
- package/dist/utils/saveToFile.js.map +1 -1
- package/package.json +20 -15
- package/dist/_virtual/_plugin-vue_export-helper.js.map +0 -1
- package/dist/components/AesButton.vue.js +0 -47
- package/dist/components/AesButton.vue.js.map +0 -1
- package/dist/components/AesSettings/AesDataMappingContinuous.vue.js +0 -131
- package/dist/components/AesSettings/AesDataMappingContinuous.vue.js.map +0 -1
- package/dist/components/AesSettings/AesDataMappingDiscrete.css +0 -1
- package/dist/components/AesSettings/AesDataMappingDiscrete.vue.js +0 -10
- package/dist/components/AesSettings/AesDataMappingDiscrete.vue.js.map +0 -1
- package/dist/components/AesSettings/AesDataMappingDiscrete.vue3.js +0 -10
- package/dist/components/AesSettings/AesDataMappingDiscrete.vue3.js.map +0 -1
- package/dist/components/AesSettings/DiscreteRow.css +0 -1
- package/dist/components/AesSettings/DiscreteRow.vue.js +0 -10
- package/dist/components/AesSettings/DiscreteRow.vue.js.map +0 -1
- package/dist/components/AesSettings/DiscreteRow.vue3.js +0 -20
- package/dist/components/AesSettings/DiscreteRow.vue3.js.map +0 -1
- package/dist/components/AesSettings/FixedColorsList.vue.js +0 -33
- package/dist/components/AesSettings/FixedColorsList.vue.js.map +0 -1
- package/dist/components/AesSettings/FixedDotShapeList.vue.js +0 -25
- package/dist/components/AesSettings/FixedDotShapeList.vue.js.map +0 -1
- package/dist/components/AesSettings/FixedLineTypeList.vue.js +0 -37
- package/dist/components/AesSettings/FixedLineTypeList.vue.js.map +0 -1
- package/dist/components/AesSettings/FormWrapper.vue.js +0 -37
- package/dist/components/AesSettings/FormWrapper.vue.js.map +0 -1
- package/dist/components/AesSettings/PalettesForm.vue.js +0 -91
- package/dist/components/AesSettings/PalettesForm.vue.js.map +0 -1
- package/dist/components/BtnIconGroup.vue.js +0 -30
- package/dist/components/BtnIconGroup.vue.js.map +0 -1
- package/dist/components/Chart.vue.js +0 -283
- package/dist/components/Chart.vue.js.map +0 -1
- package/dist/components/ChartErrorNotificationAlert.css +0 -1
- package/dist/components/ChartErrorNotificationAlert.vue.js +0 -10
- package/dist/components/ChartErrorNotificationAlert.vue.js.map +0 -1
- package/dist/components/ChartErrorNotificationAlert.vue3.js +0 -14
- package/dist/components/ChartErrorNotificationAlert.vue3.js.map +0 -1
- package/dist/components/ChartTruncationWarningAlert.css +0 -1
- package/dist/components/ChartTruncationWarningAlert.vue.js +0 -10
- package/dist/components/ChartTruncationWarningAlert.vue.js.map +0 -1
- package/dist/components/ChartTruncationWarningAlert.vue3.js +0 -8
- package/dist/components/ChartTruncationWarningAlert.vue3.js.map +0 -1
- package/dist/components/CollapsableBlock.vue.js +0 -40
- package/dist/components/CollapsableBlock.vue.js.map +0 -1
- package/dist/components/DendroTable.vue.js +0 -94
- package/dist/components/DendroTable.vue.js.map +0 -1
- package/dist/components/DendroTooltip.vue.js +0 -119
- package/dist/components/DendroTooltip.vue.js.map +0 -1
- package/dist/components/DoubleContourTemp.vue.js +0 -16
- package/dist/components/DoubleContourTemp.vue.js.map +0 -1
- package/dist/components/DragAndDrop/DnDBasketChip.vue.js +0 -70
- package/dist/components/DragAndDrop/DnDBasketChip.vue.js.map +0 -1
- package/dist/components/DragAndDrop/DnDRangeChip.vue.js +0 -79
- package/dist/components/DragAndDrop/DnDRangeChip.vue.js.map +0 -1
- package/dist/components/DragAndDrop/DndBasket.vue.js +0 -148
- package/dist/components/DragAndDrop/DndBasket.vue.js.map +0 -1
- package/dist/components/DragAndDrop/DndChip.vue.js +0 -50
- package/dist/components/DragAndDrop/DndChip.vue.js.map +0 -1
- package/dist/components/DragAndDrop/DndDoubleChip.vue.js +0 -92
- package/dist/components/DragAndDrop/DndDoubleChip.vue.js.map +0 -1
- package/dist/components/GraphStatusScreen.css +0 -1
- package/dist/components/GraphStatusScreen.vue.js +0 -10
- package/dist/components/GraphStatusScreen.vue.js.map +0 -1
- package/dist/components/GraphStatusScreen.vue3.js +0 -10
- package/dist/components/GraphStatusScreen.vue3.js.map +0 -1
- package/dist/components/LassoControls/index.css +0 -1
- package/dist/components/LassoControls/index.vue.js +0 -10
- package/dist/components/LassoControls/index.vue.js.map +0 -1
- package/dist/components/LassoControls/index.vue3.js +0 -26
- package/dist/components/LassoControls/index.vue3.js.map +0 -1
- package/dist/components/MultiselectButton.vue.js +0 -64
- package/dist/components/MultiselectButton.vue.js.map +0 -1
- package/dist/components/PanelModal.vue.js +0 -38
- package/dist/components/PanelModal.vue.js.map +0 -1
- package/dist/components/PlColorSlider.vue.js +0 -74
- package/dist/components/PlColorSlider.vue.js.map +0 -1
- package/dist/components/PlColorSliderThumb.vue.js +0 -79
- package/dist/components/PlColorSliderThumb.vue.js.map +0 -1
- package/dist/components/Popup.vue.js +0 -70
- package/dist/components/Popup.vue.js.map +0 -1
- package/dist/components/ReorderForm.vue.js +0 -10
- package/dist/components/ReorderForm.vue.js.map +0 -1
- package/dist/components/ReorderForm.vue3.js +0 -10
- package/dist/components/ReorderForm.vue3.js.map +0 -1
- package/dist/components/SettingsTabs/icons/AxesIcon.vue.js +0 -30
- package/dist/components/SettingsTabs/icons/AxesIcon.vue.js.map +0 -1
- package/dist/components/SettingsTabs/icons/DeleteChartIcon.vue.js +0 -19
- package/dist/components/SettingsTabs/icons/DeleteChartIcon.vue.js.map +0 -1
- package/dist/components/SettingsTabs/icons/ExportIcon.vue.js +0 -33
- package/dist/components/SettingsTabs/icons/ExportIcon.vue.js.map +0 -1
- package/dist/components/SettingsTabs/icons/LayersIcon.vue.js +0 -35
- package/dist/components/SettingsTabs/icons/LayersIcon.vue.js.map +0 -1
- package/dist/components/SettingsTabs/icons/LinkIcon.vue.js +0 -19
- package/dist/components/SettingsTabs/icons/LinkIcon.vue.js.map +0 -1
- package/dist/components/SettingsTabs/icons/LogIcon.vue.js +0 -12
- package/dist/components/SettingsTabs/icons/LogIcon.vue.js.map +0 -1
- package/dist/components/SettingsTabs/icons/SettingsIcon.vue.js +0 -12
- package/dist/components/SettingsTabs/icons/SettingsIcon.vue.js.map +0 -1
- package/dist/components/SettingsTabs/index.vue.js +0 -102
- package/dist/components/SettingsTabs/index.vue.js.map +0 -1
- package/dist/components/TransitionSlidePanel.vue.js +0 -26
- package/dist/components/TransitionSlidePanel.vue.js.map +0 -1
- package/dist/components/TransitionSlidePanel.vue3.js +0 -6
- package/dist/components/TransitionSlidePanel.vue3.js.map +0 -1
- package/dist/components/Zoom/ZoomInput.vue.js +0 -55
- package/dist/components/Zoom/ZoomInput.vue.js.map +0 -1
- package/dist/components/Zoom/index.vue.js +0 -47
- package/dist/components/Zoom/index.vue.js.map +0 -1
- package/dist/forms/AnnotationsForm.vue.js +0 -16
- package/dist/forms/AnnotationsForm.vue.js.map +0 -1
- package/dist/forms/AxesSettingsForm/BubbleAxesSettingsForm.vue.js +0 -256
- package/dist/forms/AxesSettingsForm/BubbleAxesSettingsForm.vue.js.map +0 -1
- package/dist/forms/AxesSettingsForm/DiscreteAxesSettingsForm.vue.js +0 -459
- package/dist/forms/AxesSettingsForm/DiscreteAxesSettingsForm.vue.js.map +0 -1
- package/dist/forms/AxesSettingsForm/HeatmapAxesSettingsForm.vue.js +0 -446
- package/dist/forms/AxesSettingsForm/HeatmapAxesSettingsForm.vue.js.map +0 -1
- package/dist/forms/AxesSettingsForm/HistogramAxesSettingsForm.vue.js +0 -295
- package/dist/forms/AxesSettingsForm/HistogramAxesSettingsForm.vue.js.map +0 -1
- package/dist/forms/AxesSettingsForm/ScatterplotAxesSettingsForm.vue.js +0 -489
- package/dist/forms/AxesSettingsForm/ScatterplotAxesSettingsForm.vue.js.map +0 -1
- package/dist/forms/AxesSettingsForm/index.vue.js +0 -24
- package/dist/forms/AxesSettingsForm/index.vue.js.map +0 -1
- package/dist/forms/DataMappingForm/BubbleForm.vue.js +0 -120
- package/dist/forms/DataMappingForm/BubbleForm.vue.js.map +0 -1
- package/dist/forms/DataMappingForm/DendroForm.vue.js +0 -254
- package/dist/forms/DataMappingForm/DendroForm.vue.js.map +0 -1
- package/dist/forms/DataMappingForm/DiscreteForm.vue.js +0 -98
- package/dist/forms/DataMappingForm/DiscreteForm.vue.js.map +0 -1
- package/dist/forms/DataMappingForm/HeatmapForm.vue.js +0 -102
- package/dist/forms/DataMappingForm/HeatmapForm.vue.js.map +0 -1
- package/dist/forms/DataMappingForm/HistogramForm.vue.js +0 -90
- package/dist/forms/DataMappingForm/HistogramForm.vue.js.map +0 -1
- package/dist/forms/DataMappingForm/Layout/FormLayout.vue.js +0 -38
- package/dist/forms/DataMappingForm/Layout/FormLayout.vue.js.map +0 -1
- package/dist/forms/DataMappingForm/Layout/MandatoryOptions.vue.js +0 -33
- package/dist/forms/DataMappingForm/Layout/MandatoryOptions.vue.js.map +0 -1
- package/dist/forms/DataMappingForm/Layout/OptionsList.vue.js +0 -10
- package/dist/forms/DataMappingForm/Layout/OptionsList.vue.js.map +0 -1
- package/dist/forms/DataMappingForm/Layout/OptionsList.vue3.js +0 -8
- package/dist/forms/DataMappingForm/Layout/OptionsList.vue3.js.map +0 -1
- package/dist/forms/DataMappingForm/ScatterplotForm.vue.js +0 -109
- package/dist/forms/DataMappingForm/ScatterplotForm.vue.js.map +0 -1
- package/dist/forms/DataMappingForm/ScatterplotUmapForm.vue.js +0 -107
- package/dist/forms/DataMappingForm/ScatterplotUmapForm.vue.js.map +0 -1
- package/dist/forms/DataMappingForm/index.vue.js +0 -28
- package/dist/forms/DataMappingForm/index.vue.js.map +0 -1
- package/dist/forms/LayersForm/AesSelector.vue.js +0 -260
- package/dist/forms/LayersForm/AesSelector.vue.js.map +0 -1
- package/dist/forms/LayersForm/DotSizeSelector.vue.js +0 -114
- package/dist/forms/LayersForm/DotSizeSelector.vue.js.map +0 -1
- package/dist/forms/LayersForm/DotSizeSelector.vue3.js +0 -6
- package/dist/forms/LayersForm/DotSizeSelector.vue3.js.map +0 -1
- package/dist/forms/LayersForm/Layer/Bubble.vue.js +0 -152
- package/dist/forms/LayersForm/Layer/Bubble.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/Dendro.vue.js +0 -122
- package/dist/forms/LayersForm/Layer/Dendro.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/discrete/Bar.vue.js +0 -72
- package/dist/forms/LayersForm/Layer/discrete/Bar.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/discrete/BinnedDots.vue.js +0 -66
- package/dist/forms/LayersForm/Layer/discrete/BinnedDots.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/discrete/Boxplot.vue.js +0 -91
- package/dist/forms/LayersForm/Layer/discrete/Boxplot.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/discrete/Errorbar.vue.js +0 -112
- package/dist/forms/LayersForm/Layer/discrete/Errorbar.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/discrete/JitteredDots.vue.js +0 -67
- package/dist/forms/LayersForm/Layer/discrete/JitteredDots.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/discrete/Line.vue.js +0 -119
- package/dist/forms/LayersForm/Layer/discrete/Line.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/discrete/Logo.vue.js +0 -37
- package/dist/forms/LayersForm/Layer/discrete/Logo.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/discrete/Sina.vue.js +0 -64
- package/dist/forms/LayersForm/Layer/discrete/Sina.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/discrete/StackedArea.vue.js +0 -103
- package/dist/forms/LayersForm/Layer/discrete/StackedArea.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/discrete/StackedBar.vue.js +0 -81
- package/dist/forms/LayersForm/Layer/discrete/StackedBar.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/discrete/Violin.vue.js +0 -107
- package/dist/forms/LayersForm/Layer/discrete/Violin.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/heatmap/Heatmap.vue.js +0 -135
- package/dist/forms/LayersForm/Layer/heatmap/Heatmap.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapAnnotations.vue.js +0 -59
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapAnnotations.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapClustered.vue.js +0 -169
- package/dist/forms/LayersForm/Layer/heatmap/HeatmapClustered.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/histogram/Bins.vue.js +0 -54
- package/dist/forms/LayersForm/Layer/histogram/Bins.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/scatterplot/Curve.vue.js +0 -47
- package/dist/forms/LayersForm/Layer/scatterplot/Curve.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/scatterplot/Scatter.vue.js +0 -84
- package/dist/forms/LayersForm/Layer/scatterplot/Scatter.vue.js.map +0 -1
- package/dist/forms/LayersForm/Layer/scatterplot-umap/Scatter.vue.js +0 -66
- package/dist/forms/LayersForm/Layer/scatterplot-umap/Scatter.vue.js.map +0 -1
- package/dist/forms/LayersForm/index.vue.js +0 -154
- package/dist/forms/LayersForm/index.vue.js.map +0 -1
- package/dist/forms/LogForm.vue.js +0 -22
- package/dist/forms/LogForm.vue.js.map +0 -1
- package/dist/forms/SettingsForm.vue.js +0 -22
- package/dist/forms/SettingsForm.vue.js.map +0 -1
- package/dist/forms/StatisticsForm/DiscreteStatisticsForm.vue.js +0 -133
- package/dist/forms/StatisticsForm/DiscreteStatisticsForm.vue.js.map +0 -1
- package/dist/forms/StatisticsForm/ScatterplotStatisticsForm.vue.js +0 -27
- package/dist/forms/StatisticsForm/ScatterplotStatisticsForm.vue.js.map +0 -1
- package/dist/forms/StatisticsForm/index.vue.js +0 -21
- package/dist/forms/StatisticsForm/index.vue.js.map +0 -1
- package/dist/forms/TemplateForm.vue.js +0 -118
- package/dist/forms/TemplateForm.vue.js.map +0 -1
- package/dist/icons/AlignCenter.vue.js +0 -24
- package/dist/icons/AlignCenter.vue.js.map +0 -1
- package/dist/icons/AlignLeft.vue.js +0 -24
- package/dist/icons/AlignLeft.vue.js.map +0 -1
- package/dist/icons/AlignRight.vue.js +0 -24
- package/dist/icons/AlignRight.vue.js.map +0 -1
- package/dist/icons/Annotation.vue.js +0 -12
- package/dist/icons/Annotation.vue.js.map +0 -1
- package/dist/icons/ArrowLeft.vue.js +0 -25
- package/dist/icons/ArrowLeft.vue.js.map +0 -1
- package/dist/icons/BarAndErrorIcon.vue.js +0 -20
- package/dist/icons/BarAndErrorIcon.vue.js.map +0 -1
- package/dist/icons/BarAndLineIcon.vue.js +0 -20
- package/dist/icons/BarAndLineIcon.vue.js.map +0 -1
- package/dist/icons/BarIcon.vue.js +0 -20
- package/dist/icons/BarIcon.vue.js.map +0 -1
- package/dist/icons/BinnedDotsIcon.vue.js +0 -20
- package/dist/icons/BinnedDotsIcon.vue.js.map +0 -1
- package/dist/icons/BoxplotAndBinnedIcon.vue.js +0 -31
- package/dist/icons/BoxplotAndBinnedIcon.vue.js.map +0 -1
- package/dist/icons/BoxplotAndJitterIcon.vue.js +0 -31
- package/dist/icons/BoxplotAndJitterIcon.vue.js.map +0 -1
- package/dist/icons/BoxplotIcon.vue.js +0 -31
- package/dist/icons/BoxplotIcon.vue.js.map +0 -1
- package/dist/icons/ColorsIcon.vue.js +0 -37
- package/dist/icons/ColorsIcon.vue.js.map +0 -1
- package/dist/icons/DendroIcon.vue.js +0 -31
- package/dist/icons/DendroIcon.vue.js.map +0 -1
- package/dist/icons/Down.vue.js +0 -23
- package/dist/icons/Down.vue.js.map +0 -1
- package/dist/icons/EditIcon.vue.js +0 -28
- package/dist/icons/EditIcon.vue.js.map +0 -1
- package/dist/icons/FrameBottom.vue.js +0 -19
- package/dist/icons/FrameBottom.vue.js.map +0 -1
- package/dist/icons/FrameEmpty.vue.js +0 -19
- package/dist/icons/FrameEmpty.vue.js.map +0 -1
- package/dist/icons/FrameFull.vue.js +0 -24
- package/dist/icons/FrameFull.vue.js.map +0 -1
- package/dist/icons/FrameLeft.vue.js +0 -19
- package/dist/icons/FrameLeft.vue.js.map +0 -1
- package/dist/icons/FrameLeftBottom.vue.js +0 -19
- package/dist/icons/FrameLeftBottom.vue.js.map +0 -1
- package/dist/icons/HeatmapAnnotation.vue.js +0 -19
- package/dist/icons/HeatmapAnnotation.vue.js.map +0 -1
- package/dist/icons/HeatmapIcon.vue.js +0 -20
- package/dist/icons/HeatmapIcon.vue.js.map +0 -1
- package/dist/icons/JitteredDotsIcon.vue.js +0 -20
- package/dist/icons/JitteredDotsIcon.vue.js.map +0 -1
- package/dist/icons/LineAndBinnedIcon.vue.js +0 -31
- package/dist/icons/LineAndBinnedIcon.vue.js.map +0 -1
- package/dist/icons/LineAndErrorbarIcon.vue.js +0 -39
- package/dist/icons/LineAndErrorbarIcon.vue.js.map +0 -1
- package/dist/icons/LineAndJitterIcon.vue.js +0 -20
- package/dist/icons/LineAndJitterIcon.vue.js.map +0 -1
- package/dist/icons/LineIcon.vue.js +0 -20
- package/dist/icons/LineIcon.vue.js.map +0 -1
- package/dist/icons/LogoIcon.vue.js +0 -37
- package/dist/icons/LogoIcon.vue.js.map +0 -1
- package/dist/icons/MinusIcon.vue.js +0 -24
- package/dist/icons/MinusIcon.vue.js.map +0 -1
- package/dist/icons/PlusIcon.vue.js +0 -24
- package/dist/icons/PlusIcon.vue.js.map +0 -1
- package/dist/icons/Right.vue.js +0 -23
- package/dist/icons/Right.vue.js.map +0 -1
- package/dist/icons/Rotation0.vue.js +0 -26
- package/dist/icons/Rotation0.vue.js.map +0 -1
- package/dist/icons/Rotation45.vue.js +0 -30
- package/dist/icons/Rotation45.vue.js.map +0 -1
- package/dist/icons/Rotation90.vue.js +0 -30
- package/dist/icons/Rotation90.vue.js.map +0 -1
- package/dist/icons/ScatterplotIcon.vue.js +0 -20
- package/dist/icons/ScatterplotIcon.vue.js.map +0 -1
- package/dist/icons/SinaIcon.vue.js +0 -20
- package/dist/icons/SinaIcon.vue.js.map +0 -1
- package/dist/icons/StackedAreaIcon.vue.js +0 -20
- package/dist/icons/StackedAreaIcon.vue.js.map +0 -1
- package/dist/icons/StackedBarIcon.vue.js +0 -20
- package/dist/icons/StackedBarIcon.vue.js.map +0 -1
- package/dist/icons/StatisticsIcon.vue.js +0 -30
- package/dist/icons/StatisticsIcon.vue.js.map +0 -1
- package/dist/icons/TemplateIcon.vue.js +0 -30
- package/dist/icons/TemplateIcon.vue.js.map +0 -1
- package/dist/icons/ViolinAndBinnedIcon.vue.js +0 -30
- package/dist/icons/ViolinAndBinnedIcon.vue.js.map +0 -1
- package/dist/icons/ViolinAndJitterIcon.vue.js +0 -35
- package/dist/icons/ViolinAndJitterIcon.vue.js.map +0 -1
- package/dist/icons/ViolinIcon.vue.js +0 -35
- package/dist/icons/ViolinIcon.vue.js.map +0 -1
- package/dist/index.d.ts +0 -4
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -6
- package/dist/index.js.map +0 -1
- package/dist/index.vue.d.ts.map +0 -1
- package/dist/index.vue.js +0 -392
- package/dist/index.vue.js.map +0 -1
- package/dist/index.vue2.js +0 -5
- package/dist/index.vue2.js.map +0 -1
- /package/dist/forms/DataMappingForm/Layout/{OptionsList.css → OptionsList.vue.css} +0 -0
- /package/dist/forms/LayersForm/{DotSizeSelector.css → DotSizeSelector.style.css} +0 -0
package/dist/ui.vue2.js
ADDED
|
@@ -0,0 +1,371 @@
|
|
|
1
|
+
import './assets/ui.css';/* empty css */
|
|
2
|
+
import { copyJSON as e } from "./utils/copyJSON.js";
|
|
3
|
+
import { composeChartSettings as t } from "./utils/createChartSettingsForRender/composeChartSettings.js";
|
|
4
|
+
import { saveToFile as n } from "./utils/saveToFile.js";
|
|
5
|
+
import { isOwnGraphMakerTab as r, useSettingsForm as i } from "./forms/index.js";
|
|
6
|
+
import { createReactiveState as ee, provideStore as te } from "./store.js";
|
|
7
|
+
import ne from "./components/GraphStatusScreen.js";
|
|
8
|
+
import re from "./components/Chart.js";
|
|
9
|
+
import ie from "./components/PanelModal.js";
|
|
10
|
+
import ae from "./components/SettingsTabs/index.js";
|
|
11
|
+
import a from "./components/TransitionSlidePanel.js";
|
|
12
|
+
import o from "./components/ChartErrorNotificationAlert.js";
|
|
13
|
+
import oe from "./components/ChartTruncationWarningAlert.js";
|
|
14
|
+
import { computed as s, createBlock as c, createCommentVNode as l, createElementBlock as se, createElementVNode as ce, createVNode as u, defineComponent as d, mergeModels as f, onMounted as le, onUnmounted as ue, openBlock as p, ref as m, renderSlot as h, resolveDynamicComponent as g, shallowRef as _, toRaw as v, unref as y, useModel as b, useSlots as de, watch as x, withCtx as S } from "vue";
|
|
15
|
+
import { MiPlots as fe } from "@milaboratories/miplots4";
|
|
16
|
+
import { DemoDataStore as C } from "@milaboratories/pf-plots";
|
|
17
|
+
import { watchDebounced as w } from "@vueuse/core";
|
|
18
|
+
var pe = { class: "graph-maker" }, T = { class: "graph-maker__main-pane" }, E = /* @__PURE__ */ d({
|
|
19
|
+
__name: "ui",
|
|
20
|
+
props: /* @__PURE__ */ f({
|
|
21
|
+
pFrame: {},
|
|
22
|
+
chartType: {},
|
|
23
|
+
defaultOptions: {},
|
|
24
|
+
defaultPalette: {},
|
|
25
|
+
fixedOptions: {},
|
|
26
|
+
allowChartDeleting: { type: Boolean },
|
|
27
|
+
allowTitleEditing: { type: Boolean },
|
|
28
|
+
driver: {},
|
|
29
|
+
tooltipButton: {},
|
|
30
|
+
labelsModifier: { type: Function },
|
|
31
|
+
dataColumnPredicate: { type: Function },
|
|
32
|
+
metaColumnPredicate: { type: Function },
|
|
33
|
+
readonlyInputs: {},
|
|
34
|
+
statusText: {}
|
|
35
|
+
}, {
|
|
36
|
+
modelValue: { required: !0 },
|
|
37
|
+
modelModifiers: {},
|
|
38
|
+
selection: {},
|
|
39
|
+
selectionModifiers: {}
|
|
40
|
+
}),
|
|
41
|
+
emits: /* @__PURE__ */ f(["delete-this-graph", "tooltip-btn-click"], ["update:modelValue", "update:selection"]),
|
|
42
|
+
setup(d, { expose: f, emit: E }) {
|
|
43
|
+
let D = b(d, "modelValue"), O = b(d, "selection"), k = d;
|
|
44
|
+
f({ reset: P });
|
|
45
|
+
let A = m(null);
|
|
46
|
+
x(() => k.pFrame, (e) => {
|
|
47
|
+
if (!e.ok || !e.value) {
|
|
48
|
+
A.value = null;
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
let t = "platforma" in window ? window.platforma?.pFrameDriver : k.driver;
|
|
52
|
+
if (!t) throw Error("PFrame driver is missing");
|
|
53
|
+
A.value = new C(e.value, t, k.labelsModifier);
|
|
54
|
+
}, {
|
|
55
|
+
immediate: !0,
|
|
56
|
+
deep: !0
|
|
57
|
+
});
|
|
58
|
+
let j = m(k.fixedOptions ?? []);
|
|
59
|
+
x(() => k.fixedOptions, (e, t) => {
|
|
60
|
+
(e && t && JSON.stringify(e) !== JSON.stringify(t) || e && !t || t && !e) && (j.value = e);
|
|
61
|
+
}, { deep: !0 });
|
|
62
|
+
let M = m(k.defaultOptions);
|
|
63
|
+
x(() => k.defaultOptions, (e) => {
|
|
64
|
+
M.value = e;
|
|
65
|
+
}, { deep: !0 });
|
|
66
|
+
let N = te(v(D.value), A, k.chartType, M, j, k.dataColumnPredicate, k.metaColumnPredicate, k.readonlyInputs, k.defaultPalette);
|
|
67
|
+
function P() {
|
|
68
|
+
let e = ee(v(D.value), k.chartType);
|
|
69
|
+
Object.assign(N.value.reactive, e), Object.assign(N.value.loading, {
|
|
70
|
+
initialInputGuide: !0,
|
|
71
|
+
initialCharts: !0,
|
|
72
|
+
initialDefaults: !0,
|
|
73
|
+
inputGuide: !1,
|
|
74
|
+
chartData: !1
|
|
75
|
+
}), M.value = k.defaultOptions;
|
|
76
|
+
}
|
|
77
|
+
let F = s(() => i(N.value.reactive.currentTab)), I = _(null), L = m(null), R = m(!1), z = m(null), B = s(() => k.pFrame.ok && !k.pFrame.value && !k.pFrame.stable), V = s(() => N.value.loading.initialInputGuide && H.value === "loading");
|
|
78
|
+
x(() => B.value, (e, t) => {
|
|
79
|
+
e && !t && (N.value.reactive.currentTab = null);
|
|
80
|
+
});
|
|
81
|
+
let H = s((e) => {
|
|
82
|
+
if (B.value) return "running";
|
|
83
|
+
if (k.pFrame.ok && k.pFrame.stable && !k.pFrame.value) return "noPframe";
|
|
84
|
+
if (!k.pFrame.ok) return "noPframeWithError";
|
|
85
|
+
let t = N.value.inputGuide.value, n = N.value.chartData.value;
|
|
86
|
+
return t.consistent ? t.ready ? n && Object.values(n.data.byColumns.values)[0]?.length === 0 ? "empty" : R.value ? z.value?.type === "unknownError" ? "unknownError" : "knownError" : N.value.loading.initialCharts || e !== "ready" && N.value.loading.chartData || N.value.loading.chartRendering || I.value === null && (N.value.loading.inputGuide || N.value.loading.chartData) ? "loading" : "ready" : M.value === null || N.value.loading.defaults || N.value.loading.initialInputGuide ? "loading" : "notReady" : "inconsistent";
|
|
87
|
+
});
|
|
88
|
+
function me(e) {
|
|
89
|
+
N.value.reactive.dendroSelectedNodeId = e?.info[0]?.id, N.value.reactive.dendroInfoByClick = e;
|
|
90
|
+
}
|
|
91
|
+
let U = m(null);
|
|
92
|
+
function W(e) {
|
|
93
|
+
let t = N.value.reactive;
|
|
94
|
+
if (e) {
|
|
95
|
+
if (t.tooltipHintWasShown) return;
|
|
96
|
+
U.value &&= (clearTimeout(U.value), null), t.showTooltipHint = !0, U.value = setTimeout(() => {
|
|
97
|
+
t.showTooltipHint = !1, t.tooltipHintWasShown = !0, U.value = null;
|
|
98
|
+
}, 3e3);
|
|
99
|
+
} else t.showTooltipHint = !1;
|
|
100
|
+
}
|
|
101
|
+
function G(e, t) {
|
|
102
|
+
D.value = {
|
|
103
|
+
...D.value,
|
|
104
|
+
selectedPolygons: t
|
|
105
|
+
};
|
|
106
|
+
let n = N.value.chartData.value?.data?.axesData;
|
|
107
|
+
if (e.length === 0 || !n) {
|
|
108
|
+
O.value = {
|
|
109
|
+
axesSpec: [],
|
|
110
|
+
selectedKeys: []
|
|
111
|
+
};
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
let r = Object.keys(n), i = N.value.inputGuide.value;
|
|
115
|
+
O.value = {
|
|
116
|
+
axesSpec: r.map((e) => i.getSourceInfo(e).spec),
|
|
117
|
+
selectedKeys: e.map((e) => r.map((t) => n[t][e]))
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
function K(e) {
|
|
121
|
+
N.value.reactive.lassoControlsState = e;
|
|
122
|
+
}
|
|
123
|
+
let q = null;
|
|
124
|
+
function he(e) {
|
|
125
|
+
e ? q = setTimeout(() => {
|
|
126
|
+
N.value.loading.chartRendering = !0;
|
|
127
|
+
}, 1e3) : (q && clearTimeout(q), N.value.loading.chartRendering = !1);
|
|
128
|
+
}
|
|
129
|
+
let J = m(!1);
|
|
130
|
+
function ge(e) {
|
|
131
|
+
J.value = e;
|
|
132
|
+
}
|
|
133
|
+
let _e = {
|
|
134
|
+
dendro: [me],
|
|
135
|
+
"scatterplot-umap": {
|
|
136
|
+
onPolygonUpdate: G,
|
|
137
|
+
onTooltipHintSwitch: W,
|
|
138
|
+
onLassoControlsStateUpdate: K,
|
|
139
|
+
onZoomChange: ge
|
|
140
|
+
},
|
|
141
|
+
discrete: [W],
|
|
142
|
+
scatterplot: {
|
|
143
|
+
onPolygonUpdate: G,
|
|
144
|
+
onTooltipHintSwitch: W,
|
|
145
|
+
onLassoControlsStateUpdate: K
|
|
146
|
+
},
|
|
147
|
+
histogram: [W],
|
|
148
|
+
heatmap: {
|
|
149
|
+
onTooltipHintSwitch: W,
|
|
150
|
+
onLoadingChange: he
|
|
151
|
+
},
|
|
152
|
+
bubble: [W]
|
|
153
|
+
};
|
|
154
|
+
function Y(e) {
|
|
155
|
+
if (e && Object.values(e.data.values)[0]?.length > 0) {
|
|
156
|
+
if (I.value) I.value.updateSettingsAndData({
|
|
157
|
+
...v(e.data),
|
|
158
|
+
id: e.data.id + (k.pFrame.ok ? k.pFrame.value : "")
|
|
159
|
+
}, v(e.settings));
|
|
160
|
+
else {
|
|
161
|
+
let t = document.getElementById("chartSvgContainer");
|
|
162
|
+
t && (I.value = fe.newPlot(v(e.data), v(e.settings), _e[e.settings.type]), e.settings.type === "scatterplot-umap" && I.value.updateChartState("polygon", D.value.selectedPolygons ?? []), I.value.mount(t));
|
|
163
|
+
}
|
|
164
|
+
L.value = I.value?.calculatedData ? { ...I.value.calculatedData } : null, R.value = I.value?.hasError ?? !1, z.value = I.value?.errorInfo ?? null;
|
|
165
|
+
} else I.value?.unmount(), I.value = null, z.value = null;
|
|
166
|
+
}
|
|
167
|
+
x(() => H.value, (e) => {
|
|
168
|
+
(e === "notReady" || e === "noPframe" || A.value === null) && (I.value?.unmount(), I.value = null);
|
|
169
|
+
});
|
|
170
|
+
let X = _(null), Z = m(null);
|
|
171
|
+
function Q(e) {
|
|
172
|
+
if (!e) {
|
|
173
|
+
X.value = null, Z.value = null;
|
|
174
|
+
return;
|
|
175
|
+
}
|
|
176
|
+
X.value = {
|
|
177
|
+
settings: e.settings,
|
|
178
|
+
data: e.data
|
|
179
|
+
}, Z.value = e.truncationWarning;
|
|
180
|
+
}
|
|
181
|
+
x([() => N.value.chartData.value], ([e]) => {
|
|
182
|
+
Q(t(v(e), v(N.value.inputGuide.value), v(N.value.uniqueValuesData.value), v(N.value.filterLabelsInfo.value), v(N.value.reactive), v(N.value.defaultPalette), v(N.value.facetValuesData.value)));
|
|
183
|
+
}), x([
|
|
184
|
+
() => N.value.reactive.template,
|
|
185
|
+
() => N.value.reactive.layersSettings,
|
|
186
|
+
() => N.value.reactive.axesSettings,
|
|
187
|
+
() => N.value.reactive.statisticsSettings,
|
|
188
|
+
() => N.value.reactive.dataBindAes,
|
|
189
|
+
() => N.value.reactive.chartScale
|
|
190
|
+
], () => {
|
|
191
|
+
Q(t(v(N.value.chartData.value), v(N.value.inputGuide.value), v(N.value.uniqueValuesData.value), v(N.value.filterLabelsInfo.value), v(N.value.reactive), v(N.value.defaultPalette), v(N.value.facetValuesData.value)));
|
|
192
|
+
}, { deep: !0 }), x(() => X.value, (e) => {
|
|
193
|
+
Y(e);
|
|
194
|
+
}), le(() => {
|
|
195
|
+
Y(null);
|
|
196
|
+
}), ue(() => {
|
|
197
|
+
U.value &&= (clearTimeout(U.value), null), I.value?.unmount();
|
|
198
|
+
}), w(() => N.value.reactive.optionsState, (t) => {
|
|
199
|
+
D.value = {
|
|
200
|
+
...D.value,
|
|
201
|
+
optionsState: e(t)
|
|
202
|
+
};
|
|
203
|
+
}, {
|
|
204
|
+
deep: !0,
|
|
205
|
+
debounce: 1e3
|
|
206
|
+
}), w(() => N.value.reactive.usedDefaultOptions, (t) => {
|
|
207
|
+
D.value = {
|
|
208
|
+
...D.value,
|
|
209
|
+
usedDefaultOptions: e(t)
|
|
210
|
+
};
|
|
211
|
+
}, {
|
|
212
|
+
deep: !0,
|
|
213
|
+
debounce: 1e3
|
|
214
|
+
}), w(() => N.value.reactive.statisticsSettings, (t) => {
|
|
215
|
+
D.value = {
|
|
216
|
+
...D.value,
|
|
217
|
+
statisticsSettings: e(t)
|
|
218
|
+
};
|
|
219
|
+
}, {
|
|
220
|
+
deep: !0,
|
|
221
|
+
debounce: 1e3
|
|
222
|
+
}), w(() => N.value.reactive.axesSettings, (t) => {
|
|
223
|
+
D.value = {
|
|
224
|
+
...D.value,
|
|
225
|
+
axesSettings: e(t)
|
|
226
|
+
};
|
|
227
|
+
}, {
|
|
228
|
+
deep: !0,
|
|
229
|
+
debounce: 1e3
|
|
230
|
+
}), w(() => N.value.reactive.layersSettings, (t) => {
|
|
231
|
+
D.value = {
|
|
232
|
+
...D.value,
|
|
233
|
+
layersSettings: e(t)
|
|
234
|
+
};
|
|
235
|
+
}, {
|
|
236
|
+
deep: !0,
|
|
237
|
+
debounce: 1e3
|
|
238
|
+
}), w(() => N.value.reactive.dataBindAes, (t) => {
|
|
239
|
+
D.value = {
|
|
240
|
+
...D.value,
|
|
241
|
+
dataBindAes: e(t)
|
|
242
|
+
};
|
|
243
|
+
}, {
|
|
244
|
+
deep: !0,
|
|
245
|
+
debounce: 1e3
|
|
246
|
+
}), w([
|
|
247
|
+
() => N.value.reactive.chartScale,
|
|
248
|
+
() => N.value.reactive.template,
|
|
249
|
+
() => N.value.reactive.currentTab
|
|
250
|
+
], ([e, t, n]) => {
|
|
251
|
+
D.value = {
|
|
252
|
+
...D.value,
|
|
253
|
+
zoomState: e,
|
|
254
|
+
template: t,
|
|
255
|
+
currentTab: n
|
|
256
|
+
};
|
|
257
|
+
}, { debounce: 1e3 }), x(() => N.value.reactive.tooltipHintWasShown, (e) => {
|
|
258
|
+
e && (D.value = {
|
|
259
|
+
...D.value,
|
|
260
|
+
tooltipHintWasShown: !0
|
|
261
|
+
});
|
|
262
|
+
}), x(() => D.value.currentTab, (e) => {
|
|
263
|
+
N.value.reactive.currentTab = e === void 0 ? "dataMapping" : e;
|
|
264
|
+
}), x(() => D.value?.layersSettings?.dendro?.showTable, (e) => {
|
|
265
|
+
N.value.reactive.layersSettings.dendro.showTable = e ?? !1;
|
|
266
|
+
});
|
|
267
|
+
function ve() {
|
|
268
|
+
n(new Blob([I.value?.export() ?? ""]), "chart.svg");
|
|
269
|
+
}
|
|
270
|
+
function ye(e) {
|
|
271
|
+
D.value = {
|
|
272
|
+
...D.value,
|
|
273
|
+
title: e
|
|
274
|
+
};
|
|
275
|
+
}
|
|
276
|
+
function be(e) {
|
|
277
|
+
N.value.reactive.dendroSelectedNodeId = e, I.value?.updateChartState("selectedNode", e);
|
|
278
|
+
}
|
|
279
|
+
let $ = de(), xe = s(() => !!$.annotationsSlot), Se = s(() => !!$.settingsSlot), Ce = s(() => !!$.logSlot);
|
|
280
|
+
return (e, t) => (p(), se("div", pe, [
|
|
281
|
+
ce("div", T, [
|
|
282
|
+
u(re, {
|
|
283
|
+
"graph-status": H.value,
|
|
284
|
+
graphTitle: D.value.title,
|
|
285
|
+
chartData: L.value,
|
|
286
|
+
"chart-ref": I.value,
|
|
287
|
+
"error-info": z.value,
|
|
288
|
+
dendroTooltipButton: d.tooltipButton,
|
|
289
|
+
"custom-status-text": d.statusText,
|
|
290
|
+
"allow-title-editing": d.allowTitleEditing,
|
|
291
|
+
isScatterplotZoomChanged: J.value,
|
|
292
|
+
onGraphTitleUpdate: ye,
|
|
293
|
+
onDendroNodeSelect: be,
|
|
294
|
+
onDendroTooltipBtnClick: t[0] ||= (t) => e.$emit("tooltip-btn-click", t)
|
|
295
|
+
}, {
|
|
296
|
+
default: S(() => [h(e.$slots, "titleLineSlot")]),
|
|
297
|
+
_: 3
|
|
298
|
+
}, 8, [
|
|
299
|
+
"graph-status",
|
|
300
|
+
"graphTitle",
|
|
301
|
+
"chartData",
|
|
302
|
+
"chart-ref",
|
|
303
|
+
"error-info",
|
|
304
|
+
"dendroTooltipButton",
|
|
305
|
+
"custom-status-text",
|
|
306
|
+
"allow-title-editing",
|
|
307
|
+
"isScatterplotZoomChanged"
|
|
308
|
+
]),
|
|
309
|
+
V.value || B.value ? (p(), c(ne, {
|
|
310
|
+
key: 0,
|
|
311
|
+
graphStatus: B.value ? "running" : "loading",
|
|
312
|
+
top: 67,
|
|
313
|
+
left: 12,
|
|
314
|
+
right: 12,
|
|
315
|
+
bottom: 12,
|
|
316
|
+
customStatusText: d.statusText
|
|
317
|
+
}, null, 8, ["graphStatus", "customStatusText"])) : l("", !0),
|
|
318
|
+
u(a, { id: "graph-settings-modal" }, {
|
|
319
|
+
default: S(() => [y(N).reactive.currentTab && !((V.value || B.value) && y(r)(y(N).reactive.currentTab)) ? (p(), c(ie, {
|
|
320
|
+
key: 0,
|
|
321
|
+
onClose: t[1] ||= (e) => y(N).reactive.currentTab = null
|
|
322
|
+
}, {
|
|
323
|
+
default: S(() => [(p(), c(g(F.value.value), null, {
|
|
324
|
+
default: S(() => [
|
|
325
|
+
y(N).reactive.currentTab === "annotations" ? h(e.$slots, "annotationsSlot", { key: 0 }) : l("", !0),
|
|
326
|
+
y(N).reactive.currentTab === "settings" ? h(e.$slots, "settingsSlot", { key: 1 }) : l("", !0),
|
|
327
|
+
y(N).reactive.currentTab === "log" ? h(e.$slots, "logSlot", { key: 2 }) : l("", !0)
|
|
328
|
+
]),
|
|
329
|
+
_: 3
|
|
330
|
+
}))]),
|
|
331
|
+
_: 3
|
|
332
|
+
})) : l("", !0)]),
|
|
333
|
+
_: 3
|
|
334
|
+
})
|
|
335
|
+
]),
|
|
336
|
+
u(ae, {
|
|
337
|
+
modelValue: y(N).reactive.currentTab,
|
|
338
|
+
"onUpdate:modelValue": t[2] ||= (e) => y(N).reactive.currentTab = e,
|
|
339
|
+
"chart-type": y(N).reactive.chartType,
|
|
340
|
+
"graph-status": H.value,
|
|
341
|
+
allowDeleting: d.allowChartDeleting,
|
|
342
|
+
hasAnnotationsSlot: xe.value,
|
|
343
|
+
hasSettingsSlot: Se.value,
|
|
344
|
+
hasLogSlot: Ce.value,
|
|
345
|
+
initialLoading: V.value || B.value,
|
|
346
|
+
onExport: ve,
|
|
347
|
+
onDelete: t[3] ||= (t) => e.$emit("delete-this-graph")
|
|
348
|
+
}, null, 8, [
|
|
349
|
+
"modelValue",
|
|
350
|
+
"chart-type",
|
|
351
|
+
"graph-status",
|
|
352
|
+
"allowDeleting",
|
|
353
|
+
"hasAnnotationsSlot",
|
|
354
|
+
"hasSettingsSlot",
|
|
355
|
+
"hasLogSlot",
|
|
356
|
+
"initialLoading"
|
|
357
|
+
]),
|
|
358
|
+
z.value?.type === "unknownError" ? (p(), c(o, {
|
|
359
|
+
key: 0,
|
|
360
|
+
errorInfo: z.value
|
|
361
|
+
}, null, 8, ["errorInfo"])) : l("", !0),
|
|
362
|
+
Z.value && (Z.value.groups || Z.value.facets) ? (p(), c(oe, {
|
|
363
|
+
key: 1,
|
|
364
|
+
"truncation-warning": Z.value
|
|
365
|
+
}, null, 8, ["truncation-warning"])) : l("", !0)
|
|
366
|
+
]));
|
|
367
|
+
}
|
|
368
|
+
});
|
|
369
|
+
export { E as default };
|
|
370
|
+
|
|
371
|
+
//# sourceMappingURL=ui.vue2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ui.vue_vue_type_script_setup_true_lang.js","names":["$emit"],"sources":["../src/ui.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport './assets/ui.scss';\nimport type {\n ChartInterface,\n DataByColumns,\n ErrorInfo,\n LassoControlsState,\n Settings,\n} from '@milaboratories/miplots4';\nimport { MiPlots } from '@milaboratories/miplots4';\nimport type { ChartType, PlotDataAndSettings } from '@milaboratories/pf-plots';\nimport { DemoDataStore } from '@milaboratories/pf-plots';\nimport type { AxisSpec, PFrameDriver, PlSelectionModel, PTableKey } from '@platforma-sdk/model';\nimport { watchDebounced } from '@vueuse/core';\nimport { computed, onMounted, onUnmounted, ref, shallowRef, toRaw, useSlots, watch } from 'vue';\nimport Chart from './components/Chart.vue';\nimport PanelModal from './components/PanelModal.vue';\nimport VTabs from './components/SettingsTabs/index.vue';\nimport TransitionSlidePanel from './components/TransitionSlidePanel.vue';\nimport ChartErrorNotificationAlert from './components/ChartErrorNotificationAlert.vue';\nimport ChartTruncationWarningAlert from './components/ChartTruncationWarningAlert.vue';\nimport { isOwnGraphMakerTab, useSettingsForm } from './forms';\nimport { createReactiveState, provideStore } from './store';\nimport type { DendroNodeInfo, GraphMakerProps, GraphMakerState, GraphStatus } from './types';\nimport { composeChartSettings, saveToFile } from './utils';\nimport type { ChartTruncationWarning } from './utils/createChartSettingsForRender/composeChartSettings';\nimport { copyJSON } from './utils/copyJSON';\nimport GraphStatusScreen from './components/GraphStatusScreen.vue';\n\nconst _emit = defineEmits(['delete-this-graph', 'tooltip-btn-click']);\n\nconst graphMakerState = defineModel<GraphMakerState>({ required: true });\nconst selectionState = defineModel<PlSelectionModel>('selection');\n\nconst props = defineProps<GraphMakerProps>();\n\ndefineExpose({\n /**\n reset() will update data-mapping, axis-settings, layers-settings with the state that is in v-model at the moment.\n In other cases editing of v-model fields doesn't make any impact to graphs and interface.\n */\n reset,\n});\n\nconst dataStore = ref<DemoDataStore | null>(null);\n\nwatch(() => props.pFrame, (pframe) => {\n if (!pframe.ok || !pframe.value) {\n dataStore.value = null;\n return;\n }\n const driver = ('platforma' in window) ? window.platforma?.pFrameDriver as PFrameDriver : props.driver;\n if (!driver) {\n throw new Error('PFrame driver is missing');\n }\n dataStore.value = new DemoDataStore(\n pframe.value,\n driver,\n props.labelsModifier,\n );\n}, { immediate: true, deep: true });\n\n// fixed options can be updated outside, other settings only inside from chart settings interface, so we don't watching other settings\nconst fixedOptions = ref<typeof props.fixedOptions>(props.fixedOptions ?? []);\nwatch(() => props.fixedOptions, (value, oldValue) => {\n if (\n (value && oldValue && JSON.stringify(value) !== JSON.stringify(oldValue))\n || (value && !oldValue)\n || (oldValue && !value)\n ) {\n fixedOptions.value = value;\n }\n}, { deep: true });\nconst defaultOptions = ref<typeof props.defaultOptions>(props.defaultOptions);\nwatch(() => props.defaultOptions, (v) => {\n defaultOptions.value = v;\n}, { deep: true });\nconst state = provideStore(\n toRaw(graphMakerState.value),\n dataStore,\n props.chartType,\n defaultOptions,\n fixedOptions,\n props.dataColumnPredicate,\n props.metaColumnPredicate,\n props.readonlyInputs,\n props.defaultPalette,\n);\n\nfunction reset() {\n const nextReactiveState = createReactiveState(\n toRaw(graphMakerState.value),\n props.chartType,\n );\n Object.assign(state.value.reactive, nextReactiveState);\n Object.assign(state.value.loading, {\n initialInputGuide: true,\n initialCharts: true,\n initialDefaults: true,\n inputGuide: false,\n chartData: false,\n });\n defaultOptions.value = props.defaultOptions;\n}\n\nconst currentForm = computed(() => useSettingsForm(state.value.reactive.currentTab));\n\nconst chartRef = shallowRef<ChartInterface | null>(null);\nconst chartCalculatedDataRef = ref<Record<string, unknown> | null>(null);\nconst chartError = ref(false);\nconst chartErrorInfo = ref<ErrorInfo | null>(null);\n\nconst isRunning = computed(\n () => props.pFrame.ok && !props.pFrame.value && !props.pFrame.stable,\n);\nconst isInitialLoading = computed(\n () => state.value.loading.initialInputGuide && graphStatus.value === 'loading',\n);\n\nwatch(() => isRunning.value, (val, prevVal) => {\n if (val && !prevVal) {\n state.value.reactive.currentTab = null;\n }\n});\n\nconst graphStatus = computed<GraphStatus>((previousStatus) => {\n if (isRunning.value) {\n return 'running';\n }\n if (props.pFrame.ok && props.pFrame.stable && !props.pFrame.value) {\n return 'noPframe';\n }\n if (!props.pFrame.ok) {\n return 'noPframeWithError';\n }\n const inputGuide = state.value.inputGuide.value;\n const chartData = state.value.chartData.value;\n if (!inputGuide.consistent) {\n return 'inconsistent';\n }\n if (!inputGuide.ready) {\n return defaultOptions.value === null\n || state.value.loading.defaults\n || state.value.loading.initialInputGuide\n ? 'loading'\n : 'notReady';\n }\n if (chartData && Object.values(chartData.data.byColumns.values)[0]?.length === 0) {\n return 'empty';\n }\n if (chartError.value) {\n return chartErrorInfo.value?.type === 'unknownError' ? 'unknownError' : 'knownError';\n }\n if (\n (state.value.loading.initialCharts || (previousStatus !== 'ready' && state.value.loading.chartData) || state.value.loading.chartRendering)\n || (chartRef.value === null && (state.value.loading.inputGuide || state.value.loading.chartData))\n ) {\n return 'loading';\n }\n return 'ready';\n});\n\nfunction onTreeNodeClick(d: DendroNodeInfo) {\n state.value.reactive.dendroSelectedNodeId = d?.info[0]?.id as number;\n state.value.reactive.dendroInfoByClick = d;\n}\n\nconst tooltipHintHideTimerRef = ref<ReturnType<typeof setTimeout> | null>(null);\n\nfunction onTooltipHintSwitch(v: boolean) {\n const reactive = state.value.reactive;\n if (v) {\n if (reactive.tooltipHintWasShown) return;\n if (tooltipHintHideTimerRef.value) {\n clearTimeout(tooltipHintHideTimerRef.value);\n tooltipHintHideTimerRef.value = null;\n }\n reactive.showTooltipHint = true;\n tooltipHintHideTimerRef.value = setTimeout(() => {\n reactive.showTooltipHint = false;\n reactive.tooltipHintWasShown = true;\n tooltipHintHideTimerRef.value = null;\n }, 3000);\n } else {\n reactive.showTooltipHint = false;\n }\n}\n\nfunction onLassoPolygonUpdate(dotIndexes: number[], polygons: { points: [number, number][]; closed: boolean }[]) {\n graphMakerState.value = {\n ...graphMakerState.value,\n selectedPolygons: polygons,\n };\n\n const axesData = state.value.chartData.value?.data?.axesData;\n if (dotIndexes.length === 0 || !axesData) {\n selectionState.value = { axesSpec: [], selectedKeys: [] };\n return;\n }\n\n const axisKeys = Object.keys(axesData);\n const inputGuide = state.value.inputGuide.value;\n selectionState.value = {\n axesSpec: axisKeys.map((axisKey) => inputGuide.getSourceInfo(axisKey).spec as AxisSpec),\n selectedKeys: dotIndexes.map((idx) => axisKeys.map((axisKey) => axesData[axisKey][idx]) as PTableKey),\n };\n}\n\nfunction onLassoStateChange(v: LassoControlsState) {\n state.value.reactive.lassoControlsState = v;\n}\nlet chartRenderingInProgress: ReturnType<typeof setTimeout> | null = null;\nfunction onLoadingStateChange(v: boolean) {\n if (v) {\n chartRenderingInProgress = setTimeout(() => {\n state.value.loading.chartRendering = true;\n }, 1000);\n } else {\n if (chartRenderingInProgress) {\n clearTimeout(chartRenderingInProgress);\n }\n state.value.loading.chartRendering = false;\n }\n}\nconst isScatterplotZoomChanged = ref(false);\nfunction onZoomChange(isZoomChanged: boolean) {\n isScatterplotZoomChanged.value = isZoomChanged;\n}\nconst graphEventHandlers: Record<ChartType, unknown> = {\n 'dendro': [onTreeNodeClick],\n 'scatterplot-umap': {\n onPolygonUpdate: onLassoPolygonUpdate,\n onTooltipHintSwitch,\n onLassoControlsStateUpdate: onLassoStateChange,\n onZoomChange,\n },\n 'discrete': [onTooltipHintSwitch],\n 'scatterplot': {\n onPolygonUpdate: onLassoPolygonUpdate,\n onTooltipHintSwitch,\n onLassoControlsStateUpdate: onLassoStateChange,\n },\n 'histogram': [onTooltipHintSwitch],\n 'heatmap': { onTooltipHintSwitch, onLoadingChange: onLoadingStateChange },\n 'bubble': [onTooltipHintSwitch],\n};\nfunction updateChart(value: { data: PlotDataAndSettings['data']['byColumns']; settings: PlotDataAndSettings['settings'] } | null) {\n // if dataByColumns exists but columns has no data - show empty chart\n if (value && Object.values(value.data.values)[0]?.length > 0) {\n // console.log('value.dataByColumns', toRaw(value.data));\n // console.log('value.settings', toRaw(value.settings));\n if (chartRef.value) {\n chartRef.value.updateSettingsAndData({ ...toRaw(value.data), id: value.data.id + (props.pFrame.ok ? props.pFrame.value : '') }, toRaw(value.settings) as Settings);\n } else {\n const htmlNode = document.getElementById('chartSvgContainer');\n if (htmlNode) {\n chartRef.value = MiPlots.newPlot(toRaw(value.data), toRaw(value.settings) as Settings, graphEventHandlers[value.settings.type as ChartType]);\n if (value.settings.type === 'scatterplot-umap') {\n // set default polygons (from props)\n chartRef.value.updateChartState('polygon', graphMakerState.value.selectedPolygons ?? []);\n }\n chartRef.value.mount(htmlNode);\n }\n }\n // calculated by chart renderer data, tree hierarchy for example\n chartCalculatedDataRef.value = chartRef.value?.calculatedData ? { ...chartRef.value.calculatedData } : null;\n chartError.value = chartRef.value?.hasError ?? false;\n chartErrorInfo.value = chartRef.value?.errorInfo ?? null;\n } else {\n chartRef.value?.unmount();\n chartRef.value = null;\n chartErrorInfo.value = null;\n }\n}\n\nwatch(() => graphStatus.value, (v) => {\n if (v === 'notReady' || v === 'noPframe' || dataStore.value === null) {\n chartRef.value?.unmount();\n chartRef.value = null;\n }\n});\n\nconst chartDataForRender = shallowRef<{ settings: Settings; data: DataByColumns } | null>(null);\nconst chartTruncationWarning = ref<ChartTruncationWarning | null>(null);\n\nfunction applyComposeResult(result: ReturnType<typeof composeChartSettings>) {\n if (!result) {\n chartDataForRender.value = null;\n chartTruncationWarning.value = null;\n return;\n }\n chartDataForRender.value = { settings: result.settings, data: result.data };\n chartTruncationWarning.value = result.truncationWarning;\n}\n\nwatch([\n () => state.value.chartData.value,\n], ([chartData]) => {\n applyComposeResult(composeChartSettings(\n toRaw(chartData),\n toRaw(state.value.inputGuide.value),\n toRaw(state.value.uniqueValuesData.value),\n toRaw(state.value.filterLabelsInfo.value),\n toRaw(state.value.reactive),\n toRaw(state.value.defaultPalette),\n toRaw(state.value.facetValuesData.value),\n ));\n});\nwatch([\n () => state.value.reactive.template,\n () => state.value.reactive.layersSettings,\n () => state.value.reactive.axesSettings,\n () => state.value.reactive.statisticsSettings,\n () => state.value.reactive.dataBindAes,\n () => state.value.reactive.chartScale,\n], () => {\n applyComposeResult(composeChartSettings(\n toRaw(state.value.chartData.value),\n toRaw(state.value.inputGuide.value),\n toRaw(state.value.uniqueValuesData.value),\n toRaw(state.value.filterLabelsInfo.value),\n toRaw(state.value.reactive),\n toRaw(state.value.defaultPalette),\n toRaw(state.value.facetValuesData.value),\n ));\n}, { deep: true });\n\nwatch(() => chartDataForRender.value, (chartData) => {\n updateChart(chartData);\n});\nonMounted(() => {\n updateChart(null);\n});\nonUnmounted(() => {\n if (tooltipHintHideTimerRef.value) {\n clearTimeout(tooltipHintHideTimerRef.value);\n tooltipHintHideTimerRef.value = null;\n }\n chartRef.value?.unmount();\n});\n\nwatchDebounced(() => state.value.reactive.optionsState, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n optionsState: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\nwatchDebounced(() => state.value.reactive.usedDefaultOptions, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n usedDefaultOptions: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\nwatchDebounced(() => state.value.reactive.statisticsSettings, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n statisticsSettings: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\nwatchDebounced(() => state.value.reactive.axesSettings, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n axesSettings: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\nwatchDebounced(() => state.value.reactive.layersSettings, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n layersSettings: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\nwatchDebounced(() => state.value.reactive.dataBindAes, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n dataBindAes: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\n\nwatchDebounced([\n () => state.value.reactive.chartScale,\n () => state.value.reactive.template,\n () => state.value.reactive.currentTab,\n], ([zoomState, template, currentTab]) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n zoomState,\n template,\n currentTab,\n };\n}, { debounce: 1000 });\n\nwatch(() => state.value.reactive.tooltipHintWasShown, (v) => {\n if (v) {\n graphMakerState.value = { ...graphMakerState.value, tooltipHintWasShown: true };\n }\n});\n\nwatch(() => graphMakerState.value.currentTab, (v) => {\n state.value.reactive.currentTab = v === undefined ? 'dataMapping' : v;\n});\n\nwatch(() => graphMakerState.value?.layersSettings?.dendro?.showTable, (v) => {\n state.value.reactive.layersSettings.dendro.showTable = v ?? false;\n});\n\nfunction onExport() {\n saveToFile(\n new Blob([\n chartRef.value?.export() ?? '',\n ]),\n 'chart.svg',\n );\n}\n\nfunction updateGraphTitle(nextTitle: string) {\n graphMakerState.value = {\n ...graphMakerState.value,\n title: nextTitle,\n };\n}\n\nfunction selectTreeNode(id: number | null) {\n state.value.reactive.dendroSelectedNodeId = id;\n chartRef.value?.updateChartState('selectedNode', id);\n}\n\nconst slots = useSlots();\n\nconst hasAnnotationsSlot = computed(() => Boolean(slots.annotationsSlot));\nconst hasSettingsSlot = computed(() => Boolean(slots.settingsSlot));\nconst hasLogSlot = computed(() => Boolean(slots.logSlot));\n\n</script>\n\n<template>\n <div class=\"graph-maker\">\n <div class=\"graph-maker__main-pane\">\n <Chart\n :graph-status=\"graphStatus\" :graphTitle=\"graphMakerState.title\" :chartData=\"chartCalculatedDataRef\"\n :chart-ref=\"chartRef\" :error-info=\"chartErrorInfo\" :dendroTooltipButton=\"tooltipButton\"\n :custom-status-text=\"statusText\"\n :allow-title-editing=\"allowTitleEditing\"\n :isScatterplotZoomChanged=\"isScatterplotZoomChanged\"\n @graph-title-update=\"updateGraphTitle\" @dendro-node-select=\"selectTreeNode\"\n @dendro-tooltip-btn-click=\"(id: string) => $emit('tooltip-btn-click', id)\"\n >\n <slot name=\"titleLineSlot\" />\n </Chart>\n <GraphStatusScreen v-if=\"isInitialLoading || isRunning\" :graphStatus=\"isRunning ? 'running' : 'loading'\" :top=\"67\" :left=\"12\" :right=\"12\" :bottom=\"12\" :customStatusText=\"statusText\" />\n <TransitionSlidePanel id=\"graph-settings-modal\">\n <PanelModal\n v-if=\"state.reactive.currentTab && !((isInitialLoading || isRunning) && isOwnGraphMakerTab(state.reactive.currentTab))\"\n @close=\"state.reactive.currentTab = null\"\n >\n <component :is=\"currentForm.value\">\n <slot v-if=\"state.reactive.currentTab === 'annotations'\" name=\"annotationsSlot\" />\n <slot v-if=\"state.reactive.currentTab === 'settings'\" name=\"settingsSlot\" />\n <slot v-if=\"state.reactive.currentTab === 'log'\" name=\"logSlot\" />\n </component>\n </PanelModal>\n </TransitionSlidePanel>\n </div>\n <VTabs\n v-model=\"state.reactive.currentTab\" :chart-type=\"state.reactive.chartType\" :graph-status=\"graphStatus\"\n :allowDeleting=\"allowChartDeleting\" :hasAnnotationsSlot=\"hasAnnotationsSlot\" :hasSettingsSlot=\"hasSettingsSlot\"\n :hasLogSlot=\"hasLogSlot\" :initialLoading=\"isInitialLoading || isRunning\" @export=\"onExport\"\n @delete=\"$emit('delete-this-graph')\"\n />\n <ChartErrorNotificationAlert v-if=\"chartErrorInfo?.type === 'unknownError'\" :errorInfo=\"chartErrorInfo\" />\n <ChartTruncationWarningAlert\n v-if=\"chartTruncationWarning && (chartTruncationWarning.groups || chartTruncationWarning.facets)\"\n :truncation-warning=\"chartTruncationWarning\"\n />\n </div>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA+BA,IAAM,IAAkB,EAA4B,GAAA,aAAoB,EAClE,IAAiB,EAA6B,GAAC,YAAY,EAE3D,IAAQ;AAEd,IAAa,EAKX,UACD,CAAC;EAEF,IAAM,IAAY,EAA0B,KAAK;AAEjD,UAAY,EAAM,SAAS,MAAW;AACpC,OAAI,CAAC,EAAO,MAAM,CAAC,EAAO,OAAO;AAC/B,MAAU,QAAQ;AAClB;;GAEF,IAAM,IAAU,eAAe,SAAU,OAAO,WAAW,eAA+B,EAAM;AAChG,OAAI,CAAC,EACH,OAAU,MAAM,2BAA2B;AAE7C,KAAU,QAAQ,IAAI,EACpB,EAAO,OACP,GACA,EAAM,eACP;KACA;GAAE,WAAW;GAAM,MAAM;GAAM,CAAC;EAGnC,IAAM,IAAe,EAA+B,EAAM,gBAAgB,EAAE,CAAC;AAC7E,UAAY,EAAM,eAAe,GAAO,MAAa;AACnD,IACG,KAAS,KAAY,KAAK,UAAU,EAAM,KAAK,KAAK,UAAU,EAAS,IACpE,KAAS,CAAC,KACV,KAAY,CAAC,OAEjB,EAAa,QAAQ;KAEtB,EAAE,MAAM,IAAM,CAAC;EAClB,IAAM,IAAiB,EAAiC,EAAM,eAAe;AAC7E,UAAY,EAAM,iBAAiB,MAAM;AACvC,KAAe,QAAQ;KACtB,EAAE,MAAM,IAAM,CAAC;EAClB,IAAM,IAAQ,GACZ,EAAM,EAAgB,MAAM,EAC5B,GACA,EAAM,WACN,GACA,GACA,EAAM,qBACN,EAAM,qBACN,EAAM,gBACN,EAAM,eACP;EAED,SAAS,IAAQ;GACf,IAAM,IAAoB,GACxB,EAAM,EAAgB,MAAM,EAC5B,EAAM,UACP;AASD,GARA,OAAO,OAAO,EAAM,MAAM,UAAU,EAAkB,EACtD,OAAO,OAAO,EAAM,MAAM,SAAS;IACjC,mBAAmB;IACnB,eAAe;IACf,iBAAiB;IACjB,YAAY;IACZ,WAAW;IACZ,CAAC,EACF,EAAe,QAAQ,EAAM;;EAG/B,IAAM,IAAc,QAAe,EAAgB,EAAM,MAAM,SAAS,WAAW,CAAC,EAE9E,IAAW,EAAkC,KAAK,EAClD,IAAyB,EAAoC,KAAK,EAClE,IAAa,EAAI,GAAM,EACvB,IAAiB,EAAsB,KAAK,EAE5C,IAAY,QACV,EAAM,OAAO,MAAM,CAAC,EAAM,OAAO,SAAS,CAAC,EAAM,OAAO,OAC/D,EACK,IAAmB,QACjB,EAAM,MAAM,QAAQ,qBAAqB,EAAY,UAAU,UACtE;AAED,UAAY,EAAU,QAAQ,GAAK,MAAY;AAC7C,GAAI,KAAO,CAAC,MACV,EAAM,MAAM,SAAS,aAAa;IAEpC;EAEF,IAAM,IAAc,GAAuB,MAAmB;AAC5D,OAAI,EAAU,MACZ,QAAO;AAET,OAAI,EAAM,OAAO,MAAM,EAAM,OAAO,UAAU,CAAC,EAAM,OAAO,MAC1D,QAAO;AAET,OAAI,CAAC,EAAM,OAAO,GAChB,QAAO;GAET,IAAM,IAAa,EAAM,MAAM,WAAW,OACpC,IAAY,EAAM,MAAM,UAAU;AAuBxC,UAtBK,EAAW,aAGX,EAAW,QAOZ,KAAa,OAAO,OAAO,EAAU,KAAK,UAAU,OAAO,CAAC,IAAI,WAAW,IACtE,UAEL,EAAW,QACN,EAAe,OAAO,SAAS,iBAAiB,iBAAiB,eAGvE,EAAM,MAAM,QAAQ,iBAAkB,MAAmB,WAAW,EAAM,MAAM,QAAQ,aAAc,EAAM,MAAM,QAAQ,kBACvH,EAAS,UAAU,SAAS,EAAM,MAAM,QAAQ,cAAc,EAAM,MAAM,QAAQ,aAE/E,YAEF,UAlBE,EAAe,UAAU,QAC3B,EAAM,MAAM,QAAQ,YACpB,EAAM,MAAM,QAAQ,oBACrB,YACA,aAPG;IAsBT;EAEF,SAAS,GAAgB,GAAmB;AAE1C,GADA,EAAM,MAAM,SAAS,uBAAuB,GAAG,KAAK,IAAI,IACxD,EAAM,MAAM,SAAS,oBAAoB;;EAG3C,IAAM,IAA0B,EAA0C,KAAK;EAE/E,SAAS,EAAoB,GAAY;GACvC,IAAM,IAAW,EAAM,MAAM;AAC7B,OAAI,GAAG;AACL,QAAI,EAAS,oBAAqB;AAMlC,IALA,AAEE,EAAwB,WADxB,aAAa,EAAwB,MAAM,EACX,OAElC,EAAS,kBAAkB,IAC3B,EAAwB,QAAQ,iBAAiB;AAG/C,KAFA,EAAS,kBAAkB,IAC3B,EAAS,sBAAsB,IAC/B,EAAwB,QAAQ;OAC/B,IAAK;SAER,GAAS,kBAAkB;;EAI/B,SAAS,EAAqB,GAAsB,GAA6D;AAC/G,KAAgB,QAAQ;IACtB,GAAG,EAAgB;IACnB,kBAAkB;IACnB;GAED,IAAM,IAAW,EAAM,MAAM,UAAU,OAAO,MAAM;AACpD,OAAI,EAAW,WAAW,KAAK,CAAC,GAAU;AACxC,MAAe,QAAQ;KAAE,UAAU,EAAE;KAAE,cAAc,EAAE;KAAE;AACzD;;GAGF,IAAM,IAAW,OAAO,KAAK,EAAS,EAChC,IAAa,EAAM,MAAM,WAAW;AAC1C,KAAe,QAAQ;IACrB,UAAU,EAAS,KAAK,MAAY,EAAW,cAAc,EAAQ,CAAC,KAAiB;IACvF,cAAc,EAAW,KAAK,MAAQ,EAAS,KAAK,MAAY,EAAS,GAAS,GAAK,CAAc;IACtG;;EAGH,SAAS,EAAmB,GAAuB;AACjD,KAAM,MAAM,SAAS,qBAAqB;;EAE5C,IAAI,IAAiE;EACrE,SAAS,GAAqB,GAAY;AACxC,GAAI,IACF,IAA2B,iBAAiB;AAC1C,MAAM,MAAM,QAAQ,iBAAiB;MACpC,IAAK,IAEJ,KACF,aAAa,EAAyB,EAExC,EAAM,MAAM,QAAQ,iBAAiB;;EAGzC,IAAM,IAA2B,EAAI,GAAM;EAC3C,SAAS,GAAa,GAAwB;AAC5C,KAAyB,QAAQ;;EAEnC,IAAM,KAAiD;GACrD,QAAU,CAAC,GAAgB;GAC3B,oBAAoB;IAClB,iBAAiB;IACjB;IACA,4BAA4B;IAC5B;IACD;GACD,UAAY,CAAC,EAAoB;GACjC,aAAe;IACb,iBAAiB;IACjB;IACA,4BAA4B;IAC7B;GACD,WAAa,CAAC,EAAoB;GAClC,SAAW;IAAE;IAAqB,iBAAiB;IAAsB;GACzE,QAAU,CAAC,EAAoB;GAChC;EACD,SAAS,EAAY,GAA6G;AAEhI,OAAI,KAAS,OAAO,OAAO,EAAM,KAAK,OAAO,CAAC,IAAI,SAAS,GAAG;AAG5D,QAAI,EAAS,MACX,GAAS,MAAM,sBAAsB;KAAE,GAAG,EAAM,EAAM,KAAK;KAAE,IAAI,EAAM,KAAK,MAAM,EAAM,OAAO,KAAK,EAAM,OAAO,QAAQ;KAAK,EAAE,EAAM,EAAM,SAAS,CAAa;SAC7J;KACL,IAAM,IAAW,SAAS,eAAe,oBAAoB;AAC7D,KAAI,MACF,EAAS,QAAQ,GAAQ,QAAQ,EAAM,EAAM,KAAK,EAAE,EAAM,EAAM,SAAS,EAAc,GAAmB,EAAM,SAAS,MAAmB,EACxI,EAAM,SAAS,SAAS,sBAE1B,EAAS,MAAM,iBAAiB,WAAW,EAAgB,MAAM,oBAAoB,EAAE,CAAC,EAE1F,EAAS,MAAM,MAAM,EAAS;;AAMlC,IAFA,EAAuB,QAAQ,EAAS,OAAO,iBAAiB,EAAE,GAAG,EAAS,MAAM,gBAAgB,GAAG,MACvG,EAAW,QAAQ,EAAS,OAAO,YAAY,IAC/C,EAAe,QAAQ,EAAS,OAAO,aAAa;SAIpD,CAFA,EAAS,OAAO,SAAS,EACzB,EAAS,QAAQ,MACjB,EAAe,QAAQ;;AAI3B,UAAY,EAAY,QAAQ,MAAM;AACpC,IAAI,MAAM,cAAc,MAAM,cAAc,EAAU,UAAU,UAC9D,EAAS,OAAO,SAAS,EACzB,EAAS,QAAQ;IAEnB;EAEF,IAAM,IAAqB,EAA+D,KAAK,EACzF,IAAyB,EAAmC,KAAK;EAEvE,SAAS,EAAmB,GAAiD;AAC3E,OAAI,CAAC,GAAQ;AAEX,IADA,EAAmB,QAAQ,MAC3B,EAAuB,QAAQ;AAC/B;;AAGF,GADA,EAAmB,QAAQ;IAAE,UAAU,EAAO;IAAU,MAAM,EAAO;IAAM,EAC3E,EAAuB,QAAQ,EAAO;;AA6GxC,EA1GA,EAAM,OACE,EAAM,MAAM,UAAU,MAC7B,GAAG,CAAC,OAAe;AAClB,KAAmB,EACjB,EAAM,EAAU,EAChB,EAAM,EAAM,MAAM,WAAW,MAAM,EACnC,EAAM,EAAM,MAAM,iBAAiB,MAAM,EACzC,EAAM,EAAM,MAAM,iBAAiB,MAAM,EACzC,EAAM,EAAM,MAAM,SAAS,EAC3B,EAAM,EAAM,MAAM,eAAe,EACjC,EAAM,EAAM,MAAM,gBAAgB,MAAM,CACzC,CAAC;IACF,EACF,EAAM;SACE,EAAM,MAAM,SAAS;SACrB,EAAM,MAAM,SAAS;SACrB,EAAM,MAAM,SAAS;SACrB,EAAM,MAAM,SAAS;SACrB,EAAM,MAAM,SAAS;SACrB,EAAM,MAAM,SAAS;GAC5B,QAAQ;AACP,KAAmB,EACjB,EAAM,EAAM,MAAM,UAAU,MAAM,EAClC,EAAM,EAAM,MAAM,WAAW,MAAM,EACnC,EAAM,EAAM,MAAM,iBAAiB,MAAM,EACzC,EAAM,EAAM,MAAM,iBAAiB,MAAM,EACzC,EAAM,EAAM,MAAM,SAAS,EAC3B,EAAM,EAAM,MAAM,eAAe,EACjC,EAAM,EAAM,MAAM,gBAAgB,MAAM,CACzC,CAAC;KACD,EAAE,MAAM,IAAM,CAAC,EAElB,QAAY,EAAmB,QAAQ,MAAc;AACnD,KAAY,EAAU;IACtB,EACF,SAAgB;AACd,KAAY,KAAK;IACjB,EACF,SAAkB;AAKhB,GAJA,AAEE,EAAwB,WADxB,aAAa,EAAwB,MAAM,EACX,OAElC,EAAS,OAAO,SAAS;IACzB,EAEF,QAAqB,EAAM,MAAM,SAAS,eAAe,MAAM;AAC7D,KAAgB,QAAQ;IACtB,GAAG,EAAgB;IACnB,cAAc,EAAS,EAAE;IAC1B;KACA;GAAE,MAAM;GAAM,UAAU;GAAM,CAAC,EAClC,QAAqB,EAAM,MAAM,SAAS,qBAAqB,MAAM;AACnE,KAAgB,QAAQ;IACtB,GAAG,EAAgB;IACnB,oBAAoB,EAAS,EAAE;IAChC;KACA;GAAE,MAAM;GAAM,UAAU;GAAM,CAAC,EAClC,QAAqB,EAAM,MAAM,SAAS,qBAAqB,MAAM;AACnE,KAAgB,QAAQ;IACtB,GAAG,EAAgB;IACnB,oBAAoB,EAAS,EAAE;IAChC;KACA;GAAE,MAAM;GAAM,UAAU;GAAM,CAAC,EAClC,QAAqB,EAAM,MAAM,SAAS,eAAe,MAAM;AAC7D,KAAgB,QAAQ;IACtB,GAAG,EAAgB;IACnB,cAAc,EAAS,EAAE;IAC1B;KACA;GAAE,MAAM;GAAM,UAAU;GAAM,CAAC,EAClC,QAAqB,EAAM,MAAM,SAAS,iBAAiB,MAAM;AAC/D,KAAgB,QAAQ;IACtB,GAAG,EAAgB;IACnB,gBAAgB,EAAS,EAAE;IAC5B;KACA;GAAE,MAAM;GAAM,UAAU;GAAM,CAAC,EAClC,QAAqB,EAAM,MAAM,SAAS,cAAc,MAAM;AAC5D,KAAgB,QAAQ;IACtB,GAAG,EAAgB;IACnB,aAAa,EAAS,EAAE;IACzB;KACA;GAAE,MAAM;GAAM,UAAU;GAAM,CAAC,EAElC,EAAe;SACP,EAAM,MAAM,SAAS;SACrB,EAAM,MAAM,SAAS;SACrB,EAAM,MAAM,SAAS;GAC5B,GAAG,CAAC,GAAW,GAAU,OAAgB;AACxC,KAAgB,QAAQ;IACtB,GAAG,EAAgB;IACnB;IACA;IACA;IACD;KACA,EAAE,UAAU,KAAM,CAAC,EAEtB,QAAY,EAAM,MAAM,SAAS,sBAAsB,MAAM;AAC3D,GAAI,MACF,EAAgB,QAAQ;IAAE,GAAG,EAAgB;IAAO,qBAAqB;IAAM;IAEjF,EAEF,QAAY,EAAgB,MAAM,aAAa,MAAM;AACnD,KAAM,MAAM,SAAS,aAAa,MAAM,KAAA,IAAY,gBAAgB;IACpE,EAEF,QAAY,EAAgB,OAAO,gBAAgB,QAAQ,YAAY,MAAM;AAC3E,KAAM,MAAM,SAAS,eAAe,OAAO,YAAY,KAAK;IAC5D;EAEF,SAAS,KAAW;AAClB,KACE,IAAI,KAAK,CACP,EAAS,OAAO,QAAQ,IAAI,GAC7B,CAAC,EACF,YACD;;EAGH,SAAS,GAAiB,GAAmB;AAC3C,KAAgB,QAAQ;IACtB,GAAG,EAAgB;IACnB,OAAO;IACR;;EAGH,SAAS,GAAe,GAAmB;AAEzC,GADA,EAAM,MAAM,SAAS,uBAAuB,GAC5C,EAAS,OAAO,iBAAiB,gBAAgB,EAAG;;EAGtD,IAAM,IAAQ,IAAU,EAElB,KAAqB,QAAe,EAAQ,EAAM,gBAAiB,EACnE,KAAkB,QAAe,EAAQ,EAAM,aAAc,EAC7D,KAAa,QAAe,EAAQ,EAAM,QAAS;yBAKvD,GAsCM,OAtCN,IAsCM;GArCJ,GAyBM,OAzBN,GAyBM;IAxBJ,EAUQ,IAAA;KATL,gBAAc,EAAA;KAAc,YAAY,EAAA,MAAgB;KAAQ,WAAW,EAAA;KAC3E,aAAW,EAAA;KAAW,cAAY,EAAA;KAAiB,qBAAqB,EAAA;KACxE,sBAAoB,EAAA;KACpB,uBAAqB,EAAA;KACrB,0BAA0B,EAAA;KAC1B,oBAAoB;KAAmB,oBAAoB;KAC3D,yBAAwB,AAAA,EAAA,QAAG,MAAeA,EAAAA,MAAK,qBAAsB,EAAE;;sBAE3C,CAA7B,EAA6B,EAAA,QAAA,gBAAA,CAAA,CAAA;;;;;;;;;;;;;IAEN,EAAA,SAAoB,EAAA,SAAA,GAAA,EAA7C,EAAwL,IAAA;;KAA/H,aAAa,EAAA,QAAS,YAAA;KAA2B,KAAK;KAAK,MAAM;KAAK,OAAO;KAAK,QAAQ;KAAK,kBAAkB,EAAA;;IAC1K,EAWuB,GAAA,EAXD,IAAG,wBAAsB,EAAA;sBAUhC,CARL,EAAA,EAAK,CAAC,SAAS,cAAU,GAAO,EAAA,SAAoB,EAAA,UAAc,EAAA,EAAkB,CAAC,EAAA,EAAK,CAAC,SAAS,WAAU,KAAA,GAAA,EADtH,EASa,IAAA;;MAPV,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,EAAK,CAAC,SAAS,aAAU;;uBAMrB,EAAA,GAAA,EAJZ,EAIY,EAJI,EAAA,MAAY,MAAK,EAAA,MAAA;wBACmD;QAAtE,EAAA,EAAK,CAAC,SAAS,eAAU,gBAArC,EAAkF,EAAA,QAAA,mBAAA,EAAA,KAAA,GAAA,CAAA,GAAA,EAAA,IAAA,GAAA;QACtE,EAAA,EAAK,CAAC,SAAS,eAAU,aAArC,EAA4E,EAAA,QAAA,gBAAA,EAAA,KAAA,GAAA,CAAA,GAAA,EAAA,IAAA,GAAA;QAChE,EAAA,EAAK,CAAC,SAAS,eAAU,QAArC,EAAkE,EAAA,QAAA,WAAA,EAAA,KAAA,GAAA,CAAA,GAAA,EAAA,IAAA,GAAA;;;;;;;;;GAK1E,EAKE,IAAA;gBAJS,EAAA,EAAK,CAAC,SAAS;6CAAf,EAAK,CAAC,SAAS,aAAU;IAAG,cAAY,EAAA,EAAK,CAAC,SAAS;IAAY,gBAAc,EAAA;IACzF,eAAe,EAAA;IAAqB,oBAAoB,GAAA;IAAqB,iBAAiB,GAAA;IAC9F,YAAY,GAAA;IAAa,gBAAgB,EAAA,SAAoB,EAAA;IAAoB;IACjF,UAAM,AAAA,EAAA,QAAA,MAAEA,EAAAA,MAAK,oBAAA;;;;;;;;;;;GAEmB,EAAA,OAAgB,SAAI,kBAAA,GAAA,EAAvD,EAA0G,GAAA;;IAA7B,WAAW,EAAA;;GAEhF,EAAA,UAA2B,EAAA,MAAuB,UAAU,EAAA,MAAuB,WAAA,GAAA,EAD3F,EAGE,IAAA;;IADC,sBAAoB,EAAA"}
|
package/dist/ui2.js
ADDED
package/dist/ui2.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ui2.js","names":[],"sources":["../src/ui.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport './assets/ui.scss';\nimport type {\n ChartInterface,\n DataByColumns,\n ErrorInfo,\n LassoControlsState,\n Settings,\n} from '@milaboratories/miplots4';\nimport { MiPlots } from '@milaboratories/miplots4';\nimport type { ChartType, PlotDataAndSettings } from '@milaboratories/pf-plots';\nimport { DemoDataStore } from '@milaboratories/pf-plots';\nimport type { AxisSpec, PFrameDriver, PlSelectionModel, PTableKey } from '@platforma-sdk/model';\nimport { watchDebounced } from '@vueuse/core';\nimport { computed, onMounted, onUnmounted, ref, shallowRef, toRaw, useSlots, watch } from 'vue';\nimport Chart from './components/Chart.vue';\nimport PanelModal from './components/PanelModal.vue';\nimport VTabs from './components/SettingsTabs/index.vue';\nimport TransitionSlidePanel from './components/TransitionSlidePanel.vue';\nimport ChartErrorNotificationAlert from './components/ChartErrorNotificationAlert.vue';\nimport ChartTruncationWarningAlert from './components/ChartTruncationWarningAlert.vue';\nimport { isOwnGraphMakerTab, useSettingsForm } from './forms';\nimport { createReactiveState, provideStore } from './store';\nimport type { DendroNodeInfo, GraphMakerProps, GraphMakerState, GraphStatus } from './types';\nimport { composeChartSettings, saveToFile } from './utils';\nimport type { ChartTruncationWarning } from './utils/createChartSettingsForRender/composeChartSettings';\nimport { copyJSON } from './utils/copyJSON';\nimport GraphStatusScreen from './components/GraphStatusScreen.vue';\n\nconst _emit = defineEmits(['delete-this-graph', 'tooltip-btn-click']);\n\nconst graphMakerState = defineModel<GraphMakerState>({ required: true });\nconst selectionState = defineModel<PlSelectionModel>('selection');\n\nconst props = defineProps<GraphMakerProps>();\n\ndefineExpose({\n /**\n reset() will update data-mapping, axis-settings, layers-settings with the state that is in v-model at the moment.\n In other cases editing of v-model fields doesn't make any impact to graphs and interface.\n */\n reset,\n});\n\nconst dataStore = ref<DemoDataStore | null>(null);\n\nwatch(() => props.pFrame, (pframe) => {\n if (!pframe.ok || !pframe.value) {\n dataStore.value = null;\n return;\n }\n const driver = ('platforma' in window) ? window.platforma?.pFrameDriver as PFrameDriver : props.driver;\n if (!driver) {\n throw new Error('PFrame driver is missing');\n }\n dataStore.value = new DemoDataStore(\n pframe.value,\n driver,\n props.labelsModifier,\n );\n}, { immediate: true, deep: true });\n\n// fixed options can be updated outside, other settings only inside from chart settings interface, so we don't watching other settings\nconst fixedOptions = ref<typeof props.fixedOptions>(props.fixedOptions ?? []);\nwatch(() => props.fixedOptions, (value, oldValue) => {\n if (\n (value && oldValue && JSON.stringify(value) !== JSON.stringify(oldValue))\n || (value && !oldValue)\n || (oldValue && !value)\n ) {\n fixedOptions.value = value;\n }\n}, { deep: true });\nconst defaultOptions = ref<typeof props.defaultOptions>(props.defaultOptions);\nwatch(() => props.defaultOptions, (v) => {\n defaultOptions.value = v;\n}, { deep: true });\nconst state = provideStore(\n toRaw(graphMakerState.value),\n dataStore,\n props.chartType,\n defaultOptions,\n fixedOptions,\n props.dataColumnPredicate,\n props.metaColumnPredicate,\n props.readonlyInputs,\n props.defaultPalette,\n);\n\nfunction reset() {\n const nextReactiveState = createReactiveState(\n toRaw(graphMakerState.value),\n props.chartType,\n );\n Object.assign(state.value.reactive, nextReactiveState);\n Object.assign(state.value.loading, {\n initialInputGuide: true,\n initialCharts: true,\n initialDefaults: true,\n inputGuide: false,\n chartData: false,\n });\n defaultOptions.value = props.defaultOptions;\n}\n\nconst currentForm = computed(() => useSettingsForm(state.value.reactive.currentTab));\n\nconst chartRef = shallowRef<ChartInterface | null>(null);\nconst chartCalculatedDataRef = ref<Record<string, unknown> | null>(null);\nconst chartError = ref(false);\nconst chartErrorInfo = ref<ErrorInfo | null>(null);\n\nconst isRunning = computed(\n () => props.pFrame.ok && !props.pFrame.value && !props.pFrame.stable,\n);\nconst isInitialLoading = computed(\n () => state.value.loading.initialInputGuide && graphStatus.value === 'loading',\n);\n\nwatch(() => isRunning.value, (val, prevVal) => {\n if (val && !prevVal) {\n state.value.reactive.currentTab = null;\n }\n});\n\nconst graphStatus = computed<GraphStatus>((previousStatus) => {\n if (isRunning.value) {\n return 'running';\n }\n if (props.pFrame.ok && props.pFrame.stable && !props.pFrame.value) {\n return 'noPframe';\n }\n if (!props.pFrame.ok) {\n return 'noPframeWithError';\n }\n const inputGuide = state.value.inputGuide.value;\n const chartData = state.value.chartData.value;\n if (!inputGuide.consistent) {\n return 'inconsistent';\n }\n if (!inputGuide.ready) {\n return defaultOptions.value === null\n || state.value.loading.defaults\n || state.value.loading.initialInputGuide\n ? 'loading'\n : 'notReady';\n }\n if (chartData && Object.values(chartData.data.byColumns.values)[0]?.length === 0) {\n return 'empty';\n }\n if (chartError.value) {\n return chartErrorInfo.value?.type === 'unknownError' ? 'unknownError' : 'knownError';\n }\n if (\n (state.value.loading.initialCharts || (previousStatus !== 'ready' && state.value.loading.chartData) || state.value.loading.chartRendering)\n || (chartRef.value === null && (state.value.loading.inputGuide || state.value.loading.chartData))\n ) {\n return 'loading';\n }\n return 'ready';\n});\n\nfunction onTreeNodeClick(d: DendroNodeInfo) {\n state.value.reactive.dendroSelectedNodeId = d?.info[0]?.id as number;\n state.value.reactive.dendroInfoByClick = d;\n}\n\nconst tooltipHintHideTimerRef = ref<ReturnType<typeof setTimeout> | null>(null);\n\nfunction onTooltipHintSwitch(v: boolean) {\n const reactive = state.value.reactive;\n if (v) {\n if (reactive.tooltipHintWasShown) return;\n if (tooltipHintHideTimerRef.value) {\n clearTimeout(tooltipHintHideTimerRef.value);\n tooltipHintHideTimerRef.value = null;\n }\n reactive.showTooltipHint = true;\n tooltipHintHideTimerRef.value = setTimeout(() => {\n reactive.showTooltipHint = false;\n reactive.tooltipHintWasShown = true;\n tooltipHintHideTimerRef.value = null;\n }, 3000);\n } else {\n reactive.showTooltipHint = false;\n }\n}\n\nfunction onLassoPolygonUpdate(dotIndexes: number[], polygons: { points: [number, number][]; closed: boolean }[]) {\n graphMakerState.value = {\n ...graphMakerState.value,\n selectedPolygons: polygons,\n };\n\n const axesData = state.value.chartData.value?.data?.axesData;\n if (dotIndexes.length === 0 || !axesData) {\n selectionState.value = { axesSpec: [], selectedKeys: [] };\n return;\n }\n\n const axisKeys = Object.keys(axesData);\n const inputGuide = state.value.inputGuide.value;\n selectionState.value = {\n axesSpec: axisKeys.map((axisKey) => inputGuide.getSourceInfo(axisKey).spec as AxisSpec),\n selectedKeys: dotIndexes.map((idx) => axisKeys.map((axisKey) => axesData[axisKey][idx]) as PTableKey),\n };\n}\n\nfunction onLassoStateChange(v: LassoControlsState) {\n state.value.reactive.lassoControlsState = v;\n}\nlet chartRenderingInProgress: ReturnType<typeof setTimeout> | null = null;\nfunction onLoadingStateChange(v: boolean) {\n if (v) {\n chartRenderingInProgress = setTimeout(() => {\n state.value.loading.chartRendering = true;\n }, 1000);\n } else {\n if (chartRenderingInProgress) {\n clearTimeout(chartRenderingInProgress);\n }\n state.value.loading.chartRendering = false;\n }\n}\nconst isScatterplotZoomChanged = ref(false);\nfunction onZoomChange(isZoomChanged: boolean) {\n isScatterplotZoomChanged.value = isZoomChanged;\n}\nconst graphEventHandlers: Record<ChartType, unknown> = {\n 'dendro': [onTreeNodeClick],\n 'scatterplot-umap': {\n onPolygonUpdate: onLassoPolygonUpdate,\n onTooltipHintSwitch,\n onLassoControlsStateUpdate: onLassoStateChange,\n onZoomChange,\n },\n 'discrete': [onTooltipHintSwitch],\n 'scatterplot': {\n onPolygonUpdate: onLassoPolygonUpdate,\n onTooltipHintSwitch,\n onLassoControlsStateUpdate: onLassoStateChange,\n },\n 'histogram': [onTooltipHintSwitch],\n 'heatmap': { onTooltipHintSwitch, onLoadingChange: onLoadingStateChange },\n 'bubble': [onTooltipHintSwitch],\n};\nfunction updateChart(value: { data: PlotDataAndSettings['data']['byColumns']; settings: PlotDataAndSettings['settings'] } | null) {\n // if dataByColumns exists but columns has no data - show empty chart\n if (value && Object.values(value.data.values)[0]?.length > 0) {\n // console.log('value.dataByColumns', toRaw(value.data));\n // console.log('value.settings', toRaw(value.settings));\n if (chartRef.value) {\n chartRef.value.updateSettingsAndData({ ...toRaw(value.data), id: value.data.id + (props.pFrame.ok ? props.pFrame.value : '') }, toRaw(value.settings) as Settings);\n } else {\n const htmlNode = document.getElementById('chartSvgContainer');\n if (htmlNode) {\n chartRef.value = MiPlots.newPlot(toRaw(value.data), toRaw(value.settings) as Settings, graphEventHandlers[value.settings.type as ChartType]);\n if (value.settings.type === 'scatterplot-umap') {\n // set default polygons (from props)\n chartRef.value.updateChartState('polygon', graphMakerState.value.selectedPolygons ?? []);\n }\n chartRef.value.mount(htmlNode);\n }\n }\n // calculated by chart renderer data, tree hierarchy for example\n chartCalculatedDataRef.value = chartRef.value?.calculatedData ? { ...chartRef.value.calculatedData } : null;\n chartError.value = chartRef.value?.hasError ?? false;\n chartErrorInfo.value = chartRef.value?.errorInfo ?? null;\n } else {\n chartRef.value?.unmount();\n chartRef.value = null;\n chartErrorInfo.value = null;\n }\n}\n\nwatch(() => graphStatus.value, (v) => {\n if (v === 'notReady' || v === 'noPframe' || dataStore.value === null) {\n chartRef.value?.unmount();\n chartRef.value = null;\n }\n});\n\nconst chartDataForRender = shallowRef<{ settings: Settings; data: DataByColumns } | null>(null);\nconst chartTruncationWarning = ref<ChartTruncationWarning | null>(null);\n\nfunction applyComposeResult(result: ReturnType<typeof composeChartSettings>) {\n if (!result) {\n chartDataForRender.value = null;\n chartTruncationWarning.value = null;\n return;\n }\n chartDataForRender.value = { settings: result.settings, data: result.data };\n chartTruncationWarning.value = result.truncationWarning;\n}\n\nwatch([\n () => state.value.chartData.value,\n], ([chartData]) => {\n applyComposeResult(composeChartSettings(\n toRaw(chartData),\n toRaw(state.value.inputGuide.value),\n toRaw(state.value.uniqueValuesData.value),\n toRaw(state.value.filterLabelsInfo.value),\n toRaw(state.value.reactive),\n toRaw(state.value.defaultPalette),\n toRaw(state.value.facetValuesData.value),\n ));\n});\nwatch([\n () => state.value.reactive.template,\n () => state.value.reactive.layersSettings,\n () => state.value.reactive.axesSettings,\n () => state.value.reactive.statisticsSettings,\n () => state.value.reactive.dataBindAes,\n () => state.value.reactive.chartScale,\n], () => {\n applyComposeResult(composeChartSettings(\n toRaw(state.value.chartData.value),\n toRaw(state.value.inputGuide.value),\n toRaw(state.value.uniqueValuesData.value),\n toRaw(state.value.filterLabelsInfo.value),\n toRaw(state.value.reactive),\n toRaw(state.value.defaultPalette),\n toRaw(state.value.facetValuesData.value),\n ));\n}, { deep: true });\n\nwatch(() => chartDataForRender.value, (chartData) => {\n updateChart(chartData);\n});\nonMounted(() => {\n updateChart(null);\n});\nonUnmounted(() => {\n if (tooltipHintHideTimerRef.value) {\n clearTimeout(tooltipHintHideTimerRef.value);\n tooltipHintHideTimerRef.value = null;\n }\n chartRef.value?.unmount();\n});\n\nwatchDebounced(() => state.value.reactive.optionsState, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n optionsState: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\nwatchDebounced(() => state.value.reactive.usedDefaultOptions, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n usedDefaultOptions: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\nwatchDebounced(() => state.value.reactive.statisticsSettings, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n statisticsSettings: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\nwatchDebounced(() => state.value.reactive.axesSettings, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n axesSettings: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\nwatchDebounced(() => state.value.reactive.layersSettings, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n layersSettings: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\nwatchDebounced(() => state.value.reactive.dataBindAes, (v) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n dataBindAes: copyJSON(v),\n };\n}, { deep: true, debounce: 1000 });\n\nwatchDebounced([\n () => state.value.reactive.chartScale,\n () => state.value.reactive.template,\n () => state.value.reactive.currentTab,\n], ([zoomState, template, currentTab]) => {\n graphMakerState.value = {\n ...graphMakerState.value,\n zoomState,\n template,\n currentTab,\n };\n}, { debounce: 1000 });\n\nwatch(() => state.value.reactive.tooltipHintWasShown, (v) => {\n if (v) {\n graphMakerState.value = { ...graphMakerState.value, tooltipHintWasShown: true };\n }\n});\n\nwatch(() => graphMakerState.value.currentTab, (v) => {\n state.value.reactive.currentTab = v === undefined ? 'dataMapping' : v;\n});\n\nwatch(() => graphMakerState.value?.layersSettings?.dendro?.showTable, (v) => {\n state.value.reactive.layersSettings.dendro.showTable = v ?? false;\n});\n\nfunction onExport() {\n saveToFile(\n new Blob([\n chartRef.value?.export() ?? '',\n ]),\n 'chart.svg',\n );\n}\n\nfunction updateGraphTitle(nextTitle: string) {\n graphMakerState.value = {\n ...graphMakerState.value,\n title: nextTitle,\n };\n}\n\nfunction selectTreeNode(id: number | null) {\n state.value.reactive.dendroSelectedNodeId = id;\n chartRef.value?.updateChartState('selectedNode', id);\n}\n\nconst slots = useSlots();\n\nconst hasAnnotationsSlot = computed(() => Boolean(slots.annotationsSlot));\nconst hasSettingsSlot = computed(() => Boolean(slots.settingsSlot));\nconst hasLogSlot = computed(() => Boolean(slots.logSlot));\n\n</script>\n\n<template>\n <div class=\"graph-maker\">\n <div class=\"graph-maker__main-pane\">\n <Chart\n :graph-status=\"graphStatus\" :graphTitle=\"graphMakerState.title\" :chartData=\"chartCalculatedDataRef\"\n :chart-ref=\"chartRef\" :error-info=\"chartErrorInfo\" :dendroTooltipButton=\"tooltipButton\"\n :custom-status-text=\"statusText\"\n :allow-title-editing=\"allowTitleEditing\"\n :isScatterplotZoomChanged=\"isScatterplotZoomChanged\"\n @graph-title-update=\"updateGraphTitle\" @dendro-node-select=\"selectTreeNode\"\n @dendro-tooltip-btn-click=\"(id: string) => $emit('tooltip-btn-click', id)\"\n >\n <slot name=\"titleLineSlot\" />\n </Chart>\n <GraphStatusScreen v-if=\"isInitialLoading || isRunning\" :graphStatus=\"isRunning ? 'running' : 'loading'\" :top=\"67\" :left=\"12\" :right=\"12\" :bottom=\"12\" :customStatusText=\"statusText\" />\n <TransitionSlidePanel id=\"graph-settings-modal\">\n <PanelModal\n v-if=\"state.reactive.currentTab && !((isInitialLoading || isRunning) && isOwnGraphMakerTab(state.reactive.currentTab))\"\n @close=\"state.reactive.currentTab = null\"\n >\n <component :is=\"currentForm.value\">\n <slot v-if=\"state.reactive.currentTab === 'annotations'\" name=\"annotationsSlot\" />\n <slot v-if=\"state.reactive.currentTab === 'settings'\" name=\"settingsSlot\" />\n <slot v-if=\"state.reactive.currentTab === 'log'\" name=\"logSlot\" />\n </component>\n </PanelModal>\n </TransitionSlidePanel>\n </div>\n <VTabs\n v-model=\"state.reactive.currentTab\" :chart-type=\"state.reactive.chartType\" :graph-status=\"graphStatus\"\n :allowDeleting=\"allowChartDeleting\" :hasAnnotationsSlot=\"hasAnnotationsSlot\" :hasSettingsSlot=\"hasSettingsSlot\"\n :hasLogSlot=\"hasLogSlot\" :initialLoading=\"isInitialLoading || isRunning\" @export=\"onExport\"\n @delete=\"$emit('delete-this-graph')\"\n />\n <ChartErrorNotificationAlert v-if=\"chartErrorInfo?.type === 'unknownError'\" :errorInfo=\"chartErrorInfo\" />\n <ChartTruncationWarningAlert\n v-if=\"chartTruncationWarning && (chartTruncationWarning.groups || chartTruncationWarning.facets)\"\n :truncation-warning=\"chartTruncationWarning\"\n />\n </div>\n</template>\n"],"mappings":""}
|
|
@@ -1,14 +1,11 @@
|
|
|
1
|
-
import { copyJSON as
|
|
2
|
-
import { loadDefaultSources as
|
|
3
|
-
async function
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
o.components[n] && e.components[n].selectorStates.push(...c);
|
|
9
|
-
return e;
|
|
1
|
+
import { copyJSON as e } from "./copyJSON.js";
|
|
2
|
+
import { loadDefaultSources as t } from "./loadDefaultSources.js";
|
|
3
|
+
async function n(n, r, i) {
|
|
4
|
+
if (!i || i.length === 0) return n;
|
|
5
|
+
let a = await t(r, i, null, !1), o = e(n);
|
|
6
|
+
for (let [e, t] of Object.entries(a)) n.components[e] && o.components[e].selectorStates.push(...t);
|
|
7
|
+
return o;
|
|
10
8
|
}
|
|
11
|
-
export {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
//# sourceMappingURL=addFixedOptionsToState.js.map
|
|
9
|
+
export { n as addFixedOptionsToState };
|
|
10
|
+
|
|
11
|
+
//# sourceMappingURL=addFixedOptionsToState.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"addFixedOptionsToState.js","sources":["../../src/utils/addFixedOptionsToState.ts"],"sourcesContent":["import type { GraphMakerProps } from '../types';\nimport { copyJSON } from './copyJSON';\nimport type { DemoDataStore, InputState, SelectorStateFilter } from '@milaboratories/pf-plots';\nimport { loadDefaultSources } from './loadDefaultSources';\n\n// hidden options that are always in the state but not visible to the user\nexport async function addFixedOptionsToState(\n state: InputState,\n dataStore: DemoDataStore,\n fixedOptions: GraphMakerProps['fixedOptions'],\n): Promise<InputState> {\n if (!fixedOptions || fixedOptions.length === 0) {\n return state;\n }\n const loadedFixedOptions = await loadDefaultSources(dataStore, fixedOptions, null, false);\n const res: InputState = copyJSON(state);\n for (const [inputName, selectorStates] of Object.entries(loadedFixedOptions)) {\n if (state.components[inputName]) {\n res.components[inputName].selectorStates.push(...selectorStates as SelectorStateFilter[]);\n }\n }\n return res;\n}\n"],"
|
|
1
|
+
{"version":3,"file":"addFixedOptionsToState.js","names":[],"sources":["../../src/utils/addFixedOptionsToState.ts"],"sourcesContent":["import type { GraphMakerProps } from '../types';\nimport { copyJSON } from './copyJSON';\nimport type { DemoDataStore, InputState, SelectorStateFilter } from '@milaboratories/pf-plots';\nimport { loadDefaultSources } from './loadDefaultSources';\n\n// hidden options that are always in the state but not visible to the user\nexport async function addFixedOptionsToState(\n state: InputState,\n dataStore: DemoDataStore,\n fixedOptions: GraphMakerProps['fixedOptions'],\n): Promise<InputState> {\n if (!fixedOptions || fixedOptions.length === 0) {\n return state;\n }\n const loadedFixedOptions = await loadDefaultSources(dataStore, fixedOptions, null, false);\n const res: InputState = copyJSON(state);\n for (const [inputName, selectorStates] of Object.entries(loadedFixedOptions)) {\n if (state.components[inputName]) {\n res.components[inputName].selectorStates.push(...selectorStates as SelectorStateFilter[]);\n }\n }\n return res;\n}\n"],"mappings":";;AAMA,eAAsB,EACpB,GACA,GACA,GACqB;AACrB,KAAI,CAAC,KAAgB,EAAa,WAAW,EAC3C,QAAO;CAET,IAAM,IAAqB,MAAM,EAAmB,GAAW,GAAc,MAAM,GAAM,EACnF,IAAkB,EAAS,EAAM;AACvC,MAAK,IAAM,CAAC,GAAW,MAAmB,OAAO,QAAQ,EAAmB,CAC1E,CAAI,EAAM,WAAW,MACnB,EAAI,WAAW,GAAW,eAAe,KAAK,GAAG,EAAwC;AAG7F,QAAO"}
|
|
@@ -1,13 +1,6 @@
|
|
|
1
|
-
function
|
|
2
|
-
|
|
3
|
-
if (((o = (n = e.components) == null ? void 0 : n.y) == null ? void 0 : o.selectorStates.length) === 0)
|
|
4
|
-
return [];
|
|
5
|
-
if (!((s = (r = e.components) == null ? void 0 : r[c]) != null && s.selectorStates.length))
|
|
6
|
-
return ["single common group"];
|
|
7
|
-
const g = (l = e.components) == null ? void 0 : l[c].selectorStates[0].selectedSource, t = u[g];
|
|
8
|
-
return (t == null ? void 0 : t.list) ?? [];
|
|
1
|
+
function e(e, t, n) {
|
|
2
|
+
return e.components?.y?.selectorStates.length === 0 ? [] : e.components?.[n]?.selectorStates.length ? t[e.components?.[n].selectorStates[0].selectedSource]?.list ?? [] : ["single common group"];
|
|
9
3
|
}
|
|
10
|
-
export {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
//# sourceMappingURL=calculateDiscreteGroups.js.map
|
|
4
|
+
export { e as calculateDiscreteGroups };
|
|
5
|
+
|
|
6
|
+
//# sourceMappingURL=calculateDiscreteGroups.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"calculateDiscreteGroups.js","sources":["../../src/utils/calculateDiscreteGroups.ts"],"sourcesContent":["import type { InputState } from '@milaboratories/pf-plots';\nimport type { UniqueValuesBySourceMap } from '../types';\n\nexport function calculateDiscreteGroups(optionsState: InputState, uniqueValuesInfo: UniqueValuesBySourceMap, field: 'primaryGrouping' | 'secondaryGrouping'): string[] {\n if (optionsState.components?.y?.selectorStates.length === 0) {\n return [];\n }\n if (!optionsState.components?.[field]?.selectorStates.length) {\n return ['single common group'];\n }\n const idGroupingStr: string = optionsState.components?.[field].selectorStates[0].selectedSource;\n const entry = uniqueValuesInfo[idGroupingStr];\n return entry?.list ?? [];\n}\n"],"
|
|
1
|
+
{"version":3,"file":"calculateDiscreteGroups.js","names":[],"sources":["../../src/utils/calculateDiscreteGroups.ts"],"sourcesContent":["import type { InputState } from '@milaboratories/pf-plots';\nimport type { UniqueValuesBySourceMap } from '../types';\n\nexport function calculateDiscreteGroups(optionsState: InputState, uniqueValuesInfo: UniqueValuesBySourceMap, field: 'primaryGrouping' | 'secondaryGrouping'): string[] {\n if (optionsState.components?.y?.selectorStates.length === 0) {\n return [];\n }\n if (!optionsState.components?.[field]?.selectorStates.length) {\n return ['single common group'];\n }\n const idGroupingStr: string = optionsState.components?.[field].selectorStates[0].selectedSource;\n const entry = uniqueValuesInfo[idGroupingStr];\n return entry?.list ?? [];\n}\n"],"mappings":"AAGA,SAAgB,EAAwB,GAA0B,GAA2C,GAA0D;AASrK,QARI,EAAa,YAAY,GAAG,eAAe,WAAW,IACjD,EAAE,GAEN,EAAa,aAAa,IAAQ,eAAe,SAIxC,EADgB,EAAa,aAAa,GAAO,eAAe,GAAG,iBAEnE,QAAQ,EAAE,GAJf,CAAC,sBAAsB"}
|
package/dist/utils/copyJSON.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"copyJSON.js","sources":["../../src/utils/copyJSON.ts"],"sourcesContent":["export function copyJSON(obj: unknown) {\n return JSON.parse(JSON.stringify(obj));\n}\n"],"
|
|
1
|
+
{"version":3,"file":"copyJSON.js","names":[],"sources":["../../src/utils/copyJSON.ts"],"sourcesContent":["export function copyJSON(obj: unknown) {\n return JSON.parse(JSON.stringify(obj));\n}\n"],"mappings":"AAAA,SAAgB,EAAS,GAAc;AACrC,QAAO,KAAK,MAAM,KAAK,UAAU,EAAI,CAAC"}
|
|
@@ -1,29 +1,39 @@
|
|
|
1
|
-
import { PALETTE_MAP as
|
|
2
|
-
import { getAxesDataFromForms as
|
|
3
|
-
|
|
4
|
-
function
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
1
|
+
import { PALETTE_MAP as e } from "../../constantsAesthetic.js";
|
|
2
|
+
import { getAxesDataFromForms as t } from "./getAxesDataFromForms.js";
|
|
3
|
+
var n = 40, r = n / 2 - 2, i = 3;
|
|
4
|
+
function a(a, o, s) {
|
|
5
|
+
let c = o.template, l = o.layersSettings[c], u = o.dataBindAes[a.valueColor.value]?.palette;
|
|
6
|
+
a.aes = {
|
|
7
|
+
cellStrokeColor: l.strokeColor ?? "#110529",
|
|
8
|
+
colorsList: e[u ?? s.continuous].colors,
|
|
9
|
+
maxRadius: r * (o.chartScale / 100),
|
|
10
|
+
minRadius: i
|
|
11
|
+
}, a.size = { cellSize: n * (o.chartScale / 100) }, Object.assign(a, t(o.axesSettings, o.chartType)), a.NAValueAs = l.NAValueAs, l.normalizationDirection && (a.normalization = {
|
|
12
|
+
method: l.normalizationMethod,
|
|
13
|
+
direction: l.normalizationDirection
|
|
14
|
+
}), (l.aggregateByX || l.aggregateByY) && (a.aggregation = {
|
|
15
|
+
x: l.aggregateByX && a.xGroupBy && a.xGroupBy.length > 0,
|
|
16
|
+
y: l.aggregateByY && a.yGroupBy && a.yGroupBy.length > 0,
|
|
17
|
+
method: l.aggregationMethod
|
|
18
|
+
});
|
|
19
|
+
let d = o.axesSettings.other.nullValueLabel;
|
|
20
|
+
return a.xColumn &&= {
|
|
21
|
+
...a.xColumn,
|
|
22
|
+
nullValueLabel: d
|
|
23
|
+
}, a.yColumn &&= {
|
|
24
|
+
...a.yColumn,
|
|
25
|
+
nullValueLabel: d
|
|
26
|
+
}, a.xGroupBy &&= a.xGroupBy.map((e) => ({
|
|
27
|
+
...e,
|
|
28
|
+
nullValueLabel: d
|
|
29
|
+
})), a.yGroupBy &&= a.yGroupBy.map((e) => ({
|
|
30
|
+
...e,
|
|
31
|
+
nullValueLabel: d
|
|
32
|
+
})), a.facetBy &&= a.facetBy.map((e) => ({
|
|
33
|
+
...e,
|
|
34
|
+
nullValueLabel: d
|
|
35
|
+
})), a;
|
|
25
36
|
}
|
|
26
|
-
export {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
//# sourceMappingURL=composeBubbleSettings.js.map
|
|
37
|
+
export { a as composeBubbleSettings };
|
|
38
|
+
|
|
39
|
+
//# sourceMappingURL=composeBubbleSettings.js.map
|