UNPKG

@nakedobjects/gemini

Version:

Single Page Application client for a Naked Objects application.

115 lines 15.9 kB
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>                   "]}