Fix show and hide all buttons

This commit is contained in:
Andrew Kingston 2024-05-17 15:18:49 +01:00
parent 594b2eb04c
commit d2a92e2c90
2 changed files with 10 additions and 20 deletions

View File

@ -11,30 +11,20 @@
$: anyHidden = $columns.some(col => !col.visible)
$: text = getText($columns)
const toggleVisibility = async (column, visible) => {
const toggleColumn = async (column, visible) => {
datasource.actions.addSchemaMutation(column.name, { visible })
await datasource.actions.saveSchemaMutations()
dispatch(visible ? "show-column" : "hide-column")
}
const showAll = async () => {
const toggleAll = async visible => {
let mutations = {}
columns.forEach(column => {
mutations[column.name] = { visible: true }
$columns.forEach(column => {
mutations[column.name] = { visible }
})
datasource.actions.addSchemaMutations(mutations)
await datasource.actions.saveSchemaMutations()
dispatch("show-column")
}
const hideAll = async () => {
let mutations = {}
columns.forEach(column => {
mutations[column.name] = { visible: false }
})
datasource.actions.addSchemaMutations(mutations)
await datasource.actions.saveSchemaMutations()
dispatch("hide-column")
dispatch(visible ? "show-column" : "hide-column")
}
const getText = columns => {
@ -74,14 +64,14 @@
<Toggle
size="S"
value={column.visible}
on:change={e => toggleVisibility(column, e.detail)}
on:change={e => toggleColumn(column, e.detail)}
disabled={column.primaryDisplay}
/>
{/each}
</div>
<div class="buttons">
<ActionButton on:click={showAll}>Show all</ActionButton>
<ActionButton on:click={hideAll}>Hide all</ActionButton>
<ActionButton on:click={() => toggleAll(true)}>Show all</ActionButton>
<ActionButton on:click={() => toggleAll(false)}>Hide all</ActionButton>
</div>
</div>
</Popover>

View File

@ -47,7 +47,7 @@ export const deriveStores = context => {
// prop and user overrides
const enrichedSchema = derived(
[schema, schemaOverrides, schemaMutations, columnWhitelist],
([$schema, $schemaOverrides, schemaMutations, $columnWhitelist]) => {
([$schema, $schemaOverrides, $schemaMutations, $columnWhitelist]) => {
if (!$schema) {
return null
}
@ -60,7 +60,7 @@ export const deriveStores = context => {
enrichedSchema[field] = {
...$schema[field],
...$schemaOverrides?.[field],
...schemaMutations[field],
...$schemaMutations[field],
}
})
return enrichedSchema