mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
- Move all strings of the form {`...`} to use just ""
- Fix RoleBindingDetails not rendering the name of the role binding
Signed-off-by: Sebastian Malton <sebastian@malton.name>
84 lines
2.0 KiB
TypeScript
84 lines
2.0 KiB
TypeScript
import "./log-search.scss";
|
|
|
|
import React, { useEffect } from "react";
|
|
import { observer } from "mobx-react";
|
|
import { SearchInput } from "../input";
|
|
import { searchStore } from "../../../common/search-store";
|
|
import { Icon } from "../icon";
|
|
|
|
export interface PodLogSearchProps {
|
|
onSearch: (query: string) => void
|
|
toPrevOverlay: () => void
|
|
toNextOverlay: () => void
|
|
}
|
|
|
|
interface Props extends PodLogSearchProps {
|
|
logs: string[]
|
|
}
|
|
|
|
export const LogSearch = observer((props: Props) => {
|
|
const { logs, onSearch, toPrevOverlay, toNextOverlay } = props;
|
|
const { setNextOverlayActive, setPrevOverlayActive, searchQuery, occurrences, activeFind, totalFinds } = searchStore;
|
|
const jumpDisabled = !searchQuery || !occurrences.length;
|
|
const findCounts = (
|
|
<div className="find-count">
|
|
{activeFind}/{totalFinds}
|
|
</div>
|
|
);
|
|
|
|
const setSearch = (query: string) => {
|
|
searchStore.onSearch(logs, query);
|
|
onSearch(query);
|
|
};
|
|
|
|
const onPrevOverlay = () => {
|
|
setPrevOverlayActive();
|
|
toPrevOverlay();
|
|
};
|
|
|
|
const onNextOverlay = () => {
|
|
setNextOverlayActive();
|
|
toNextOverlay();
|
|
};
|
|
|
|
const onClear = () => {
|
|
setSearch("");
|
|
};
|
|
|
|
const onKeyDown = (evt: React.KeyboardEvent<any>) => {
|
|
if (evt.key === "Enter") {
|
|
onNextOverlay();
|
|
}
|
|
};
|
|
|
|
useEffect(() => {
|
|
// Refresh search when logs changed
|
|
searchStore.onSearch(logs);
|
|
}, [logs]);
|
|
|
|
return (
|
|
<div className="LogSearch flex box grow justify-flex-end gaps align-center">
|
|
<SearchInput
|
|
value={searchQuery}
|
|
onChange={setSearch}
|
|
showClearIcon={true}
|
|
contentRight={totalFinds > 0 && findCounts}
|
|
onClear={onClear}
|
|
onKeyDown={onKeyDown}
|
|
/>
|
|
<Icon
|
|
material="keyboard_arrow_up"
|
|
tooltip="Previous"
|
|
onClick={onPrevOverlay}
|
|
disabled={jumpDisabled}
|
|
/>
|
|
<Icon
|
|
material="keyboard_arrow_down"
|
|
tooltip="Next"
|
|
onClick={onNextOverlay}
|
|
disabled={jumpDisabled}
|
|
/>
|
|
</div>
|
|
);
|
|
});
|