forked from tykayn/funky-framadate-front
style for adding time
This commit is contained in:
parent
4a47e9fea3
commit
7e12d9d34f
9
src/app/core/models/dateChoice.model.ts
Normal file
9
src/app/core/models/dateChoice.model.ts
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
export interface DateChoice {
|
||||||
|
literal: string;
|
||||||
|
timeSlices: TimeSlices[];
|
||||||
|
date_object: Date;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface TimeSlices {
|
||||||
|
literal: string;
|
||||||
|
}
|
@ -45,6 +45,7 @@
|
|||||||
<input
|
<input
|
||||||
[(ngModel)]="choice.date_object"
|
[(ngModel)]="choice.date_object"
|
||||||
(keyup)="keyOnChoice($event, id)"
|
(keyup)="keyOnChoice($event, id)"
|
||||||
|
class="date-choice-item"
|
||||||
name="dateChoices_{{ id }}"
|
name="dateChoices_{{ id }}"
|
||||||
id="dateChoices_{{ id }}"
|
id="dateChoices_{{ id }}"
|
||||||
useValueAsDate
|
useValueAsDate
|
||||||
@ -53,12 +54,18 @@
|
|||||||
<button (click)="dateChoices.splice(id, 1)" class="btn btn-warning">
|
<button (click)="dateChoices.splice(id, 1)" class="btn btn-warning">
|
||||||
<i class="fa fa-times" aria-hidden="true"></i>
|
<i class="fa fa-times" aria-hidden="true"></i>
|
||||||
</button>
|
</button>
|
||||||
<button (click)="addTimeToDate(choice, id)" *ngIf="hasSeveralHours" class="btn btn--primary">
|
<br />
|
||||||
{{ 'dates.add_time' | translate }}
|
|
||||||
</button>
|
|
||||||
<div *ngIf="hasSeveralHours" class="several-times">
|
<div *ngIf="hasSeveralHours" class="several-times">
|
||||||
<br />
|
<br />
|
||||||
<app-time-list [timeSlices]="choice.timeSlices"></app-time-list>
|
<app-time-list [timeSlices]="choice.timeSlices" [prefix_choice_id]="id"></app-time-list>
|
||||||
|
<div class="text-right">
|
||||||
|
<button (click)="addTimeToDate(choice, id)" class="btn btn--primary">
|
||||||
|
<i class="fa fa-plus"></i>
|
||||||
|
<!-- {{ 'dates.add_time' | translate }}-->
|
||||||
|
<i class="fa fa-clock-o"></i>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -6,8 +6,12 @@
|
|||||||
}
|
}
|
||||||
.icon {
|
.icon {
|
||||||
margin-right: 1ch;
|
margin-right: 1ch;
|
||||||
|
margin-left: 1ch;
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
}
|
}
|
||||||
.several-times {
|
.several-times {
|
||||||
padding-left: 2em;
|
padding-left: 2em;
|
||||||
}
|
}
|
||||||
|
.date-choice-item {
|
||||||
|
width: 75%;
|
||||||
|
}
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
import { ChangeDetectorRef, Component, Inject, Input } from '@angular/core';
|
import { ChangeDetectorRef, Component, Inject, Input } from '@angular/core';
|
||||||
import { moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';
|
import { moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';
|
||||||
import { DateChoice } from '../../../../../../../../mocks/old-stuff/config/defaultConfigs';
|
|
||||||
import { DOCUMENT } from '@angular/common';
|
import { DOCUMENT } from '@angular/common';
|
||||||
import { FormGroup } from '@angular/forms';
|
import { FormGroup } from '@angular/forms';
|
||||||
import { ToastService } from '../../../../../../core/services/toast.service';
|
import { ToastService } from '../../../../../../core/services/toast.service';
|
||||||
import { StorageService } from '../../../../../../core/services/storage.service';
|
import { StorageService } from '../../../../../../core/services/storage.service';
|
||||||
import { MatDialog } from '@angular/material/dialog';
|
import { MatDialog } from '@angular/material/dialog';
|
||||||
import { ShortcutsHelpComponent } from '../../../../../shared/components/ui/shortcuts-help/shortcuts-help.component';
|
import { ShortcutsHelpComponent } from '../../../../../shared/components/ui/shortcuts-help/shortcuts-help.component';
|
||||||
|
import { DateChoice } from '../../../../../../core/models/dateChoice.model';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-day-list',
|
selector: 'app-day-list',
|
||||||
@ -64,19 +64,21 @@ export class DayListComponent {
|
|||||||
* @param choice DateChoice
|
* @param choice DateChoice
|
||||||
* @param id number
|
* @param id number
|
||||||
*/
|
*/
|
||||||
addTimeToDate(choice: DateChoice, id: number) {
|
addTimeToDate(choice: DateChoice, id: number): void {
|
||||||
if (!choice.timeSlices) {
|
if (!choice.timeSlices) {
|
||||||
choice.timeSlices = [];
|
choice.timeSlices = [];
|
||||||
}
|
}
|
||||||
choice.timeSlices.push({
|
choice.timeSlices.push({
|
||||||
literal: '',
|
literal: '',
|
||||||
});
|
});
|
||||||
const selector =
|
// focus on created field
|
||||||
'[ng-reflect-choice_label="dateTime_' + id + '_ dateList_' + (choice.timeSlices.length - 1) + '"]';
|
|
||||||
this.cd.detectChanges();
|
this.cd.detectChanges();
|
||||||
const elem = this.document.querySelector(selector);
|
const selector = '#choice_' + id + '_timeChoices_' + (choice.timeSlices.length - 1);
|
||||||
if (elem) {
|
const firstField = this.document.querySelector(selector);
|
||||||
elem.focus();
|
if (firstField) {
|
||||||
|
firstField.focus();
|
||||||
|
} else {
|
||||||
|
console.log('no last time choice found');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,16 +1,21 @@
|
|||||||
<div class="time-list-container" cdkDropList [cdkDropListData]="timeSlices" (cdkDropListDropped)="dropTimeItem($event)">
|
<div class="time-list-container" cdkDropList [cdkDropListData]="timeSlices" (cdkDropListDropped)="dropTimeItem($event)">
|
||||||
<div *ngFor="let time of timeSlices; index as id" class="time-choice" cdkDrag>
|
<div *ngFor="let time of timeSlices; index as id" class="time-choice" cdkDrag>
|
||||||
<label class="icon button is-default" for="timeChoices_{{ id }}">
|
<label class="icon button is-default" for="choice_{{ prefix_choice_id }}_timeChoices_{{ id }}">
|
||||||
<i class="fa fa-arrows-v" aria-hidden="true"></i>
|
<i class="fa fa-arrows-v" aria-hidden="true"></i>
|
||||||
</label>
|
</label>
|
||||||
<input
|
<input
|
||||||
class="time-list-item"
|
class="time-list-item"
|
||||||
[(ngModel)]="time.literal"
|
[(ngModel)]="time.literal"
|
||||||
name="timeChoices_{{ id }}"
|
name="timeChoices_{{ id }}"
|
||||||
|
(keyup.arrowDown)="focusOnNextField(id)"
|
||||||
|
(keyup.arrowUp)="focusOnFieldNumber(id - 1)"
|
||||||
|
(keyup.arrowLeft)="removeTimeIfEmpty(time.literal, id)"
|
||||||
|
(keyup.alt.d)="removeTime(id)"
|
||||||
|
(blur)="removeTimeIfEmpty(time.literal, id)"
|
||||||
type="text"
|
type="text"
|
||||||
id="timeChoices_{{ id }}"
|
id="choice_{{ prefix_choice_id }}_timeChoices_{{ id }}"
|
||||||
/>
|
/>
|
||||||
<button (click)="timeSlices.splice(id, 1)" class="btn btn-warning">
|
<button (click)="removeTime(id)" class="btn btn-warning">
|
||||||
<i class="fa fa-times" aria-hidden="true"></i>
|
<i class="fa fa-times" aria-hidden="true"></i>
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
import { Component, Input, OnInit } from '@angular/core';
|
import { ChangeDetectorRef, Component, Inject, Input, OnInit } from '@angular/core';
|
||||||
import { TimeSlices } from '../../../../../../../../mocks/old-stuff/config/defaultConfigs';
|
|
||||||
import { moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';
|
import { moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';
|
||||||
|
import { DOCUMENT } from '@angular/common';
|
||||||
|
import { TimeSlices } from '../../../../../../core/models/dateChoice.model';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-time-list',
|
selector: 'app-time-list',
|
||||||
@ -10,7 +12,10 @@ import { moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';
|
|||||||
export class TimeListComponent implements OnInit {
|
export class TimeListComponent implements OnInit {
|
||||||
@Input()
|
@Input()
|
||||||
public timeSlices: TimeSlices[];
|
public timeSlices: TimeSlices[];
|
||||||
constructor() {}
|
@Input()
|
||||||
|
public prefix_choice_id = '';
|
||||||
|
|
||||||
|
constructor(@Inject(DOCUMENT) private document: any, private cd: ChangeDetectorRef) {}
|
||||||
|
|
||||||
ngOnInit(): void {}
|
ngOnInit(): void {}
|
||||||
|
|
||||||
@ -27,4 +32,52 @@ export class TimeListComponent implements OnInit {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
removeTime(id: number) {
|
||||||
|
this.timeSlices.splice(id, 1);
|
||||||
|
this.focusOnLastField();
|
||||||
|
}
|
||||||
|
|
||||||
|
focusOnFieldNumber(fieldId: number) {
|
||||||
|
console.log('focus on fieldId', fieldId);
|
||||||
|
const selector = '#choice_' + this.prefix_choice_id + '_timeChoices_' + fieldId;
|
||||||
|
const firstField = this.document.querySelector(selector);
|
||||||
|
if (firstField) {
|
||||||
|
console.log('found', firstField);
|
||||||
|
firstField.focus();
|
||||||
|
}
|
||||||
|
return firstField;
|
||||||
|
}
|
||||||
|
|
||||||
|
focusOnNextField(currentId: number) {
|
||||||
|
const fieldFound = this.focusOnFieldNumber(currentId + 1);
|
||||||
|
if (!fieldFound) {
|
||||||
|
console.log('pas trouvé de field avec id', currentId + 1);
|
||||||
|
this.createNewField();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
focusOnLastField() {
|
||||||
|
this.cd.detectChanges();
|
||||||
|
if (!this.focusOnFieldNumber(this.timeSlices.length - 1)) {
|
||||||
|
console.log('no last time choice found');
|
||||||
|
this.createNewField();
|
||||||
|
this.focusOnLastField();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
removeTimeIfEmpty(timeLiteral, id) {
|
||||||
|
if (timeLiteral === '') {
|
||||||
|
this.removeTime(id);
|
||||||
|
this.focusOnFieldNumber(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
createNewField() {
|
||||||
|
// create new field
|
||||||
|
this.timeSlices.push({
|
||||||
|
literal: '',
|
||||||
|
});
|
||||||
|
this.cd.detectChanges();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -133,9 +133,9 @@ mat-checkbox {
|
|||||||
|
|
||||||
.cdk-drag {
|
.cdk-drag {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
border-left: 3px white solid;
|
//border-left: 3px white solid;
|
||||||
&:hover {
|
&:hover {
|
||||||
border-left: 3px #ccc solid;
|
background: #fefefe;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.admin-form {
|
.admin-form {
|
||||||
@ -191,7 +191,7 @@ mat-checkbox {
|
|||||||
padding: 1em;
|
padding: 1em;
|
||||||
height: 4em;
|
height: 4em;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
background: white;
|
background: $primary;
|
||||||
}
|
}
|
||||||
|
|
||||||
.cdk-drag-animating {
|
.cdk-drag-animating {
|
||||||
@ -219,9 +219,6 @@ mat-checkbox {
|
|||||||
border-left: $success 3px solid;
|
border-left: $success 3px solid;
|
||||||
padding-left: 1em;
|
padding-left: 1em;
|
||||||
}
|
}
|
||||||
.btn {
|
|
||||||
margin: 0.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.bar-nav-admin {
|
.bar-nav-admin {
|
||||||
//position:fixed;
|
//position:fixed;
|
||||||
|
@ -31,3 +31,10 @@ h4 {
|
|||||||
.nobold {
|
.nobold {
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.text-right {
|
||||||
|
text-align: right;
|
||||||
|
}
|
||||||
|
.text-center {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user