mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-28 17:36:00 +00:00
resize datagrid columns
This commit is contained in:
@@ -1,14 +1,17 @@
|
|||||||
<script lang="ts">
|
<script>
|
||||||
import FontIcon from '../icons/FontIcon.svelte';
|
import FontIcon from '../icons/FontIcon.svelte';
|
||||||
import DropDownButton from '../elements/DropDownButton.svelte';
|
import DropDownButton from '../elements/DropDownButton.svelte';
|
||||||
|
import splitterDrag from '../utility/splitterDrag';
|
||||||
|
|
||||||
import ColumnLabel from './ColumnLabel.svelte';
|
import ColumnLabel from './ColumnLabel.svelte';
|
||||||
|
|
||||||
export let column;
|
export let column;
|
||||||
export let conid = undefined;
|
export let conid = undefined;
|
||||||
export let database = undefined;
|
export let database = undefined;
|
||||||
|
export let setSort;
|
||||||
export let grouping = undefined;
|
export let grouping = undefined;
|
||||||
export let order = undefined;
|
export let order = undefined;
|
||||||
|
export let setGrouping;
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="header">
|
<div class="header">
|
||||||
@@ -31,6 +34,7 @@
|
|||||||
</span>
|
</span>
|
||||||
{/if}
|
{/if}
|
||||||
<DropDownButton />
|
<DropDownButton />
|
||||||
|
<div class="horizontal-split-handle resizeHandleControl" use:splitterDrag={'clientX'} on:resizeSplitter />
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
@@ -48,12 +52,12 @@
|
|||||||
.icon {
|
.icon {
|
||||||
margin-left: 3px;
|
margin-left: 3px;
|
||||||
}
|
}
|
||||||
.resizer {
|
/* .resizer {
|
||||||
background-color: var(--theme-border);
|
background-color: var(--theme-border);
|
||||||
width: 2px;
|
width: 2px;
|
||||||
cursor: col-resize;
|
cursor: col-resize;
|
||||||
z-index: 1;
|
z-index: 1;
|
||||||
}
|
} */
|
||||||
.grouping {
|
.grouping {
|
||||||
color: var(--theme-font-alt);
|
color: var(--theme-font-alt);
|
||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
|
|||||||
@@ -1,8 +1,9 @@
|
|||||||
<script lang="ts" context="module">
|
<script context="module">
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<script lang="ts">
|
<script>
|
||||||
import { createMultiLineFilter } from 'dbgate-filterparser';
|
import { createMultiLineFilter } from 'dbgate-filterparser';
|
||||||
|
import splitterDrag from '../utility/splitterDrag';
|
||||||
|
|
||||||
import FilterMultipleValuesModal from '../modals/FilterMultipleValuesModal.svelte';
|
import FilterMultipleValuesModal from '../modals/FilterMultipleValuesModal.svelte';
|
||||||
|
|
||||||
@@ -16,6 +17,7 @@ import { createMultiLineFilter } from 'dbgate-filterparser';
|
|||||||
export let filterType;
|
export let filterType;
|
||||||
export let filter;
|
export let filter;
|
||||||
export let setFilter;
|
export let setFilter;
|
||||||
|
export let showResizeSplitter = false;
|
||||||
|
|
||||||
let value;
|
let value;
|
||||||
|
|
||||||
@@ -149,6 +151,9 @@ import { createMultiLineFilter } from 'dbgate-filterparser';
|
|||||||
<div class="flex">
|
<div class="flex">
|
||||||
<input type="text" readOnly={isReadOnly} bind:value on:keydown={handleKeyDown} />
|
<input type="text" readOnly={isReadOnly} bind:value on:keydown={handleKeyDown} />
|
||||||
<DropDownButton icon="icon filter" menu={createMenu} />
|
<DropDownButton icon="icon filter" menu={createMenu} />
|
||||||
|
{#if showResizeSplitter}
|
||||||
|
<div class="horizontal-split-handle resizeHandleControl" use:splitterDrag={'clientX'} on:resizeSplitter />
|
||||||
|
{/if}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
|||||||
@@ -355,7 +355,19 @@
|
|||||||
data-col={col.colIndex}
|
data-col={col.colIndex}
|
||||||
style={`width:${col.width}px; min-width:${col.width}px; max-width:${col.width}px`}
|
style={`width:${col.width}px; min-width:${col.width}px; max-width:${col.width}px`}
|
||||||
>
|
>
|
||||||
<ColumnHeaderControl column={col} {conid} {database} />
|
<ColumnHeaderControl
|
||||||
|
column={col}
|
||||||
|
{conid}
|
||||||
|
{database}
|
||||||
|
setSort={display.sortable ? order => display.setSort(col.uniqueName, order) : null}
|
||||||
|
order={display.getSortOrder(col.uniqueName)}
|
||||||
|
on:resizeSplitter={e => {
|
||||||
|
// @ts-ignore
|
||||||
|
display.resizeColumn(col.uniqueName, col.width, e.detail);
|
||||||
|
}}
|
||||||
|
setGrouping={display.sortable ? groupFunc => display.setGrouping(col.uniqueName, groupFunc) : null}
|
||||||
|
grouping={display.getGrouping(col.uniqueName)}
|
||||||
|
/>
|
||||||
</td>
|
</td>
|
||||||
{/each}
|
{/each}
|
||||||
</tr>
|
</tr>
|
||||||
@@ -384,6 +396,11 @@
|
|||||||
filterType={getFilterType(col.dataType)}
|
filterType={getFilterType(col.dataType)}
|
||||||
filter={display.getFilter(col.uniqueName)}
|
filter={display.getFilter(col.uniqueName)}
|
||||||
setFilter={value => display.setFilter(col.uniqueName, value)}
|
setFilter={value => display.setFilter(col.uniqueName, value)}
|
||||||
|
showResizeSplitter
|
||||||
|
on:resizeSplitter={e => {
|
||||||
|
// @ts-ignore
|
||||||
|
display.resizeColumn(col.uniqueName, col.width, e.detail);
|
||||||
|
}}
|
||||||
/>
|
/>
|
||||||
</td>
|
</td>
|
||||||
{/each}
|
{/each}
|
||||||
|
|||||||
Reference in New Issue
Block a user