Files
dbgate/packages/web/src/charts/ChartEditor.svelte
2021-03-20 08:35:18 +01:00

161 lines
5.1 KiB
Svelte

<script lang="ts">
import AboutModal from '../modals/AboutModal.svelte';
import { presetPrimaryColors } from '@ant-design/colors';
import { startCase } from 'lodash';
import FormProviderCore from '../forms/FormProviderCore.svelte';
import HorizontalSplitter from '../elements/HorizontalSplitter.svelte';
import WidgetColumnBar from '../widgets/WidgetColumnBar.svelte';
import WidgetColumnBarItem from '../widgets/WidgetColumnBarItem.svelte';
import ManagerInnerContainer from '../elements/ManagerInnerContainer.svelte';
import FormSelectField from '../forms/FormSelectField.svelte';
import FormTextField from '../forms/FormTextField.svelte';
import FormCheckboxField from '../forms/FormCheckboxField.svelte';
import { writable } from 'svelte/store';
import FormFieldTemplateTiny from '../forms/FormFieldTemplateTiny.svelte';
import createRef from '../utility/createRef';
import { getConnectionInfo } from '../utility/metadataLoaders';
import { findEngineDriver } from 'dbgate-tools';
import { extensions } from '../stores';
import { loadChartData, loadChartStructure } from './chartDataLoader';
import DataChart from './DataChart.svelte';
import _ from 'lodash';
export let data;
export let configStore;
export let conid;
export let database;
export let sql;
export let menu;
let availableColumnNames = [];
let error = null;
let loadedData = null;
$: config = $configStore;
const getDriver = async () => {
const conn = await getConnectionInfo({ conid });
if (!conn) return;
const driver = findEngineDriver(conn, $extensions);
return driver;
};
const handleLoadColumns = async () => {
const driver = await getDriver();
if (!driver) return;
try {
const columns = await loadChartStructure(driver, conid, database, sql);
availableColumnNames = columns;
} catch (err) {
error = err.message;
}
};
const handleLoadData = async () => {
const driver = await getDriver();
if (!driver) return;
const loaded = await loadChartData(driver, conid, database, sql, config);
if (!loaded) return;
const { columns, rows } = loaded;
loadedData = {
structure: columns,
rows,
};
};
$: {
$extensions;
if (sql && conid && database) {
handleLoadColumns();
}
}
$: {
if (data) {
availableColumnNames = data.structure.columns.map(x => x.columnName);
}
}
$: {
$extensions;
if (config.labelColumn && sql && conid && database) {
handleLoadData();
}
}
let managerSize;
</script>
<FormProviderCore values={configStore} template={FormFieldTemplateTiny}>
<HorizontalSplitter initialValue="300px" bind:size={managerSize}>
<div class="left" slot="1">
<WidgetColumnBar>
<WidgetColumnBarItem title="Style" name="style" height="40%">
<ManagerInnerContainer width={managerSize}>
<FormSelectField
label="Chart type"
name="chartType"
isNative
options={[
{ value: 'bar', label: 'Bar' },
{ value: 'line', label: 'Line' },
{ value: 'pie', label: 'Pie' },
{ value: 'polarArea', label: 'Polar area' },
]}
/>
<FormTextField label="Color set" name="colorSeed" />
<FormSelectField
label="Truncate from"
name="truncateFrom"
isNative
options={[
{ value: 'begin', label: 'Begin' },
{ value: 'end', label: 'End (most recent data for datetime)' },
]}
/>
<FormTextField label="Truncate limit" name="truncateLimit" />
<FormCheckboxField label="Show relative values" name="showRelativeValues" />
</ManagerInnerContainer>
</WidgetColumnBarItem>
<WidgetColumnBarItem title="Data" name="data">
<ManagerInnerContainer width={managerSize}>
{#if availableColumnNames.length > 0}
<FormSelectField
label="Label column"
name="labelColumn"
isNative
options={[{ value: '' }, ...availableColumnNames.map(col => ({ value: col, label: col }))]}
/>
{/if}
{#each availableColumnNames as col (col)}
<FormCheckboxField label={col} name={`dataColumn_${col}`} />
{#if config[`dataColumn_${col}`]}
<FormSelectField
label="Color"
name={`dataColumnColor_${col}`}
isNative
options={[
{ value: '', label: 'Random' },
..._.keys(presetPrimaryColors).map(color => ({ value: color, label: _.startCase(color) })),
]}
/>
{/if}
{/each}
</ManagerInnerContainer>
</WidgetColumnBarItem>
</WidgetColumnBar>
</div>
<svelte:fragment slot="2">
<DataChart data={data || loadedData} {menu} />
</svelte:fragment>
</HorizontalSplitter>
</FormProviderCore>
<style>
.left {
background-color: var(--theme-bg-0);
display: flex;
flex: 1;
}
</style>