mirror of
https://github.com/Eugeny/tabby.git
synced 2025-06-08 05:20:01 +00:00
99 lines
3.5 KiB
TypeScript
99 lines
3.5 KiB
TypeScript
/* eslint-disable @typescript-eslint/explicit-module-boundary-types */
|
|
import { Observable, OperatorFunction, debounceTime, map, distinctUntilChanged } from 'rxjs'
|
|
import { Component, Input, ViewChild, ViewContainerRef, ComponentFactoryResolver, Injector } from '@angular/core'
|
|
import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap'
|
|
import { ConfigProxy, ConfigService, Profile, ProfileProvider, ProfileSettingsComponent, ProfilesService, TAB_COLORS } from 'tabby-core'
|
|
|
|
const iconsData = require('../../../tabby-core/src/icons.json')
|
|
const iconsClassList = Object.keys(iconsData).map(
|
|
icon => iconsData[icon].map(
|
|
style => `fa${style[0]} fa-${icon}`,
|
|
),
|
|
).flat()
|
|
|
|
/** @hidden */
|
|
@Component({
|
|
templateUrl: './editProfileModal.component.pug',
|
|
})
|
|
export class EditProfileModalComponent<P extends Profile> {
|
|
@Input() profile: P & ConfigProxy
|
|
@Input() profileProvider: ProfileProvider<P>
|
|
@Input() settingsComponent: new () => ProfileSettingsComponent<P>
|
|
@Input() defaultsMode = false
|
|
groupNames: string[]
|
|
@ViewChild('placeholder', { read: ViewContainerRef }) placeholder: ViewContainerRef
|
|
|
|
private _profile: Profile
|
|
private settingsComponentInstance?: ProfileSettingsComponent<P>
|
|
|
|
constructor (
|
|
private injector: Injector,
|
|
private componentFactoryResolver: ComponentFactoryResolver,
|
|
private profilesService: ProfilesService,
|
|
config: ConfigService,
|
|
private modalInstance: NgbActiveModal,
|
|
) {
|
|
this.groupNames = [...new Set(
|
|
(config.store.profiles as Profile[])
|
|
.map(x => x.group)
|
|
.filter(x => !!x),
|
|
)].sort() as string[]
|
|
}
|
|
|
|
colorsAutocomplete = text$ => text$.pipe(
|
|
debounceTime(200),
|
|
distinctUntilChanged(),
|
|
map((q: string) =>
|
|
TAB_COLORS
|
|
.filter(x => !q || x.name.toLowerCase().startsWith(q.toLowerCase()))
|
|
.map(x => x.value),
|
|
),
|
|
)
|
|
|
|
colorsFormatter = value => {
|
|
return TAB_COLORS.find(x => x.value === value)?.name ?? value
|
|
}
|
|
|
|
ngOnInit () {
|
|
this._profile = this.profile
|
|
this.profile = this.profilesService.getConfigProxyForProfile(this.profile, this.defaultsMode)
|
|
}
|
|
|
|
ngAfterViewInit () {
|
|
const componentType = this.profileProvider.settingsComponent
|
|
if (componentType) {
|
|
setTimeout(() => {
|
|
const componentFactory = this.componentFactoryResolver.resolveComponentFactory(componentType)
|
|
const componentRef = componentFactory.create(this.injector)
|
|
this.settingsComponentInstance = componentRef.instance
|
|
this.settingsComponentInstance.profile = this.profile
|
|
this.placeholder.insert(componentRef.hostView)
|
|
})
|
|
}
|
|
}
|
|
|
|
groupTypeahead = (text$: Observable<string>) =>
|
|
text$.pipe(
|
|
debounceTime(200),
|
|
distinctUntilChanged(),
|
|
map(q => this.groupNames.filter(x => !q || x.toLowerCase().includes(q.toLowerCase()))),
|
|
)
|
|
|
|
iconSearch: OperatorFunction<string, string[]> = (text$: Observable<string>) =>
|
|
text$.pipe(
|
|
debounceTime(200),
|
|
map(term => iconsClassList.filter(v => v.toLowerCase().includes(term.toLowerCase())).slice(0, 10)),
|
|
)
|
|
|
|
save () {
|
|
this.profile.group ||= undefined
|
|
this.settingsComponentInstance?.save?.()
|
|
this.profile.__cleanup()
|
|
this.modalInstance.close(this._profile)
|
|
}
|
|
|
|
cancel () {
|
|
this.modalInstance.dismiss()
|
|
}
|
|
}
|