From eeda58822c5406ae249bb0aa4e17ed50a5e1b07c Mon Sep 17 00:00:00 2001 From: Andrew Kingston Date: Wed, 29 Mar 2023 14:57:56 +0100 Subject: [PATCH] Improve preservation of column widths in sheets when making schema changes --- .../src/components/sheet/Sheet.svelte | 3 +-- .../components/sheet/cells/HeaderCell.svelte | 16 +++++++++++- .../src/components/sheet/stores/columns.js | 26 +++++++++++++------ 3 files changed, 34 insertions(+), 11 deletions(-) diff --git a/packages/frontend-core/src/components/sheet/Sheet.svelte b/packages/frontend-core/src/components/sheet/Sheet.svelte index e68771b54a..f1c14800c2 100644 --- a/packages/frontend-core/src/components/sheet/Sheet.svelte +++ b/packages/frontend-core/src/components/sheet/Sheet.svelte @@ -10,9 +10,8 @@ import { createScrollStores } from "./stores/scroll" import { createBoundsStores } from "./stores/bounds" import { createUIStores } from "./stores/ui" - export { createUserStores } from "./stores/users" - import { createWebsocket } from "./websocket" import { createUserStores } from "./stores/users" + import { createWebsocket } from "./websocket" import { createResizeStores } from "./stores/resize" import { createMenuStores } from "./stores/menu" import { createMaxScrollStores } from "./stores/max-scroll" diff --git a/packages/frontend-core/src/components/sheet/cells/HeaderCell.svelte b/packages/frontend-core/src/components/sheet/cells/HeaderCell.svelte index 669cee2606..6913300dc6 100644 --- a/packages/frontend-core/src/components/sheet/cells/HeaderCell.svelte +++ b/packages/frontend-core/src/components/sheet/cells/HeaderCell.svelte @@ -18,6 +18,9 @@ dispatch, config, ui, + table, + rows, + API, } = getContext("sheet") let anchor @@ -79,7 +82,18 @@ open = false } - const makeDisplayColumn = () => {} + const makeDisplayColumn = async () => { + const tableDefinition = $table + if (!tableDefinition) { + return + } + await API.saveTable({ + ...tableDefinition, + primaryDisplay: column.name, + }) + await rows.actions.refreshSchema() + open = false + }
{ // Merge new schema fields with existing schema in order to preserve widths schema.subscribe($schema => { - const currentColumns = get(columns) if (!$schema) { columns.set([]) + stickyColumn.set(null) return } + const currentColumns = get(columns) + const currentStickyColumn = get(stickyColumn) // Get field list let fields = [] @@ -55,7 +57,12 @@ export const createColumnsStores = context => { // Update columns, removing extraneous columns and adding missing ones columns.set( fields.map(field => { - const existing = currentColumns.find(x => x.name === field) + // Check if there is an existing column with this name so we can keep + // the width setting + let existing = currentColumns.find(x => x.name === field) + if (!existing && currentStickyColumn?.name === field) { + existing = currentStickyColumn + } return { name: field, width: existing?.width || DefaultColumnWidth, @@ -64,21 +71,24 @@ export const createColumnsStores = context => { } }) ) - }) - schema.subscribe($schema => { + // Update sticky column const primaryDisplay = Object.entries($schema).find(entry => { return entry[1].primaryDisplay }) if (!primaryDisplay) { - stickyColumn.set(null) return } - const existingWidth = get(stickyColumn)?.width - const same = primaryDisplay[0] === get(stickyColumn)?.name + + // Check if there is an existing column with this name so we can keep + // the width setting + let existing = currentColumns.find(x => x.name === primaryDisplay[0]) + if (!existing && currentStickyColumn?.name === primaryDisplay[0]) { + existing = currentStickyColumn + } stickyColumn.set({ name: primaryDisplay[0], - width: same ? existingWidth : DefaultColumnWidth, + width: existing?.width || DefaultColumnWidth, left: 40, schema: primaryDisplay[1], idx: "sticky",