mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-31 17:38:48 +00:00
#1219 Default range date
This commit is contained in:
@@ -54,15 +54,9 @@ export class DateRangeWidget extends WidgetComponent {
|
|||||||
|
|
||||||
debug: boolean = false;
|
debug: boolean = false;
|
||||||
|
|
||||||
dialogStart: any = new mdDateTimePicker.default({
|
dialogStart: any;
|
||||||
type: 'date',
|
|
||||||
future: moment().add(21, 'years')
|
|
||||||
});
|
|
||||||
|
|
||||||
dialogEnd: any = new mdDateTimePicker.default({
|
dialogEnd: any;
|
||||||
type: 'date',
|
|
||||||
future: moment().add(21, 'years')
|
|
||||||
});
|
|
||||||
|
|
||||||
constructor(public elementRef: ElementRef,
|
constructor(public elementRef: ElementRef,
|
||||||
private formBuilder: FormBuilder) {
|
private formBuilder: FormBuilder) {
|
||||||
@@ -72,26 +66,39 @@ export class DateRangeWidget extends WidgetComponent {
|
|||||||
ngOnInit() {
|
ngOnInit() {
|
||||||
this.initForm();
|
this.initForm();
|
||||||
this.addAccessibilityLabelToDatePicker();
|
this.addAccessibilityLabelToDatePicker();
|
||||||
this.initSartDateDialog();
|
|
||||||
this.initEndDateDialog();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
initForm() {
|
initForm() {
|
||||||
let today = moment().format('YYYY-MM-DD');
|
let startDateForm = this.field.value ? this.field.value.startDate : '' ;
|
||||||
|
let startDate = this.convertToMomentDate(startDateForm);
|
||||||
|
let endDateForm = this.field.value ? this.field.value.endDate : '' ;
|
||||||
|
let endDate = this.convertToMomentDate(endDateForm);
|
||||||
|
|
||||||
let startDateControl = new FormControl(today);
|
let startDateControl = new FormControl(startDate);
|
||||||
startDateControl.setValidators(Validators.required);
|
startDateControl.setValidators(Validators.required);
|
||||||
this.dateRange.addControl('startDate', startDateControl);
|
this.dateRange.addControl('startDate', startDateControl);
|
||||||
|
|
||||||
let endDateControl = new FormControl(today);
|
let endDateControl = new FormControl(endDate);
|
||||||
endDateControl.setValidators(Validators.required);
|
endDateControl.setValidators(Validators.required);
|
||||||
this.dateRange.addControl('endDate', endDateControl);
|
this.dateRange.addControl('endDate', endDateControl);
|
||||||
|
|
||||||
this.dateRange.setValidators(dateCheck);
|
this.dateRange.setValidators(dateCheck);
|
||||||
this.dateRange.valueChanges.subscribe(data => this.onGroupValueChanged(data));
|
this.dateRange.valueChanges.subscribe(data => this.onGroupValueChanged(data));
|
||||||
|
|
||||||
|
this.initSartDateDialog(startDate);
|
||||||
|
this.initEndDateDialog(endDate);
|
||||||
}
|
}
|
||||||
|
|
||||||
initSartDateDialog() {
|
initSartDateDialog(date: string) {
|
||||||
|
let settings: any = {
|
||||||
|
type: 'date',
|
||||||
|
past: moment().subtract(100, 'years'),
|
||||||
|
future: moment().add(100, 'years')
|
||||||
|
};
|
||||||
|
|
||||||
|
settings.init = moment(date, DateRangeWidget.FORMAT_DATE_ACTIVITI);
|
||||||
|
|
||||||
|
this.dialogStart = new mdDateTimePicker.default(settings);
|
||||||
this.dialogStart.trigger = this.startElement.nativeElement;
|
this.dialogStart.trigger = this.startElement.nativeElement;
|
||||||
|
|
||||||
let startDateButton = document.getElementById('startDateButton');
|
let startDateButton = document.getElementById('startDateButton');
|
||||||
@@ -130,7 +137,16 @@ export class DateRangeWidget extends WidgetComponent {
|
|||||||
return span;
|
return span;
|
||||||
}
|
}
|
||||||
|
|
||||||
initEndDateDialog() {
|
initEndDateDialog(date: string) {
|
||||||
|
let settings: any = {
|
||||||
|
type: 'date',
|
||||||
|
past: moment().subtract(100, 'years'),
|
||||||
|
future: moment().add(100, 'years')
|
||||||
|
};
|
||||||
|
|
||||||
|
settings.init = moment(date, DateRangeWidget.FORMAT_DATE_ACTIVITI);
|
||||||
|
|
||||||
|
this.dialogEnd = new mdDateTimePicker.default(settings);
|
||||||
this.dialogEnd.trigger = this.endElement.nativeElement;
|
this.dialogEnd.trigger = this.endElement.nativeElement;
|
||||||
|
|
||||||
let endDateButton = document.getElementById('endDateButton');
|
let endDateButton = document.getElementById('endDateButton');
|
||||||
@@ -164,16 +180,24 @@ export class DateRangeWidget extends WidgetComponent {
|
|||||||
|
|
||||||
onGroupValueChanged(data: any) {
|
onGroupValueChanged(data: any) {
|
||||||
if (this.dateRange.valid) {
|
if (this.dateRange.valid) {
|
||||||
let dateStart = this.convertMomentDate(this.dateRange.controls['startDate'].value);
|
let dateStart = this.convertToMomentDateWithTime(this.dateRange.controls['startDate'].value);
|
||||||
let endStart = this.convertMomentDate(this.dateRange.controls['endDate'].value);
|
let endStart = this.convertToMomentDateWithTime(this.dateRange.controls['endDate'].value);
|
||||||
this.dateRangeChanged.emit({startDate: dateStart, endDate: endStart});
|
this.dateRangeChanged.emit({startDate: dateStart, endDate: endStart});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public convertMomentDate(date: string) {
|
public convertToMomentDateWithTime(date: string) {
|
||||||
return moment(date, DateRangeWidget.FORMAT_DATE_ACTIVITI, true).format(DateRangeWidget.FORMAT_DATE_ACTIVITI) + 'T00:00:00.000Z';
|
return moment(date, DateRangeWidget.FORMAT_DATE_ACTIVITI, true).format(DateRangeWidget.FORMAT_DATE_ACTIVITI) + 'T00:00:00.000Z';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private convertToMomentDate(date: string) {
|
||||||
|
if (date) {
|
||||||
|
return moment(date).format(DateRangeWidget.FORMAT_DATE_ACTIVITI);
|
||||||
|
} else {
|
||||||
|
return moment().format(DateRangeWidget.FORMAT_DATE_ACTIVITI);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
ngOnDestroy() {
|
ngOnDestroy() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -72,7 +72,7 @@ export class ReportParameterDetailsModel {
|
|||||||
name: string;
|
name: string;
|
||||||
nameKey: string;
|
nameKey: string;
|
||||||
type: string;
|
type: string;
|
||||||
value: string;
|
value: any;
|
||||||
options: ParameterValueModel[];
|
options: ParameterValueModel[];
|
||||||
dependsOn: string;
|
dependsOn: string;
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user