@alauda/ui 7.3.3-beta.1 → 7.3.3-beta.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/resizable/resizable.directive.mjs +52 -58
- package/esm2022/table/table-cell.directive.mjs +3 -5
- package/esm2022/table/table-col-resizable.directive.mjs +30 -9
- package/esm2022/table/table-header-cell.directive.mjs +3 -5
- package/esm2022/table/table-scroll.directive.mjs +13 -18
- package/esm2022/table/table.component.mjs +12 -9
- package/fesm2022/alauda-ui.mjs +111 -101
- package/fesm2022/alauda-ui.mjs.map +1 -1
- package/package.json +2 -1
- package/resizable/resizable.directive.d.ts +10 -13
- package/table/table-col-resizable.directive.d.ts +3 -0
- package/table/table-scroll.directive.d.ts +1 -2
- package/table/table.component.d.ts +2 -1
- /package/{theme → resizable}/resizable.scss +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
1
|
+
import { Directive, ElementRef, EventEmitter, inject, Input, Output, Renderer2, } from '@angular/core';
|
|
2
|
+
import { fromEvent, Subject, take, takeUntil } from 'rxjs';
|
|
3
|
+
import { handlePixel } from '../utils';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export class ContainerForResizableDirective {
|
|
6
6
|
el = inject(ElementRef);
|
|
@@ -18,44 +18,36 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
18
18
|
}]
|
|
19
19
|
}] });
|
|
20
20
|
export class ResizableDirective {
|
|
21
|
-
renderer2;
|
|
22
|
-
doc;
|
|
23
|
-
containerDirective;
|
|
24
21
|
minWidth;
|
|
25
22
|
maxWidth;
|
|
23
|
+
manualAdjustment = false;
|
|
26
24
|
resizeStart = new EventEmitter();
|
|
27
25
|
resizing = new EventEmitter();
|
|
28
26
|
resizeEnd = new EventEmitter();
|
|
27
|
+
elementRef = inject(ElementRef);
|
|
28
|
+
renderer2 = inject(Renderer2);
|
|
29
|
+
containerDirective = inject(ContainerForResizableDirective, {
|
|
30
|
+
optional: true,
|
|
31
|
+
});
|
|
32
|
+
element = this.elementRef.nativeElement;
|
|
33
|
+
containerElement = this.containerDirective?.el.nativeElement || this.element;
|
|
29
34
|
destroy$$ = new Subject();
|
|
30
|
-
containerElement;
|
|
31
|
-
element;
|
|
32
35
|
initialWidth;
|
|
33
36
|
mouseDownScreenX;
|
|
34
37
|
resizeHandle;
|
|
35
38
|
resizeOverlay;
|
|
36
39
|
resizeBar;
|
|
37
|
-
mouseUpSubscription;
|
|
38
|
-
document;
|
|
39
40
|
handleHasUp;
|
|
40
41
|
BAR_WIDTH = 2;
|
|
41
|
-
constructor(element, renderer2, doc, containerDirective) {
|
|
42
|
-
this.renderer2 = renderer2;
|
|
43
|
-
this.doc = doc;
|
|
44
|
-
this.containerDirective = containerDirective;
|
|
45
|
-
this.element = element.nativeElement;
|
|
46
|
-
this.document = this.doc;
|
|
47
|
-
this.containerElement =
|
|
48
|
-
this.containerDirective?.el.nativeElement || this.element;
|
|
49
|
-
}
|
|
50
42
|
ngAfterViewInit() {
|
|
51
43
|
this.createResizeHandle();
|
|
52
|
-
this.binEvent(this.element, 'mouseover'
|
|
44
|
+
this.binEvent(this.element, 'mouseover').subscribe(() => {
|
|
53
45
|
this.handleHasUp = true;
|
|
54
46
|
if (!this.resizeBar) {
|
|
55
47
|
this.setResizeHandleVisible(true);
|
|
56
48
|
}
|
|
57
49
|
});
|
|
58
|
-
this.binEvent(this.element, 'mouseout'
|
|
50
|
+
this.binEvent(this.element, 'mouseout').subscribe(() => {
|
|
59
51
|
this.handleHasUp = false;
|
|
60
52
|
this.setResizeHandleVisible(false);
|
|
61
53
|
});
|
|
@@ -64,23 +56,25 @@ export class ResizableDirective {
|
|
|
64
56
|
this.destroy$$.next();
|
|
65
57
|
this.destroy$$.complete();
|
|
66
58
|
}
|
|
67
|
-
binEvent(target, eventType
|
|
68
|
-
return fromEvent(target, eventType)
|
|
69
|
-
.pipe(takeUntil(this.destroy$$))
|
|
70
|
-
.subscribe(callback);
|
|
59
|
+
binEvent(target, eventType) {
|
|
60
|
+
return fromEvent(target, eventType).pipe(takeUntil(this.destroy$$));
|
|
71
61
|
}
|
|
72
62
|
setResizeHandleVisible(isVisible) {
|
|
73
|
-
this.resizeHandle
|
|
63
|
+
if (this.resizeHandle) {
|
|
74
64
|
this.renderer2.setStyle(this.resizeHandle, 'visibility', isVisible ? 'visible' : 'hidden');
|
|
65
|
+
}
|
|
75
66
|
}
|
|
76
67
|
createResizeHandle() {
|
|
77
|
-
if (
|
|
78
|
-
|
|
79
|
-
this.renderer2.addClass(this.resizeHandle, 'resize-handle');
|
|
80
|
-
this.binEvent(this.resizeHandle, 'click', (e) => e.stopPropagation());
|
|
81
|
-
this.binEvent(this.resizeHandle, 'mousedown', this.onMousedown.bind(this));
|
|
82
|
-
this.renderer2.appendChild(this.element, this.resizeHandle);
|
|
68
|
+
if (this.resizeHandle) {
|
|
69
|
+
return;
|
|
83
70
|
}
|
|
71
|
+
this.resizeHandle = this.renderer2.createElement('div');
|
|
72
|
+
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
|
+
this.renderer2.appendChild(this.element, this.resizeHandle);
|
|
84
78
|
}
|
|
85
79
|
createResizeOverlay() {
|
|
86
80
|
this.resizeOverlay = this.renderer2.createElement('div');
|
|
@@ -102,33 +96,42 @@ export class ResizableDirective {
|
|
|
102
96
|
this.mouseDownScreenX = event.clientX;
|
|
103
97
|
this.createResizeOverlay();
|
|
104
98
|
this.createResizeBar();
|
|
105
|
-
|
|
106
|
-
|
|
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
|
+
});
|
|
107
108
|
}
|
|
108
109
|
onMouseup(event) {
|
|
109
|
-
this.handleHasUp
|
|
110
|
+
if (this.handleHasUp) {
|
|
111
|
+
this.setResizeHandleVisible(true);
|
|
112
|
+
}
|
|
110
113
|
this.renderer2.removeChild(this.containerElement, this.resizeOverlay);
|
|
111
114
|
this.resizeOverlay = null;
|
|
112
115
|
this.renderer2.removeChild(this.containerElement, this.resizeBar);
|
|
113
116
|
this.resizeBar = null;
|
|
114
117
|
const movementX = event.clientX - this.mouseDownScreenX;
|
|
115
118
|
const newWidth = this.initialWidth + movementX;
|
|
116
|
-
this.
|
|
117
|
-
if (
|
|
118
|
-
this.
|
|
119
|
+
const width = this.getFinalWidth(newWidth);
|
|
120
|
+
if (!this.manualAdjustment) {
|
|
121
|
+
this.renderer2.setStyle(this.element, 'width', handlePixel(width));
|
|
119
122
|
}
|
|
120
|
-
this.
|
|
123
|
+
this.resizeEnd.emit(width);
|
|
121
124
|
}
|
|
122
|
-
move
|
|
125
|
+
move(event) {
|
|
123
126
|
if (!this.resizeBar) {
|
|
124
127
|
return;
|
|
125
128
|
}
|
|
126
129
|
const movementX = event.clientX - this.mouseDownScreenX;
|
|
127
130
|
const newWidth = this.initialWidth + movementX;
|
|
128
131
|
const finalWidth = this.getFinalWidth(newWidth);
|
|
129
|
-
this.renderer2.setStyle(this.resizeBar, 'left',
|
|
132
|
+
this.renderer2.setStyle(this.resizeBar, 'left', handlePixel(finalWidth + this.getOffset() - this.BAR_WIDTH));
|
|
130
133
|
this.resizing.emit(finalWidth);
|
|
131
|
-
}
|
|
134
|
+
}
|
|
132
135
|
getFinalWidth(newWidth) {
|
|
133
136
|
const _max = this.containerElement.clientWidth + this.getOffset();
|
|
134
137
|
const minWidth = this.handleWidth(this.minWidth || this.getOffset());
|
|
@@ -146,20 +149,14 @@ export class ResizableDirective {
|
|
|
146
149
|
if (!width) {
|
|
147
150
|
return;
|
|
148
151
|
}
|
|
149
|
-
if (width.
|
|
152
|
+
if (width.endsWith('%')) {
|
|
150
153
|
const tableWidth = this.containerElement.clientWidth;
|
|
151
154
|
return (tableWidth * Number.parseFloat(width)) / 100;
|
|
152
155
|
}
|
|
153
156
|
return Number.parseFloat(width.replace(/\D+/, ''));
|
|
154
157
|
}
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
this.mouseUpSubscription.unsubscribe();
|
|
158
|
-
this.mouseUpSubscription = null;
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ResizableDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: DOCUMENT }, { token: ContainerForResizableDirective, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
162
|
-
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 });
|
|
158
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ResizableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
159
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: ResizableDirective, isStandalone: true, selector: "[auiResizable]", inputs: { minWidth: "minWidth", maxWidth: "maxWidth", manualAdjustment: "manualAdjustment" }, outputs: { resizeStart: "resizeStart", resizing: "resizing", resizeEnd: "resizeEnd" }, host: { classAttribute: "aui-resizable" }, ngImport: i0 });
|
|
163
160
|
}
|
|
164
161
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ResizableDirective, decorators: [{
|
|
165
162
|
type: Directive,
|
|
@@ -170,15 +167,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
170
167
|
},
|
|
171
168
|
standalone: true,
|
|
172
169
|
}]
|
|
173
|
-
}],
|
|
174
|
-
type: Inject,
|
|
175
|
-
args: [DOCUMENT]
|
|
176
|
-
}] }, { type: ContainerForResizableDirective, decorators: [{
|
|
177
|
-
type: Optional
|
|
178
|
-
}] }]; }, propDecorators: { minWidth: [{
|
|
170
|
+
}], propDecorators: { minWidth: [{
|
|
179
171
|
type: Input
|
|
180
172
|
}], maxWidth: [{
|
|
181
173
|
type: Input
|
|
174
|
+
}], manualAdjustment: [{
|
|
175
|
+
type: Input
|
|
182
176
|
}], resizeStart: [{
|
|
183
177
|
type: Output
|
|
184
178
|
}], resizing: [{
|
|
@@ -186,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
186
180
|
}], resizeEnd: [{
|
|
187
181
|
type: Output
|
|
188
182
|
}] } });
|
|
189
|
-
//# 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 { DOCUMENT } from '@angular/common';\nimport {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  Renderer2,\n} from '@angular/core';\nimport { fromEvent, Subject, Subscription, 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  el = inject(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 mouseUpSubscription: Subscription;\n  private readonly document: Document;\n  private handleHasUp: boolean;\n  private readonly BAR_WIDTH = 2;\n\n  constructor(\n    element: ElementRef,\n    readonly renderer2: Renderer2,\n    @Inject(DOCUMENT)\n    private readonly doc: Document,\n    @Optional()\n    private readonly containerDirective: ContainerForResizableDirective,\n  ) {\n    this.element = element.nativeElement;\n    this.document = this.doc;\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    this.resizeHandle &&\n      this.renderer2.setStyle(\n        this.resizeHandle,\n        'visibility',\n        isVisible ? 'visible' : 'hidden',\n      );\n  }\n\n  private createResizeHandle() {\n    if (!this.resizeHandle) {\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(\n        this.resizeHandle,\n        'mousedown',\n        this.onMousedown.bind(this),\n      );\n\n      this.renderer2.appendChild(this.element, this.resizeHandle);\n    }\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    this.mouseUpSubscription = this.binEvent<MouseEvent>(\n      document,\n      'mouseup',\n      ev => this.onMouseup(ev),\n    );\n\n    this.binEvent(document, 'mousemove', this.move);\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    if (this.mouseUpSubscription && !this.mouseUpSubscription.closed) {\n      this._destroySubscription();\n    }\n\n    this.document.removeEventListener('mousemove', this.move);\n  }\n\n  private readonly 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.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  private _destroySubscription() {\n    if (this.mouseUpSubscription) {\n      this.mouseUpSubscription.unsubscribe();\n      this.mouseUpSubscription = null;\n    }\n  }\n}\n"]}
|
|
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"]}
|
|
@@ -1,15 +1,13 @@
|
|
|
1
1
|
import { CdkCell } from '@angular/cdk/table';
|
|
2
2
|
import { Directive, Input } from '@angular/core';
|
|
3
|
-
import {
|
|
4
|
-
import { TABLE_PREFIX_CLASSNAME } from './table.component';
|
|
3
|
+
import { tableBem } from './table.component';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "@angular/cdk/table";
|
|
7
|
-
const bem = buildBem(TABLE_PREFIX_CLASSNAME);
|
|
8
6
|
export class TableCellDirective extends CdkCell {
|
|
9
7
|
direction = 'row';
|
|
10
8
|
constructor(columnDef, elementRef) {
|
|
11
9
|
super(columnDef, elementRef);
|
|
12
|
-
elementRef.nativeElement.classList.add(
|
|
10
|
+
elementRef.nativeElement.classList.add(tableBem.element(`column-${columnDef.cssClassFriendlyName}`));
|
|
13
11
|
}
|
|
14
12
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TableCellDirective, deps: [{ token: i1.CdkColumnDef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
15
13
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: TableCellDirective, isStandalone: true, selector: "aui-table-cell", inputs: { direction: "direction" }, host: { attributes: { "role": "gridcell" }, properties: { "class.aui-table__cell--column": "direction === \"column\"" }, classAttribute: "aui-table__cell" }, usesInheritance: true, ngImport: i0 });
|
|
@@ -28,4 +26,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
28
26
|
}], ctorParameters: function () { return [{ type: i1.CdkColumnDef }, { type: i0.ElementRef }]; }, propDecorators: { direction: [{
|
|
29
27
|
type: Input
|
|
30
28
|
}] } });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2VsbC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdGFibGUvdGFibGUtY2VsbC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBZ0IsTUFBTSxvQkFBb0IsQ0FBQztBQUMzRCxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU3RCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7OztBQWE3QyxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsT0FBTztJQUU3QyxTQUFTLEdBQXFCLEtBQUssQ0FBQztJQUVwQyxZQUFZLFNBQXVCLEVBQUUsVUFBbUM7UUFDdEUsS0FBSyxDQUFDLFNBQVMsRUFBRSxVQUFVLENBQUMsQ0FBQztRQUM3QixVQUFVLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQ3BDLFFBQVEsQ0FBQyxPQUFPLENBQUMsVUFBVSxTQUFTLENBQUMsb0JBQW9CLEVBQUUsQ0FBQyxDQUM3RCxDQUFDO0lBQ0osQ0FBQzt1R0FUVSxrQkFBa0I7MkZBQWxCLGtCQUFrQjs7MkZBQWxCLGtCQUFrQjtrQkFWOUIsU0FBUzttQkFBQztvQkFFVCxRQUFRLEVBQUUsZ0JBQWdCO29CQUMxQixJQUFJLEVBQUU7d0JBQ0osS0FBSyxFQUFFLGlCQUFpQjt3QkFDeEIsSUFBSSxFQUFFLFVBQVU7d0JBQ2hCLGlDQUFpQyxFQUFFLHdCQUF3QjtxQkFDNUQ7b0JBQ0QsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzRIQUdDLFNBQVM7c0JBRFIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENka0NlbGwsIENka0NvbHVtbkRlZiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay90YWJsZSc7XG5pbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IHRhYmxlQmVtIH0gZnJvbSAnLi90YWJsZS5jb21wb25lbnQnO1xuXG4vKiogQ2VsbCB0ZW1wbGF0ZSBjb250YWluZXIgdGhhdCBhZGRzIHRoZSByaWdodCBjbGFzc2VzIGFuZCByb2xlLiAqL1xuQERpcmVjdGl2ZSh7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvZGlyZWN0aXZlLXNlbGVjdG9yXG4gIHNlbGVjdG9yOiAnYXVpLXRhYmxlLWNlbGwnLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdhdWktdGFibGVfX2NlbGwnLFxuICAgIHJvbGU6ICdncmlkY2VsbCcsXG4gICAgJ1tjbGFzcy5hdWktdGFibGVfX2NlbGwtLWNvbHVtbl0nOiAnZGlyZWN0aW9uID09PSBcImNvbHVtblwiJyxcbiAgfSxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgVGFibGVDZWxsRGlyZWN0aXZlIGV4dGVuZHMgQ2RrQ2VsbCB7XG4gIEBJbnB1dCgpXG4gIGRpcmVjdGlvbjogJ3JvdycgfCAnY29sdW1uJyA9ICdyb3cnO1xuXG4gIGNvbnN0cnVjdG9yKGNvbHVtbkRlZjogQ2RrQ29sdW1uRGVmLCBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50Pikge1xuICAgIHN1cGVyKGNvbHVtbkRlZiwgZWxlbWVudFJlZik7XG4gICAgZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmNsYXNzTGlzdC5hZGQoXG4gICAgICB0YWJsZUJlbS5lbGVtZW50KGBjb2x1bW4tJHtjb2x1bW5EZWYuY3NzQ2xhc3NGcmllbmRseU5hbWV9YCksXG4gICAgKTtcbiAgfVxufVxuIl19
|
|
@@ -1,39 +1,60 @@
|
|
|
1
1
|
import { Directive, inject, Input } from '@angular/core';
|
|
2
2
|
import { takeUntil } from 'rxjs';
|
|
3
3
|
import { ResizableDirective } from '../resizable';
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
4
|
+
import { handlePixel } from '../utils';
|
|
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';
|
|
10
|
+
manualAdjustment = true;
|
|
9
11
|
tableColumnDefDirective = inject(TableColumnDefDirective);
|
|
10
12
|
tableComponent = inject(TableComponent);
|
|
11
13
|
tableScrollWrapperDirective = inject(TableScrollWrapperDirective, {
|
|
12
14
|
optional: true,
|
|
13
15
|
});
|
|
14
16
|
styleEl;
|
|
17
|
+
sheet;
|
|
15
18
|
hostAttr;
|
|
16
19
|
ngAfterViewInit() {
|
|
17
20
|
super.ngAfterViewInit();
|
|
18
21
|
this.containerElement = (this.tableScrollWrapperDirective || this.tableComponent).el.nativeElement;
|
|
19
|
-
const bem = buildBem(TABLE_PREFIX_CLASSNAME);
|
|
20
22
|
this.resizeEnd.pipe(takeUntil(this.destroy$$)).subscribe(width => {
|
|
21
|
-
const className =
|
|
23
|
+
const className = tableBem.element(`column-${this.tableColumnDefDirective.cssClassFriendlyName}`);
|
|
22
24
|
if (!this.hostAttr) {
|
|
23
|
-
this.hostAttr = `resizable-${
|
|
25
|
+
this.hostAttr = `table-resizable-dynamic-style-${tableResizableDynamicStyleUid++}`;
|
|
24
26
|
this.containerElement.setAttribute(this.hostAttr, '');
|
|
25
|
-
this.styleEl = this.renderer2.createElement('style');
|
|
26
|
-
this.renderer2.appendChild(this.containerElement, this.styleEl);
|
|
27
27
|
}
|
|
28
|
-
|
|
28
|
+
const styleString = `
|
|
29
29
|
[${this.hostAttr}] .${className} {
|
|
30
30
|
width: ${handlePixel(width)} !important;
|
|
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 {
|
|
42
|
+
if (!this.styleEl) {
|
|
43
|
+
this.styleEl = this.renderer2.createElement('style');
|
|
44
|
+
this.renderer2.appendChild(this.containerElement, this.styleEl);
|
|
45
|
+
}
|
|
46
|
+
this.styleEl.innerHTML = styleString;
|
|
47
|
+
}
|
|
34
48
|
this.tableComponent.updateStickyColumnStyles();
|
|
35
49
|
});
|
|
36
50
|
}
|
|
51
|
+
ngOnDestroy() {
|
|
52
|
+
super.ngOnDestroy();
|
|
53
|
+
if (this.sheet) {
|
|
54
|
+
const idx = document.adoptedStyleSheets.indexOf(this.sheet);
|
|
55
|
+
document.adoptedStyleSheets.splice(idx, 1);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
37
58
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TableColResizableDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
38
59
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: TableColResizableDirective, isStandalone: true, selector: "[auiTableColResizable]", inputs: { minWidth: "minWidth" }, usesInheritance: true, ngImport: i0 });
|
|
39
60
|
}
|
|
@@ -46,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
46
67
|
}], propDecorators: { minWidth: [{
|
|
47
68
|
type: Input
|
|
48
69
|
}] } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sLXJlc2l6YWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdGFibGUvdGFibGUtY29sLXJlc2l6YWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRWpDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNsRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRXZDLE9BQU8sRUFDTCxRQUFRLEVBQ1IsdUJBQXVCLEVBQ3ZCLGNBQWMsRUFDZCwyQkFBMkIsR0FDNUIsTUFBTSxTQUFTLENBQUM7O0FBRWpCLElBQUksNkJBQTZCLEdBQUcsQ0FBQyxDQUFDO0FBTXRDLE1BQU0sT0FBTywwQkFDWCxTQUFRLGtCQUFrQjtJQUlqQixRQUFRLEdBQUcsTUFBTSxDQUFDO0lBRVQsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO0lBRXpCLHVCQUF1QixHQUFHLE1BQU0sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO0lBQzFELGNBQWMsR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDeEMsMkJBQTJCLEdBQUcsTUFBTSxDQUNuRCwyQkFBMkIsRUFDM0I7UUFDRSxRQUFRLEVBQUUsSUFBSTtLQUNmLENBQ0YsQ0FBQztJQUVNLE9BQU8sQ0FBbUI7SUFDMUIsS0FBSyxDQUFnQjtJQUNyQixRQUFRLENBQVM7SUFFaEIsZUFBZTtRQUN0QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFeEIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLENBQ3RCLElBQUksQ0FBQywyQkFBMkIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUN4RCxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFFbkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUMvRCxNQUFNLFNBQVMsR0FBRyxRQUFRLENBQUMsT0FBTyxDQUNoQyxVQUFVLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxvQkFBb0IsRUFBRSxDQUM5RCxDQUFDO1lBQ0YsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUcsaUNBQWlDLDZCQUE2QixFQUFFLEVBQUUsQ0FBQztnQkFDbkYsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO2FBQ3ZEO1lBQ0QsTUFBTSxXQUFXLEdBQUc7VUFDaEIsSUFBSSxDQUFDLFFBQVEsTUFBTSxTQUFTO2lCQUNyQixXQUFXLENBQUMsS0FBSyxDQUFDOzs7T0FHNUIsQ0FBQztZQUNGLElBQUksYUFBYSxFQUFFO2dCQUNqQixJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRTtvQkFDZixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksYUFBYSxFQUFFLENBQUM7b0JBQ2pDLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO2lCQUM5QztnQkFDRCxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsQ0FBQzthQUNyQztpQkFBTTtnQkFDTCxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtvQkFDakIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztvQkFDckQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztpQkFDakU7Z0JBQ0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEdBQUcsV0FBVyxDQUFDO2FBQ3RDO1lBRUQsSUFBSSxDQUFDLGNBQWMsQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1FBQ2pELENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVRLFdBQVc7UUFDbEIsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBRXBCLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNkLE1BQU0sR0FBRyxHQUFHLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzVELFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDO1NBQzVDO0lBQ0gsQ0FBQzt1R0FwRVUsMEJBQTBCOzJGQUExQiwwQkFBMEI7OzJGQUExQiwwQkFBMEI7a0JBSnRDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzhCQU1VLFFBQVE7c0JBRGhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdJbml0LCBEaXJlY3RpdmUsIGluamVjdCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBSZXNpemFibGVEaXJlY3RpdmUgfSBmcm9tICcuLi9yZXNpemFibGUnO1xuaW1wb3J0IHsgaGFuZGxlUGl4ZWwgfSBmcm9tICcuLi91dGlscyc7XG5cbmltcG9ydCB7XG4gIHRhYmxlQmVtLFxuICBUYWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSxcbiAgVGFibGVDb21wb25lbnQsXG4gIFRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSxcbn0gZnJvbSAnLi9pbmRleCc7XG5cbmxldCB0YWJsZVJlc2l6YWJsZUR5bmFtaWNTdHlsZVVpZCA9IDA7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1thdWlUYWJsZUNvbFJlc2l6YWJsZV0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJsZUNvbFJlc2l6YWJsZURpcmVjdGl2ZVxuICBleHRlbmRzIFJlc2l6YWJsZURpcmVjdGl2ZVxuICBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXRcbntcbiAgQElucHV0KClcbiAgb3ZlcnJpZGUgbWluV2lkdGggPSAnNjBweCc7XG5cbiAgb3ZlcnJpZGUgcmVhZG9ubHkgbWFudWFsQWRqdXN0bWVudCA9IHRydWU7XG5cbiAgcHJpdmF0ZSByZWFkb25seSB0YWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSA9IGluamVjdChUYWJsZUNvbHVtbkRlZkRpcmVjdGl2ZSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgdGFibGVDb21wb25lbnQgPSBpbmplY3QoVGFibGVDb21wb25lbnQpO1xuICBwcml2YXRlIHJlYWRvbmx5IHRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSA9IGluamVjdChcbiAgICBUYWJsZVNjcm9sbFdyYXBwZXJEaXJlY3RpdmUsXG4gICAge1xuICAgICAgb3B0aW9uYWw6IHRydWUsXG4gICAgfSxcbiAgKTtcblxuICBwcml2YXRlIHN0eWxlRWw6IEhUTUxTdHlsZUVsZW1lbnQ7XG4gIHByaXZhdGUgc2hlZXQ6IENTU1N0eWxlU2hlZXQ7XG4gIHByaXZhdGUgaG9zdEF0dHI6IHN0cmluZztcblxuICBvdmVycmlkZSBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgc3VwZXIubmdBZnRlclZpZXdJbml0KCk7XG5cbiAgICB0aGlzLmNvbnRhaW5lckVsZW1lbnQgPSAoXG4gICAgICB0aGlzLnRhYmxlU2Nyb2xsV3JhcHBlckRpcmVjdGl2ZSB8fCB0aGlzLnRhYmxlQ29tcG9uZW50XG4gICAgKS5lbC5uYXRpdmVFbGVtZW50O1xuXG4gICAgdGhpcy5yZXNpemVFbmQucGlwZSh0YWtlVW50aWwodGhpcy5kZXN0cm95JCQpKS5zdWJzY3JpYmUod2lkdGggPT4ge1xuICAgICAgY29uc3QgY2xhc3NOYW1lID0gdGFibGVCZW0uZWxlbWVudChcbiAgICAgICAgYGNvbHVtbi0ke3RoaXMudGFibGVDb2x1bW5EZWZEaXJlY3RpdmUuY3NzQ2xhc3NGcmllbmRseU5hbWV9YCxcbiAgICAgICk7XG4gICAgICBpZiAoIXRoaXMuaG9zdEF0dHIpIHtcbiAgICAgICAgdGhpcy5ob3N0QXR0ciA9IGB0YWJsZS1yZXNpemFibGUtZHluYW1pYy1zdHlsZS0ke3RhYmxlUmVzaXphYmxlRHluYW1pY1N0eWxlVWlkKyt9YDtcbiAgICAgICAgdGhpcy5jb250YWluZXJFbGVtZW50LnNldEF0dHJpYnV0ZSh0aGlzLmhvc3RBdHRyLCAnJyk7XG4gICAgICB9XG4gICAgICBjb25zdCBzdHlsZVN0cmluZyA9IGBcbiAgICAgICBbJHt0aGlzLmhvc3RBdHRyfV0gLiR7Y2xhc3NOYW1lfSB7XG4gICAgICAgIHdpZHRoOiAke2hhbmRsZVBpeGVsKHdpZHRoKX0gIWltcG9ydGFudDtcbiAgICAgICAgZmxleDogbm9uZSAhaW1wb3J0YW50O1xuICAgICAgfVxuICAgICAgYDtcbiAgICAgIGlmIChDU1NTdHlsZVNoZWV0KSB7XG4gICAgICAgIGlmICghdGhpcy5zaGVldCkge1xuICAgICAgICAgIHRoaXMuc2hlZXQgPSBuZXcgQ1NTU3R5bGVTaGVldCgpO1xuICAgICAgICAgIGRvY3VtZW50LmFkb3B0ZWRTdHlsZVNoZWV0cy5wdXNoKHRoaXMuc2hlZXQpO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMuc2hlZXQucmVwbGFjZVN5bmMoc3R5bGVTdHJpbmcpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgaWYgKCF0aGlzLnN0eWxlRWwpIHtcbiAgICAgICAgICB0aGlzLnN0eWxlRWwgPSB0aGlzLnJlbmRlcmVyMi5jcmVhdGVFbGVtZW50KCdzdHlsZScpO1xuICAgICAgICAgIHRoaXMucmVuZGVyZXIyLmFwcGVuZENoaWxkKHRoaXMuY29udGFpbmVyRWxlbWVudCwgdGhpcy5zdHlsZUVsKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnN0eWxlRWwuaW5uZXJIVE1MID0gc3R5bGVTdHJpbmc7XG4gICAgICB9XG5cbiAgICAgIHRoaXMudGFibGVDb21wb25lbnQudXBkYXRlU3RpY2t5Q29sdW1uU3R5bGVzKCk7XG4gICAgfSk7XG4gIH1cblxuICBvdmVycmlkZSBuZ09uRGVzdHJveSgpIHtcbiAgICBzdXBlci5uZ09uRGVzdHJveSgpO1xuXG4gICAgaWYgKHRoaXMuc2hlZXQpIHtcbiAgICAgIGNvbnN0IGlkeCA9IGRvY3VtZW50LmFkb3B0ZWRTdHlsZVNoZWV0cy5pbmRleE9mKHRoaXMuc2hlZXQpO1xuICAgICAgZG9jdW1lbnQuYWRvcHRlZFN0eWxlU2hlZXRzLnNwbGljZShpZHgsIDEpO1xuICAgIH1cbiAgfVxufVxuIl19
|
|
@@ -1,14 +1,12 @@
|
|
|
1
1
|
import { CdkHeaderCell } from '@angular/cdk/table';
|
|
2
2
|
import { Directive } from '@angular/core';
|
|
3
|
-
import {
|
|
4
|
-
import { TABLE_PREFIX_CLASSNAME } from './table.component';
|
|
3
|
+
import { tableBem } from './table.component';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "@angular/cdk/table";
|
|
7
|
-
const bem = buildBem(TABLE_PREFIX_CLASSNAME);
|
|
8
6
|
export class TableHeaderCellDirective extends CdkHeaderCell {
|
|
9
7
|
constructor(columnDef, elementRef) {
|
|
10
8
|
super(columnDef, elementRef);
|
|
11
|
-
elementRef.nativeElement.classList.add(
|
|
9
|
+
elementRef.nativeElement.classList.add(tableBem.element(`column-${columnDef.cssClassFriendlyName}`));
|
|
12
10
|
}
|
|
13
11
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TableHeaderCellDirective, deps: [{ token: i1.CdkColumnDef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
14
12
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: TableHeaderCellDirective, isStandalone: true, selector: "aui-table-header-cell", host: { attributes: { "role": "columnheader" }, classAttribute: "aui-table__header-cell" }, usesInheritance: true, ngImport: i0 });
|
|
@@ -24,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
24
22
|
standalone: true,
|
|
25
23
|
}]
|
|
26
24
|
}], ctorParameters: function () { return [{ type: i1.CdkColumnDef }, { type: i0.ElementRef }]; } });
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtaGVhZGVyLWNlbGwuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3RhYmxlL3RhYmxlLWhlYWRlci1jZWxsLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWdCLGFBQWEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxTQUFTLEVBQWMsTUFBTSxlQUFlLENBQUM7QUFFdEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLG1CQUFtQixDQUFDOzs7QUFZN0MsTUFBTSxPQUFPLHdCQUF5QixTQUFRLGFBQWE7SUFDekQsWUFBWSxTQUF1QixFQUFFLFVBQW1DO1FBQ3RFLEtBQUssQ0FBQyxTQUFTLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFDN0IsVUFBVSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUNwQyxRQUFRLENBQUMsT0FBTyxDQUFDLFVBQVUsU0FBUyxDQUFDLG9CQUFvQixFQUFFLENBQUMsQ0FDN0QsQ0FBQztJQUNKLENBQUM7dUdBTlUsd0JBQXdCOzJGQUF4Qix3QkFBd0I7OzJGQUF4Qix3QkFBd0I7a0JBVHBDLFNBQVM7bUJBQUM7b0JBRVQsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsSUFBSSxFQUFFO3dCQUNKLEtBQUssRUFBRSx3QkFBd0I7d0JBQy9CLElBQUksRUFBRSxjQUFjO3FCQUNyQjtvQkFDRCxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZGtDb2x1bW5EZWYsIENka0hlYWRlckNlbGwgfSBmcm9tICdAYW5ndWxhci9jZGsvdGFibGUnO1xuaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IHRhYmxlQmVtIH0gZnJvbSAnLi90YWJsZS5jb21wb25lbnQnO1xuXG4vKiogSGVhZGVyIGNlbGwgdGVtcGxhdGUgY29udGFpbmVyIHRoYXQgYWRkcyB0aGUgcmlnaHQgY2xhc3NlcyBhbmQgcm9sZS4gKi9cbkBEaXJlY3RpdmUoe1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2RpcmVjdGl2ZS1zZWxlY3RvclxuICBzZWxlY3RvcjogJ2F1aS10YWJsZS1oZWFkZXItY2VsbCcsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2F1aS10YWJsZV9faGVhZGVyLWNlbGwnLFxuICAgIHJvbGU6ICdjb2x1bW5oZWFkZXInLFxuICB9LFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJsZUhlYWRlckNlbGxEaXJlY3RpdmUgZXh0ZW5kcyBDZGtIZWFkZXJDZWxsIHtcbiAgY29uc3RydWN0b3IoY29sdW1uRGVmOiBDZGtDb2x1bW5EZWYsIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+KSB7XG4gICAgc3VwZXIoY29sdW1uRGVmLCBlbGVtZW50UmVmKTtcbiAgICBlbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LmFkZChcbiAgICAgIHRhYmxlQmVtLmVsZW1lbnQoYGNvbHVtbi0ke2NvbHVtbkRlZi5jc3NDbGFzc0ZyaWVuZGx5TmFtZX1gKSxcbiAgICApO1xuICB9XG59XG4iXX0=
|
|
@@ -1,16 +1,15 @@
|
|
|
1
1
|
import { CdkScrollable } from '@angular/cdk/scrolling';
|
|
2
2
|
import { Directive, ElementRef, Host, HostBinding, inject, Input, Optional, } from '@angular/core';
|
|
3
3
|
import { Subject, fromEvent, merge, startWith, takeUntil, switchMap, NEVER, BehaviorSubject, } from 'rxjs';
|
|
4
|
-
import { coerceAttrBoolean, observeResizeOn } from '../utils';
|
|
5
|
-
import {
|
|
4
|
+
import { buildBem, coerceAttrBoolean, observeResizeOn } from '../utils';
|
|
5
|
+
import { tableBem } from './table.component';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@angular/cdk/scrolling";
|
|
8
8
|
import * as i2 from "./table.component";
|
|
9
9
|
import * as i3 from "@angular/cdk/bidi";
|
|
10
|
-
const
|
|
11
|
-
const
|
|
12
|
-
const
|
|
13
|
-
const SCROLL_BEFORE_END_CLASS = `${SHADOW_CLASS}--before-end`;
|
|
10
|
+
const shadowClass = tableBem.element('scroll-shadow');
|
|
11
|
+
const shadowBem = buildBem(shadowClass);
|
|
12
|
+
const scrollBeforeEndClass = shadowBem.modifier('before-end');
|
|
14
13
|
const HAS_TABLE_TOP_SHADOW = 'hasTableTopShadow';
|
|
15
14
|
const HAS_TABLE_BOTTOM_SHADOW = 'hasTableBottomShadow';
|
|
16
15
|
const HAS_TABLE_VERTICAL_SCROLL = 'hasTableVerticalScroll';
|
|
@@ -53,8 +52,7 @@ export class TableScrollableDirective extends CdkScrollable {
|
|
|
53
52
|
this.el = el;
|
|
54
53
|
this.table = table;
|
|
55
54
|
}
|
|
56
|
-
|
|
57
|
-
SHADOW_CLASS = true;
|
|
55
|
+
className = `${scrollBeforeEndClass} ${shadowClass}`;
|
|
58
56
|
get containerEl() {
|
|
59
57
|
return this.el.nativeElement;
|
|
60
58
|
}
|
|
@@ -97,16 +95,16 @@ export class TableScrollableDirective extends CdkScrollable {
|
|
|
97
95
|
}
|
|
98
96
|
mutateHorizontalScroll() {
|
|
99
97
|
const scrollDis = this.containerEl.scrollWidth - this.containerEl.offsetWidth;
|
|
100
|
-
this.placeClassList(this.containerEl.classList, scrollDis > 0,
|
|
98
|
+
this.placeClassList(this.containerEl.classList, scrollDis > 0, shadowBem.modifier('has-scroll'));
|
|
101
99
|
const scrollLeft = this.containerEl.scrollLeft;
|
|
102
|
-
this.placeClassList(this.containerEl.classList, scrollLeft > 0,
|
|
103
|
-
this.placeClassList(this.containerEl.classList, scrollLeft < scrollDis,
|
|
100
|
+
this.placeClassList(this.containerEl.classList, scrollLeft > 0, shadowBem.modifier('scrolling'));
|
|
101
|
+
this.placeClassList(this.containerEl.classList, scrollLeft < scrollDis, scrollBeforeEndClass);
|
|
104
102
|
}
|
|
105
103
|
placeClassList(classList, condition, className) {
|
|
106
104
|
classList[condition ? 'add' : 'remove'](className);
|
|
107
105
|
}
|
|
108
106
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TableScrollableDirective, deps: [{ token: i0.ElementRef }, { token: i1.ScrollDispatcher }, { token: i0.NgZone }, { token: i2.TableComponent, host: true }, { token: i3.Directionality, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
109
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: TableScrollableDirective, isStandalone: true, selector: "[auiTableScrollable]", inputs: { scrollable: ["auiTableScrollable", "scrollable"] }, host: { properties: { "class
|
|
107
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: TableScrollableDirective, isStandalone: true, selector: "[auiTableScrollable]", inputs: { scrollable: ["auiTableScrollable", "scrollable"] }, host: { properties: { "class": "this.className" } }, providers: [
|
|
110
108
|
{ provide: CdkScrollable, useExisting: TableScrollableDirective },
|
|
111
109
|
], usesInheritance: true, ngImport: i0 });
|
|
112
110
|
}
|
|
@@ -126,11 +124,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
126
124
|
}] }]; }, propDecorators: { scrollable: [{
|
|
127
125
|
type: Input,
|
|
128
126
|
args: ['auiTableScrollable']
|
|
129
|
-
}],
|
|
127
|
+
}], className: [{
|
|
130
128
|
type: HostBinding,
|
|
131
|
-
args: [
|
|
132
|
-
}], SHADOW_CLASS: [{
|
|
133
|
-
type: HostBinding,
|
|
134
|
-
args: [`class.${SHADOW_CLASS}`]
|
|
129
|
+
args: ['class']
|
|
135
130
|
}] } });
|
|
136
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-scroll.directive.js","sourceRoot":"","sources":["../../../src/table/table-scroll.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directionality } from '@angular/cdk/bidi';\nimport { CdkScrollable, ScrollDispatcher } from '@angular/cdk/scrolling';\nimport {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  Host,\n  HostBinding,\n  inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n} from '@angular/core';\nimport {\n  Subject,\n  fromEvent,\n  merge,\n  startWith,\n  takeUntil,\n  switchMap,\n  NEVER,\n  BehaviorSubject,\n} from 'rxjs';\n\nimport { coerceAttrBoolean, observeResizeOn } from '../utils';\n\nimport { TABLE_PREFIX_CLASSNAME, TableComponent } from './table.component';\n\nconst SHADOW_CLASS = `${TABLE_PREFIX_CLASSNAME}__scroll-shadow`;\nconst HAS_SCROLL_CLASS = `${SHADOW_CLASS}--has-scroll`;\nconst SCROLLING_CLASS = `${SHADOW_CLASS}--scrolling`;\nconst SCROLL_BEFORE_END_CLASS = `${SHADOW_CLASS}--before-end`;\n\nconst HAS_TABLE_TOP_SHADOW = 'hasTableTopShadow';\nconst HAS_TABLE_BOTTOM_SHADOW = 'hasTableBottomShadow';\nconst HAS_TABLE_VERTICAL_SCROLL = 'hasTableVerticalScroll';\n\n@Directive({\n  selector: '[auiTableScrollWrapper]',\n  host: {\n    class: 'aui-table__scroll-wrapper',\n  },\n  standalone: true,\n})\nexport class TableScrollWrapperDirective {\n  @HostBinding('style.max-height')\n  @Input()\n  auiTableScrollWrapper = '100%';\n\n  el = inject(ElementRef);\n}\n\n@Directive({\n  selector: '[auiTableScrollable]',\n  providers: [\n    { provide: CdkScrollable, useExisting: TableScrollableDirective },\n  ],\n  standalone: true,\n})\nexport class TableScrollableDirective\n  extends CdkScrollable\n  implements AfterViewInit, OnInit, OnDestroy\n{\n  @Input('auiTableScrollable')\n  set scrollable(scrollable: boolean | '') {\n    this._scrollable = coerceAttrBoolean(scrollable);\n    this.scrollable$$.next(this._scrollable);\n  }\n\n  get scrollable() {\n    return this._scrollable;\n  }\n\n  private _scrollable = true;\n\n  scrollable$$ = new BehaviorSubject<boolean>(this._scrollable);\n  destroy$$ = new Subject<void>();\n\n  constructor(\n    private readonly el: ElementRef<HTMLElement>,\n    scrollDispatcher: ScrollDispatcher,\n    ngZone: NgZone,\n    @Host() private readonly table: TableComponent<unknown>,\n    @Optional() dir?: Directionality,\n  ) {\n    super(el, scrollDispatcher, ngZone, dir);\n  }\n\n  @HostBinding(`class.${SCROLL_BEFORE_END_CLASS}`)\n  SCROLL_BEFORE_END_CLASS = true;\n\n  @HostBinding(`class.${SHADOW_CLASS}`)\n  SHADOW_CLASS = true;\n\n  get containerEl() {\n    return this.el.nativeElement;\n  }\n\n  override ngOnInit() {\n    if (this.scrollable) {\n      this.scrollDispatcher.register(this);\n    }\n  }\n\n  ngAfterViewInit() {\n    this.viewMutation();\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  viewMutation() {\n    this.scrollable$$\n      .pipe(\n        switchMap(scrollable => {\n          if (scrollable) {\n            this.scrollDispatcher.register(this);\n            return merge(\n              observeResizeOn(this.containerEl),\n              fromEvent(this.containerEl, 'scroll'),\n            ).pipe(startWith(null));\n          }\n\n          this.scrollDispatcher.deregister(this);\n          return NEVER;\n        }),\n      )\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(() => {\n        this.mutateVerticalScroll();\n        this.mutateHorizontalScroll();\n      });\n  }\n\n  mutateVerticalScroll() {\n    const scrollDis =\n      this.containerEl.scrollHeight - this.containerEl.offsetHeight;\n\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollDis > 0,\n      HAS_TABLE_VERTICAL_SCROLL,\n    );\n\n    const scrollTop = this.containerEl.scrollTop;\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollTop > 0,\n      HAS_TABLE_TOP_SHADOW,\n    );\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollTop < scrollDis,\n      HAS_TABLE_BOTTOM_SHADOW,\n    );\n\n    // 兼容屏幕缩放是 sticky多列的样式问题\n    this.table.updateStickyColumnStyles();\n  }\n\n  mutateHorizontalScroll() {\n    const scrollDis =\n      this.containerEl.scrollWidth - this.containerEl.offsetWidth;\n\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollDis > 0,\n      HAS_SCROLL_CLASS,\n    );\n\n    const scrollLeft = this.containerEl.scrollLeft;\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollLeft > 0,\n      SCROLLING_CLASS,\n    );\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollLeft < scrollDis,\n      SCROLL_BEFORE_END_CLASS,\n    );\n  }\n\n  placeClassList(\n    classList: DOMTokenList,\n    condition: boolean,\n    className: string,\n  ) {\n    classList[condition ? 'add' : 'remove'](className);\n  }\n}\n"]}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-scroll.directive.js","sourceRoot":"","sources":["../../../src/table/table-scroll.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directionality } from '@angular/cdk/bidi';\nimport { CdkScrollable, ScrollDispatcher } from '@angular/cdk/scrolling';\nimport {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  Host,\n  HostBinding,\n  inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n} from '@angular/core';\nimport {\n  Subject,\n  fromEvent,\n  merge,\n  startWith,\n  takeUntil,\n  switchMap,\n  NEVER,\n  BehaviorSubject,\n} from 'rxjs';\n\nimport { buildBem, coerceAttrBoolean, observeResizeOn } from '../utils';\n\nimport { tableBem, TableComponent } from './table.component';\n\nconst shadowClass = tableBem.element('scroll-shadow');\nconst shadowBem = buildBem(shadowClass);\nconst scrollBeforeEndClass = shadowBem.modifier('before-end');\n\nconst HAS_TABLE_TOP_SHADOW = 'hasTableTopShadow';\nconst HAS_TABLE_BOTTOM_SHADOW = 'hasTableBottomShadow';\nconst HAS_TABLE_VERTICAL_SCROLL = 'hasTableVerticalScroll';\n\n@Directive({\n  selector: '[auiTableScrollWrapper]',\n  host: {\n    class: 'aui-table__scroll-wrapper',\n  },\n  standalone: true,\n})\nexport class TableScrollWrapperDirective {\n  @HostBinding('style.max-height')\n  @Input()\n  auiTableScrollWrapper = '100%';\n\n  el = inject(ElementRef);\n}\n\n@Directive({\n  selector: '[auiTableScrollable]',\n  providers: [\n    { provide: CdkScrollable, useExisting: TableScrollableDirective },\n  ],\n  standalone: true,\n})\nexport class TableScrollableDirective\n  extends CdkScrollable\n  implements AfterViewInit, OnInit, OnDestroy\n{\n  @Input('auiTableScrollable')\n  set scrollable(scrollable: boolean | '') {\n    this._scrollable = coerceAttrBoolean(scrollable);\n    this.scrollable$$.next(this._scrollable);\n  }\n\n  get scrollable() {\n    return this._scrollable;\n  }\n\n  private _scrollable = true;\n\n  scrollable$$ = new BehaviorSubject<boolean>(this._scrollable);\n  destroy$$ = new Subject<void>();\n\n  constructor(\n    private readonly el: ElementRef<HTMLElement>,\n    scrollDispatcher: ScrollDispatcher,\n    ngZone: NgZone,\n    @Host() private readonly table: TableComponent<unknown>,\n    @Optional() dir?: Directionality,\n  ) {\n    super(el, scrollDispatcher, ngZone, dir);\n  }\n\n  @HostBinding('class')\n  className = `${scrollBeforeEndClass} ${shadowClass}`;\n\n  get containerEl() {\n    return this.el.nativeElement;\n  }\n\n  override ngOnInit() {\n    if (this.scrollable) {\n      this.scrollDispatcher.register(this);\n    }\n  }\n\n  ngAfterViewInit() {\n    this.viewMutation();\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  viewMutation() {\n    this.scrollable$$\n      .pipe(\n        switchMap(scrollable => {\n          if (scrollable) {\n            this.scrollDispatcher.register(this);\n            return merge(\n              observeResizeOn(this.containerEl),\n              fromEvent(this.containerEl, 'scroll'),\n            ).pipe(startWith(null));\n          }\n\n          this.scrollDispatcher.deregister(this);\n          return NEVER;\n        }),\n      )\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(() => {\n        this.mutateVerticalScroll();\n        this.mutateHorizontalScroll();\n      });\n  }\n\n  mutateVerticalScroll() {\n    const scrollDis =\n      this.containerEl.scrollHeight - this.containerEl.offsetHeight;\n\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollDis > 0,\n      HAS_TABLE_VERTICAL_SCROLL,\n    );\n\n    const scrollTop = this.containerEl.scrollTop;\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollTop > 0,\n      HAS_TABLE_TOP_SHADOW,\n    );\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollTop < scrollDis,\n      HAS_TABLE_BOTTOM_SHADOW,\n    );\n\n    // 兼容屏幕缩放是 sticky多列的样式问题\n    this.table.updateStickyColumnStyles();\n  }\n\n  mutateHorizontalScroll() {\n    const scrollDis =\n      this.containerEl.scrollWidth - this.containerEl.offsetWidth;\n\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollDis > 0,\n      shadowBem.modifier('has-scroll'),\n    );\n\n    const scrollLeft = this.containerEl.scrollLeft;\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollLeft > 0,\n      shadowBem.modifier('scrolling'),\n    );\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollLeft < scrollDis,\n      scrollBeforeEndClass,\n    );\n  }\n\n  placeClassList(\n    classList: DOMTokenList,\n    condition: boolean,\n    className: string,\n  ) {\n    classList[condition ? 'add' : 'remove'](className);\n  }\n}\n"]}
|