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

246 lines
6.4 KiB
HTML
Raw Normal View History

2020-10-29 18:43:19 +01:00
<div class="admin-form">
<h1>
2020-10-29 18:43:19 +01:00
{{ 'creation.title' | translate }}
</h1>
2020-11-05 19:13:43 +01:00
2020-11-03 16:13:47 +01:00
<button class="btn btn--warning" (click)="askInitFormDefault()">
<i class="fa fa-refresh"></i>
Tout réinitialiser
</button>
2020-10-29 18:43:19 +01:00
2020-11-03 15:44:08 +01:00
<form [formGroup]="form">
<div class="form-field">
2020-11-05 19:13:43 +01:00
<span class="pre-selector">
{{ 'creation.want' | translate }}
</span>
2020-11-06 12:04:38 +01:00
<div class="kind-of-poll columns">
<div class="column">
<button
class="btn-block btn"
[ngClass]="{ 'is-primary': form.controls.isAboutDate.value }"
(click)="form.controls.isAboutDate.setValue(true)"
>
<i class="fa fa-calendar"></i>
{{ 'creation.kind.date' | translate }}
</button>
</div>
<div class="column">
<button
class="btn-block btn btn-default"
[ngClass]="{ 'is-primary': !form.controls.isAboutDate.value }"
(click)="form.controls.isAboutDate.setValue(false)"
>
<i class="fa fa-stats"></i>
{{ 'creation.kind.classic' | translate }}
</button>
</div>
2020-11-05 19:13:43 +01:00
</div>
2020-11-03 15:44:08 +01:00
2020-11-05 19:13:43 +01:00
<span>
{{ 'creation.choose_title' | translate }}
2020-11-03 15:44:08 +01:00
</span>
<label class="hidden" for="title">Titre</label>
2020-10-29 18:43:19 +01:00
<input
#title
matInput
2020-11-05 19:13:43 +01:00
[placeholder]="'creation.choose_title_placeholder' | translate"
2020-10-29 18:43:19 +01:00
formControlName="title"
id="title"
autofocus="autofocus"
(change)="updateSlug()"
required
/>
<button
mat-button
*ngIf="title.value"
matSuffix
mat-icon-button
aria-label="Clear"
(click)="title.value = ''"
>
<i class="fa fa-close"></i>
</button>
2020-11-03 15:44:08 +01:00
</div>
2020-11-05 19:13:43 +01:00
2020-11-06 12:04:38 +01:00
<fieldset class="date-kind">
<!-- choix spécialement pour les dates-->
</fieldset>
2020-11-05 19:13:43 +01:00
<div class="form-field">
2020-11-06 12:04:38 +01:00
<h2>
{{ 'choices.title' | translate }}
</h2>
{{ 'dates.add' | translate }}
<p>
<i>
{{ 'choices.helper' | translate }}
</i>
</p>
{{ 'choices.answer_preset_1' | translate }}
{{ 'choices.add' | translate }}
{{ 'choices.continue' | translate }}
2020-11-05 19:13:43 +01:00
<span>
<span class="columns">
<span class="column">
<button class="btn is-primary" (click)="addChoice()">
<i class="fa fa-plus"></i>
Ajouter un choix
</button>
</span>
<span class="column pull-right">
<button class="btn is-warning" (click)="reinitChoices()">
<i class="fa fa-recycle"></i>
Réinitialiser
</button>
</span>
</span>
<span *ngFor="let choice of choices.controls; let i = index">
<div class="form-row" [formGroup]="choice">
<div class="columns">
2020-11-06 12:04:38 +01:00
<div class="column">
<button class="btn btn-warning" (click)="deleteChoiceField(i)">
<i class="fa fa-times"></i>
</button>
{{ i * 1 + 1 }})
</div>
2020-11-05 19:13:43 +01:00
<div class="column">
<label for="label" class="hidden">label</label>
<input formControlName="label" id="label" placeholder="Enter a choice description" />
<br />
2020-11-06 12:04:38 +01:00
<label for="imageUrl" class="hidden">image Url</label>
2020-11-05 19:13:43 +01:00
<input formControlName="imageUrl" id="imageUrl" placeholder="URL de l' image" />
</div>
</div>
</div>
</span>
</span>
</div>
2020-11-03 15:44:08 +01:00
<div>
2020-11-06 12:04:38 +01:00
<label class="" for="creatorEmail">
<span>
{{ 'creation.name' | translate }}
</span>
</label>
<label class="hidden" for="creatorPseudo">
<span>
{{ 'creation.email' | translate }}
</span>
</label>
<input #title matInput placeholder="pseudo" formControlName="creatorPseudo" id="creatorPseudo" required />
2020-11-03 15:44:08 +01:00
<input
#title
2020-10-29 18:43:19 +01:00
matInput
2020-11-03 15:44:08 +01:00
placeholder="mon-email@example.com"
formControlName="creatorEmail"
id="creatorEmail"
2020-10-29 18:43:19 +01:00
required
2020-11-03 15:44:08 +01:00
/>
</div>
2020-10-29 18:43:19 +01:00
2020-11-03 15:44:08 +01:00
<br />
2020-11-06 12:04:38 +01:00
<button class="btn is-info" (click)="advancedDisplayEnabled = !advancedDisplayEnabled">
<i class="fa fa-save"></i>
{{ 'creation.advanced' | translate }}
2020-11-03 15:44:08 +01:00
</button>
2020-11-06 12:04:38 +01:00
<hr />
2020-10-31 17:36:54 +01:00
2020-11-06 12:04:38 +01:00
<fieldset class="complete well" *ngIf="advancedDisplayEnabled">
<h2>{{ 'creation.advanced' | translate }}</h2>
<label for="descr">Description (optionnel)</label>
<textarea
#description
matInput
id="descr"
placeholder="Description"
formControlName="description"
required
></textarea>
2020-11-03 15:47:44 +01:00
<button
mat-button
2020-11-06 12:04:38 +01:00
*ngIf="description.value"
2020-11-03 15:47:44 +01:00
matSuffix
mat-icon-button
aria-label="Clear"
2020-11-06 12:04:38 +01:00
(click)="description.value = ''"
2020-11-03 15:47:44 +01:00
>
<i class="fa fa-close"></i>
</button>
2020-11-06 12:04:38 +01:00
<br />
<label for="slug"
>Url pour les participants
<i class="fa fa-close"></i>
</label>
<br />
<span
>{{ urlPrefix }}
<strong>
{{ form.controls.slug.value }}
</strong>
</span>
2020-11-03 15:47:44 +01:00
<button
mat-button
2020-11-06 12:04:38 +01:00
*ngIf="form.controls.slug.value"
2020-11-03 15:47:44 +01:00
matSuffix
mat-icon-button
aria-label="Clear"
2020-11-06 12:04:38 +01:00
(click)="slug.value = ''"
></button>
<input #slug matInput id="slug" placeholder="Url" formControlName="slug" required />
<br />
<div appearance="outline" class="is-not-flex">
<mat-label>Nombre de jours avant expiration</mat-label>
<input
#expiracy
id="expiracy"
matInput
type="number"
placeholder="Nombre de jours avant expiration"
formControlName="expiracyNumberOfDays"
required
/>
<button
mat-button
*ngIf="expiracy.value"
matSuffix
mat-icon-button
aria-label="Clear"
(click)="expiracy.value = ''"
>
<i class="fa fa-close"></i>
</button>
2020-11-05 19:13:43 +01:00
</div>
2020-11-06 12:04:38 +01:00
<mat-checkbox class="is-not-flex" formControlName="areResultsPublic">
Les participants pourront consulter les résultats
</mat-checkbox>
<mat-checkbox class="is-not-flex" formControlName="isAboutDate">
Les choix possibles concerneront des dates
</mat-checkbox>
<mat-checkbox class="is-not-flex" formControlName="isProtectedByPassword">
Le sondage sera protégé par un mot de passe
</mat-checkbox>
<mat-checkbox class="is-not-flex" formControlName="isOwnerNotifiedByEmailOnNewVote">
Vous recevrez un mail à chaque nouvelle participation
</mat-checkbox>
<mat-checkbox class="is-not-flex" formControlName="isOwnerNotifiedByEmailOnNewComment">
Vous recevrez un mail à chaque nouveau commentaire
</mat-checkbox>
<mat-checkbox class="is-not-flex" formControlName="isMaybeAnswerAvailable">
La réponse « peut-être » sera disponible
</mat-checkbox>
</fieldset>
<div class="columns">
<div class="column"></div>
2020-11-05 19:13:43 +01:00
<div class="column">
<button class="btn is-success" (click)="createPoll()" [disabled]="!form.valid || !form.valid">
<i class="fa fa-save"></i>
Enregistrer le sondage
</button>
</div>
</div>
2020-11-03 15:44:08 +01:00
</form>
2020-10-29 18:43:19 +01:00
</div>