mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
* MNT-24354 update license header [ci:force] * MNT-24354 fix lint [ci:force] * MNT-24354 [ci:force] * MNT-24354 update license header in process-services [ci:force] --------- Co-authored-by: DaryaBalvanovich <darya.balvanovich1@hyland.com>
239 lines
7.6 KiB
TypeScript
239 lines
7.6 KiB
TypeScript
/*!
|
|
* @license
|
|
* Copyright © 2005-2024 Hyland Software, Inc. and its affiliates. All rights reserved.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
import { Component, EventEmitter, Input, OnInit, Output, ViewEncapsulation, OnDestroy, ViewChild } from '@angular/core';
|
|
import { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';
|
|
import { Observable, Subject } from 'rxjs';
|
|
import { UntypedFormBuilder, Validators, UntypedFormGroup, UntypedFormControl } from '@angular/forms';
|
|
import { DateFnsUtils, UserPreferencesService, UserPreferenceValues } from '@alfresco/adf-core';
|
|
import { PeopleCloudComponent } from '../../../people/components/people-cloud.component';
|
|
import { GroupCloudComponent } from '../../../group/components/group-cloud.component';
|
|
import { TaskCloudService } from '../../services/task-cloud.service';
|
|
import { StartTaskCloudRequestModel } from '../models/start-task-cloud-request.model';
|
|
import { takeUntil } from 'rxjs/operators';
|
|
import { TaskPriorityOption } from '../../models/task.model';
|
|
import { IdentityUserService } from '../../../people/services/identity-user.service';
|
|
import { IdentityUserModel } from '../../../people/models/identity-user.model';
|
|
import { DateFnsAdapter, MAT_DATE_FNS_FORMATS } from '@angular/material-date-fns-adapter';
|
|
import { isValid, parse } from 'date-fns';
|
|
|
|
const MAX_NAME_LENGTH = 255;
|
|
const DATE_FORMAT: string = 'dd/MM/yyyy';
|
|
|
|
@Component({
|
|
selector: 'adf-cloud-start-task',
|
|
templateUrl: './start-task-cloud.component.html',
|
|
styleUrls: ['./start-task-cloud.component.scss'],
|
|
providers: [
|
|
{ provide: DateAdapter, useClass: DateFnsAdapter },
|
|
{ provide: MAT_DATE_FORMATS, useValue: MAT_DATE_FNS_FORMATS }
|
|
],
|
|
encapsulation: ViewEncapsulation.None
|
|
})
|
|
export class StartTaskCloudComponent implements OnInit, OnDestroy {
|
|
/** (required) Name of the app. */
|
|
@Input()
|
|
appName: string = '';
|
|
|
|
/** Maximum length of the task name. */
|
|
@Input()
|
|
maxNameLength: number = MAX_NAME_LENGTH;
|
|
|
|
/** Name of the task. */
|
|
@Input()
|
|
name: string = '';
|
|
|
|
/** Emitted when the task is successfully created. */
|
|
@Output()
|
|
success: EventEmitter<any> = new EventEmitter<any>();
|
|
|
|
/** Emitted when the cancel button is clicked by the user. */
|
|
@Output()
|
|
cancel: EventEmitter<void> = new EventEmitter<void>();
|
|
|
|
/** Emitted when an error occurs. */
|
|
@Output()
|
|
error: EventEmitter<any> = new EventEmitter<any>();
|
|
|
|
@ViewChild('peopleInput')
|
|
assignee: PeopleCloudComponent;
|
|
|
|
@ViewChild('groupInput')
|
|
candidateGroups: GroupCloudComponent;
|
|
|
|
users$: Observable<any[]>;
|
|
|
|
taskId: string;
|
|
|
|
dueDate: Date;
|
|
|
|
submitted = false;
|
|
|
|
assigneeName: string;
|
|
|
|
candidateGroupNames: string[] = [];
|
|
|
|
dateError: boolean;
|
|
|
|
taskForm: UntypedFormGroup;
|
|
|
|
currentUser: IdentityUserModel;
|
|
|
|
formKey: string;
|
|
|
|
priorities: TaskPriorityOption[];
|
|
|
|
private assigneeForm = new UntypedFormControl('');
|
|
private groupForm = new UntypedFormControl('');
|
|
private onDestroy$ = new Subject<boolean>();
|
|
|
|
constructor(
|
|
private taskService: TaskCloudService,
|
|
private dateAdapter: DateAdapter<DateFnsAdapter>,
|
|
private userPreferencesService: UserPreferencesService,
|
|
private formBuilder: UntypedFormBuilder,
|
|
private identityUserService: IdentityUserService
|
|
) {}
|
|
|
|
ngOnInit() {
|
|
this.userPreferencesService
|
|
.select(UserPreferenceValues.Locale)
|
|
.pipe(takeUntil(this.onDestroy$))
|
|
.subscribe((locale) => this.dateAdapter.setLocale(DateFnsUtils.getLocaleFromString(locale)));
|
|
this.loadCurrentUser();
|
|
this.buildForm();
|
|
this.loadDefaultPriorities();
|
|
}
|
|
|
|
ngOnDestroy() {
|
|
this.onDestroy$.next(true);
|
|
this.onDestroy$.complete();
|
|
}
|
|
|
|
buildForm() {
|
|
this.taskForm = this.formBuilder.group({
|
|
name: new UntypedFormControl(this.name, [Validators.required, Validators.maxLength(this.getMaxNameLength()), this.whitespaceValidator]),
|
|
priority: new UntypedFormControl(''),
|
|
description: new UntypedFormControl('', [this.whitespaceValidator]),
|
|
formKey: new UntypedFormControl()
|
|
});
|
|
}
|
|
|
|
private getMaxNameLength(): number {
|
|
return this.maxNameLength > MAX_NAME_LENGTH ? MAX_NAME_LENGTH : this.maxNameLength;
|
|
}
|
|
|
|
private loadCurrentUser() {
|
|
this.currentUser = this.identityUserService.getCurrentUserInfo();
|
|
this.assigneeName = this.currentUser.username;
|
|
}
|
|
|
|
private loadDefaultPriorities() {
|
|
this.priorities = this.taskService.priorities;
|
|
}
|
|
|
|
public saveTask() {
|
|
this.submitted = true;
|
|
const newTask = Object.assign(this.taskForm.value);
|
|
newTask.dueDate = this.dueDate;
|
|
newTask.assignee = this.assigneeName;
|
|
newTask.formKey = this.formKey;
|
|
newTask.candidateGroups = this.candidateGroupNames;
|
|
|
|
this.createNewTask(new StartTaskCloudRequestModel(newTask));
|
|
}
|
|
|
|
private createNewTask(newTask: StartTaskCloudRequestModel) {
|
|
this.taskService.createNewTask(newTask, this.appName).subscribe(
|
|
(res: any) => {
|
|
this.submitted = false;
|
|
this.success.emit(res);
|
|
},
|
|
(err) => {
|
|
this.submitted = false;
|
|
this.error.emit(err);
|
|
}
|
|
);
|
|
}
|
|
|
|
public onCancel() {
|
|
this.cancel.emit();
|
|
}
|
|
|
|
onDateChanged(newDateValue) {
|
|
this.dateError = false;
|
|
|
|
if (newDateValue) {
|
|
const date = parse(newDateValue, DATE_FORMAT, new Date());
|
|
|
|
if (!isValid(date)) {
|
|
this.dateError = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
onAssigneeSelect(assignee: IdentityUserModel) {
|
|
this.assigneeName = assignee ? assignee.username : '';
|
|
}
|
|
|
|
onAssigneeRemove() {
|
|
this.assigneeName = '';
|
|
}
|
|
|
|
onCandidateGroupSelect(candidateGroup: any) {
|
|
if (candidateGroup.name) {
|
|
this.candidateGroupNames.push(candidateGroup.name);
|
|
}
|
|
}
|
|
|
|
onCandidateGroupRemove(candidateGroup: any) {
|
|
if (candidateGroup.name) {
|
|
this.candidateGroupNames = this.candidateGroupNames.filter((name: string) => name !== candidateGroup.name);
|
|
}
|
|
}
|
|
|
|
canStartTask(): boolean {
|
|
return !(this.dateError || !this.taskForm.valid || this.submitted || this.assignee.hasError() || this.candidateGroups.hasError());
|
|
}
|
|
|
|
public whitespaceValidator(control: UntypedFormControl) {
|
|
const isWhitespace = (control.value || '').trim().length === 0;
|
|
const isControlValid = control.value.length === 0 || !isWhitespace;
|
|
return isControlValid ? null : { whitespace: true };
|
|
}
|
|
|
|
get nameController(): UntypedFormControl {
|
|
return this.taskForm.get('name') as UntypedFormControl;
|
|
}
|
|
|
|
get priorityController(): UntypedFormControl {
|
|
return this.taskForm.get('priority') as UntypedFormControl;
|
|
}
|
|
|
|
get assigneeFormControl(): UntypedFormControl {
|
|
return this.assigneeForm;
|
|
}
|
|
|
|
get candidateUserFormControl(): UntypedFormControl {
|
|
return this.groupForm;
|
|
}
|
|
|
|
onFormSelect(formKey: string) {
|
|
this.formKey = formKey || '';
|
|
}
|
|
}
|