This commit is contained in:
samunohito 2024-01-29 08:12:11 +09:00
parent e21c43e2aa
commit 53bad559a0
4 changed files with 37 additions and 8 deletions

View file

@ -1,5 +1,5 @@
<template>
<tr :class="$style.row">
<tr :class="[$style.row]">
<MkNumberCell
:content="(row.index + 1).toString()"
:row="row"

View file

@ -124,7 +124,6 @@ function onKeyDown(ev: KeyboardEvent) {
switch (state.value) {
case 'normal': {
// normal
ev.preventDefault();
if (ev.ctrlKey) {
@ -418,6 +417,7 @@ function onMouseMove(ev: MouseEvent) {
unSelectionOutOfRange(leftTop, rightBottom);
expandRange(leftTop, rightBottom);
previousCellAddress.value = targetCellAddress;
break;
@ -692,7 +692,6 @@ function refreshData() {
const _data: DataSource[] = data.value;
const _rows: GridRow[] = _data.map((_, index) => ({
index,
}));
const _columns: GridColumn[] = columnSettings.value.map((setting, index) => ({
index,

View file

@ -1,6 +1,12 @@
<template>
<th :class="[$style.num, [top ? {} : $style.border]]">
<th :class="[$style.cell, [top ? {} : $style.border]]">
<div
:class="[
$style.root,
]"
>
{{ content }}
</div>
</th>
</template>
@ -16,10 +22,33 @@ defineProps<{
</script>
<style module lang="scss">
.num {
$cellHeight: 28px;
$cellWidth: 34px;
.cell {
overflow: hidden;
white-space: nowrap;
height: $cellHeight;
max-height: $cellHeight;
min-height: $cellHeight;
min-width: $cellWidth;
width: $cellWidth;
cursor: pointer;
}
.root {
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
box-sizing: border-box;
padding: 0 8px;
min-width: 30px;
width: 30px;
height: 100%;
border: solid 0.5px transparent;
&.selected {
background-color: var(--accentedBg);
}
}
.border {

View file

@ -33,6 +33,7 @@ export type GridColumn = {
export type GridRow = {
index: number;
selected: boolean;
}
export type CellValueChangedEvent = {