moved spinner intro baseTerminalTab

This commit is contained in:
Eugene Pankov 2021-07-05 22:14:42 +02:00
parent 025d2d1748
commit 07095f3476
No known key found for this signature in database
GPG key ID: 5896FCBBDD1CF4F4
12 changed files with 61 additions and 91 deletions

View file

@ -18,8 +18,7 @@
"license": "MIT", "license": "MIT",
"devDependencies": { "devDependencies": {
"@types/node": "14.14.14", "@types/node": "14.14.14",
"ansi-colors": "^4.1.1", "ansi-colors": "^4.1.1"
"cli-spinner": "^0.2.10"
}, },
"peerDependencies": { "peerDependencies": {
"@angular/animations": "^9.1.9", "@angular/animations": "^9.1.9",

View file

@ -1,6 +1,5 @@
/* eslint-disable @typescript-eslint/explicit-module-boundary-types */ /* eslint-disable @typescript-eslint/explicit-module-boundary-types */
import colors from 'ansi-colors' import colors from 'ansi-colors'
import { Spinner } from 'cli-spinner'
import { Component, Injector } from '@angular/core' import { Component, Injector } from '@angular/core'
import { first } from 'rxjs/operators' import { first } from 'rxjs/operators'
import { SelectorService } from 'tabby-core' import { SelectorService } from 'tabby-core'
@ -68,21 +67,14 @@ export class SerialTabComponent extends BaseTerminalTabComponent {
this.setSession(session) this.setSession(session)
this.write(`Connecting to `) this.write(`Connecting to `)
const spinner = new Spinner({ this.startSpinner('Connecting')
text: 'Connecting',
stream: {
write: x => this.write(x),
},
})
spinner.setSpinnerString(6)
spinner.start()
try { try {
await this.session!.start() await this.session!.start()
spinner.stop(true) this.stopSpinner()
session.emitServiceMessage('Port opened') session.emitServiceMessage('Port opened')
} catch (e) { } catch (e) {
spinner.stop(true) this.stopSpinner()
this.write(colors.black.bgRed(' X ') + ' ' + colors.red(e.message) + '\r\n') this.write(colors.black.bgRed(' X ') + ' ' + colors.red(e.message) + '\r\n')
return return
} }

View file

@ -24,7 +24,6 @@
"@types/node": "14.14.31", "@types/node": "14.14.31",
"@types/ssh2": "^0.5.46", "@types/ssh2": "^0.5.46",
"ansi-colors": "^4.1.1", "ansi-colors": "^4.1.1",
"cli-spinner": "^0.2.10",
"ssh2": "^1.1.0", "ssh2": "^1.1.0",
"sshpk": "Eugeny/node-sshpk#89ed17dfae425a8b629873c8337e77d26838c04f", "sshpk": "Eugeny/node-sshpk#89ed17dfae425a8b629873c8337e77d26838c04f",
"strip-ansi": "^7.0.0" "strip-ansi": "^7.0.0"

View file

@ -1,5 +1,4 @@
import colors from 'ansi-colors' import colors from 'ansi-colors'
import { Spinner } from 'cli-spinner'
import { Component, Injector, HostListener } from '@angular/core' import { Component, Injector, HostListener } from '@angular/core'
import { NgbModal } from '@ng-bootstrap/ng-bootstrap' import { NgbModal } from '@ng-bootstrap/ng-bootstrap'
import { first } from 'rxjs/operators' import { first } from 'rxjs/operators'
@ -26,13 +25,6 @@ export class SSHTabComponent extends BaseTerminalTabComponent {
private sessionStack: SSHSession[] = [] private sessionStack: SSHSession[] = []
private recentInputs = '' private recentInputs = ''
private reconnectOffered = false private reconnectOffered = false
private spinner = new Spinner({
text: 'Connecting',
stream: {
write: x => this.write(x),
},
})
private spinnerActive = false
constructor ( constructor (
injector: Injector, injector: Injector,
@ -120,13 +112,11 @@ export class SSHTabComponent extends BaseTerminalTabComponent {
this.write('\r\n' + colors.black.bgWhite(' SSH ') + ` Connecting to ${session.profile.options.host}\r\n`) this.write('\r\n' + colors.black.bgWhite(' SSH ') + ` Connecting to ${session.profile.options.host}\r\n`)
this.startSpinner() this.startSpinner('Connecting')
this.attachSessionHandler(session.serviceMessage$, msg => { this.attachSessionHandler(session.serviceMessage$, msg => {
this.pauseSpinner(() => { this.write(`\r${colors.black.bgWhite(' SSH ')} ${msg}\r\n`)
this.write(`\r${colors.black.bgWhite(' SSH ')} ${msg}\r\n`) session.resize(this.size.columns, this.size.rows)
session.resize(this.size.columns, this.size.rows)
})
}) })
try { try {
@ -232,24 +222,4 @@ export class SSHTabComponent extends BaseTerminalTabComponent {
onClick (): void { onClick (): void {
this.sftpPanelVisible = false this.sftpPanelVisible = false
} }
private startSpinner () {
this.spinner.setSpinnerString(6)
this.spinner.start()
this.spinnerActive = true
}
private stopSpinner () {
this.spinner.stop(true)
this.spinnerActive = false
}
private pauseSpinner (work: () => void) {
const wasActive = this.spinnerActive
this.stopSpinner()
work()
if (wasActive) {
this.startSpinner()
}
}
} }

View file

@ -1,6 +1,6 @@
import colors from 'ansi-colors' import colors from 'ansi-colors'
import { Duplex } from 'stream' import { Duplex } from 'stream'
import { Injectable, Injector, NgZone } from '@angular/core' import { Injectable, NgZone } from '@angular/core'
import { NgbModal } from '@ng-bootstrap/ng-bootstrap' import { NgbModal } from '@ng-bootstrap/ng-bootstrap'
import { Client } from 'ssh2' import { Client } from 'ssh2'
import { exec } from 'child_process' import { exec } from 'child_process'
@ -16,8 +16,7 @@ export class SSHService {
private detectedWinSCPPath: string | null private detectedWinSCPPath: string | null
private constructor ( private constructor (
private injector: Injector, log: LogService,
private log: LogService,
private zone: NgZone, private zone: NgZone,
private ngbModal: NgbModal, private ngbModal: NgbModal,
private passwordStorage: PasswordStorageService, private passwordStorage: PasswordStorageService,

View file

@ -74,11 +74,6 @@ brace-expansion@^1.1.7:
balanced-match "^1.0.0" balanced-match "^1.0.0"
concat-map "0.0.1" concat-map "0.0.1"
cli-spinner@^0.2.10:
version "0.2.10"
resolved "https://registry.yarnpkg.com/cli-spinner/-/cli-spinner-0.2.10.tgz#f7d617a36f5c47a7bc6353c697fc9338ff782a47"
integrity sha512-U0sSQ+JJvSLi1pAYuJykwiA8Dsr15uHEy85iCJ6A+0DjVxivr3d+N2Wjvodeg89uP5K6TswFkKBfAD7B3YSn/Q==
cli@0.4.x: cli@0.4.x:
version "0.4.5" version "0.4.5"
resolved "https://registry.yarnpkg.com/cli/-/cli-0.4.5.tgz#78f9485cd161b566e9a6c72d7170c4270e81db61" resolved "https://registry.yarnpkg.com/cli/-/cli-0.4.5.tgz#78f9485cd161b566e9a6c72d7170c4270e81db61"

View file

@ -17,8 +17,7 @@
"author": "Eugene Pankov", "author": "Eugene Pankov",
"license": "MIT", "license": "MIT",
"devDependencies": { "devDependencies": {
"@types/node": "14.14.31", "@types/node": "14.14.31"
"cli-spinner": "^0.2.10"
}, },
"peerDependencies": { "peerDependencies": {
"@angular/animations": "^9.1.9", "@angular/animations": "^9.1.9",

View file

@ -1,5 +1,4 @@
import colors from 'ansi-colors' import colors from 'ansi-colors'
import { Spinner } from 'cli-spinner'
import { Component, Injector } from '@angular/core' import { Component, Injector } from '@angular/core'
import { first } from 'rxjs/operators' import { first } from 'rxjs/operators'
import { Platform, RecoveryToken } from 'tabby-core' import { Platform, RecoveryToken } from 'tabby-core'
@ -19,13 +18,6 @@ export class TelnetTabComponent extends BaseTerminalTabComponent {
profile?: TelnetProfile profile?: TelnetProfile
session: TelnetSession|null = null session: TelnetSession|null = null
private reconnectOffered = false private reconnectOffered = false
private spinner = new Spinner({
text: 'Connecting',
stream: {
write: x => this.write(x),
},
})
private spinnerActive = false
// eslint-disable-next-line @typescript-eslint/no-useless-constructor // eslint-disable-next-line @typescript-eslint/no-useless-constructor
constructor ( constructor (
@ -84,13 +76,11 @@ export class TelnetTabComponent extends BaseTerminalTabComponent {
this.setSession(session) this.setSession(session)
try { try {
this.startSpinner() this.startSpinner('Connecting')
this.attachSessionHandler(session.serviceMessage$, msg => { this.attachSessionHandler(session.serviceMessage$, msg => {
this.pauseSpinner(() => { this.write(`\r${colors.black.bgWhite(' Telnet ')} ${msg}\r\n`)
this.write(`\r${colors.black.bgWhite(' Telnet ')} ${msg}\r\n`) session.resize(this.size.columns, this.size.rows)
session.resize(this.size.columns, this.size.rows)
})
}) })
try { try {
@ -133,24 +123,4 @@ export class TelnetTabComponent extends BaseTerminalTabComponent {
} }
)).response === 1 )).response === 1
} }
private startSpinner () {
this.spinner.setSpinnerString(6)
this.spinner.start()
this.spinnerActive = true
}
private stopSpinner () {
this.spinner.stop(true)
this.spinnerActive = false
}
private pauseSpinner (work: () => void) {
const wasActive = this.spinnerActive
this.stopSpinner()
work()
if (wasActive) {
this.startSpinner()
}
}
} }

View file

@ -27,6 +27,7 @@
"dataurl": "0.1.0", "dataurl": "0.1.0",
"deep-equal": "2.0.5", "deep-equal": "2.0.5",
"ps-node": "^0.1.6", "ps-node": "^0.1.6",
"cli-spinner": "^0.2.10",
"runes": "^0.4.2", "runes": "^0.4.2",
"shell-escape": "^0.2.0", "shell-escape": "^0.2.0",
"utils-decorators": "^1.8.1", "utils-decorators": "^1.8.1",

View file

@ -1,5 +1,6 @@
import { Observable, Subject, Subscription } from 'rxjs' import { Observable, Subject, Subscription } from 'rxjs'
import { first } from 'rxjs/operators' import { first } from 'rxjs/operators'
import { Spinner } from 'cli-spinner'
import colors from 'ansi-colors' import colors from 'ansi-colors'
import { NgZone, OnInit, OnDestroy, Injector, ViewChild, HostBinding, Input, ElementRef, InjectFlags } from '@angular/core' import { NgZone, OnInit, OnDestroy, Injector, ViewChild, HostBinding, Input, ElementRef, InjectFlags } from '@angular/core'
import { trigger, transition, style, animate, AnimationTriggerMetadata } from '@angular/animations' import { trigger, transition, style, animate, AnimationTriggerMetadata } from '@angular/animations'
@ -119,6 +120,12 @@ export class BaseTerminalTabComponent extends BaseTabComponent implements OnInit
private allFocusModeSubscription: Subscription|null = null private allFocusModeSubscription: Subscription|null = null
private sessionHandlers = new SubscriptionContainer() private sessionHandlers = new SubscriptionContainer()
private sessionSupportsBracketedPaste = false private sessionSupportsBracketedPaste = false
private spinner = new Spinner({
stream: {
write: x => this.writeRaw(x),
},
})
private spinnerActive = false
get input$ (): Observable<Buffer> { get input$ (): Observable<Buffer> {
if (!this.frontend) { if (!this.frontend) {
@ -369,6 +376,12 @@ export class BaseTerminalTabComponent extends BaseTabComponent implements OnInit
* Feeds input into the terminal frontend * Feeds input into the terminal frontend
*/ */
write (data: string): void { write (data: string): void {
this.withSpinnerPaused(() => {
this.writeRaw(data)
})
}
protected writeRaw (data: string): void {
if (!this.frontend) { if (!this.frontend) {
throw new Error('Frontend not ready') throw new Error('Frontend not ready')
} }
@ -666,4 +679,33 @@ export class BaseTerminalTabComponent extends BaseTabComponent implements OnInit
protected detachSessionHandlers (): void { protected detachSessionHandlers (): void {
this.sessionHandlers.cancelAll() this.sessionHandlers.cancelAll()
} }
protected startSpinner (text?: string): void {
if (this.spinnerActive) {
return
}
if (text) {
this.spinner.text = text
}
this.spinner.setSpinnerString(6)
this.spinner.start()
this.spinnerActive = true
}
protected stopSpinner (): void {
if (!this.spinnerActive) {
return
}
this.spinner.stop(true)
this.spinnerActive = false
}
protected withSpinnerPaused (work: () => void): void {
const wasActive = this.spinnerActive
this.stopSpinner()
work()
if (wasActive) {
this.startSpinner()
}
}
} }

View file

@ -1,6 +1,5 @@
import { Observable, Subject } from 'rxjs' import { Observable, Subject } from 'rxjs'
/** /**
* A session object for a [[BaseTerminalTabComponent]] * A session object for a [[BaseTerminalTabComponent]]
* Extend this to implement custom I/O and process management for your terminal tab * Extend this to implement custom I/O and process management for your terminal tab

View file

@ -52,6 +52,11 @@ call-bind@^1.0.0, call-bind@^1.0.2:
function-bind "^1.1.1" function-bind "^1.1.1"
get-intrinsic "^1.0.2" get-intrinsic "^1.0.2"
cli-spinner@^0.2.10:
version "0.2.10"
resolved "https://registry.yarnpkg.com/cli-spinner/-/cli-spinner-0.2.10.tgz#f7d617a36f5c47a7bc6353c697fc9338ff782a47"
integrity sha512-U0sSQ+JJvSLi1pAYuJykwiA8Dsr15uHEy85iCJ6A+0DjVxivr3d+N2Wjvodeg89uP5K6TswFkKBfAD7B3YSn/Q==
connected-domain@^1.0.0: connected-domain@^1.0.0:
version "1.0.0" version "1.0.0"
resolved "https://registry.yarnpkg.com/connected-domain/-/connected-domain-1.0.0.tgz#bfe77238c74be453a79f0cb6058deeb4f2358e93" resolved "https://registry.yarnpkg.com/connected-domain/-/connected-domain-1.0.0.tgz#bfe77238c74be453a79f0cb6058deeb4f2358e93"