@ng-nest/ui 18.0.18 → 18.0.20

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.
@@ -60,6 +60,7 @@ export class XColorPickerPortalComponent {
60
60
  this.animating.emit(true);
61
61
  }
62
62
  ngOnInit() {
63
+ this.colorConvert();
63
64
  this.destroyRef.onDestroy(() => {
64
65
  this.destroy.set(true);
65
66
  this.unSubject.next();
@@ -76,7 +77,7 @@ export class XColorPickerPortalComponent {
76
77
  ngOnChanges(simples) {
77
78
  const { value } = simples;
78
79
  if (XIsChange(value))
79
- this.colorConvert();
80
+ !this.drag() && this.colorConvert();
80
81
  }
81
82
  setPanelValue() {
82
83
  this.setTransform();
@@ -416,4 +417,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
416
417
  type: HostListener,
417
418
  args: ['@x-connect-base-animation.start', ['$event']]
418
419
  }] } });
419
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker-portal.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/color-picker/color-picker-portal.component.ts","../../../../../lib/ng-nest/ui/color-picker/color-picker-portal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  OnInit,\r\n  ElementRef,\r\n  Renderer2,\r\n  HostListener,\r\n  HostBinding,\r\n  inject,\r\n  input,\r\n  output,\r\n  model,\r\n  viewChild,\r\n  signal,\r\n  DestroyRef,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  AfterViewInit,\r\n  TemplateRef\r\n} from '@angular/core';\r\nimport { XColorPickerPortalPrefix, XColorType } from './color-picker.property';\r\nimport { XConnectBaseAnimation, XIsChange, XPositionTopBottom } from '@ng-nest/ui/core';\r\nimport { XSliderSelectComponent } from '@ng-nest/ui/slider-select';\r\nimport { Subject } from 'rxjs';\r\nimport { CdkDragMove } from '@angular/cdk/drag-drop';\r\nimport { DecimalPipe, NgTemplateOutlet, PercentPipe } from '@angular/common';\r\nimport { XInputComponent } from '@ng-nest/ui/input';\r\nimport { DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { XTabsComponent, XTabComponent } from '@ng-nest/ui/tabs';\r\nimport { FormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: `${XColorPickerPortalPrefix}`,\r\n  standalone: true,\r\n  imports: [\r\n    FormsModule,\r\n    DragDropModule,\r\n    NgTemplateOutlet,\r\n    XSliderSelectComponent,\r\n    XTabsComponent,\r\n    XTabComponent,\r\n    XInputComponent\r\n  ],\r\n  templateUrl: './color-picker-portal.component.html',\r\n  styleUrls: ['./color-picker-portal.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [DecimalPipe, PercentPipe],\r\n  animations: [XConnectBaseAnimation]\r\n})\r\nexport class XColorPickerPortalComponent implements OnInit, OnChanges, AfterViewInit {\r\n  @HostBinding('@x-connect-base-animation') public get getPlacement() {\r\n    return this.placement();\r\n  }\r\n  @HostListener('@x-connect-base-animation.done', ['$event']) done() {\r\n    if (this.destroy()) return;\r\n    this.animating.emit(false);\r\n  }\r\n  @HostListener('@x-connect-base-animation.start', ['$event']) start() {\r\n    if (this.destroy()) return;\r\n    this.animating.emit(true);\r\n  }\r\n\r\n  panelRef = viewChild.required('panelRef', { read: ElementRef<HTMLElement> });\r\n  plateRef = viewChild.required('plateRef', { read: ElementRef<HTMLElement> });\r\n  transparentCom = viewChild.required('transparentCom', { read: XSliderSelectComponent });\r\n  value = model<string>('');\r\n  inputCom = input<XInputComponent>();\r\n  placement = input<XPositionTopBottom>();\r\n  panelTemplate = input<TemplateRef<any>>();\r\n\r\n  animating = output<boolean>();\r\n  nodeClick = output<string>();\r\n\r\n  transparentRail = signal<HTMLElement | null>(null);\r\n  sliderColorNum = signal(0);\r\n  type = signal<XColorType | null>(null);\r\n  offset = signal(0);\r\n  panel = signal<DOMRect | null>(null);\r\n  plate = signal<DOMRect | null>(null);\r\n  transformX = signal(0);\r\n  transformY = signal(0);\r\n  initTransformX = signal(0);\r\n  initTransformY = signal(0);\r\n  drag = signal(false);\r\n\r\n  rgba = signal<{ r?: number; g?: number; b?: number; a?: number }>({ a: 1 });\r\n  hsla = signal<{ h?: number; s?: number; l?: number; a?: number; sp?: string; lp?: string }>({\r\n    h: 0,\r\n    a: 1\r\n  });\r\n  hex = signal<string>('');\r\n\r\n  destroy = signal(false);\r\n  private unSubject = new Subject<void>();\r\n  private destroyRef = inject(DestroyRef);\r\n\r\n  private renderer = inject(Renderer2);\r\n  private decimal = inject(DecimalPipe);\r\n  private percent = inject(PercentPipe);\r\n\r\n  ngOnInit(): void {\r\n    this.destroyRef.onDestroy(() => {\r\n      this.destroy.set(true);\r\n      this.unSubject.next();\r\n      this.unSubject.complete();\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.panel.set(this.panelRef().nativeElement.getBoundingClientRect());\r\n    this.plate.set(this.plateRef().nativeElement.getBoundingClientRect());\r\n    this.offset.set((this.panel()!.width - this.plate()!.width) / 2);\r\n    this.transparentRail.set(\r\n      this.transparentCom().elementRef.nativeElement.querySelector('.x-slider-select-rail div')!\r\n    );\r\n    this.setPanelValue();\r\n  }\r\n\r\n  ngOnChanges(simples: SimpleChanges) {\r\n    const { value } = simples;\r\n    if (XIsChange(value)) this.colorConvert();\r\n  }\r\n\r\n  setPanelValue() {\r\n    this.setTransform();\r\n    this.setPlateBackground();\r\n    this.setRailBackground();\r\n  }\r\n\r\n  hexChange() {\r\n    if (this.drag() || !/(^#[0-9A-F]{6}$)/i.test(this.hex())) return;\r\n    this.rgba.set(this.hexToRgba(this.hex()));\r\n    this.hsla.set(this.rgbaToHsla(this.rgba()));\r\n    this.setHslaPercent();\r\n    this.setTransform();\r\n    this.setPlateBackground();\r\n    this.setValue();\r\n  }\r\n\r\n  stopPropagation(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  colorConvert() {\r\n    const value = this.value()!;\r\n    if (/^#/.test(value)) {\r\n      this.hex.set(value);\r\n      this.rgba.set(this.hexToRgba(this.hex()));\r\n      this.hsla.set(this.rgbaToHsla(this.rgba()));\r\n      this.setHslaPercent();\r\n      this.type.set('hex');\r\n    } else if (/rgb/.test(value)) {\r\n      this.rgbaConvert(value);\r\n      this.hex.set(this.rgbaToHex(this.rgba()));\r\n      this.hsla.set(this.rgbaToHsla(this.rgba()));\r\n      this.setHslaPercent();\r\n      this.type.set('rgba');\r\n    } else if (/hsl/.test(value)) {\r\n      this.hslaConvert(value);\r\n      this.rgba.set(this.hslaToRgba(this.hsla()));\r\n      this.hex.set(this.rgbaToHex(this.rgba()));\r\n      this.type.set('hsla');\r\n    }\r\n    this.setPanelValue();\r\n  }\r\n\r\n  rgbaConvert(str: string) {\r\n    let rgba = str\r\n      .replace(/rgba?\\(/, '')\r\n      .replace(/rgb?\\(/, '')\r\n      .replace(/\\)/, '')\r\n      .replace(/[\\s+]/g, '')\r\n      .split(',');\r\n    if (rgba.length > 2) {\r\n      this.rgba.set({\r\n        r: Number(rgba[0]),\r\n        g: Number(rgba[1]),\r\n        b: Number(rgba[2]),\r\n        a: Number(rgba.length > 3 ? rgba[3] : 1)\r\n      });\r\n    }\r\n  }\r\n\r\n  hslaConvert(str: string) {\r\n    let hsla = str\r\n      .replace(/hsla?\\(/, '')\r\n      .replace(/hsl?\\(/, '')\r\n      .replace(/\\)/, '')\r\n      .replace(/[\\s+]/g, '')\r\n      .split(',');\r\n    if (hsla.length > 2) {\r\n      this.hsla.set({\r\n        h: Number(hsla[0]),\r\n        s: Number(hsla[1].replace('%', '')) / 100,\r\n        l: Number(hsla[2].replace('%', '')) / 100,\r\n        a: Number(hsla.length > 3 ? hsla[3] : 1)\r\n      });\r\n      this.setHslaPercent();\r\n    }\r\n  }\r\n\r\n  plateClick(event: MouseEvent) {\r\n    if (this.drag()) return;\r\n    const rect = this.plateRef().nativeElement.getBoundingClientRect();\r\n    const left = event.clientX - rect.left;\r\n    const top = event.clientY - rect.top;\r\n    this.transformX.set(left - this.offset());\r\n    this.transformY.set(top - this.offset());\r\n    this.initTransformX.set(this.transformX());\r\n    this.initTransformY.set(this.transformY());\r\n    this.setLetfTop(left, top);\r\n  }\r\n\r\n  setTransform() {\r\n    if (!this.plate()) return;\r\n    let hsv = this.hslToHsv(this.hsla().h!, this.hsla().s!, this.hsla().l!);\r\n    this.transformX.set(hsv.s * this.plate()!.width - this.offset());\r\n    this.transformY.set((1 - hsv.v) * this.plate()!.height - this.offset());\r\n    this.initTransformX.set(this.transformX());\r\n    this.initTransformY.set(this.transformY());\r\n  }\r\n\r\n  started() {\r\n    this.drag.set(true);\r\n  }\r\n\r\n  ended() {\r\n    this.initTransformX.set(this.transformX());\r\n    this.initTransformY.set(this.transformY());\r\n    setTimeout(() => {\r\n      this.drag.set(false);\r\n    });\r\n  }\r\n\r\n  moved(drag: CdkDragMove) {\r\n    const transform = drag.source.getFreeDragPosition();\r\n    drag.source.reset();\r\n    this.transformX.set(transform.x + this.initTransformX());\r\n    this.transformY.set(transform.y + this.initTransformY());\r\n\r\n    const left = this.transformX() + this.offset();\r\n    const top = this.transformY() + this.offset();\r\n    this.setLetfTop(left, top);\r\n  }\r\n\r\n  setLetfTop(left: number, top: number) {\r\n    let s = left / this.plate()!.width;\r\n    let v = 1 - top / this.plate()!.height;\r\n    let l = ((2 - s) * v) / 2;\r\n    if (l !== 0) {\r\n      if (l === 1) {\r\n        s = 0;\r\n      } else if (l < 0.5) {\r\n        s = (s * v) / (l * 2);\r\n      } else {\r\n        s = (s * v) / (2 - l * 2);\r\n      }\r\n    }\r\n    this.hsla.update((x) => {\r\n      x.s = Number(this.decimal.transform(s, '1.2-2'));\r\n      x.l = Number(this.decimal.transform(l, '1.2-2'));\r\n      return { ...x };\r\n    });\r\n    this.setHslaPercent();\r\n    this.rgba.set(this.hslaToRgba(this.hsla()));\r\n    this.hex.set(this.rgbaToHex(this.rgba()));\r\n    this.setValue();\r\n  }\r\n\r\n  setHslaPercent() {\r\n    this.hsla.update((x) => {\r\n      x.sp = this.hsla().s === 0 ? '0%' : (this.percent.transform(this.hsla().s, '1.0-0') as string);\r\n      return { ...x };\r\n    });\r\n    this.hsla.update((x) => {\r\n      x.lp = this.hsla().l === 0 ? '0%' : (this.percent.transform(this.hsla().l, '1.0-0') as string);\r\n      return { ...x };\r\n    });\r\n  }\r\n\r\n  hueChange() {\r\n    this.setPlateBackground();\r\n    this.rgba.set(this.hslaToRgba(this.hsla()));\r\n    this.hex.set(this.rgbaToHex(this.rgba()));\r\n    this.setValue();\r\n  }\r\n\r\n  setPlateBackground() {\r\n    if (!this.plateRef()) return;\r\n    this.renderer.setStyle(this.plateRef().nativeElement, 'background-color', `hsl(${this.hsla().h}, 100%, 50%)`);\r\n  }\r\n\r\n  setRailBackground() {\r\n    if (!this.transparentRail()) return;\r\n    this.renderer.setStyle(\r\n      this.transparentRail(),\r\n      'background',\r\n      `linear-gradient(to right, rgba(${this.rgba().r}, ${this.rgba().g}, ${this.rgba().b}, 0) 0%, rgba(${this.rgba().r}, ${this.rgba().g}, ${this.rgba().b}, 1) 100%)`\r\n    );\r\n  }\r\n\r\n  transparentChange() {\r\n    this.rgba.set(this.hslaToRgba(this.hsla()));\r\n    this.hex.set(this.rgbaToHex(this.rgba()));\r\n    this.setValue();\r\n  }\r\n\r\n  setValue() {\r\n    this.setValueByType();\r\n    this.setRailBackground();\r\n    this.nodeClick.emit(this.value());\r\n  }\r\n\r\n  setValueByType() {\r\n    if (this.type() === 'hex') {\r\n      this.value.set(`${this.hex()}`);\r\n    } else if (this.type() === 'rgba') {\r\n      this.value.set(`rgba(${this.rgba().r}, ${this.rgba().g}, ${this.rgba().b}, ${this.rgba().a})`);\r\n    } else if (this.type() === 'hsla') {\r\n      this.value.set(`hsla(${this.hsla().h}, ${this.hsla().sp}, ${this.hsla().lp}, ${this.hsla().a})`);\r\n    }\r\n  }\r\n\r\n  hslaToRgba(hsla: { h?: number; s?: number; l?: number; a?: number }) {\r\n    let r, g, b;\r\n    let [h, s, l] = [hsla.h as number, hsla.s as number, hsla.l as number];\r\n    if (s == 0) {\r\n      r = g = b = l;\r\n    } else {\r\n      let hue2rgb = (p: number, q: number, t: number) => {\r\n        if (t < 0) t += 1;\r\n        if (t > 1) t -= 1;\r\n        if (t < 1 / 6) return p + (q - p) * 6 * t;\r\n        if (t < 1 / 2) return q;\r\n        if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\r\n        return p;\r\n      };\r\n\r\n      let q = l < 0.5 ? l * (1 + s) : l + s - l * s;\r\n      let p = 2 * l - q;\r\n      r = hue2rgb(p, q, h / 360 + 1 / 3);\r\n      g = hue2rgb(p, q, h / 360);\r\n      b = hue2rgb(p, q, h / 360 - 1 / 3);\r\n    }\r\n    return {\r\n      r: Math.round(r * 255),\r\n      g: Math.round(g * 255),\r\n      b: Math.round(b * 255),\r\n      a: Number(hsla.a)\r\n    };\r\n  }\r\n\r\n  rgbaToHex(rgba: { r?: number; g?: number; b?: number; a?: number }) {\r\n    let hex = [\r\n      (rgba.r as number).toString(16),\r\n      (rgba.g as number).toString(16),\r\n      (rgba.b as number).toString(16),\r\n      Math.round(255 * (rgba.a as number)).toString(16)\r\n    ];\r\n    hex.forEach((x, index) => {\r\n      if (index === 3 && x === 'ff') {\r\n        hex[index] = '';\r\n      }\r\n      if (x.length === 1) {\r\n        hex[index] = '0' + x;\r\n      }\r\n    });\r\n    return `#${hex.join('')}`;\r\n  }\r\n\r\n  rgbaToHsla(rgba: { r?: number; g?: number; b?: number; a?: number }) {\r\n    let [r, g, b] = [(rgba.r as number) / 255, (rgba.g as number) / 255, (rgba.b as number) / 255];\r\n    let [max, min] = [Math.max(r, g, b), Math.min(r, g, b)];\r\n    let h = 0;\r\n    let s = 0;\r\n    let l = (max + min) / 2;\r\n\r\n    if (max === min) {\r\n      h = s = 0;\r\n    } else {\r\n      let d = max - min;\r\n      s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\r\n      switch (max) {\r\n        case r:\r\n          h = (g - b) / d + (g < b ? 6 : 0);\r\n          break;\r\n        case g:\r\n          h = (b - r) / d + 2;\r\n          break;\r\n        case b:\r\n          h = (r - g) / d + 4;\r\n          break;\r\n      }\r\n      h /= 6;\r\n    }\r\n\r\n    return {\r\n      h: Math.round(h * 360),\r\n      s: Number(this.decimal.transform(s, '1.2-2')),\r\n      l: Number(this.decimal.transform(l, '1.2-2')),\r\n      a: Number(rgba.a)\r\n    };\r\n  }\r\n\r\n  hexToRgba(hex: string) {\r\n    let hexNum = hex.substring(1);\r\n    let a = 1;\r\n    if (hexNum.length === 8) {\r\n      a = Number(this.decimal.transform(Number('0x' + hexNum.slice(-2)) / 255, '1.2-2'));\r\n      hexNum = hexNum.substring(0, hexNum.length - 2);\r\n    }\r\n    let num = Number('0x' + (hexNum.length < 6 ? this.repeatLetter(hexNum, 2) : hexNum));\r\n    return { r: num >> 16, g: (num >> 8) & 0xff, b: num & 0xff, a: a };\r\n  }\r\n\r\n  hslToHsv(h: number, s: number, l: number) {\r\n    let hHsv, sHsv, v;\r\n\r\n    hHsv = h;\r\n\r\n    if (l == 0) {\r\n      sHsv = 0;\r\n      v = 0;\r\n    } else if (l > 0 && l <= 0.5) {\r\n      sHsv = (2 * s) / (1 + s);\r\n      v = l * (1 + s);\r\n    } else {\r\n      sHsv = (2 * s - 2 * s * l) / (s - s * l + l);\r\n      v = s - s * l + l;\r\n    }\r\n\r\n    return {\r\n      h: hHsv,\r\n      s: Number(this.decimal.transform(sHsv, '1.2-2')),\r\n      v: Number(this.decimal.transform(v, '1.2-2'))\r\n    };\r\n  }\r\n\r\n  repeatWord(word: string, num: number) {\r\n    let result = '';\r\n    for (let i = 0; i < num; i++) {\r\n      result += word;\r\n    }\r\n    return result;\r\n  }\r\n\r\n  repeatLetter(word: string, num: number) {\r\n    let result = '';\r\n    for (let letter of word) {\r\n      result += this.repeatWord(letter, num);\r\n    }\r\n    return result;\r\n  }\r\n}\r\n","<div class=\"x-color-picker-portal\" tabindex=\"-1\" (click)=\"stopPropagation($event)\">\r\n  <div #panelRef class=\"x-color-picker-portal-panel\">\r\n    <div #plateRef class=\"x-color-picker-portal-plate\" (click)=\"plateClick($event)\">\r\n      <div class=\"x-color-picker-portal-white\"></div>\r\n      <div class=\"x-color-picker-portal-black\"></div>\r\n      <div\r\n        #dragCom\r\n        class=\"x-color-picker-portal-cursor\"\r\n        [style.left.px]=\"transformX()\"\r\n        [style.top.px]=\"transformY()\"\r\n        cdkDrag\r\n        [cdkDragBoundary]=\"panelRef\"\r\n        (cdkDragStarted)=\"started()\"\r\n        (cdkDragEnded)=\"ended()\"\r\n        (cdkDragMoved)=\"moved($event)\"\r\n      ></div>\r\n    </div>\r\n  </div>\r\n  <div class=\"x-color-picker-portal-tool\">\r\n    <div class=\"x-color-picker-portal-operations\">\r\n      <!-- <x-button icon=\"fto-edit-2\" onlyIcon></x-button> -->\r\n      <div class=\"x-color-picker-portal-selected\">\r\n        <div [style.background-color]=\"value()\"></div>\r\n      </div>\r\n      <div class=\"x-color-picker-portal-area\">\r\n        <div class=\"x-color-picker-portal-slider\">\r\n          <x-slider-select\r\n            [style.width.%]=\"100\"\r\n            [(ngModel)]=\"hsla().h\"\r\n            min=\"0\"\r\n            max=\"360\"\r\n            step=\"1\"\r\n            (dragStartEmit)=\"started()\"\r\n            (dragEndEmit)=\"ended()\"\r\n            (ngModelChange)=\"hueChange()\"\r\n          ></x-slider-select>\r\n        </div>\r\n        <div class=\"x-color-picker-portal-transparent\">\r\n          <x-slider-select\r\n            [style.width.%]=\"100\"\r\n            #transparentCom\r\n            [(ngModel)]=\"hsla().a\"\r\n            min=\"0\"\r\n            max=\"1\"\r\n            step=\"0.01\"\r\n            (dragStarted)=\"started()\"\r\n            (dragEnded)=\"ended()\"\r\n            (ngModelChange)=\"transparentChange()\"\r\n          ></x-slider-select>\r\n          <div class=\"x-color-picker-portal-alpha\"></div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"x-color-picker-portal-type\">\r\n      <x-tabs animated=\"false\" justify=\"center\">\r\n        <x-tab label=\"HEX\">\r\n          <div class=\"x-color-picker-portal-type-content\">\r\n            <x-input [style.width.%]=\"100\" [(ngModel)]=\"hex\" (ngModelChange)=\"hexChange()\"></x-input>\r\n          </div>\r\n        </x-tab>\r\n        <x-tab label=\"RGBA\">\r\n          <div class=\"x-color-picker-portal-type-content\">\r\n            <x-input [(ngModel)]=\"rgba().r\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"rgba().g\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"rgba().b\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"rgba().a\" disabled></x-input>\r\n          </div>\r\n        </x-tab>\r\n        <x-tab label=\"HSLA\">\r\n          <div class=\"x-color-picker-portal-type-content\">\r\n            <x-input [(ngModel)]=\"hsla().h\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"hsla().sp\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"hsla().lp\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"hsla().a\" disabled></x-input>\r\n          </div>\r\n        </x-tab>\r\n      </x-tabs>\r\n    </div>\r\n    <div class=\"x-color-picker-panel\">\r\n      <ng-container *ngTemplateOutlet=\"panelTemplate()!\"></ng-container>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
420
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker-portal.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/color-picker/color-picker-portal.component.ts","../../../../../lib/ng-nest/ui/color-picker/color-picker-portal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  OnInit,\r\n  ElementRef,\r\n  Renderer2,\r\n  HostListener,\r\n  HostBinding,\r\n  inject,\r\n  input,\r\n  output,\r\n  model,\r\n  viewChild,\r\n  signal,\r\n  DestroyRef,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  AfterViewInit,\r\n  TemplateRef\r\n} from '@angular/core';\r\nimport { XColorPickerPortalPrefix, XColorType } from './color-picker.property';\r\nimport { XConnectBaseAnimation, XIsChange, XPositionTopBottom } from '@ng-nest/ui/core';\r\nimport { XSliderSelectComponent } from '@ng-nest/ui/slider-select';\r\nimport { Subject } from 'rxjs';\r\nimport { CdkDragMove } from '@angular/cdk/drag-drop';\r\nimport { DecimalPipe, NgTemplateOutlet, PercentPipe } from '@angular/common';\r\nimport { XInputComponent } from '@ng-nest/ui/input';\r\nimport { DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { XTabsComponent, XTabComponent } from '@ng-nest/ui/tabs';\r\nimport { FormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: `${XColorPickerPortalPrefix}`,\r\n  standalone: true,\r\n  imports: [\r\n    FormsModule,\r\n    DragDropModule,\r\n    NgTemplateOutlet,\r\n    XSliderSelectComponent,\r\n    XTabsComponent,\r\n    XTabComponent,\r\n    XInputComponent\r\n  ],\r\n  templateUrl: './color-picker-portal.component.html',\r\n  styleUrls: ['./color-picker-portal.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [DecimalPipe, PercentPipe],\r\n  animations: [XConnectBaseAnimation]\r\n})\r\nexport class XColorPickerPortalComponent implements OnInit, OnChanges, AfterViewInit {\r\n  @HostBinding('@x-connect-base-animation') public get getPlacement() {\r\n    return this.placement();\r\n  }\r\n  @HostListener('@x-connect-base-animation.done', ['$event']) done() {\r\n    if (this.destroy()) return;\r\n    this.animating.emit(false);\r\n  }\r\n  @HostListener('@x-connect-base-animation.start', ['$event']) start() {\r\n    if (this.destroy()) return;\r\n    this.animating.emit(true);\r\n  }\r\n\r\n  panelRef = viewChild.required('panelRef', { read: ElementRef<HTMLElement> });\r\n  plateRef = viewChild.required('plateRef', { read: ElementRef<HTMLElement> });\r\n  transparentCom = viewChild.required('transparentCom', { read: XSliderSelectComponent });\r\n  value = model<string>('');\r\n  inputCom = input<XInputComponent>();\r\n  placement = input<XPositionTopBottom>();\r\n  panelTemplate = input<TemplateRef<any>>();\r\n\r\n  animating = output<boolean>();\r\n  nodeClick = output<string>();\r\n\r\n  transparentRail = signal<HTMLElement | null>(null);\r\n  sliderColorNum = signal(0);\r\n  type = signal<XColorType | null>(null);\r\n  offset = signal(0);\r\n  panel = signal<DOMRect | null>(null);\r\n  plate = signal<DOMRect | null>(null);\r\n  transformX = signal(0);\r\n  transformY = signal(0);\r\n  initTransformX = signal(0);\r\n  initTransformY = signal(0);\r\n  drag = signal(false);\r\n\r\n  rgba = signal<{ r?: number; g?: number; b?: number; a?: number }>({ a: 1 });\r\n  hsla = signal<{ h?: number; s?: number; l?: number; a?: number; sp?: string; lp?: string }>({\r\n    h: 0,\r\n    a: 1\r\n  });\r\n  hex = signal<string>('');\r\n\r\n  destroy = signal(false);\r\n  private unSubject = new Subject<void>();\r\n  private destroyRef = inject(DestroyRef);\r\n\r\n  private renderer = inject(Renderer2);\r\n  private decimal = inject(DecimalPipe);\r\n  private percent = inject(PercentPipe);\r\n\r\n  ngOnInit(): void {\r\n    this.colorConvert();\r\n    this.destroyRef.onDestroy(() => {\r\n      this.destroy.set(true);\r\n      this.unSubject.next();\r\n      this.unSubject.complete();\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.panel.set(this.panelRef().nativeElement.getBoundingClientRect());\r\n    this.plate.set(this.plateRef().nativeElement.getBoundingClientRect());\r\n    this.offset.set((this.panel()!.width - this.plate()!.width) / 2);\r\n    this.transparentRail.set(\r\n      this.transparentCom().elementRef.nativeElement.querySelector('.x-slider-select-rail div')!\r\n    );\r\n    this.setPanelValue();\r\n  }\r\n\r\n  ngOnChanges(simples: SimpleChanges) {\r\n    const { value } = simples;\r\n    if (XIsChange(value)) !this.drag() && this.colorConvert();\r\n  }\r\n\r\n  setPanelValue() {\r\n    this.setTransform();\r\n    this.setPlateBackground();\r\n    this.setRailBackground();\r\n  }\r\n\r\n  hexChange() {\r\n    if (this.drag() || !/(^#[0-9A-F]{6}$)/i.test(this.hex())) return;\r\n    this.rgba.set(this.hexToRgba(this.hex()));\r\n    this.hsla.set(this.rgbaToHsla(this.rgba()));\r\n    this.setHslaPercent();\r\n    this.setTransform();\r\n    this.setPlateBackground();\r\n    this.setValue();\r\n  }\r\n\r\n  stopPropagation(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  colorConvert() {\r\n    const value = this.value()!;\r\n    if (/^#/.test(value)) {\r\n      this.hex.set(value);\r\n      this.rgba.set(this.hexToRgba(this.hex()));\r\n      this.hsla.set(this.rgbaToHsla(this.rgba()));\r\n      this.setHslaPercent();\r\n      this.type.set('hex');\r\n    } else if (/rgb/.test(value)) {\r\n      this.rgbaConvert(value);\r\n      this.hex.set(this.rgbaToHex(this.rgba()));\r\n      this.hsla.set(this.rgbaToHsla(this.rgba()));\r\n      this.setHslaPercent();\r\n      this.type.set('rgba');\r\n    } else if (/hsl/.test(value)) {\r\n      this.hslaConvert(value);\r\n      this.rgba.set(this.hslaToRgba(this.hsla()));\r\n      this.hex.set(this.rgbaToHex(this.rgba()));\r\n      this.type.set('hsla');\r\n    }\r\n    this.setPanelValue();\r\n  }\r\n\r\n  rgbaConvert(str: string) {\r\n    let rgba = str\r\n      .replace(/rgba?\\(/, '')\r\n      .replace(/rgb?\\(/, '')\r\n      .replace(/\\)/, '')\r\n      .replace(/[\\s+]/g, '')\r\n      .split(',');\r\n    if (rgba.length > 2) {\r\n      this.rgba.set({\r\n        r: Number(rgba[0]),\r\n        g: Number(rgba[1]),\r\n        b: Number(rgba[2]),\r\n        a: Number(rgba.length > 3 ? rgba[3] : 1)\r\n      });\r\n    }\r\n  }\r\n\r\n  hslaConvert(str: string) {\r\n    let hsla = str\r\n      .replace(/hsla?\\(/, '')\r\n      .replace(/hsl?\\(/, '')\r\n      .replace(/\\)/, '')\r\n      .replace(/[\\s+]/g, '')\r\n      .split(',');\r\n    if (hsla.length > 2) {\r\n      this.hsla.set({\r\n        h: Number(hsla[0]),\r\n        s: Number(hsla[1].replace('%', '')) / 100,\r\n        l: Number(hsla[2].replace('%', '')) / 100,\r\n        a: Number(hsla.length > 3 ? hsla[3] : 1)\r\n      });\r\n      this.setHslaPercent();\r\n    }\r\n  }\r\n\r\n  plateClick(event: MouseEvent) {\r\n    if (this.drag()) return;\r\n    const rect = this.plateRef().nativeElement.getBoundingClientRect();\r\n    const left = event.clientX - rect.left;\r\n    const top = event.clientY - rect.top;\r\n    this.transformX.set(left - this.offset());\r\n    this.transformY.set(top - this.offset());\r\n    this.initTransformX.set(this.transformX());\r\n    this.initTransformY.set(this.transformY());\r\n    this.setLetfTop(left, top);\r\n  }\r\n\r\n  setTransform() {\r\n    if (!this.plate()) return;\r\n    let hsv = this.hslToHsv(this.hsla().h!, this.hsla().s!, this.hsla().l!);\r\n    this.transformX.set(hsv.s * this.plate()!.width - this.offset());\r\n    this.transformY.set((1 - hsv.v) * this.plate()!.height - this.offset());\r\n    this.initTransformX.set(this.transformX());\r\n    this.initTransformY.set(this.transformY());\r\n  }\r\n\r\n  started() {\r\n    this.drag.set(true);\r\n  }\r\n\r\n  ended() {\r\n    this.initTransformX.set(this.transformX());\r\n    this.initTransformY.set(this.transformY());\r\n    setTimeout(() => {\r\n      this.drag.set(false);\r\n    });\r\n  }\r\n\r\n  moved(drag: CdkDragMove) {\r\n    const transform = drag.source.getFreeDragPosition();\r\n    drag.source.reset();\r\n    this.transformX.set(transform.x + this.initTransformX());\r\n    this.transformY.set(transform.y + this.initTransformY());\r\n\r\n    const left = this.transformX() + this.offset();\r\n    const top = this.transformY() + this.offset();\r\n    this.setLetfTop(left, top);\r\n  }\r\n\r\n  setLetfTop(left: number, top: number) {\r\n    let s = left / this.plate()!.width;\r\n    let v = 1 - top / this.plate()!.height;\r\n    let l = ((2 - s) * v) / 2;\r\n    if (l !== 0) {\r\n      if (l === 1) {\r\n        s = 0;\r\n      } else if (l < 0.5) {\r\n        s = (s * v) / (l * 2);\r\n      } else {\r\n        s = (s * v) / (2 - l * 2);\r\n      }\r\n    }\r\n    this.hsla.update((x) => {\r\n      x.s = Number(this.decimal.transform(s, '1.2-2'));\r\n      x.l = Number(this.decimal.transform(l, '1.2-2'));\r\n      return { ...x };\r\n    });\r\n    this.setHslaPercent();\r\n    this.rgba.set(this.hslaToRgba(this.hsla()));\r\n    this.hex.set(this.rgbaToHex(this.rgba()));\r\n    this.setValue();\r\n  }\r\n\r\n  setHslaPercent() {\r\n    this.hsla.update((x) => {\r\n      x.sp = this.hsla().s === 0 ? '0%' : (this.percent.transform(this.hsla().s, '1.0-0') as string);\r\n      return { ...x };\r\n    });\r\n    this.hsla.update((x) => {\r\n      x.lp = this.hsla().l === 0 ? '0%' : (this.percent.transform(this.hsla().l, '1.0-0') as string);\r\n      return { ...x };\r\n    });\r\n  }\r\n\r\n  hueChange() {\r\n    this.setPlateBackground();\r\n    this.rgba.set(this.hslaToRgba(this.hsla()));\r\n    this.hex.set(this.rgbaToHex(this.rgba()));\r\n    this.setValue();\r\n  }\r\n\r\n  setPlateBackground() {\r\n    if (!this.plateRef()) return;\r\n    this.renderer.setStyle(this.plateRef().nativeElement, 'background-color', `hsl(${this.hsla().h}, 100%, 50%)`);\r\n  }\r\n\r\n  setRailBackground() {\r\n    if (!this.transparentRail()) return;\r\n    this.renderer.setStyle(\r\n      this.transparentRail(),\r\n      'background',\r\n      `linear-gradient(to right, rgba(${this.rgba().r}, ${this.rgba().g}, ${this.rgba().b}, 0) 0%, rgba(${this.rgba().r}, ${this.rgba().g}, ${this.rgba().b}, 1) 100%)`\r\n    );\r\n  }\r\n\r\n  transparentChange() {\r\n    this.rgba.set(this.hslaToRgba(this.hsla()));\r\n    this.hex.set(this.rgbaToHex(this.rgba()));\r\n    this.setValue();\r\n  }\r\n\r\n  setValue() {\r\n    this.setValueByType();\r\n    this.setRailBackground();\r\n    this.nodeClick.emit(this.value());\r\n  }\r\n\r\n  setValueByType() {\r\n    if (this.type() === 'hex') {\r\n      this.value.set(`${this.hex()}`);\r\n    } else if (this.type() === 'rgba') {\r\n      this.value.set(`rgba(${this.rgba().r}, ${this.rgba().g}, ${this.rgba().b}, ${this.rgba().a})`);\r\n    } else if (this.type() === 'hsla') {\r\n      this.value.set(`hsla(${this.hsla().h}, ${this.hsla().sp}, ${this.hsla().lp}, ${this.hsla().a})`);\r\n    }\r\n  }\r\n\r\n  hslaToRgba(hsla: { h?: number; s?: number; l?: number; a?: number }) {\r\n    let r, g, b;\r\n    let [h, s, l] = [hsla.h as number, hsla.s as number, hsla.l as number];\r\n    if (s == 0) {\r\n      r = g = b = l;\r\n    } else {\r\n      let hue2rgb = (p: number, q: number, t: number) => {\r\n        if (t < 0) t += 1;\r\n        if (t > 1) t -= 1;\r\n        if (t < 1 / 6) return p + (q - p) * 6 * t;\r\n        if (t < 1 / 2) return q;\r\n        if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\r\n        return p;\r\n      };\r\n\r\n      let q = l < 0.5 ? l * (1 + s) : l + s - l * s;\r\n      let p = 2 * l - q;\r\n      r = hue2rgb(p, q, h / 360 + 1 / 3);\r\n      g = hue2rgb(p, q, h / 360);\r\n      b = hue2rgb(p, q, h / 360 - 1 / 3);\r\n    }\r\n    return {\r\n      r: Math.round(r * 255),\r\n      g: Math.round(g * 255),\r\n      b: Math.round(b * 255),\r\n      a: Number(hsla.a)\r\n    };\r\n  }\r\n\r\n  rgbaToHex(rgba: { r?: number; g?: number; b?: number; a?: number }) {\r\n    let hex = [\r\n      (rgba.r as number).toString(16),\r\n      (rgba.g as number).toString(16),\r\n      (rgba.b as number).toString(16),\r\n      Math.round(255 * (rgba.a as number)).toString(16)\r\n    ];\r\n    hex.forEach((x, index) => {\r\n      if (index === 3 && x === 'ff') {\r\n        hex[index] = '';\r\n      }\r\n      if (x.length === 1) {\r\n        hex[index] = '0' + x;\r\n      }\r\n    });\r\n    return `#${hex.join('')}`;\r\n  }\r\n\r\n  rgbaToHsla(rgba: { r?: number; g?: number; b?: number; a?: number }) {\r\n    let [r, g, b] = [(rgba.r as number) / 255, (rgba.g as number) / 255, (rgba.b as number) / 255];\r\n    let [max, min] = [Math.max(r, g, b), Math.min(r, g, b)];\r\n    let h = 0;\r\n    let s = 0;\r\n    let l = (max + min) / 2;\r\n\r\n    if (max === min) {\r\n      h = s = 0;\r\n    } else {\r\n      let d = max - min;\r\n      s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\r\n      switch (max) {\r\n        case r:\r\n          h = (g - b) / d + (g < b ? 6 : 0);\r\n          break;\r\n        case g:\r\n          h = (b - r) / d + 2;\r\n          break;\r\n        case b:\r\n          h = (r - g) / d + 4;\r\n          break;\r\n      }\r\n      h /= 6;\r\n    }\r\n\r\n    return {\r\n      h: Math.round(h * 360),\r\n      s: Number(this.decimal.transform(s, '1.2-2')),\r\n      l: Number(this.decimal.transform(l, '1.2-2')),\r\n      a: Number(rgba.a)\r\n    };\r\n  }\r\n\r\n  hexToRgba(hex: string) {\r\n    let hexNum = hex.substring(1);\r\n    let a = 1;\r\n    if (hexNum.length === 8) {\r\n      a = Number(this.decimal.transform(Number('0x' + hexNum.slice(-2)) / 255, '1.2-2'));\r\n      hexNum = hexNum.substring(0, hexNum.length - 2);\r\n    }\r\n    let num = Number('0x' + (hexNum.length < 6 ? this.repeatLetter(hexNum, 2) : hexNum));\r\n    return { r: num >> 16, g: (num >> 8) & 0xff, b: num & 0xff, a: a };\r\n  }\r\n\r\n  hslToHsv(h: number, s: number, l: number) {\r\n    let hHsv, sHsv, v;\r\n\r\n    hHsv = h;\r\n\r\n    if (l == 0) {\r\n      sHsv = 0;\r\n      v = 0;\r\n    } else if (l > 0 && l <= 0.5) {\r\n      sHsv = (2 * s) / (1 + s);\r\n      v = l * (1 + s);\r\n    } else {\r\n      sHsv = (2 * s - 2 * s * l) / (s - s * l + l);\r\n      v = s - s * l + l;\r\n    }\r\n\r\n    return {\r\n      h: hHsv,\r\n      s: Number(this.decimal.transform(sHsv, '1.2-2')),\r\n      v: Number(this.decimal.transform(v, '1.2-2'))\r\n    };\r\n  }\r\n\r\n  repeatWord(word: string, num: number) {\r\n    let result = '';\r\n    for (let i = 0; i < num; i++) {\r\n      result += word;\r\n    }\r\n    return result;\r\n  }\r\n\r\n  repeatLetter(word: string, num: number) {\r\n    let result = '';\r\n    for (let letter of word) {\r\n      result += this.repeatWord(letter, num);\r\n    }\r\n    return result;\r\n  }\r\n}\r\n","<div class=\"x-color-picker-portal\" tabindex=\"-1\" (click)=\"stopPropagation($event)\">\r\n  <div #panelRef class=\"x-color-picker-portal-panel\">\r\n    <div #plateRef class=\"x-color-picker-portal-plate\" (click)=\"plateClick($event)\">\r\n      <div class=\"x-color-picker-portal-white\"></div>\r\n      <div class=\"x-color-picker-portal-black\"></div>\r\n      <div\r\n        #dragCom\r\n        class=\"x-color-picker-portal-cursor\"\r\n        [style.left.px]=\"transformX()\"\r\n        [style.top.px]=\"transformY()\"\r\n        cdkDrag\r\n        [cdkDragBoundary]=\"panelRef\"\r\n        (cdkDragStarted)=\"started()\"\r\n        (cdkDragEnded)=\"ended()\"\r\n        (cdkDragMoved)=\"moved($event)\"\r\n      ></div>\r\n    </div>\r\n  </div>\r\n  <div class=\"x-color-picker-portal-tool\">\r\n    <div class=\"x-color-picker-portal-operations\">\r\n      <!-- <x-button icon=\"fto-edit-2\" onlyIcon></x-button> -->\r\n      <div class=\"x-color-picker-portal-selected\">\r\n        <div [style.background-color]=\"value()\"></div>\r\n      </div>\r\n      <div class=\"x-color-picker-portal-area\">\r\n        <div class=\"x-color-picker-portal-slider\">\r\n          <x-slider-select\r\n            [style.width.%]=\"100\"\r\n            [(ngModel)]=\"hsla().h\"\r\n            min=\"0\"\r\n            max=\"360\"\r\n            step=\"1\"\r\n            (dragStartEmit)=\"started()\"\r\n            (dragEndEmit)=\"ended()\"\r\n            (ngModelChange)=\"hueChange()\"\r\n          ></x-slider-select>\r\n        </div>\r\n        <div class=\"x-color-picker-portal-transparent\">\r\n          <x-slider-select\r\n            [style.width.%]=\"100\"\r\n            #transparentCom\r\n            [(ngModel)]=\"hsla().a\"\r\n            min=\"0\"\r\n            max=\"1\"\r\n            step=\"0.01\"\r\n            (dragStarted)=\"started()\"\r\n            (dragEnded)=\"ended()\"\r\n            (ngModelChange)=\"transparentChange()\"\r\n          ></x-slider-select>\r\n          <div class=\"x-color-picker-portal-alpha\"></div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"x-color-picker-portal-type\">\r\n      <x-tabs animated=\"false\" justify=\"center\">\r\n        <x-tab label=\"HEX\">\r\n          <div class=\"x-color-picker-portal-type-content\">\r\n            <x-input [style.width.%]=\"100\" [(ngModel)]=\"hex\" (ngModelChange)=\"hexChange()\"></x-input>\r\n          </div>\r\n        </x-tab>\r\n        <x-tab label=\"RGBA\">\r\n          <div class=\"x-color-picker-portal-type-content\">\r\n            <x-input [(ngModel)]=\"rgba().r\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"rgba().g\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"rgba().b\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"rgba().a\" disabled></x-input>\r\n          </div>\r\n        </x-tab>\r\n        <x-tab label=\"HSLA\">\r\n          <div class=\"x-color-picker-portal-type-content\">\r\n            <x-input [(ngModel)]=\"hsla().h\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"hsla().sp\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"hsla().lp\" disabled></x-input>\r\n            <x-input [(ngModel)]=\"hsla().a\" disabled></x-input>\r\n          </div>\r\n        </x-tab>\r\n      </x-tabs>\r\n    </div>\r\n    <div class=\"x-color-picker-panel\">\r\n      <ng-container *ngTemplateOutlet=\"panelTemplate()!\"></ng-container>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
@@ -1,5 +1,5 @@
1
- import { Subject, distinctUntilChanged, fromEvent, interval, takeUntil } from 'rxjs';
2
- import { Component, ViewEncapsulation, ChangeDetectionStrategy, inject, viewChild, signal, computed } from '@angular/core';
1
+ import { Subject, debounceTime, distinctUntilChanged, fromEvent, interval, takeUntil } from 'rxjs';
2
+ import { Component, ViewEncapsulation, ChangeDetectionStrategy, inject, viewChild, signal } from '@angular/core';
3
3
  import { XIsEmpty, XIsNotNil, XIsFunction, XIsString } from '@ng-nest/ui/core';
4
4
  import { XInputNumberPrefix, XInputNumberProperty } from './input-number.property';
5
5
  import { XValueAccessor } from '@ng-nest/ui/base-form';
@@ -14,24 +14,7 @@ export class XInputNumberComponent extends XInputNumberProperty {
14
14
  super();
15
15
  this.inputNumber = viewChild.required('inputNumber');
16
16
  this.inputEleRef = viewChild.required('inputEleRef');
17
- this.displayValue = computed(() => {
18
- const value = this.value();
19
- const formatter = this.formatter();
20
- if (!XIsEmpty(value) && !formatter) {
21
- return Number(value).toFixed(this.precision());
22
- }
23
- else if (formatter) {
24
- const valueFormatter = formatter(Number(this.value()));
25
- const displayValue = XIsNotNil(valueFormatter) ? valueFormatter : '';
26
- if (XIsNotNil(displayValue)) {
27
- return displayValue;
28
- }
29
- else {
30
- return '';
31
- }
32
- }
33
- return '';
34
- });
17
+ this.displayValue = signal('');
35
18
  this.minDisabled = signal(false);
36
19
  this.maxDisabled = signal(false);
37
20
  this.icon = signal('');
@@ -41,13 +24,31 @@ export class XInputNumberComponent extends XInputNumberProperty {
41
24
  this.valueChange = new Subject();
42
25
  this.document = inject(DOCUMENT);
43
26
  this.unSubject = new Subject();
27
+ this.inputValue = new Subject();
44
28
  this.valueChange.pipe(distinctUntilChanged(), takeUntil(this.unSubject)).subscribe((x) => {
45
29
  this.onChange && this.onChange(x);
46
30
  });
31
+ this.inputValue.pipe(debounceTime(500), takeUntil(this.unSubject)).subscribe((value) => {
32
+ if (XIsFunction(this.formatter())) {
33
+ value = value.replace(/[^0-9]/g, '');
34
+ }
35
+ if (value === '') {
36
+ this.value.set(null);
37
+ }
38
+ else {
39
+ this.verify(Number(value));
40
+ this.setDisplayValue(this.value());
41
+ }
42
+ this.valueChange.next(this.value());
43
+ });
47
44
  }
48
- change(value) {
49
- this.verify(value);
50
- this.valueChange.next(this.value());
45
+ writeValue(value) {
46
+ this.value.set(value);
47
+ this.verify(Number(value));
48
+ this.setDisplayValue(this.value());
49
+ }
50
+ ngOnInit() {
51
+ this.setDisplayValue(this.value());
51
52
  }
52
53
  down(event, limit, increase = true) {
53
54
  if (this.disabledComputed())
@@ -93,6 +94,7 @@ export class XInputNumberComponent extends XInputNumberProperty {
93
94
  this.value.set(0);
94
95
  let value = Number(this.value()) + limit;
95
96
  this.verify(value);
97
+ this.setDisplayValue(value);
96
98
  this.valueChange.next(this.value());
97
99
  }
98
100
  verify(value) {
@@ -114,18 +116,32 @@ export class XInputNumberComponent extends XInputNumberProperty {
114
116
  onInput(x) {
115
117
  const input = x.target;
116
118
  let value = input.value;
117
- if (XIsFunction(this.formatter)) {
118
- value = value.replace(/[^0-9]/g, '');
119
+ this.inputValue.next(value);
120
+ }
121
+ setDisplayValue(value) {
122
+ if (XIsEmpty(value)) {
123
+ this.displayValue.set('');
124
+ return;
119
125
  }
120
- this.verify(value);
121
- this.inputEleRef().inputRef().nativeElement.value = this.displayValue();
122
- this.valueChange.next(this.value());
126
+ let displayValue = '';
127
+ const formatter = this.formatter();
128
+ if (!XIsEmpty(value) && !formatter) {
129
+ displayValue = Number(value).toFixed(this.precision());
130
+ }
131
+ else if (formatter) {
132
+ const valueFormatter = formatter(Number(this.value()));
133
+ const val = XIsNotNil(valueFormatter) ? valueFormatter : '';
134
+ if (XIsNotNil(val)) {
135
+ displayValue = val.toString();
136
+ }
137
+ }
138
+ this.displayValue.set(displayValue);
123
139
  }
124
140
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: XInputNumberComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
125
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: XInputNumberComponent, isStandalone: true, selector: "x-input-number", providers: [XValueAccessor(XInputNumberComponent)], viewQueries: [{ propertyName: "inputNumber", first: true, predicate: ["inputNumber"], descendants: true, isSignal: true }, { propertyName: "inputEleRef", first: true, predicate: ["inputEleRef"], descendants: true, isSignal: 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]=\"disabledComputed() || 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 plain\r\n flat\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]=\"disabledComputed()\"\r\n [required]=\"requiredComputed()\"\r\n [validator]=\"validatorComputed()\"\r\n [inputValidator]=\"inputValidator()\"\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 [min]=\"min()\"\r\n [max]=\"max()\"\r\n [bordered]=\"bordered()\"\r\n [before]=\"hiddenButton() ? '' : beforeButtonTpl\"\r\n [after]=\"hiddenButton() ? '' : afterButtonTpl\"\r\n [pattern]=\"patternComputed()\"\r\n [message]=\"messageComputed()\"\r\n (xInput)=\"onInput($event); formControlValidator()\"\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]=\"disabledComputed() || 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 plain\r\n flat\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}.x-input-number,.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 }); }
141
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: XInputNumberComponent, isStandalone: true, selector: "x-input-number", providers: [XValueAccessor(XInputNumberComponent)], viewQueries: [{ propertyName: "inputNumber", first: true, predicate: ["inputNumber"], descendants: true, isSignal: true }, { propertyName: "inputEleRef", first: true, predicate: ["inputEleRef"], descendants: true, isSignal: 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]=\"disabledComputed() || 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 plain\r\n flat\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]=\"disabledComputed()\"\r\n [required]=\"requiredComputed()\"\r\n [validator]=\"validatorComputed()\"\r\n [inputValidator]=\"inputValidator()\"\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 [valueTpl]=\"valueTpl()\"\r\n [valueTplContext]=\"valueTplContext()\"\r\n [size]=\"size()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [bordered]=\"bordered()\"\r\n [before]=\"hiddenButton() ? '' : beforeButtonTpl\"\r\n [after]=\"hiddenButton() ? '' : afterButtonTpl\"\r\n [pattern]=\"patternComputed()\"\r\n [message]=\"messageComputed()\"\r\n (xInput)=\"onInput($event); formControlValidator()\"\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]=\"disabledComputed() || 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 plain\r\n flat\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}.x-input-number,.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 }); }
126
142
  }
127
143
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: XInputNumberComponent, decorators: [{
128
144
  type: Component,
129
- 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]=\"disabledComputed() || 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 plain\r\n flat\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]=\"disabledComputed()\"\r\n [required]=\"requiredComputed()\"\r\n [validator]=\"validatorComputed()\"\r\n [inputValidator]=\"inputValidator()\"\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 [min]=\"min()\"\r\n [max]=\"max()\"\r\n [bordered]=\"bordered()\"\r\n [before]=\"hiddenButton() ? '' : beforeButtonTpl\"\r\n [after]=\"hiddenButton() ? '' : afterButtonTpl\"\r\n [pattern]=\"patternComputed()\"\r\n [message]=\"messageComputed()\"\r\n (xInput)=\"onInput($event); formControlValidator()\"\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]=\"disabledComputed() || 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 plain\r\n flat\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}.x-input-number,.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"] }]
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]=\"disabledComputed() || 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 plain\r\n flat\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]=\"disabledComputed()\"\r\n [required]=\"requiredComputed()\"\r\n [validator]=\"validatorComputed()\"\r\n [inputValidator]=\"inputValidator()\"\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 [valueTpl]=\"valueTpl()\"\r\n [valueTplContext]=\"valueTplContext()\"\r\n [size]=\"size()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [bordered]=\"bordered()\"\r\n [before]=\"hiddenButton() ? '' : beforeButtonTpl\"\r\n [after]=\"hiddenButton() ? '' : afterButtonTpl\"\r\n [pattern]=\"patternComputed()\"\r\n [message]=\"messageComputed()\"\r\n (xInput)=\"onInput($event); formControlValidator()\"\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]=\"disabledComputed() || 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 plain\r\n flat\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}.x-input-number,.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"] }]
130
146
  }], ctorParameters: () => [] });
131
- //# 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, takeUntil } from 'rxjs';\r\nimport {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  inject,\r\n  viewChild,\r\n  signal,\r\n  computed\r\n} from '@angular/core';\r\nimport { XIsEmpty, XNumber, XIsNotNil, 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 {\r\n  inputNumber = viewChild.required<ElementRef<HTMLElement>>('inputNumber');\r\n  inputEleRef = viewChild.required<XInputComponent>('inputEleRef');\r\n\r\n  displayValue = computed(() => {\r\n    const value = this.value();\r\n    const formatter = this.formatter();\r\n    if (!XIsEmpty(value) && !formatter) {\r\n      return Number(value).toFixed(this.precision());\r\n    } else if (formatter) {\r\n      const valueFormatter = formatter(Number(this.value()));\r\n      const displayValue = XIsNotNil(valueFormatter) ? valueFormatter : '';\r\n      if (XIsNotNil(displayValue)) {\r\n        return displayValue;\r\n      } else {\r\n        return '';\r\n      }\r\n    }\r\n    return '';\r\n  });\r\n  minDisabled = signal(false);\r\n  maxDisabled = signal(false);\r\n  mousedown$!: Subscription;\r\n  mouseup$!: Subscription;\r\n  timer: any;\r\n  icon = signal('');\r\n  iconSpin = signal(false);\r\n  clearable = signal(false);\r\n  isDown = signal(false);\r\n  valueChange = new Subject<any>();\r\n\r\n  document = inject(DOCUMENT);\r\n  private unSubject = new Subject<void>();\r\n\r\n  constructor() {\r\n    super();\r\n    this.valueChange.pipe(distinctUntilChanged(), takeUntil(this.unSubject)).subscribe((x) => {\r\n      this.onChange && this.onChange(x);\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  }\r\n\r\n  down(event: Event, limit: XNumber, increase: boolean = true): void {\r\n    if (this.disabledComputed()) return;\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.isDown.set(true);\r\n    this.timer = setTimeout(() => {\r\n      this.mousedown$ = interval(Number(this.debounce()))\r\n        .pipe(takeUntil(this.unSubject))\r\n        .subscribe(() => {\r\n          this.plus(event, limit, increase);\r\n        });\r\n      this.mouseup$ = fromEvent(this.document.documentElement, 'mouseup')\r\n        .pipe(takeUntil(this.unSubject))\r\n        .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.disabledComputed()) return;\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.isDown.set(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.disabledComputed()) 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.set(0);\r\n    let value = Number(this.value()) + limit;\r\n    this.verify(value);\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.set(value);\r\n    if (Number.isNaN(+this.value())) {\r\n      this.value.set(oldValue);\r\n    } else {\r\n      this.maxDisabled.set(value >= this.max());\r\n      this.minDisabled.set(value <= this.min());\r\n      this.value.set(this.maxDisabled() ? this.max() : this.minDisabled() ? this.min() : value);\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.valueChange.next(this.value());\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]=\"disabledComputed() || 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        plain\r\n        flat\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]=\"disabledComputed()\"\r\n      [required]=\"requiredComputed()\"\r\n      [validator]=\"validatorComputed()\"\r\n      [inputValidator]=\"inputValidator()\"\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      [min]=\"min()\"\r\n      [max]=\"max()\"\r\n      [bordered]=\"bordered()\"\r\n      [before]=\"hiddenButton() ? '' : beforeButtonTpl\"\r\n      [after]=\"hiddenButton() ? '' : afterButtonTpl\"\r\n      [pattern]=\"patternComputed()\"\r\n      [message]=\"messageComputed()\"\r\n      (xInput)=\"onInput($event); formControlValidator()\"\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]=\"disabledComputed() || 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        plain\r\n        flat\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"]}
147
+ //# 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, debounceTime, distinctUntilChanged, fromEvent, interval, takeUntil } from 'rxjs';\r\nimport {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  inject,\r\n  viewChild,\r\n  signal\r\n} from '@angular/core';\r\nimport { XIsEmpty, XNumber, XIsNotNil, 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 {\r\n  inputNumber = viewChild.required<ElementRef<HTMLElement>>('inputNumber');\r\n  inputEleRef = viewChild.required<XInputComponent>('inputEleRef');\r\n\r\n  displayValue = signal<string>('');\r\n  minDisabled = signal(false);\r\n  maxDisabled = signal(false);\r\n  mousedown$!: Subscription;\r\n  mouseup$!: Subscription;\r\n  timer: any;\r\n  icon = signal('');\r\n  iconSpin = signal(false);\r\n  clearable = signal(false);\r\n  isDown = signal(false);\r\n  valueChange = new Subject<any>();\r\n\r\n  document = inject(DOCUMENT);\r\n  private unSubject = new Subject<void>();\r\n\r\n  inputValue = new Subject<string>();\r\n\r\n  constructor() {\r\n    super();\r\n    this.valueChange.pipe(distinctUntilChanged(), takeUntil(this.unSubject)).subscribe((x) => {\r\n      this.onChange && this.onChange(x);\r\n    });\r\n\r\n    this.inputValue.pipe(debounceTime(500), takeUntil(this.unSubject)).subscribe((value) => {\r\n      if (XIsFunction(this.formatter())) {\r\n        value = value.replace(/[^0-9]/g, '');\r\n      }\r\n      if (value === '') {\r\n        this.value.set(null);\r\n      } else {\r\n        this.verify(Number(value));\r\n        this.setDisplayValue(this.value());\r\n      }\r\n      this.valueChange.next(this.value());\r\n    });\r\n  }\r\n\r\n  override writeValue(value: any): void {\r\n    this.value.set(value);\r\n    this.verify(Number(value));\r\n    this.setDisplayValue(this.value());\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setDisplayValue(this.value());\r\n  }\r\n\r\n  down(event: Event, limit: XNumber, increase: boolean = true): void {\r\n    if (this.disabledComputed()) return;\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.isDown.set(true);\r\n    this.timer = setTimeout(() => {\r\n      this.mousedown$ = interval(Number(this.debounce()))\r\n        .pipe(takeUntil(this.unSubject))\r\n        .subscribe(() => {\r\n          this.plus(event, limit, increase);\r\n        });\r\n      this.mouseup$ = fromEvent(this.document.documentElement, 'mouseup')\r\n        .pipe(takeUntil(this.unSubject))\r\n        .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.disabledComputed()) return;\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.isDown.set(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.disabledComputed()) 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.set(0);\r\n    let value = Number(this.value()) + limit;\r\n    this.verify(value);\r\n    this.setDisplayValue(value);\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.set(value);\r\n    if (Number.isNaN(+this.value())) {\r\n      this.value.set(oldValue);\r\n    } else {\r\n      this.maxDisabled.set(value >= this.max());\r\n      this.minDisabled.set(value <= this.min());\r\n      this.value.set(this.maxDisabled() ? this.max() : this.minDisabled() ? this.min() : value);\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    this.inputValue.next(value);\r\n  }\r\n\r\n  setDisplayValue(value: string | number) {\r\n    if (XIsEmpty(value)) {\r\n      this.displayValue.set('');\r\n      return;\r\n    }\r\n    let displayValue = '';\r\n    const formatter = this.formatter();\r\n    if (!XIsEmpty(value) && !formatter) {\r\n      displayValue = Number(value).toFixed(this.precision());\r\n    } else if (formatter) {\r\n      const valueFormatter = formatter(Number(this.value()));\r\n      const val = XIsNotNil(valueFormatter) ? valueFormatter : '';\r\n      if (XIsNotNil(val)) {\r\n        displayValue = val.toString();\r\n      }\r\n    }\r\n    this.displayValue.set(displayValue);\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]=\"disabledComputed() || 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        plain\r\n        flat\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]=\"disabledComputed()\"\r\n      [required]=\"requiredComputed()\"\r\n      [validator]=\"validatorComputed()\"\r\n      [inputValidator]=\"inputValidator()\"\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      [valueTpl]=\"valueTpl()\"\r\n      [valueTplContext]=\"valueTplContext()\"\r\n      [size]=\"size()\"\r\n      [min]=\"min()\"\r\n      [max]=\"max()\"\r\n      [bordered]=\"bordered()\"\r\n      [before]=\"hiddenButton() ? '' : beforeButtonTpl\"\r\n      [after]=\"hiddenButton() ? '' : afterButtonTpl\"\r\n      [pattern]=\"patternComputed()\"\r\n      [message]=\"messageComputed()\"\r\n      (xInput)=\"onInput($event); formControlValidator()\"\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]=\"disabledComputed() || 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        plain\r\n        flat\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"]}