/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { NgModule, Component, Input, Output, EventEmitter, forwardRef } from '@angular/core'; import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms'; import { CommonModule } from '@angular/common'; import { SharedModule } from 'primeng/primeng'; import { DxDateBoxModule } from 'devextreme-angular/ui/date-box'; import { Common } from '../_services/common.service'; import { formatDate } from "devextreme/localization"; import moment from 'moment-es6'; import { locale } from 'devextreme/localization'; import 'devextreme-intl'; import { baseZIndex } from 'devextreme/ui/overlay'; // # Calendar TH locale('th'); // # Calendar TH baseZIndex(9999); export class SocDateBoxComponent { /** * @param {?} common */ constructor(common) { this.common = common; this.id = ''; this.width = '100%'; this.type = 'date'; this.max = undefined; this.min = undefined; this.acceptCustomValue = true; this.maxZoomLevel = 'month'; this.minZoomLevel = 'century'; this.valueChange = new EventEmitter(); this.openOnFieldClick = true; this.disabled = false; this.interval = 30; this.showAnalogClock = false; this.format = { formatter: (date) => { if (this.type === 'datetime') { return formatDate(date, 'shortDateShortTime'); } else if (this.type === 'time') { return formatDate(date, 'shortTime'); } else { return formatDate(date, 'shortDate'); } }, parser: (date) => { /** @type {?} */ let format = 'D/M/YYYY'; if (this.type === 'datetime') { format = 'D/M/YYYY HH:mm'; } else if (this.type === 'time') { format = 'HH:mm'; } /** @type {?} */ const dateFormated = moment(date, format, true).subtract(543, 'year').toDate(); return dateFormated; } }; /** * START Bind Value */ this.onModelChange = () => { }; this.onModelTouched = () => { }; } /** * @return {?} */ ngOnInit() { return tslib_1.__awaiter(this, void 0, void 0, function* () { }); } /** * @return {?} */ ngAfterViewInit() { } /** * @return {?} */ onOpened() { this.common.fnChangeCalendarYear(); // # Calendar TH if (this.maxZoomLevel === 'year' || this.maxZoomLevel === 'decade') { this.common.fnChangeCalendarYearOnce(); // # Calendar TH } /** * * SECTION แก้ปัญหา ปฏิทินไม่แสดงใน modal ที่ prod @type {?} */ const element = document.querySelector('.dx-overlay-wrapper.dx-dropdowneditor-overlay.dx-popup-wrapper.dx-datebox-wrapper.dx-datebox-wrapper-date.dx-datebox-wrapper-calendar'); /** @type {?} */ const subElement = document.querySelector('.dx-overlay-wrapper.dx-dropdowneditor-overlay.dx-popup-wrapper.dx-datebox-wrapper.dx-datebox-wrapper-date.dx-datebox-wrapper-calendar > .dx-overlay-content.dx-popup-normal'); if (element) { /** @type {?} */ const style = element.getAttribute('style'); /** @type {?} */ const newStyle = style.replace('z-index: 1501;', 'z-index: 2050;'); console.log('LOG: SocDateBoxComponent -> onOpened -> newStyle element', newStyle); element.setAttribute('style', newStyle); } if (subElement) { /** @type {?} */ const style = subElement.getAttribute('style'); /** @type {?} */ const newStyle = style.replace('z-index: 1501;', 'z-index: 2050;'); console.log('LOG: SocDateBoxComponent -> onOpened -> newStyle subElement', newStyle); subElement.setAttribute('style', newStyle); } /** !SECTION */ } /** * @param {?} e * @return {?} */ onValueChanged(e) { console.log("​SocDateBoxComponent -> onValueChanged -> e", e); this.valueChange.emit(e.value); } /** * @param {?} value * @return {?} */ writeValue(value) { } /** * @param {?} fn * @return {?} */ registerOnChange(fn) { } /** * @param {?} fn * @return {?} */ registerOnTouched(fn) { } } SocDateBoxComponent.decorators = [ { type: Component, args: [{ selector: 'soc-date-box', providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SocDateBoxComponent), multi: true }], template: ` ` }] } ]; /** @nocollapse */ SocDateBoxComponent.ctorParameters = () => [ { type: Common } ]; SocDateBoxComponent.propDecorators = { id: [{ type: Input }], width: [{ type: Input }], type: [{ type: Input }], value: [{ type: Input }], max: [{ type: Input }], min: [{ type: Input }], acceptCustomValue: [{ type: Input }], maxZoomLevel: [{ type: Input }], minZoomLevel: [{ type: Input }], valueChange: [{ type: Output }], openOnFieldClick: [{ type: Input }], disabled: [{ type: Input }], interval: [{ type: Input }], showAnalogClock: [{ type: Input }] }; if (false) { /** @type {?} */ SocDateBoxComponent.prototype.id; /** @type {?} */ SocDateBoxComponent.prototype.width; /** @type {?} */ SocDateBoxComponent.prototype.type; /** @type {?} */ SocDateBoxComponent.prototype.value; /** @type {?} */ SocDateBoxComponent.prototype.max; /** @type {?} */ SocDateBoxComponent.prototype.min; /** @type {?} */ SocDateBoxComponent.prototype.acceptCustomValue; /** @type {?} */ SocDateBoxComponent.prototype.maxZoomLevel; /** @type {?} */ SocDateBoxComponent.prototype.minZoomLevel; /** @type {?} */ SocDateBoxComponent.prototype.valueChange; /** @type {?} */ SocDateBoxComponent.prototype.openOnFieldClick; /** @type {?} */ SocDateBoxComponent.prototype.disabled; /** @type {?} */ SocDateBoxComponent.prototype.interval; /** @type {?} */ SocDateBoxComponent.prototype.showAnalogClock; /** @type {?} */ SocDateBoxComponent.prototype.format; /** * START Bind Value * @type {?} */ SocDateBoxComponent.prototype.onModelChange; /** @type {?} */ SocDateBoxComponent.prototype.onModelTouched; /** @type {?} */ SocDateBoxComponent.prototype.common; } export class SharedDateBoxModule { } SharedDateBoxModule.decorators = [ { type: NgModule, args: [{ imports: [CommonModule, FormsModule, SharedModule, DxDateBoxModule], exports: [SocDateBoxComponent, SharedModule], declarations: [SocDateBoxComponent], },] } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"soc-date-box.js","sourceRoot":"ng://soc-app-library/","sources":["lib/_template/soc-date-box.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    NgModule, Component, OnInit, Input, Output, EventEmitter, forwardRef, AfterViewInit\n} from '@angular/core';\nimport { FormsModule, NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { SharedModule } from 'primeng/primeng';\n// import { Request } from '../_services/request.service';\nimport * as _ from 'lodash';\nimport { DxDateBoxModule } from 'devextreme-angular/ui/date-box';\nimport { Common } from '../_services/common.service';\nimport { formatDate } from \"devextreme/localization\";\nimport moment from 'moment-es6';\nimport { locale } from 'devextreme/localization'; // # Calendar TH\nimport 'devextreme-intl';\nimport {baseZIndex} from 'devextreme/ui/overlay';\n// # Calendar TH\nlocale('th');// # Calendar TH\nbaseZIndex(9999);\n@Component({\n    selector: 'soc-date-box',\n    providers: [{\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: forwardRef(() => SocDateBoxComponent),\n        multi: true\n    }],\n    template: `\n    <dx-date-box [showAnalogClock]=\"showAnalogClock\" [id]=\"id\" [(value)]=\"value\" [type]=\"type\" [disabled]=\"disabled\" [width]=\"width\" [interval]=\"interval\" [acceptCustomValue]=\"true\" [displayFormat]=\"format\" invalidDateMessage=\"วันที่ไม่ถูกต้อง กรุณากรอกเป็น วัน/เดือน/ปี\"\n    [openOnFieldClick]=\"openOnFieldClick\" (onOpened)=\"onOpened()\" (onValueChanged)=\"onValueChanged($event)\" [max]=\"max\" [min]=\"min\" [maxZoomLevel]=\"maxZoomLevel\" [minZoomLevel]=\"minZoomLevel\"></dx-date-box>\n\n`\n})\nexport class SocDateBoxComponent implements ControlValueAccessor, OnInit, AfterViewInit {\n    @Input() id = '';\n    @Input() width = '100%';\n    @Input() type = 'date';\n    @Input() value: any;\n    @Input() max = undefined;\n    @Input() min = undefined;\n    @Input() acceptCustomValue = true;\n    @Input() maxZoomLevel = 'month';\n    @Input() minZoomLevel = 'century';\n    @Output() valueChange: EventEmitter<string> = new EventEmitter<string>();\n    @Input() openOnFieldClick = true;\n    @Input() disabled = false;\n    @Input() interval: number = 30;\n    @Input() showAnalogClock: boolean = false;\n    format = {\n        formatter: (date) => {\n            if (this.type === 'datetime') {\n                return formatDate(date, 'shortDateShortTime');\n            } else if (this.type === 'time') {\n                return formatDate(date, 'shortTime');\n            } else {\n                return formatDate(date, 'shortDate');\n            }\n        },\n        parser: (date) => {\n            let format = 'D/M/YYYY';\n            if (this.type === 'datetime') {\n                format = 'D/M/YYYY HH:mm';\n            } else if (this.type === 'time') {\n                format = 'HH:mm';\n            }\n            const dateFormated = moment(date, format, true).subtract(543, 'year').toDate();\n            return dateFormated;\n        }\n    };\n    constructor(private common: Common,) { }\n    async ngOnInit() {\n    }\n    ngAfterViewInit() {\n    }\n    onOpened() {\n        this.common.fnChangeCalendarYear(); // # Calendar TH\n        if (this.maxZoomLevel === 'year' || this.maxZoomLevel === 'decade') {\n            this.common.fnChangeCalendarYearOnce(); // # Calendar TH\n        }\n        /** SECTION แก้ปัญหา ปฏิทินไม่แสดงใน modal ที่ prod */\n        const element = document.querySelector('.dx-overlay-wrapper.dx-dropdowneditor-overlay.dx-popup-wrapper.dx-datebox-wrapper.dx-datebox-wrapper-date.dx-datebox-wrapper-calendar');\n        const subElement = document.querySelector('.dx-overlay-wrapper.dx-dropdowneditor-overlay.dx-popup-wrapper.dx-datebox-wrapper.dx-datebox-wrapper-date.dx-datebox-wrapper-calendar > .dx-overlay-content.dx-popup-normal');\n        if (element) {\n            const style = element.getAttribute('style');\n            const newStyle = style.replace('z-index: 1501;', 'z-index: 2050;');\n            console.log('LOG: SocDateBoxComponent -> onOpened -> newStyle element', newStyle);\n            element.setAttribute('style', newStyle);\n        }\n        if (subElement) {\n            const style = subElement.getAttribute('style');\n            const newStyle = style.replace('z-index: 1501;', 'z-index: 2050;');\n            console.log('LOG: SocDateBoxComponent -> onOpened -> newStyle subElement', newStyle);\n            subElement.setAttribute('style', newStyle);\n        }\n        /** !SECTION */\n    }\n    onValueChanged(e:any) {\n\t\tconsole.log(\"​SocDateBoxComponent -> onValueChanged -> e\", e)\n        this.valueChange.emit(e.value);\n    }\n    // displayFormat (value) {\n    //     console.log(\"​SocDateBoxComponent -> displayFormat -> value\", value)\n    //     const year = moment(value).get('year');\n\t// \tconsole.log(\"​SocDateBoxComponent -> displayFormat -> year\", year)\n    //     // let dateString = formatDate(value, \"longDate\");\n    //     let dateString =  moment(value).add(543,'year').format('DD/MM/YYYY')\n    //     return dateString;\n    // }\n    /** START Bind Value */\n    onModelChange: Function = () => { };\n    onModelTouched: Function = () => { };\n    writeValue(value: any): void { }\n    registerOnChange(fn: Function): void { }\n    registerOnTouched(fn: Function): void { }\n    /** END Bind Value */\n\n}\n\n@NgModule({\n    imports: [CommonModule, FormsModule, SharedModule, DxDateBoxModule],\n    exports: [SocDateBoxComponent, SharedModule],\n    declarations: [SocDateBoxComponent],\n})\nexport class SharedDateBoxModule { }\n"]}