Skip to main content

BaseDetailComponent

BaseDetailComponent

A base class for entity detail views. It should be used in conjunction with the

BaseEntityResolver.

Example

@Component({
selector: 'app-my-entity',
templateUrl: './my-entity.component.html',
styleUrls: ['./my-entity.component.scss'],
changeDetection: ChangeDetectionStrategy.OnPush,
})
export class GlobalSettingsComponent extends BaseDetailComponent<MyEntityFragment> implements OnInit {
detailForm: FormGroup;

constructor(
router: Router,
route: ActivatedRoute,
serverConfigService: ServerConfigService,
protected dataService: DataService,
private formBuilder: FormBuilder,
) {
super(route, router, serverConfigService, dataService);
this.detailForm = this.formBuilder.group({
name: [''],
});
}

protected setFormValues(entity: MyEntityFragment, languageCode: LanguageCode): void {
this.detailForm.patchValue({
name: entity.name,
});
}
}
Signature
class BaseDetailComponent<Entity extends { id: string; updatedAt?: string }> implements DeactivateAware {
entity$: Observable<Entity>;
availableLanguages$: Observable<LanguageCode[]>;
languageCode$: Observable<LanguageCode>;
languageCode: LanguageCode;
isNew$: Observable<boolean>;
id: string;
abstract detailForm: UntypedFormGroup;
protected destroy$ = new Subject<void>();
constructor(route: ActivatedRoute, router: Router, serverConfigService: ServerConfigService, dataService: DataService)
init() => ;
setUpStreams() => ;
destroy() => ;
setLanguage(code: LanguageCode) => ;
canDeactivate() => boolean;
setFormValues(entity: Entity, languageCode: LanguageCode) => void;
setCustomFieldFormValues(customFields: CustomFieldConfig[], formGroup: AbstractControl | null, entity: T, currentTranslation?: TranslationOf<T>) => ;
getCustomFieldConfig(key: Exclude<keyof CustomFields, '__typename'>) => CustomFieldConfig[];
setQueryParam(key: string, value: any) => ;
}
  • Implements: DeactivateAware

entity$

property
Observable<Entity>

availableLanguages$

property
Observable<LanguageCode[]>

languageCode$

property
Observable<LanguageCode>

languageCode

property

isNew$

property
Observable<boolean>

id

property
string

detailForm

property
UntypedFormGroup

destroy$

property

constructor

method
(route: ActivatedRoute, router: Router, serverConfigService: ServerConfigService, dataService: DataService) => BaseDetailComponent

init

method
() =>

setUpStreams

method
() =>

destroy

method
() =>

setLanguage

method
(code: LanguageCode) =>

canDeactivate

method
() => boolean

setFormValues

method
(entity: Entity, languageCode: LanguageCode) => void

setCustomFieldFormValues

method
(customFields: CustomFieldConfig[], formGroup: AbstractControl | null, entity: T, currentTranslation?: TranslationOf<T>) =>

getCustomFieldConfig

method
(key: Exclude<keyof CustomFields, '__typename'>) => CustomFieldConfig[]

setQueryParam

method
(key: string, value: any) =>