可安装到任意 UI 库
安装:
$ npm i log-visual-comp
使用示例:
import App from 'log-visual-comp';
// 实例化和默认配置
// 当日志渲染后可到上方操作区修改配置,并且该配置将保留到下一批数据,除非重新实例化
const app = new App('log-visual-app', {
useTimestamp: true, // 显示时间戳
useWrapLines: true, // 当容器宽度小于日志宽度时日志会自动换行显示
useContext: true, // 打开查看每条日志上下文的按钮
search: '2052475', // 实例化时高亮搜索结果
maxHeight: 600, // 当日志列表容器高度超过 600 时出现滚动条
});
// 传入 Logs 数据
// 如果 Logs 数据更新再次调用本方法
app.setState({
logs,
stream,
})
// 并且也支持多个输入源的数组,logs 将被合并并且正序排序
app.setState(
[
{
logs,
stream,
},
{
logs,
stream,
},
{
logs,
stream,
},
]
)
// 在回调事件中添加 loading 效果
app.setLoading(true);
http.req(data => {
app.setState(data);
app.setLoading(false);
})
// 监听筛选事件
app.onFilter(function (pubs) {
console.info(pubs);
// 通常筛选结束后会再次请求数据并重新 setState()
});
// 注册上下文渲染回调
// 需要实例化时打开 useContext: true
// log 和 stream 分别来自传入的 log 对象和 stream 对象
app.regRenderContext(function (render, { log, stream }) {
// 模拟请求上下文
app.setLoading(true);
setTimeout(() => {
// prevs 和 nexts 分别是二维数组类型的 log: [Timestamp, Text]
render(mockContextData.prevs, mockContextData.nexts);
app.setLoading(false);
}, 2000);
});
// #20210407新增:上下文弹窗中点击加载更多日志
app.regRenderMoreContext(function (render) {
app.setLoading(true);
// 模拟请求上下文
setTimeout(() => {
// 以下仅是一个示例
// 通过修改当前上下文日志列表(直接添加到原来的上下文日志列表)并传入执行 render 函数
render([...mockContextData.prevs, ...mockContextData.nexts], mockContextData.nexts);
app.setLoading(false);
}, 1000);
});
// 搜索并高亮结果
app.search('some str');
启动开发服务:
# 安装
$ npm i
# 启动开发服务
$ npm start
编译到静态文件:
$ npm run build
发布到 NPM 仓库:
# 需事先在本地配置 NPM 帐户
$ npm run publish