From c1bc80c0b7f851f14f40f9b087b37af6c2be83f8 Mon Sep 17 00:00:00 2001 From: Robert Jaros Date: Mon, 25 Nov 2019 15:55:07 +0100 Subject: Support column groups in the Tabulator componenet (#111) --- .../src/main/kotlin/pl/treksoft/kvision/tabulator/Options.kt | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'kvision-modules/kvision-tabulator/src/main/kotlin') diff --git a/kvision-modules/kvision-tabulator/src/main/kotlin/pl/treksoft/kvision/tabulator/Options.kt b/kvision-modules/kvision-tabulator/src/main/kotlin/pl/treksoft/kvision/tabulator/Options.kt index 27911e52..66337568 100644 --- a/kvision-modules/kvision-tabulator/src/main/kotlin/pl/treksoft/kvision/tabulator/Options.kt +++ b/kvision-modules/kvision-tabulator/src/main/kotlin/pl/treksoft/kvision/tabulator/Options.kt @@ -261,6 +261,7 @@ fun DownloadConfig.toJs(): Tabulator.DownloadConfig { data class ColumnDefinition( val title: String, val field: String? = null, + val columns: List>? = null, val visible: Boolean? = null, val align: Align? = null, val width: String? = null, @@ -429,6 +430,7 @@ fun ColumnDefinition.toJs( return obj { this.title = i18nTranslator(title) if (field != null) this.field = field + if (columns != null) this.columns = columns.map { it.toJs(i18nTranslator) }.toTypedArray() if (visible != null) this.visible = visible if (align != null) this.align = align.align if (width != null) this.width = width @@ -708,7 +710,8 @@ data class TabulatorOptions( fun TabulatorOptions.toJs( i18nTranslator: (String) -> (String) ): Tabulator.Options { - val tmpCellEditCancelled = this.columns?.find { it.editorComponentFunction != null }?.let { + val allColumns = this.columns?.let { c -> c + c.mapNotNull { it.columns }.flatten() } + val tmpCellEditCancelled = allColumns?.find { it.editorComponentFunction != null }?.let { { cell: Tabulator.CellComponent -> cellEditCancelled?.invoke(cell) cell.getTable().redraw(true) -- cgit