typing fixes

This commit is contained in:
Eugene Pankov 2023-02-27 00:09:04 +01:00
parent 1e5cfd1d4b
commit 441f442915
No known key found for this signature in database
GPG Key ID: 5896FCBBDD1CF4F4
17 changed files with 40 additions and 28 deletions

View File

@ -71,7 +71,7 @@ title-bar(
ngbDropdown ngbDropdown
) )
button.btn.btn-secondary.btn-tab-bar( button.btn.btn-secondary.btn-tab-bar(
[title]='button.title', [title]='button.label',
(click)='button.run && button.run()', (click)='button.run && button.run()',
[fastHtmlBind]='button.icon', [fastHtmlBind]='button.icon',
ngbDropdownToggle, ngbDropdownToggle,

View File

@ -79,8 +79,8 @@ export class AppRootComponent {
constructor ( constructor (
private hotkeys: HotkeysService, private hotkeys: HotkeysService,
private updater: UpdaterService,
private commands: CommandService, private commands: CommandService,
public updater: UpdaterService,
public hostWindow: HostWindowService, public hostWindow: HostWindowService,
public hostApp: HostAppService, public hostApp: HostAppService,
public config: ConfigService, public config: ConfigService,

View File

@ -6,7 +6,7 @@ import { PlatformService } from '../api/platform'
selector: '[fastHtmlBind]', selector: '[fastHtmlBind]',
}) })
export class FastHtmlBindDirective implements OnChanges { export class FastHtmlBindDirective implements OnChanges {
@Input() fastHtmlBind: string @Input() fastHtmlBind?: string
constructor ( constructor (
private el: ElementRef, private el: ElementRef,
@ -14,7 +14,7 @@ export class FastHtmlBindDirective implements OnChanges {
) { } ) { }
ngOnChanges (): void { ngOnChanges (): void {
this.el.nativeElement.innerHTML = this.fastHtmlBind || '' this.el.nativeElement.innerHTML = this.fastHtmlBind ?? ''
for (const link of this.el.nativeElement.querySelectorAll('a')) { for (const link of this.el.nativeElement.querySelectorAll('a')) {
link.addEventListener('click', event => { link.addEventListener('click', event => {
event.preventDefault() event.preventDefault()

View File

@ -13,7 +13,7 @@ ng-container(*ngIf='!argvMode')
(ngModelChange)='parseCommand()' (ngModelChange)='parseCommand()'
) )
ng-container(*ngIf='argvMode') ng-container(*ngIf='argvMode && _model')
.mb-3 .mb-3
label(translate) Program label(translate) Program
.input-group .input-group
@ -28,7 +28,7 @@ ng-container(*ngIf='argvMode')
[(ngModel)]='_model.command', [(ngModel)]='_model.command',
) )
.mb-3 .mb-3(*ngIf='_model.args')
label(translate) Arguments label(translate) Arguments
.input-group( .input-group(
*ngFor='let arg of _model.args; index as i; trackBy: trackByIndex', *ngFor='let arg of _model.args; index as i; trackBy: trackByIndex',

View File

@ -21,8 +21,8 @@ ul.nav-tabs.mb-2(ngbNav, #nav='ngbNav')
i.fas.fa-fw.fa-search(*ngIf='availablePluginsReady') i.fas.fa-fw.fa-search(*ngIf='availablePluginsReady')
input.form-control( input.form-control(
type='text', type='text',
[(ngModel)]='_1', [(ngModel)]='availableFilter',
(ngModelChange)='searchAvailable(_1)', (ngModelChange)='searchAvailable(availableFilter)',
[placeholder]='"Search plugins"|translate' [placeholder]='"Search plugins"|translate'
) )
@ -64,8 +64,8 @@ ul.nav-tabs.mb-2(ngbNav, #nav='ngbNav')
i.fas.fa-fw.fa-search i.fas.fa-fw.fa-search
input.form-control( input.form-control(
type='text', type='text',
[(ngModel)]='_2', [(ngModel)]='installedFilter',
(ngModelChange)='searchInstalled(_2)', (ngModelChange)='searchInstalled(installedFilter)',
[placeholder]='"Search plugins"|translate' [placeholder]='"Search plugins"|translate'
) )
@ -89,7 +89,7 @@ ul.nav-tabs.mb-2(ngbNav, #nav='ngbNav')
i.fas.fa-fw.fa-circle-notch.fa-spin(*ngIf='busy.get(plugin.name) == BusyState.Installing') i.fas.fa-fw.fa-circle-notch.fa-spin(*ngIf='busy.get(plugin.name) == BusyState.Installing')
span( span(
translate='Upgrade to {version}', translate='Upgrade to {version}',
[translateParams]='{version: knownUpgrades[plugin.name].version}' [translateParams]='{version: knownUpgrades[plugin.name]?.version}'
) )
ng-template(ngbPanelContent) ng-template(ngbPanelContent)

View File

@ -32,6 +32,8 @@ export class PluginsSettingsTabComponent {
@HostBinding('class.content-box') true @HostBinding('class.content-box') true
installedPlugins$: PluginInfo[] = [] installedPlugins$: PluginInfo[] = []
installedFilter = ''
availableFilter = ''
constructor ( constructor (
private config: ConfigService, private config: ConfigService,

View File

@ -85,7 +85,7 @@ ul.nav-tabs(ngbNav, #nav='ngbNav')
.header .header
.title(translate) Slow feed .title(translate) Slow feed
.description(translate) Sends data one byte at a time .description(translate) Sends data one byte at a time
toggle([(ngModel)]='profile.options.slowFeed') toggle([(ngModel)]='profile.options.slowSend')
li(ngbNavItem) li(ngbNavItem)
a(ngbNavLink, translate) Login scripts a(ngbNavLink, translate) Login scripts

View File

@ -185,6 +185,7 @@ h3.mt-4(translate) Docking
label.btn.btn-secondary(id='dockScreenCurrent') label.btn.btn-secondary(id='dockScreenCurrent')
span(translate) Current span(translate) Current
input.btn-check( input.btn-check(
*ngFor='let screen of screens',
type='radio', type='radio',
name='dockScreen', name='dockScreen',
[(ngModel)]='config.store.appearance.dockScreen', [(ngModel)]='config.store.appearance.dockScreen',

View File

@ -10,7 +10,7 @@
.d-flex.align-items-center .d-flex.align-items-center
label(translate) Last known host key fingerprint label(translate) Last known host key fingerprint
.badge.text-bg-danger.ms-auto {{ selector.type }} .badge.text-bg-danger.ms-auto {{ selector.type }}
code {{knownHost.digest}} code {{knownHost?.digest}}
.mb-3 .mb-3
.d-flex.align-items-center .d-flex.align-items-center

View File

@ -195,6 +195,7 @@ ul.nav-tabs(ngbNav, #nav='ngbNav')
a(ngbNavLink, translate) Ports a(ngbNavLink, translate) Ports
ng-template(ngbNavContent) ng-template(ngbNavContent)
ssh-port-forwarding-config( ssh-port-forwarding-config(
*ngIf='profile.options.forwardedPorts',
[model]='profile.options.forwardedPorts', [model]='profile.options.forwardedPorts',
(forwardAdded)='onForwardAdded($event)', (forwardAdded)='onForwardAdded($event)',
(forwardRemoved)='onForwardRemoved($event)' (forwardRemoved)='onForwardRemoved($event)'

View File

@ -38,10 +38,10 @@ sftp-panel.bg-dark(
@panelSlide, @panelSlide,
[@.disabled]='!config.store.accessibility.animations', [@.disabled]='!config.store.accessibility.animations',
[(path)]='sftpPath', [(path)]='sftpPath',
*ngIf='sftpPanelVisible', *ngIf='sftpPanelVisible && sshSession',
(click)='$event.stopPropagation()', (click)='$event.stopPropagation()',
[session]='sshSession', [session]='sshSession!',
[cwdDetectionAvailable]='session?.supportsWorkingDirectory()', [cwdDetectionAvailable]='session?.supportsWorkingDirectory() ?? false',
(closed)='sftpPanelVisible = false' (closed)='sftpPanelVisible = false'
) )
@ -49,5 +49,5 @@ keyboard-interactive-auth-panel.bg-dark(
*ngIf='activeKIPrompt', *ngIf='activeKIPrompt',
[prompt]='activeKIPrompt', [prompt]='activeKIPrompt',
(click)='$event.stopPropagation()', (click)='$event.stopPropagation()',
(done)='activeKIPrompt = null; frontend.focus()' (done)='activeKIPrompt = null; frontend?.focus()'
) )

View File

@ -1,11 +1,11 @@
.terminal-toolbar-spacer .terminal-toolbar-spacer
.content(#content, [style.opacity]='frontendIsReady ? 1 : 0') .content(#content, [style.opacity]='frontendIsReady ? 1 : 0')
search-panel( search-panel(
*ngIf='showSearchPanel && hasFocus', *ngIf='showSearchPanel && hasFocus && frontend',
@toolbarSlide, @toolbarSlide,
[@.disabled]='!config.store.accessibility.animations', [@.disabled]='!config.store.accessibility.animations',
[frontend]='frontend', [frontend]='frontend',
(close)='showSearchPanel = false; frontend?.cancelSearch()' (close)='showSearchPanel = false; frontend.cancelSearch()'
) )
button.btn.btn-sm.btn-link.toolbar-pin-button( button.btn.btn-sm.btn-link.toolbar-pin-button(

View File

@ -1,9 +1,9 @@
.head .head
.bg-dark.p-3.mb-4(*ngIf='model != null') .bg-dark.p-3.mb-4(*ngIf='model != undefined')
.d-flex.align-items-center .d-flex.align-items-center
span {{model.name}} span {{model.name}}
.me-auto .me-auto
a.btn-link((click)='selectScheme(null); $event.preventDefault()', href='#', translate) Clear a.btn-link((click)='selectScheme(undefined); $event.preventDefault()', href='#', translate) Clear
color-scheme-preview([scheme]='model') color-scheme-preview([scheme]='model')

View File

@ -11,7 +11,7 @@ _('Search color schemes')
/** @hidden */ /** @hidden */
@Component({ @Component({
selector: 'color-scheme-selector', selector: 'color-scheme-selector',
templateUrl:'./colorSchemeSelector.component.pug', templateUrl: './colorSchemeSelector.component.pug',
styles: [` styles: [`
:host { :host {
display: block; display: block;
@ -25,8 +25,8 @@ export class ColorSchemeSelectorComponent {
allColorSchemes: TerminalColorScheme[] = [] allColorSchemes: TerminalColorScheme[] = []
filter = '' filter = ''
@Input() model: TerminalColorScheme|null = null @Input() model?: TerminalColorScheme
@Output() modelChange = new EventEmitter<TerminalColorScheme|null>() @Output() modelChange = new EventEmitter<TerminalColorScheme|undefined>()
@HostBinding('class.content-box') true @HostBinding('class.content-box') true
@ -45,7 +45,7 @@ export class ColorSchemeSelectorComponent {
this.changeDetector.markForCheck() this.changeDetector.markForCheck()
} }
selectScheme (scheme: TerminalColorScheme|null) { selectScheme (scheme: TerminalColorScheme|undefined) {
this.model = scheme this.model = scheme
this.modelChange.emit(scheme) this.modelChange.emit(scheme)
this.changeDetector.markForCheck() this.changeDetector.markForCheck()

View File

@ -62,7 +62,7 @@
*ngFor='let _ of config.store.terminal.colorScheme.colors; let idx = index; trackBy: colorsTrackBy', *ngFor='let _ of config.store.terminal.colorScheme.colors; let idx = index; trackBy: colorsTrackBy',
[(model)]='config.store.terminal.colorScheme.colors[idx]', [(model)]='config.store.terminal.colorScheme.colors[idx]',
(modelChange)='config.save()', (modelChange)='config.save()',
[title]='idx', [title]='idx.toString()',
hint='ANSI color {{idx}}' hint='ANSI color {{idx}}'
) )

View File

@ -10,7 +10,7 @@
div(ngbDropdownMenu) div(ngbDropdownMenu)
a.d-flex.flex-column( a.d-flex.flex-column(
*ngFor='let mode of inputModes', *ngFor='let mode of inputModes',
(click)='options.inputMode = mode.key', (click)='setInputMode(mode.key)',
ngbDropdownItem ngbDropdownItem
) )
div {{mode.name|translate}} div {{mode.name|translate}}
@ -37,7 +37,7 @@
div(ngbDropdownMenu) div(ngbDropdownMenu)
a.d-flex.flex-column( a.d-flex.flex-column(
*ngFor='let mode of outputModes', *ngFor='let mode of outputModes',
(click)='options.outputMode = mode.key', (click)='setOutputMode(mode.key)',
ngbDropdownItem ngbDropdownItem
) )
div {{mode.name|translate}} div {{mode.name|translate}}

View File

@ -60,4 +60,12 @@ export class StreamProcessingSettingsComponent {
getOutputModeName (key) { getOutputModeName (key) {
return this.outputModes.find(x => x.key === key)?.name return this.outputModes.find(x => x.key === key)?.name
} }
setInputMode (mode) {
this.options.inputMode = mode
}
setOutputMode (mode) {
this.options.outputMode = mode
}
} }