heartbeat-monitor/.next/static/webpack/app/page.591979329fc83864.hot-update.js
OpenClaw Bot 08f1ff6af8 Simplify UI with clean card grid layout
- Redesigned with simpler card-based grid layout
- Added grid/list view toggle
- Cleaner status badges (ONLINE/OFFLINE)
- Simplified stats display (2 stats per card)
- Removed complex animations and effects
- Easier to read and scan quickly
- Consistent spacing and typography
2026-02-18 13:39:41 -06:00

62 lines
231 KiB
JavaScript

"use strict";
/*
* ATTENTION: An "eval-source-map" devtool has been used.
* This devtool is neither made for production nor for readable output files.
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
* or disable the default devtool with "devtool: false".
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
*/
self["webpackHotUpdate_N_E"]("app/page",{
/***/ "(app-pages-browser)/./node_modules/recharts/es6/cartesian/Line.js":
/*!*****************************************************!*\
!*** ./node_modules/recharts/es6/cartesian/Line.js ***!
\*****************************************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval(__webpack_require__.ts("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Line: () => (/* binding */ Line)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"(app-pages-browser)/./node_modules/next/dist/compiled/react/index.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var react_smooth__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! react-smooth */ \"(app-pages-browser)/./node_modules/react-smooth/es6/index.js\");\n/* harmony import */ var lodash_isFunction__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! lodash/isFunction */ \"(app-pages-browser)/./node_modules/lodash/isFunction.js\");\n/* harmony import */ var lodash_isFunction__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(lodash_isFunction__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var lodash_isNil__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! lodash/isNil */ \"(app-pages-browser)/./node_modules/lodash/isNil.js\");\n/* harmony import */ var lodash_isNil__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(lodash_isNil__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var lodash_isEqual__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! lodash/isEqual */ \"(app-pages-browser)/./node_modules/lodash/isEqual.js\");\n/* harmony import */ var lodash_isEqual__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(lodash_isEqual__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var clsx__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! clsx */ \"(app-pages-browser)/./node_modules/clsx/dist/clsx.mjs\");\n/* harmony import */ var _shape_Curve__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../shape/Curve */ \"(app-pages-browser)/./node_modules/recharts/es6/shape/Curve.js\");\n/* harmony import */ var _shape_Dot__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ../shape/Dot */ \"(app-pages-browser)/./node_modules/recharts/es6/shape/Dot.js\");\n/* harmony import */ var _container_Layer__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../container/Layer */ \"(app-pages-browser)/./node_modules/recharts/es6/container/Layer.js\");\n/* harmony import */ var _component_LabelList__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ../component/LabelList */ \"(app-pages-browser)/./node_modules/recharts/es6/component/LabelList.js\");\n/* harmony import */ var _ErrorBar__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./ErrorBar */ \"(app-pages-browser)/./node_modules/recharts/es6/cartesian/ErrorBar.js\");\n/* harmony import */ var _util_DataUtils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../util/DataUtils */ \"(app-pages-browser)/./node_modules/recharts/es6/util/DataUtils.js\");\n/* harmony import */ var _util_ReactUtils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../util/ReactUtils */ \"(app-pages-browser)/./node_modules/recharts/es6/util/ReactUtils.js\");\n/* harmony import */ var _util_Global__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ../util/Global */ \"(app-pages-browser)/./node_modules/recharts/es6/util/Global.js\");\n/* harmony import */ var _util_ChartUtils__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../util/ChartUtils */ \"(app-pages-browser)/./node_modules/recharts/es6/util/ChartUtils.js\");\nvar _excluded = [\n \"type\",\n \"layout\",\n \"connectNulls\",\n \"ref\"\n], _excluded2 = [\n \"key\"\n];\nfunction _typeof(o) {\n \"@babel/helpers - typeof\";\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function(o) {\n return typeof o;\n } : function(o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}\nfunction _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = _objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for(i = 0; i < sourceSymbolKeys.length; i++){\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n for(var key in source){\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n }\n return target;\n}\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i];\n for(var key in source){\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\nfunction ownKeys(e, r) {\n var t = Object.keys(e);\n if (Object.getOwnPropertySymbols) {\n var o = Object.getOwnPropertySymbols(e);\n r && (o = o.filter(function(r) {\n return Object.getOwnPropertyDescriptor(e, r).enumerable;\n })), t.push.apply(t, o);\n }\n return t;\n}\nfunction _objectSpread(e) {\n for(var r = 1; r < arguments.length; r++){\n var t = null != arguments[r] ? arguments[r] : {};\n r % 2 ? ownKeys(Object(t), !0).forEach(function(r) {\n _defineProperty(e, r, t[r]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function(r) {\n Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));\n });\n }\n return e;\n}\nfunction _toConsumableArray(arr) {\n return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();\n}\nfunction _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\nfunction _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return _arrayLikeToArray(arr);\n}\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nfunction _defineProperties(target, props) {\n for(var i = 0; i < props.length; i++){\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nfunction _callSuper(t, o, e) {\n return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e));\n}\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return _assertThisInitialized(self);\n}\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}\nfunction _isNativeReflectConstruct() {\n try {\n var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function() {}));\n } catch (t) {}\n return (_isNativeReflectConstruct = function _isNativeReflectConstruct() {\n return !!t;\n })();\n}\nfunction _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) _setPrototypeOf(subClass, superClass);\n}\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}\nfunction _defineProperty(obj, key, value) {\n key = _toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _toPropertyKey(t) {\n var i = _toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : i + \"\";\n}\nfunction _toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}\n/**\n * @fileOverview Line\n */ \n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvar Line = /*#__PURE__*/ function(_PureComponent) {\n function Line() {\n var _this;\n _classCallCheck(this, Line);\n for(var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++){\n args[_key] = arguments[_key];\n }\n _this = _callSuper(this, Line, [].concat(args));\n _defineProperty(_this, \"state\", {\n isAnimationFinished: true,\n totalLength: 0\n });\n _defineProperty(_this, \"generateSimpleStrokeDasharray\", function(totalLength, length) {\n return \"\".concat(length, \"px \").concat(totalLength - length, \"px\");\n });\n _defineProperty(_this, \"getStrokeDasharray\", function(length, totalLength, lines) {\n var lineLength = lines.reduce(function(pre, next) {\n return pre + next;\n });\n // if lineLength is 0 return the default when no strokeDasharray is provided\n if (!lineLength) {\n return _this.generateSimpleStrokeDasharray(totalLength, length);\n }\n var count = Math.floor(length / lineLength);\n var remainLength = length % lineLength;\n var restLength = totalLength - length;\n var remainLines = [];\n for(var i = 0, sum = 0; i < lines.length; sum += lines[i], ++i){\n if (sum + lines[i] > remainLength) {\n remainLines = [].concat(_toConsumableArray(lines.slice(0, i)), [\n remainLength - sum\n ]);\n break;\n }\n }\n var emptyLines = remainLines.length % 2 === 0 ? [\n 0,\n restLength\n ] : [\n restLength\n ];\n return [].concat(_toConsumableArray(Line.repeat(lines, count)), _toConsumableArray(remainLines), emptyLines).map(function(line) {\n return \"\".concat(line, \"px\");\n }).join(', ');\n });\n _defineProperty(_this, \"id\", (0,_util_DataUtils__WEBPACK_IMPORTED_MODULE_5__.uniqueId)('recharts-line-'));\n _defineProperty(_this, \"pathRef\", function(node) {\n _this.mainCurve = node;\n });\n _defineProperty(_this, \"handleAnimationEnd\", function() {\n _this.setState({\n isAnimationFinished: true\n });\n if (_this.props.onAnimationEnd) {\n _this.props.onAnimationEnd();\n }\n });\n _defineProperty(_this, \"handleAnimationStart\", function() {\n _this.setState({\n isAnimationFinished: false\n });\n if (_this.props.onAnimationStart) {\n _this.props.onAnimationStart();\n }\n });\n return _this;\n }\n _inherits(Line, _PureComponent);\n return _createClass(Line, [\n {\n key: \"componentDidMount\",\n value: function componentDidMount() {\n if (!this.props.isAnimationActive) {\n return;\n }\n var totalLength = this.getTotalLength();\n this.setState({\n totalLength: totalLength\n });\n }\n },\n {\n key: \"componentDidUpdate\",\n value: function componentDidUpdate() {\n if (!this.props.isAnimationActive) {\n return;\n }\n var totalLength = this.getTotalLength();\n if (totalLength !== this.state.totalLength) {\n this.setState({\n totalLength: totalLength\n });\n }\n }\n },\n {\n key: \"getTotalLength\",\n value: function getTotalLength() {\n var curveDom = this.mainCurve;\n try {\n return curveDom && curveDom.getTotalLength && curveDom.getTotalLength() || 0;\n } catch (err) {\n return 0;\n }\n }\n },\n {\n key: \"renderErrorBar\",\n value: function renderErrorBar(needClip, clipPathId) {\n if (this.props.isAnimationActive && !this.state.isAnimationFinished) {\n return null;\n }\n var _this$props = this.props, points = _this$props.points, xAxis = _this$props.xAxis, yAxis = _this$props.yAxis, layout = _this$props.layout, children = _this$props.children;\n var errorBarItems = (0,_util_ReactUtils__WEBPACK_IMPORTED_MODULE_6__.findAllByType)(children, _ErrorBar__WEBPACK_IMPORTED_MODULE_7__.ErrorBar);\n if (!errorBarItems) {\n return null;\n }\n var dataPointFormatter = function dataPointFormatter(dataPoint, dataKey) {\n return {\n x: dataPoint.x,\n y: dataPoint.y,\n value: dataPoint.value,\n errorVal: (0,_util_ChartUtils__WEBPACK_IMPORTED_MODULE_8__.getValueByDataKey)(dataPoint.payload, dataKey)\n };\n };\n var errorBarProps = {\n clipPath: needClip ? \"url(#clipPath-\".concat(clipPathId, \")\") : null\n };\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_container_Layer__WEBPACK_IMPORTED_MODULE_9__.Layer, errorBarProps, errorBarItems.map(function(item) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().cloneElement(item, {\n key: \"bar-\".concat(item.props.dataKey),\n data: points,\n xAxis: xAxis,\n yAxis: yAxis,\n layout: layout,\n dataPointFormatter: dataPointFormatter\n });\n }));\n }\n },\n {\n key: \"renderDots\",\n value: function renderDots(needClip, clipDot, clipPathId) {\n var isAnimationActive = this.props.isAnimationActive;\n if (isAnimationActive && !this.state.isAnimationFinished) {\n return null;\n }\n var _this$props2 = this.props, dot = _this$props2.dot, points = _this$props2.points, dataKey = _this$props2.dataKey;\n var lineProps = (0,_util_ReactUtils__WEBPACK_IMPORTED_MODULE_6__.filterProps)(this.props, false);\n var customDotProps = (0,_util_ReactUtils__WEBPACK_IMPORTED_MODULE_6__.filterProps)(dot, true);\n var dots = points.map(function(entry, i) {\n var dotProps = _objectSpread(_objectSpread(_objectSpread({\n key: \"dot-\".concat(i),\n r: 3\n }, lineProps), customDotProps), {}, {\n index: i,\n cx: entry.x,\n cy: entry.y,\n value: entry.value,\n dataKey: dataKey,\n payload: entry.payload,\n points: points\n });\n return Line.renderDotItem(dot, dotProps);\n });\n var dotsProps = {\n clipPath: needClip ? \"url(#clipPath-\".concat(clipDot ? '' : 'dots-').concat(clipPathId, \")\") : null\n };\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_container_Layer__WEBPACK_IMPORTED_MODULE_9__.Layer, _extends({\n className: \"recharts-line-dots\",\n key: \"dots\"\n }, dotsProps), dots);\n }\n },\n {\n key: \"renderCurveStatically\",\n value: function renderCurveStatically(points, needClip, clipPathId, props) {\n var _this$props3 = this.props, type = _this$props3.type, layout = _this$props3.layout, connectNulls = _this$props3.connectNulls, ref = _this$props3.ref, others = _objectWithoutProperties(_this$props3, _excluded);\n var curveProps = _objectSpread(_objectSpread(_objectSpread({}, (0,_util_ReactUtils__WEBPACK_IMPORTED_MODULE_6__.filterProps)(others, true)), {}, {\n fill: 'none',\n className: 'recharts-line-curve',\n clipPath: needClip ? \"url(#clipPath-\".concat(clipPathId, \")\") : null,\n points: points\n }, props), {}, {\n type: type,\n layout: layout,\n connectNulls: connectNulls\n });\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_shape_Curve__WEBPACK_IMPORTED_MODULE_10__.Curve, _extends({}, curveProps, {\n pathRef: this.pathRef\n }));\n }\n },\n {\n key: \"renderCurveWithAnimation\",\n value: function renderCurveWithAnimation(needClip, clipPathId) {\n var _this2 = this;\n var _this$props4 = this.props, points = _this$props4.points, strokeDasharray = _this$props4.strokeDasharray, isAnimationActive = _this$props4.isAnimationActive, animationBegin = _this$props4.animationBegin, animationDuration = _this$props4.animationDuration, animationEasing = _this$props4.animationEasing, animationId = _this$props4.animationId, animateNewValues = _this$props4.animateNewValues, width = _this$props4.width, height = _this$props4.height;\n var _this$state = this.state, prevPoints = _this$state.prevPoints, totalLength = _this$state.totalLength;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(react_smooth__WEBPACK_IMPORTED_MODULE_11__[\"default\"], {\n begin: animationBegin,\n duration: animationDuration,\n isActive: isAnimationActive,\n easing: animationEasing,\n from: {\n t: 0\n },\n to: {\n t: 1\n },\n key: \"line-\".concat(animationId),\n onAnimationEnd: this.handleAnimationEnd,\n onAnimationStart: this.handleAnimationStart\n }, function(_ref) {\n var t = _ref.t;\n if (prevPoints) {\n var prevPointsDiffFactor = prevPoints.length / points.length;\n var stepData = points.map(function(entry, index) {\n var prevPointIndex = Math.floor(index * prevPointsDiffFactor);\n if (prevPoints[prevPointIndex]) {\n var prev = prevPoints[prevPointIndex];\n var interpolatorX = (0,_util_DataUtils__WEBPACK_IMPORTED_MODULE_5__.interpolateNumber)(prev.x, entry.x);\n var interpolatorY = (0,_util_DataUtils__WEBPACK_IMPORTED_MODULE_5__.interpolateNumber)(prev.y, entry.y);\n return _objectSpread(_objectSpread({}, entry), {}, {\n x: interpolatorX(t),\n y: interpolatorY(t)\n });\n }\n // magic number of faking previous x and y location\n if (animateNewValues) {\n var _interpolatorX = (0,_util_DataUtils__WEBPACK_IMPORTED_MODULE_5__.interpolateNumber)(width * 2, entry.x);\n var _interpolatorY = (0,_util_DataUtils__WEBPACK_IMPORTED_MODULE_5__.interpolateNumber)(height / 2, entry.y);\n return _objectSpread(_objectSpread({}, entry), {}, {\n x: _interpolatorX(t),\n y: _interpolatorY(t)\n });\n }\n return _objectSpread(_objectSpread({}, entry), {}, {\n x: entry.x,\n y: entry.y\n });\n });\n return _this2.renderCurveStatically(stepData, needClip, clipPathId);\n }\n var interpolator = (0,_util_DataUtils__WEBPACK_IMPORTED_MODULE_5__.interpolateNumber)(0, totalLength);\n var curLength = interpolator(t);\n var currentStrokeDasharray;\n if (strokeDasharray) {\n var lines = \"\".concat(strokeDasharray).split(/[,\\s]+/gim).map(function(num) {\n return parseFloat(num);\n });\n currentStrokeDasharray = _this2.getStrokeDasharray(curLength, totalLength, lines);\n } else {\n currentStrokeDasharray = _this2.generateSimpleStrokeDasharray(totalLength, curLength);\n }\n return _this2.renderCurveStatically(points, needClip, clipPathId, {\n strokeDasharray: currentStrokeDasharray\n });\n });\n }\n },\n {\n key: \"renderCurve\",\n value: function renderCurve(needClip, clipPathId) {\n var _this$props5 = this.props, points = _this$props5.points, isAnimationActive = _this$props5.isAnimationActive;\n var _this$state2 = this.state, prevPoints = _this$state2.prevPoints, totalLength = _this$state2.totalLength;\n if (isAnimationActive && points && points.length && (!prevPoints && totalLength > 0 || !lodash_isEqual__WEBPACK_IMPORTED_MODULE_3___default()(prevPoints, points))) {\n return this.renderCurveWithAnimation(needClip, clipPathId);\n }\n return this.renderCurveStatically(points, needClip, clipPathId);\n }\n },\n {\n key: \"render\",\n value: function render() {\n var _filterProps;\n var _this$props6 = this.props, hide = _this$props6.hide, dot = _this$props6.dot, points = _this$props6.points, className = _this$props6.className, xAxis = _this$props6.xAxis, yAxis = _this$props6.yAxis, top = _this$props6.top, left = _this$props6.left, width = _this$props6.width, height = _this$props6.height, isAnimationActive = _this$props6.isAnimationActive, id = _this$props6.id;\n if (hide || !points || !points.length) {\n return null;\n }\n var isAnimationFinished = this.state.isAnimationFinished;\n var hasSinglePoint = points.length === 1;\n var layerClass = (0,clsx__WEBPACK_IMPORTED_MODULE_4__[\"default\"])('recharts-line', className);\n var needClipX = xAxis && xAxis.allowDataOverflow;\n var needClipY = yAxis && yAxis.allowDataOverflow;\n var needClip = needClipX || needClipY;\n var clipPathId = lodash_isNil__WEBPACK_IMPORTED_MODULE_2___default()(id) ? this.id : id;\n var _ref2 = (_filterProps = (0,_util_ReactUtils__WEBPACK_IMPORTED_MODULE_6__.filterProps)(dot, false)) !== null && _filterProps !== void 0 ? _filterProps : {\n r: 3,\n strokeWidth: 2\n }, _ref2$r = _ref2.r, r = _ref2$r === void 0 ? 3 : _ref2$r, _ref2$strokeWidth = _ref2.strokeWidth, strokeWidth = _ref2$strokeWidth === void 0 ? 2 : _ref2$strokeWidth;\n var _ref3 = (0,_util_ReactUtils__WEBPACK_IMPORTED_MODULE_6__.hasClipDot)(dot) ? dot : {}, _ref3$clipDot = _ref3.clipDot, clipDot = _ref3$clipDot === void 0 ? true : _ref3$clipDot;\n var dotSize = r * 2 + strokeWidth;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_container_Layer__WEBPACK_IMPORTED_MODULE_9__.Layer, {\n className: layerClass\n }, needClipX || needClipY ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"defs\", null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"clipPath\", {\n id: \"clipPath-\".concat(clipPathId)\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"rect\", {\n x: needClipX ? left : left - width / 2,\n y: needClipY ? top : top - height / 2,\n width: needClipX ? width : width * 2,\n height: needClipY ? height : height * 2\n })), !clipDot && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"clipPath\", {\n id: \"clipPath-dots-\".concat(clipPathId)\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"rect\", {\n x: left - dotSize / 2,\n y: top - dotSize / 2,\n width: width + dotSize,\n height: height + dotSize\n }))) : null, !hasSinglePoint && this.renderCurve(needClip, clipPathId), this.renderErrorBar(needClip, clipPathId), (hasSinglePoint || dot) && this.renderDots(needClip, clipDot, clipPathId), (!isAnimationActive || isAnimationFinished) && _component_LabelList__WEBPACK_IMPORTED_MODULE_12__.LabelList.renderCallByParent(this.props, points));\n }\n }\n ], [\n {\n key: \"getDerivedStateFromProps\",\n value: function getDerivedStateFromProps(nextProps, prevState) {\n if (nextProps.animationId !== prevState.prevAnimationId) {\n return {\n prevAnimationId: nextProps.animationId,\n curPoints: nextProps.points,\n prevPoints: prevState.curPoints\n };\n }\n if (nextProps.points !== prevState.curPoints) {\n return {\n curPoints: nextProps.points\n };\n }\n return null;\n }\n },\n {\n key: \"repeat\",\n value: function repeat(lines, count) {\n var linesUnit = lines.length % 2 !== 0 ? [].concat(_toConsumableArray(lines), [\n 0\n ]) : lines;\n var result = [];\n for(var i = 0; i < count; ++i){\n result = [].concat(_toConsumableArray(result), _toConsumableArray(linesUnit));\n }\n return result;\n }\n },\n {\n key: \"renderDotItem\",\n value: function renderDotItem(option, props) {\n var dotItem;\n if (/*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().isValidElement(option)) {\n dotItem = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().cloneElement(option, props);\n } else if (lodash_isFunction__WEBPACK_IMPORTED_MODULE_1___default()(option)) {\n dotItem = option(props);\n } else {\n var key = props.key, dotProps = _objectWithoutProperties(props, _excluded2);\n var className = (0,clsx__WEBPACK_IMPORTED_MODULE_4__[\"default\"])('recharts-line-dot', typeof option !== 'boolean' ? option.className : '');\n dotItem = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_shape_Dot__WEBPACK_IMPORTED_MODULE_13__.Dot, _extends({\n key: key\n }, dotProps, {\n className: className\n }));\n }\n return dotItem;\n }\n }\n ]);\n}(react__WEBPACK_IMPORTED_MODULE_0__.PureComponent);\n_defineProperty(Line, \"displayName\", 'Line');\n_defineProperty(Line, \"defaultProps\", {\n xAxisId: 0,\n yAxisId: 0,\n connectNulls: false,\n activeDot: true,\n dot: true,\n legendType: 'line',\n stroke: '#3182bd',\n strokeWidth: 1,\n fill: '#fff',\n points: [],\n isAnimationActive: !_util_Global__WEBPACK_IMPORTED_MODULE_14__.Global.isSsr,\n animateNewValues: true,\n animationBegin: 0,\n animationDuration: 1500,\n animationEasing: 'ease',\n hide: false,\n label: false\n});\n/**\n * Compose the data of each group\n * @param {Object} props The props from the component\n * @param {Object} xAxis The configuration of x-axis\n * @param {Object} yAxis The configuration of y-axis\n * @param {String} dataKey The unique key of a group\n * @return {Array} Composed data\n */ _defineProperty(Line, \"getComposedData\", function(_ref4) {\n var props = _ref4.props, xAxis = _ref4.xAxis, yAxis = _ref4.yAxis, xAxisTicks = _ref4.xAxisTicks, yAxisTicks = _ref4.yAxisTicks, dataKey = _ref4.dataKey, bandSize = _ref4.bandSize, displayedData = _ref4.displayedData, offset = _ref4.offset;\n var layout = props.layout;\n var points = displayedData.map(function(entry, index) {\n var value = (0,_util_ChartUtils__WEBPACK_IMPORTED_MODULE_8__.getValueByDataKey)(entry, dataKey);\n if (layout === 'horizontal') {\n return {\n x: (0,_util_ChartUtils__WEBPACK_IMPORTED_MODULE_8__.getCateCoordinateOfLine)({\n axis: xAxis,\n ticks: xAxisTicks,\n bandSize: bandSize,\n entry: entry,\n index: index\n }),\n y: lodash_isNil__WEBPACK_IMPORTED_MODULE_2___default()(value) ? null : yAxis.scale(value),\n value: value,\n payload: entry\n };\n }\n return {\n x: lodash_isNil__WEBPACK_IMPORTED_MODULE_2___default()(value) ? null : xAxis.scale(value),\n y: (0,_util_ChartUtils__WEBPACK_IMPORTED_MODULE_8__.getCateCoordinateOfLine)({\n axis: yAxis,\n ticks: yAxisTicks,\n bandSize: bandSize,\n entry: entry,\n index: index\n }),\n value: value,\n payload: entry\n };\n });\n return _objectSpread({\n points: points,\n layout: layout\n }, offset);\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(app-pages-browser)/./node_modules/recharts/es6/cartesian/Line.js","mappings":"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","sources":["/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/node_modules/recharts/es6/cartesian/Line.js"],"sourcesContent":["var _excluded = [\"type\", \"layout\", \"connectNulls\", \"ref\"],\n  _excluded2 = [\"key\"];\nfunction _typeof(o) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o; }, _typeof(o); }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } } return target; }\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nfunction ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }\nfunction _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } else if (call !== void 0) { throw new TypeError(\"Derived constructors may only return object or undefined\"); } return _assertThisInitialized(self); }\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\nfunction _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, \"prototype\", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == _typeof(i) ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != _typeof(i)) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\n/**\n * @fileOverview Line\n */\nimport React, { PureComponent } from 'react';\nimport Animate from 'react-smooth';\nimport isFunction from 'lodash/isFunction';\nimport isNil from 'lodash/isNil';\nimport isEqual from 'lodash/isEqual';\nimport clsx from 'clsx';\nimport { Curve } from '../shape/Curve';\nimport { Dot } from '../shape/Dot';\nimport { Layer } from '../container/Layer';\nimport { LabelList } from '../component/LabelList';\nimport { ErrorBar } from './ErrorBar';\nimport { uniqueId, interpolateNumber } from '../util/DataUtils';\nimport { findAllByType, filterProps, hasClipDot } from '../util/ReactUtils';\nimport { Global } from '../util/Global';\nimport { getCateCoordinateOfLine, getValueByDataKey } from '../util/ChartUtils';\nexport var Line = /*#__PURE__*/function (_PureComponent) {\n  function Line() {\n    var _this;\n    _classCallCheck(this, Line);\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n    _this = _callSuper(this, Line, [].concat(args));\n    _defineProperty(_this, \"state\", {\n      isAnimationFinished: true,\n      totalLength: 0\n    });\n    _defineProperty(_this, \"generateSimpleStrokeDasharray\", function (totalLength, length) {\n      return \"\".concat(length, \"px \").concat(totalLength - length, \"px\");\n    });\n    _defineProperty(_this, \"getStrokeDasharray\", function (length, totalLength, lines) {\n      var lineLength = lines.reduce(function (pre, next) {\n        return pre + next;\n      });\n\n      // if lineLength is 0 return the default when no strokeDasharray is provided\n      if (!lineLength) {\n        return _this.generateSimpleStrokeDasharray(totalLength, length);\n      }\n      var count = Math.floor(length / lineLength);\n      var remainLength = length % lineLength;\n      var restLength = totalLength - length;\n      var remainLines = [];\n      for (var i = 0, sum = 0; i < lines.length; sum += lines[i], ++i) {\n        if (sum + lines[i] > remainLength) {\n          remainLines = [].concat(_toConsumableArray(lines.slice(0, i)), [remainLength - sum]);\n          break;\n        }\n      }\n      var emptyLines = remainLines.length % 2 === 0 ? [0, restLength] : [restLength];\n      return [].concat(_toConsumableArray(Line.repeat(lines, count)), _toConsumableArray(remainLines), emptyLines).map(function (line) {\n        return \"\".concat(line, \"px\");\n      }).join(', ');\n    });\n    _defineProperty(_this, \"id\", uniqueId('recharts-line-'));\n    _defineProperty(_this, \"pathRef\", function (node) {\n      _this.mainCurve = node;\n    });\n    _defineProperty(_this, \"handleAnimationEnd\", function () {\n      _this.setState({\n        isAnimationFinished: true\n      });\n      if (_this.props.onAnimationEnd) {\n        _this.props.onAnimationEnd();\n      }\n    });\n    _defineProperty(_this, \"handleAnimationStart\", function () {\n      _this.setState({\n        isAnimationFinished: false\n      });\n      if (_this.props.onAnimationStart) {\n        _this.props.onAnimationStart();\n      }\n    });\n    return _this;\n  }\n  _inherits(Line, _PureComponent);\n  return _createClass(Line, [{\n    key: \"componentDidMount\",\n    value: function componentDidMount() {\n      if (!this.props.isAnimationActive) {\n        return;\n      }\n      var totalLength = this.getTotalLength();\n      this.setState({\n        totalLength: totalLength\n      });\n    }\n  }, {\n    key: \"componentDidUpdate\",\n    value: function componentDidUpdate() {\n      if (!this.props.isAnimationActive) {\n        return;\n      }\n      var totalLength = this.getTotalLength();\n      if (totalLength !== this.state.totalLength) {\n        this.setState({\n          totalLength: totalLength\n        });\n      }\n    }\n  }, {\n    key: \"getTotalLength\",\n    value: function getTotalLength() {\n      var curveDom = this.mainCurve;\n      try {\n        return curveDom && curveDom.getTotalLength && curveDom.getTotalLength() || 0;\n      } catch (err) {\n        return 0;\n      }\n    }\n  }, {\n    key: \"renderErrorBar\",\n    value: function renderErrorBar(needClip, clipPathId) {\n      if (this.props.isAnimationActive && !this.state.isAnimationFinished) {\n        return null;\n      }\n      var _this$props = this.props,\n        points = _this$props.points,\n        xAxis = _this$props.xAxis,\n        yAxis = _this$props.yAxis,\n        layout = _this$props.layout,\n        children = _this$props.children;\n      var errorBarItems = findAllByType(children, ErrorBar);\n      if (!errorBarItems) {\n        return null;\n      }\n      var dataPointFormatter = function dataPointFormatter(dataPoint, dataKey) {\n        return {\n          x: dataPoint.x,\n          y: dataPoint.y,\n          value: dataPoint.value,\n          errorVal: getValueByDataKey(dataPoint.payload, dataKey)\n        };\n      };\n      var errorBarProps = {\n        clipPath: needClip ? \"url(#clipPath-\".concat(clipPathId, \")\") : null\n      };\n      return /*#__PURE__*/React.createElement(Layer, errorBarProps, errorBarItems.map(function (item) {\n        return /*#__PURE__*/React.cloneElement(item, {\n          key: \"bar-\".concat(item.props.dataKey),\n          data: points,\n          xAxis: xAxis,\n          yAxis: yAxis,\n          layout: layout,\n          dataPointFormatter: dataPointFormatter\n        });\n      }));\n    }\n  }, {\n    key: \"renderDots\",\n    value: function renderDots(needClip, clipDot, clipPathId) {\n      var isAnimationActive = this.props.isAnimationActive;\n      if (isAnimationActive && !this.state.isAnimationFinished) {\n        return null;\n      }\n      var _this$props2 = this.props,\n        dot = _this$props2.dot,\n        points = _this$props2.points,\n        dataKey = _this$props2.dataKey;\n      var lineProps = filterProps(this.props, false);\n      var customDotProps = filterProps(dot, true);\n      var dots = points.map(function (entry, i) {\n        var dotProps = _objectSpread(_objectSpread(_objectSpread({\n          key: \"dot-\".concat(i),\n          r: 3\n        }, lineProps), customDotProps), {}, {\n          index: i,\n          cx: entry.x,\n          cy: entry.y,\n          value: entry.value,\n          dataKey: dataKey,\n          payload: entry.payload,\n          points: points\n        });\n        return Line.renderDotItem(dot, dotProps);\n      });\n      var dotsProps = {\n        clipPath: needClip ? \"url(#clipPath-\".concat(clipDot ? '' : 'dots-').concat(clipPathId, \")\") : null\n      };\n      return /*#__PURE__*/React.createElement(Layer, _extends({\n        className: \"recharts-line-dots\",\n        key: \"dots\"\n      }, dotsProps), dots);\n    }\n  }, {\n    key: \"renderCurveStatically\",\n    value: function renderCurveStatically(points, needClip, clipPathId, props) {\n      var _this$props3 = this.props,\n        type = _this$props3.type,\n        layout = _this$props3.layout,\n        connectNulls = _this$props3.connectNulls,\n        ref = _this$props3.ref,\n        others = _objectWithoutProperties(_this$props3, _excluded);\n      var curveProps = _objectSpread(_objectSpread(_objectSpread({}, filterProps(others, true)), {}, {\n        fill: 'none',\n        className: 'recharts-line-curve',\n        clipPath: needClip ? \"url(#clipPath-\".concat(clipPathId, \")\") : null,\n        points: points\n      }, props), {}, {\n        type: type,\n        layout: layout,\n        connectNulls: connectNulls\n      });\n      return /*#__PURE__*/React.createElement(Curve, _extends({}, curveProps, {\n        pathRef: this.pathRef\n      }));\n    }\n  }, {\n    key: \"renderCurveWithAnimation\",\n    value: function renderCurveWithAnimation(needClip, clipPathId) {\n      var _this2 = this;\n      var _this$props4 = this.props,\n        points = _this$props4.points,\n        strokeDasharray = _this$props4.strokeDasharray,\n        isAnimationActive = _this$props4.isAnimationActive,\n        animationBegin = _this$props4.animationBegin,\n        animationDuration = _this$props4.animationDuration,\n        animationEasing = _this$props4.animationEasing,\n        animationId = _this$props4.animationId,\n        animateNewValues = _this$props4.animateNewValues,\n        width = _this$props4.width,\n        height = _this$props4.height;\n      var _this$state = this.state,\n        prevPoints = _this$state.prevPoints,\n        totalLength = _this$state.totalLength;\n      return /*#__PURE__*/React.createElement(Animate, {\n        begin: animationBegin,\n        duration: animationDuration,\n        isActive: isAnimationActive,\n        easing: animationEasing,\n        from: {\n          t: 0\n        },\n        to: {\n          t: 1\n        },\n        key: \"line-\".concat(animationId),\n        onAnimationEnd: this.handleAnimationEnd,\n        onAnimationStart: this.handleAnimationStart\n      }, function (_ref) {\n        var t = _ref.t;\n        if (prevPoints) {\n          var prevPointsDiffFactor = prevPoints.length / points.length;\n          var stepData = points.map(function (entry, index) {\n            var prevPointIndex = Math.floor(index * prevPointsDiffFactor);\n            if (prevPoints[prevPointIndex]) {\n              var prev = prevPoints[prevPointIndex];\n              var interpolatorX = interpolateNumber(prev.x, entry.x);\n              var interpolatorY = interpolateNumber(prev.y, entry.y);\n              return _objectSpread(_objectSpread({}, entry), {}, {\n                x: interpolatorX(t),\n                y: interpolatorY(t)\n              });\n            }\n\n            // magic number of faking previous x and y location\n            if (animateNewValues) {\n              var _interpolatorX = interpolateNumber(width * 2, entry.x);\n              var _interpolatorY = interpolateNumber(height / 2, entry.y);\n              return _objectSpread(_objectSpread({}, entry), {}, {\n                x: _interpolatorX(t),\n                y: _interpolatorY(t)\n              });\n            }\n            return _objectSpread(_objectSpread({}, entry), {}, {\n              x: entry.x,\n              y: entry.y\n            });\n          });\n          return _this2.renderCurveStatically(stepData, needClip, clipPathId);\n        }\n        var interpolator = interpolateNumber(0, totalLength);\n        var curLength = interpolator(t);\n        var currentStrokeDasharray;\n        if (strokeDasharray) {\n          var lines = \"\".concat(strokeDasharray).split(/[,\\s]+/gim).map(function (num) {\n            return parseFloat(num);\n          });\n          currentStrokeDasharray = _this2.getStrokeDasharray(curLength, totalLength, lines);\n        } else {\n          currentStrokeDasharray = _this2.generateSimpleStrokeDasharray(totalLength, curLength);\n        }\n        return _this2.renderCurveStatically(points, needClip, clipPathId, {\n          strokeDasharray: currentStrokeDasharray\n        });\n      });\n    }\n  }, {\n    key: \"renderCurve\",\n    value: function renderCurve(needClip, clipPathId) {\n      var _this$props5 = this.props,\n        points = _this$props5.points,\n        isAnimationActive = _this$props5.isAnimationActive;\n      var _this$state2 = this.state,\n        prevPoints = _this$state2.prevPoints,\n        totalLength = _this$state2.totalLength;\n      if (isAnimationActive && points && points.length && (!prevPoints && totalLength > 0 || !isEqual(prevPoints, points))) {\n        return this.renderCurveWithAnimation(needClip, clipPathId);\n      }\n      return this.renderCurveStatically(points, needClip, clipPathId);\n    }\n  }, {\n    key: \"render\",\n    value: function render() {\n      var _filterProps;\n      var _this$props6 = this.props,\n        hide = _this$props6.hide,\n        dot = _this$props6.dot,\n        points = _this$props6.points,\n        className = _this$props6.className,\n        xAxis = _this$props6.xAxis,\n        yAxis = _this$props6.yAxis,\n        top = _this$props6.top,\n        left = _this$props6.left,\n        width = _this$props6.width,\n        height = _this$props6.height,\n        isAnimationActive = _this$props6.isAnimationActive,\n        id = _this$props6.id;\n      if (hide || !points || !points.length) {\n        return null;\n      }\n      var isAnimationFinished = this.state.isAnimationFinished;\n      var hasSinglePoint = points.length === 1;\n      var layerClass = clsx('recharts-line', className);\n      var needClipX = xAxis && xAxis.allowDataOverflow;\n      var needClipY = yAxis && yAxis.allowDataOverflow;\n      var needClip = needClipX || needClipY;\n      var clipPathId = isNil(id) ? this.id : id;\n      var _ref2 = (_filterProps = filterProps(dot, false)) !== null && _filterProps !== void 0 ? _filterProps : {\n          r: 3,\n          strokeWidth: 2\n        },\n        _ref2$r = _ref2.r,\n        r = _ref2$r === void 0 ? 3 : _ref2$r,\n        _ref2$strokeWidth = _ref2.strokeWidth,\n        strokeWidth = _ref2$strokeWidth === void 0 ? 2 : _ref2$strokeWidth;\n      var _ref3 = hasClipDot(dot) ? dot : {},\n        _ref3$clipDot = _ref3.clipDot,\n        clipDot = _ref3$clipDot === void 0 ? true : _ref3$clipDot;\n      var dotSize = r * 2 + strokeWidth;\n      return /*#__PURE__*/React.createElement(Layer, {\n        className: layerClass\n      }, needClipX || needClipY ? /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"clipPath\", {\n        id: \"clipPath-\".concat(clipPathId)\n      }, /*#__PURE__*/React.createElement(\"rect\", {\n        x: needClipX ? left : left - width / 2,\n        y: needClipY ? top : top - height / 2,\n        width: needClipX ? width : width * 2,\n        height: needClipY ? height : height * 2\n      })), !clipDot && /*#__PURE__*/React.createElement(\"clipPath\", {\n        id: \"clipPath-dots-\".concat(clipPathId)\n      }, /*#__PURE__*/React.createElement(\"rect\", {\n        x: left - dotSize / 2,\n        y: top - dotSize / 2,\n        width: width + dotSize,\n        height: height + dotSize\n      }))) : null, !hasSinglePoint && this.renderCurve(needClip, clipPathId), this.renderErrorBar(needClip, clipPathId), (hasSinglePoint || dot) && this.renderDots(needClip, clipDot, clipPathId), (!isAnimationActive || isAnimationFinished) && LabelList.renderCallByParent(this.props, points));\n    }\n  }], [{\n    key: \"getDerivedStateFromProps\",\n    value: function getDerivedStateFromProps(nextProps, prevState) {\n      if (nextProps.animationId !== prevState.prevAnimationId) {\n        return {\n          prevAnimationId: nextProps.animationId,\n          curPoints: nextProps.points,\n          prevPoints: prevState.curPoints\n        };\n      }\n      if (nextProps.points !== prevState.curPoints) {\n        return {\n          curPoints: nextProps.points\n        };\n      }\n      return null;\n    }\n  }, {\n    key: \"repeat\",\n    value: function repeat(lines, count) {\n      var linesUnit = lines.length % 2 !== 0 ? [].concat(_toConsumableArray(lines), [0]) : lines;\n      var result = [];\n      for (var i = 0; i < count; ++i) {\n        result = [].concat(_toConsumableArray(result), _toConsumableArray(linesUnit));\n      }\n      return result;\n    }\n  }, {\n    key: \"renderDotItem\",\n    value: function renderDotItem(option, props) {\n      var dotItem;\n      if ( /*#__PURE__*/React.isValidElement(option)) {\n        dotItem = /*#__PURE__*/React.cloneElement(option, props);\n      } else if (isFunction(option)) {\n        dotItem = option(props);\n      } else {\n        var key = props.key,\n          dotProps = _objectWithoutProperties(props, _excluded2);\n        var className = clsx('recharts-line-dot', typeof option !== 'boolean' ? option.className : '');\n        dotItem = /*#__PURE__*/React.createElement(Dot, _extends({\n          key: key\n        }, dotProps, {\n          className: className\n        }));\n      }\n      return dotItem;\n    }\n  }]);\n}(PureComponent);\n_defineProperty(Line, \"displayName\", 'Line');\n_defineProperty(Line, \"defaultProps\", {\n  xAxisId: 0,\n  yAxisId: 0,\n  connectNulls: false,\n  activeDot: true,\n  dot: true,\n  legendType: 'line',\n  stroke: '#3182bd',\n  strokeWidth: 1,\n  fill: '#fff',\n  points: [],\n  isAnimationActive: !Global.isSsr,\n  animateNewValues: true,\n  animationBegin: 0,\n  animationDuration: 1500,\n  animationEasing: 'ease',\n  hide: false,\n  label: false\n});\n/**\n * Compose the data of each group\n * @param {Object} props The props from the component\n * @param  {Object} xAxis   The configuration of x-axis\n * @param  {Object} yAxis   The configuration of y-axis\n * @param  {String} dataKey The unique key of a group\n * @return {Array}  Composed data\n */\n_defineProperty(Line, \"getComposedData\", function (_ref4) {\n  var props = _ref4.props,\n    xAxis = _ref4.xAxis,\n    yAxis = _ref4.yAxis,\n    xAxisTicks = _ref4.xAxisTicks,\n    yAxisTicks = _ref4.yAxisTicks,\n    dataKey = _ref4.dataKey,\n    bandSize = _ref4.bandSize,\n    displayedData = _ref4.displayedData,\n    offset = _ref4.offset;\n  var layout = props.layout;\n  var points = displayedData.map(function (entry, index) {\n    var value = getValueByDataKey(entry, dataKey);\n    if (layout === 'horizontal') {\n      return {\n        x: getCateCoordinateOfLine({\n          axis: xAxis,\n          ticks: xAxisTicks,\n          bandSize: bandSize,\n          entry: entry,\n          index: index\n        }),\n        y: isNil(value) ? null : yAxis.scale(value),\n        value: value,\n        payload: entry\n      };\n    }\n    return {\n      x: isNil(value) ? null : xAxis.scale(value),\n      y: getCateCoordinateOfLine({\n        axis: yAxis,\n        ticks: yAxisTicks,\n        bandSize: bandSize,\n        entry: entry,\n        index: index\n      }),\n      value: value,\n      payload: entry\n    };\n  });\n  return _objectSpread({\n    points: points,\n    layout: layout\n  }, offset);\n});"],"names":["_excluded","_excluded2","_typeof","o","Symbol","iterator","constructor","prototype","_objectWithoutProperties","source","excluded","target","_objectWithoutPropertiesLoose","key","i","Object","getOwnPropertySymbols","sourceSymbolKeys","length","indexOf","propertyIsEnumerable","call","hasOwnProperty","_extends","assign","bind","arguments","apply","ownKeys","e","r","t","keys","filter","getOwnPropertyDescriptor","enumerable","push","_objectSpread","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","_toConsumableArray","arr","_arrayWithoutHoles","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","TypeError","minLen","_arrayLikeToArray","n","toString","slice","name","Array","from","test","iter","isArray","len","arr2","_classCallCheck","instance","Constructor","_defineProperties","props","descriptor","configurable","writable","_toPropertyKey","_createClass","protoProps","staticProps","_callSuper","_getPrototypeOf","_possibleConstructorReturn","_isNativeReflectConstruct","Reflect","construct","self","_assertThisInitialized","ReferenceError","Boolean","valueOf","setPrototypeOf","getPrototypeOf","__proto__","_inherits","subClass","superClass","create","value","_setPrototypeOf","p","obj","_toPrimitive","toPrimitive","String","Number","React","PureComponent","Animate","isFunction","isNil","isEqual","clsx","Curve","Dot","Layer","LabelList","ErrorBar","uniqueId","interpolateNumber","findAllByType","filterProps","hasClipDot","Global","getCateCoordinateOfLine","getValueByDataKey","Line","_PureComponent","_this","_len","args","_key","concat","isAnimationFinished","totalLength","lines","lineLength","reduce","pre","next","generateSimpleStrokeDasharray","count","Math","floor","remainLength","restLength","remainLines","sum","emptyLines","repeat","map","line","join","node","mainCurve","setState","onAnimationEnd","onAnimationStart","componentDidMount","isAnimationActive","getTotalLength","componentDidUpdate","state","curveDom","err","renderErrorBar","needClip","clipPathId","_this$props","points","xAxis","yAxis","layout","children","errorBarItems","dataPointFormatter","dataPoint","dataKey","x","y","errorVal","payload","errorBarProps","clipPath","createElement","item","cloneElement","data","renderDots","clipDot","_this$props2","dot","lineProps","customDotProps","dots","entry","dotProps","index","cx","cy","renderDotItem","dotsProps","className","renderCurveStatically","_this$props3","type","connectNulls","ref","others","curveProps","fill","pathRef","renderCurveWithAnimation","_this2","_this$props4","strokeDasharray","animationBegin","animationDuration","animationEasing","animationId","animateNewValues","width","height","_this$state","prevPoints","begin","duration","isActive","easing","to","handleAnimationEnd","handleAnimationStart","_ref","prevPointsDiffFactor","stepData","prevPointIndex","prev","interpolatorX","interpolatorY","_interpolatorX","_interpolatorY","interpolator","curLength","currentStrokeDasharray","split","num","parseFloat","getStrokeDasharray","renderCurve","_this$props5","_this$state2","render","_filterProps","_this$props6","hide","top","left","id","hasSinglePoint","layerClass","needClipX","allowDataOverflow","needClipY","_ref2","strokeWidth","_ref2$r","_ref2$strokeWidth","_ref3","_ref3$clipDot","dotSize","renderCallByParent","getDerivedStateFromProps","nextProps","prevState","prevAnimationId","curPoints","linesUnit","result","option","dotItem","isValidElement","xAxisId","yAxisId","activeDot","legendType","stroke","isSsr","label","_ref4","xAxisTicks","yAxisTicks","bandSize","displayedData","offset","axis","ticks","scale"],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(app-pages-browser)/./node_modules/recharts/es6/cartesian/Line.js\n"));
/***/ }),
/***/ "(app-pages-browser)/./node_modules/recharts/es6/chart/LineChart.js":
/*!******************************************************!*\
!*** ./node_modules/recharts/es6/chart/LineChart.js ***!
\******************************************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval(__webpack_require__.ts("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ LineChart: () => (/* binding */ LineChart)\n/* harmony export */ });\n/* harmony import */ var _generateCategoricalChart__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./generateCategoricalChart */ \"(app-pages-browser)/./node_modules/recharts/es6/chart/generateCategoricalChart.js\");\n/* harmony import */ var _cartesian_Line__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../cartesian/Line */ \"(app-pages-browser)/./node_modules/recharts/es6/cartesian/Line.js\");\n/* harmony import */ var _cartesian_XAxis__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../cartesian/XAxis */ \"(app-pages-browser)/./node_modules/recharts/es6/cartesian/XAxis.js\");\n/* harmony import */ var _cartesian_YAxis__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../cartesian/YAxis */ \"(app-pages-browser)/./node_modules/recharts/es6/cartesian/YAxis.js\");\n/* harmony import */ var _util_CartesianUtils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../util/CartesianUtils */ \"(app-pages-browser)/./node_modules/recharts/es6/util/CartesianUtils.js\");\n/**\n * @fileOverview Line Chart\n */ \n\n\n\n\nvar LineChart = (0,_generateCategoricalChart__WEBPACK_IMPORTED_MODULE_0__.generateCategoricalChart)({\n chartName: 'LineChart',\n GraphicalChild: _cartesian_Line__WEBPACK_IMPORTED_MODULE_1__.Line,\n axisComponents: [\n {\n axisType: 'xAxis',\n AxisComp: _cartesian_XAxis__WEBPACK_IMPORTED_MODULE_2__.XAxis\n },\n {\n axisType: 'yAxis',\n AxisComp: _cartesian_YAxis__WEBPACK_IMPORTED_MODULE_3__.YAxis\n }\n ],\n formatAxisMap: _util_CartesianUtils__WEBPACK_IMPORTED_MODULE_4__.formatAxisMap\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFwcC1wYWdlcy1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9yZWNoYXJ0cy9lczYvY2hhcnQvTGluZUNoYXJ0LmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOztDQUVDLEdBQ3FFO0FBQzdCO0FBQ0U7QUFDQTtBQUNZO0FBQ2hELElBQUlLLFlBQVlMLG1GQUF3QkEsQ0FBQztJQUM5Q00sV0FBVztJQUNYQyxnQkFBZ0JOLGlEQUFJQTtJQUNwQk8sZ0JBQWdCO1FBQUM7WUFDZkMsVUFBVTtZQUNWQyxVQUFVUixtREFBS0E7UUFDakI7UUFBRztZQUNETyxVQUFVO1lBQ1ZDLFVBQVVQLG1EQUFLQTtRQUNqQjtLQUFFO0lBQ0ZDLGVBQWVBLCtEQUFhQTtBQUM5QixHQUFHIiwic291cmNlcyI6WyIvVXNlcnMvbWF0dGJydWNlL0RvY3VtZW50cy9Qcm9qZWN0cy9PcGVuQ2xhdy9XZWIvaGVhcnRiZWF0LW1vbml0b3Ivbm9kZV9tb2R1bGVzL3JlY2hhcnRzL2VzNi9jaGFydC9MaW5lQ2hhcnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAZmlsZU92ZXJ2aWV3IExpbmUgQ2hhcnRcbiAqL1xuaW1wb3J0IHsgZ2VuZXJhdGVDYXRlZ29yaWNhbENoYXJ0IH0gZnJvbSAnLi9nZW5lcmF0ZUNhdGVnb3JpY2FsQ2hhcnQnO1xuaW1wb3J0IHsgTGluZSB9IGZyb20gJy4uL2NhcnRlc2lhbi9MaW5lJztcbmltcG9ydCB7IFhBeGlzIH0gZnJvbSAnLi4vY2FydGVzaWFuL1hBeGlzJztcbmltcG9ydCB7IFlBeGlzIH0gZnJvbSAnLi4vY2FydGVzaWFuL1lBeGlzJztcbmltcG9ydCB7IGZvcm1hdEF4aXNNYXAgfSBmcm9tICcuLi91dGlsL0NhcnRlc2lhblV0aWxzJztcbmV4cG9ydCB2YXIgTGluZUNoYXJ0ID0gZ2VuZXJhdGVDYXRlZ29yaWNhbENoYXJ0KHtcbiAgY2hhcnROYW1lOiAnTGluZUNoYXJ0JyxcbiAgR3JhcGhpY2FsQ2hpbGQ6IExpbmUsXG4gIGF4aXNDb21wb25lbnRzOiBbe1xuICAgIGF4aXNUeXBlOiAneEF4aXMnLFxuICAgIEF4aXNDb21wOiBYQXhpc1xuICB9LCB7XG4gICAgYXhpc1R5cGU6ICd5QXhpcycsXG4gICAgQXhpc0NvbXA6IFlBeGlzXG4gIH1dLFxuICBmb3JtYXRBeGlzTWFwOiBmb3JtYXRBeGlzTWFwXG59KTsiXSwibmFtZXMiOlsiZ2VuZXJhdGVDYXRlZ29yaWNhbENoYXJ0IiwiTGluZSIsIlhBeGlzIiwiWUF4aXMiLCJmb3JtYXRBeGlzTWFwIiwiTGluZUNoYXJ0IiwiY2hhcnROYW1lIiwiR3JhcGhpY2FsQ2hpbGQiLCJheGlzQ29tcG9uZW50cyIsImF4aXNUeXBlIiwiQXhpc0NvbXAiXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(app-pages-browser)/./node_modules/recharts/es6/chart/LineChart.js\n"));
/***/ }),
/***/ "(app-pages-browser)/./src/app/page.tsx":
/*!**************************!*\
!*** ./src/app/page.tsx ***!
\**************************/
/***/ ((module, __webpack_exports__, __webpack_require__) => {
eval(__webpack_require__.ts("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ HeartbeatMonitor)\n/* harmony export */ });\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react/jsx-dev-runtime */ \"(app-pages-browser)/./node_modules/next/dist/compiled/react/jsx-dev-runtime.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"(app-pages-browser)/./node_modules/next/dist/compiled/react/index.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! __barrel_optimize__?names=Activity,ExternalLink,LayoutGrid,List,Plus,RefreshCw,Trash2!=!lucide-react */ \"(app-pages-browser)/./node_modules/lucide-react/dist/esm/icons/activity.js\");\n/* harmony import */ var _barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! __barrel_optimize__?names=Activity,ExternalLink,LayoutGrid,List,Plus,RefreshCw,Trash2!=!lucide-react */ \"(app-pages-browser)/./node_modules/lucide-react/dist/esm/icons/list.js\");\n/* harmony import */ var _barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! __barrel_optimize__?names=Activity,ExternalLink,LayoutGrid,List,Plus,RefreshCw,Trash2!=!lucide-react */ \"(app-pages-browser)/./node_modules/lucide-react/dist/esm/icons/layout-grid.js\");\n/* harmony import */ var _barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! __barrel_optimize__?names=Activity,ExternalLink,LayoutGrid,List,Plus,RefreshCw,Trash2!=!lucide-react */ \"(app-pages-browser)/./node_modules/lucide-react/dist/esm/icons/refresh-cw.js\");\n/* harmony import */ var _barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! __barrel_optimize__?names=Activity,ExternalLink,LayoutGrid,List,Plus,RefreshCw,Trash2!=!lucide-react */ \"(app-pages-browser)/./node_modules/lucide-react/dist/esm/icons/plus.js\");\n/* harmony import */ var _barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! __barrel_optimize__?names=Activity,ExternalLink,LayoutGrid,List,Plus,RefreshCw,Trash2!=!lucide-react */ \"(app-pages-browser)/./node_modules/lucide-react/dist/esm/icons/external-link.js\");\n/* harmony import */ var _barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! __barrel_optimize__?names=Activity,ExternalLink,LayoutGrid,List,Plus,RefreshCw,Trash2!=!lucide-react */ \"(app-pages-browser)/./node_modules/lucide-react/dist/esm/icons/trash-2.js\");\n/* harmony import */ var _barrel_optimize_names_Line_LineChart_ResponsiveContainer_recharts__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! __barrel_optimize__?names=Line,LineChart,ResponsiveContainer!=!recharts */ \"(app-pages-browser)/./node_modules/recharts/es6/component/ResponsiveContainer.js\");\n/* harmony import */ var _barrel_optimize_names_Line_LineChart_ResponsiveContainer_recharts__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! __barrel_optimize__?names=Line,LineChart,ResponsiveContainer!=!recharts */ \"(app-pages-browser)/./node_modules/recharts/es6/chart/LineChart.js\");\n/* harmony import */ var _barrel_optimize_names_Line_LineChart_ResponsiveContainer_recharts__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! __barrel_optimize__?names=Line,LineChart,ResponsiveContainer!=!recharts */ \"(app-pages-browser)/./node_modules/recharts/es6/cartesian/Line.js\");\n/* __next_internal_client_entry_do_not_use__ default auto */ \nvar _s = $RefreshSig$();\n\n\n\nfunction HeartbeatMonitor() {\n _s();\n const [apps, setApps] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([]);\n const [status, setStatus] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([]);\n const [loading, setLoading] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(true);\n const [checking, setChecking] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(null);\n const [showAddApp, setShowAddApp] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(false);\n const [viewMode, setViewMode] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(\"grid\");\n const [selectedApp, setSelectedApp] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(null);\n const [newApp, setNewApp] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)({\n name: \"\",\n description: \"\",\n url: \"http://localhost:\",\n port: 3000,\n path: \"\",\n command: \"npm run dev\",\n category: \"Other\",\n color: \"#22C55E\",\n enabled: true\n });\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)({\n \"HeartbeatMonitor.useEffect\": ()=>{\n fetchData();\n const interval = setInterval(fetchData, 30000);\n return ({\n \"HeartbeatMonitor.useEffect\": ()=>clearInterval(interval)\n })[\"HeartbeatMonitor.useEffect\"];\n }\n }[\"HeartbeatMonitor.useEffect\"], []);\n async function fetchData() {\n try {\n const res = await fetch(\"/api/monitor\");\n const data = await res.json();\n setApps(data.apps || []);\n setStatus(data.status || []);\n } catch (err) {\n console.error(\"Failed to fetch data:\", err);\n } finally{\n setLoading(false);\n }\n }\n async function checkApp(app) {\n setChecking(app.id);\n try {\n const start = Date.now();\n await fetch(app.url, {\n method: \"HEAD\",\n mode: \"no-cors\"\n });\n const responseTime = Date.now() - start;\n const entry = {\n appId: app.id,\n timestamp: new Date().toISOString(),\n status: \"up\",\n responseTime\n };\n await fetch(\"/api/monitor\", {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\"\n },\n body: JSON.stringify({\n action: \"recordStatus\",\n entry\n })\n });\n fetchData();\n } catch (e) {\n const entry = {\n appId: app.id,\n timestamp: new Date().toISOString(),\n status: \"down\"\n };\n await fetch(\"/api/monitor\", {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\"\n },\n body: JSON.stringify({\n action: \"recordStatus\",\n entry\n })\n });\n fetchData();\n } finally{\n setChecking(null);\n }\n }\n async function addApp(e) {\n e.preventDefault();\n if (!newApp.name || !newApp.url) return;\n await fetch(\"/api/monitor\", {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\"\n },\n body: JSON.stringify({\n action: \"addApp\",\n app: newApp\n })\n });\n setNewApp({\n name: \"\",\n description: \"\",\n url: \"http://localhost:\",\n port: 3000,\n path: \"\",\n command: \"npm run dev\",\n category: \"Other\",\n color: \"#22C55E\",\n enabled: true\n });\n setShowAddApp(false);\n fetchData();\n }\n async function deleteApp(id) {\n if (!confirm(\"Delete this app from monitoring?\")) return;\n await fetch(\"/api/monitor\", {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\"\n },\n body: JSON.stringify({\n action: \"deleteApp\",\n id\n })\n });\n fetchData();\n }\n function getAppStatus(appId) {\n const appStatus = status.filter((s)=>s.appId === appId);\n const latest = appStatus[appStatus.length - 1];\n const isUp = (latest === null || latest === void 0 ? void 0 : latest.status) === \"up\";\n const uptime = appStatus.length > 0 ? Math.round(appStatus.filter((s)=>s.status === \"up\").length / appStatus.length * 100) : 100;\n return {\n latest,\n isUp,\n uptime,\n history: appStatus.slice(-10)\n };\n }\n const totalApps = apps.length;\n const onlineApps = apps.filter((app)=>getAppStatus(app.id).isUp).length;\n const offlineApps = totalApps - onlineApps;\n if (loading) {\n return /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"min-h-screen bg-slate-950 flex items-center justify-center\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"text-slate-400\",\n children: \"Loading...\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 159,\n columnNumber: 9\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 158,\n columnNumber: 7\n }, this);\n }\n return /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"min-h-screen bg-slate-950 text-slate-100\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"header\", {\n className: \"bg-slate-900 border-b border-slate-800\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"max-w-7xl mx-auto px-4 py-4\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"flex items-center justify-between\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"flex items-center gap-3\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"w-10 h-10 bg-emerald-500 rounded-lg flex items-center justify-center\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_2__[\"default\"], {\n className: \"w-5 h-5 text-white\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 172,\n columnNumber: 17\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 171,\n columnNumber: 15\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"h1\", {\n className: \"text-xl font-bold text-white\",\n children: \"Heartbeat Monitor\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 175,\n columnNumber: 17\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-sm text-slate-400\",\n children: [\n onlineApps,\n \" of \",\n totalApps,\n \" services online\"\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 176,\n columnNumber: 17\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 174,\n columnNumber: 15\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 170,\n columnNumber: 13\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"flex items-center gap-2\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"button\", {\n onClick: ()=>setViewMode(viewMode === \"grid\" ? \"list\" : \"grid\"),\n className: \"p-2 bg-slate-800 rounded-lg text-slate-400 hover:text-white\",\n children: viewMode === \"grid\" ? /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_3__[\"default\"], {\n className: \"w-5 h-5\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 187,\n columnNumber: 40\n }, this) : /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_4__[\"default\"], {\n className: \"w-5 h-5\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 187,\n columnNumber: 71\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 183,\n columnNumber: 15\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"button\", {\n onClick: fetchData,\n className: \"p-2 bg-slate-800 rounded-lg text-slate-400 hover:text-white\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_5__[\"default\"], {\n className: \"w-5 h-5\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 193,\n columnNumber: 17\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 189,\n columnNumber: 15\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"button\", {\n onClick: ()=>setShowAddApp(true),\n className: \"flex items-center gap-2 bg-emerald-500 hover:bg-emerald-600 text-white px-4 py-2 rounded-lg font-medium\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_6__[\"default\"], {\n className: \"w-4 h-4\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 199,\n columnNumber: 17\n }, this),\n \"Add\"\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 195,\n columnNumber: 15\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 182,\n columnNumber: 13\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 169,\n columnNumber: 11\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 168,\n columnNumber: 9\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 167,\n columnNumber: 7\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"main\", {\n className: \"max-w-7xl mx-auto px-4 py-6\",\n children: viewMode === \"grid\" ? /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4\",\n children: apps.map((app)=>{\n const { isUp, uptime, history, latest } = getAppStatus(app.id);\n return /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"bg-slate-900 rounded-xl border-2 p-5 transition-all hover:scale-[1.02] cursor-pointer \".concat(isUp ? \"border-emerald-500/30\" : \"border-red-500/30\"),\n onClick: ()=>setSelectedApp(app),\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"flex items-center justify-between mb-4\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"span\", {\n className: \"px-3 py-1 rounded-full text-xs font-bold \".concat(isUp ? \"bg-emerald-500/20 text-emerald-400\" : \"bg-red-500/20 text-red-400\"),\n children: isUp ? \"● ONLINE\" : \"● OFFLINE\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 224,\n columnNumber: 21\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"span\", {\n className: \"text-slate-500 text-sm\",\n children: app.port\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 231,\n columnNumber: 21\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 223,\n columnNumber: 19\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"mb-4\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"h3\", {\n className: \"text-lg font-bold text-white mb-1\",\n children: app.name\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 236,\n columnNumber: 21\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-slate-400 text-sm\",\n children: app.description || \"No description\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 237,\n columnNumber: 21\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 235,\n columnNumber: 19\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"grid grid-cols-2 gap-3 mb-4\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"bg-slate-800 rounded-lg p-3\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-xs text-slate-500 mb-1\",\n children: \"Uptime\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 243,\n columnNumber: 23\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-xl font-bold \".concat(uptime >= 90 ? \"text-emerald-400\" : \"text-yellow-400\"),\n children: [\n uptime,\n \"%\"\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 244,\n columnNumber: 23\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 242,\n columnNumber: 21\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"bg-slate-800 rounded-lg p-3\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-xs text-slate-500 mb-1\",\n children: \"Response\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 249,\n columnNumber: 23\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-xl font-bold text-white\",\n children: (latest === null || latest === void 0 ? void 0 : latest.responseTime) ? \"\".concat(latest.responseTime, \"ms\") : \"--\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 250,\n columnNumber: 23\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 248,\n columnNumber: 21\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 241,\n columnNumber: 19\n }, this),\n history.length > 1 && /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"h-16 mb-4\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Line_LineChart_ResponsiveContainer_recharts__WEBPACK_IMPORTED_MODULE_7__.ResponsiveContainer, {\n width: \"100%\",\n height: \"100%\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Line_LineChart_ResponsiveContainer_recharts__WEBPACK_IMPORTED_MODULE_8__.LineChart, {\n data: history.map((h, i)=>({\n i,\n status: h.status === \"up\" ? 1 : 0\n })),\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Line_LineChart_ResponsiveContainer_recharts__WEBPACK_IMPORTED_MODULE_9__.Line, {\n type: \"step\",\n dataKey: \"status\",\n stroke: isUp ? \"#22C55E\" : \"#EF4444\",\n strokeWidth: 2,\n dot: false\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 261,\n columnNumber: 27\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 260,\n columnNumber: 25\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 259,\n columnNumber: 23\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 258,\n columnNumber: 21\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"flex gap-2\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"button\", {\n onClick: (e)=>{\n e.stopPropagation();\n checkApp(app);\n },\n disabled: checking === app.id,\n className: \"flex-1 bg-slate-800 hover:bg-slate-700 text-slate-300 py-2 rounded-lg text-sm font-medium transition-colors\",\n children: checking === app.id ? \"Checking...\" : \"Check Now\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 275,\n columnNumber: 21\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"a\", {\n href: app.url,\n target: \"_blank\",\n rel: \"noopener noreferrer\",\n onClick: (e)=>e.stopPropagation(),\n className: \"p-2 bg-slate-800 hover:bg-slate-700 text-slate-300 rounded-lg\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n className: \"w-4 h-4\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 292,\n columnNumber: 23\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 285,\n columnNumber: 21\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 274,\n columnNumber: 19\n }, this)\n ]\n }, app.id, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 215,\n columnNumber: 17\n }, this);\n })\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 210,\n columnNumber: 11\n }, this) : /* List View */ /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"space-y-2\",\n children: apps.map((app)=>{\n const { isUp, uptime, latest } = getAppStatus(app.id);\n return /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"flex items-center gap-4 bg-slate-900 rounded-lg border-l-4 p-4 \".concat(isUp ? \"border-l-emerald-500\" : \"border-l-red-500\"),\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"w-3 h-3 rounded-full \".concat(isUp ? \"bg-emerald-500\" : \"bg-red-500\")\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 312,\n columnNumber: 19\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"flex-1 min-w-0\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"h3\", {\n className: \"font-semibold text-white\",\n children: app.name\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 315,\n columnNumber: 21\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-sm text-slate-400 truncate\",\n children: app.url\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 316,\n columnNumber: 21\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 314,\n columnNumber: 19\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"hidden sm:flex items-center gap-6 text-sm\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"text-center\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-slate-500\",\n children: \"Port\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 321,\n columnNumber: 23\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"font-mono text-white\",\n children: app.port\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 322,\n columnNumber: 23\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 320,\n columnNumber: 21\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"text-center\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-slate-500\",\n children: \"Uptime\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 325,\n columnNumber: 23\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"font-mono \".concat(uptime >= 90 ? \"text-emerald-400\" : \"text-yellow-400\"),\n children: [\n uptime,\n \"%\"\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 326,\n columnNumber: 23\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 324,\n columnNumber: 21\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"text-center\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-slate-500\",\n children: \"Response\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 331,\n columnNumber: 23\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"font-mono text-white\",\n children: (latest === null || latest === void 0 ? void 0 : latest.responseTime) ? \"\".concat(latest.responseTime, \"ms\") : \"--\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 332,\n columnNumber: 23\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 330,\n columnNumber: 21\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 319,\n columnNumber: 19\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"flex items-center gap-2\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"button\", {\n onClick: ()=>checkApp(app),\n disabled: checking === app.id,\n className: \"p-2 text-slate-400 hover:text-white\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_5__[\"default\"], {\n className: \"w-4 h-4 \".concat(checking === app.id ? \"animate-spin\" : \"\")\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 344,\n columnNumber: 23\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 339,\n columnNumber: 21\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"a\", {\n href: app.url,\n target: \"_blank\",\n rel: \"noopener noreferrer\",\n className: \"p-2 text-slate-400 hover:text-white\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n className: \"w-4 h-4\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 352,\n columnNumber: 23\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 346,\n columnNumber: 21\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"button\", {\n onClick: ()=>deleteApp(app.id),\n className: \"p-2 text-slate-400 hover:text-red-400\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(_barrel_optimize_names_Activity_ExternalLink_LayoutGrid_List_Plus_RefreshCw_Trash2_lucide_react__WEBPACK_IMPORTED_MODULE_11__[\"default\"], {\n className: \"w-4 h-4\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 358,\n columnNumber: 23\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 354,\n columnNumber: 21\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 338,\n columnNumber: 19\n }, this)\n ]\n }, app.id, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 306,\n columnNumber: 17\n }, this);\n })\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 301,\n columnNumber: 11\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 208,\n columnNumber: 7\n }, this),\n showAddApp && /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"fixed inset-0 bg-black/50 flex items-center justify-center z-50 p-4\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"bg-slate-900 rounded-xl p-6 w-full max-w-md\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"h2\", {\n className: \"text-xl font-bold text-white mb-4\",\n children: \"Add New App\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 372,\n columnNumber: 13\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"form\", {\n onSubmit: addApp,\n className: \"space-y-4\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"label\", {\n className: \"block text-sm text-slate-400 mb-1\",\n children: \"Name\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 375,\n columnNumber: 17\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"input\", {\n type: \"text\",\n value: newApp.name,\n onChange: (e)=>setNewApp({\n ...newApp,\n name: e.target.value\n }),\n className: \"w-full bg-slate-800 border border-slate-700 rounded-lg px-3 py-2 text-white\",\n required: true\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 376,\n columnNumber: 17\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 374,\n columnNumber: 15\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"label\", {\n className: \"block text-sm text-slate-400 mb-1\",\n children: \"Description\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 385,\n columnNumber: 17\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"input\", {\n type: \"text\",\n value: newApp.description,\n onChange: (e)=>setNewApp({\n ...newApp,\n description: e.target.value\n }),\n className: \"w-full bg-slate-800 border border-slate-700 rounded-lg px-3 py-2 text-white\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 386,\n columnNumber: 17\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 384,\n columnNumber: 15\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"grid grid-cols-2 gap-4\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"label\", {\n className: \"block text-sm text-slate-400 mb-1\",\n children: \"URL\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 395,\n columnNumber: 19\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"input\", {\n type: \"text\",\n value: newApp.url,\n onChange: (e)=>setNewApp({\n ...newApp,\n url: e.target.value\n }),\n className: \"w-full bg-slate-800 border border-slate-700 rounded-lg px-3 py-2 text-white\",\n required: true\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 396,\n columnNumber: 19\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 394,\n columnNumber: 17\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"label\", {\n className: \"block text-sm text-slate-400 mb-1\",\n children: \"Port\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 405,\n columnNumber: 19\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"input\", {\n type: \"number\",\n value: newApp.port,\n onChange: (e)=>setNewApp({\n ...newApp,\n port: parseInt(e.target.value)\n }),\n className: \"w-full bg-slate-800 border border-slate-700 rounded-lg px-3 py-2 text-white\",\n required: true\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 406,\n columnNumber: 19\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 404,\n columnNumber: 17\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 393,\n columnNumber: 15\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"flex gap-3 pt-2\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"button\", {\n type: \"button\",\n onClick: ()=>setShowAddApp(false),\n className: \"flex-1 bg-slate-800 hover:bg-slate-700 text-slate-300 py-2 rounded-lg\",\n children: \"Cancel\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 416,\n columnNumber: 17\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"button\", {\n type: \"submit\",\n className: \"flex-1 bg-emerald-500 hover:bg-emerald-600 text-white py-2 rounded-lg font-medium\",\n children: \"Add App\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 423,\n columnNumber: 17\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 415,\n columnNumber: 15\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 373,\n columnNumber: 13\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 371,\n columnNumber: 11\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 370,\n columnNumber: 9\n }, this),\n selectedApp && /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"fixed inset-0 bg-black/50 flex items-center justify-center z-50 p-4\",\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"bg-slate-900 rounded-xl p-6 w-full max-w-lg\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"flex items-center justify-between mb-4\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"h2\", {\n className: \"text-xl font-bold text-white\",\n children: selectedApp.name\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 440,\n columnNumber: 15\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"button\", {\n onClick: ()=>setSelectedApp(null),\n className: \"text-slate-400 hover:text-white\",\n children: \"✕\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 441,\n columnNumber: 15\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 439,\n columnNumber: 13\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"space-y-4\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"grid grid-cols-2 gap-4\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"bg-slate-800 rounded-lg p-3\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-sm text-slate-500\",\n children: \"URL\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 452,\n columnNumber: 19\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-emerald-400 font-mono text-sm break-all\",\n children: selectedApp.url\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 453,\n columnNumber: 19\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 451,\n columnNumber: 17\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"bg-slate-800 rounded-lg p-3\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-sm text-slate-500\",\n children: \"Port\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 456,\n columnNumber: 19\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"p\", {\n className: \"text-white font-mono\",\n children: selectedApp.port\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 457,\n columnNumber: 19\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 455,\n columnNumber: 17\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 450,\n columnNumber: 15\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n className: \"flex gap-3\",\n children: [\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"button\", {\n onClick: ()=>{\n checkApp(selectedApp);\n setSelectedApp(null);\n },\n className: \"flex-1 bg-emerald-500 hover:bg-emerald-600 text-white py-2 rounded-lg font-medium\",\n children: \"Check Now\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 462,\n columnNumber: 17\n }, this),\n /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"button\", {\n onClick: ()=>{\n deleteApp(selectedApp.id);\n setSelectedApp(null);\n },\n className: \"flex-1 bg-red-500/20 hover:bg-red-500/30 text-red-400 py-2 rounded-lg font-medium\",\n children: \"Delete\"\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 471,\n columnNumber: 17\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 461,\n columnNumber: 15\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 449,\n columnNumber: 13\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 438,\n columnNumber: 11\n }, this)\n }, void 0, false, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 437,\n columnNumber: 9\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx\",\n lineNumber: 165,\n columnNumber: 5\n }, this);\n}\n_s(HeartbeatMonitor, \"nPvs5T0CRMHWpqOE0JVMs57LLmM=\");\n_c = HeartbeatMonitor;\nvar _c;\n$RefreshReg$(_c, \"HeartbeatMonitor\");\n\n\n;\n // Wrapped in an IIFE to avoid polluting the global scope\n ;\n (function () {\n var _a, _b;\n // Legacy CSS implementations will `eval` browser code in a Node.js context\n // to extract CSS. For backwards compatibility, we need to check we're in a\n // browser context before continuing.\n if (typeof self !== 'undefined' &&\n // AMP / No-JS mode does not inject these helpers:\n '$RefreshHelpers$' in self) {\n // @ts-ignore __webpack_module__ is global\n var currentExports = module.exports;\n // @ts-ignore __webpack_module__ is global\n var prevSignature = (_b = (_a = module.hot.data) === null || _a === void 0 ? void 0 : _a.prevSignature) !== null && _b !== void 0 ? _b : null;\n // This cannot happen in MainTemplate because the exports mismatch between\n // templating and execution.\n self.$RefreshHelpers$.registerExportsForReactRefresh(currentExports, module.id);\n // A module can be accepted automatically based on its exports, e.g. when\n // it is a Refresh Boundary.\n if (self.$RefreshHelpers$.isReactRefreshBoundary(currentExports)) {\n // Save the previous exports signature on update so we can compare the boundary\n // signatures. We avoid saving exports themselves since it causes memory leaks (https://github.com/vercel/next.js/pull/53797)\n module.hot.dispose(function (data) {\n data.prevSignature =\n self.$RefreshHelpers$.getRefreshBoundarySignature(currentExports);\n });\n // Unconditionally accept an update to this module, we'll check if it's\n // still a Refresh Boundary later.\n // @ts-ignore importMeta is replaced in the loader\n module.hot.accept();\n // This field is set when the previous version of this module was a\n // Refresh Boundary, letting us know we need to check for invalidation or\n // enqueue an update.\n if (prevSignature !== null) {\n // A boundary can become ineligible if its exports are incompatible\n // with the previous exports.\n //\n // For example, if you add/remove/change exports, we'll want to\n // re-execute the importing modules, and force those components to\n // re-render. Similarly, if you convert a class component to a\n // function, we want to invalidate the boundary.\n if (self.$RefreshHelpers$.shouldInvalidateReactRefreshBoundary(prevSignature, self.$RefreshHelpers$.getRefreshBoundarySignature(currentExports))) {\n module.hot.invalidate();\n }\n else {\n self.$RefreshHelpers$.scheduleUpdate();\n }\n }\n }\n else {\n // Since we just executed the code for the module, it's possible that the\n // new exports made it ineligible for being a boundary.\n // We only care about the case when we were _previously_ a boundary,\n // because we already accepted this update (accidental side effect).\n var isNoLongerABoundary = prevSignature !== null;\n if (isNoLongerABoundary) {\n module.hot.invalidate();\n }\n }\n }\n })();\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(app-pages-browser)/./src/app/page.tsx","mappings":"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","sources":["/Users/mattbruce/Documents/Projects/OpenClaw/Web/heartbeat-monitor/src/app/page.tsx"],"sourcesContent":["\"use client\";\n\nimport { useState, useEffect } from \"react\";\nimport { Activity, Plus, RefreshCw, Trash2, ExternalLink, LayoutGrid, List, Settings } from \"lucide-react\";\nimport { LineChart, Line, XAxis, YAxis, Tooltip, ResponsiveContainer } from \"recharts\";\n\ninterface App {\n  id: string;\n  name: string;\n  description: string;\n  url: string;\n  port: number;\n  path: string;\n  command: string;\n  category: string;\n  color: string;\n  enabled: boolean;\n}\n\ninterface StatusEntry {\n  appId: string;\n  timestamp: string;\n  status: \"up\" | \"down\";\n  responseTime?: number;\n}\n\nexport default function HeartbeatMonitor() {\n  const [apps, setApps] = useState<App[]>([]);\n  const [status, setStatus] = useState<StatusEntry[]>([]);\n  const [loading, setLoading] = useState(true);\n  const [checking, setChecking] = useState<string | null>(null);\n  const [showAddApp, setShowAddApp] = useState(false);\n  const [viewMode, setViewMode] = useState<\"grid\" | \"list\">(\"grid\");\n  const [selectedApp, setSelectedApp] = useState<App | null>(null);\n  const [newApp, setNewApp] = useState<Partial<App>>({\n    name: \"\",\n    description: \"\",\n    url: \"http://localhost:\",\n    port: 3000,\n    path: \"\",\n    command: \"npm run dev\",\n    category: \"Other\",\n    color: \"#22C55E\",\n    enabled: true,\n  });\n\n  useEffect(() => {\n    fetchData();\n    const interval = setInterval(fetchData, 30000);\n    return () => clearInterval(interval);\n  }, []);\n\n  async function fetchData() {\n    try {\n      const res = await fetch(\"/api/monitor\");\n      const data = await res.json();\n      setApps(data.apps || []);\n      setStatus(data.status || []);\n    } catch (err) {\n      console.error(\"Failed to fetch data:\", err);\n    } finally {\n      setLoading(false);\n    }\n  }\n\n  async function checkApp(app: App) {\n    setChecking(app.id);\n    try {\n      const start = Date.now();\n      await fetch(app.url, { method: \"HEAD\", mode: \"no-cors\" });\n      const responseTime = Date.now() - start;\n      \n      const entry: StatusEntry = {\n        appId: app.id,\n        timestamp: new Date().toISOString(),\n        status: \"up\",\n        responseTime,\n      };\n\n      await fetch(\"/api/monitor\", {\n        method: \"POST\",\n        headers: { \"Content-Type\": \"application/json\" },\n        body: JSON.stringify({ action: \"recordStatus\", entry }),\n      });\n\n      fetchData();\n    } catch {\n      const entry: StatusEntry = {\n        appId: app.id,\n        timestamp: new Date().toISOString(),\n        status: \"down\",\n      };\n\n      await fetch(\"/api/monitor\", {\n        method: \"POST\",\n        headers: { \"Content-Type\": \"application/json\" },\n        body: JSON.stringify({ action: \"recordStatus\", entry }),\n      });\n\n      fetchData();\n    } finally {\n      setChecking(null);\n    }\n  }\n\n  async function addApp(e: React.FormEvent) {\n    e.preventDefault();\n    if (!newApp.name || !newApp.url) return;\n\n    await fetch(\"/api/monitor\", {\n      method: \"POST\",\n      headers: { \"Content-Type\": \"application/json\" },\n      body: JSON.stringify({ action: \"addApp\", app: newApp }),\n    });\n\n    setNewApp({\n      name: \"\",\n      description: \"\",\n      url: \"http://localhost:\",\n      port: 3000,\n      path: \"\",\n      command: \"npm run dev\",\n      category: \"Other\",\n      color: \"#22C55E\",\n      enabled: true,\n    });\n    setShowAddApp(false);\n    fetchData();\n  }\n\n  async function deleteApp(id: string) {\n    if (!confirm(\"Delete this app from monitoring?\")) return;\n    await fetch(\"/api/monitor\", {\n      method: \"POST\",\n      headers: { \"Content-Type\": \"application/json\" },\n      body: JSON.stringify({ action: \"deleteApp\", id }),\n    });\n    fetchData();\n  }\n\n  function getAppStatus(appId: string) {\n    const appStatus = status.filter((s) => s.appId === appId);\n    const latest = appStatus[appStatus.length - 1];\n    const isUp = latest?.status === \"up\";\n    const uptime = appStatus.length > 0 \n      ? Math.round((appStatus.filter(s => s.status === \"up\").length / appStatus.length) * 100)\n      : 100;\n    \n    return { latest, isUp, uptime, history: appStatus.slice(-10) };\n  }\n\n  const totalApps = apps.length;\n  const onlineApps = apps.filter((app) => getAppStatus(app.id).isUp).length;\n  const offlineApps = totalApps - onlineApps;\n\n  if (loading) {\n    return (\n      <div className=\"min-h-screen bg-slate-950 flex items-center justify-center\">\n        <div className=\"text-slate-400\">Loading...</div>\n      </div>\n    );\n  }\n\n  return (\n    <div className=\"min-h-screen bg-slate-950 text-slate-100\">\n      {/* Header */}\n      <header className=\"bg-slate-900 border-b border-slate-800\">\n        <div className=\"max-w-7xl mx-auto px-4 py-4\">\n          <div className=\"flex items-center justify-between\">\n            <div className=\"flex items-center gap-3\">\n              <div className=\"w-10 h-10 bg-emerald-500 rounded-lg flex items-center justify-center\">\n                <Activity className=\"w-5 h-5 text-white\" />\n              </div>\n              <div>\n                <h1 className=\"text-xl font-bold text-white\">Heartbeat Monitor</h1>\n                <p className=\"text-sm text-slate-400\">\n                  {onlineApps} of {totalApps} services online\n                </p>\n              </div>\n            </div>\n            \n            <div className=\"flex items-center gap-2\">\n              <button\n                onClick={() => setViewMode(viewMode === \"grid\" ? \"list\" : \"grid\")}\n                className=\"p-2 bg-slate-800 rounded-lg text-slate-400 hover:text-white\"\n              >\n                {viewMode === \"grid\" ? <List className=\"w-5 h-5\" /> : <LayoutGrid className=\"w-5 h-5\" />}\n              </button>\n              <button\n                onClick={fetchData}\n                className=\"p-2 bg-slate-800 rounded-lg text-slate-400 hover:text-white\"\n              >\n                <RefreshCw className=\"w-5 h-5\" />\n              </button>\n              <button\n                onClick={() => setShowAddApp(true)}\n                className=\"flex items-center gap-2 bg-emerald-500 hover:bg-emerald-600 text-white px-4 py-2 rounded-lg font-medium\"\n              >\n                <Plus className=\"w-4 h-4\" />\n                Add\n              </button>\n            </div>\n          </div>\n        </div>\n      </header>\n\n      {/* Main Content */}\n      <main className=\"max-w-7xl mx-auto px-4 py-6\">\n        {viewMode === \"grid\" ? (\n          <div className=\"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4\">\n            {apps.map((app) => {\n              const { isUp, uptime, history, latest } = getAppStatus(app.id);\n              \n              return (\n                <div\n                  key={app.id}\n                  className={`bg-slate-900 rounded-xl border-2 p-5 transition-all hover:scale-[1.02] cursor-pointer ${\n                    isUp ? \"border-emerald-500/30\" : \"border-red-500/30\"\n                  }`}\n                  onClick={() => setSelectedApp(app)}\n                >\n                  {/* Status Badge */}\n                  <div className=\"flex items-center justify-between mb-4\">\n                    <span className={`px-3 py-1 rounded-full text-xs font-bold ${\n                      isUp \n                        ? \"bg-emerald-500/20 text-emerald-400\" \n                        : \"bg-red-500/20 text-red-400\"\n                    }`}>\n                      {isUp ? \"● ONLINE\" : \"● OFFLINE\"}\n                    </span>\n                    <span className=\"text-slate-500 text-sm\">{app.port}</span>\n                  </div>\n\n                  {/* App Info */}\n                  <div className=\"mb-4\">\n                    <h3 className=\"text-lg font-bold text-white mb-1\">{app.name}</h3>\n                    <p className=\"text-slate-400 text-sm\">{app.description || \"No description\"}</p>\n                  </div>\n\n                  {/* Stats Grid */}\n                  <div className=\"grid grid-cols-2 gap-3 mb-4\">\n                    <div className=\"bg-slate-800 rounded-lg p-3\">\n                      <p className=\"text-xs text-slate-500 mb-1\">Uptime</p>\n                      <p className={`text-xl font-bold ${uptime >= 90 ? \"text-emerald-400\" : \"text-yellow-400\"}`}>\n                        {uptime}%\n                      </p>\n                    </div>\n                    <div className=\"bg-slate-800 rounded-lg p-3\">\n                      <p className=\"text-xs text-slate-500 mb-1\">Response</p>\n                      <p className=\"text-xl font-bold text-white\">\n                        {latest?.responseTime ? `${latest.responseTime}ms` : \"--\"}\n                      </p>\n                    </div>\n                  </div>\n\n                  {/* Mini Chart */}\n                  {history.length > 1 && (\n                    <div className=\"h-16 mb-4\">\n                      <ResponsiveContainer width=\"100%\" height=\"100%\">\n                        <LineChart data={history.map((h, i) => ({ i, status: h.status === \"up\" ? 1 : 0 }))}>\n                          <Line\n                            type=\"step\"\n                            dataKey=\"status\"\n                            stroke={isUp ? \"#22C55E\" : \"#EF4444\"}\n                            strokeWidth={2}\n                            dot={false}\n                          />\n                        </LineChart>\n                      </ResponsiveContainer>\n                    </div>\n                  )}\n\n                  {/* Actions */}\n                  <div className=\"flex gap-2\">\n                    <button\n                      onClick={(e) => {\n                        e.stopPropagation();\n                        checkApp(app);\n                      }}\n                      disabled={checking === app.id}\n                      className=\"flex-1 bg-slate-800 hover:bg-slate-700 text-slate-300 py-2 rounded-lg text-sm font-medium transition-colors\"\n                    >\n                      {checking === app.id ? \"Checking...\" : \"Check Now\"}\n                    </button>\n                    <a\n                      href={app.url}\n                      target=\"_blank\"\n                      rel=\"noopener noreferrer\"\n                      onClick={(e) => e.stopPropagation()}\n                      className=\"p-2 bg-slate-800 hover:bg-slate-700 text-slate-300 rounded-lg\"\n                    >\n                      <ExternalLink className=\"w-4 h-4\" />\n                    </a>\n                  </div>\n                </div>\n              );\n            })}\n          </div>\n        ) : (\n          /* List View */\n          <div className=\"space-y-2\">\n            {apps.map((app) => {\n              const { isUp, uptime, latest } = getAppStatus(app.id);\n              \n              return (\n                <div\n                  key={app.id}\n                  className={`flex items-center gap-4 bg-slate-900 rounded-lg border-l-4 p-4 ${\n                    isUp ? \"border-l-emerald-500\" : \"border-l-red-500\"\n                  }`}\n                >\n                  <div className={`w-3 h-3 rounded-full ${isUp ? \"bg-emerald-500\" : \"bg-red-500\"}`} />\n                  \n                  <div className=\"flex-1 min-w-0\">\n                    <h3 className=\"font-semibold text-white\">{app.name}</h3>\n                    <p className=\"text-sm text-slate-400 truncate\">{app.url}</p>\n                  </div>\n                  \n                  <div className=\"hidden sm:flex items-center gap-6 text-sm\">\n                    <div className=\"text-center\">\n                      <p className=\"text-slate-500\">Port</p>\n                      <p className=\"font-mono text-white\">{app.port}</p>\n                    </div>\n                    <div className=\"text-center\">\n                      <p className=\"text-slate-500\">Uptime</p>\n                      <p className={`font-mono ${uptime >= 90 ? \"text-emerald-400\" : \"text-yellow-400\"}`}>\n                        {uptime}%\n                      </p>\n                    </div>\n                    <div className=\"text-center\">\n                      <p className=\"text-slate-500\">Response</p>\n                      <p className=\"font-mono text-white\">\n                        {latest?.responseTime ? `${latest.responseTime}ms` : \"--\"}\n                      </p>\n                    </div>\n                  </div>\n                  \n                  <div className=\"flex items-center gap-2\">\n                    <button\n                      onClick={() => checkApp(app)}\n                      disabled={checking === app.id}\n                      className=\"p-2 text-slate-400 hover:text-white\"\n                    >\n                      <RefreshCw className={`w-4 h-4 ${checking === app.id ? \"animate-spin\" : \"\"}`} />\n                    </button>\n                    <a\n                      href={app.url}\n                      target=\"_blank\"\n                      rel=\"noopener noreferrer\"\n                      className=\"p-2 text-slate-400 hover:text-white\"\n                    >\n                      <ExternalLink className=\"w-4 h-4\" />\n                    </a>\n                    <button\n                      onClick={() => deleteApp(app.id)}\n                      className=\"p-2 text-slate-400 hover:text-red-400\"\n                    >\n                      <Trash2 className=\"w-4 h-4\" />\n                    </button>\n                  </div>\n                </div>\n              );\n            })}\n          </div>\n        )}\n      </main>\n\n      {/* Add App Modal */}\n      {showAddApp && (\n        <div className=\"fixed inset-0 bg-black/50 flex items-center justify-center z-50 p-4\">\n          <div className=\"bg-slate-900 rounded-xl p-6 w-full max-w-md\">\n            <h2 className=\"text-xl font-bold text-white mb-4\">Add New App</h2>\n            <form onSubmit={addApp} className=\"space-y-4\">\n              <div>\n                <label className=\"block text-sm text-slate-400 mb-1\">Name</label>\n                <input\n                  type=\"text\"\n                  value={newApp.name}\n                  onChange={(e) => setNewApp({ ...newApp, name: e.target.value })}\n                  className=\"w-full bg-slate-800 border border-slate-700 rounded-lg px-3 py-2 text-white\"\n                  required\n                />\n              </div>\n              <div>\n                <label className=\"block text-sm text-slate-400 mb-1\">Description</label>\n                <input\n                  type=\"text\"\n                  value={newApp.description}\n                  onChange={(e) => setNewApp({ ...newApp, description: e.target.value })}\n                  className=\"w-full bg-slate-800 border border-slate-700 rounded-lg px-3 py-2 text-white\"\n                />\n              </div>\n              <div className=\"grid grid-cols-2 gap-4\">\n                <div>\n                  <label className=\"block text-sm text-slate-400 mb-1\">URL</label>\n                  <input\n                    type=\"text\"\n                    value={newApp.url}\n                    onChange={(e) => setNewApp({ ...newApp, url: e.target.value })}\n                    className=\"w-full bg-slate-800 border border-slate-700 rounded-lg px-3 py-2 text-white\"\n                    required\n                  />\n                </div>\n                <div>\n                  <label className=\"block text-sm text-slate-400 mb-1\">Port</label>\n                  <input\n                    type=\"number\"\n                    value={newApp.port}\n                    onChange={(e) => setNewApp({ ...newApp, port: parseInt(e.target.value) })}\n                    className=\"w-full bg-slate-800 border border-slate-700 rounded-lg px-3 py-2 text-white\"\n                    required\n                  />\n                </div>\n              </div>\n              <div className=\"flex gap-3 pt-2\">\n                <button\n                  type=\"button\"\n                  onClick={() => setShowAddApp(false)}\n                  className=\"flex-1 bg-slate-800 hover:bg-slate-700 text-slate-300 py-2 rounded-lg\"\n                >\n                  Cancel\n                </button>\n                <button\n                  type=\"submit\"\n                  className=\"flex-1 bg-emerald-500 hover:bg-emerald-600 text-white py-2 rounded-lg font-medium\"\n                >\n                  Add App\n                </button>\n              </div>\n            </form>\n          </div>\n        </div>\n      )}\n\n      {/* App Detail Modal */}\n      {selectedApp && (\n        <div className=\"fixed inset-0 bg-black/50 flex items-center justify-center z-50 p-4\">\n          <div className=\"bg-slate-900 rounded-xl p-6 w-full max-w-lg\">\n            <div className=\"flex items-center justify-between mb-4\">\n              <h2 className=\"text-xl font-bold text-white\">{selectedApp.name}</h2>\n              <button\n                onClick={() => setSelectedApp(null)}\n                className=\"text-slate-400 hover:text-white\"\n              >\n                ✕\n              </button>\n            </div>\n            \n            <div className=\"space-y-4\">\n              <div className=\"grid grid-cols-2 gap-4\">\n                <div className=\"bg-slate-800 rounded-lg p-3\">\n                  <p className=\"text-sm text-slate-500\">URL</p>\n                  <p className=\"text-emerald-400 font-mono text-sm break-all\">{selectedApp.url}</p>\n                </div>\n                <div className=\"bg-slate-800 rounded-lg p-3\">\n                  <p className=\"text-sm text-slate-500\">Port</p>\n                  <p className=\"text-white font-mono\">{selectedApp.port}</p>\n                </div>\n              </div>\n              \n              <div className=\"flex gap-3\">\n                <button\n                  onClick={() => {\n                    checkApp(selectedApp);\n                    setSelectedApp(null);\n                  }}\n                  className=\"flex-1 bg-emerald-500 hover:bg-emerald-600 text-white py-2 rounded-lg font-medium\"\n                >\n                  Check Now\n                </button>\n                <button\n                  onClick={() => {\n                    deleteApp(selectedApp.id);\n                    setSelectedApp(null);\n                  }}\n                  className=\"flex-1 bg-red-500/20 hover:bg-red-500/30 text-red-400 py-2 rounded-lg font-medium\"\n                >\n                  Delete\n                </button>\n              </div>\n            </div>\n          </div>\n        </div>\n      )}\n    </div>\n  );\n}\n"],"names":["useState","useEffect","Activity","Plus","RefreshCw","Trash2","ExternalLink","LayoutGrid","List","LineChart","Line","ResponsiveContainer","HeartbeatMonitor","apps","setApps","status","setStatus","loading","setLoading","checking","setChecking","showAddApp","setShowAddApp","viewMode","setViewMode","selectedApp","setSelectedApp","newApp","setNewApp","name","description","url","port","path","command","category","color","enabled","fetchData","interval","setInterval","clearInterval","res","fetch","data","json","err","console","error","checkApp","app","id","start","Date","now","method","mode","responseTime","entry","appId","timestamp","toISOString","headers","body","JSON","stringify","action","addApp","e","preventDefault","deleteApp","confirm","getAppStatus","appStatus","filter","s","latest","length","isUp","uptime","Math","round","history","slice","totalApps","onlineApps","offlineApps","div","className","header","h1","p","button","onClick","main","map","span","h3","width","height","h","i","type","dataKey","stroke","strokeWidth","dot","stopPropagation","disabled","a","href","target","rel","h2","form","onSubmit","label","input","value","onChange","required","parseInt"],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(app-pages-browser)/./src/app/page.tsx\n"));
/***/ }),
/***/ "(app-pages-browser)/./node_modules/lucide-react/dist/esm/icons/layout-grid.js":
/*!*****************************************************************!*\
!*** ./node_modules/lucide-react/dist/esm/icons/layout-grid.js ***!
\*****************************************************************/
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
eval(__webpack_require__.ts("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ __iconNode: () => (/* binding */ __iconNode),\n/* harmony export */ \"default\": () => (/* binding */ LayoutGrid)\n/* harmony export */ });\n/* harmony import */ var _createLucideIcon_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../createLucideIcon.js */ \"(app-pages-browser)/./node_modules/lucide-react/dist/esm/createLucideIcon.js\");\n/**\n * @license lucide-react v0.474.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */ \nconst __iconNode = [\n [\n \"rect\",\n {\n width: \"7\",\n height: \"7\",\n x: \"3\",\n y: \"3\",\n rx: \"1\",\n key: \"1g98yp\"\n }\n ],\n [\n \"rect\",\n {\n width: \"7\",\n height: \"7\",\n x: \"14\",\n y: \"3\",\n rx: \"1\",\n key: \"6d4xhi\"\n }\n ],\n [\n \"rect\",\n {\n width: \"7\",\n height: \"7\",\n x: \"14\",\n y: \"14\",\n rx: \"1\",\n key: \"nxv5o0\"\n }\n ],\n [\n \"rect\",\n {\n width: \"7\",\n height: \"7\",\n x: \"3\",\n y: \"14\",\n rx: \"1\",\n key: \"1bb6yr\"\n }\n ]\n];\nconst LayoutGrid = (0,_createLucideIcon_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(\"LayoutGrid\", __iconNode);\n //# sourceMappingURL=layout-grid.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFwcC1wYWdlcy1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9sdWNpZGUtcmVhY3QvZGlzdC9lc20vaWNvbnMvbGF5b3V0LWdyaWQuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBR08sTUFBTSxVQUF1QjtJQUNsQztRQUFDLE9BQVE7UUFBQTtZQUFFLE9BQU87WUFBSyxDQUFRO1lBQUssQ0FBRztZQUFLLEdBQUcsQ0FBSztZQUFBLElBQUksQ0FBSztZQUFBLEtBQUs7UUFBQSxDQUFVO0tBQUE7SUFDNUU7UUFBQyxPQUFRO1FBQUE7WUFBRSxPQUFPO1lBQUssQ0FBUTtZQUFLLENBQUc7WUFBTSxHQUFHLENBQUs7WUFBQSxJQUFJLENBQUs7WUFBQSxLQUFLO1FBQUEsQ0FBVTtLQUFBO0lBQzdFO1FBQUMsT0FBUTtRQUFBO1lBQUUsT0FBTztZQUFLLENBQVE7WUFBSyxDQUFHO1lBQU0sR0FBRyxDQUFNO1lBQUEsSUFBSSxDQUFLO1lBQUEsS0FBSztRQUFBLENBQVU7S0FBQTtJQUM5RTtRQUFDLE9BQVE7UUFBQTtZQUFFLE9BQU87WUFBSyxDQUFRO1lBQUssQ0FBRztZQUFLLEdBQUcsQ0FBTTtZQUFBLElBQUksQ0FBSztZQUFBLEtBQUs7UUFBQSxDQUFVO0tBQUE7Q0FDL0U7QUFhTSxpQkFBYSxrRUFBaUIsZUFBYyxDQUFVIiwic291cmNlcyI6WyIvVXNlcnMvbWF0dGJydWNlL0RvY3VtZW50cy9Qcm9qZWN0cy9zcmMvaWNvbnMvbGF5b3V0LWdyaWQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNyZWF0ZUx1Y2lkZUljb24gZnJvbSAnLi4vY3JlYXRlTHVjaWRlSWNvbic7XG5pbXBvcnQgeyBJY29uTm9kZSB9IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IF9faWNvbk5vZGU6IEljb25Ob2RlID0gW1xuICBbJ3JlY3QnLCB7IHdpZHRoOiAnNycsIGhlaWdodDogJzcnLCB4OiAnMycsIHk6ICczJywgcng6ICcxJywga2V5OiAnMWc5OHlwJyB9XSxcbiAgWydyZWN0JywgeyB3aWR0aDogJzcnLCBoZWlnaHQ6ICc3JywgeDogJzE0JywgeTogJzMnLCByeDogJzEnLCBrZXk6ICc2ZDR4aGknIH1dLFxuICBbJ3JlY3QnLCB7IHdpZHRoOiAnNycsIGhlaWdodDogJzcnLCB4OiAnMTQnLCB5OiAnMTQnLCByeDogJzEnLCBrZXk6ICdueHY1bzAnIH1dLFxuICBbJ3JlY3QnLCB7IHdpZHRoOiAnNycsIGhlaWdodDogJzcnLCB4OiAnMycsIHk6ICcxNCcsIHJ4OiAnMScsIGtleTogJzFiYjZ5cicgfV0sXG5dO1xuXG4vKipcbiAqIEBjb21wb25lbnQgQG5hbWUgTGF5b3V0R3JpZFxuICogQGRlc2NyaXB0aW9uIEx1Y2lkZSBTVkcgaWNvbiBjb21wb25lbnQsIHJlbmRlcnMgU1ZHIEVsZW1lbnQgd2l0aCBjaGlsZHJlbi5cbiAqXG4gKiBAcHJldmlldyAhW2ltZ10oZGF0YTppbWFnZS9zdmcreG1sO2Jhc2U2NCxQSE4yWnlBZ2VHMXNibk05SW1oMGRIQTZMeTkzZDNjdWR6TXViM0puTHpJd01EQXZjM1puSWdvZ0lIZHBaSFJvUFNJeU5DSUtJQ0JvWldsbmFIUTlJakkwSWdvZ0lIWnBaWGRDYjNnOUlqQWdNQ0F5TkNBeU5DSUtJQ0JtYVd4c1BTSnViMjVsSWdvZ0lITjBjbTlyWlQwaUl6QXdNQ0lnYzNSNWJHVTlJbUpoWTJ0bmNtOTFibVF0WTI5c2IzSTZJQ05tWm1ZN0lHSnZjbVJsY2kxeVlXUnBkWE02SURKd2VDSUtJQ0J6ZEhKdmEyVXRkMmxrZEdnOUlqSWlDaUFnYzNSeWIydGxMV3hwYm1WallYQTlJbkp2ZFc1a0lnb2dJSE4wY205clpTMXNhVzVsYW05cGJqMGljbTkxYm1RaUNqNEtJQ0E4Y21WamRDQjNhV1IwYUQwaU55SWdhR1ZwWjJoMFBTSTNJaUI0UFNJeklpQjVQU0l6SWlCeWVEMGlNU0lnTHo0S0lDQThjbVZqZENCM2FXUjBhRDBpTnlJZ2FHVnBaMmgwUFNJM0lpQjRQU0l4TkNJZ2VUMGlNeUlnY25nOUlqRWlJQzgrQ2lBZ1BISmxZM1FnZDJsa2RHZzlJamNpSUdobGFXZG9kRDBpTnlJZ2VEMGlNVFFpSUhrOUlqRTBJaUJ5ZUQwaU1TSWdMejRLSUNBOGNtVmpkQ0IzYVdSMGFEMGlOeUlnYUdWcFoyaDBQU0kzSWlCNFBTSXpJaUI1UFNJeE5DSWdjbmc5SWpFaUlDOCtDand2YzNablBnbz0pIC0gaHR0cHM6Ly9sdWNpZGUuZGV2L2ljb25zL2xheW91dC1ncmlkXG4gKiBAc2VlIGh0dHBzOi8vbHVjaWRlLmRldi9ndWlkZS9wYWNrYWdlcy9sdWNpZGUtcmVhY3QgLSBEb2N1bWVudGF0aW9uXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IHByb3BzIC0gTHVjaWRlIGljb25zIHByb3BzIGFuZCBhbnkgdmFsaWQgU1ZHIGF0dHJpYnV0ZVxuICogQHJldHVybnMge0pTWC5FbGVtZW50fSBKU1ggRWxlbWVudFxuICpcbiAqL1xuY29uc3QgTGF5b3V0R3JpZCA9IGNyZWF0ZUx1Y2lkZUljb24oJ0xheW91dEdyaWQnLCBfX2ljb25Ob2RlKTtcblxuZXhwb3J0IGRlZmF1bHQgTGF5b3V0R3JpZDtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(app-pages-browser)/./node_modules/lucide-react/dist/esm/icons/layout-grid.js\n"));
/***/ }),
/***/ "(app-pages-browser)/./node_modules/lucide-react/dist/esm/icons/list.js":
/*!**********************************************************!*\
!*** ./node_modules/lucide-react/dist/esm/icons/list.js ***!
\**********************************************************/
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
eval(__webpack_require__.ts("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ __iconNode: () => (/* binding */ __iconNode),\n/* harmony export */ \"default\": () => (/* binding */ List)\n/* harmony export */ });\n/* harmony import */ var _createLucideIcon_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../createLucideIcon.js */ \"(app-pages-browser)/./node_modules/lucide-react/dist/esm/createLucideIcon.js\");\n/**\n * @license lucide-react v0.474.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */ \nconst __iconNode = [\n [\n \"path\",\n {\n d: \"M3 12h.01\",\n key: \"nlz23k\"\n }\n ],\n [\n \"path\",\n {\n d: \"M3 18h.01\",\n key: \"1tta3j\"\n }\n ],\n [\n \"path\",\n {\n d: \"M3 6h.01\",\n key: \"1rqtza\"\n }\n ],\n [\n \"path\",\n {\n d: \"M8 12h13\",\n key: \"1za7za\"\n }\n ],\n [\n \"path\",\n {\n d: \"M8 18h13\",\n key: \"1lx6n3\"\n }\n ],\n [\n \"path\",\n {\n d: \"M8 6h13\",\n key: \"ik3vkj\"\n }\n ]\n];\nconst List = (0,_createLucideIcon_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(\"List\", __iconNode);\n //# sourceMappingURL=list.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFwcC1wYWdlcy1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9sdWNpZGUtcmVhY3QvZGlzdC9lc20vaWNvbnMvbGlzdC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFHTyxNQUFNLFVBQXVCO0lBQ2xDO1FBQUMsTUFBUTtRQUFBO1lBQUUsR0FBRyxDQUFhO1lBQUEsS0FBSztRQUFBLENBQVU7S0FBQTtJQUMxQztRQUFDLE1BQVE7UUFBQTtZQUFFLEdBQUcsQ0FBYTtZQUFBLEtBQUs7UUFBQSxDQUFVO0tBQUE7SUFDMUM7UUFBQyxNQUFRO1FBQUE7WUFBRSxHQUFHLENBQVk7WUFBQSxLQUFLO1FBQUEsQ0FBVTtLQUFBO0lBQ3pDO1FBQUMsTUFBUTtRQUFBO1lBQUUsR0FBRyxDQUFZO1lBQUEsS0FBSztRQUFBLENBQVU7S0FBQTtJQUN6QztRQUFDLE1BQVE7UUFBQTtZQUFFLEdBQUcsQ0FBWTtZQUFBLEtBQUs7UUFBQSxDQUFVO0tBQUE7SUFDekM7UUFBQyxNQUFRO1FBQUE7WUFBRSxHQUFHLENBQVc7WUFBQSxLQUFLO1FBQUEsQ0FBVTtLQUFBO0NBQzFDO0FBYU0sV0FBTyxrRUFBaUIsU0FBUSxDQUFVIiwic291cmNlcyI6WyIvVXNlcnMvbWF0dGJydWNlL0RvY3VtZW50cy9Qcm9qZWN0cy9zcmMvaWNvbnMvbGlzdC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY3JlYXRlTHVjaWRlSWNvbiBmcm9tICcuLi9jcmVhdGVMdWNpZGVJY29uJztcbmltcG9ydCB7IEljb25Ob2RlIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgX19pY29uTm9kZTogSWNvbk5vZGUgPSBbXG4gIFsncGF0aCcsIHsgZDogJ00zIDEyaC4wMScsIGtleTogJ25sejIzaycgfV0sXG4gIFsncGF0aCcsIHsgZDogJ00zIDE4aC4wMScsIGtleTogJzF0dGEzaicgfV0sXG4gIFsncGF0aCcsIHsgZDogJ00zIDZoLjAxJywga2V5OiAnMXJxdHphJyB9XSxcbiAgWydwYXRoJywgeyBkOiAnTTggMTJoMTMnLCBrZXk6ICcxemE3emEnIH1dLFxuICBbJ3BhdGgnLCB7IGQ6ICdNOCAxOGgxMycsIGtleTogJzFseDZuMycgfV0sXG4gIFsncGF0aCcsIHsgZDogJ004IDZoMTMnLCBrZXk6ICdpazN2a2onIH1dLFxuXTtcblxuLyoqXG4gKiBAY29tcG9uZW50IEBuYW1lIExpc3RcbiAqIEBkZXNjcmlwdGlvbiBMdWNpZGUgU1ZHIGljb24gY29tcG9uZW50LCByZW5kZXJzIFNWRyBFbGVtZW50IHdpdGggY2hpbGRyZW4uXG4gKlxuICogQHByZXZpZXcgIVtpbWddKGRhdGE6aW1hZ2Uvc3ZnK3htbDtiYXNlNjQsUEhOMlp5QWdlRzFzYm5NOUltaDBkSEE2THk5M2QzY3Vkek11YjNKbkx6SXdNREF2YzNabklnb2dJSGRwWkhSb1BTSXlOQ0lLSUNCb1pXbG5hSFE5SWpJMElnb2dJSFpwWlhkQ2IzZzlJakFnTUNBeU5DQXlOQ0lLSUNCbWFXeHNQU0p1YjI1bElnb2dJSE4wY205clpUMGlJekF3TUNJZ2MzUjViR1U5SW1KaFkydG5jbTkxYm1RdFkyOXNiM0k2SUNObVptWTdJR0p2Y21SbGNpMXlZV1JwZFhNNklESndlQ0lLSUNCemRISnZhMlV0ZDJsa2RHZzlJaklpQ2lBZ2MzUnliMnRsTFd4cGJtVmpZWEE5SW5KdmRXNWtJZ29nSUhOMGNtOXJaUzFzYVc1bGFtOXBiajBpY205MWJtUWlDajRLSUNBOGNHRjBhQ0JrUFNKTk15QXhNbWd1TURFaUlDOCtDaUFnUEhCaGRHZ2daRDBpVFRNZ01UaG9MakF4SWlBdlBnb2dJRHh3WVhSb0lHUTlJazB6SURab0xqQXhJaUF2UGdvZ0lEeHdZWFJvSUdROUlrMDRJREV5YURFeklpQXZQZ29nSUR4d1lYUm9JR1E5SWswNElERTRhREV6SWlBdlBnb2dJRHh3WVhSb0lHUTlJazA0SURab01UTWlJQzgrQ2p3dmMzWm5QZ289KSAtIGh0dHBzOi8vbHVjaWRlLmRldi9pY29ucy9saXN0XG4gKiBAc2VlIGh0dHBzOi8vbHVjaWRlLmRldi9ndWlkZS9wYWNrYWdlcy9sdWNpZGUtcmVhY3QgLSBEb2N1bWVudGF0aW9uXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IHByb3BzIC0gTHVjaWRlIGljb25zIHByb3BzIGFuZCBhbnkgdmFsaWQgU1ZHIGF0dHJpYnV0ZVxuICogQHJldHVybnMge0pTWC5FbGVtZW50fSBKU1ggRWxlbWVudFxuICpcbiAqL1xuY29uc3QgTGlzdCA9IGNyZWF0ZUx1Y2lkZUljb24oJ0xpc3QnLCBfX2ljb25Ob2RlKTtcblxuZXhwb3J0IGRlZmF1bHQgTGlzdDtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(app-pages-browser)/./node_modules/lucide-react/dist/esm/icons/list.js\n"));
/***/ })
});