mirror of
https://github.com/fleetdm/fleet
synced 2026-05-24 09:28:54 +00:00
## Front end for #19551 Feature branch merge to `main` – all work as been previously approved in individual PRs to the feature branch. - [x] Changes file added for user-visible changes in `changes/` - [x] Added/updated tests - [x] Manual QA for all new/changed functionality --------- Co-authored-by: Jacob Shandling <jacob@fleetdm.com>
91 lines
2.7 KiB
TypeScript
91 lines
2.7 KiB
TypeScript
import React from "react";
|
|
|
|
import Modal from "components/Modal";
|
|
import Button from "components/buttons/Button";
|
|
import FleetAce from "components/FleetAce";
|
|
import CustomLink from "components/CustomLink";
|
|
import Editor from "components/Editor";
|
|
|
|
const baseClass = "advanced-options-modal";
|
|
|
|
interface IAdvancedOptionsModalProps {
|
|
installScript: string;
|
|
preInstallQuery?: string;
|
|
postInstallScript?: string;
|
|
onExit: () => void;
|
|
}
|
|
|
|
const AdvancedOptionsModal = ({
|
|
installScript,
|
|
preInstallQuery,
|
|
postInstallScript,
|
|
onExit,
|
|
}: IAdvancedOptionsModalProps) => {
|
|
return (
|
|
<Modal className={baseClass} title="Advanced options" onExit={onExit}>
|
|
<>
|
|
<p>
|
|
Advanced options are read-only. To change options, delete software and
|
|
add again.
|
|
</p>
|
|
<div className={`${baseClass}__form-inputs`}>
|
|
<Editor
|
|
readOnly
|
|
wrapEnabled
|
|
maxLines={10}
|
|
name="install-script"
|
|
value={installScript}
|
|
helpText="Fleet will run this command on hosts to install software."
|
|
label="Install script"
|
|
labelTooltip="For security agents, add the script provided by the vendor."
|
|
isFormField
|
|
/>
|
|
{preInstallQuery && (
|
|
<div className={`${baseClass}__input-field`}>
|
|
<span>Pre-install condition:</span>
|
|
<FleetAce
|
|
readOnly
|
|
value={preInstallQuery}
|
|
label="Query"
|
|
name="preInstallQuery"
|
|
maxLines={10}
|
|
helpText={
|
|
<>
|
|
Software will be installed only if the{" "}
|
|
<CustomLink
|
|
className={`${baseClass}__table-link`}
|
|
text="query returns results"
|
|
url="https://fleetdm.com/tables"
|
|
newTab
|
|
/>
|
|
</>
|
|
}
|
|
/>
|
|
</div>
|
|
)}
|
|
{postInstallScript && (
|
|
<div className={`${baseClass}__input-field`}>
|
|
<span>Post-install script:</span>
|
|
<Editor
|
|
readOnly
|
|
wrapEnabled
|
|
name="post-install-script-editor"
|
|
maxLines={10}
|
|
value={postInstallScript}
|
|
helpText="Shell (macOS and Linux) or PowerShell (Windows)."
|
|
isFormField
|
|
/>
|
|
</div>
|
|
)}
|
|
</div>
|
|
<div className="modal-cta-wrap">
|
|
<Button variant="brand" onClick={onExit}>
|
|
Done
|
|
</Button>
|
|
</div>
|
|
</>
|
|
</Modal>
|
|
);
|
|
};
|
|
|
|
export default AdvancedOptionsModal;
|