@grapecity/inputman.angular
Version:
このパッケージには、Angular用の[InputManJS](https://developer.mescius.jp/inputmanjs)コンポーネントが含まれます。
203 lines • 23 kB
JavaScript
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}"]}