fleet/frontend/components/side_panels/QuerySidePanel/QuerySidePanel.tsx
Martavis Parker b6659cfaaa
Refactored Manage Hosts (#2233)
* Add new feature: team policies

* Continue work on team policies

* Continue work on team policies

* Continue team policies

* Revert accidental deletion

* Rename variables

* code refactored; working on runtime errors

* updated front end docs

* Update URLs from team to teams, add tests for policy auth

* Fix test

* Continue work on team policies

* Add permission checks

* mange hosts functional and cleaned up; typing

* improved label logic

* added try catch to awaits

* lint fixes

* frontend unit tests don't work for functional components

* test fix

* revert

* Address errors related to refetch on window focus

* Add loading error check

* Fix typos in loading error checks

* Guard against invariant condition in useEffect

* Update links and routes for team policies

* lint fixes

* Update frontend/pages/hosts/ManageHostsPage/helpers.ts

Co-authored-by: gillespi314 <73313222+gillespi314@users.noreply.github.com>

* Change inherited policies button, tooltip

* lint fixes

Co-authored-by: gillespi314 <73313222+gillespi314@users.noreply.github.com>
Co-authored-by: Tomas Touceda <chiiph@gmail.com>
2021-09-30 12:32:06 -07:00

158 lines
4.8 KiB
TypeScript

import React from "react";
import classnames from "classnames";
import IconToolTip from "components/IconToolTip";
import { IOsqueryTable } from "interfaces/osquery_table"; // @ts-ignore
import { osqueryTableNames } from "utilities/osquery_tables"; // @ts-ignore
import Dropdown from "components/forms/fields/Dropdown"; // @ts-ignore
import FleetIcon from "components/icons/FleetIcon"; // @ts-ignore
import SecondarySidePanelContainer from "../SecondarySidePanelContainer";
import AppleIcon from "../../../../assets/images/icon-apple-dark-20x20@2x.png";
import LinuxIcon from "../../../../assets/images/icon-linux-dark-20x20@2x.png";
import WindowsIcon from "../../../../assets/images/icon-windows-dark-20x20@2x.png";
import CloseIcon from "../../../../assets/images/icon-close-black-50-8x8@2x.png";
interface IQuerySidePanel {
selectedOsqueryTable: IOsqueryTable;
onOsqueryTableSelect: (tableName: string) => void;
onClose?: () => void;
}
const baseClass = "query-side-panel";
const QuerySidePanel = ({
selectedOsqueryTable,
onOsqueryTableSelect,
onClose,
}: IQuerySidePanel) => {
const displayTypeForDataType = (dataType: string) => {
switch (dataType) {
case "TEXT_TYPE":
return "text";
case "BIGINT_TYPE":
return "big int";
case "INTEGER_TYPE":
return "integer";
default:
return dataType;
}
};
const onSelectTable = (value: string) => {
onOsqueryTableSelect(value);
};
const renderColumns = () => {
const columns = selectedOsqueryTable?.columns;
const columnBaseClass = "query-column-list";
return columns?.map((column) => (
<li key={column.name} className={`${columnBaseClass}__item`}>
<span className={`${columnBaseClass}__name`}>{column.name}</span>
<IconToolTip text={column.description} />
<div className={`${columnBaseClass}__description`}>
<span className={`${columnBaseClass}__type`}>
{displayTypeForDataType(column.type)}
</span>
</div>
</li>
));
};
const renderTableSelect = () => {
const tableNames = osqueryTableNames?.map((name: string) => {
return { label: name, value: name };
});
if (!tableNames) {
return null;
}
return (
<Dropdown
options={tableNames}
value={selectedOsqueryTable?.name}
onChange={onSelectTable}
placeholder="Choose Table..."
/>
);
};
const { description, platforms } = selectedOsqueryTable || {};
const iconClasses = classnames([`${baseClass}__icon`], "icon");
return (
<SecondarySidePanelContainer className={baseClass}>
<div
role="button"
className={`${baseClass}__close-button`}
tabIndex={0}
onClick={onClose}
>
<img alt="Close sidebar" src={CloseIcon} />
</div>
<div className={`${baseClass}__choose-table`}>
<h2 className={`${baseClass}__header`}>Tables</h2>
{renderTableSelect()}
<p className={`${baseClass}__description`}>{description}</p>
</div>
<div className={`${baseClass}__os-availability`}>
<h2 className={`${baseClass}__header`}>OS Availability</h2>
<ul className={`${baseClass}__platforms`}>
{platforms?.map((platform) => {
if (platform === "all") {
return (
<li key={platform}>
<FleetIcon name="hosts" /> {platform}
</li>
);
} else if (platform === "freebsd") {
return (
<li key={platform}>
<FleetIcon name="single-host" /> {platform}
</li>
);
}
platform = platform.toLowerCase();
let icon = (
<img
src={AppleIcon}
alt={`${platform} icon`}
className={iconClasses}
/>
);
if (platform === "linux") {
icon = (
<img
src={LinuxIcon}
alt={`${platform} icon`}
className={iconClasses}
/>
);
} else if (platform === "windows") {
icon = (
<img
src={WindowsIcon}
alt={`${platform} icon`}
className={iconClasses}
/>
);
}
return (
<li key={platform}>
{icon} {platform}
</li>
);
})}
</ul>
</div>
<div className={`${baseClass}__columns`}>
<h2 className={`${baseClass}__header`}>Columns</h2>
<ul className={`${baseClass}__column-list`}>{renderColumns()}</ul>
</div>
</SecondarySidePanelContainer>
);
};
export default QuerySidePanel;