Add flags for controlling editing and adding rows in sheets

This commit is contained in:
Andrew Kingston 2023-03-07 11:51:47 +00:00
parent 554659bd91
commit 84770c72c2
3 changed files with 41 additions and 4 deletions

View File

@ -2,8 +2,9 @@
import { getContext } from "svelte" import { getContext } from "svelte"
import SheetScrollWrapper from "./SheetScrollWrapper.svelte" import SheetScrollWrapper from "./SheetScrollWrapper.svelte"
import HeaderCell from "./cells/HeaderCell.svelte" import HeaderCell from "./cells/HeaderCell.svelte"
import { Icon } from "@budibase/bbui"
const { visibleColumns } = getContext("sheet") const { visibleColumns, dispatch, config } = getContext("sheet")
</script> </script>
<div class="header"> <div class="header">
@ -14,6 +15,11 @@
{/each} {/each}
</div> </div>
</SheetScrollWrapper> </SheetScrollWrapper>
{#if $config.allowAddColumns}
<div class="new-column" on:click={() => dispatch("add-column")}>
<Icon size="S" name="Add" />
</div>
{/if}
</div> </div>
<style> <style>
@ -26,4 +32,19 @@
.row { .row {
display: flex; display: flex;
} }
.new-column {
position: absolute;
right: 0;
top: 0;
height: var(--cell-height);
background: var(--spectrum-global-color-gray-100);
display: grid;
place-items: center;
width: 40px;
border-left: var(--cell-border);
}
.new-column:hover {
cursor: pointer;
background: var(--spectrum-global-color-gray-200);
}
</style> </style>

View File

@ -26,6 +26,8 @@
export let tableId export let tableId
export let allowAddRows = true export let allowAddRows = true
export let allowSelectRows = true export let allowSelectRows = true
export let allowAddColumns = true
export let allowEditColumns = true
// Sheet constants // Sheet constants
const cellHeight = 36 const cellHeight = 36
@ -36,6 +38,8 @@
tableId, tableId,
allowAddRows, allowAddRows,
allowSelectRows, allowSelectRows,
allowAddColumns,
allowEditColumns,
}) })
// Build up spreadsheet context // Build up spreadsheet context
@ -65,6 +69,8 @@
tableId, tableId,
allowAddRows, allowAddRows,
allowSelectRows, allowSelectRows,
allowAddColumns,
allowEditColumns,
}) })
// Set context for children to consume // Set context for children to consume

View File

@ -7,8 +7,16 @@
export let column export let column
export let orderable = true export let orderable = true
const { reorder, isReordering, isResizing, rand, sort, columns, dispatch } = const {
getContext("sheet") reorder,
isReordering,
isResizing,
rand,
sort,
columns,
dispatch,
config,
} = getContext("sheet")
let anchor let anchor
let open = false let open = false
@ -117,7 +125,9 @@
animate={false} animate={false}
> >
<Menu> <Menu>
<MenuItem icon="Edit" on:click={editColumn}>Edit column</MenuItem> {#if $config.allowEditColumns}
<MenuItem icon="Edit" on:click={editColumn}>Edit column</MenuItem>
{/if}
<MenuItem icon="SortOrderUp" on:click={sortAscending}> <MenuItem icon="SortOrderUp" on:click={sortAscending}>
Sort ascending Sort ascending
</MenuItem> </MenuItem>