From bcd17dfc0a23d229f5920488d30923f1859e38c3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Saffet=20Bar=C4=B1=C5=9F=20Karaca?= Date: Wed, 31 Jan 2024 17:55:39 +0300 Subject: [PATCH] feat: table component * feat: Remove console log in story * feat: Change map to foreach for querySelectorAll * feat: Change story title to Table --- src/components/table/bl-table.stories.mdx | 26 ++++---- src/components/table/bl-table.ts | 60 ++++++++++++------- .../table/table-cell/bl-table-cell.ts | 2 +- 3 files changed, 57 insertions(+), 31 deletions(-) diff --git a/src/components/table/bl-table.stories.mdx b/src/components/table/bl-table.stories.mdx index fad63e53..afc3b000 100644 --- a/src/components/table/bl-table.stories.mdx +++ b/src/components/table/bl-table.stories.mdx @@ -3,7 +3,7 @@ import {Meta, Canvas, ArgsTable, Story} from '@storybook/addon-docs'; import { UPDATE_STORY_ARGS } from "@storybook/core-events"; { const tableData = sortedData || data; const onSort = (event) => { const [sortKey, sortDirection] = event.detail; - console.log("onSort", event.detail); const columnType = sortKey==="id" ? "number" : "string"; updateArgs({ ...args, @@ -48,7 +47,6 @@ export const TableTemplate = (args, {id}) => { }); } const onRowSelect = (event) => { - console.log("onRowSelect", event.detail); updateArgs({ ...args, selectValue: event.detail, @@ -59,11 +57,11 @@ export const TableTemplate = (args, {id}) => {
@@ -103,11 +101,15 @@ export const TableTemplate = (args, {id}) => { # Table Component -Checkbox Group is a component to take multiple selections from user with a list of options. It needs to be used with `bl-checkbox` component. -If you set a list of `values`, options with those values will be selected. +Table is a component to visualize a data set in rows and columns. It needs to be used with `bl-table-header`, `bl-table-body`, `bl-table-row`, `bl-table-header-cell`, `bl-table-cell` component. {TableTemplate.bind({})} diff --git a/src/components/table/bl-table.ts b/src/components/table/bl-table.ts index 31992983..7e544d01 100644 --- a/src/components/table/bl-table.ts +++ b/src/components/table/bl-table.ts @@ -1,4 +1,4 @@ -import { CSSResultGroup, html, LitElement, TemplateResult } from "lit"; +import { CSSResultGroup, html, LitElement, PropertyValues, TemplateResult } from "lit"; import { customElement, property, state } from "lit/decorators.js"; import "element-internals-polyfill"; import { event, EventDispatcher } from "../../utilities/event"; @@ -14,7 +14,7 @@ export const blRowSelectChangeEventName = "bl-table-row-select"; /** * @tag bl-table - * @summary Baklava Button component + * @summary Baklava Table component * */ @customElement(blTableTag) @@ -33,11 +33,9 @@ export default class BlTable extends LitElement { set selectValue(value: string[]) { this._selectValue = value; this.updateComplete.then(() => { - Array.from(this.querySelectorAll("bl-table-header-cell,bl-table-cell,bl-table-row")).map( - com => { - (com as BlTableHeaderCell | BlTableCell | BlTableRow).requestUpdate(); - } - ); + this.querySelectorAll("bl-table-header-cell,bl-table-cell,bl-table-row").forEach(com => { + (com as BlTableHeaderCell | BlTableCell | BlTableRow).requestUpdate(); + }); }); } @@ -107,6 +105,20 @@ export default class BlTable extends LitElement { @state() private _sortDirection: string = ""; + protected updated(_changedProperties: PropertyValues) { + if ( + _changedProperties.has("selectable") || + _changedProperties.has("multiple") || + _changedProperties.has("stickyFirstColumn") || + _changedProperties.has("stickyLastColumn") || + _changedProperties.has("sortable") + ) { + this.querySelectorAll("bl-table-header-cell,bl-table-cell,bl-table-row").forEach(com => { + (com as BlTableHeaderCell | BlTableCell | BlTableRow).requestUpdate(); + }); + } + } + get tableRows() { return this.querySelectorAll("bl-table-body bl-table-row"); } @@ -150,21 +162,29 @@ export default class BlTable extends LitElement { ); } + changeHeaderCheckbox(selected: boolean) { + if (selected) { + this.selectValue = Array.from(this.tableRows) + .filter(tr => !(tr as BlTableRow).disabled) + .map(tr => (tr as BlTableRow).selectionKey); + } else { + this.selectValue = []; + } + } + + changeRowCheckbox(selected: boolean, selectionKey: string) { + if (this.isRowSelected(selectionKey) && !selected) { + this.selectValue = this.selectValue.filter(v => v !== selectionKey); + } else if (!this.isRowSelected(selectionKey) && selected) { + this.selectValue = [...this.selectValue, selectionKey]; + } + } + onSelectionChange(isHeader = false, selected: boolean, selectionKey: string) { if (isHeader) { - if (selected) { - this.selectValue = Array.from(this.tableRows) - .filter(tr => !(tr as BlTableRow).disabled) - .map(tr => (tr as BlTableRow).selectionKey); - } else { - this.selectValue = []; - } + this.changeHeaderCheckbox(selected); } else { - if (this.selectValue.includes(selectionKey) && !selected) { - this.selectValue = this.selectValue.filter(v => v !== selectionKey); - } else if (!this.selectValue.includes(selectionKey) && selected) { - this.selectValue = [...this.selectValue, selectionKey]; - } + this.changeRowCheckbox(selected, selectionKey); } this.onRowSelect(this.selectValue); @@ -174,7 +194,7 @@ export default class BlTable extends LitElement { this._sortDirection = sortDirection; this.onSort([this.sortKey, this.sortDirection]); this.updateComplete.then(() => { - Array.from(this.querySelectorAll("bl-table-header-cell")).map(com => { + this.querySelectorAll("bl-table-header-cell").forEach(com => { (com as BlTableHeaderCell).requestUpdate(); }); }); diff --git a/src/components/table/table-cell/bl-table-cell.ts b/src/components/table/table-cell/bl-table-cell.ts index 93f4903c..8847e4cc 100644 --- a/src/components/table/table-cell/bl-table-cell.ts +++ b/src/components/table/table-cell/bl-table-cell.ts @@ -21,7 +21,7 @@ export default class BlTableCell extends LitElement { * Disable selection */ @property({ type: Boolean, reflect: true, attribute: "disable-selection" }) - disableSelection: boolean = false; + disableSelection = false; private get _table() { return this.closest("bl-table") ?? null;