Newer
Older
import { Component, OnInit, ViewChild } from '@angular/core';
import { TranslateService } from '@ngx-translate/core';
import { takeUntil } from 'rxjs/operators';
ClozeElement, InputElement, LikertElement
} from 'common/interfaces/elements';
import { ClozeUtils } from 'common/util/cloze';
import { UnitStateService } from '../../services/unit-state.service';
import { ElementComponent } from 'common/directives/element-component.directive';
import { UnitStateElementValueMappingService } from '../../services/unit-state-element-value-mapping.service';
import { MessageService } from 'common/services/message.service';
import { VeronaSubscriptionService } from 'verona/services/verona-subscription.service';
import { ValidatorService } from '../../services/validator.service';
import { KeypadService } from '../../services/keypad.service';
import { TextFieldComponent } from 'common/components/ui-elements/text-field.component';
import { ElementFormGroupDirective } from '../../directives/element-form-group.directive';
import { KeyboardService } from '../../services/keyboard.service';
import { DeviceService } from '../../services/device.service';
@Component({
selector: 'aspect-element-compound-group',
templateUrl: './element-compound-group.component.html',
styleUrls: ['./element-compound-group.component.scss']
})
export class ElementCompoundGroupComponent extends ElementFormGroupDirective implements OnInit {
@ViewChild('elementComponent') elementComponent!: ElementComponent;
ClozeElement!: ClozeElement;
LikertElement!: LikertElement;
isKeypadOpen!: boolean;
private keyboardService: KeyboardService,
private deviceService: DeviceService,
public keypadService: KeypadService,
public unitStateService: UnitStateService,
public unitStateElementValueMappingService: UnitStateElementValueMappingService,
public translateService: TranslateService,
public messageService: MessageService,
public veronaSubscriptionService: VeronaSubscriptionService,
public validatorService: ValidatorService
) {
super();
}
const childModels = this.elementModel.type === 'cloze' ?
ClozeUtils.getClozeChildElements((this.elementModel as ClozeElement).document) :
(this.elementModel as LikertElement).rows;
this.createForm(childModels);
onChildrenAdded(children: ElementComponent[]): void {
children.forEach(child => {
const childModel = child.elementModel as InputElement;
this.registerAtUnitStateService(
childModel.id,
this.unitStateElementValueMappingService.mapToUnitState(childModel.value, childModel.type),
if (childModel.type === 'text-field') {
const textFieldComponent = child as TextFieldComponent;
.onFocusChanged
.pipe(takeUntil(this.ngUnsubscribe))
.subscribe(element => {
this.onFocusChanged(element, textFieldComponent, childModel);
});
(child as TextFieldComponent)
.onKeyDown
.pipe(takeUntil(this.ngUnsubscribe))
.subscribe(element => {
this.registerHardwareKeyboard(element, textFieldComponent);
private onFocusChanged(inputElement: HTMLElement | null,
elementComponent: TextFieldComponent,
elementModel: InputElement): void {
if (elementModel.inputAssistance !== 'none') {
this.isKeypadOpen = this.keypadService.toggle(inputElement, elementComponent);
}
if (elementModel.showSoftwareKeyboard && !elementModel.readOnly) {
this.keyboardService.toggle(inputElement, elementComponent, this.deviceService.isMobileWithoutHardwareKeyboard);
}
}
private registerHardwareKeyboard(inputElement: HTMLElement | null,
elementComponent: TextFieldComponent): void {
this.deviceService.registerHardwareKeyboard();
this.keyboardService.toggle(inputElement, elementComponent, this.deviceService.isMobileWithoutHardwareKeyboard);
}