UNPKG

@hawtio/react

Version:

A Hawtio reimplementation based on TypeScript + React.

902 lines (806 loc) 50.5 kB
"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