@ng-nest/ui 16.0.2 → 16.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/auto-complete/auto-complete.component.d.ts +4 -1
- package/cascade/cascade.component.d.ts +4 -1
- package/color-picker/color-picker.component.d.ts +4 -1
- package/core/functions/parent-path.d.ts +1 -0
- package/date-picker/date-picker.component.d.ts +4 -1
- package/date-picker/date-range.component.d.ts +2 -0
- package/esm2022/auto-complete/auto-complete.component.mjs +35 -7
- package/esm2022/cascade/cascade.component.mjs +36 -8
- package/esm2022/color-picker/color-picker.component.mjs +36 -8
- package/esm2022/core/functions/parent-path.mjs +10 -1
- package/esm2022/date-picker/date-picker.component.mjs +36 -9
- package/esm2022/date-picker/date-range.component.mjs +31 -6
- package/esm2022/form/control.component.mjs +2 -2
- package/esm2022/form/form.property.mjs +1 -1
- package/esm2022/select/select.component.mjs +37 -9
- package/esm2022/time-picker/time-picker.component.mjs +32 -6
- package/esm2022/tree-select/tree-select.component.mjs +36 -8
- package/fesm2022/ng-nest-ui-auto-complete.mjs +34 -7
- package/fesm2022/ng-nest-ui-auto-complete.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-cascade.mjs +35 -8
- package/fesm2022/ng-nest-ui-cascade.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-color-picker.mjs +34 -7
- package/fesm2022/ng-nest-ui-color-picker.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-core.mjs +10 -1
- package/fesm2022/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-date-picker.mjs +60 -8
- package/fesm2022/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-form.mjs +1 -1
- package/fesm2022/ng-nest-ui-form.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-select.mjs +37 -10
- package/fesm2022/ng-nest-ui-select.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-time-picker.mjs +31 -5
- package/fesm2022/ng-nest-ui-time-picker.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-tree-select.mjs +35 -8
- package/fesm2022/ng-nest-ui-tree-select.mjs.map +1 -1
- package/form/form.property.d.ts +10 -0
- package/package.json +7 -7
- package/select/select.component.d.ts +4 -1
- package/time-picker/time-picker.component.d.ts +2 -0
- package/tree-select/tree-select.component.d.ts +4 -1
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { XPortalConnectedPosition } from '@ng-nest/ui/portal';
|
|
2
|
-
import { Subject } from 'rxjs';
|
|
3
|
-
import { Component, ViewEncapsulation, ChangeDetectionStrategy, ViewChild } from '@angular/core';
|
|
2
|
+
import { Subject, fromEvent } from 'rxjs';
|
|
3
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy, ViewChild, inject } from '@angular/core';
|
|
4
4
|
import { XDateRangePrefix, XDateRangeProperty } from './date-picker.property';
|
|
5
|
-
import { XIsEmpty, XIsDate, XIsNumber, XIsChange, XClearClass, XIsString, XIsNull, XDateYearWeek, XDateYearQuarter } from '@ng-nest/ui/core';
|
|
6
|
-
import { DatePipe } from '@angular/common';
|
|
7
|
-
import { map, takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { XIsEmpty, XIsDate, XIsNumber, XIsChange, XClearClass, XIsString, XIsNull, XDateYearWeek, XDateYearQuarter, XParents } from '@ng-nest/ui/core';
|
|
6
|
+
import { DOCUMENT, DatePipe } from '@angular/common';
|
|
7
|
+
import { filter, map, takeUntil } from 'rxjs/operators';
|
|
8
8
|
import { XValueAccessor } from '@ng-nest/ui/base-form';
|
|
9
9
|
import { XDateRangePortalComponent } from './date-range-portal.component';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
@@ -113,6 +113,7 @@ class XDateRangeComponent extends XDateRangeProperty {
|
|
|
113
113
|
this.flexClass = [];
|
|
114
114
|
this.locale = {};
|
|
115
115
|
this._unSubject = new Subject();
|
|
116
|
+
this.document = inject(DOCUMENT);
|
|
116
117
|
}
|
|
117
118
|
ngOnInit() {
|
|
118
119
|
this.setFlex(this.dateRange.nativeElement, this.renderer, this.justify, this.align, this.direction);
|
|
@@ -159,6 +160,30 @@ class XDateRangeComponent extends XDateRangeProperty {
|
|
|
159
160
|
setHostTypeClass() {
|
|
160
161
|
this.renderer.addClass(this.elementRef.nativeElement, `x-date-range-${this.type}`);
|
|
161
162
|
}
|
|
163
|
+
setParantScroll() {
|
|
164
|
+
if (!this.document)
|
|
165
|
+
return;
|
|
166
|
+
const parents = XParents(this.elementRef.nativeElement);
|
|
167
|
+
let firstScroll = null;
|
|
168
|
+
for (let item of parents) {
|
|
169
|
+
if (item.clientHeight < item.scrollHeight) {
|
|
170
|
+
firstScroll = item;
|
|
171
|
+
break;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
if (firstScroll && firstScroll.tagName !== 'BODY') {
|
|
175
|
+
fromEvent(firstScroll, 'scroll')
|
|
176
|
+
.pipe(filter(() => this.portalAttached()), takeUntil(this._unSubject))
|
|
177
|
+
.subscribe(() => {
|
|
178
|
+
this.portal?.overlayRef?.updatePosition();
|
|
179
|
+
const eract = this.elementRef.nativeElement.getBoundingClientRect();
|
|
180
|
+
const frect = firstScroll.getBoundingClientRect();
|
|
181
|
+
if (eract.top + eract.height - frect.top < 0 || eract.bottom > frect.bottom) {
|
|
182
|
+
this.closeSubject.next();
|
|
183
|
+
}
|
|
184
|
+
});
|
|
185
|
+
}
|
|
186
|
+
}
|
|
162
187
|
setFormat() {
|
|
163
188
|
if (this.format !== 'yyyy-MM-dd')
|
|
164
189
|
return;
|
|
@@ -448,4 +473,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
|
|
|
448
473
|
type: ViewChild,
|
|
449
474
|
args: ['inputEndCom', { static: true }]
|
|
450
475
|
}] } });
|
|
451
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-range.component.ts","../../../../../lib/ng-nest/ui/date-picker/date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { XPortalService, XPortalOverlayRef, XPortalConnectedPosition } from '@ng-nest/ui/portal';\r\nimport { Subject } from 'rxjs';\r\nimport {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Renderer2,\r\n  ElementRef,\r\n  OnChanges,\r\n  ViewContainerRef,\r\n  ViewChild,\r\n  SimpleChanges\r\n} from '@angular/core';\r\nimport { XDatePickerModelType, XDateRangePrefix, XDateRangeProperty } from './date-picker.property';\r\nimport {\r\n  XIsEmpty,\r\n  XIsDate,\r\n  XIsNumber,\r\n  XIsChange,\r\n  XCorner,\r\n  XClearClass,\r\n  XIsString,\r\n  XConfigService,\r\n  XIsNull,\r\n  XDateYearWeek,\r\n  XDateYearQuarter\r\n} from '@ng-nest/ui/core';\r\nimport { XInputComponent, XInputGroupComponent } from '@ng-nest/ui/input';\r\nimport { DatePipe } from '@angular/common';\r\nimport { Overlay, OverlayConfig, FlexibleConnectedPositionStrategy, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\nimport { XDateRangePortalComponent } from './date-range-portal.component';\r\nimport { XI18nDatePicker, XI18nService } from '@ng-nest/ui/i18n';\r\n\r\n@Component({\r\n  selector: `${XDateRangePrefix}`,\r\n  templateUrl: './date-range.component.html',\r\n  styleUrls: ['./date-range.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XDateRangeComponent), DatePipe]\r\n})\r\nexport class XDateRangeComponent extends XDateRangeProperty implements OnInit, OnChanges {\r\n  @ViewChild('dateRange', { static: true }) dateRange!: ElementRef<HTMLElement>;\r\n  @ViewChild('inputGroup', { static: true }) inputGroup!: XInputGroupComponent;\r\n  @ViewChild('inputStartCom', { static: true }) inputStartCom!: XInputComponent;\r\n  @ViewChild('inputEndCom', { static: true }) inputEndCom!: XInputComponent;\r\n\r\n  modelType: XDatePickerModelType = 'date';\r\n  numberValue!: (number | null)[];\r\n  isInput = false;\r\n  showClearable: boolean = false;\r\n\r\n  get getStartPlaceholder() {\r\n    if (this.placeholder && this.placeholder.length > 0) return this.placeholder[0];\r\n    if (this.type === 'month') {\r\n      return this.locale.startMonth;\r\n    } else if (this.type === 'quarter') {\r\n      return this.locale.startQuarter;\r\n    } else if (this.type === 'year') {\r\n      return this.locale.startYear;\r\n    } else if (this.type === 'week') {\r\n      return this.locale.startWeek;\r\n    } else {\r\n      return this.locale.startDate;\r\n    }\r\n  }\r\n\r\n  get getEndPlaceholder() {\r\n    if (this.placeholder && this.placeholder.length > 1) return this.placeholder[1];\r\n    if (this.type === 'month') {\r\n      return this.locale.endMonth;\r\n    } else if (this.type === 'quarter') {\r\n      return this.locale.endQuarter;\r\n    } else if (this.type === 'year') {\r\n      return this.locale.endYear;\r\n    } else if (this.type === 'week') {\r\n      return this.locale.endWeek;\r\n    } else {\r\n      return this.locale.endDate;\r\n    }\r\n  }\r\n\r\n  override get requiredIsEmpty() {\r\n    return this.validator && this.required && XIsEmpty(this.value);\r\n  }\r\n\r\n  override writeValue(value: any) {\r\n    if (XIsEmpty(value)) {\r\n      value = [];\r\n      this.numberValue = [];\r\n    }\r\n    if (value.length > 0) {\r\n      if (XIsDate(value[0])) {\r\n        this.modelType = 'date';\r\n        this.numberValue = value.map((x: Date) => x.getTime());\r\n      } else if (XIsNumber(value[0])) {\r\n        this.modelType = 'number';\r\n        this.numberValue = value;\r\n      } else if (XIsString(value[0])) {\r\n        this.modelType = 'string';\r\n        const valueTime = value.map((x: string) => new Date(x).getTime());\r\n        this.numberValue = !isNaN(valueTime[0]) ? valueTime : [];\r\n      }\r\n    }\r\n    this.value = value;\r\n    this.setDisplayValue(this.numberValue);\r\n    this.valueChange.next(this.numberValue);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  enter: boolean = false;\r\n  inputClearable: boolean = false;\r\n  animating = false;\r\n  displayValue: string[] = [];\r\n  portal!: XPortalOverlayRef<XDateRangePortalComponent>;\r\n  icon: string = 'fto-calendar';\r\n  box!: DOMRect;\r\n  protalHeight!: number;\r\n  maxNodes: number = 6;\r\n  protalTobottom: boolean = true;\r\n  valueChange: Subject<any> = new Subject();\r\n  dataChange: Subject<any> = new Subject();\r\n  positionChange: Subject<any> = new Subject();\r\n  closeSubject: Subject<void> = new Subject();\r\n  activeTypeChange = new Subject<'start' | 'end'>();\r\n  startDisplay: string | number = '';\r\n  endDisplay: string | number = '';\r\n  activeType?: 'start' | 'end';\r\n  flexClass: string[] = [];\r\n  locale: XI18nDatePicker = {};\r\n  private _unSubject = new Subject<void>();\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public configService: XConfigService,\r\n    public override cdr: ChangeDetectorRef,\r\n    private portalService: XPortalService,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private datePipe: DatePipe,\r\n    private overlay: Overlay,\r\n    private i18n: XI18nService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setFlex(this.dateRange.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n    this.setHostTypeClass();\r\n    this.setFormat();\r\n    this.setClassMap();\r\n    this.setSubject();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.setPortal();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { type, justify, align, direction, size, labelAlign } = changes;\r\n    XIsChange(size, labelAlign) && this.setClassMap();\r\n    XIsChange(justify, align, direction) && this.setFlexClass();\r\n    if (XIsChange(type)) {\r\n      this.setFormat();\r\n      this.setDisplayValue(this.numberValue);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  setSubject() {\r\n    this.closeSubject.pipe(takeUntil(this._unSubject)).subscribe(() => {\r\n      this.closePortal();\r\n    });\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.datePicker as XI18nDatePicker),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  setFlexClass() {\r\n    if (this.flexClass.length > 0) {\r\n      for (let cls of this.flexClass) {\r\n        this.renderer.removeClass(this.dateRange.nativeElement, cls);\r\n      }\r\n    }\r\n    this.flexClass = this.setFlex(this.dateRange.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n  }\r\n\r\n  setHostTypeClass() {\r\n    this.renderer.addClass(this.elementRef.nativeElement, `x-date-range-${this.type}`);\r\n  }\r\n\r\n  setFormat() {\r\n    if (this.format !== 'yyyy-MM-dd') return;\r\n    if (this.type === 'date') {\r\n      this.format = 'yyyy-MM-dd';\r\n    } else if (this.type === 'year') {\r\n      this.format = 'yyyy';\r\n    } else if (this.type === 'month') {\r\n      this.format = 'yyyy-MM';\r\n    } else if (this.type === 'date-time') {\r\n      this.format = 'yyyy-MM-dd HH:mm:ss';\r\n    } else if (this.type === 'date-hour') {\r\n      this.format = 'yyyy-MM-dd HH';\r\n    } else if (this.type === 'date-minute') {\r\n      this.format = 'yyyy-MM-dd HH:mm';\r\n    }\r\n  }\r\n\r\n  menter() {\r\n    if (this.disabled || !this.clearable) return;\r\n    this.enter = true;\r\n    if (!XIsEmpty(this.numberValue)) {\r\n      this.icon = '';\r\n      this.showClearable = true;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  mleave() {\r\n    if (this.disabled || !this.clearable) return;\r\n    this.enter = false;\r\n    if (this.clearable) {\r\n      this.icon = 'fto-calendar';\r\n      this.showClearable = false;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  clearEmit() {\r\n    this.value = [];\r\n    this.numberValue = [];\r\n    this.startDisplay = '';\r\n    this.endDisplay = '';\r\n    this.mleave();\r\n    this.valueChange.next(this.numberValue);\r\n    this.formControlValidator();\r\n    this.modelChange();\r\n    this.inputStartCom.inputFocus();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onIconClick(event: Event) {\r\n    if (this.icon === 'fto-x') {\r\n      this.clearEmit();\r\n    }\r\n    event.stopPropagation();\r\n  }\r\n\r\n  modelChange() {\r\n    if (this.onChange) {\r\n      this.onChange(this.getValue());\r\n    }\r\n  }\r\n\r\n  getValue() {\r\n    return this.modelType === 'date'\r\n      ? this.numberValue.map((x) => new Date(x!))\r\n      : this.modelType === 'string'\r\n      ? this.numberValue.map((x) => this.datePipe.transform(x, this.format))\r\n      : this.numberValue;\r\n  }\r\n\r\n  getNumberValue() {\r\n    return this.modelType === 'date'\r\n      ? this.value.map((x: Date) => x.getTime())\r\n      : this.modelType === 'string'\r\n      ? this.value.map((x: string) => new Date(x).getTime())\r\n      : this.value;\r\n  }\r\n\r\n  portalAttached() {\r\n    return this.portal?.overlayRef?.hasAttached();\r\n  }\r\n\r\n  closePortal() {\r\n    if (this.portalAttached()) {\r\n      this.portal?.overlayRef?.detach();\r\n      this.active = false;\r\n      this.closeReduction();\r\n      this.cdr.detectChanges();\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  closeReduction() {\r\n    if (!this.numberValue || this.numberValue.length === 0 || this.numberValue.includes(null)) {\r\n      if (!this.value || this.value.length === 0) {\r\n        this.startDisplay = '';\r\n        this.endDisplay = '';\r\n        this.numberValue = [];\r\n      } else {\r\n        this.numberValue = this.getNumberValue();\r\n        this.setDisplayValue(this.numberValue);\r\n      }\r\n    }\r\n    if (!this.numberValue.includes(null) && this.value && !this.value.includes(null)) {\r\n      let numberValue = this.getNumberValue();\r\n      if (this.numberValue[0] !== numberValue[0] || this.numberValue[1] !== numberValue[1]) {\r\n        this.numberValue = numberValue;\r\n        this.setDisplayValue(this.numberValue);\r\n      }\r\n    }\r\n  }\r\n\r\n  destroyPortal() {\r\n    this.portal?.overlayRef?.dispose();\r\n  }\r\n\r\n  showPortal($event: Event, type?: 'start' | 'end') {\r\n    type && $event.stopPropagation();\r\n    if (this.disabled || this.animating) return;\r\n    this.activeType = type || 'start';\r\n    this.activeTypeChange.next(this.activeType);\r\n    if (this.active) return;\r\n    this.active = true;\r\n    const config: OverlayConfig = {\r\n      backdropClass: '',\r\n      positionStrategy: this.setPlacement(),\r\n      scrollStrategy: this.overlay.scrollStrategies.reposition()\r\n    };\r\n    this.setPosition(config);\r\n    this.portal = this.portalService.attach({\r\n      content: XDateRangePortalComponent,\r\n      viewContainerRef: this.viewContainerRef,\r\n      overlayConfig: config\r\n    });\r\n    this.portal.overlayRef\r\n      ?.outsidePointerEvents()\r\n      .pipe(takeUntil(this._unSubject))\r\n      .subscribe((event: MouseEvent) => {\r\n        const clickTarget = event.target as HTMLElement;\r\n        if (clickTarget !== this.inputStartCom.inputRef.nativeElement && clickTarget !== this.inputEndCom.inputRef.nativeElement) {\r\n          this.closeSubject.next();\r\n        }\r\n      });\r\n    this.setInstance();\r\n  }\r\n\r\n  setPosition(config: OverlayConfig) {\r\n    let position = config.positionStrategy as FlexibleConnectedPositionStrategy;\r\n    position.positionChanges.pipe(takeUntil(this._unSubject)).subscribe((pos: ConnectedOverlayPositionChange) => {\r\n      const place = XPortalConnectedPosition.get(pos.connectionPair) as XCorner;\r\n      place !== this.placement && this.positionChange.next(place);\r\n    });\r\n  }\r\n\r\n  setInstance() {\r\n    let componentRef = this.portal?.componentRef;\r\n    if (!componentRef) return;\r\n    Object.assign(componentRef.instance, {\r\n      type: this.type,\r\n      value: this.numberValue,\r\n      placement: this.placement,\r\n      valueChange: this.valueChange,\r\n      positionChange: this.positionChange,\r\n      activeType: this.activeType,\r\n      extraFooter: this.extraFooter,\r\n      preset: this.preset,\r\n      activeTypeChange: this.activeTypeChange,\r\n      disabledDate: this.disabledDate,\r\n      disabledTime: this.disabledTime,\r\n      closePortal: () => this.closeSubject.next(),\r\n      destroyPortal: () => this.destroyPortal(),\r\n      nodeEmit: (dates: Date[], close = true) => this.onNodeClick(dates, close),\r\n      startNodeEmit: (node: Date, close = false, isDatePicker: boolean = true) => this.startNodeClick(node, close, isDatePicker),\r\n      endNodeEmit: (node: Date, close = false, isDatePicker: boolean = true) => this.endNodeClick(node, close, isDatePicker),\r\n      animating: (ing: boolean) => (this.animating = ing)\r\n    });\r\n    componentRef.changeDetectorRef.detectChanges();\r\n  }\r\n\r\n  startNodeClick(node?: Date, close = false, isDatePicker: boolean = true) {\r\n    this.startDisplay = !node\r\n      ? ''\r\n      : this.type === 'week'\r\n      ? XDateYearWeek(node)!\r\n      : this.type === 'quarter'\r\n      ? XDateYearQuarter(node)!\r\n      : this.datePipe.transform(node, this.format)!;\r\n    if (!close && isDatePicker) {\r\n      this.inputEndCom.inputFocus('after');\r\n      this.activeTypeChange.next('end');\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  endNodeClick(node?: Date, close = false, isDatePicker: boolean = true) {\r\n    this.endDisplay = !node\r\n      ? ''\r\n      : this.type === 'week'\r\n      ? XDateYearWeek(node)!\r\n      : this.type === 'quarter'\r\n      ? XDateYearQuarter(node)!\r\n      : this.datePipe.transform(node, this.format)!;\r\n    if (!close && isDatePicker) {\r\n      this.inputStartCom.inputFocus('after');\r\n      this.activeTypeChange.next('start');\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onNodeClick(dates: Date[], close = true) {\r\n    this.isInput = false;\r\n    this.numberValue = dates.map((x) => x.getTime());\r\n    this.value = this.getValue();\r\n    this.setDisplayValue(this.numberValue);\r\n    this.formControlValidator();\r\n    if (close) {\r\n      this.closeSubject.next();\r\n    }\r\n    this.modelChange();\r\n  }\r\n\r\n  onInput() {\r\n    this.isInput = true;\r\n  }\r\n\r\n  onFocus(type: 'start' | 'end') {\r\n    this.activeType = type;\r\n    this.activeChange.next(this.activeType);\r\n  }\r\n\r\n  setDisplayValue(dateNumber: (number | null)[]) {\r\n    if (!dateNumber) return;\r\n    if (!XIsNull(dateNumber[0])) {\r\n      if (this.type === 'week') {\r\n        this.startDisplay = XDateYearWeek(dateNumber[0]!)!;\r\n      } else if (this.type === 'quarter') {\r\n        this.startDisplay = XDateYearQuarter(dateNumber[0]!)!;\r\n      } else {\r\n        this.startDisplay = this.datePipe.transform(dateNumber[0], this.format) as string;\r\n      }\r\n    }\r\n    if (!XIsNull(dateNumber[1])) {\r\n      if (this.type === 'week') {\r\n        this.endDisplay = XDateYearWeek(dateNumber[1]!)!;\r\n      } else if (this.type === 'quarter') {\r\n        this.endDisplay = XDateYearQuarter(dateNumber[1]!)!;\r\n      } else {\r\n        this.endDisplay = this.datePipe.transform(dateNumber[1], this.format) as string;\r\n      }\r\n    }\r\n  }\r\n\r\n  setPlacement() {\r\n    return this.portalService.setPlacement({\r\n      elementRef: this.inputGroup.elementRef,\r\n      placement: [this.placement as XCorner, 'bottom-start', 'bottom-end', 'top-start', 'top-end'],\r\n      transformOriginOn: 'x-date-range-portal'\r\n    });\r\n  }\r\n\r\n  setPortal() {\r\n    this.portalAttached() && this.portal?.overlayRef?.updatePositionStrategy(this.setPlacement());\r\n  }\r\n\r\n  setClassMap() {\r\n    XClearClass(this.classMap, this.labelMap);\r\n    this.classMap[`${XDateRangePrefix}-${this.size}`] = this.size ? true : false;\r\n    this.labelMap[`x-text-align-${this.labelAlign}`] = this.labelAlign ? true : false;\r\n  }\r\n\r\n  formControlChanges() {\r\n    this.ngOnInit();\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<div\r\n  #dateRange\r\n  class=\"x-date-range\"\r\n  [ngClass]=\"classMap\"\r\n  [class.x-flex]=\"justify || align || direction\"\r\n  [class.x-checked]=\"value\"\r\n  [class.x-disabled]=\"disabled\"\r\n  [class.x-required]=\"requiredIsEmpty\"\r\n  [class.x-invalid]=\"invalid\"\r\n  [class.x-date-range-bordered]=\"bordered\"\r\n  [class.x-date-range-active]=\"active\"\r\n  [class.x-date-range-active-start]=\"activeType === 'start'\"\r\n  [class.x-date-range-active-end]=\"activeType === 'end'\"\r\n>\r\n  <label *ngIf=\"label\" [class.x-date-range-label-required]=\"required\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n  <div class=\"x-date-range-row\">\r\n    <x-input-group #inputGroup class=\"x-date-range-group\" (mouseenter)=\"menter()\" (mouseleave)=\"mleave()\" (click)=\"showPortal($event)\">\r\n      <x-input\r\n        #inputStartCom\r\n        class=\"x-data-range-input x-data-range-input-start\"\r\n        type=\"text\"\r\n        bordered=\"false\"\r\n        [size]=\"size\"\r\n        [disabled]=\"disabled\"\r\n        [placeholder]=\"getStartPlaceholder\"\r\n        (xFocus)=\"onFocus('start')\"\r\n        (xClick)=\"showPortal($event, 'start')\"\r\n        [(ngModel)]=\"startDisplay\"\r\n        icon=\"fto-arrow-right\"\r\n      ></x-input>\r\n      <x-input\r\n        #inputEndCom\r\n        class=\"x-data-range-input x-data-range-input-end\"\r\n        type=\"text\"\r\n        bordered=\"false\"\r\n        [size]=\"size\"\r\n        [disabled]=\"disabled\"\r\n        [placeholder]=\"getEndPlaceholder\"\r\n        (xFocus)=\"onFocus('end')\"\r\n        (xClick)=\"showPortal($event, 'end')\"\r\n        [(ngModel)]=\"endDisplay\"\r\n        [icon]=\"icon\"\r\n        (clearEmit)=\"clearEmit()\"\r\n        [clearable]=\"showClearable\"\r\n      ></x-input>\r\n      <div *ngIf=\"active\" class=\"x-date-range-active-bar\"></div>\r\n    </x-input-group>\r\n    <span class=\"x-date-range-error-message\" *ngIf=\"invalid\">{{ invalidMessage }}</span>\r\n    <ng-container *ngIf=\"requiredIsEmpty || invalid\">\r\n      <div class=\"x-border-error x-top-left\"></div>\r\n      <div class=\"x-border-error x-top-right\"></div>\r\n      <div class=\"x-border-error x-bottom-left\"></div>\r\n      <div class=\"x-border-error x-bottom-right\"></div>\r\n    </ng-container>\r\n  </div>\r\n</div>\r\n"]}
|
|
476
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-range.component.ts","../../../../../lib/ng-nest/ui/date-picker/date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { XPortalService, XPortalOverlayRef, XPortalConnectedPosition } from '@ng-nest/ui/portal';\r\nimport { Subject, fromEvent } from 'rxjs';\r\nimport {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Renderer2,\r\n  ElementRef,\r\n  OnChanges,\r\n  ViewContainerRef,\r\n  ViewChild,\r\n  SimpleChanges,\r\n  inject\r\n} from '@angular/core';\r\nimport { XDatePickerModelType, XDateRangePrefix, XDateRangeProperty } from './date-picker.property';\r\nimport {\r\n  XIsEmpty,\r\n  XIsDate,\r\n  XIsNumber,\r\n  XIsChange,\r\n  XCorner,\r\n  XClearClass,\r\n  XIsString,\r\n  XConfigService,\r\n  XIsNull,\r\n  XDateYearWeek,\r\n  XDateYearQuarter,\r\n  XParents\r\n} from '@ng-nest/ui/core';\r\nimport { XInputComponent, XInputGroupComponent } from '@ng-nest/ui/input';\r\nimport { DOCUMENT, DatePipe } from '@angular/common';\r\nimport { Overlay, OverlayConfig, FlexibleConnectedPositionStrategy, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\r\nimport { filter, map, takeUntil } from 'rxjs/operators';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\nimport { XDateRangePortalComponent } from './date-range-portal.component';\r\nimport { XI18nDatePicker, XI18nService } from '@ng-nest/ui/i18n';\r\n\r\n@Component({\r\n  selector: `${XDateRangePrefix}`,\r\n  templateUrl: './date-range.component.html',\r\n  styleUrls: ['./date-range.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XDateRangeComponent), DatePipe]\r\n})\r\nexport class XDateRangeComponent extends XDateRangeProperty implements OnInit, OnChanges {\r\n  @ViewChild('dateRange', { static: true }) dateRange!: ElementRef<HTMLElement>;\r\n  @ViewChild('inputGroup', { static: true }) inputGroup!: XInputGroupComponent;\r\n  @ViewChild('inputStartCom', { static: true }) inputStartCom!: XInputComponent;\r\n  @ViewChild('inputEndCom', { static: true }) inputEndCom!: XInputComponent;\r\n\r\n  modelType: XDatePickerModelType = 'date';\r\n  numberValue!: (number | null)[];\r\n  isInput = false;\r\n  showClearable: boolean = false;\r\n\r\n  get getStartPlaceholder() {\r\n    if (this.placeholder && this.placeholder.length > 0) return this.placeholder[0];\r\n    if (this.type === 'month') {\r\n      return this.locale.startMonth;\r\n    } else if (this.type === 'quarter') {\r\n      return this.locale.startQuarter;\r\n    } else if (this.type === 'year') {\r\n      return this.locale.startYear;\r\n    } else if (this.type === 'week') {\r\n      return this.locale.startWeek;\r\n    } else {\r\n      return this.locale.startDate;\r\n    }\r\n  }\r\n\r\n  get getEndPlaceholder() {\r\n    if (this.placeholder && this.placeholder.length > 1) return this.placeholder[1];\r\n    if (this.type === 'month') {\r\n      return this.locale.endMonth;\r\n    } else if (this.type === 'quarter') {\r\n      return this.locale.endQuarter;\r\n    } else if (this.type === 'year') {\r\n      return this.locale.endYear;\r\n    } else if (this.type === 'week') {\r\n      return this.locale.endWeek;\r\n    } else {\r\n      return this.locale.endDate;\r\n    }\r\n  }\r\n\r\n  override get requiredIsEmpty() {\r\n    return this.validator && this.required && XIsEmpty(this.value);\r\n  }\r\n\r\n  override writeValue(value: any) {\r\n    if (XIsEmpty(value)) {\r\n      value = [];\r\n      this.numberValue = [];\r\n    }\r\n    if (value.length > 0) {\r\n      if (XIsDate(value[0])) {\r\n        this.modelType = 'date';\r\n        this.numberValue = value.map((x: Date) => x.getTime());\r\n      } else if (XIsNumber(value[0])) {\r\n        this.modelType = 'number';\r\n        this.numberValue = value;\r\n      } else if (XIsString(value[0])) {\r\n        this.modelType = 'string';\r\n        const valueTime = value.map((x: string) => new Date(x).getTime());\r\n        this.numberValue = !isNaN(valueTime[0]) ? valueTime : [];\r\n      }\r\n    }\r\n    this.value = value;\r\n    this.setDisplayValue(this.numberValue);\r\n    this.valueChange.next(this.numberValue);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  enter: boolean = false;\r\n  inputClearable: boolean = false;\r\n  animating = false;\r\n  displayValue: string[] = [];\r\n  portal!: XPortalOverlayRef<XDateRangePortalComponent>;\r\n  icon: string = 'fto-calendar';\r\n  box!: DOMRect;\r\n  protalHeight!: number;\r\n  maxNodes: number = 6;\r\n  protalTobottom: boolean = true;\r\n  valueChange: Subject<any> = new Subject();\r\n  dataChange: Subject<any> = new Subject();\r\n  positionChange: Subject<any> = new Subject();\r\n  closeSubject: Subject<void> = new Subject();\r\n  activeTypeChange = new Subject<'start' | 'end'>();\r\n  startDisplay: string | number = '';\r\n  endDisplay: string | number = '';\r\n  activeType?: 'start' | 'end';\r\n  flexClass: string[] = [];\r\n  locale: XI18nDatePicker = {};\r\n  private _unSubject = new Subject<void>();\r\n  document = inject(DOCUMENT);\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public configService: XConfigService,\r\n    public override cdr: ChangeDetectorRef,\r\n    private portalService: XPortalService,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private datePipe: DatePipe,\r\n    private overlay: Overlay,\r\n    private i18n: XI18nService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setFlex(this.dateRange.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n    this.setHostTypeClass();\r\n    this.setFormat();\r\n    this.setClassMap();\r\n    this.setSubject();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.setPortal();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { type, justify, align, direction, size, labelAlign } = changes;\r\n    XIsChange(size, labelAlign) && this.setClassMap();\r\n    XIsChange(justify, align, direction) && this.setFlexClass();\r\n    if (XIsChange(type)) {\r\n      this.setFormat();\r\n      this.setDisplayValue(this.numberValue);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  setSubject() {\r\n    this.closeSubject.pipe(takeUntil(this._unSubject)).subscribe(() => {\r\n      this.closePortal();\r\n    });\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.datePicker as XI18nDatePicker),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  setFlexClass() {\r\n    if (this.flexClass.length > 0) {\r\n      for (let cls of this.flexClass) {\r\n        this.renderer.removeClass(this.dateRange.nativeElement, cls);\r\n      }\r\n    }\r\n    this.flexClass = this.setFlex(this.dateRange.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n  }\r\n\r\n  setHostTypeClass() {\r\n    this.renderer.addClass(this.elementRef.nativeElement, `x-date-range-${this.type}`);\r\n  }\r\n\r\n  setParantScroll() {\r\n    if (!this.document) return;\r\n    const parents = XParents(this.elementRef.nativeElement);\r\n    let firstScroll: HTMLElement | null = null;\r\n    for (let item of parents) {\r\n      if (item.clientHeight < item.scrollHeight) {\r\n        firstScroll = item;\r\n        break;\r\n      }\r\n    }\r\n    if (firstScroll && firstScroll.tagName !== 'BODY') {\r\n      fromEvent(firstScroll, 'scroll')\r\n        .pipe(\r\n          filter(() => this.portalAttached()!),\r\n          takeUntil(this._unSubject)\r\n        )\r\n        .subscribe(() => {\r\n          this.portal?.overlayRef?.updatePosition();\r\n          const eract = this.elementRef.nativeElement.getBoundingClientRect();\r\n          const frect = firstScroll!.getBoundingClientRect();\r\n          if (eract.top + eract.height - frect.top < 0 || eract.bottom > frect.bottom) {\r\n            this.closeSubject.next();\r\n          }\r\n        });\r\n    }\r\n  }\r\n\r\n  setFormat() {\r\n    if (this.format !== 'yyyy-MM-dd') return;\r\n    if (this.type === 'date') {\r\n      this.format = 'yyyy-MM-dd';\r\n    } else if (this.type === 'year') {\r\n      this.format = 'yyyy';\r\n    } else if (this.type === 'month') {\r\n      this.format = 'yyyy-MM';\r\n    } else if (this.type === 'date-time') {\r\n      this.format = 'yyyy-MM-dd HH:mm:ss';\r\n    } else if (this.type === 'date-hour') {\r\n      this.format = 'yyyy-MM-dd HH';\r\n    } else if (this.type === 'date-minute') {\r\n      this.format = 'yyyy-MM-dd HH:mm';\r\n    }\r\n  }\r\n\r\n  menter() {\r\n    if (this.disabled || !this.clearable) return;\r\n    this.enter = true;\r\n    if (!XIsEmpty(this.numberValue)) {\r\n      this.icon = '';\r\n      this.showClearable = true;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  mleave() {\r\n    if (this.disabled || !this.clearable) return;\r\n    this.enter = false;\r\n    if (this.clearable) {\r\n      this.icon = 'fto-calendar';\r\n      this.showClearable = false;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  clearEmit() {\r\n    this.value = [];\r\n    this.numberValue = [];\r\n    this.startDisplay = '';\r\n    this.endDisplay = '';\r\n    this.mleave();\r\n    this.valueChange.next(this.numberValue);\r\n    this.formControlValidator();\r\n    this.modelChange();\r\n    this.inputStartCom.inputFocus();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onIconClick(event: Event) {\r\n    if (this.icon === 'fto-x') {\r\n      this.clearEmit();\r\n    }\r\n    event.stopPropagation();\r\n  }\r\n\r\n  modelChange() {\r\n    if (this.onChange) {\r\n      this.onChange(this.getValue());\r\n    }\r\n  }\r\n\r\n  getValue() {\r\n    return this.modelType === 'date'\r\n      ? this.numberValue.map((x) => new Date(x!))\r\n      : this.modelType === 'string'\r\n      ? this.numberValue.map((x) => this.datePipe.transform(x, this.format))\r\n      : this.numberValue;\r\n  }\r\n\r\n  getNumberValue() {\r\n    return this.modelType === 'date'\r\n      ? this.value.map((x: Date) => x.getTime())\r\n      : this.modelType === 'string'\r\n      ? this.value.map((x: string) => new Date(x).getTime())\r\n      : this.value;\r\n  }\r\n\r\n  portalAttached() {\r\n    return this.portal?.overlayRef?.hasAttached();\r\n  }\r\n\r\n  closePortal() {\r\n    if (this.portalAttached()) {\r\n      this.portal?.overlayRef?.detach();\r\n      this.active = false;\r\n      this.closeReduction();\r\n      this.cdr.detectChanges();\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  closeReduction() {\r\n    if (!this.numberValue || this.numberValue.length === 0 || this.numberValue.includes(null)) {\r\n      if (!this.value || this.value.length === 0) {\r\n        this.startDisplay = '';\r\n        this.endDisplay = '';\r\n        this.numberValue = [];\r\n      } else {\r\n        this.numberValue = this.getNumberValue();\r\n        this.setDisplayValue(this.numberValue);\r\n      }\r\n    }\r\n    if (!this.numberValue.includes(null) && this.value && !this.value.includes(null)) {\r\n      let numberValue = this.getNumberValue();\r\n      if (this.numberValue[0] !== numberValue[0] || this.numberValue[1] !== numberValue[1]) {\r\n        this.numberValue = numberValue;\r\n        this.setDisplayValue(this.numberValue);\r\n      }\r\n    }\r\n  }\r\n\r\n  destroyPortal() {\r\n    this.portal?.overlayRef?.dispose();\r\n  }\r\n\r\n  showPortal($event: Event, type?: 'start' | 'end') {\r\n    type && $event.stopPropagation();\r\n    if (this.disabled || this.animating) return;\r\n    this.activeType = type || 'start';\r\n    this.activeTypeChange.next(this.activeType);\r\n    if (this.active) return;\r\n    this.active = true;\r\n    const config: OverlayConfig = {\r\n      backdropClass: '',\r\n      positionStrategy: this.setPlacement(),\r\n      scrollStrategy: this.overlay.scrollStrategies.reposition()\r\n    };\r\n    this.setPosition(config);\r\n    this.portal = this.portalService.attach({\r\n      content: XDateRangePortalComponent,\r\n      viewContainerRef: this.viewContainerRef,\r\n      overlayConfig: config\r\n    });\r\n    this.portal.overlayRef\r\n      ?.outsidePointerEvents()\r\n      .pipe(takeUntil(this._unSubject))\r\n      .subscribe((event: MouseEvent) => {\r\n        const clickTarget = event.target as HTMLElement;\r\n        if (clickTarget !== this.inputStartCom.inputRef.nativeElement && clickTarget !== this.inputEndCom.inputRef.nativeElement) {\r\n          this.closeSubject.next();\r\n        }\r\n      });\r\n    this.setInstance();\r\n  }\r\n\r\n  setPosition(config: OverlayConfig) {\r\n    let position = config.positionStrategy as FlexibleConnectedPositionStrategy;\r\n    position.positionChanges.pipe(takeUntil(this._unSubject)).subscribe((pos: ConnectedOverlayPositionChange) => {\r\n      const place = XPortalConnectedPosition.get(pos.connectionPair) as XCorner;\r\n      place !== this.placement && this.positionChange.next(place);\r\n    });\r\n  }\r\n\r\n  setInstance() {\r\n    let componentRef = this.portal?.componentRef;\r\n    if (!componentRef) return;\r\n    Object.assign(componentRef.instance, {\r\n      type: this.type,\r\n      value: this.numberValue,\r\n      placement: this.placement,\r\n      valueChange: this.valueChange,\r\n      positionChange: this.positionChange,\r\n      activeType: this.activeType,\r\n      extraFooter: this.extraFooter,\r\n      preset: this.preset,\r\n      activeTypeChange: this.activeTypeChange,\r\n      disabledDate: this.disabledDate,\r\n      disabledTime: this.disabledTime,\r\n      closePortal: () => this.closeSubject.next(),\r\n      destroyPortal: () => this.destroyPortal(),\r\n      nodeEmit: (dates: Date[], close = true) => this.onNodeClick(dates, close),\r\n      startNodeEmit: (node: Date, close = false, isDatePicker: boolean = true) => this.startNodeClick(node, close, isDatePicker),\r\n      endNodeEmit: (node: Date, close = false, isDatePicker: boolean = true) => this.endNodeClick(node, close, isDatePicker),\r\n      animating: (ing: boolean) => (this.animating = ing)\r\n    });\r\n    componentRef.changeDetectorRef.detectChanges();\r\n  }\r\n\r\n  startNodeClick(node?: Date, close = false, isDatePicker: boolean = true) {\r\n    this.startDisplay = !node\r\n      ? ''\r\n      : this.type === 'week'\r\n      ? XDateYearWeek(node)!\r\n      : this.type === 'quarter'\r\n      ? XDateYearQuarter(node)!\r\n      : this.datePipe.transform(node, this.format)!;\r\n    if (!close && isDatePicker) {\r\n      this.inputEndCom.inputFocus('after');\r\n      this.activeTypeChange.next('end');\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  endNodeClick(node?: Date, close = false, isDatePicker: boolean = true) {\r\n    this.endDisplay = !node\r\n      ? ''\r\n      : this.type === 'week'\r\n      ? XDateYearWeek(node)!\r\n      : this.type === 'quarter'\r\n      ? XDateYearQuarter(node)!\r\n      : this.datePipe.transform(node, this.format)!;\r\n    if (!close && isDatePicker) {\r\n      this.inputStartCom.inputFocus('after');\r\n      this.activeTypeChange.next('start');\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onNodeClick(dates: Date[], close = true) {\r\n    this.isInput = false;\r\n    this.numberValue = dates.map((x) => x.getTime());\r\n    this.value = this.getValue();\r\n    this.setDisplayValue(this.numberValue);\r\n    this.formControlValidator();\r\n    if (close) {\r\n      this.closeSubject.next();\r\n    }\r\n    this.modelChange();\r\n  }\r\n\r\n  onInput() {\r\n    this.isInput = true;\r\n  }\r\n\r\n  onFocus(type: 'start' | 'end') {\r\n    this.activeType = type;\r\n    this.activeChange.next(this.activeType);\r\n  }\r\n\r\n  setDisplayValue(dateNumber: (number | null)[]) {\r\n    if (!dateNumber) return;\r\n    if (!XIsNull(dateNumber[0])) {\r\n      if (this.type === 'week') {\r\n        this.startDisplay = XDateYearWeek(dateNumber[0]!)!;\r\n      } else if (this.type === 'quarter') {\r\n        this.startDisplay = XDateYearQuarter(dateNumber[0]!)!;\r\n      } else {\r\n        this.startDisplay = this.datePipe.transform(dateNumber[0], this.format) as string;\r\n      }\r\n    }\r\n    if (!XIsNull(dateNumber[1])) {\r\n      if (this.type === 'week') {\r\n        this.endDisplay = XDateYearWeek(dateNumber[1]!)!;\r\n      } else if (this.type === 'quarter') {\r\n        this.endDisplay = XDateYearQuarter(dateNumber[1]!)!;\r\n      } else {\r\n        this.endDisplay = this.datePipe.transform(dateNumber[1], this.format) as string;\r\n      }\r\n    }\r\n  }\r\n\r\n  setPlacement() {\r\n    return this.portalService.setPlacement({\r\n      elementRef: this.inputGroup.elementRef,\r\n      placement: [this.placement as XCorner, 'bottom-start', 'bottom-end', 'top-start', 'top-end'],\r\n      transformOriginOn: 'x-date-range-portal'\r\n    });\r\n  }\r\n\r\n  setPortal() {\r\n    this.portalAttached() && this.portal?.overlayRef?.updatePositionStrategy(this.setPlacement());\r\n  }\r\n\r\n  setClassMap() {\r\n    XClearClass(this.classMap, this.labelMap);\r\n    this.classMap[`${XDateRangePrefix}-${this.size}`] = this.size ? true : false;\r\n    this.labelMap[`x-text-align-${this.labelAlign}`] = this.labelAlign ? true : false;\r\n  }\r\n\r\n  formControlChanges() {\r\n    this.ngOnInit();\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<div\r\n  #dateRange\r\n  class=\"x-date-range\"\r\n  [ngClass]=\"classMap\"\r\n  [class.x-flex]=\"justify || align || direction\"\r\n  [class.x-checked]=\"value\"\r\n  [class.x-disabled]=\"disabled\"\r\n  [class.x-required]=\"requiredIsEmpty\"\r\n  [class.x-invalid]=\"invalid\"\r\n  [class.x-date-range-bordered]=\"bordered\"\r\n  [class.x-date-range-active]=\"active\"\r\n  [class.x-date-range-active-start]=\"activeType === 'start'\"\r\n  [class.x-date-range-active-end]=\"activeType === 'end'\"\r\n>\r\n  <label *ngIf=\"label\" [class.x-date-range-label-required]=\"required\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n  <div class=\"x-date-range-row\">\r\n    <x-input-group #inputGroup class=\"x-date-range-group\" (mouseenter)=\"menter()\" (mouseleave)=\"mleave()\" (click)=\"showPortal($event)\">\r\n      <x-input\r\n        #inputStartCom\r\n        class=\"x-data-range-input x-data-range-input-start\"\r\n        type=\"text\"\r\n        bordered=\"false\"\r\n        [size]=\"size\"\r\n        [disabled]=\"disabled\"\r\n        [placeholder]=\"getStartPlaceholder\"\r\n        (xFocus)=\"onFocus('start')\"\r\n        (xClick)=\"showPortal($event, 'start')\"\r\n        [(ngModel)]=\"startDisplay\"\r\n        icon=\"fto-arrow-right\"\r\n      ></x-input>\r\n      <x-input\r\n        #inputEndCom\r\n        class=\"x-data-range-input x-data-range-input-end\"\r\n        type=\"text\"\r\n        bordered=\"false\"\r\n        [size]=\"size\"\r\n        [disabled]=\"disabled\"\r\n        [placeholder]=\"getEndPlaceholder\"\r\n        (xFocus)=\"onFocus('end')\"\r\n        (xClick)=\"showPortal($event, 'end')\"\r\n        [(ngModel)]=\"endDisplay\"\r\n        [icon]=\"icon\"\r\n        (clearEmit)=\"clearEmit()\"\r\n        [clearable]=\"showClearable\"\r\n      ></x-input>\r\n      <div *ngIf=\"active\" class=\"x-date-range-active-bar\"></div>\r\n    </x-input-group>\r\n    <span class=\"x-date-range-error-message\" *ngIf=\"invalid\">{{ invalidMessage }}</span>\r\n    <ng-container *ngIf=\"requiredIsEmpty || invalid\">\r\n      <div class=\"x-border-error x-top-left\"></div>\r\n      <div class=\"x-border-error x-top-right\"></div>\r\n      <div class=\"x-border-error x-bottom-left\"></div>\r\n      <div class=\"x-border-error x-bottom-right\"></div>\r\n    </ng-container>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -46,7 +46,7 @@ class XControlComponent extends XControlProperty {
|
|
|
46
46
|
this.option.label = '';
|
|
47
47
|
this.option.label = `${this.option.label}${this.form.labelSuffix}`;
|
|
48
48
|
this._control = this.createControl(this.option);
|
|
49
|
-
this._formControl = new UntypedFormControl(this._control.value);
|
|
49
|
+
this._formControl = new UntypedFormControl(this._control.value, { nonNullable: this._control.nonNullable });
|
|
50
50
|
this.setValidators();
|
|
51
51
|
this._formControl.statusChanges.pipe(takeUntil(this._unSubject)).subscribe((x) => {
|
|
52
52
|
this.setMessages(x);
|
|
@@ -195,4 +195,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
|
|
|
195
195
|
type: ViewChild,
|
|
196
196
|
args: [FormControlName]
|
|
197
197
|
}] } });
|
|
198
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/form/control.component.ts","../../../../../lib/ng-nest/ui/form/control.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,iBAAiB,EACjB,uBAAuB,EACvB,KAAK,EACL,SAAS,EAKV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAIhB,eAAe,EAEf,aAAa,EAEb,cAAc,EAEd,gBAAgB,EAEhB,aAAa,EAGb,kBAAkB,EAClB,mBAAmB,EAEnB,cAAc,EAEd,YAAY,EAEZ,oBAAoB,EAEpB,kBAAkB,EAElB,mBAAmB,EAGnB,YAAY,EAGZ,gBAAgB,EAChB,oBAAoB,EAErB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,kBAAkB,EAAwD,MAAM,gBAAgB,CAAC;AACvI,OAAO,EAAE,QAAQ,EAAkB,WAAW,EAAE,MAAM,kBAAkB,CAAC;AACzE,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;;;;;;;;;;;;;;;;;;;;;AAE5D,MAOa,iBAAkB,SAAQ,gBAAgB;IAYrD;IACE,mDAAmD;IAC5C,GAAsB,EACtB,aAA6B,EAC7B,IAAkB;QAEzB,KAAK,EAAE,CAAC;QAJD,QAAG,GAAH,GAAG,CAAmB;QACtB,kBAAa,GAAb,aAAa,CAAgB;QAC7B,SAAI,GAAJ,IAAI,CAAc;QAZ3B,WAAM,GAAc,EAAE,CAAC;QACf,iBAAY,GAAG,CAAC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC;QACrF,iBAAY,GAAG,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;QAE/C,kBAAa,GAAkB,EAAE,CAAC;QAClC,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;IAUzC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,MAAM,GAAG,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QACjC,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;YAAE,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC;QACxD,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;QACnE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAChD,IAAI,CAAC,YAAY,GAAG,IAAI,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAChE,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC/E,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,CAAC,aAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;QACzD,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QACpE,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,GAAG,EAAE;YACxB,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAS,EAAE,EAAE;gBACtC,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE;oBAC/C,IAAI,CAAC,OAAO,CAAC,aAAqB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;iBACzD;YACH,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,kBAAkB,EAAE,CAAC;QACrE,CAAC,CAAC;QACF,IAAI,CAAC,IAAI,CAAC,YAAY;aACnB,IAAI,CACH,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAiB,CAAC,EAC/B,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B;aACA,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACf,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YAChB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,eAAe;QACb,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAc,EAAE,IAAI,CAAC,QAAgC,CAAC,CAAC;QAClF,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;QACzD,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,aAAsC,CAAC;QACpG,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,kBAAkB,EAAE,CAAC;IACrE,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;IAChC,CAAC;IAED,aAAa;QACX,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAChD,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;SAC7B;aAAM;YACL,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;SAC5B;QACD,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACjD,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;SACnE;QACD,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE;YACzB,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;QACD,IAAI,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE;YAC7C,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,aAAa,EAAE,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAe,CAAC,CAAC,CAAC;SAClG;QACD,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACpD,IAAI,CAAC,YAAY,CAAC,sBAAsB,EAAE,CAAC;IAC7C,CAAC;IAED,QAAQ;QACN,KAAK,IAAI,IAAI,IAAI,IAAI,CAAC,YAAY,EAAE;YAClC,IAAI,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;gBAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAI,IAAI,CAAC,IAAY,CAAC,IAAI,CAAC,CAAC;SAC/E;IACH,CAAC;IAED,UAAU;QACR,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;YACxC,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE;gBACtC,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;aACtE;SACF;aAAM;YACL,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAiB,CAAC,CAAC,CAAC;SACnG;IACH,CAAC;IAED,aAAa,CAAC,OAAe;QAC3B,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;YACxC,OAAQ,IAAI,CAAC,QAAQ,CAAC,OAAsB,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC;SAC7G;aAAM;YACL,OAAO,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC;SAC9B;IACH,CAAC;IAED,WAAW,CAAC,KAAwB;QAClC,IAAI,OAAO,GAAiB,IAAI,CAAC,YAAY,CAAC;QAC9C,IAAI,KAAK,KAAK,SAAS,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,KAAK,IAAI,EAAE;YAC5D,IAAI,QAAQ,GAAa,EAAE,CAAC;YAC5B,KAAK,MAAM,GAAG,IAAI,OAAO,CAAC,MAAM,EAAE;gBAChC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACtD,IAAI,GAAG,KAAK,UAAU,EAAE;oBACtB,QAAQ,GAAG,CAAC,GAAG,QAAQ,EAAE,GAAG,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,QAAQ,IAAI,UAAU,EAAE,CAAC,CAAC;iBAC7E;qBAAM,IAAI,GAAG,KAAK,SAAS,EAAE;oBAC5B,QAAQ,GAAG,CAAC,GAAG,QAAQ,EAAE,GAAG,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;iBACjG;qBAAM,IAAI,GAAG,KAAK,gBAAgB,EAAE;oBACnC,QAAQ,GAAG,CAAC,GAAG,QAAQ,EAAE,GAAG,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC;iBAC/D;aACF;YACD,OAAO,CAAC,QAAQ,GAAG,QAAQ,CAAC;SAC7B;aAAM,IAAI,KAAK,KAAK,OAAO,EAAE;YAC5B,OAAO,CAAC,QAAQ,GAAG,EAAE,CAAC;SACvB;IACH,CAAC;IAED,aAAa,CAAC,MAA0B;QACtC,QAAQ,MAAM,CAAC,OAAO,EAAE;YACtB,KAAK,OAAO;gBACV,OAAO,IAAI,aAAa,CAAC,MAA6B,CAAC,CAAC;YAC1D,KAAK,QAAQ;gBACX,OAAO,IAAI,cAAc,CAAC,MAA8B,CAAC,CAAC;YAC5D,KAAK,UAAU;gBACb,OAAO,IAAI,gBAAgB,CAAC,MAAgC,CAAC,CAAC;YAChE,KAAK,OAAO;gBACV,OAAO,IAAI,aAAa,CAAC,MAA6B,CAAC,CAAC;YAC1D,KAAK,QAAQ;gBACX,OAAO,IAAI,cAAc,CAAC,MAA8B,CAAC,CAAC;YAC5D,KAAK,MAAM;gBACT,OAAO,IAAI,YAAY,CAAC,MAA4B,CAAC,CAAC;YACxD,KAAK,aAAa;gBAChB,OAAO,IAAI,kBAAkB,CAAC,MAAkC,CAAC,CAAC;YACpE,KAAK,aAAa;gBAChB,OAAO,IAAI,kBAAkB,CAAC,MAAkC,CAAC,CAAC;YACpE,KAAK,cAAc;gBACjB,OAAO,IAAI,mBAAmB,CAAC,MAAmC,CAAC,CAAC;YACtE,KAAK,eAAe;gBAClB,OAAO,IAAI,oBAAoB,CAAC,MAAoC,CAAC,CAAC;YACxE,KAAK,SAAS;gBACZ,OAAO,IAAI,eAAe,CAAC,MAA+B,CAAC,CAAC;YAC9D,KAAK,cAAc;gBACjB,OAAO,IAAI,mBAAmB,CAAC,MAAmC,CAAC,CAAC;YACtE,KAAK,UAAU;gBACb,OAAO,IAAI,gBAAgB,CAAC,MAAgC,CAAC,CAAC;YAChE,KAAK,MAAM;gBACT,OAAO,IAAI,YAAY,CAAC,MAA4B,CAAC,CAAC;YACxD,KAAK,eAAe;gBAClB,OAAO,IAAI,oBAAoB,CAAC,MAAoC,CAAC,CAAC;YACxE;gBACE,OAAO,IAAI,aAAa,CAAC,MAA6B,CAAC,CAAC;SAC3D;IACH,CAAC;iIApKU,iBAAiB;qHAAjB,iBAAiB,sIAGjB,eAAe,uECjE5B,mhFAiDA;;SDaa,iBAAiB;2FAAjB,iBAAiB;kBAP7B,SAAS;+BACE,WAAW,iBAGN,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;gKAG7B,MAAM;sBAAvB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACsB,OAAO;sBAAlC,SAAS;uBAAC,eAAe","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  Input,\r\n  ViewChild,\r\n  ChangeDetectorRef,\r\n  OnInit,\r\n  AfterViewInit,\r\n  OnDestroy\r\n} from '@angular/core';\r\nimport {\r\n  XControlProperty,\r\n  XFormControlOption,\r\n  XFormControlComponent,\r\n  XFormControlType,\r\n  XCascadeControl,\r\n  XCascadeControlOption,\r\n  XInputControl,\r\n  XInputControlOption,\r\n  XSelectControl,\r\n  XSelectControlOption,\r\n  XCheckboxControl,\r\n  XCheckboxControlOption,\r\n  XRadioControl,\r\n  XRadioControlOption,\r\n  XDatePickerControlOption,\r\n  XDatePickerControl,\r\n  XInputNumberControl,\r\n  XInputNumberControlOption,\r\n  XSwitchControl,\r\n  XSwitchControlOption,\r\n  XRateControl,\r\n  XRateControlOption,\r\n  XSliderSelectControl,\r\n  XSliderSelectControlOption,\r\n  XTimePickerControl,\r\n  XTimePickerControlOption,\r\n  XColorPickerControl,\r\n  XColorPickerControlOption,\r\n  XFormControl,\r\n  XFindControl,\r\n  XFindControlOption,\r\n  XTextareaControlOption,\r\n  XTextareaControl,\r\n  XAutoCompleteControl,\r\n  XAutoCompleteControlOption\r\n} from './form.property';\r\nimport { FormControlName, Validators, UntypedFormControl, ValidatorFn, ControlValueAccessor, FormControlStatus } from '@angular/forms';\r\nimport { XIsEmpty, XConfigService, XIsFunction } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\nimport { XI18nForm, XI18nService } from '@ng-nest/ui/i18n';\r\nimport { XFormInputValidator } from '@ng-nest/ui/base-form';\r\n\r\n@Component({\r\n  selector: 'x-control',\r\n  templateUrl: './control.component.html',\r\n  styleUrls: ['./control.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XControlComponent extends XControlProperty implements OnInit, AfterViewInit, OnDestroy {\r\n  @Input() override option!: XFormControlOption;\r\n  @Input() form: any;\r\n  @ViewChild(FormControlName) control!: FormControlName;\r\n  locale: XI18nForm = {};\r\n  private _sharedProps = ['span', 'direction', 'justify', 'align', 'labelWidth', 'labelAlign'];\r\n  private _changeProps = ['label', ...this._sharedProps];\r\n  private _control!: XFormControlType;\r\n  private _validatorFns: ValidatorFn[] = [];\r\n  private _unSubject = new Subject<void>();\r\n  private _formControl!: UntypedFormControl;\r\n\r\n  constructor(\r\n    // @Host() @Optional() public form: XFormComponent,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService,\r\n    public i18n: XI18nService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.option = { ...this.option };\r\n    this.setProps();\r\n    if (XIsEmpty(this.option.label)) this.option.label = '';\r\n    this.option.label = `${this.option.label}${this.form.labelSuffix}`;\r\n    this._control = this.createControl(this.option);\r\n    this._formControl = new UntypedFormControl(this._control.value);\r\n    this.setValidators();\r\n    this._formControl.statusChanges.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.setMessages(x);\r\n    });\r\n    this._control.setValidators = () => this.setValidators();\r\n    this.form.formGroup.addControl(this._control.id, this._formControl);\r\n    this.option.change = () => {\r\n      this._changeProps.forEach((x: string) => {\r\n        if (this.control.valueAccessor && this.option[x]) {\r\n          (this.control.valueAccessor as any)[x] = this.option[x];\r\n        }\r\n      });\r\n      this.form.controlComponents[this._control.id].formControlChanges();\r\n    };\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.form as XI18nForm),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    Object.assign(this.control.valueAccessor!, this._control as ControlValueAccessor);\r\n    this.form.controlTypes[this._control.id] = this._control;\r\n    this.form.controlComponents[this._control.id] = this.control.valueAccessor as XFormControlComponent;\r\n    this.form.controlComponents[this._control.id].formControlChanges();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  setValidators() {\r\n    this._validatorFns = [];\r\n    if (this._control.disabled || this.form.disabled) {\r\n      this._formControl.disable();\r\n    } else {\r\n      this._formControl.enable();\r\n    }\r\n    if (this._control.required && !this.form.disabled) {\r\n      this._validatorFns = [...this._validatorFns, Validators.required];\r\n    }\r\n    if (this._control.pattern) {\r\n      this.setPattern();\r\n    }\r\n    if (XIsFunction(this._control.inputValidator)) {\r\n      this._validatorFns = [...this._validatorFns, XFormInputValidator(this._control.inputValidator!)];\r\n    }\r\n    this._formControl.setValidators(this._validatorFns);\r\n    this._formControl.updateValueAndValidity();\r\n  }\r\n\r\n  setProps() {\r\n    for (let prop of this._sharedProps) {\r\n      if (XIsEmpty(this.option[prop])) this.option[prop] = (this.form as any)[prop];\r\n    }\r\n  }\r\n\r\n  setPattern() {\r\n    if (Array.isArray(this._control.pattern)) {\r\n      for (const pt of this._control.pattern) {\r\n        this._validatorFns = [...this._validatorFns, Validators.pattern(pt)];\r\n      }\r\n    } else {\r\n      this._validatorFns = [...this._validatorFns, Validators.pattern(this._control.pattern as RegExp)];\r\n    }\r\n  }\r\n\r\n  getPatternMsg(pattern: string) {\r\n    if (Array.isArray(this._control.pattern)) {\r\n      return (this._control.message as Array<any>)[this._control.pattern.findIndex((x) => String(x) === pattern)];\r\n    } else {\r\n      return this._control.message;\r\n    }\r\n  }\r\n\r\n  setMessages(state: FormControlStatus) {\r\n    let control: XFormControl = this._formControl;\r\n    if (state === 'INVALID' && this._formControl.errors !== null) {\r\n      let messages: string[] = [];\r\n      for (const key in control.errors) {\r\n        const label = this._control.label || this._control.id;\r\n        if (key === 'required') {\r\n          messages = [...messages, `${label} ${this.locale?.required || 'required'}`];\r\n        } else if (key === 'pattern') {\r\n          messages = [...messages, `${label} ${this.getPatternMsg(control.errors[key].requiredPattern)}`];\r\n        } else if (key === 'inputValidator') {\r\n          messages = [...messages, `${label} ${this._control.message}`];\r\n        }\r\n      }\r\n      control.messages = messages;\r\n    } else if (state === 'VALID') {\r\n      control.messages = [];\r\n    }\r\n  }\r\n\r\n  createControl(option: XFormControlOption) {\r\n    switch (option.control) {\r\n      case 'input':\r\n        return new XInputControl(option as XInputControlOption);\r\n      case 'select':\r\n        return new XSelectControl(option as XSelectControlOption);\r\n      case 'checkbox':\r\n        return new XCheckboxControl(option as XCheckboxControlOption);\r\n      case 'radio':\r\n        return new XRadioControl(option as XRadioControlOption);\r\n      case 'switch':\r\n        return new XSwitchControl(option as XSwitchControlOption);\r\n      case 'rate':\r\n        return new XRateControl(option as XRateControlOption);\r\n      case 'date-picker':\r\n        return new XDatePickerControl(option as XDatePickerControlOption);\r\n      case 'time-picker':\r\n        return new XTimePickerControl(option as XTimePickerControlOption);\r\n      case 'input-number':\r\n        return new XInputNumberControl(option as XInputNumberControlOption);\r\n      case 'slider-select':\r\n        return new XSliderSelectControl(option as XSliderSelectControlOption);\r\n      case 'cascade':\r\n        return new XCascadeControl(option as XCascadeControlOption);\r\n      case 'color-picker':\r\n        return new XColorPickerControl(option as XColorPickerControlOption);\r\n      case 'textarea':\r\n        return new XTextareaControl(option as XTextareaControlOption);\r\n      case 'find':\r\n        return new XFindControl(option as XFindControlOption);\r\n      case 'auto-complete':\r\n        return new XAutoCompleteControl(option as XAutoCompleteControlOption);\r\n      default:\r\n        return new XInputControl(option as XInputControlOption);\r\n    }\r\n  }\r\n}\r\n","<div class=\"x-control\" [formGroup]=\"form.formGroup\">\r\n  <ng-container [ngSwitch]=\"option.control\">\r\n    <ng-container *ngSwitchCase=\"'input'\">\r\n      <x-input [formControlName]=\"option.id\" (clearEmit)=\"option.clearClick && option.clearClick($event)\"></x-input>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'select'\">\r\n      <x-select [formControlName]=\"option.id\"></x-select>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'cascade'\">\r\n      <x-cascade [formControlName]=\"option.id\" (nodeEmit)=\"option.nodeClick && option.nodeClick($event)\"></x-cascade>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'checkbox'\">\r\n      <x-checkbox [formControlName]=\"option.id\"></x-checkbox>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'color-picker'\">\r\n      <x-color-picker [formControlName]=\"option.id\"></x-color-picker>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'date-picker'\">\r\n      <x-date-picker [formControlName]=\"option.id\" (nodeEmit)=\"option.nodeClick && option.nodeClick($event)\"></x-date-picker>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'input-number'\">\r\n      <x-input-number [formControlName]=\"option.id\"></x-input-number>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'radio'\">\r\n      <x-radio [formControlName]=\"option.id\"></x-radio>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'rate'\">\r\n      <x-rate [formControlName]=\"option.id\"></x-rate>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'slider-select'\">\r\n      <x-slider-select [formControlName]=\"option.id\"></x-slider-select>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'switch'\">\r\n      <x-switch [formControlName]=\"option.id\"></x-switch>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'time-picker'\">\r\n      <x-time-picker [formControlName]=\"option.id\"></x-time-picker>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'textarea'\">\r\n      <x-textarea [formControlName]=\"option.id\" (clearEmit)=\"option.clearClick && option.clearClick($event)\"></x-textarea>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'auto-complete'\">\r\n      <x-auto-complete [formControlName]=\"option.id\" (nodeEmit)=\"option.nodeClick && option.nodeClick($event)\"></x-auto-complete>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'find'\">\r\n      <x-find [formControlName]=\"option.id\"></x-find>\r\n    </ng-container>\r\n  </ng-container>\r\n</div>\r\n"]}
|
|
198
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/form/control.component.ts","../../../../../lib/ng-nest/ui/form/control.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  Input,\r\n  ViewChild,\r\n  ChangeDetectorRef,\r\n  OnInit,\r\n  AfterViewInit,\r\n  OnDestroy\r\n} from '@angular/core';\r\nimport {\r\n  XControlProperty,\r\n  XFormControlOption,\r\n  XFormControlComponent,\r\n  XFormControlType,\r\n  XCascadeControl,\r\n  XCascadeControlOption,\r\n  XInputControl,\r\n  XInputControlOption,\r\n  XSelectControl,\r\n  XSelectControlOption,\r\n  XCheckboxControl,\r\n  XCheckboxControlOption,\r\n  XRadioControl,\r\n  XRadioControlOption,\r\n  XDatePickerControlOption,\r\n  XDatePickerControl,\r\n  XInputNumberControl,\r\n  XInputNumberControlOption,\r\n  XSwitchControl,\r\n  XSwitchControlOption,\r\n  XRateControl,\r\n  XRateControlOption,\r\n  XSliderSelectControl,\r\n  XSliderSelectControlOption,\r\n  XTimePickerControl,\r\n  XTimePickerControlOption,\r\n  XColorPickerControl,\r\n  XColorPickerControlOption,\r\n  XFormControl,\r\n  XFindControl,\r\n  XFindControlOption,\r\n  XTextareaControlOption,\r\n  XTextareaControl,\r\n  XAutoCompleteControl,\r\n  XAutoCompleteControlOption\r\n} from './form.property';\r\nimport { FormControlName, Validators, UntypedFormControl, ValidatorFn, ControlValueAccessor, FormControlStatus } from '@angular/forms';\r\nimport { XIsEmpty, XConfigService, XIsFunction } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\nimport { XI18nForm, XI18nService } from '@ng-nest/ui/i18n';\r\nimport { XFormInputValidator } from '@ng-nest/ui/base-form';\r\n\r\n@Component({\r\n  selector: 'x-control',\r\n  templateUrl: './control.component.html',\r\n  styleUrls: ['./control.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XControlComponent extends XControlProperty implements OnInit, AfterViewInit, OnDestroy {\r\n  @Input() override option!: XFormControlOption;\r\n  @Input() form: any;\r\n  @ViewChild(FormControlName) control!: FormControlName;\r\n  locale: XI18nForm = {};\r\n  private _sharedProps = ['span', 'direction', 'justify', 'align', 'labelWidth', 'labelAlign'];\r\n  private _changeProps = ['label', ...this._sharedProps];\r\n  private _control!: XFormControlType;\r\n  private _validatorFns: ValidatorFn[] = [];\r\n  private _unSubject = new Subject<void>();\r\n  private _formControl!: UntypedFormControl;\r\n\r\n  constructor(\r\n    // @Host() @Optional() public form: XFormComponent,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService,\r\n    public i18n: XI18nService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.option = { ...this.option };\r\n    this.setProps();\r\n    if (XIsEmpty(this.option.label)) this.option.label = '';\r\n    this.option.label = `${this.option.label}${this.form.labelSuffix}`;\r\n    this._control = this.createControl(this.option);\r\n    this._formControl = new UntypedFormControl(this._control.value, { nonNullable: this._control.nonNullable });\r\n    this.setValidators();\r\n    this._formControl.statusChanges.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.setMessages(x);\r\n    });\r\n    this._control.setValidators = () => this.setValidators();\r\n    this.form.formGroup.addControl(this._control.id, this._formControl);\r\n    this.option.change = () => {\r\n      this._changeProps.forEach((x: string) => {\r\n        if (this.control.valueAccessor && this.option[x]) {\r\n          (this.control.valueAccessor as any)[x] = this.option[x];\r\n        }\r\n      });\r\n      this.form.controlComponents[this._control.id].formControlChanges();\r\n    };\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.form as XI18nForm),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    Object.assign(this.control.valueAccessor!, this._control as ControlValueAccessor);\r\n    this.form.controlTypes[this._control.id] = this._control;\r\n    this.form.controlComponents[this._control.id] = this.control.valueAccessor as XFormControlComponent;\r\n    this.form.controlComponents[this._control.id].formControlChanges();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  setValidators() {\r\n    this._validatorFns = [];\r\n    if (this._control.disabled || this.form.disabled) {\r\n      this._formControl.disable();\r\n    } else {\r\n      this._formControl.enable();\r\n    }\r\n    if (this._control.required && !this.form.disabled) {\r\n      this._validatorFns = [...this._validatorFns, Validators.required];\r\n    }\r\n    if (this._control.pattern) {\r\n      this.setPattern();\r\n    }\r\n    if (XIsFunction(this._control.inputValidator)) {\r\n      this._validatorFns = [...this._validatorFns, XFormInputValidator(this._control.inputValidator!)];\r\n    }\r\n    this._formControl.setValidators(this._validatorFns);\r\n    this._formControl.updateValueAndValidity();\r\n  }\r\n\r\n  setProps() {\r\n    for (let prop of this._sharedProps) {\r\n      if (XIsEmpty(this.option[prop])) this.option[prop] = (this.form as any)[prop];\r\n    }\r\n  }\r\n\r\n  setPattern() {\r\n    if (Array.isArray(this._control.pattern)) {\r\n      for (const pt of this._control.pattern) {\r\n        this._validatorFns = [...this._validatorFns, Validators.pattern(pt)];\r\n      }\r\n    } else {\r\n      this._validatorFns = [...this._validatorFns, Validators.pattern(this._control.pattern as RegExp)];\r\n    }\r\n  }\r\n\r\n  getPatternMsg(pattern: string) {\r\n    if (Array.isArray(this._control.pattern)) {\r\n      return (this._control.message as Array<any>)[this._control.pattern.findIndex((x) => String(x) === pattern)];\r\n    } else {\r\n      return this._control.message;\r\n    }\r\n  }\r\n\r\n  setMessages(state: FormControlStatus) {\r\n    let control: XFormControl = this._formControl;\r\n    if (state === 'INVALID' && this._formControl.errors !== null) {\r\n      let messages: string[] = [];\r\n      for (const key in control.errors) {\r\n        const label = this._control.label || this._control.id;\r\n        if (key === 'required') {\r\n          messages = [...messages, `${label} ${this.locale?.required || 'required'}`];\r\n        } else if (key === 'pattern') {\r\n          messages = [...messages, `${label} ${this.getPatternMsg(control.errors[key].requiredPattern)}`];\r\n        } else if (key === 'inputValidator') {\r\n          messages = [...messages, `${label} ${this._control.message}`];\r\n        }\r\n      }\r\n      control.messages = messages;\r\n    } else if (state === 'VALID') {\r\n      control.messages = [];\r\n    }\r\n  }\r\n\r\n  createControl(option: XFormControlOption) {\r\n    switch (option.control) {\r\n      case 'input':\r\n        return new XInputControl(option as XInputControlOption);\r\n      case 'select':\r\n        return new XSelectControl(option as XSelectControlOption);\r\n      case 'checkbox':\r\n        return new XCheckboxControl(option as XCheckboxControlOption);\r\n      case 'radio':\r\n        return new XRadioControl(option as XRadioControlOption);\r\n      case 'switch':\r\n        return new XSwitchControl(option as XSwitchControlOption);\r\n      case 'rate':\r\n        return new XRateControl(option as XRateControlOption);\r\n      case 'date-picker':\r\n        return new XDatePickerControl(option as XDatePickerControlOption);\r\n      case 'time-picker':\r\n        return new XTimePickerControl(option as XTimePickerControlOption);\r\n      case 'input-number':\r\n        return new XInputNumberControl(option as XInputNumberControlOption);\r\n      case 'slider-select':\r\n        return new XSliderSelectControl(option as XSliderSelectControlOption);\r\n      case 'cascade':\r\n        return new XCascadeControl(option as XCascadeControlOption);\r\n      case 'color-picker':\r\n        return new XColorPickerControl(option as XColorPickerControlOption);\r\n      case 'textarea':\r\n        return new XTextareaControl(option as XTextareaControlOption);\r\n      case 'find':\r\n        return new XFindControl(option as XFindControlOption);\r\n      case 'auto-complete':\r\n        return new XAutoCompleteControl(option as XAutoCompleteControlOption);\r\n      default:\r\n        return new XInputControl(option as XInputControlOption);\r\n    }\r\n  }\r\n}\r\n","<div class=\"x-control\" [formGroup]=\"form.formGroup\">\r\n  <ng-container [ngSwitch]=\"option.control\">\r\n    <ng-container *ngSwitchCase=\"'input'\">\r\n      <x-input [formControlName]=\"option.id\" (clearEmit)=\"option.clearClick && option.clearClick($event)\"></x-input>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'select'\">\r\n      <x-select [formControlName]=\"option.id\"></x-select>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'cascade'\">\r\n      <x-cascade [formControlName]=\"option.id\" (nodeEmit)=\"option.nodeClick && option.nodeClick($event)\"></x-cascade>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'checkbox'\">\r\n      <x-checkbox [formControlName]=\"option.id\"></x-checkbox>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'color-picker'\">\r\n      <x-color-picker [formControlName]=\"option.id\"></x-color-picker>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'date-picker'\">\r\n      <x-date-picker [formControlName]=\"option.id\" (nodeEmit)=\"option.nodeClick && option.nodeClick($event)\"></x-date-picker>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'input-number'\">\r\n      <x-input-number [formControlName]=\"option.id\"></x-input-number>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'radio'\">\r\n      <x-radio [formControlName]=\"option.id\"></x-radio>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'rate'\">\r\n      <x-rate [formControlName]=\"option.id\"></x-rate>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'slider-select'\">\r\n      <x-slider-select [formControlName]=\"option.id\"></x-slider-select>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'switch'\">\r\n      <x-switch [formControlName]=\"option.id\"></x-switch>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'time-picker'\">\r\n      <x-time-picker [formControlName]=\"option.id\"></x-time-picker>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'textarea'\">\r\n      <x-textarea [formControlName]=\"option.id\" (clearEmit)=\"option.clearClick && option.clearClick($event)\"></x-textarea>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'auto-complete'\">\r\n      <x-auto-complete [formControlName]=\"option.id\" (nodeEmit)=\"option.nodeClick && option.nodeClick($event)\"></x-auto-complete>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'find'\">\r\n      <x-find [formControlName]=\"option.id\"></x-find>\r\n    </ng-container>\r\n  </ng-container>\r\n</div>\r\n"]}
|
|
@@ -199,4 +199,4 @@ export class XAutoCompleteControl extends XControl {
|
|
|
199
199
|
super(option);
|
|
200
200
|
}
|
|
201
201
|
}
|
|
202
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.property.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/form/form.property.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAA+B,QAAQ,EAAW,YAAY,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AACxH,OAAO,EAAE,KAAK,EAAE,SAAS,EAAe,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AACpF,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAetE,OAAO,EAAe,SAAS,EAAE,MAAM,uBAAuB,CAAC;;AAG/D;;;;GAIG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,QAAQ,CAAC;AACpC,MAAM,aAAa,GAAG,MAAM,CAAC;AAO7B;;GAEG;AACH,MACa,aAAc,SAAQ,SAAS;IAD5C;;QAEE;;;WAGG;QACM,cAAS,GAAqB,IAAI,gBAAgB,CAAC,EAAE,CAAC,CAAC;QAqBhE;;;WAGG;QACM,aAAQ,GAAsC,EAAE,CAAC;QAC1D;;;WAGG;QACkD,UAAK,GAAW,MAAM,CAAC;QAC5E;;;WAGG;QACM,eAAU,GAAkB,EAAE,CAAC;QACxC;;;WAGG;QACO,YAAO,GAAG,IAAI,YAAY,EAAe,CAAC;KACrD;iIA9CY,aAAa;qHAAb,aAAa,6RADkC,EAAE;;AAgBK;IAAvD,WAAW,CAAU,aAAa,EAAE,CAAC,CAAC;IAAE,YAAY,EAAE;4CAAiB;AAKxD;IAAf,YAAY,EAAE;2CAAgB;AAKU;IAAxC,WAAW,CAAU,aAAa,EAAE,EAAE,CAAC;kDAAsB;AAUlB;IAA3C,WAAW,CAAS,aAAa,EAAE,MAAM,CAAC;4CAAwB;SAnCjE,aAAa;2FAAb,aAAa;kBADzB,SAAS;mBAAC,EAAE,QAAQ,EAAE,GAAG,WAAW,WAAW,EAAE,QAAQ,EAAE,EAAE,EAAE;8BAMrD,SAAS;sBAAjB,KAAK;gBAKG,KAAK;sBAAb,KAAK;gBAK2D,KAAK;sBAArE,KAAK;gBAKmB,IAAI;sBAA5B,KAAK;gBAK4C,WAAW;sBAA5D,KAAK;gBAKG,QAAQ;sBAAhB,KAAK;gBAK+C,KAAK;sBAAzD,KAAK;gBAKG,UAAU;sBAAlB,KAAK;gBAKI,OAAO;sBAAhB,MAAM;;AAsET;;;GAGG;AACH,MAAM,OAAO,QAAS,SAAQ,SAAS;IAmErC,YAAY,SAAyB,EAAE;QACrC,KAAK,EAAE,CAAC;QACR,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC;YAAE,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAC1C,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC9B,CAAC;CACF;AA6BD;;;;GAIG;AACH,MAAM,CAAC,MAAM,cAAc,GAAG,WAAW,CAAC;AAE1C;;GAEG;AACH,MACa,gBAAgB;iIAAhB,gBAAgB;qHAAhB,gBAAgB,wFADkC,EAAE;;SACpD,gBAAgB;2FAAhB,gBAAgB;kBAD5B,SAAS;mBAAC,EAAE,QAAQ,EAAE,GAAG,cAAc,WAAW,EAAE,QAAQ,EAAE,EAAE,EAAE;8BAMxD,MAAM;sBAAd,KAAK;;AAGR,MAAM,OAAO,YAAa,SAAQ,kBAAkB;IAApD;;QACE;;;WAGG;QACH,aAAQ,GAAc,EAAE,CAAC;IAC3B,CAAC;CAAA;AA0ED,MAAM,OAAO,aAAc,SAAQ,QAAQ;IACzC,YAAY,SAA8B,EAAE;QAC1C,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,cAAe,SAAQ,QAAQ;IAC1C,YAAY,SAA+B,EAAE;QAC3C,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,eAAgB,SAAQ,QAAQ;IAC3C,YAAY,SAAgC,EAAE;QAC5C,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,gBAAiB,SAAQ,QAAQ;IAC5C,YAAY,SAAiC,EAAE;QAC7C,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,mBAAoB,SAAQ,QAAQ;IAC/C,YAAY,SAAoC,EAAE;QAChD,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,kBAAmB,SAAQ,QAAQ;IAC9C,YAAY,SAAmC,EAAE;QAC/C,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,mBAAoB,SAAQ,QAAQ;IAC/C,YAAY,SAAoC,EAAE;QAChD,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,aAAc,SAAQ,QAAQ;IACzC,YAAY,SAA8B,EAAE;QAC1C,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,YAAa,SAAQ,QAAQ;IACxC,YAAY,SAA6B,EAAE;QACzC,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,oBAAqB,SAAQ,QAAQ;IAChD,YAAY,SAAqC,EAAE;QACjD,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,cAAe,SAAQ,QAAQ;IAC1C,YAAY,SAA+B,EAAE;QAC3C,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,kBAAmB,SAAQ,QAAQ;IAC9C,YAAY,SAAmC,EAAE;QAC/C,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,gBAAiB,SAAQ,QAAQ;IAC5C,YAAY,SAAiC,EAAE;QAC7C,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,YAAa,SAAQ,QAAQ;IACxC,YAAY,SAA6B,EAAE;QACzC,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAMD,MAAM,OAAO,oBAAqB,SAAQ,QAAQ;IAChD,YAAY,SAAqC,EAAE;QACjD,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF","sourcesContent":["import { XIdentity, XIdentityProperty, XBoolean, XIsEmpty, XNumber, XInputNumber, XWithConfig } from '@ng-nest/ui/core';\r\nimport { Input, Component, TemplateRef, Output, EventEmitter } from '@angular/core';\r\nimport { UntypedFormControl, UntypedFormGroup } from '@angular/forms';\r\nimport { XInputOption, XInputComponent } from '@ng-nest/ui/input';\r\nimport { XSelectOption, XSelectComponent } from '@ng-nest/ui/select';\r\nimport { XCascadeOption, XCascadeComponent } from '@ng-nest/ui/cascade';\r\nimport { XCheckboxOption, XCheckboxComponent } from '@ng-nest/ui/checkbox';\r\nimport { XColorPickerOption, XColorPickerComponent } from '@ng-nest/ui/color-picker';\r\nimport { XDatePickerOption, XDatePickerComponent } from '@ng-nest/ui/date-picker';\r\nimport { XInputNumberOption, XInputNumberComponent } from '@ng-nest/ui/input-number';\r\nimport { XRadioOption, XRadioComponent } from '@ng-nest/ui/radio';\r\nimport { XRateOption, XRateComponent } from '@ng-nest/ui/rate';\r\nimport { XSliderSelectOption, XSliderSelectComponent } from '@ng-nest/ui/slider-select';\r\nimport { XSwitchOption, XSwitchComponent } from '@ng-nest/ui/switch';\r\nimport { XTimePickerOption, XTimePickerComponent } from '@ng-nest/ui/time-picker';\r\nimport { XTextareaOption, XTextareaComponent } from '@ng-nest/ui/textarea';\r\nimport { XFindOption, XFindComponent } from '@ng-nest/ui/find';\r\nimport { XFormOption, XFormProp } from '@ng-nest/ui/base-form';\r\nimport { XAutoCompleteOption, XAutoCompleteComponent } from '@ng-nest/ui/auto-complete';\r\n\r\n/**\r\n * Form\r\n * @selector x-form\r\n * @decorator component\r\n */\r\nexport const XFormPrefix = 'x-form';\r\nconst X_CONFIG_NAME = 'form';\r\n\r\n/**\r\n * @zh_CN 模板\r\n * @en_US Template\r\n */\r\nexport type XFormTemplate = { [property: string]: TemplateRef<any> };\r\n/**\r\n * Form Property\r\n */\r\n@Component({ selector: `${XFormPrefix}-property`, template: '' })\r\nexport class XFormProperty extends XFormProp {\r\n  /**\r\n   * @zh_CN 表单 FormGroup\r\n   * @en_US Form FormGroup\r\n   */\r\n  @Input() formGroup: UntypedFormGroup = new UntypedFormGroup({});\r\n  /**\r\n   * @zh_CN 表单名称\r\n   * @en_US Form name\r\n   */\r\n  @Input() title?: string;\r\n  /**\r\n   * @zh_CN 控件间距，单位rem\r\n   * @en_US Control spacing, unit rem\r\n   */\r\n  @Input() @XWithConfig<XNumber>(X_CONFIG_NAME, 1) @XInputNumber() space?: XNumber;\r\n  /**\r\n   * @zh_CN 控件宽度，24栅格\r\n   * @en_US Control width, 24 grid\r\n   */\r\n  @Input() @XInputNumber() span?: XNumber;\r\n  /**\r\n   * @zh_CN 标签后缀\r\n   * @en_US Label suffix\r\n   */\r\n  @Input() @XWithConfig<XNumber>(X_CONFIG_NAME, '') labelSuffix?: string;\r\n  /**\r\n   * @zh_CN 表单控件\r\n   * @en_US Form control\r\n   */\r\n  @Input() controls: XFormControlOption[] | XFormRow[] = [];\r\n  /**\r\n   * @zh_CN 表单宽度\r\n   * @en_US Form width\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_NAME, '100%') width: string = '100%';\r\n  /**\r\n   * @zh_CN 自定义模板\r\n   * @en_US Custom template\r\n   */\r\n  @Input() controlTpl: XFormTemplate = {};\r\n  /**\r\n   * @zh_CN Submit\r\n   * @en_US Submit\r\n   */\r\n  @Output() xSubmit = new EventEmitter<SubmitEvent>();\r\n}\r\n\r\n/**\r\n * @zh_CN 控件对象\r\n * @en_US Control object\r\n */\r\nexport interface XControlOption extends XIdentityProperty {\r\n  /**\r\n   * @zh_CN 值\r\n   * @en_US Value\r\n   */\r\n  value?: any;\r\n  /**\r\n   * @zh_CN 控件类型\r\n   * @en_US Control type\r\n   */\r\n  control?: XControlType;\r\n  /**\r\n   * @zh_CN 禁用\r\n   * @en_US Disabled\r\n   */\r\n  disabled?: XBoolean;\r\n  /**\r\n   * @zh_CN 只读\r\n   * @en_US Read only\r\n   */\r\n  readonly?: XBoolean;\r\n  /**\r\n   * @zh_CN 必填\r\n   * @en_US Required\r\n   */\r\n  required?: XBoolean;\r\n  /**\r\n   * @zh_CN 隐藏\r\n   * @en_US Hide\r\n   */\r\n  hidden?: XBoolean;\r\n  /**\r\n   * @zh_CN 列宽\r\n   * @en_US Column width\r\n   */\r\n  span?: number;\r\n  /**\r\n   * @zh_CN 正则验证规则\r\n   * @en_US Regular validation rules\r\n   */\r\n  pattern?: RegExp | RegExp[];\r\n  /**\r\n   * @zh_CN 验证不通过提示文字\r\n   * @en_US Verification failed prompt text\r\n   */\r\n  message?: string | string[];\r\n  /**\r\n   * @zh_CN 输入框的验证函数\r\n   * @en_US Validation function of input box\r\n   */\r\n  inputValidator?: (value: any) => boolean;\r\n  /**\r\n   * @zh_CN 外部改变事件\r\n   * @en_US External change event\r\n   */\r\n  change?: () => void;\r\n  /**\r\n   * @zh_CN 自定义属性\r\n   * @en_US Custom attributes\r\n   */\r\n  [property: string]: any;\r\n}\r\n\r\n/**\r\n * @zh_CN 控件对象\r\n * @en_US Control object\r\n */\r\nexport class XControl extends XIdentity implements XControlOption {\r\n  /**\r\n   * @zh_CN 值\r\n   * @en_US Value\r\n   */\r\n  value?: any;\r\n  /**\r\n   * @zh_CN 控件类型\r\n   * @en_US Control type\r\n   */\r\n  control?: XControlType;\r\n  /**\r\n   * @zh_CN 禁用\r\n   * @en_US Disabled\r\n   */\r\n  disabled?: XBoolean;\r\n  /**\r\n   * @zh_CN 只读\r\n   * @en_US Read only\r\n   */\r\n  readonly?: XBoolean;\r\n  /**\r\n   * @zh_CN 必填\r\n   * @en_US Required\r\n   */\r\n  required?: XBoolean;\r\n  /**\r\n   * @zh_CN 隐藏\r\n   * @en_US Hide\r\n   */\r\n  hidden?: XBoolean;\r\n  /**\r\n   * @zh_CN 列宽\r\n   * @en_US Column width\r\n   */\r\n  span?: number;\r\n  /**\r\n   * @zh_CN 正则验证规则\r\n   * @en_US Regular validation rules\r\n   */\r\n  pattern?: RegExp | RegExp[];\r\n  /**\r\n   * @zh_CN 验证不通过提示文字\r\n   * @en_US Verification failed prompt text\r\n   */\r\n  message?: string | string[];\r\n  /**\r\n   * @zh_CN 输入框的验证函数\r\n   * @en_US Validation function of input box\r\n   */\r\n  inputValidator?: (value: any) => boolean;\r\n  /**\r\n   * @zh_CN 外部改变事件\r\n   * @en_US External change event\r\n   */\r\n  change?: () => void;\r\n  /**\r\n   * @zh_CN 设置验证\r\n   * @en_US Set verification\r\n   */\r\n  setValidators?: () => void;\r\n  /**\r\n   * @zh_CN 自定义属性\r\n   * @en_US Custom attributes\r\n   */\r\n  [property: string]: any;\r\n\r\n  constructor(option: XControlOption = {}) {\r\n    super();\r\n    if (XIsEmpty(this.value)) this.value = '';\r\n    Object.assign(this, option);\r\n  }\r\n}\r\n\r\n/**\r\n * @zh_CN 表单行对象\r\n * @en_US Form row object\r\n */\r\nexport interface XFormRow {\r\n  /**\r\n   * @zh_CN 行标题\r\n   * @en_US Row header\r\n   */\r\n  title?: string;\r\n  /**\r\n   * @zh_CN 行图标\r\n   * @en_US Row icon\r\n   */\r\n  icon?: string;\r\n  /**\r\n   * @zh_CN 行中的控件\r\n   * @en_US Control in row\r\n   */\r\n  controls: XFormControlOption[];\r\n  /**\r\n   * @zh_CN 隐藏\r\n   * @en_US Hidden\r\n   */\r\n  hidden?: XBoolean;\r\n}\r\n\r\n/**\r\n * Control\r\n * @selector x-control\r\n * @decorator component\r\n */\r\nexport const XControlPrefix = 'x-control';\r\n\r\n/**\r\n * Control Property\r\n */\r\n@Component({ selector: `${XControlPrefix}-property`, template: '' })\r\nexport class XControlProperty {\r\n  /**\r\n   * @zh_CN 控件对象\r\n   * @en_US Control object\r\n   */\r\n  @Input() option?: XControlOption;\r\n}\r\n\r\nexport class XFormControl extends UntypedFormControl {\r\n  /**\r\n   * @zh_CN 提示信息\r\n   * @en_US Prompt information\r\n   */\r\n  messages?: string[] = [];\r\n}\r\n\r\nexport type XFormControlOption =\r\n  | XInputControlOption\r\n  | XSelectControlOption\r\n  | XCascadeControlOption\r\n  | XCheckboxControlOption\r\n  | XColorPickerControlOption\r\n  | XDatePickerControlOption\r\n  | XInputNumberControlOption\r\n  | XRadioControlOption\r\n  | XRateControlOption\r\n  | XSliderSelectControlOption\r\n  | XSwitchControlOption\r\n  | XTimePickerControlOption\r\n  | XFindControlOption\r\n  | XTemplateControlOption;\r\n\r\nexport type XFormControlComponent =\r\n  | XInputComponent\r\n  | XSelectComponent\r\n  | XCascadeComponent\r\n  | XCheckboxComponent\r\n  | XColorPickerComponent\r\n  | XDatePickerComponent\r\n  | XInputNumberComponent\r\n  | XRadioComponent\r\n  | XRateComponent\r\n  | XSliderSelectComponent\r\n  | XSwitchComponent\r\n  | XTimePickerComponent\r\n  | XTextareaComponent\r\n  | XFindComponent\r\n  | XAutoCompleteComponent;\r\n\r\nexport type XFormControlType =\r\n  | XInputControl\r\n  | XSelectControl\r\n  | XCascadeControl\r\n  | XCheckboxControl\r\n  | XColorPickerControl\r\n  | XDatePickerControl\r\n  | XInputNumberControl\r\n  | XRadioControl\r\n  | XRateControl\r\n  | XSliderSelectControl\r\n  | XSwitchControl\r\n  | XTimePickerControl\r\n  | XTextareaControl\r\n  | XFindControl\r\n  | XAutoCompleteControl;\r\n\r\nexport type XControlType =\r\n  | 'input'\r\n  | 'select'\r\n  | 'cascade'\r\n  | 'checkbox'\r\n  | 'color-picker'\r\n  | 'date-picker'\r\n  | 'input-number'\r\n  | 'radio'\r\n  | 'rate'\r\n  | 'slider-select'\r\n  | 'switch'\r\n  | 'time-picker'\r\n  | 'textarea'\r\n  | 'find'\r\n  | 'auto-complete'\r\n  | 'template';\r\n\r\n/**\r\n * Input Control\r\n */\r\nexport interface XInputControlOption extends XControlOption, XInputOption {}\r\nexport class XInputControl extends XControl {\r\n  constructor(option: XInputControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Select Control\r\n */\r\nexport interface XSelectControlOption extends XControlOption, XSelectOption {}\r\nexport class XSelectControl extends XControl {\r\n  constructor(option: XSelectControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Cascade Control\r\n */\r\nexport interface XCascadeControlOption extends XControlOption, XCascadeOption {}\r\nexport class XCascadeControl extends XControl {\r\n  constructor(option: XCascadeControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Checkbox Control\r\n */\r\nexport interface XCheckboxControlOption extends XControlOption, XCheckboxOption {}\r\nexport class XCheckboxControl extends XControl {\r\n  constructor(option: XCheckboxControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * ColorPicker Control\r\n */\r\nexport interface XColorPickerControlOption extends XControlOption, XColorPickerOption {}\r\nexport class XColorPickerControl extends XControl {\r\n  constructor(option: XColorPickerControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * DatePicker Control\r\n */\r\nexport interface XDatePickerControlOption extends XControlOption, XDatePickerOption {}\r\nexport class XDatePickerControl extends XControl {\r\n  constructor(option: XDatePickerControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * InputNumber Control\r\n */\r\nexport interface XInputNumberControlOption extends XControlOption, XInputNumberOption {}\r\nexport class XInputNumberControl extends XControl {\r\n  constructor(option: XInputNumberControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Radio Control\r\n */\r\nexport interface XRadioControlOption extends XControlOption, XRadioOption {}\r\nexport class XRadioControl extends XControl {\r\n  constructor(option: XRadioControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Rate Control\r\n */\r\nexport interface XRateControlOption extends XControlOption, XRateOption {}\r\nexport class XRateControl extends XControl {\r\n  constructor(option: XRateControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * SliderSelect Control\r\n */\r\nexport interface XSliderSelectControlOption extends XControlOption, XSliderSelectOption {}\r\nexport class XSliderSelectControl extends XControl {\r\n  constructor(option: XSliderSelectControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Switch Control\r\n */\r\nexport interface XSwitchControlOption extends XControlOption, XSwitchOption {}\r\nexport class XSwitchControl extends XControl {\r\n  constructor(option: XSwitchControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * TimePicker Control\r\n */\r\nexport interface XTimePickerControlOption extends XControlOption, XTimePickerOption {}\r\nexport class XTimePickerControl extends XControl {\r\n  constructor(option: XTimePickerControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Textarea Control\r\n */\r\nexport interface XTextareaControlOption extends XControlOption, XTextareaOption {}\r\nexport class XTextareaControl extends XControl {\r\n  constructor(option: XTextareaControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Find Control\r\n */\r\nexport interface XFindControlOption extends XControlOption, XFindOption {}\r\nexport class XFindControl extends XControl {\r\n  constructor(option: XFindControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * AutoComplete Control\r\n */\r\nexport interface XAutoCompleteControlOption extends XControlOption, XAutoCompleteOption {}\r\nexport class XAutoCompleteControl extends XControl {\r\n  constructor(option: XAutoCompleteControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Template Control\r\n */\r\nexport interface XTemplateControlOption extends XControlOption, XFormOption {}\r\n"]}
|
|
202
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.property.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/form/form.property.ts"],"names":[],"mappings":"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","sourcesContent":["import { XIdentity, XIdentityProperty, XBoolean, XIsEmpty, XNumber, XInputNumber, XWithConfig } from '@ng-nest/ui/core';\r\nimport { Input, Component, TemplateRef, Output, EventEmitter } from '@angular/core';\r\nimport { UntypedFormControl, UntypedFormGroup } from '@angular/forms';\r\nimport { XInputOption, XInputComponent } from '@ng-nest/ui/input';\r\nimport { XSelectOption, XSelectComponent } from '@ng-nest/ui/select';\r\nimport { XCascadeOption, XCascadeComponent } from '@ng-nest/ui/cascade';\r\nimport { XCheckboxOption, XCheckboxComponent } from '@ng-nest/ui/checkbox';\r\nimport { XColorPickerOption, XColorPickerComponent } from '@ng-nest/ui/color-picker';\r\nimport { XDatePickerOption, XDatePickerComponent } from '@ng-nest/ui/date-picker';\r\nimport { XInputNumberOption, XInputNumberComponent } from '@ng-nest/ui/input-number';\r\nimport { XRadioOption, XRadioComponent } from '@ng-nest/ui/radio';\r\nimport { XRateOption, XRateComponent } from '@ng-nest/ui/rate';\r\nimport { XSliderSelectOption, XSliderSelectComponent } from '@ng-nest/ui/slider-select';\r\nimport { XSwitchOption, XSwitchComponent } from '@ng-nest/ui/switch';\r\nimport { XTimePickerOption, XTimePickerComponent } from '@ng-nest/ui/time-picker';\r\nimport { XTextareaOption, XTextareaComponent } from '@ng-nest/ui/textarea';\r\nimport { XFindOption, XFindComponent } from '@ng-nest/ui/find';\r\nimport { XFormOption, XFormProp } from '@ng-nest/ui/base-form';\r\nimport { XAutoCompleteOption, XAutoCompleteComponent } from '@ng-nest/ui/auto-complete';\r\n\r\n/**\r\n * Form\r\n * @selector x-form\r\n * @decorator component\r\n */\r\nexport const XFormPrefix = 'x-form';\r\nconst X_CONFIG_NAME = 'form';\r\n\r\n/**\r\n * @zh_CN 模板\r\n * @en_US Template\r\n */\r\nexport type XFormTemplate = { [property: string]: TemplateRef<any> };\r\n/**\r\n * Form Property\r\n */\r\n@Component({ selector: `${XFormPrefix}-property`, template: '' })\r\nexport class XFormProperty extends XFormProp {\r\n  /**\r\n   * @zh_CN 表单 FormGroup\r\n   * @en_US Form FormGroup\r\n   */\r\n  @Input() formGroup: UntypedFormGroup = new UntypedFormGroup({});\r\n  /**\r\n   * @zh_CN 表单名称\r\n   * @en_US Form name\r\n   */\r\n  @Input() title?: string;\r\n  /**\r\n   * @zh_CN 控件间距，单位rem\r\n   * @en_US Control spacing, unit rem\r\n   */\r\n  @Input() @XWithConfig<XNumber>(X_CONFIG_NAME, 1) @XInputNumber() space?: XNumber;\r\n  /**\r\n   * @zh_CN 控件宽度，24栅格\r\n   * @en_US Control width, 24 grid\r\n   */\r\n  @Input() @XInputNumber() span?: XNumber;\r\n  /**\r\n   * @zh_CN 标签后缀\r\n   * @en_US Label suffix\r\n   */\r\n  @Input() @XWithConfig<XNumber>(X_CONFIG_NAME, '') labelSuffix?: string;\r\n  /**\r\n   * @zh_CN 表单控件\r\n   * @en_US Form control\r\n   */\r\n  @Input() controls: XFormControlOption[] | XFormRow[] = [];\r\n  /**\r\n   * @zh_CN 表单宽度\r\n   * @en_US Form width\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_NAME, '100%') width: string = '100%';\r\n  /**\r\n   * @zh_CN 自定义模板\r\n   * @en_US Custom template\r\n   */\r\n  @Input() controlTpl: XFormTemplate = {};\r\n  /**\r\n   * @zh_CN Submit\r\n   * @en_US Submit\r\n   */\r\n  @Output() xSubmit = new EventEmitter<SubmitEvent>();\r\n}\r\n\r\n/**\r\n * @zh_CN 控件对象\r\n * @en_US Control object\r\n */\r\nexport interface XControlOption extends XIdentityProperty {\r\n  /**\r\n   * @zh_CN 值\r\n   * @en_US Value\r\n   */\r\n  value?: any;\r\n  /**\r\n   * @zh_CN 初始默认值\r\n   * @en_US Default value\r\n   */\r\n  defaultValue?: any;\r\n  /**\r\n   * @zh_CN 控件类型\r\n   * @en_US Control type\r\n   */\r\n  control?: XControlType;\r\n  /**\r\n   * @zh_CN 禁用\r\n   * @en_US Disabled\r\n   */\r\n  disabled?: XBoolean;\r\n  /**\r\n   * @zh_CN 只读\r\n   * @en_US Read only\r\n   */\r\n  readonly?: XBoolean;\r\n  /**\r\n   * @zh_CN 必填\r\n   * @en_US Required\r\n   */\r\n  required?: XBoolean;\r\n  /**\r\n   * @zh_CN 隐藏\r\n   * @en_US Hide\r\n   */\r\n  hidden?: XBoolean;\r\n  /**\r\n   * @zh_CN 列宽\r\n   * @en_US Column width\r\n   */\r\n  span?: number;\r\n  /**\r\n   * @zh_CN 正则验证规则\r\n   * @en_US Regular validation rules\r\n   */\r\n  pattern?: RegExp | RegExp[];\r\n  /**\r\n   * @zh_CN 验证不通过提示文字\r\n   * @en_US Verification failed prompt text\r\n   */\r\n  message?: string | string[];\r\n  /**\r\n   * @zh_CN 输入框的验证函数\r\n   * @en_US Validation function of input box\r\n   */\r\n  inputValidator?: (value: any) => boolean;\r\n  /**\r\n   * @zh_CN 外部改变事件\r\n   * @en_US External change event\r\n   */\r\n  change?: () => void;\r\n  /**\r\n   * @zh_CN 自定义属性\r\n   * @en_US Custom attributes\r\n   */\r\n  [property: string]: any;\r\n}\r\n\r\n/**\r\n * @zh_CN 控件对象\r\n * @en_US Control object\r\n */\r\nexport class XControl extends XIdentity implements XControlOption {\r\n  /**\r\n   * @zh_CN 值\r\n   * @en_US Value\r\n   */\r\n  value?: any;\r\n  /**\r\n   * @zh_CN 开启这个，执行 reset 的时候初始为设置的 value，默认为 null\r\n   * @en_US Enable this. When performing a reset, the initial value is the set value, which defaults to null\r\n   */\r\n  nonNullable?: any;\r\n  /**\r\n   * @zh_CN 控件类型\r\n   * @en_US Control type\r\n   */\r\n  control?: XControlType;\r\n  /**\r\n   * @zh_CN 禁用\r\n   * @en_US Disabled\r\n   */\r\n  disabled?: XBoolean;\r\n  /**\r\n   * @zh_CN 只读\r\n   * @en_US Read only\r\n   */\r\n  readonly?: XBoolean;\r\n  /**\r\n   * @zh_CN 必填\r\n   * @en_US Required\r\n   */\r\n  required?: XBoolean;\r\n  /**\r\n   * @zh_CN 隐藏\r\n   * @en_US Hide\r\n   */\r\n  hidden?: XBoolean;\r\n  /**\r\n   * @zh_CN 列宽\r\n   * @en_US Column width\r\n   */\r\n  span?: number;\r\n  /**\r\n   * @zh_CN 正则验证规则\r\n   * @en_US Regular validation rules\r\n   */\r\n  pattern?: RegExp | RegExp[];\r\n  /**\r\n   * @zh_CN 验证不通过提示文字\r\n   * @en_US Verification failed prompt text\r\n   */\r\n  message?: string | string[];\r\n  /**\r\n   * @zh_CN 输入框的验证函数\r\n   * @en_US Validation function of input box\r\n   */\r\n  inputValidator?: (value: any) => boolean;\r\n  /**\r\n   * @zh_CN 外部改变事件\r\n   * @en_US External change event\r\n   */\r\n  change?: () => void;\r\n  /**\r\n   * @zh_CN 设置验证\r\n   * @en_US Set verification\r\n   */\r\n  setValidators?: () => void;\r\n  /**\r\n   * @zh_CN 自定义属性\r\n   * @en_US Custom attributes\r\n   */\r\n  [property: string]: any;\r\n\r\n  constructor(option: XControlOption = {}) {\r\n    super();\r\n    if (XIsEmpty(this.value)) this.value = '';\r\n    Object.assign(this, option);\r\n  }\r\n}\r\n\r\n/**\r\n * @zh_CN 表单行对象\r\n * @en_US Form row object\r\n */\r\nexport interface XFormRow {\r\n  /**\r\n   * @zh_CN 行标题\r\n   * @en_US Row header\r\n   */\r\n  title?: string;\r\n  /**\r\n   * @zh_CN 行图标\r\n   * @en_US Row icon\r\n   */\r\n  icon?: string;\r\n  /**\r\n   * @zh_CN 行中的控件\r\n   * @en_US Control in row\r\n   */\r\n  controls: XFormControlOption[];\r\n  /**\r\n   * @zh_CN 隐藏\r\n   * @en_US Hidden\r\n   */\r\n  hidden?: XBoolean;\r\n}\r\n\r\n/**\r\n * Control\r\n * @selector x-control\r\n * @decorator component\r\n */\r\nexport const XControlPrefix = 'x-control';\r\n\r\n/**\r\n * Control Property\r\n */\r\n@Component({ selector: `${XControlPrefix}-property`, template: '' })\r\nexport class XControlProperty {\r\n  /**\r\n   * @zh_CN 控件对象\r\n   * @en_US Control object\r\n   */\r\n  @Input() option?: XControlOption;\r\n}\r\n\r\nexport class XFormControl extends UntypedFormControl {\r\n  /**\r\n   * @zh_CN 提示信息\r\n   * @en_US Prompt information\r\n   */\r\n  messages?: string[] = [];\r\n}\r\n\r\nexport type XFormControlOption =\r\n  | XInputControlOption\r\n  | XSelectControlOption\r\n  | XCascadeControlOption\r\n  | XCheckboxControlOption\r\n  | XColorPickerControlOption\r\n  | XDatePickerControlOption\r\n  | XInputNumberControlOption\r\n  | XRadioControlOption\r\n  | XRateControlOption\r\n  | XSliderSelectControlOption\r\n  | XSwitchControlOption\r\n  | XTimePickerControlOption\r\n  | XFindControlOption\r\n  | XTemplateControlOption;\r\n\r\nexport type XFormControlComponent =\r\n  | XInputComponent\r\n  | XSelectComponent\r\n  | XCascadeComponent\r\n  | XCheckboxComponent\r\n  | XColorPickerComponent\r\n  | XDatePickerComponent\r\n  | XInputNumberComponent\r\n  | XRadioComponent\r\n  | XRateComponent\r\n  | XSliderSelectComponent\r\n  | XSwitchComponent\r\n  | XTimePickerComponent\r\n  | XTextareaComponent\r\n  | XFindComponent\r\n  | XAutoCompleteComponent;\r\n\r\nexport type XFormControlType =\r\n  | XInputControl\r\n  | XSelectControl\r\n  | XCascadeControl\r\n  | XCheckboxControl\r\n  | XColorPickerControl\r\n  | XDatePickerControl\r\n  | XInputNumberControl\r\n  | XRadioControl\r\n  | XRateControl\r\n  | XSliderSelectControl\r\n  | XSwitchControl\r\n  | XTimePickerControl\r\n  | XTextareaControl\r\n  | XFindControl\r\n  | XAutoCompleteControl;\r\n\r\nexport type XControlType =\r\n  | 'input'\r\n  | 'select'\r\n  | 'cascade'\r\n  | 'checkbox'\r\n  | 'color-picker'\r\n  | 'date-picker'\r\n  | 'input-number'\r\n  | 'radio'\r\n  | 'rate'\r\n  | 'slider-select'\r\n  | 'switch'\r\n  | 'time-picker'\r\n  | 'textarea'\r\n  | 'find'\r\n  | 'auto-complete'\r\n  | 'template';\r\n\r\n/**\r\n * Input Control\r\n */\r\nexport interface XInputControlOption extends XControlOption, XInputOption {}\r\nexport class XInputControl extends XControl {\r\n  constructor(option: XInputControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Select Control\r\n */\r\nexport interface XSelectControlOption extends XControlOption, XSelectOption {}\r\nexport class XSelectControl extends XControl {\r\n  constructor(option: XSelectControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Cascade Control\r\n */\r\nexport interface XCascadeControlOption extends XControlOption, XCascadeOption {}\r\nexport class XCascadeControl extends XControl {\r\n  constructor(option: XCascadeControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Checkbox Control\r\n */\r\nexport interface XCheckboxControlOption extends XControlOption, XCheckboxOption {}\r\nexport class XCheckboxControl extends XControl {\r\n  constructor(option: XCheckboxControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * ColorPicker Control\r\n */\r\nexport interface XColorPickerControlOption extends XControlOption, XColorPickerOption {}\r\nexport class XColorPickerControl extends XControl {\r\n  constructor(option: XColorPickerControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * DatePicker Control\r\n */\r\nexport interface XDatePickerControlOption extends XControlOption, XDatePickerOption {}\r\nexport class XDatePickerControl extends XControl {\r\n  constructor(option: XDatePickerControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * InputNumber Control\r\n */\r\nexport interface XInputNumberControlOption extends XControlOption, XInputNumberOption {}\r\nexport class XInputNumberControl extends XControl {\r\n  constructor(option: XInputNumberControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Radio Control\r\n */\r\nexport interface XRadioControlOption extends XControlOption, XRadioOption {}\r\nexport class XRadioControl extends XControl {\r\n  constructor(option: XRadioControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Rate Control\r\n */\r\nexport interface XRateControlOption extends XControlOption, XRateOption {}\r\nexport class XRateControl extends XControl {\r\n  constructor(option: XRateControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * SliderSelect Control\r\n */\r\nexport interface XSliderSelectControlOption extends XControlOption, XSliderSelectOption {}\r\nexport class XSliderSelectControl extends XControl {\r\n  constructor(option: XSliderSelectControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Switch Control\r\n */\r\nexport interface XSwitchControlOption extends XControlOption, XSwitchOption {}\r\nexport class XSwitchControl extends XControl {\r\n  constructor(option: XSwitchControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * TimePicker Control\r\n */\r\nexport interface XTimePickerControlOption extends XControlOption, XTimePickerOption {}\r\nexport class XTimePickerControl extends XControl {\r\n  constructor(option: XTimePickerControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Textarea Control\r\n */\r\nexport interface XTextareaControlOption extends XControlOption, XTextareaOption {}\r\nexport class XTextareaControl extends XControl {\r\n  constructor(option: XTextareaControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Find Control\r\n */\r\nexport interface XFindControlOption extends XControlOption, XFindOption {}\r\nexport class XFindControl extends XControl {\r\n  constructor(option: XFindControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * AutoComplete Control\r\n */\r\nexport interface XAutoCompleteControlOption extends XControlOption, XAutoCompleteOption {}\r\nexport class XAutoCompleteControl extends XControl {\r\n  constructor(option: XAutoCompleteControlOption = {}) {\r\n    super(option);\r\n  }\r\n}\r\n\r\n/**\r\n * Template Control\r\n */\r\nexport interface XTemplateControlOption extends XControlOption, XFormOption {}\r\n"]}
|