soc-date-box.js 20.9 KB
/**
 * @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);
var SocDateBoxComponent = /** @class */ (function () {
    function SocDateBoxComponent(common) {
        var _this = this;
        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: function (date) {
                if (_this.type === 'datetime') {
                    return formatDate(date, 'shortDateShortTime');
                }
                else if (_this.type === 'time') {
                    return formatDate(date, 'shortTime');
                }
                else {
                    return formatDate(date, 'shortDate');
                }
            },
            parser: function (date) {
                /** @type {?} */
                var format = 'D/M/YYYY';
                if (_this.type === 'datetime') {
                    format = 'D/M/YYYY HH:mm';
                }
                else if (_this.type === 'time') {
                    format = 'HH:mm';
                }
                /** @type {?} */
                var dateFormated = moment(date, format, true).subtract(543, 'year').toDate();
                return dateFormated;
            }
        };
        /**
         * START Bind Value
         */
        this.onModelChange = function () { };
        this.onModelTouched = function () { };
    }
    /**
     * @return {?}
     */
    SocDateBoxComponent.prototype.ngOnInit = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            return tslib_1.__generator(this, function (_a) {
                return [2 /*return*/];
            });
        });
    };
    /**
     * @return {?}
     */
    SocDateBoxComponent.prototype.ngAfterViewInit = /**
     * @return {?}
     */
    function () {
    };
    /**
     * @return {?}
     */
    SocDateBoxComponent.prototype.onOpened = /**
     * @return {?}
     */
    function () {
        this.common.fnChangeCalendarYear(); // # Calendar TH
        if (this.maxZoomLevel === 'year' || this.maxZoomLevel === 'decade') {
            this.common.fnChangeCalendarYearOnce(); // # Calendar TH
        }
        /** *
         * SECTION แก้ปัญหา ปฏิทินไม่แสดงใน modal ที่ prod
          @type {?} */
        var element = document.querySelector('.dx-overlay-wrapper.dx-dropdowneditor-overlay.dx-popup-wrapper.dx-datebox-wrapper.dx-datebox-wrapper-date.dx-datebox-wrapper-calendar');
        /** @type {?} */
        var 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 {?} */
            var style = element.getAttribute('style');
            /** @type {?} */
            var newStyle = style.replace('z-index: 1501;', 'z-index: 2050;');
            console.log('LOG: SocDateBoxComponent -> onOpened -> newStyle element', newStyle);
            element.setAttribute('style', newStyle);
        }
        if (subElement) {
            /** @type {?} */
            var style = subElement.getAttribute('style');
            /** @type {?} */
            var 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 {?}
     */
    SocDateBoxComponent.prototype.onValueChanged = /**
     * @param {?} e
     * @return {?}
     */
    function (e) {
        console.log("​SocDateBoxComponent -> onValueChanged -> e", e);
        this.valueChange.emit(e.value);
    };
    /**
     * @param {?} value
     * @return {?}
     */
    SocDateBoxComponent.prototype.writeValue = /**
     * @param {?} value
     * @return {?}
     */
    function (value) { };
    /**
     * @param {?} fn
     * @return {?}
     */
    SocDateBoxComponent.prototype.registerOnChange = /**
     * @param {?} fn
     * @return {?}
     */
    function (fn) { };
    /**
     * @param {?} fn
     * @return {?}
     */
    SocDateBoxComponent.prototype.registerOnTouched = /**
     * @param {?} fn
     * @return {?}
     */
    function (fn) { };
    SocDateBoxComponent.decorators = [
        { type: Component, args: [{
                    selector: 'soc-date-box',
                    providers: [{
                            provide: NG_VALUE_ACCESSOR,
                            useExisting: forwardRef(function () { return SocDateBoxComponent; }),
                            multi: true
                        }],
                    template: "\n    <dx-date-box [showAnalogClock]=\"showAnalogClock\" [id]=\"id\" [(value)]=\"value\" [type]=\"type\" [disabled]=\"disabled\" [width]=\"width\" [interval]=\"interval\" [acceptCustomValue]=\"true\" [displayFormat]=\"format\" invalidDateMessage=\"\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E44\u0E21\u0E48\u0E16\u0E39\u0E01\u0E15\u0E49\u0E2D\u0E07 \u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01\u0E40\u0E1B\u0E47\u0E19 \u0E27\u0E31\u0E19/\u0E40\u0E14\u0E37\u0E2D\u0E19/\u0E1B\u0E35\"\n    [openOnFieldClick]=\"openOnFieldClick\" (onOpened)=\"onOpened()\" (onValueChanged)=\"onValueChanged($event)\" [max]=\"max\" [min]=\"min\" [maxZoomLevel]=\"maxZoomLevel\" [minZoomLevel]=\"minZoomLevel\"></dx-date-box>\n\n"
                }] }
    ];
    /** @nocollapse */
    SocDateBoxComponent.ctorParameters = function () { return [
        { 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 }]
    };
    return SocDateBoxComponent;
}());
export { SocDateBoxComponent };
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;
}
var SharedDateBoxModule = /** @class */ (function () {
    function SharedDateBoxModule() {
    }
    SharedDateBoxModule.decorators = [
        { type: NgModule, args: [{
                    imports: [CommonModule, FormsModule, SharedModule, DxDateBoxModule],
                    exports: [SocDateBoxComponent, SharedModule],
                    declarations: [SocDateBoxComponent],
                },] }
    ];
    return SharedDateBoxModule;
}());
export { SharedDateBoxModule };

//# 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"]}