member_webapp/@overflow/probe/component/detail/detail.component.ts
2018-05-26 18:08:40 +09:00

80 lines
2.1 KiB
TypeScript

import { Component, Input, Output, EventEmitter, ViewChild } from '@angular/core';
import { Probe, ProbeHost } from '@overflow/commons-typescript/model/probe';
import { MessageService } from 'primeng/components/common/messageservice';
@Component({
selector: 'of-probe-detail',
templateUrl: './detail.component.html',
providers: [MessageService]
})
export class ProbeDetailComponent {
@Input() pending: boolean;
@Input() probeHost: ProbeHost;
@Output() modify = new EventEmitter<ProbeHost>();
@Output() discovery = new EventEmitter<number>();
editMode = false;
displayNameErrMsg: string;
descriptionErrMsg: string;
displayName: string;
description: string;
constructor(private messageService: MessageService) {
}
onDisplayNameEditing(value: string) {
const msg: string = this.checkValidDisplayName(value);
if (msg !== null) {
this.displayNameErrMsg = msg;
} else {
this.displayNameErrMsg = null;
this.displayName = value;
}
}
onDescriptionEditing(value: string) {
const msg: string = this.checkValidDescription(value);
if (msg !== null) {
this.descriptionErrMsg = msg;
} else {
this.descriptionErrMsg = null;
this.description = value;
}
}
onEditSave() {
this.probeHost.probe.displayName = this.displayName;
this.probeHost.probe.description = this.description;
this.modify.emit(this.probeHost);
this.editMode = false;
}
onDiscoveryClick() {
this.discovery.emit(this.probeHost.id);
}
checkValidDisplayName(value: string): string | null {
if (value.length <= 2 || value.length > 20) {
return 'displayname length : 3 ~ 20';
}
const regex = /[`~!@#$%^&*()_|+\-=?;:'",.<>\{\}\[\]\\\/]/gi;
if (value.match(regex)) {
return 'Cannot use special characters.';
}
return null;
}
checkValidDescription(value: string): string | null {
if (value.length > 50) {
return 'description length : 0 ~ 50';
}
const regex = /[`~!@#$%^&*()_|+\-=?;:'",.<>\{\}\[\]\\\/]/gi;
if (value.match(regex)) {
return 'Cannot use special characters.';
}
return null;
}
}