mirror of
https://github.com/Eugeny/tabby.git
synced 2025-09-13 20:04:33 +00:00
Compare commits
53 Commits
v1.0.207
...
all-contri
Author | SHA1 | Date | |
---|---|---|---|
![]() |
008cae9710 | ||
![]() |
d38a900553 | ||
![]() |
964cd482b2 | ||
![]() |
c127a00016 | ||
![]() |
e857da28ac | ||
![]() |
06b625cb6f | ||
![]() |
8e8cf6a500 | ||
![]() |
4930d0fac6 | ||
![]() |
ba31e14fa4 | ||
![]() |
ff49b50d7d | ||
![]() |
b436eac973 | ||
![]() |
64195940a1 | ||
![]() |
69dd2993af | ||
![]() |
2b65bb4b14 | ||
![]() |
4ed4d756c9 | ||
![]() |
fa9ee756d2 | ||
![]() |
223d8549ad | ||
![]() |
1e6c2cba76 | ||
![]() |
bba72b4bb8 | ||
![]() |
3739455f32 | ||
![]() |
ab4899043f | ||
![]() |
1776b840f4 | ||
![]() |
3ea1b7f561 | ||
![]() |
cee39b3b9f | ||
![]() |
218fb8130c | ||
![]() |
d718f437f0 | ||
![]() |
defe30781b | ||
![]() |
a3a6e3d137 | ||
![]() |
a5f4f23301 | ||
![]() |
bdcfba10a3 | ||
![]() |
e120031cb0 | ||
![]() |
5adfdd432a | ||
![]() |
897e06d329 | ||
![]() |
db2280e147 | ||
![]() |
8a49c738b4 | ||
![]() |
439a7a8d44 | ||
![]() |
c681902929 | ||
![]() |
a3fd6f5846 | ||
![]() |
de81f12a17 | ||
![]() |
242f136a41 | ||
![]() |
9425920f94 | ||
![]() |
d15b67a05f | ||
![]() |
8237785409 | ||
![]() |
8f68105460 | ||
![]() |
66b7632958 | ||
![]() |
c906af5bec | ||
![]() |
24c64a5e24 | ||
![]() |
ebf0d89b07 | ||
![]() |
bacb458df3 | ||
![]() |
49d05cc23b | ||
![]() |
0894c305ad | ||
![]() |
c3baad4525 | ||
![]() |
3b15b35447 |
@@ -1292,6 +1292,24 @@
|
|||||||
"contributions": [
|
"contributions": [
|
||||||
"code"
|
"code"
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"login": "C41M50N",
|
||||||
|
"name": "Charles Buffington",
|
||||||
|
"avatar_url": "https://avatars.githubusercontent.com/u/29805363?v=4",
|
||||||
|
"profile": "https://cbuff.dev",
|
||||||
|
"contributions": [
|
||||||
|
"code"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"login": "GeminiLn",
|
||||||
|
"name": "Yu Qin",
|
||||||
|
"avatar_url": "https://avatars.githubusercontent.com/u/12425057?v=4",
|
||||||
|
"profile": "https://github.com/GeminiLn",
|
||||||
|
"contributions": [
|
||||||
|
"code"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"contributorsPerLine": 7,
|
"contributorsPerLine": 7,
|
||||||
|
2
.github/workflows/docs.yml
vendored
2
.github/workflows/docs.yml
vendored
@@ -14,7 +14,7 @@ jobs:
|
|||||||
- name: Installing Node
|
- name: Installing Node
|
||||||
uses: actions/setup-node@v3.7.0
|
uses: actions/setup-node@v3.7.0
|
||||||
with:
|
with:
|
||||||
node-version: 16
|
node-version: 20
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
|
1
.gitignore
vendored
1
.gitignore
vendored
@@ -37,3 +37,4 @@ tabby-ssh/util/pagent.exe
|
|||||||
*.psd
|
*.psd
|
||||||
|
|
||||||
crowdin.yml
|
crowdin.yml
|
||||||
|
.crowdin.env
|
||||||
|
@@ -23,6 +23,8 @@ sudo apt install libfontconfig-dev libsecret-1-dev libarchive-tools libnss3 liba
|
|||||||
yarn
|
yarn
|
||||||
```
|
```
|
||||||
|
|
||||||
|
_⚠️Note: If you forked this repository, you may need to pull down the tags from this repository before installing node modules. `git pull --tags upstream master`_
|
||||||
|
|
||||||
Build Tabby:
|
Build Tabby:
|
||||||
|
|
||||||
```
|
```
|
||||||
|
@@ -338,6 +338,8 @@ Dank geht an diese wunderbaren Menschen ([emoji key](https://allcontributors.org
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://cbuff.dev"><img src="https://avatars.githubusercontent.com/u/29805363?v=4?s=100" width="100px;" alt="Charles Buffington"/><br /><sub><b>Charles Buffington</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=C41M50N" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://github.com/GeminiLn"><img src="https://avatars.githubusercontent.com/u/12425057?v=4?s=100" width="100px;" alt="Yu Qin"/><br /><sub><b>Yu Qin</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=GeminiLn" title="Code">💻</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@@ -340,6 +340,7 @@ Gracias a estas maravillosas personas ([emoji key](https://allcontributors.org/d
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://cbuff.dev"><img src="https://avatars.githubusercontent.com/u/29805363?v=4?s=100" width="100px;" alt="Charles Buffington"/><br /><sub><b>Charles Buffington</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=C41M50N" title="Code">💻</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@@ -337,6 +337,8 @@ Terima kasih kepada mereka yang telah membantu ([emoji key](https://allcontribut
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://cbuff.dev"><img src="https://avatars.githubusercontent.com/u/29805363?v=4?s=100" width="100px;" alt="Charles Buffington"/><br /><sub><b>Charles Buffington</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=C41M50N" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://github.com/GeminiLn"><img src="https://avatars.githubusercontent.com/u/12425057?v=4?s=100" width="100px;" alt="Yu Qin"/><br /><sub><b>Yu Qin</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=GeminiLn" title="Code">💻</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@@ -333,6 +333,8 @@ Grazie a queste persone meravigliose ([emoji key](https://allcontributors.org/do
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://cbuff.dev"><img src="https://avatars.githubusercontent.com/u/29805363?v=4?s=100" width="100px;" alt="Charles Buffington"/><br /><sub><b>Charles Buffington</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=C41M50N" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://github.com/GeminiLn"><img src="https://avatars.githubusercontent.com/u/12425057?v=4?s=100" width="100px;" alt="Yu Qin"/><br /><sub><b>Yu Qin</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=GeminiLn" title="Code">💻</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@@ -348,6 +348,7 @@ Windows上では、`Tabby.exe`がある場所と同じ場所に`data`フォル
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://cbuff.dev"><img src="https://avatars.githubusercontent.com/u/29805363?v=4?s=100" width="100px;" alt="Charles Buffington"/><br /><sub><b>Charles Buffington</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=C41M50N" title="Code">💻</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@@ -332,6 +332,8 @@ Pull requests and plugins are welcome!
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://cbuff.dev"><img src="https://avatars.githubusercontent.com/u/29805363?v=4?s=100" width="100px;" alt="Charles Buffington"/><br /><sub><b>Charles Buffington</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=C41M50N" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://github.com/GeminiLn"><img src="https://avatars.githubusercontent.com/u/12425057?v=4?s=100" width="100px;" alt="Yu Qin"/><br /><sub><b>Yu Qin</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=GeminiLn" title="Code">💻</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@@ -354,6 +354,8 @@ Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/d
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://cbuff.dev"><img src="https://avatars.githubusercontent.com/u/29805363?v=4?s=100" width="100px;" alt="Charles Buffington"/><br /><sub><b>Charles Buffington</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=C41M50N" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://github.com/GeminiLn"><img src="https://avatars.githubusercontent.com/u/12425057?v=4?s=100" width="100px;" alt="Yu Qin"/><br /><sub><b>Yu Qin</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=GeminiLn" title="Code">💻</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@@ -341,6 +341,8 @@ Obrigado vai para essas pessoas maravilhosas ([emoji key](https://allcontributor
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://cbuff.dev"><img src="https://avatars.githubusercontent.com/u/29805363?v=4?s=100" width="100px;" alt="Charles Buffington"/><br /><sub><b>Charles Buffington</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=C41M50N" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://github.com/GeminiLn"><img src="https://avatars.githubusercontent.com/u/12425057?v=4?s=100" width="100px;" alt="Yu Qin"/><br /><sub><b>Yu Qin</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=GeminiLn" title="Code">💻</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@@ -29,7 +29,7 @@
|
|||||||
[**Tabby**](https://tabby.sh) (ранее **Terminus**) — широко конфигурируемый эмулятор терминала, SSH- и COM-клиент для Windows, macOS и Linux:
|
[**Tabby**](https://tabby.sh) (ранее **Terminus**) — широко конфигурируемый эмулятор терминала, SSH- и COM-клиент для Windows, macOS и Linux:
|
||||||
|
|
||||||
* Встроенный SSH- и Telnet-клиент и менеджер подключений;
|
* Встроенный SSH- и Telnet-клиент и менеджер подключений;
|
||||||
* Встроенный последовтаельный терминал;
|
* Встроенный последовательный терминал;
|
||||||
* Темы и цветовые схемы;
|
* Темы и цветовые схемы;
|
||||||
* Полностью настраеваемые сочетания клавиш;
|
* Полностью настраеваемые сочетания клавиш;
|
||||||
* Панели;
|
* Панели;
|
||||||
@@ -39,7 +39,7 @@
|
|||||||
* Полная поддержка Unicode, включая символы двойной ширины;
|
* Полная поддержка Unicode, включая символы двойной ширины;
|
||||||
* Не задыхается при быстром выводе;
|
* Не задыхается при быстром выводе;
|
||||||
* Полноценный опыт работы с shell на Windows, включая дополнение слов и команд по Tab (при помощи Clink);
|
* Полноценный опыт работы с shell на Windows, включая дополнение слов и команд по Tab (при помощи Clink);
|
||||||
* Втроенное защищённое хранилище для SSH-ключей и настроек;
|
* Встроенное защищённое хранилище для SSH-ключей и настроек;
|
||||||
* SSH-, SFTP- и Telnet-клиент доступен как [веб-приложение](https://tabby.sh/app) (также для [самостоятелньного хостинга](https://github.com/Eugeny/tabby-web)).
|
* SSH-, SFTP- и Telnet-клиент доступен как [веб-приложение](https://tabby.sh/app) (также для [самостоятелньного хостинга](https://github.com/Eugeny/tabby-web)).
|
||||||
|
|
||||||
# Содержание <!-- omit in toc -->
|
# Содержание <!-- omit in toc -->
|
||||||
@@ -71,7 +71,7 @@
|
|||||||
* Деление окна на несколько панелей;
|
* Деление окна на несколько панелей;
|
||||||
* Вкладки на любой стороне окна;
|
* Вкладки на любой стороне окна;
|
||||||
* Опционально закрепляемое окно с глобальной горячей клавишей для вызова («Quake console»);
|
* Опционально закрепляемое окно с глобальной горячей клавишей для вызова («Quake console»);
|
||||||
* Определение прогресса процесса;
|
* Определение прогресса выполняемого процесса;
|
||||||
* Уведомления о завершении процессов;
|
* Уведомления о завершении процессов;
|
||||||
* Защита от выполнения команд при вставке, предупреждения о вставке нескольких строк;
|
* Защита от выполнения команд при вставке, предупреждения о вставке нескольких строк;
|
||||||
* Лигатуры шрифтов;
|
* Лигатуры шрифтов;
|
||||||
@@ -94,7 +94,7 @@
|
|||||||
|
|
||||||
* Сохранение соединений;
|
* Сохранение соединений;
|
||||||
* Поддержка ввода readline;
|
* Поддержка ввода readline;
|
||||||
* Опциональый побатный ввод HEX и вывод hexdump;
|
* Опциональный побатный ввод HEX и вывод hexdump;
|
||||||
* Преобразование newline;
|
* Преобразование newline;
|
||||||
* Автоматическое восстановление соединения.
|
* Автоматическое восстановление соединения.
|
||||||
|
|
||||||
@@ -115,9 +115,9 @@
|
|||||||
* [save-output](https://github.com/Eugeny/tabby-save-output) — запись вывода терминала в файл;
|
* [save-output](https://github.com/Eugeny/tabby-save-output) — запись вывода терминала в файл;
|
||||||
* [sync-config](https://github.com/starxg/terminus-sync-config) — синхронизация конфига в Gist или Gitee;
|
* [sync-config](https://github.com/starxg/terminus-sync-config) — синхронизация конфига в Gist или Gitee;
|
||||||
* [clippy](https://github.com/Eugeny/tabby-clippy) — плагин-пример, который постоянно будет вас бесить;
|
* [clippy](https://github.com/Eugeny/tabby-clippy) — плагин-пример, который постоянно будет вас бесить;
|
||||||
* [workspace-manager](https://github.com/composer404/tabby-workspace-manager) — позволяет создавать пользовательские провили рабочего окружеиня на основе конфига;
|
* [workspace-manager](https://github.com/composer404/tabby-workspace-manager) — позволяет создавать пользовательские профили рабочего окружения на основе конфига;
|
||||||
* [search-in-browser](https://github.com/composer404/tabby-search-in-browser) — открывает браузер по умолчанию с текстом, выделенном во вкладке Tabby.
|
* [search-in-browser](https://github.com/composer404/tabby-search-in-browser) — открывает браузер по умолчанию с текстом, выделенном во вкладке Tabby.
|
||||||
* [sftp-tab](https://github.com/wljince007/tabby-sftp-tab) - open sftp tab for ssh connection like SecureCRT
|
* [sftp-tab](https://github.com/wljince007/tabby-sftp-tab) - открывает sftp вкладку для ssh соединения, похож на SecureCRT
|
||||||
|
|
||||||
<a name="themes"></a>
|
<a name="themes"></a>
|
||||||
# Темы
|
# Темы
|
||||||
@@ -333,6 +333,8 @@ Pull-запросы и плагины приветствуются!
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://cbuff.dev"><img src="https://avatars.githubusercontent.com/u/29805363?v=4?s=100" width="100px;" alt="Charles Buffington"/><br /><sub><b>Charles Buffington</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=C41M50N" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://github.com/GeminiLn"><img src="https://avatars.githubusercontent.com/u/12425057?v=4?s=100" width="100px;" alt="Yu Qin"/><br /><sub><b>Yu Qin</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=GeminiLn" title="Code">💻</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@@ -332,6 +332,8 @@
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
<td align="center" valign="top" width="14.28%"><a href="https://5k.work/"><img src="https://avatars.githubusercontent.com/u/82694310?v=4?s=100" width="100px;" alt="Mxmilu"/><br /><sub><b>Mxmilu</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=Mxmilu666" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://cbuff.dev"><img src="https://avatars.githubusercontent.com/u/29805363?v=4?s=100" width="100px;" alt="Charles Buffington"/><br /><sub><b>Charles Buffington</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=C41M50N" title="Code">💻</a></td>
|
||||||
|
<td align="center" valign="top" width="14.28%"><a href="https://github.com/GeminiLn"><img src="https://avatars.githubusercontent.com/u/12425057?v=4?s=100" width="100px;" alt="Yu Qin"/><br /><sub><b>Yu Qin</b></sub></a><br /><a href="https://github.com/Eugeny/tabby/commits?author=GeminiLn" title="Code">💻</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@@ -183,9 +183,10 @@ export class Application {
|
|||||||
}
|
}
|
||||||
|
|
||||||
enableTray (): void {
|
enableTray (): void {
|
||||||
if (!!this.tray || process.platform === 'linux') {
|
if (!!this.tray || process.platform === 'linux' || (this.configStore.hideTray ?? false) === true) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if (process.platform === 'darwin') {
|
if (process.platform === 'darwin') {
|
||||||
this.tray = new Tray(`${app.getAppPath()}/assets/tray-darwinTemplate.png`)
|
this.tray = new Tray(`${app.getAppPath()}/assets/tray-darwinTemplate.png`)
|
||||||
this.tray.setPressedImage(`${app.getAppPath()}/assets/tray-darwinHighlightTemplate.png`)
|
this.tray.setPressedImage(`${app.getAppPath()}/assets/tray-darwinHighlightTemplate.png`)
|
||||||
|
@@ -24,6 +24,7 @@
|
|||||||
"electron-updater": "^5.2.1",
|
"electron-updater": "^5.2.1",
|
||||||
"fontmanager-redux": "1.1.0",
|
"fontmanager-redux": "1.1.0",
|
||||||
"glasstron": "0.1.1",
|
"glasstron": "0.1.1",
|
||||||
|
"node-powershell": "5.0.1",
|
||||||
"js-yaml": "4.1.0",
|
"js-yaml": "4.1.0",
|
||||||
"keytar": "^7.9.0",
|
"keytar": "^7.9.0",
|
||||||
"mz": "^2.7.0",
|
"mz": "^2.7.0",
|
||||||
|
@@ -1,7 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
cat > '/usr/bin/${executable}' << END
|
cat > '/usr/bin/${executable}' << END
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
'/opt/${productFilename}/${executable}' --no-sandbox $@
|
'/opt/${productFilename}/${executable}' --no-sandbox \$@
|
||||||
END
|
END
|
||||||
|
|
||||||
chmod +x '/usr/bin/${executable}'
|
chmod +x '/usr/bin/${executable}'
|
||||||
|
@@ -76,8 +76,6 @@ snap:
|
|||||||
- system-observe
|
- system-observe
|
||||||
deb:
|
deb:
|
||||||
depends:
|
depends:
|
||||||
- gconf2
|
|
||||||
- gconf-service
|
|
||||||
- gnome-keyring
|
- gnome-keyring
|
||||||
- libnotify4
|
- libnotify4
|
||||||
- libsecret-1-0
|
- libsecret-1-0
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Afrikaans\n"
|
"Language-Team: Afrikaans\n"
|
||||||
"Language: af_ZA\n"
|
"Language: af_ZA\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Bulgarian\n"
|
"Language-Team: Bulgarian\n"
|
||||||
"Language: bg_BG\n"
|
"Language: bg_BG\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Czech\n"
|
"Language-Team: Czech\n"
|
||||||
"Language: cs_CZ\n"
|
"Language: cs_CZ\n"
|
||||||
"PO-Revision-Date: 2023-11-04 21:09\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Danish\n"
|
"Language-Team: Danish\n"
|
||||||
"Language: da_DK\n"
|
"Language: da_DK\n"
|
||||||
"PO-Revision-Date: 2023-10-06 11:30\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: German\n"
|
"Language-Team: German\n"
|
||||||
"Language: de_DE\n"
|
"Language: de_DE\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: English, United Kingdom\n"
|
"Language-Team: English, United Kingdom\n"
|
||||||
"Language: en_GB\n"
|
"Language: en_GB\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
@@ -2036,6 +2036,10 @@ msgstr ""
|
|||||||
msgid "Show Serial connections"
|
msgid "Show Serial connections"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
#: locale/tmp-html/tabby-settings/src/components/windowSettingsTab.component.html:73
|
||||||
|
msgid "Hide Tabby in tray or menu bar."
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
#: locale/tmp-html/tabby-settings/src/components/windowSettingsTab.component.html:152
|
#: locale/tmp-html/tabby-settings/src/components/windowSettingsTab.component.html:152
|
||||||
msgid "Show tabs in fullscreen mode"
|
msgid "Show tabs in fullscreen mode"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
@@ -2044,6 +2048,10 @@ msgstr ""
|
|||||||
msgid "Show toolbar"
|
msgid "Show toolbar"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
#: locale/tmp-html/tabby-settings/src/components/windowSettingsTab.component.html:73
|
||||||
|
msgid "Hide tray"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
#: locale/tmp-html/tabby-settings/src/components/vaultSettingsTab.component.html:45
|
#: locale/tmp-html/tabby-settings/src/components/vaultSettingsTab.component.html:45
|
||||||
msgid "Show vault contents"
|
msgid "Show vault contents"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Spanish\n"
|
"Language-Team: Spanish\n"
|
||||||
"Language: es_ES\n"
|
"Language: es_ES\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: French\n"
|
"Language-Team: French\n"
|
||||||
"Language: fr_FR\n"
|
"Language: fr_FR\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Croatian\n"
|
"Language-Team: Croatian\n"
|
||||||
"Language: hr_HR\n"
|
"Language: hr_HR\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Indonesian\n"
|
"Language-Team: Indonesian\n"
|
||||||
"Language: id_ID\n"
|
"Language: id_ID\n"
|
||||||
"PO-Revision-Date: 2023-10-06 11:30\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Italian\n"
|
"Language-Team: Italian\n"
|
||||||
"Language: it_IT\n"
|
"Language: it_IT\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Japanese\n"
|
"Language-Team: Japanese\n"
|
||||||
"Language: ja_JP\n"
|
"Language: ja_JP\n"
|
||||||
"PO-Revision-Date: 2023-11-04 21:09\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Korean\n"
|
"Language-Team: Korean\n"
|
||||||
"Language: ko_KR\n"
|
"Language: ko_KR\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Polish\n"
|
"Language-Team: Polish\n"
|
||||||
"Language: pl_PL\n"
|
"Language: pl_PL\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Portuguese, Brazilian\n"
|
"Language-Team: Portuguese, Brazilian\n"
|
||||||
"Language: pt_BR\n"
|
"Language: pt_BR\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Portuguese\n"
|
"Language-Team: Portuguese\n"
|
||||||
"Language: pt_PT\n"
|
"Language: pt_PT\n"
|
||||||
"PO-Revision-Date: 2023-10-06 11:30\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Russian\n"
|
"Language-Team: Russian\n"
|
||||||
"Language: ru_RU\n"
|
"Language: ru_RU\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
2574
locale/sr-SP.po
Normal file
2574
locale/sr-SP.po
Normal file
File diff suppressed because it is too large
Load Diff
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Swedish\n"
|
"Language-Team: Swedish\n"
|
||||||
"Language: sv_SE\n"
|
"Language: sv_SE\n"
|
||||||
"PO-Revision-Date: 2023-11-04 21:09\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
2575
locale/tr-TR.po
Normal file
2575
locale/tr-TR.po
Normal file
File diff suppressed because it is too large
Load Diff
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Ukrainian\n"
|
"Language-Team: Ukrainian\n"
|
||||||
"Language: uk_UA\n"
|
"Language: uk_UA\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Chinese Simplified\n"
|
"Language-Team: Chinese Simplified\n"
|
||||||
"Language: zh_CN\n"
|
"Language: zh_CN\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -10,7 +10,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: tabby\n"
|
"Project-Id-Version: tabby\n"
|
||||||
"Language-Team: Chinese Traditional\n"
|
"Language-Team: Chinese Traditional\n"
|
||||||
"Language: zh_TW\n"
|
"Language: zh_TW\n"
|
||||||
"PO-Revision-Date: 2024-03-04 09:41\n"
|
"PO-Revision-Date: 2024-03-11 20:11\n"
|
||||||
|
|
||||||
#: tabby-local/src/components/terminalTab.component.ts:113
|
#: tabby-local/src/components/terminalTab.component.ts:113
|
||||||
msgid "\"{command}\" is still running. Close?"
|
msgid "\"{command}\" is still running. Close?"
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
import { Observable, Subject, distinctUntilChanged, filter, debounceTime } from 'rxjs'
|
import { Observable, Subject, BehaviorSubject, distinctUntilChanged, filter, debounceTime } from 'rxjs'
|
||||||
import { EmbeddedViewRef, Injector, ViewContainerRef, ViewRef } from '@angular/core'
|
import { EmbeddedViewRef, Injector, ViewContainerRef, ViewRef } from '@angular/core'
|
||||||
import { RecoveryToken } from '../api/tabRecovery'
|
import { RecoveryToken } from '../api/tabRecovery'
|
||||||
import { BaseComponent } from './base.component'
|
import { BaseComponent } from './base.component'
|
||||||
@@ -75,9 +75,9 @@ export abstract class BaseTabComponent extends BaseComponent {
|
|||||||
private titleChange = new Subject<string>()
|
private titleChange = new Subject<string>()
|
||||||
private focused = new Subject<void>()
|
private focused = new Subject<void>()
|
||||||
private blurred = new Subject<void>()
|
private blurred = new Subject<void>()
|
||||||
private visibility = new Subject<boolean>()
|
protected visibility = new BehaviorSubject<boolean>(false)
|
||||||
private progress = new Subject<number|null>()
|
protected progress = new BehaviorSubject<number|null>(null)
|
||||||
private activity = new Subject<boolean>()
|
protected activity = new BehaviorSubject<boolean>(false)
|
||||||
private destroyed = new Subject<void>()
|
private destroyed = new Subject<void>()
|
||||||
|
|
||||||
private _destroyCalled = false
|
private _destroyCalled = false
|
||||||
|
@@ -1,7 +1,11 @@
|
|||||||
|
.icon(
|
||||||
|
[fastHtmlBind]='pngPath',
|
||||||
|
*ngIf='!isHTML && isPNG'
|
||||||
|
)
|
||||||
i.icon(
|
i.icon(
|
||||||
class='fa-fw {{icon}}',
|
class='fa-fw {{icon}}',
|
||||||
[style.color]='color',
|
[style.color]='color',
|
||||||
*ngIf='!isHTML'
|
*ngIf='!isHTML && !isPNG'
|
||||||
)
|
)
|
||||||
.icon(
|
.icon(
|
||||||
[fastHtmlBind]='icon',
|
[fastHtmlBind]='icon',
|
||||||
|
@@ -12,7 +12,15 @@ export class ProfileIconComponent extends BaseComponent {
|
|||||||
@Input() icon?: string
|
@Input() icon?: string
|
||||||
@Input() color?: string
|
@Input() color?: string
|
||||||
|
|
||||||
|
get pngPath (): string {
|
||||||
|
return `<img src="${this.icon?.trim()}" width="16" height="16" />`
|
||||||
|
}
|
||||||
|
|
||||||
get isHTML (): boolean {
|
get isHTML (): boolean {
|
||||||
return this.icon?.startsWith('<') ?? false
|
return this.icon?.startsWith('<') ?? false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get isPNG (): boolean {
|
||||||
|
return this.icon?.endsWith('.png') ?? false
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -471,6 +471,8 @@ export class SplitTabComponent extends BaseTabComponent implements AfterViewInit
|
|||||||
}
|
}
|
||||||
tab.removeFromContainer()
|
tab.removeFromContainer()
|
||||||
tab.parent = this
|
tab.parent = this
|
||||||
|
|
||||||
|
tab.emitVisibility(this.visibility.value)
|
||||||
}
|
}
|
||||||
|
|
||||||
let target = relative ? this.getParentOf(relative) : null
|
let target = relative ? this.getParentOf(relative) : null
|
||||||
|
@@ -43,6 +43,7 @@ enableWelcomeTab: true
|
|||||||
electronFlags:
|
electronFlags:
|
||||||
- ['force_discrete_gpu', '0']
|
- ['force_discrete_gpu', '0']
|
||||||
enableAutomaticUpdates: true
|
enableAutomaticUpdates: true
|
||||||
|
hideTray: false
|
||||||
version: 1
|
version: 1
|
||||||
vault: null
|
vault: null
|
||||||
encrypted: false
|
encrypted: false
|
||||||
|
@@ -20,7 +20,9 @@ import localeKO from '@angular/common/locales/ko'
|
|||||||
import localePL from '@angular/common/locales/pl'
|
import localePL from '@angular/common/locales/pl'
|
||||||
import localePT from '@angular/common/locales/pt'
|
import localePT from '@angular/common/locales/pt'
|
||||||
import localeRU from '@angular/common/locales/ru'
|
import localeRU from '@angular/common/locales/ru'
|
||||||
|
import localeSRSP from '@angular/common/locales/sr-Cyrl'
|
||||||
import localeSV from '@angular/common/locales/sv'
|
import localeSV from '@angular/common/locales/sv'
|
||||||
|
import localeTR from '@angular/common/locales/tr'
|
||||||
import localeUK from '@angular/common/locales/uk'
|
import localeUK from '@angular/common/locales/uk'
|
||||||
import localeZH from '@angular/common/locales/zh'
|
import localeZH from '@angular/common/locales/zh'
|
||||||
import { Observable, Subject } from 'rxjs'
|
import { Observable, Subject } from 'rxjs'
|
||||||
@@ -45,7 +47,9 @@ registerLocaleData(localeKO)
|
|||||||
registerLocaleData(localePL)
|
registerLocaleData(localePL)
|
||||||
registerLocaleData(localePT)
|
registerLocaleData(localePT)
|
||||||
registerLocaleData(localeRU)
|
registerLocaleData(localeRU)
|
||||||
|
registerLocaleData(localeSRSP)
|
||||||
registerLocaleData(localeSV)
|
registerLocaleData(localeSV)
|
||||||
|
registerLocaleData(localeTR)
|
||||||
registerLocaleData(localeUK)
|
registerLocaleData(localeUK)
|
||||||
registerLocaleData(localeZH)
|
registerLocaleData(localeZH)
|
||||||
|
|
||||||
@@ -136,6 +140,10 @@ export class LocaleService {
|
|||||||
code: 'sv-SE',
|
code: 'sv-SE',
|
||||||
name: 'Svenska',
|
name: 'Svenska',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
code: 'tr-TR',
|
||||||
|
name: 'Türkçe',
|
||||||
|
},
|
||||||
{
|
{
|
||||||
code: 'bg-BG',
|
code: 'bg-BG',
|
||||||
name: 'Български',
|
name: 'Български',
|
||||||
@@ -144,6 +152,10 @@ export class LocaleService {
|
|||||||
code: 'ru-RU',
|
code: 'ru-RU',
|
||||||
name: 'Русский',
|
name: 'Русский',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
code: 'sr-SP',
|
||||||
|
name: 'Српски',
|
||||||
|
},
|
||||||
{
|
{
|
||||||
code: 'uk-UA',
|
code: 'uk-UA',
|
||||||
name: 'Українська',
|
name: 'Українська',
|
||||||
|
@@ -6,6 +6,8 @@ import { HostAppService, Platform, isWindowsBuild, WIN_BUILD_WSL_EXE_DISTRO_FLAG
|
|||||||
|
|
||||||
import { ShellProvider, Shell } from 'tabby-local'
|
import { ShellProvider, Shell } from 'tabby-local'
|
||||||
|
|
||||||
|
import { PowerShell } from 'node-powershell'
|
||||||
|
|
||||||
/* eslint-disable block-scoped-var */
|
/* eslint-disable block-scoped-var */
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@@ -38,10 +40,42 @@ const wslIconMap: Record<string, string> = {
|
|||||||
/** @hidden */
|
/** @hidden */
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class WSLShellProvider extends ShellProvider {
|
export class WSLShellProvider extends ShellProvider {
|
||||||
|
private _pwsh: PowerShell
|
||||||
|
|
||||||
constructor (
|
constructor (
|
||||||
private hostApp: HostAppService,
|
private hostApp: HostAppService,
|
||||||
) {
|
) {
|
||||||
super()
|
super()
|
||||||
|
|
||||||
|
// make sure that this will not use the powershell profile
|
||||||
|
// that may take a long time to load
|
||||||
|
this._pwsh = new PowerShell({
|
||||||
|
executableOptions: {
|
||||||
|
'-NoProfile': true,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
private async _resolveIcon (defaultDistKey: any): Promise<string> {
|
||||||
|
let _icon = wslIconMap.Linux
|
||||||
|
|
||||||
|
// check if the register has PackageFamilyName
|
||||||
|
if (defaultDistKey.PackageFamilyName) {
|
||||||
|
// get the icon from the package family name
|
||||||
|
const packageFamilyName = (defaultDistKey.PackageFamilyName.value as string).split('_')[0]
|
||||||
|
|
||||||
|
if (packageFamilyName) {
|
||||||
|
const _ret = await this._pwsh.invoke(`Get-AppxPackage ${packageFamilyName} | ConvertTo-Json`)
|
||||||
|
|
||||||
|
if (!_ret.hadErrors && _ret.stdout?.toString() !== undefined && _ret.stdout.toString() !== '') {
|
||||||
|
const appx = JSON.parse(_ret.stdout.toString())
|
||||||
|
const installationLocation = appx.InstallLocation
|
||||||
|
_icon = `${installationLocation}\\Assets\\Square44x44Logo.targetsize-16.png`
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return _icon
|
||||||
}
|
}
|
||||||
|
|
||||||
async provide (): Promise<Shell[]> {
|
async provide (): Promise<Shell[]> {
|
||||||
@@ -59,6 +93,7 @@ export class WSLShellProvider extends ShellProvider {
|
|||||||
if (lxss?.DefaultDistribution) {
|
if (lxss?.DefaultDistribution) {
|
||||||
const defaultDistKey = wnr.getRegistryKey(wnr.HK.CU, lxssPath + '\\' + String(lxss.DefaultDistribution.value))
|
const defaultDistKey = wnr.getRegistryKey(wnr.HK.CU, lxssPath + '\\' + String(lxss.DefaultDistribution.value))
|
||||||
if (defaultDistKey?.DistributionName) {
|
if (defaultDistKey?.DistributionName) {
|
||||||
|
const _icon = await this._resolveIcon(defaultDistKey)
|
||||||
const shell: Shell = {
|
const shell: Shell = {
|
||||||
id: 'wsl',
|
id: 'wsl',
|
||||||
name: 'WSL / Default distro',
|
name: 'WSL / Default distro',
|
||||||
@@ -68,7 +103,7 @@ export class WSLShellProvider extends ShellProvider {
|
|||||||
COLORTERM: 'truecolor',
|
COLORTERM: 'truecolor',
|
||||||
},
|
},
|
||||||
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
||||||
icon: wslIconMap[defaultDistKey.DistributionName.value] ?? wslIconMap.Linux,
|
icon: wslIconMap[defaultDistKey.DistributionName.value] ?? _icon,
|
||||||
}
|
}
|
||||||
shells.push(shell)
|
shells.push(shell)
|
||||||
}
|
}
|
||||||
@@ -90,11 +125,14 @@ export class WSLShellProvider extends ShellProvider {
|
|||||||
return []
|
return []
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const child of wnr.listRegistrySubkeys(wnr.HK.CU, lxssPath) as string[]) {
|
for (const child of wnr.listRegistrySubkeys(wnr.HK.CU, lxssPath) as string[]) {
|
||||||
const childKey = wnr.getRegistryKey(wnr.HK.CU, lxssPath + '\\' + child)
|
const childKey = wnr.getRegistryKey(wnr.HK.CU, lxssPath + '\\' + child)
|
||||||
if (!childKey.DistributionName || !childKey.BasePath) {
|
if (!childKey.DistributionName || !childKey.BasePath) {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const _icon = await this._resolveIcon(childKey)
|
||||||
const wslVersion = (childKey.Flags?.value || 0) & 8 ? 2 : 1
|
const wslVersion = (childKey.Flags?.value || 0) & 8 ? 2 : 1
|
||||||
const name = childKey.DistributionName.value
|
const name = childKey.DistributionName.value
|
||||||
const fsBase = wslVersion === 2 ? `\\\\wsl$\\${name}` : childKey.BasePath.value as string + '\\rootfs'
|
const fsBase = wslVersion === 2 ? `\\\\wsl$\\${name}` : childKey.BasePath.value as string + '\\rootfs'
|
||||||
@@ -110,7 +148,7 @@ export class WSLShellProvider extends ShellProvider {
|
|||||||
COLORTERM: 'truecolor',
|
COLORTERM: 'truecolor',
|
||||||
},
|
},
|
||||||
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
||||||
icon: wslIconMap[name] ?? wslIconMap.Linux,
|
icon: wslIconMap[name] ?? _icon,
|
||||||
}
|
}
|
||||||
shells.push(shell)
|
shells.push(shell)
|
||||||
}
|
}
|
||||||
|
@@ -18,7 +18,7 @@
|
|||||||
"author": "Eugene Pankov",
|
"author": "Eugene Pankov",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"untildify": "^4.0.0",
|
"@xterm/addon-web-links": "^0.10.0",
|
||||||
"xterm-addon-web-links": "^0.7.0"
|
"untildify": "^4.0.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -1,7 +1,7 @@
|
|||||||
import { Inject, Injectable } from '@angular/core'
|
import { Inject, Injectable } from '@angular/core'
|
||||||
import { ConfigService, PlatformService } from 'tabby-core'
|
import { ConfigService, PlatformService } from 'tabby-core'
|
||||||
import { TerminalDecorator, BaseTerminalTabComponent, XTermFrontend } from 'tabby-terminal'
|
import { TerminalDecorator, BaseTerminalTabComponent, XTermFrontend } from 'tabby-terminal'
|
||||||
import { WebLinksAddon } from 'xterm-addon-web-links'
|
import { WebLinksAddon } from '@xterm/addon-web-links'
|
||||||
import { LinkHandler } from './api'
|
import { LinkHandler } from './api'
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
|
@@ -2,6 +2,11 @@
|
|||||||
# yarn lockfile v1
|
# yarn lockfile v1
|
||||||
|
|
||||||
|
|
||||||
|
"@xterm/addon-web-links@^0.10.0":
|
||||||
|
version "0.10.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@xterm/addon-web-links/-/addon-web-links-0.10.0.tgz#be3eccaf1cbd4063161458205cd4bbee2b0f34f9"
|
||||||
|
integrity sha512-QhrHCUr8w6ATGviyXwcAIM1qN3nD1hdxwMC8fsW7z/6aaQlb2nt7zmByJt4eOn7ZzrHOzczljqV5S2pkdQp2xw==
|
||||||
|
|
||||||
untildify@^4.0.0:
|
untildify@^4.0.0:
|
||||||
version "4.0.0"
|
version "4.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/untildify/-/untildify-4.0.0.tgz#2bc947b953652487e4600949fb091e3ae8cd919b"
|
resolved "https://registry.yarnpkg.com/untildify/-/untildify-4.0.0.tgz#2bc947b953652487e4600949fb091e3ae8cd919b"
|
||||||
|
@@ -132,7 +132,9 @@ export class AutoOpenTabCLIHandler extends CLIHandler {
|
|||||||
async handle (event: CLIEvent): Promise<boolean> {
|
async handle (event: CLIEvent): Promise<boolean> {
|
||||||
if (!event.secondInstance && this.config.store.terminal.autoOpen && !this.config.store.enableWelcomeTab) {
|
if (!event.secondInstance && this.config.store.terminal.autoOpen && !this.config.store.enableWelcomeTab) {
|
||||||
this.app.ready$.subscribe(() => {
|
this.app.ready$.subscribe(() => {
|
||||||
this.terminal.openTab()
|
if (this.app.tabs.length === 0) {
|
||||||
|
this.terminal.openTab()
|
||||||
|
}
|
||||||
})
|
})
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
@@ -121,6 +121,15 @@ h3.mb-3(translate) Window
|
|||||||
label.btn.btn-secondary(for='frameFull')
|
label.btn.btn-secondary(for='frameFull')
|
||||||
span(translate) Full
|
span(translate) Full
|
||||||
|
|
||||||
|
.form-line(*ngIf='hostApp.platform !== Platform.Web && hostApp.platform !== Platform.Linux')
|
||||||
|
.header
|
||||||
|
.title(translate) Hide tray
|
||||||
|
.description(translate) Hide Tabby in tray or menu bar.
|
||||||
|
toggle(
|
||||||
|
[(ngModel)]='config.store.hideTray',
|
||||||
|
(ngModelChange)='saveConfiguration(true)'
|
||||||
|
)
|
||||||
|
|
||||||
h3.mt-4(translate) Docking
|
h3.mt-4(translate) Docking
|
||||||
|
|
||||||
.form-line(*ngIf='docking')
|
.form-line(*ngIf='docking')
|
||||||
|
@@ -184,13 +184,17 @@ export class ConfigSyncService {
|
|||||||
|
|
||||||
private async autoSync () {
|
private async autoSync () {
|
||||||
while (true) {
|
while (true) {
|
||||||
if (this.isEnabled() && this.config.store.configSync.auto) {
|
try {
|
||||||
const cfg = await this.getConfig(this.config.store.configSync.configID)
|
if (this.isEnabled() && this.config.store.configSync.auto) {
|
||||||
if (new Date(cfg.modified_at) > this.lastRemoteChange) {
|
const cfg = await this.getConfig(this.config.store.configSync.configID)
|
||||||
this.logger.info('Remote config changed, downloading')
|
if (new Date(cfg.modified_at) > this.lastRemoteChange) {
|
||||||
this.download()
|
this.logger.info('Remote config changed, downloading')
|
||||||
this.lastRemoteChange = new Date(cfg.modified_at)
|
this.download()
|
||||||
|
this.lastRemoteChange = new Date(cfg.modified_at)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
} catch (error) {
|
||||||
|
this.logger.debug('Recovering from autoSync network error')
|
||||||
}
|
}
|
||||||
await new Promise(resolve => setTimeout(resolve, 60000))
|
await new Promise(resolve => setTimeout(resolve, 60000))
|
||||||
}
|
}
|
||||||
|
@@ -2,3 +2,4 @@ export * from './contextMenu'
|
|||||||
export * from './interfaces'
|
export * from './interfaces'
|
||||||
export * from './importer'
|
export * from './importer'
|
||||||
export * from './proxyStream'
|
export * from './proxyStream'
|
||||||
|
export { SSHMultiplexerService } from '../services/sshMultiplexer.service'
|
||||||
|
@@ -1,7 +1,10 @@
|
|||||||
terminal-toolbar([tab]='this')
|
terminal-toolbar([tab]='this')
|
||||||
i.fas.fa-xs.fa-circle.text-success.me-2(*ngIf='session && session.open')
|
i.fas.fa-xs.fa-circle.text-success.me-2(*ngIf='session && session.open')
|
||||||
i.fas.fa-xs.fa-circle.text-danger.me-2(*ngIf='!session || !session.open')
|
i.fas.fa-xs.fa-circle.text-danger.me-2(*ngIf='!session || !session.open')
|
||||||
strong.me-auto {{profile.options.user}}@{{profile.options.host}}:{{profile.options.port}}
|
strong.me-auto(
|
||||||
|
style='user-select: text; cursor: text;'
|
||||||
|
onclick='event.stopPropagation()'
|
||||||
|
) {{profile.options.user}}@{{profile.options.host}}:{{profile.options.port}}
|
||||||
|
|
||||||
.me-2(
|
.me-2(
|
||||||
ngbDropdown,
|
ngbDropdown,
|
||||||
|
@@ -1,4 +1,12 @@
|
|||||||
|
import 'ssh2'
|
||||||
const nodeCrypto = require('crypto')
|
const nodeCrypto = require('crypto')
|
||||||
const browserDH = require('diffie-hellman/browser')
|
const browserDH = require('diffie-hellman/browser')
|
||||||
nodeCrypto.createDiffieHellmanGroup = browserDH.createDiffieHellmanGroup
|
nodeCrypto.createDiffieHellmanGroup = browserDH.createDiffieHellmanGroup
|
||||||
nodeCrypto.createDiffieHellman = browserDH.createDiffieHellman
|
nodeCrypto.createDiffieHellman = browserDH.createDiffieHellman
|
||||||
|
|
||||||
|
// Declare function missing from @types
|
||||||
|
declare module 'ssh2' {
|
||||||
|
interface Client {
|
||||||
|
setNoDelay: (enable?: boolean) => this
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -218,6 +218,8 @@ export class SSHSession {
|
|||||||
const resultPromise: Promise<void> = new Promise(async (resolve, reject) => {
|
const resultPromise: Promise<void> = new Promise(async (resolve, reject) => {
|
||||||
ssh.on('ready', () => {
|
ssh.on('ready', () => {
|
||||||
connected = true
|
connected = true
|
||||||
|
// Fix SSH Lagging
|
||||||
|
ssh.setNoDelay(true)
|
||||||
if (this.savedPassword) {
|
if (this.savedPassword) {
|
||||||
this.passwordStorage.savePassword(this.profile, this.savedPassword)
|
this.passwordStorage.savePassword(this.profile, this.savedPassword)
|
||||||
}
|
}
|
||||||
|
@@ -19,6 +19,15 @@
|
|||||||
"author": "Eugene Pankov",
|
"author": "Eugene Pankov",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
"@xterm/addon-canvas": "^0.6.0",
|
||||||
|
"@xterm/addon-fit": "^0.9.0",
|
||||||
|
"@xterm/addon-image": "^0.7.0",
|
||||||
|
"@xterm/addon-ligatures": "^0.8.0",
|
||||||
|
"@xterm/addon-search": "^0.14.0",
|
||||||
|
"@xterm/addon-serialize": "^0.12.0",
|
||||||
|
"@xterm/addon-unicode11": "^0.7.0",
|
||||||
|
"@xterm/addon-webgl": "^0.17.0",
|
||||||
|
"@xterm/xterm": "^5.4.0",
|
||||||
"ansi-colors": "^4.1.1",
|
"ansi-colors": "^4.1.1",
|
||||||
"binstring": "^0.2.1",
|
"binstring": "^0.2.1",
|
||||||
"buffer-replace": "^1.0.0",
|
"buffer-replace": "^1.0.0",
|
||||||
@@ -28,15 +37,6 @@
|
|||||||
"ngx-colors": "^3.4.0",
|
"ngx-colors": "^3.4.0",
|
||||||
"patch-package": "^6.5.0",
|
"patch-package": "^6.5.0",
|
||||||
"runes": "^0.4.2",
|
"runes": "^0.4.2",
|
||||||
"xterm": "^5.3.0",
|
|
||||||
"xterm-addon-canvas": "^0.5.0",
|
|
||||||
"xterm-addon-fit": "^0.8.0",
|
|
||||||
"xterm-addon-image": "^0.5.0",
|
|
||||||
"xterm-addon-ligatures": "^0.7.0",
|
|
||||||
"xterm-addon-search": "^0.13.0",
|
|
||||||
"xterm-addon-serialize": "^0.11.0",
|
|
||||||
"xterm-addon-unicode11": "^0.6.0",
|
|
||||||
"xterm-addon-webgl": "^0.16.0",
|
|
||||||
"zmodem.js": "^0.1.9"
|
"zmodem.js": "^0.1.9"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
|
@@ -3,6 +3,7 @@
|
|||||||
width: 600px;
|
width: 600px;
|
||||||
max-width: 80vw;
|
max-width: 80vw;
|
||||||
right: 40px;
|
right: 40px;
|
||||||
|
height: 36px;
|
||||||
z-index: 5;
|
z-index: 5;
|
||||||
border-radius: 0 0 5px 5px;
|
border-radius: 0 0 5px 5px;
|
||||||
background: rgba(0, 0, 0, .95);
|
background: rgba(0, 0, 0, .95);
|
||||||
@@ -22,6 +23,6 @@
|
|||||||
opacity: .5;
|
opacity: .5;
|
||||||
}
|
}
|
||||||
|
|
||||||
::ng-deep svg {
|
:host ::ng-deep svg {
|
||||||
height: 16px;
|
height: 16px;
|
||||||
}
|
}
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
@import url("../../node_modules/xterm/css/xterm.css");
|
@import url("../../node_modules/@xterm/xterm/css/xterm.css");
|
||||||
|
|
||||||
@font-face {
|
@font-face {
|
||||||
font-family: "monospace-fallback";
|
font-family: "monospace-fallback";
|
||||||
|
@@ -2,15 +2,15 @@ import { BehaviorSubject, filter, firstValueFrom, takeUntil } from 'rxjs'
|
|||||||
import { Injector } from '@angular/core'
|
import { Injector } from '@angular/core'
|
||||||
import { ConfigService, getCSSFontFamily, getWindows10Build, HostAppService, HotkeysService, Platform, PlatformService, ThemesService } from 'tabby-core'
|
import { ConfigService, getCSSFontFamily, getWindows10Build, HostAppService, HotkeysService, Platform, PlatformService, ThemesService } from 'tabby-core'
|
||||||
import { Frontend, SearchOptions, SearchState } from './frontend'
|
import { Frontend, SearchOptions, SearchState } from './frontend'
|
||||||
import { Terminal, ITheme } from 'xterm'
|
import { Terminal, ITheme } from '@xterm/xterm'
|
||||||
import { FitAddon } from 'xterm-addon-fit'
|
import { FitAddon } from '@xterm/addon-fit'
|
||||||
import { LigaturesAddon } from 'xterm-addon-ligatures'
|
import { LigaturesAddon } from '@xterm/addon-ligatures'
|
||||||
import { ISearchOptions, SearchAddon } from 'xterm-addon-search'
|
import { ISearchOptions, SearchAddon } from '@xterm/addon-search'
|
||||||
import { WebglAddon } from 'xterm-addon-webgl'
|
import { WebglAddon } from '@xterm/addon-webgl'
|
||||||
import { Unicode11Addon } from 'xterm-addon-unicode11'
|
import { Unicode11Addon } from '@xterm/addon-unicode11'
|
||||||
import { SerializeAddon } from 'xterm-addon-serialize'
|
import { SerializeAddon } from '@xterm/addon-serialize'
|
||||||
import { ImageAddon } from 'xterm-addon-image'
|
import { ImageAddon } from '@xterm/addon-image'
|
||||||
import { CanvasAddon } from 'xterm-addon-canvas'
|
import { CanvasAddon } from '@xterm/addon-canvas'
|
||||||
import './xterm.css'
|
import './xterm.css'
|
||||||
import deepEqual from 'deep-equal'
|
import deepEqual from 'deep-equal'
|
||||||
import { BaseTerminalProfile, TerminalColorScheme } from '../api/interfaces'
|
import { BaseTerminalProfile, TerminalColorScheme } from '../api/interfaces'
|
||||||
|
@@ -2,6 +2,54 @@
|
|||||||
# yarn lockfile v1
|
# yarn lockfile v1
|
||||||
|
|
||||||
|
|
||||||
|
"@xterm/addon-canvas@^0.6.0":
|
||||||
|
version "0.6.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@xterm/addon-canvas/-/addon-canvas-0.6.0.tgz#08b2af252b8e4c5af3870820576a9a6ca18d517e"
|
||||||
|
integrity sha512-+nj2x595vItxfuAFxzXp46Izrh4EnEyS0Z60hX1iy6OFliP5OQu8Wu7n59m7m1vT6Q4nIWoN1WiH+VLAk4D9jQ==
|
||||||
|
|
||||||
|
"@xterm/addon-fit@^0.9.0":
|
||||||
|
version "0.9.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@xterm/addon-fit/-/addon-fit-0.9.0.tgz#29846f08782c51ad85b949528c45b84ad4ec45d7"
|
||||||
|
integrity sha512-hDlPPbTVPYyvwXu/asW8HbJkI/2RMi0cMaJnBZYVeJB0SWP2NeESMCNr+I7CvBlyI0sAxpxOg8Wk4OMkxBz9WA==
|
||||||
|
|
||||||
|
"@xterm/addon-image@^0.7.0":
|
||||||
|
version "0.7.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@xterm/addon-image/-/addon-image-0.7.0.tgz#86e7342a3fe3fac6ba42944054e660916ec44953"
|
||||||
|
integrity sha512-OXJvmWXhJ5tdqSFX9yR2/d9AXwOz8+lJOghEPu2lSuwgLlMcOZ2YA+YuxPrisXIB2UctEHPAvVDGLbS9cESbzg==
|
||||||
|
|
||||||
|
"@xterm/addon-ligatures@^0.8.0":
|
||||||
|
version "0.8.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@xterm/addon-ligatures/-/addon-ligatures-0.8.0.tgz#d7f196c09edad0e7e45c691dce74f28bab683c37"
|
||||||
|
integrity sha512-hvClRA4a4saHXJV+Svxo6tC9NLN17coKbbFChhaQFvTe+TAx+G+LI1NytI8rmSIosOhg9m4uYB3J9o3Qyj4qxA==
|
||||||
|
dependencies:
|
||||||
|
font-finder "^1.1.0"
|
||||||
|
font-ligatures "^1.4.1"
|
||||||
|
|
||||||
|
"@xterm/addon-search@^0.14.0":
|
||||||
|
version "0.14.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@xterm/addon-search/-/addon-search-0.14.0.tgz#783c1a3fb301a98f0d0598453bd80d22cb0863ed"
|
||||||
|
integrity sha512-gyKIjC1c2bqxBevPmWlMWRsHqiufUgl3HjN3OYim6YPClqNRUlTab7l8aW8i3W83XzU9q0gmAfIOe4KDmo0GfQ==
|
||||||
|
|
||||||
|
"@xterm/addon-serialize@^0.12.0":
|
||||||
|
version "0.12.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@xterm/addon-serialize/-/addon-serialize-0.12.0.tgz#e83e8c21722dac7970521ade2df3ea07dbc2fd30"
|
||||||
|
integrity sha512-VJGfiTYfWJ1MC+eBBm7lY29+EMxnwpl2i6GecEwqe/7oXr2OEdMofdrpeXMa8OtlMd9bqjfdIfOoSZMmAzBm3w==
|
||||||
|
|
||||||
|
"@xterm/addon-unicode11@^0.7.0":
|
||||||
|
version "0.7.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@xterm/addon-unicode11/-/addon-unicode11-0.7.0.tgz#cf4fa4da58b0cbcad3666e03d642184f76fe7d27"
|
||||||
|
integrity sha512-HIhQpRenrslPn6GlUmCYZcSXvdU0JkTgXQ66dx9QwXEzgNhoh70b7hXPZDBoMD/bH/7DYlseeGO7qKQlFzyhbA==
|
||||||
|
|
||||||
|
"@xterm/addon-webgl@^0.17.0":
|
||||||
|
version "0.17.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@xterm/addon-webgl/-/addon-webgl-0.17.0.tgz#1da534456b7971ebb2f08c381d4732d1f104d7d8"
|
||||||
|
integrity sha512-KUH//EZCz7j1+IekW8sZzmcj/y9gOLf/HMcsWXjg0Xr5cT1lIBIIbbBlbf5kZ+XnA/8c1IuBm1vx+blzlfPk0g==
|
||||||
|
|
||||||
|
"@xterm/xterm@^5.4.0":
|
||||||
|
version "5.4.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@xterm/xterm/-/xterm-5.4.0.tgz#a35b585750ca492cbf2a4c99472c480d8c122840"
|
||||||
|
integrity sha512-GlyzcZZ7LJjhFevthHtikhiDIl8lnTSgol6eTM4aoSNLcuXu3OEhnbqdCVIjtIil3jjabf3gDtb1S8FGahsuEw==
|
||||||
|
|
||||||
"@yarnpkg/lockfile@^1.1.0":
|
"@yarnpkg/lockfile@^1.1.0":
|
||||||
version "1.1.0"
|
version "1.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz#e77a97fbd345b76d83245edcd17d393b1b41fb31"
|
resolved "https://registry.yarnpkg.com/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz#e77a97fbd345b76d83245edcd17d393b1b41fb31"
|
||||||
@@ -464,54 +512,6 @@ xtend@^4.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54"
|
resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54"
|
||||||
integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==
|
integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==
|
||||||
|
|
||||||
xterm-addon-canvas@^0.5.0:
|
|
||||||
version "0.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/xterm-addon-canvas/-/xterm-addon-canvas-0.5.0.tgz#95d056cec6da42a51b2c47746a011409020c388c"
|
|
||||||
integrity sha512-QOo/eZCMrCleAgMimfdbaZCgmQRWOml63Ued6RwQ+UTPvQj3Av9QKx3xksmyYrDGRO/AVRXa9oNuzlYvLdmoLQ==
|
|
||||||
|
|
||||||
xterm-addon-fit@^0.8.0:
|
|
||||||
version "0.8.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/xterm-addon-fit/-/xterm-addon-fit-0.8.0.tgz#48ca99015385141918f955ca7819e85f3691d35f"
|
|
||||||
integrity sha512-yj3Np7XlvxxhYF/EJ7p3KHaMt6OdwQ+HDu573Vx1lRXsVxOcnVJs51RgjZOouIZOczTsskaS+CpXspK81/DLqw==
|
|
||||||
|
|
||||||
xterm-addon-image@^0.5.0:
|
|
||||||
version "0.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/xterm-addon-image/-/xterm-addon-image-0.5.0.tgz#3c9bb332a3de55ab200dbefd3411e3b0d985314f"
|
|
||||||
integrity sha512-bWXUBeDzhisYh0clVKx4JgQrZjpn+/QRMRwNsfnRpjCMhgmZ+SL3Bivktd7q03O4uKMMcAOe6bSmppwP9/um0Q==
|
|
||||||
|
|
||||||
xterm-addon-ligatures@^0.7.0:
|
|
||||||
version "0.7.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/xterm-addon-ligatures/-/xterm-addon-ligatures-0.7.0.tgz#28e24744fc06e83b0e3dad51f96823b036714ab3"
|
|
||||||
integrity sha512-5HXKCN5vB8KkqLIloItZkYAwMWF4Y2yOQsc4oFUXOjV3GnZskZpH0W+8rJH+80wxLNym7OMpdmg3a/Vd/+owDg==
|
|
||||||
dependencies:
|
|
||||||
font-finder "^1.1.0"
|
|
||||||
font-ligatures "^1.4.1"
|
|
||||||
|
|
||||||
xterm-addon-search@^0.13.0:
|
|
||||||
version "0.13.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/xterm-addon-search/-/xterm-addon-search-0.13.0.tgz#21286f4db48aa949fbefce34bb8bc0c9d3cec627"
|
|
||||||
integrity sha512-sDUwG4CnqxUjSEFh676DlS3gsh3XYCzAvBPSvJ5OPgF3MRL3iHLPfsb06doRicLC2xXNpeG2cWk8x1qpESWJMA==
|
|
||||||
|
|
||||||
xterm-addon-serialize@^0.11.0:
|
|
||||||
version "0.11.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/xterm-addon-serialize/-/xterm-addon-serialize-0.11.0.tgz#e8b34a3618750a9e132562a6459627059c031226"
|
|
||||||
integrity sha512-2CNDnmLdLkNWfsxNFkGsI5FE9W/BbsMzeOrbu59yNqH9L6k1gmL+Ab6VXxEp2NQUJSzaiqi6t0nFR5k5EDkVIg==
|
|
||||||
|
|
||||||
xterm-addon-unicode11@^0.6.0:
|
|
||||||
version "0.6.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/xterm-addon-unicode11/-/xterm-addon-unicode11-0.6.0.tgz#733fd17bdf2ae6e818493db1d41241c999de0786"
|
|
||||||
integrity sha512-5pkb8YoS/deRtNqQRw8t640mu+Ga8B2MG3RXGQu0bwgcfr8XiXIRI880TWM49ICAHhTmnOLPzIIBIjEnCq7k2A==
|
|
||||||
|
|
||||||
xterm-addon-webgl@^0.16.0:
|
|
||||||
version "0.16.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/xterm-addon-webgl/-/xterm-addon-webgl-0.16.0.tgz#9872d08a64136f893b27ef9a6412136d3bf563c4"
|
|
||||||
integrity sha512-E8cq1AiqNOv0M/FghPT+zPAEnvIQRDbAbkb04rRYSxUym69elPWVJ4sv22FCLBqM/3LcrmBLl/pELnBebVFKgA==
|
|
||||||
|
|
||||||
xterm@^5.3.0:
|
|
||||||
version "5.3.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/xterm/-/xterm-5.3.0.tgz#867daf9cc826f3d45b5377320aabd996cb0fce46"
|
|
||||||
integrity sha512-8QqjlekLUFTrU6x7xck1MsPzPA571K5zNqWm0M0oroYEWVOptZ0+ubQSkQ3uxIEhcIHRujJy6emDWX4A7qyFzg==
|
|
||||||
|
|
||||||
yallist@^4.0.0:
|
yallist@^4.0.0:
|
||||||
version "4.0.0"
|
version "4.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72"
|
resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72"
|
||||||
|
Reference in New Issue
Block a user