mirror of
https://github.com/fleetdm/fleet
synced 2026-05-17 05:58:40 +00:00
Issues https://github.com/fleetdm/fleet/issues/17587, https://github.com/fleetdm/fleet/issues/18836, https://github.com/fleetdm/fleet/issues/18837, https://github.com/fleetdm/fleet/pull/18339, and https://github.com/fleetdm/fleet/pull/18340 # TODOS - Integrate backend - Unit/integration tests - Various todos noted in comments - Cleanup styles and organization of components (de-duplicating and consolidating where possible) - Activity feed updates (if any) # Checklist for submitter If some of the following don't apply, delete the relevant line. <!-- Note that API documentation changes are now addressed by the product design team. --> - [ ] Changes file added for user-visible changes in `changes/`, `orbit/changes/` or `ee/fleetd-chrome/changes`. See [Changes files](https://fleetdm.com/docs/contributing/committing-changes#changes-files) for more information. - [ ] Input data is properly validated, `SELECT *` is avoided, SQL injection is prevented (using placeholders for values in statements) - [ ] Added support on fleet's osquery simulator `cmd/osquery-perf` for new osquery data ingestion features. - [ ] Added/updated tests - [ ] If database migrations are included, checked table schema to confirm autoupdate - For database migrations: - [ ] Checked schema for all modified table for columns that will auto-update timestamps during migration. - [ ] Confirmed that updating the timestamps is acceptable, and will not cause unwanted side effects. - [ ] Ensured the correct collation is explicitly set for character columns (`COLLATE utf8mb4_unicode_ci`). - [ ] Manual QA for all new/changed functionality - For Orbit and Fleet Desktop changes: - [ ] Manual QA must be performed in the three main OSs, macOS, Windows and Linux. - [ ] Auto-update manual QA, from released version of component to new version (see [tools/tuf/test](../tools/tuf/test/README.md)). --------- Co-authored-by: Gabriel Hernandez <ghernandez345@gmail.com>
88 lines
2.4 KiB
TypeScript
88 lines
2.4 KiB
TypeScript
import classnames from "classnames";
|
|
import React from "react";
|
|
import { Tooltip as ReactTooltip5, PlacesType } from "react-tooltip-5";
|
|
|
|
import { uniqueId } from "lodash";
|
|
|
|
interface ITooltipWrapper {
|
|
children: React.ReactNode;
|
|
// default is bottom-start
|
|
position?: PlacesType;
|
|
isDelayed?: boolean;
|
|
underline?: boolean;
|
|
// Below two props used here to maintain the API of the old TooltipWrapper
|
|
// A clearer system would be to use the 3 below commented props, which describe exactly where they
|
|
// will apply, `element` being the element this tooltip will wrap. Associated logic is commented
|
|
// out, but ready to be used.
|
|
className?: string;
|
|
tooltipClass?: string;
|
|
// wrapperCustomClass?: string;
|
|
// elementCustomClass?: string;
|
|
// tipCustomClass?: string;
|
|
clickable?: boolean;
|
|
tipContent: React.ReactNode;
|
|
/** If set to `true`, will not show the tooltip. This can be used to dynamically
|
|
* disable the tooltip from the parent component.
|
|
*
|
|
* @default false
|
|
*/
|
|
disableTooltip?: boolean;
|
|
}
|
|
|
|
const baseClass = "component__tooltip-wrapper";
|
|
|
|
const TooltipWrapper = ({
|
|
// wrapperCustomClass,
|
|
// elementCustomClass,
|
|
// tipCustomClass,
|
|
children,
|
|
tipContent,
|
|
position = "bottom-start",
|
|
isDelayed,
|
|
underline = true,
|
|
className,
|
|
tooltipClass,
|
|
clickable = true,
|
|
disableTooltip = false,
|
|
}: ITooltipWrapper) => {
|
|
const wrapperClassNames = classnames(baseClass, className, {
|
|
// [`${baseClass}__${wrapperCustomClass}`]: !!wrapperCustomClass,
|
|
});
|
|
|
|
const elementClassNames = classnames(`${baseClass}__element`, {
|
|
// [`${baseClass}__${elementCustomClass}`]: !!elementCustomClass,
|
|
[`${baseClass}__underline`]: underline,
|
|
});
|
|
|
|
const tipClassNames = classnames(`${baseClass}__tip-text`, tooltipClass, {
|
|
// [`${baseClass}__${tipCustomClass}`]: !!tipCustomClass,
|
|
});
|
|
|
|
const tipId = uniqueId();
|
|
|
|
return (
|
|
<span className={wrapperClassNames}>
|
|
<div className={elementClassNames} data-tooltip-id={tipId}>
|
|
{children}
|
|
</div>
|
|
{!disableTooltip && (
|
|
<ReactTooltip5
|
|
className={tipClassNames}
|
|
id={tipId}
|
|
delayShow={isDelayed ? 500 : undefined}
|
|
delayHide={isDelayed ? 500 : undefined}
|
|
noArrow
|
|
place={position}
|
|
opacity={1}
|
|
disableStyleInjection
|
|
clickable={clickable}
|
|
offset={5}
|
|
>
|
|
{tipContent}
|
|
</ReactTooltip5>
|
|
)}
|
|
</span>
|
|
);
|
|
};
|
|
|
|
export default TooltipWrapper;
|