@nakedobjects/gemini
Version:
Single Page Application client for a Naked Objects application.
115 lines • 15.9 kB
JavaScript
import { ViewChild } from '@angular/core';
import { Component, EventEmitter, Input } from '@angular/core';
import { PropertyViewModel } from '@nakedobjects/view-models';
import { DatePickerOptions } from '../date-picker/date-picker.component';
import { fixedDateFormat } from '@nakedobjects/services';
import * as i0 from "@angular/core";
import * as i1 from "@nakedobjects/services";
import * as i2 from "@angular/forms";
import * as i3 from "../date-picker/date-picker.component";
export class DatePickerFacadeComponent {
datePickerOptions = new DatePickerOptions();
constructor(configService) {
this.inputEvents = new EventEmitter();
this.datePickerOptions.format = configService.config.dateInputFormat;
}
control;
form;
fieldViewModel;
set model(m) {
this.fieldViewModel = m;
this.datePickerOptions.class = m instanceof PropertyViewModel ? 'datepicker-property' : 'datepicker-parameter';
}
get model() {
return this.fieldViewModel;
}
datepicker;
inputEvents;
get id() {
return this.model.paneArgId;
}
get description() {
return this.model.description;
}
setValueIfChanged(dateModel) {
const oldValue = this.control.value;
const newValue = dateModel ? dateModel.toFormat(fixedDateFormat) : '';
if (newValue !== oldValue) {
this.model.resetMessage();
this.model.clientValid = true;
this.control.setValue(newValue);
}
}
handleDefaultEvent(data) {
if (this.control) {
if (data === 'closed') {
const dateModel = this.datepicker?.dateModel ?? null;
this.setValueIfChanged(dateModel);
}
}
}
handleDateChangedEvent(dateModel) {
if (this.control) {
this.setValueIfChanged(dateModel);
}
}
handleDateClearedEvent() {
if (this.control) {
this.model.resetMessage();
this.model.clientValid = true;
this.control.setValue('');
}
}
handleInvalidDateEvent(_) {
if (this.control) {
this.model.setInvalidDate();
this.model.clientValid = false;
this.control.setErrors({ [this.model.getMessage()]: true });
}
}
handleEvents(e) {
switch (e.type) {
case ('default'):
this.handleDefaultEvent(e.data);
break;
case ('dateChanged'):
this.handleDateChangedEvent(e.data);
break;
case ('dateCleared'):
this.handleDateClearedEvent();
break;
case ('dateInvalid'):
this.handleInvalidDateEvent(e.data);
break;
default: // ignore
}
}
ngAfterViewInit() {
const existingValue = this.control && this.control.value;
if (existingValue && (existingValue instanceof String || typeof existingValue === 'string')) {
setTimeout(() => this.inputEvents.emit({ type: 'setDate', data: existingValue, }));
}
}
focus() {
return this.datepicker?.focus();
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatePickerFacadeComponent, deps: [{ token: i1.ConfigService }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: DatePickerFacadeComponent, selector: "nof-date-picker-facade", inputs: { control: "control", form: "form", model: "model" }, viewQueries: [{ propertyName: "datepicker", first: true, predicate: ["dp"], descendants: true }], ngImport: i0, template: "<div [formGroup]=\"form\">\n <nof-date-picker #dp [id]=\"id\" [inputEvents]=\"inputEvents\" (outputEvents)=\"handleEvents($event)\" [options]=\"datePickerOptions\" [description]=\"description\"></nof-date-picker >\n</div> ", styles: [""], dependencies: [{ kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i3.DatePickerComponent, selector: "nof-date-picker", inputs: ["options", "inputEvents", "id", "description"], outputs: ["outputEvents"] }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatePickerFacadeComponent, decorators: [{
type: Component,
args: [{ selector: 'nof-date-picker-facade', template: "<div [formGroup]=\"form\">\n <nof-date-picker #dp [id]=\"id\" [inputEvents]=\"inputEvents\" (outputEvents)=\"handleEvents($event)\" [options]=\"datePickerOptions\" [description]=\"description\"></nof-date-picker >\n</div> " }]
}], ctorParameters: () => [{ type: i1.ConfigService }], propDecorators: { control: [{
type: Input,
args: [{ required: true }]
}], form: [{
type: Input,
args: [{ required: true }]
}], model: [{
type: Input,
args: [{ required: true }]
}], datepicker: [{
type: ViewChild,
args: ['dp', { static: false }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker-facade.component.js","sourceRoot":"","sources":["../../../../gemini/src/date-picker-facade/date-picker-facade.component.ts","../../../../gemini/src/date-picker-facade/date-picker-facade.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ViewChild } from '@angular/core';\nimport { Component, EventEmitter, Input } from '@angular/core';\nimport { AbstractControl, FormGroup } from '@angular/forms';\nimport { ConfigService } from '@nakedobjects/services';\nimport { FieldViewModel, PropertyViewModel } from '@nakedobjects/view-models';\nimport { DateTime } from 'luxon';\nimport { DatePickerComponent, DatePickerOptions } from '../date-picker/date-picker.component';\nimport { IDatePickerInputEvent, IDatePickerOutputEvent } from '../date-picker/date-picker.component';\nimport { fixedDateFormat } from '@nakedobjects/services';\n\n@Component({\n    selector: 'nof-date-picker-facade',\n    templateUrl: 'date-picker-facade.component.html',\n    styleUrls: ['date-picker-facade.component.css']\n})\nexport class DatePickerFacadeComponent implements AfterViewInit {\n\n    datePickerOptions = new DatePickerOptions();\n\n    constructor(configService: ConfigService) {\n        this.inputEvents = new EventEmitter<IDatePickerInputEvent>();\n        this.datePickerOptions.format = configService.config.dateInputFormat;\n    }\n\n    @Input({required: true})\n    control!: AbstractControl;\n\n    @Input({required: true})\n    form!: FormGroup;\n\n    private fieldViewModel!: FieldViewModel;\n\n    @Input({required: true})\n    set model(m: FieldViewModel) {\n        this.fieldViewModel = m;\n        this.datePickerOptions.class = m instanceof PropertyViewModel ? 'datepicker-property' : 'datepicker-parameter';\n    }\n\n    get model(): FieldViewModel {\n        return this.fieldViewModel;\n    }\n\n    @ViewChild('dp', {static: false})\n    datepicker?: DatePickerComponent;\n\n    inputEvents: EventEmitter<IDatePickerInputEvent>;\n\n    get id() {\n        return this.model.paneArgId;\n    }\n\n    get description() {\n        return this.model.description;\n    }\n\n    setValueIfChanged(dateModel: DateTime | null) {\n        const oldValue = this.control.value;\n        const newValue = dateModel ? dateModel.toFormat(fixedDateFormat) : '';\n\n        if (newValue !== oldValue) {\n            this.model.resetMessage();\n            this.model.clientValid = true;\n            this.control.setValue(newValue);\n        }\n    }\n\n    handleDefaultEvent(data: string) {\n        if (this.control) {\n            if (data === 'closed') {\n                const dateModel = this.datepicker?.dateModel ?? null;\n                this.setValueIfChanged(dateModel);\n            }\n        }\n    }\n\n    handleDateChangedEvent(dateModel: DateTime) {\n        if (this.control) {\n            this.setValueIfChanged(dateModel);\n        }\n    }\n\n    handleDateClearedEvent() {\n        if (this.control) {\n            this.model.resetMessage();\n            this.model.clientValid = true;\n            this.control.setValue('');\n        }\n    }\n\n    handleInvalidDateEvent(_: string) {\n        if (this.control) {\n            this.model.setInvalidDate();\n            this.model.clientValid = false;\n            this.control.setErrors({ [this.model.getMessage()]: true });\n        }\n    }\n\n    handleEvents(e: IDatePickerOutputEvent) {\n        switch (e.type) {\n            case ('default'):\n                this.handleDefaultEvent(e.data);\n                break;\n            case ('dateChanged'):\n                this.handleDateChangedEvent(e.data);\n                break;\n            case ('dateCleared'):\n                this.handleDateClearedEvent();\n                break;\n            case ('dateInvalid'):\n                this.handleInvalidDateEvent(e.data);\n                break;\n\n            default: // ignore\n        }\n    }\n\n    ngAfterViewInit(): void {\n        const existingValue = this.control && this.control.value;\n        if (existingValue && (existingValue instanceof String || typeof existingValue === 'string')) {\n            setTimeout(() => this.inputEvents.emit({ type: 'setDate', data: existingValue as string, }));\n        }\n    }\n\n    focus() {\n        return this.datepicker?.focus();\n    }\n}\n","<div [formGroup]=\"form\">\n    <nof-date-picker #dp [id]=\"id\" [inputEvents]=\"inputEvents\" (outputEvents)=\"handleEvents($event)\"  [options]=\"datePickerOptions\" [description]=\"description\"></nof-date-picker >\n</div>                   "]}