@alauda/ui 7.3.3-beta.7 → 7.3.3-beta.9
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,12 +1,10 @@
|
|
|
1
|
-
import { Directive, EventEmitter,
|
|
1
|
+
import { Directive, ElementRef, EventEmitter, inject, Input, Output, Renderer2, } from '@angular/core';
|
|
2
2
|
import { fromEvent, Subject, takeUntil } from 'rxjs';
|
|
3
|
+
import { handlePixel } from '../utils';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
export class ContainerForResizableDirective {
|
|
5
|
-
el;
|
|
6
|
-
|
|
7
|
-
this.el = el;
|
|
8
|
-
}
|
|
9
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ContainerForResizableDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
6
|
+
el = inject(ElementRef);
|
|
7
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ContainerForResizableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
10
8
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: ContainerForResizableDirective, isStandalone: true, selector: "[auiContainerForResizable]", host: { classAttribute: "aui-container-for-resizable" }, ngImport: i0 });
|
|
11
9
|
}
|
|
12
10
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ContainerForResizableDirective, decorators: [{
|
|
@@ -18,18 +16,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
18
16
|
},
|
|
19
17
|
standalone: true,
|
|
20
18
|
}]
|
|
21
|
-
}]
|
|
19
|
+
}] });
|
|
22
20
|
export class ResizableDirective {
|
|
23
|
-
renderer2;
|
|
24
|
-
containerDirective;
|
|
25
21
|
minWidth;
|
|
26
22
|
maxWidth;
|
|
27
23
|
resizeStart = new EventEmitter();
|
|
28
24
|
resizing = new EventEmitter();
|
|
29
25
|
resizeEnd = new EventEmitter();
|
|
26
|
+
elementRef = inject(ElementRef);
|
|
27
|
+
renderer2 = inject(Renderer2);
|
|
28
|
+
containerDirective = inject(ContainerForResizableDirective, {
|
|
29
|
+
optional: true,
|
|
30
|
+
});
|
|
31
|
+
element = this.elementRef.nativeElement;
|
|
32
|
+
containerElement = this.containerDirective?.el.nativeElement || this.element;
|
|
30
33
|
destroy$$ = new Subject();
|
|
31
|
-
containerElement;
|
|
32
|
-
element;
|
|
33
34
|
initialWidth;
|
|
34
35
|
mouseDownScreenX;
|
|
35
36
|
resizeHandle;
|
|
@@ -37,22 +38,15 @@ export class ResizableDirective {
|
|
|
37
38
|
resizeBar;
|
|
38
39
|
handleHasUp;
|
|
39
40
|
BAR_WIDTH = 2;
|
|
40
|
-
constructor(element, renderer2, containerDirective) {
|
|
41
|
-
this.renderer2 = renderer2;
|
|
42
|
-
this.containerDirective = containerDirective;
|
|
43
|
-
this.element = element.nativeElement;
|
|
44
|
-
this.containerElement =
|
|
45
|
-
this.containerDirective?.el.nativeElement || this.element;
|
|
46
|
-
}
|
|
47
41
|
ngAfterViewInit() {
|
|
48
42
|
this.createResizeHandle();
|
|
49
|
-
this.binEvent(this.element, 'mouseover'
|
|
43
|
+
this.binEvent(this.element, 'mouseover').subscribe(() => {
|
|
50
44
|
this.handleHasUp = true;
|
|
51
45
|
if (!this.resizeBar) {
|
|
52
46
|
this.setResizeHandleVisible(true);
|
|
53
47
|
}
|
|
54
48
|
});
|
|
55
|
-
this.binEvent(this.element, 'mouseout'
|
|
49
|
+
this.binEvent(this.element, 'mouseout').subscribe(() => {
|
|
56
50
|
this.handleHasUp = false;
|
|
57
51
|
this.setResizeHandleVisible(false);
|
|
58
52
|
});
|
|
@@ -61,10 +55,8 @@ export class ResizableDirective {
|
|
|
61
55
|
this.destroy$$.next();
|
|
62
56
|
this.destroy$$.complete();
|
|
63
57
|
}
|
|
64
|
-
binEvent(target, eventType
|
|
65
|
-
return fromEvent(target, eventType)
|
|
66
|
-
.pipe(takeUntil(this.destroy$$))
|
|
67
|
-
.subscribe(callback);
|
|
58
|
+
binEvent(target, eventType) {
|
|
59
|
+
return fromEvent(target, eventType).pipe(takeUntil(this.destroy$$));
|
|
68
60
|
}
|
|
69
61
|
setResizeHandleVisible(isVisible) {
|
|
70
62
|
if (this.resizeHandle) {
|
|
@@ -77,8 +69,10 @@ export class ResizableDirective {
|
|
|
77
69
|
}
|
|
78
70
|
this.resizeHandle = this.renderer2.createElement('div');
|
|
79
71
|
this.renderer2.addClass(this.resizeHandle, 'resize-handle');
|
|
80
|
-
this.binEvent(this.resizeHandle, 'click'
|
|
81
|
-
this.binEvent(this.resizeHandle, 'mousedown'
|
|
72
|
+
this.binEvent(this.resizeHandle, 'click').subscribe(e => e.stopPropagation());
|
|
73
|
+
this.binEvent(this.resizeHandle, 'mousedown').subscribe(e => {
|
|
74
|
+
this.onMousedown(e);
|
|
75
|
+
});
|
|
82
76
|
this.renderer2.appendChild(this.element, this.resizeHandle);
|
|
83
77
|
}
|
|
84
78
|
createResizeOverlay() {
|
|
@@ -101,15 +95,19 @@ export class ResizableDirective {
|
|
|
101
95
|
this.mouseDownScreenX = event.clientX;
|
|
102
96
|
this.createResizeOverlay();
|
|
103
97
|
this.createResizeBar();
|
|
104
|
-
const mouseMoveSubscription = this.binEvent(document, 'mousemove'
|
|
105
|
-
|
|
98
|
+
const mouseMoveSubscription = this.binEvent(document, 'mousemove').subscribe(e => {
|
|
99
|
+
this.move(e);
|
|
100
|
+
});
|
|
101
|
+
const mouseUpSubscription = this.binEvent(document, 'mouseup').subscribe(ev => {
|
|
106
102
|
this.onMouseup(ev);
|
|
107
103
|
mouseUpSubscription.unsubscribe();
|
|
108
104
|
mouseMoveSubscription.unsubscribe();
|
|
109
105
|
});
|
|
110
106
|
}
|
|
111
107
|
onMouseup(event) {
|
|
112
|
-
this.handleHasUp
|
|
108
|
+
if (this.handleHasUp) {
|
|
109
|
+
this.setResizeHandleVisible(true);
|
|
110
|
+
}
|
|
113
111
|
this.renderer2.removeChild(this.containerElement, this.resizeOverlay);
|
|
114
112
|
this.resizeOverlay = null;
|
|
115
113
|
this.renderer2.removeChild(this.containerElement, this.resizeBar);
|
|
@@ -125,7 +123,7 @@ export class ResizableDirective {
|
|
|
125
123
|
const movementX = event.clientX - this.mouseDownScreenX;
|
|
126
124
|
const newWidth = this.initialWidth + movementX;
|
|
127
125
|
const finalWidth = this.getFinalWidth(newWidth);
|
|
128
|
-
this.renderer2.setStyle(this.resizeBar, 'left',
|
|
126
|
+
this.renderer2.setStyle(this.resizeBar, 'left', handlePixel(finalWidth + this.getOffset() - this.BAR_WIDTH));
|
|
129
127
|
this.resizing.emit(finalWidth);
|
|
130
128
|
}
|
|
131
129
|
getFinalWidth(newWidth) {
|
|
@@ -145,13 +143,13 @@ export class ResizableDirective {
|
|
|
145
143
|
if (!width) {
|
|
146
144
|
return;
|
|
147
145
|
}
|
|
148
|
-
if (width.
|
|
146
|
+
if (width.endsWith('%')) {
|
|
149
147
|
const tableWidth = this.containerElement.clientWidth;
|
|
150
148
|
return (tableWidth * Number.parseFloat(width)) / 100;
|
|
151
149
|
}
|
|
152
150
|
return Number.parseFloat(width.replace(/\D+/, ''));
|
|
153
151
|
}
|
|
154
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ResizableDirective, deps: [
|
|
152
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ResizableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
155
153
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: ResizableDirective, isStandalone: true, selector: "[auiResizable]", inputs: { minWidth: "minWidth", maxWidth: "maxWidth" }, outputs: { resizeStart: "resizeStart", resizing: "resizing", resizeEnd: "resizeEnd" }, host: { classAttribute: "aui-resizable" }, ngImport: i0 });
|
|
156
154
|
}
|
|
157
155
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ResizableDirective, decorators: [{
|
|
@@ -163,9 +161,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
163
161
|
},
|
|
164
162
|
standalone: true,
|
|
165
163
|
}]
|
|
166
|
-
}],
|
|
167
|
-
type: Optional
|
|
168
|
-
}] }]; }, propDecorators: { minWidth: [{
|
|
164
|
+
}], propDecorators: { minWidth: [{
|
|
169
165
|
type: Input
|
|
170
166
|
}], maxWidth: [{
|
|
171
167
|
type: Input
|
|
@@ -176,4 +172,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
176
172
|
}], resizeEnd: [{
|
|
177
173
|
type: Output
|
|
178
174
|
}] } });
|
|
179
|
-
//# 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  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  Renderer2,\n} from '@angular/core';\nimport { fromEvent, Subject, takeUntil } from 'rxjs';\n\n@Directive({\n  selector: '[auiContainerForResizable]',\n  host: {\n    class: 'aui-container-for-resizable',\n  },\n  standalone: true,\n})\nexport class ContainerForResizableDirective {\n  constructor(readonly el: ElementRef) {}\n}\n\n/**\n * 使用此指令需要引入resizable.scss\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  @Output()\n  resizeStart = new EventEmitter<number>();\n\n  @Output()\n  resizing = new EventEmitter<number>();\n\n  @Output()\n  resizeEnd = new EventEmitter<number>();\n\n  destroy$$ = new Subject<void>();\n  containerElement: Element;\n\n  private readonly element: HTMLElement;\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  constructor(\n    element: ElementRef,\n    readonly renderer2: Renderer2,\n    @Optional()\n    private readonly containerDirective: ContainerForResizableDirective,\n  ) {\n    this.element = element.nativeElement;\n    this.containerElement =\n      this.containerDirective?.el.nativeElement || this.element;\n  }\n\n  ngAfterViewInit() {\n    this.createResizeHandle();\n\n    this.binEvent(this.element, 'mouseover', () => {\n      this.handleHasUp = true;\n      if (!this.resizeBar) {\n        this.setResizeHandleVisible(true);\n      }\n    });\n    this.binEvent(this.element, 'mouseout', () => {\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    callback: (e: E) => void,\n  ) {\n    return fromEvent<E>(target, eventType)\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(callback);\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(this.resizeHandle, 'click', (e: Event) =>\n      e.stopPropagation(),\n    );\n    this.binEvent(this.resizeHandle, 'mousedown', this.onMousedown.bind(this));\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 mouseMoveSubscription = this.binEvent(\n      document,\n      'mousemove',\n      this.move.bind(this),\n    );\n\n    const mouseUpSubscription = this.binEvent<MouseEvent>(\n      document,\n      'mouseup',\n      ev => {\n        this.onMouseup(ev);\n        mouseUpSubscription.unsubscribe();\n        mouseMoveSubscription.unsubscribe();\n      },\n    );\n  }\n\n  private onMouseup(event: MouseEvent): void {\n    this.handleHasUp && this.setResizeHandleVisible(true);\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    this.resizeEnd.emit(this.getFinalWidth(newWidth));\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      `${finalWidth + this.getOffset() - this.BAR_WIDTH}px`,\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\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.includes('%')) {\n      const tableWidth = this.containerElement.clientWidth;\n      return (tableWidth * Number.parseFloat(width)) / 100;\n    }\n    return Number.parseFloat(width.replace(/\\D+/, ''));\n  }\n}\n"]}
|
|
175
|
+
//# 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, 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 */\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  @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(e =>\n      e.stopPropagation(),\n    );\n    this.binEvent<MouseEvent>(this.resizeHandle, 'mousedown').subscribe(e => {\n      this.onMousedown(e);\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 mouseMoveSubscription = this.binEvent<MouseEvent>(\n      document,\n      'mousemove',\n    ).subscribe(e => {\n      this.move(e);\n    });\n\n    const mouseUpSubscription = this.binEvent<MouseEvent>(\n      document,\n      'mouseup',\n    ).subscribe(ev => {\n      this.onMouseup(ev);\n      mouseUpSubscription.unsubscribe();\n      mouseMoveSubscription.unsubscribe();\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    this.resizeEnd.emit(this.getFinalWidth(newWidth));\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"]}
|
|
@@ -4,6 +4,7 @@ import { ResizableDirective } from '../resizable';
|
|
|
4
4
|
import { handlePixel } from '../utils';
|
|
5
5
|
import { tableBem, TableColumnDefDirective, TableComponent, TableScrollWrapperDirective, } from './index';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
+
let tableResizableDynamicStyleUid = 0;
|
|
7
8
|
export class TableColResizableDirective extends ResizableDirective {
|
|
8
9
|
minWidth = '60px';
|
|
9
10
|
tableColumnDefDirective = inject(TableColumnDefDirective);
|
|
@@ -19,7 +20,7 @@ export class TableColResizableDirective extends ResizableDirective {
|
|
|
19
20
|
this.resizeEnd.pipe(takeUntil(this.destroy$$)).subscribe(width => {
|
|
20
21
|
const className = tableBem.element(`column-${this.tableColumnDefDirective.cssClassFriendlyName}`);
|
|
21
22
|
if (!this.hostAttr) {
|
|
22
|
-
this.hostAttr = `resizable-${
|
|
23
|
+
this.hostAttr = `table-resizable-dynamic-style-${tableResizableDynamicStyleUid++}`;
|
|
23
24
|
this.containerElement.setAttribute(this.hostAttr, '');
|
|
24
25
|
this.styleEl = this.renderer2.createElement('style');
|
|
25
26
|
this.renderer2.appendChild(this.containerElement, this.styleEl);
|
|
@@ -45,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
45
46
|
}], propDecorators: { minWidth: [{
|
|
46
47
|
type: Input
|
|
47
48
|
}] } });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sLXJlc2l6YWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdGFibGUvdGFibGUtY29sLXJlc2l6YWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRWpDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNsRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRXZDLE9BQU8sRUFDTCxRQUFRLEVBQ1IsdUJBQXVCLEVBQ3ZCLGNBQWMsRUFDZCwyQkFBMkIsR0FDNUIsTUFBTSxTQUFTLENBQUM7O0FBRWpCLElBQUksNkJBQTZCLEdBQUcsQ0FBQyxDQUFDO0FBTXRDLE1BQU0sT0FBTywwQkFDWCxTQUFRLGtCQUFrQjtJQUlqQixRQUFRLEdBQUcsTUFBTSxDQUFDO0lBRVYsdUJBQXVCLEdBQUcsTUFBTSxDQUFDLHVCQUF1QixDQUFDLENBQUM7SUFDMUQsY0FBYyxHQUFHLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUN4QywyQkFBMkIsR0FBRyxNQUFNLENBQ25ELDJCQUEyQixFQUMzQjtRQUNFLFFBQVEsRUFBRSxJQUFJO0tBQ2YsQ0FDRixDQUFDO0lBRU0sT0FBTyxDQUFtQjtJQUMxQixRQUFRLENBQVM7SUFFaEIsZUFBZTtRQUN0QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFeEIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLENBQ3RCLElBQUksQ0FBQywyQkFBMkIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUN4RCxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFFbkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUMvRCxNQUFNLFNBQVMsR0FBRyxRQUFRLENBQUMsT0FBTyxDQUNoQyxVQUFVLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxvQkFBb0IsRUFBRSxDQUM5RCxDQUFDO1lBQ0YsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUcsaUNBQWlDLDZCQUE2QixFQUFFLEVBQUUsQ0FBQztnQkFDbkYsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO2dCQUN0RCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO2dCQUNyRCxJQUFJLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO2FBQ2pFO1lBQ0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEdBQUc7VUFDckIsSUFBSSxDQUFDLFFBQVEsTUFBTSxTQUFTO2lCQUNyQixXQUFXLENBQUMsS0FBSyxDQUFDOzs7T0FHNUIsQ0FBQztZQUVGLElBQUksQ0FBQyxjQUFjLENBQUMsd0JBQXdCLEVBQUUsQ0FBQztRQUNqRCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7dUdBN0NVLDBCQUEwQjsyRkFBMUIsMEJBQTBCOzsyRkFBMUIsMEJBQTBCO2tCQUp0QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx3QkFBd0I7b0JBQ2xDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQjs4QkFNVSxRQUFRO3NCQURoQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgRGlyZWN0aXZlLCBpbmplY3QsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgUmVzaXphYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi4vcmVzaXphYmxlJztcbmltcG9ydCB7IGhhbmRsZVBpeGVsIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5pbXBvcnQge1xuICB0YWJsZUJlbSxcbiAgVGFibGVDb2x1bW5EZWZEaXJlY3RpdmUsXG4gIFRhYmxlQ29tcG9uZW50LFxuICBUYWJsZVNjcm9sbFdyYXBwZXJEaXJlY3RpdmUsXG59IGZyb20gJy4vaW5kZXgnO1xuXG5sZXQgdGFibGVSZXNpemFibGVEeW5hbWljU3R5bGVVaWQgPSAwO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXVpVGFibGVDb2xSZXNpemFibGVdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgVGFibGVDb2xSZXNpemFibGVEaXJlY3RpdmVcbiAgZXh0ZW5kcyBSZXNpemFibGVEaXJlY3RpdmVcbiAgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0XG57XG4gIEBJbnB1dCgpXG4gIG92ZXJyaWRlIG1pbldpZHRoID0gJzYwcHgnO1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgdGFibGVDb2x1bW5EZWZEaXJlY3RpdmUgPSBpbmplY3QoVGFibGVDb2x1bW5EZWZEaXJlY3RpdmUpO1xuICBwcml2YXRlIHJlYWRvbmx5IHRhYmxlQ29tcG9uZW50ID0gaW5qZWN0KFRhYmxlQ29tcG9uZW50KTtcbiAgcHJpdmF0ZSByZWFkb25seSB0YWJsZVNjcm9sbFdyYXBwZXJEaXJlY3RpdmUgPSBpbmplY3QoXG4gICAgVGFibGVTY3JvbGxXcmFwcGVyRGlyZWN0aXZlLFxuICAgIHtcbiAgICAgIG9wdGlvbmFsOiB0cnVlLFxuICAgIH0sXG4gICk7XG5cbiAgcHJpdmF0ZSBzdHlsZUVsOiBIVE1MU3R5bGVFbGVtZW50O1xuICBwcml2YXRlIGhvc3RBdHRyOiBzdHJpbmc7XG5cbiAgb3ZlcnJpZGUgbmdBZnRlclZpZXdJbml0KCkge1xuICAgIHN1cGVyLm5nQWZ0ZXJWaWV3SW5pdCgpO1xuXG4gICAgdGhpcy5jb250YWluZXJFbGVtZW50ID0gKFxuICAgICAgdGhpcy50YWJsZVNjcm9sbFdyYXBwZXJEaXJlY3RpdmUgfHwgdGhpcy50YWJsZUNvbXBvbmVudFxuICAgICkuZWwubmF0aXZlRWxlbWVudDtcblxuICAgIHRoaXMucmVzaXplRW5kLnBpcGUodGFrZVVudGlsKHRoaXMuZGVzdHJveSQkKSkuc3Vic2NyaWJlKHdpZHRoID0+IHtcbiAgICAgIGNvbnN0IGNsYXNzTmFtZSA9IHRhYmxlQmVtLmVsZW1lbnQoXG4gICAgICAgIGBjb2x1bW4tJHt0aGlzLnRhYmxlQ29sdW1uRGVmRGlyZWN0aXZlLmNzc0NsYXNzRnJpZW5kbHlOYW1lfWAsXG4gICAgICApO1xuICAgICAgaWYgKCF0aGlzLmhvc3RBdHRyKSB7XG4gICAgICAgIHRoaXMuaG9zdEF0dHIgPSBgdGFibGUtcmVzaXphYmxlLWR5bmFtaWMtc3R5bGUtJHt0YWJsZVJlc2l6YWJsZUR5bmFtaWNTdHlsZVVpZCsrfWA7XG4gICAgICAgIHRoaXMuY29udGFpbmVyRWxlbWVudC5zZXRBdHRyaWJ1dGUodGhpcy5ob3N0QXR0ciwgJycpO1xuICAgICAgICB0aGlzLnN0eWxlRWwgPSB0aGlzLnJlbmRlcmVyMi5jcmVhdGVFbGVtZW50KCdzdHlsZScpO1xuICAgICAgICB0aGlzLnJlbmRlcmVyMi5hcHBlbmRDaGlsZCh0aGlzLmNvbnRhaW5lckVsZW1lbnQsIHRoaXMuc3R5bGVFbCk7XG4gICAgICB9XG4gICAgICB0aGlzLnN0eWxlRWwuaW5uZXJIVE1MID0gYFxuICAgICAgIFske3RoaXMuaG9zdEF0dHJ9XSAuJHtjbGFzc05hbWV9IHtcbiAgICAgICAgd2lkdGg6ICR7aGFuZGxlUGl4ZWwod2lkdGgpfSAhaW1wb3J0YW50O1xuICAgICAgICBmbGV4OiBub25lICFpbXBvcnRhbnQ7XG4gICAgICB9XG4gICAgICBgO1xuXG4gICAgICB0aGlzLnRhYmxlQ29tcG9uZW50LnVwZGF0ZVN0aWNreUNvbHVtblN0eWxlcygpO1xuICAgIH0pO1xuICB9XG59XG4iXX0=
|
package/fesm2022/alauda-ui.mjs
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { CdkAccordion, CdkAccordionItem, CdkAccordionModule } from '@angular/cdk/accordion';
|
|
2
2
|
import * as i0 from '@angular/core';
|
|
3
|
-
import { Component, ViewEncapsulation, ChangeDetectionStrategy, SkipSelf, Optional, Input, HostBinding, Injectable, Pipe, booleanAttribute, TemplateRef, Inject, NgModule, Directive, ContentChild, EventEmitter, Output, ElementRef, ContentChildren, ChangeDetectorRef, forwardRef, ViewChild, HostListener, Host, InjectionToken, isDevMode, numberAttribute, Injector, Type, ViewContainerRef, ViewChildren, inject } from '@angular/core';
|
|
3
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy, SkipSelf, Optional, Input, HostBinding, Injectable, Pipe, booleanAttribute, TemplateRef, Inject, NgModule, Directive, ContentChild, EventEmitter, Output, ElementRef, ContentChildren, ChangeDetectorRef, forwardRef, ViewChild, HostListener, Host, InjectionToken, isDevMode, numberAttribute, Injector, Type, ViewContainerRef, ViewChildren, inject, Renderer2 } from '@angular/core';
|
|
4
4
|
import { DOCUMENT, NgIf, NgClass, CommonModule, NgTemplateOutlet, NgFor, AsyncPipe, DecimalPipe, NgStyle, DatePipe, NgComponentOutlet, NgSwitch, NgSwitchCase, NgSwitchDefault } from '@angular/common';
|
|
5
5
|
import { ReplaySubject, distinctUntilChanged, Subject, takeUntil, Observable, share, startWith, map, filter, take, merge as merge$1, fromEvent, combineLatest, debounceTime, switchMap, of, EMPTY, tap, BehaviorSubject, withLatestFrom, delay, first, throttleTime, firstValueFrom, NEVER, observeOn, animationFrameScheduler, repeat, takeWhile, endWith, Subscription } from 'rxjs';
|
|
6
6
|
import * as i1 from '@angular/common/http';
|
|
@@ -9542,11 +9542,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
9542
9542
|
}] });
|
|
9543
9543
|
|
|
9544
9544
|
class ContainerForResizableDirective {
|
|
9545
|
-
el;
|
|
9546
|
-
|
|
9547
|
-
this.el = el;
|
|
9548
|
-
}
|
|
9549
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ContainerForResizableDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
9545
|
+
el = inject(ElementRef);
|
|
9546
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ContainerForResizableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
9550
9547
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: ContainerForResizableDirective, isStandalone: true, selector: "[auiContainerForResizable]", host: { classAttribute: "aui-container-for-resizable" }, ngImport: i0 });
|
|
9551
9548
|
}
|
|
9552
9549
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ContainerForResizableDirective, decorators: [{
|
|
@@ -9558,18 +9555,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
9558
9555
|
},
|
|
9559
9556
|
standalone: true,
|
|
9560
9557
|
}]
|
|
9561
|
-
}]
|
|
9558
|
+
}] });
|
|
9562
9559
|
class ResizableDirective {
|
|
9563
|
-
renderer2;
|
|
9564
|
-
containerDirective;
|
|
9565
9560
|
minWidth;
|
|
9566
9561
|
maxWidth;
|
|
9567
9562
|
resizeStart = new EventEmitter();
|
|
9568
9563
|
resizing = new EventEmitter();
|
|
9569
9564
|
resizeEnd = new EventEmitter();
|
|
9565
|
+
elementRef = inject(ElementRef);
|
|
9566
|
+
renderer2 = inject(Renderer2);
|
|
9567
|
+
containerDirective = inject(ContainerForResizableDirective, {
|
|
9568
|
+
optional: true,
|
|
9569
|
+
});
|
|
9570
|
+
element = this.elementRef.nativeElement;
|
|
9571
|
+
containerElement = this.containerDirective?.el.nativeElement || this.element;
|
|
9570
9572
|
destroy$$ = new Subject();
|
|
9571
|
-
containerElement;
|
|
9572
|
-
element;
|
|
9573
9573
|
initialWidth;
|
|
9574
9574
|
mouseDownScreenX;
|
|
9575
9575
|
resizeHandle;
|
|
@@ -9577,22 +9577,15 @@ class ResizableDirective {
|
|
|
9577
9577
|
resizeBar;
|
|
9578
9578
|
handleHasUp;
|
|
9579
9579
|
BAR_WIDTH = 2;
|
|
9580
|
-
constructor(element, renderer2, containerDirective) {
|
|
9581
|
-
this.renderer2 = renderer2;
|
|
9582
|
-
this.containerDirective = containerDirective;
|
|
9583
|
-
this.element = element.nativeElement;
|
|
9584
|
-
this.containerElement =
|
|
9585
|
-
this.containerDirective?.el.nativeElement || this.element;
|
|
9586
|
-
}
|
|
9587
9580
|
ngAfterViewInit() {
|
|
9588
9581
|
this.createResizeHandle();
|
|
9589
|
-
this.binEvent(this.element, 'mouseover'
|
|
9582
|
+
this.binEvent(this.element, 'mouseover').subscribe(() => {
|
|
9590
9583
|
this.handleHasUp = true;
|
|
9591
9584
|
if (!this.resizeBar) {
|
|
9592
9585
|
this.setResizeHandleVisible(true);
|
|
9593
9586
|
}
|
|
9594
9587
|
});
|
|
9595
|
-
this.binEvent(this.element, 'mouseout'
|
|
9588
|
+
this.binEvent(this.element, 'mouseout').subscribe(() => {
|
|
9596
9589
|
this.handleHasUp = false;
|
|
9597
9590
|
this.setResizeHandleVisible(false);
|
|
9598
9591
|
});
|
|
@@ -9601,10 +9594,8 @@ class ResizableDirective {
|
|
|
9601
9594
|
this.destroy$$.next();
|
|
9602
9595
|
this.destroy$$.complete();
|
|
9603
9596
|
}
|
|
9604
|
-
binEvent(target, eventType
|
|
9605
|
-
return fromEvent(target, eventType)
|
|
9606
|
-
.pipe(takeUntil(this.destroy$$))
|
|
9607
|
-
.subscribe(callback);
|
|
9597
|
+
binEvent(target, eventType) {
|
|
9598
|
+
return fromEvent(target, eventType).pipe(takeUntil(this.destroy$$));
|
|
9608
9599
|
}
|
|
9609
9600
|
setResizeHandleVisible(isVisible) {
|
|
9610
9601
|
if (this.resizeHandle) {
|
|
@@ -9617,8 +9608,10 @@ class ResizableDirective {
|
|
|
9617
9608
|
}
|
|
9618
9609
|
this.resizeHandle = this.renderer2.createElement('div');
|
|
9619
9610
|
this.renderer2.addClass(this.resizeHandle, 'resize-handle');
|
|
9620
|
-
this.binEvent(this.resizeHandle, 'click'
|
|
9621
|
-
this.binEvent(this.resizeHandle, 'mousedown'
|
|
9611
|
+
this.binEvent(this.resizeHandle, 'click').subscribe(e => e.stopPropagation());
|
|
9612
|
+
this.binEvent(this.resizeHandle, 'mousedown').subscribe(e => {
|
|
9613
|
+
this.onMousedown(e);
|
|
9614
|
+
});
|
|
9622
9615
|
this.renderer2.appendChild(this.element, this.resizeHandle);
|
|
9623
9616
|
}
|
|
9624
9617
|
createResizeOverlay() {
|
|
@@ -9641,15 +9634,19 @@ class ResizableDirective {
|
|
|
9641
9634
|
this.mouseDownScreenX = event.clientX;
|
|
9642
9635
|
this.createResizeOverlay();
|
|
9643
9636
|
this.createResizeBar();
|
|
9644
|
-
const mouseMoveSubscription = this.binEvent(document, 'mousemove'
|
|
9645
|
-
|
|
9637
|
+
const mouseMoveSubscription = this.binEvent(document, 'mousemove').subscribe(e => {
|
|
9638
|
+
this.move(e);
|
|
9639
|
+
});
|
|
9640
|
+
const mouseUpSubscription = this.binEvent(document, 'mouseup').subscribe(ev => {
|
|
9646
9641
|
this.onMouseup(ev);
|
|
9647
9642
|
mouseUpSubscription.unsubscribe();
|
|
9648
9643
|
mouseMoveSubscription.unsubscribe();
|
|
9649
9644
|
});
|
|
9650
9645
|
}
|
|
9651
9646
|
onMouseup(event) {
|
|
9652
|
-
this.handleHasUp
|
|
9647
|
+
if (this.handleHasUp) {
|
|
9648
|
+
this.setResizeHandleVisible(true);
|
|
9649
|
+
}
|
|
9653
9650
|
this.renderer2.removeChild(this.containerElement, this.resizeOverlay);
|
|
9654
9651
|
this.resizeOverlay = null;
|
|
9655
9652
|
this.renderer2.removeChild(this.containerElement, this.resizeBar);
|
|
@@ -9665,7 +9662,7 @@ class ResizableDirective {
|
|
|
9665
9662
|
const movementX = event.clientX - this.mouseDownScreenX;
|
|
9666
9663
|
const newWidth = this.initialWidth + movementX;
|
|
9667
9664
|
const finalWidth = this.getFinalWidth(newWidth);
|
|
9668
|
-
this.renderer2.setStyle(this.resizeBar, 'left',
|
|
9665
|
+
this.renderer2.setStyle(this.resizeBar, 'left', handlePixel(finalWidth + this.getOffset() - this.BAR_WIDTH));
|
|
9669
9666
|
this.resizing.emit(finalWidth);
|
|
9670
9667
|
}
|
|
9671
9668
|
getFinalWidth(newWidth) {
|
|
@@ -9685,13 +9682,13 @@ class ResizableDirective {
|
|
|
9685
9682
|
if (!width) {
|
|
9686
9683
|
return;
|
|
9687
9684
|
}
|
|
9688
|
-
if (width.
|
|
9685
|
+
if (width.endsWith('%')) {
|
|
9689
9686
|
const tableWidth = this.containerElement.clientWidth;
|
|
9690
9687
|
return (tableWidth * Number.parseFloat(width)) / 100;
|
|
9691
9688
|
}
|
|
9692
9689
|
return Number.parseFloat(width.replace(/\D+/, ''));
|
|
9693
9690
|
}
|
|
9694
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ResizableDirective, deps: [
|
|
9691
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ResizableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
9695
9692
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: ResizableDirective, isStandalone: true, selector: "[auiResizable]", inputs: { minWidth: "minWidth", maxWidth: "maxWidth" }, outputs: { resizeStart: "resizeStart", resizing: "resizing", resizeEnd: "resizeEnd" }, host: { classAttribute: "aui-resizable" }, ngImport: i0 });
|
|
9696
9693
|
}
|
|
9697
9694
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ResizableDirective, decorators: [{
|
|
@@ -9703,9 +9700,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
9703
9700
|
},
|
|
9704
9701
|
standalone: true,
|
|
9705
9702
|
}]
|
|
9706
|
-
}],
|
|
9707
|
-
type: Optional
|
|
9708
|
-
}] }]; }, propDecorators: { minWidth: [{
|
|
9703
|
+
}], propDecorators: { minWidth: [{
|
|
9709
9704
|
type: Input
|
|
9710
9705
|
}], maxWidth: [{
|
|
9711
9706
|
type: Input
|
|
@@ -10411,6 +10406,7 @@ const TABLE_MODULE = [
|
|
|
10411
10406
|
TableScrollWrapperDirective,
|
|
10412
10407
|
];
|
|
10413
10408
|
|
|
10409
|
+
let tableResizableDynamicStyleUid = 0;
|
|
10414
10410
|
class TableColResizableDirective extends ResizableDirective {
|
|
10415
10411
|
minWidth = '60px';
|
|
10416
10412
|
tableColumnDefDirective = inject(TableColumnDefDirective);
|
|
@@ -10426,7 +10422,7 @@ class TableColResizableDirective extends ResizableDirective {
|
|
|
10426
10422
|
this.resizeEnd.pipe(takeUntil(this.destroy$$)).subscribe(width => {
|
|
10427
10423
|
const className = tableBem.element(`column-${this.tableColumnDefDirective.cssClassFriendlyName}`);
|
|
10428
10424
|
if (!this.hostAttr) {
|
|
10429
|
-
this.hostAttr = `resizable-${
|
|
10425
|
+
this.hostAttr = `table-resizable-dynamic-style-${tableResizableDynamicStyleUid++}`;
|
|
10430
10426
|
this.containerElement.setAttribute(this.hostAttr, '');
|
|
10431
10427
|
this.styleEl = this.renderer2.createElement('style');
|
|
10432
10428
|
this.renderer2.appendChild(this.containerElement, this.styleEl);
|