UNPKG

@grapecity/inputman.angular

Version:

このパッケージには、Angular用の[InputManJS](https://developer.mescius.jp/inputmanjs)コンポーネントが含まれます。

203 lines 23 kB
import { __decorate, __metadata } from "tslib"; import { Component, ElementRef, Input, Output, EventEmitter, forwardRef } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { GC } from '../inputman'; import { Property } from '../common'; import { GcComponents } from './GcComponents'; import * as i0 from "@angular/core"; export class GcCalendarComponent extends GcComponents { constructor(ref) { super(ref); this.onChange = () => { }; this.onTouched = () => { }; this.onClickDate = new EventEmitter(); this.onScrolled = new EventEmitter(); this.onFocusDateChanged = new EventEmitter(); this.onSelectedDateChanged = new EventEmitter(); // For V2.1 Compatibility, we have to keep this property or event this.focusDateChange = new EventEmitter(); this.selectedDateChange = new EventEmitter(); } writeValue(value) { if (this.selectionMode == undefined || this.selectionMode == GC.InputMan.CalendarSelectionMode.One) { this.selectedDate = value; if (this._imCtrl) { this._imCtrl.selectedDate = this.selectedDate; } } else { if (this._imCtrl) { if (value instanceof Array) { this._imCtrl.setSelections(value); } else { this._imCtrl.setSelections([value]); } } } } registerOnChange(onChange) { this.onChange = onChange; } registerOnTouched(onTouched) { this.onTouched = onTouched; } setDisabledState(isDisabled) { this.enabled = !isDisabled; if (this._imCtrl) { this._imCtrl.enabled = this.enabled; } } initGcComponent() { var element = document.createElement('div'); this.createTemplate(element); if (Array.isArray(this.calendarDimensions)) { this.calendarDimensions = { width: this.calendarDimensions[0], height: this.calendarDimensions[1] }; } this._imCtrl = new GC.InputMan.GcCalendar(element, this); } bindEvent() { if (!this._imCtrl) { return; } this._imCtrl.onClickDate((s) => { this.onClickDate.emit(s); }); this._imCtrl.onScrolled((s) => { this.onScrolled.emit(s); }); this._imCtrl.onFocusDateChanged((s) => { this.onFocusDateChanged.emit(s); this.focusDateChange.emit(s.getFocusDate()); }); this._imCtrl.onSelectedDateChanged((s) => { this.onSelectedDateChanged.emit(s); if (this._imCtrl.selectionMode == GC.InputMan.CalendarSelectionMode.One) { this.onChange(s.getSelectedDate()); } else { this.onChange(s.getSelections()); } this.onTouched(); this.selectedDateChange.emit(s.getSelectedDate()); }); } } GcCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GcCalendarComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); GcCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GcCalendarComponent, selector: "gc-calendar", inputs: { visible: "visible", calendarZoomRange: "calendarZoomRange", maxSelectionCount: "maxSelectionCount", selectionMode: "selectionMode", selectedDate: "selectedDate", enabled: "enabled", weekTitleSelect: "weekTitleSelect", weekNumberSelect: "weekNumberSelect", focusDate: "focusDate", maxDate: "maxDate", minDate: "minDate", allowSelection: "allowSelection", emptyRows: "emptyRows", firstDayOfWeek: "firstDayOfWeek", firstFiscalMonth: "firstFiscalMonth", firstMonthInView: "firstMonthInView", yearMonthFormat: "yearMonthFormat", headerFormat: "headerFormat", showZoomButton: "showZoomButton", showRokuyou: "showRokuyou", showHeader: "showHeader", showToday: "showToday", showWeekNumber: "showWeekNumber", showTrailing: "showTrailing", calendarYear: "calendarYear", showNavigator: "showNavigator", navigatorOrientation: "navigatorOrientation", overrideTipText: "overrideTipText", calendarType: "calendarType", calendarDimensions: "calendarDimensions", scrollRate: "scrollRate", autoSwitch: "autoSwitch", showAnimation: "showAnimation", width: "width", height: "height", minWidth: "minWidth", minHeight: "minHeight", maxWidth: "maxWidth", maxHeight: "maxHeight", allowResize: "allowResize" }, outputs: { onClickDate: "onClickDate", onScrolled: "onScrolled", onFocusDateChanged: "onFocusDateChanged", onSelectedDateChanged: "onSelectedDateChanged", focusDateChange: "focusDateChange", selectedDateChange: "selectedDateChange" }, providers: [ { provide: NG_VALUE_ACCESSOR, multi: true, useExisting: forwardRef(() => GcCalendarComponent), } ], usesInheritance: true, ngImport: i0, template: ``, isInline: true }); __decorate([ Property("setCalendarDimensions", "", true), __metadata("design:type", Array) ], GcCalendarComponent.prototype, "calendarDimensions", void 0); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GcCalendarComponent, decorators: [{ type: Component, args: [{ selector: 'gc-calendar', template: ``, providers: [ { provide: NG_VALUE_ACCESSOR, multi: true, useExisting: forwardRef(() => GcCalendarComponent), } ] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { visible: [{ type: Input }], calendarZoomRange: [{ type: Input }], maxSelectionCount: [{ type: Input }], selectionMode: [{ type: Input }], selectedDate: [{ type: Input }], enabled: [{ type: Input }], weekTitleSelect: [{ type: Input }], weekNumberSelect: [{ type: Input }], focusDate: [{ type: Input }], maxDate: [{ type: Input }], minDate: [{ type: Input }], allowSelection: [{ type: Input }], emptyRows: [{ type: Input }], firstDayOfWeek: [{ type: Input }], firstFiscalMonth: [{ type: Input }], firstMonthInView: [{ type: Input }], yearMonthFormat: [{ type: Input }], headerFormat: [{ type: Input }], showZoomButton: [{ type: Input }], showRokuyou: [{ type: Input }], showHeader: [{ type: Input }], showToday: [{ type: Input }], showWeekNumber: [{ type: Input }], showTrailing: [{ type: Input }], calendarYear: [{ type: Input }], showNavigator: [{ type: Input }], navigatorOrientation: [{ type: Input }], overrideTipText: [{ type: Input }], calendarType: [{ type: Input }], calendarDimensions: [{ type: Input }], scrollRate: [{ type: Input }], autoSwitch: [{ type: Input }], showAnimation: [{ type: Input }], width: [{ type: Input }], height: [{ type: Input }], minWidth: [{ type: Input }], minHeight: [{ type: Input }], maxWidth: [{ type: Input }], maxHeight: [{ type: Input }], allowResize: [{ type: Input }], onClickDate: [{ type: Output }], onScrolled: [{ type: Output }], onFocusDateChanged: [{ type: Output }], onSelectedDateChanged: [{ type: Output }], focusDateChange: [{ type: Output }], selectedDateChange: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GcCalendar.js","sourceRoot":"","sources":["../../../components/GcCalendar.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, Output, EventEmitter, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { GC } from '../inputman';\nimport { Property } from '../common';\nimport { GcComponents } from './GcComponents';\nimport { GcNumberComponent } from './GcNumber';\n\ninterface Dimensions {\n    width: number;\n    height: number;\n}\n\n@Component({\n    selector: 'gc-calendar',\n    template: ``,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            multi: true,\n            useExisting: forwardRef(() => GcCalendarComponent),\n        }\n    ]\n})\nexport class GcCalendarComponent extends GcComponents<GC.InputMan.GcCalendar> implements ControlValueAccessor {\n    constructor(ref: ElementRef) {\n        super(ref);\n    }\n\n    private onChange: Function = () => { };\n    private onTouched: Function = () => { };\n\n    writeValue(value: any): void {\n        if (this.selectionMode == undefined || this.selectionMode == GC.InputMan.CalendarSelectionMode.One) {\n            this.selectedDate = value;\n            if (this._imCtrl) {\n                this._imCtrl.selectedDate = this.selectedDate;\n            }\n        } else {\n            if (this._imCtrl) {\n                if (value instanceof Array) {\n                    this._imCtrl.setSelections(value);\n                } else {\n                    this._imCtrl.setSelections([value]);\n                }\n            }\n        }\n    }\n    registerOnChange(onChange: any): void {\n        this.onChange = onChange;\n    }\n    registerOnTouched(onTouched: any): void {\n        this.onTouched = onTouched;\n    }\n    setDisabledState(isDisabled: boolean): void {\n        this.enabled = !isDisabled;\n        if (this._imCtrl) {\n            this._imCtrl.enabled = this.enabled;\n        }\n    }\n\n    protected initGcComponent() {\n        var element = document.createElement('div');\n        this.createTemplate(element);\n        if (Array.isArray((this as any).calendarDimensions)) {\n            (this as any).calendarDimensions = <Dimensions>{\n                width: (this as any).calendarDimensions[0],\n                height: (this as any).calendarDimensions[1]\n            }\n        }\n        this._imCtrl = new GC.InputMan.GcCalendar(element, this as any);\n    }\n\n    @Input()\n    public visible: boolean;\n    @Input()\n    public calendarZoomRange: GC.InputMan.CalendarZoomRange | GC.InputMan.CalendarType[];\n    @Input()\n    public maxSelectionCount: number;\n    @Input()\n    public selectionMode: GC.InputMan.CalendarSelectionMode;\n    @Input()\n    public selectedDate: Date | null;\n    @Input()\n    public enabled: boolean;\n    @Input()\n    public weekTitleSelect: boolean;\n    @Input()\n    public weekNumberSelect: boolean;\n    @Input()\n    public focusDate: Date | null;\n    @Input()\n    public maxDate: Date | null;\n    @Input()\n    public minDate: Date | null;\n    @Input()\n    public allowSelection: GC.InputMan.AllowSelection;\n    @Input()\n    public emptyRows: GC.InputMan.EmptyRows;\n    @Input()\n    public firstDayOfWeek: GC.InputMan.DayOfWeek;\n    @Input()\n    public firstFiscalMonth: GC.InputMan.Months;\n    @Input()\n    public firstMonthInView: GC.InputMan.Months;\n    @Input()\n    public yearMonthFormat: string;\n    @Input()\n    public headerFormat: string;\n    @Input()\n    public showZoomButton: boolean;\n    @Input()\n    public showRokuyou: GC.InputMan.Rokuyou;\n    @Input()\n    public showHeader: boolean;\n    @Input()\n    public showToday: boolean;\n    @Input()\n    public showWeekNumber: boolean;\n    @Input()\n    public showTrailing: boolean;\n    @Input()\n    public calendarYear: GC.InputMan.CalendarYear;\n    @Input()\n    public showNavigator: GC.InputMan.CalendarNavigators;\n    @Input()\n    public navigatorOrientation: number | GC.InputMan.NavigatorOrientation;\n    @Input()\n    public overrideTipText: string;\n    @Input()\n    public calendarType: GC.InputMan.CalendarType;\n    @Property(\"setCalendarDimensions\", \"\", true)\n    @Input()\n    public calendarDimensions: Array<number>;\n    @Input()\n    public scrollRate: number;\n    @Input()\n    public autoSwitch: boolean;\n    @Input()\n    public showAnimation: boolean;\n    @Input()\n    public width: number | string;\n    @Input()\n    public height: number | string;\n    @Input()\n    public minWidth: number | string;\n    @Input()\n    public minHeight: number | string;\n    @Input()\n    public maxWidth: number | string;\n    @Input()\n    public maxHeight: number | string;\n    @Input()\n    public allowResize: boolean;\n    @Output()\n    public onClickDate: EventEmitter<GC.InputMan.GcCalendar> = new EventEmitter();\n    @Output()\n    public onScrolled: EventEmitter<GC.InputMan.GcCalendar> = new EventEmitter();\n    @Output()\n    public onFocusDateChanged: EventEmitter<GC.InputMan.GcCalendar> = new EventEmitter();\n    @Output()\n    public onSelectedDateChanged: EventEmitter<GC.InputMan.GcCalendar> = new EventEmitter();\n    // For V2.1 Compatibility, we have to keep this property or event\n    @Output()\n    public focusDateChange: EventEmitter<Date> = new EventEmitter();\n    @Output()\n    public selectedDateChange: EventEmitter<Date> = new EventEmitter();\n\n\n    protected bindEvent() {\n        if (!this._imCtrl) {\n            return;\n        }\n\n        this._imCtrl.onClickDate((s) => { this.onClickDate.emit(s) });\n        this._imCtrl.onScrolled((s) => { this.onScrolled.emit(s) });\n        this._imCtrl.onFocusDateChanged((s) => {\n            this.onFocusDateChanged.emit(s);\n            this.focusDateChange.emit(s.getFocusDate());\n        });\n        this._imCtrl.onSelectedDateChanged((s) => {\n            this.onSelectedDateChanged.emit(s);\n            if (this._imCtrl.selectionMode == GC.InputMan.CalendarSelectionMode.One) {\n                this.onChange(s.getSelectedDate());\n            } else {\n                this.onChange(s.getSelections());\n            }\n            this.onTouched();\n            this.selectedDateChange.emit(s.getSelectedDate());\n        });\n    }\n}"]}