@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,
|
|
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
|
-
|
|
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,
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sLXJlc2l6YWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdGFibGUvdGFibGUtY29sLXJlc2l6YWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRWpDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNsRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRXZDLE9BQU8sRUFDTCxRQUFRLEVBQ1IsdUJBQXVCLEVBQ3ZCLGNBQWMsRUFDZCwyQkFBMkIsR0FDNUIsTUFBTSxTQUFTLENBQUM7O0FBRWpCLElBQUksNkJBQTZCLEdBQUcsQ0FBQyxDQUFDO0FBTXRDLE1BQU0sT0FBTywwQkFDWCxTQUFRLGtCQUFrQjtJQUlqQixRQUFRLEdBQUcsTUFBTSxDQUFDO0lBRVQsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO0lBRXpCLHVCQUF1QixHQUFHLE1BQU0sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO0lBQzFELGNBQWMsR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDeEMsMkJBQTJCLEdBQUcsTUFBTSxDQUNuRCwyQkFBMkIsRUFDM0I7UUFDRSxRQUFRLEVBQUUsSUFBSTtLQUNmLENBQ0YsQ0FBQztJQUVNLE9BQU8sQ0FBbUI7SUFDMUIsS0FBSyxDQUFnQjtJQUNyQixRQUFRLENBQVM7SUFFaEIsZUFBZTtRQUN0QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFeEIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLENBQ3RCLElBQUksQ0FBQywyQkFBMkIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUN4RCxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFFbkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUMvRCxNQUFNLFNBQVMsR0FBRyxRQUFRLENBQUMsT0FBTyxDQUNoQyxVQUFVLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxvQkFBb0IsRUFBRSxDQUM5RCxDQUFDO1lBQ0YsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUcsaUNBQWlDLDZCQUE2QixFQUFFLEVBQUUsQ0FBQztnQkFDbkYsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO2FBQ3ZEO1lBQ0QsTUFBTSxXQUFXLEdBQUc7VUFDaEIsSUFBSSxDQUFDLFFBQVEsTUFBTSxTQUFTO2lCQUNyQixXQUFXLENBQUMsS0FBSyxDQUFDOzs7T0FHNUIsQ0FBQztZQUNGLElBQUksT0FBTyxhQUFhLEtBQUssV0FBVyxFQUFFO2dCQUN4QyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtvQkFDakIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztvQkFDckQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztpQkFDakU7Z0JBQ0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEdBQUcsV0FBVyxDQUFDO2FBQ3RDO2lCQUFNO2dCQUNMLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFO29CQUNmLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxhQUFhLEVBQUUsQ0FBQztvQkFDakMsUUFBUSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7aUJBQzlDO2dCQUNELElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxDQUFDO2FBQ3JDO1lBRUQsSUFBSSxDQUFDLGNBQWMsQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1FBQ2pELENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVRLFdBQVc7UUFDbEIsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBRXBCLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNkLE1BQU0sR0FBRyxHQUFHLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzVELFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQzNDLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1NBQ25CO0lBQ0gsQ0FBQzt1R0FyRVUsMEJBQTBCOzJGQUExQiwwQkFBMEI7OzJGQUExQiwwQkFBMEI7a0JBSnRDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzhCQU1VLFFBQVE7c0JBRGhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdJbml0LCBEaXJlY3RpdmUsIGluamVjdCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBSZXNpemFibGVEaXJlY3RpdmUgfSBmcm9tICcuLi9yZXNpemFibGUnO1xuaW1wb3J0IHsgaGFuZGxlUGl4ZWwgfSBmcm9tICcuLi91dGlscyc7XG5cbmltcG9ydCB7XG4gIHRhYmxlQmVtLFxuICBUYWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSxcbiAgVGFibGVDb21wb25lbnQsXG4gIFRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSxcbn0gZnJvbSAnLi9pbmRleCc7XG5cbmxldCB0YWJsZVJlc2l6YWJsZUR5bmFtaWNTdHlsZVVpZCA9IDA7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1thdWlUYWJsZUNvbFJlc2l6YWJsZV0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJsZUNvbFJlc2l6YWJsZURpcmVjdGl2ZVxuICBleHRlbmRzIFJlc2l6YWJsZURpcmVjdGl2ZVxuICBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXRcbntcbiAgQElucHV0KClcbiAgb3ZlcnJpZGUgbWluV2lkdGggPSAnNjBweCc7XG5cbiAgb3ZlcnJpZGUgcmVhZG9ubHkgbWFudWFsQWRqdXN0bWVudCA9IHRydWU7XG5cbiAgcHJpdmF0ZSByZWFkb25seSB0YWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSA9IGluamVjdChUYWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgdGFibGVDb21wb25lbnQgPSBpbmplY3QoVGFibGVDb21wb25lbnQpO1xuICBwcml2YXRlIHJlYWRvbmx5IHRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSA9IGluamVjdChcbiAgICBUYWJsZVNjcm9sbFdyYXBwZXJEaXJlY3RpdmUsXG4gICAge1xuICAgICAgb3B0aW9uYWw6IHRydWUsXG4gICAgfSxcbiAgKTtcblxuICBwcml2YXRlIHN0eWxlRWw6IEhUTUxTdHlsZUVsZW1lbnQ7XG4gIHByaXZhdGUgc2hlZXQ6IENTU1N0eWxlU2hlZXQ7XG4gIHByaXZhdGUgaG9zdEF0dHI6IHN0cmluZztcblxuICBvdmVycmlkZSBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgc3VwZXIubmdBZnRlclZpZXdJbml0KCk7XG5cbiAgICB0aGlzLmNvbnRhaW5lckVsZW1lbnQgPSAoXG4gICAgICB0aGlzLnRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSB8fCB0aGlzLnRhYmxlQ29tcG9uZW50XG4gICAgKS5lbC5uYXRpdmVFbGVtZW50O1xuXG4gICAgdGhpcy5yZXNpemVFbmQucGlwZSh0YWtlVW50aWwodGhpcy5kZXN0cm95JCQpKS5zdWJzY3JpYmUod2lkdGggPT4ge1xuICAgICAgY29uc3QgY2xhc3NOYW1lID0gdGFibGVCZW0uZWxlbWVudChcbiAgICAgICAgYGNvbHVtbi0ke3RoaXMudGFibGVDb2x1bW5EZWZEaXJlY3RpdmUuY3NzQ2xhc3NGcmllbmRseU5hbWV9YCxcbiAgICAgICk7XG4gICAgICBpZiAoIXRoaXMuaG9zdEF0dHIpIHtcbiAgICAgICAgdGhpcy5ob3N0QXR0ciA9IGB0YWJsZS1yZXNpemFibGUtZHluYW1pYy1zdHlsZS0ke3RhYmxlUmVzaXphYmxlRHluYW1pY1N0eWxlVWlkKyt9YDtcbiAgICAgICAgdGhpcy5jb250YWluZXJFbGVtZW50LnNldEF0dHJpYnV0ZSh0aGlzLmhvc3RBdHRyLCAnJyk7XG4gICAgICB9XG4gICAgICBjb25zdCBzdHlsZVN0cmluZyA9IGBcbiAgICAgICBbJHt0aGlzLmhvc3RBdHRyfV0gLiR7Y2xhc3NOYW1lfSB7XG4gICAgICAgIHdpZHRoOiAke2hhbmRsZVBpeGVsKHdpZHRoKX0gIWltcG9ydGFudDtcbiAgICAgICAgZmxleDogbm9uZSAhaW1wb3J0YW50O1xuICAgICAgfVxuICAgICAgYDtcbiAgICAgIGlmICh0eXBlb2YgQ1NTU3R5bGVTaGVldCA9PT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgaWYgKCF0aGlzLnN0eWxlRWwpIHtcbiAgICAgICAgICB0aGlzLnN0eWxlRWwgPSB0aGlzLnJlbmRlcmVyMi5jcmVhdGVFbGVtZW50KCdzdHlsZScpO1xuICAgICAgICAgIHRoaXMucmVuZGVyZXIyLmFwcGVuZENoaWxkKHRoaXMuY29udGFpbmVyRWxlbWVudCwgdGhpcy5zdHlsZUVsKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnN0eWxlRWwuaW5uZXJIVE1MID0gc3R5bGVTdHJpbmc7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBpZiAoIXRoaXMuc2hlZXQpIHtcbiAgICAgICAgICB0aGlzLnNoZWV0ID0gbmV3IENTU1N0eWxlU2hlZXQoKTtcbiAgICAgICAgICBkb2N1bWVudC5hZG9wdGVkU3R5bGVTaGVldHMucHVzaCh0aGlzLnNoZWV0KTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnNoZWV0LnJlcGxhY2VTeW5jKHN0eWxlU3RyaW5nKTtcbiAgICAgIH1cblxuICAgICAgdGhpcy50YWJsZUNvbXBvbmVudC51cGRhdGVTdGlja3lDb2x1bW5TdHlsZXMoKTtcbiAgICB9KTtcbiAgfVxuXG4gIG92ZXJyaWRlIG5nT25EZXN0cm95KCkge1xuICAgIHN1cGVyLm5nT25EZXN0cm95KCk7XG5cbiAgICBpZiAodGhpcy5zaGVldCkge1xuICAgICAgY29uc3QgaWR4ID0gZG9jdW1lbnQuYWRvcHRlZFN0eWxlU2hlZXRzLmluZGV4T2YodGhpcy5zaGVldCk7XG4gICAgICBkb2N1bWVudC5hZG9wdGVkU3R5bGVTaGVldHMuc3BsaWNlKGlkeCwgMSk7XG4gICAgICB0aGlzLnNoZWV0ID0gbnVsbDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
package/fesm2022/alauda-ui.mjs
CHANGED
|
@@ -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
|
-
|
|
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 });
|