dont hide chart errors

This commit is contained in:
Gerard Burns 2024-04-18 08:23:19 +01:00
parent b75d054cdd
commit f5345fd4f3
2 changed files with 5 additions and 62 deletions

View File

@ -296,9 +296,6 @@
return false return false
} }
if (sectionDependsOnValue == null && sectionRealDependentValue == null) {
return false
}
if (sectionDependsOnValue != null && sectionDependsOnValue !== sectionRealDependentValue) { if (sectionDependsOnValue != null && sectionDependsOnValue !== sectionRealDependentValue) {
return false return false
} }

View File

@ -11,75 +11,27 @@
// Apex charts directly modifies the options object with default properties and internal variables. These being present could unintentionally cause issues to the provider of this prop as the changes are reflected in that component as well. To prevent any issues we clone this here to provide a buffer. // Apex charts directly modifies the options object with default properties and internal variables. These being present could unintentionally cause issues to the provider of this prop as the changes are reflected in that component as well. To prevent any issues we clone this here to provide a buffer.
$: optionsCopy = cloneDeep(options); $: optionsCopy = cloneDeep(options);
/*
export let invalid = false
const parseValue = (value) => {
// A value like [10, 11, 12] actually would be output by parseInt as `10`, but this behaviour is odd and not something a
// reasonable user would expect.
if (Array.isArray(value)) {
return null;
}
const parsedValue = parseInt(value, 10);
if (Number.isNaN(parsedValue)) {
return null;
}
return parsedValue
}
const parseOptions = (optionsCopy) => {
const parsedOptions = { series: [], ...cloneDeep(optionsCopy)}
// Object form of series, used by most charts
if (parsedOptions.series.some(entry => Array.isArray(entry?.data))) {
parsedOptions.series = parsedOptions.series.map(entry => ({ ...entry, data: parseValue})parseValue);
} else {
// Scalar form of series, used by non-axis charts like pie and donut
parsedOptions.series = parsedOptions.series.map(parseValue);
}
return parsedOptions;
}
$: parsedOptions = parseOptions(optionsCopy);
*/
let chartElement; let chartElement;
let chart; let chart;
const updateChart = async (newOptions) => { const updateChart = async (newOptions) => {
try { await chart?.updateOptions(newOptions)
await chart?.updateOptions(newOptions)
} catch(e) {
//console.log(e)
}
} }
const renderChart = async (newChartElement) => { const renderChart = async (newChartElement) => {
try { await chart?.destroy()
await chart?.destroy() chart = new ApexCharts(newChartElement, optionsCopy)
chart = new ApexCharts(newChartElement, optionsCopy) await chart.render()
await chart.render()
} catch(e) {
//console.log(e)
}
}
const isSeriesValid = (series) => {
return true
} }
$: noData = optionsCopy == null || optionsCopy?.series?.length === 0 $: noData = optionsCopy == null || optionsCopy?.series?.length === 0
$: hide = noData || !seriesValid $: hide = noData
// Call render chart upon changes to hide, as apex charts has issues with rendering upon changes automatically // Call render chart upon changes to hide, as apex charts has issues with rendering upon changes automatically
// if the chart is hidden. // if the chart is hidden.
$: renderChart(chartElement, hide) $: renderChart(chartElement, hide)
$: updateChart(optionsCopy) $: updateChart(optionsCopy)
$: seriesValid = isSeriesValid(optionsCopy?.series || [])
</script> </script>
{#key optionsCopy?.customColor} {#key optionsCopy?.customColor}
@ -89,13 +41,7 @@
<Icon name="Alert" color="var(--spectrum-global-color-static-red-600)" /> <Icon name="Alert" color="var(--spectrum-global-color-static-red-600)" />
Add rows to your data source to start using your component Add rows to your data source to start using your component
</div> </div>
{:else if $builderStore.inBuilder && !seriesValid}
<div class="component-placeholder" use:styleable={{ ...$component.styles, normal: {}, custom: null, empty: true }}>
<Icon name="Alert" color="var(--spectrum-global-color-static-red-600)" />
Your selected data cannot be displayed in this chart
</div>
{/if} {/if}
{/key} {/key}
<style> <style>