Skip to content

Commit

Permalink
Add xterm-addon-search-bar (runatlantis#3507)
Browse files Browse the repository at this point in the history
  • Loading branch information
X-Guardian authored Jun 11, 2023
1 parent 504d1b7 commit fa6a77a
Show file tree
Hide file tree
Showing 3 changed files with 123 additions and 0 deletions.
7 changes: 7 additions & 0 deletions server/controllers/templates/web_templates.go
Original file line number Diff line number Diff line change
Expand Up @@ -407,6 +407,8 @@ var ProjectJobsTemplate = template.Must(template.New("blank.html.tmpl").Parse(`
<script src="{{ .CleanedBasePath }}/static/js/xterm-4.9.0.js"></script>
<script src="{{ .CleanedBasePath }}/static/js/xterm-addon-attach-0.6.0.js"></script>
<script src="{{ .CleanedBasePath }}/static/js/xterm-addon-fit-0.4.0.js"></script>
<script src="{{ .CleanedBasePath }}/static/js/xterm-addon-search-0.7.0.js"></script>
<script src="{{ .CleanedBasePath }}/static/js/xterm-addon-search-bar.js"></script>
<script>
function updateTerminalStatus(msg) {
Expand All @@ -431,9 +433,14 @@ var ProjectJobsTemplate = template.Must(template.New("blank.html.tmpl").Parse(`
})
var attachAddon = new AttachAddon.AttachAddon(socket);
var fitAddon = new FitAddon.FitAddon();
var searchAddon = new SearchAddon.SearchAddon();
var searchBarAddon = new SearchBarAddon.SearchBarAddon({searchAddon});
term.loadAddon(attachAddon);
term.loadAddon(fitAddon);
term.loadAddon(searchAddon);
term.loadAddon(searchBarAddon);
term.open(document.getElementById("terminal"));
searchBarAddon.show();
fitAddon.fit();
window.addEventListener("resize", () => fitAddon.fit());
</script>
Expand Down
2 changes: 2 additions & 0 deletions server/static/js/xterm-addon-search-0.7.0.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

114 changes: 114 additions & 0 deletions server/static/js/xterm-addon-search-bar.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,114 @@
!(function (e, t) {
"object" == typeof exports && "undefined" != typeof module
? t(exports)
: "function" == typeof define && define.amd
? define(["exports"], t)
: t((e.SearchBarAddon = {}));
})(this, function (e) {
"use strict";
!(function (e, t) {
void 0 === t && (t = {});
var a = t.insertAt;
if (e && "undefined" != typeof document) {
var i = document.head || document.getElementsByTagName("head")[0],
n = document.createElement("style");
(n.type = "text/css"),
"top" === a && i.firstChild
? i.insertBefore(n, i.firstChild)
: i.appendChild(n),
n.styleSheet
? (n.styleSheet.cssText = e)
: n.appendChild(document.createTextNode(e));
}
})(
`.xterm-search-bar__addon{position:absolute;max-width:1467px;top:0;right:28px;color:#000;background:#fff;
padding:5px 10px;box-shadow:0 2px 8px #000;background-color:#252526;z-index:999;display:flex}.xterm-search-bar__addon
.search-bar__input{background-color:#3c3c3c;color:#ccc;border:0;margin-bottom:0px;padding:2px;height:20px;width:227px}.xterm-search-bar__addon
.search-bar__btn{min-width:20px;width:20px;height:20px;display:flex;display:-webkit-flex;flex:initial;background-position:50%;
margin-left:3px;margin-bottom:0px;background-repeat:no-repeat;background-color:#252526;border:0;cursor:pointer;padding: 0}.xterm-search-bar__addon
.search-bar__btn:hover{background-color:#666}.xterm-search-bar__addon .search-bar__btn.prev{background-image:url("")}.xterm-search-bar__addon
.search-bar__btn.next{background-image:url("")}.xterm-search-bar__addon
.search-bar__btn.close{background-image:url("")}`
);
const t = "xterm-search-bar__addon";
(e.SearchBarAddon = class {
constructor(e) {
(this.options = e || {}),
this.options &&
this.options.searchAddon &&
(this.searchAddon = this.options.searchAddon);
}
activate(e) {
(this.terminal = e), this.searchAddon;
}
dispose() {
this.hidden();
}
show() {
if (!this.terminal || !this.terminal.element) return;
if (this.searchBarElement)
return (
(this.searchBarElement.style.visibility = "visible"),
void this.searchBarElement.querySelector("input").select()
);
this.terminal.element.style.position = "relative";
const e = document.createElement("div");
(e.innerHTML =
`<input type="text" class="search-bar__input" name="search-bar__input"/>
<button class="search-bar__btn prev"></button>
<button class="search-bar__btn next"></button>
<button class="search-bar__btn close"></button>`),
(e.className = t);
const a = this.terminal.element.parentElement;
(this.searchBarElement = e),
/* ["relative", "absolute", "fixed"].includes(a.style.position) ||
(a.style.position = "relative"),*/
a.appendChild(this.searchBarElement),
this.on(".search-bar__btn.close", "click", () => {
this.hidden();
}),
this.on(".search-bar__btn.next", "click", () => {
this.searchAddon.findNext(this.searchKey, { incremental: !1 });
}),
this.on(".search-bar__btn.prev", "click", () => {
this.searchAddon.findPrevious(this.searchKey, { incremental: !1 });
}),
this.on(".search-bar__input", "keyup", (e) => {
(this.searchKey = e.target.value),
this.searchAddon.findNext(this.searchKey, {
incremental: "Enter" !== e.key,
});
}),
this.searchBarElement.querySelector("input").select();
}
hidden() {
this.searchBarElement &&
this.terminal.element.parentElement &&
(this.searchBarElement.style.visibility = "hidden");
}
on(e, t, a) {
const i = this.terminal.element.parentElement;
i.addEventListener(t, (t) => {
let n = t.target;
for (; n !== document.querySelector(e); ) {
if (n === i) {
n = null;
break;
}
n = n.parentElement;
}
n === document.querySelector(e) &&
(a.call(this, t), t.stopPropagation());
});
}
addNewStyle(e) {
let a = document.getElementById(t);
a ||
(((a = document.createElement("style")).type = "text/css"),
(a.id = t),
document.getElementsByTagName("head")[0].appendChild(a)),
a.appendChild(document.createTextNode(e));
}
}),
Object.defineProperty(e, "__esModule", { value: !0 });
});

0 comments on commit fa6a77a

Please sign in to comment.