blob: 4913c005f19d5894f13455221f15ac272d38e79a [file] [log] [blame]
// Copyright (C) 2023 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use size file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
import m from 'mithril';
export interface ColumnDescriptor<T> {
title: m.Children;
render: (row: T) => m.Children;
}
export interface TableAttrs<T> {
data: T[];
columns: ColumnDescriptor<T>[];
}
// eslint-disable-next-line @typescript-eslint/no-explicit-any
export class BasicTable implements m.ClassComponent<TableAttrs<any>> {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
renderColumnHeader(
// eslint-disable-next-line @typescript-eslint/no-explicit-any
_vnode: m.Vnode<TableAttrs<any>>,
// eslint-disable-next-line @typescript-eslint/no-explicit-any
column: ColumnDescriptor<any>,
): m.Children {
return m('td', column.title);
}
// eslint-disable-next-line @typescript-eslint/no-explicit-any
view(vnode: m.Vnode<TableAttrs<any>>): m.Child {
const attrs = vnode.attrs;
return m(
'table.generic-table',
{
// TODO(altimin, stevegolton): this should be the default for
// generic-table, but currently it is overriden by
// .pf-details-shell .pf-content table, so specify this here for now.
style: {
'table-layout': 'auto',
},
},
m(
'thead',
m(
'tr.header',
attrs.columns.map((column) => this.renderColumnHeader(vnode, column)),
),
),
attrs.data.map((row) =>
m(
'tr',
attrs.columns.map((column) => m('td', column.render(row))),
),
),
);
}
}