@hawtio/react
Version:
A Hawtio reimplementation based on TypeScript + React.
902 lines (806 loc) • 50.5 kB
JavaScript
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
var _chunkOJIIWKORjs = require('./chunk-OJIIWKOR.js');
var _chunkHS42NURZjs = require('./chunk-HS42NURZ.js');
require('./chunk-BLJGIIMV.js');
require('./chunk-WYFZRJ4C.js');
var _chunkBJ6TSPQKjs = require('./chunk-BJ6TSPQK.js');
var _chunkBHIEXRGKjs = require('./chunk-BHIEXRGK.js');
// src/plugins/quartz/Quartz.tsx
var _reactcore = require('@patternfly/react-core');
var _reactsplit = require('react-split'); var _reactsplit2 = _interopRequireDefault(_reactsplit);
// src/plugins/quartz/QuartzContent.tsx
var _cubesicon = require('@patternfly/react-icons/dist/esm/icons/cubes-icon');
var _react = require('react'); var _react2 = _interopRequireDefault(_react);
var _reactrouterdom = require('react-router-dom');
// src/plugins/quartz/context.ts
// src/plugins/quartz/icons/quartz.png
var quartz_default = "";
// src/plugins/quartz/icons/index.tsx
var _jsxruntime = require('react/jsx-runtime');
var QuartzIcon = /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "img", { src: quartz_default, alt: "quartz" });
// src/plugins/quartz/context.ts
function useQuartz() {
const [tree, setTree] = _react.useState.call(void 0, _chunkBJ6TSPQKjs.MBeanTree.createEmpty(_chunkHS42NURZjs.pluginName3));
const { selectedNode, setSelectedNode } = _react.useContext.call(void 0, _chunkBJ6TSPQKjs.PluginNodeSelectionContext);
const [loaded, setLoaded] = _react.useState.call(void 0, false);
const selectedNodeRef = _react.useRef.call(void 0, selectedNode);
const populateTree = async () => {
_chunkHS42NURZjs.log3.debug("Populate Quartz tree");
const schedulers = (await _chunkHS42NURZjs.quartzService.searchSchedulers()).map((node) => {
const scheduler = node.copyTo(_nullishCoalesce(node.getProperty("name"), () => ( node.name)));
scheduler.icon = QuartzIcon;
return scheduler;
});
_chunkHS42NURZjs.log3.debug("Found schedulers:", schedulers);
const newTree = _chunkBJ6TSPQKjs.MBeanTree.createFromNodes(_chunkHS42NURZjs.pluginName3, schedulers);
setTree(newTree);
if (!selectedNodeRef.current) {
selectedNodeRef.current = _nullishCoalesce(schedulers[0], () => ( null));
}
let newSelected = null;
newTree.forEach(_nullishCoalesce(_optionalChain([selectedNodeRef, 'access', _ => _.current, 'optionalAccess', _2 => _2.path, 'call', _3 => _3()]), () => ( [])), (node) => {
node.defaultExpanded = true;
newSelected = node;
});
setSelectedNode(newSelected);
};
_react.useEffect.call(void 0, () => {
const loadTree = async () => {
await populateTree();
setLoaded(true);
};
const listener = () => {
setLoaded(false);
loadTree();
};
_chunkBHIEXRGKjs.eventService.onRefresh(listener);
loadTree();
return () => _chunkBHIEXRGKjs.eventService.removeListener(_chunkBHIEXRGKjs.EVENT_REFRESH, listener);
}, []);
return { tree, loaded, selectedNode, setSelectedNode };
}
var QuartzContext = _react.createContext.call(void 0, {
tree: _chunkBJ6TSPQKjs.MBeanTree.createEmpty(_chunkHS42NURZjs.pluginName3),
selectedNode: null,
setSelectedNode: () => {
}
});
// src/plugins/quartz/jobs/Jobs.tsx
var _deprecated = require('@patternfly/react-core/deprecated');
var _reacttable = require('@patternfly/react-table');
var Jobs = () => {
const { selectedNode } = _react.useContext.call(void 0, QuartzContext);
const [jobs, setJobs] = _react.useState.call(void 0, []);
const [isReading, setIsReading] = _react.useState.call(void 0, true);
const [isDetailOpen, setIsDetailOpen] = _react.useState.call(void 0, false);
const [selectedJob, setSelectedJob] = _react.useState.call(void 0, null);
_react.useEffect.call(void 0, () => {
if (!selectedNode || !selectedNode.mbean || !selectedNode.objectName) {
return;
}
setIsReading(true);
const { objectName } = selectedNode;
const loadJobs = async () => {
const jobs2 = await _chunkHS42NURZjs.quartzService.loadJobs(objectName);
setJobs(jobs2);
setIsReading(false);
};
loadJobs();
_chunkHS42NURZjs.quartzService.registerJobsLoad(objectName, (jobs2) => {
setJobs(jobs2);
});
return () => _chunkHS42NURZjs.quartzService.unregisterAll();
}, [selectedNode]);
if (!selectedNode || !selectedNode.mbean || !selectedNode.objectName) {
return null;
}
if (isReading) {
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkBJ6TSPQKjs.HawtioLoadingCard, {});
}
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _react2.default.Fragment, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_chunkOJIIWKORjs.FilteredTable,
{
classPrefix: "quartz-jobs",
rows: jobs,
highlightSearch: true,
tableColumns: [
{
name: "Group",
key: "group",
percentageWidth: 20
},
{
name: "Name",
key: "name",
percentageWidth: 10
},
{
name: "Durable",
key: "durability",
percentageWidth: 10
},
{
name: "Recover",
key: "shouldRecover",
percentageWidth: 10
},
{
name: "Job Class Name",
key: "jobClass",
percentageWidth: 20
},
{
name: "Description",
key: "description",
percentageWidth: 20,
hideValues: ["null"]
}
],
fixedSearchCategories: [
{
name: "Durable",
key: "durability",
values: ["true", "false"]
},
{
name: "Recover",
key: "shouldRecover",
values: ["true", "false"]
}
],
searchCategories: [
{
name: "Group",
key: "group"
},
{
name: "Name",
key: "name"
},
{
name: "Job Class",
key: "jobClass"
},
{
name: "Description",
key: "description"
}
],
onClick: (row) => {
setSelectedJob(row);
setIsDetailOpen(true);
}
}
),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
JobDetailModal,
{
isOpen: isDetailOpen,
onClose: () => {
setIsDetailOpen(false);
setSelectedJob(null);
},
input: selectedJob
}
)
] });
};
var JobDetailModal = ({ isOpen, onClose, input }) => {
if (!input) {
return null;
}
const { group, name, jobDataMap } = input;
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_deprecated.Modal,
{
id: "quartz-jobs-detail-modal",
variant: "medium",
title: `Job Detail: ${group}/${name}`,
isOpen,
onClose,
actions: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Button, { variant: "primary", onClick: onClose, children: "Close" }, "close")
],
children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reacttable.Table, { id: "quartz-jobs-detail-table", variant: "compact", "aria-label": "Job Detail Table", isStriped: true, children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reacttable.Thead, { children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reacttable.Tr, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reacttable.Th, { children: "Key" }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reacttable.Th, { children: "Value" })
] }) }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reacttable.Tbody, { children: Object.entries(jobDataMap).map(([key, value], index) => /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reacttable.Tr, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reacttable.Td, { children: key }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reacttable.Td, { children: value })
] }, index)) })
] })
}
);
};
// src/plugins/quartz/scheduler/Scheduler.tsx
var _checkcircleicon = require('@patternfly/react-icons/dist/esm/icons/check-circle-icon');
var _pausecircleicon = require('@patternfly/react-icons/dist/esm/icons/pause-circle-icon');
var _jolokiajs = require('jolokia.js'); var _jolokiajs2 = _interopRequireDefault(_jolokiajs);
var Scheduler = () => {
const { selectedNode } = _react.useContext.call(void 0, QuartzContext);
const [attributes, setAttributes] = _react.useState.call(void 0, {});
const [isReading, setIsReading] = _react.useState.call(void 0, true);
const [reload, setReload] = _react.useState.call(void 0, false);
_react.useEffect.call(void 0, () => {
if (!selectedNode || !selectedNode.objectName) {
return;
}
setIsReading(true);
const { objectName: objectName2 } = selectedNode;
_chunkBJ6TSPQKjs.attributeService.readWithCallback(objectName2, (attrs) => {
setAttributes(attrs);
setIsReading(false);
});
_chunkBJ6TSPQKjs.attributeService.register({ type: "read", mbean: objectName2 }, (response) => {
if (_jolokiajs2.default.isResponseFetchError(response)) {
_chunkHS42NURZjs.log3.warn("Scheduler - Attributes (fetch error):", response);
return;
}
if (_jolokiajs2.default.isError(response)) {
_chunkHS42NURZjs.log3.warn("Scheduler - Attributes (Jolokia error):", response.error);
return;
}
_chunkHS42NURZjs.log3.debug("Scheduler - Attributes:", response.value);
setAttributes(response.value);
});
return () => _chunkBJ6TSPQKjs.attributeService.unregisterAll();
}, [selectedNode]);
_react.useEffect.call(void 0, () => {
if (!selectedNode || !selectedNode.objectName || !reload) {
return;
}
_chunkHS42NURZjs.log3.debug("Reload scheduler attributes");
setIsReading(true);
const { objectName: objectName2 } = selectedNode;
_chunkBJ6TSPQKjs.attributeService.readWithCallback(objectName2, (attrs) => {
setAttributes(attrs);
setIsReading(false);
});
setReload(false);
}, [selectedNode, reload]);
if (!selectedNode || !selectedNode.objectName) {
return null;
}
if (isReading) {
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkBJ6TSPQKjs.HawtioLoadingCard, {});
}
const { name, objectName } = selectedNode;
const canStartPauseScheduler = () => {
return selectedNode.hasInvokeRights(_chunkHS42NURZjs.QUARTZ_OPERATIONS.start, _chunkHS42NURZjs.QUARTZ_OPERATIONS.standby);
};
const handleSchedulerSwitchChange = async (start) => {
await (start ? _chunkHS42NURZjs.quartzService.start(name, objectName) : _chunkHS42NURZjs.quartzService.pause(name, objectName));
setReload(true);
};
const canUpdateSampleStatisticsEnabled = () => {
return selectedNode.hasInvokeRights(_chunkHS42NURZjs.QUARTZ_OPERATIONS.start, _chunkHS42NURZjs.QUARTZ_OPERATIONS.standby);
};
const handleSampledStatisticsSwitchChange = async (value) => {
await _chunkHS42NURZjs.quartzService.updateSampleStatisticsEnabled(name, objectName, value);
setReload(true);
};
const scheduler = {
// scheduler
started: attributes["Started"],
name: attributes["SchedulerName"],
instance: attributes["SchedulerInstanceId"],
version: attributes["Version"],
jobStoreClassName: attributes["JobStoreClassName"],
threadPoolClassName: attributes["ThreadPoolClassName"],
threadPoolSize: attributes["ThreadPoolSize"],
// sampled statistics
sampledStatisticsEnabled: attributes["SampledStatisticsEnabled"],
jobsCompleted: attributes["JobsCompletedMostRecentSample"],
jobsExecuted: attributes["JobsExecutedMostRecentSample"],
jobsScheduled: attributes["JobsScheduledMostRecentSample"]
};
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.Stack, { id: "quartz-scheduler", hasGutter: true, children: [
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.Card, { id: "quartz-scheduler-main", isPlain: true, children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reactcore.CardHeader,
{
actions: {
actions: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reactcore.Switch,
{
id: "quartz-scheduler-main-switch",
label: "Started",
isChecked: scheduler.started,
isDisabled: !canStartPauseScheduler(),
onChange: (_event, start) => handleSchedulerSwitchChange(start),
isReversed: true
}
),
hasNoOffset: false
},
children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.CardTitle, { children: [
scheduler.started ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Icon, { status: "success", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _checkcircleicon.CheckCircleIcon, {}) }) : /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Icon, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _pausecircleicon.PauseCircleIcon, {}) }),
"Scheduler"
] })
}
),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.CardBody, { children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.DescriptionList, { isCompact: true, isHorizontal: true, children: [
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.DescriptionListGroup, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListTerm, { children: "Name" }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListDescription, { children: scheduler.name })
] }),
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.DescriptionListGroup, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListTerm, { children: "Instance" }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListDescription, { children: scheduler.instance })
] }),
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.DescriptionListGroup, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListTerm, { children: "Version" }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListDescription, { children: scheduler.version })
] }),
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.DescriptionListGroup, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListTerm, { children: "Job store class name" }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListDescription, { children: scheduler.jobStoreClassName })
] }),
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.DescriptionListGroup, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListTerm, { children: "Thread pool class name" }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListDescription, { children: scheduler.threadPoolClassName })
] }),
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.DescriptionListGroup, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListTerm, { children: "Thread pool size" }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListDescription, { children: scheduler.threadPoolSize })
] })
] }) })
] }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Divider, {}),
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.Card, { id: "quartz-scheduler-statistics", isPlain: true, children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reactcore.CardHeader,
{
actions: {
actions: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reactcore.Switch,
{
id: "quartz-scheduler-statistics-switch",
label: "Enabled",
isChecked: scheduler.sampledStatisticsEnabled,
isDisabled: !canUpdateSampleStatisticsEnabled(),
onChange: (_event, value) => handleSampledStatisticsSwitchChange(value),
isReversed: true
}
),
hasNoOffset: false,
className: void 0
},
children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.CardTitle, { children: [
scheduler.sampledStatisticsEnabled ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Icon, { status: "success", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _checkcircleicon.CheckCircleIcon, {}) }) : /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Icon, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _pausecircleicon.PauseCircleIcon, {}) }),
"Sampled Statistics (Most Recent Samples)"
] })
}
),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.CardBody, { children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.DescriptionList, { isCompact: true, isHorizontal: true, children: [
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.DescriptionListGroup, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListTerm, { children: "Jobs completed" }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListDescription, { children: scheduler.jobsCompleted })
] }),
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.DescriptionListGroup, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListTerm, { children: "Jobs executed" }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListDescription, { children: scheduler.jobsExecuted })
] }),
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.DescriptionListGroup, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListTerm, { children: "Jobs scheduled" }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.DescriptionListDescription, { children: scheduler.jobsScheduled })
] })
] }) })
] })
] });
};
// src/plugins/quartz/triggers/Triggers.tsx
// src/plugins/quartz/triggers/TriggersManualModal.tsx
var TriggersManualModal = ({ isOpen, onClose, input }) => {
const { selectedNode } = _react.useContext.call(void 0, QuartzContext);
const [parameters, setParameters] = _react.useState.call(void 0, "{}");
if (!selectedNode || !selectedNode.objectName) {
return null;
}
const { objectName } = selectedNode;
const { name, group, jobName, jobGroup } = input;
const fireTrigger = () => {
_chunkHS42NURZjs.log3.info("Manually fire trigger:", objectName, input, parameters);
_chunkHS42NURZjs.quartzService.triggerJob(objectName, jobName, jobGroup, parameters);
clear();
};
const clear = () => {
setParameters("{}");
onClose();
};
const manualTriggerButtons = [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Button, { variant: "danger", form: "quartz-triggers-manual-modal-form", onClick: fireTrigger, children: "Fire now" }, "fire"),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Button, { variant: "link", onClick: clear, children: "Cancel" }, "cancel")
];
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_deprecated.Modal,
{
id: "quartz-triggers-manual-modal",
variant: "medium",
title: `Manually Fire Trigger: ${group}/${name}`,
isOpen,
onClose: clear,
actions: manualTriggerButtons,
children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.Form, { id: "quartz-triggers-manual-modal-form", isHorizontal: true, children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.FormGroup, { label: "Name", fieldId: "quartz-triggers-manual-modal-form-name", children: name }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.FormGroup, { label: "Group", fieldId: "quartz-triggers-manual-modal-form-group", children: group }),
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.FormGroup, { label: "Parameters", fieldId: "quartz-triggers-manual-modal-form-parameters", children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reactcore.TextArea,
{
id: "quartz-triggers-manual-modal-form-parameters-input",
"aria-label": "quartz triggers manual modal form parameters",
resizeOrientation: "vertical",
value: parameters,
onChange: (_event, value) => setParameters(value)
}
),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.FormHelperText, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.HelperText, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.HelperTextItem, { children: ["Parameters if any (", /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "code", { children: "java.util.Map" }, 1), " in JSON syntax)"] }) }) })
] })
] })
}
);
};
// src/plugins/quartz/triggers/TriggersUpdateModal.tsx
var TriggersUpdateModal = ({ isOpen, onClose, input, reload }) => {
const { selectedNode } = _react.useContext.call(void 0, QuartzContext);
const [trigger, setTrigger] = _react.useState.call(void 0, input);
if (!selectedNode || !selectedNode.objectName) {
return null;
}
const { objectName } = selectedNode;
const isCron = input.type === "cron";
const isSimple = input.type === "simple";
const updateTrigger = async () => {
_chunkHS42NURZjs.log3.info("Update trigger:", objectName, trigger);
await _chunkHS42NURZjs.quartzService.updateTrigger(objectName, trigger);
reload();
onClose();
};
const clear = () => {
setTrigger(input);
onClose();
};
const updateTriggerButtons = [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Button, { variant: "primary", form: "quartz-triggers-update-modal-form", onClick: updateTrigger, children: "Update" }, "update"),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Button, { variant: "link", onClick: clear, children: "Cancel" }, "cancel")
];
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_deprecated.Modal,
{
id: "quartz-triggers-update-modal",
variant: "medium",
title: `Update Trigger: ${input.group}/${input.name}`,
isOpen,
onClose: clear,
actions: updateTriggerButtons,
children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.Form, { id: "quartz-triggers-update-modal-form", isHorizontal: true, children: [
isCron && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.FormGroup, { label: "Cron expression", isRequired: true, fieldId: "quartz-triggers-update-modal-form-cron", children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reactcore.TextInput,
{
id: "quartz-triggers-update-modal-form-cron",
name: "quartz-triggers-update-modal-form-cron",
isRequired: true,
value: trigger.expression,
onChange: (_event, value) => setTrigger({ ...trigger, expression: value })
}
),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.FormHelperText, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.HelperText, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.HelperTextItem, { children: "Specify a cron expression for the trigger" }) }) })
] }),
isSimple && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _react2.default.Fragment, { children: [
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.FormGroup, { label: "Repeat count", isRequired: true, fieldId: "quartz-triggers-update-modal-form-repeat-count", children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reactcore.TextInput,
{
id: "quartz-triggers-update-modal-form-repeat-count",
name: "quartz-triggers-update-modal-form-repeat-count",
isRequired: true,
type: "number",
value: trigger.repeatCount,
onChange: (_event, value) => setTrigger({ ...trigger, repeatCount: parseInt(value) })
}
),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.FormHelperText, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.HelperText, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.HelperTextItem, { children: "Number of times to repeat. Use -1 for forever" }) }) })
] }),
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.FormGroup, { label: "Repeat interval", isRequired: true, fieldId: "quartz-triggers-update-modal-form-repeat-interval", children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reactcore.TextInput,
{
id: "quartz-triggers-update-modal-form-repeat-interval",
name: "quartz-triggers-update-modal-form-repeat-interval",
isRequired: true,
type: "number",
value: trigger.repeatInterval,
onChange: (_event, value) => setTrigger({ ...trigger, repeatInterval: parseInt(value) })
}
),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.FormHelperText, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.HelperText, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.HelperTextItem, { children: "Elapsed time in millis between triggering" }) }) })
] })
] }),
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.FormGroup, { label: "Misfire Instruction", isRequired: true, fieldId: "quartz-triggers-update-modal-form-misfire", children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reactcore.FormSelect,
{
id: "quartz-triggers-update-modal-form-misfire-select",
"aria-label": "Select Misfire Instruction",
value: trigger.misfireInstruction,
onChange: (_event, value) => setTrigger({ ...trigger, misfireInstruction: parseInt(value) }),
children: _chunkHS42NURZjs.misfireInstructions.map(({ value, label }, index) => /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.FormSelectOption, { value, label }, index))
}
),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.FormHelperText, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.HelperText, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.HelperTextItem, { children: "What to do when misfiring happens" }) }) })
] })
] })
}
);
};
// src/plugins/quartz/triggers/Triggers.tsx
var Triggers = () => {
const { selectedNode } = _react.useContext.call(void 0, QuartzContext);
const [triggers, setTriggers] = _react.useState.call(void 0, []);
const [isReading, setIsReading] = _react.useState.call(void 0, true);
const [reload, setReload] = _react.useState.call(void 0, false);
const [isUpdateOpen, setIsUpdateOpen] = _react.useState.call(void 0, false);
const [isManualOpen, setIsManualOpen] = _react.useState.call(void 0, false);
_react.useEffect.call(void 0, () => {
if (!selectedNode || !selectedNode.objectName) {
return;
}
setIsReading(true);
const { objectName: objectName2 } = selectedNode;
const loadTriggers = async () => {
const triggers2 = await _chunkHS42NURZjs.quartzService.loadTriggers(objectName2);
setTriggers(triggers2);
setIsReading(false);
};
loadTriggers();
_chunkHS42NURZjs.quartzService.registerTriggersLoad(objectName2, (triggers2) => {
setTriggers(triggers2);
});
return () => _chunkHS42NURZjs.quartzService.unregisterAll();
}, [selectedNode]);
_react.useEffect.call(void 0, () => {
if (!selectedNode || !selectedNode.objectName || !reload) {
return;
}
_chunkHS42NURZjs.log3.debug("Reload triggers");
const { objectName: objectName2 } = selectedNode;
const loadTriggers = async () => {
const triggers2 = await _chunkHS42NURZjs.quartzService.loadTriggers(objectName2);
setTriggers(triggers2);
};
loadTriggers();
setReload(false);
}, [selectedNode, reload]);
if (!selectedNode || !selectedNode.objectName) {
return null;
}
if (isReading) {
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkBJ6TSPQKjs.HawtioLoadingCard, {});
}
const triggerStates = ["NORMAL", "PAUSED"];
const { objectName } = selectedNode;
const triggerReload = () => setReload(true);
const canUpdateTrigger = () => {
return selectedNode.hasInvokeRights(
_chunkHS42NURZjs.QUARTZ_FACADE_OPERATIONS.updateCronTrigger,
_chunkHS42NURZjs.QUARTZ_FACADE_OPERATIONS.updateSimpleTrigger
);
};
const handleUpdateToggle = () => {
setIsUpdateOpen(!isUpdateOpen);
};
const canTriggerJob = () => {
return selectedNode.hasInvokeRights(_chunkHS42NURZjs.QUARTZ_OPERATIONS.triggerJob);
};
const handleManualToggle = () => {
setIsManualOpen(!isManualOpen);
};
const canPauseTrigger = () => {
return selectedNode.hasInvokeRights(_chunkHS42NURZjs.QUARTZ_OPERATIONS.pauseTrigger);
};
const pauseTrigger = async (trigger) => {
await _chunkHS42NURZjs.quartzService.pauseTrigger(objectName, trigger.name, trigger.group);
triggerReload();
};
const canResumeTrigger = () => {
return selectedNode.hasInvokeRights(_chunkHS42NURZjs.QUARTZ_OPERATIONS.resumeTrigger);
};
const resumeTrigger = async (trigger) => {
await _chunkHS42NURZjs.quartzService.resumeTrigger(objectName, trigger.name, trigger.group);
triggerReload();
};
const toMisfireText = (misfireInstruction) => {
return _nullishCoalesce(_optionalChain([_chunkHS42NURZjs.misfireInstructions, 'access', _4 => _4.find, 'call', _5 => _5(({ value }) => misfireInstruction === value), 'optionalAccess', _6 => _6.label]), () => ( "Unknown"));
};
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_chunkOJIIWKORjs.FilteredTable,
{
rows: triggers,
highlightSearch: true,
tableColumns: [
{
name: "State",
key: "state",
percentageWidth: 10,
renderer: ({ state }) => _optionalChain([state, 'optionalAccess', _7 => _7.toLowerCase, 'call', _8 => _8()]) === "normal" ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Icon, { status: "success", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _checkcircleicon.CheckCircleIcon, {}) }) : /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Icon, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _pausecircleicon.PauseCircleIcon, {}) })
},
{
name: "Group",
key: "group",
percentageWidth: 10
},
{
name: "Name",
key: "name",
percentageWidth: 10
},
{
name: "Type",
key: "type",
percentageWidth: 10
},
{
name: "Expression",
key: "expression",
percentageWidth: 20
},
{
name: "Misfire Instruction",
key: "misfireInstruction",
percentageWidth: 15,
renderer: ({ misfireInstruction }) => toMisfireText(misfireInstruction)
},
{
name: "Previous Execution",
key: "previousFireTime",
percentageWidth: 15
},
{
name: "Next Execution",
key: "nextFireTime",
percentageWidth: 15
},
{
name: "Final execution",
key: "finalFireTime",
percentageWidth: 10,
hideValues: ["null"]
},
{
name: "Action",
percentageWidth: 10,
renderer: (row) => _optionalChain([row, 'access', _9 => _9.state, 'optionalAccess', _10 => _10.toLowerCase, 'call', _11 => _11()]) === "normal" ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Button, { variant: "danger", size: "sm", onClick: () => pauseTrigger(row), isDisabled: !canPauseTrigger(), children: "Pause" }) : /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Button, { variant: "primary", size: "sm", onClick: () => resumeTrigger(row), isDisabled: !canResumeTrigger(), children: "Resume" })
},
{
isAction: true,
percentageWidth: 10,
renderer: (row) => /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment, { children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reacttable.ActionsColumn,
{
items: [
{
title: "Update Trigger",
isDisabled: !canUpdateTrigger(),
onClick: handleUpdateToggle
},
{
title: "Trigger Manually",
isDisabled: !canTriggerJob(),
onClick: handleManualToggle
}
]
}
),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
TriggersUpdateModal,
{
isOpen: isUpdateOpen,
onClose: handleUpdateToggle,
input: row,
reload: triggerReload
}
),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, TriggersManualModal, { isOpen: isManualOpen, onClose: handleManualToggle, input: row })
] })
}
],
fixedSearchCategories: [
{
name: "State",
key: "state",
values: triggerStates
}
],
searchCategories: [
{
name: "Group",
key: "group"
},
{
name: "Name",
key: "name"
},
{
name: "Type",
key: "type"
}
]
}
);
};
// src/plugins/quartz/QuartzContent.tsx
var QuartzContent = () => {
const { tree, selectedNode } = _react.useContext.call(void 0, QuartzContext);
const { pathname, search } = _reactrouterdom.useLocation.call(void 0, );
if (tree.isEmpty()) {
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.PageSection, { hasBodyWrapper: false, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.EmptyState, { headingLevel: "h1", icon: _cubesicon.CubesIcon, titleText: "No Quartz schedulers found", variant: "full" }) });
}
if (!selectedNode) {
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.PageSection, { hasBodyWrapper: false, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.EmptyState, { headingLevel: "h1", icon: _cubesicon.CubesIcon, titleText: "No scheduler selected", variant: "full", children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.EmptyStateBody, { children: "The Quartz plugin allows you to see details about running Quartz Schedulers, and their associated triggers and jobs." }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.EmptyStateFooter, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.EmptyStateBody, { children: "Select a Quartz Scheduler in the tree to continue." }) })
] }) });
}
const navItems = [
{ id: "scheduler", title: "Scheduler", component: Scheduler },
{ id: "triggers", title: "Triggers", component: Triggers },
{ id: "jobs", title: "Jobs", component: Jobs },
{ id: "attributes", title: "Attributes", component: _chunkBJ6TSPQKjs.Attributes },
{ id: "operations", title: "Operations", component: _chunkBJ6TSPQKjs.Operations }
];
const nav = /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Nav, { "aria-label": "Quartz Nav", variant: "horizontal-subnav", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.NavList, { children: navItems.map((nav2) => /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.NavItem, { isActive: pathname === `${_chunkHS42NURZjs.pluginPath3}/${nav2.id}`, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactrouterdom.NavLink, { to: { pathname: nav2.id, search }, children: nav2.title }) }, nav2.id)) }) });
const routes = navItems.map((nav2) => /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactrouterdom.Route, { path: nav2.id, element: _react2.default.createElement(nav2.component) }, nav2.id));
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.PageGroup, { id: "quartz-content", children: [
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactcore.PageSection, { id: "quartz-content-header", hasBodyWrapper: false, children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Title, { headingLevel: "h1", children: selectedNode.name }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Content, { component: "small", children: selectedNode.objectName })
] }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.PageSection, { hasBodyWrapper: false, type: "tabs", children: nav }),
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reactcore.PageSection,
{
id: "quartz-content-main",
padding: { default: "noPadding" },
hasOverflowScroll: true,
"aria-label": "quartz-content-main",
hasBodyWrapper: false,
children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactrouterdom.Routes, { children: [
routes,
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactrouterdom.Route, { path: "/", element: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactrouterdom.Navigate, { to: _nullishCoalesce(_optionalChain([navItems, 'access', _12 => _12[0], 'optionalAccess', _13 => _13.id]), () => ( "")) }) }, "root")
] })
}
)
] });
};
// src/plugins/quartz/QuartzTreeView.tsx
var QuartzTreeView = () => {
const { tree, selectedNode, setSelectedNode } = _react.useContext.call(void 0, QuartzContext);
const onSelect = (_event, item) => {
setSelectedNode(item);
};
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
_reactcore.TreeView,
{
id: "quartz-tree-view",
data: tree.getTree(),
hasGuides: true,
hasSelectableNodes: true,
activeItems: selectedNode ? [selectedNode] : [],
onSelect
}
);
};
// src/plugins/quartz/Quartz.tsx
var Quartz = () => {
const { tree, loaded, selectedNode, setSelectedNode } = useQuartz();
if (!loaded) {
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.PageSection, { hasBodyWrapper: false, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _reactcore.Spinner, { "aria-label": "Loading Quartz schedulers" }) });
}
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, QuartzContext.Provider, { value: { tree, selectedNode, setSelectedNode }, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _reactsplit2.default, { className: "quartz-split", sizes: [20, 80], minSize: 100, gutterSize: 5, children: [
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { children: /* @__PURE__ */ _jsxruntime.jsx.c