@ng-nest/ui 17.0.8 → 17.0.10

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.
@@ -1,15 +1,15 @@
1
1
  import { OnInit, ElementRef, SimpleChanges, OnChanges } from '@angular/core';
2
2
  import { XCarouselProperty } from './carousel.property';
3
3
  import { XNumber, XConfigService } from '@ng-nest/ui/core';
4
- import { BehaviorSubject } from 'rxjs';
4
+ import { BehaviorSubject, Subscription } from 'rxjs';
5
5
  import * as i0 from "@angular/core";
6
6
  export declare class XCarouselComponent extends XCarouselProperty implements OnInit, OnChanges {
7
7
  carousel: ElementRef<HTMLElement>;
8
8
  content: ElementRef<HTMLElement>;
9
9
  start: number;
10
10
  before: number;
11
- timer: any;
12
- precentTimer: any;
11
+ timer?: Subscription;
12
+ precentTimer?: Subscription;
13
13
  panelChanges: BehaviorSubject<any>[];
14
14
  platformId: Object;
15
15
  isBrowser: boolean;
@@ -300,6 +300,7 @@ export interface XInputGroupConfig {
300
300
  export interface XInputNumberConfig {
301
301
  size?: XSize;
302
302
  bordered?: XBoolean;
303
+ hiddenButton?: XBoolean;
303
304
  }
304
305
  export interface XImageConfig {
305
306
  previewText?: string;
@@ -1,7 +1,7 @@
1
1
  import { Component, ViewEncapsulation, ChangeDetectorRef, ChangeDetectionStrategy, ViewChild, PLATFORM_ID, inject } from '@angular/core';
2
2
  import { XCarouselPrefix, XCarouselProperty } from './carousel.property';
3
3
  import { XIsUndefined, XIsChange, XIsEmpty, XResize, XConfigService } from '@ng-nest/ui/core';
4
- import { Subject } from 'rxjs';
4
+ import { Subject, interval } from 'rxjs';
5
5
  import { takeUntil, debounceTime } from 'rxjs/operators';
6
6
  import { NgClass, isPlatformBrowser } from '@angular/common';
7
7
  import { XButtonComponent } from '@ng-nest/ui/button';
@@ -42,7 +42,8 @@ export class XCarouselComponent extends XCarouselProperty {
42
42
  XIsChange(active) && this.setActiveItem(Number(this.active));
43
43
  }
44
44
  ngOnDestroy() {
45
- this.timer && clearInterval(this.timer);
45
+ this.timer?.unsubscribe();
46
+ this.precentTimer?.unsubscribe();
46
47
  this.panelChanges.forEach((x) => x.complete());
47
48
  this._unSubject.complete();
48
49
  this._unSubject.unsubscribe();
@@ -57,18 +58,20 @@ export class XCarouselComponent extends XCarouselProperty {
57
58
  resetInterval() {
58
59
  if (!this.isBrowser)
59
60
  return;
60
- this.timer && clearInterval(this.timer);
61
- this.precentTimer && clearInterval(this.precentTimer);
62
- this.percent = 0;
63
- const js = Number(this.interval) / 100;
64
- this.precentTimer = setInterval(() => {
65
- this.percent += 1;
66
- this.cdr.detectChanges();
67
- }, js);
68
- this.timer = setInterval(() => {
61
+ this.timer?.unsubscribe();
62
+ if (this.progress) {
63
+ this.precentTimer?.unsubscribe();
64
+ this.percent = 0;
65
+ const js = Number(this.interval) / 100;
66
+ this.precentTimer = interval(js).subscribe(() => {
67
+ this.percent += 1;
68
+ this.cdr.markForCheck();
69
+ });
70
+ }
71
+ this.timer = interval(Number(this.interval)).subscribe(() => {
69
72
  this.percent = 0;
70
73
  this.setActiveItem(Number(this.active) + 1);
71
- }, Number(this.interval));
74
+ });
72
75
  }
73
76
  setActiveItem(index) {
74
77
  if (this.start === -1)
@@ -78,7 +81,7 @@ export class XCarouselComponent extends XCarouselProperty {
78
81
  this.active = nextValue;
79
82
  this.panelChanges.forEach((sub) => sub.next(true));
80
83
  this.activeChange.emit(this.active);
81
- this.cdr.detectChanges();
84
+ this.cdr.markForCheck();
82
85
  }
83
86
  setClassMap() {
84
87
  this.classMap[`${XCarouselPrefix}-${this.direction}`] = !XIsEmpty(this.direction);
@@ -99,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
99
102
  type: ViewChild,
100
103
  args: ['content']
101
104
  }] } });
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/carousel/carousel.component.ts","../../../../../lib/ng-nest/ui/carousel/carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  ViewChild,\r\n  PLATFORM_ID,\r\n  inject\r\n} from '@angular/core';\r\nimport { XCarouselPrefix, XCarouselProperty } from './carousel.property';\r\nimport { XIsUndefined, XIsChange, XIsEmpty, XNumber, XResize, XConfigService, XResizeObserver } from '@ng-nest/ui/core';\r\nimport { BehaviorSubject, Subject } from 'rxjs';\r\nimport { takeUntil, debounceTime } from 'rxjs/operators';\r\nimport { NgClass, isPlatformBrowser } from '@angular/common';\r\nimport { XButtonComponent } from '@ng-nest/ui/button';\r\nimport { XProgressComponent } from '@ng-nest/ui/progress';\r\n\r\n@Component({\r\n  selector: `${XCarouselPrefix}`,\r\n  standalone: true,\r\n  imports: [NgClass, XButtonComponent, XProgressComponent],\r\n  templateUrl: './carousel.component.html',\r\n  styleUrls: ['./carousel.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XCarouselComponent extends XCarouselProperty implements OnInit, OnChanges {\r\n  @ViewChild('carousel') carousel!: ElementRef<HTMLElement>;\r\n  @ViewChild('content') content!: ElementRef<HTMLElement>;\r\n  start: number = -1;\r\n  before!: number;\r\n  timer: any;\r\n  precentTimer: any;\r\n  panelChanges: BehaviorSubject<any>[] = [];\r\n  platformId = inject(PLATFORM_ID);\r\n  isBrowser = true;\r\n  percent = 0;\r\n  count = 0;\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: XResizeObserver;\r\n  private cdr = inject(ChangeDetectorRef);\r\n  configService = inject(XConfigService);\r\n\r\n  get page() {\r\n    return Number(this.active) + 1;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.isBrowser = isPlatformBrowser(this.platformId);\r\n    this.setClassMap();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.autoplay && this.resetInterval();\r\n    XResize(this.content.nativeElement)\r\n      .pipe(debounceTime(30), takeUntil(this._unSubject))\r\n      .subscribe((x) => {\r\n        this.panelChanges.forEach((sub) => sub.next(true));\r\n        this._resizeObserver = x.resizeObserver;\r\n        this.cdr.detectChanges();\r\n      });\r\n  }\r\n\r\n  ngOnChanges(simples: SimpleChanges): void {\r\n    const { active } = simples;\r\n    XIsChange(active) && this.setActiveItem(Number(this.active));\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.timer && clearInterval(this.timer);\r\n    this.panelChanges.forEach((x) => x.complete());\r\n    this._unSubject.complete();\r\n    this._unSubject.unsubscribe();\r\n    this._resizeObserver?.disconnect();\r\n  }\r\n\r\n  action(index: XNumber, increase: number, event?: string): void {\r\n    if (!XIsUndefined(event) && this.trigger !== event) return;\r\n    this.autoplay && this.resetInterval();\r\n    this.setActiveItem(Number(index) + increase);\r\n  }\r\n\r\n  resetInterval(): void {\r\n    if (!this.isBrowser) return;\r\n    this.timer && clearInterval(this.timer);\r\n    this.precentTimer && clearInterval(this.precentTimer);\r\n    this.percent = 0;\r\n    const js = Number(this.interval) / 100;\r\n    this.precentTimer = setInterval(() => {\r\n      this.percent += 1;\r\n      this.cdr.detectChanges();\r\n    }, js);\r\n    this.timer = setInterval(() => {\r\n      this.percent = 0;\r\n      this.setActiveItem(Number(this.active) + 1);\r\n    }, Number(this.interval));\r\n  }\r\n\r\n  setActiveItem(index: number): void {\r\n    if (this.start === -1) return;\r\n    this.before = Number(this.active);\r\n    const nextValue = index > this.start ? 0 : index < 0 ? this.start : index;\r\n    this.active = nextValue;\r\n    this.panelChanges.forEach((sub) => sub.next(true));\r\n    this.activeChange.emit(this.active);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setClassMap() {\r\n    this.classMap[`${XCarouselPrefix}-${this.direction}`] = !XIsEmpty(this.direction);\r\n  }\r\n\r\n  getActivated(index: number) {\r\n    return Number(this.active) === index;\r\n  }\r\n}\r\n","<div\r\n  #carousel\r\n  class=\"x-carousel\"\r\n  [ngClass]=\"classMap\"\r\n  [class.x-carousel-arrow-always]=\"arrow === 'always'\"\r\n  [class.x-carousel-has-current]=\"current\"\r\n  [class.x-carousel-indicator-outside]=\"outside || card\"\r\n>\r\n  <div #content class=\"x-carousel-content\" [style.height]=\"height\">\r\n    @if (arrow !== 'never' && direction !== 'vertical') {\r\n      <x-button class=\"arrow-left\" icon=\"fto-chevron-left\" (click)=\"action(active, -1)\"></x-button>\r\n      <x-button class=\"arrow-right\" icon=\"fto-chevron-right\" (click)=\"action(active, 1)\"></x-button>\r\n    }\r\n    <ng-content></ng-content>\r\n    @if (text) {\r\n      <div class=\"x-carousel-text\">{{ text }}</div>\r\n    }\r\n    @if (current) {\r\n      <div class=\"x-carousel-current\">\r\n        <span class=\"x-carousel-active\">{{ page }}</span> /\r\n        <span class=\"x-carousel-count\">{{ count }}</span>\r\n      </div>\r\n    }\r\n    @if (progress) {\r\n      <div class=\"x-carousel-progress\">\r\n        <x-progress [percent]=\"percent\" [color]=\"progressColor\" [info]=\"false\" height=\"0.325rem\"></x-progress>\r\n      </div>\r\n    }\r\n  </div>\r\n  <ul class=\"x-carousel-indicator\">\r\n    @for (panel of panelChanges; track i; let i = $index) {\r\n      <li [class.x-activated]=\"getActivated(i)\" (click)=\"action(i, 0, 'click')\" (mouseenter)=\"action(i, 0, 'hover')\">\r\n        <x-button type=\"text\"></x-button>\r\n      </li>\r\n    }\r\n  </ul>\r\n</div>\r\n"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/carousel/carousel.component.ts","../../../../../lib/ng-nest/ui/carousel/carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  ViewChild,\r\n  PLATFORM_ID,\r\n  inject\r\n} from '@angular/core';\r\nimport { XCarouselPrefix, XCarouselProperty } from './carousel.property';\r\nimport { XIsUndefined, XIsChange, XIsEmpty, XNumber, XResize, XConfigService, XResizeObserver } from '@ng-nest/ui/core';\r\nimport { BehaviorSubject, Subject, Subscription, interval } from 'rxjs';\r\nimport { takeUntil, debounceTime } from 'rxjs/operators';\r\nimport { NgClass, isPlatformBrowser } from '@angular/common';\r\nimport { XButtonComponent } from '@ng-nest/ui/button';\r\nimport { XProgressComponent } from '@ng-nest/ui/progress';\r\n\r\n@Component({\r\n  selector: `${XCarouselPrefix}`,\r\n  standalone: true,\r\n  imports: [NgClass, XButtonComponent, XProgressComponent],\r\n  templateUrl: './carousel.component.html',\r\n  styleUrls: ['./carousel.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XCarouselComponent extends XCarouselProperty implements OnInit, OnChanges {\r\n  @ViewChild('carousel') carousel!: ElementRef<HTMLElement>;\r\n  @ViewChild('content') content!: ElementRef<HTMLElement>;\r\n  start: number = -1;\r\n  before!: number;\r\n  timer?: Subscription;\r\n  precentTimer?: Subscription;\r\n  panelChanges: BehaviorSubject<any>[] = [];\r\n  platformId = inject(PLATFORM_ID);\r\n  isBrowser = true;\r\n  percent = 0;\r\n  count = 0;\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: XResizeObserver;\r\n  private cdr = inject(ChangeDetectorRef);\r\n  configService = inject(XConfigService);\r\n\r\n  get page() {\r\n    return Number(this.active) + 1;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.isBrowser = isPlatformBrowser(this.platformId);\r\n    this.setClassMap();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.autoplay && this.resetInterval();\r\n    XResize(this.content.nativeElement)\r\n      .pipe(debounceTime(30), takeUntil(this._unSubject))\r\n      .subscribe((x) => {\r\n        this.panelChanges.forEach((sub) => sub.next(true));\r\n        this._resizeObserver = x.resizeObserver;\r\n        this.cdr.detectChanges();\r\n      });\r\n  }\r\n\r\n  ngOnChanges(simples: SimpleChanges): void {\r\n    const { active } = simples;\r\n    XIsChange(active) && this.setActiveItem(Number(this.active));\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.timer?.unsubscribe();\r\n    this.precentTimer?.unsubscribe();\r\n    this.panelChanges.forEach((x) => x.complete());\r\n    this._unSubject.complete();\r\n    this._unSubject.unsubscribe();\r\n    this._resizeObserver?.disconnect();\r\n  }\r\n\r\n  action(index: XNumber, increase: number, event?: string): void {\r\n    if (!XIsUndefined(event) && this.trigger !== event) return;\r\n    this.autoplay && this.resetInterval();\r\n    this.setActiveItem(Number(index) + increase);\r\n  }\r\n\r\n  resetInterval(): void {\r\n    if (!this.isBrowser) return;\r\n    this.timer?.unsubscribe();\r\n    if (this.progress) {\r\n      this.precentTimer?.unsubscribe();\r\n      this.percent = 0;\r\n      const js = Number(this.interval) / 100;\r\n      this.precentTimer = interval(js).subscribe(() => {\r\n        this.percent += 1;\r\n        this.cdr.markForCheck();\r\n      });\r\n    }\r\n    this.timer = interval(Number(this.interval)).subscribe(() => {\r\n      this.percent = 0;\r\n      this.setActiveItem(Number(this.active) + 1);\r\n    });\r\n  }\r\n\r\n  setActiveItem(index: number): void {\r\n    if (this.start === -1) return;\r\n    this.before = Number(this.active);\r\n    const nextValue = index > this.start ? 0 : index < 0 ? this.start : index;\r\n    this.active = nextValue;\r\n    this.panelChanges.forEach((sub) => sub.next(true));\r\n    this.activeChange.emit(this.active);\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  setClassMap() {\r\n    this.classMap[`${XCarouselPrefix}-${this.direction}`] = !XIsEmpty(this.direction);\r\n  }\r\n\r\n  getActivated(index: number) {\r\n    return Number(this.active) === index;\r\n  }\r\n}\r\n","<div\r\n  #carousel\r\n  class=\"x-carousel\"\r\n  [ngClass]=\"classMap\"\r\n  [class.x-carousel-arrow-always]=\"arrow === 'always'\"\r\n  [class.x-carousel-has-current]=\"current\"\r\n  [class.x-carousel-indicator-outside]=\"outside || card\"\r\n>\r\n  <div #content class=\"x-carousel-content\" [style.height]=\"height\">\r\n    @if (arrow !== 'never' && direction !== 'vertical') {\r\n      <x-button class=\"arrow-left\" icon=\"fto-chevron-left\" (click)=\"action(active, -1)\"></x-button>\r\n      <x-button class=\"arrow-right\" icon=\"fto-chevron-right\" (click)=\"action(active, 1)\"></x-button>\r\n    }\r\n    <ng-content></ng-content>\r\n    @if (text) {\r\n      <div class=\"x-carousel-text\">{{ text }}</div>\r\n    }\r\n    @if (current) {\r\n      <div class=\"x-carousel-current\">\r\n        <span class=\"x-carousel-active\">{{ page }}</span> /\r\n        <span class=\"x-carousel-count\">{{ count }}</span>\r\n      </div>\r\n    }\r\n    @if (progress) {\r\n      <div class=\"x-carousel-progress\">\r\n        <x-progress [percent]=\"percent\" [color]=\"progressColor\" [info]=\"false\" height=\"0.325rem\"></x-progress>\r\n      </div>\r\n    }\r\n  </div>\r\n  <ul class=\"x-carousel-indicator\">\r\n    @for (panel of panelChanges; track i; let i = $index) {\r\n      <li [class.x-activated]=\"getActivated(i)\" (click)=\"action(i, 0, 'click')\" (mouseenter)=\"action(i, 0, 'hover')\">\r\n        <x-button type=\"text\"></x-button>\r\n      </li>\r\n    }\r\n  </ul>\r\n</div>\r\n"]}
@@ -1,3 +1,3 @@
1
1
  import { InjectionToken } from '@angular/core';
2
2
  export const X_CONFIG = new InjectionToken('x-config');
3
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../../../../lib/ng-nest/ui/core/config/config.ts"],"names":[],"mappings":"AAuBA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAY/C,MAAM,CAAC,MAAM,QAAQ,GAAG,IAAI,cAAc,CAAU,UAAU,CAAC,CAAC","sourcesContent":["import {\r\n  XSize,\r\n  XBoolean,\r\n  XType,\r\n  XEffect,\r\n  XNumber,\r\n  XPositionLeftRight,\r\n  XJustify,\r\n  XShape,\r\n  XFit,\r\n  XShadow,\r\n  XTrigger,\r\n  XDisplayDirection,\r\n  XCorner,\r\n  XDirection,\r\n  XPlace,\r\n  XPosition,\r\n  XPlacement,\r\n  XPositionTopBottom,\r\n  XStatus,\r\n  XAlign,\r\n  XTemplate\r\n} from '../interfaces';\r\nimport { InjectionToken } from '@angular/core';\r\nimport { XTheme } from '../theme';\r\n\r\nexport interface XConfig {\r\n  components?: XComponentConfig;\r\n  theme?: XTheme;\r\n}\r\n\r\nexport type XConfigKey = keyof XConfig;\r\n\r\nexport type XComponentConfigKey = keyof XComponentConfig;\r\n\r\nexport const X_CONFIG = new InjectionToken<XConfig>('x-config');\r\n\r\nexport interface XComponentConfig {\r\n  affix?: XAffixConfig;\r\n  alert?: XAlertConfig;\r\n  anchor?: XAnchorConfig;\r\n  avatar?: XAvatarConfig;\r\n  autoComplete?: XAutoCompleteConfig;\r\n  backTop?: XBackTopConfig;\r\n  badge?: XBadgeConfgig;\r\n  button?: XButtonConfig;\r\n  buttons?: XButtonsConfig;\r\n  calendar?: XCalendarConfig;\r\n  card?: XCardConfig;\r\n  carousel?: XCarouselConfig;\r\n  cascade?: XCascadeConfig;\r\n  checkbox?: XCheckboxConfig;\r\n  collapse?: XCollapseConfig;\r\n  color?: XColorConfig;\r\n  colorPicker?: XColorPickerConfig;\r\n  comment?: XCommentConfig;\r\n  container?: XContainerConfig;\r\n  header?: XHeaderConfig;\r\n  aside?: XAsideConfig;\r\n  footer?: XFooterConfig;\r\n  crumb?: XCrumbComfig;\r\n  datePicker?: XDatePickerConfig;\r\n  dateRange?: XDateRangeConfig;\r\n  dialog?: XDialogConfig;\r\n  drawer?: XDrawerConfig;\r\n  dropdown?: XDropdownConfig;\r\n  description?: XDescriptionConfig;\r\n  empty?: XEmptyConfig;\r\n  find?: XFindConfig;\r\n  form?: XFormConfig;\r\n  highlight?: XHighlightConfig;\r\n  icon?: XIconConfig;\r\n  inner?: XInnerConfig;\r\n  input?: XInputConfig;\r\n  inputGroup?: XInputGroupConfig;\r\n  inputNumber?: XInputNumberConfig;\r\n  image?: XImageConfig;\r\n  col?: XColConfig;\r\n  row?: XRowConfig;\r\n  ripple?: XRippleConfig;\r\n  link?: XLinkConfig;\r\n  list?: XListConfig;\r\n  listOption?: XListOptionConfig;\r\n  loading?: XLoadingConfig;\r\n  menu?: XMenuConfig;\r\n  message?: XMessageConfig;\r\n  messageBox?: XMessageBoxConfig;\r\n  notification?: XNotificationConfig;\r\n  outlet?: XOutletConfig;\r\n  pageHeader?: XPageHeaderConfig;\r\n  pagination?: XPaginationConfig;\r\n  pattern?: XPatternConfig;\r\n  popconfirm?: XPopconfirmConfig;\r\n  popover?: XPopoverConfig;\r\n  portal?: XPortalConfig;\r\n  progress?: XProgressConfing;\r\n  radio?: XRadioConfig;\r\n  rate?: XRateConfig;\r\n  result?: XResultConfig;\r\n  select?: XSelectConfig;\r\n  skeleton?: XSkeletonConfig;\r\n  slider?: XSliderConfig;\r\n  sliderSelect?: XSliderSelectConfig;\r\n  statistic?: XStatisticConfig;\r\n  countdown?: XCountdownConfig;\r\n  steps?: XStepsConfig;\r\n  switch?: XSwitchConfig;\r\n  table?: XTableConfig;\r\n  tabs?: XTabsConfig;\r\n  tag?: XTagConfig;\r\n  textRetract?: XTextRetractConfig;\r\n  theme?: XThemeConfig;\r\n  timeAgo?: XTimeAgoConfig;\r\n  timePicker?: XTimePickerConfig;\r\n  timeRange?: XTimeRangeConfig;\r\n  timeline?: XTimelineConfig;\r\n  tooltip?: XTooltipConfig;\r\n  transfer?: XTransferConfig;\r\n  tree?: XTreeConfig;\r\n  treeFile?: XTreeFileConfig;\r\n  treeSelect?: XTreeSelectConfig;\r\n  textarea?: XTextareaConfig;\r\n  upload?: XUploadConfig;\r\n  keyword?: XKeywordConfig;\r\n}\r\n\r\nexport interface XAffixConfig {\r\n  top?: string;\r\n  left?: string;\r\n}\r\n\r\nexport interface XAlertConfig {\r\n  effect?: XEffect;\r\n  hideClose?: XBoolean;\r\n  showIcon?: XBoolean;\r\n  disabledAnimation?: XBoolean;\r\n  draggable?: XBoolean;\r\n  resizable?: XBoolean;\r\n  dragHandleTitle?: XBoolean;\r\n  duration?: XNumber;\r\n}\r\n\r\nexport interface XAnchorConfig {\r\n  affixTop?: string;\r\n  affixWidth?: string;\r\n  layout?: XPositionLeftRight;\r\n  justify?: XJustify;\r\n}\r\n\r\nexport interface XAvatarConfig {\r\n  size?: XSize;\r\n  shape?: XShape;\r\n  fit?: XFit;\r\n  gap?: number;\r\n  backgroundColor?: string;\r\n}\r\n\r\nexport interface XAutoCompleteConfig {\r\n  placement?: XPositionTopBottom;\r\n  debounceTime?: number;\r\n  size?: XSize;\r\n  bordered?: boolean;\r\n  caseSensitive?: boolean;\r\n  onlySelect?: boolean;\r\n}\r\n\r\nexport interface XBackTopConfig {\r\n  right?: string;\r\n  bottom?: string;\r\n  visibilityHeight?: XNumber;\r\n}\r\n\r\nexport interface XBadgeConfgig {\r\n  type?: XType;\r\n}\r\n\r\nexport interface XButtonConfig {\r\n  size?: XSize;\r\n  type?: XType;\r\n  plain?: XBoolean;\r\n  round?: XBoolean;\r\n  circle?: XBoolean;\r\n  attrType?: 'submit' | 'button' | 'reset';\r\n}\r\n\r\nexport interface XButtonsConfig {\r\n  space?: XNumber;\r\n  hiddenBorder?: XBoolean;\r\n}\r\n\r\nexport interface XCalendarConfig {}\r\n\r\nexport interface XCardConfig {\r\n  shadow?: XShadow;\r\n}\r\n\r\nexport interface XCarouselConfig {\r\n  height?: string;\r\n  trigger?: XTrigger;\r\n  arrow?: XShadow;\r\n  direction?: XDisplayDirection;\r\n}\r\n\r\nexport interface XCascadeConfig {\r\n  placement?: XCorner;\r\n  size?: XSize;\r\n  bordered?: boolean;\r\n  nodeTrigger?: XTrigger;\r\n  nodeHoverDelay?: XNumber;\r\n}\r\n\r\nexport interface XCheckboxConfig {\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XCollapseConfig {\r\n  showIcon?: Boolean;\r\n  ghost?: Boolean;\r\n  iconPosition?: 'left' | 'right';\r\n  bordered?: Boolean;\r\n}\r\n\r\nexport interface XColorConfig {\r\n  merge?: string;\r\n  amounts?: string;\r\n}\r\n\r\nexport interface XColorPickerConfig {\r\n  placement?: XCorner;\r\n}\r\n\r\nexport interface XCommentConfig {\r\n  contentMax?: number;\r\n}\r\n\r\nexport interface XContainerConfig {\r\n  direction?: XDirection;\r\n}\r\n\r\nexport interface XHeaderConfig {\r\n  height?: number;\r\n}\r\n\r\nexport interface XAsideConfig {\r\n  width?: number;\r\n}\r\n\r\nexport interface XFooterConfig {\r\n  height?: number;\r\n}\r\n\r\nexport interface XCrumbComfig {\r\n  separator?: string;\r\n}\r\n\r\nexport interface XDatePickerConfig {\r\n  format?: string;\r\n  clearable?: XBoolean;\r\n  placement?: XCorner;\r\n  size?: XSize;\r\n  bordered?: boolean;\r\n}\r\n\r\nexport interface XDateRangeConfig {\r\n  format?: string;\r\n  clearable?: XBoolean;\r\n  placement?: XCorner;\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n}\r\n\r\nexport interface XDialogConfig {\r\n  placement?: XPlace;\r\n  offset?: string;\r\n  width?: string;\r\n  minWidth?: string;\r\n  minHeight?: string;\r\n  effect?: XEffect;\r\n  showCancel?: XBoolean;\r\n  cancelText?: string;\r\n  showConfirm?: XBoolean;\r\n  confirmText?: string;\r\n  backdropClose?: XBoolean;\r\n  draggable?: XBoolean;\r\n  resizable?: XBoolean;\r\n  maximize?: XBoolean;\r\n  hasBackdrop?: XBoolean;\r\n  className?: string;\r\n  buttonsCenter?: XBoolean;\r\n}\r\n\r\nexport interface XDrawerConfig {\r\n  placement?: XPosition;\r\n  size?: string;\r\n  backdropClose?: XBoolean;\r\n  hasBackdrop?: XBoolean;\r\n  className?: string;\r\n}\r\n\r\nexport interface XDropdownConfig {\r\n  trigger?: XTrigger;\r\n  placement?: XPlacement;\r\n}\r\n\r\nexport interface XDescriptionConfig {\r\n  bordered?: XBoolean;\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XEmptyConfig {\r\n  img?: XTemplate;\r\n  content?: XTemplate;\r\n}\r\n\r\nexport interface XFindConfig {\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  columnLabel?: string;\r\n  dialogTitle?: string;\r\n  dialogCheckboxLabel?: string;\r\n  dialogCheckboxWidth?: number;\r\n  dialogEmptyContent?: string;\r\n  dialogButtonsCenter?: XBoolean;\r\n  tableIndex?: number;\r\n  tableSize?: number;\r\n  tableLoading?: XBoolean;\r\n  tableVirtualScroll?: boolean;\r\n  tableRowHeight?: XNumber;\r\n  treeExpandedLevel?: XNumber;\r\n}\r\n\r\nexport interface XFormConfig {\r\n  space?: XNumber;\r\n  labelSuffix?: string;\r\n  width?: string;\r\n}\r\n\r\nexport interface XHighlightConfig {}\r\n\r\nexport interface XIconConfig {\r\n  href?: string;\r\n}\r\n\r\nexport interface XInnerConfig {\r\n  padding?: string;\r\n}\r\n\r\nexport interface XInputConfig {\r\n  clearable?: XBoolean;\r\n  iconLayout?: XPositionLeftRight;\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  inputPadding?: XNumber;\r\n  inputIconPadding?: XNumber;\r\n}\r\n\r\nexport interface XInputGroupConfig {\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  compact?: XBoolean;\r\n}\r\n\r\nexport interface XInputNumberConfig {\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n}\r\n\r\nexport interface XImageConfig {\r\n  previewText?: string;\r\n}\r\n\r\nexport interface XColConfig {}\r\n\r\nexport interface XRowConfig {}\r\n\r\nexport interface XRippleConfig {\r\n  type?: XType;\r\n}\r\n\r\nexport interface XLinkConfig {\r\n  underline?: XBoolean;\r\n  iconRight?: XBoolean;\r\n  preventDefault?: XBoolean;\r\n}\r\n\r\nexport interface XListConfig {\r\n  selectAllText?: string;\r\n  loadMoreText?: string;\r\n  loadingMoreText?: string;\r\n  caseSensitive?: boolean;\r\n}\r\n\r\nexport interface XListOptionConfig {\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XLoadingConfig {\r\n  size?: XSize;\r\n  text?: string;\r\n  icon?: string;\r\n  color?: string;\r\n  background?: string;\r\n  zIndex?: number;\r\n}\r\n\r\nexport interface XMenuConfig {\r\n  size?: XSize;\r\n  width?: string;\r\n  trigger?: XTrigger;\r\n}\r\n\r\nexport interface XMessageConfig {\r\n  type?: XStatus;\r\n  width?: string;\r\n  placement?: XPlace;\r\n  displayType?: string;\r\n  offset?: string | string[];\r\n  duration?: number;\r\n  hideClose?: boolean;\r\n  showIcon?: boolean;\r\n}\r\n\r\nexport interface XMessageBoxConfig {}\r\n\r\nexport interface XNotificationConfig {}\r\n\r\nexport interface XOutletConfig {}\r\n\r\nexport interface XPageHeaderConfig {\r\n  backIcon?: string;\r\n  backText?: string;\r\n}\r\n\r\nexport interface XPaginationConfig {\r\n  index?: XNumber;\r\n  size?: XNumber;\r\n  space?: XNumber;\r\n  pageLinkSize?: XNumber;\r\n  hiddenBorder?: boolean;\r\n  showEllipsis?: boolean;\r\n  showTotal?: boolean;\r\n  showSize?: boolean;\r\n  sizeWidth?: number;\r\n  sizeData?: number[];\r\n  showInputSize?: boolean;\r\n  inputSizeWidth?: number;\r\n  showJump?: boolean;\r\n  jumpWidth?: number;\r\n  simple?: boolean;\r\n  simpleIndexWidth?: number;\r\n}\r\n\r\nexport interface XPatternConfig {}\r\n\r\nexport interface XPopconfirmConfig {\r\n  placement?: XPlacement;\r\n  trigger?: XTrigger;\r\n  width?: string;\r\n  icon?: string;\r\n  iconColor?: string;\r\n  cancelText?: string;\r\n  confirmText?: string;\r\n}\r\n\r\nexport interface XPopoverConfig {\r\n  placement?: XPlacement;\r\n  trigger?: XTrigger;\r\n  width?: string;\r\n}\r\n\r\nexport interface XPortalConfig {}\r\n\r\nexport interface XProgressConfing {\r\n  height?: string;\r\n  stepWidth?: string;\r\n}\r\n\r\nexport interface XRadioConfig {\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XRateConfig {\r\n  color?: string | { [color: string]: (rate: number) => boolean };\r\n}\r\n\r\nexport interface XResultConfig {}\r\n\r\nexport interface XSelectConfig {\r\n  placement?: XPositionTopBottom;\r\n  clearable?: XBoolean;\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  portalMaxHeight?: string;\r\n  selectAllText?: string;\r\n  search?: XBoolean;\r\n  caseSensitive?: XBoolean;\r\n  debounceTime?: number;\r\n  maxTagCount?: number;\r\n  virtualScroll?: XBoolean;\r\n}\r\n\r\nexport interface XSkeletonConfig {}\r\n\r\nexport interface XSliderConfig {\r\n  animated?: XBoolean;\r\n  size?: XSize;\r\n  showExpand?: XBoolean;\r\n  autoShowArrow?: XBoolean;\r\n  trigger?: XTrigger;\r\n}\r\n\r\nexport interface XSliderSelectConfig {}\r\n\r\nexport interface XStatisticConfig {}\r\n\r\nexport interface XCountdownConfig {\r\n  format?: string;\r\n}\r\n\r\nexport interface XStepsConfig {}\r\n\r\nexport interface XSwitchConfig {\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XTableConfig {\r\n  index?: number;\r\n  size?: number;\r\n  loading?: XBoolean;\r\n  showHeader?: XBoolean;\r\n  virtualScroll?: boolean;\r\n  rowHeight?: XNumber;\r\n  itemSize?: XNumber;\r\n  bordered?: XNumber;\r\n  allowSelectRow?: XBoolean;\r\n  allowCheckRow?: XBoolean;\r\n  rowSize?: XSize;\r\n  showPagination?: XBoolean;\r\n  treeTable?: XBoolean;\r\n  expandedAll?: XBoolean;\r\n  expandedLevel?: XNumber;\r\n  hiddenPaginationBorder?: XBoolean;\r\n  hiddenWrapBorder?: XBoolean;\r\n  showEmpty?: XBoolean;\r\n  emptyImg?: XTemplate;\r\n  emptyContent?: XTemplate;\r\n}\r\n\r\nexport interface XTabsConfig {\r\n  size?: XSize;\r\n  trigger?: XTrigger;\r\n}\r\n\r\nexport interface XTagConfig {\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  closable?: XBoolean;\r\n  dark?: XBoolean;\r\n}\r\n\r\nexport interface XTextRetractConfig {\r\n  max?: XNumber;\r\n}\r\n\r\nexport interface XThemeConfig {\r\n  amounts?: XNumber[];\r\n}\r\n\r\nexport interface XTimeAgoConfig {}\r\n\r\nexport interface XTimePickerConfig {\r\n  format?: string;\r\n  placement?: XCorner;\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  use12Hours?: XBoolean;\r\n  defaultNow?: XBoolean;\r\n}\r\n\r\nexport interface XTimeRangeConfig {}\r\n\r\nexport interface XTimelineConfig {\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XTooltipConfig {\r\n  placement?: XPlacement;\r\n}\r\n\r\nexport interface XTransferConfig {\r\n  titles?: string[];\r\n  drag?: XBoolean;\r\n  virtualScroll?: XBoolean;\r\n}\r\n\r\nexport interface XTreeConfig {\r\n  spacing?: XNumber;\r\n  nodeHeight?: XNumber;\r\n  nodeAlignItems?: XAlign;\r\n  virtualScroll?: boolean;\r\n  onlyLeaf?: boolean;\r\n  showLine?: boolean;\r\n}\r\n\r\nexport interface XTextareaConfig {\r\n  clearable?: XBoolean;\r\n  iconLayout?: XPositionLeftRight;\r\n}\r\n\r\nexport interface XTreeFileConfig {\r\n  maxHeight?: XNumber;\r\n  spacing?: XNumber;\r\n}\r\n\r\nexport interface XTreeSelectConfig {\r\n  placement?: XPositionTopBottom;\r\n  clearable?: XBoolean;\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  portalMaxHeight?: string;\r\n  selectAllText?: string;\r\n  search?: XBoolean;\r\n  caseSensitive?: XBoolean;\r\n  debounceTime?: number;\r\n  maxTagCount?: number;\r\n  virtualScroll?: XBoolean;\r\n  showPath?: XBoolean;\r\n  separator?: string;\r\n  onlyLeaf?: boolean;\r\n}\r\n\r\nexport interface XUploadConfig {\r\n  download?: XBoolean;\r\n  multipleModel?: 'cover' | 'add';\r\n}\r\n\r\nexport interface XKeywordConfig {\r\n  type?: XType;\r\n  color?: string;\r\n  caseSensitive?: boolean;\r\n}\r\n"]}
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../../../../lib/ng-nest/ui/core/config/config.ts"],"names":[],"mappings":"AAuBA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAY/C,MAAM,CAAC,MAAM,QAAQ,GAAG,IAAI,cAAc,CAAU,UAAU,CAAC,CAAC","sourcesContent":["import {\r\n  XSize,\r\n  XBoolean,\r\n  XType,\r\n  XEffect,\r\n  XNumber,\r\n  XPositionLeftRight,\r\n  XJustify,\r\n  XShape,\r\n  XFit,\r\n  XShadow,\r\n  XTrigger,\r\n  XDisplayDirection,\r\n  XCorner,\r\n  XDirection,\r\n  XPlace,\r\n  XPosition,\r\n  XPlacement,\r\n  XPositionTopBottom,\r\n  XStatus,\r\n  XAlign,\r\n  XTemplate\r\n} from '../interfaces';\r\nimport { InjectionToken } from '@angular/core';\r\nimport { XTheme } from '../theme';\r\n\r\nexport interface XConfig {\r\n  components?: XComponentConfig;\r\n  theme?: XTheme;\r\n}\r\n\r\nexport type XConfigKey = keyof XConfig;\r\n\r\nexport type XComponentConfigKey = keyof XComponentConfig;\r\n\r\nexport const X_CONFIG = new InjectionToken<XConfig>('x-config');\r\n\r\nexport interface XComponentConfig {\r\n  affix?: XAffixConfig;\r\n  alert?: XAlertConfig;\r\n  anchor?: XAnchorConfig;\r\n  avatar?: XAvatarConfig;\r\n  autoComplete?: XAutoCompleteConfig;\r\n  backTop?: XBackTopConfig;\r\n  badge?: XBadgeConfgig;\r\n  button?: XButtonConfig;\r\n  buttons?: XButtonsConfig;\r\n  calendar?: XCalendarConfig;\r\n  card?: XCardConfig;\r\n  carousel?: XCarouselConfig;\r\n  cascade?: XCascadeConfig;\r\n  checkbox?: XCheckboxConfig;\r\n  collapse?: XCollapseConfig;\r\n  color?: XColorConfig;\r\n  colorPicker?: XColorPickerConfig;\r\n  comment?: XCommentConfig;\r\n  container?: XContainerConfig;\r\n  header?: XHeaderConfig;\r\n  aside?: XAsideConfig;\r\n  footer?: XFooterConfig;\r\n  crumb?: XCrumbComfig;\r\n  datePicker?: XDatePickerConfig;\r\n  dateRange?: XDateRangeConfig;\r\n  dialog?: XDialogConfig;\r\n  drawer?: XDrawerConfig;\r\n  dropdown?: XDropdownConfig;\r\n  description?: XDescriptionConfig;\r\n  empty?: XEmptyConfig;\r\n  find?: XFindConfig;\r\n  form?: XFormConfig;\r\n  highlight?: XHighlightConfig;\r\n  icon?: XIconConfig;\r\n  inner?: XInnerConfig;\r\n  input?: XInputConfig;\r\n  inputGroup?: XInputGroupConfig;\r\n  inputNumber?: XInputNumberConfig;\r\n  image?: XImageConfig;\r\n  col?: XColConfig;\r\n  row?: XRowConfig;\r\n  ripple?: XRippleConfig;\r\n  link?: XLinkConfig;\r\n  list?: XListConfig;\r\n  listOption?: XListOptionConfig;\r\n  loading?: XLoadingConfig;\r\n  menu?: XMenuConfig;\r\n  message?: XMessageConfig;\r\n  messageBox?: XMessageBoxConfig;\r\n  notification?: XNotificationConfig;\r\n  outlet?: XOutletConfig;\r\n  pageHeader?: XPageHeaderConfig;\r\n  pagination?: XPaginationConfig;\r\n  pattern?: XPatternConfig;\r\n  popconfirm?: XPopconfirmConfig;\r\n  popover?: XPopoverConfig;\r\n  portal?: XPortalConfig;\r\n  progress?: XProgressConfing;\r\n  radio?: XRadioConfig;\r\n  rate?: XRateConfig;\r\n  result?: XResultConfig;\r\n  select?: XSelectConfig;\r\n  skeleton?: XSkeletonConfig;\r\n  slider?: XSliderConfig;\r\n  sliderSelect?: XSliderSelectConfig;\r\n  statistic?: XStatisticConfig;\r\n  countdown?: XCountdownConfig;\r\n  steps?: XStepsConfig;\r\n  switch?: XSwitchConfig;\r\n  table?: XTableConfig;\r\n  tabs?: XTabsConfig;\r\n  tag?: XTagConfig;\r\n  textRetract?: XTextRetractConfig;\r\n  theme?: XThemeConfig;\r\n  timeAgo?: XTimeAgoConfig;\r\n  timePicker?: XTimePickerConfig;\r\n  timeRange?: XTimeRangeConfig;\r\n  timeline?: XTimelineConfig;\r\n  tooltip?: XTooltipConfig;\r\n  transfer?: XTransferConfig;\r\n  tree?: XTreeConfig;\r\n  treeFile?: XTreeFileConfig;\r\n  treeSelect?: XTreeSelectConfig;\r\n  textarea?: XTextareaConfig;\r\n  upload?: XUploadConfig;\r\n  keyword?: XKeywordConfig;\r\n}\r\n\r\nexport interface XAffixConfig {\r\n  top?: string;\r\n  left?: string;\r\n}\r\n\r\nexport interface XAlertConfig {\r\n  effect?: XEffect;\r\n  hideClose?: XBoolean;\r\n  showIcon?: XBoolean;\r\n  disabledAnimation?: XBoolean;\r\n  draggable?: XBoolean;\r\n  resizable?: XBoolean;\r\n  dragHandleTitle?: XBoolean;\r\n  duration?: XNumber;\r\n}\r\n\r\nexport interface XAnchorConfig {\r\n  affixTop?: string;\r\n  affixWidth?: string;\r\n  layout?: XPositionLeftRight;\r\n  justify?: XJustify;\r\n}\r\n\r\nexport interface XAvatarConfig {\r\n  size?: XSize;\r\n  shape?: XShape;\r\n  fit?: XFit;\r\n  gap?: number;\r\n  backgroundColor?: string;\r\n}\r\n\r\nexport interface XAutoCompleteConfig {\r\n  placement?: XPositionTopBottom;\r\n  debounceTime?: number;\r\n  size?: XSize;\r\n  bordered?: boolean;\r\n  caseSensitive?: boolean;\r\n  onlySelect?: boolean;\r\n}\r\n\r\nexport interface XBackTopConfig {\r\n  right?: string;\r\n  bottom?: string;\r\n  visibilityHeight?: XNumber;\r\n}\r\n\r\nexport interface XBadgeConfgig {\r\n  type?: XType;\r\n}\r\n\r\nexport interface XButtonConfig {\r\n  size?: XSize;\r\n  type?: XType;\r\n  plain?: XBoolean;\r\n  round?: XBoolean;\r\n  circle?: XBoolean;\r\n  attrType?: 'submit' | 'button' | 'reset';\r\n}\r\n\r\nexport interface XButtonsConfig {\r\n  space?: XNumber;\r\n  hiddenBorder?: XBoolean;\r\n}\r\n\r\nexport interface XCalendarConfig {}\r\n\r\nexport interface XCardConfig {\r\n  shadow?: XShadow;\r\n}\r\n\r\nexport interface XCarouselConfig {\r\n  height?: string;\r\n  trigger?: XTrigger;\r\n  arrow?: XShadow;\r\n  direction?: XDisplayDirection;\r\n}\r\n\r\nexport interface XCascadeConfig {\r\n  placement?: XCorner;\r\n  size?: XSize;\r\n  bordered?: boolean;\r\n  nodeTrigger?: XTrigger;\r\n  nodeHoverDelay?: XNumber;\r\n}\r\n\r\nexport interface XCheckboxConfig {\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XCollapseConfig {\r\n  showIcon?: Boolean;\r\n  ghost?: Boolean;\r\n  iconPosition?: 'left' | 'right';\r\n  bordered?: Boolean;\r\n}\r\n\r\nexport interface XColorConfig {\r\n  merge?: string;\r\n  amounts?: string;\r\n}\r\n\r\nexport interface XColorPickerConfig {\r\n  placement?: XCorner;\r\n}\r\n\r\nexport interface XCommentConfig {\r\n  contentMax?: number;\r\n}\r\n\r\nexport interface XContainerConfig {\r\n  direction?: XDirection;\r\n}\r\n\r\nexport interface XHeaderConfig {\r\n  height?: number;\r\n}\r\n\r\nexport interface XAsideConfig {\r\n  width?: number;\r\n}\r\n\r\nexport interface XFooterConfig {\r\n  height?: number;\r\n}\r\n\r\nexport interface XCrumbComfig {\r\n  separator?: string;\r\n}\r\n\r\nexport interface XDatePickerConfig {\r\n  format?: string;\r\n  clearable?: XBoolean;\r\n  placement?: XCorner;\r\n  size?: XSize;\r\n  bordered?: boolean;\r\n}\r\n\r\nexport interface XDateRangeConfig {\r\n  format?: string;\r\n  clearable?: XBoolean;\r\n  placement?: XCorner;\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n}\r\n\r\nexport interface XDialogConfig {\r\n  placement?: XPlace;\r\n  offset?: string;\r\n  width?: string;\r\n  minWidth?: string;\r\n  minHeight?: string;\r\n  effect?: XEffect;\r\n  showCancel?: XBoolean;\r\n  cancelText?: string;\r\n  showConfirm?: XBoolean;\r\n  confirmText?: string;\r\n  backdropClose?: XBoolean;\r\n  draggable?: XBoolean;\r\n  resizable?: XBoolean;\r\n  maximize?: XBoolean;\r\n  hasBackdrop?: XBoolean;\r\n  className?: string;\r\n  buttonsCenter?: XBoolean;\r\n}\r\n\r\nexport interface XDrawerConfig {\r\n  placement?: XPosition;\r\n  size?: string;\r\n  backdropClose?: XBoolean;\r\n  hasBackdrop?: XBoolean;\r\n  className?: string;\r\n}\r\n\r\nexport interface XDropdownConfig {\r\n  trigger?: XTrigger;\r\n  placement?: XPlacement;\r\n}\r\n\r\nexport interface XDescriptionConfig {\r\n  bordered?: XBoolean;\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XEmptyConfig {\r\n  img?: XTemplate;\r\n  content?: XTemplate;\r\n}\r\n\r\nexport interface XFindConfig {\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  columnLabel?: string;\r\n  dialogTitle?: string;\r\n  dialogCheckboxLabel?: string;\r\n  dialogCheckboxWidth?: number;\r\n  dialogEmptyContent?: string;\r\n  dialogButtonsCenter?: XBoolean;\r\n  tableIndex?: number;\r\n  tableSize?: number;\r\n  tableLoading?: XBoolean;\r\n  tableVirtualScroll?: boolean;\r\n  tableRowHeight?: XNumber;\r\n  treeExpandedLevel?: XNumber;\r\n}\r\n\r\nexport interface XFormConfig {\r\n  space?: XNumber;\r\n  labelSuffix?: string;\r\n  width?: string;\r\n}\r\n\r\nexport interface XHighlightConfig {}\r\n\r\nexport interface XIconConfig {\r\n  href?: string;\r\n}\r\n\r\nexport interface XInnerConfig {\r\n  padding?: string;\r\n}\r\n\r\nexport interface XInputConfig {\r\n  clearable?: XBoolean;\r\n  iconLayout?: XPositionLeftRight;\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  inputPadding?: XNumber;\r\n  inputIconPadding?: XNumber;\r\n}\r\n\r\nexport interface XInputGroupConfig {\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  compact?: XBoolean;\r\n}\r\n\r\nexport interface XInputNumberConfig {\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  hiddenButton?: XBoolean;\r\n}\r\n\r\nexport interface XImageConfig {\r\n  previewText?: string;\r\n}\r\n\r\nexport interface XColConfig {}\r\n\r\nexport interface XRowConfig {}\r\n\r\nexport interface XRippleConfig {\r\n  type?: XType;\r\n}\r\n\r\nexport interface XLinkConfig {\r\n  underline?: XBoolean;\r\n  iconRight?: XBoolean;\r\n  preventDefault?: XBoolean;\r\n}\r\n\r\nexport interface XListConfig {\r\n  selectAllText?: string;\r\n  loadMoreText?: string;\r\n  loadingMoreText?: string;\r\n  caseSensitive?: boolean;\r\n}\r\n\r\nexport interface XListOptionConfig {\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XLoadingConfig {\r\n  size?: XSize;\r\n  text?: string;\r\n  icon?: string;\r\n  color?: string;\r\n  background?: string;\r\n  zIndex?: number;\r\n}\r\n\r\nexport interface XMenuConfig {\r\n  size?: XSize;\r\n  width?: string;\r\n  trigger?: XTrigger;\r\n}\r\n\r\nexport interface XMessageConfig {\r\n  type?: XStatus;\r\n  width?: string;\r\n  placement?: XPlace;\r\n  displayType?: string;\r\n  offset?: string | string[];\r\n  duration?: number;\r\n  hideClose?: boolean;\r\n  showIcon?: boolean;\r\n}\r\n\r\nexport interface XMessageBoxConfig {}\r\n\r\nexport interface XNotificationConfig {}\r\n\r\nexport interface XOutletConfig {}\r\n\r\nexport interface XPageHeaderConfig {\r\n  backIcon?: string;\r\n  backText?: string;\r\n}\r\n\r\nexport interface XPaginationConfig {\r\n  index?: XNumber;\r\n  size?: XNumber;\r\n  space?: XNumber;\r\n  pageLinkSize?: XNumber;\r\n  hiddenBorder?: boolean;\r\n  showEllipsis?: boolean;\r\n  showTotal?: boolean;\r\n  showSize?: boolean;\r\n  sizeWidth?: number;\r\n  sizeData?: number[];\r\n  showInputSize?: boolean;\r\n  inputSizeWidth?: number;\r\n  showJump?: boolean;\r\n  jumpWidth?: number;\r\n  simple?: boolean;\r\n  simpleIndexWidth?: number;\r\n}\r\n\r\nexport interface XPatternConfig {}\r\n\r\nexport interface XPopconfirmConfig {\r\n  placement?: XPlacement;\r\n  trigger?: XTrigger;\r\n  width?: string;\r\n  icon?: string;\r\n  iconColor?: string;\r\n  cancelText?: string;\r\n  confirmText?: string;\r\n}\r\n\r\nexport interface XPopoverConfig {\r\n  placement?: XPlacement;\r\n  trigger?: XTrigger;\r\n  width?: string;\r\n}\r\n\r\nexport interface XPortalConfig {}\r\n\r\nexport interface XProgressConfing {\r\n  height?: string;\r\n  stepWidth?: string;\r\n}\r\n\r\nexport interface XRadioConfig {\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XRateConfig {\r\n  color?: string | { [color: string]: (rate: number) => boolean };\r\n}\r\n\r\nexport interface XResultConfig {}\r\n\r\nexport interface XSelectConfig {\r\n  placement?: XPositionTopBottom;\r\n  clearable?: XBoolean;\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  portalMaxHeight?: string;\r\n  selectAllText?: string;\r\n  search?: XBoolean;\r\n  caseSensitive?: XBoolean;\r\n  debounceTime?: number;\r\n  maxTagCount?: number;\r\n  virtualScroll?: XBoolean;\r\n}\r\n\r\nexport interface XSkeletonConfig {}\r\n\r\nexport interface XSliderConfig {\r\n  animated?: XBoolean;\r\n  size?: XSize;\r\n  showExpand?: XBoolean;\r\n  autoShowArrow?: XBoolean;\r\n  trigger?: XTrigger;\r\n}\r\n\r\nexport interface XSliderSelectConfig {}\r\n\r\nexport interface XStatisticConfig {}\r\n\r\nexport interface XCountdownConfig {\r\n  format?: string;\r\n}\r\n\r\nexport interface XStepsConfig {}\r\n\r\nexport interface XSwitchConfig {\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XTableConfig {\r\n  index?: number;\r\n  size?: number;\r\n  loading?: XBoolean;\r\n  showHeader?: XBoolean;\r\n  virtualScroll?: boolean;\r\n  rowHeight?: XNumber;\r\n  itemSize?: XNumber;\r\n  bordered?: XNumber;\r\n  allowSelectRow?: XBoolean;\r\n  allowCheckRow?: XBoolean;\r\n  rowSize?: XSize;\r\n  showPagination?: XBoolean;\r\n  treeTable?: XBoolean;\r\n  expandedAll?: XBoolean;\r\n  expandedLevel?: XNumber;\r\n  hiddenPaginationBorder?: XBoolean;\r\n  hiddenWrapBorder?: XBoolean;\r\n  showEmpty?: XBoolean;\r\n  emptyImg?: XTemplate;\r\n  emptyContent?: XTemplate;\r\n}\r\n\r\nexport interface XTabsConfig {\r\n  size?: XSize;\r\n  trigger?: XTrigger;\r\n}\r\n\r\nexport interface XTagConfig {\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  closable?: XBoolean;\r\n  dark?: XBoolean;\r\n}\r\n\r\nexport interface XTextRetractConfig {\r\n  max?: XNumber;\r\n}\r\n\r\nexport interface XThemeConfig {\r\n  amounts?: XNumber[];\r\n}\r\n\r\nexport interface XTimeAgoConfig {}\r\n\r\nexport interface XTimePickerConfig {\r\n  format?: string;\r\n  placement?: XCorner;\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  use12Hours?: XBoolean;\r\n  defaultNow?: XBoolean;\r\n}\r\n\r\nexport interface XTimeRangeConfig {}\r\n\r\nexport interface XTimelineConfig {\r\n  size?: XSize;\r\n}\r\n\r\nexport interface XTooltipConfig {\r\n  placement?: XPlacement;\r\n}\r\n\r\nexport interface XTransferConfig {\r\n  titles?: string[];\r\n  drag?: XBoolean;\r\n  virtualScroll?: XBoolean;\r\n}\r\n\r\nexport interface XTreeConfig {\r\n  spacing?: XNumber;\r\n  nodeHeight?: XNumber;\r\n  nodeAlignItems?: XAlign;\r\n  virtualScroll?: boolean;\r\n  onlyLeaf?: boolean;\r\n  showLine?: boolean;\r\n}\r\n\r\nexport interface XTextareaConfig {\r\n  clearable?: XBoolean;\r\n  iconLayout?: XPositionLeftRight;\r\n}\r\n\r\nexport interface XTreeFileConfig {\r\n  maxHeight?: XNumber;\r\n  spacing?: XNumber;\r\n}\r\n\r\nexport interface XTreeSelectConfig {\r\n  placement?: XPositionTopBottom;\r\n  clearable?: XBoolean;\r\n  size?: XSize;\r\n  bordered?: XBoolean;\r\n  portalMaxHeight?: string;\r\n  selectAllText?: string;\r\n  search?: XBoolean;\r\n  caseSensitive?: XBoolean;\r\n  debounceTime?: number;\r\n  maxTagCount?: number;\r\n  virtualScroll?: XBoolean;\r\n  showPath?: XBoolean;\r\n  separator?: string;\r\n  onlyLeaf?: boolean;\r\n}\r\n\r\nexport interface XUploadConfig {\r\n  download?: XBoolean;\r\n  multipleModel?: 'cover' | 'add';\r\n}\r\n\r\nexport interface XKeywordConfig {\r\n  type?: XType;\r\n  color?: string;\r\n  caseSensitive?: boolean;\r\n}\r\n"]}
@@ -41,7 +41,7 @@ export class XIconComponent extends XIconProperty {
41
41
  this.renderer.addClass(this.elementRef.nativeElement, XIconPrefix);
42
42
  }
43
43
  ngOnChanges(changes) {
44
- const { type, spin } = changes;
44
+ const { type, spin, color } = changes;
45
45
  if (XIsChange(type)) {
46
46
  this.setSvgElement();
47
47
  this.renderer.removeClass(this.elementRef.nativeElement, type.previousValue);
@@ -51,6 +51,9 @@ export class XIconComponent extends XIconProperty {
51
51
  if (XIsChange(spin)) {
52
52
  this.cdr.detectChanges();
53
53
  }
54
+ if (XIsChange(color)) {
55
+ this.renderer.setStyle(this.elementRef.nativeElement, 'color', this.color);
56
+ }
54
57
  }
55
58
  getSvg() {
56
59
  if (this._loaded)
@@ -66,13 +69,9 @@ export class XIconComponent extends XIconProperty {
66
69
  }
67
70
  setSvgElement() {
68
71
  const typeIcon = this.setSourceUrl(this.type);
69
- const toIcon = this.setSourceUrl(this.to);
70
72
  let icons = [typeIcon];
71
73
  if (XIsEmpty(typeIcon))
72
74
  return;
73
- if (!XIsEmpty(toIcon)) {
74
- icons = [...icons, toIcon];
75
- }
76
75
  this.iconService.getSvgs(this.href, ...icons).subscribe((x) => this.setSvgs(x));
77
76
  }
78
77
  setSvgs(svgs) {
@@ -82,7 +81,6 @@ export class XIconComponent extends XIconProperty {
82
81
  this.renderer.removeChild(this.elementRef.nativeElement, firstChild);
83
82
  }
84
83
  this._svgElement = this.buildSvg(svgs.shift());
85
- // this.setAnimates(svgs);
86
84
  this.setAttributes(this._svgElement);
87
85
  this.renderer.appendChild(this.elementRef.nativeElement, this._svgElement);
88
86
  this.cdr.markForCheck();
@@ -181,4 +179,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
181
179
  type: HostBinding,
182
180
  args: ['class.x-icon-spin']
183
181
  }] } });
184
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/icon/icon.component.ts","../../../../../lib/ng-nest/ui/icon/icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  Renderer2,\r\n  ChangeDetectorRef,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  HostBinding,\r\n  inject\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { XIconPrefix, XIconProperty } from './icon.property';\r\nimport { XIconService } from './icon.service';\r\nimport { warnIconTypeNotFound, warnSVGTagNotFound, XIsChange, XIsEmpty, XConfigService } from '@ng-nest/ui/core';\r\n\r\n// 来源路径对应\r\nexport const XSouceUrl: { [property: string]: string } = {\r\n  adf: `ant-design/fill/`,\r\n  ado: `ant-design/outline/`,\r\n  adt: `ant-design/twotone/`,\r\n  eaf: `eva/fill/`,\r\n  eao: `eva/outline/`,\r\n  fto: `feather/`,\r\n  fab: `font-awesome/brands/`,\r\n  far: `font-awesome/regular/`,\r\n  fas: `font-awesome/solid/`,\r\n  mdf: `material-design/fill/`,\r\n  mdo: `material-design/outline/`\r\n};\r\n\r\nexport const XViewBox = [\r\n  // { souces: [\"adf\", \"ado\", \"adt\"], value: \"0 0 1024 1024\" },\r\n  // { souces: [\"eaf\", \"eao\"], value: \"0 0 24 24\" },\r\n  // { souces: [\"fto\"], value: \"0 0 24 24\" }\r\n];\r\n\r\n@Component({\r\n  selector: `${XIconPrefix}`,\r\n  standalone: true,\r\n  templateUrl: './icon.component.html',\r\n  styleUrls: ['./style/index.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XIconComponent extends XIconProperty implements OnInit, OnChanges {\r\n  private _svgElement!: SVGElement;\r\n  private _loaded: boolean = false;\r\n  private document = inject(DOCUMENT);\r\n  private elementRef = inject(ElementRef);\r\n  private renderer = inject(Renderer2);\r\n  private iconService = inject(XIconService);\r\n  private cdr = inject(ChangeDetectorRef);\r\n  configService = inject(XConfigService);\r\n\r\n  @HostBinding('class.x-icon-spin') get getSpin() {\r\n    return this.spin;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.renderer.addClass(this.elementRef.nativeElement, XIconPrefix);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { type, spin } = changes;\r\n    if (XIsChange(type)) {\r\n      this.setSvgElement();\r\n      this.renderer.removeClass(this.elementRef.nativeElement, type.previousValue);\r\n      this.renderer.addClass(this.elementRef.nativeElement, `${this.type}`);\r\n      this.cdr.detectChanges();\r\n    }\r\n    if (XIsChange(spin)) {\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  getSvg() {\r\n    if (this._loaded) return;\r\n    let height = this.document.documentElement.clientHeight;\r\n    let width = this.document.documentElement.clientWidth;\r\n    let box = this.elementRef.nativeElement.getBoundingClientRect();\r\n    if (box.top <= height && box.left <= width) {\r\n      this.setSvgElement();\r\n      this.renderer.addClass(this.elementRef.nativeElement, `${this.type}`);\r\n      this._loaded = true;\r\n    }\r\n  }\r\n\r\n  setSvgElement() {\r\n    const typeIcon = this.setSourceUrl(this.type);\r\n    const toIcon = this.setSourceUrl(this.to);\r\n    let icons = [typeIcon];\r\n    if (XIsEmpty(typeIcon)) return;\r\n    if (!XIsEmpty(toIcon)) {\r\n      icons = [...icons, toIcon];\r\n    }\r\n    this.iconService.getSvgs(this.href!, ...icons).subscribe((x) => this.setSvgs(x));\r\n  }\r\n\r\n  setSvgs(svgs: string[]) {\r\n    if (svgs?.length > 0) {\r\n      let firstChild = this.elementRef.nativeElement.firstChild;\r\n      if (firstChild) {\r\n        this.renderer.removeChild(this.elementRef.nativeElement, firstChild);\r\n      }\r\n      this._svgElement = this.buildSvg(svgs.shift() as string) as SVGSVGElement;\r\n      // this.setAnimates(svgs);\r\n      this.setAttributes(this._svgElement);\r\n      this.renderer.appendChild(this.elementRef.nativeElement, this._svgElement);\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  setSourceUrl(type?: string) {\r\n    if (typeof type === 'undefined') return '';\r\n    const split = type.split('-');\r\n    const souce = split.shift();\r\n    if (typeof souce === 'undefined') return '';\r\n    const souceUrl = XSouceUrl[souce];\r\n    const fileName = split.join('-');\r\n    if (!souceUrl || !fileName) {\r\n      warnIconTypeNotFound();\r\n    }\r\n    return `${souceUrl}${fileName}`;\r\n  }\r\n\r\n  setAttributes(svgEle: SVGElement) {\r\n    if (svgEle) {\r\n      this.renderer.setAttribute(svgEle, 'width', '1em');\r\n      this.renderer.setAttribute(svgEle, 'height', '1em');\r\n    }\r\n  }\r\n\r\n  buildSvg(svgStr: string): SVGSVGElement | undefined {\r\n    const result = this.document.createElementNS('http://www.w3.org/2000/svg', 'svg') as SVGSVGElement;\r\n    const svg = this.createSvg(svgStr);\r\n    if (!svg) return;\r\n    svg.children.forEach((x) => {\r\n      x.removeAttribute('class');\r\n      if (x.tagName === 'rect') {\r\n        x.setAttribute('fill', 'none');\r\n      }\r\n      result.appendChild(x);\r\n    });\r\n    this.setAttribute(result, svg.ele, 'viewBox');\r\n    this.setAttribute(result, svg.ele, 'fill', 'currentColor');\r\n    this.setAttribute(result, svg.ele, 'stroke');\r\n    this.setAttribute(result, svg.ele, 'stroke-width');\r\n    this.setAttribute(result, svg.ele, 'stroke-linecap');\r\n    this.setAttribute(result, svg.ele, 'stroke-linejoin');\r\n    if (!result) {\r\n      warnSVGTagNotFound();\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  createSvg(svgStr: string) {\r\n    const div = this.document.createElement('div');\r\n    div.innerHTML = svgStr;\r\n    let svgEle = div.querySelector('svg') as SVGElement;\r\n    if (!svgEle) return null;\r\n    return {\r\n      ele: svgEle,\r\n      children: svgEle.querySelectorAll('path, polyline, polygon, circle, line, rect')\r\n    };\r\n  }\r\n\r\n  setAttribute(svg: SVGElement, svgEle: SVGElement, attribute: string, def?: string) {\r\n    let attr = svgEle.getAttribute(attribute);\r\n    if (attr) {\r\n      svg.setAttribute(attribute, attr);\r\n    } else if (def) {\r\n      svg.setAttribute(attribute, def);\r\n    }\r\n  }\r\n\r\n  //<animate begin=\"mouseenter\" dur=\"500ms\" repeatCount=\"1\" attributeName=\"d\" from=\"M86.425,13.204l5.648,12.741H0.55   l0.125-12.616L0.55,0.544h91.523L86.425,13.204z\" to=\"M92.725,13.521l0.044,12.887H1.245   l7-12.616l-7-12.785h91.523L92.725,13.521z\" fill=\"freeze\"></animate>\r\n\r\n  setAnimates(svgs: string[]) {\r\n    if (svgs?.length > 0) {\r\n      let svg = this.createSvg(svgs.shift() as string);\r\n      for (let i = 0; i < this._svgElement.children.length; i++) {\r\n        let child = this._svgElement.children[i];\r\n        let toChild = svg?.children[i];\r\n        if (child?.nodeName === 'path' && toChild?.nodeName === 'path') {\r\n          let toAnimate = this.document.createElement('animate');\r\n          toAnimate.setAttribute('dur', '500ms');\r\n          toAnimate.setAttribute('repeatCount', '1');\r\n          toAnimate.setAttribute('attributeName', 'd');\r\n          toAnimate.setAttribute('fill', 'freeze');\r\n          toAnimate.setAttribute('from', child.getAttribute('d') as string);\r\n          toAnimate.setAttribute('to', toChild.getAttribute('d') as string);\r\n          this.renderer.appendChild(child, toAnimate);\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n","\r\n"]}
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/icon/icon.component.ts","../../../../../lib/ng-nest/ui/icon/icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  Renderer2,\r\n  ChangeDetectorRef,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  HostBinding,\r\n  inject\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { XIconPrefix, XIconProperty } from './icon.property';\r\nimport { XIconService } from './icon.service';\r\nimport { warnIconTypeNotFound, warnSVGTagNotFound, XIsChange, XIsEmpty, XConfigService } from '@ng-nest/ui/core';\r\n\r\n// 来源路径对应\r\nexport const XSouceUrl: { [property: string]: string } = {\r\n  adf: `ant-design/fill/`,\r\n  ado: `ant-design/outline/`,\r\n  adt: `ant-design/twotone/`,\r\n  eaf: `eva/fill/`,\r\n  eao: `eva/outline/`,\r\n  fto: `feather/`,\r\n  fab: `font-awesome/brands/`,\r\n  far: `font-awesome/regular/`,\r\n  fas: `font-awesome/solid/`,\r\n  mdf: `material-design/fill/`,\r\n  mdo: `material-design/outline/`\r\n};\r\n\r\nexport const XViewBox = [\r\n  // { souces: [\"adf\", \"ado\", \"adt\"], value: \"0 0 1024 1024\" },\r\n  // { souces: [\"eaf\", \"eao\"], value: \"0 0 24 24\" },\r\n  // { souces: [\"fto\"], value: \"0 0 24 24\" }\r\n];\r\n\r\n@Component({\r\n  selector: `${XIconPrefix}`,\r\n  standalone: true,\r\n  templateUrl: './icon.component.html',\r\n  styleUrls: ['./style/index.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XIconComponent extends XIconProperty implements OnInit, OnChanges {\r\n  private _svgElement!: SVGElement;\r\n  private _loaded: boolean = false;\r\n  private document = inject(DOCUMENT);\r\n  private elementRef = inject(ElementRef);\r\n  private renderer = inject(Renderer2);\r\n  private iconService = inject(XIconService);\r\n  private cdr = inject(ChangeDetectorRef);\r\n  configService = inject(XConfigService);\r\n\r\n  @HostBinding('class.x-icon-spin') get getSpin() {\r\n    return this.spin;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.renderer.addClass(this.elementRef.nativeElement, XIconPrefix);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { type, spin, color } = changes;\r\n    if (XIsChange(type)) {\r\n      this.setSvgElement();\r\n      this.renderer.removeClass(this.elementRef.nativeElement, type.previousValue);\r\n      this.renderer.addClass(this.elementRef.nativeElement, `${this.type}`);\r\n      this.cdr.detectChanges();\r\n    }\r\n    if (XIsChange(spin)) {\r\n      this.cdr.detectChanges();\r\n    }\r\n    if (XIsChange(color)) {\r\n      this.renderer.setStyle(this.elementRef.nativeElement, 'color', this.color);\r\n    }\r\n  }\r\n\r\n  getSvg() {\r\n    if (this._loaded) return;\r\n    let height = this.document.documentElement.clientHeight;\r\n    let width = this.document.documentElement.clientWidth;\r\n    let box = this.elementRef.nativeElement.getBoundingClientRect();\r\n    if (box.top <= height && box.left <= width) {\r\n      this.setSvgElement();\r\n      this.renderer.addClass(this.elementRef.nativeElement, `${this.type}`);\r\n      this._loaded = true;\r\n    }\r\n  }\r\n\r\n  setSvgElement() {\r\n    const typeIcon = this.setSourceUrl(this.type);\r\n    let icons = [typeIcon];\r\n    if (XIsEmpty(typeIcon)) return;\r\n    this.iconService.getSvgs(this.href!, ...icons).subscribe((x) => this.setSvgs(x));\r\n  }\r\n\r\n  setSvgs(svgs: string[]) {\r\n    if (svgs?.length > 0) {\r\n      let firstChild = this.elementRef.nativeElement.firstChild;\r\n      if (firstChild) {\r\n        this.renderer.removeChild(this.elementRef.nativeElement, firstChild);\r\n      }\r\n      this._svgElement = this.buildSvg(svgs.shift() as string) as SVGSVGElement;\r\n      this.setAttributes(this._svgElement);\r\n      this.renderer.appendChild(this.elementRef.nativeElement, this._svgElement);\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  setSourceUrl(type?: string) {\r\n    if (typeof type === 'undefined') return '';\r\n    const split = type.split('-');\r\n    const souce = split.shift();\r\n    if (typeof souce === 'undefined') return '';\r\n    const souceUrl = XSouceUrl[souce];\r\n    const fileName = split.join('-');\r\n    if (!souceUrl || !fileName) {\r\n      warnIconTypeNotFound();\r\n    }\r\n    return `${souceUrl}${fileName}`;\r\n  }\r\n\r\n  setAttributes(svgEle: SVGElement) {\r\n    if (svgEle) {\r\n      this.renderer.setAttribute(svgEle, 'width', '1em');\r\n      this.renderer.setAttribute(svgEle, 'height', '1em');\r\n    }\r\n  }\r\n\r\n  buildSvg(svgStr: string): SVGSVGElement | undefined {\r\n    const result = this.document.createElementNS('http://www.w3.org/2000/svg', 'svg') as SVGSVGElement;\r\n    const svg = this.createSvg(svgStr);\r\n    if (!svg) return;\r\n    svg.children.forEach((x) => {\r\n      x.removeAttribute('class');\r\n      if (x.tagName === 'rect') {\r\n        x.setAttribute('fill', 'none');\r\n      }\r\n      result.appendChild(x);\r\n    });\r\n    this.setAttribute(result, svg.ele, 'viewBox');\r\n    this.setAttribute(result, svg.ele, 'fill', 'currentColor');\r\n    this.setAttribute(result, svg.ele, 'stroke');\r\n    this.setAttribute(result, svg.ele, 'stroke-width');\r\n    this.setAttribute(result, svg.ele, 'stroke-linecap');\r\n    this.setAttribute(result, svg.ele, 'stroke-linejoin');\r\n    if (!result) {\r\n      warnSVGTagNotFound();\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  createSvg(svgStr: string) {\r\n    const div = this.document.createElement('div');\r\n    div.innerHTML = svgStr;\r\n    let svgEle = div.querySelector('svg') as SVGElement;\r\n    if (!svgEle) return null;\r\n    return {\r\n      ele: svgEle,\r\n      children: svgEle.querySelectorAll('path, polyline, polygon, circle, line, rect')\r\n    };\r\n  }\r\n\r\n  setAttribute(svg: SVGElement, svgEle: SVGElement, attribute: string, def?: string) {\r\n    let attr = svgEle.getAttribute(attribute);\r\n    if (attr) {\r\n      svg.setAttribute(attribute, attr);\r\n    } else if (def) {\r\n      svg.setAttribute(attribute, def);\r\n    }\r\n  }\r\n\r\n  //<animate begin=\"mouseenter\" dur=\"500ms\" repeatCount=\"1\" attributeName=\"d\" from=\"M86.425,13.204l5.648,12.741H0.55   l0.125-12.616L0.55,0.544h91.523L86.425,13.204z\" to=\"M92.725,13.521l0.044,12.887H1.245   l7-12.616l-7-12.785h91.523L92.725,13.521z\" fill=\"freeze\"></animate>\r\n\r\n  setAnimates(svgs: string[]) {\r\n    if (svgs?.length > 0) {\r\n      let svg = this.createSvg(svgs.shift() as string);\r\n      for (let i = 0; i < this._svgElement.children.length; i++) {\r\n        let child = this._svgElement.children[i];\r\n        let toChild = svg?.children[i];\r\n        if (child?.nodeName === 'path' && toChild?.nodeName === 'path') {\r\n          let toAnimate = this.document.createElement('animate');\r\n          toAnimate.setAttribute('dur', '500ms');\r\n          toAnimate.setAttribute('repeatCount', '1');\r\n          toAnimate.setAttribute('attributeName', 'd');\r\n          toAnimate.setAttribute('fill', 'freeze');\r\n          toAnimate.setAttribute('from', child.getAttribute('d') as string);\r\n          toAnimate.setAttribute('to', toChild.getAttribute('d') as string);\r\n          this.renderer.appendChild(child, toAnimate);\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n","\r\n"]}
@@ -15,7 +15,7 @@ export const XIconHref = 'https://ngnest.com/static/icons/';
15
15
  */
16
16
  export class XIconProperty extends XProperty {
17
17
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: XIconProperty, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
18
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: XIconProperty, selector: "x-icon-property", inputs: { href: "href", type: "type", color: "color", rotate: "rotate", spin: "spin", to: "to" }, usesInheritance: true, ngImport: i0, template: '', isInline: true }); }
18
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: XIconProperty, selector: "x-icon-property", inputs: { href: "href", type: "type", color: "color", rotate: "rotate", spin: "spin" }, usesInheritance: true, ngImport: i0, template: '', isInline: true }); }
19
19
  }
20
20
  __decorate([
21
21
  XWithConfig(X_CONFIG_NAME, XIconHref)
@@ -39,7 +39,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
39
39
  type: Input
40
40
  }], spin: [{
41
41
  type: Input
42
- }], to: [{
43
- type: Input
44
42
  }] } });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5wcm9wZXJ0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL2ljb24vaWNvbi5wcm9wZXJ0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxZQUFZLEVBQ1osYUFBYSxFQUdiLFdBQVcsRUFDWixNQUFNLGtCQUFrQixDQUFDO0FBQzFCLE9BQU8sRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVqRDs7OztHQUlHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLFFBQVEsQ0FBQztBQUVwQyxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUM7QUFFN0IsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUFHLGtDQUFrQyxDQUFDO0FBRTVEOztHQUVHO0FBRUgsTUFBTSxPQUFPLGFBQWMsU0FBUSxTQUFTO2lJQUEvQixhQUFhO3FIQUFiLGFBQWEsZ0xBRGtDLEVBQUU7O0FBTUo7SUFBOUMsV0FBVyxDQUFTLGFBQWEsRUFBRSxTQUFTLENBQUM7MkNBQWU7QUFlN0M7SUFBZixZQUFZLEVBQUU7NkNBQWtCO0FBS2hCO0lBQWhCLGFBQWEsRUFBRTsyQ0FBaUI7MkZBekIvQixhQUFhO2tCQUR6QixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLEdBQUcsV0FBVyxXQUFXLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRTs4QkFNTixJQUFJO3NCQUEzRCxLQUFLO2dCQUtHLElBQUk7c0JBQVosS0FBSztnQkFLRyxLQUFLO3NCQUFiLEtBQUs7Z0JBS21CLE1BQU07c0JBQTlCLEtBQUs7Z0JBS29CLElBQUk7c0JBQTdCLEtBQUs7Z0JBS0csRUFBRTtzQkFBVixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBYUHJvcGVydHksXHJcbiAgWElucHV0TnVtYmVyLFxyXG4gIFhJbnB1dEJvb2xlYW4sXHJcbiAgWE51bWJlcixcclxuICBYQm9vbGVhbixcclxuICBYV2l0aENvbmZpZ1xyXG59IGZyb20gJ0BuZy1uZXN0L3VpL2NvcmUnO1xyXG5pbXBvcnQgeyBJbnB1dCwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKipcclxuICogSWNvblxyXG4gKiBAc2VsZWN0b3IgeC1pY29uXHJcbiAqIEBkZWNvcmF0b3IgY29tcG9uZW50XHJcbiAqL1xyXG5leHBvcnQgY29uc3QgWEljb25QcmVmaXggPSAneC1pY29uJztcclxuXHJcbmNvbnN0IFhfQ09ORklHX05BTUUgPSAnaWNvbic7XHJcblxyXG5leHBvcnQgY29uc3QgWEljb25IcmVmID0gJ2h0dHBzOi8vbmduZXN0LmNvbS9zdGF0aWMvaWNvbnMvJztcclxuXHJcbi8qKlxyXG4gKiBJY29uIFByb3BlcnR5XHJcbiAqL1xyXG5AQ29tcG9uZW50KHsgc2VsZWN0b3I6IGAke1hJY29uUHJlZml4fS1wcm9wZXJ0eWAsIHRlbXBsYXRlOiAnJyB9KVxyXG5leHBvcnQgY2xhc3MgWEljb25Qcm9wZXJ0eSBleHRlbmRzIFhQcm9wZXJ0eSB7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIFNWRyDlm77moIfmoLnot6/lvoTlnLDlnYDvvIzlj6/ku6XpgJrov4flhajlsYDlj6rphY3nva7kuIDmrKHvvIzmiYDmnInlm77moIfotYTmupDlnKggZ2l0aHViIOS4iueahCBuZy1uZXN0LWljb24g5LitXHJcbiAgICogQGVuX1VTIFRoZSByb290IGFkZHJlc3Mgb2YgdGhlIFNWRyBpY29uIGNhbiBiZSBjb25maWd1cmVkIG9ubHkgb25jZSBnbG9iYWxseS4gQWxsIGljb24gcmVzb3VyY2VzIGFyZSBpbiBuZy1uZXN0LWljb24gb24gZ2l0aHViXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPHN0cmluZz4oWF9DT05GSUdfTkFNRSwgWEljb25IcmVmKSBocmVmITogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlm77moIfnsbvlnotcclxuICAgKiBAZW5fVVMgSWNvbiB0eXBlXHJcbiAgICovXHJcbiAgQElucHV0KCkgdHlwZT86IHN0cmluZztcclxuICAvKipcclxuICAgKiBAemhfQ04g5Zu+5qCH6aKc6ImyXHJcbiAgICogQGVuX1VTIEljb24gY29sb3JcclxuICAgKi9cclxuICBASW5wdXQoKSBjb2xvcj86IHN0cmluZyB8IHN0cmluZ1tdO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlm77moIfml4vovazop5LluqZcclxuICAgKiBAZW5fVVMgSWNvbiByb3RhdGlvbiBhbmdsZVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIEBYSW5wdXROdW1iZXIoKSByb3RhdGU/OiBYTnVtYmVyO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiBsb2FkaW5n5pWI5p6c77yI5Zu+5qCH5LiA55u05peL6L2s77yJXHJcbiAgICogQGVuX1VTIExvYWRpbmcgZWZmZWN0IChpY29uIGtlZXBzIHJvdGF0aW5nKVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIEBYSW5wdXRCb29sZWFuKCkgc3Bpbj86IFhCb29sZWFuO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlj5jljJbkuLrnmoTlm77moIfvvIjmnKrlrp7njrDvvIlcclxuICAgKiBAZW5fVVMgSWNvbiB0byBjaGFuZ2UgdG8gKG5vdCBpbXBsZW1lbnRlZClcclxuICAgKi9cclxuICBASW5wdXQoKSB0bz86IHN0cmluZztcclxufVxyXG5cclxuLyoqXHJcbiAqIEB6aF9DTiDlm77moIfmnaXmupBcclxuICogQGVuX1VTIEljb24gc291cmNlXHJcbiAqL1xyXG5leHBvcnQgdHlwZSBYSWNvblNvdXJjZSA9ICdhbnQtZGVzaWduJyB8ICdldmEnIHwgJ2ZlYXRoZXInIHwgJ2ZvbnQtYXdlc29tZScgfCAnbWF0ZXJpYWwtZGVzaWduJztcclxuIl19
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5wcm9wZXJ0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL2ljb24vaWNvbi5wcm9wZXJ0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsYUFBYSxFQUFxQixXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUMxRyxPQUFPLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFakQ7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxRQUFRLENBQUM7QUFFcEMsTUFBTSxhQUFhLEdBQUcsTUFBTSxDQUFDO0FBRTdCLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxrQ0FBa0MsQ0FBQztBQUU1RDs7R0FFRztBQUVILE1BQU0sT0FBTyxhQUFjLFNBQVEsU0FBUztpSUFBL0IsYUFBYTtxSEFBYixhQUFhLHNLQURrQyxFQUFFOztBQU1KO0lBQTlDLFdBQVcsQ0FBUyxhQUFhLEVBQUUsU0FBUyxDQUFDOzJDQUFlO0FBZTdDO0lBQWYsWUFBWSxFQUFFOzZDQUFrQjtBQUtoQjtJQUFoQixhQUFhLEVBQUU7MkNBQWlCOzJGQXpCL0IsYUFBYTtrQkFEekIsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSxHQUFHLFdBQVcsV0FBVyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUU7OEJBTU4sSUFBSTtzQkFBM0QsS0FBSztnQkFLRyxJQUFJO3NCQUFaLEtBQUs7Z0JBS0csS0FBSztzQkFBYixLQUFLO2dCQUttQixNQUFNO3NCQUE5QixLQUFLO2dCQUtvQixJQUFJO3NCQUE3QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgWFByb3BlcnR5LCBYSW5wdXROdW1iZXIsIFhJbnB1dEJvb2xlYW4sIFhOdW1iZXIsIFhCb29sZWFuLCBYV2l0aENvbmZpZyB9IGZyb20gJ0BuZy1uZXN0L3VpL2NvcmUnO1xyXG5pbXBvcnQgeyBJbnB1dCwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKipcclxuICogSWNvblxyXG4gKiBAc2VsZWN0b3IgeC1pY29uXHJcbiAqIEBkZWNvcmF0b3IgY29tcG9uZW50XHJcbiAqL1xyXG5leHBvcnQgY29uc3QgWEljb25QcmVmaXggPSAneC1pY29uJztcclxuXHJcbmNvbnN0IFhfQ09ORklHX05BTUUgPSAnaWNvbic7XHJcblxyXG5leHBvcnQgY29uc3QgWEljb25IcmVmID0gJ2h0dHBzOi8vbmduZXN0LmNvbS9zdGF0aWMvaWNvbnMvJztcclxuXHJcbi8qKlxyXG4gKiBJY29uIFByb3BlcnR5XHJcbiAqL1xyXG5AQ29tcG9uZW50KHsgc2VsZWN0b3I6IGAke1hJY29uUHJlZml4fS1wcm9wZXJ0eWAsIHRlbXBsYXRlOiAnJyB9KVxyXG5leHBvcnQgY2xhc3MgWEljb25Qcm9wZXJ0eSBleHRlbmRzIFhQcm9wZXJ0eSB7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIFNWRyDlm77moIfmoLnot6/lvoTlnLDlnYDvvIzlj6/ku6XpgJrov4flhajlsYDlj6rphY3nva7kuIDmrKHvvIzmiYDmnInlm77moIfotYTmupDlnKggZ2l0aHViIOS4iueahCBuZy1uZXN0LWljb24g5LitXHJcbiAgICogQGVuX1VTIFRoZSByb290IGFkZHJlc3Mgb2YgdGhlIFNWRyBpY29uIGNhbiBiZSBjb25maWd1cmVkIG9ubHkgb25jZSBnbG9iYWxseS4gQWxsIGljb24gcmVzb3VyY2VzIGFyZSBpbiBuZy1uZXN0LWljb24gb24gZ2l0aHViXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPHN0cmluZz4oWF9DT05GSUdfTkFNRSwgWEljb25IcmVmKSBocmVmITogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlm77moIfnsbvlnotcclxuICAgKiBAZW5fVVMgSWNvbiB0eXBlXHJcbiAgICovXHJcbiAgQElucHV0KCkgdHlwZT86IHN0cmluZztcclxuICAvKipcclxuICAgKiBAemhfQ04g5Zu+5qCH6aKc6ImyXHJcbiAgICogQGVuX1VTIEljb24gY29sb3JcclxuICAgKi9cclxuICBASW5wdXQoKSBjb2xvcj86IHN0cmluZztcclxuICAvKipcclxuICAgKiBAemhfQ04g5Zu+5qCH5peL6L2s6KeS5bqmXHJcbiAgICogQGVuX1VTIEljb24gcm90YXRpb24gYW5nbGVcclxuICAgKi9cclxuICBASW5wdXQoKSBAWElucHV0TnVtYmVyKCkgcm90YXRlPzogWE51bWJlcjtcclxuICAvKipcclxuICAgKiBAemhfQ04gbG9hZGluZ+aViOaenO+8iOWbvuagh+S4gOebtOaXi+i9rO+8iVxyXG4gICAqIEBlbl9VUyBMb2FkaW5nIGVmZmVjdCAoaWNvbiBrZWVwcyByb3RhdGluZylcclxuICAgKi9cclxuICBASW5wdXQoKSBAWElucHV0Qm9vbGVhbigpIHNwaW4/OiBYQm9vbGVhbjtcclxufVxyXG5cclxuLyoqXHJcbiAqIEB6aF9DTiDlm77moIfmnaXmupBcclxuICogQGVuX1VTIEljb24gc291cmNlXHJcbiAqL1xyXG5leHBvcnQgdHlwZSBYSWNvblNvdXJjZSA9ICdhbnQtZGVzaWduJyB8ICdldmEnIHwgJ2ZlYXRoZXInIHwgJ2ZvbnQtYXdlc29tZScgfCAnbWF0ZXJpYWwtZGVzaWduJztcclxuIl19
@@ -138,11 +138,11 @@ export class XInputNumberComponent extends XInputNumberProperty {
138
138
  this.cdr.detectChanges();
139
139
  }
140
140
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: XInputNumberComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
141
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: XInputNumberComponent, isStandalone: true, selector: "x-input-number", providers: [XValueAccessor(XInputNumberComponent)], viewQueries: [{ propertyName: "inputNumber", first: true, predicate: ["inputNumber"], descendants: true, static: true }, { propertyName: "inputEleRef", first: true, predicate: XInputComponent, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div #inputNumber class=\"x-input-number\">\r\n <div class=\"x-input-number-row\">\r\n <ng-template #beforeButtonTpl>\r\n <x-button\r\n class=\"x-input-number-reduce\"\r\n icon=\"fto-minus\"\r\n [size]=\"size\"\r\n [onlyIcon]=\"!bordered\"\r\n [disabled]=\"disabled || minDisabled\"\r\n (click)=\"!minDisabled && plus($event, step, false); formControlValidator()\"\r\n attrType=\"button\"\r\n (mousedown)=\"!minDisabled && down($event, step, false)\"\r\n (mouseup)=\"up($event)\"\r\n ></x-button>\r\n </ng-template>\r\n <x-input\r\n #inputEleRef\r\n class=\"x-input-number-input\"\r\n [label]=\"label\"\r\n [labelWidth]=\"labelWidth\"\r\n [labelAlign]=\"labelAlign\"\r\n [justify]=\"justify\"\r\n [align]=\"align\"\r\n [direction]=\"direction\"\r\n [disabled]=\"disabled\"\r\n [required]=\"required\"\r\n [validator]=\"validator\"\r\n [icon]=\"icon\"\r\n [iconSpin]=\"iconSpin\"\r\n [placeholder]=\"placeholder\"\r\n [readonly]=\"readonly\"\r\n [clearable]=\"clearable\"\r\n [(ngModel)]=\"displayValue\"\r\n (ngModelChange)=\"change($event)\"\r\n [valueTpl]=\"valueTpl\"\r\n [valueTplContext]=\"valueTplContext\"\r\n [size]=\"size\"\r\n [bordered]=\"bordered\"\r\n [before]=\"beforeButtonTpl\"\r\n [after]=\"afterButtonTpl\"\r\n [pattern]=\"pattern\"\r\n [message]=\"message\"\r\n (xInput)=\"onInput($event); formControlValidator()\"\r\n (xBlur)=\"onBlur()\"\r\n ></x-input>\r\n <ng-template #afterButtonTpl>\r\n <x-button\r\n class=\"x-input-number-plus\"\r\n icon=\"fto-plus\"\r\n [size]=\"size\"\r\n [onlyIcon]=\"!bordered\"\r\n [disabled]=\"disabled || maxDisabled\"\r\n (click)=\"!maxDisabled && plus($event, step); formControlValidator()\"\r\n attrType=\"button\"\r\n (mousedown)=\"!maxDisabled && down($event, step)\"\r\n (mouseup)=\"up($event)\"\r\n ></x-button>\r\n </ng-template>\r\n @if (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 }\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-input-number{display:inline-block;width:12rem}.x-input-number{margin:0;padding:0;width:100%}.x-input-number-input{width:100%}.x-input-number-input input{text-align:center}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: XInputComponent, selector: "x-input" }, { kind: "component", type: XButtonComponent, selector: "x-button" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
141
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: XInputNumberComponent, isStandalone: true, selector: "x-input-number", providers: [XValueAccessor(XInputNumberComponent)], viewQueries: [{ propertyName: "inputNumber", first: true, predicate: ["inputNumber"], descendants: true, static: true }, { propertyName: "inputEleRef", first: true, predicate: XInputComponent, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div #inputNumber class=\"x-input-number\" [class.x-input-number-hidden-button]=\"hiddenButton\">\r\n <div class=\"x-input-number-row\">\r\n <ng-template #beforeButtonTpl>\r\n <x-button\r\n class=\"x-input-number-reduce\"\r\n icon=\"fto-minus\"\r\n [size]=\"size\"\r\n [onlyIcon]=\"!bordered\"\r\n [disabled]=\"disabled || minDisabled\"\r\n (click)=\"!minDisabled && plus($event, step, false); formControlValidator()\"\r\n attrType=\"button\"\r\n (mousedown)=\"!minDisabled && down($event, step, false)\"\r\n (mouseup)=\"up($event)\"\r\n ></x-button>\r\n </ng-template>\r\n <x-input\r\n #inputEleRef\r\n class=\"x-input-number-input\"\r\n [label]=\"label\"\r\n [labelWidth]=\"labelWidth\"\r\n [labelAlign]=\"labelAlign\"\r\n [justify]=\"justify\"\r\n [align]=\"align\"\r\n [direction]=\"direction\"\r\n [disabled]=\"disabled\"\r\n [required]=\"required\"\r\n [validator]=\"validator\"\r\n [icon]=\"icon\"\r\n [iconSpin]=\"iconSpin\"\r\n [placeholder]=\"placeholder\"\r\n [readonly]=\"readonly\"\r\n [clearable]=\"clearable\"\r\n [(ngModel)]=\"displayValue\"\r\n (ngModelChange)=\"change($event)\"\r\n [valueTpl]=\"valueTpl\"\r\n [valueTplContext]=\"valueTplContext\"\r\n [size]=\"size\"\r\n [bordered]=\"bordered\"\r\n [before]=\"hiddenButton ? '' : beforeButtonTpl\"\r\n [after]=\"hiddenButton ? '' : afterButtonTpl\"\r\n [pattern]=\"pattern\"\r\n [message]=\"message\"\r\n (xInput)=\"onInput($event); formControlValidator()\"\r\n (xBlur)=\"onBlur()\"\r\n ></x-input>\r\n <ng-template #afterButtonTpl>\r\n <x-button\r\n class=\"x-input-number-plus\"\r\n icon=\"fto-plus\"\r\n [size]=\"size\"\r\n [onlyIcon]=\"!bordered\"\r\n [disabled]=\"disabled || maxDisabled\"\r\n (click)=\"!maxDisabled && plus($event, step); formControlValidator()\"\r\n attrType=\"button\"\r\n (mousedown)=\"!maxDisabled && down($event, step)\"\r\n (mouseup)=\"up($event)\"\r\n ></x-button>\r\n </ng-template>\r\n @if (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 }\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-input-number{display:inline-block;width:12rem}.x-input-number{margin:0;padding:0;width:100%}.x-input-number-input{width:100%}.x-input-number-input input{text-align:center}.x-input-number-hidden-button .x-input-number-input input{text-align:left}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: XInputComponent, selector: "x-input" }, { kind: "component", type: XButtonComponent, selector: "x-button" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
142
142
  }
143
143
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: XInputNumberComponent, decorators: [{
144
144
  type: Component,
145
- args: [{ selector: `${XInputNumberPrefix}`, standalone: true, imports: [FormsModule, ReactiveFormsModule, XInputComponent, XButtonComponent], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XInputNumberComponent)], template: "<div #inputNumber class=\"x-input-number\">\r\n <div class=\"x-input-number-row\">\r\n <ng-template #beforeButtonTpl>\r\n <x-button\r\n class=\"x-input-number-reduce\"\r\n icon=\"fto-minus\"\r\n [size]=\"size\"\r\n [onlyIcon]=\"!bordered\"\r\n [disabled]=\"disabled || minDisabled\"\r\n (click)=\"!minDisabled && plus($event, step, false); formControlValidator()\"\r\n attrType=\"button\"\r\n (mousedown)=\"!minDisabled && down($event, step, false)\"\r\n (mouseup)=\"up($event)\"\r\n ></x-button>\r\n </ng-template>\r\n <x-input\r\n #inputEleRef\r\n class=\"x-input-number-input\"\r\n [label]=\"label\"\r\n [labelWidth]=\"labelWidth\"\r\n [labelAlign]=\"labelAlign\"\r\n [justify]=\"justify\"\r\n [align]=\"align\"\r\n [direction]=\"direction\"\r\n [disabled]=\"disabled\"\r\n [required]=\"required\"\r\n [validator]=\"validator\"\r\n [icon]=\"icon\"\r\n [iconSpin]=\"iconSpin\"\r\n [placeholder]=\"placeholder\"\r\n [readonly]=\"readonly\"\r\n [clearable]=\"clearable\"\r\n [(ngModel)]=\"displayValue\"\r\n (ngModelChange)=\"change($event)\"\r\n [valueTpl]=\"valueTpl\"\r\n [valueTplContext]=\"valueTplContext\"\r\n [size]=\"size\"\r\n [bordered]=\"bordered\"\r\n [before]=\"beforeButtonTpl\"\r\n [after]=\"afterButtonTpl\"\r\n [pattern]=\"pattern\"\r\n [message]=\"message\"\r\n (xInput)=\"onInput($event); formControlValidator()\"\r\n (xBlur)=\"onBlur()\"\r\n ></x-input>\r\n <ng-template #afterButtonTpl>\r\n <x-button\r\n class=\"x-input-number-plus\"\r\n icon=\"fto-plus\"\r\n [size]=\"size\"\r\n [onlyIcon]=\"!bordered\"\r\n [disabled]=\"disabled || maxDisabled\"\r\n (click)=\"!maxDisabled && plus($event, step); formControlValidator()\"\r\n attrType=\"button\"\r\n (mousedown)=\"!maxDisabled && down($event, step)\"\r\n (mouseup)=\"up($event)\"\r\n ></x-button>\r\n </ng-template>\r\n @if (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 }\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-input-number{display:inline-block;width:12rem}.x-input-number{margin:0;padding:0;width:100%}.x-input-number-input{width:100%}.x-input-number-input input{text-align:center}\n"] }]
145
+ args: [{ selector: `${XInputNumberPrefix}`, standalone: true, imports: [FormsModule, ReactiveFormsModule, XInputComponent, XButtonComponent], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XInputNumberComponent)], template: "<div #inputNumber class=\"x-input-number\" [class.x-input-number-hidden-button]=\"hiddenButton\">\r\n <div class=\"x-input-number-row\">\r\n <ng-template #beforeButtonTpl>\r\n <x-button\r\n class=\"x-input-number-reduce\"\r\n icon=\"fto-minus\"\r\n [size]=\"size\"\r\n [onlyIcon]=\"!bordered\"\r\n [disabled]=\"disabled || minDisabled\"\r\n (click)=\"!minDisabled && plus($event, step, false); formControlValidator()\"\r\n attrType=\"button\"\r\n (mousedown)=\"!minDisabled && down($event, step, false)\"\r\n (mouseup)=\"up($event)\"\r\n ></x-button>\r\n </ng-template>\r\n <x-input\r\n #inputEleRef\r\n class=\"x-input-number-input\"\r\n [label]=\"label\"\r\n [labelWidth]=\"labelWidth\"\r\n [labelAlign]=\"labelAlign\"\r\n [justify]=\"justify\"\r\n [align]=\"align\"\r\n [direction]=\"direction\"\r\n [disabled]=\"disabled\"\r\n [required]=\"required\"\r\n [validator]=\"validator\"\r\n [icon]=\"icon\"\r\n [iconSpin]=\"iconSpin\"\r\n [placeholder]=\"placeholder\"\r\n [readonly]=\"readonly\"\r\n [clearable]=\"clearable\"\r\n [(ngModel)]=\"displayValue\"\r\n (ngModelChange)=\"change($event)\"\r\n [valueTpl]=\"valueTpl\"\r\n [valueTplContext]=\"valueTplContext\"\r\n [size]=\"size\"\r\n [bordered]=\"bordered\"\r\n [before]=\"hiddenButton ? '' : beforeButtonTpl\"\r\n [after]=\"hiddenButton ? '' : afterButtonTpl\"\r\n [pattern]=\"pattern\"\r\n [message]=\"message\"\r\n (xInput)=\"onInput($event); formControlValidator()\"\r\n (xBlur)=\"onBlur()\"\r\n ></x-input>\r\n <ng-template #afterButtonTpl>\r\n <x-button\r\n class=\"x-input-number-plus\"\r\n icon=\"fto-plus\"\r\n [size]=\"size\"\r\n [onlyIcon]=\"!bordered\"\r\n [disabled]=\"disabled || maxDisabled\"\r\n (click)=\"!maxDisabled && plus($event, step); formControlValidator()\"\r\n attrType=\"button\"\r\n (mousedown)=\"!maxDisabled && down($event, step)\"\r\n (mouseup)=\"up($event)\"\r\n ></x-button>\r\n </ng-template>\r\n @if (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 }\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-input-number{display:inline-block;width:12rem}.x-input-number{margin:0;padding:0;width:100%}.x-input-number-input{width:100%}.x-input-number-input input{text-align:center}.x-input-number-hidden-button .x-input-number-input input{text-align:left}\n"] }]
146
146
  }], propDecorators: { inputNumber: [{
147
147
  type: ViewChild,
148
148
  args: ['inputNumber', { static: true }]
@@ -150,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
150
150
  type: ViewChild,
151
151
  args: [XInputComponent, { static: true }]
152
152
  }] } });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/input-number/input-number.component.ts","../../../../../lib/ng-nest/ui/input-number/input-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Subject, Subscription, distinctUntilChanged, fromEvent, interval } 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  ViewChild,\r\n  inject\r\n} from '@angular/core';\r\nimport { XIsEmpty, XNumber, XClearClass, XConfigService, isNotNil, XIsFunction, XIsString } from '@ng-nest/ui/core';\r\nimport { XInputNumberPrefix, XInputNumberProperty } from './input-number.property';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\nimport { XInputComponent } from '@ng-nest/ui/input';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { XButtonComponent } from '@ng-nest/ui/button';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\n@Component({\r\n  selector: `${XInputNumberPrefix}`,\r\n  standalone: true,\r\n  imports: [FormsModule, ReactiveFormsModule, XInputComponent, XButtonComponent],\r\n  templateUrl: './input-number.component.html',\r\n  styleUrls: ['./style/index.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XInputNumberComponent)]\r\n})\r\nexport class XInputNumberComponent extends XInputNumberProperty implements OnInit {\r\n  @ViewChild('inputNumber', { static: true }) inputNumber!: ElementRef<HTMLElement>;\r\n\r\n  @ViewChild(XInputComponent, { static: true }) inputEleRef!: XInputComponent;\r\n\r\n  override writeValue(value: any) {\r\n    this.value = value;\r\n    this.setDisplayValue();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  displayValue: any = '';\r\n  minDisabled: boolean = false;\r\n  maxDisabled: boolean = false;\r\n  mousedown$!: Subscription;\r\n  mouseup$!: Subscription;\r\n  timer: any;\r\n  icon: string = '';\r\n  iconSpin = false;\r\n  clearable = false;\r\n  isDown = false;\r\n  valueChange = new Subject<any>();\r\n\r\n  document = inject(DOCUMENT);\r\n  private renderer = inject(Renderer2);\r\n  override cdr = inject(ChangeDetectorRef);\r\n  configService = inject(XConfigService);\r\n\r\n  ngOnInit() {\r\n    this.setFlex(this.inputNumber.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n    this.setClassMap();\r\n    this.valueChange.pipe(distinctUntilChanged()).subscribe((x) => {\r\n      this.onChange && this.onChange(x);\r\n    });\r\n  }\r\n\r\n  setClassMap() {\r\n    XClearClass(this.labelMap);\r\n    this.labelMap[`x-text-align-${this.labelAlign}`] = this.labelAlign ? true : false;\r\n  }\r\n\r\n  setDisplayValue() {\r\n    if (!XIsEmpty(this.value) && !this.formatter) {\r\n      this.displayValue = Number(this.value).toFixed(Number(this.precision));\r\n    } else if (this.formatter) {\r\n      const displayValue = isNotNil(this.formatter(Number(this.value))) ? this.formatter(Number(this.value)) : '';\r\n      if (isNotNil(displayValue)) {\r\n        this.displayValue = displayValue;\r\n      }\r\n    }\r\n  }\r\n\r\n  change(value: any) {\r\n    this.verify(value);\r\n    this.valueChange.next(this.value);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onBlur() {\r\n    this.displayValue = this.displayValue;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  down(event: Event, limit: XNumber, increase: boolean = true): void {\r\n    if (this.disabled) return;\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.isDown = true;\r\n    this.timer = setTimeout(() => {\r\n      this.mousedown$ = interval(Number(this.debounce)).subscribe(() => {\r\n        this.plus(event, limit, increase);\r\n      });\r\n      this.mouseup$ = fromEvent(this.document.documentElement, 'mouseup').subscribe((event: Event) => {\r\n        this.up(event);\r\n      });\r\n    }, 150);\r\n  }\r\n\r\n  up(event: Event) {\r\n    if (this.disabled) return;\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.isDown = false;\r\n    if (this.mousedown$) this.mousedown$.unsubscribe();\r\n    if (this.mouseup$) this.mouseup$.unsubscribe();\r\n  }\r\n\r\n  plus(event: Event, limit: XNumber, increase: boolean = true) {\r\n    if (this.disabled) return;\r\n    limit = Number(limit);\r\n    if (!increase) limit = -limit;\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    if (this.timer) clearTimeout(this.timer);\r\n    if (Number.isNaN(+this.value)) this.value = 0;\r\n    let value = Number(this.value) + limit;\r\n    this.verify(value);\r\n    this.cdr.detectChanges();\r\n    this.valueChange.next(this.value);\r\n  }\r\n\r\n  verify(value: string | number) {\r\n    if (XIsString(value) && Number(value).toString() !== value) {\r\n      return;\r\n    }\r\n    value = Number(Number(value).toFixed(Number(this.precision)));\r\n    const oldValue: number = this.value;\r\n    this.value = value;\r\n    if (Number.isNaN(+this.value)) {\r\n      this.value = oldValue;\r\n      this.setDisplayValue();\r\n    } else {\r\n      this.maxDisabled = value >= Number(this.max);\r\n      this.minDisabled = value <= Number(this.min);\r\n      this.value = this.maxDisabled ? this.max : this.minDisabled ? this.min : value;\r\n      this.setDisplayValue();\r\n    }\r\n  }\r\n\r\n  onInput(x: Event) {\r\n    const input = x.target as HTMLInputElement;\r\n    let value = input.value;\r\n    if (XIsFunction(this.formatter)) {\r\n      value = value.replace(/[^0-9]/g, '');\r\n    }\r\n    this.verify(value);\r\n    this.inputEleRef.inputRef.nativeElement.value = this.displayValue;\r\n    this.cdr.detectChanges();\r\n    this.valueChange.next(this.value);\r\n  }\r\n\r\n  formControlChanges() {\r\n    this.ngOnInit();\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<div #inputNumber class=\"x-input-number\">\r\n  <div class=\"x-input-number-row\">\r\n    <ng-template #beforeButtonTpl>\r\n      <x-button\r\n        class=\"x-input-number-reduce\"\r\n        icon=\"fto-minus\"\r\n        [size]=\"size\"\r\n        [onlyIcon]=\"!bordered\"\r\n        [disabled]=\"disabled || minDisabled\"\r\n        (click)=\"!minDisabled && plus($event, step, false); formControlValidator()\"\r\n        attrType=\"button\"\r\n        (mousedown)=\"!minDisabled && down($event, step, false)\"\r\n        (mouseup)=\"up($event)\"\r\n      ></x-button>\r\n    </ng-template>\r\n    <x-input\r\n      #inputEleRef\r\n      class=\"x-input-number-input\"\r\n      [label]=\"label\"\r\n      [labelWidth]=\"labelWidth\"\r\n      [labelAlign]=\"labelAlign\"\r\n      [justify]=\"justify\"\r\n      [align]=\"align\"\r\n      [direction]=\"direction\"\r\n      [disabled]=\"disabled\"\r\n      [required]=\"required\"\r\n      [validator]=\"validator\"\r\n      [icon]=\"icon\"\r\n      [iconSpin]=\"iconSpin\"\r\n      [placeholder]=\"placeholder\"\r\n      [readonly]=\"readonly\"\r\n      [clearable]=\"clearable\"\r\n      [(ngModel)]=\"displayValue\"\r\n      (ngModelChange)=\"change($event)\"\r\n      [valueTpl]=\"valueTpl\"\r\n      [valueTplContext]=\"valueTplContext\"\r\n      [size]=\"size\"\r\n      [bordered]=\"bordered\"\r\n      [before]=\"beforeButtonTpl\"\r\n      [after]=\"afterButtonTpl\"\r\n      [pattern]=\"pattern\"\r\n      [message]=\"message\"\r\n      (xInput)=\"onInput($event); formControlValidator()\"\r\n      (xBlur)=\"onBlur()\"\r\n    ></x-input>\r\n    <ng-template #afterButtonTpl>\r\n      <x-button\r\n        class=\"x-input-number-plus\"\r\n        icon=\"fto-plus\"\r\n        [size]=\"size\"\r\n        [onlyIcon]=\"!bordered\"\r\n        [disabled]=\"disabled || maxDisabled\"\r\n        (click)=\"!maxDisabled && plus($event, step); formControlValidator()\"\r\n        attrType=\"button\"\r\n        (mousedown)=\"!maxDisabled && down($event, step)\"\r\n        (mouseup)=\"up($event)\"\r\n      ></x-button>\r\n    </ng-template>\r\n    @if (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    }\r\n  </div>\r\n</div>\r\n"]}
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/input-number/input-number.component.ts","../../../../../lib/ng-nest/ui/input-number/input-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Subject, Subscription, distinctUntilChanged, fromEvent, interval } 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  ViewChild,\r\n  inject\r\n} from '@angular/core';\r\nimport { XIsEmpty, XNumber, XClearClass, XConfigService, isNotNil, XIsFunction, XIsString } from '@ng-nest/ui/core';\r\nimport { XInputNumberPrefix, XInputNumberProperty } from './input-number.property';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\nimport { XInputComponent } from '@ng-nest/ui/input';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { XButtonComponent } from '@ng-nest/ui/button';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\n@Component({\r\n  selector: `${XInputNumberPrefix}`,\r\n  standalone: true,\r\n  imports: [FormsModule, ReactiveFormsModule, XInputComponent, XButtonComponent],\r\n  templateUrl: './input-number.component.html',\r\n  styleUrls: ['./style/index.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XInputNumberComponent)]\r\n})\r\nexport class XInputNumberComponent extends XInputNumberProperty implements OnInit {\r\n  @ViewChild('inputNumber', { static: true }) inputNumber!: ElementRef<HTMLElement>;\r\n\r\n  @ViewChild(XInputComponent, { static: true }) inputEleRef!: XInputComponent;\r\n\r\n  override writeValue(value: any) {\r\n    this.value = value;\r\n    this.setDisplayValue();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  displayValue: any = '';\r\n  minDisabled: boolean = false;\r\n  maxDisabled: boolean = false;\r\n  mousedown$!: Subscription;\r\n  mouseup$!: Subscription;\r\n  timer: any;\r\n  icon: string = '';\r\n  iconSpin = false;\r\n  clearable = false;\r\n  isDown = false;\r\n  valueChange = new Subject<any>();\r\n\r\n  document = inject(DOCUMENT);\r\n  private renderer = inject(Renderer2);\r\n  override cdr = inject(ChangeDetectorRef);\r\n  configService = inject(XConfigService);\r\n\r\n  ngOnInit() {\r\n    this.setFlex(this.inputNumber.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n    this.setClassMap();\r\n    this.valueChange.pipe(distinctUntilChanged()).subscribe((x) => {\r\n      this.onChange && this.onChange(x);\r\n    });\r\n  }\r\n\r\n  setClassMap() {\r\n    XClearClass(this.labelMap);\r\n    this.labelMap[`x-text-align-${this.labelAlign}`] = this.labelAlign ? true : false;\r\n  }\r\n\r\n  setDisplayValue() {\r\n    if (!XIsEmpty(this.value) && !this.formatter) {\r\n      this.displayValue = Number(this.value).toFixed(Number(this.precision));\r\n    } else if (this.formatter) {\r\n      const displayValue = isNotNil(this.formatter(Number(this.value))) ? this.formatter(Number(this.value)) : '';\r\n      if (isNotNil(displayValue)) {\r\n        this.displayValue = displayValue;\r\n      }\r\n    }\r\n  }\r\n\r\n  change(value: any) {\r\n    this.verify(value);\r\n    this.valueChange.next(this.value);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onBlur() {\r\n    this.displayValue = this.displayValue;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  down(event: Event, limit: XNumber, increase: boolean = true): void {\r\n    if (this.disabled) return;\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.isDown = true;\r\n    this.timer = setTimeout(() => {\r\n      this.mousedown$ = interval(Number(this.debounce)).subscribe(() => {\r\n        this.plus(event, limit, increase);\r\n      });\r\n      this.mouseup$ = fromEvent(this.document.documentElement, 'mouseup').subscribe((event: Event) => {\r\n        this.up(event);\r\n      });\r\n    }, 150);\r\n  }\r\n\r\n  up(event: Event) {\r\n    if (this.disabled) return;\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.isDown = false;\r\n    if (this.mousedown$) this.mousedown$.unsubscribe();\r\n    if (this.mouseup$) this.mouseup$.unsubscribe();\r\n  }\r\n\r\n  plus(event: Event, limit: XNumber, increase: boolean = true) {\r\n    if (this.disabled) return;\r\n    limit = Number(limit);\r\n    if (!increase) limit = -limit;\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    if (this.timer) clearTimeout(this.timer);\r\n    if (Number.isNaN(+this.value)) this.value = 0;\r\n    let value = Number(this.value) + limit;\r\n    this.verify(value);\r\n    this.cdr.detectChanges();\r\n    this.valueChange.next(this.value);\r\n  }\r\n\r\n  verify(value: string | number) {\r\n    if (XIsString(value) && Number(value).toString() !== value) {\r\n      return;\r\n    }\r\n    value = Number(Number(value).toFixed(Number(this.precision)));\r\n    const oldValue: number = this.value;\r\n    this.value = value;\r\n    if (Number.isNaN(+this.value)) {\r\n      this.value = oldValue;\r\n      this.setDisplayValue();\r\n    } else {\r\n      this.maxDisabled = value >= Number(this.max);\r\n      this.minDisabled = value <= Number(this.min);\r\n      this.value = this.maxDisabled ? this.max : this.minDisabled ? this.min : value;\r\n      this.setDisplayValue();\r\n    }\r\n  }\r\n\r\n  onInput(x: Event) {\r\n    const input = x.target as HTMLInputElement;\r\n    let value = input.value;\r\n    if (XIsFunction(this.formatter)) {\r\n      value = value.replace(/[^0-9]/g, '');\r\n    }\r\n    this.verify(value);\r\n    this.inputEleRef.inputRef.nativeElement.value = this.displayValue;\r\n    this.cdr.detectChanges();\r\n    this.valueChange.next(this.value);\r\n  }\r\n\r\n  formControlChanges() {\r\n    this.ngOnInit();\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<div #inputNumber class=\"x-input-number\" [class.x-input-number-hidden-button]=\"hiddenButton\">\r\n  <div class=\"x-input-number-row\">\r\n    <ng-template #beforeButtonTpl>\r\n      <x-button\r\n        class=\"x-input-number-reduce\"\r\n        icon=\"fto-minus\"\r\n        [size]=\"size\"\r\n        [onlyIcon]=\"!bordered\"\r\n        [disabled]=\"disabled || minDisabled\"\r\n        (click)=\"!minDisabled && plus($event, step, false); formControlValidator()\"\r\n        attrType=\"button\"\r\n        (mousedown)=\"!minDisabled && down($event, step, false)\"\r\n        (mouseup)=\"up($event)\"\r\n      ></x-button>\r\n    </ng-template>\r\n    <x-input\r\n      #inputEleRef\r\n      class=\"x-input-number-input\"\r\n      [label]=\"label\"\r\n      [labelWidth]=\"labelWidth\"\r\n      [labelAlign]=\"labelAlign\"\r\n      [justify]=\"justify\"\r\n      [align]=\"align\"\r\n      [direction]=\"direction\"\r\n      [disabled]=\"disabled\"\r\n      [required]=\"required\"\r\n      [validator]=\"validator\"\r\n      [icon]=\"icon\"\r\n      [iconSpin]=\"iconSpin\"\r\n      [placeholder]=\"placeholder\"\r\n      [readonly]=\"readonly\"\r\n      [clearable]=\"clearable\"\r\n      [(ngModel)]=\"displayValue\"\r\n      (ngModelChange)=\"change($event)\"\r\n      [valueTpl]=\"valueTpl\"\r\n      [valueTplContext]=\"valueTplContext\"\r\n      [size]=\"size\"\r\n      [bordered]=\"bordered\"\r\n      [before]=\"hiddenButton ? '' : beforeButtonTpl\"\r\n      [after]=\"hiddenButton ? '' : afterButtonTpl\"\r\n      [pattern]=\"pattern\"\r\n      [message]=\"message\"\r\n      (xInput)=\"onInput($event); formControlValidator()\"\r\n      (xBlur)=\"onBlur()\"\r\n    ></x-input>\r\n    <ng-template #afterButtonTpl>\r\n      <x-button\r\n        class=\"x-input-number-plus\"\r\n        icon=\"fto-plus\"\r\n        [size]=\"size\"\r\n        [onlyIcon]=\"!bordered\"\r\n        [disabled]=\"disabled || maxDisabled\"\r\n        (click)=\"!maxDisabled && plus($event, step); formControlValidator()\"\r\n        attrType=\"button\"\r\n        (mousedown)=\"!maxDisabled && down($event, step)\"\r\n        (mouseup)=\"up($event)\"\r\n      ></x-button>\r\n    </ng-template>\r\n    @if (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    }\r\n  </div>\r\n</div>\r\n"]}