@alauda/ui 7.3.3-beta.27 → 7.3.3-beta.29

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/index.d.ts CHANGED
@@ -20,7 +20,6 @@ export * from './message';
20
20
  export * from './notification';
21
21
  export * from './paginator';
22
22
  export * from './radio';
23
- export * from './resizable';
24
23
  export * from './scrolling';
25
24
  export * from './select';
26
25
  export * from './sort';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alauda/ui",
3
- "version": "7.3.3-beta.27",
3
+ "version": "7.3.3-beta.29",
4
4
  "description": "Angular UI components by Alauda Frontend Team.",
5
5
  "repository": "git+https://github.com/alauda/alauda-ui.git",
6
6
  "author": "Alauda Frontend",
@@ -6,8 +6,7 @@ export declare class TableColumnResizableDirective implements AfterViewInit {
6
6
  private readonly renderer2;
7
7
  private readonly tableColumnDefDirective;
8
8
  private readonly tableComponent;
9
- private readonly tableScrollWrapperDirective;
10
- private readonly selfElement;
9
+ private readonly columnElement;
11
10
  private readonly containerElement;
12
11
  private styleElement;
13
12
  private hostAttr;
@@ -23,6 +22,7 @@ export declare class TableColumnResizableDirective implements AfterViewInit {
23
22
  private getWidthInRange;
24
23
  private getResizeRange;
25
24
  private getActualWidth;
25
+ private isStickyLeftBorderColumn;
26
26
  private renderWidthStyles;
27
27
  static ɵfac: i0.ɵɵFactoryDeclaration<TableColumnResizableDirective, never>;
28
28
  static ɵdir: i0.ɵɵDirectiveDeclaration<TableColumnResizableDirective, "[auiTableColumnResizable]", never, { "minWidth": { "alias": "minWidth"; "required": false; }; "maxWidth": { "alias": "maxWidth"; "required": false; }; }, {}, never, never, true, never>;
@@ -1,2 +0,0 @@
1
- export { ResizableDirective } from './resizable.directive';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVzaXphYmxlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgUmVzaXphYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9yZXNpemFibGUuZGlyZWN0aXZlJztcbiJdfQ==
@@ -1,147 +0,0 @@
1
- import { Directive, ElementRef, EventEmitter, inject, Input, Output, Renderer2, } from '@angular/core';
2
- import { fromEvent, map, Subject, switchMap, takeUntil, tap } from 'rxjs';
3
- import { handlePixel } from '../utils';
4
- import * as i0 from "@angular/core";
5
- export class ContainerForResizableDirective {
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 });
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 });
9
- }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ContainerForResizableDirective, decorators: [{
11
- type: Directive,
12
- args: [{
13
- selector: '[auiContainerForResizable]',
14
- host: {
15
- class: 'aui-container-for-resizable',
16
- },
17
- standalone: true,
18
- }]
19
- }] });
20
- export class ResizableDirective {
21
- minWidth;
22
- maxWidth;
23
- manualAdjustment = false;
24
- resizeStart = new EventEmitter();
25
- resizing = new EventEmitter();
26
- resizeEnd = new EventEmitter();
27
- elementRef = inject(ElementRef);
28
- renderer2 = inject(Renderer2);
29
- containerDirective = inject(ContainerForResizableDirective, {
30
- optional: true,
31
- });
32
- BAR_WIDTH = 2;
33
- element = this.elementRef.nativeElement;
34
- containerElement = this.containerDirective?.el.nativeElement || this.element;
35
- destroy$$ = new Subject();
36
- ngAfterViewInit() {
37
- const resizeHandle = this.createResizeHandle();
38
- fromEvent(resizeHandle, 'click')
39
- .pipe(takeUntil(this.destroy$$))
40
- .subscribe(event => event.stopPropagation());
41
- this.bindResizable(resizeHandle);
42
- }
43
- ngOnDestroy() {
44
- this.destroy$$.next();
45
- this.destroy$$.complete();
46
- }
47
- bindResizable(resizeHandle) {
48
- fromEvent(resizeHandle, 'mousedown')
49
- .pipe(map(event => {
50
- event.preventDefault();
51
- event.stopPropagation();
52
- const initialWidth = this.element.clientWidth;
53
- this.resizeStart.emit(initialWidth);
54
- this.renderer2.setStyle(resizeHandle, 'visibility', 'hidden');
55
- return {
56
- resizeBar: this.createResizeBar(),
57
- resizeOverlay: this.createResizeOverlay(),
58
- initialWidth,
59
- mouseDownScreenX: event.clientX,
60
- };
61
- }), switchMap(({ resizeBar, resizeOverlay, initialWidth, mouseDownScreenX }) => fromEvent(document, 'mousemove').pipe(map(event => {
62
- const movementX = event.clientX - mouseDownScreenX;
63
- const newWidth = initialWidth + movementX;
64
- const width = this.getFinalWidth(newWidth);
65
- this.renderer2.setStyle(resizeBar, 'left', handlePixel(width + this.getOffset() - this.BAR_WIDTH));
66
- return width;
67
- }), takeUntil(fromEvent(document, 'mouseup').pipe(tap(event => {
68
- this.renderer2.removeStyle(resizeHandle, 'visibility');
69
- this.renderer2.removeChild(this.containerElement, resizeOverlay);
70
- this.renderer2.removeChild(this.containerElement, resizeBar);
71
- const movementX = event.clientX - mouseDownScreenX;
72
- const newWidth = initialWidth + movementX;
73
- const width = this.getFinalWidth(newWidth);
74
- if (!this.manualAdjustment) {
75
- this.renderer2.setStyle(this.element, 'width', handlePixel(width));
76
- }
77
- this.resizeEnd.emit(width);
78
- }))))), takeUntil(this.destroy$$))
79
- .subscribe(width => {
80
- this.resizing.emit(width);
81
- });
82
- }
83
- createResizeHandle() {
84
- const resizeHandle = this.renderer2.createElement('div');
85
- this.renderer2.addClass(resizeHandle, 'resize-handle');
86
- this.renderer2.appendChild(this.element, resizeHandle);
87
- return resizeHandle;
88
- }
89
- createResizeOverlay() {
90
- const resizeOverlay = this.renderer2.createElement('div');
91
- this.renderer2.addClass(resizeOverlay, 'resize-overlay');
92
- this.renderer2.appendChild(this.containerElement, resizeOverlay);
93
- return resizeOverlay;
94
- }
95
- createResizeBar() {
96
- const resizeBar = this.renderer2.createElement('div');
97
- this.renderer2.addClass(resizeBar, 'resize-bar');
98
- this.renderer2.setStyle(resizeBar, 'left', this.element.clientWidth + this.getOffset() - this.BAR_WIDTH + 'px');
99
- this.renderer2.appendChild(this.containerElement, resizeBar);
100
- return resizeBar;
101
- }
102
- getFinalWidth(newWidth) {
103
- const _max = this.containerElement.clientWidth + this.getOffset();
104
- const minWidth = this.handleWidth(this.minWidth || this.getOffset());
105
- const maxWidth = this.handleWidth(this.maxWidth || _max);
106
- return Math.max(Math.min(maxWidth, newWidth), minWidth);
107
- }
108
- getOffset() {
109
- return (this.element.getBoundingClientRect().left -
110
- this.containerElement.getBoundingClientRect().left);
111
- }
112
- handleWidth(width) {
113
- if (typeof width === 'number') {
114
- return width;
115
- }
116
- if (!width) {
117
- return;
118
- }
119
- if (width.endsWith('%')) {
120
- const tableWidth = this.containerElement.clientWidth;
121
- return (tableWidth * Number.parseFloat(width)) / 100;
122
- }
123
- return Number.parseFloat(width.replace(/\D+/, ''));
124
- }
125
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ResizableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
126
- 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" }, ngImport: i0 });
127
- }
128
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ResizableDirective, decorators: [{
129
- type: Directive,
130
- args: [{
131
- selector: '[auiResizable]',
132
- standalone: true,
133
- }]
134
- }], propDecorators: { minWidth: [{
135
- type: Input
136
- }], maxWidth: [{
137
- type: Input
138
- }], manualAdjustment: [{
139
- type: Input
140
- }], resizeStart: [{
141
- type: Output
142
- }], resizing: [{
143
- type: Output
144
- }], resizeEnd: [{
145
- type: Output
146
- }] } });
147
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable.directive.js","sourceRoot":"","sources":["../../../src/resizable/resizable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Input,\n  OnDestroy,\n  Output,\n  Renderer2,\n} from '@angular/core';\nimport { fromEvent, map, Subject, switchMap, takeUntil, tap } from 'rxjs';\n\nimport { handlePixel } from '../utils';\n\n@Directive({\n  selector: '[auiContainerForResizable]',\n  host: {\n    class: 'aui-container-for-resizable',\n  },\n  standalone: true,\n})\nexport class ContainerForResizableDirective {\n  el = inject<ElementRef<HTMLElement>>(ElementRef);\n}\n\n/**\n * 使用此指令需要引入 resizable.scss\n *\n * @example `@import 'node_modules/@alauda/ui/resizable/resizable';`\n */\n@Directive({\n  selector: '[auiResizable]',\n  standalone: true,\n})\nexport class ResizableDirective implements AfterViewInit, OnDestroy {\n  @Input()\n  minWidth: string | number;\n\n  @Input()\n  maxWidth: string | number;\n\n  @Input()\n  manualAdjustment = false;\n\n  @Output()\n  resizeStart = new EventEmitter<number>();\n\n  @Output()\n  resizing = new EventEmitter<number>();\n\n  @Output()\n  resizeEnd = new EventEmitter<number>();\n\n  private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  renderer2 = inject(Renderer2);\n  private readonly containerDirective = inject(ContainerForResizableDirective, {\n    optional: true,\n  });\n\n  private readonly BAR_WIDTH = 2;\n\n  private readonly element = this.elementRef.nativeElement;\n  containerElement = this.containerDirective?.el.nativeElement || this.element;\n\n  destroy$$ = new Subject<void>();\n\n  ngAfterViewInit() {\n    const resizeHandle = this.createResizeHandle();\n\n    fromEvent<Event>(resizeHandle, 'click')\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(event => event.stopPropagation());\n\n    this.bindResizable(resizeHandle);\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  private bindResizable(resizeHandle: HTMLElement) {\n    fromEvent<MouseEvent>(resizeHandle, 'mousedown')\n      .pipe(\n        map(event => {\n          event.preventDefault();\n          event.stopPropagation();\n\n          const initialWidth = this.element.clientWidth;\n          this.resizeStart.emit(initialWidth);\n\n          // 避免两条线不对齐\n          this.renderer2.setStyle(resizeHandle, 'visibility', 'hidden');\n\n          return {\n            resizeBar: this.createResizeBar(),\n            resizeOverlay: this.createResizeOverlay(),\n            initialWidth,\n            mouseDownScreenX: event.clientX,\n          };\n        }),\n        switchMap(\n          ({ resizeBar, resizeOverlay, initialWidth, mouseDownScreenX }) =>\n            fromEvent<MouseEvent>(document, 'mousemove').pipe(\n              map(event => {\n                const movementX = event.clientX - mouseDownScreenX;\n                const newWidth = initialWidth + movementX;\n                const width = this.getFinalWidth(newWidth);\n                this.renderer2.setStyle(\n                  resizeBar,\n                  'left',\n                  handlePixel(width + this.getOffset() - this.BAR_WIDTH),\n                );\n                return width;\n              }),\n              takeUntil(\n                fromEvent<MouseEvent>(document, 'mouseup').pipe(\n                  tap(event => {\n                    this.renderer2.removeStyle(resizeHandle, 'visibility');\n\n                    this.renderer2.removeChild(\n                      this.containerElement,\n                      resizeOverlay,\n                    );\n                    this.renderer2.removeChild(\n                      this.containerElement,\n                      resizeBar,\n                    );\n\n                    const movementX = event.clientX - mouseDownScreenX;\n                    const newWidth = initialWidth + movementX;\n                    const width = this.getFinalWidth(newWidth);\n                    if (!this.manualAdjustment) {\n                      this.renderer2.setStyle(\n                        this.element,\n                        'width',\n                        handlePixel(width),\n                      );\n                    }\n                    this.resizeEnd.emit(width);\n                  }),\n                ),\n              ),\n            ),\n        ),\n        takeUntil(this.destroy$$),\n      )\n      .subscribe(width => {\n        this.resizing.emit(width);\n      });\n  }\n\n  private createResizeHandle() {\n    const resizeHandle = this.renderer2.createElement('div');\n    this.renderer2.addClass(resizeHandle, 'resize-handle');\n    this.renderer2.appendChild(this.element, resizeHandle);\n    return resizeHandle;\n  }\n\n  private createResizeOverlay() {\n    const resizeOverlay = this.renderer2.createElement('div');\n    this.renderer2.addClass(resizeOverlay, 'resize-overlay');\n    this.renderer2.appendChild(this.containerElement, resizeOverlay);\n    return resizeOverlay;\n  }\n\n  private createResizeBar() {\n    const resizeBar = this.renderer2.createElement('div');\n    this.renderer2.addClass(resizeBar, 'resize-bar');\n    this.renderer2.setStyle(\n      resizeBar,\n      'left',\n      this.element.clientWidth + this.getOffset() - this.BAR_WIDTH + 'px',\n    );\n    this.renderer2.appendChild(this.containerElement, resizeBar);\n    return resizeBar;\n  }\n\n  private getFinalWidth(newWidth: number): number {\n    // 不能超出边界\n    const _max = this.containerElement.clientWidth + this.getOffset();\n    const minWidth = this.handleWidth(this.minWidth || this.getOffset());\n    const maxWidth = this.handleWidth(this.maxWidth || _max);\n    return Math.max(Math.min(maxWidth, newWidth), minWidth);\n  }\n\n  private getOffset() {\n    return (\n      this.element.getBoundingClientRect().left -\n      this.containerElement.getBoundingClientRect().left\n    );\n  }\n\n  private handleWidth(width: string | number) {\n    if (typeof width === 'number') {\n      return width;\n    }\n    if (!width) {\n      return;\n    }\n    if (width.endsWith('%')) {\n      const tableWidth = this.containerElement.clientWidth;\n      return (tableWidth * Number.parseFloat(width)) / 100;\n    }\n    return Number.parseFloat(width.replace(/\\D+/, ''));\n  }\n}\n"]}
@@ -1 +0,0 @@
1
- export { ResizableDirective } from './resizable.directive';
@@ -1,34 +0,0 @@
1
- import { AfterViewInit, ElementRef, EventEmitter, OnDestroy, Renderer2 } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import * as i0 from "@angular/core";
4
- export declare class ContainerForResizableDirective {
5
- el: ElementRef<HTMLElement>;
6
- static ɵfac: i0.ɵɵFactoryDeclaration<ContainerForResizableDirective, never>;
7
- static ɵdir: i0.ɵɵDirectiveDeclaration<ContainerForResizableDirective, "[auiContainerForResizable]", never, {}, {}, never, never, true, never>;
8
- }
9
- export declare class ResizableDirective implements AfterViewInit, OnDestroy {
10
- minWidth: string | number;
11
- maxWidth: string | number;
12
- manualAdjustment: boolean;
13
- resizeStart: EventEmitter<number>;
14
- resizing: EventEmitter<number>;
15
- resizeEnd: EventEmitter<number>;
16
- private readonly elementRef;
17
- renderer2: Renderer2;
18
- private readonly containerDirective;
19
- private readonly BAR_WIDTH;
20
- private readonly element;
21
- containerElement: HTMLElement;
22
- destroy$$: Subject<void>;
23
- ngAfterViewInit(): void;
24
- ngOnDestroy(): void;
25
- private bindResizable;
26
- private createResizeHandle;
27
- private createResizeOverlay;
28
- private createResizeBar;
29
- private getFinalWidth;
30
- private getOffset;
31
- private handleWidth;
32
- static ɵfac: i0.ɵɵFactoryDeclaration<ResizableDirective, never>;
33
- static ɵdir: i0.ɵɵDirectiveDeclaration<ResizableDirective, "[auiResizable]", never, { "minWidth": { "alias": "minWidth"; "required": false; }; "maxWidth": { "alias": "maxWidth"; "required": false; }; "manualAdjustment": { "alias": "manualAdjustment"; "required": false; }; }, { "resizeStart": "resizeStart"; "resizing": "resizing"; "resizeEnd": "resizeEnd"; }, never, never, true, never>;
34
- }
@@ -1,44 +0,0 @@
1
- @import '../theme/var';
2
-
3
- [auiresizable],
4
- .aui-container-for-resizable {
5
- position: relative;
6
- }
7
-
8
- [auiresizable]:hover {
9
- .resize-handle {
10
- visibility: visible;
11
- }
12
- }
13
-
14
- .resize-handle {
15
- display: inline-block;
16
- position: absolute;
17
- right: 0;
18
- top: 0;
19
- width: 6px;
20
- cursor: col-resize;
21
- height: 100%;
22
- z-index: 9999;
23
- border-right: 2px solid use-rgb(p-2);
24
- visibility: hidden;
25
- }
26
-
27
- .resize-overlay {
28
- position: absolute;
29
- display: block;
30
- inset: 0;
31
- z-index: 1000;
32
- cursor: col-resize;
33
- }
34
-
35
- .resize-bar {
36
- top: 0;
37
- bottom: 0;
38
- position: absolute;
39
- cursor: col-resize;
40
- background: use-rgb(p-2);
41
- width: 2px;
42
- z-index: 9999;
43
- display: block;
44
- }