UNPKG

xterm-addon-search-bar

Version:

[![Build Status](https://github.com/yinshuxun/xterm-addon-search-bar/workflows/ci/badge.svg?branch=master&event=push)](https://github.com/yinshuxun/xterm-addon-search-bar/actions) [![Build Status](https://github.com/yinshuxun/xterm-addon-search-bar/workfl

133 lines (125 loc) 6.42 kB
/*! * xterm-addon-search-bar.js v0.2.0 * (c) 2018-2020 yinshuxun * Released under the MIT License. */ function styleInject(css, ref) { if ( ref === void 0 ) ref = {}; var insertAt = ref.insertAt; if (!css || typeof document === 'undefined') { return; } var head = document.head || document.getElementsByTagName('head')[0]; var style = document.createElement('style'); style.type = 'text/css'; if (insertAt === 'top') { if (head.firstChild) { head.insertBefore(style, head.firstChild); } else { head.appendChild(style); } } else { head.appendChild(style); } if (style.styleSheet) { style.styleSheet.cssText = css; } else { style.appendChild(document.createTextNode(css)); } } var css = ".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;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;background-repeat:no-repeat;background-color:#252526;border:0;cursor:pointer}.xterm-search-bar__addon .search-bar__btn:hover{background-color:#666}.xterm-search-bar__addon .search-bar__btn.prev{margin-left:20px;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(\"\")}"; styleInject(css); const ADDON_MARKER_NAME = 'xterm-search-bar__addon'; class SearchBarAddon { constructor(options) { this.options = options || {}; if (this.options && this.options.searchAddon) { this.searchAddon = this.options.searchAddon; } } activate(terminal) { this.terminal = terminal; if (!this.searchAddon) { console.error('Cannot use search bar addon until search addon has been loaded!'); } } dispose() { this.hidden(); } show() { if (!this.terminal || !this.terminal.element) { return; } if (this.searchBarElement) { this.searchBarElement.style.visibility = 'visible'; this.searchBarElement.querySelector('input').select(); return; } this.terminal.element.style.position = 'relative'; const element = document.createElement('div'); element.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> `; element.className = ADDON_MARKER_NAME; const parentElement = this.terminal.element.parentElement; this.searchBarElement = element; if (!['relative', 'absoulte', 'fixed'].includes(parentElement.style.position)) { parentElement.style.position = 'relative'; } parentElement.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: false }); }); this.on('.search-bar__btn.prev', 'click', () => { this.searchAddon.findPrevious(this.searchKey, { incremental: false }); }); this.on('.search-bar__input', 'keyup', (e) => { this.searchKey = e.target.value; this.searchAddon.findNext(this.searchKey, { incremental: e.key !== `Enter` }); }); this.searchBarElement.querySelector('input').select(); } hidden() { if (this.searchBarElement && this.terminal.element.parentElement) { this.searchBarElement.style.visibility = 'hidden'; } } on(selector, event, cb) { const parentElement = this.terminal.element.parentElement; parentElement.addEventListener(event, (e) => { let target = e.target; while (target !== document.querySelector(selector)) { if (target === parentElement) { target = null; break; } target = target.parentElement; } if (target === document.querySelector(selector)) { cb.call(this, e); e.stopPropagation(); } }); } addNewStyle(newStyle) { let styleElement = document.getElementById(ADDON_MARKER_NAME); if (!styleElement) { styleElement = document.createElement('style'); styleElement.type = 'text/css'; styleElement.id = ADDON_MARKER_NAME; document.getElementsByTagName('head')[0].appendChild(styleElement); } styleElement.appendChild(document.createTextNode(newStyle)); } } export { SearchBarAddon };