mirror of https://github.com/Budibase/budibase.git
9 changed files with 303 additions and 380 deletions
@ -1,30 +1,97 @@ |
|||||
<script> |
<script> |
||||
|
import { onMount } from "svelte" |
||||
|
import { store, backendUiStore } from "builderStore" |
||||
|
import { notifier } from "builderStore/store/notifications" |
||||
|
import { Modal, ModalContent, Icon } from "@budibase/bbui" |
||||
import ColumnHeaderPopover from "../popovers/ColumnPopover.svelte" |
import ColumnHeaderPopover from "../popovers/ColumnPopover.svelte" |
||||
|
import CreateEditColumnPopover from "../popovers/CreateEditColumnPopover.svelte" |
||||
|
|
||||
|
const SORT_ICON_MAP = { |
||||
|
asc: "ri-arrow-down-fill", |
||||
|
desc: "ri-arrow-up-fill", |
||||
|
} |
||||
|
|
||||
|
export let field |
||||
export let column |
export let column |
||||
export let gridApi |
export let gridApi |
||||
export let field |
export let enableMenu = true |
||||
export let enableMenu |
export let enableSorting = true |
||||
|
export let showColumnMenu |
||||
|
export let progressSort |
||||
|
|
||||
let menuButton |
let menuButton |
||||
|
let sortDirection = "" |
||||
|
let modal |
||||
|
|
||||
// field = { |
let originalName = field.name |
||||
// name: column.colId, |
let primaryDisplay = |
||||
// colDef: column.colDef, |
$backendUiStore.selectedTable.primaryDisplay == null || |
||||
// } |
$backendUiStore.selectedTable.primaryDisplay === field.name |
||||
|
|
||||
console.log("in svelte", $$restProps) |
|
||||
|
|
||||
function toggleMenu() { |
function toggleMenu() { |
||||
this.agParams.showColumnMenu(menuButton) |
showColumnMenu(menuButton) |
||||
|
} |
||||
|
|
||||
|
function onSort(event) { |
||||
|
progressSort(event.shiftKey) |
||||
|
} |
||||
|
|
||||
|
function showModal() { |
||||
|
modal.show() |
||||
} |
} |
||||
|
|
||||
|
async function saveColumn() { |
||||
|
backendUiStore.update(state => { |
||||
|
backendUiStore.actions.tables.saveField({ |
||||
|
originalName, |
||||
|
field, |
||||
|
primaryDisplay, |
||||
|
}) |
||||
|
return state |
||||
|
}) |
||||
|
notifier.success(`Column ${field.name} saved successfully.`) |
||||
|
modal.hide() |
||||
|
} |
||||
|
|
||||
|
onMount(() => { |
||||
|
column.addEventListener("sortChanged", () => { |
||||
|
sortDirection = column.getSort() |
||||
|
}) |
||||
|
}) |
||||
</script> |
</script> |
||||
|
|
||||
<button bind:this={menuButton} on:click={toggleMenu} /> |
<header on:click={onSort}> |
||||
<ColumnHeaderPopover on:click {field} /> |
<div> |
||||
|
<span>{field.name}</span> |
||||
|
{#if enableSorting && sortDirection} |
||||
|
<i class={SORT_ICON_MAP[sortDirection]} /> |
||||
|
{/if} |
||||
|
</div> |
||||
|
<Modal bind:this={modal}> |
||||
|
<ModalContent |
||||
|
title={`Edit Column: ${field.name}`} |
||||
|
confirmText={'Save Column'} |
||||
|
onConfirm={saveColumn}> |
||||
|
<CreateEditColumnPopover {field} /> |
||||
|
</ModalContent> |
||||
|
</Modal> |
||||
|
<div> |
||||
|
<span on:click|stopPropagation={showModal}> |
||||
|
<i class="ri-pencil-line" /> |
||||
|
</span> |
||||
|
<span on:click|stopPropagation={toggleMenu} bind:this={menuButton}> |
||||
|
<i class="ri-filter-line" /> |
||||
|
</span> |
||||
|
</div> |
||||
|
</header> |
||||
|
|
||||
<style> |
<style> |
||||
h1 { |
header { |
||||
color: rebeccapurple; |
font-family: Inter; |
||||
|
display: flex; |
||||
|
justify-content: space-between; |
||||
|
height: 100%; |
||||
|
width: 100%; |
||||
|
align-items: center; |
||||
} |
} |
||||
</style> |
</style> |
||||
|
|||||
@ -1,27 +1,28 @@ |
|||||
<script> |
<script> |
||||
import { DropdownMenu, TextButton as Button, Icon } from "@budibase/bbui" |
import { |
||||
|
DropdownMenu, |
||||
|
TextButton as Button, |
||||
|
Icon, |
||||
|
Modal, |
||||
|
ModalContent, |
||||
|
} from "@budibase/bbui" |
||||
import CreateEditColumnPopover from "../popovers/CreateEditColumnPopover.svelte" |
import CreateEditColumnPopover from "../popovers/CreateEditColumnPopover.svelte" |
||||
|
|
||||
let anchor |
let modal |
||||
let dropdown |
|
||||
let fieldName |
let fieldName |
||||
</script> |
</script> |
||||
|
|
||||
<div bind:this={anchor}> |
<div> |
||||
<Button text small on:click={dropdown.show}> |
<Button text small on:click={modal.show}> |
||||
<Icon name="addcolumn" /> |
<Icon name="addcolumn" /> |
||||
Create New Column |
Create New Column |
||||
</Button> |
</Button> |
||||
</div> |
</div> |
||||
<DropdownMenu bind:this={dropdown} {anchor} align="left"> |
<Modal bind:this={modal}> |
||||
<h5>Create Column</h5> |
<ModalContent |
||||
<CreateEditColumnPopover onClosed={dropdown.hide} /> |
title={'Create Column'} |
||||
</DropdownMenu> |
confirmText={'Save Column'} |
||||
|
onConfirm={console.log}> |
||||
<style> |
<CreateEditColumnPopover /> |
||||
h5 { |
</ModalContent> |
||||
padding: var(--spacing-xl) 0 0 var(--spacing-xl); |
</Modal> |
||||
margin: 0; |
|
||||
font-weight: 500; |
|
||||
} |
|
||||
</style> |
|
||||
|
|||||
@ -0,0 +1,145 @@ |
|||||
|
<script> |
||||
|
import { backendUiStore } from "builderStore" |
||||
|
import { DropdownMenu, Button, Icon, Input, Select } from "@budibase/bbui" |
||||
|
import { FIELDS } from "constants/backend" |
||||
|
import CreateEditColumnPopover from "./CreateEditColumnPopover.svelte" |
||||
|
import ConfirmDialog from "components/common/ConfirmDialog.svelte" |
||||
|
import { notifier } from "../../../../builderStore/store/notifications" |
||||
|
|
||||
|
export let field |
||||
|
|
||||
|
let anchor |
||||
|
let dropdown |
||||
|
let editing |
||||
|
let confirmDeleteDialog |
||||
|
|
||||
|
$: sortColumn = $backendUiStore.sort && $backendUiStore.sort.column |
||||
|
$: sortDirection = $backendUiStore.sort && $backendUiStore.sort.direction |
||||
|
$: type = field?.type |
||||
|
|
||||
|
function showEditor() { |
||||
|
editing = true |
||||
|
} |
||||
|
|
||||
|
function hideEditor() { |
||||
|
dropdown.hide() |
||||
|
editing = false |
||||
|
} |
||||
|
|
||||
|
function showDelete() { |
||||
|
dropdown.hide() |
||||
|
confirmDeleteDialog.show() |
||||
|
} |
||||
|
|
||||
|
function deleteColumn() { |
||||
|
if (field.name === $backendUiStore.selectedTable.primaryDisplay) { |
||||
|
notifier.danger("You cannot delete the display column") |
||||
|
} else { |
||||
|
backendUiStore.actions.tables.deleteField(field) |
||||
|
notifier.success("Column deleted") |
||||
|
} |
||||
|
hideEditor() |
||||
|
} |
||||
|
|
||||
|
function sort(direction, column) { |
||||
|
backendUiStore.update(state => { |
||||
|
if (direction !== "none") { |
||||
|
state.sort = { direction, column } |
||||
|
} else { |
||||
|
state.sort = undefined |
||||
|
} |
||||
|
return state |
||||
|
}) |
||||
|
hideEditor() |
||||
|
} |
||||
|
</script> |
||||
|
|
||||
|
<div class="container" bind:this={anchor} on:click={dropdown.show}> |
||||
|
<span>{field.name}</span> |
||||
|
<Icon name="arrowdown" /> |
||||
|
</div> |
||||
|
<DropdownMenu bind:this={dropdown} {anchor} align="left"> |
||||
|
{#if editing} |
||||
|
<h5>Edit Column</h5> |
||||
|
<CreateEditColumnPopover onClosed={hideEditor} {field} /> |
||||
|
{:else} |
||||
|
<ul> |
||||
|
{#if type !== 'link'} |
||||
|
<li data-cy="edit-column-header" on:click={showEditor}> |
||||
|
<Icon name="edit" /> |
||||
|
Edit |
||||
|
</li> |
||||
|
{/if} |
||||
|
<li data-cy="delete-column-header" on:click={showDelete}> |
||||
|
<Icon name="delete" /> |
||||
|
Delete |
||||
|
</li> |
||||
|
{#if sortDirection === 'desc' || sortDirection === 'asc'} |
||||
|
<li on:click={() => sort('none', field.name)}> |
||||
|
<Icon name="close" /> |
||||
|
Remove sort |
||||
|
</li> |
||||
|
{/if} |
||||
|
{#if sortDirection === 'desc' || sortColumn !== field.name} |
||||
|
<li on:click={() => sort('asc', field.name)}> |
||||
|
<Icon name="sortascending" /> |
||||
|
Sort A - Z |
||||
|
</li> |
||||
|
{/if} |
||||
|
{#if sortDirection === 'asc' || sortColumn !== field.name} |
||||
|
<li on:click={() => sort('desc', field.name)}> |
||||
|
<Icon name="sortdescending" /> |
||||
|
Sort Z - A |
||||
|
</li> |
||||
|
{/if} |
||||
|
</ul> |
||||
|
{/if} |
||||
|
</DropdownMenu> |
||||
|
<ConfirmDialog |
||||
|
bind:this={confirmDeleteDialog} |
||||
|
body={`Are you sure you wish to delete this column? Your data will be deleted and this action cannot be undone.`} |
||||
|
okText="Delete Column" |
||||
|
onOk={deleteColumn} |
||||
|
title="Confirm Delete" /> |
||||
|
|
||||
|
<style> |
||||
|
.container { |
||||
|
display: flex; |
||||
|
flex-direction: row; |
||||
|
justify-content: flex-start; |
||||
|
align-items: center; |
||||
|
gap: var(--spacing-xs); |
||||
|
} |
||||
|
|
||||
|
h5 { |
||||
|
padding: var(--spacing-xl) 0 0 var(--spacing-xl); |
||||
|
margin: 0; |
||||
|
font-weight: 500; |
||||
|
} |
||||
|
|
||||
|
ul { |
||||
|
list-style: none; |
||||
|
padding-left: 0; |
||||
|
margin: 0; |
||||
|
padding: var(--spacing-s) 0; |
||||
|
} |
||||
|
|
||||
|
li { |
||||
|
display: flex; |
||||
|
font-family: var(--font-sans); |
||||
|
font-size: var(--font-size-xs); |
||||
|
color: var(--ink); |
||||
|
padding: var(--spacing-s) var(--spacing-m); |
||||
|
margin: auto 0px; |
||||
|
align-items: center; |
||||
|
cursor: pointer; |
||||
|
} |
||||
|
|
||||
|
li:hover { |
||||
|
background-color: var(--grey-2); |
||||
|
} |
||||
|
|
||||
|
li:active { |
||||
|
color: var(--blue); |
||||
|
} |
||||
|
</style> |
||||
Loading…
Reference in new issue