funky-framadate-front/src/app/features/administration/form/form.component.ts

128 lines
4.1 KiB
TypeScript
Raw Normal View History

import { ChangeDetectorRef, Component, Inject, Input, OnInit } from '@angular/core';
2020-10-29 18:43:19 +01:00
import { Poll } from '../../../core/models/poll.model';
2021-02-08 11:32:58 +01:00
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
2020-10-29 18:43:19 +01:00
import { UuidService } from '../../../core/services/uuid.service';
import { ApiService } from '../../../core/services/api.service';
2020-11-03 16:13:47 +01:00
import { ToastService } from '../../../core/services/toast.service';
2020-11-05 19:13:43 +01:00
import { PollService } from '../../../core/services/poll.service';
import { DOCUMENT } from '@angular/common';
2020-12-16 17:21:01 +01:00
import { Router } from '@angular/router';
2020-10-29 18:43:19 +01:00
@Component({
selector: 'app-admin-form',
templateUrl: './form.component.html',
styleUrls: ['./form.component.scss'],
})
export class FormComponent implements OnInit {
@Input()
public poll?: Poll;
2020-11-03 15:44:08 +01:00
public form: FormGroup;
2020-10-29 21:30:33 +01:00
public advancedDisplayEnabled = false;
2020-10-29 18:43:19 +01:00
2020-11-03 16:13:47 +01:00
constructor(
private fb: FormBuilder,
private cd: ChangeDetectorRef,
2020-11-03 16:13:47 +01:00
private uuidService: UuidService,
private toastService: ToastService,
2020-11-05 19:13:43 +01:00
private pollService: PollService,
2021-02-12 14:51:17 +01:00
public apiService: ApiService,
2020-12-16 17:21:01 +01:00
private router: Router,
@Inject(DOCUMENT) private document: any
2020-11-03 16:13:47 +01:00
) {}
2021-02-04 16:14:07 +01:00
2020-10-29 18:43:19 +01:00
ngOnInit(): void {
2020-11-03 15:44:08 +01:00
this.initFormDefault();
2021-02-04 16:14:07 +01:00
2020-11-13 09:38:42 +01:00
const pollsAvailable = this.pollService.getAllAvailablePolls();
console.log('pollsAvailable', pollsAvailable);
2020-10-29 18:43:19 +01:00
}
initFormDefault(showDemoValues = true): void {
2021-02-08 18:55:31 +01:00
const creationDate = new Date();
2020-11-03 15:44:08 +01:00
this.form = this.fb.group({
title: ['', [Validators.required, Validators.minLength(12)]],
creatorPseudo: ['', [Validators.required]],
creatorEmail: ['', [Validators.required]],
slug: [this.uuidService.getUUID(), [Validators.required]],
description: ['', [Validators.required]],
2021-02-08 11:32:58 +01:00
choices: this.fb.array([
this.fb.group({
label: ['', [Validators.required]],
imageUrl: ['', [Validators.required]],
}),
]),
2021-02-08 18:55:31 +01:00
dateChoices: this.fb.array([
this.fb.group({
label: ['', [Validators.required]],
// if we have enabled detailed time choices per date choice, we have to make a time property for each date choice
timeChoices: this.fb.array([
this.fb.group({
label: ['', [Validators.required]],
}),
]),
}),
]),
timeChoices: this.fb.array([
this.fb.group({
label: ['', [Validators.required]],
}),
]),
2021-02-08 11:32:58 +01:00
configuration: this.fb.group({
2021-02-08 18:55:31 +01:00
areResultsPublic: [true, [Validators.required]],
2021-02-08 11:32:58 +01:00
whoCanChangeAnswers: ['everybody', [Validators.required]],
2021-02-08 18:55:31 +01:00
isProtectedByPassword: [false, [Validators.required]],
isOwnerNotifiedByEmailOnNewVote: [false, [Validators.required]],
isOwnerNotifiedByEmailOnNewComment: [false, [Validators.required]],
isMaybeAnswerAvailable: [false, [Validators.required]],
isAboutDate: [true, [Validators.required]],
isZeroKnoledge: [false, [Validators.required]],
expiresDaysDelay: [60, [Validators.required, Validators.min(1)]],
maxCountOfAnswers: [150, [Validators.required, Validators.min(1)]],
allowComments: [true, [Validators.required]],
password: [this.uuidService.getUUID(), [Validators.required]],
dateCreated: [creationDate, [Validators.required]],
2021-02-09 11:27:01 +01:00
hasSeveralHours: [true, [Validators.required]],
2021-02-08 18:55:31 +01:00
hasMaxCountOfAnswers: [true, [Validators.required, Validators.min(1)]],
2021-02-08 11:32:58 +01:00
}),
startDateInterval: ['', [Validators.required]],
endDateInterval: ['', [Validators.required]],
2020-11-03 15:44:08 +01:00
});
console.log('this.form ', this.form);
if (showDemoValues) {
this.setDemoValues();
2021-02-08 11:32:58 +01:00
this.toastService.display('default values filled for demo');
}
}
/**
* add example values to the form, overrides defaults of PollConfiguration
*/
2020-11-06 12:04:38 +01:00
setDemoValues(): void {
2020-11-03 15:44:08 +01:00
this.form.patchValue({
2021-02-05 15:34:00 +01:00
title: '',
2020-11-03 15:44:08 +01:00
description: 'répondez SVP <3 ! *-* ',
2020-11-03 16:13:47 +01:00
slug: this.uuidService.getUUID(),
creatorPseudo: 'Chuck Norris',
2020-11-09 12:44:24 +01:00
creatorEmail: 'chucknorris@example.com',
2020-11-03 16:13:47 +01:00
isAboutDate: true,
2021-02-08 11:32:58 +01:00
// hasSeveralHours: true,
2021-02-05 17:02:52 +01:00
configuration: {
whoCanChangeAnswers: 'everybody',
isProtectedByPassword: false,
isOwnerNotifiedByEmailOnNewVote: false,
isOwnerNotifiedByEmailOnNewComment: false,
isMaybeAnswerAvailable: false,
areResultsPublic: true,
2021-02-08 18:55:31 +01:00
expiresDaysDelay: 60,
2021-02-05 17:02:52 +01:00
},
2021-02-05 15:34:00 +01:00
comments: [],
choices: [],
dateChoices: [],
timeChoices: [],
2020-11-03 15:44:08 +01:00
});
}
2020-10-29 18:43:19 +01:00
}