Skip to content

Commit

Permalink
Merge pull request #1031 from 3YOURMIND/split-out-new-table
Browse files Browse the repository at this point in the history
feature(KtTable): initial implementation
  • Loading branch information
Isokaeder authored Dec 11, 2024
2 parents 4624bdd + 8a0c1a0 commit e554f4c
Show file tree
Hide file tree
Showing 46 changed files with 2,697 additions and 79 deletions.
1 change: 1 addition & 0 deletions eslint.config.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import yocoPackageJSON from './packages/yoco/package.json' assert { type: 'json'
const trustedDependencies = new Set([
'@metatypes/typography',
'@metatypes/units',
'@tanstack/table-core',
'filesize',
'nanoid',
'zod',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
import { computed, defineComponent, ref } from 'vue'
export default defineComponent({
name: 'CodePreview',
name: 'CodePreviewLegacy',
props: {
vueSlotLabel: { default: 'Kotti-UI', type: String },
styleSlotLabel: { default: 'Kotti-Style', type: String },
Expand Down
2 changes: 2 additions & 0 deletions packages/documentation/data/menu.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import {
KtNavbar,
KtPagination,
KtPopover,
KtTable,
KtTableLegacy,
KtTag,
KtToaster,
Expand Down Expand Up @@ -173,6 +174,7 @@ export const menu: Array<Section> = [
makeComponentMenuItem(KtModal),
makeComponentMenuItem(KtPagination),
makeComponentMenuItem(KtPopover),
makeComponentMenuItem(KtTable),
makeComponentMenuItem(KtTableLegacy),
makeComponentMenuItem(KtTag),
makeComponentMenuItem(KtToaster),
Expand Down
8 changes: 4 additions & 4 deletions packages/documentation/pages/usage/components/drawer.vue
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ You can also customize the width of drawer by setting both `defaultWidth` and `e

When the `disallowCloseOutside` flag is set, it prevents the user from accidentally closing the drawer by clicking outside of the drawer.

<CodePreview>
<CodePreviewLegacy>

<div slot="vue">

Expand Down Expand Up @@ -124,7 +124,7 @@ When the `disallowCloseOutside` flag is set, it prevents the user from accidenta

</div>

</CodePreview>
</CodePreviewLegacy>

## Usage

Expand All @@ -143,14 +143,14 @@ import { defineComponent } from 'vue'
import { KtDrawer } from '@3yourmind/kotti-ui'
import CodePreview from '~/components/CodePreview.vue'
import CodePreviewLegacy from '~/components/CodePreviewLegacy.vue'
import ComponentInfo from '~/components/ComponentInfo.vue'
export default defineComponent({
name: 'DocumentationPageUsageComponentsDrawer',
components: {
ComponentInfo,
CodePreview,
CodePreviewLegacy,
},
data() {
return {
Expand Down
52 changes: 26 additions & 26 deletions packages/documentation/pages/usage/components/table-legacy.vue
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ _Update:_ The use of `key` is deprecated use `prop` instead of `key` when defini

_For better performance in complex operations_, define a `rowKey` to index each row with.

<CodePreview>
<CodePreviewLegacy>

<div slot="vue">

Expand Down Expand Up @@ -75,7 +75,7 @@ _For better performance in complex operations_, define a `rowKey` to index each

</div>

</CodePreview>
</CodePreviewLegacy>

## Declarative form

Expand Down Expand Up @@ -466,7 +466,7 @@ To sort remotly:
> You must use `slot-scope` prop for the `actions` slot for it to be detected.
> Update: shorthand for v-slot is used now, instead.

<CodePreview vueSlotLabel="Actions Table" styleSlotLabel="html">
<CodePreviewLegacy vueSlotLabel="Actions Table" styleSlotLabel="html">
<div slot="vue">
<KtTableLegacy :rows="rows" :columns="columnsDefault">
<div slot="actions" slot-scope="{row, rowIndex}">
Expand All @@ -487,11 +487,11 @@ To sort remotly:
```

</div>
</CodePreview>
</CodePreviewLegacy>

_Update_: Preferably, since the above syntax is now deprecated, use [v-slot](https://vuejs.org/v2/guide/components-slots.html)

<CodePreview vueSlotLabel="v-slot syntax" styleSlotLabel="shorthand">
<CodePreviewLegacy vueSlotLabel="v-slot syntax" styleSlotLabel="shorthand">
<div slot="vue">

```html
Expand All @@ -514,13 +514,13 @@ _Update_: Preferably, since the above syntax is now deprecated, use [v-slot](htt
```

</div>
</CodePreview>
</CodePreviewLegacy>

## Expandable

`isExpandable` enables expandability of the row**s**, defined on `<KtTableLegacy/>`. You use the `slot="expand"` to define the template that shows on expansion.

<CodePreview vueSlotLabel="Expandable Table" styleSlotLabel="html">
<CodePreviewLegacy vueSlotLabel="Expandable Table" styleSlotLabel="html">
<div slot="vue">
<KtTableLegacy :rows="rows" :columns="columnsDefault" isExpandable>
<div slot="expand" slot-scope="{ row, rowIndex }">
Expand All @@ -542,13 +542,13 @@ _Update_: Preferably, since the above syntax is now deprecated, use [v-slot](htt
```

</div>
</CodePreview>
</CodePreviewLegacy>

The default behavior only allows you to expand one row at a time; expanding one row would trigger any currently-expanded rows to shrink back.

If you want to allow for the expansion of multiple rows at a time, set the `expandMultiple` flag on `<KtTableLegacy />`, as well.

<CodePreview vueSlotLabel="Expandable Table" styleSlotLabel="html">
<CodePreviewLegacy vueSlotLabel="Expandable Table" styleSlotLabel="html">
<div slot="vue">
<KtTableLegacy :rows="rows" :columns="columnsDefault" isExpandable expandMultiple>
<div slot="expand" slot-scope="{ row, rowIndex }">
Expand All @@ -569,7 +569,7 @@ If you want to allow for the expansion of multiple rows at a time, set the `expa
```

</div>
</CodePreview>
</CodePreviewLegacy>

## Custom Render

Expand All @@ -590,7 +590,7 @@ It is possible to customize parts (columns) of the table by passing your own ren
- `renderHeader` &rarr; custom render fn, to render a custom element in the header of the column. Instead you can use, slot='header'
- `renderCell` &rarr; custom render fn, to render a custom element in the cells of the column. Instead use a default slot.

<CodePreview vueSlotLabel="Custom Render Table" styleSlotLabel="html">
<CodePreviewLegacy vueSlotLabel="Custom Render Table" styleSlotLabel="html">
<div slot="vue" >
<KtTableLegacy
:rows="rows"
Expand Down Expand Up @@ -632,7 +632,7 @@ It is possible to customize parts (columns) of the table by passing your own ren
```

</div>
</CodePreview>
</CodePreviewLegacy>

```jsx
{
Expand Down Expand Up @@ -680,7 +680,7 @@ It is possible to customize parts (columns) of the table by passing your own ren
}
```

<CodePreview vueSlotLabel="Custom Loading" styleSlotLabel="html">
<CodePreviewLegacy vueSlotLabel="Custom Loading" styleSlotLabel="html">
<div slot="vue">
<KtTableLegacy
:rows="rows"
Expand Down Expand Up @@ -708,9 +708,9 @@ It is possible to customize parts (columns) of the table by passing your own ren
```

</div>
</CodePreview>
</CodePreviewLegacy>

<CodePreview vueSlotLabel="Empty Table" styleSlotLabel="html">
<CodePreviewLegacy vueSlotLabel="Empty Table" styleSlotLabel="html">
<div slot="vue">
<KtTableLegacy
:rows="[]"
Expand All @@ -737,7 +737,7 @@ It is possible to customize parts (columns) of the table by passing your own ren
```

</div>
</CodePreview>
</CodePreviewLegacy>

```js
renderLoading() {
Expand All @@ -750,7 +750,7 @@ renderEmpty() {

You can also use slots instead of render props. [`slot="loading"`, `slot="empty"`, `slot="header"`, `slot="default"`].

<CodePreview vueSlotLabel="Loading Slot" styleSlotLabel="html">
<CodePreviewLegacy vueSlotLabel="Loading Slot" styleSlotLabel="html">
<div slot="vue">
<KtTableLegacy :rows="rows" :columns="columnsDefault" loading>
<div slot="loading">
Expand All @@ -768,9 +768,9 @@ You can also use slots instead of render props. [`slot="loading"`, `slot="empty"
```

</div>
</CodePreview>
</CodePreviewLegacy>

<CodePreview vueSlotLabel="Empty Slot" styleSlotLabel="html">
<CodePreviewLegacy vueSlotLabel="Empty Slot" styleSlotLabel="html">
<div slot="vue">
<KtTableLegacy :rows="emptyRows" :columns="columnsDefault">
<div slot="empty">
Expand All @@ -791,9 +791,9 @@ You can also use slots instead of render props. [`slot="loading"`, `slot="empty"
```

</div>
</CodePreview>
</CodePreviewLegacy>

<CodePreview vueSlotLabel="header/default slots" styleSlotLabel="html">
<CodePreviewLegacy vueSlotLabel="header/default slots" styleSlotLabel="html">
<div slot="vue">
<KtTableLegacy :rows="rows">
<KtTableLegacyColumn
Expand Down Expand Up @@ -839,7 +839,7 @@ You can also use slots instead of render props. [`slot="loading"`, `slot="empty"
```

</div>
</CodePreview>
</CodePreviewLegacy>

### Provider/Consumer and Mixin

Expand All @@ -862,7 +862,7 @@ _Notes_:

> There’s also the _deprecated_ `KtTableColumnsStateMixin`.

<CodePreview vueSlotLabel="Consumer/Provider Table" styleSlotLabel="html">
<CodePreviewLegacy vueSlotLabel="Consumer/Provider Table" styleSlotLabel="html">
<div slot="vue">
<KtTableLegacyProvider>
<div>
Expand Down Expand Up @@ -949,7 +949,7 @@ _Notes_:
```

</div>
</CodePreview>
</CodePreviewLegacy>

```js
{
Expand Down Expand Up @@ -1112,7 +1112,7 @@ import {
} from '@3yourmind/kotti-ui'
import { Kotti } from '@3yourmind/kotti-ui'
import CodePreview from '~/components/CodePreview.vue'
import CodePreviewLegacy from '~/components/CodePreviewLegacy.vue'
import ComponentInfo from '~/components/ComponentInfo.vue'
import { info } from '~/utilities/toaster'
Expand Down Expand Up @@ -1145,7 +1145,7 @@ const rows = [
export default {
name: 'DocumentationPageUsageComponentsTable',
components: {
CodePreview,
CodePreviewLegacy,
ComponentInfo,
KtAvatar,
KtBanner,
Expand Down
Loading

0 comments on commit e554f4c

Please sign in to comment.