@alauda/ui 7.3.3-beta.10 → 7.3.3-beta.11

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,5 +1,5 @@
1
1
  import { Directive, ElementRef, EventEmitter, inject, Input, Output, Renderer2, } from '@angular/core';
2
- import { fromEvent, Subject, take, takeUntil } from 'rxjs';
2
+ import { fromEvent, map, Subject, switchMap, takeUntil, tap } from 'rxjs';
3
3
  import { handlePixel } from '../utils';
4
4
  import * as i0 from "@angular/core";
5
5
  export class ContainerForResizableDirective {
@@ -32,8 +32,6 @@ export class ResizableDirective {
32
32
  element = this.elementRef.nativeElement;
33
33
  containerElement = this.containerDirective?.el.nativeElement || this.element;
34
34
  destroy$$ = new Subject();
35
- initialWidth;
36
- mouseDownScreenX;
37
35
  resizeHandle;
38
36
  resizeOverlay;
39
37
  resizeBar;
@@ -41,6 +39,7 @@ export class ResizableDirective {
41
39
  BAR_WIDTH = 2;
42
40
  ngAfterViewInit() {
43
41
  this.createResizeHandle();
42
+ this.binEvent(this.resizeHandle, 'click').subscribe(event => event.stopPropagation());
44
43
  this.binEvent(this.element, 'mouseover').subscribe(() => {
45
44
  this.handleHasUp = true;
46
45
  if (!this.resizeBar) {
@@ -51,6 +50,7 @@ export class ResizableDirective {
51
50
  this.handleHasUp = false;
52
51
  this.setResizeHandleVisible(false);
53
52
  });
53
+ this.bindResizable();
54
54
  }
55
55
  ngOnDestroy() {
56
56
  this.destroy$$.next();
@@ -59,21 +59,53 @@ export class ResizableDirective {
59
59
  binEvent(target, eventType) {
60
60
  return fromEvent(target, eventType).pipe(takeUntil(this.destroy$$));
61
61
  }
62
+ bindResizable() {
63
+ let initialWidth;
64
+ let mouseDownScreenX;
65
+ const mouseup$ = this.binEvent(document, 'mouseup').pipe(tap(event => {
66
+ if (this.handleHasUp) {
67
+ this.setResizeHandleVisible(true);
68
+ }
69
+ this.renderer2.removeChild(this.containerElement, this.resizeOverlay);
70
+ this.resizeOverlay = null;
71
+ this.renderer2.removeChild(this.containerElement, this.resizeBar);
72
+ this.resizeBar = null;
73
+ const movementX = event.clientX - mouseDownScreenX;
74
+ const newWidth = initialWidth + movementX;
75
+ const width = this.getFinalWidth(newWidth);
76
+ if (!this.manualAdjustment) {
77
+ this.renderer2.setStyle(this.element, 'width', handlePixel(width));
78
+ }
79
+ this.resizeEnd.emit(width);
80
+ }));
81
+ this.binEvent(this.resizeHandle, 'mousedown')
82
+ .pipe(tap(event => {
83
+ event.preventDefault();
84
+ event.stopPropagation();
85
+ initialWidth = this.element.clientWidth;
86
+ mouseDownScreenX = event.clientX;
87
+ this.resizeStart.emit(initialWidth);
88
+ this.setResizeHandleVisible(false);
89
+ this.createResizeOverlay();
90
+ this.createResizeBar();
91
+ }), switchMap(() => this.binEvent(document, 'mousemove').pipe(map(event => {
92
+ const movementX = event.clientX - mouseDownScreenX;
93
+ const newWidth = initialWidth + movementX;
94
+ const width = this.getFinalWidth(newWidth);
95
+ this.resizing.emit(width);
96
+ return width;
97
+ }), takeUntil(mouseup$))))
98
+ .subscribe(width => {
99
+ this.renderer2.setStyle(this.resizeBar, 'left', handlePixel(width + this.getOffset() - this.BAR_WIDTH));
100
+ this.resizing.emit(width);
101
+ });
102
+ }
62
103
  setResizeHandleVisible(isVisible) {
63
- if (this.resizeHandle) {
64
- this.renderer2.setStyle(this.resizeHandle, 'visibility', isVisible ? 'visible' : 'hidden');
65
- }
104
+ this.renderer2.setStyle(this.resizeHandle, 'visibility', isVisible ? 'visible' : 'hidden');
66
105
  }
67
106
  createResizeHandle() {
68
- if (this.resizeHandle) {
69
- return;
70
- }
71
107
  this.resizeHandle = this.renderer2.createElement('div');
72
108
  this.renderer2.addClass(this.resizeHandle, 'resize-handle');
73
- this.binEvent(this.resizeHandle, 'click').subscribe(event => event.stopPropagation());
74
- this.binEvent(this.resizeHandle, 'mousedown').subscribe(event => {
75
- this.onMousedown(event);
76
- });
77
109
  this.renderer2.appendChild(this.element, this.resizeHandle);
78
110
  }
79
111
  createResizeOverlay() {
@@ -87,51 +119,6 @@ export class ResizableDirective {
87
119
  this.renderer2.setStyle(this.resizeBar, 'left', this.element.clientWidth + this.getOffset() - this.BAR_WIDTH + 'px');
88
120
  this.renderer2.appendChild(this.containerElement, this.resizeBar);
89
121
  }
90
- onMousedown(event) {
91
- event.preventDefault();
92
- event.stopPropagation();
93
- this.setResizeHandleVisible(false);
94
- this.initialWidth = this.element.clientWidth;
95
- this.resizeStart.emit(this.initialWidth);
96
- this.mouseDownScreenX = event.clientX;
97
- this.createResizeOverlay();
98
- this.createResizeBar();
99
- const mouseup$ = this.binEvent(document, 'mouseup').pipe(take(1));
100
- mouseup$.subscribe(event => {
101
- this.onMouseup(event);
102
- });
103
- this.binEvent(document, 'mousemove')
104
- .pipe(takeUntil(mouseup$))
105
- .subscribe(event => {
106
- this.move(event);
107
- });
108
- }
109
- onMouseup(event) {
110
- if (this.handleHasUp) {
111
- this.setResizeHandleVisible(true);
112
- }
113
- this.renderer2.removeChild(this.containerElement, this.resizeOverlay);
114
- this.resizeOverlay = null;
115
- this.renderer2.removeChild(this.containerElement, this.resizeBar);
116
- this.resizeBar = null;
117
- const movementX = event.clientX - this.mouseDownScreenX;
118
- const newWidth = this.initialWidth + movementX;
119
- const width = this.getFinalWidth(newWidth);
120
- if (!this.manualAdjustment) {
121
- this.renderer2.setStyle(this.element, 'width', handlePixel(width));
122
- }
123
- this.resizeEnd.emit(width);
124
- }
125
- move(event) {
126
- if (!this.resizeBar) {
127
- return;
128
- }
129
- const movementX = event.clientX - this.mouseDownScreenX;
130
- const newWidth = this.initialWidth + movementX;
131
- const finalWidth = this.getFinalWidth(newWidth);
132
- this.renderer2.setStyle(this.resizeBar, 'left', handlePixel(finalWidth + this.getOffset() - this.BAR_WIDTH));
133
- this.resizing.emit(finalWidth);
134
- }
135
122
  getFinalWidth(newWidth) {
136
123
  const _max = this.containerElement.clientWidth + this.getOffset();
137
124
  const minWidth = this.handleWidth(this.minWidth || this.getOffset());
@@ -180,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
180
167
  }], resizeEnd: [{
181
168
  type: Output
182
169
  }] } });
183
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable.directive.js","sourceRoot":"","sources":["../../../src/resizable/resizable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Input,\n  OnDestroy,\n  Output,\n  Renderer2,\n} from '@angular/core';\nimport { fromEvent, Subject, take, takeUntil } from 'rxjs';\n\nimport { handlePixel } from '../utils';\n\n@Directive({\n  selector: '[auiContainerForResizable]',\n  host: {\n    class: 'aui-container-for-resizable',\n  },\n  standalone: true,\n})\nexport class ContainerForResizableDirective {\n  el = inject<ElementRef<HTMLElement>>(ElementRef);\n}\n\n/**\n * 使用此指令需要引入 resizable.scss\n * @example `node_modules/@alauda/ui/resizable/resizable`\n */\n@Directive({\n  selector: '[auiResizable]',\n  host: {\n    class: 'aui-resizable',\n  },\n  standalone: true,\n})\nexport class ResizableDirective implements AfterViewInit, OnDestroy {\n  @Input()\n  minWidth: string | number;\n\n  @Input()\n  maxWidth: string | number;\n\n  @Input()\n  manualAdjustment = false;\n\n  @Output()\n  resizeStart = new EventEmitter<number>();\n\n  @Output()\n  resizing = new EventEmitter<number>();\n\n  @Output()\n  resizeEnd = new EventEmitter<number>();\n\n  elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  renderer2 = inject(Renderer2);\n  containerDirective = inject(ContainerForResizableDirective, {\n    optional: true,\n  });\n\n  private readonly element = this.elementRef.nativeElement;\n  containerElement = this.containerDirective?.el.nativeElement || this.element;\n\n  destroy$$ = new Subject<void>();\n\n  private initialWidth: number;\n  private mouseDownScreenX: number;\n  resizeHandle: HTMLElement; // 在指令作用的元素上插入引导分割线，hover到作用元素后出现，拖动事件的宿主\n  resizeOverlay: HTMLElement; // 在拖动时创建出一个透明的遮罩层，用以鼠标样式在拖动时总是拖动样式\n  resizeBar: HTMLElement; // 拖动时的参考线，该参考线会被插入到 containerElement\n  private handleHasUp: boolean;\n  private readonly BAR_WIDTH = 2;\n\n  ngAfterViewInit() {\n    this.createResizeHandle();\n\n    this.binEvent(this.element, 'mouseover').subscribe(() => {\n      this.handleHasUp = true;\n      if (!this.resizeBar) {\n        this.setResizeHandleVisible(true);\n      }\n    });\n    this.binEvent(this.element, 'mouseout').subscribe(() => {\n      this.handleHasUp = false;\n      this.setResizeHandleVisible(false);\n    });\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  private binEvent<E>(\n    target: HTMLElement | Document | Window,\n    eventType: string,\n  ) {\n    return fromEvent<E>(target, eventType).pipe(takeUntil(this.destroy$$));\n  }\n\n  private setResizeHandleVisible(isVisible: boolean) {\n    if (this.resizeHandle) {\n      this.renderer2.setStyle(\n        this.resizeHandle,\n        'visibility',\n        isVisible ? 'visible' : 'hidden',\n      );\n    }\n  }\n\n  private createResizeHandle() {\n    if (this.resizeHandle) {\n      return;\n    }\n\n    this.resizeHandle = this.renderer2.createElement('div');\n    this.renderer2.addClass(this.resizeHandle, 'resize-handle');\n\n    this.binEvent<Event>(this.resizeHandle, 'click').subscribe(event =>\n      event.stopPropagation(),\n    );\n    this.binEvent<MouseEvent>(this.resizeHandle, 'mousedown').subscribe(\n      event => {\n        this.onMousedown(event);\n      },\n    );\n\n    this.renderer2.appendChild(this.element, this.resizeHandle);\n  }\n\n  private createResizeOverlay() {\n    this.resizeOverlay = this.renderer2.createElement('div');\n    this.renderer2.addClass(this.resizeOverlay, 'resize-overlay');\n    this.renderer2.appendChild(this.containerElement, this.resizeOverlay);\n  }\n\n  private createResizeBar() {\n    this.resizeBar = this.renderer2.createElement('div');\n    this.renderer2.addClass(this.resizeBar, 'resize-bar');\n    this.renderer2.setStyle(\n      this.resizeBar,\n      'left',\n      this.element.clientWidth + this.getOffset() - this.BAR_WIDTH + 'px',\n    );\n    this.renderer2.appendChild(this.containerElement, this.resizeBar);\n  }\n\n  private onMousedown(event: MouseEvent): void {\n    event.preventDefault();\n    event.stopPropagation();\n\n    // 避免两条线不对齐\n    this.setResizeHandleVisible(false);\n\n    this.initialWidth = this.element.clientWidth;\n    this.resizeStart.emit(this.initialWidth);\n    this.mouseDownScreenX = event.clientX;\n    this.createResizeOverlay();\n    this.createResizeBar();\n\n    const mouseup$ = this.binEvent<MouseEvent>(document, 'mouseup').pipe(\n      take(1),\n    );\n    mouseup$.subscribe(event => {\n      this.onMouseup(event);\n    });\n\n    this.binEvent<MouseEvent>(document, 'mousemove')\n      .pipe(takeUntil(mouseup$))\n      .subscribe(event => {\n        this.move(event);\n      });\n  }\n\n  private onMouseup(event: MouseEvent): void {\n    if (this.handleHasUp) {\n      this.setResizeHandleVisible(true);\n    }\n\n    this.renderer2.removeChild(this.containerElement, this.resizeOverlay);\n    this.resizeOverlay = null;\n    this.renderer2.removeChild(this.containerElement, this.resizeBar);\n    this.resizeBar = null;\n\n    const movementX = event.clientX - this.mouseDownScreenX;\n    const newWidth = this.initialWidth + movementX;\n    const width = this.getFinalWidth(newWidth);\n\n    if (!this.manualAdjustment) {\n      this.renderer2.setStyle(this.element, 'width', handlePixel(width));\n    }\n    this.resizeEnd.emit(width);\n  }\n\n  private move(event: MouseEvent) {\n    if (!this.resizeBar) {\n      return;\n    }\n    const movementX = event.clientX - this.mouseDownScreenX;\n    const newWidth = this.initialWidth + movementX;\n\n    const finalWidth = this.getFinalWidth(newWidth);\n    this.renderer2.setStyle(\n      this.resizeBar,\n      'left',\n      handlePixel(finalWidth + this.getOffset() - this.BAR_WIDTH),\n    );\n    this.resizing.emit(finalWidth);\n  }\n\n  private getFinalWidth(newWidth: number): number {\n    // 不能超出边界\n    const _max = this.containerElement.clientWidth + this.getOffset();\n    const minWidth = this.handleWidth(this.minWidth || this.getOffset());\n    const maxWidth = this.handleWidth(this.maxWidth || _max);\n    return Math.max(Math.min(maxWidth, newWidth), minWidth);\n  }\n\n  private getOffset() {\n    return (\n      this.element.getBoundingClientRect().left -\n      this.containerElement.getBoundingClientRect().left\n    );\n  }\n\n  private handleWidth(width: string | number) {\n    if (typeof width === 'number') {\n      return width;\n    }\n    if (!width) {\n      return;\n    }\n    if (width.endsWith('%')) {\n      const tableWidth = this.containerElement.clientWidth;\n      return (tableWidth * Number.parseFloat(width)) / 100;\n    }\n    return Number.parseFloat(width.replace(/\\D+/, ''));\n  }\n}\n"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable.directive.js","sourceRoot":"","sources":["../../../src/resizable/resizable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Input,\n  OnDestroy,\n  Output,\n  Renderer2,\n} from '@angular/core';\nimport { fromEvent, map, Subject, switchMap, takeUntil, tap } from 'rxjs';\n\nimport { handlePixel } from '../utils';\n\n@Directive({\n  selector: '[auiContainerForResizable]',\n  host: {\n    class: 'aui-container-for-resizable',\n  },\n  standalone: true,\n})\nexport class ContainerForResizableDirective {\n  el = inject<ElementRef<HTMLElement>>(ElementRef);\n}\n\n/**\n * 使用此指令需要引入 resizable.scss\n * @example `@import 'node_modules/@alauda/ui/resizable/resizable';`\n */\n@Directive({\n  selector: '[auiResizable]',\n  host: {\n    class: 'aui-resizable',\n  },\n  standalone: true,\n})\nexport class ResizableDirective implements AfterViewInit, OnDestroy {\n  @Input()\n  minWidth: string | number;\n\n  @Input()\n  maxWidth: string | number;\n\n  @Input()\n  manualAdjustment = false;\n\n  @Output()\n  resizeStart = new EventEmitter<number>();\n\n  @Output()\n  resizing = new EventEmitter<number>();\n\n  @Output()\n  resizeEnd = new EventEmitter<number>();\n\n  private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  renderer2 = inject(Renderer2);\n  private readonly containerDirective = inject(ContainerForResizableDirective, {\n    optional: true,\n  });\n\n  private readonly element = this.elementRef.nativeElement;\n  containerElement = this.containerDirective?.el.nativeElement || this.element;\n\n  destroy$$ = new Subject<void>();\n\n  resizeHandle: HTMLElement; // 在指令作用的元素上插入引导分割线，hover到作用元素后出现，拖动事件的宿主\n  resizeOverlay: HTMLElement; // 在拖动时创建出一个透明的遮罩层，用以鼠标样式在拖动时总是拖动样式\n  resizeBar: HTMLElement; // 拖动时的参考线，该参考线会被插入到 containerElement\n  private handleHasUp: boolean;\n  private readonly BAR_WIDTH = 2;\n\n  ngAfterViewInit() {\n    this.createResizeHandle();\n\n    this.binEvent<Event>(this.resizeHandle, 'click').subscribe(event =>\n      event.stopPropagation(),\n    );\n\n    this.binEvent(this.element, 'mouseover').subscribe(() => {\n      this.handleHasUp = true;\n      if (!this.resizeBar) {\n        this.setResizeHandleVisible(true);\n      }\n    });\n    this.binEvent(this.element, 'mouseout').subscribe(() => {\n      this.handleHasUp = false;\n      this.setResizeHandleVisible(false);\n    });\n\n    this.bindResizable();\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  private binEvent<E>(\n    target: HTMLElement | Document | Window,\n    eventType: string,\n  ) {\n    return fromEvent<E>(target, eventType).pipe(takeUntil(this.destroy$$));\n  }\n\n  private bindResizable() {\n    let initialWidth: number;\n    let mouseDownScreenX: number;\n\n    const mouseup$ = this.binEvent<MouseEvent>(document, 'mouseup').pipe(\n      tap(event => {\n        if (this.handleHasUp) {\n          this.setResizeHandleVisible(true);\n        }\n\n        this.renderer2.removeChild(this.containerElement, this.resizeOverlay);\n        this.resizeOverlay = null;\n        this.renderer2.removeChild(this.containerElement, this.resizeBar);\n        this.resizeBar = null;\n\n        const movementX = event.clientX - mouseDownScreenX;\n        const newWidth = initialWidth + movementX;\n        const width = this.getFinalWidth(newWidth);\n\n        if (!this.manualAdjustment) {\n          this.renderer2.setStyle(this.element, 'width', handlePixel(width));\n        }\n        this.resizeEnd.emit(width);\n      }),\n    );\n\n    this.binEvent<MouseEvent>(this.resizeHandle, 'mousedown')\n      .pipe(\n        tap(event => {\n          event.preventDefault();\n          event.stopPropagation();\n\n          initialWidth = this.element.clientWidth;\n          mouseDownScreenX = event.clientX;\n          this.resizeStart.emit(initialWidth);\n\n          // 避免两条线不对齐\n          this.setResizeHandleVisible(false);\n          this.createResizeOverlay();\n          this.createResizeBar();\n        }),\n        switchMap(() =>\n          this.binEvent<MouseEvent>(document, 'mousemove').pipe(\n            map(event => {\n              const movementX = event.clientX - mouseDownScreenX;\n              const newWidth = initialWidth + movementX;\n              const width = this.getFinalWidth(newWidth);\n              this.resizing.emit(width);\n              return width;\n            }),\n            takeUntil(mouseup$),\n          ),\n        ),\n      )\n      .subscribe(width => {\n        this.renderer2.setStyle(\n          this.resizeBar,\n          'left',\n          handlePixel(width + this.getOffset() - this.BAR_WIDTH),\n        );\n        this.resizing.emit(width);\n      });\n  }\n\n  private setResizeHandleVisible(isVisible: boolean) {\n    this.renderer2.setStyle(\n      this.resizeHandle,\n      'visibility',\n      isVisible ? 'visible' : 'hidden',\n    );\n  }\n\n  private createResizeHandle() {\n    this.resizeHandle = this.renderer2.createElement('div');\n    this.renderer2.addClass(this.resizeHandle, 'resize-handle');\n    this.renderer2.appendChild(this.element, this.resizeHandle);\n  }\n\n  private createResizeOverlay() {\n    this.resizeOverlay = this.renderer2.createElement('div');\n    this.renderer2.addClass(this.resizeOverlay, 'resize-overlay');\n    this.renderer2.appendChild(this.containerElement, this.resizeOverlay);\n  }\n\n  private createResizeBar() {\n    this.resizeBar = this.renderer2.createElement('div');\n    this.renderer2.addClass(this.resizeBar, 'resize-bar');\n    this.renderer2.setStyle(\n      this.resizeBar,\n      'left',\n      this.element.clientWidth + this.getOffset() - this.BAR_WIDTH + 'px',\n    );\n    this.renderer2.appendChild(this.containerElement, this.resizeBar);\n  }\n\n  private getFinalWidth(newWidth: number): number {\n    // 不能超出边界\n    const _max = this.containerElement.clientWidth + this.getOffset();\n    const minWidth = this.handleWidth(this.minWidth || this.getOffset());\n    const maxWidth = this.handleWidth(this.maxWidth || _max);\n    return Math.max(Math.min(maxWidth, newWidth), minWidth);\n  }\n\n  private getOffset() {\n    return (\n      this.element.getBoundingClientRect().left -\n      this.containerElement.getBoundingClientRect().left\n    );\n  }\n\n  private handleWidth(width: string | number) {\n    if (typeof width === 'number') {\n      return width;\n    }\n    if (!width) {\n      return;\n    }\n    if (width.endsWith('%')) {\n      const tableWidth = this.containerElement.clientWidth;\n      return (tableWidth * Number.parseFloat(width)) / 100;\n    }\n    return Number.parseFloat(width.replace(/\\D+/, ''));\n  }\n}\n"]}
@@ -31,20 +31,20 @@ export class TableColResizableDirective extends ResizableDirective {
31
31
  flex: none !important;
32
32
  }
33
33
  `;
34
- if (CSSStyleSheet) {
35
- if (!this.sheet) {
36
- this.sheet = new CSSStyleSheet();
37
- document.adoptedStyleSheets.push(this.sheet);
38
- }
39
- this.sheet.replaceSync(styleString);
40
- }
41
- else {
34
+ if (typeof CSSStyleSheet === 'undefined') {
42
35
  if (!this.styleEl) {
43
36
  this.styleEl = this.renderer2.createElement('style');
44
37
  this.renderer2.appendChild(this.containerElement, this.styleEl);
45
38
  }
46
39
  this.styleEl.innerHTML = styleString;
47
40
  }
41
+ else {
42
+ if (!this.sheet) {
43
+ this.sheet = new CSSStyleSheet();
44
+ document.adoptedStyleSheets.push(this.sheet);
45
+ }
46
+ this.sheet.replaceSync(styleString);
47
+ }
48
48
  this.tableComponent.updateStickyColumnStyles();
49
49
  });
50
50
  }
@@ -53,6 +53,7 @@ export class TableColResizableDirective extends ResizableDirective {
53
53
  if (this.sheet) {
54
54
  const idx = document.adoptedStyleSheets.indexOf(this.sheet);
55
55
  document.adoptedStyleSheets.splice(idx, 1);
56
+ this.sheet = null;
56
57
  }
57
58
  }
58
59
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TableColResizableDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
@@ -67,4 +68,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
67
68
  }], propDecorators: { minWidth: [{
68
69
  type: Input
69
70
  }] } });
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sLXJlc2l6YWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdGFibGUvdGFibGUtY29sLXJlc2l6YWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRWpDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNsRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRXZDLE9BQU8sRUFDTCxRQUFRLEVBQ1IsdUJBQXVCLEVBQ3ZCLGNBQWMsRUFDZCwyQkFBMkIsR0FDNUIsTUFBTSxTQUFTLENBQUM7O0FBRWpCLElBQUksNkJBQTZCLEdBQUcsQ0FBQyxDQUFDO0FBTXRDLE1BQU0sT0FBTywwQkFDWCxTQUFRLGtCQUFrQjtJQUlqQixRQUFRLEdBQUcsTUFBTSxDQUFDO0lBRVQsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO0lBRXpCLHVCQUF1QixHQUFHLE1BQU0sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO0lBQzFELGNBQWMsR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDeEMsMkJBQTJCLEdBQUcsTUFBTSxDQUNuRCwyQkFBMkIsRUFDM0I7UUFDRSxRQUFRLEVBQUUsSUFBSTtLQUNmLENBQ0YsQ0FBQztJQUVNLE9BQU8sQ0FBbUI7SUFDMUIsS0FBSyxDQUFnQjtJQUNyQixRQUFRLENBQVM7SUFFaEIsZUFBZTtRQUN0QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFeEIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLENBQ3RCLElBQUksQ0FBQywyQkFBMkIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUN4RCxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFFbkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUMvRCxNQUFNLFNBQVMsR0FBRyxRQUFRLENBQUMsT0FBTyxDQUNoQyxVQUFVLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxvQkFBb0IsRUFBRSxDQUM5RCxDQUFDO1lBQ0YsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUcsaUNBQWlDLDZCQUE2QixFQUFFLEVBQUUsQ0FBQztnQkFDbkYsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO2FBQ3ZEO1lBQ0QsTUFBTSxXQUFXLEdBQUc7VUFDaEIsSUFBSSxDQUFDLFFBQVEsTUFBTSxTQUFTO2lCQUNyQixXQUFXLENBQUMsS0FBSyxDQUFDOzs7T0FHNUIsQ0FBQztZQUNGLElBQUksYUFBYSxFQUFFO2dCQUNqQixJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRTtvQkFDZixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksYUFBYSxFQUFFLENBQUM7b0JBQ2pDLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO2lCQUM5QztnQkFDRCxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsQ0FBQzthQUNyQztpQkFBTTtnQkFDTCxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtvQkFDakIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztvQkFDckQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztpQkFDakU7Z0JBQ0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEdBQUcsV0FBVyxDQUFDO2FBQ3RDO1lBRUQsSUFBSSxDQUFDLGNBQWMsQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1FBQ2pELENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVRLFdBQVc7UUFDbEIsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBRXBCLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNkLE1BQU0sR0FBRyxHQUFHLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzVELFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDO1NBQzVDO0lBQ0gsQ0FBQzt1R0FwRVUsMEJBQTBCOzJGQUExQiwwQkFBMEI7OzJGQUExQiwwQkFBMEI7a0JBSnRDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzhCQU1VLFFBQVE7c0JBRGhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdJbml0LCBEaXJlY3RpdmUsIGluamVjdCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBSZXNpemFibGVEaXJlY3RpdmUgfSBmcm9tICcuLi9yZXNpemFibGUnO1xuaW1wb3J0IHsgaGFuZGxlUGl4ZWwgfSBmcm9tICcuLi91dGlscyc7XG5cbmltcG9ydCB7XG4gIHRhYmxlQmVtLFxuICBUYWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSxcbiAgVGFibGVDb21wb25lbnQsXG4gIFRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSxcbn0gZnJvbSAnLi9pbmRleCc7XG5cbmxldCB0YWJsZVJlc2l6YWJsZUR5bmFtaWNTdHlsZVVpZCA9IDA7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1thdWlUYWJsZUNvbFJlc2l6YWJsZV0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJsZUNvbFJlc2l6YWJsZURpcmVjdGl2ZVxuICBleHRlbmRzIFJlc2l6YWJsZURpcmVjdGl2ZVxuICBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXRcbntcbiAgQElucHV0KClcbiAgb3ZlcnJpZGUgbWluV2lkdGggPSAnNjBweCc7XG5cbiAgb3ZlcnJpZGUgcmVhZG9ubHkgbWFudWFsQWRqdXN0bWVudCA9IHRydWU7XG5cbiAgcHJpdmF0ZSByZWFkb25seSB0YWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSA9IGluamVjdChUYWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgdGFibGVDb21wb25lbnQgPSBpbmplY3QoVGFibGVDb21wb25lbnQpO1xuICBwcml2YXRlIHJlYWRvbmx5IHRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSA9IGluamVjdChcbiAgICBUYWJsZVNjcm9sbFdyYXBwZXJEaXJlY3RpdmUsXG4gICAge1xuICAgICAgb3B0aW9uYWw6IHRydWUsXG4gICAgfSxcbiAgKTtcblxuICBwcml2YXRlIHN0eWxlRWw6IEhUTUxTdHlsZUVsZW1lbnQ7XG4gIHByaXZhdGUgc2hlZXQ6IENTU1N0eWxlU2hlZXQ7XG4gIHByaXZhdGUgaG9zdEF0dHI6IHN0cmluZztcblxuICBvdmVycmlkZSBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgc3VwZXIubmdBZnRlclZpZXdJbml0KCk7XG5cbiAgICB0aGlzLmNvbnRhaW5lckVsZW1lbnQgPSAoXG4gICAgICB0aGlzLnRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSB8fCB0aGlzLnRhYmxlQ29tcG9uZW50XG4gICAgKS5lbC5uYXRpdmVFbGVtZW50O1xuXG4gICAgdGhpcy5yZXNpemVFbmQucGlwZSh0YWtlVW50aWwodGhpcy5kZXN0cm95JCQpKS5zdWJzY3JpYmUod2lkdGggPT4ge1xuICAgICAgY29uc3QgY2xhc3NOYW1lID0gdGFibGVCZW0uZWxlbWVudChcbiAgICAgICAgYGNvbHVtbi0ke3RoaXMudGFibGVDb2x1bW5EZWZEaXJlY3RpdmUuY3NzQ2xhc3NGcmllbmRseU5hbWV9YCxcbiAgICAgICk7XG4gICAgICBpZiAoIXRoaXMuaG9zdEF0dHIpIHtcbiAgICAgICAgdGhpcy5ob3N0QXR0ciA9IGB0YWJsZS1yZXNpemFibGUtZHluYW1pYy1zdHlsZS0ke3RhYmxlUmVzaXphYmxlRHluYW1pY1N0eWxlVWlkKyt9YDtcbiAgICAgICAgdGhpcy5jb250YWluZXJFbGVtZW50LnNldEF0dHJpYnV0ZSh0aGlzLmhvc3RBdHRyLCAnJyk7XG4gICAgICB9XG4gICAgICBjb25zdCBzdHlsZVN0cmluZyA9IGBcbiAgICAgICBbJHt0aGlzLmhvc3RBdHRyfV0gLiR7Y2xhc3NOYW1lfSB7XG4gICAgICAgIHdpZHRoOiAke2hhbmRsZVBpeGVsKHdpZHRoKX0gIWltcG9ydGFudDtcbiAgICAgICAgZmxleDogbm9uZSAhaW1wb3J0YW50O1xuICAgICAgfVxuICAgICAgYDtcbiAgICAgIGlmIChDU1NTdHlsZVNoZWV0KSB7XG4gICAgICAgIGlmICghdGhpcy5zaGVldCkge1xuICAgICAgICAgIHRoaXMuc2hlZXQgPSBuZXcgQ1NTU3R5bGVTaGVldCgpO1xuICAgICAgICAgIGRvY3VtZW50LmFkb3B0ZWRTdHlsZVNoZWV0cy5wdXNoKHRoaXMuc2hlZXQpO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMuc2hlZXQucmVwbGFjZVN5bmMoc3R5bGVTdHJpbmcpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgaWYgKCF0aGlzLnN0eWxlRWwpIHtcbiAgICAgICAgICB0aGlzLnN0eWxlRWwgPSB0aGlzLnJlbmRlcmVyMi5jcmVhdGVFbGVtZW50KCdzdHlsZScpO1xuICAgICAgICAgIHRoaXMucmVuZGVyZXIyLmFwcGVuZENoaWxkKHRoaXMuY29udGFpbmVyRWxlbWVudCwgdGhpcy5zdHlsZUVsKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnN0eWxlRWwuaW5uZXJIVE1MID0gc3R5bGVTdHJpbmc7XG4gICAgICB9XG5cbiAgICAgIHRoaXMudGFibGVDb21wb25lbnQudXBkYXRlU3RpY2t5Q29sdW1uU3R5bGVzKCk7XG4gICAgfSk7XG4gIH1cblxuICBvdmVycmlkZSBuZ09uRGVzdHJveSgpIHtcbiAgICBzdXBlci5uZ09uRGVzdHJveSgpO1xuXG4gICAgaWYgKHRoaXMuc2hlZXQpIHtcbiAgICAgIGNvbnN0IGlkeCA9IGRvY3VtZW50LmFkb3B0ZWRTdHlsZVNoZWV0cy5pbmRleE9mKHRoaXMuc2hlZXQpO1xuICAgICAgZG9jdW1lbnQuYWRvcHRlZFN0eWxlU2hlZXRzLnNwbGljZShpZHgsIDEpO1xuICAgIH1cbiAgfVxufVxuIl19
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sLXJlc2l6YWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdGFibGUvdGFibGUtY29sLXJlc2l6YWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRWpDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNsRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRXZDLE9BQU8sRUFDTCxRQUFRLEVBQ1IsdUJBQXVCLEVBQ3ZCLGNBQWMsRUFDZCwyQkFBMkIsR0FDNUIsTUFBTSxTQUFTLENBQUM7O0FBRWpCLElBQUksNkJBQTZCLEdBQUcsQ0FBQyxDQUFDO0FBTXRDLE1BQU0sT0FBTywwQkFDWCxTQUFRLGtCQUFrQjtJQUlqQixRQUFRLEdBQUcsTUFBTSxDQUFDO0lBRVQsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO0lBRXpCLHVCQUF1QixHQUFHLE1BQU0sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO0lBQzFELGNBQWMsR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDeEMsMkJBQTJCLEdBQUcsTUFBTSxDQUNuRCwyQkFBMkIsRUFDM0I7UUFDRSxRQUFRLEVBQUUsSUFBSTtLQUNmLENBQ0YsQ0FBQztJQUVNLE9BQU8sQ0FBbUI7SUFDMUIsS0FBSyxDQUFnQjtJQUNyQixRQUFRLENBQVM7SUFFaEIsZUFBZTtRQUN0QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFeEIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLENBQ3RCLElBQUksQ0FBQywyQkFBMkIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUN4RCxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFFbkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUMvRCxNQUFNLFNBQVMsR0FBRyxRQUFRLENBQUMsT0FBTyxDQUNoQyxVQUFVLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxvQkFBb0IsRUFBRSxDQUM5RCxDQUFDO1lBQ0YsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUcsaUNBQWlDLDZCQUE2QixFQUFFLEVBQUUsQ0FBQztnQkFDbkYsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO2FBQ3ZEO1lBQ0QsTUFBTSxXQUFXLEdBQUc7VUFDaEIsSUFBSSxDQUFDLFFBQVEsTUFBTSxTQUFTO2lCQUNyQixXQUFXLENBQUMsS0FBSyxDQUFDOzs7T0FHNUIsQ0FBQztZQUNGLElBQUksT0FBTyxhQUFhLEtBQUssV0FBVyxFQUFFO2dCQUN4QyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtvQkFDakIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztvQkFDckQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztpQkFDakU7Z0JBQ0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEdBQUcsV0FBVyxDQUFDO2FBQ3RDO2lCQUFNO2dCQUNMLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFO29CQUNmLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxhQUFhLEVBQUUsQ0FBQztvQkFDakMsUUFBUSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7aUJBQzlDO2dCQUNELElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxDQUFDO2FBQ3JDO1lBRUQsSUFBSSxDQUFDLGNBQWMsQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1FBQ2pELENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVRLFdBQVc7UUFDbEIsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBRXBCLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNkLE1BQU0sR0FBRyxHQUFHLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzVELFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQzNDLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1NBQ25CO0lBQ0gsQ0FBQzt1R0FyRVUsMEJBQTBCOzJGQUExQiwwQkFBMEI7OzJGQUExQiwwQkFBMEI7a0JBSnRDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzhCQU1VLFFBQVE7c0JBRGhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdJbml0LCBEaXJlY3RpdmUsIGluamVjdCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBSZXNpemFibGVEaXJlY3RpdmUgfSBmcm9tICcuLi9yZXNpemFibGUnO1xuaW1wb3J0IHsgaGFuZGxlUGl4ZWwgfSBmcm9tICcuLi91dGlscyc7XG5cbmltcG9ydCB7XG4gIHRhYmxlQmVtLFxuICBUYWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSxcbiAgVGFibGVDb21wb25lbnQsXG4gIFRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSxcbn0gZnJvbSAnLi9pbmRleCc7XG5cbmxldCB0YWJsZVJlc2l6YWJsZUR5bmFtaWNTdHlsZVVpZCA9IDA7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1thdWlUYWJsZUNvbFJlc2l6YWJsZV0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJsZUNvbFJlc2l6YWJsZURpcmVjdGl2ZVxuICBleHRlbmRzIFJlc2l6YWJsZURpcmVjdGl2ZVxuICBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXRcbntcbiAgQElucHV0KClcbiAgb3ZlcnJpZGUgbWluV2lkdGggPSAnNjBweCc7XG5cbiAgb3ZlcnJpZGUgcmVhZG9ubHkgbWFudWFsQWRqdXN0bWVudCA9IHRydWU7XG5cbiAgcHJpdmF0ZSByZWFkb25seSB0YWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSA9IGluamVjdChUYWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgdGFibGVDb21wb25lbnQgPSBpbmplY3QoVGFibGVDb21wb25lbnQpO1xuICBwcml2YXRlIHJlYWRvbmx5IHRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSA9IGluamVjdChcbiAgICBUYWJsZVNjcm9sbFdyYXBwZXJEaXJlY3RpdmUsXG4gICAge1xuICAgICAgb3B0aW9uYWw6IHRydWUsXG4gICAgfSxcbiAgKTtcblxuICBwcml2YXRlIHN0eWxlRWw6IEhUTUxTdHlsZUVsZW1lbnQ7XG4gIHByaXZhdGUgc2hlZXQ6IENTU1N0eWxlU2hlZXQ7XG4gIHByaXZhdGUgaG9zdEF0dHI6IHN0cmluZztcblxuICBvdmVycmlkZSBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgc3VwZXIubmdBZnRlclZpZXdJbml0KCk7XG5cbiAgICB0aGlzLmNvbnRhaW5lckVsZW1lbnQgPSAoXG4gICAgICB0aGlzLnRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSB8fCB0aGlzLnRhYmxlQ29tcG9uZW50XG4gICAgKS5lbC5uYXRpdmVFbGVtZW50O1xuXG4gICAgdGhpcy5yZXNpemVFbmQucGlwZSh0YWtlVW50aWwodGhpcy5kZXN0cm95JCQpKS5zdWJzY3JpYmUod2lkdGggPT4ge1xuICAgICAgY29uc3QgY2xhc3NOYW1lID0gdGFibGVCZW0uZWxlbWVudChcbiAgICAgICAgYGNvbHVtbi0ke3RoaXMudGFibGVDb2x1bW5EZWZEaXJlY3RpdmUuY3NzQ2xhc3NGcmllbmRseU5hbWV9YCxcbiAgICAgICk7XG4gICAgICBpZiAoIXRoaXMuaG9zdEF0dHIpIHtcbiAgICAgICAgdGhpcy5ob3N0QXR0ciA9IGB0YWJsZS1yZXNpemFibGUtZHluYW1pYy1zdHlsZS0ke3RhYmxlUmVzaXphYmxlRHluYW1pY1N0eWxlVWlkKyt9YDtcbiAgICAgICAgdGhpcy5jb250YWluZXJFbGVtZW50LnNldEF0dHJpYnV0ZSh0aGlzLmhvc3RBdHRyLCAnJyk7XG4gICAgICB9XG4gICAgICBjb25zdCBzdHlsZVN0cmluZyA9IGBcbiAgICAgICBbJHt0aGlzLmhvc3RBdHRyfV0gLiR7Y2xhc3NOYW1lfSB7XG4gICAgICAgIHdpZHRoOiAke2hhbmRsZVBpeGVsKHdpZHRoKX0gIWltcG9ydGFudDtcbiAgICAgICAgZmxleDogbm9uZSAhaW1wb3J0YW50O1xuICAgICAgfVxuICAgICAgYDtcbiAgICAgIGlmICh0eXBlb2YgQ1NTU3R5bGVTaGVldCA9PT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgaWYgKCF0aGlzLnN0eWxlRWwpIHtcbiAgICAgICAgICB0aGlzLnN0eWxlRWwgPSB0aGlzLnJlbmRlcmVyMi5jcmVhdGVFbGVtZW50KCdzdHlsZScpO1xuICAgICAgICAgIHRoaXMucmVuZGVyZXIyLmFwcGVuZENoaWxkKHRoaXMuY29udGFpbmVyRWxlbWVudCwgdGhpcy5zdHlsZUVsKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnN0eWxlRWwuaW5uZXJIVE1MID0gc3R5bGVTdHJpbmc7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBpZiAoIXRoaXMuc2hlZXQpIHtcbiAgICAgICAgICB0aGlzLnNoZWV0ID0gbmV3IENTU1N0eWxlU2hlZXQoKTtcbiAgICAgICAgICBkb2N1bWVudC5hZG9wdGVkU3R5bGVTaGVldHMucHVzaCh0aGlzLnNoZWV0KTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnNoZWV0LnJlcGxhY2VTeW5jKHN0eWxlU3RyaW5nKTtcbiAgICAgIH1cblxuICAgICAgdGhpcy50YWJsZUNvbXBvbmVudC51cGRhdGVTdGlja3lDb2x1bW5TdHlsZXMoKTtcbiAgICB9KTtcbiAgfVxuXG4gIG92ZXJyaWRlIG5nT25EZXN0cm95KCkge1xuICAgIHN1cGVyLm5nT25EZXN0cm95KCk7XG5cbiAgICBpZiAodGhpcy5zaGVldCkge1xuICAgICAgY29uc3QgaWR4ID0gZG9jdW1lbnQuYWRvcHRlZFN0eWxlU2hlZXRzLmluZGV4T2YodGhpcy5zaGVldCk7XG4gICAgICBkb2N1bWVudC5hZG9wdGVkU3R5bGVTaGVldHMuc3BsaWNlKGlkeCwgMSk7XG4gICAgICB0aGlzLnNoZWV0ID0gbnVsbDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -9571,8 +9571,6 @@ class ResizableDirective {
9571
9571
  element = this.elementRef.nativeElement;
9572
9572
  containerElement = this.containerDirective?.el.nativeElement || this.element;
9573
9573
  destroy$$ = new Subject();
9574
- initialWidth;
9575
- mouseDownScreenX;
9576
9574
  resizeHandle;
9577
9575
  resizeOverlay;
9578
9576
  resizeBar;
@@ -9580,6 +9578,7 @@ class ResizableDirective {
9580
9578
  BAR_WIDTH = 2;
9581
9579
  ngAfterViewInit() {
9582
9580
  this.createResizeHandle();
9581
+ this.binEvent(this.resizeHandle, 'click').subscribe(event => event.stopPropagation());
9583
9582
  this.binEvent(this.element, 'mouseover').subscribe(() => {
9584
9583
  this.handleHasUp = true;
9585
9584
  if (!this.resizeBar) {
@@ -9590,6 +9589,7 @@ class ResizableDirective {
9590
9589
  this.handleHasUp = false;
9591
9590
  this.setResizeHandleVisible(false);
9592
9591
  });
9592
+ this.bindResizable();
9593
9593
  }
9594
9594
  ngOnDestroy() {
9595
9595
  this.destroy$$.next();
@@ -9598,21 +9598,53 @@ class ResizableDirective {
9598
9598
  binEvent(target, eventType) {
9599
9599
  return fromEvent(target, eventType).pipe(takeUntil(this.destroy$$));
9600
9600
  }
9601
+ bindResizable() {
9602
+ let initialWidth;
9603
+ let mouseDownScreenX;
9604
+ const mouseup$ = this.binEvent(document, 'mouseup').pipe(tap(event => {
9605
+ if (this.handleHasUp) {
9606
+ this.setResizeHandleVisible(true);
9607
+ }
9608
+ this.renderer2.removeChild(this.containerElement, this.resizeOverlay);
9609
+ this.resizeOverlay = null;
9610
+ this.renderer2.removeChild(this.containerElement, this.resizeBar);
9611
+ this.resizeBar = null;
9612
+ const movementX = event.clientX - mouseDownScreenX;
9613
+ const newWidth = initialWidth + movementX;
9614
+ const width = this.getFinalWidth(newWidth);
9615
+ if (!this.manualAdjustment) {
9616
+ this.renderer2.setStyle(this.element, 'width', handlePixel(width));
9617
+ }
9618
+ this.resizeEnd.emit(width);
9619
+ }));
9620
+ this.binEvent(this.resizeHandle, 'mousedown')
9621
+ .pipe(tap(event => {
9622
+ event.preventDefault();
9623
+ event.stopPropagation();
9624
+ initialWidth = this.element.clientWidth;
9625
+ mouseDownScreenX = event.clientX;
9626
+ this.resizeStart.emit(initialWidth);
9627
+ this.setResizeHandleVisible(false);
9628
+ this.createResizeOverlay();
9629
+ this.createResizeBar();
9630
+ }), switchMap(() => this.binEvent(document, 'mousemove').pipe(map(event => {
9631
+ const movementX = event.clientX - mouseDownScreenX;
9632
+ const newWidth = initialWidth + movementX;
9633
+ const width = this.getFinalWidth(newWidth);
9634
+ this.resizing.emit(width);
9635
+ return width;
9636
+ }), takeUntil(mouseup$))))
9637
+ .subscribe(width => {
9638
+ this.renderer2.setStyle(this.resizeBar, 'left', handlePixel(width + this.getOffset() - this.BAR_WIDTH));
9639
+ this.resizing.emit(width);
9640
+ });
9641
+ }
9601
9642
  setResizeHandleVisible(isVisible) {
9602
- if (this.resizeHandle) {
9603
- this.renderer2.setStyle(this.resizeHandle, 'visibility', isVisible ? 'visible' : 'hidden');
9604
- }
9643
+ this.renderer2.setStyle(this.resizeHandle, 'visibility', isVisible ? 'visible' : 'hidden');
9605
9644
  }
9606
9645
  createResizeHandle() {
9607
- if (this.resizeHandle) {
9608
- return;
9609
- }
9610
9646
  this.resizeHandle = this.renderer2.createElement('div');
9611
9647
  this.renderer2.addClass(this.resizeHandle, 'resize-handle');
9612
- this.binEvent(this.resizeHandle, 'click').subscribe(event => event.stopPropagation());
9613
- this.binEvent(this.resizeHandle, 'mousedown').subscribe(event => {
9614
- this.onMousedown(event);
9615
- });
9616
9648
  this.renderer2.appendChild(this.element, this.resizeHandle);
9617
9649
  }
9618
9650
  createResizeOverlay() {
@@ -9626,51 +9658,6 @@ class ResizableDirective {
9626
9658
  this.renderer2.setStyle(this.resizeBar, 'left', this.element.clientWidth + this.getOffset() - this.BAR_WIDTH + 'px');
9627
9659
  this.renderer2.appendChild(this.containerElement, this.resizeBar);
9628
9660
  }
9629
- onMousedown(event) {
9630
- event.preventDefault();
9631
- event.stopPropagation();
9632
- this.setResizeHandleVisible(false);
9633
- this.initialWidth = this.element.clientWidth;
9634
- this.resizeStart.emit(this.initialWidth);
9635
- this.mouseDownScreenX = event.clientX;
9636
- this.createResizeOverlay();
9637
- this.createResizeBar();
9638
- const mouseup$ = this.binEvent(document, 'mouseup').pipe(take(1));
9639
- mouseup$.subscribe(event => {
9640
- this.onMouseup(event);
9641
- });
9642
- this.binEvent(document, 'mousemove')
9643
- .pipe(takeUntil(mouseup$))
9644
- .subscribe(event => {
9645
- this.move(event);
9646
- });
9647
- }
9648
- onMouseup(event) {
9649
- if (this.handleHasUp) {
9650
- this.setResizeHandleVisible(true);
9651
- }
9652
- this.renderer2.removeChild(this.containerElement, this.resizeOverlay);
9653
- this.resizeOverlay = null;
9654
- this.renderer2.removeChild(this.containerElement, this.resizeBar);
9655
- this.resizeBar = null;
9656
- const movementX = event.clientX - this.mouseDownScreenX;
9657
- const newWidth = this.initialWidth + movementX;
9658
- const width = this.getFinalWidth(newWidth);
9659
- if (!this.manualAdjustment) {
9660
- this.renderer2.setStyle(this.element, 'width', handlePixel(width));
9661
- }
9662
- this.resizeEnd.emit(width);
9663
- }
9664
- move(event) {
9665
- if (!this.resizeBar) {
9666
- return;
9667
- }
9668
- const movementX = event.clientX - this.mouseDownScreenX;
9669
- const newWidth = this.initialWidth + movementX;
9670
- const finalWidth = this.getFinalWidth(newWidth);
9671
- this.renderer2.setStyle(this.resizeBar, 'left', handlePixel(finalWidth + this.getOffset() - this.BAR_WIDTH));
9672
- this.resizing.emit(finalWidth);
9673
- }
9674
9661
  getFinalWidth(newWidth) {
9675
9662
  const _max = this.containerElement.clientWidth + this.getOffset();
9676
9663
  const minWidth = this.handleWidth(this.minWidth || this.getOffset());
@@ -10441,20 +10428,20 @@ class TableColResizableDirective extends ResizableDirective {
10441
10428
  flex: none !important;
10442
10429
  }
10443
10430
  `;
10444
- if (CSSStyleSheet) {
10445
- if (!this.sheet) {
10446
- this.sheet = new CSSStyleSheet();
10447
- document.adoptedStyleSheets.push(this.sheet);
10448
- }
10449
- this.sheet.replaceSync(styleString);
10450
- }
10451
- else {
10431
+ if (typeof CSSStyleSheet === 'undefined') {
10452
10432
  if (!this.styleEl) {
10453
10433
  this.styleEl = this.renderer2.createElement('style');
10454
10434
  this.renderer2.appendChild(this.containerElement, this.styleEl);
10455
10435
  }
10456
10436
  this.styleEl.innerHTML = styleString;
10457
10437
  }
10438
+ else {
10439
+ if (!this.sheet) {
10440
+ this.sheet = new CSSStyleSheet();
10441
+ document.adoptedStyleSheets.push(this.sheet);
10442
+ }
10443
+ this.sheet.replaceSync(styleString);
10444
+ }
10458
10445
  this.tableComponent.updateStickyColumnStyles();
10459
10446
  });
10460
10447
  }
@@ -10463,6 +10450,7 @@ class TableColResizableDirective extends ResizableDirective {
10463
10450
  if (this.sheet) {
10464
10451
  const idx = document.adoptedStyleSheets.indexOf(this.sheet);
10465
10452
  document.adoptedStyleSheets.splice(idx, 1);
10453
+ this.sheet = null;
10466
10454
  }
10467
10455
  }
10468
10456
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TableColResizableDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });