0
owncast/web/pages/components/log-table.tsx

79 lines
1.6 KiB
TypeScript
Raw Normal View History

2020-10-29 18:01:38 -07:00
import React from "react";
import { timeFormat } from "d3-time-format";
import { Table, } from "antd";
import Linkify from "react-linkify";
export default function LogTable({ logs, pageSize }) {
const columns = [
{
title: "Level",
dataIndex: "level",
key: "level",
filters: [
{
text: "Info",
value: "info",
},
{
text: "Warning",
value: "warning",
},
{
text: "Error",
value: "Error",
},
],
onFilter: (level, row) => row.level.indexOf(level) === 0,
render: renderColumnLevel,
},
{
title: "Timestamp",
dataIndex: "time",
key: "time",
render: (timestamp) =>
timeFormat("%H:%M:%S %m/%d/%Y")(new Date(timestamp)),
sorter: (a, b) => new Date(a.time).getTime() - new Date(b.time).getTime(),
sortDirections: ["descend", "ascend"],
defaultSortOrder: "descend",
},
{
title: "Message",
dataIndex: "message",
key: "message",
render: renderMessage,
},
];
return (
<div>
<Table
dataSource={logs}
columns={columns}
rowKey={(row) => row.time}
pagination={{ pageSize: pageSize || 20 }}
/>
;
</div>
);
}
function renderColumnLevel(text, entry) {
let color = 'black';
if (entry.level === "warning") {
color = "orange";
} else if (entry.level === 'error') {
color = "red";
}
const style = {
color,
};
return <div style={style}>{text}</div>;
}
function renderMessage(text, entry) {
return (
<Linkify>{text}</Linkify>
)
}