react-terminal-viewer-cicd 2.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +181 -0
- package/dist/esm/Addon/EventEmiter.d.ts +18 -0
- package/dist/esm/Addon/EventEmiter.js +64 -0
- package/dist/esm/Addon/HighlightAddon.d.ts +26 -0
- package/dist/esm/Addon/HighlightAddon.js +188 -0
- package/dist/esm/Addon/SearchAddon.d.ts +140 -0
- package/dist/esm/Addon/SearchAddon.js +797 -0
- package/dist/esm/Addon/WorkerLog/GlobalContext.d.ts +10 -0
- package/dist/esm/Addon/WorkerLog/GlobalContext.js +37 -0
- package/dist/esm/Addon/WorkerLog/LimitMap.d.ts +14 -0
- package/dist/esm/Addon/WorkerLog/LimitMap.js +54 -0
- package/dist/esm/Addon/WorkerLog/LogWorker.d.ts +2 -0
- package/dist/esm/Addon/WorkerLog/LogWorker.js +13 -0
- package/dist/esm/Addon/WorkerLog/Logs.d.ts +21 -0
- package/dist/esm/Addon/WorkerLog/Logs.js +60 -0
- package/dist/esm/Addon/WorkerLog/Mark.d.ts +36 -0
- package/dist/esm/Addon/WorkerLog/Mark.js +155 -0
- package/dist/esm/Addon/WorkerLog/Searcher.d.ts +16 -0
- package/dist/esm/Addon/WorkerLog/Searcher.js +88 -0
- package/dist/esm/Addon/WorkerLog/WebWokerServer.d.ts +10 -0
- package/dist/esm/Addon/WorkerLog/WebWokerServer.js +57 -0
- package/dist/esm/Addon/WorkerLog/WebWorkerClient.d.ts +13 -0
- package/dist/esm/Addon/WorkerLog/WebWorkerClient.js +83 -0
- package/dist/esm/Addon/WorkerLog/log.worker.d.ts +1 -0
- package/dist/esm/Addon/WorkerLog/log.worker.js +63 -0
- package/dist/esm/Addon/WorkerLog/types.d.ts +18 -0
- package/dist/esm/Addon/WorkerLog/types.js +1 -0
- package/dist/esm/Addon/useAddon.d.ts +9 -0
- package/dist/esm/Addon/useAddon.js +33 -0
- package/dist/esm/Hooks/useBatchProcess.d.ts +2 -0
- package/dist/esm/Hooks/useBatchProcess.js +47 -0
- package/dist/esm/Hooks/useCache.d.ts +31 -0
- package/dist/esm/Hooks/useCache.js +206 -0
- package/dist/esm/Hooks/useDebounceInput.d.ts +3 -0
- package/dist/esm/Hooks/useDebounceInput.js +26 -0
- package/dist/esm/Hooks/useLocalStore.d.ts +2 -0
- package/dist/esm/Hooks/useLocalStore.js +9 -0
- package/dist/esm/Hooks/useRemote.d.ts +30 -0
- package/dist/esm/Hooks/useRemote.js +398 -0
- package/dist/esm/Hooks/useThrottle.d.ts +2 -0
- package/dist/esm/Hooks/useThrottle.js +13 -0
- package/dist/esm/Hooks/useWorkerLogs.d.ts +9 -0
- package/dist/esm/Hooks/useWorkerLogs.js +162 -0
- package/dist/esm/TerminalViewer/index.d.ts +185 -0
- package/dist/esm/TerminalViewer/index.js +292 -0
- package/dist/esm/TerminalViewer/index.less +17 -0
- package/dist/esm/TerminalViewerBody/index.d.ts +87 -0
- package/dist/esm/TerminalViewerBody/index.js +248 -0
- package/dist/esm/TerminalViewerBody/index.less +51 -0
- package/dist/esm/TerminalViewerHeader/index.d.ts +88 -0
- package/dist/esm/TerminalViewerHeader/index.js +129 -0
- package/dist/esm/TerminalViewerHeader/index.less +143 -0
- package/dist/esm/TerminalViewerToolBar/index.d.ts +46 -0
- package/dist/esm/TerminalViewerToolBar/index.js +28 -0
- package/dist/esm/TerminalViewerToolBar/index.less +32 -0
- package/dist/esm/TerminalViewerVirtualDom/index.d.ts +71 -0
- package/dist/esm/TerminalViewerVirtualDom/index.js +309 -0
- package/dist/esm/TerminalViewerVirtualDom/index.less +68 -0
- package/dist/esm/index.d.ts +9 -0
- package/dist/esm/index.js +9 -0
- package/dist/esm/mock/index.d.ts +12 -0
- package/dist/esm/mock/index.js +98 -0
- package/dist/esm/types.d.ts +30 -0
- package/dist/esm/types.js +1 -0
- package/dist/worker/Addon/EventEmiter.d.ts +18 -0
- package/dist/worker/Addon/HighlightAddon.d.ts +26 -0
- package/dist/worker/Addon/SearchAddon.d.ts +140 -0
- package/dist/worker/Addon/WorkerLog/GlobalContext.d.ts +10 -0
- package/dist/worker/Addon/WorkerLog/LimitMap.d.ts +14 -0
- package/dist/worker/Addon/WorkerLog/LogWorker.d.ts +2 -0
- package/dist/worker/Addon/WorkerLog/Logs.d.ts +21 -0
- package/dist/worker/Addon/WorkerLog/Mark.d.ts +36 -0
- package/dist/worker/Addon/WorkerLog/Searcher.d.ts +16 -0
- package/dist/worker/Addon/WorkerLog/WebWokerServer.d.ts +10 -0
- package/dist/worker/Addon/WorkerLog/WebWorkerClient.d.ts +13 -0
- package/dist/worker/Addon/WorkerLog/log.worker.d.ts +1 -0
- package/dist/worker/Addon/WorkerLog/types.d.ts +18 -0
- package/dist/worker/Addon/useAddon.d.ts +9 -0
- package/dist/worker/Hooks/useBatchProcess.d.ts +2 -0
- package/dist/worker/Hooks/useCache.d.ts +31 -0
- package/dist/worker/Hooks/useDebounceInput.d.ts +3 -0
- package/dist/worker/Hooks/useLocalStore.d.ts +2 -0
- package/dist/worker/Hooks/useRemote.d.ts +30 -0
- package/dist/worker/Hooks/useRemote.test.d.ts +1 -0
- package/dist/worker/Hooks/useThrottle.d.ts +2 -0
- package/dist/worker/Hooks/useWorkerLogs.d.ts +9 -0
- package/dist/worker/TerminalViewer/index.d.ts +185 -0
- package/dist/worker/TerminalViewer/index.test.d.ts +1 -0
- package/dist/worker/TerminalViewerBody/index.d.ts +87 -0
- package/dist/worker/TerminalViewerBody/index.test.d.ts +1 -0
- package/dist/worker/TerminalViewerHeader/index.d.ts +88 -0
- package/dist/worker/TerminalViewerToolBar/index.d.ts +46 -0
- package/dist/worker/TerminalViewerVirtualDom/index.d.ts +71 -0
- package/dist/worker/index.d.ts +9 -0
- package/dist/worker/log.worker.js +2 -0
- package/dist/worker/log.worker.js.map +1 -0
- package/dist/worker/mock/index.d.ts +12 -0
- package/dist/worker/types.d.ts +30 -0
- package/package.json +97 -0
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
function _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); }
|
|
2
|
+
function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, catch: function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
|
|
3
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
|
|
4
|
+
function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
|
|
5
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
6
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
7
|
+
function _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); }
|
|
8
|
+
function _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; }
|
|
9
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
10
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
11
|
+
function 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; }
|
|
12
|
+
function _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; }
|
|
13
|
+
function _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; }
|
|
14
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
|
|
15
|
+
function _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); }
|
|
16
|
+
import React, { forwardRef, useState, useEffect, useRef, useImperativeHandle } from 'react';
|
|
17
|
+
import { Terminal } from 'xterm';
|
|
18
|
+
import 'xterm/css/xterm.css';
|
|
19
|
+
import { FitAddon } from 'xterm-addon-fit';
|
|
20
|
+
import { WebLinksAddon } from 'xterm-addon-web-links';
|
|
21
|
+
import { CanvasAddon } from 'xterm-addon-canvas';
|
|
22
|
+
import { SearchAddon } from "../Addon/SearchAddon";
|
|
23
|
+
import { HighlightAddon } from "../Addon/HighlightAddon";
|
|
24
|
+
import useAddon from "../Addon/useAddon";
|
|
25
|
+
import useRemote from "../Hooks/useRemote";
|
|
26
|
+
import useThrottle from "../Hooks/useThrottle";
|
|
27
|
+
import "./index.less";
|
|
28
|
+
var defaultTerminalOptions = {
|
|
29
|
+
cursorBlink: false,
|
|
30
|
+
convertEol: false,
|
|
31
|
+
scrollback: Number.MAX_SAFE_INTEGER,
|
|
32
|
+
drawBoldTextInBrightColors: false,
|
|
33
|
+
allowProposedApi: true,
|
|
34
|
+
allowTransparency: true,
|
|
35
|
+
fontSize: 13,
|
|
36
|
+
fontFamily: 'Roboto Mono,Andale Mono,Consolas,Courier New,monospace',
|
|
37
|
+
lineHeight: 20 / 17,
|
|
38
|
+
fastScrollSensitivity: 35
|
|
39
|
+
};
|
|
40
|
+
var defaultTheme = {
|
|
41
|
+
selectionBackground: '#30363d',
|
|
42
|
+
selectionForeground: '#b5bbc6',
|
|
43
|
+
background: '#24292e',
|
|
44
|
+
foreground: '#b5bbc6'
|
|
45
|
+
};
|
|
46
|
+
var mergeOptions = function mergeOptions(options) {
|
|
47
|
+
var localOptions = options !== null && options !== void 0 ? options : {};
|
|
48
|
+
return _objectSpread(_objectSpread(_objectSpread({}, defaultTerminalOptions), localOptions), {}, {
|
|
49
|
+
theme: _objectSpread(_objectSpread({}, defaultTheme), localOptions.theme || defaultTheme)
|
|
50
|
+
});
|
|
51
|
+
};
|
|
52
|
+
// eslint-disable-next-line react/display-name
|
|
53
|
+
var TerminalViewerBody = /*#__PURE__*/forwardRef(function (_ref, ref) {
|
|
54
|
+
var fitProp = _ref.fit,
|
|
55
|
+
autoScrollProp = _ref.autoScroll,
|
|
56
|
+
className = _ref.className,
|
|
57
|
+
empty = _ref.empty,
|
|
58
|
+
webLinksSupportProp = _ref.webLinksSupport,
|
|
59
|
+
canvasSupport = _ref.canvasSupport,
|
|
60
|
+
remoteOptions = _ref.remoteOptions,
|
|
61
|
+
cacheOptions = _ref.cacheOptions,
|
|
62
|
+
highlightOptions = _ref.highlightOptions,
|
|
63
|
+
terminalOptions = _ref.terminalOptions,
|
|
64
|
+
_ref$defaultData = _ref.defaultData,
|
|
65
|
+
defaultData = _ref$defaultData === void 0 ? '' : _ref$defaultData,
|
|
66
|
+
onAddonReady = _ref.onAddonReady,
|
|
67
|
+
onLoading = _ref.onLoading;
|
|
68
|
+
var mountedRef = useRef(false);
|
|
69
|
+
var exposedRef = useRef({
|
|
70
|
+
terminal: undefined,
|
|
71
|
+
addons: undefined,
|
|
72
|
+
refresh: undefined
|
|
73
|
+
});
|
|
74
|
+
var autoScrollRef = useRef(autoScrollProp !== null && autoScrollProp !== void 0 ? autoScrollProp : true);
|
|
75
|
+
var terminalOptionsRef = useRef(mergeOptions(terminalOptions));
|
|
76
|
+
var _useState = useState(),
|
|
77
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
78
|
+
terminalInstance = _useState2[0],
|
|
79
|
+
setTerminalInstance = _useState2[1];
|
|
80
|
+
var fit = fitProp !== null && fitProp !== void 0 ? fitProp : true;
|
|
81
|
+
var webLinksSupport = webLinksSupportProp !== null && webLinksSupportProp !== void 0 ? webLinksSupportProp : true;
|
|
82
|
+
var domRef = useRef(null);
|
|
83
|
+
var handleAddonReady = function handleAddonReady(terminal, addon) {
|
|
84
|
+
if (terminal && addon && onAddonReady instanceof Function) {
|
|
85
|
+
onAddonReady(terminal, addon);
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
var canvasInstance = useAddon(terminalInstance, CanvasAddon, !!terminalInstance && !!canvasSupport, handleAddonReady);
|
|
89
|
+
var webLinksInstance = useAddon(terminalInstance, WebLinksAddon, !!terminalInstance && webLinksSupport, handleAddonReady);
|
|
90
|
+
var fitInstance = useAddon(terminalInstance, FitAddon, !!terminalInstance && fit, handleAddonReady);
|
|
91
|
+
var searcherInstance = useAddon(terminalInstance, SearchAddon, !!terminalInstance, handleAddonReady);
|
|
92
|
+
var highlightInstance = useAddon(terminalInstance, HighlightAddon, !!terminalInstance && !!highlightOptions, function (terminal, instance) {
|
|
93
|
+
var hInstance = instance;
|
|
94
|
+
if (hInstance) {
|
|
95
|
+
hInstance.highlight(highlightOptions);
|
|
96
|
+
handleAddonReady(terminal, hInstance);
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
var throttleFit = useThrottle(function () {
|
|
100
|
+
if (mountedRef.current && fitInstance !== null && fitInstance !== void 0 && fitInstance.fit) {
|
|
101
|
+
fitInstance.fit();
|
|
102
|
+
}
|
|
103
|
+
}, 3000);
|
|
104
|
+
var _useRemote = useRemote(defaultData, function (string) {
|
|
105
|
+
if (terminalInstance && mountedRef.current && string) {
|
|
106
|
+
terminalInstance.write(string, function () {
|
|
107
|
+
if (!autoScrollRef.current) {
|
|
108
|
+
terminalInstance.scrollToLine(0);
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
}, remoteOptions, cacheOptions),
|
|
113
|
+
refresh = _useRemote.refresh,
|
|
114
|
+
data = _useRemote.data,
|
|
115
|
+
loading = _useRemote.loading,
|
|
116
|
+
cacheStore = _useRemote.cacheStore;
|
|
117
|
+
useEffect(function () {
|
|
118
|
+
terminalOptionsRef.current = mergeOptions(terminalOptions);
|
|
119
|
+
autoScrollRef.current = autoScrollProp !== null && autoScrollProp !== void 0 ? autoScrollProp : true;
|
|
120
|
+
});
|
|
121
|
+
// 初始化 xterm
|
|
122
|
+
useEffect(function () {
|
|
123
|
+
var instance = new Terminal(terminalOptionsRef.current);
|
|
124
|
+
setTerminalInstance(instance);
|
|
125
|
+
return function () {
|
|
126
|
+
instance.dispose();
|
|
127
|
+
};
|
|
128
|
+
}, []);
|
|
129
|
+
|
|
130
|
+
// 挂载 xterm
|
|
131
|
+
useEffect(function () {
|
|
132
|
+
if (domRef.current) {
|
|
133
|
+
terminalInstance === null || terminalInstance === void 0 || terminalInstance.open(domRef.current);
|
|
134
|
+
mountedRef.current = true;
|
|
135
|
+
}
|
|
136
|
+
return function () {
|
|
137
|
+
terminalInstance === null || terminalInstance === void 0 || terminalInstance.clear();
|
|
138
|
+
mountedRef.current = false;
|
|
139
|
+
};
|
|
140
|
+
}, [terminalInstance]);
|
|
141
|
+
|
|
142
|
+
// 渲染数据
|
|
143
|
+
useEffect(function () {
|
|
144
|
+
if (terminalInstance && defaultData) {
|
|
145
|
+
terminalInstance.write(defaultData);
|
|
146
|
+
}
|
|
147
|
+
}, [terminalInstance, defaultData]);
|
|
148
|
+
useEffect(function () {
|
|
149
|
+
var resizeObserver = new ResizeObserver(throttleFit);
|
|
150
|
+
var dom = domRef.current;
|
|
151
|
+
if (dom) {
|
|
152
|
+
resizeObserver.observe(dom);
|
|
153
|
+
}
|
|
154
|
+
return function () {
|
|
155
|
+
if (dom) {
|
|
156
|
+
resizeObserver.unobserve(dom);
|
|
157
|
+
resizeObserver.disconnect();
|
|
158
|
+
}
|
|
159
|
+
};
|
|
160
|
+
}, [fitInstance, throttleFit]);
|
|
161
|
+
useEffect(function () {
|
|
162
|
+
if (typeof onLoading === 'function') {
|
|
163
|
+
onLoading(loading);
|
|
164
|
+
}
|
|
165
|
+
}, [loading, onLoading]);
|
|
166
|
+
useEffect(function () {
|
|
167
|
+
exposedRef.current.terminal = terminalInstance;
|
|
168
|
+
exposedRef.current.addons = {
|
|
169
|
+
search: searcherInstance,
|
|
170
|
+
fit: fitInstance,
|
|
171
|
+
webLinks: webLinksInstance,
|
|
172
|
+
highlight: highlightInstance,
|
|
173
|
+
canvas: canvasInstance
|
|
174
|
+
};
|
|
175
|
+
exposedRef.current.refresh = /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
|
|
176
|
+
var _exposedRef$current;
|
|
177
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
178
|
+
while (1) switch (_context.prev = _context.next) {
|
|
179
|
+
case 0:
|
|
180
|
+
_context.next = 2;
|
|
181
|
+
return refresh();
|
|
182
|
+
case 2:
|
|
183
|
+
(_exposedRef$current = exposedRef.current) === null || _exposedRef$current === void 0 || (_exposedRef$current = _exposedRef$current.terminal) === null || _exposedRef$current === void 0 || _exposedRef$current.clear();
|
|
184
|
+
case 3:
|
|
185
|
+
case "end":
|
|
186
|
+
return _context.stop();
|
|
187
|
+
}
|
|
188
|
+
}, _callee);
|
|
189
|
+
}));
|
|
190
|
+
});
|
|
191
|
+
useImperativeHandle(ref, function () {
|
|
192
|
+
return {
|
|
193
|
+
el: domRef.current,
|
|
194
|
+
refresh: function () {
|
|
195
|
+
var _refresh = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2() {
|
|
196
|
+
var _exposedRef$current2;
|
|
197
|
+
return _regeneratorRuntime().wrap(function _callee2$(_context2) {
|
|
198
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
199
|
+
case 0:
|
|
200
|
+
return _context2.abrupt("return", ((_exposedRef$current2 = exposedRef.current) === null || _exposedRef$current2 === void 0 ? void 0 : _exposedRef$current2.refresh) && exposedRef.current.refresh());
|
|
201
|
+
case 1:
|
|
202
|
+
case "end":
|
|
203
|
+
return _context2.stop();
|
|
204
|
+
}
|
|
205
|
+
}, _callee2);
|
|
206
|
+
}));
|
|
207
|
+
function refresh() {
|
|
208
|
+
return _refresh.apply(this, arguments);
|
|
209
|
+
}
|
|
210
|
+
return refresh;
|
|
211
|
+
}(),
|
|
212
|
+
addons: {
|
|
213
|
+
search: function search() {
|
|
214
|
+
var _exposedRef$current3;
|
|
215
|
+
return (_exposedRef$current3 = exposedRef.current) === null || _exposedRef$current3 === void 0 || (_exposedRef$current3 = _exposedRef$current3.addons) === null || _exposedRef$current3 === void 0 ? void 0 : _exposedRef$current3.search;
|
|
216
|
+
},
|
|
217
|
+
fit: function fit() {
|
|
218
|
+
var _exposedRef$current4;
|
|
219
|
+
return (_exposedRef$current4 = exposedRef.current) === null || _exposedRef$current4 === void 0 || (_exposedRef$current4 = _exposedRef$current4.addons) === null || _exposedRef$current4 === void 0 ? void 0 : _exposedRef$current4.fit;
|
|
220
|
+
},
|
|
221
|
+
webLinks: function webLinks() {
|
|
222
|
+
var _exposedRef$current5;
|
|
223
|
+
return (_exposedRef$current5 = exposedRef.current) === null || _exposedRef$current5 === void 0 || (_exposedRef$current5 = _exposedRef$current5.addons) === null || _exposedRef$current5 === void 0 ? void 0 : _exposedRef$current5.webLinks;
|
|
224
|
+
},
|
|
225
|
+
highlight: function highlight() {
|
|
226
|
+
var _exposedRef$current6;
|
|
227
|
+
return (_exposedRef$current6 = exposedRef.current) === null || _exposedRef$current6 === void 0 || (_exposedRef$current6 = _exposedRef$current6.addons) === null || _exposedRef$current6 === void 0 ? void 0 : _exposedRef$current6.highlight;
|
|
228
|
+
},
|
|
229
|
+
canvas: function canvas() {
|
|
230
|
+
var _exposedRef$current$a;
|
|
231
|
+
return (_exposedRef$current$a = exposedRef.current.addons) === null || _exposedRef$current$a === void 0 ? void 0 : _exposedRef$current$a.canvas;
|
|
232
|
+
}
|
|
233
|
+
},
|
|
234
|
+
cacheStore: cacheStore,
|
|
235
|
+
terminal: function terminal() {
|
|
236
|
+
var _exposedRef$current7;
|
|
237
|
+
return (_exposedRef$current7 = exposedRef.current) === null || _exposedRef$current7 === void 0 ? void 0 : _exposedRef$current7.terminal;
|
|
238
|
+
}
|
|
239
|
+
};
|
|
240
|
+
});
|
|
241
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
242
|
+
className: ['terminal-viewer-body', className].filter(Boolean).join(' '),
|
|
243
|
+
ref: domRef
|
|
244
|
+
}, (data === null || data === void 0 ? void 0 : data.length) === 0 && (empty || /*#__PURE__*/React.createElement("div", {
|
|
245
|
+
className: "terminal-viewer-body-empty"
|
|
246
|
+
}, "\u6682\u65E0\u6570\u636E")));
|
|
247
|
+
});
|
|
248
|
+
export default TerminalViewerBody;
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
.terminal-viewer-body {
|
|
2
|
+
position: relative;
|
|
3
|
+
display: flex;
|
|
4
|
+
flex-direction: column;
|
|
5
|
+
width: 100%;
|
|
6
|
+
height: 100%;
|
|
7
|
+
overflow: hidden;
|
|
8
|
+
background: #24292e;
|
|
9
|
+
|
|
10
|
+
.terminal.xterm {
|
|
11
|
+
padding: 16px;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
// canvas 模式
|
|
15
|
+
.xterm-cursor-layer {
|
|
16
|
+
display: none;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
// dom 模式
|
|
20
|
+
.xterm-cursor {
|
|
21
|
+
color: inherit !important;
|
|
22
|
+
background: transparent !important;
|
|
23
|
+
outline: none !important;
|
|
24
|
+
outline-offset: 0 !important;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
.xterm-rows {
|
|
28
|
+
will-change: contents;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
// dom 模式下的搜索高亮
|
|
32
|
+
.xterm-decoration-top {
|
|
33
|
+
color: #000;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// 关键字渲染无法右键复制
|
|
37
|
+
.xterm-decoration {
|
|
38
|
+
pointer-events: none;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
.terminal-viewer-body-empty {
|
|
43
|
+
position: absolute;
|
|
44
|
+
z-index: 1600;
|
|
45
|
+
display: flex;
|
|
46
|
+
align-items: center;
|
|
47
|
+
justify-content: center;
|
|
48
|
+
width: 100%;
|
|
49
|
+
height: 100%;
|
|
50
|
+
color: #b5bbc6;
|
|
51
|
+
}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import './index.less';
|
|
3
|
+
export interface TerminalViewerHeaderProps {
|
|
4
|
+
/**
|
|
5
|
+
* @description.zh-CN 搜索框 placeholder
|
|
6
|
+
* @default 请输入
|
|
7
|
+
*/
|
|
8
|
+
placeholder?: string;
|
|
9
|
+
/**
|
|
10
|
+
* @description.zh-CN 搜索框默认内容
|
|
11
|
+
*
|
|
12
|
+
*/
|
|
13
|
+
defaultValue?: string;
|
|
14
|
+
/**
|
|
15
|
+
* @description.zh-CN 是否支持清除搜索框
|
|
16
|
+
* @default true
|
|
17
|
+
*/
|
|
18
|
+
clearable?: string;
|
|
19
|
+
/**
|
|
20
|
+
* @description.zh-CN 是否支持刷新
|
|
21
|
+
*/
|
|
22
|
+
refreshable?: boolean;
|
|
23
|
+
/**
|
|
24
|
+
* @description.zh-CN 是否处于加载状态
|
|
25
|
+
*/
|
|
26
|
+
loading?: boolean;
|
|
27
|
+
/**
|
|
28
|
+
* @description.zh-CN 搜索结果
|
|
29
|
+
*/
|
|
30
|
+
searchResult?: {
|
|
31
|
+
resultIndex: number;
|
|
32
|
+
resultCount: number;
|
|
33
|
+
};
|
|
34
|
+
/**
|
|
35
|
+
* @description.zh-CN 激活的标题
|
|
36
|
+
* @default 0;
|
|
37
|
+
*/
|
|
38
|
+
activeTitleIndex?: number;
|
|
39
|
+
/**
|
|
40
|
+
* @description.zh-CN Tab 标题
|
|
41
|
+
*/
|
|
42
|
+
titles?: React.ReactNode[] | number[];
|
|
43
|
+
/**
|
|
44
|
+
* @description.zh-CN 搜索框前的内容
|
|
45
|
+
*/
|
|
46
|
+
inputAddonBefore?: React.ReactNode;
|
|
47
|
+
/**
|
|
48
|
+
* @description.zh-CN 搜索框后的内容
|
|
49
|
+
*/
|
|
50
|
+
inputAddonAfter?: React.ReactNode;
|
|
51
|
+
/**
|
|
52
|
+
*@description.zh-CN 自定义图标
|
|
53
|
+
*/
|
|
54
|
+
icons?: {
|
|
55
|
+
search?: React.ReactNode;
|
|
56
|
+
up?: React.ReactNode;
|
|
57
|
+
down?: React.ReactNode;
|
|
58
|
+
clear?: React.ReactNode;
|
|
59
|
+
refresh?: React.ReactNode;
|
|
60
|
+
loading?: React.ReactNode;
|
|
61
|
+
};
|
|
62
|
+
/**
|
|
63
|
+
* @description.zh-CN 点击下一个按钮回调
|
|
64
|
+
*/
|
|
65
|
+
onSearchPrev?: (value: string) => void;
|
|
66
|
+
/**
|
|
67
|
+
* @description.zh-CN 点击上一个按钮回调
|
|
68
|
+
*/
|
|
69
|
+
onSearchNext?: (value: string) => void;
|
|
70
|
+
/**
|
|
71
|
+
* @description.zh-CN 搜索框文本变更回调函数
|
|
72
|
+
*/
|
|
73
|
+
onSearchChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
74
|
+
/**
|
|
75
|
+
* @description.zh-CN 清空文本框后回调函数
|
|
76
|
+
*/
|
|
77
|
+
onSearchClear?: (e: React.SyntheticEvent<HTMLElement>) => void;
|
|
78
|
+
/**
|
|
79
|
+
* @description.zh-CN 点击 Tab 标题后回调函数
|
|
80
|
+
*/
|
|
81
|
+
onTitleChange?: (index: number) => void;
|
|
82
|
+
/**
|
|
83
|
+
*@description.zh-CN 点击刷新按钮后的回调
|
|
84
|
+
*/
|
|
85
|
+
onRefresh?: (e: React.SyntheticEvent<HTMLSpanElement>) => void;
|
|
86
|
+
}
|
|
87
|
+
declare const TerminalViewerHeader: React.FC<TerminalViewerHeaderProps>;
|
|
88
|
+
export default TerminalViewerHeader;
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
2
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
3
|
+
function _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); }
|
|
4
|
+
function _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; }
|
|
5
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
6
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
7
|
+
import React, { useCallback, useEffect, useRef, useState } from 'react';
|
|
8
|
+
import { CloseCircleFilled, SearchOutlined, UpOutlined, DownOutlined, ReloadOutlined, LoadingOutlined } from '@ant-design/icons';
|
|
9
|
+
import "./index.less";
|
|
10
|
+
var TerminalViewerHeader = function TerminalViewerHeader(_ref) {
|
|
11
|
+
var _ref$placeholder = _ref.placeholder,
|
|
12
|
+
placeholder = _ref$placeholder === void 0 ? '请输入' : _ref$placeholder,
|
|
13
|
+
defaultValue = _ref.defaultValue,
|
|
14
|
+
_ref$clearable = _ref.clearable,
|
|
15
|
+
clearable = _ref$clearable === void 0 ? true : _ref$clearable,
|
|
16
|
+
_ref$refreshable = _ref.refreshable,
|
|
17
|
+
refreshable = _ref$refreshable === void 0 ? true : _ref$refreshable,
|
|
18
|
+
_ref$loading = _ref.loading,
|
|
19
|
+
loading = _ref$loading === void 0 ? false : _ref$loading,
|
|
20
|
+
_ref$activeTitleIndex = _ref.activeTitleIndex,
|
|
21
|
+
activeTitleIndex = _ref$activeTitleIndex === void 0 ? 0 : _ref$activeTitleIndex,
|
|
22
|
+
titles = _ref.titles,
|
|
23
|
+
searchResult = _ref.searchResult,
|
|
24
|
+
inputAddonBefore = _ref.inputAddonBefore,
|
|
25
|
+
inputAddonAfter = _ref.inputAddonAfter,
|
|
26
|
+
icons = _ref.icons,
|
|
27
|
+
onTitleChange = _ref.onTitleChange,
|
|
28
|
+
onSearchPrev = _ref.onSearchPrev,
|
|
29
|
+
onSearchNext = _ref.onSearchNext,
|
|
30
|
+
onSearchChange = _ref.onSearchChange,
|
|
31
|
+
onSearchClear = _ref.onSearchClear,
|
|
32
|
+
onRefresh = _ref.onRefresh;
|
|
33
|
+
var _useState = useState(defaultValue || ''),
|
|
34
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
35
|
+
value = _useState2[0],
|
|
36
|
+
setValue = _useState2[1];
|
|
37
|
+
var inputRef = useRef(null);
|
|
38
|
+
var handleInputChange = useCallback(function (e) {
|
|
39
|
+
setValue(e.target.value);
|
|
40
|
+
if (onSearchChange instanceof Function) {
|
|
41
|
+
onSearchChange(e);
|
|
42
|
+
}
|
|
43
|
+
}, [onSearchChange]);
|
|
44
|
+
var handleSearchPrev = function handleSearchPrev() {
|
|
45
|
+
if (onSearchPrev instanceof Function) {
|
|
46
|
+
onSearchPrev(value || '');
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
var handleSearchNext = function handleSearchNext() {
|
|
50
|
+
if (onSearchNext instanceof Function) {
|
|
51
|
+
onSearchNext(value || '');
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
var handleSearchClear = function handleSearchClear(e) {
|
|
55
|
+
setValue('');
|
|
56
|
+
if (onSearchClear instanceof Function) {
|
|
57
|
+
onSearchClear(e);
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
// 切换 Tab 清空搜索框
|
|
61
|
+
useEffect(function () {
|
|
62
|
+
setValue('');
|
|
63
|
+
}, [activeTitleIndex]);
|
|
64
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
65
|
+
className: "terminal-viewer-header"
|
|
66
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
67
|
+
className: "terminal-viewer-header-tab"
|
|
68
|
+
}, Array.isArray(titles) && titles.map(function (title, index) {
|
|
69
|
+
var itemClassName = ['terminal-viewer-header-tab-item', index === activeTitleIndex && 'active'].filter(Boolean).join(' ');
|
|
70
|
+
var handleTitleChange = function handleTitleChange(i) {
|
|
71
|
+
if (typeof onTitleChange === 'function') {
|
|
72
|
+
onTitleChange(i);
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
if (typeof title === 'number') {
|
|
76
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
77
|
+
key: title,
|
|
78
|
+
className: itemClassName,
|
|
79
|
+
onClick: function onClick() {
|
|
80
|
+
return handleTitleChange(index);
|
|
81
|
+
}
|
|
82
|
+
}, "Tab", title + 1);
|
|
83
|
+
}
|
|
84
|
+
return (
|
|
85
|
+
/*#__PURE__*/
|
|
86
|
+
// eslint-disable-next-line react/no-array-index-key
|
|
87
|
+
React.createElement("div", {
|
|
88
|
+
key: index,
|
|
89
|
+
className: itemClassName,
|
|
90
|
+
onClick: function onClick() {
|
|
91
|
+
return handleTitleChange(index);
|
|
92
|
+
}
|
|
93
|
+
}, title)
|
|
94
|
+
);
|
|
95
|
+
})), /*#__PURE__*/React.createElement("div", {
|
|
96
|
+
className: "terminal-viewer-header-action"
|
|
97
|
+
}, inputAddonBefore, refreshable && /*#__PURE__*/React.createElement("span", {
|
|
98
|
+
className: "terminal-viewer-header-refresh",
|
|
99
|
+
onClick: loading ? undefined : onRefresh
|
|
100
|
+
}, loading ? (icons === null || icons === void 0 ? void 0 : icons.loading) || /*#__PURE__*/React.createElement(LoadingOutlined, null) : (icons === null || icons === void 0 ? void 0 : icons.refresh) || /*#__PURE__*/React.createElement(ReloadOutlined, null)), /*#__PURE__*/React.createElement("div", {
|
|
101
|
+
className: "terminal-viewer-input-wrapper"
|
|
102
|
+
}, /*#__PURE__*/React.createElement("input", {
|
|
103
|
+
ref: inputRef,
|
|
104
|
+
type: "text",
|
|
105
|
+
value: value,
|
|
106
|
+
className: "terminal-viewer-input",
|
|
107
|
+
onChange: handleInputChange,
|
|
108
|
+
placeholder: placeholder,
|
|
109
|
+
onKeyDown: function onKeyDown(e) {
|
|
110
|
+
if (e.key === 'Enter') {
|
|
111
|
+
handleSearchNext();
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
115
|
+
className: "terminal-viewer-input-suffix"
|
|
116
|
+
}, !!value && /*#__PURE__*/React.createElement("span", {
|
|
117
|
+
className: "input-suffix-search-result"
|
|
118
|
+
}, "".concat(((searchResult === null || searchResult === void 0 ? void 0 : searchResult.resultCount) || 0) > 0 ? ((searchResult === null || searchResult === void 0 ? void 0 : searchResult.resultIndex) || 0) + 1 : 0, "/").concat(((searchResult === null || searchResult === void 0 ? void 0 : searchResult.resultCount) || 0) >= 1000 ? '1000+' : (searchResult === null || searchResult === void 0 ? void 0 : searchResult.resultCount) || 0)), clearable && !!value && /*#__PURE__*/React.createElement("span", {
|
|
119
|
+
className: "input-suffix-clear",
|
|
120
|
+
onClick: handleSearchClear
|
|
121
|
+
}, (icons === null || icons === void 0 ? void 0 : icons.clear) || /*#__PURE__*/React.createElement(CloseCircleFilled, null)), /*#__PURE__*/React.createElement("span", {
|
|
122
|
+
className: "input-suffix-search-tool",
|
|
123
|
+
onClick: handleSearchPrev
|
|
124
|
+
}, (icons === null || icons === void 0 ? void 0 : icons.up) || /*#__PURE__*/React.createElement(UpOutlined, null)), /*#__PURE__*/React.createElement("span", {
|
|
125
|
+
className: "input-suffix-search-tool",
|
|
126
|
+
onClick: handleSearchNext
|
|
127
|
+
}, (icons === null || icons === void 0 ? void 0 : icons.down) || /*#__PURE__*/React.createElement(DownOutlined, null)), (icons === null || icons === void 0 ? void 0 : icons.search) || /*#__PURE__*/React.createElement(SearchOutlined, null))), inputAddonAfter));
|
|
128
|
+
};
|
|
129
|
+
export default TerminalViewerHeader;
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
.terminal-viewer-header {
|
|
2
|
+
display: flex;
|
|
3
|
+
padding: 12px 16px;
|
|
4
|
+
background: #1e2a3d;
|
|
5
|
+
border-bottom: 1px solid #4d545e;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
.terminal-viewer-header-tab {
|
|
9
|
+
display: flex;
|
|
10
|
+
flex-grow: 1;
|
|
11
|
+
align-items: center;
|
|
12
|
+
margin-right: 16px;
|
|
13
|
+
overflow-x: auto;
|
|
14
|
+
white-space: nowrap;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
.terminal-viewer-header-tab-item {
|
|
18
|
+
display: flex;
|
|
19
|
+
align-items: center;
|
|
20
|
+
padding: 0 12px;
|
|
21
|
+
color: #878c96;
|
|
22
|
+
cursor: pointer;
|
|
23
|
+
|
|
24
|
+
// & + & {
|
|
25
|
+
// margin-left: -8px;
|
|
26
|
+
// }
|
|
27
|
+
|
|
28
|
+
&:hover {
|
|
29
|
+
color: #fff;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
&.active {
|
|
33
|
+
padding: 4px 12px;
|
|
34
|
+
color: #fff;
|
|
35
|
+
background: #4a525e;
|
|
36
|
+
border-radius: 16px;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
.terminal-viewer-header-action {
|
|
41
|
+
display: flex;
|
|
42
|
+
flex-shrink: 0;
|
|
43
|
+
align-items: center;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.terminal-viewer-input-wrapper {
|
|
47
|
+
display: flex;
|
|
48
|
+
align-items: center;
|
|
49
|
+
min-width: 280px;
|
|
50
|
+
padding: 4px 12px;
|
|
51
|
+
color: #fff;
|
|
52
|
+
background-color: #4a525e;
|
|
53
|
+
border-radius: 4px;
|
|
54
|
+
|
|
55
|
+
&:hover {
|
|
56
|
+
box-shadow: 0 0 0 1px#d4d6d9;
|
|
57
|
+
|
|
58
|
+
.input-suffix-clear {
|
|
59
|
+
display: flex;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.input-suffix-search-tool {
|
|
63
|
+
display: flex;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
input.terminal-viewer-input {
|
|
69
|
+
flex-grow: 1;
|
|
70
|
+
height: 24px;
|
|
71
|
+
margin: 0;
|
|
72
|
+
padding: 0;
|
|
73
|
+
color: #fff;
|
|
74
|
+
background-color: #4a525e;
|
|
75
|
+
border: 0;
|
|
76
|
+
outline: none;
|
|
77
|
+
|
|
78
|
+
&::placeholder {
|
|
79
|
+
color: #fff;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
&:hover {
|
|
83
|
+
border: none;
|
|
84
|
+
outline: none;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
&:focus {
|
|
88
|
+
border: none;
|
|
89
|
+
outline: none;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
.terminal-viewer-input-suffix {
|
|
94
|
+
display: flex;
|
|
95
|
+
flex-shrink: 0;
|
|
96
|
+
align-items: center;
|
|
97
|
+
|
|
98
|
+
.anticon-search {
|
|
99
|
+
font-size: 16px;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
> * {
|
|
103
|
+
margin-left: 8px;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
.input-suffix-clear {
|
|
108
|
+
display: none;
|
|
109
|
+
align-items: center;
|
|
110
|
+
justify-content: center;
|
|
111
|
+
font-size: 12px;
|
|
112
|
+
cursor: pointer;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
.input-suffix-search-result {
|
|
116
|
+
font-size: 12px;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
.input-suffix-search-tool {
|
|
120
|
+
display: none;
|
|
121
|
+
align-items: center;
|
|
122
|
+
justify-content: center;
|
|
123
|
+
padding: 2px 4px;
|
|
124
|
+
font-size: 12px;
|
|
125
|
+
background: #878c96;
|
|
126
|
+
border-radius: 4px;
|
|
127
|
+
cursor: pointer;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
.input-suffix-search--disabled {
|
|
131
|
+
cursor: not-allowed;
|
|
132
|
+
pointer-events: none;
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
.terminal-viewer-header-refresh {
|
|
136
|
+
display: flex;
|
|
137
|
+
align-items: center;
|
|
138
|
+
justify-content: center;
|
|
139
|
+
margin-right: 16px;
|
|
140
|
+
color: #fff;
|
|
141
|
+
font-size: 16px;
|
|
142
|
+
cursor: pointer;
|
|
143
|
+
}
|